13#ifndef CD_MULTIINDEX_H
14#define CD_MULTIINDEX_H
24#include <CD_NamespaceHeader.H>
216#include <CD_NamespaceFooter.H>
SpaceDim multi-index type for use with higher order Taylor series.
Definition CD_MultiIndex.H:31
void operator++()
Increment multi-index lexicographically.
Definition CD_MultiIndex.cpp:152
void makeMaps()
Fill maps.
Definition CD_MultiIndex.cpp:195
MultiIndex()=delete
Weak construction is bad.
int factorial() const
Factorial function.
Definition CD_MultiIndex.cpp:111
int norm() const
Get norm of multi-index.
Definition CD_MultiIndex.cpp:122
std::vector< IntVect >::iterator m_iter
Pointer to index.
Definition CD_MultiIndex.H:171
void makeIndices()
Fill m_indices.
Definition CD_MultiIndex.cpp:158
IntVect m_curIndex
Current idnex.
Definition CD_MultiIndex.H:166
void reset()
Reset multi-index to point to the first index.
Definition CD_MultiIndex.cpp:34
IntVect getCurrentIndex() const
Get index.
Definition CD_MultiIndex.cpp:40
~MultiIndex()=default
Destructor.
int m_order
Maximum order representable by this multi-index.
Definition CD_MultiIndex.H:161
int operator[](const int a_dir) const
Get one index.
Definition CD_MultiIndex.cpp:88
IntVect getMultiIndex(const int a_linearIndex) const
Get a multi-index corresponding to the linear index (i.e. column number)
Definition CD_MultiIndex.cpp:73
MultiIndex(const MultiIndex &a_index)=default
Copy constructor.
MultiIndex & operator=(const MultiIndex &a_other)=default
Assignment operator.
std::map< int, IntVect > m_mapToMultiIndex
Map going from linear index to multi-index.
Definition CD_MultiIndex.H:186
bool ok() const
Check that multi-index is ok.
Definition CD_MultiIndex.cpp:94
std::map< IntVect, int > m_mapToLinearIndex
Map for going from lexicographically ordered multi-index to linear index.
Definition CD_MultiIndex.H:181
int getLinearIndex(const IntVect a_MultiIndex) const
Get the linear index (i.e. column number) for a given multi-index.
Definition CD_MultiIndex.cpp:58
int getOrder() const
Get highest order for this index.
Definition CD_MultiIndex.cpp:46
void define(const int a_order)
Define function.
Definition CD_MultiIndex.cpp:23
std::vector< IntVect > m_indices
All indices.
Definition CD_MultiIndex.H:176
Real pow(const RealVect &a_vec)
Power function for multi-indices.
Definition CD_MultiIndex.cpp:139
int getNumIndices() const
Return number of indices in MultiIndex range.
Definition CD_MultiIndex.cpp:52
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26