upm
0.5.1
Sensor/Actuator repository for libmraa (v0.9.1)
|
UPM API for the Veris HWXPXX Hardware Protocol Humidity and Temperature Sensor. More...
This module implements support for the Veris HWXPHTX Hardware Protocol Humidity and Temperature Sensor family. It uses MODBUS over an RS485 interface. You must have libmodbus v3.1.2 (or greater) installed to compile and use this driver.
This module was developed using libmodbus 3.1.2, and the HWXPHTX. This sensor supports humidity, and optionally, temperature, slider switch, and override switch reporting. The HWXPHTX used to develop this driver did not include the optional slider or override switches, however support for them is provided.
It was developed using an RS232->RS485 inteface. You cannot use the built in MCU TTL UART pins for accessing this device – you must use a full serial RS232->RS485 interface connected via USB.
Public Member Functions | |
HWXPXX (std::string device, int address, int baud=19200, int bits=8, char parity='N', int stopBits=2) | |
~HWXPXX () | |
void | update () |
float | getTemperature (bool fahrenheit=false) |
float | getHumidity () |
int | getSlider () |
bool | getOverrideSwitchStatus () |
void | clearOverrideSwitch () |
int | getTemperatureOffset () |
int | getHumidityOffset () |
void | setTemperatureOffset (int offset) |
void | setHumidityOffset (int offset) |
void | setTemperatureScale (bool fahrenheit) |
std::string | getSlaveID () |
void | setSlaveAddress (int addr) |
void | setDebug (bool enable) |
Protected Attributes | |
modbus_t * | m_mbContext |
bool | m_isCelcius |
HWXPXX | ( | std::string | device, |
int | address, | ||
int | baud = 19200 , |
||
int | bits = 8 , |
||
char | parity = 'N' , |
||
int | stopBits = 2 |
||
) |
HWXPXX constructor
device | Path to the serial device |
address | The MODBUS slave address |
baud | The baudrate of the device. Default: 19200 |
bits | The number of bits per byte. Default: 8 |
parity | The parity of the connection, 'N' for None, 'E' for Even, 'O' for Odd. Default: 'N' |
stopBits | The number of stop bits. Default: 2 |
void update | ( | void | ) |
Read current values from the sensor and update internal stored values. This method must be called prior to querying any values, such as temperature, humidity, override switch status, or slider switch status.
float getTemperature | ( | bool | fahrenheit = false | ) |
Get the current temperature. update() must have been called prior to calling this method. If this option was not installed, this method will always return 0C/0F, depending on the scale the device is operating in natively.
fahrenheit | true to return the temperature in degrees fahrenheit, false to return the temperature in degrees celcius. The default is false (degrees Celcius). |
float getHumidity | ( | void | ) |
Get the current relative humidity. update() must have been called prior to calling this method.
int getSlider | ( | ) |
Get the current slider switch position. update() must have been called prior to calling this method. This returns a value between 0-100 corresponding to the position of the slider switch. If this option is not installed, this method will always return 0.
bool getOverrideSwitchStatus | ( | ) |
Get the current override switch status. update() must have been called prior to calling this method. This returns true if the override switch was pressed. Use clearOverrideSwitch() to reset this value to false. If this option is not installed, then this method will always return false. It is not possible to programatically set this value to true - that can only be done by physically pressing the override switch.
void clearOverrideSwitch | ( | ) |
Clear the override switch status (set it to false). If this option is not installed, then this method will have no effect (the overide switch status will always be false).
int getTemperatureOffset | ( | ) |
Return the current temperature offset stored on the device. This is a value between -50 and +50, specified in tenths of a degree in whatever scale (Celcius or Fahrenheit) is in use. This offset is applied to the returned temperature reading by the device.
int getHumidityOffset | ( | ) |
Return the current humidity offset stored on the device. This is a value between -100 and +100, specified in tenths of a percent. This offset is applied to the returned humidity reading by the device.
void setTemperatureOffset | ( | int | offset | ) |
Set the stored temperature offset on the device. This is a value between -50 and +50, specified in tenths of a degree in what ever scale (Celcius or Fahrenheit) is in use. This offset is applied to the returned temperature reading by the device.
offset | Offset in tenths of a degree with a range of -50 to +50 |
void setHumidityOffset | ( | int | offset | ) |
Set the stored humidity offset on the device. This is a value between -100 and +100, specified in tenths of a percent. This offset is applied to the returned humidity reading by the device.
offset | Offset in tenths of a percent with a range of -100 to +100 |
void setTemperatureScale | ( | bool | fahrenheit | ) |
Set the temperature scale used by the device. This driver detects this setting automatically and adjusts itself accordingly, so this is generally never needed. It is used to set the native reporting scale of the temperature either in degrees Celcius or Fahrenheit. Its setting will not affect the operation of getTemperature().
fahrenheit | true to set Fahrenheit, false to set Celcius |
string getSlaveID | ( | ) |
Return a string corresponding the the device's MODBUS slave ID. This includes information such as the manufacturer, device model number and serial number.
void setSlaveAddress | ( | int | addr | ) |
void setDebug | ( | bool | enable | ) |
Enable or disable debugging output. This primarily enables and disables libmodbus debugging output.
enable | true to enable debugging, false otherwise |