42#include "../../tools/parallel/parallelToolbox.hpp"
43#include "reuseIndexManagerBase.hpp"
58 template<
typename T_Index,
typename T_ParallelToolbox>
65 CODI_DEFAULT_PARALLEL_TOOLBOX);
71 template<
typename Type>
72 using Atomic =
typename ParallelToolbox::template Atomic<Type>;
94 static Atomic<T_Index> _globalMaximumIndex;
95 return _globalMaximumIndex;
101 static bool _globalMaximumIndexInitialized =
false;
102 return _globalMaximumIndexInitialized;
108 static ReadWriteMutex _globalMaximumIndexMutex;
109 return _globalMaximumIndexMutex;
118 globalMaximumIndexMutex().lockWrite();
119 if (!globalMaximumIndexInitialized()) {
120 globalMaximumIndex() = reservedIndices;
121 globalMaximumIndexInitialized() =
true;
123 globalMaximumIndexMutex().unlockWrite();
124 generateNewIndices();
137 unsigned long maximumGlobalIndex = globalMaximumIndex();
140 TapeValues::LocalReductionOperation
constexpr operation = TapeValues::LocalReductionOperation::Max;
154 return globalMaximumIndex();
172 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:96
CoDiPack - Code Differentiation Package.
Definition codi.hpp:94
static bool constexpr NeedsStaticStorage
< See ReuseIndexManagerBase.
Definition parallelReuseIndexManager.hpp:84
T_Index Index
See ParallelReuseIndexManager.
Definition parallelReuseIndexManager.hpp:63
~ParallelReuseIndexManager()
Destructor.
Definition parallelReuseIndexManager.hpp:128
void addToTapeValues(TapeValues &values) const
Add storage and other information to the tape values.
Definition parallelReuseIndexManager.hpp:136
inlineIndex getLargestCreatedIndex() const
Returns the largest created index.
Definition parallelReuseIndexManager.hpp:153
ParallelReuseIndexManager(Index const &reservedIndices)
Definition parallelReuseIndexManager.hpp:117
ReuseIndexManagerBase< Index, ParallelReuseIndexManager > Base
Base class abbreviation.
Definition parallelReuseIndexManager.hpp:66
T_ParallelToolbox ParallelToolbox
See ParallelReuseIndexManager.
Definition parallelReuseIndexManager.hpp:64
static bool constexpr IsLinear
Definition reuseIndexManagerBase.hpp:80
ReuseIndexManagerBase()
Definition reuseIndexManagerBase.hpp:123
std::vector< Index > unusedIndices
Definition reuseIndexManagerBase.hpp:90
static bool constexpr CopyNeedsStatement
Definition reuseIndexManagerBase.hpp:79
void addToTapeValues(TapeValues &values) const
Definition reuseIndexManagerBase.hpp:259
size_t indexSizeIncrement
Definition reuseIndexManagerBase.hpp:93
size_t unusedIndicesPos
Definition reuseIndexManagerBase.hpp:91
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