Source code for emod_controller_python_binding.dinput2relay1temp2_module
# Python binding to a C library for di2pr1t2 module
#
# ctypes module is part of the standard library.
# With ctypes, you need to satisfy any compile time dependency on python, and your binding will work on any python that has ctypes, not just the one it was compiled against.
# It should be noted that ctypes only works with C functions.
# Binding
from ctypes import *
import ctypes
from enum import Enum
try:
c_lib = ctypes.CDLL("/usr/lib/libdi2r1t2_module.so")
except OSError:
c_lib = None
print("C Library not found.")
DI2R1T2MODULE_NUMBER_OF_DI = 2
DI2R1T2MODULE_NUMBER_OF_RELAYS = 1
DI2R1T2MODULE_NUMBER_OF_TEMP = 2
DI2R1T2MODULE_ALL_DIGITAL_INPUT = 0x0003
DI2R1T2MODULE_ALL_TEMP_INPUT = 0x03
DI2R1T2MODULE_INPUT01 = 0x0001
DI2R1T2MODULE_INPUT02 = 0x0002
DI2R1T2MODULE_RELAY1 = 0x01
TEMP_SENSOR1 = 1
TEMP_SENSOR2 = 2
TWO_WIRE_PT100SENSOR = 1
THREE_WIRE_PT100SENSOR = 2
FOUR_WIRE_PT100SENSOR = 3
TWO_WIRE_PT1000SENSOR = 4
THREE_WIRE_PT1000SENSOR = 5
FOUR_WIRE_PT1000SENSOR = 6
PRETRIGGERED_TIME = 0
PULSE_COUNTER = 1
WIDTH_COUNTER = 2
DInput2Relay1Temp2ModuleCallback_Type = ctypes.CFUNCTYPE(
None,
ctypes.POINTER(ctypes.c_uint8),
ctypes.c_uint16,
ctypes.c_uint8,
ctypes.POINTER(ctypes.c_void_p),
)
[docs]class DInput2Relay1Temp2Module:
def __init__(self):
c_lib.DInput2Relay1Temp2Module_create.argtypes = []
c_lib.DInput2Relay1Temp2Module_create.restype = ctypes.POINTER(ctypes.c_void_p)
self.obj = c_lib.DInput2Relay1Temp2Module_create()
[docs] def init(self):
"""
Initialize module. It is important to emphasize that init() method is mandatory to call it and must be called always after instantiating the
module. It can be called several times, each of which the module is initialized again.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_init.argtypes = [ctypes.POINTER(ctypes.c_void_p)]
c_lib.DInput2Relay1Temp2Module_init.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_init(self.obj)
[docs] def init_with_callback(self, callback):
"""
Initialize module. It is important to emphasize that this method is mandatory to call it.
It can be called several times, each of which the module is initialized again.
Args:
callback: function that will be called when a configured event occurs.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_init.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
DInput2Relay1Temp2ModuleCallback_Type,
ctypes.POINTER(ctypes.c_void_p),
]
c_lib.DInput2Relay1Temp2Module_init.restype = ctypes.c_int
ret = c_lib.DInput2Relay1Temp2Module_init(self.obj, callback, self.obj)
return ret
[docs] def init_v(self, callback, variant):
"""
Initialize module. It is important to emphasize that this method is mandatory to call it.
It can be called several times, each of which the module is initialized again.
Args:
callback: function that will be called when a configured event occurs.
variant: identifies the module in case more than one module of the same type are present.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_init_v.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
DInput2Relay1Temp2ModuleCallback_Type,
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint8,
]
c_lib.DInput2Relay1Temp2Module_init_v.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_init_v(
self.obj, callback, self.obj, ctypes.c_uint8(variant)
)
[docs] def get_digital_input_status(self, input_mask):
"""
Gets a digital input status.
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
Returns:
status: returns last received input number status (0:deactivated, 1: activated).
new_data: returns if new data has arrived since the last function call. If status has not been
received yet, NO_NEW_DATA_READ is returned. Parameter is initialized inside the class.
"""
c_lib.DInput2Relay1Temp2Module_getStatus.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.POINTER(ctypes.c_uint8),
ctypes.POINTER(ctypes.c_bool),
]
c_lib.DInput2Relay1Temp2Module_getStatus.restype = ctypes.c_int32
status = ctypes.c_uint8(0)
new_data = ctypes.c_bool(False)
ret = c_lib.DInput2Relay1Temp2Module_getStatus(
self.obj,
ctypes.c_uint16(input_mask),
ctypes.byref(status),
ctypes.byref(new_data),
)
return [status.value, new_data.value]
[docs] def get_digital_input_all_status(self):
"""
Gets all digital input status.
Returns:
status: returns last received input number status (0:deactivated, 1: activated) for each digital input.
new_data: returns if new data has arrived since the last function call. If a digital input status has not been received yet,
NO_NEW_DATA_READ is returned in that input. Parameter is initialized inside the class.
"""
c_lib.DInput2Relay1Temp2Module_getAllStatus.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_uint8),
ctypes.POINTER(ctypes.c_bool),
]
c_lib.DInput2Relay1Temp2Module_getAllStatus.restype = ctypes.c_int32
Uint8Array = ctypes.c_uint8 * DI2R1T2MODULE_NUMBER_OF_DI
status = Uint8Array()
new_data = ctypes.c_bool(False)
ret = c_lib.DInput2Relay1Temp2Module_getAllStatus(
self.obj, status, ctypes.byref(new_data)
)
return [status, new_data.value]
[docs] def set_pulse_filter_time(self, input_mask, ms_time):
"""
Sets the pulse filter time. All pulses with a shorter time will be discarded.
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
ms_time: pulse width (in ms). Value range 0 to 2^32-1. A 0-value means disable pulse. Default value is 0.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_setPulseFilterTime.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_setPulseFilterTime.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_setPulseFilterTime(
self.obj, ctypes.c_uint16(input_mask), ctypes.c_uint32(ms_time)
)
[docs] def set_all_pulse_filter_time(self, ms_time):
"""
Sets the pulse filter time for all inputs.
Args:
ms_time: pulse width (in ms). Value range 0 to 2^32-1. A 0-value means disable pulse. Default value is 0.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_setPulseFilterTime.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_setPulseFilterTime.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_setAllPulseFilterTime(
self.obj, ctypes.c_uint32(ms_time)
)
[docs] def get_pulse_filter_time(self, input_mask):
"""
Gets current pulse filter time.
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
Returns:
It returns pulse width (in ms).
"""
c_lib.DInput2Relay1Temp2Module_getPulseFilterTime.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getPulseFilterTime.restype = ctypes.c_int32
ms_time = ctypes.c_uint32(0)
ret = c_lib.DInput2Relay1Temp2Module_getPulseFilterTime(
self.obj, ctypes.c_uint16(input_mask), ctypes.byref(ms_time)
)
return ms_time.value
[docs] def get_all_pulse_filter_time(self):
"""
Gets current pulse filter time for all inputs.
Returns:
It returns pulse width (in ms) for each input.
"""
c_lib.DInput2Relay1Temp2Module_getAllPulseFilterTime.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getAllPulseFilterTime.restype = ctypes.c_int32
Uint32Array = ctypes.c_uint32 * DI2R1T2MODULE_NUMBER_OF_DI
ms_times = Uint32Array()
ret = c_lib.DInput2Relay1Temp2Module_getAllPulseFilterTime(self.obj, ms_times)
return ms_times
[docs] def get_pulse_count(self, input_mask):
"""
Gets number of pulses occurred in an input after a reset.
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
Returns:
It returns the number of pulses.
"""
c_lib.DInput2Relay1Temp2Module_getPulseCount.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getPulseCount.restype = ctypes.c_int32
count = ctypes.c_uint32(0)
ret = c_lib.DInput2Relay1Temp2Module_getPulseCount(
self.obj, ctypes.c_uint16(input_mask), ctypes.byref(count)
)
return count.value
[docs] def get_all_pulse_count(self):
"""
Gets number of pulses occurred in all inputs.
Returns:
It returns the number of pulses for each digital input.
"""
c_lib.DInput2Relay1Temp2Module_getAllPulseCount.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getAllPulseCount.restype = ctypes.c_int32
Uint32Array = ctypes.c_uint32 * DI2R1T2MODULE_NUMBER_OF_DI
counts = Uint32Array()
ret = c_lib.DInput2Relay1Temp2Module_getAllPulseCount(self.obj, counts)
return counts
[docs] def reset_pulse_count(self, input_mask):
"""
Resets the number of pulses in an input.
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_resetPulseCount.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
]
c_lib.DInput2Relay1Temp2Module_resetPulseCount.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_resetPulseCount(
self.obj, ctypes.c_uint16(input_mask)
)
[docs] def reset_all_pulse_count(self):
"""
Resets the number of pulses in all inputs..
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_resetAllPulseCount.argtypes = [
ctypes.POINTER(ctypes.c_void_p)
]
c_lib.DInput2Relay1Temp2Module_resetAllPulseCount.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_resetAllPulseCount(self.obj)
[docs] def get_pulse_width(self, input_mask):
"""
Gets last pulse width occurred in an input..
Args:
input_mask: digital input number to get the status, as enumerated above in the constants section.
Returns:
It returns pulse width (in ms).
"""
c_lib.DInput2Relay1Temp2Module_getPulseWidth.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getPulseWidth.restype = ctypes.c_int32
width = ctypes.c_uint32(0)
ret = c_lib.DInput2Relay1Temp2Module_getPulseWidth(
self.obj, ctypes.c_uint16(input_mask), ctypes.byref(width)
)
return width.value
[docs] def get_all_pulse_width(self):
"""
Gets last pulse width occurred in all inputs..
Returns:
It returns an an array of counts representing the last pulse width occurred in each input.
"""
c_lib.DInput2Relay1Temp2Module_getAllPulseWidth.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_uint32),
]
c_lib.DInput2Relay1Temp2Module_getAllPulseWidth.restype = ctypes.c_int32
Uint32Array = ctypes.c_uint32 * DI2R1T2MODULE_NUMBER_OF_DI
widths = Uint32Array()
ret = c_lib.DInput2Relay1Temp2Module_getAllPulseWidth(self.obj, widths)
return widths
[docs] def switch_mode_digital_input(self, input_mask, mode):
"""
Usually, this function only needs to be called at the beginning in the configuration stage.
Args:
input_mask: digital input number to be configured.
mode: desired mode for the input; PULSE_COUNTER or PULSE_WIDTH as enumerated above in the constants section.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_switchToModeDI.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.c_int,
]
c_lib.DInput2Relay1Temp2Module_switchToModeDI.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_switchToModeDI(
self.obj, ctypes.c_uint16(input_mask), ctypes.c_int(mode)
)
[docs] def config_pulse_width(self, relay_mask, width_ms):
"""
Configure pulse width of a relay or list of relays. When pulse width is 0 a relay stays in the
current state, and there is no pulse.
Args:
relay_mask: relay or list of relays to configure.
width_ms: pulse width in ms. Value range 0 to 2^32-1. A 0-value means disable pulse. Default value is 0.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configPulseWidth.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configPulseWidth.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_configPulseWidth(
self.obj, ctypes.c_uint16(relay_mask), ctypes.c_uint32(width_ms)
)
[docs] def config_all_pulse_width(self, width_ms):
"""
Configure pulse width of al relays. When pulse width is 0 a relay stays in the current state,
and there is no pulse.
Args:
width_ms: pulse width in ms. Value range 0 to 2^32-1. A 0-value means disable pulse. Default
value is 0.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configAllPulseWidth.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configAllPulseWidth.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_configAllPulseWidth(
self.obj, ctypes.c_uint32(width_ms)
)
[docs] def activate_relay(self, relay_mask):
"""
Activates a relay or set of relays..
Args:
relay_mask: relay or list of relays to activate.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_activate.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
]
c_lib.DInput2Relay1Temp2Module_activate.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_activate(
self.obj, ctypes.c_uint16(relay_mask)
)
[docs] def deactivate_relay(self, relay_mask):
"""
Deactivates a relay or set of relays..
Args:
relay_mask: relay or list of relays to deactivate.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_deactivate.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
]
c_lib.DInput2Relay1Temp2Module_deactivate.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_deactivate(
self.obj, ctypes.c_uint16(relay_mask)
)
[docs] def activate_all_relays(self):
"""
Activates all module relays.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_activateAll.argtypes = [
ctypes.POINTER(ctypes.c_void_p)
]
c_lib.DInput2Relay1Temp2Module_activateAll.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_activateAll(self.obj)
[docs] def deactivate_all_relays(self):
"""
Deactivates all module relays.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_deactivateAll.argtypes = [
ctypes.POINTER(ctypes.c_void_p)
]
c_lib.DInput2Relay1Temp2Module_deactivateAll.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_deactivateAll(self.obj)
[docs] def get_relay_status(self, relay_mask):
"""
Gets a relay status.
Args:
relay_mask: relay mask number to get the status.
Returns:
Every bit represents a relay order status. Status is 1 when is activate and 0 when deactivate.
"""
c_lib.DInput2Relay1Temp2Module_getRelayStatus.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint16,
ctypes.POINTER(ctypes.c_uint8),
]
c_lib.DInput2Relay1Temp2Module_getRelayStatus.restype = ctypes.c_int32
status = ctypes.c_uint8(0)
ret = c_lib.DInput2Relay1Temp2Module_getRelayStatus(
self.obj, ctypes.c_uint16(relay_mask), ctypes.byref(status)
)
return status.value
[docs] def get_all_relay_status(self):
"""
Gets all relay status..
Returns:
Every bit represents a relay order status. Status is 1 when is activate and 0 when deactivate.
"""
c_lib.DInput2Relay1Temp2Module_getAllRelayStatus.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_uint8),
]
c_lib.DInput2Relay1Temp2Module_getAllRelayStatus.restype = ctypes.c_int32
status = ctypes.c_uint8(0)
ret = c_lib.DInput2Relay1Temp2Module_getAllRelayStatus(
self.obj, ctypes.byref(status)
)
return status.value
[docs] def configure_temp_sensor(self, id, config):
"""
Select configuration on a temperature sensor.
Args:
id: temperature sensor number to set the configuration, as enumerated above in the constants
section.
config: type of temperature sensor as enumerated above in the constants section.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configTempSensor.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_int,
ctypes.c_int,
]
c_lib.DInput2Relay1Temp2Module_configTempSensor.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_configTempSensor(
self.obj, ctypes.c_int(id), ctypes.c_int(config)
)
[docs] def config_all_temp_sensor(self, config):
"""
Select a common configuration on all temperature sensors.
Args:
config: type of temperature sensor as enumerated above in the constants section.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configAllTempSensor.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_int,
]
c_lib.DInput2Relay1Temp2Module_configAllTempSensor.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_configAllTempSensor(
self.obj, ctypes.c_int(config)
)
[docs] def get_temp_sensor_config(self, id):
"""
Gets configuration from a specified temperature sensor.
Args:
id: temperature sensor number to get the status, as enumerated above in the constants section.
Returns:
It returns the type of temperature sensor as enumerated above in the constants section.
"""
c_lib.DInput2Relay1Temp2Module_getTempSensorConfig.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_int,
ctypes.POINTER(ctypes.c_int),
]
c_lib.DInput2Relay1Temp2Module_getTempSensorConfig.restype = ctypes.c_int32
config = ctypes.c_int(0)
ret = c_lib.DInput2Relay1Temp2Module_getTempSensorConfig(
self.obj, ctypes.c_int(id), ctypes.byref(config)
)
return config.value
[docs] def get_temp_sensor(self, id):
"""
Gets temperature (in hundredths of a degree) from a specified sensor.
Args:
id: temperature sensor number to get the status, as enumerated above in the constants section.
Returns:
It returns temperature in hundredths of a celsius degree. It is kUnplugged (as enumerated in the constants above) if the sensor is unplugged..
"""
c_lib.DInput2Relay1Temp2Module_getTempSensor.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_int,
ctypes.POINTER(ctypes.c_int16),
]
c_lib.DInput2Relay1Temp2Module_getTempSensor.restype = ctypes.c_int32
value = ctypes.c_int16(0)
ret = c_lib.DInput2Relay1Temp2Module_getTempSensor(
self.obj, ctypes.c_int(id), ctypes.byref(value)
)
return value.value
[docs] def get_all_temp_sensor(self):
"""
Gets temperature (in hundredths of a degree) from all sensors.
Returns:
It returns temperature in hundredths of a celsius degree. It is kUnplugged (as enumerated in the constants above) if the sensor is unplugged..
"""
c_lib.DInput2Relay1Temp2Module_getAllTempSensor.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.POINTER(ctypes.c_int16),
]
c_lib.DInput2Relay1Temp2Module_getAllTempSensor.restype = ctypes.c_int32
int16Array = ctypes.c_int16 * DI2R1T2MODULE_NUMBER_OF_TEMP
values = int16Array()
ret = c_lib.DInput2Relay1Temp2Module_getAllTempSensor(
self.obj, values
)
return values
[docs] def config_event_at_time_interval_dinput(self, time_interval):
"""
Configures module for calling init callback_func at specified period.
Args:
time_interval: period in milliseconds. Minimum value is 500ms.
event_mask: bit mask representing inputs that must trigger the event.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventAtTimeIntervalDI.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configEventAtTimeIntervalDI.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventAtTimeIntervalDI(
self.obj, ctypes.c_uint32(time_interval)
)
[docs] def config_event_on_new_data_dinput(self):
"""
Configures module for calling init callback_func when new data on input occurs.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventOnNewDataDI.argtypes = [
ctypes.POINTER(ctypes.c_void_p)
]
c_lib.DInput2Relay1Temp2Module_configEventOnNewDataDI.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_configEventOnNewDataDI(self.obj)
[docs] def config_event_on_value_change_dinput(self, threshold, event_mask):
"""
Configures module for calling init callback_func when input changes its value by a specified amount.
Args:
threshold: amount of samples that triggers the event.
event_mask: bit mask representing inputs that must trigger the event.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
ctypes.c_uint16,
]
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI(
self.obj, ctypes.c_uint32(threshold), ctypes.c_uint16(event_mask)
)
[docs] def config_event_at_time_interval_temp(self, time_interval, event_mask):
"""
Configures module for calling init callback_func at specified period.
Args:
time_interval: period in milliseconds. Minimum value is 500ms.
event_mask: bit mask representing inputs that must trigger the event.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeDI(
self.obj, ctypes.c_uint32(time_interval), ctypes.c_uint32(event_mask)
)
[docs] def config_event_on_value_change_temp(self, threshold, event_mask):
"""
Configures module for calling init callback_func when input changes its value by a specified amount.
Args:
threshold: amount of samples that triggers the event.
event_mask: bit mask representing inputs that must trigger the event.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeTemp.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeTemp.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventOnValueChangeTemp(
self.obj, ctypes.c_uint32(threshold), ctypes.c_uint32(event_mask)
)
[docs] def configure_event_within_range_temp(self, low_limit, high_limit, event_mask):
"""
Configures module for calling init callback_func when sensor enters the specified range..
Args:
low_limit: low limit of the range in samples.
high_limit: high limit of the range in samples.
event_mask: bit mask representing inputs that must trigger the event. Default value is
kTempSensorAll.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventWithinRangeTemp.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
ctypes.c_uint32,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configEventWithinRangeTemp.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventWithinRangeTemp(
self.obj,
ctypes.c_uint32(low_limit),
ctypes.c_uint32(high_limit),
ctypes.c_uint32(event_mask),
)
[docs] def configure_event_out_of_range_temp(self, low_limit, high_limit, event_mask):
"""
Configures module for calling init callback_func when input value gets out of the specified range.
Args:
low_limit: low limit of the range in samples.
high_limit: high limit of the range in samples.
event_mask: bit mask representing inputs that must trigger the event.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_configEventOutOfRangeTemp.argtypes = [
ctypes.POINTER(ctypes.c_void_p),
ctypes.c_uint32,
ctypes.c_uint32,
ctypes.c_uint32,
]
c_lib.DInput2Relay1Temp2Module_configEventOutOfRangeTemp.restype = (
ctypes.c_int32
)
return c_lib.DInput2Relay1Temp2Module_configEventOutOfRangeTemp(
self.obj,
ctypes.c_uint32(low_limit),
ctypes.c_uint32(high_limit),
ctypes.c_uint32(event_mask),
)
[docs] def reset_event_configuration(self):
"""
Resets all previously configured events.
Returns:
It returns if the initialization was successfull (0) or not (!=0).
"""
c_lib.DInput2Relay1Temp2Module_resetEventConfig.argtypes = [
ctypes.POINTER(ctypes.c_void_p)
]
c_lib.DInput2Relay1Temp2Module_resetEventConfig.restype = ctypes.c_int32
return c_lib.DInput2Relay1Temp2Module_resetEventConfig(self.obj)