I am coding an SNMP Agent. I need to send values that have a decimal point to an SNMP Manager.
I have a couple options:
If I truncate the number I lose a lot of information that I need.
If I multiply by a constant, then the manager will display strange units that the end-user would rather not see. (grams instead of kilograms).
So, I'm doing option 3. What do I do?
as an octect-stream in IEEE-754 format (8 Octets). See: http://en.wikipedia.org/wiki/IEEE_754-2008
The usual, standard way this is done is to define a TEXTUAL-CONVENTION with an integral type (such as Integer32 or Unsigned32) and a DISPLAY-HINT with "d-N" format, where N is the number of places the decimal should be shifted for display purposes.
Thus, for a value with a single decimal place ranging from (say) 0.0 to 10.0, you would use a TEXTUAL-CONVENTION of type Unsigned32(0..100) and a DISPLAY-HINT of "d-1". On the wire, the value ranges from 0 to 100, but the manager (by way of the MIB module being loaded) will shift the decimal one place to display a range of 0.0 to 10.0.
Other ways of doing it are not conducive to interoperability.
I rather send that data via OCTET STRING/DisplayString. Numbers such as "1.5" can be sent easily.
However, if the data need to be accurate, you may use Kyle's suggestion by sending bytes (octets). Noticeably that is also sent via OCTET STRING as it is a perfect byte container.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With