Skip to content

Commit

Permalink
Add VelocityPerturbation option for TovStar
Browse files Browse the repository at this point in the history
  • Loading branch information
shabibti committed May 21, 2024
1 parent b580941 commit 39213c5
Show file tree
Hide file tree
Showing 7 changed files with 75 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -32,15 +32,15 @@ MagnetizedTovStar& MagnetizedTovStar::operator=(MagnetizedTovStar&& /*rhs*/) =
MagnetizedTovStar::~MagnetizedTovStar() = default;

MagnetizedTovStar::MagnetizedTovStar(
const double central_rest_mass_density,
const double central_rest_mass_density, const double velocity_perturbation,
std::unique_ptr<MagnetizedTovStar::equation_of_state_type>
equation_of_state,
const RelativisticEuler::Solutions::TovCoordinates coordinate_system,
std::vector<std::unique_ptr<
grmhd::AnalyticData::InitialMagneticFields::InitialMagneticField>>
magnetic_fields)
: tov_star(central_rest_mass_density, std::move(equation_of_state),
coordinate_system),
: tov_star(central_rest_mass_density, velocity_perturbation,
std::move(equation_of_state), coordinate_system),
magnetic_fields_(std::move(magnetic_fields)) {}

MagnetizedTovStar::MagnetizedTovStar(const MagnetizedTovStar& rhs)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ struct MagnetizedTovVariables
using Base::operator();
using Base::coords;
using Base::eos;
using Base::perturbation;
using Base::radial_solution;
using Base::radius;

Expand All @@ -52,10 +53,12 @@ struct MagnetizedTovVariables
const tnsr::I<DataType, 3>& local_x, const DataType& local_radius,
const RelativisticEuler::Solutions::TovSolution& local_radial_solution,
const EquationsOfState::EquationOfState<true, 1>& local_eos,
const double perturbation,
const std::vector<std::unique_ptr<
grmhd::AnalyticData::InitialMagneticFields::InitialMagneticField>>&
mag_fields)
: Base(local_x, local_radius, local_radial_solution, local_eos),
: Base(local_x, local_radius, local_radial_solution, local_eos,
perturbation),
magnetic_fields(mag_fields) {}

