Skip to content

Commit

Permalink
use abs for volume and area for 1d and 2d (#3007)
Browse files Browse the repository at this point in the history
Use std::abs to make sure volume in non-cartesian coord are positive. Also make sure 1d/2d noncartesian area are positive since area direction becomes trivial when we have phi-symmetry.
  • Loading branch information
zhichen3 authored Dec 3, 2024
1 parent bd282c1 commit c4b7181
Showing 1 changed file with 11 additions and 11 deletions.
22 changes: 11 additions & 11 deletions Source/driver/Castro_util.H
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ Real volume(const int& i, const int& j, const int& k,
Real rl = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];
Real rr = rl + dx[0];

vol = M_PI * dx[0] * (rr + rl);
vol = std::abs(M_PI * dx[0] * (rr + rl));

} else {

Expand All @@ -226,7 +226,7 @@ Real volume(const int& i, const int& j, const int& k,
Real rl = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];
Real rr = rl + dx[0];

vol = (4.0_rt / 3.0_rt) * M_PI * dx[0] * (rl * rl + rl * rr + rr * rr);
vol = std::abs((4.0_rt / 3.0_rt) * M_PI * dx[0] * (rl * rl + rl * rr + rr * rr));

}

Expand All @@ -247,7 +247,7 @@ Real volume(const int& i, const int& j, const int& k,
Real r_l = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];
Real r_r = geomdata.ProbLo()[0] + static_cast<Real>(i+1) * dx[0];

vol = M_PI * (r_l + r_r) * dx[0] * dx[1];
vol = std::abs(M_PI * (r_l + r_r) * dx[0] * dx[1]);

} else {

Expand All @@ -260,8 +260,8 @@ Real volume(const int& i, const int& j, const int& k,
Real theta_l = geomdata.ProbLo()[1] + static_cast<Real>(j) * dx[1];
Real theta_r = geomdata.ProbLo()[1] + static_cast<Real>(j+1) * dx[1];

vol = twoThirdsPi * (std::cos(theta_l) - std::cos(theta_r)) * dx[0] *
(r_r * r_r + r_r * r_l + r_l * r_l);
vol = std::abs(twoThirdsPi * (std::cos(theta_l) - std::cos(theta_r)) * dx[0] *
(r_r * r_r + r_r * r_l + r_l * r_l));

}

Expand Down Expand Up @@ -306,15 +306,15 @@ Real area(const int& i, const int& j, const int& k,

Real r = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];

a = 2.0_rt * M_PI * r;
a = std::abs(2.0_rt * M_PI * r);

} else {

// Spherical

Real r = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];

a = 4.0_rt * M_PI * r * r;
a = std::abs(4.0_rt * M_PI * r * r);

}

Expand All @@ -339,11 +339,11 @@ Real area(const int& i, const int& j, const int& k,

if (idir == 0) {
Real r = geomdata.ProbLo()[0] + static_cast<Real>(i) * dx[0];
a = 2.0_rt * M_PI * r * dx[1];
a = std::abs(2.0_rt * M_PI * r * dx[1]);
}
else {
Real r = geomdata.ProbLo()[0] + (static_cast<Real>(i) + 0.5_rt) * dx[0];
a = 2.0_rt * M_PI * r * dx[0];
a = std::abs(2.0_rt * M_PI * r * dx[0]);
}

} else {
Expand All @@ -355,13 +355,13 @@ Real area(const int& i, const int& j, const int& k,
Real theta_l = geomdata.ProbLo()[1] + static_cast<Real>(j) * dx[1];
Real theta_r = geomdata.ProbLo()[1] + static_cast<Real>(j+1) * dx[1];

a = 2.0_rt * M_PI * r * r * (std::cos(theta_l) - std::cos(theta_r));
a = std::abs(2.0_rt * M_PI * r * r * (std::cos(theta_l) - std::cos(theta_r)));
}
else {
Real r = geomdata.ProbLo()[0] + (static_cast<Real>(i) + 0.5_rt) * dx[0];
Real theta = geomdata.ProbLo()[1] + static_cast<Real>(j) * dx[1];

a = 2.0_rt * M_PI * std::sin(theta) * r * dx[0];
a = std::abs(2.0_rt * M_PI * std::sin(theta) * r * dx[0]);
}

}
Expand Down

0 comments on commit c4b7181

Please sign in to comment.