Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Analytic electron EOS and zsplit modifier #444

Merged
merged 41 commits into from
Dec 18, 2024
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
2b258e4
ideal gas electron EOS implemented. Still need to add zsplit and docu…
jonahm-LANL Dec 11, 2024
6167b75
zsplit mostly implemented
jonahm-LANL Dec 16, 2024
4b4a2fa
zsplit compiles
jonahm-LANL Dec 16, 2024
3d18cae
tests work
jonahm-LANL Dec 16, 2024
7fba185
add test for zsplits
jonahm-LANL Dec 16, 2024
2512249
messages
jonahm-LANL Dec 16, 2024
8085e61
Add discussion of lambdas, add discussion of 3T, add discussion of ZS…
jonahm-LANL Dec 17, 2024
7e9a7ec
changelog
jonahm-LANL Dec 17, 2024
54c8a25
Merge branch 'main' into jmm/zsplit
Yurlungur Dec 17, 2024
aaa57cc
clang format 12 stay around please
jonahm-LANL Dec 17, 2024
0dfef59
latest for docs, noble for formatting
jonahm-LANL Dec 17, 2024
a0a8069
try updating to latest catch2 release
jonahm-LANL Dec 17, 2024
c692221
unused variable
jonahm-LANL Dec 17, 2024
98fb444
typo and also try to make wno-psabi only for C++
jonahm-LANL Dec 17, 2024
08172b2
try to fix cuda errors for static members
jonahm-LANL Dec 17, 2024
95c60cd
No GCC. You are wrong and I am right.
jonahm-LANL Dec 17, 2024
3b030b1
disable some EOSs from default variant
jonahm-LANL Dec 17, 2024
7886d11
shrink the default variant
jonahm-LANL Dec 17, 2024
dc803ed
Disable python build in github tests as it now takes an incredibly lo…
jonahm-LANL Dec 17, 2024
a0f00c4
update build to be parallel
jonahm-LANL Dec 17, 2024
c43afcc
try enabling python build now again with parallel builds
jonahm-LANL Dec 17, 2024
d282d09
undo removal of relativistic EOS
jonahm-LANL Dec 17, 2024
090559e
fix type list comma
jonahm-LANL Dec 17, 2024
d80e40c
add parallel builds for the docs build
jonahm-LANL Dec 17, 2024
780fbd4
WHY IS IT DYING WITHOUT AN ERROR MESSAGE
jonahm-LANL Dec 17, 2024
af1e70a
turn off IPO to see if this fixes the memory problems with the linker
jonahm-LANL Dec 17, 2024
ed6622f
no need for verbose output
jonahm-LANL Dec 17, 2024
39990f8
switch to ld.gold linker
jonahm-LANL Dec 17, 2024
6f6b6f8
huh...
jonahm-LANL Dec 17, 2024
830bb5e
disabling intraprocedural optimization seems to way slow down the build
jonahm-LANL Dec 17, 2024
d0dcacd
extend memory limits on system, use release build to remove debug sym…
jonahm-LANL Dec 17, 2024
bc721f8
runner not available for ubuntu-noble now. Try older version string?
jonahm-LANL Dec 17, 2024
fc3ee77
add doc info
jonahm-LANL Dec 18, 2024
0e9f910
add v&v EOS option to spackage
jonahm-LANL Dec 18, 2024
2c013c3
spackage should have vandv set to true
jonahm-LANL Dec 18, 2024
7368490
document spackage change
jonahm-LANL Dec 18, 2024
4e93e12
Sam jones comments
jonahm-LANL Dec 18, 2024
551fc3e
Update doc/sphinx/src/modifiers.rst
Yurlungur Dec 18, 2024
6e255b9
Update doc/sphinx/src/modifiers.rst
Yurlungur Dec 18, 2024
5042643
hjhp and pdmullen comments
jonahm-LANL Dec 18, 2024
03d646d
Merge branch 'jmm/zsplit' of github.com:lanl/singularity-eos into jmm…
jonahm-LANL Dec 18, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/formatting.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ on:
jobs:
formatting:
name: Check Formatting
runs-on: ubuntu-latest
runs-on: ubuntu-noble
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Latest is now 24.04 which does not support clang-format-12. For now, just pin to older Ubuntu. WIll resolve the dependency issue long term in a formal single MR in the new year. See #446

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this is now ubuntu-22.04. Must use version number, not version name.


