8#include <compile_time_options.h>
14 namespace EquationOfStateLibrary
33 this->add_parameter(
"gamma", gamma_,
"The ratio of specific heats");
36 this->add_parameter(
"vdw a", a_,
"The vdw a constant");
40 "covolume b", b_,
"The maximum compressibility constant");
49 "gas constant R", R_,
"The specific gas constant R");
51 cv_ = R_ / (gamma_ - 1.);
54 ParameterAcceptor::parse_parameters_call_back.connect([
this] {
70 double pressure(
double rho,
double e)
const final
72 const auto intermolecular = a_ * rho * rho;
73 const auto numerator = rho * e + intermolecular;
74 const auto covolume = 1. - b_ * rho;
75 return (gamma_ - 1.) * numerator / covolume - intermolecular;
87 const auto intermolecular = a_ * rho * rho;
88 const auto covolume = 1. - b_ * rho;
89 const auto numerator = (p + intermolecular) * covolume;
90 const auto denominator = rho * (gamma_ - 1.);
91 return numerator / denominator - a_ * rho;
102 return (e + a_ * rho) / cv_;
114 const auto covolume = 1. - b_ * rho;
115 const auto numerator = gamma_ * (gamma_ - 1.) * (e + a_ * rho);
116 return std::sqrt(numerator / (covolume * covolume) - 2. * a_ * rho);
virtual double specific_internal_energy(double rho, double p) const =0
virtual double pressure(double rho, double e) const =0
virtual double speed_of_sound(double rho, double e) const =0
virtual double temperature(double rho, double e) const =0
VanDerWaals(const std::string &subsection)
double temperature(double rho, double e) const final
double pressure(double rho, double e) const final
double speed_of_sound(double rho, double e) const final
double specific_internal_energy(double rho, double p) const final