void operator()(
Expand Down Expand Up @@ -145,7 +148,7 @@ class MagnetizedTovStar : public virtual evolution::initial_data::InitialData,
~MagnetizedTovStar() override;

MagnetizedTovStar(
double central_rest_mass_density,
double central_rest_mass_density, double velocity_perturbation,
std::unique_ptr<EquationsOfState::EquationOfState<true, 1>>
equation_of_state,
RelativisticEuler::Solutions::TovCoordinates coordinate_system,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,12 @@ namespace RelativisticEuler::Solutions {
TovStar::TovStar(CkMigrateMessage* msg) : InitialData(msg) {}

TovStar::TovStar(
const double central_rest_mass_density,
const double central_rest_mass_density, const double velocity_perturbation,
std::unique_ptr<EquationsOfState::EquationOfState<true, 1>>
equation_of_state,
const RelativisticEuler::Solutions::TovCoordinates coordinate_system)
: central_rest_mass_density_(central_rest_mass_density),
velocity_perturbation_(velocity_perturbation),
equation_of_state_(std::move(equation_of_state)),
coordinate_system_(coordinate_system),
radial_solution_(*equation_of_state_, central_rest_mass_density_,
Expand All @@ -33,13 +34,15 @@ TovStar::TovStar(
TovStar::TovStar(const TovStar& rhs)
: evolution::initial_data::InitialData(rhs),
central_rest_mass_density_(rhs.central_rest_mass_density_),
velocity_perturbation_(rhs.velocity_perturbation_),
equation_of_state_(rhs.equation_of_state_->get_clone()),
coordinate_system_(rhs.coordinate_system_),
radial_solution_(*equation_of_state_, central_rest_mass_density_,
coordinate_system_) {}

TovStar& TovStar::operator=(const TovStar& rhs) {
central_rest_mass_density_ = rhs.central_rest_mass_density_;
velocity_perturbation_ = rhs.velocity_perturbation_;
equation_of_state_ = rhs.equation_of_state_->get_clone();
coordinate_system_ = rhs.coordinate_system_;
radial_solution_ = RelativisticEuler::Solutions::TovSolution(
Expand All @@ -55,6 +58,7 @@ std::unique_ptr<evolution::initial_data::InitialData> TovStar::get_clone()
void TovStar::pup(PUP::er& p) {
InitialData::pup(p);
p | central_rest_mass_density_;
p | velocity_perturbation_;
p | equation_of_state_;
p | coordinate_system_;
p | radial_solution_;
Expand Down Expand Up @@ -514,11 +518,23 @@ void TovVariables<DataType, Region>::operator()(
template <typename DataType, StarRegion Region>
void TovVariables<DataType, Region>::operator()(
const gsl::not_null<tnsr::I<DataType, 3>*> spatial_velocity,
const gsl::not_null<Cache*> /*cache*/,
const gsl::not_null<Cache*> cache,
hydro::Tags::SpatialVelocity<DataType, 3> /*meta*/) const {
get<0>(*spatial_velocity) = 0.;
get<1>(*spatial_velocity) = 0.;
get<2>(*spatial_velocity) = 0.;
if constexpr (Region == StarRegion::Center or
Region == StarRegion::Exterior) {
get<0>(*spatial_velocity) = 0.;
get<1>(*spatial_velocity) = 0.;
get<2>(*spatial_velocity) = 0.;
} else {
const auto& areal_radius =
radial_solution.coordinate_system() ==
RelativisticEuler::Solutions::TovCoordinates::Isotropic
? get(cache->get_var(*this, Tags::ArealRadius<DataType>{}))
: radius;
get<0>(*spatial_velocity) = perturbation * coords.get(0) / areal_radius;
get<1>(*spatial_velocity) = perturbation * coords.get(1) / areal_radius;
get<2>(*spatial_velocity) = perturbation * coords.get(2) / areal_radius;
}
}

template <typename DataType, StarRegion Region>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -139,16 +139,19 @@ struct TovVariables {
TovVariables(
const tnsr::I<DataType, 3>& local_coords, const DataType& local_radius,
const RelativisticEuler::Solutions::TovSolution& local_radial_solution,
const EquationsOfState::EquationOfState<true, 1>& local_eos)
const EquationsOfState::EquationOfState<true, 1>& local_eos,
const double perturb)
: coords(local_coords),
radius(local_radius),
radial_solution(local_radial_solution),
eos(local_eos) {}
eos(local_eos),
perturbation(perturb) {}

const tnsr::I<DataType, 3>& coords;
const DataType& radius;
const RelativisticEuler::Solutions::TovSolution& radial_solution;
const EquationsOfState::EquationOfState<true, 1>& eos;
const double perturbation;

void operator()(gsl::not_null<Scalar<DataType>*> mass_over_radius,
gsl::not_null<Cache*> cache,
Expand Down Expand Up @@ -336,6 +339,13 @@ class TovStar : public virtual evolution::initial_data::InitialData,
static type lower_bound() { return 0.; }
};

struct VelocityPerturbation {
using type = double;
static constexpr Options::String help = {
"Magnitude of radially symmetric velocity perturbation for driving "
"oscillations."};
};

/// Areal (Schwarzschild) or isotropic coordinates
struct Coordinates {
using type = RelativisticEuler::Solutions::TovCoordinates;
Expand All @@ -346,7 +356,7 @@ class TovStar : public virtual evolution::initial_data::InitialData,
static constexpr size_t volume_dim = 3_st;

using options =
tmpl::list<CentralDensity,
tmpl::list<CentralDensity, VelocityPerturbation,
hydro::OptionTags::InitialDataEquationOfState<true, 1>,
Coordinates>;

Expand All @@ -361,7 +371,7 @@ class TovStar : public virtual evolution::initial_data::InitialData,
TovStar(TovStar&& /*rhs*/) = default;
TovStar& operator=(TovStar&& /*rhs*/) = default;
~TovStar() override = default;
TovStar(double central_rest_mass_density,
TovStar(double central_rest_mass_density, double velocity_perturbation,
std::unique_ptr<EquationsOfState::EquationOfState<true, 1>>
equation_of_state,
const RelativisticEuler::Solutions::TovCoordinates coordinate_system =
Expand Down Expand Up @@ -420,7 +430,11 @@ class TovStar : public virtual evolution::initial_data::InitialData,
VarsComputer<DataType, tov_detail::StarRegion::Exterior>;
typename ExteriorVarsComputer::Cache cache{get_size(radius)};
ExteriorVarsComputer computer{
x, radius, radial_solution_, *equation_of_state_,
x,
radius,
radial_solution_,
*equation_of_state_,
velocity_perturbation_,
std::forward<VarsComputerArgs>(vars_computer_args)...};
return {cache.get_var(computer, Tags{})...};
} else if (max(radius) <= outer_radius and
Expand All @@ -430,7 +444,11 @@ class TovStar : public virtual evolution::initial_data::InitialData,
VarsComputer<DataType, tov_detail::StarRegion::Interior>;
typename InteriorVarsComputer::Cache cache{get_size(radius)};
InteriorVarsComputer computer{
x, radius, radial_solution_, *equation_of_state_,
x,
radius,
radial_solution_,
*equation_of_state_,
velocity_perturbation_,
std::forward<VarsComputerArgs>(vars_computer_args)...};
return {cache.get_var(computer, Tags{})...};
} else {
Expand Down Expand Up @@ -472,22 +490,31 @@ class TovStar : public virtual evolution::initial_data::InitialData,
if (get_element(radius, i) > outer_radius) {
typename ExteriorVarsComputer::Cache cache{1};
ExteriorVarsComputer computer{
x_i, get_element(radius, i), radial_solution_,
x_i,
get_element(radius, i),
radial_solution_,
*equation_of_state_,
velocity_perturbation_,
std::forward<VarsComputerArgs>(vars_computer_args)...};
expand_pack(get_var(i, cache, computer, Tags{})...);
} else if (get_element(radius, i) > center_radius_cutoff) {
typename InteriorVarsComputer::Cache cache{1};
InteriorVarsComputer computer{
x_i, get_element(radius, i), radial_solution_,
x_i,
get_element(radius, i),
radial_solution_,
*equation_of_state_,
velocity_perturbation_,
std::forward<VarsComputerArgs>(vars_computer_args)...};
expand_pack(get_var(i, cache, computer, Tags{})...);
} else {
typename CenterVarsComputer::Cache cache{1};
CenterVarsComputer computer{
x_i, get_element(radius, i), radial_solution_,
x_i,
get_element(radius, i),
radial_solution_,
*equation_of_state_,
velocity_perturbation_,
std::forward<VarsComputerArgs>(vars_computer_args)...};
expand_pack(get_var(i, cache, computer, Tags{})...);
}
Expand Down Expand Up @@ -521,6 +548,7 @@ class TovStar : public virtual evolution::initial_data::InitialData,

double central_rest_mass_density_ =
std::numeric_limits<double>::signaling_NaN();
double velocity_perturbation_ = std::numeric_limits<double>::signaling_NaN();
std::unique_ptr<equation_of_state_type> equation_of_state_;
RelativisticEuler::Solutions::TovCoordinates coordinate_system_{};
RelativisticEuler::Solutions::TovSolution radial_solution_{};
Expand Down
6 changes: 3 additions & 3 deletions src/PointwiseFunctions/AnalyticSolutions/Xcts/TovStar.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -195,12 +195,12 @@ class TovStar : public elliptic::analytic_data::AnalyticSolution {
TovStar& operator=(TovStar&&) = default;
~TovStar() = default;

TovStar(double central_rest_mass_density,
TovStar(double central_rest_mass_density, double velocity_perturbation,
std::unique_ptr<EquationsOfState::EquationOfState<true, 1>>
equation_of_state,
const RelativisticEuler::Solutions::TovCoordinates coordinate_system)
: tov_star(central_rest_mass_density, std::move(equation_of_state),
coordinate_system) {}
: tov_star(central_rest_mass_density, velocity_perturbation,
std::move(equation_of_state), coordinate_system) {}

const EquationsOfState::EquationOfState<true, 1>& equation_of_state() const {
return tov_star.equation_of_state();
Expand Down
5 changes: 3 additions & 2 deletions tests/Unit/Elliptic/Systems/Xcts/Test_HydroQuantities.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@
#include "PointwiseFunctions/AnalyticSolutions/Xcts/Factory.hpp"
#include "PointwiseFunctions/AnalyticSolutions/Xcts/TovStar.hpp"
#include "PointwiseFunctions/Hydro/EquationsOfState/PolytropicFluid.hpp"
#include "PointwiseFunctions/Hydro/Tags.hpp"
#include "PointwiseFunctions/Hydro/LowerSpatialFourVelocity.hpp"
#include "PointwiseFunctions/Hydro/Tags.hpp"
#include "PointwiseFunctions/InitialDataUtilities/AnalyticSolution.hpp"
#include "PointwiseFunctions/InitialDataUtilities/Background.hpp"
#include "Utilities/ProtocolHelpers.hpp"
Expand Down Expand Up @@ -47,7 +47,8 @@ SPECTRE_TEST_CASE("Unit.Elliptic.Systems.Xcts.HydroQuantities",
using hydro_tags = AnalyticData::hydro_tags<DataVector>;
using spatial_metric_tag = gr::Tags::SpatialMetric<DataVector, 3>;
const Solutions::TovStar tov_star{
1.e-3, std::make_unique<EquationsOfState::PolytropicFluid<true>>(1., 2.),
1.e-3, 0.0,
std::make_unique<EquationsOfState::PolytropicFluid<true>>(1., 2.),
RelativisticEuler::Solutions::TovCoordinates::Schwarzschild};
const double outer_radius = tov_star.radial_solution().outer_radius();
const tnsr::I<DataVector, 3> x{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ void test_tov_star(const TovCoordinates coord_system) {
RelativisticEuler::Solutions::TovStar>(
"TovStar:\n"
" CentralDensity: 1.0e-3\n"
" VelocityPerturbation: 0.0\n"
" EquationOfState:\n"
" PolytropicFluid:\n"
" PolytropicConstant: 100.0\n"
Expand All @@ -92,7 +93,7 @@ void test_tov_star(const TovCoordinates coord_system) {
{
INFO("Semantics");
CHECK(solution ==
TovStar{1.0e-3,
TovStar{1.0e-3, 0,
std::make_unique<EquationsOfState::PolytropicFluid<true>>(
100.0, 2.0),
coord_system});
Expand All @@ -110,7 +111,7 @@ void test_tov_star(const TovCoordinates coord_system) {
custom_approx(10.0473500683));
// Check a second solution
TovStar second_solution{
1.0e-3,
1.0e-3, 0,
std::make_unique<EquationsOfState::PolytropicFluid<true>>(8.0, 2.0)};
CHECK(second_solution.radial_solution().outer_radius() ==
custom_approx(3.4685521362));
Expand Down

0 comments on commit 39213c5

Please sign in to comment.