From 47d5616564585140caa18484945142b4b7f95448 Mon Sep 17 00:00:00 2001 From: Patrick Avery Date: Sat, 17 Aug 2024 20:10:28 -0500 Subject: [PATCH] Treat arrays with empty shapes as numbers Calling `tolist()` on these types of arrays yields a single number rather than a list. This would cause errors with the yaml dumper since it was expected a list. Instead, we should just follow the route for single numbers and call `.item()` instead. This fixes the issue. Signed-off-by: Patrick Avery --- hexrd/utils/yaml.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/hexrd/utils/yaml.py b/hexrd/utils/yaml.py index 88555ec41..41412aaf5 100644 --- a/hexrd/utils/yaml.py +++ b/hexrd/utils/yaml.py @@ -12,9 +12,13 @@ class NumpyToNativeDumper(yaml.SafeDumper): converted to a basic type. """ def represent_data(self, data): - if isinstance(data, np.ndarray): + # Empty shape arrays should be treated as numbers, not arrays. + is_empty_shape_array = ( + isinstance(data, np.ndarray) and data.shape == () + ) + if isinstance(data, np.ndarray) and not is_empty_shape_array: return self.represent_list(data.tolist()) - elif isinstance(data, (np.generic, np.number)): + elif isinstance(data, (np.generic, np.number)) or is_empty_shape_array: item = data.item() if isinstance(item, (np.generic, np.number)): # This means it was not converted successfully.