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

Erick/production 1.0 #106

Open
wants to merge 83 commits into
base: development
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
7a53b35
Make IMFP calculation energy dependent
shankar-1729 Nov 4, 2024
de0bac5
Ensure that rho, temp and Ye are uniformally spaced.
shankar-1729 Nov 4, 2024
7daa907
Implement function to calculate maximum of IMFP over the grid (UNTESTED)
shankar-1729 Oct 26, 2024
2c67c2e
Move multifab for IMFB inside compute_max_IMFP function, correct temp…
shankar-1729 Oct 30, 2024
795615c
do not input ba, dm and ngrow inside compute_max_IMFP function
shankar-1729 Oct 30, 2024
a9d22c4
calculate max_IMFP_abs inside function compute_dt
shankar-1729 Oct 30, 2024
66eeb3c
Remove dt calculation from compute_dt function
shankar-1729 Oct 31, 2024
3480a61
Adding basics comments and documentation to new functions
erickurquilla1999 Nov 4, 2024
8458eae
Change the position of the calculation of the maximum IMFP
erickurquilla1999 Nov 4, 2024
792c8fd
Compute maximum of IMFP when IMFP method is 1 too
erickurquilla1999 Nov 4, 2024
4b43fff
Compute the maximum IMFP and pass it as a parameter to the compute_dt…
erickurquilla1999 Nov 4, 2024
db60725
Cleaning up the compute_dt function and adding documentation.
erickurquilla1999 Nov 4, 2024
d02f865
Include a generated file to compute the trace of the neutrino number …
erickurquilla1999 Nov 4, 2024
0959355
Solving issue in generated file to compute trace of mesh neutrino and…
erickurquilla1999 Nov 4, 2024
b4c008b
Compute maximum trace of the neutrino and antineutrino from mesh quan…
erickurquilla1999 Nov 4, 2024
0399808
Create a function that computes the minimum value in a MultiFab in pa…
erickurquilla1999 Nov 5, 2024
be783b9
Set some if statements to handle simulations with empty periodic boun…
erickurquilla1999 Nov 5, 2024
d8e9f1e
Generate a new file to compute the trace on mesh quantities
erickurquilla1999 Nov 5, 2024
c5c70ed
Solve syntaxis mistakes and compute the minumin time step rather than…
erickurquilla1999 Nov 5, 2024
9703bac
Make function compute_max_IMFP return a multifab with the maximum inv…
erickurquilla1999 Nov 5, 2024
aada239
Compute the minimum combination of TrN/Opacity*c. This quantity provi…
erickurquilla1999 Nov 5, 2024
8a737ea
Delete commented lines and handle periodic empty boundary conditions …
erickurquilla1999 Nov 5, 2024
3420c23
Cleaning up and addiing comments to the compute_dt function
erickurquilla1999 Nov 5, 2024
4594186
Add documentation for header file of Evolve.cpp file
erickurquilla1999 Nov 5, 2024
acbf75d
Delete unnecessary generation of two files that compute the trace.
erickurquilla1999 Nov 5, 2024
2296774
Setting the min(TrN, TrNbar) to one in case it is zero
erickurquilla1999 Nov 5, 2024
97e981e
Cleaning space
erickurquilla1999 Nov 5, 2024
c1be327
Cleaning up compute_max_IMFP function
erickurquilla1999 Nov 5, 2024
af7a2c8
Creating documentation for compute_max_IMFP function
erickurquilla1999 Nov 5, 2024
08fc11f
Set the new time step to agree with the new function that computes th…
erickurquilla1999 Nov 5, 2024
dac02e9
Solving issue when looping over the MultiFabs. Now it does not loop o…
erickurquilla1999 Nov 6, 2024
f76d6fb
Delete unnecessary lines
erickurquilla1999 Nov 6, 2024
1021c4e
Update empty periodic boundary condition test
erickurquilla1999 Nov 6, 2024
aa6f913
Setting the right cfl factors for particles to equilibrium test
erickurquilla1999 Nov 6, 2024
ec29a9b
Set up the Fermi-Dirac test for multi-energy particles with the follo…
erickurquilla1999 Nov 6, 2024
8f7094b
Delete unnecessary functions
erickurquilla1999 Nov 6, 2024
a114cc8
Solving possible issue with zero inverse mean free path
erickurquilla1999 Nov 6, 2024
7358916
Improve documentation
erickurquilla1999 Nov 6, 2024
2a3525d
Solve syntax issue
erickurquilla1999 Nov 6, 2024
94a9bf2
Solving issue with fermi dirac test
erickurquilla1999 Nov 7, 2024
3f60f26
Fix time step function: now calculates the time step based on a basic…
erickurquilla1999 Nov 25, 2024
f1c9cd7
Adding comments on the definitions of V_stupid and V_adaptive
erickurquilla1999 Nov 25, 2024
216fc2a
Delete unnecessary line that computes the trace of matrices.
erickurquilla1999 Nov 25, 2024
f09220b
Add input parameter for the minimum allowed time step in the simulation
erickurquilla1999 Nov 25, 2024
981c3e2
Including the minimum time step barrier in the function that computes…
erickurquilla1999 Nov 25, 2024
94af9fb
Including a new neutrino container to store the minimum dt for every …
erickurquilla1999 Nov 25, 2024
9255937
Delete documentation in Evolve.H header file and input the time step …
erickurquilla1999 Nov 25, 2024
bd4be86
Add a flag to choose between two different methods for computing the …
erickurquilla1999 Nov 25, 2024
2835ede
Add a new method to compute the time step based on the time derivativ…
erickurquilla1999 Nov 25, 2024
e49ff1b
Delete unnecessary variables and comments.
erickurquilla1999 Nov 25, 2024
d437789
Add time_step_method flag to input parameters.
erickurquilla1999 Nov 25, 2024
4873d89
Update input parameters.
erickurquilla1999 Nov 25, 2024
f5e9e71
Improve script that compute dE and antineutrino chemical potential fo…
erickurquilla1999 Nov 25, 2024
f37885e
Setting asserts at the end of the collisional flavor instability test…
erickurquilla1999 Nov 25, 2024
5ed145b
Fix issue with Method 1 for computing the time step
erickurquilla1999 Nov 25, 2024
c7dbd0d
Set collisional flavor instability test to use Method 1 for computing…
erickurquilla1999 Nov 25, 2024
e8f4b84
Fix issue in method 0 to compute time step
erickurquilla1999 Nov 25, 2024
d6c37a4
Adding comments in st9 initial condition to avoid future confusion
erickurquilla1999 Nov 25, 2024
653bc78
Adding comments to avoid future confusion in fermi-dirac test
erickurquilla1999 Nov 25, 2024
40a853b
Remove 'FIXME' comments.
erickurquilla1999 Nov 25, 2024
34f27cf
Return mf_IMFP at the end of the function instead of in every if stat…
erickurquilla1999 Nov 25, 2024
a5f4b30
Delete print line in main
erickurquilla1999 Nov 25, 2024
c2aa1b4
Create a script to plot the polarization vector components for single…
erickurquilla1999 Nov 25, 2024
501fe69
Add an if statement to compute the IMFP MultiFab only when the time s…
erickurquilla1999 Nov 25, 2024
1652a0e
Set the maximum grid size for every direction in the domain.
erickurquilla1999 Nov 25, 2024
61c025d
Update input file to define max grid size in every direction in the d…
erickurquilla1999 Nov 25, 2024
86e8500
Making convertToHDF5.py script works in 3D simulations
erickurquilla1999 Nov 27, 2024
0de65c0
Adding a line to stop execution when a NaN appears in N and N bar
erickurquilla1999 Nov 29, 2024
e02dc74
Improve section the leave the code is N or Nbar is NaN
erickurquilla1999 Nov 29, 2024
9ea0ae6
Plotting best figures in collisional instability test
erickurquilla1999 Dec 2, 2024
8b44a36
Adding units to labels and legends
erickurquilla1999 Dec 2, 2024
104bb0f
Updating plots and legens in CFI test
erickurquilla1999 Dec 2, 2024
8c92437
Delete lines that import unused packages in the collisional instabili…
erickurquilla1999 Dec 4, 2024
4e61f3d
Setting optimal max_grid_size in tests input file
erickurquilla1999 Dec 4, 2024
e01666d
Add a script to save particle information from binary to HDF5, organi…
erickurquilla1999 Jan 4, 2025
b403f71
Optimizing script that write particles data per cell. Now it only doe…
erickurquilla1999 Jan 4, 2025
e37eeb7
Create a new script for parallel optimization of the write_partices_p…
erickurquilla1999 Jan 4, 2025
773a933
Adding an script that write particle information parallelized over grids
erickurquilla1999 Jan 4, 2025
2d5a3c6
Solving issue creating particles file
erickurquilla1999 Jan 4, 2025
3c62f34
Delete thread parallelization
erickurquilla1999 Jan 4, 2025
bfbba28
Update write particles per cell script to recive the grid index as in…
erickurquilla1999 Jan 4, 2025
2ab5ab3
Delete file
erickurquilla1999 Jan 4, 2025
cdd589e
Fix issue with number of amrex grid subdivision
erickurquilla1999 Jan 4, 2025
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
Prev Previous commit
Next Next commit
Cleaning up and addiing comments to the compute_dt function
  • Loading branch information
erickurquilla1999 committed Nov 7, 2024
commit 3420c238250003b99e258e6502aa305aefc4364a
86 changes: 51 additions & 35 deletions Source/Evolve.cpp
Original file line number Diff line number Diff line change
@@ -272,34 +272,43 @@ MultiFab compute_max_IMFP(const Geometry& geom, const MultiFab& state, const Tes
}

/**
* @brief Computes the time step for the simulation based on various CFL factors.
* @brief Computes the time step size for the simulation based on various CFL factors and conditions.
*
* This function calculates the time step for the simulation by considering the
* CFL factors for translation, flavor, and collision. It uses the maximum IMFP
* value to determine the collision time step and combines it with the translation
* and flavor time steps to find the minimum time step for the simulation.
* This function calculates the time step size considering translation, flavor, and collision CFL factors.
* It ensures that the time step is limited by the smallest of these factors to maintain stability.
*
* @param geom The geometry of the simulation domain.
* @param state The MultiFab containing the state variables.
* @param neutrinos The container holding the flavored neutrinos.
* @param maximum_IMFP_abs The maximum inverse mean free path for absorption.
* @return The computed time step for the simulation.
* @param state The state MultiFab containing the simulation data.
* @param neutrinos The container for flavored neutrinos.
* @param parms Pointer to the structure containing simulation parameters.
* @param maximum_IMFP_abs The MultiFab containing the maximum inverse mean free path for absorption.
*
* @return The computed time step size.
*
* @note At least one of cfl_factor, flavor_cfl_factor, or collision_cfl_factor must be greater than 0.0.
* @note The function handles periodic boundary conditions and black hole regions if specified in the parameters.
* @note The function performs a reduction operation to find the minimum time step across all cells and MPI ranks.
*/
Real compute_dt(
const Geometry& geom,
const MultiFab& state,
const FlavoredNeutrinoContainer&,
const FlavoredNeutrinoContainer& neutrinos,
const TestParams* parms,
const MultiFab& maximum_IMFP_abs)
{
{
// Initialize the maximum real value
const Real max_real = std::numeric_limits<Real>::max();
erickurquilla1999 marked this conversation as resolved.
Show resolved Hide resolved

AMREX_ASSERT(parms->cfl_factor > 0.0 || parms->flavor_cfl_factor > 0.0 || parms->collision_cfl_factor > 0.0);
AMREX_ASSERT_WITH_MESSAGE(parms->cfl_factor > 0.0 || parms->flavor_cfl_factor > 0.0 || parms->collision_cfl_factor > 0.0,
"Error: At least one of cfl_factor, flavor_cfl_factor, or collision_cfl_factor must be greater than 0.0.");

// translation part of timestep limit
// Get the cell size array
const auto dxi = geom.CellSizeArray();
Real dt_translation = 0.0;
Real dt_translation = 0.0;
if (parms->cfl_factor > 0.0) {
dt_translation = std::min(std::min(dxi[0], dxi[1]), dxi[2]) / PhysConst::c * parms->cfl_factor;
// Calculate the time step size based on the translation CFL factor
// dt = (min(dx,dy,dz)/c) * cfl_factor
dt_translation = std::min({dxi[0], dxi[1], dxi[2]}) / PhysConst::c * parms->cfl_factor;
}

Real dt_flavor = 0.0;
@@ -316,30 +325,31 @@ Real compute_dt(
reduce_op.eval(bx, reduce_data,
[=] AMREX_GPU_DEVICE (int i, int j, int k) -> ReduceTuple
{

// Check if the cell is at the boundary or inside the black hole
if (parms->do_periodic_empty_bc == 1) {

// Check if the cell is at the boundary
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

only one comment indicating if cell at boundary

if (i == 0 || i == parms->ncell[0] - 1 ||
j == 0 || j == parms->ncell[1] - 1 ||
k == 0 || k == parms->ncell[2] - 1) {

return {std::numeric_limits<Real>::max(), std::numeric_limits<Real>::max(), std::numeric_limits<Real>::max()};

return {max_real,max_real,max_real};
}
}else if (parms->do_blackhole == 1) {
// Check if the cell is inside the black hole

// Calculate the cell size
double cell_size_x = parms->Lx / parms->ncell[0];
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

need to avoid calculating IMFP inside of the black hole as well

double cell_size_y = parms->Ly / parms->ncell[1];
double cell_size_z = parms->Lz / parms->ncell[2];

// Calculate the cell center coordinates
double x_cell_center = (i + 0.5) * cell_size_x;
double y_cell_center = (j + 0.5) * cell_size_y;
double z_cell_center = (k + 0.5) * cell_size_z;

// Calculate the distance from the black hole center
Real distance_from_bh = sqrt(pow(x_cell_center - parms->bh_center_x, 2) + pow(y_cell_center - parms->bh_center_y, 2) + pow(z_cell_center - parms->bh_center_z, 2));

// Check if the cell is inside the black hole
if (distance_from_bh < parms->bh_radius) {
return {std::numeric_limits<Real>::max(), std::numeric_limits<Real>::max(), std::numeric_limits<Real>::max()};
return {max_real,max_real,max_real};
}
}

@@ -352,11 +362,12 @@ Real compute_dt(
Real trace_n = 0.0, trace_nbar = 0.0;
#include "generated_files/Evolve.cpp_compute_trace_2"

// Calculate the minimum trace between neutrinos and antineutrinos
Real min_trace = min(trace_n, trace_nbar);

Real dt_adaptive = min_trace / V_adaptive;
Real dt_stupid = min_trace / V_stupid;
Real dt_absorption = min_trace / multifab_IMFP(i, j, k);
Real dt_adaptive = min_trace / std::abs(V_adaptive); // dt = min(trN,trNbar)/|V_adaptive|
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The units don't seem to match

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the trace shouldn't be used at all

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

also put the hbar here so dt has units of time

Real dt_stupid = min_trace / std::abs(V_stupid); // dt = min(trN,trNbar)/|V_stupid|
Real dt_absorption = min_trace / multifab_IMFP(i, j, k); // dt = 1/IMFP

return {dt_adaptive, dt_stupid, dt_absorption};
});
@@ -374,17 +385,20 @@ Real compute_dt(
ParallelDescriptor::ReduceRealMin(min_dt_absorption);

// define the dt associated with each method
Real dt_flavor_adaptive = std::numeric_limits<Real>::max();
Real dt_flavor_stupid = std::numeric_limits<Real>::max();
Real dt_flavor_absorption = std::numeric_limits<Real>::max(); // Initialize with infinity
Real dt_flavor_adaptive = max_real;
Real dt_flavor_stupid = max_real;
Real dt_flavor_absorption = max_real; // Initialize with infinity

if (parms->attenuation_hamiltonians != 0) {
dt_flavor_adaptive = PhysConst::hbar * min_dt_adaptive * parms->flavor_cfl_factor / parms->attenuation_hamiltonians;
// dt = min( min(trN,trNbar)/|V_adaptive| ) * hbar * flavor_cfl_factor / attenuation_hamiltonians
dt_flavor_adaptive = PhysConst::hbar * min_dt_adaptive * parms->flavor_cfl_factor / parms->attenuation_hamiltonians;
// dt = min( min(trN,trNbar)/|V_stupid| ) * hbar * flavor_cfl_factor / attenuation_hamiltonians
dt_flavor_stupid = PhysConst::hbar * min_dt_stupid * parms->flavor_cfl_factor / parms->attenuation_hamiltonians;
}

if (parms->IMFP_method == 1 || parms->IMFP_method == 2) {
// Calculate dt_flavor_absorption
// dt = min( min( trN, trNbar ) / IMFP ) * collision_cfl_factor / c
dt_flavor_absorption = ( min_dt_absorption / PhysConst::c ) * parms->collision_cfl_factor;
}

@@ -398,12 +412,14 @@ Real compute_dt(
Real dt = 0.0;
if (dt_translation != 0.0 && dt_flavor != 0.0) {
dt = std::min(dt_translation, dt_flavor);
} else if (dt_translation != 0.0) {
dt = dt_translation;
} else if (dt_flavor != 0.0) {
dt = dt_flavor;
} else {
amrex::Error("Timestep selection failed, both dt_translation and dt_flavor are zero. Try using both cfl_factor and flavor_cfl_factor.");
if (dt_translation != 0.0) {
dt = dt_translation;
} else if (dt_flavor != 0.0) {
dt = dt_flavor;
} else {
amrex::Error("Timestep selection failed, both dt_translation and dt_flavor are zero. Try using both cfl_factor and flavor_cfl_factor.");
}
}

return dt;