|
GridFire v0.7.0_rc2
General Purpose Nuclear Network
|
#include <py_engine.h>
Public Member Functions | |
| const std::vector< fourdst::atomic::Species > & | getNetworkSpecies () const override |
| PyDynamicEngine Implementation ///. | |
| std::expected< gridfire::engine::StepDerivatives< double >, gridfire::engine::EngineStatus > | calculateRHSAndEnergy (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Calculate the right-hand side (dY/dt) and energy generation. | |
| gridfire::engine::NetworkJacobian | generateJacobianMatrix (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Generate the Jacobian matrix for the current state. | |
| gridfire::engine::NetworkJacobian | generateJacobianMatrix (const fourdst::composition::CompositionAbstract &comp, double T9, double rho, const std::vector< fourdst::atomic::Species > &activeSpecies) const override |
| Generate the Jacobian matrix for the current state using a subset of active species. | |
| gridfire::engine::NetworkJacobian | generateJacobianMatrix (const fourdst::composition::CompositionAbstract &comp, double T9, double rho, const gridfire::engine::SparsityPattern &sparsityPattern) const override |
| Generate the Jacobian matrix for the current state with a specified sparsity pattern. | |
| void | generateStoichiometryMatrix () override |
| Generate the stoichiometry matrix for the network. | |
| int | getStoichiometryMatrixEntry (const fourdst::atomic::Species &species, const gridfire::reaction::Reaction &reaction) const override |
| Get an entry from the stoichiometry matrix. | |
| double | calculateMolarReactionFlow (const gridfire::reaction::Reaction &reaction, const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Calculate the molar reaction flow for a given reaction. | |
| const gridfire::reaction::ReactionSet & | getNetworkReactions () const override |
| Get the set of logical reactions in the network. | |
| void | setNetworkReactions (const gridfire::reaction::ReactionSet &reactions) override |
| Set the reactions for the network. | |
| std::expected< std::unordered_map< fourdst::atomic::Species, double >, gridfire::engine::EngineStatus > | getSpeciesTimescales (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Compute timescales for all species in the network. | |
| std::expected< std::unordered_map< fourdst::atomic::Species, double >, gridfire::engine::EngineStatus > | getSpeciesDestructionTimescales (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Compute destruction timescales for all species in the network. | |
| fourdst::composition::Composition | update (const gridfire::NetIn &netIn) override |
| Update the internal state of the engine. | |
| bool | isStale (const gridfire::NetIn &netIn) override |
| Check if the engine's internal state is stale. | |
| void | setScreeningModel (gridfire::screening::ScreeningType model) override |
| Set the electron screening model. | |
| gridfire::screening::ScreeningType | getScreeningModel () const override |
| Get the current electron screening model. | |
| size_t | getSpeciesIndex (const fourdst::atomic::Species &species) const override |
| Get the index of a species in the network. | |
| std::vector< double > | mapNetInToMolarAbundanceVector (const gridfire::NetIn &netIn) const override |
| Map a NetIn object to a vector of molar abundances. | |
| gridfire::engine::PrimingReport | primeEngine (const gridfire::NetIn &netIn) override |
| Prime the engine with initial conditions. | |
| gridfire::engine::BuildDepthType | getDepth () const override |
| Get the depth of the network. | |
| void | rebuild (const fourdst::composition::CompositionAbstract &comp, gridfire::engine::BuildDepthType depth) override |
| Rebuild the network with a specified depth. | |
| gridfire::engine::EnergyDerivatives | calculateEpsDerivatives (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Calculate the derivatives of the energy generation rate with respect to T and rho. | |
| fourdst::composition::Composition | collectComposition (const fourdst::composition::CompositionAbstract &comp, double T9, double rho) const override |
| Recursively collect composition from current engine and any sub engines if they exist. | |
| gridfire::engine::SpeciesStatus | getSpeciesStatus (const fourdst::atomic::Species &species) const override |
| Get the status of a species in the network. | |
Public Member Functions inherited from gridfire::engine::Engine | |
| virtual | ~Engine ()=default |
| Virtual destructor. | |
Private Attributes | |
| std::vector< fourdst::atomic::Species > | m_species_cache |
|
nodiscardoverridevirtual |
Calculate the derivatives of the energy generation rate with respect to T and rho.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This method computes the partial derivatives of the specific nuclear energy generation rate with respect to temperature and density for the current state.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Calculate the molar reaction flow for a given reaction.
| reaction | The reaction for which to calculate the flow. |
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This method computes the net rate at which the given reaction proceeds under the current state.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Calculate the right-hand side (dY/dt) and energy generation.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This function must be implemented by derived classes to compute the time derivatives of all species and the specific nuclear energy generation rate for the current state.
Implements gridfire::engine::Engine.
|
overridevirtual |
Recursively collect composition from current engine and any sub engines if they exist.
If species i is defined in comp and in any sub engine or self composition then the molar abundance of species i in the returned composition will be that defined in comp. If there are species defined in sub engine compositions which are not defined in comp then their molar abundances will be based on the reported values from each sub engine.
| comp | Input composition to "normalize". |
| T9 | |
| rho |
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Generate the Jacobian matrix for the current state.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This method must compute and store the Jacobian matrix (∂(dY/dt)_i/∂Y_j) for the current state. The matrix can then be accessed via getJacobianMatrixEntry().
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Generate the Jacobian matrix for the current state with a specified sparsity pattern.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
| sparsityPattern | The sparsity pattern to use for the Jacobian matrix. |
This method must compute and store the Jacobian matrix (∂(dY/dt)_i/∂Y_j) for the current state using automatic differentiation, taking into account the provided sparsity pattern. The matrix can then be accessed via getJacobianMatrixEntry().
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Generate the Jacobian matrix for the current state using a subset of active species.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
| activeSpecies | The set of species to include in the Jacobian calculation. |
This method must compute and store the Jacobian matrix (∂(dY/dt)_i/∂Y_j) for the current state, considering only the specified subset of active species. The matrix can then be accessed via getJacobianMatrixEntry().
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Generate the stoichiometry matrix for the network.
This method must compute and store the stoichiometry matrix, which encodes the net change of each species in each reaction.
Implements gridfire::engine::DynamicEngine.
|
inlineoverridevirtual |
Get the depth of the network.
This method is intended to provide information about the network's structure, such as how many layers of reactions or species are present. It can be useful for diagnostics and understanding the network's complexity.
Reimplemented from gridfire::engine::DynamicEngine.
|
overridevirtual |
Get the set of logical reactions in the network.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
PyDynamicEngine Implementation ///.
Implements gridfire::engine::Engine.
|
overridevirtual |
Get the current electron screening model.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Compute destruction timescales for all species in the network.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This method estimates the destruction timescale for each species, which can be useful for understanding reaction flows and equilibrium states.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Get the index of a species in the network.
| species | The species to look up. |
This method allows querying the index of a specific species in the engine's internal representation. It is useful for accessing species data efficiently.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Get the status of a species in the network.
| species | The species to check. |
This method allows querying the current status of a specific species within the engine's network.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Compute timescales for all species in the network.
| comp | Composition object containing current abundances. |
| T9 | Temperature in units of 10^9 K. |
| rho | Density in g/cm^3. |
This method estimates the timescale for abundance change of each species, which can be used for timestep control, diagnostics, and reaction network culling.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Get an entry from the stoichiometry matrix.
| species | species to look up stoichiometry for. |
| reaction | reaction to find |
The stoichiometry matrix must have been generated by generateStoichiometryMatrix().
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Check if the engine's internal state is stale.
| netIn | A struct containing the current network input, such as temperature, density, and composition. |
This method allows derived classes to determine if their internal state is out-of-date with respect to the provided network conditions. If the engine is stale, it may require a call to update() before performing calculations.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Map a NetIn object to a vector of molar abundances.
| netIn | The input conditions for the network. |
This method converts the input conditions into a vector of molar abundances, which can be used for further calculations or diagnostics.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Prime the engine with initial conditions.
| netIn | The input conditions for the network. |
This method is used to prepare the engine for calculations by setting up initial conditions, reactions, and species. It may involve compiling reaction rates, initializing internal data structures, and performing any necessary pre-computation.
Implements gridfire::engine::DynamicEngine.
|
inlineoverridevirtual |
Rebuild the network with a specified depth.
| comp | The composition to rebuild the network with. |
| depth | The desired depth of the network. |
This method is intended to allow dynamic adjustment of the network's depth, which may involve adding or removing species and reactions based on the specified depth. However, not all engines support this operation.
Reimplemented from gridfire::engine::DynamicEngine.
|
overridevirtual |
Set the reactions for the network.
| reactions | The set of reactions to use in the network. |
This method replaces the current set of reactions in the network with the provided set. It marks the engine as stale, requiring regeneration of matrices and recalculation of rates.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Set the electron screening model.
| model | The type of screening model to use for reaction rate calculations. |
This method allows changing the screening model at runtime. Screening corrections account for the electrostatic shielding of nuclei by electrons, which affects reaction rates in dense stellar plasmas.
Implements gridfire::engine::DynamicEngine.
|
overridevirtual |
Update the internal state of the engine.
| netIn | A struct containing the current network input, such as temperature, density, and composition. |
This method is intended to be implemented by derived classes to update their internal state based on the provided network conditions. For example, an adaptive engine might use this to re-evaluate which reactions and species are active. For other engines that do not support manually updating, this method might do nothing.
Implements gridfire::engine::DynamicEngine.
|
mutableprivate |