Viskores  1.0
InputIndex.h
Go to the documentation of this file.
1 //============================================================================
2 // The contents of this file are covered by the Viskores license. See
3 // LICENSE.txt for details.
4 //
5 // By contributing to this file, all contributors agree to the Developer
6 // Certificate of Origin Version 1.1 (DCO 1.1) as stated in DCO.txt.
7 //============================================================================
8 
9 //============================================================================
10 // Copyright (c) Kitware, Inc.
11 // All rights reserved.
12 // See LICENSE.txt for details.
13 //
14 // This software is distributed WITHOUT ANY WARRANTY; without even
15 // the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 // PURPOSE. See the above copyright notice for more information.
17 //============================================================================
18 #ifndef viskores_exec_arg_InputIndex_h
19 #define viskores_exec_arg_InputIndex_h
20 
23 
24 namespace viskores
25 {
26 namespace exec
27 {
28 namespace arg
29 {
30 
38 {
39 };
40 
52 {
53  // The index does not really matter because the fetch is going to ignore it.
54  // However, it still has to point to a valid parameter in the
55  // ControlSignature because the templating is going to grab a fetch tag
56  // whether we use it or not. 1 should be guaranteed to be valid since you
57  // need at least one argument for the input domain.
58  static constexpr viskores::IdComponent INDEX = 1;
60 };
61 
62 template <typename FetchTag, typename ExecObjectType>
63 struct Fetch<FetchTag, viskores::exec::arg::AspectTagInputIndex, ExecObjectType>
64 {
66 
67  template <typename ThreadIndicesType>
68  VISKORES_EXEC viskores::Id Load(const ThreadIndicesType& indices, const ExecObjectType&) const
69  {
70  return indices.GetInputIndex();
71  }
72 
73  template <typename ThreadIndicesType>
74  VISKORES_EXEC void Store(const ThreadIndicesType&, const ExecObjectType&, const ValueType&) const
75  {
76  // Store is a no-op.
77  }
78 };
79 }
80 }
81 } // namespace viskores::exec::arg
82 
83 #endif //viskores_exec_arg_InputIndex_h
viskores::exec::arg::Fetch< FetchTag, viskores::exec::arg::AspectTagInputIndex, ExecObjectType >::ValueType
viskores::Id ValueType
Definition: InputIndex.h:65
viskores::exec::arg::InputIndex::INDEX
static constexpr viskores::IdComponent INDEX
Definition: InputIndex.h:58
viskores::exec::arg::Fetch< FetchTag, viskores::exec::arg::AspectTagInputIndex, ExecObjectType >::Load
viskores::Id Load(const ThreadIndicesType &indices, const ExecObjectType &) const
Definition: InputIndex.h:68
viskores::IdComponent
viskores::Int32 IdComponent
Base type to use to index small lists.
Definition: Types.h:202
ExecutionSignatureTagBase.h
viskores::Id
viskores::Int64 Id
Base type to use to index arrays.
Definition: Types.h:235
viskores::exec::arg::Fetch< FetchTag, viskores::exec::arg::AspectTagInputIndex, ExecObjectType >::Store
void Store(const ThreadIndicesType &, const ExecObjectType &, const ValueType &) const
Definition: InputIndex.h:74
viskores::exec::arg::Fetch
Class for loading and storing values in thread instance.
Definition: Fetch.h:57
viskores
Groups connected points that have the same field value.
Definition: Atomic.h:27
viskores::exec::arg::AspectTagInputIndex
Aspect tag to use for getting the work index.
Definition: InputIndex.h:37
Fetch.h
viskores::exec::arg::ExecutionSignatureTagBase
The base class for all tags used in an ExecutionSignature.
Definition: ExecutionSignatureTagBase.h:45
VISKORES_EXEC
#define VISKORES_EXEC
Definition: ExportMacros.h:59
viskores::exec::arg::InputIndex
The ExecutionSignature tag to use to get the input index.
Definition: InputIndex.h:51