mirror of
https://gitlab.kitware.com/vtk/vtk-m
synced 2024-10-05 01:49:02 +00:00
ad1e7b5bdb
This mechanism sets up CMake variables that allow a user to select which modules/libraries to create. Dependencies will be tracked down to ensure that all of a module's dependencies are also enabled. The modules are also arranged into groups. Groups allow you to set the enable flag for a group of modules at once. Thus, if you have several modules that are likely to be used together, you can create a group for them. This can be handy in converting user-friendly CMake options (such as `VTKm_ENABLE_RENDERING`) to the modules that enable that by pointing to the appropriate group.
329 lines
10 KiB
C++
329 lines
10 KiB
C++
//============================================================================
|
|
// Copyright (c) Kitware, Inc.
|
|
// All rights reserved.
|
|
// See LICENSE.txt for details.
|
|
//
|
|
// This software is distributed WITHOUT ANY WARRANTY; without even
|
|
// the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
// PURPOSE. See the above copyright notice for more information.
|
|
//============================================================================
|
|
|
|
#include <vtkm/testing/Testing.h>
|
|
|
|
#include <vtkm/TypeTraits.h>
|
|
#include <vtkm/cont/ArrayHandle.h>
|
|
#include <vtkm/internal/ArrayPortalValueReference.h>
|
|
|
|
namespace
|
|
{
|
|
|
|
static constexpr vtkm::Id ARRAY_SIZE = 10;
|
|
|
|
template <typename ArrayPortalType>
|
|
void SetReference(vtkm::Id index, vtkm::internal::ArrayPortalValueReference<ArrayPortalType> ref)
|
|
{
|
|
using ValueType = typename ArrayPortalType::ValueType;
|
|
ref = TestValue(index, ValueType());
|
|
}
|
|
|
|
template <typename ArrayPortalType>
|
|
void CheckReference(vtkm::Id index, vtkm::internal::ArrayPortalValueReference<ArrayPortalType> ref)
|
|
{
|
|
using ValueType = typename ArrayPortalType::ValueType;
|
|
VTKM_TEST_ASSERT(test_equal(ref, TestValue(index, ValueType())), "Got bad value from reference.");
|
|
}
|
|
|
|
template <typename ArrayPortalType>
|
|
void TryOperatorsNoVec(vtkm::Id index,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType> ref,
|
|
vtkm::TypeTraitsScalarTag)
|
|
{
|
|
using ValueType = typename ArrayPortalType::ValueType;
|
|
|
|
ValueType expected = TestValue(index, ValueType());
|
|
VTKM_TEST_ASSERT(ref.Get() == expected, "Reference did not start out as expected.");
|
|
|
|
VTKM_TEST_ASSERT(!(ref < ref));
|
|
VTKM_TEST_ASSERT(ref < ValueType(expected + ValueType(1)));
|
|
VTKM_TEST_ASSERT(ValueType(expected - ValueType(1)) < ref);
|
|
|
|
VTKM_TEST_ASSERT(!(ref > ref));
|
|
VTKM_TEST_ASSERT(ref > ValueType(expected - ValueType(1)));
|
|
VTKM_TEST_ASSERT(ValueType(expected + ValueType(1)) > ref);
|
|
|
|
VTKM_TEST_ASSERT(ref <= ref);
|
|
VTKM_TEST_ASSERT(ref <= ValueType(expected + ValueType(1)));
|
|
VTKM_TEST_ASSERT(ValueType(expected - ValueType(1)) <= ref);
|
|
|
|
VTKM_TEST_ASSERT(ref >= ref);
|
|
VTKM_TEST_ASSERT(ref >= ValueType(expected - ValueType(1)));
|
|
VTKM_TEST_ASSERT(ValueType(expected + ValueType(1)) >= ref);
|
|
}
|
|
|
|
template <typename ArrayPortalType>
|
|
void TryOperatorsNoVec(vtkm::Id,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType>,
|
|
vtkm::TypeTraitsVectorTag)
|
|
{
|
|
}
|
|
|
|
template <typename ArrayPortalType>
|
|
void TryOperatorsInt(vtkm::Id index,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType> ref,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType> scratch,
|
|
vtkm::TypeTraitsScalarTag,
|
|
vtkm::TypeTraitsIntegerTag)
|
|
{
|
|
using ValueType = typename ArrayPortalType::ValueType;
|
|
|
|
ValueType expected = TestValue(index, ValueType());
|
|
VTKM_TEST_ASSERT(ref.Get() == expected, "Reference did not start out as expected.");
|
|
|
|
VTKM_TEST_ASSERT((ref % ref) == (expected % expected));
|
|
VTKM_TEST_ASSERT((ref % expected) == (expected % expected));
|
|
VTKM_TEST_ASSERT((expected % ref) == (expected % expected));
|
|
|
|
VTKM_TEST_ASSERT((ref ^ ref) == (expected ^ expected));
|
|
VTKM_TEST_ASSERT((ref ^ expected) == (expected ^ expected));
|
|
VTKM_TEST_ASSERT((expected ^ ref) == (expected ^ expected));
|
|
|
|
VTKM_TEST_ASSERT((ref | ref) == (expected | expected));
|
|
VTKM_TEST_ASSERT((ref | expected) == (expected | expected));
|
|
VTKM_TEST_ASSERT((expected | ref) == (expected | expected));
|
|
|
|
VTKM_TEST_ASSERT((ref & ref) == (expected & expected));
|
|
VTKM_TEST_ASSERT((ref & expected) == (expected & expected));
|
|
VTKM_TEST_ASSERT((expected & ref) == (expected & expected));
|
|
|
|
VTKM_TEST_ASSERT((ref << ref) == (expected << expected));
|
|
VTKM_TEST_ASSERT((ref << expected) == (expected << expected));
|
|
VTKM_TEST_ASSERT((expected << ref) == (expected << expected));
|
|
|
|
VTKM_TEST_ASSERT((ref << ref) == (expected << expected));
|
|
VTKM_TEST_ASSERT((ref << expected) == (expected << expected));
|
|
VTKM_TEST_ASSERT((expected << ref) == (expected << expected));
|
|
|
|
VTKM_TEST_ASSERT(~ref == ~expected);
|
|
|
|
VTKM_TEST_ASSERT(!(!ref));
|
|
|
|
VTKM_TEST_ASSERT(ref && ref);
|
|
VTKM_TEST_ASSERT(ref && expected);
|
|
VTKM_TEST_ASSERT(expected && ref);
|
|
|
|
VTKM_TEST_ASSERT(ref || ref);
|
|
VTKM_TEST_ASSERT(ref || expected);
|
|
VTKM_TEST_ASSERT(expected || ref);
|
|
|
|
scratch = ValueType(7);
|
|
const ValueType operand = ValueType(7);
|
|
#define RESET \
|
|
ref = TestValue(index, ValueType()); \
|
|
expected = TestValue(index, ValueType());
|
|
|
|
RESET;
|
|
ref &= scratch;
|
|
expected &= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref &= operand;
|
|
expected &= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref |= scratch;
|
|
expected |= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref |= operand;
|
|
expected |= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref >>= scratch;
|
|
expected >>= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref >>= operand;
|
|
expected >>= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref <<= scratch;
|
|
expected <<= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref <<= operand;
|
|
expected <<= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref ^= scratch;
|
|
expected ^= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref ^= operand;
|
|
expected ^= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
#undef RESET
|
|
}
|
|
|
|
template <typename ArrayPortalType, typename DimTag, typename NumericTag>
|
|
void TryOperatorsInt(vtkm::Id,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType>,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType>,
|
|
DimTag,
|
|
NumericTag)
|
|
{
|
|
}
|
|
|
|
template <typename ArrayPortalType>
|
|
void TryOperators(vtkm::Id index,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType> ref,
|
|
vtkm::internal::ArrayPortalValueReference<ArrayPortalType> scratch)
|
|
{
|
|
using ValueType = typename ArrayPortalType::ValueType;
|
|
|
|
ValueType expected = TestValue(index, ValueType());
|
|
VTKM_TEST_ASSERT(ref.Get() == expected, "Reference did not start out as expected.");
|
|
|
|
// Test comparison operators.
|
|
VTKM_TEST_ASSERT(ref == ref);
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
VTKM_TEST_ASSERT(expected == ref);
|
|
|
|
VTKM_TEST_ASSERT(!(ref != ref));
|
|
VTKM_TEST_ASSERT(!(ref != expected));
|
|
VTKM_TEST_ASSERT(!(expected != ref));
|
|
|
|
TryOperatorsNoVec(index, ref, typename vtkm::TypeTraits<ValueType>::DimensionalityTag());
|
|
|
|
VTKM_TEST_ASSERT((ref + ref) == (expected + expected));
|
|
VTKM_TEST_ASSERT((ref + expected) == (expected + expected));
|
|
VTKM_TEST_ASSERT((expected + ref) == (expected + expected));
|
|
|
|
VTKM_TEST_ASSERT((ref - ref) == (expected - expected));
|
|
VTKM_TEST_ASSERT((ref - expected) == (expected - expected));
|
|
VTKM_TEST_ASSERT((expected - ref) == (expected - expected));
|
|
|
|
VTKM_TEST_ASSERT((ref * ref) == (expected * expected));
|
|
VTKM_TEST_ASSERT((ref * expected) == (expected * expected));
|
|
VTKM_TEST_ASSERT((expected * ref) == (expected * expected));
|
|
|
|
VTKM_TEST_ASSERT((ref / ref) == (expected / expected));
|
|
VTKM_TEST_ASSERT((ref / expected) == (expected / expected));
|
|
VTKM_TEST_ASSERT((expected / ref) == (expected / expected));
|
|
|
|
|
|
scratch = ValueType(7);
|
|
const ValueType operand = ValueType(7);
|
|
#define RESET \
|
|
ref = TestValue(index, ValueType()); \
|
|
expected = TestValue(index, ValueType());
|
|
|
|
RESET;
|
|
ref += scratch;
|
|
expected += operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref += operand;
|
|
expected += operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref -= scratch;
|
|
expected -= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref -= operand;
|
|
expected -= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref *= scratch;
|
|
expected *= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref *= operand;
|
|
expected *= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
ref /= scratch;
|
|
expected /= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
RESET;
|
|
ref /= operand;
|
|
expected /= operand;
|
|
VTKM_TEST_ASSERT(ref == expected);
|
|
|
|
RESET;
|
|
TryOperatorsInt(index,
|
|
ref,
|
|
scratch,
|
|
typename vtkm::TypeTraits<ValueType>::DimensionalityTag(),
|
|
typename vtkm::TypeTraits<ValueType>::NumericTag());
|
|
|
|
#undef RESET
|
|
}
|
|
|
|
struct DoTestForType
|
|
{
|
|
template <typename ValueType>
|
|
VTKM_CONT void operator()(const ValueType&) const
|
|
{
|
|
vtkm::cont::ArrayHandle<ValueType> array;
|
|
array.Allocate(ARRAY_SIZE);
|
|
|
|
std::cout << "Set array using reference" << std::endl;
|
|
using PortalType = typename vtkm::cont::ArrayHandle<ValueType>::WritePortalType;
|
|
PortalType portal = array.WritePortal();
|
|
for (vtkm::Id index = 0; index < ARRAY_SIZE; ++index)
|
|
{
|
|
SetReference(index, vtkm::internal::ArrayPortalValueReference<PortalType>(portal, index));
|
|
}
|
|
|
|
std::cout << "Check values" << std::endl;
|
|
CheckPortal(portal);
|
|
|
|
std::cout << "Check references in set array." << std::endl;
|
|
for (vtkm::Id index = 0; index < ARRAY_SIZE; ++index)
|
|
{
|
|
CheckReference(index, vtkm::internal::ArrayPortalValueReference<PortalType>(portal, index));
|
|
}
|
|
|
|
std::cout << "Make a scratch buffer for ref-ref operations." << std::endl;
|
|
vtkm::cont::ArrayHandle<ValueType> scratchArray;
|
|
scratchArray.Allocate(1);
|
|
PortalType scratchPortal = scratchArray.WritePortal();
|
|
|
|
std::cout << "Check that operators work." << std::endl;
|
|
// Start at 1 to avoid issues with 0.
|
|
for (vtkm::Id index = 1; index < ARRAY_SIZE; ++index)
|
|
{
|
|
TryOperators(index,
|
|
vtkm::internal::ArrayPortalValueReference<PortalType>(portal, index),
|
|
vtkm::internal::ArrayPortalValueReference<PortalType>(scratchPortal, 0));
|
|
}
|
|
}
|
|
};
|
|
|
|
void DoTest()
|
|
{
|
|
// We are not testing on the default (exemplar) types because we want to test operators, and
|
|
// many basic C types could fail on basic operations. Small integer types (such as unsigned
|
|
// bytes) get automatically promoted to larger types, so doing somthing like a += operation
|
|
// causes annoying compiler warnings. Float types are also problematic because comparison
|
|
// operations like == can fail even when you expect the values to be the same.
|
|
vtkm::testing::Testing::TryTypes(DoTestForType(),
|
|
vtkm::List<vtkm::Int32, vtkm::UInt64, vtkm::Id3>());
|
|
}
|
|
|
|
} // anonymous namespace
|
|
|
|
int UnitTestArrayPortalValueReference(int argc, char* argv[])
|
|
{
|
|
return vtkm::testing::Testing::Run(DoTest, argc, argv);
|
|
}
|