42#include "../../tools/parallel/parallelToolbox.hpp"
43#include "reuseIndexManagerBase.hpp"
58 template<
typename T_Index,
typename T_ParallelToolbox>
66 CODI_DEFAULT_PARALLEL_TOOLBOX);
72 template<
typename Type>
73 using Atomic =
typename ParallelToolbox::template Atomic<Type>;
95 static Atomic<T_Index> _globalMaximumIndex;
96 return _globalMaximumIndex;
102 static bool _globalMaximumIndexInitialized =
false;
103 return _globalMaximumIndexInitialized;
109 static ReadWriteMutex _globalMaximumIndexMutex;
110 return _globalMaximumIndexMutex;
119 globalMaximumIndexMutex().lockWrite();
120 if (!globalMaximumIndexInitialized()) {
121 globalMaximumIndex() = reservedIndices;
122 globalMaximumIndexInitialized() =
true;
124 globalMaximumIndexMutex().unlockWrite();
125 generateNewIndices();
138 unsigned long maximumGlobalIndex = globalMaximumIndex();
141 TapeValues::LocalReductionOperation
constexpr operation = TapeValues::LocalReductionOperation::Max;
155 return globalMaximumIndex();
173 for (
size_t pos = 0; pos < this->indexSizeIncrement; ++pos) {
#define CODI_NO_INLINE
See codi::Config::AvoidedInlines.
Definition config.h:426
#define CODI_INLINE
See codi::Config::ForcedInlines.
Definition config.h:469
#define codiAssert(x)
See codi::Config::EnableAssert.
Definition config.h:441
#define CODI_DD(Type, Default)
Abbreviation for CODI_DECLARE_DEFAULT.
Definition macros.hpp:97
CoDiPack - Code Differentiation Package.
Definition codi.hpp:97
static bool constexpr NeedsStaticStorage
< See ReuseIndexManagerBase.
Definition parallelReuseIndexManager.hpp:85
T_Index Index
See ParallelReuseIndexManager.
Definition parallelReuseIndexManager.hpp:63
Index ActiveTypeIndexData
Same as the index.
Definition parallelReuseIndexManager.hpp:64
~ParallelReuseIndexManager()
Destructor.
Definition parallelReuseIndexManager.hpp:129
void addToTapeValues(TapeValues &values) const
Add storage and other information to the tape values.
Definition parallelReuseIndexManager.hpp:137
inlineIndex getLargestCreatedIndex() const
Returns the largest created index.
Definition parallelReuseIndexManager.hpp:154
ParallelReuseIndexManager(Index const &reservedIndices)
Definition parallelReuseIndexManager.hpp:118
ReuseIndexManagerBase< Index, ParallelReuseIndexManager > Base
Base class abbreviation.
Definition parallelReuseIndexManager.hpp:67
T_ParallelToolbox ParallelToolbox
See ParallelReuseIndexManager.
Definition parallelReuseIndexManager.hpp:65
static bool constexpr IsLinear
Definition reuseIndexManagerBase.hpp:81
ReuseIndexManagerBase()
Definition reuseIndexManagerBase.hpp:124
std::vector< Index > unusedIndices
Definition reuseIndexManagerBase.hpp:91
static bool constexpr CopyNeedsStatement
Definition reuseIndexManagerBase.hpp:80
void addToTapeValues(TapeValues &values) const
Definition reuseIndexManagerBase.hpp:265
size_t indexSizeIncrement
Definition reuseIndexManagerBase.hpp:94
size_t unusedIndicesPos
Definition reuseIndexManagerBase.hpp:92
Tape information that can be printed in a pretty print format or a table format.
Definition tapeValues.hpp:75
void addUnsignedLongEntry(std::string const &name, unsigned long const &value, LocalReductionOperation operation=LocalReductionOperation::Sum)
Add unsigned long entry.
Definition tapeValues.hpp:163