Skip to content

Commit

Permalink
Merge pull request #4536 from isaaclegred/enthalpy_bugfix
Browse files Browse the repository at this point in the history
Fix bug in rootfind for enthalpy parametrization
  • Loading branch information
nilsdeppe authored Dec 20, 2022
2 parents e44a3ce + 2df1957 commit 03d3915
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 2 deletions.
2 changes: 1 addition & 1 deletion src/PointwiseFunctions/Hydro/EquationsOfState/Enthalpy.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -501,7 +501,7 @@ double Enthalpy<LowDensityEoS>::rest_mass_density_from_enthalpy(
const auto x = x_from_density(density);
return evaluate_coefficients(coefficients_, x) - specific_enthalpy;
};
return RootFinder::toms748(f, reference_density_, maximum_density_, 1.0e-14,
return RootFinder::toms748(f, minimum_density_, maximum_density_, 1.0e-14,
1.0e-15);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@

#include "Framework/TestingFramework.hpp"

#include <cmath>
#include <limits>
#include <pup.h>
#include <vector>
Expand All @@ -16,7 +17,6 @@
#include "PointwiseFunctions/Hydro/EquationsOfState/EquationOfState.hpp"
#include "PointwiseFunctions/Hydro/EquationsOfState/Factory.hpp"
#include "PointwiseFunctions/Hydro/SpecificEnthalpy.hpp"

namespace EquationsOfState {
namespace {

Expand Down Expand Up @@ -159,6 +159,30 @@ void check_exact() {
hydro::relativistic_specific_enthalpy(rho, eps, p));
CHECK(get(rho) == approx(get(rho_from_enthalpy)));
}
{
// Guarantee that the root find has the correct bracket by explicitly
// nonsensical there, so if the correct braket
const auto oscillating_eos = Enthalpy<Spectral>{
0.5,
2.0,
1.0,
M_PI/log(2.0),
std::vector<double>{3.5},
std::vector<double>{0.0},
std::vector<double>{0.5},
Spectral{.5, .25, std::vector<double>{2.0}, 1.0},
0.0};
//cos(pi)) = -1, so the enthalpy is just 1 at z=log(2.0),
// which is rho =1.0
// If the rootfinder had the wrong braket z in [0, log(4)] it would
// not find the root bracketed, as cos(0) = 1, cos(log(4)*pi/log(2)) =
// cos(2*pi) = 1, so at these bounds h = 2.0 > 1.25
const Scalar<double> target_enthalpy{3.25};
const Scalar<double> target_rho{pow(2.0, 1.0/3.0)};
const auto rho_from_enthalpy =
oscillating_eos.rest_mass_density_from_enthalpy(target_enthalpy);
CHECK(get(target_rho) == approx(get(rho_from_enthalpy)));
}
// Test bounds
CHECK(0.0 == eos.rest_mass_density_lower_bound());
CHECK(0.0 == eos.specific_internal_energy_lower_bound(1.0));
Expand Down

0 comments on commit 03d3915

Please sign in to comment.