//============================================================================ // 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. //============================================================================ #ifndef vtk_m_exec_arg_IncidentElementCount_h #define vtk_m_exec_arg_IncidentElementCount_h #include #include namespace vtkm { namespace exec { namespace arg { /// \brief Aspect tag to use for getting the incident element count. /// /// The \c AspectTagIncidentElementCount aspect tag causes the \c Fetch class to /// obtain the number of indices that map to the current topology element. /// struct AspectTagIncidentElementCount { }; /// \brief The \c ExecutionSignature tag to get the number of incident elements. /// /// In a topology map, there are \em visited and \em incident topology elements /// specified. The scheduling occurs on the \em visited elements, and for each /// \em visited element there is some number of incident \em incident elements /// that are accessible. This \c ExecutionSignature tag provides the number of /// these \em incident elements that are accessible. /// struct IncidentElementCount : vtkm::exec::arg::ExecutionSignatureTagBase { static constexpr vtkm::IdComponent INDEX = 1; using AspectTag = vtkm::exec::arg::AspectTagIncidentElementCount; }; template struct Fetch { using ValueType = vtkm::IdComponent; VTKM_SUPPRESS_EXEC_WARNINGS template VTKM_EXEC ValueType Load(const ThreadIndicesType& indices, const ExecObjectType&) const { return indices.GetIndicesIncident().GetNumberOfComponents(); } template VTKM_EXEC void Store(const ThreadIndicesType&, const ExecObjectType&, const ValueType&) const { // Store is a no-op. } }; } } } // namespace vtkm::exec::arg #endif //vtk_m_exec_arg_IncidentElementCount_h