steps:
- name: Checkout code
Expand Down
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
## Current develop

### Added (new features/APIs/variables/...)
- [[PR444]](https://github.com/lanl/singularity-eos/pull/444) Add Z split modifier and electron ideal gas EOS

### Fixed (Repair bugs, etc)
- [[PR439]](https://github.com/lanl/singularity-eos/pull/439) Add mean atomic mass and number to EOS API
Expand Down
8 changes: 6 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -440,8 +440,8 @@ if(SINGULARITY_BUILD_TESTS)
FetchContent_Declare(
Catch2
GIT_REPOSITORY https://github.com/catchorg/Catch2.git
# or later is fine too
GIT_TAG v3.0.1)
# jmm: updated Dec 17, 2024 to avoid build errors on modern gcc
GIT_TAG v3.7.1)
Comment on lines +453 to +454
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Catch2 v3.0.1 does not compile on ubuntu 24.04. Update to 3.7.1 to rescue it.

FetchContent_MakeAvailable(Catch2)
list(APPEND CMAKE_MODULE_PATH ${Catch2_SOURCE_DIR}/contrib)
endif()
Expand Down Expand Up @@ -560,6 +560,10 @@ target_compile_options(
-use_fast_math
> # release
> # cuda

# Suppresses annoying ABI notes. See:
# https://stackoverflow.com/questions/52020305/what-exactly-does-gccs-wpsabi-option-do-what-are-the-implications-of-supressi
$<$<CXX_COMPILER_ID:GNU>:-Wno-psabi>
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

GCC outputs these ABI notes. When compiling with -Werr those notes cause compilation to fail, but the notes explain gcc bugs, and are not singularity-eos problems. In the way we build singularity-eos (via spack or in-tree), ABI incompatibilities will never impact us.

)
if (SINGULARITY_STRICT_WARNINGS)
target_compile_options(singularity-eos_Interface INTERFACE
Expand Down
120 changes: 120 additions & 0 deletions doc/sphinx/src/models.rst
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,61 @@ functional forms for :math:`\Gamma` and the reference curves, the task of
calculating a **thermodynamically consistent** temperature becomes more
complicated.

The 3T Model
``````````````
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

In high-energy denisty physics, the so-called three-temperature (or
3T) model is often employed. In this model, a material is fully or
partially ionized. Due to the separation in masses between electrons
and atomic nuclei, electrons come into thermal equilibrium and ions
come into thermal equilibrium, but the two populations are not in
thermal equilibrium with each other. This introduces separate electron
and ion temperatures. The third temperature is potentially a radiation
temperature.

By convention in 3T physics, density :math:`\rho` is always the mass
density of the ions. The electron number density may then be computed
as

.. math::

n = \left\langle Z \right\rangle \frac{\rho}{\left\langle A\right\rangle m_p}

where here :math:`\left\langle Z\right\rangle` is the average number
of electrons contributed per atom, also called mean ionization state,
:math:`\rho` is the ion mass density, :math:`\bar{A}` is the mean
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
atomic mass (in grams per mole) of a given material and :math:`m_p` is
the proton mass.

.. note::

Note that there is notational ambiguity between the average
ionization state and the average atomic number, as the symbol for
both is :math:`Z`. To disambiguate in ``singularity-eos``, we use
overbars to reference mean atomic properties such as mean atomic
mass :math:`\bar{A}` and mean atomic number :math:`\bar{Z}` while we
use :math:`\left\langle Z\right\rangle` to denote mean ionizaiton
state.

Also by convention, the specific internal energy carried by electrons
:math:`\varepsilon_e` is specific with respect to the *ion* mass. In
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
particular:

.. math::

u_e = \varepsilon_e \rho

where here :math:`u_e` is the internal energy per unit volume carried
by electrons and, as discussed above, :math:`\rho` is ion mass
density.

``singularity-eos`` assumes that, when 3T physics is active, electrons
and ions are each described by a separate equation of state
object. Several models are specifically designed to represent, e.g.,
the electron equation of state or ion equation of state. The tabulated
models may also support loading tables specifically for electron or
ion equations of state.

Available EOS Information and Nomenclature
------------------------------------------

Expand Down Expand Up @@ -469,6 +524,71 @@ the atomic mass and number as a final optional parameter, e.g.,
IdealGas(Real gm1, Real Cv, MeanAtomicProperties(Abar, Zbar));
IdealGas(Real gm1, Real Cv, Real EntropyT0, Real EntropyRho0, MeanAtomicProperties(Abar, Zbar));

Ideal Electron Gas
```````````````````

The ideal electron gas equation of state is designed for use with 3T
physics. It is an ideal Boltzmann gas of electrons. As such, each
electron is assumed to have three translational degrees of freedom
:math:`f`, such that

.. math::

\Gamma = \frac{2}{f} = \frac{2}{3}

and

.. math::

\gamma = \Gamma + 1 = \frac{5}{3}.

The pressure is given by the number density of electrons times
:math:`k_b T` for Boltzmann constant :math:`k_b` and temperature
:math:`T`:

.. math::

P = \frac{\rho}{m_p \bar{A}}\left\langle Z \right\rangle k_b T
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

The specific heat is then

.. math::

C_V = \frac{\left\langle Z \right\rangle k_b}{\Gamma m_p \bar{A}}
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

so that

.. math::

P = \Gamma \rho C_V T

as expected.

The constructor takes only the ``MeanAtomicProperties`` struct, which
is a required input:

.. code-block::cpp

IdealElectrons(const MeanAtomicProperties &AZbar);

Optionally reference values may be provided for the entropy
calculation, which is computed in the same way as the standard ideal
gas.
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

Calls to compute state variables require the mean ionization state,
which must be passed in the ``lambda`` parameter, e.g.,

.. code-block:: cpp

Real lambda[1] = {Z};
Real P = eos.PressureFromDensityTemperature(rho, T, lambda);

.. note::

For now, the ideal electron gas is not in the default variant
provided by singularity-eos. If you would like to use it, you must
implement your own custom variant.

Stiffened Gas
`````````````

Expand Down
111 changes: 103 additions & 8 deletions doc/sphinx/src/modifiers.rst
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,16 @@ Equation of State Modifiers
provides some internal transformation on inputs and outputs. For
example the ``ShiftedEOS`` modifier changes the zero point energy of a
given EOS model by shifting all energies up or down. Modifiers can be
used to, for example, production-harden a model. Only certain
combinations of ``EOS`` and ``modifier`` are permitted by the defualt
``Variant``. For example, only ``IdealGas``, ``SpinerEOS``, and
``StellarCollapse`` support the ``RelativisticEOS`` and ``UnitSystem``
modifiers. All models support the ``ShiftedEOS`` and ``ScaledEOS``
modifiers. However, note that modifiers do not commute, and only one
order is supported. The ordering, inside-out, is ``UnitSystem`` or
``RelativisticEOS``, then ``ScaledEOS``, then ``ShiftedEOS``.
used to, for example, production-harden a model.

Only certain combinations of ``EOS`` and ``modifier`` are permitted by
the defualt ``Variant``. For example, only ``IdealGas``,
``SpinerEOS``, and ``StellarCollapse`` support the ``RelativisticEOS``
and ``UnitSystem`` modifiers. All models support the ``ShiftedEOS``
and ``ScaledEOS`` modifiers. However, note that modifiers do not
commute, and only one order is supported. The ordering, inside-out, is
``UnitSystem`` or ``RelativisticEOS``, then ``ScaledEOS``, then
``ShiftedEOS``.

We list below the available modifiers and their constructors.

Expand Down Expand Up @@ -187,6 +189,99 @@ internal energy, and temperature. On the other hand,
specifies the unit system by specifying units for time, mass, length,
and temperature.

Z-Split EOS
-------------

For 3T physics (as described in the models section) it is often
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
desirable to have a separate equation of state for electrons and a
separate equation of state for ions. The Z-split model takes a total
equation of state and splits it into electron and ion components. The
"Z" here signifies mean ionization state, or the average number of
free electrons contributed per atomic nucleus, which is the mean
atomic number in the case of full ionization, but could be smaller in
the case of partial ionization. (It is zero for an unionized gas.) The
physical model of Z-split can be derived from an ideal gas equation of
state. For an ideal gas made up of electrons and ions, where all
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
molecular bonds have been broken, the total pressure is given by

.. math::

P_t = (\left\langle Z\right\rangle + 1) \frac{\rho}{m_p \bar{A}} k_b T

where :math:`\left\langle Z\right\rangle` is the mean ionization
state, :math:`rho` is the ion mass density (the electron ion mass
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
density is negligible), :math:`m_p` is the proton mass,
:math:`\bar{A}` is the mean atomic mass, :math:`k_b` is Boltzmann's
constant, and :math:`T` is temperature. The contribution from
electrons is proportional to :math:`\left\langle Z\right\rangle`.

The split simply splits the total pressure into normalized
contributions for the electrons:

.. math::

P_e = \frac{\left\langle Z\right\rangle}{1 + \left\langle Z\right\rangle} P_t(\rho, T_e)

and ions:

.. math::

P_i = \frac{1}{1 + \left\langle Z\right\rangle} P_t(\rho, T_i)

where here :math:`T_e` is the electron temperature and :math:`T_i` the
ion temperature such that, when the temperatures are equal,

.. math::

P_e + P_i = P_t

The same split is applied to the specific internal energy:

.. math::

\varepsilon_e = \frac{\left\langle Z\right\rangle}{1 + \left\langle Z\right\rangle} \varepsilon_t(\rho, T_e)\\
\varepsilon_i = \frac{1}{1 + \left\langle Z\right\rangle} \varepsilon_t(\rho, T_i)

and the remaining state variables and thermodynamic derivatives can be
derived from these relations.

In ``singularity-eos``, the z-split is implemented as the templated class

.. code-block:: cpp

template<ZSplitComponent ztype, typename T>
class ZSplit

where ``ZSPlitComponent`` may either be ``ZSplitComponent::Electrons``
or ``ZSplitComponent::Ions``. As syntactic sugar, ``ZSplitE<T>`` and
``ZSplitI<T>`` are available. The Z-split constructor does not require
any additional parameters, so you may construct one as, e.g.,
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

.. code-block:: cpp

using namespace singularity
auto ion_eos = ZSPlitI<IdealGas>(IdealGas(gm1, Cv);

and similarly for electrons,

.. code-block:: cpp

auto electron_eos = ZSPlitE<IdealGas>(IdealGas(gm1, Cv);

The Z-split modifier takes the ionization state as an additional
parameter via the lambda. For example:

.. code-block:: cpp

Real lambda[1] = {Z};
Real Pe = electron_eos.PressureFromDensityTemperature(rho, temperature, lambda);

.. note::

For now, the Z-split EOS is not in the default variant provided by
singularity-eos. If you would like to use it, you must implement
your own custom variant.

Composing Modifiers
--------------------

Expand Down
12 changes: 12 additions & 0 deletions doc/sphinx/src/using-eos.rst
Original file line number Diff line number Diff line change
Expand Up @@ -737,6 +737,18 @@ For more details on modifiers, see the :ref:`modifiers<modifiers>`
section. If you need a combination of modifiers not supported by
default, we recommend building a custom variant as described above.

Modifiers and Lambdas
-----------------------

Modifiers may require lambdas. When this is the case, the lambda
required by the modifier is appended to the end of the lambda
indexer. For example, the ``StellarCollapse`` EOS model requires
``nlambda=2``. The ``ZSplitI`` modifier rquires
``nlambda=1``. Together, ``ZSplitI<StellarCollapse>`` requires a
lambda indexer of length 3, an the ordering is two parameters for
``StellarCollapse`` first, and then the parameter required by
``ZSplitI``.
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved

Preferred Inputs
-----------------

Expand Down
2 changes: 2 additions & 0 deletions singularity-eos/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -57,13 +57,15 @@ register_headers(
eos/modifiers/ramps_eos.hpp
eos/modifiers/shifted_eos.hpp
eos/modifiers/eos_unitsystem.hpp
eos/modifiers/zsplit_eos.hpp
eos/eos_base.hpp
eos/eos_eospac.hpp
eos/eos_noble_abel.hpp
eos/eos_stiff.hpp
eos/singularity_eos_init_utils.hpp
eos/variant_utils.hpp
eos/eos_carnahan_starling.hpp
eos/eos_electrons.hpp
)

if (SINGULARITY_BUILD_CLOSURE)
Expand Down
39 changes: 21 additions & 18 deletions singularity-eos/eos/eos_base.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -66,23 +66,24 @@ char *StrCat(char *destination, const char *source) {
// VECTOR functionality to overload the scalar implementations in the derived
// classes. Do not add functions here that are not overloads of derived class features.
// TODO(JMM): Should we have more macros that capture just some of these?
#define SG_ADD_BASE_CLASS_USINGS(EOSDERIVED) \
using EosBase<EOSDERIVED>::TemperatureFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::InternalEnergyFromDensityTemperature; \
using EosBase<EOSDERIVED>::PressureFromDensityTemperature; \
using EosBase<EOSDERIVED>::PressureFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::MinInternalEnergyFromDensity; \
using EosBase<EOSDERIVED>::SpecificHeatFromDensityTemperature; \
using EosBase<EOSDERIVED>::SpecificHeatFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::BulkModulusFromDensityTemperature; \
using EosBase<EOSDERIVED>::BulkModulusFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::GruneisenParamFromDensityTemperature; \
using EosBase<EOSDERIVED>::GruneisenParamFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::FillEos; \
using EosBase<EOSDERIVED>::EntropyFromDensityTemperature; \
using EosBase<EOSDERIVED>::EntropyFromDensityInternalEnergy; \
using EosBase<EOSDERIVED>::GibbsFreeEnergyFromDensityTemperature; \
using EosBase<EOSDERIVED>::GibbsFreeEnergyFromDensityInternalEnergy;
// JMM: Use VA_ARGS to capture more complex template types
#define SG_ADD_BASE_CLASS_USINGS(...) \
Comment on lines +69 to +70
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The problem here is that preprocessor macros interpret commas as separate arguments. This allows us to pass classes with multiple template arguments through the macro transparently.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice addition!

using EosBase<__VA_ARGS__>::TemperatureFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::InternalEnergyFromDensityTemperature; \
using EosBase<__VA_ARGS__>::PressureFromDensityTemperature; \
using EosBase<__VA_ARGS__>::PressureFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::MinInternalEnergyFromDensity; \
using EosBase<__VA_ARGS__>::SpecificHeatFromDensityTemperature; \
using EosBase<__VA_ARGS__>::SpecificHeatFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::BulkModulusFromDensityTemperature; \
using EosBase<__VA_ARGS__>::BulkModulusFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::GruneisenParamFromDensityTemperature; \
using EosBase<__VA_ARGS__>::GruneisenParamFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::FillEos; \
using EosBase<__VA_ARGS__>::EntropyFromDensityTemperature; \
using EosBase<__VA_ARGS__>::EntropyFromDensityInternalEnergy; \
using EosBase<__VA_ARGS__>::GibbsFreeEnergyFromDensityTemperature; \
using EosBase<__VA_ARGS__>::GibbsFreeEnergyFromDensityInternalEnergy;

// This macro adds these methods to a derived class. Due to scope,
// these can't be implemented in the base class, unless we make
Expand Down Expand Up @@ -111,7 +112,9 @@ char *StrCat(char *destination, const char *source) {
} \
constexpr bool AllDynamicMemoryIsShareable() const { \
return t_.AllDynamicMemoryIsShareable(); \
} \
}

#define SG_ADD_MODIFIER_MEAN_METHODS(t_) \
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

split these out into separate modifier methods in preparation for isotopics.

PORTABLE_INLINE_FUNCTION \
Real MeanAtomicMass() const { return t_.MeanAtomicMass(); } \
PORTABLE_INLINE_FUNCTION \
Expand Down
Loading
Loading