 4D-STAR
        4D-STAR
      Towards 3D Stellar Structure and Evolution Models
of Stars; or,
New Dimensions in Stellar Structure and Evolution
Emily M. Boudreaux & 4D-STAR Collaboration
Challenges and Innovations in Computational Astrophysics IV
      4D-STAR is funded by European Research Council (ERC) under the Horizon Europe programme 
(Synergy Grant agreement No. 101071505: 4D-STAR)
        Work for this project is funded by the European Union. 
Views and opinions expressed are however those of the author(s) only and do not necessarily
 reflect those of the European Union or the European Research Council
 
  Overview
Overview
| Name | Equation | 
|---|---|
| Mass Continuity | \[\frac{dM_{r}}{dr} = 4\pi r^{2}\rho\] | 
| Hydrostatic Equilibrium | \[\frac{dP}{dr} = -\rho g\] | 
| Energy Continuity | \[\frac{dL_{r}}{dr} = 4\pi r^{2}\rho\varepsilon\] | 
| Energy Transport | \[\frac{dT}{dr} = \frac{3}{16\pi a}\frac{\kappa}{c}\frac{L_{r}}{r^{2}}\] | 
 
       
  Stellar Evolution and Rotation in Four dimensions
• Finite Element using MFEM (mfem.org)
• Limited use in stellar structure modeling (Jalali 2010)
• Loads of work from other fields to make these problems more tractable
 
   
   
  
          pip install gridfire
      
from gridfire.engine import GraphEngine, MultiscalePartitioningEngineView, AdaptiveEngineView
from gridfire.solver import DirectNetworkSolver
from gridfire.type import NetIn
from fourdst.composition import Composition
from fourdst.atomic import species
symbols : list[str] = ["H-1", "He-3", "He-4", "C-12", "N-14", "O-16", "Ne-20", "Mg-24"]
X : list[float]     = [0.708, 2.94e-5, 0.276, 0.003, 0.0011, 9.62e-3, 1.62e-3, 5.16e-4]
comp = Composition()
comp.registerSymbol(symbols)
comp.setMassFraction(symbols, X)
comp.finalize(True)
print(f"Initial H-1 mass fraction {comp.getMassFraction("H-1")}")
netIn = NetIn()
netIn.composition = comp
netIn.temperature = 1.5e7
netIn.density = 1.6e2
netIn.tMax = 1e-9
netIn.dt0 = 1e-12
baseEngine = GraphEngine(netIn.composition, 2)
baseEngine.setUseReverseReactions(False)
qseEngine = MultiscalePartitioningEngineView(baseEngine)
adaptiveEngine = AdaptiveEngineView(qseEngine)
solver = DirectNetworkSolver(adaptiveEngine)
def callback(context):
    H1Index = context.engine.getSpeciesIndex(species["H-1"])
    He4Index = context.engine.getSpeciesIndex(species["He-4"])
    C12ndex = context.engine.getSpeciesIndex(species["C-12"])
    Mgh24ndex = context.engine.getSpeciesIndex(species["Mg-24"])
    print(f"Time: {context.t}, H-1: {context.state[H1Index]}, He-4: {context.state[He4Index]}, C-12: {context.state[C12ndex]}, Mg-24: {context.state[Mgh24ndex]}")
solver.set_callback(callback)
results = solver.evaluate(netIn)
print(f"Final H-1 mass fraction {results.composition.getMassFraction("H-1")}")
       
  | Module Name | Status | Description | Current Assignee | 
|---|---|---|---|
| config | Complete | This module handles all configuration files. It is responsible for parsing the YAML files | N/A | 
| composition | MVS | This module tracks a general composition object, allowing for arbitrary species tracking and mixing | N/A | 
| const | Complete | This module contains all physical constants from the CODATA 2022 data release as well as some astronomical constants from IAU 2015 | N/A | 
| eos | MVS | This module implements both a general interface for equation of states as well as specific equations of states. Currently the helmholtz equation of state is the only one implemented. | N/A | 
| meshIO | Complete | This module handles all I/O for the mesh. It is responsible for reading and writing the mesh to disk. This is used to interface with the resource manager which allows for easier configuration on the user end. | N/A | 
| misc | WIP | This is a catch-all module for miscellaneous things. Generally we should avoid putting stuff in here but sometimes (such as for debugging macros) it is useful. | N/A | 
| network | MVS | This module handles the nuclear network and burning calculations. Currently only Frank Timmes’ Approx8 network is implemented. It also implements a general interface for nuclear networks so that other networks can be added. | N/A | 
| opac | WIP | This module handles opacity calculation / interpolation. | A.D. | 
| poly | WIP | This module computes polytropic models which are used as initial states for solving the structure equations. | E.B. | 
| probe | Complete | This module implements the probenamespace which is used to hold functions for probing the current state of the code (stuff likewhydtin MESA). | N/A | 
| python | WIP | This module contains all code relevant to the Python interface. All interface code is then organized in submodules within this (such as python/config). | E.B. | 
| resource | Complete | This module handles loading resources from disk in a clean fashion. The key justification here is to avoid users having to explicitly set environmental variables but also to make loading of resources anywhere in the code easier to handle. | N/A | 
| types | Complete | This module implements custom datatypes for SERiF which do not cleanly fall into any other module (i.e. __datatypesshould not go inmisc). | N/A | 
 
 
        opat-core