Looking to get more accurate results from Ping sensor readings
Don M
Posts: 1,653
in Propeller 1
I guessing there is some rounding off that is happening with the standard Ping object code. For example lets say I have something in front of the Ping and it reports back 11 inches. However looking at the ticks I see 883. Taking that times 1000 and dividing by the correction factor of 73746 I get 11.9735... which is closer to 12 than 11. How do I get that better precision being able to round up / down rather than rounding off? Any examples?
Thanks.
Thanks.
Comments
This changes the resolution to 1/10". Of course you'll need to verify that you max distance (ticks * 10_000) will fit into POSX. You might also look into the ** operator instead of using the simple division.
(833 * 1000) / 73746 = 11.295
You are correct but reread the top post... it's 883 not 833
How about multiply by 1000 and then add 500 ?
Then when you divide and truncate to integer inches you get a correct rounding to the nearest inch.
But I'm with JonnyMac, any reason to not just work at a higher resolution?
inches10 := ping.ticks(SONAR) * 10_000 / ping#TO_IN
Ok I messed around with this a bit. So the result is 119. If I divide it by 10 I still end up with 11 so I don't understand the premise of this exercise.
If I add 5 and then divide by 10 I get 12 which is what I want so using your suggestion of multiplying by 1000, adding 500 then dividing by 1000 would also work.
I was also looking at F32 object. I tried using the FRound(a) method. I'm not sure really how it should work. I tried FRound(883000 / 73746) thinking it would do the division and round it appropriately but it returns 0. If I use FRound(11.97) it returns 12. If I try FRound(11.46) it returns 11. So that works.
So then I tried using FDiv(883000, 73746), assinging it to a long variable then using FRound on that variable but that didn't work either. In fact the FDiv(883000, 73746) returned a number 1094608486 which makes no sense to me.
I've never used the F32 object before so I need much enlightenment as to its use. Should I use it or just do the multply by 1000, add 500 then divide? I'd like to understand what Jon was trying to suggest.
Oh, for Pete's sake -- did you never learn how to round up numbers in school? You stated you wanted more accuracy, yet didn't state the resolution of that accuracy. If you're just going for inches, here's the trick for rounding up.
If you're wanting accuracy, why would you want to round up? Just live with units that are in 1/10 inch. If you going to output to a display, output the value divided by 10, a period, then the value // 10 -- boom, Bob is your uncle.
I was making it way more complicated than needed. Thanks to all.
Values passed to the FRound, FDiv, etc etc must be floating point values not integers. FRound returns a 32bit integer; FDiv returns a 32 bit float. A 32 bit float consists of a sign, exponent and fraction (mantissa) [see https://en.wikipedia.org/wiki/Single-precision_floating-point_format].
FRound(FDiv(8.83e+5,7.3746e+4)) should produce the expected result
FRound(FDiv(883000.0, 73746.0)) should also produce the expected result
https://en.wikipedia.org/wiki/Single-precision_floating-point_format
"resolution" is the term for the smallest change your measurement can detect. For example, 1 inch, 0.1inch, 1mm or 1nm.
"accuracy" is the term for the actual correctness of the measurement. Usually expressed as plus or minus some percentage of the full scale range or plus or minus some absolute amount. For example +/-0.1 inches.
One can have a very high resolution with a very poor accuracy.
For example I recently saw a demo of a sensor that could detect movements of huge steel I-beams down to a couple of nano-meters. It could not tell anything about where the I-beam actually was! Huge resolving power, no accuracy.
@Heater- I "resolve" to be more "accurate" in asking questions.... Thanks for your help.
Actually I plan to add that at a later point in the project. I was reading about that a couple days ago.
According to one of the posts I made in the above linked thread, a 30 degree F change in temperature can effect the speed of sound by about 3%.
The speed of sound is 331.3 + 0.6 * Temp in Celsius (yields speed in m/s). Awhile back I wrote a blog post on how to turn the problem on its head and use the pinger as a temperature sensor. Any who, correcting for temperature is really pretty easy and worth doing for sure. I like the MCP9808 for a pure temp sensor.