-
Notifications
You must be signed in to change notification settings - Fork 117
Special Relativity
Athena++ supports special-relativistic fluid dynamics. In this mode the primitive variables are
- comoving rest mass density ρ,
- gas pressure pgas,
- spatial components u i of the 4-velocity, and
- passive scalar dimensionless concentration χ (one for each species).
In MHD we also have a magnetic field B with components B i.
The conserved variables are
- coordinate-frame density D = γρ,
- total energy density E = γ 2wtot − ptot − b tb t,
- momentum density M with components M i = γ 2wtotv i − b tb i, and
- coordinate-frame species density S = χD.
Here we define the following useful quantities:
- Lorentz factor γ = (1 + u1u1 + u2u2 + u3u3)1/2,
- 3-velocity components v i = u i/γ,
- projected 4-field with components b t = γ v⋅B and b i = B i/γ + b tv i,
- magnetic pressure pmag = ημνb μb ν/2,
- total pressure ptot = pgas + pmag,
- adiabatic index Γ,
- comoving gas enthalpy wgas = ρ + Γ/(Γ−1) × pgas,
- comoving magnetic enthalpy wmag = 2pmag,
- comoving total enthalpy wtot = wgas + wmag.
The evolution equations are then
- ∂tD + ∂j (γρv j) = 0,
- ∂tE + ∂jM j = 0,
- ∂tM i + ∂j (γ 2wtotv iv j + ptotδ ij − b ib j) = 0,
- ∂tB i + ∂j (γv jb i − γv ib j) = 0, and
- ∂tS + ∂j (χγρv j) = 0.
The momentum equation might have source terms on the right-hand side in non-Cartesian coordinates.
To enable special relativity, add the -s
flag when configuring. This option will automatically select an appropriate Riemann solver and equation of state. The Riemann solver can be local Lax-Friedrichs, HLLE, HLLC (hydrodynamics only), or HLLD (MHD only). Note the Roe solver is unavailable for relativity. The equation of state must be adiabatic (i.e. gamma-law).
SR is compatible with the same set of coordinates as Newtonian physics: Cartesian, cylindrical, and spherical-polar. Note the coordinates labeled "Minkowski" are for use with general relativity only. For those with GR experience, it is worth noting that cylindrical and spherical-polar coordinates are implemented in a locally orthonormal way for SR, rather than in the natural coordinate way. For example, a purely radial velocity field that is everywhere half the speed of light will have constant components (0.5, 0, 0) in spherical coordinates, rather than spatially varying components and understood basis vectors that also vary in magnitude spatially. This is reflected in the output data.
When calculating timesteps in SR, Athena++ assumes a signal speed of the speed of light (i.e. unity). Therefore a fixed grid will have fixed timesteps given by the CFL number multiplied by the smallest cell width.
SR is fully compatible with static and adaptive mesh refinement.
Caution is advised when simulating extreme conditions (very high Lorentz factors, high magnetizations, etc.). Due to the extra nonlinear coupling in SR compared to Newtonian physics, there are more ways in which a simulation can go wrong, often manifesting in recovering superluminal velocities in the conserved-to-primitive variable inversion.
In order to help robustness, various limits are available in the <hydro>
section of the input file, described below:
Name | Default Value | Description |
---|---|---|
dfloor | ≈10-35 | floor on ρ |
pfloor | ≈10-35 | floor on pgas |
sfloor | ≈10-35 | floor on χ |
gamma_max | 1000 | ceiling on γ |
sigma_max | 0 | ceiling on 2pmag/ρ; only used if positive |
beta_min | 0 | floor on pgas/pmag; only used if positive |
If Lorentz factors above γmax are found, the primitive velocities are all rescaled by the same factor in order to make γ = γmax. For the limits on plasma σ and β, ρ and pgas are adjusted and the magnetic field is left alone in order to preserve ∇⋅B = 0.
Getting Started
User Guide
- Configuring
- Compiling
- The Input File
- Problem Generators
- Boundary Conditions
- Coordinate Systems and Meshes
- Running the Code
- Outputs
- Using MPI and OpenMP
- Static Mesh Refinement
- Adaptive Mesh Refinement
- Load Balancing
- Special Relativity
- General Relativity
- Passive Scalars
- Shearing Box
- Diffusion Processes
- General Equation of State
- FFT
- High-Order Methods
- Super-Time-Stepping
- Orbital Advection
- Rotating System
- Reading Data from External Files
Programmer Guide