Data formats, Floating point data format (float) – Basler Electric DGC-2020HD Modbus Protocol User Manual

Page 14

Advertising
background image

8

9469300991 Rev A

General Information

DGC-2020HD Modbus

™ Protocol

CRC Hi error check
CRC Lo error check

Response

The response message echoes the Query message after the register has been altered.

Data Formats

DGC-2020HD systems support the following data types:

Data types mapped to 2 registers

o Signed Integer 32 (Int32)

o Unsigned Integer 32 (Uint32)

o Floating Point (Float)

o IP Address (IP Address)

o Strings maximum 4 characters long (String)

Data types mapped to 1 register

o Unsigned Integer 16 (Uint16)

o Unsigned Integer 8 (Uint8)

o Strings maximum 2 characters long (String)

Data types mapped to more than 2 registers

o Strings longer than 4 characters (String)

Floating Point Data Format (Float)

The Modbus floating point data format uses two consecutive holding registers to represent a data value.
The first register contains the low-order 16 bits of the following 32-bit format:

MSB is the sign bit for the floating-point value (0 = positive).

The next 8 bits are the exponent biased by 127 decimal.

The 23 LSBs comprise the normalized mantissa. The most-significant bit of the mantissa is
always assumed to be 1 and is not explicitly stored, yielding an effective precision of 24 bits.

The value of the floating-point number is obtained by multiplying the binary mantissa times two raised to
the power of the unbiased exponent. The assumed bit of the binary mantissa has the value of 1.0, with
the remaining 23 bits providing a fractional value. Table 4 shows the floating-point format.

Table 4. Floating Point Format

Sign

Exponent + 127

Mantissa

1 Bit

8 Bits

23 Bits

The floating-point format allows for values ranging from approximately 8.43X10^

-37

to 3.38X10^

38

. A

floating-point value of all zeroes is the value zero. A floating-point value of all ones (not a number)
signifies a value currently not applicable or disabled.

Example: The value 95,800 represented in floating-point format is hexadecimal 47BB1C00. This number
will read from two consecutive holding registers as follows:

Holding Register

Value

K (Hi Byte)

hex 1C

K (Lo Byte)

hex 00

K+1 (Hi Byte)

hex 47

K+1 (Lo Byte)

hex BB

The same byte alignments are required to write.

Advertising