42#include "../../misc/mathUtility.hpp"
43#include "../data/emptyData.hpp"
44#include "indexManagerInterface.hpp"
65 template<
typename T_Index,
typename T_Impl>
104 return static_cast<Impl&
>(*this);
109 return static_cast<Impl const&
>(*this);
114 cast().generateNewIndices();
143 template<
typename Tape>
145 bool generatedNewIndex =
false;
150 generateNewIndices();
151 generatedNewIndex =
true;
164 return generatedNewIndex;
168 template<
typename Tape>
170 freeIndex<Tape>(index);
172 bool generatedNewIndex =
false;
174 generateNewIndices();
175 generatedNewIndex =
true;
183 return generatedNewIndex;
187 template<
typename Tape>
190 freeIndex<Tape>(lhs);
192 assignIndex<Tape>(lhs);
197 template<
typename Tape>
221 Index needToGenerate = index - cast().getLargestCreatedIndex();
222 size_t newUnusedIndexSize = this->unusedIndicesPos + needToGenerate;
225 newUnusedIndexSize =
getNextMultiple(newUnusedIndexSize, this->indexSizeIncrement);
226 this->unusedIndices.resize(newUnusedIndexSize);
230 generateNewIndices();
260 unsigned long storedIndices = this->usedIndicesPos + this->
unusedIndicesPos;
261 unsigned long allocatedIndices = this->usedIndices.size() + this->unusedIndices.size();
263 double memoryStoredIndices = (double)storedIndices * (
double)(
sizeof(
Index));
264 double memoryAllocatedIndices = (double)allocatedIndices * (
double)(
sizeof(
Index));
266 TapeValues::LocalReductionOperation
constexpr operation = Impl::NeedsStaticStorage
267 ? TapeValues::LocalReductionOperation::Max
268 : TapeValues::LocalReductionOperation::Sum;
271 values.
addDoubleEntry(
"Memory used", memoryStoredIndices, operation,
true,
false);
272 values.
addDoubleEntry(
"Memory allocated", memoryAllocatedIndices, operation,
false,
true);
283 CODI_NO_INLINE void increaseIndicesSizeTo(std::vector<Index>& v,
size_t minimalSize) {
#define CODI_NO_INLINE
See codi::Config::AvoidedInlines.
Definition config.h:417
#define CODI_INLINE
See codi::Config::ForcedInlines.
Definition config.h:457
#define codiAssert(x)
See codi::Config::EnableAssert.
Definition config.h:432
#define CODI_DD(Type, Default)
Abbreviation for CODI_DECLARE_DEFAULT.
Definition macros.hpp:94
#define CODI_IMPLEMENTATION
Used in interface declarations to indicate the type of the implementing class.
Definition macros.hpp:105
bool constexpr SortIndicesOnReset
Reuse index tapes will sort their indices on a reset.
Definition config.h:264
CoDiPack - Code Differentiation Package.
Definition codi.hpp:91
IntegralType getNextMultiple(IntegralType const &targetSize, IntegralType const &chunkSize)
Helper function for overallocation in multiples of a given chunk size.
Definition mathUtility.hpp:49
No data is stored in this DataInterface implementation. It is used to terminate the recursive nature ...
Definition emptyData.hpp:54
EmptyPosition Position
No positional data.
Definition emptyData.hpp:59
Empty Position with no nested data.
Definition position.hpp:47
static void notifyIndexAssignListeners(Index const &index)
Invoke callbacks for IndexAssign events.
Definition eventSystem.hpp:778
static void notifyIndexFreeListeners(Index const &index)
Invoke callbacks for IndexFree events.
Definition eventSystem.hpp:806
Indices enable the mapping of primal values to their adjoint counterparts.
Definition indexManagerInterface.hpp:78
static Index constexpr InactiveIndex
Default inactive index for all index managers.
Definition indexManagerInterface.hpp:86
Index getLargestCreatedIndex() const
Returns the largest created index.
Identifiers are reused. Freed identifiers are assigned to new variables. Variables keep their indices...
Definition reuseIndexManagerBase.hpp:66
static bool constexpr IsLinear
Identifiers are not coupled to statements.
Definition reuseIndexManagerBase.hpp:80
bool assignUnusedIndex(Index &index)
Call on registering input values.
Definition reuseIndexManagerBase.hpp:169
bool valid
Prevent index free after destruction.
Definition reuseIndexManagerBase.hpp:95
~ReuseIndexManagerBase()
Destructor.
Definition reuseIndexManagerBase.hpp:134
T_Impl Impl
See ReuseIndexManagerBase.
Definition reuseIndexManagerBase.hpp:70
ReuseIndexManagerBase()
Definition reuseIndexManagerBase.hpp:123
bool assignIndex(Index &index)
Call on assignment of a primal value, e.g. on w for w = a + b.
Definition reuseIndexManagerBase.hpp:144
std::vector< Index > unusedIndices
Pool of indices that have not been used in this recording yet.
Definition reuseIndexManagerBase.hpp:90
std::vector< Index > usedIndices
Pool of indices that have already been used in this recording.
Definition reuseIndexManagerBase.hpp:87
static bool constexpr CopyNeedsStatement
No copy optimization is implemented.
Definition reuseIndexManagerBase.hpp:79
void addToTapeValues(TapeValues &values) const
Add storage and other information to the tape values.
Definition reuseIndexManagerBase.hpp:259
static bool constexpr NeedsStaticStorage
Identifiers are managed globally.
Definition reuseIndexManagerBase.hpp:81
T_Index Index
See ReuseIndexManagerBase.
Definition reuseIndexManagerBase.hpp:69
size_t indexSizeIncrement
Block size for index pool enlargement.
Definition reuseIndexManagerBase.hpp:93
size_t unusedIndicesPos
Number of remaining unused indices.
Definition reuseIndexManagerBase.hpp:91
void freeIndex(Index &index)
Call on destruction of a primal value. Usually called from the destructor.
Definition reuseIndexManagerBase.hpp:198
size_t usedIndicesPos
Number of remaining used indices.
Definition reuseIndexManagerBase.hpp:88
void reset()
Reset for a new recording.
Definition reuseIndexManagerBase.hpp:236
void copyIndex(Index &lhs, Index const &rhs)
Call on copy of a primal value, e.g. w = a.
Definition reuseIndexManagerBase.hpp:188
void updateLargestCreatedIndex(Index const &index)
Update the largest generated index.
Definition reuseIndexManagerBase.hpp:216
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
void addDoubleEntry(std::string const &name, double const &value, LocalReductionOperation operation=LocalReductionOperation::Sum, bool usedMem=false, bool allocatedMem=false)
Add double entry. If it is a memory entry, it should be in bytes.
Definition tapeValues.hpp:137