vtk-m/vtkm/cont/testing/UnitTestArrayHandleTransform.cxx

197 lines
7.1 KiB
C++
Raw Normal View History

2015-04-13 20:43:18 +00:00
//=============================================================================
//
// 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.
//
// Copyright 2015 National Technology & Engineering Solutions of Sandia, LLC (NTESS).
2015-04-13 20:43:18 +00:00
// Copyright 2015 UT-Battelle, LLC.
// Copyright 2015 Los Alamos National Security.
2015-04-13 20:43:18 +00:00
//
// Under the terms of Contract DE-NA0003525 with NTESS,
2015-04-13 20:43:18 +00:00
// the U.S. Government retains certain rights in this software.
// Under the terms of Contract DE-AC52-06NA25396 with Los Alamos National
// Laboratory (LANL), the U.S. Government retains certain rights in
// this software.
//
//=============================================================================
#include <vtkm/cont/ArrayHandleTransform.h>
#include <vtkm/VecTraits.h>
#include <vtkm/cont/ArrayHandle.h>
#include <vtkm/cont/ArrayHandleCounting.h>
#include <vtkm/cont/DeviceAdapter.h>
#include <vtkm/exec/FunctorBase.h>
#include <vtkm/cont/testing/Testing.h>
2017-05-18 14:29:41 +00:00
namespace
{
2015-04-13 20:43:18 +00:00
const vtkm::Id ARRAY_SIZE = 10;
2017-05-18 14:29:41 +00:00
template <typename ValueType>
2015-04-13 20:43:18 +00:00
struct MySquare
{
2017-05-18 14:29:41 +00:00
template <typename U>
VTKM_EXEC ValueType operator()(U u) const
{
return vtkm::dot(u, u);
}
2015-04-13 20:43:18 +00:00
};
2017-05-18 14:29:41 +00:00
template <typename OriginalPortalType, typename TransformedPortalType>
2015-04-13 20:43:18 +00:00
struct CheckTransformFunctor : vtkm::exec::FunctorBase
{
OriginalPortalType OriginalPortal;
TransformedPortalType TransformedPortal;
VTKM_EXEC
2017-05-18 14:29:41 +00:00
void operator()(vtkm::Id index) const
{
using T = typename TransformedPortalType::ValueType;
2017-05-18 14:29:41 +00:00
typename OriginalPortalType::ValueType original = this->OriginalPortal.Get(index);
2015-04-13 20:43:18 +00:00
T transformed = this->TransformedPortal.Get(index);
2017-05-18 14:29:41 +00:00
if (!test_equal(transformed, MySquare<T>()(original)))
{
2015-04-13 20:43:18 +00:00
this->RaiseError("Encountered bad transformed value.");
}
}
};
2017-05-18 14:29:41 +00:00
template <typename OriginalArrayHandleType, typename TransformedArrayHandleType, typename Device>
VTKM_CONT CheckTransformFunctor<
typename OriginalArrayHandleType::template ExecutionTypes<Device>::PortalConst,
typename TransformedArrayHandleType::template ExecutionTypes<Device>::PortalConst>
make_CheckTransformFunctor(const OriginalArrayHandleType& originalArray,
const TransformedArrayHandleType& transformedArray,
Device)
2015-04-13 20:43:18 +00:00
{
using OriginalPortalType =
typename OriginalArrayHandleType::template ExecutionTypes<Device>::PortalConst;
using TransformedPortalType =
typename TransformedArrayHandleType::template ExecutionTypes<Device>::PortalConst;
2015-04-13 20:43:18 +00:00
CheckTransformFunctor<OriginalPortalType, TransformedPortalType> functor;
functor.OriginalPortal = originalArray.PrepareForInput(Device());
functor.TransformedPortal = transformedArray.PrepareForInput(Device());
return functor;
}
2017-05-18 14:29:41 +00:00
template <typename OriginalArrayHandleType, typename TransformedArrayHandleType>
VTKM_CONT void CheckControlPortals(const OriginalArrayHandleType& originalArray,
const TransformedArrayHandleType& transformedArray)
{
std::cout << " Verify that the control portal works" << std::endl;
using OriginalPortalType = typename OriginalArrayHandleType::PortalConstControl;
using TransformedPortalType = typename TransformedArrayHandleType::PortalConstControl;
2017-05-18 14:29:41 +00:00
VTKM_TEST_ASSERT(originalArray.GetNumberOfValues() == transformedArray.GetNumberOfValues(),
"Number of values in transformed array incorrect.");
OriginalPortalType originalPortal = originalArray.GetPortalConstControl();
2017-05-18 14:29:41 +00:00
TransformedPortalType transformedPortal = transformedArray.GetPortalConstControl();
2017-05-18 14:29:41 +00:00
VTKM_TEST_ASSERT(originalPortal.GetNumberOfValues() == transformedPortal.GetNumberOfValues(),
"Number of values in transformed portal incorrect.");
for (vtkm::Id index = 0; index < originalArray.GetNumberOfValues(); index++)
{
using T = typename TransformedPortalType::ValueType;
typename OriginalPortalType::ValueType original = originalPortal.Get(index);
T transformed = transformedPortal.Get(index);
2017-05-18 14:29:41 +00:00
VTKM_TEST_ASSERT(test_equal(transformed, MySquare<T>()(original)), "Bad transform value.");
}
}
2017-05-18 14:29:41 +00:00
template <typename InputValueType>
2015-04-13 20:43:18 +00:00
struct TransformTests
{
using OutputValueType = typename vtkm::VecTraits<InputValueType>::ComponentType;
using FunctorType = MySquare<OutputValueType>;
2015-04-13 20:43:18 +00:00
using TransformHandle =
vtkm::cont::ArrayHandleTransform<vtkm::cont::ArrayHandle<InputValueType>, FunctorType>;
2015-04-13 20:43:18 +00:00
using CountingTransformHandle =
vtkm::cont::ArrayHandleTransform<vtkm::cont::ArrayHandleCounting<InputValueType>, FunctorType>;
2015-04-13 20:43:18 +00:00
using Device = VTKM_DEFAULT_DEVICE_ADAPTER_TAG;
using Algorithm = vtkm::cont::DeviceAdapterAlgorithm<Device>;
2015-04-13 20:43:18 +00:00
void operator()() const
{
FunctorType functor;
2017-05-18 14:29:41 +00:00
std::cout << "Test a transform handle with a counting handle as the values" << std::endl;
vtkm::cont::ArrayHandleCounting<InputValueType> counting = vtkm::cont::make_ArrayHandleCounting(
InputValueType(OutputValueType(0)), InputValueType(1), ARRAY_SIZE);
2015-04-13 20:43:18 +00:00
CountingTransformHandle countingTransformed =
2017-05-30 14:00:01 +00:00
vtkm::cont::make_ArrayHandleTransform(counting, functor);
2015-04-13 20:43:18 +00:00
CheckControlPortals(counting, countingTransformed);
std::cout << " Verify that the execution portal works" << std::endl;
2017-05-18 14:29:41 +00:00
Algorithm::Schedule(make_CheckTransformFunctor(counting, countingTransformed, Device()),
ARRAY_SIZE);
2015-04-13 20:43:18 +00:00
2017-05-18 14:29:41 +00:00
std::cout << "Test a transform handle with a normal handle as the values" << std::endl;
2015-04-13 20:43:18 +00:00
//we are going to connect the two handles up, and than fill
//the values and make the transform sees the new values in the handle
vtkm::cont::ArrayHandle<InputValueType> input;
2017-05-18 14:29:41 +00:00
TransformHandle thandle(input, functor);
2015-04-13 20:43:18 +00:00
using Portal = typename vtkm::cont::ArrayHandle<InputValueType>::PortalControl;
2015-04-13 20:43:18 +00:00
input.Allocate(ARRAY_SIZE);
Portal portal = input.GetPortalControl();
2017-05-18 14:29:41 +00:00
for (vtkm::Id index = 0; index < ARRAY_SIZE; ++index)
2015-04-13 20:43:18 +00:00
{
2017-05-18 14:29:41 +00:00
portal.Set(index, TestValue(index, InputValueType()));
2015-04-13 20:43:18 +00:00
}
CheckControlPortals(input, thandle);
std::cout << " Verify that the execution portal works" << std::endl;
2017-05-18 14:29:41 +00:00
Algorithm::Schedule(make_CheckTransformFunctor(input, thandle, Device()), ARRAY_SIZE);
2015-04-13 20:43:18 +00:00
2017-05-18 14:29:41 +00:00
std::cout << "Modify array handle values to ensure transform gets updated" << std::endl;
for (vtkm::Id index = 0; index < ARRAY_SIZE; ++index)
2015-04-13 20:43:18 +00:00
{
2017-05-18 14:29:41 +00:00
portal.Set(index, TestValue(index * index, InputValueType()));
2015-04-13 20:43:18 +00:00
}
CheckControlPortals(input, thandle);
std::cout << " Verify that the execution portal works" << std::endl;
2017-05-18 14:29:41 +00:00
Algorithm::Schedule(make_CheckTransformFunctor(input, thandle, Device()), ARRAY_SIZE);
2015-04-13 20:43:18 +00:00
}
};
struct TryInputType
{
2017-05-18 14:29:41 +00:00
template <typename InputType>
void operator()(InputType) const
{
2015-04-13 20:43:18 +00:00
TransformTests<InputType>()();
}
};
void TestArrayHandleTransform()
{
vtkm::testing::Testing::TryTypes(TryInputType());
2015-04-13 20:43:18 +00:00
}
} // annonymous namespace
2017-05-18 14:29:41 +00:00
int UnitTestArrayHandleTransform(int, char* [])
2015-04-13 20:43:18 +00:00
{
return vtkm::cont::testing::Testing::Run(TestArrayHandleTransform);
}