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

address rotation source in spherical 2d coordinate #2967

Merged
merged 22 commits into from
Dec 20, 2024
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
e2df70a
update get_omega to be compatible with spherical2d and the correspond…
zhichen3 Sep 25, 2024
0cfb603
rename omega_vec to omega
zhichen3 Sep 25, 2024
3ea85c8
make sure position vector in cross product is (r,0,0)
zhichen3 Sep 25, 2024
bc129b3
separate out the construct of dt_omega_matrix
zhichen3 Sep 25, 2024
f3cd8cd
fix rotating torus initialization
zhichen3 Sep 25, 2024
8129ca4
fix compilation error
zhichen3 Sep 25, 2024
1fa51a6
fix compilation
zhichen3 Sep 25, 2024
59d123c
fix shadowing variable
zhichen3 Sep 25, 2024
ffe98b9
fix shadowing again
zhichen3 Sep 25, 2024
e756616
Merge branch 'development' into 2d_spherical_rotation
zingale Sep 26, 2024
4ffd7a9
Merge branch 'development' into 2d_spherical_rotation
zingale Sep 26, 2024
eb83e4e
Merge branch 'development' into 2d_spherical_rotation
zingale Oct 7, 2024
1261061
Merge branch 'development' into 2d_spherical_rotation
zingale Oct 24, 2024
0593ad3
Merge branch 'development' into 2d_spherical_rotation
zingale Nov 17, 2024
01d43f8
Merge branch '2d_spherical_rotation' of github.com:zhichen3/Castro in…
zhichen3 Dec 8, 2024
3e910b4
Merge branch 'development' into 2d_spherical_rotation
zhichen3 Dec 8, 2024
4321ca1
Merge branch '2d_spherical_rotation' of github.com:zhichen3/Castro in…
zhichen3 Dec 8, 2024
3cde3f4
Merge branch 'development' into 2d_spherical_rotation
zingale Dec 18, 2024
0c1c2d4
Merge branch '2d_spherical_rotation' of github.com:zhichen3/Castro in…
zhichen3 Dec 20, 2024
601921b
update docs on spherical rotation axis
zhichen3 Dec 20, 2024
06956a0
update doc
zhichen3 Dec 20, 2024
ed27187
fix spelling
zhichen3 Dec 20, 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
5 changes: 2 additions & 3 deletions Exec/hydro_tests/rotating_torus/problem_initialize.H
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,12 @@ void problem_initialize ()
auto omega = get_omega();
#else
// Provide a dummy value so that we can compile without rotation.
Real omega[3] = {0.0_rt, 0.0_rt, 2.0_rt * M_PI};
Real omega = 2.0_rt * M_PI;
#endif

// Figure out R_0, the maximum pressure radius.

problem::density_maximum_radius = std::pow(C::Gconst * point_mass /
(omega[0] * omega[0] + omega[1] * omega[1] + omega[2] * omega[2]), 1.0_rt/3.0_rt);
problem::density_maximum_radius = std::pow(C::Gconst * point_mass / (omega * omega), 1.0_rt/3.0_rt);

