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

Add general entropy functionality to EOS #233

Merged
merged 50 commits into from
Mar 16, 2023
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
45ee5d6
Add sublime text and Mac OSX filesystem things to the gitignore
jhp-lanl Feb 16, 2023
2228efb
Remove commented code, add vector entropy functions, and add a defaul…
jhp-lanl Feb 16, 2023
f408ec5
Add entropy functions to variant
jhp-lanl Feb 16, 2023
a444167
Add section on complete EOS and the beginnings of documentation for e…
jhp-lanl Feb 16, 2023
e3a9c88
Merge branch 'main' of github.com:lanl/singularity-eos into jhp/entropy
jhp-lanl Feb 16, 2023
2d615d2
Finalize entropy documentation
jhp-lanl Feb 16, 2023
d2110d6
Add entropy to the ideal gas
jhp-lanl Feb 16, 2023
5b4be78
Add EntropyIsNotEnabled to default using statements
jhp-lanl Feb 16, 2023
a561bd0
Disable entropy in other EOS for the time being
jhp-lanl Feb 16, 2023
7c98861
Add entropy to unitsystem modifier
jhp-lanl Feb 17, 2023
be3e658
Add Helmholtz explanation for scaling ratios that leads to entropy sc…
jhp-lanl Feb 17, 2023
44a9529
Add basic, unmodified, entropy lookups for ramps and relativistic mod…
jhp-lanl Feb 17, 2023
234a34c
Add entropy lookups with shifted energies
jhp-lanl Feb 17, 2023
3d94fc9
Apply scaling ratio to entropy output
jhp-lanl Feb 17, 2023
a5cdf7c
Move note and add one to Vinet on divergent entropy
jhp-lanl Feb 17, 2023
eff8b4d
Reorganize changelog
jhp-lanl Feb 17, 2023
25c8d46
Update changelog for entropy additions
jhp-lanl Feb 17, 2023
3b2ffdc
Whoops... cmath
jhp-lanl Feb 17, 2023
05e7bf9
Fix typos and compile-time bugs
jhp-lanl Feb 18, 2023
e8b6db5
Merge branch 'main' of github.com:lanl/singularity-eos into jhp/entropy
jhp-lanl Feb 27, 2023
bf800ba
Merge branch 'jhp/update_ports_of_call' of github.com:lanl/singularit…
jhp-lanl Feb 27, 2023
6d35286
Add scratch versions of entropy functions to base class
jhp-lanl Feb 27, 2023
b7ae939
Ports of call update reverses condition to be more appropriate
jhp-lanl Feb 27, 2023
8c65f1f
Fix a few typos when resolving merge conflicts
jhp-lanl Feb 27, 2023
d76d0f9
Fix extra template parameter
jhp-lanl Feb 28, 2023
3d019ad
clang format
jhp-lanl Feb 28, 2023
bc96b66
Fix typo in ideal gas entropy lookup
jhp-lanl Feb 28, 2023
e9c052a
Merge branch 'main' of github.com:lanl/singularity-eos into jhp/entropy
jhp-lanl Feb 28, 2023
f19c783
Merge branch 'jhp/entropy' of github.com:lanl/singularity-eos into jh…
jhp-lanl Feb 28, 2023
89f07d3
Add base class usings for entropy vector lookups
jhp-lanl Feb 28, 2023
665174e
Add base class usings to modifiers
jhp-lanl Feb 28, 2023
408226e
Just kidding... this already had the usings
jhp-lanl Feb 28, 2023
818a495
Add base class usings for entropy
jhp-lanl Feb 28, 2023
f5cafe9
Needed to add a S(rho,e) method for stellar collapse because there wa…
jhp-lanl Feb 28, 2023
240198c
Add default error messages for JWL and Davis when accessing entropy (…
jhp-lanl Feb 28, 2023
1a1df04
Add basic test for ideal gas entropy
jhp-lanl Feb 28, 2023
a5ea8ec
Add scalar test for ideal gas entropy at key values
jhp-lanl Feb 28, 2023
5e5ca0b
Add test of the entropy error in the Gruneisen EOS
jhp-lanl Feb 28, 2023
743d1dc
clang format
jhp-lanl Feb 28, 2023
4c3d2ae
Update ports-of-call in the package.py to update the version in the g…
jhp-lanl Feb 28, 2023
8382c4b
Change the EntropyIsNotEnabled() function to use char and remove type…
jhp-lanl Mar 1, 2023
7c2452b
Fix some warnings
jhp-lanl Mar 1, 2023
2f985bb
Add some footnotes and update the Davis EOS
jhp-lanl Mar 1, 2023
411cec6
Remove constexpr to satisfy power9 compiler
jhp-lanl Mar 1, 2023
3fc6125
clang format
jhp-lanl Mar 1, 2023
e220b75
Add `std` namespace to srcat calls
jhp-lanl Mar 1, 2023
5b894e0
Update language on P-T inversion to note spiner exception
jhp-lanl Mar 1, 2023
8c870ce
Only run exception test when portability strategy is none
jhp-lanl Mar 1, 2023
6497055
Fix merge conflicts in changelog
jhp-lanl Mar 16, 2023
4655c06
Cite Ann's reference
jhp-lanl Mar 16, 2023
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
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,6 @@ utils/variant
cmake-gen*
spack-build-*
spack-configure-*
._*
*.sublime*
jhp-lanl marked this conversation as resolved.
Show resolved Hide resolved

14 changes: 5 additions & 9 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,28 +2,24 @@

## Current develop

### Fixed (Repair, bugs, ect)
- [[PR232]](https://github.com/lanl/singularity-eos/pull/228) Fixed uninitialized cmake path variables

### Fixed (issue #227)
- [[PR228]](https://github.com/lanl/singularity-eos/pull/228) and [[PR229]](https://github.com/lanl/singularity-eos/pull/229) added untracked header files in cmake

### Added (entropy calculation for stellar collapse eos)
- [[PR226]](https://github.com/lanl/singularity-eos/pull/226) added entropy interpolation to stellar collapse eos

### Fixed (Repair bugs, etc)
jhp-lanl marked this conversation as resolved.
Show resolved Hide resolved
- [[PR228]](https://github.com/lanl/singularity-eos/pull/228) added untracked header files in cmake
- [[PR215]](https://github.com/lanl/singularity-eos/pull/215) and [[PR216]](https://github.com/lanl/singularity-eos/pull/216) fix duplicate definition of EPS and fix CI
- [[PR232]](https://github.com/lanl/singularity-eos/pull/228) Fixed uninitialized cmake path variables

### Added (new features/APIs/variables/...)
- [[PR202]](https://github.com/lanl/singularity-eos/pull/202) added the Vinet analytical EOS wth test cases and documentation.
- [[PR226]](https://github.com/lanl/singularity-eos/pull/226) added entropy interpolation to stellar collapse eos
- [[PR209]](https://github.com/lanl/singularity-eos/pull/209) added more documentation around how to contribute to the project and also what a contributor can expect from the core team
- [[PR214]](https://github.com/lanl/singularity-eos/pull/214) added documentation about adding a new EOS
- [[PR226]](https://github.com/lanl/singularity-eos/pull/226) added entropy interpolation to stellar collapse eos
- [[PR228]](https://github.com/lanl/singularity-eos/pull/228) and [[PR229]](https://github.com/lanl/singularity-eos/pull/229) added untracked header files in cmake
- [[PR233]](https://github.com/lanl/singularity-eos/pull/233) Added entropy for the ideal gas and modifiers and an error for EOS where entropy is not implemented yet

### Changed (changing behavior/API/variables/...)
- [[PR223]](https://github.com/lanl/singularity-eos/pull/223) Update ports-of-call and add portable error handling
- [[PR219]](https://github.com/lanl/singularity-eos/pull/219) Removed static analysis from re-git pipeline
- [[PR233]](https://github.com/lanl/singularity-eos/pull/233) Exposed entropy for the EOS type (now required for future EOS)

### Infrastructure (changes irrelevant to downstream codes)
- [[PR190]](https://github.com/lanl/singularity-eos/pull/190) update CI on re-git
Expand Down
395 changes: 319 additions & 76 deletions doc/sphinx/src/models.rst

Large diffs are not rendered by default.

39 changes: 38 additions & 1 deletion doc/sphinx/src/modifiers.rst
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,44 @@ energy. The pressure is unchanged under the operation

for some scale parameter :math:`s`. The ``ScaledEOS`` applies this
transformation to any equation of state, not just an ideal gas, where
the pressure may change.
the pressure may change for different scaling ratios.

Another way of understanding scaling ratios is that the pressure can be written
as

.. math::

P = \left(\frac{\partial F}{\partial V} \right)_T

where :math:`F` is the Helmholtz free energy. For a given scaling such that
:math:`\rho_\mathrm{eos} = s\rho_\mathrm{in}`, the volume obeys the inverse
scaling. Since the scaling ratio is constant, it can be substituted into the
above expression so that

.. math::

P = \left(\frac{\partial F_\mathrm{eos}}{\partial V_\mathrm{eos}} \right)_T
= \left(\frac{\partial F_\mathrm{in}}{\partial V_\mathrm{in}} \right)_T
= \left(\frac{\partial F_\mathrm{in}}{s \partial V_\mathrm{eos}} \right)_T
= \left(\frac{s\partial F_\mathrm{eos}}{s \partial V_\mathrm{eos}} \right)_T

which implies that the Helmholtz free energy must scale in the same way as
volume (inverse to density) in order to preserve the same pressure. Applying
this scaling to the definition of the Helmholtz free energy yields

.. math::

F_\mathrm{eos} = e_\mathrm{eos} - TS_\mathrm{eos} = \frac{1}{R} F_\mathrm{in}
= \frac{1}{R}e_\mathrm{in} - T\left(\frac{1}{R}S_\mathrm{in}\right),

where the implicaiton is that this inverse the scaling ratio should also be
applied to energy. The inverse scaling ratio must be applied to the entropy
here in order to ensure that all other thermodynamic potentials
(energy, entropy, and the Gibbs free energy) scale similarly.

where :math:`e` is the internal energy and :math:`S` is the entropy. The
implication is that the same scaling should be applied to the energy and entropy
to maintain thermodynamic consistency.

The constructor for ``ScaledEOS`` accepts the underlying model, and
the scale parameter. For example, a shifted ideal gas might be
Expand Down
104 changes: 40 additions & 64 deletions singularity-eos/eos/eos_base.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
#include <string>

#include <ports-of-call/portability.hpp>
#include <ports-of-call/portable_errors.hpp>

namespace singularity {
namespace mfuncname {
Expand Down Expand Up @@ -50,7 +51,10 @@ namespace eos_base {
using EosBase<EOSDERIVED>::MinimumDensity; \
using EosBase<EOSDERIVED>::MinimumTemperature; \
using EosBase<EOSDERIVED>::PTofRE; \
using EosBase<EOSDERIVED>::FillEos;
using EosBase<EOSDERIVED>::FillEos; \
using EosBase<EOSDERIVED>::EntropyFromDensityTemperature; \
using EosBase<EOSDERIVED>::EntropyFromDensityEnergy; \
using EosBase<EOSDERIVED>::EntropyIsNotEnabled;

/*
This is a CRTP that allows for static inheritance so that default behavior for
Expand Down Expand Up @@ -121,6 +125,34 @@ class EosBase {
});
}
template <typename RealIndexer, typename ConstRealIndexer, typename LambdaIndexer>
inline void EntropyFromDensityTemperature(ConstRealIndexer &&rhos,
ConstRealIndexer &&temperatures,
RealIndexer &&entropies, const int num,
LambdaIndexer &&lambdas) const {
static auto const name = SG_MEMBER_FUNC_NAME();
static auto const cname = name.c_str();
CRTP copy = *(static_cast<CRTP const *>(this));
portableFor(
cname, 0, num, PORTABLE_LAMBDA(const int i) {
entropies[i] =
copy.EntropyFromDensityTemperature(rhos[i], temperatures[i], lambdas[i]);
});
}
template <typename RealIndexer, typename ConstRealIndexer, typename LambdaIndexer>
inline void EntropyFromDensityInternalEnergy(ConstRealIndexer &&rhos,
ConstRealIndexer &&sies,
RealIndexer &&entropies, const int num,
LambdaIndexer &&lambdas) const {
static auto const name = SG_MEMBER_FUNC_NAME();
static auto const cname = name.c_str();
CRTP copy = *(static_cast<CRTP const *>(this));
portableFor(
cname, 0, num, PORTABLE_LAMBDA(const int i) {
entropies[i] =
copy.EntropyFromDensityInternalEnergy(rhos[i], sies[i], lambdas[i]);
});
}
template <typename RealIndexer, typename ConstRealIndexer, typename LambdaIndexer>
inline void SpecificHeatFromDensityTemperature(ConstRealIndexer &&rhos,
ConstRealIndexer &&temperatures,
RealIndexer &&cvs, const int num,
Expand Down Expand Up @@ -264,69 +296,13 @@ class EosBase {
PORTABLE_INLINE_FUNCTION
Real RhoPmin(const Real temp) const { return 0.0; }

// Specialzied vector version of PTofRE maybe more suited for EOSPAC
// }
// template<typename RealIndexer, typename LambdaIndexer>
// inline
// void PTofRE(RealIndexer &&rhos, RealIndexer &&sies,
// RealIndexer &&presses, RealIndexer &&temps,
// RealIndexer &&dpdrs, RealIndexer &&dpdes,
// RealIndexer &&dtdrs, RealIndexer &&dtdes,
// const int num, LambdaIndexer &&lambdas) const {
// // Get the dervived class
// auto eos = static_cast<CRTP const&>(*this);

// // Lookup at density and energy
// eos.PressureFromDensityInternalEnergy(rhos, sies, num, presses,
// lambdas);
// eos.TemperatureFromDensityInternalEnergy(rhos, sies, num, temps,
// lambdas);
// // Peturbation factor
// Real factor = 1. + 1.0e-06;

// // Perturb densities and do lookups
// portableFor(
// 'PerturbDensities', 0, num, PORTABLE_LAMBDA(const int i) {
// rhos[i] *= factor;
// }
// );
// eos.PressureFromDensityInternalEnergy(rhos, sies, num, dpdrs,
// lambdas);
// eos.TemperatureFromDensityInternalEnergy(rhos, sies, num, dtdrs,
// lambdas);

// // Reset densities, perturb energies, and do lookups
// portableFor(
// 'PerturbEnergiesResetDensities', 0, num,
// PORTABLE_LAMBDA(const int i) {
// sies[i] *= factor;
// rhos[i] /= factor;
// }
// );
// eos.PressureFromDensityInternalEnergy(rhos, sies, dpdes, num,
// lambdas);
// eos.TemperatureFromDensityInternalEnergy(rhos, sies, dtdes, num,
// lambdas);

// // Reset the energies to their original values
// portableFor(
// 'ResetEnergies', 0, num, PORTABLE_LAMBDA(const int i) {
// sies[i] /= factor;
// }
// );

// // Calculate the derivatives
// portableFor(
// 'CalculateDerivatives', 0., num, PORTABLE_LAMBDA(const int i) {
// dpdrs[i] = (dpdrs[i] - presses[i]) / (rhos[i] * (1. - factor));
// dpdes[i] = (dpdes[i] - presses[i]) / (sies[i] * (1. - factor));
// dtdrs[i] = (dtdrs[i] - temps[i]) / (rhos[i] * (1. - factor));
// dtdes[i] = (dtdes[i] - temps[i]) / (sies[i] * (1. - factor));
// }
// );

// return;
// }
// Default entropy behavior is to return an error
[[noreturn]] PORTABLE_FORCE_INLINE_FUNCTION
jhp-lanl marked this conversation as resolved.
Show resolved Hide resolved
void EntropyIsNotEnabled() const {
PORTABLE_ALWAYS_THROW_OR_ABORT(std::string("Entropy is not enabled for the '") +
std::string(typeid(CRTP).name()) +
std::string("' EOS"));
}
};
} // namespace eos_base
} // namespace singularity
Expand Down
10 changes: 10 additions & 0 deletions singularity-eos/eos/eos_davis.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,16 @@ class DavisReactants : public EosBase<DavisReactants> {
const Real rho, const Real sie, Real *lambda = nullptr) const {
return Ps(rho) + Gamma(rho) * rho * (sie - Es(rho));
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const {
EntropyIsNotEnabled();
return 1.0
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const {
EntropyIsNotEnabled();
return 1.0
}
Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
PORTABLE_INLINE_FUNCTION Real SpecificHeatFromDensityTemperature(
const Real rho, const Real temp, Real *lambda = nullptr) const {
return SpecificHeatFromDensityInternalEnergy(
Expand Down
15 changes: 15 additions & 0 deletions singularity-eos/eos/eos_eospac.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,8 @@ class EOSPAC : public EosBase<EOSPAC> {
using EosBase<EOSPAC>::InternalEnergyFromDensityTemperature;
using EosBase<EOSPAC>::PressureFromDensityTemperature;
using EosBase<EOSPAC>::PressureFromDensityInternalEnergy;
using EosBase<EOSPAC>::EntropyFromDensityTemperature;
using EosBase<EOSPAC>::EntropyFromDensityInternalEnergy;
using EosBase<EOSPAC>::SpecificHeatFromDensityTemperature;
using EosBase<EOSPAC>::SpecificHeatFromDensityInternalEnergy;
using EosBase<EOSPAC>::BulkModulusFromDensityTemperature;
Expand All @@ -89,6 +91,7 @@ class EOSPAC : public EosBase<EOSPAC> {
using EosBase<EOSPAC>::GruneisenParamFromDensityInternalEnergy;
using EosBase<EOSPAC>::PTofRE;
using EosBase<EOSPAC>::FillEos;
using EosBase<EOSPAC>::EntropyIsNotEnabled;

// TODO (JHP): Change EOSPAC vector implementations to be more performant
// template<typename RealIndexer, typename ConstRealIndexer, typename LambdaIndexer>
Expand Down Expand Up @@ -273,6 +276,12 @@ PORTABLE_INLINE_FUNCTION Real EOSPAC::PressureFromDensityTemperature(const Real
return Real(pressureFromSesame(P[0]));
}

PORTABLE_INLINE_FUNCTION Real EOSPAC::EntropyFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const {
EntropyIsNotEnabled();
return 1.0
}

Yurlungur marked this conversation as resolved.
Show resolved Hide resolved
PORTABLE_INLINE_FUNCTION void EOSPAC::FillEos(Real &rho, Real &temp, Real &sie,
Real &press, Real &cv, Real &bmod,
const unsigned long output,
Expand Down Expand Up @@ -386,6 +395,12 @@ PORTABLE_INLINE_FUNCTION Real EOSPAC::PressureFromDensityInternalEnergy(
Real temp = TemperatureFromDensityInternalEnergy(rho, sie, lambda);
return PressureFromDensityTemperature(rho, temp, lambda);
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const {
using namespace EospacWrapper;
const Real temp = TemperatureFromDensityInternalEnergy(rho, sie, lambda);
return EntropyFromDensityTemperature(rho, temp, lambda);
}
PORTABLE_INLINE_FUNCTION Real EOSPAC::SpecificHeatFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda) const {
using namespace EospacWrapper;
Expand Down
16 changes: 16 additions & 0 deletions singularity-eos/eos/eos_gruneisen.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,10 @@ class Gruneisen : public EosBase<Gruneisen> {
const Real rho, const Real temperature, Real *lambda = nullptr) const;
PORTABLE_INLINE_FUNCTION Real PressureFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const;
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const;
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const;
PORTABLE_INLINE_FUNCTION Real SpecificHeatFromDensityTemperature(
const Real rho, const Real temperatummmmmmre, Real *lambda = nullptr) const {
return _Cv;
Expand Down Expand Up @@ -306,6 +310,12 @@ PORTABLE_INLINE_FUNCTION Real Gruneisen::PressureFromDensityInternalEnergy(
}
return P_H + Gamma(rho) * rho * (sie - E_H);
}
PORTABLE_INLINE_FUNCTION Real Gruneisen::EntropyFromDensityInternalEnergy(
const Real rho_in, const Real sie, Real *lambda) const {
const Real rho = std::min(rho_in, _rho_max);
EntropyIsNotEnabled();
return 1.0;
}
PORTABLE_INLINE_FUNCTION Real Gruneisen::BulkModulusFromDensityInternalEnergy(
const Real rho_in, const Real sie, Real *lambda) const {
using namespace gruneisen_utils;
Expand All @@ -328,6 +338,12 @@ PORTABLE_INLINE_FUNCTION Real Gruneisen::PressureFromDensityTemperature(
return PressureFromDensityInternalEnergy(
rho, InternalEnergyFromDensityTemperature(rho, temp));
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityTemperature(
const Real rho_in, const Real sie, Real *lambda = nullptr) const {
const Real rho = std::min(rho_in, _rho_max);
const Real sie = InternalEnergyFromDensityTemperature(rho, temp);
return EntropyFromDensityInternalEnergy(rho, sie);
}
PORTABLE_INLINE_FUNCTION Real Gruneisen::BulkModulusFromDensityTemperature(
const Real rho_in, const Real temp, Real *lambda) const {
const Real rho = std::min(rho_in, _rho_max);
Expand Down
41 changes: 39 additions & 2 deletions singularity-eos/eos/eos_ideal.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,15 @@
#include <cmath>
#include <cstdio>
#include <string>
#include <cmath>

// Ports-of-call
#include <ports-of-call/portability.hpp>

// Base stuff
#include <singularity-eos/base/constants.hpp>
#include <singularity-eos/base/eos_error.hpp>
#include <singularity-eos/base/robust_utils.hpp>
#include <singularity-eos/eos/eos_base.hpp>

#define MYMAX(a, b) a > b ? a : b
Expand All @@ -40,13 +42,36 @@ class IdealGas : public EosBase<IdealGas> {
PORTABLE_INLINE_FUNCTION IdealGas(Real gm1, Real Cv)
: _Cv(Cv), _gm1(gm1), _rho0(_P0 / (_gm1 * _Cv * _T0)), _sie0(_Cv * _T0),
_bmod0((_gm1 + 1) * _gm1 * _rho0 * _Cv * _T0), _dpde0(_gm1 * _rho0),
_dvdt0(1. / (_rho0 * _T0)) {}
_dvdt0(1. / (_rho0 * _T0)), _EntropyT0(_T0),
_EntropyRho0(_rho0)
{
checkParams();
}
PORTABLE_INLINE_FUNCTION IdealGas(Real gm1, Real Cv, Real EntropyT0,
Real EntropyRho0)
: _Cv(Cv), _gm1(gm1), _rho0(_P0 / (_gm1 * _Cv * _T0)), _sie0(_Cv * _T0),
_bmod0((_gm1 + 1) * _gm1 * _rho0 * _Cv * _T0), _dpde0(_gm1 * _rho0),
_dvdt0(1. / (_rho0 * _T0)), _EntropyT0(EntropyT0),
_EntropyRho0(EntropyRho0)
{
checkInputs();
}

IdealGas GetOnDevice() { return *this; }
IdealGas GetOnDevice() {
return *this;
}
PORTABLE_INLINE_FUNCTION Real TemperatureFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const {
return MYMAX(0.0, sie / _Cv);
}
PORTABLE_INLINE_FUNCTION void checkParams() const {
// Portable_require seems to do the opposite of what it should. Conditions
// reflect this and the code should be changed when ports-of-call changes
PORTABLE_ALWAYS_REQUIRE(_Cv <= 0, "Heat capacity must be positive");
PORTABLE_ALWAYS_REQUIRE(_gm1 <= 0);
PORTABLE_ALWAYS_REQUIRE(_EntropyT0 <= 0);
PORTABLE_ALWAYS_REQUIRE(_EntropyRho0 <= 0);
}
PORTABLE_INLINE_FUNCTION Real InternalEnergyFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const {
return MYMAX(0.0, _Cv * temperature);
Expand All @@ -59,6 +84,16 @@ class IdealGas : public EosBase<IdealGas> {
const Real rho, const Real sie, Real *lambda = nullptr) const {
return MYMAX(0.0, _gm1 * rho * sie);
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const {
return _Cv * log(robust::ratio(temperature, _EntropyT0)) +
_gm1 * _Cv * log(robust::ratio(_EntropyRho0, density));
}
PORTABLE_INLINE_FUNCTION Real EntropyFromDensityInternalEnergy(
const Real rho, const Real sie, Real *lambda = nullptr) const {
const Real temp = TemperatureFromDensityInternalEnergy(rho, sie, lambda);
return EntropyFromDensityTemperature(rho, sie, lambda);
}
PORTABLE_INLINE_FUNCTION Real SpecificHeatFromDensityTemperature(
const Real rho, const Real temperature, Real *lambda = nullptr) const {
return _Cv;
Expand Down Expand Up @@ -128,6 +163,8 @@ class IdealGas : public EosBase<IdealGas> {
// static constexpr const char _eos_type[] = {"IdealGas"};
static constexpr const unsigned long _preferred_input =
thermalqs::density | thermalqs::specific_internal_energy;
// optional entropy reference state variables
Real _EntropyT0, _EntropyRho0;
};

PORTABLE_INLINE_FUNCTION
Expand Down
Loading