vtk-m/vtkm/worklet/gradient/CellGradient.h
Robert Maynard 8d04796b1f Allow Vector Gradient computation to output fancy fields and not gradient
Basically we can run the gradient worklet and compute the Divergence, Vorticity,
and QCriterion without ever having to store the gradient tensor in global memory
2017-07-03 16:11:01 -04:00

74 lines
2.4 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.
//
// Copyright 2014 Sandia Corporation.
// Copyright 2014 UT-Battelle, LLC.
// Copyright 2014 Los Alamos National Security.
//
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
// 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.
//============================================================================
#ifndef vtk_m_worklet_gradient_CellGradient_h
#define vtk_m_worklet_gradient_CellGradient_h
#include <vtkm/exec/CellDerivative.h>
#include <vtkm/exec/ParametricCoordinates.h>
#include <vtkm/worklet/WorkletMapTopology.h>
#include <vtkm/worklet/gradient/GradientOutput.h>
namespace vtkm
{
namespace worklet
{
namespace gradient
{
template <typename T>
struct CellGradientInType : vtkm::ListTagBase<T>
{
};
template <typename T>
struct CellGradient : vtkm::worklet::WorkletMapPointToCell
{
typedef void ControlSignature(CellSetIn,
FieldInPoint<Vec3> pointCoordinates,
FieldInPoint<CellGradientInType<T>> inputField,
GradientOutputs outputFields);
typedef void ExecutionSignature(CellShape, PointCount, _2, _3, _4);
typedef _1 InputDomain;
template <typename CellTagType,
typename PointCoordVecType,
typename FieldInVecType,
typename GradientOutType>
VTKM_EXEC void operator()(CellTagType shape,
vtkm::IdComponent pointCount,
const PointCoordVecType& wCoords,
const FieldInVecType& field,
GradientOutType& outputGradient) const
{
vtkm::Vec<vtkm::FloatDefault, 3> center =
vtkm::exec::ParametricCoordinatesCenter(pointCount, shape, *this);
outputGradient = vtkm::exec::CellDerivative(field, wCoords, center, shape, *this);
}
};
}
}
}
#endif