From 65ee42d179d76f7040bd9442f6e9146f1d89a156 Mon Sep 17 00:00:00 2001 From: Michael Jackson Date: Wed, 16 Oct 2024 16:05:55 -0400 Subject: [PATCH] ENH: Add function to compare a pair of attribute matrix. Signed-off-by: Michael Jackson --- .../simplnx/UnitTest/UnitTestCommon.hpp | 89 +++++++++++++++++++ 1 file changed, 89 insertions(+) diff --git a/test/UnitTestCommon/include/simplnx/UnitTest/UnitTestCommon.hpp b/test/UnitTestCommon/include/simplnx/UnitTest/UnitTestCommon.hpp index a3576cc674..aaca3b8825 100644 --- a/test/UnitTestCommon/include/simplnx/UnitTest/UnitTestCommon.hpp +++ b/test/UnitTestCommon/include/simplnx/UnitTest/UnitTestCommon.hpp @@ -1020,6 +1020,95 @@ inline void AddImageGeometry(DataStructure& dataStructure, const SizeVec3& image imageGeom->setOrigin(origin); } +inline void CompareExemplarToGenerateAttributeMatrix(const DataStructure& exemplarDataStructure, const DataPath& exemplarAttributeMatrix, const DataStructure& computedDataStructure, + const DataPath& computedAttributeMatrix) +{ + auto& cellDataGroup = exemplarDataStructure.getDataRefAs(exemplarAttributeMatrix); + // std::vector selectedCellArrays; + + // Create the vector of all cell DataPaths from the exemplar data structure + for(auto& child : cellDataGroup) + { + DataPath exemplarDataArrayPath = exemplarAttributeMatrix.createChildPath(child.second->getName()); + DataPath computedDataArrayPath = computedAttributeMatrix.createChildPath(child.second->getName()); + + const auto* exemplarArrayPtr = exemplarDataStructure.getDataAs(exemplarDataArrayPath); + const auto* computedArrayPtr = computedDataStructure.getDataAs(computedDataArrayPath); + + // Check to see if there is something to compare against in the exemplar file. + if(nullptr == exemplarArrayPtr) + { + continue; + } + if(nullptr == computedArrayPtr) + { + continue; + } + + DataType type = DataType::int8; + const IArray::ArrayType arrayType = computedArrayPtr->getArrayType(); + if(arrayType == IArray::ArrayType::DataArray) + { + type = exemplarDataStructure.getDataRefAs(exemplarDataArrayPath).getDataType(); + } + if(arrayType == IArray::ArrayType::NeighborListArray) + { + type = exemplarDataStructure.getDataRefAs(exemplarDataArrayPath).getDataType(); + } + + switch(type) + { + case DataType::boolean: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::int8: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::int16: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::int32: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::int64: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::uint8: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::uint16: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::uint32: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::uint64: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::float32: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + case DataType::float64: { + nx::core::UnitTest::CompareArrays(computedArrayPtr, exemplarArrayPtr); + break; + } + default: { + throw std::runtime_error("Invalid DataType"); + } + } + } +} + inline void CompareExemplarToGeneratedData(const DataStructure& dataStructure, const DataStructure& exemplarDataStructure, const DataPath attributeMatrix, const std::string& exemplarDataContainerName) { auto& cellDataGroup = dataStructure.getDataRefAs(attributeMatrix);