Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
but this is not what most real systems expect.
"""
if a is None or b is None: # These occur, for example, in unions
return (a is None) == (b is None)
elif isinstance(model, pydsdl.CompositeType):
if type(a) != type(b): # pragma: no cover
return False
for f in pyuavcan.dsdl.get_model(a).fields_except_padding: # pragma: no cover
if not are_close(f.data_type,
pyuavcan.dsdl.get_attribute(a, f.name),
pyuavcan.dsdl.get_attribute(b, f.name)):
return False
return True # Empty objects of same type compare equal
elif isinstance(model, pydsdl.ArrayType):
if len(a) != len(b) or a.dtype != b.dtype: # pragma: no cover
return False
if isinstance(model.element_type, pydsdl.PrimitiveType):
return bool(numpy.allclose(a, b, equal_nan=True)) # Speedup for large arrays like images or point clouds
else:
return all(itertools.starmap(functools.partial(are_close, model.element_type), zip(a, b)))
elif isinstance(model, pydsdl.FloatType):
t = {
16: numpy.float16,
32: numpy.float32,
64: numpy.float64,
}[model.bit_length]
return bool(numpy.allclose(t(a), t(b), equal_nan=True))
else:
but this is not what most real systems expect.
"""
if a is None or b is None: # These occur, for example, in unions
return (a is None) == (b is None)
elif isinstance(data_type, pydsdl.CompositeType):
if type(a) != type(b): # pragma: no cover
return False
for f in pyuavcan.dsdl.get_type(a).fields_except_padding: # pragma: no cover
if not _are_close(f.data_type,
pyuavcan.dsdl.get_attribute(a, f.name),
pyuavcan.dsdl.get_attribute(b, f.name)):
return False
return True # Empty objects of same type compare equal
elif isinstance(data_type, pydsdl.ArrayType):
return all(starmap(partial(_are_close, data_type.element_type), zip(a, b))) \
if len(a) == len(b) and a.dtype == b.dtype else False
elif isinstance(data_type, pydsdl.FloatType):
t = {
16: numpy.float16,
32: numpy.float32,
64: numpy.float64,
}[data_type.bit_length]
return numpy.allclose(t(a), t(b), equal_nan=True)
else:
return numpy.allclose(a, b)
for f in model.fields_except_padding:
field_type = f.data_type
try:
value = source.pop(f.name)
except LookupError:
continue # No value specified, keep original value
if isinstance(field_type, pydsdl.CompositeType):
field_obj = get_attribute(destination, f.name)
if field_obj is None: # Oh, this is a union
field_obj = get_class(field_type)() # The variant was not selected, construct a default
set_attribute(destination, f.name, field_obj) # Switch the union to the new variant
update_from_builtin(field_obj, value)
elif isinstance(field_type, pydsdl.ArrayType):
element_type = field_type.element_type
if isinstance(element_type, pydsdl.PrimitiveType):
set_attribute(destination, f.name, value)
elif isinstance(element_type, pydsdl.CompositeType):
dtype = get_class(element_type)
set_attribute(destination, f.name, [update_from_builtin(dtype(), s) for s in value])
else:
assert False, f'Unexpected array element type: {element_type!r}'
elif isinstance(field_type, pydsdl.PrimitiveType):
set_attribute(destination, f.name, value)
else:
assert False, f'Unexpected field type: {field_type!r}'
if source: