CoolDwarf.star package¶
Submodules¶
CoolDwarf.star.sphere module¶
sphere.py
This module contains the VoxelSphere class, which represents a 3D voxelized sphere model for a star. The VoxelSphere class provides methods for computing various physical properties of the star, including its radius, enclosed mass, energy flux, and more.
The VoxelSphere class uses an equation of state (EOS) for the star, which can be inverted to compute pressure and temperature grids. It also provides methods for updating the energy of the star and recomputing its state.
The module imports several utility functions and constants from the CoolDwarf package, as well as classes for handling errors related to energy conservation and non-convergence.
All units are in non log space cgs unless otherwise specified.
Dependencies¶
numpy
tqdm
torch
cupy
pandas
scipy.interpolate
CoolDwarf.utils.math
CoolDwarf.utils.const
CoolDwarf.utils.format
CoolDwarf.EOS
CoolDwarf.model
CoolDwarf.err
Classes¶
VoxelSphere: Represents a 3D voxelized sphere model for a star.
Functions¶
default_tol: Returns a dictionary of default numerical tolerances for the cooling model.
Exceptions¶
EnergyConservationError: Raised when there is a violation of energy conservation.
NonConvergenceError: Raised when a computation fails to converge.
VolumeError: Raised when the volume error is greater than the tolerance.
ResolutionError: Raised when the resolution is insufficient.
Example Usage¶
>>> from CoolDwarf.star import VoxelSphere
>>> from CoolDwarf.utils.plot import plot_3d_gradients, visualize_scalar_field
>>> from CoolDwarf.utils import setup_logging
>>> from CoolDwarf.EOS import get_eos
>>> from CoolDwarf.opac import KramerOpac
>>> from CoolDwarf.EOS.invert import Inverter
>>> import numpy as cp
>>> import matplotlib.pyplot as plt
>>> setup_logging(debug=True)
>>> EOS = get_eos("EOS/TABLEEOS_2021_Trho_Y0292_v1", "CD21")
>>> opac = KramerOpac(0.7, 0.02)
>>> sphere = VoxelSphere(8e31, "BrownDwarfMESA/BD_TEST.mod", EOS, opac, radialResolution=50, altitudinalResolition=10, azimuthalResolition=20)
>>> sphere.evolve(maxTime=3.154e+7, dt=86400)
>>> print(f"Surface Temp: {sphere.surface_temperature_profile}")
- class CoolDwarf.star.sphere.VoxelSphere(mass, model, EOS, opac, pressureRegularization=1e-05, radialResolution=10, azimuthalResolition=10, altitudinalResolition=10, t0=0, X=0.75, Y=0.25, Z=0, tol={'maxEChange': 0.0001, 'relax': 1e-06, 'volCheck': 0.01}, modelFormat='mesa', alpha=1.901, mindt=0.1, cfl_factor=0.5, imodelOut=False, imodelOutCadence=1000, imodelOutCadenceUnit='s', fmodelOut=True)¶
Bases:
object
A class to represent a 3D voxelized sphere model for a star.
- Raises:
- EnergyConservationError
If there is a violation of energy conservation.
- NonConvergenceError
If a computation fails to converge.
- Attributes:
- CONSTdict
A dictionary of physical constants.
mass
floatReturns the mass grid for the star.
- modelstr
The name of the stellar model to use.
- modelFormatstr
The format of the stellar model. Default is ‘mesa’. May also be ‘dsep’.
- EOSEOS
The equation of state for the star.
- opacOpac
The opacity of the star.
- pressureRegularizationfloat
A regularization parameter for the pressure computation.
- radialResolutionint
The number of radial divisions in the voxelized sphere.
- azimuthalResolutionint
The number of azimuthal divisions in the voxelized sphere.
- t0float
The initial time of the star.
- Xfloat
The hydrogen mass fraction of the star.
- Yfloat
The helium mass fraction of the star.
- Zfloat
The metal mass fraction of the star.
- alphafloat
The mixing length parameter.
- mindtfloat
The minimum timestep for the star.
- cfl_factorfloat
The Courant-Friedrichs-Lewy factor for the star.
- toldict
A dictionary of numerical tolerances for the cooling model. Keys are ‘relax’ and ‘maxEChange’. Default is {‘relax’: 1e-6, ‘maxEChange’: 1e-4, ‘volCheck’: 1e-2}. Relax is the relaxation parameter for the energy update. MaxEChange is the maximum fractional change in energy allowed per timestep. volCheck is the maximum fractional error in volume allowed.
Methods
Cp
([delta_t])Computes the specific heat capacity of the star at constant pressure.
as_dict
()Returns a dictionary representation of the star. Returns ------- dict: A dictionary representation of the star.
Returns a pandas DataFrame representation of the star. Returns ------- pandas.DataFrame: A DataFrame representation of the star.
evolve
([maxTime, dt, pbar, callback, cbc, cargs])Evolves the star over a specified time period using a specified timestep.
inject_energy
(i, j, k, dE)Injects energy into the star at a specified grid point.
inject_energy_coord
(r, theta, phi, dE)Injects energy into the star at a specified coordinate. Parameters ---------- r : float The radial coordinate of the grid point. theta : float The azimuthal coordinate of the grid point. phi : float The altitudinal coordinate of the grid point. dE : float The amount of energy to inject into the star.
save
(filename)Save to a binary file format.
spherical_grid_equal_volume
(numRadial, ...)Generate points within a sphere with equal volume using a stratified sampling approach.
timestep
([userdt])Computes a timestep for the star based on the CFL condition or the user-specified timestep.
- CONST = {'G': 6.6743e-08, 'a': 7.5646e-15, 'c': 29979245800.0, 'mH': 1.00784, 'mHe': 4.002602}¶
- Cp(delta_t: float = 1)¶
Computes the specific heat capacity of the star at constant pressure.
- Parameters:
- delta_tfloat, optional
A small change in temperature for computing the specific heat capacity. Default is 1e-5.
- Returns:
- xp.ndarray: The specific heat capacity of the star at constant pressure.
- as_dict()¶
Returns a dictionary representation of the star. Returns ——-
dict: A dictionary representation of the star.
- as_pandas()¶
Returns a pandas DataFrame representation of the star. Returns ——-
pandas.DataFrame: A DataFrame representation of the star.
- property cfl_dt: float¶
Computes the timestep based on the Courant-Friedrichs-Lewy (CFL) condition.
- Returns:
- float: The timestep based on the CFL condition.
- property convective_energy_flux: Tuple[ndarray, ndarray, ndarray]¶
Computes the convective energy flux in the radial, azimuthal, and altitudinal directions. We take a mixing length theory approach to compute the convective energy flux.
The convective enertgy flux for some coordinate direction is given by: Fconv = (1/2) * rho * Cp * v * (TGrad - ad) where rho is the density, Cp is the specific heat capacity, v is the convective velocity along that coordinate axis, TGrad is the temperature gradient along that coordinte axis, and ad is the adiabatic gradient.
- Returns:
- tuple: A tuple of 3D arrays representing the convective energy flux in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (FconvR, FconvTheta, FconvPhi).
- property convective_overturn_timescale: Tuple[ndarray, ndarray, ndarray]¶
Computes the convective overturn timescale in the radial, azimuthal, and altitudinal directions. The convective overturn timescale is given by the mixing length divided by the convective velocity.
- Returns:
- tuple: A tuple of 3D arrays representing the convective overturn timescale in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (tauR, tauTheta, tauPhi).
- property convective_velocity: Tuple[ndarray, ndarray, ndarray]¶
Computes the convective velocity in the radial, azimuthal, and altitudinal directions. The convective velocity is given by the mixing length divided by two times the square root of the product of the gravitational acceleration and the difference between the adiabatic gradient and the temperature gradient.
- Returns:
- tuple: A tuple of 3D arrays representing the convective velocity in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (vR, vTheta, vPhi).
- property dEdt: ndarray¶
Computes the time derivative of the energy for the star.
- Returns:
- xp.ndarray: The time derivative of the energy for the star.
- property density: ndarray¶
Returns the density grid for the star. Returns ——-
xp.ndarray: The density grid for the star.
- property enclosed_mass¶
Computes the enclosed mass of the star as a function of radius.
- Returns:
- interp1d: A 1D interpolation function for the enclosed mass.
- property energy: ndarray¶
Returns the energy grid for the star.
- property energy_flux: Tuple[Tuple[ndarray, ndarray, ndarray], Tuple[ndarray, ndarray, ndarray]]¶
Computes the energy flux in the radial, azimuthal, and altitudinal directions.
- Returns:
- tuple: A tuple of 3D arrays representing the energy flux in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of ((fluxR, fluxTheta, fluxPhi), (fluxR, fluxTheta, fluxPhi)).
- evolve(maxTime: float = 31540000.0, dt: float = 86400, pbar=False, callback=<function VoxelSphere.<lambda>>, cbc=1, cargs: tuple = ())¶
Evolves the star over a specified time period using a specified timestep.
- Parameters:
- maxTimefloat, optional
The maximum time to evolve the star. Default is 3.154e+7.
- dtfloat, optional
The timestep to use for the evolution. Default is 86400.
- pbarbool, optional
Display a progress bar for the evolution. Default is False.
- callbackfunction, optional
A callback function to call at each timestep. Default is a function that does nothing. Function will be called after each timestep. The star object will be passed as an argument. The function signature must be callback(star, *args).
- cbcint, optional
The cadence at which to call the callback function. 1 meaning every time step. 2 would be every other timestep and so on…
- cargstuple, optional
Additional arguments to pass to the callback function.
- property flux_divergence: Tuple[Tuple[ndarray, ndarray, ndarray], Tuple[ndarray, ndarray, ndarray]]¶
Computes the divergence of the energy flux in the radial, azimuthal, and altitudinal directions.
- Returns:
- tuple: A tuple of 3D arrays representing the divergence of the energy flux in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of ((delFConvR, delFConvTheta, delFConvPhi), (delFRadR, delFRadTheta, delFRadPhi)).
- property gradRadEr: Tuple[ndarray, ndarray, ndarray]¶
Computes the radiative energy gradient.
- Returns:
- tuple: A tuple of 3D arrays representing the radiative energy gradient in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (delErR, delErTheta, delErPhi).
- property gradT: Tuple[ndarray, ndarray, ndarray]¶
Computes the temperature gradients in the radial, azimuthal, and altitudinal directions.
- Returns:
- tuple: A tuple of 3D arrays representing the temperature gradients in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (tGradR, tGradTheta, tGradPhi).
- property gravitational_acceleration: ndarray¶
Computes the gravitational acceleration for the star. If the mass grid is zero at a given grid point, the gravitational acceleration is set to infinity to deal with the singularity at r=0.
- Returns:
- xp.ndarray: The gravitational acceleration for the star.
- inject_energy(i, j, k, dE)¶
Injects energy into the star at a specified grid point.
- Parameters:
- iint
The radial index of the grid point.
- jint
The azimuthal index of the grid point.
- kint
The altitudinal index of the grid point.
- dEfloat
The amount of energy to inject into the star.
- inject_energy_coord(r, theta, phi, dE)¶
Injects energy into the star at a specified coordinate. Parameters ———- r : float
The radial coordinate of the grid point.
- thetafloat
The azimuthal coordinate of the grid point.
- phifloat
The altitudinal coordinate of the grid point.
- dEfloat
The amount of energy to inject into the star.
- property mass: ndarray¶
Returns the mass grid for the star. Returns ——-
xp.ndarray: The mass grid for the star.
- property mixing_length: ndarray¶
Computes the mixing length for the star.
- Returns:
- xp.ndarray: The mixing length for the star.
- property pressure: ndarray¶
Returns the pressure grid for the star. Returns ——-
xp.ndarray: The pressure grid for the star.
- property pressure_scale_height: ndarray¶
Computes the pressure scale height for the star.
- Returns:
- xp.ndarray: The pressure scale height for the star.
- property radiative_energy_flux: Tuple[ndarray, ndarray, ndarray]¶
Computes the radiative energy flux in the radial, azimuthal, and altitudinal directions.
- Returns:
- tuple: A tuple of 3D arrays representing the radiative energy flux in the radial, azimuthal, and altitudinal directions.
- The arrays are in the form of (fluxRadR, fluxRadTheta, fluxRadPhi).
- property radius¶
Returns the radius of the star.
- Returns:
- float: The radius of the star.
- save(filename: str) bool ¶
Save to a binary file format. Currently the model format is being defined in the joplin notebook I am using to keep track of development.
- Parameters:
- filenamestr
The filename to save the star to.
- Returns:
- bool: A flag indicating if the save was successful.
- spherical_grid_equal_volume(numRadial, numTheta, numPhi, radius)¶
Generate points within a sphere with equal volume using a stratified sampling approach. Returns radius, theta, phi as meshgrids and volume elements for each point.
- Parameters:
- numRadialint
Number of radial segments.
- numThetaint
Number of azimuthal segments.
- numPhiint
Number of altitudinal segments.
- radiusfloat
Radius of the sphere.
- Returns:
- tuple: A tuple of meshgrids for the radial, azimuthal, and altitudinal positions, and the volume elements.
- Raises:
- VolumeError
If the volume error is greater than the tolerance.
- property surface_temperature_profile: ndarray¶
Computes the surface temperature profile for the star.
- Returns:
- xp.ndarray: The surface temperature profile for the star.
- property temperature: ndarray¶
Returns the temperature grid for the star.
- Returns:
- xp.ndarray: The temperature grid for the star.
- timestep(userdt: float = inf) float ¶
Computes a timestep for the star based on the CFL condition or the user-specified timestep. The actual timestep used is the minimum of the CFL timestep and the user-specified timestep, and this will be returned.
The energy of the star is then updated based on the computed timestep. Following this, the energy is used to invert the EOS and update the temperature and density grids. The energy conservation is checked, and if the energy change is greater than the maximum energy change tolerance, the timestep is halved and the energy, temperature, density, and pressure grids are reset to their initial values.
When the energy conservation is satisfied, the evolutionary step is incremented, and the time is updated based on the the acutal timestep used. The timestep is then returned.
- Parameters:
- userdtfloat, optional
The user-specified timestep. Default is xp.inf.
- Returns:
- float: The actual timestep used for the star.
- Raises:
- EnergyConservationError
If there is a violation of energy conservation.
- NonConvergenceError
If the model fails to converge after a certain number of timesteps.
Examples
>>> star = VoxelSphere(...) >>> star.timestep()
- CoolDwarf.star.sphere.default_tol()¶
Returns a dictionary of default numerical tolerances for the cooling model.
- Returns:
- dict: A dictionary of default numerical tolerances for the cooling model.
- Keys are ‘relax’, ‘maxEChange’, and ‘volCheck’.