// Maximum and minimum vertical extent of the torus is the same as the radial extent

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ void problem_initialize_state_data (int i, int j, int k,
const Real* probhi = geomdata.ProbHi();

#ifdef ROTATION
auto omega = get_omega();
auto omega = get_omega_vec(geomdata, j);
#else
// Provide a dummy value so that we can compile without rotation.
Real omega[3] = {0.0_rt, 0.0_rt, 2.0_rt * M_PI};
Expand Down
7 changes: 5 additions & 2 deletions Exec/science/wdmerger/Prob.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -798,6 +798,7 @@ Castro::update_relaxation(Real time, Real dt) {
get_lagrange_points(mass_P, mass_S, com_P, com_S, L1, L2, L3);

const auto dx = geom.CellSizeArray();
const auto coord = geom.Coord();
GeometryData geomdata = geom.data();

MultiFab& phi_new = get_new_data(PhiGrav_Type);
Expand Down Expand Up @@ -833,7 +834,8 @@ Castro::update_relaxation(Real time, Real dt) {

// Compute the effective potential.

Real phiEff = phi(i,j,k) + rotational_potential(r);
auto omega_vec = get_omega_vec(geomdata, j);
Real phiEff = phi(i,j,k) + rotational_potential(r, omega_vec, coord);

for (int n = 0; n < 3; ++n) {
r[n] -= L1[n];
Expand Down Expand Up @@ -901,7 +903,8 @@ Castro::update_relaxation(Real time, Real dt) {
GpuArray<Real, 3> r;
position(i, j, k, geomdata, r);

Real phiEff = phi(i,j,k) + rotational_potential(r);
auto omega_vec = get_omega_vec(geomdata, j);
Real phiEff = phi(i,j,k) + rotational_potential(r, omega_vec, coord);

Real done = 0.0_rt;

Expand Down
23 changes: 19 additions & 4 deletions Exec/science/wdmerger/Problem_Derive.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -419,6 +419,8 @@ void ca_derphieff(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*ncomp*/

const auto dx = geom.CellSizeArray();
const auto problo = geom.ProbLoArray();
const auto coord = geom.Coord();
const auto geomdata = geom.data();

amrex::ParallelFor(bx,
[=] AMREX_GPU_HOST_DEVICE (int i, int j, int k)
Expand All @@ -438,8 +440,9 @@ void ca_derphieff(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*ncomp*/
#else
loc[2] = 0.0_rt;
#endif
auto omega = get_omega_vec(geomdata, j);

der(i,j,k,0) = dat(i,j,k,0) + rotational_potential(loc);
der(i,j,k,0) = dat(i,j,k,0) + rotational_potential(loc, omega, coord);
});
}

Expand All @@ -458,6 +461,8 @@ void ca_derphieffpm_p(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*nco

const auto dx = geom.CellSizeArray();
const auto problo = geom.ProbLoArray();
const auto coord = geom.Coord();
const auto geomdata = geom.data();

amrex::ParallelFor(bx,
[=] AMREX_GPU_HOST_DEVICE (int i, int j, int k)
Expand Down Expand Up @@ -492,7 +497,9 @@ void ca_derphieffpm_p(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*nco
loc[iloc] -= problem::center[iloc];
}

der(i,j,k,0) = -C::Gconst * problem::mass_P / r + rotational_potential(loc);
auto omega = get_omega_vec(geomdata, j);

der(i,j,k,0) = -C::Gconst * problem::mass_P / r + rotational_potential(loc, omega, coord);
});
}

Expand All @@ -508,6 +515,8 @@ void ca_derphieffpm_s(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*nco

const auto dx = geom.CellSizeArray();
const auto problo = geom.ProbLoArray();
const auto coord = geom.Coord();
const auto geomdata = geom.data();

amrex::ParallelFor(bx,
[=] AMREX_GPU_HOST_DEVICE (int i, int j, int k)
Expand Down Expand Up @@ -542,7 +551,9 @@ void ca_derphieffpm_s(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*nco
loc[iloc] -= problem::center[iloc];
}

der(i,j,k,0) = -C::Gconst * problem::mass_S / r + rotational_potential(loc);
auto omega = get_omega_vec(geomdata, j);

der(i,j,k,0) = -C::Gconst * problem::mass_S / r + rotational_potential(loc, omega, coord);
});
}

Expand Down Expand Up @@ -572,6 +583,8 @@ void ca_derrhophiRot(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*ncom

const auto dx = geom.CellSizeArray();
const auto problo = geom.ProbLoArray();
const auto coord = geom.Coord();
const auto geomdata = geom.data();

amrex::ParallelFor(bx,
[=] AMREX_GPU_HOST_DEVICE (int i, int j, int k)
Expand All @@ -592,7 +605,9 @@ void ca_derrhophiRot(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*ncom
loc[2] = 0.0_rt;
#endif

der(i,j,k,0) = dat(i,j,k,0) * rotational_potential(loc);
auto omega = get_omega_vec(geomdata, j);

der(i,j,k,0) = dat(i,j,k,0) * rotational_potential(loc, omega, coord);
});
}

Expand Down
2 changes: 1 addition & 1 deletion Exec/science/wdmerger/problem_initialize_state_data.H
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ void problem_initialize_state_data (int i, int j, int k,
// or secondary (in which case interpolate from the respective model)
// or if we are in an ambient zone.

auto omega = get_omega();
auto omega = get_omega_vec(geomdata, j);

GpuArray<Real, 3> loc;
position(i, j, k, geomdata, loc);
Expand Down
4 changes: 3 additions & 1 deletion Exec/science/wdmerger/wdmerger_util.H
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,9 @@ Real stellar_mask (int i, int j, int k,
loc[iloc] -= problem::center[iloc];
}

Real phi_rot = rotational_potential(loc);
auto omega = get_omega_vec(geomdata, j);

Real phi_rot = rotational_potential(loc, omega, geomdata.Coord());

Real phi_p = -C::Gconst * problem::mass_P / r_P + phi_rot;
Real phi_s = -C::Gconst * problem::mass_S / r_S + phi_rot;
Expand Down
7 changes: 6 additions & 1 deletion Source/driver/_cpp_parameters
Original file line number Diff line number Diff line change
Expand Up @@ -490,7 +490,12 @@ rot_source_type int 4 ROTATION
# for better coupling of the Coriolis terms
implicit_rotation_update bool 1 ROTATION

# the coordinate axis (:math:`x=1`, :math:`y=2`, :math:`z=3`) for the rotation vector
# the coordinate axis for the rotation vector
# For Cartesian: (:math:`x=1`, :math:`y=2`, :math:`z=3`)
# For non-Cartesian coordinates, this parameter doesn't do anything because:
# For RZ (Cylindrical 2D), it is automatically set to z-axis (rot_axis = 2)
# For Spherical2D, it is also assumed to be in the z-axis
# i.e. cos(theta) r_hat - sin(theta) theta_hat in Spherical coordinate.
rot_axis int 3 ROTATION

# include a central point mass
Expand Down
5 changes: 3 additions & 2 deletions Source/driver/sum_utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -400,7 +400,8 @@ Castro::gwstrain (Real time,

GpuArray<Real, 3> pos{r};
#ifdef ROTATION
pos = inertial_rotation(r, time);
auto omega = get_omega_vec(geomdata, j);
pos = inertial_rotation(r, omega, time);
#endif

// For constructing the velocity in the inertial frame, we need to
Expand Down Expand Up @@ -431,7 +432,7 @@ Castro::gwstrain (Real time,

GpuArray<Real, 3> inertial_g{g};
#ifdef ROTATION
inertial_g = inertial_rotation(g, time);
inertial_g = inertial_rotation(g, omega, time);
#endif

// Absorb the factor of 2 outside the integral into the zone mass, for efficiency.
Expand Down
Loading
Loading