12#ifndef CD_KMCDualState_H
13#define CD_KMCDualState_H
21#include <CD_NamespaceHeader.H>
29template <
typename T =
long long>
163#include <CD_NamespaceFooter.H>
Implementation of CD_KMCDualState.H.
Declaration of a "dual state" for advancing with the Kinetic Monte Carlo module.
Definition CD_KMCDualState.H:31
State & getNonReactiveState() noexcept
Get modifiable non-reactive state.
Definition CD_KMCDualStateImplem.H:116
KMCDualState(const KMCDualState &&)=delete
Disallowed move constructor.
KMCDualState()=default
Default constructor.
KMCDualState(const KMCDualState &)=default
Copy constructor.
int m_numNonReactiveSpecies
Number of non-reactive species.
Definition CD_KMCDualState.H:141
State m_nonReactiveState
Non-reactive state.
Definition CD_KMCDualState.H:151
bool isValidState() const noexcept
Check if state is a valid state. An invalid state will have a negative number of reactants/non-reacta...
Definition CD_KMCDualStateImplem.H:50
void define(const size_t a_numReactiveSpecies, const size_t a_numNonReactiveSpecies) noexcept
Define function constructor.
Definition CD_KMCDualStateImplem.H:37
void linearIn(const std::vector< T > &a_linearizedState) noexcept
Linearize the input buffer.
Definition CD_KMCDualStateImplem.H:89
virtual ~KMCDualState()
Destructor.
Definition CD_KMCDualStateImplem.H:32
KMCDualState & operator=(const KMCDualState &)=default
Copy assignment constructor.
std::vector< T > linearOut() const noexcept
Linearize the state onto an output vector.
Definition CD_KMCDualStateImplem.H:77
State m_reactiveState
Reactive state.
Definition CD_KMCDualState.H:146
State & getReactiveState() noexcept
Get modifiable reactive state.
Definition CD_KMCDualStateImplem.H:102
KMCDualState & operator=(const KMCDualState &&)=delete
Disallowed move assignement.
int m_numReactiveSpecies
Number of reactive species.
Definition CD_KMCDualState.H:136
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:37
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:25