From 68555afcbda95fd144cdf9666c45db2581f48f0a Mon Sep 17 00:00:00 2001 From: Liwei Ji Date: Wed, 26 Jun 2024 20:43:05 +0000 Subject: [PATCH] Multipole: beautify func outputModes --- Multipole/param.ccl | 27 ------------------------- Multipole/src/multipole.cxx | 39 +++++++++++++++++-------------------- 2 files changed, 18 insertions(+), 48 deletions(-) diff --git a/Multipole/param.ccl b/Multipole/param.ccl index 4376af04..70821e25 100644 --- a/Multipole/param.ccl +++ b/Multipole/param.ccl @@ -94,33 +94,6 @@ CCTK_INT l_max "The maximum l mode to extract" STEERABLE=always 0:9 :: "l >= 0" } 2 -CCTK_BOOLEAN enable_test "whether to set a spherical harmonic in the 'harmonic' grid functions" -{ -} "no" - -CCTK_BOOLEAN enable_test_Weyl "whether to set a spherical harmonic in the 'Weyl::Psi4r and i' grid functions" -{ -} "no" - -CCTK_INT test_l "which mode to put into the test variables" -{ - * :: "Any integer" -} 2 - -CCTK_INT test_m "which mode to put into the test variables" -{ - * :: "Any integer" -} 2 - -CCTK_INT test_sw "which spin weight to put into the test variables" -{ - * :: "Any integer" -} -2 - -CCTK_BOOLEAN test_mode_proportional_to_r "whether the test spherical harmonic coefficient is proportional to the radial coordinate" -{ -} "no" - CCTK_BOOLEAN output_tsv "Output a simple ASCII file for each mode at each radius" { } "yes" diff --git a/Multipole/src/multipole.cxx b/Multipole/src/multipole.cxx index fc65ea8d..5cc4ccb8 100644 --- a/Multipole/src/multipole.cxx +++ b/Multipole/src/multipole.cxx @@ -21,34 +21,31 @@ static Sphere *g_sphere = nullptr; static vector g_vars; static vector g_spin_weights; -static void output_modes(CCTK_ARGUMENTS, const VariableParse vars[], - const CCTK_REAL radii[], const ModeArray &modes) { +// Function to output modes +static void outputModes(CCTK_ARGUMENTS, const VariableParse vars[], + const CCTK_REAL radii[], const ModeArray &modes) { DECLARE_CCTK_ARGUMENTS; DECLARE_CCTK_PARAMETERS; - if (output_tsv) { - if (CCTK_MyProc(cctkGH) == 0) { - for (int v = 0; v < modes.getNumVars(); v++) { - for (int i = 0; i < modes.getNumRadii(); i++) { - const CCTK_REAL rad = radii[i]; - for (int l = 0; l <= modes.getMaxL(); l++) { - for (int m = -l; m <= l; m++) { - ostringstream name; - name << "mp_" << vars[v].name << "_l" << l << "_m" << m << "_r" - << setiosflags(ios::fixed) << setprecision(2) << rad - << ".tsv"; - OutputComplexToFile(CCTK_PASS_CTOC, name.str(), - modes(v, i, l, m, 0), modes(v, i, l, m, 1)); - } + if (output_tsv && CCTK_MyProc(cctkGH) == 0) { + for (int v = 0; v < modes.getNumVars(); ++v) { + for (int i = 0; i < modes.getNumRadii(); ++i) { + const CCTK_REAL rad = radii[i]; + for (int l = 0; l <= modes.getMaxL(); ++l) { + for (int m = -l; m <= l; ++m) { + std::ostringstream filename; + filename << "mp_" << vars[v].name << "_l" << l << "_m" << m << "_r" + << std::fixed << std::setprecision(2) << rad << ".tsv"; + + OutputComplexToFile(CCTK_PASS_CTOC, filename.str(), + modes(v, i, l, m, 0), modes(v, i, l, m, 1)); } } } } } - if (output_hdf5) { - if (CCTK_MyProc(cctkGH) == 0) { - OutputComplexToH5File(CCTK_PASS_CTOC, vars, radii, modes); - } + if (output_hdf5 && CCTK_MyProc(cctkGH) == 0) { + OutputComplexToH5File(CCTK_PASS_CTOC, vars, radii, modes); } } @@ -203,7 +200,7 @@ extern "C" void Multipole_Calc(CCTK_ARGUMENTS) { } // loop over radii } // loop over variables - output_modes(CCTK_PASS_CTOC, g_vars.data(), radius, modes); + outputModes(CCTK_PASS_CTOC, g_vars.data(), radius, modes); } } // namespace Multipole