Viskores  1.0
OutputIndex.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_OutputIndex_h
19 #define viskores_exec_arg_OutputIndex_h
20 
23 
24 namespace viskores
25 {
26 namespace exec
27 {
28 namespace arg
29 {
30 
38 {
39 };
40 
53 {
54  // The index does not really matter because the fetch is going to ignore it.
55  // However, it still has to point to a valid parameter in the
56  // ControlSignature because the templating is going to grab a fetch tag
57  // whether we use it or not. 1 should be guaranteed to be valid since you
58  // need at least one argument for the output domain.
59  static constexpr viskores::IdComponent INDEX = 1;
61 };
62 
63 template <typename FetchTag, typename ExecObjectType>
64 struct Fetch<FetchTag, viskores::exec::arg::AspectTagOutputIndex, ExecObjectType>
65 {
67 
68  template <typename ThreadIndicesType>
69  VISKORES_EXEC viskores::Id Load(const ThreadIndicesType& indices, const ExecObjectType&) const
70  {
71  return indices.GetOutputIndex();
72  }
73 
74  template <typename ThreadIndicesType>
75  VISKORES_EXEC void Store(const ThreadIndicesType&, const ExecObjectType&, const ValueType&) const
76  {
77  // Store is a no-op.
78  }
79 };
80 }
81 }
82 } // namespace viskores::exec::arg
83 
84 #endif //viskores_exec_arg_OutputIndex_h
viskores::exec::arg::OutputIndex::INDEX
static constexpr viskores::IdComponent INDEX
Definition: OutputIndex.h:59
viskores::IdComponent
viskores::Int32 IdComponent
Base type to use to index small lists.
Definition: Types.h:202
viskores::exec::arg::Fetch< FetchTag, viskores::exec::arg::AspectTagOutputIndex, ExecObjectType >::Load
viskores::Id Load(const ThreadIndicesType &indices, const ExecObjectType &) const
Definition: OutputIndex.h:69
ExecutionSignatureTagBase.h
viskores::exec::arg::Fetch< FetchTag, viskores::exec::arg::AspectTagOutputIndex, ExecObjectType >::Store
void Store(const ThreadIndicesType &, const ExecObjectType &, const ValueType &) const
Definition: OutputIndex.h:75
viskores::Id
viskores::Int64 Id
Base type to use to index arrays.
Definition: Types.h:235
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::OutputIndex
The ExecutionSignature tag to use to get the output index.
Definition: OutputIndex.h:52
Fetch.h
viskores::exec::arg::AspectTagOutputIndex
Aspect tag to use for getting the work index.
Definition: OutputIndex.h:37
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::Fetch< FetchTag, viskores::exec::arg::AspectTagOutputIndex, ExecObjectType >::ValueType
viskores::Id ValueType
Definition: OutputIndex.h:66