|
@@ -269,71 +269,6 @@ updateNeededForFilteredValue(const UA_Variant *value, const UA_Variant *oldValue
|
|
return false;
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
-#define ABS_SUBTRACT_TYPE_INDEPENDENT(a,b) ((a)>(b)?(a)-(b):(b)-(a))
|
|
|
|
-
|
|
|
|
-static UA_INLINE UA_Boolean
|
|
|
|
-outOfDeadBand(const void *data1, const void *data2, const size_t index, const UA_DataType *type, const UA_Double deadbandValue) {
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_SBYTE]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_SByte*)data1)[index], ((const UA_SByte*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_BYTE]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Byte*)data1)[index], ((const UA_Byte*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_INT16]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Int16*)data1)[index], ((const UA_Int16*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_UINT16]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_UInt16*)data1)[index], ((const UA_UInt16*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_INT32]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Int32*)data1)[index], ((const UA_Int32*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_UINT32]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_UInt32*)data1)[index], ((const UA_UInt32*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_INT64]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Int64*)data1)[index], ((const UA_Int64*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_UINT64]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_UInt64*)data1)[index], ((const UA_UInt64*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_FLOAT]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Float*)data1)[index], ((const UA_Float*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- } else
|
|
|
|
- if (type == &UA_TYPES[UA_TYPES_DOUBLE]) {
|
|
|
|
- if (ABS_SUBTRACT_TYPE_INDEPENDENT(((const UA_Double*)data1)[index], ((const UA_Double*)data2)[index]) <= deadbandValue)
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
- return true;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-static UA_INLINE UA_Boolean
|
|
|
|
-updateNeededForFilteredValue(const UA_Variant *value, const UA_Variant *oldValue, const UA_Double deadbandValue) {
|
|
|
|
- if (value->arrayLength != oldValue->arrayLength) {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
- if (value->type != oldValue->type) {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
- if (UA_Variant_isScalar(value)) {
|
|
|
|
- return outOfDeadBand(value->data, oldValue->data, 0, value->type, deadbandValue);
|
|
|
|
- } else {
|
|
|
|
- for (size_t i = 0; i < value->arrayLength; ++i) {
|
|
|
|
- if (outOfDeadBand(value->data, oldValue->data, i, value->type, deadbandValue))
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- return false;
|
|
|
|
-}
|
|
|
|
|
|
|
|
/* When a change is detected, encoding contains the heap-allocated binary encoded value */
|
|
/* When a change is detected, encoding contains the heap-allocated binary encoded value */
|
|
static UA_Boolean
|
|
static UA_Boolean
|