From 8d4459fdb1f17cf607a0f8a01fce13c59563f343 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Sat, 10 Feb 2024 16:14:02 -0500 Subject: [PATCH 01/56] codespell fix (#2751) --- Source/reactions/Castro_react.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/reactions/Castro_react.cpp b/Source/reactions/Castro_react.cpp index 6859b891a5..73c5a3c873 100644 --- a/Source/reactions/Castro_react.cpp +++ b/Source/reactions/Castro_react.cpp @@ -414,7 +414,7 @@ Castro::react_state(MultiFab& s, MultiFab& r, Real time, Real dt, const int stra }); #if defined(AMREX_USE_HIP) - Gpu::streamSynchronize(); // otherwise HIP may faile to allocate the necessary resources. + Gpu::streamSynchronize(); // otherwise HIP may fail to allocate the necessary resources. #endif } @@ -806,7 +806,7 @@ Castro::react_state(Real time, Real dt) }); #if defined(AMREX_USE_HIP) - Gpu::streamSynchronize(); // otherwise HIP may faile to allocate the necessary resources. + Gpu::streamSynchronize(); // otherwise HIP may fail to allocate the necessary resources. #endif } From 9bbf9dc13b949eaaaadf89c7e048c0cc0e58f88a Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Sun, 11 Feb 2024 10:49:57 -0500 Subject: [PATCH 02/56] add some checks on dynamic_casts in gravity (#2737) --- Source/gravity/Gravity.cpp | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/Source/gravity/Gravity.cpp b/Source/gravity/Gravity.cpp index 8ef59f0e46..35fab221d3 100644 --- a/Source/gravity/Gravity.cpp +++ b/Source/gravity/Gravity.cpp @@ -1844,8 +1844,13 @@ Gravity::fill_multipole_BCs(int crse_level, int fine_level, const Vector(&(parent->getLevel(lev+1)))->build_fine_mask(); - MultiFab::Multiply(source, mask, 0, 0, 1, 0); + auto *castro_level = dynamic_cast(&(parent->getLevel(lev+1))); + if (castro_level != nullptr) { + const MultiFab& mask = castro_level->build_fine_mask(); + MultiFab::Multiply(source, mask, 0, 0, 1, 0); + } else { + amrex::Abort("unable to access mask"); + } } // Loop through the grids and compute the individual contributions @@ -2968,7 +2973,11 @@ Gravity::set_mass_offset (Real time, bool multi_level) { for (int lev = 0; lev <= parent->finestLevel(); lev++) { auto* cs = dynamic_cast(&parent->getLevel(lev)); - mass_offset += cs->volWgtSum("density", time); + if (cs != nullptr) { + mass_offset += cs->volWgtSum("density", time); + } else { + amrex::Abort("unable to access volWgtSum"); + } } } else @@ -3132,9 +3141,13 @@ Gravity::make_radial_gravity(int level, Real time, RealVector& radial_grav) if (lev < level) { auto* fine_level = dynamic_cast(&(parent->getLevel(lev+1))); - const MultiFab& mask = fine_level->build_fine_mask(); - for (int n = 0; n < NUM_STATE; ++n) { - MultiFab::Multiply(S, mask, 0, n, 1, 0); + if (fine_level != nullptr) { + const MultiFab& mask = fine_level->build_fine_mask(); + for (int n = 0; n < NUM_STATE; ++n) { + MultiFab::Multiply(S, mask, 0, n, 1, 0); + } + } else { + amrex::Abort("unable to create mask"); } } From 08d58b44f90b946b857fbc1cc572614c7bc69adf Mon Sep 17 00:00:00 2001 From: Khanak Bhargava <56127611+khanakbhargava@users.noreply.github.com> Date: Sun, 11 Feb 2024 17:29:07 -0500 Subject: [PATCH 03/56] Moving enuc to derived variables in io.rst (#2752) --- Docs/source/io.rst | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/Docs/source/io.rst b/Docs/source/io.rst index 1a29b56988..5f244f2776 100644 --- a/Docs/source/io.rst +++ b/Docs/source/io.rst @@ -271,8 +271,6 @@ radiation quantities). | (where X is any of the species | :math:`\omegadot_k = DX_k/Dt` | | | defined in the network) | | | +-----------------------------------+---------------------------------------------------+--------------------------------------+ -| ``enuc`` | Nuclear energy generation rate / gram | :math:`{\rm erg~g^{-1}~s^{-1}}` | -+-----------------------------------+---------------------------------------------------+--------------------------------------+ | ``rho_enuc`` | Nuclear energy generation rate density | :math:`{\rm erg~cm^{-3}~s^{-1}}` | +-----------------------------------+---------------------------------------------------+--------------------------------------+ | ``phiGrav`` | Gravitational potential | :math:`{\rm erg~g^{-1}}` | @@ -393,7 +391,8 @@ Derived variables | ``y_velocity``, | :math:`\ub = (\rho \ub)/\rho` | | | | ``z_velocity`` | | | | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ - +| ``enuc`` | Nuclear energy generation rate / gram | ``derenuc`` | :math:`{\rm erg~g^{-1}~s^{-1}}` | ++-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ problem-specific plotfile variables ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ From fe6ff480b6c88c9ca16d281740373c864893aec3 Mon Sep 17 00:00:00 2001 From: Khanak Bhargava <56127611+khanakbhargava@users.noreply.github.com> Date: Mon, 12 Feb 2024 14:04:00 -0500 Subject: [PATCH 04/56] Fixed a character in the table (#2753) I think the table stuff might just be a warning and not caught by the CI --- Docs/source/io.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Docs/source/io.rst b/Docs/source/io.rst index 5f244f2776..2054eb4e1c 100644 --- a/Docs/source/io.rst +++ b/Docs/source/io.rst @@ -391,7 +391,7 @@ Derived variables | ``y_velocity``, | :math:`\ub = (\rho \ub)/\rho` | | | | ``z_velocity`` | | | | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ -| ``enuc`` | Nuclear energy generation rate / gram | ``derenuc`` | :math:`{\rm erg~g^{-1}~s^{-1}}` | +| ``enuc`` | Nuclear energy generation rate / gram | ``derenuc`` | :math:`{\rm erg~g^{-1}~s^{-1}}` | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ problem-specific plotfile variables From 62193e94e15339132028443bb960f7bea0545846 Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Mon, 12 Feb 2024 19:41:09 -0500 Subject: [PATCH 05/56] Turn Sphinx warnings into errors in CI (#2754) --- .github/workflows/docs-test.yml | 9 ++++++++- .gitignore | 2 ++ Docs/rp.py | 10 +++++----- Docs/source/FlowChart.rst | 2 +- Docs/source/docutils.conf | 2 ++ Docs/source/index.rst | 2 +- 6 files changed, 19 insertions(+), 8 deletions(-) create mode 100644 Docs/source/docutils.conf diff --git a/.github/workflows/docs-test.yml b/.github/workflows/docs-test.yml index be80c197fc..562a305b7a 100644 --- a/.github/workflows/docs-test.yml +++ b/.github/workflows/docs-test.yml @@ -9,6 +9,10 @@ on: branches: - development +env: + # enable color output from Sphinx + FORCE_COLOR: "1" + jobs: docs: runs-on: ubuntu-latest @@ -33,7 +37,10 @@ jobs: - name: Build docs run: | cd Docs/ - make SPHINXOPTS=-v NO_DOXYGEN=TRUE html + # remove missing TOC entries that would otherwise be generated by + # doxygen to avoid warnings about missing references + sed -i -e 's/^ filelist$//; s/^ classlist$//' source/index.rst + make SPHINXOPTS='-v -W --keep-going' NO_DOXYGEN=TRUE html - name: Check links run: | diff --git a/.gitignore b/.gitignore index 6f29568fcb..648030bee4 100644 --- a/.gitignore +++ b/.gitignore @@ -72,6 +72,8 @@ Docs/source/namespacelist.rst Docs/source/runtime_parameters.rst Docs/source/*_files.rst Docs/source/preprocessed_files +Docs/source/yt_example.rst +Docs/source/yt_example_files/ amr_diag.out diff --git a/Docs/rp.py b/Docs/rp.py index 343d1f6dc6..5bb7f43301 100755 --- a/Docs/rp.py +++ b/Docs/rp.py @@ -7,17 +7,17 @@ from more_itertools import unique_everseen MAIN_HEADER = """ -+--------------------------------------------+-------------------------------------------------------------+---------------+ -| parameter | description | default value | -+============================================+=============================================================+===============+ ++--------------------------------------------+-------------------------------------------------------------+-----------------------------+ +| parameter | description | default value | ++============================================+=============================================================+=============================+ """ SEPARATOR = """ -+--------------------------------------------+-------------------------------------------------------------+---------------+ ++--------------------------------------------+-------------------------------------------------------------+-----------------------------+ """ ENTRY = """ -| {:42} | {:59} | {:13} | +| {:42} | {:59} | {:27} | """ WRAP_LEN = 59 diff --git a/Docs/source/FlowChart.rst b/Docs/source/FlowChart.rst index f24c4cfa7b..a47b22ad55 100644 --- a/Docs/source/FlowChart.rst +++ b/Docs/source/FlowChart.rst @@ -309,7 +309,7 @@ In the code, the objective is to evolve the state from the old time, A. Create ``Sborder``, initialized from ``S_old`` B. Call ``clean_state()`` to make sure the thermodynamics are in - sync, in particular, compute the temperature. + sync, in particular, compute the temperature. C. [``SHOCK_VAR``] zero out the shock flag. diff --git a/Docs/source/docutils.conf b/Docs/source/docutils.conf new file mode 100644 index 0000000000..3b4d0981a5 --- /dev/null +++ b/Docs/source/docutils.conf @@ -0,0 +1,2 @@ +[parsers] +line_length_limit = 1000000 diff --git a/Docs/source/index.rst b/Docs/source/index.rst index 14b646d378..0500e0bd62 100644 --- a/Docs/source/index.rst +++ b/Docs/source/index.rst @@ -60,7 +60,7 @@ https://github.com/amrex-astro/Castro filelist classlist - .. namespacelist +.. namespacelist .. toctree:: :caption: References From 1bdc65076bb13ee9279f1c4fdf7b0b34648adcab Mon Sep 17 00:00:00 2001 From: KiranEiden <32306975+KiranEiden@users.noreply.github.com> Date: Tue, 13 Feb 2024 14:44:55 -0800 Subject: [PATCH 06/56] Update documentation regarding species sources and normalization (#2742) This PR updates the Hydrodynamics section documentation to highlight that sources for passive variables in the conserved state are off by default. It also removes the reference to castro.normalize_species, which does not appear to be a valid runtime parameter any longer. I am happy to introduce additional documentation regarding the species normalization if that would be helpful -- my understanding is that it is on by default now. --- Docs/source/Hydrodynamics.rst | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/Docs/source/Hydrodynamics.rst b/Docs/source/Hydrodynamics.rst index 8d76bd5fdf..44cdf3e553 100644 --- a/Docs/source/Hydrodynamics.rst +++ b/Docs/source/Hydrodynamics.rst @@ -342,6 +342,14 @@ accounted for in **Steps 1** and **6**. The source terms are: S_{{\rm ext},\rho Y_k} \end{array}\right)^n. +.. index:: USE_SPECIES_SOURCES + +.. note:: To reduce memory usage, we do not include source terms for the + advected quantities, species, and auxiliary variables in the conserved + state vector by default. If your application needs external source terms for + these variables, set `USE_SPECIES_SOURCES=TRUE` when compiling so that space + will be allocated for them. + Primitive Forms =============== @@ -585,9 +593,6 @@ runtime parameters for hydrodynamics: See :ref:`sponge_section` for more details on the sponge. -- ``castro.normalize_species``: enforce that :math:`\sum_i X_i = 1` - (0 or 1; default: 0) - .. index:: castro.small_dens, castro.small_temp, castro.small_pres Several floors are imposed on the thermodynamic quantities to prevet unphysical From 73aacc436dd06fddded5b02cc8d9418b6f896f91 Mon Sep 17 00:00:00 2001 From: KiranEiden <32306975+KiranEiden@users.noreply.github.com> Date: Wed, 14 Feb 2024 05:13:15 -0800 Subject: [PATCH 07/56] Use double-backticks for compilation parameter in docs (#2756) --- Docs/source/Hydrodynamics.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Docs/source/Hydrodynamics.rst b/Docs/source/Hydrodynamics.rst index 44cdf3e553..edaaf8accd 100644 --- a/Docs/source/Hydrodynamics.rst +++ b/Docs/source/Hydrodynamics.rst @@ -347,7 +347,7 @@ accounted for in **Steps 1** and **6**. The source terms are: .. note:: To reduce memory usage, we do not include source terms for the advected quantities, species, and auxiliary variables in the conserved state vector by default. If your application needs external source terms for - these variables, set `USE_SPECIES_SOURCES=TRUE` when compiling so that space + these variables, set ``USE_SPECIES_SOURCES=TRUE`` when compiling so that space will be allocated for them. Primitive Forms From 56d243e7adcf05d52648cf893f80c725ae810fb9 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 19 Feb 2024 10:53:02 -0500 Subject: [PATCH 08/56] some nse_test cleaning (#2653) quiet clang-tidy warnings redirect convergence output into files this also makes it use simplified-SDC by default --- Exec/reacting_tests/nse_test/GNUmakefile | 1 + Exec/reacting_tests/nse_test/README.md | 11 +++++++---- .../nse_test/convergence_simplified_sdc_w_vel.sh | 10 +++++----- .../nse_test/problem_initialize_state_data.H | 9 ++++----- 4 files changed, 17 insertions(+), 14 deletions(-) diff --git a/Exec/reacting_tests/nse_test/GNUmakefile b/Exec/reacting_tests/nse_test/GNUmakefile index 4fe368f65e..9d232868f2 100644 --- a/Exec/reacting_tests/nse_test/GNUmakefile +++ b/Exec/reacting_tests/nse_test/GNUmakefile @@ -11,6 +11,7 @@ USE_MPI = TRUE USE_REACT = TRUE +USE_SIMPLIFIED_SDC := TRUE CASTRO_HOME ?= ../../.. diff --git a/Exec/reacting_tests/nse_test/README.md b/Exec/reacting_tests/nse_test/README.md index 5b534c03ab..b5b833193b 100644 --- a/Exec/reacting_tests/nse_test/README.md +++ b/Exec/reacting_tests/nse_test/README.md @@ -1,4 +1,4 @@ -# nse_test +# `nse_test` This is a simple test problem designed to explore how well hydro and reactions are coupled when a system enters NSE. @@ -7,7 +7,10 @@ This version is based on ``reacting_convergence`` (which is in turn based on ``acoustic_pulse_general``), but using the ``aprox19`` network with the NSE table enabled. -You can run the Strang convergence test with the script convergence_strang.sh +You can run the simplified-SDC convergence test with the script +`convergence_simplified_sdc_w_vel.sh` + +The script `create_pretty_tables.py` will take the 2 (or 3) output +files and make a single LaTeX-formatted table of the results. Use +the `--simple` argument to format in plaintext. -The script create_pretty_tables.py will take the 2 output files and -make a single LaTeX-formatted table of the results. diff --git a/Exec/reacting_tests/nse_test/convergence_simplified_sdc_w_vel.sh b/Exec/reacting_tests/nse_test/convergence_simplified_sdc_w_vel.sh index 0748f46b5b..02b79af326 100755 --- a/Exec/reacting_tests/nse_test/convergence_simplified_sdc_w_vel.sh +++ b/Exec/reacting_tests/nse_test/convergence_simplified_sdc_w_vel.sh @@ -10,17 +10,17 @@ problem.u0=1.e8 problem.v0=1.e8 " -mpiexec -n 8 ${EXEC} inputs.32 ${RUNPARAMS} >& /dev/null -mpiexec -n 8 ${EXEC} inputs.64 ${RUNPARAMS} >& /dev/null -mpiexec -n 8 ${EXEC} inputs.128 ${RUNPARAMS} >& /dev/null +mpiexec -n 8 ${EXEC} inputs.32 ${RUNPARAMS} >& 32.out +mpiexec -n 8 ${EXEC} inputs.64 ${RUNPARAMS} >& 64.out +mpiexec -n 8 ${EXEC} inputs.128 ${RUNPARAMS} >& 128.out RichardsonConvergenceTest2d.gnu.ex coarFile=nse_test_32_plt00080 mediFile=nse_test_64_plt00160 fineFile=nse_test_128_plt00320 >& nse_convergence_simple_sdc_vlo.out -mpiexec -n 8 ${EXEC} inputs.256 ${RUNPARAMS} >& /dev/null +mpiexec -n 8 ${EXEC} inputs.256 ${RUNPARAMS} >& 256.out RichardsonConvergenceTest2d.gnu.ex coarFile=nse_test_64_plt00160 mediFile=nse_test_128_plt00320 fineFile=nse_test_256_plt00640 >& nse_convergence_simple_sdc_lo.out -mpiexec -n 8 ${EXEC} inputs.512 ${RUNPARAMS} >& /dev/null +mpiexec -n 8 ${EXEC} inputs.512 ${RUNPARAMS} >& 512.out RichardsonConvergenceTest2d.gnu.ex coarFile=nse_test_128_plt00320 mediFile=nse_test_256_plt00640 fineFile=nse_test_512_plt01280 >& nse_convergence_simple_sdc_hi.out diff --git a/Exec/reacting_tests/nse_test/problem_initialize_state_data.H b/Exec/reacting_tests/nse_test/problem_initialize_state_data.H index 884a606411..301aba5d2c 100644 --- a/Exec/reacting_tests/nse_test/problem_initialize_state_data.H +++ b/Exec/reacting_tests/nse_test/problem_initialize_state_data.H @@ -16,7 +16,6 @@ void problem_initialize_state_data (int i, int j, int k, Array4 const& state, const GeometryData& geomdata) { - int coord_type = geomdata.Coord(); const Real* dx = geomdata.CellSize(); const Real* problo = geomdata.ProbLo(); @@ -101,11 +100,11 @@ void problem_initialize_state_data (int i, int j, int k, // since the species are interpolated, normalize them Real sumX = 0.0_rt; - for (int n = 0; n < NumSpec; n++) { - sumX += burn_state.xn[n]; + for (auto X : burn_state.xn) { + sumX += X; } - for (int n = 0; n < NumSpec; n++) { - burn_state.xn[n] /= sumX; + for (auto & X : burn_state.xn) { + X /= sumX; } #ifdef NSE_NET From 377991e39a62b361113aea711d61c185cb35daaa Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Fri, 23 Feb 2024 12:39:55 -0500 Subject: [PATCH 09/56] subchandra analysis script: fix lap_rho name (#2760) --- Exec/science/subchandra/analysis/subch_sequence.py | 1 + 1 file changed, 1 insertion(+) diff --git a/Exec/science/subchandra/analysis/subch_sequence.py b/Exec/science/subchandra/analysis/subch_sequence.py index e6f6fad56c..73d2eba3b1 100755 --- a/Exec/science/subchandra/analysis/subch_sequence.py +++ b/Exec/science/subchandra/analysis/subch_sequence.py @@ -103,6 +103,7 @@ def doit(field, add_contours, pfiles): if field == "lap_rho" or add_contours: ds.force_periodicity() ds.add_field(name=("gas", "lap_rho"), sampling_type="local", + display_name=r"$\log_{10}(|\rho^{-1}\nabla^2\rho|)$", function=_lap_rho, units="", validators=[ValidateSpatial(1)]) From 9a07326d47a0baa8b607111506147523d7943054 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Fri, 23 Feb 2024 14:11:23 -0500 Subject: [PATCH 10/56] some updates to the massive star slice plots (#2759) now we offset t based on the driving time also add a time-sequence plot --- .../analysis/massive_star_multi.py | 18 +- .../analysis/massive_star_sequence.py | 178 ++++++++++++++++++ 2 files changed, 191 insertions(+), 5 deletions(-) create mode 100755 Exec/science/massive_star/analysis/massive_star_sequence.py diff --git a/Exec/science/massive_star/analysis/massive_star_multi.py b/Exec/science/massive_star/analysis/massive_star_multi.py index 29f6bf3829..4722093e33 100755 --- a/Exec/science/massive_star/analysis/massive_star_multi.py +++ b/Exec/science/massive_star/analysis/massive_star_multi.py @@ -22,6 +22,13 @@ def make_plot(plotfile, prefix="plot", width_frac=0.1, ds = CastroDataset(plotfile) + t_drive = 0.0 + if "[*] castro.drive_initial_convection_tmax" in ds.parameters: + t_drive = ds.parameters["[*] castro.drive_initial_convection_tmax"] + elif "castro.drive_initial_convection_tmax" in ds.parameters: + t_drive = ds.parameters["castro.drive_initial_convection_tmax"] + print(t_drive) + xmin = ds.domain_left_edge[0] xmax = ds.domain_right_edge[0] @@ -70,8 +77,9 @@ def make_plot(plotfile, prefix="plot", width_frac=0.1, if f == "enuc": # now do a contour of NSE - sp.annotate_contour("in_nse", ncont=1, clim=(0.5, 0.5), take_log=False, - plot_args={"colors": "k", "linewidths": 2}) + if ("boxlib", "in_nse") in ds.derived_field_list: + sp.annotate_contour("in_nse", ncont=1, clim=(0.5, 0.5), take_log=False, + plot_args={"colors": "k", "linewidths": 2}) sp.set_axes_unit("cm") @@ -79,7 +87,7 @@ def make_plot(plotfile, prefix="plot", width_frac=0.1, cbar_location=cbar_location, cbar_pad="2%") fig.subplots_adjust(left=0.05, right=0.95, bottom=0.025, top=0.975) - fig.text(0.02, 0.02, f"time = {float(ds.current_time):8.2f} s", + fig.text(0.02, 0.02, f"$t - \\tau_\\mathrm{{drive}}$ = {float(ds.current_time) - t_drive:6.1f} s", transform=fig.transFigure) fig.set_size_inches(size) fig.tight_layout() @@ -87,7 +95,7 @@ def make_plot(plotfile, prefix="plot", width_frac=0.1, if layout[0] >= layout[1]: extra = "_vertical" - fig.savefig(f"{prefix}_{os.path.basename(plotfile)}_w{width_frac:04.2f}{extra}.pdf", pad_inches=0) + fig.savefig(f"{prefix}_{os.path.basename(plotfile)}_w{width_frac:04.2f}{extra}.pdf", pad_inches=0.1, bbox_inches="tight") if __name__ == "__main__": @@ -95,7 +103,7 @@ def make_plot(plotfile, prefix="plot", width_frac=0.1, p = argparse.ArgumentParser() p.add_argument("--vertical", action="store_true", help="plot 2x2 or 1x4") - p.add_argument("--width_fraction", type=float, default=0.1, + p.add_argument("--width-fraction", type=float, default=0.1, help="fraction of domain to show") p.add_argument("plotfile", type=str, nargs=1, help="plotfile to plot") diff --git a/Exec/science/massive_star/analysis/massive_star_sequence.py b/Exec/science/massive_star/analysis/massive_star_sequence.py new file mode 100755 index 0000000000..96b4218085 --- /dev/null +++ b/Exec/science/massive_star/analysis/massive_star_sequence.py @@ -0,0 +1,178 @@ +#!/usr/bin/env python3 + +import argparse +import os + +import matplotlib +import matplotlib.pyplot as plt +import numpy as np +from mpl_toolkits.axes_grid1 import ImageGrid + +import yt +from yt.frontends.boxlib.api import CastroDataset +# assume that our data is in CGS +from yt.units import cm + +matplotlib.use('agg') + +times = [50, 100, 150, 200, 250] + +def find_files(plist): + + mask = np.zeros(len(times)) + files_to_plot = [] + for pfile in plist: + for k, t in enumerate(times): + if mask[k]: + continue + print(pfile) + ds = CastroDataset(pfile) + if ds.current_time >= t: + files_to_plot.append(pfile) + mask[k] = 1.0 + + return files_to_plot + + +def make_plot(field, pfiles, *, + width_frac=0.1, + size=(19.2, 10.8)): + + fig = plt.figure() + + if len(pfiles) > 8: + nrows = 3 + ncols = (len(pfiles) + 1)//3 + elif len(pfiles) >= 4: + nrows = 2 + ncols = (len(pfiles) + 1)//2 + else: + nrows = 1 + ncols = len(pfiles) + + grid = ImageGrid(fig, 111, nrows_ncols=(nrows, ncols), + axes_pad=0.2, cbar_pad=0.05, + label_mode="L", cbar_mode="single") + + # get some metadata + ds = CastroDataset(pfiles[0]) + + t_drive = 0.0 + if "[*] castro.drive_initial_convection_tmax" in ds.parameters: + t_drive = ds.parameters["[*] castro.drive_initial_convection_tmax"] + elif "castro.drive_initial_convection_tmax" in ds.parameters: + t_drive = ds.parameters["castro.drive_initial_convection_tmax"] + print(t_drive) + + xmin = ds.domain_left_edge[0] + xmax = ds.domain_right_edge[0] + + ymin = ds.domain_left_edge[1] + ymax = ds.domain_right_edge[1] + + xctr = 0.0 * xmin + L_x = xmax - xmin + + yctr = 0.5 * (ymin + ymax) + L_y = ymax - ymin + + f = field + + if f == "Temp" or f == "abar": + text_color = "white" + else: + text_color = "black" + + for i in range(nrows * ncols): + + if i < len(pfiles): + pf = pfiles[i] + else: + grid[i].remove() + continue + + ds = CastroDataset(pf) + + sp = yt.SlicePlot(ds, "theta", f, + center=[xmin + 0.5*width_frac*L_x, yctr, 0.0*cm], + width=[width_frac*L_x, width_frac*L_y, 0.0*cm], + fontsize="12") + + sp.set_buff_size((2400,2400)) + + sp.annotate_text((0.05, 0.05), + f"$t - \\tau_\\mathrm{{drive}}$ = {float(ds.current_time) - t_drive:8.2f} s", + coord_system="axis", + text_args={"color": text_color}) + + + if f == "Ye": + sp.set_zlim(f, 0.46, 0.5) + sp.set_log(f, False) + sp.set_cmap(f, "magma_r") + elif f == "abar": + sp.set_log(f, False) + sp.set_cmap(f, "viridis") + elif f == "enuc": + sp.set_log(f, True, linthresh=1.e12) + sp.set_zlim(f, -1.e20, 1.e20) + sp.set_cmap(f, "bwr") + elif f == "MachNumber": + sp.set_zlim(f, 1.e-4, 0.3) + sp.set_cmap(f, "plasma") + elif f == "magvel": + sp.set_zlim(f, 100.0, 2.e7) + sp.set_cmap(f, "viridis") + elif f == "magvort": + sp.set_cmap(f, "magma") + sp.set_zlim(f, 1.e-2, 5) + + if f == "enuc": + # now do a contour of NSE + if ("boxlib", "in_nse") in ds.derived_field_list: + sp.annotate_contour("in_nse", levels=1, clim=(0.5, 0.5), take_log=False, + plot_args={"colors": "k", "linewidths": 2}) + + sp.set_axes_unit("cm") + + plot = sp.plots[field] + plot.figure = fig + plot.axes = grid[i].axes + plot.cax = grid.cbar_axes[i] + if i < len(pfiles)-1: + grid[i].axes.xaxis.offsetText.set_visible(False) + if i > 0: + grid[i].axes.yaxis.offsetText.set_visible(False) + + sp._setup_plots() + + fig.set_size_inches(size) + fig.tight_layout() + extra = "" + + fig.savefig(f"massive_star_{f}_w{width_frac:04.2f}.pdf", pad_inches=0.1, bbox_inches="tight") + + +if __name__ == "__main__": + + p = argparse.ArgumentParser() + p.add_argument("--var", type=str, default="Temp", + help="variable to plot") + p.add_argument("--vertical", action="store_true", + help="plot 2x2 or 1x4") + p.add_argument("--width-fraction", type=float, default=0.1, + help="fraction of domain to show") + p.add_argument("plotfiles", type=str, nargs="+", + help="list of plotfiles to plot") + + args = p.parse_args() + + if args.vertical: + size = (7.5, 8.5) + else: + size = (19.2, 8.5) + + plist = find_files(args.plotfiles) + + make_plot(args.var, plist, + width_frac=args.width_fraction, size=size) From 6522215d25962bfe06218f506c8fe4e0841db983 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 28 Feb 2024 07:58:57 -0500 Subject: [PATCH 11/56] set a slightly tighter shock_detection_threshold for oddeven (#2723) this is needed to suppress the carbuncle instability --- Exec/hydro_tests/oddeven/inputs.2d | 1 + 1 file changed, 1 insertion(+) diff --git a/Exec/hydro_tests/oddeven/inputs.2d b/Exec/hydro_tests/oddeven/inputs.2d index 163f9461f6..3ed51b3f92 100644 --- a/Exec/hydro_tests/oddeven/inputs.2d +++ b/Exec/hydro_tests/oddeven/inputs.2d @@ -22,6 +22,7 @@ castro.do_hydro = 1 castro.do_react = 0 castro.ppm_type = 0 castro.hybrid_riemann = 1 +castro.shock_detection_threshold = 0.5 # TIME STEP CONTROL From ac57e6bc2690da63825b75109746620435185e4b Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 28 Feb 2024 07:59:11 -0500 Subject: [PATCH 12/56] some massive_star inputs fixes (#2758) in_nse is not derived, so it wasn't being stored turn on pslope don't store burn weights --- Exec/science/massive_star/inputs_2d.nse | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/Exec/science/massive_star/inputs_2d.nse b/Exec/science/massive_star/inputs_2d.nse index 38d15ec74a..f0e45d585a 100644 --- a/Exec/science/massive_star/inputs_2d.nse +++ b/Exec/science/massive_star/inputs_2d.nse @@ -32,6 +32,7 @@ castro.do_sponge = 1 castro.ppm_type = 1 castro.ppm_temp_fix = 0 +castro.use_pslope = 1 castro.use_flattening = 1 @@ -64,12 +65,12 @@ amr.check_int = 50 # number of timesteps between checkpoints amr.plot_file = massive_star_plt # root name of plot file amr.plot_per = 5.0 amr.derive_plot_vars = ALL -castro.store_burn_weights = 1 +castro.store_burn_weights = 0 amr.small_plot_file = massive_star_smallplt # root name of plot file amr.small_plot_per = 0.5 -amr.small_plot_vars = density Temp -amr.derive_small_plot_vars = abar Ye enuc MachNumber magvel magvort in_nse +amr.small_plot_vars = density Temp in_nse +amr.derive_small_plot_vars = abar Ye enuc MachNumber magvel magvort fab.format = NATIVE_32 From 582f93d7ea77499abc3cd1724f5ffefbbbe54154 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 28 Feb 2024 07:59:23 -0500 Subject: [PATCH 13/56] update the massive star initial model plot script (#2757) things weren't lining up --- .../massive_star/analysis/initial_model.py | 29 +++++++++++++------ 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/Exec/science/massive_star/analysis/initial_model.py b/Exec/science/massive_star/analysis/initial_model.py index aecc03368d..d46cc5001b 100644 --- a/Exec/science/massive_star/analysis/initial_model.py +++ b/Exec/science/massive_star/analysis/initial_model.py @@ -10,9 +10,8 @@ def find_r_for_rho(r, rho, rho_want): return r[idx] -#file = "../15m_500_sec.aprox19.hse.6400" -file = "../15m_500_sec.aprox19.hse.20.0km" -Lx = 1.6384e10 +file = "../15m_500_sec.aprox19.hse.5.00km" +Lx = 8.192e9 data = np.loadtxt(file) @@ -65,6 +64,10 @@ def find_r_for_rho(r, rho, rho_want): ax.set_xlabel("r [cm]") ax.set_ylabel(r"$\rho~[\rm{g/cm^3}]$, $T~[K]$") + +ax.set_xlim(None, 5.e10) +ax.grid(color="b", alpha=0.5, ls=":") + ax2 = ax.twinx() ax2.set_ylabel(r"$Y_e$") @@ -74,8 +77,9 @@ def find_r_for_rho(r, rho, rho_want): lns = l1 + l2 + l3 labs = [l.get_label() for l in lns] -ax.legend(lns, labs, frameon=False) +ax.legend(lns, labs, frameon=False, loc=6) +# species plot ax = fig.add_subplot(212) @@ -92,15 +96,17 @@ def find_r_for_rho(r, rho, rho_want): if Xmax > threshold: if Xmax > 0.5: - lw = 2 + lw = 3 + ls = "-" else: lw = 1 - ax.plot(data[:,0], data[:,n], label=var, lw=lw) + ls = "--" + ax.plot(data[:,0], data[:,n], label=var, lw=lw, ls=ls) ax.axvline(r_refine, color="0.25", ls=":") -ax.axvline(Lx, color="0.25", ls="-") +ax.axvline(Lx, color="0.5", ls="-") ax.set_xscale("log") ax.set_yscale("log") @@ -108,11 +114,16 @@ def find_r_for_rho(r, rho, rho_want): ax.set_xlabel("r [cm]") ax.set_ylabel("mass fraction") -ax.legend(frameon=False, fontsize="small", ncol=2) +ax.set_xlim(None, 5.e10) +ax.set_ylim(1.e-6, None) + +ax.grid(color="b", alpha=0.5, ls=":") + +ax.legend(frameon=True, edgecolor="w", ncol=1, framealpha=0.5) fig.set_size_inches((8, 12)) fig.tight_layout() -fig.savefig("initial_model.png") +fig.savefig("initial_model.pdf") From 465a83f5a582811ba10f8b8446aded3bbdc5b23f Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Fri, 1 Mar 2024 08:21:21 -0500 Subject: [PATCH 14/56] add a 3d inputs for the massive star problem (#2763) --- Exec/science/massive_star/inputs_3d.nse | 158 ++++++++++++++++++++++++ 1 file changed, 158 insertions(+) create mode 100644 Exec/science/massive_star/inputs_3d.nse diff --git a/Exec/science/massive_star/inputs_3d.nse b/Exec/science/massive_star/inputs_3d.nse new file mode 100644 index 0000000000..eebdba6af2 --- /dev/null +++ b/Exec/science/massive_star/inputs_3d.nse @@ -0,0 +1,158 @@ +# ------------------ INPUTS TO MAIN PROGRAM ------------------- + +amr.plot_files_output = 1 +amr.checkpoint_files_output = 1 + +max_step = 50 +stop_time = 360000 + +geometry.is_periodic = 0 0 +geometry.coord_sys = 0 # r-z coordinates + +geometry.prob_lo = 0. 0. 0. +geometry.prob_hi = 1.6384e10 1.6384e10 1.6384e10 + +amr.n_cell = 512 512 512 + +amr.max_level = 3 # maximum level number allowed + +castro.lo_bc = 2 2 2 +castro.hi_bc = 2 2 2 + +# >>>>>>>>>>>>> BC FLAGS <<<<<<<<<<<<<<<< +# 0 = Interior 3 = Symmetry +# 1 = Inflow 4 = SlipWall +# 2 = Outflow 5 = NoSlipWall +# >>>>>>>>>>>>> BC FLAGS <<<<<<<<<<<<<<<< + +# GPU options +castro.hydro_memory_footprint_ratio = 3 + + +castro.do_hydro = 1 +castro.do_grav = 1 +castro.do_react = 1 +castro.do_sponge = 1 + +castro.ppm_type = 1 +castro.ppm_temp_fix = 0 +castro.use_pslope = 1 + +castro.use_flattening = 1 + +castro.riemann_solver = 1 + +gravity.gravity_type = MonopoleGrav +gravity.drdxfac = 2 +castro.grav_source_type = 4 + +castro.sponge_upper_density = 1.e3 +castro.sponge_lower_density = 1.e2 +castro.sponge_timescale = 1.e-3 + +castro.cfl = 0.4 # cfl number for hyperbolic system +castro.init_shrink = 0.01 # scale back initial timestep by this factor +castro.change_max = 1.2 # factor by which dt is allowed to change each timestep +castro.sum_interval = 10 # timesteps between computing and printing volume averages + +#castro.dtnuc_e = 0.25 +#castro.dtnuc_X = 0.25 + +amr.ref_ratio = 2 2 2 2 # refinement ratio +amr.regrid_int = 10000 # how often to regrid +amr.n_error_buf = 4 2 2 2 # number of buffer cells in error est +amr.grid_eff = 0.7 # what constitutes an efficient grid + +amr.check_file = massive_star_chk # root name of checkpoint file +amr.check_int = 200 # number of timesteps between checkpoints + +amr.plot_file = massive_star_plt # root name of plot file +amr.plot_per = 5.0 +amr.derive_plot_vars = ALL +castro.store_burn_weights = 0 + +amr.small_plot_file = massive_star_smallplt # root name of plot file +amr.small_plot_per = 0.5 +amr.small_plot_vars = density Temp in_nse\ +amr.derive_small_plot_vars = abar Ye enuc MachNumber magvel magvort + +fab.format = NATIVE_32 + +castro.plot_per_is_exact = 0 + + +amr.max_grid_size = 64 # maximum grid size allowed -- used to control parallelism +amr.blocking_factor = 32 # block factor in grid generation + +amr.v = 1 # control verbosity in Amr.cpp +castro.v = 1 # control verbosity in Castro.cpp + + +castro.small_dens = 1.0 +castro.small_temp = 1.e6 + +castro.time_integration_method = 3 +castro.use_retry = 1 +castro.max_subcycles = 16 + +# problem initialization + +problem.model_name = "15m_500_sec.aprox19.hse.5.00km" + +problem.perturb_model = 1 +problem.velpert_amplitude = 5.e6 + +problem.interpolate_pres = 1 + +# convection + +castro.drive_initial_convection = 1 +castro.drive_initial_convection_reinit_period = 2 +castro.drive_initial_convection_tmax = 50 + +# refinement + +amr.refinement_indicators = denerr denerr2 denerr3 + +amr.refine.denerr.max_level = 1 +amr.refine.denerr.value_greater = 1.e3 +amr.refine.denerr.field_name = density + +amr.refine.denerr2.max_level = 2 +amr.refine.denerr2.value_greater = 1.e4 +amr.refine.denerr2.field_name = density + +amr.refine.denerr3.max_level = 3 +amr.refine.denerr3.value_greater = 1.e5 +amr.refine.denerr3.field_name = density + + +# Microphysics + +integrator.rtol_spec = 1.e-5 +integrator.atol_spec = 1.e-5 +integrator.rtol_enuc = 1.e-5 +integrator.atol_enuc = 1.e-5 + +integrator.jacobian = 1 + +network.rho_nse = 1.e7 +network.T_nse = 3.e9 +network.Si_nse = 0.02 +network.C_nse = 1.0 +network.O_nse = 1.0 + +integrator.ode_max_steps = 500000 + +network.small_x = 1.e-10 + +network.nse_relax_factor = 0.9 + +# use cubic interpolation from the NSE table +network.nse_table_interp_linear = 0 + +# disable jacobian caching in VODE +integrator.use_jacobian_caching = 0 + +# do we include weak rate neutrino losses in the energy? +integrator.nse_include_enu_weak = 0 From 8cb814bd796f21c2620aa3906ee7088a371c179d Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Fri, 1 Mar 2024 15:57:38 -0500 Subject: [PATCH 15/56] update changes --- CHANGES.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/CHANGES.md b/CHANGES.md index 12be083506..7aeb11c743 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,3 +1,14 @@ +# 24.03 + + * Documentation updates (#2742, #2752, #2753) + + * Fix some code warnings (#2737) + + * Fixed the exact Riemann solver compilation (#2745) + + * Fix an issue with large kernel sizes with ROCm in the reduction code + in the reactions (#2749) + # 24.02 * Lot's of code fixes from coverity and clang-tidy (#2736, #2734, From 5728a640ea7e5e7c47532402ff754e6a1a030fe6 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Thu, 7 Mar 2024 17:27:46 -0500 Subject: [PATCH 16/56] update to 24.03 --- external/Microphysics | 2 +- external/amrex | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/external/Microphysics b/external/Microphysics index 649063a33f..02d46a67cf 160000 --- a/external/Microphysics +++ b/external/Microphysics @@ -1 +1 @@ -Subproject commit 649063a33f1ef83dd9acc457d7a79ceebcf3b60c +Subproject commit 02d46a67cf5852509cc35db7850e5f87da495679 diff --git a/external/amrex b/external/amrex index 52393d3faf..d737886d57 160000 --- a/external/amrex +++ b/external/amrex @@ -1 +1 @@ -Subproject commit 52393d3fafc835fa379f0420aa2de4ccdddf155a +Subproject commit d737886d574d4f1c0cf76323337b666ecd5bb4e0 From 25cc6d8f8594a613c88682da052e1147c45bd64b Mon Sep 17 00:00:00 2001 From: Zhi Chen <62574124+zhichen3@users.noreply.github.com> Date: Fri, 8 Mar 2024 10:26:48 -0500 Subject: [PATCH 17/56] update detonation problem for nse_net (#2765) --- Exec/science/Detonation/GNUmakefile | 2 +- Exec/science/Detonation/analysis/profiles.py | 48 +++++++++++++------ Exec/science/Detonation/inputs-det-x.nse_net | 8 ++-- .../problem_initialize_state_data.H | 10 ++-- 4 files changed, 44 insertions(+), 24 deletions(-) diff --git a/Exec/science/Detonation/GNUmakefile b/Exec/science/Detonation/GNUmakefile index 256b2c173b..2783b93351 100644 --- a/Exec/science/Detonation/GNUmakefile +++ b/Exec/science/Detonation/GNUmakefile @@ -18,7 +18,7 @@ EOS_DIR := helmholtz # This sets the EOS directory in $(MICROPHYSICS_HOME)/networks ifeq ($(USE_NSE_NET), TRUE) - NETWORK_DIR := ase + NETWORK_DIR := subch_base SCREEN_METHOD := chabrier1998 else NETWORK_DIR := aprox19 diff --git a/Exec/science/Detonation/analysis/profiles.py b/Exec/science/Detonation/analysis/profiles.py index 2fd0f6ae3a..26aa70cb8f 100755 --- a/Exec/science/Detonation/analysis/profiles.py +++ b/Exec/science/Detonation/analysis/profiles.py @@ -35,7 +35,7 @@ def nuc_list_filter(nuc): return 0 -def get_Te_profile(plotfile): +def get_Te_profile(plotfile, plot_in_nse=False): ds = yt.load(plotfile, hint="castro") @@ -48,10 +48,11 @@ def get_Te_profile(plotfile): x_coord = np.array(ad['x'][srt]) temp = np.array(ad['Temp'][srt]) enuc = np.array(ad['enuc'][srt]) - + if plot_in_nse: + in_nse = np.array(ad['in_nse'][srt]) + return time, x_coord, temp, enuc, in_nse return time, x_coord, temp, enuc - def get_nuc_profile(plotfile): ds = yt.load(plotfile, hint="castro") @@ -72,19 +73,27 @@ def get_nuc_profile(plotfile): return time, x_coord, nuc_fracs -def plot_Te(prefix, nums, skip, limitlabels, xmin, xmax): +def plot_Te(prefix, nums, skip, limitlabels, xmin, xmax, plot_in_nse=False): f = plt.figure() - f.set_size_inches(7.0, 9.0) - - ax_T = f.add_subplot(211) - ax_e = f.add_subplot(212) # Get set of colors to use and apply to plot numplots = int(len(nums) / skip) cm = plt.get_cmap('nipy_spectral') clist = [cm(0.95*i/numplots) for i in range(numplots + 1)] hexclist = [rgba_to_hex(ci) for ci in clist] + + if plot_in_nse: + f.set_size_inches(7.0, 12.0) + ax_nse = f.add_subplot(311) + ax_T = f.add_subplot(312) + ax_e = f.add_subplot(313) + ax_nse.set_prop_cycle(cycler('color', hexclist)) + else: + f.set_size_inches(7.0, 9.0) + ax_T = f.add_subplot(211) + ax_e = f.add_subplot(212) + ax_T.set_prop_cycle(cycler('color', hexclist)) ax_e.set_prop_cycle(cycler('color', hexclist)) @@ -101,7 +110,11 @@ def plot_Te(prefix, nums, skip, limitlabels, xmin, xmax): pfile = f"{prefix}{nums[n]}" - time, x, T, enuc = get_Te_profile(pfile) + if plot_in_nse: + time, x, T, enuc, in_nse = get_Te_profile(pfile, plot_in_nse) + ax_nse.plot(x, in_nse) + else: + time, x, T, enuc = get_Te_profile(pfile) if index % skiplabels == 0: ax_T.plot(x, T, label=f"t = {time:6.4g} s") @@ -117,6 +130,9 @@ def plot_Te(prefix, nums, skip, limitlabels, xmin, xmax): if xmax > 0: ax_T.set_xlim(xmin, xmax) + ax_e.set_xlim(xmin, xmax) + if plot_in_nse: + ax_nse.set_xlim(xmin, xmax) ax_e.set_yscale("log") ax_e.set_ylabel(r"$S_\mathrm{nuc}$ (erg/g/s)") @@ -125,8 +141,8 @@ def plot_Te(prefix, nums, skip, limitlabels, xmin, xmax): cur_lims = ax_e.get_ylim() ax_e.set_ylim(1.e-10*cur_lims[-1], cur_lims[-1]) - if xmax > 0: - ax_e.set_xlim(xmin, xmax) + if plot_in_nse: + ax_nse.set_ylabel("IN NSE") f.savefig("det_Te.png") @@ -189,12 +205,13 @@ def plot_nuc_frac(prefix, nums, skip, limitlabels, xmin, xmax): f.savefig("det_nuc.png") -def doit(prefix, nums, skip, limitlabels, xmin, xmax, do_nuc_fracs=False): +def doit(prefix, nums, skip, limitlabels, xmin, xmax, + do_nuc_fracs=False, plot_in_nse=False): if do_nuc_fracs: plot_nuc_frac(prefix, nums, skip, limitlabels, xmin, xmax) else: - plot_Te(prefix, nums, skip, limitlabels, xmin, xmax) + plot_Te(prefix, nums, skip, limitlabels, xmin, xmax, plot_in_nse) if __name__ == "__main__": @@ -214,6 +231,9 @@ def doit(prefix, nums, skip, limitlabels, xmin, xmax, do_nuc_fracs=False): p.add_argument("--do_nuc_fracs", dest="do_nuc_fracs", action="store_true", help="Plot nuc fracs, otherwise Temp and enuc plot") + p.add_argument("--plot_in_nse", dest="plot_in_nse", + action="store_true", + help="Plot in_nse quantity along with temperature and enuc") args = p.parse_args() @@ -221,4 +241,4 @@ def doit(prefix, nums, skip, limitlabels, xmin, xmax, do_nuc_fracs=False): plot_nums = sorted([p.split("plt")[1] for p in args.plotfiles], key=int) doit(plot_prefix, plot_nums, args.skip, args.limitlabels, args.xmin, - args.xmax, do_nuc_fracs=args.do_nuc_fracs) + args.xmax, do_nuc_fracs=args.do_nuc_fracs, plot_in_nse=args.plot_in_nse) diff --git a/Exec/science/Detonation/inputs-det-x.nse_net b/Exec/science/Detonation/inputs-det-x.nse_net index cab9513b75..d67a09d289 100644 --- a/Exec/science/Detonation/inputs-det-x.nse_net +++ b/Exec/science/Detonation/inputs-det-x.nse_net @@ -32,7 +32,7 @@ castro.small_temp = 1.e7 castro.riemann_solver = 0 -castro.time_integration_method = 0 +castro.time_integration_method = 3 # TIME STEP CONTROL castro.cfl = 0.5 # cfl number for hyperbolic system @@ -104,10 +104,10 @@ integrator.rtol_spec = 1.e-6 integrator.atol_spec = 1.e-6 integrator.rtol_enuc = 1.e-6 -integrator.jacobian = 1 +integrator.jacobian = 2 integrator.ode_max_steps = 1500000 -nse.nse_molar_independent = 1 +nse.nse_molar_independent = 0 nse.nse_dx_independent = 1 nse.ase_tol = 0.1 -nse.nse_skip_molar = 1 \ No newline at end of file +nse.nse_skip_molar = 0 \ No newline at end of file diff --git a/Exec/science/Detonation/problem_initialize_state_data.H b/Exec/science/Detonation/problem_initialize_state_data.H index 3b08ce86a9..f594e8f15e 100644 --- a/Exec/science/Detonation/problem_initialize_state_data.H +++ b/Exec/science/Detonation/problem_initialize_state_data.H @@ -62,12 +62,12 @@ void problem_initialize_state_data (int i, int j, int k, burn_state.mu_p = problem::mu_p; burn_state.mu_n = problem::mu_n; - if (burn_state.T > 2.0e9) { - auto nse_state = get_actual_nse_state(burn_state); + if (burn_state.T > 2.5e9) { + auto nse_state = get_actual_nse_state(burn_state, 1.0e-10_rt, true); - for (int n = 0; n < NumSpec; ++n) { - state(i,j,k,UFS+n) = state(i,j,k,URHO) * nse_state.xn[n]; - } + // for (int n = 0; n < NumSpec; ++n) { + // state(i,j,k,UFS+n) = state(i,j,k,URHO) * nse_state.xn[n]; + // } state(i,j,k,UMUP) = nse_state.mu_p; state(i,j,k,UMUN) = nse_state.mu_n; From 4aedefce04c8e9641f3b72810f57b525e1699cec Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Sat, 9 Mar 2024 18:39:40 -0500 Subject: [PATCH 18/56] better refinement for the 3d massivestar (#2764) --- Exec/science/massive_star/inputs_3d.nse | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/Exec/science/massive_star/inputs_3d.nse b/Exec/science/massive_star/inputs_3d.nse index eebdba6af2..d7e2cdd48e 100644 --- a/Exec/science/massive_star/inputs_3d.nse +++ b/Exec/science/massive_star/inputs_3d.nse @@ -58,7 +58,7 @@ castro.sum_interval = 10 # timesteps between computing and printing volu #castro.dtnuc_e = 0.25 #castro.dtnuc_X = 0.25 -amr.ref_ratio = 2 2 2 2 # refinement ratio +amr.ref_ratio = 4 2 2 2 # refinement ratio amr.regrid_int = 10000 # how often to regrid amr.n_error_buf = 4 2 2 2 # number of buffer cells in error est amr.grid_eff = 0.7 # what constitutes an efficient grid @@ -73,9 +73,13 @@ castro.store_burn_weights = 0 amr.small_plot_file = massive_star_smallplt # root name of plot file amr.small_plot_per = 0.5 -amr.small_plot_vars = density Temp in_nse\ +amr.small_plot_vars = density Temp in_nse amr.derive_small_plot_vars = abar Ye enuc MachNumber magvel magvort +#amr.checkpoint_files_output = 0 +#amr.plot_files_output = 0 +#amr.smallplot_files_output = 0 + fab.format = NATIVE_32 castro.plot_per_is_exact = 0 @@ -115,15 +119,15 @@ castro.drive_initial_convection_tmax = 50 amr.refinement_indicators = denerr denerr2 denerr3 amr.refine.denerr.max_level = 1 -amr.refine.denerr.value_greater = 1.e3 +amr.refine.denerr.value_greater = 2.e3 amr.refine.denerr.field_name = density amr.refine.denerr2.max_level = 2 -amr.refine.denerr2.value_greater = 1.e4 +amr.refine.denerr2.value_greater = 3.e4 amr.refine.denerr2.field_name = density amr.refine.denerr3.max_level = 3 -amr.refine.denerr3.value_greater = 1.e5 +amr.refine.denerr3.value_greater = 3.e5 amr.refine.denerr3.field_name = density From fbd880fa0ed49df9005b2c73aeeadfa107ea1c94 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Sat, 9 Mar 2024 18:54:44 -0500 Subject: [PATCH 19/56] add style CI from Microphysics (#2769) this checks for tabs and trailing whitespace --- .github/workflows/get_release_txt.py | 6 +- .github/workflows/style.yml | 22 ++ .github/workflows/style/check_tabs.sh | 36 ++++ .../style/check_trailing_whitespaces.sh | 38 ++++ Diagnostics/DustCollapse/analytic.f90 | 10 +- Diagnostics/DustCollapse/analytic.txt | 200 +++++++++--------- Diagnostics/Sedov/main.cpp | 2 +- Docs/preprocess_files.py | 4 +- Docs/source/ConvertCheckpoint.rst | 2 +- Docs/source/EOS.rst | 2 +- Docs/source/FlowChart.rst | 26 +-- Docs/source/Hydrodynamics.rst | 22 +- Docs/source/Introduction.rst | 2 +- Docs/source/Particles.rst | 14 +- Docs/source/build_system.rst | 14 +- Docs/source/creating_a_problem.rst | 4 +- Docs/source/development.rst | 2 +- Docs/source/diffusion.rst | 4 +- Docs/source/faq.rst | 6 +- Docs/source/hse.rst | 2 +- Docs/source/inputs.rst | 4 +- Docs/source/mhd.rst | 4 +- Docs/source/problem_setups.rst | 8 +- Docs/source/radiation.rst | 2 +- Docs/source/reactions.rst | 6 +- Docs/source/software.rst | 6 +- Docs/source/sponge.rst | 6 +- Docs/source/timestepping.rst | 2 +- Docs/source/visualization.rst | 2 +- .../problem_initialize_state_data.H | 2 +- .../StarGrav/problem_initialize_mhd_data.H | 4 +- .../hse_convergence/convergence_plm.sh | 40 ++-- .../hse_convergence/convergence_ppm.sh | 32 +-- .../hse_convergence/convergence_sdc.sh | 40 ++-- .../hydrostatic_adjust/problem_source.H | 2 +- Exec/hydro_tests/Sedov/problem_initialize.H | 2 +- .../Sedov/problem_initialize_state_data.H | 2 +- .../testsuite_analysis/sedov_2d_sph_in_cyl.py | 2 +- .../acoustic_pulse/analysis/slice_multi.py | 2 +- .../acoustic_pulse/convergence_ppm_as_1d.sh | 2 +- .../problem_initialize_state_data.H | 2 +- .../analysis/slice_multi.py | 2 +- .../problem_initialize.H | 2 +- .../gamma_law_bubble/Problem_Derive.cpp | 2 +- .../gresho_vortex/problem_initialize.H | 2 +- .../problem_initialize_state_data.H | 2 +- .../problem_initialize_state_data.H | 14 +- .../test_convect/problem_diagnostics.H | 4 +- .../hydro_tests/test_convect/problem_source.H | 6 +- .../toy_convect/problem_diagnostics.H | 4 +- .../problem_initialize_state_data.H | 2 +- .../Rad2Tshock/python/Analytical-Test.py | 74 +++---- .../Rad2Tshock/python/LowrieEdwardsUnits.py | 4 +- .../Rad2Tshock/python/RadShock.py | 18 +- .../Rad2Tshock/python/initincgs.py | 6 +- .../Rad2Tshock/python/paper-M2-mg.py | 2 +- .../Rad2Tshock/python/paper-M2.py | 2 +- .../radiation_tests/Rad2Tshock/python/phys.py | 4 +- .../problem_initialize_rad_data.H | 2 +- .../problem_initialize_state_data.H | 2 +- .../RadShestakovBolstad/python/initunits.py | 4 +- .../RadShestakovBolstad/python/paper.py | 6 +- .../RadShestakovBolstad/python/phys.py | 4 +- .../RadSphere/Tools/fradsphere.f90 | 14 +- .../radiation_tests/RadSphere/Tools/radbc.f90 | 12 +- .../RadSuOlson/python/paper.py | 4 +- .../RadSuOlsonMG/python/initunits.py | 2 +- .../RadSuOlsonMG/python/paper.py | 8 +- .../RadSuOlsonMG/python/phys.py | 4 +- .../analysis/slice_multi.py | 2 +- .../bubble_convergence/converge_test.sh | 2 +- .../problem_initialize_state_data.H | 2 +- .../nse_test/analysis/slice_multi.py | 2 +- .../analysis/slice_multi.py | 2 +- .../reacting_convergence/problem_initialize.H | 2 +- Exec/reacting_tests/toy_flame/Prob.cpp | 4 +- .../Detonation/analysis/shock_speed.py | 6 +- Exec/science/convective_flame/slice.py | 2 +- Exec/science/flame/Prob.cpp | 4 +- .../flame_wave/analysis/flame_speed.py | 28 +-- .../flame_wave/analysis/front_tracker.py | 136 ++++++------ .../flame_wave/analysis/image_animator.py | 8 +- .../flame_wave/analysis/mpl_image_animator.py | 32 +-- .../flame_wave/analysis/plot_generator.py | 22 +- Exec/science/flame_wave/analysis/profiles.py | 4 +- .../flame_wave/analysis/trajectories_info.py | 2 +- .../frontier/frontier-scaling-2023-04-06.txt | 2 +- .../frontier-scaling-rkc-2023-05-31.txt | 2 +- .../scaling/summit/scaling_20200613.txt | 4 +- .../scaling/summit/scaling_20230407.txt | 4 +- .../massive_star/analysis/initial_model.py | 4 +- .../problem_initialize_state_data.H | 2 +- Exec/science/planet/HotJupiter.cpp | 80 +++---- Exec/science/planet/dataset_lineplot.py | 144 ++++++------- .../wdmerger/problem_initialize_mhd_data.H | 16 +- Exec/science/wdmerger/problem_source.H | 2 +- Exec/science/wdmerger/wdmerger_util.cpp | 4 +- Exec/unit_tests/diffusion_test/Prob.cpp | 2 +- Exec/unit_tests/diffusion_test/README.md | 48 ++--- .../convergence_powerlaw_sdc4.txt | 20 +- .../problem_initialize_state_data.H | 2 +- Source/diffusion/Diffusion.H | 2 +- Source/driver/Castro.H | 12 +- Source/driver/Castro.cpp | 44 ++-- Source/driver/Castro_advance.cpp | 10 +- Source/driver/Castro_io.cpp | 6 +- Source/driver/Castro_setup.cpp | 14 +- Source/driver/Derive.H | 2 +- Source/driver/runtime_parameters.H | 2 +- Source/driver/sum_utils.cpp | 14 +- Source/gravity/Castro_gravity.cpp | 2 +- Source/gravity/Gravity.cpp | 46 ++-- Source/gravity/binary.H | 2 +- Source/hydro/Castro_ctu_rad.cpp | 4 +- Source/hydro/Castro_hydro.cpp | 6 +- Source/hydro/outline.txt | 4 +- Source/hydro/riemann.cpp | 4 +- Source/mhd/electric.cpp | 2 +- Source/mhd/hlld.cpp | 14 +- Source/mhd/mhd_eigen.H | 10 +- Source/problems/Prob.cpp | 2 +- Source/radiation/Castro_radiation.cpp | 10 +- Source/radiation/HABEC.H | 4 +- Source/radiation/HypreABec.cpp | 18 +- Source/radiation/HypreExtMultiABec.cpp | 14 +- Source/radiation/HypreMultiABec.cpp | 2 +- Source/radiation/MGFLD.cpp | 78 +++---- Source/radiation/MGFLDRadSolver.cpp | 94 ++++---- Source/radiation/MGRadBndry.cpp | 4 +- Source/radiation/RadBndry.cpp | 6 +- Source/radiation/RadHydro.H | 2 +- Source/radiation/RadMultiGroup.cpp | 2 +- Source/radiation/RadPlotvar.cpp | 4 +- Source/radiation/RadSolve.cpp | 26 +-- Source/radiation/SGRadSolver.cpp | 2 +- Source/radiation/_interpbndry/RadBndryData.H | 6 +- .../radiation/_interpbndry/RadBndryData.cpp | 2 +- Source/radiation/_interpbndry/RadBoundCond.H | 4 +- .../_interpbndry/RadInterpBndryData.H | 8 +- Source/radiation/fluxlimiter.H | 2 +- Source/rotation/Castro_rotation.H | 2 +- Source/rotation/rotation_sources.cpp | 4 +- Source/sdc/Castro_sdc.cpp | 2 +- Source/sdc/sdc_newton_solve.H | 2 +- Util/ConvertCheckpoint/Embiggen.cpp | 94 ++++---- Util/code_checker/clang_static_analysis.py | 2 +- Util/code_checker/pr_tab_remover.sh | 2 +- Util/scripts/get_castro.sh | 2 +- Util/scripts/get_castro_date.sh | 2 +- Util/yt/README.md | 6 +- Util/yt/vol-wd-spherical-stereo.py | 4 +- Util/yt/vol-wd-spherical.py | 4 +- deploy_docs_action.sh | 6 +- license.txt | 6 +- 154 files changed, 1061 insertions(+), 965 deletions(-) create mode 100644 .github/workflows/style.yml create mode 100755 .github/workflows/style/check_tabs.sh create mode 100755 .github/workflows/style/check_trailing_whitespaces.sh diff --git a/.github/workflows/get_release_txt.py b/.github/workflows/get_release_txt.py index 4837761d6c..30cee63eff 100644 --- a/.github/workflows/get_release_txt.py +++ b/.github/workflows/get_release_txt.py @@ -26,9 +26,9 @@ txt = txt[m.end():].strip() else: txt = "" - - # we now need to substitute characters in the string so that - # the action can deal with line breaks + + # we now need to substitute characters in the string so that + # the action can deal with line breaks txt = txt.replace('%', '%25') txt = txt.replace('\n', '%0A') txt = txt.replace('\r', '%0D') diff --git a/.github/workflows/style.yml b/.github/workflows/style.yml new file mode 100644 index 0000000000..5b5af5e8dd --- /dev/null +++ b/.github/workflows/style.yml @@ -0,0 +1,22 @@ +name: Style + +on: [push, pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-style + cancel-in-progress: true + +jobs: + tabs: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Tabs + run: .github/workflows/style/check_tabs.sh + + trailing_whitespaces: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Trailing Whitespaces + run: .github/workflows/style/check_trailing_whitespaces.sh diff --git a/.github/workflows/style/check_tabs.sh b/.github/workflows/style/check_tabs.sh new file mode 100755 index 0000000000..f4418644e3 --- /dev/null +++ b/.github/workflows/style/check_tabs.sh @@ -0,0 +1,36 @@ +#!/usr/bin/env bash + +set -eu -o pipefail + +find . -type d \( -name .git \ + -o -path ./paper \ + -o -name build -o -name install \ + -o -name tmp_build_dir -o -name tmp_install_dir \ + \) -prune -o \ + -type f \( \( -name "*.H" -o -name "*.h" -o -name "*.hh" -o -name "*.hpp" \ + -o -name "*.c" -o -name "*.cc" -o -name "*.cpp" -o -name "*.cxx" \ + -o -name "*.f" -o -name "*.F" -o -name "*.f90" -o -name "*.F90" \ + -o -name "*.py" \ + -o -name "*.md" -o -name "*.rst" \ + -o -name "*.sh" \ + -o -name "*.tex" \ + -o -name "*.txt" \ + -o -name "*.yml" \) \ + -a \( ! -name "*.tab.h" -a ! -name "*.tab.nolint.H" \ + -a ! -name "*.lex.h" -a ! -name "*.lex.nolint.H" \) \ + \) \ + -exec grep -Iq . {} \; \ + -exec sed -i 's/\t/\ \ \ \ /g' {} + + +gitdiff=`git diff` + +if [ -z "$gitdiff" ] +then + exit 0 +else + echo -e "\nTabs are not allowed. Changes suggested by" + echo -e " ${0}\n" + git --no-pager diff + echo "" + exit 1 +fi diff --git a/.github/workflows/style/check_trailing_whitespaces.sh b/.github/workflows/style/check_trailing_whitespaces.sh new file mode 100755 index 0000000000..b33b62cf5c --- /dev/null +++ b/.github/workflows/style/check_trailing_whitespaces.sh @@ -0,0 +1,38 @@ +#!/usr/bin/env bash + +set -eu -o pipefail + +find . -type d \( -name .git \ + -o -path ./paper \ + -o -name build -o -name install \ + -o -name tmp_build_dir -o -name tmp_install_dir \ + -o -path ./util/gcem \ + \) -prune -o \ + -type f \( \( -name "*.H" -o -name "*.h" -o -name "*.hh" -o -name "*.hpp" \ + -o -name "*.c" -o -name "*.cc" -o -name "*.cpp" -o -name "*.cxx" \ + -o -name "*.f" -o -name "*.F" -o -name "*.f90" -o -name "*.F90" \ + -o -name "*.py" \ + -o -name "*.rst" \ + -o -name "*.sh" \ + -o -name "*.tex" \ + -o -name "*.txt" \ + -o -name "*.yml" \) \ + -a \( ! -name "*.tab.h" -a ! -name "*.tab.nolint.H" \ + -a ! -name "*.lex.h" -a ! -name "*.lex.nolint.H" \ + -a ! -path "./networks/*/reaclib_rates.H" \) \ + \) \ + -exec grep -Iq . {} \; \ + -exec sed -i 's/[[:blank:]]\+$//g' {} + + +gitdiff=`git diff` + +if [ -z "$gitdiff" ] +then + exit 0 +else + echo -e "\nTrailing whitespaces at the end of a line are not allowed. Changes suggested by" + echo -e " ${0}\n" + git --no-pager diff + echo "" + exit 1 +fi diff --git a/Diagnostics/DustCollapse/analytic.f90 b/Diagnostics/DustCollapse/analytic.f90 index d1a4093b26..bb21aae071 100644 --- a/Diagnostics/DustCollapse/analytic.f90 +++ b/Diagnostics/DustCollapse/analytic.f90 @@ -1,6 +1,6 @@ ! Print out the analytic solution for the homologous dust collapse problem, ! from Colgate and White 1966, ApJ, 143, 626. -! +! ! This will yield r(t) as a function of t module constants_module @@ -18,7 +18,7 @@ module constants_module ! we try to do equal timesteps, but eventually, the radius of the ! sphere is changing so quickly that we need to adjust the size of - ! the timestep. The code will take nstep timesteps, with the + ! the timestep. The code will take nstep timesteps, with the ! initial timestep to be (t_f - t_i)/(nstep - 1). Once the radius ! begins to change significantly, we will begin halving the timestep ! as needed. @@ -111,7 +111,7 @@ function f(r,t) result (func) use constants_module implicit none - + double precision, intent(in) :: r, t double precision :: func @@ -130,7 +130,7 @@ function dfdr(r,t) result (dfuncdr) use constants_module implicit none - + double precision, intent(in) :: r, t double precision :: dfuncdr @@ -145,4 +145,4 @@ function dfdr(r,t) result (dfuncdr) end function dfdr - + diff --git a/Diagnostics/DustCollapse/analytic.txt b/Diagnostics/DustCollapse/analytic.txt index e6295cd8d9..d77350424a 100644 --- a/Diagnostics/DustCollapse/analytic.txt +++ b/Diagnostics/DustCollapse/analytic.txt @@ -1,100 +1,100 @@ - 1.00000000000000002E-003 649909135.03119123 - 2.00000001505167783E-003 649636489.29833126 - 3.00000003010335563E-003 649181909.86863339 - 4.00000004515503344E-003 648545142.11149800 - 5.00000006020671125E-003 647725827.94719517 - 6.00000007525838906E-003 646723505.15455902 - 7.00000009031006686E-003 645537605.90191960 - 8.00000010536174554E-003 644167454.93684888 - 9.00000012041342334E-003 642612267.44508624 - 1.00000001354651012E-002 640871146.53866076 - 1.10000001505167790E-002 638943080.30864108 - 1.20000001655684568E-002 636826938.57690644 - 1.30000001806201346E-002 634521469.03385830 - 1.40000001956718124E-002 632025293.06391215 - 1.50000002107234902E-002 629336900.94825923 - 1.60000002257751697E-002 626454646.57255840 - 1.70000002408268493E-002 623376741.51493466 - 1.80000002558785288E-002 620101248.48522842 - 1.90000002709302084E-002 616626074.03659952 - 2.00000002859818879E-002 612948960.51813209 - 2.10000003010335674E-002 609067477.12493813 - 2.20000003160852470E-002 604979010.01064956 - 2.30000003311369265E-002 600680751.32512844 - 2.40000003461886061E-002 596169687.06278419 - 2.50000003612402856E-002 591442583.57983398 - 2.60000003762919651E-002 586495972.61729527 - 2.70000003913436447E-002 581326134.64072454 - 2.80000004063953242E-002 575929080.27714694 - 2.90000004214470038E-002 570300529.59325635 - 3.00000004364986833E-002 564435888.91553104 - 3.10000004515503629E-002 558330224.84078777 - 3.20000004666020424E-002 551978235.02284503 - 3.30000004816537185E-002 545374215.24478471 - 3.40000004967053945E-002 538512022.19347811 - 3.50000005117570706E-002 531385031.23928392 - 3.60000005268087467E-002 523986088.38359386 - 3.70000005418604228E-002 516307455.36294323 - 3.80000005569120988E-002 508340746.68114388 - 3.90000005719637749E-002 500076857.06765401 - 4.00000005870154510E-002 491505877.51411915 - 4.10000006020671270E-002 482616997.59909481 - 4.20000006171188031E-002 473398391.23751330 - 4.30000006321704792E-002 463837082.26100677 - 4.40000006472221553E-002 453918785.24165601 - 4.50000006622738313E-002 443627715.70000380 - 4.60000006773255074E-002 432946362.08711797 - 4.70000006923771835E-002 421855209.57271582 - 4.80000007074288595E-002 410332402.41148412 - 4.90000007224805356E-002 398353327.09658945 - 5.00000007375322117E-002 385890092.01365507 - 5.10000007525838878E-002 372910869.89102477 - 5.20000007676355638E-002 359379055.40856612 - 5.30000007826872399E-002 345252169.23859328 - 5.40000007977389160E-002 330480407.04867899 - 5.50000008127905921E-002 315004679.66142160 - 5.60000008278422681E-002 298753904.09996289 - 5.70000008428939442E-002 281641156.80718756 - 5.80000008579456203E-002 263558033.79028088 - 5.90000008729972963E-002 244366057.62596649 - 6.00000008880489724E-002 223882951.33293855 - 6.10000009031006485E-002 201859366.65185842 - 6.20000009181523246E-002 177936241.02956882 - 6.30000009332040006E-002 151557910.30957550 - 6.40000009482556836E-002 121765291.35095723 - 6.50000009633073667E-002 86559267.089058787 - 6.55000009708332082E-002 65426461.293441042 - 6.57500009745961289E-002 53302138.933172308 - 6.60000009783590497E-002 39426676.852969810 - 6.61250009802405031E-002 31420419.466817942 - 6.61875009811812298E-002 26990556.317915626 - 6.62500009821219565E-002 22141701.774704639 - 6.63125009830626833E-002 16660747.853145797 - 6.63437509835330536E-002 13545243.019599622 - 6.63750009840034239E-002 10005961.472616604 - 6.63906259842386021E-002 7977189.7376845730 - 6.63984384843561981E-002 6859353.5722278254 - 6.64062509844737942E-002 5640194.0016339840 - 6.64140634845913902E-002 4269001.8157937871 - 6.64179697346501813E-002 3494062.1127031618 - 6.64218759847089724E-002 2619905.3127237577 - 6.64238291097383748E-002 2123622.6108079469 - 6.64257822347677773E-002 1559918.6189464168 - 6.64267587972824786E-002 1236456.8137497872 - 6.64272470785398222E-002 1057927.6240404730 - 6.64277353597971659E-002 862738.15614189487 - 6.64282236410545096E-002 642083.82668608800 - 6.64284677816831814E-002 516374.94981919462 - 6.64287119223118533E-002 372785.75911960861 - 6.64288339926261961E-002 289635.30197500519 - 6.64288950277833606E-002 243297.18415601959 - 6.64289560629405251E-002 192010.14249639038 - 6.64289865805191143E-002 163648.20723028996 - 6.64290170980977035E-002 132563.58387729200 - 6.64290476156762927E-002 97253.723591483620 - 6.64290628744655803E-002 76985.780308764486 - 6.64290705038602242E-002 65794.226798446252 - 6.64290781332548680E-002 53550.730279557472 - 6.64290857626495118E-002 39692.287404006805 - 6.64290895773468337E-002 31781.040806673544 - 6.64290933920441556E-002 22714.975861705043 + 1.00000000000000002E-003 649909135.03119123 + 2.00000001505167783E-003 649636489.29833126 + 3.00000003010335563E-003 649181909.86863339 + 4.00000004515503344E-003 648545142.11149800 + 5.00000006020671125E-003 647725827.94719517 + 6.00000007525838906E-003 646723505.15455902 + 7.00000009031006686E-003 645537605.90191960 + 8.00000010536174554E-003 644167454.93684888 + 9.00000012041342334E-003 642612267.44508624 + 1.00000001354651012E-002 640871146.53866076 + 1.10000001505167790E-002 638943080.30864108 + 1.20000001655684568E-002 636826938.57690644 + 1.30000001806201346E-002 634521469.03385830 + 1.40000001956718124E-002 632025293.06391215 + 1.50000002107234902E-002 629336900.94825923 + 1.60000002257751697E-002 626454646.57255840 + 1.70000002408268493E-002 623376741.51493466 + 1.80000002558785288E-002 620101248.48522842 + 1.90000002709302084E-002 616626074.03659952 + 2.00000002859818879E-002 612948960.51813209 + 2.10000003010335674E-002 609067477.12493813 + 2.20000003160852470E-002 604979010.01064956 + 2.30000003311369265E-002 600680751.32512844 + 2.40000003461886061E-002 596169687.06278419 + 2.50000003612402856E-002 591442583.57983398 + 2.60000003762919651E-002 586495972.61729527 + 2.70000003913436447E-002 581326134.64072454 + 2.80000004063953242E-002 575929080.27714694 + 2.90000004214470038E-002 570300529.59325635 + 3.00000004364986833E-002 564435888.91553104 + 3.10000004515503629E-002 558330224.84078777 + 3.20000004666020424E-002 551978235.02284503 + 3.30000004816537185E-002 545374215.24478471 + 3.40000004967053945E-002 538512022.19347811 + 3.50000005117570706E-002 531385031.23928392 + 3.60000005268087467E-002 523986088.38359386 + 3.70000005418604228E-002 516307455.36294323 + 3.80000005569120988E-002 508340746.68114388 + 3.90000005719637749E-002 500076857.06765401 + 4.00000005870154510E-002 491505877.51411915 + 4.10000006020671270E-002 482616997.59909481 + 4.20000006171188031E-002 473398391.23751330 + 4.30000006321704792E-002 463837082.26100677 + 4.40000006472221553E-002 453918785.24165601 + 4.50000006622738313E-002 443627715.70000380 + 4.60000006773255074E-002 432946362.08711797 + 4.70000006923771835E-002 421855209.57271582 + 4.80000007074288595E-002 410332402.41148412 + 4.90000007224805356E-002 398353327.09658945 + 5.00000007375322117E-002 385890092.01365507 + 5.10000007525838878E-002 372910869.89102477 + 5.20000007676355638E-002 359379055.40856612 + 5.30000007826872399E-002 345252169.23859328 + 5.40000007977389160E-002 330480407.04867899 + 5.50000008127905921E-002 315004679.66142160 + 5.60000008278422681E-002 298753904.09996289 + 5.70000008428939442E-002 281641156.80718756 + 5.80000008579456203E-002 263558033.79028088 + 5.90000008729972963E-002 244366057.62596649 + 6.00000008880489724E-002 223882951.33293855 + 6.10000009031006485E-002 201859366.65185842 + 6.20000009181523246E-002 177936241.02956882 + 6.30000009332040006E-002 151557910.30957550 + 6.40000009482556836E-002 121765291.35095723 + 6.50000009633073667E-002 86559267.089058787 + 6.55000009708332082E-002 65426461.293441042 + 6.57500009745961289E-002 53302138.933172308 + 6.60000009783590497E-002 39426676.852969810 + 6.61250009802405031E-002 31420419.466817942 + 6.61875009811812298E-002 26990556.317915626 + 6.62500009821219565E-002 22141701.774704639 + 6.63125009830626833E-002 16660747.853145797 + 6.63437509835330536E-002 13545243.019599622 + 6.63750009840034239E-002 10005961.472616604 + 6.63906259842386021E-002 7977189.7376845730 + 6.63984384843561981E-002 6859353.5722278254 + 6.64062509844737942E-002 5640194.0016339840 + 6.64140634845913902E-002 4269001.8157937871 + 6.64179697346501813E-002 3494062.1127031618 + 6.64218759847089724E-002 2619905.3127237577 + 6.64238291097383748E-002 2123622.6108079469 + 6.64257822347677773E-002 1559918.6189464168 + 6.64267587972824786E-002 1236456.8137497872 + 6.64272470785398222E-002 1057927.6240404730 + 6.64277353597971659E-002 862738.15614189487 + 6.64282236410545096E-002 642083.82668608800 + 6.64284677816831814E-002 516374.94981919462 + 6.64287119223118533E-002 372785.75911960861 + 6.64288339926261961E-002 289635.30197500519 + 6.64288950277833606E-002 243297.18415601959 + 6.64289560629405251E-002 192010.14249639038 + 6.64289865805191143E-002 163648.20723028996 + 6.64290170980977035E-002 132563.58387729200 + 6.64290476156762927E-002 97253.723591483620 + 6.64290628744655803E-002 76985.780308764486 + 6.64290705038602242E-002 65794.226798446252 + 6.64290781332548680E-002 53550.730279557472 + 6.64290857626495118E-002 39692.287404006805 + 6.64290895773468337E-002 31781.040806673544 + 6.64290933920441556E-002 22714.975861705043 diff --git a/Diagnostics/Sedov/main.cpp b/Diagnostics/Sedov/main.cpp index 4a32f24b6b..348ad545e0 100644 --- a/Diagnostics/Sedov/main.cpp +++ b/Diagnostics/Sedov/main.cpp @@ -304,7 +304,7 @@ int main(int argc, char* argv[]) e_bin[index] += (fab(i,j,k,rhoe_comp) / fab(i,j,k,dens_comp)) * vol; volcount[index] += vol; - + } } } diff --git a/Docs/preprocess_files.py b/Docs/preprocess_files.py index d28b983fb2..7e9bf06790 100644 --- a/Docs/preprocess_files.py +++ b/Docs/preprocess_files.py @@ -16,7 +16,7 @@ def strip_directives(filename, filepath, outpath): """ Read in file, remove all preprocessor directives and output. - This is also going to switch square brackets initializing arrays to + This is also going to switch square brackets initializing arrays to parentheses and remove the new-line characters """ @@ -43,7 +43,7 @@ def strip_directives(filename, filepath, outpath): continue # loop over files in subdirectories and run strip_directives on all - # C++ header files + # C++ header files for f in sorted(os.listdir(os.path.join(rootdir, subdir))): if (f[-2:] == ".H"): strip_directives(f, os.path.join(rootdir, subdir), outdir) diff --git a/Docs/source/ConvertCheckpoint.rst b/Docs/source/ConvertCheckpoint.rst index 9f0b9834fd..58a82b5a8e 100644 --- a/Docs/source/ConvertCheckpoint.rst +++ b/Docs/source/ConvertCheckpoint.rst @@ -39,7 +39,7 @@ Now let’s suppose that you want to grow the domain by a factor of 8 and cover that new larger domain with a level that is a factor of 2 coarser than the existing level 0 grids. -#. First, set ``DIM =`` in the GNUmakefile, and type ``make`` in the +#. First, set ``DIM =`` in the GNUmakefile, and type ``make`` in the ``Util/ConvertCheckpoint/`` directory. This will make an executable from the ``Embiggen.cpp`` code. diff --git a/Docs/source/EOS.rst b/Docs/source/EOS.rst index 6ddc5321f9..fb42cc888c 100644 --- a/Docs/source/EOS.rst +++ b/Docs/source/EOS.rst @@ -4,7 +4,7 @@ Equation of State Castro is written in a modular fashion so that the EOS can be supplied by the user. No equations of state -are distributed with Castro, instead they are part +are distributed with Castro, instead they are part of the separate `Microphysics repository `_. Most equations of state are written to take :math:`(\rho, T, X_k)` as diff --git a/Docs/source/FlowChart.rst b/Docs/source/FlowChart.rst index a47b22ad55..0af763298a 100644 --- a/Docs/source/FlowChart.rst +++ b/Docs/source/FlowChart.rst @@ -56,7 +56,7 @@ The time-integration method used is controlled by * ``time_integration_method = 2``: this is a full implementation of the spectral deferred corrections formalism, with both 2nd and 4th order integration implemented. At the moment, this does not support - multilevel domains. Note: because of differences in the interfaces with the + multilevel domains. Note: because of differences in the interfaces with the default Strang method, you must compile with ``USE_TRUE_SDC = TRUE`` for this method to work. @@ -214,7 +214,7 @@ of each step. Strang+CTU Evolution ==================== -``do_advance_ctu()`` in ``Castro_advance_ctu.cpp`` +``do_advance_ctu()`` in ``Castro_advance_ctu.cpp`` This described the flow using Strang splitting and the CTU hydrodynamics (or MHD) method, including gravity, rotation, and @@ -264,7 +264,7 @@ defined consistently, i.e., :math:`\rho^n` and :math:`\phi^n` satisfy the Poisso \Delta \phi^n = 4\pi G\rho^n -(see :ref:`ch:gravity` for more details about how the Poisson equation is solved.) +(see :ref:`ch:gravity` for more details about how the Poisson equation is solved.) Note that in :eq:`eq:source_correct`, we can actually do some sources implicitly by updating density first, and then momentum, @@ -372,7 +372,7 @@ In the code, the objective is to evolve the state from the old time, [``do_old_sources()`` ] The time level :math:`n` sources are computed, and added to the - StateData ``Source_Type``. + StateData ``Source_Type``. The sources that we deal with here are: @@ -527,14 +527,14 @@ In the code, the objective is to evolve the state from the old time, Now we correct the source terms applied to ``S_new`` so they are time-centered. Previously we added :math:`\Delta t\, \Sb(\Ub^\star)` to the state, when - we really want + we really want :math:`(\Delta t/2)[\Sb(\Ub^\star + \Sb(\Ub^{n+1,(b)})]` . We start by computing the source term vector :math:`\Sb(\Ub^{n+1,(b)})` using the updated state, :math:`\Ub^{n+1,(b)}`. We then compute the correction, :math:`(\Delta t/2)[\Sb(\Ub^{n+1,(b)}) - \Sb(\Ub^\star)]` to add to :math:`\Ub^{n+1,(b)}` to give us the properly time-centered source, - and the fully updated state, :math:`\Ub^{n+1,(c)}`. + and the fully updated state, :math:`\Ub^{n+1,(c)}`. This correction is stored in the ``new_sources`` MultiFab [1]_. @@ -608,7 +608,7 @@ We write our evolution equation as: .. math:: \frac{\partial \Ub}{\partial t} = {\bf A}(\Ub) + {\bf R}(\Ub) -where :math:`{\bf A}(\Ub) = -\nabla \cdot {\bf F}(\Ub) + {\bf S}(\Ub)`, with the +where :math:`{\bf A}(\Ub) = -\nabla \cdot {\bf F}(\Ub) + {\bf S}(\Ub)`, with the hydrodynamic source terms, :math:`{\bf S}` grouped together with the flux divergence. The SDC update looks at the solution a several time nodes (the number @@ -635,7 +635,7 @@ is important when we consider the 4th order method. In Castro, there are two parameters that together determine the number and location of the temporal nodes, the accuracy of the integral, and hence the overall accuracy in time: ``castro.sdc_order`` and -``castro.sdc_quadrature``. +``castro.sdc_quadrature``. ``castro.sdc_quadrature = 0`` uses Gauss-Lobatto integration, which includes both the starting and ending @@ -686,7 +686,7 @@ The overall evolution appears as: * ``A_new`` : the advective term at each time node at the current iteration. - + * ``R_old`` : the reactive source term at each time node at the old iteration. @@ -749,7 +749,7 @@ The update through all time nodes for a single iteration is done by * Call ``construct_mol_hydro_source`` to get the advective update at the current time node, stored in ``A_new[m]``. - + * Bootstrap the first iteration. For the first iteration, we don't have the old iteration's @@ -789,7 +789,7 @@ The update through all time nodes for a single iteration is done by #. Store the reaction information for the plotfiles. #. Call ``finalize_do_advance`` to clean up the memory. - + Simplified-SDC Evolution ======================== @@ -855,7 +855,7 @@ summarize those differences. \Sb^\mathrm{corr} = \frac{1}{2} \left ( \Sb^{n+1,(k-1)} - S^n \right ) where :math:`\Sb^n` does not have an iteration subscript, since we always have the - same old time state. + same old time state. Applying this corrector to the the source at time :math:`n`, will give us a source that is time-centered, @@ -890,7 +890,7 @@ summarize those differences. We first compute :math:`\mathcal{A}(\Ub)` using ``hydro_sources``, ``old_source``, and ``new_source`` via the ``sum_of_source()`` function. This produces an advective source of the form: - + .. math:: \left [ \mathcal{A}(\Ub) \right ]^{n+1/2} = - [\nabla \cdot {\bf F}]^{n+1/2} + \frac{1}{2} (S^n + S^{n+1}) diff --git a/Docs/source/Hydrodynamics.rst b/Docs/source/Hydrodynamics.rst index edaaf8accd..9c22cf8fa9 100644 --- a/Docs/source/Hydrodynamics.rst +++ b/Docs/source/Hydrodynamics.rst @@ -100,7 +100,7 @@ several main data structures that hold the state. source terms. ``NQSRC`` ≤ ``NQ``. .. note:: if ``RADIATION`` is defined, then only the gas/hydro terms are - present in ``NQSRC``. + present in ``NQSRC``. :numref:`table:primlist` gives the names of the primitive variable integer keys for accessing these arrays. Note, unless otherwise specified the quantities without a subscript @@ -364,13 +364,13 @@ The primitive variable equations for density, velocity, and pressure are: \begin{align} \frac{\partial\rho}{\partial t} &= -\ub\cdot\nabla\rho - \rho\nabla\cdot\ub + S_{{\rm ext},\rho} \\ % - \frac{\partial\ub}{\partial t} &= -\ub\cdot\nabla\ub - \frac{1}{\rho}\nabla p + \gb + + \frac{\partial\ub}{\partial t} &= -\ub\cdot\nabla\ub - \frac{1}{\rho}\nabla p + \gb + \frac{1}{\rho} (\Sb_{{\rm ext},\rho\ub} - \ub \; S_{{\rm ext},\rho}) \\ \frac{\partial p}{\partial t} &= -\ub\cdot\nabla p - \rho c^2\nabla\cdot\ub + \left(\frac{\partial p}{\partial \rho}\right)_{e,X}S_{{\rm ext},\rho}\nonumber\\ &+\ \frac{1}{\rho}\sum_k\left(\frac{\partial p}{\partial X_k}\right)_{\rho,e,X_j,j\neq k}\left(\rho\dot\omega_k + S_{{\rm ext},\rho X_k} - X_kS_{{\rm ext},\rho}\right)\nonumber\\ & +\ \frac{1}{\rho}\left(\frac{\partial p}{\partial e}\right)_{\rho,X}\left[-eS_{{\rm ext},\rho} - \sum_k\rho q_k\dot\omega_k + \nabla\cdot\kth\nabla T \right.\nonumber\\ - & \quad\qquad\qquad\qquad+\ S_{{\rm ext},\rho E} - \ub\cdot\left(\Sb_{{\rm ext},\rho\ub} - \frac{\ub}{2}S_{{\rm ext},\rho}\right)\Biggr] + & \quad\qquad\qquad\qquad+\ S_{{\rm ext},\rho E} - \ub\cdot\left(\Sb_{{\rm ext},\rho\ub} - \frac{\ub}{2}S_{{\rm ext},\rho}\right)\Biggr] \end{align} The advected quantities appear as: @@ -382,7 +382,7 @@ The advected quantities appear as: ( S_{{\rm ext},\rho A_k} - A_k S_{{\rm ext},\rho} ), \\ \frac{\partial X_k}{\partial t} &= -\ub\cdot\nabla X_k + \dot\omega_k + \frac{1}{\rho} ( S_{{\rm ext},\rho X_k} - X_k S_{{\rm ext},\rho} ), \\ - \frac{\partial Y_k}{\partial t} &= -\ub\cdot\nabla Y_k + \frac{1}{\rho} + \frac{\partial Y_k}{\partial t} &= -\ub\cdot\nabla Y_k + \frac{1}{\rho} ( S_{{\rm ext},\rho Y_k} - Y_k S_{{\rm ext},\rho} ). \end{align} @@ -399,7 +399,7 @@ We augment the above system with an internal energy equation: .. math:: \begin{align} - \frac{\partial(\rho e)}{\partial t} &= - \ub\cdot\nabla(\rho e) - (\rho e+p)\nabla\cdot\ub - \sum_k \rho q_k\dot\omega_k + \frac{\partial(\rho e)}{\partial t} &= - \ub\cdot\nabla(\rho e) - (\rho e+p)\nabla\cdot\ub - \sum_k \rho q_k\dot\omega_k + \nabla\cdot\kth\nabla T + S_{{\rm ext},\rho E} \nonumber\\ & -\ \ub\cdot\left(\Sb_{{\rm ext},\rho\ub}-\frac{1}{2}S_{{\rm ext},\rho}\ub\right), \end{align} @@ -794,7 +794,7 @@ equations in 1D, for simplicity): .. math:: \alpha_{i,\pm} = \frac{\alpha_{i,\pm}(D^2s)_{i,\text{lim}}}{\max\left[(D^2s)_{i},1\times 10^{-10}\right]} - - If we are not at an extremum and + - If we are not at an extremum and :math:`|\alpha_{i,\pm}| > 2|\alpha_{i,\mp}|`, then define .. math:: s = \text{sign}(\alpha_{i,\mp}) @@ -937,7 +937,7 @@ neighboring cell-centered values of :math:`c`. We have also computed :math:`\rho_{\rm small}, p_{\rm small}`, and :math:`c_{\rm small}` using cell-centered data. -Here are the steps. First, define +Here are the steps. First, define :math:`(\rho c)_{\rm small} = \rho_{\rm small}c_{\rm small}`. Then, define: .. math:: (\rho c)_{L/R} = \max\left[(\rho c)_{\rm small},\left|\Gamma_{L/R},p_{L/R},\rho_{L/R}\right|\right]. @@ -1003,8 +1003,8 @@ Then, define (\rho e)_{\rm gdnv} &=& f(\rho e)^* + (1-f)(\rho e)_0. \end{align} -Finally, if :math:`c_{\rm out} < 0`, set -:math:`\rho_{\rm gdnv}=\rho_0, u_{\rm gdnv}=u_0, p_{\rm gdnv}=p_0`, and +Finally, if :math:`c_{\rm out} < 0`, set +:math:`\rho_{\rm gdnv}=\rho_0, u_{\rm gdnv}=u_0, p_{\rm gdnv}=p_0`, and :math:`(\rho e)_{\rm gdnv}=(\rho e)_0`. If :math:`c_{\rm in}\ge 0`, set :math:`\rho_{\rm gdnv}=\rho^*, u_{\rm gdnv}=u^*, p_{\rm gdnv}=p^*`, and :math:`(\rho e)_{\rm gdnv}=(\rho e)^*`. @@ -1166,8 +1166,8 @@ where :math:`0 \leq \theta_{{\rm i}+1/2} \leq 1` is a scalar, and :math:`\mathbf where :math:`0 < \text{CFL} < 1` is the CFL safety factor (the method is guaranteed to preserve positivity as long as :math:`\text{CFL} < 1/2`), and :math:`\alpha` is a scalar that ensures multi-dimensional correctness -(:math:`\alpha = 1` in 1D, :math:`1/2` in 2D, :math:`1/3` in 3D). -:math:`\mathbf{F}_{{\rm i}}` is the flux of material evaluated at the zone center +(:math:`\alpha = 1` in 1D, :math:`1/2` in 2D, :math:`1/3` in 3D). +:math:`\mathbf{F}_{{\rm i}}` is the flux of material evaluated at the zone center :math:`{\rm i}` using the cell-centered quantities :math:`\mathbf{U}`. The scalar :math:`\theta_{{\rm i}+1/2}` is chosen at every interface by calculating the update that would be obtained from , setting diff --git a/Docs/source/Introduction.rst b/Docs/source/Introduction.rst index 0395a625ed..0755432b54 100644 --- a/Docs/source/Introduction.rst +++ b/Docs/source/Introduction.rst @@ -72,7 +72,7 @@ Castro works in CGS units unless otherwise specified. throughout the code documentation and papers. .. _table:units: - + .. table:: Common quantities and units. +-----------------------+-----------------------+-----------------------+ diff --git a/Docs/source/Particles.rst b/Docs/source/Particles.rst index 10cbca4cd2..05a762df47 100644 --- a/Docs/source/Particles.rst +++ b/Docs/source/Particles.rst @@ -49,12 +49,12 @@ example, an input file for a model fluid with 6 particles in 2-D Cartesian coordinates may look like:: 6 - 3.28125e+08 9.9198e+08 - 5.46875e+08 9.9198e+08 - 7.65625e+08 9.9198e+08 - 9.84375e+08 9.9198e+08 - 1.20312e+09 9.9198e+08 - 1.42188e+09 9.9198e+08 + 3.28125e+08 9.9198e+08 + 5.46875e+08 9.9198e+08 + 7.65625e+08 9.9198e+08 + 9.84375e+08 9.9198e+08 + 1.20312e+09 9.9198e+08 + 1.42188e+09 9.9198e+08 According to this input file, the 6 particles will be positioned at the same height (same :math:`y` coordinate in the second column), @@ -105,7 +105,7 @@ a particle and extract its history (i.e., the trajectory in :numref:`fig:particl A model atmosphere with the arrows showing the direction of the fluid motion. .. _fig:particletrajectory: -.. figure:: tracer_trajectory.png +.. figure:: tracer_trajectory.png The trajectories of 500 particles following the fluid motion on the atmosphere. The particles are initially positioned at five diff --git a/Docs/source/build_system.rst b/Docs/source/build_system.rst index 928f383871..832315fe51 100644 --- a/Docs/source/build_system.rst +++ b/Docs/source/build_system.rst @@ -27,7 +27,7 @@ Most of these are parameters from AMReX. * ``USE_ALL_CASTRO``: compile all of the core Castro directories. This is the default (``TRUE``), and should not be changed for general simulations. The purpose of this flag is for unit tests, which - do not need all of the Castro directories compiled. + do not need all of the Castro directories compiled. * ``USE_AMR_CORE``: compile all of the core AMReX directories, including ``Base/``, ``AmrCore/``, ``Amr/``, and ``Boundary/``. This defaults @@ -129,7 +129,7 @@ Microphysics Parameters composition if we are using the ``general_null`` network (e.g., ``gammalaw.net``). The build system will look for this file in the Microphysics repo. - * ``INTEGRATOR_DIR``: this is the ODE integrator to use to integrate the + * ``INTEGRATOR_DIR``: this is the ODE integrator to use to integrate the reaction system. This is expected to be a subdirectory in the Microphysics repo. @@ -166,14 +166,14 @@ Hydrodynamics and Source Term Parameters Simulation Flow Parameters ^^^^^^^^^^^^^^^^^^^^^^^^^^ - * ``USE_POST_SIM``: if this is defined, then Castro will call the user-defined + * ``USE_POST_SIM``: if this is defined, then Castro will call the user-defined routine ``problem_post_simulation()`` after the full evolution of the problem has ended. .. index:: USE_POST_SIM - * ``USE_MAESTRO_INIT``: this enables the code to allow Castro to restart from a - Maestro simulation. This will need to be updated in the future to allow for + * ``USE_MAESTRO_INIT``: this enables the code to allow Castro to restart from a + Maestro simulation. This will need to be updated in the future to allow for restarts from MAESTROeX. .. index:: USE_MAESTRO_INIT @@ -199,7 +199,7 @@ Build Process Procedure At build time, there are a number of source files that are autogenerated based on the configuration of the problem. Most of these files are output into - ``tmp_build_dir/castro_sources/Nd.COMP.OPTIONS.EXE/``, where ``N`` is the + ``tmp_build_dir/castro_sources/Nd.COMP.OPTIONS.EXE/``, where ``N`` is the dimensionality, ``COMP`` is the compiler name, and ``OPTIONS`` can be any number of options (``MPI``, ``DEBUG``, ...). @@ -253,7 +253,7 @@ This is the current build system process. * If the problem directory defines a ``_prob_params`` then it is parsed and used to C++ header and source files ``prob_parameters.H`` and ``prob_parameters.cpp``. These handle reading the ``problem.*`` parameters from the inputs file. - Even without a problem-specific ``_prob_params``, all of the + Even without a problem-specific ``_prob_params``, all of the variables in ``Castro/Source/problems/_default_prob_params`` will be included. * The script ``Castro/Util/scripts/write_probdata.py`` is used diff --git a/Docs/source/creating_a_problem.rst b/Docs/source/creating_a_problem.rst index 4ab653511c..84d471fa9e 100644 --- a/Docs/source/creating_a_problem.rst +++ b/Docs/source/creating_a_problem.rst @@ -74,7 +74,7 @@ The variables will all be initialized for the GPU as well. Problem Initialization ---------------------- -Here we describe the main problem initialization routines. +Here we describe the main problem initialization routines. .. index:: initialize_problem @@ -96,7 +96,7 @@ Here we describe the main problem initialization routines. gravity) and in computing some of the derived variables (like angular momentum). - If you need coordinate information, it can be obtained + If you need coordinate information, it can be obtained by constructing a ``Geometry`` object using ``DefaultGeometry()`` and accessing its ``ProbLo()`` and ``ProbHi()`` methods. diff --git a/Docs/source/development.rst b/Docs/source/development.rst index 9e28bbca19..b5cc8590a8 100644 --- a/Docs/source/development.rst +++ b/Docs/source/development.rst @@ -138,5 +138,5 @@ Continuous Integration We github actions to run integration tests on the code and to build and deploy the documentation. -Currently, we run the `clang static analyzer `_, which finds potential bugs in the code. It also runs a script to convert any tabs in the code into spaces. Both of these are run on pull requests to the Castro GitHub repo, and are run weekly on the development branch. +Currently, we run the `clang static analyzer `_, which finds potential bugs in the code. It also runs a script to convert any tabs in the code into spaces. Both of these are run on pull requests to the Castro GitHub repo, and are run weekly on the development branch. diff --git a/Docs/source/diffusion.rst b/Docs/source/diffusion.rst index d38f58eebf..bf5bf1165b 100644 --- a/Docs/source/diffusion.rst +++ b/Docs/source/diffusion.rst @@ -39,7 +39,7 @@ specific heat at constant volume. Finally, ignore hydrodynamics, so .. math:: \frac{\partial T}{\partial t} = D \nabla^2 T -where :math:`D \equiv \kth/(\rho c_v)`. +where :math:`D \equiv \kth/(\rho c_v)`. The timestep limiter for this is: @@ -84,7 +84,7 @@ code by linearly scaling the conductivity to zero between these limits, e.g., Conductivities ============== -To complete the setup, a thermal conductivity must be specified. These +To complete the setup, a thermal conductivity must be specified. These are supplied by Microphysics, and use an interface similar to the equation of state interface. diff --git a/Docs/source/faq.rst b/Docs/source/faq.rst index c723b745db..2d806224a2 100644 --- a/Docs/source/faq.rst +++ b/Docs/source/faq.rst @@ -77,7 +77,7 @@ Debugging - ``amrex.fpe_trap_overflow`` - For further capabilities, you can get + For further capabilities, you can get more information than the backtrace of the call stack info by instrumenting the code. Here is an example. You know the line ``Real rho = state(cell,0);`` is @@ -191,7 +191,7 @@ Managing Runs #. *How can I check the compilation parameters of a Castro executable?* - The build information (including git hashes, modules, EoS, network, etc.) can be displayed by running the executable as + The build information (including git hashes, modules, EoS, network, etc.) can be displayed by running the executable as :: @@ -226,7 +226,7 @@ Runtime Errors specie abundance validity check by setting ``castro.abundance_failure_tolerance`` to a higher value, or increasing the density floor below which this is ignored by changing ``castro.abundance_failure_rho_cutoff``. - + Visualization ============= diff --git a/Docs/source/hse.rst b/Docs/source/hse.rst index c6cf7e9df3..a58acee2ce 100644 --- a/Docs/source/hse.rst +++ b/Docs/source/hse.rst @@ -46,7 +46,7 @@ The 4th order MC limiter uses information in zones :math:`\{i-2,i-1,i,i+1,i+2\}`. We pick zone ``i`` as the reference and integrate from ``i`` to the 4 other zone centers, and construct :math:`\{\tilde{p}_{i-2}, \tilde{p}_{i-1}, \tilde{p}_{i}, \tilde{p}_{i+1}, \tilde{p}_{i+2}\}`. We then limit on this, giving us the change in the excess -pressure over the zone, :math:`\Delta \tilde{p}_i`. Finally, we +pressure over the zone, :math:`\Delta \tilde{p}_i`. Finally, we construct the total slope (including the hydrostatic part) as: .. math:: diff --git a/Docs/source/inputs.rst b/Docs/source/inputs.rst index f857462769..75bd182d9f 100644 --- a/Docs/source/inputs.rst +++ b/Docs/source/inputs.rst @@ -3,14 +3,14 @@ Input Files *********** The Castro executable uses an inputs file at runtime to set and -alter the behavior of the algorithm and initial conditions. +alter the behavior of the algorithm and initial conditions. Runtime parameters take the form ``namespace.parameter = value`` , where *namespace* identifies the major code component. Some parameters take multiple values separated by spaces. Typically -named ``inputs``, it +named ``inputs``, it * Sets the AMReX parameters for gridding, refinement, etc., through the ``geometry`` and ``amr`` namespaces. diff --git a/Docs/source/mhd.rst b/Docs/source/mhd.rst index 833a7f5850..5ef47d31e0 100644 --- a/Docs/source/mhd.rst +++ b/Docs/source/mhd.rst @@ -88,10 +88,10 @@ components. This is done separately from the main conserved fluid state. The conserved fluid state is initialized in ``problem_initialize_state_data()`` just as -with pure hydrodynamics problems. Note that you do not need to include +with pure hydrodynamics problems. Note that you do not need to include the magnetic energy contribution to the total energy density, ``UEDEN``. After this initialization, the driver handles the addition of the magnetic -contribution. +contribution. Hydrodynamics Update diff --git a/Docs/source/problem_setups.rst b/Docs/source/problem_setups.rst index 7e0d05fcc9..fcfe62b083 100644 --- a/Docs/source/problem_setups.rst +++ b/Docs/source/problem_setups.rst @@ -44,7 +44,7 @@ problems are: gravitational potential of a perfect cube, for which there is an analytic solution. It tests our isolated boundary conditions. This was demonstrated in :cite:`katz:2016`. - + * ``hydro_tests``: @@ -114,7 +114,7 @@ problems are: * ``Rad2Tshock``: This sets up a radiating shock that can be compared to a semi-analytic solution described in :cite:`lowrieedwards`. - + * ``RadFront``: This is the optically-thin streaming of a radiation front problem demonstrated originally in Castro in :cite:`CastroII`. @@ -127,7 +127,7 @@ problems are: * ``RadSphere``: This is a multigroup radiating sphere test problem with an analytic solution, described in :cite:`graziani:2008` and :cite:`swestymyra:2009` and shown in Castro in :cite:`CastroIII`. - + * ``RadSuOlson``: This is a non-equlibrium Marshak wave test described in :cite:`suolson:1996` and shown in Castro in :cite:`CastroII`. @@ -136,7 +136,7 @@ problems are: * ``RadThermalWave``: A thermal wave test adapted from :cite:`howellgreenough:2003` and shown in Castro in :cite:`CastroII`. - + * ``reacting_tests``: * ``bubble_convergence``: a reacting bubble problem designed for measuring the convergence of diff --git a/Docs/source/radiation.rst b/Docs/source/radiation.rst index dda11f1d5f..6587219d74 100644 --- a/Docs/source/radiation.rst +++ b/Docs/source/radiation.rst @@ -204,7 +204,7 @@ The parameters describing the opacity include: singular, we must set some floors in practice to prevent numerical issues. We have one floor for the opacity, which is applied to both the Planck and Rosseland opacities, and we - also have a temperature floor. + also have a temperature floor. - ``opacity.kappa_floor = 1.d-50`` diff --git a/Docs/source/reactions.rst b/Docs/source/reactions.rst index cbef46f81d..ed23b9d746 100644 --- a/Docs/source/reactions.rst +++ b/Docs/source/reactions.rst @@ -188,7 +188,7 @@ In ``Castro_react.cpp``, the flow is: * $U^\mathrm{new}(\rho X_k) = U^\mathrm{new}(\rho) \cdot \mathtt{burn\_state.xn[k]}$ * if ``NAUX_NET > 0``: $U^\mathrm{new}(\rho \alpha_k) = U^\mathrm{new}(\rho) \cdot \mathtt{burn\_state.aux[k]}$ - + * if ``NSE_NET`` : * $U(\mu_p) = \mathtt{burn\_state.mu\_p}$ @@ -255,7 +255,7 @@ In ``Castro_react.cpp``, the flow is: * Store the advective update that will be used during the SDC integration. -* Compute +* Compute * Initialize the metadata that is used for diagnostics @@ -313,7 +313,7 @@ In ``Castro_react.cpp``, the flow is: * $U^\mathrm{new}(\rho X_k) = U^\mathrm{new}(\rho) \cdot \mathtt{burn\_state.xn[k]}$ * if ``NAUX_NET > 0``: $U^\mathrm{new}(\rho \alpha_k) = U^\mathrm{new}(\rho) \cdot \mathtt{burn\_state.aux[k]}$ - + * if ``NSE_NET`` : * $U(\mu_p) = \mathtt{burn\_state.mu\_p}$ diff --git a/Docs/source/software.rst b/Docs/source/software.rst index 50043718a5..16abfba1d6 100644 --- a/Docs/source/software.rst +++ b/Docs/source/software.rst @@ -7,7 +7,7 @@ Code structure Castro is built upon the AMReX C++ framework. This provides high-level classes for managing an adaptive mesh refinement -simulation, including the core data structures we will deal with. +simulation, including the core data structures we will deal with. AMReX provides convenient data structures that allow for this workflow—high level objects in C++ that communicate with our computational kernels, with @@ -191,7 +191,7 @@ FArrayBoxes). A ``MultiFab`` contains an array of ``Box`` es, including boxes owned by other processors for the purpose of communication, an array of MPI ranks specifying which MPI processor owns each ``Box``, and an array of pointers to ``FArrayBoxes`` owned by this MPI -processor. +processor. .. note:: a ``MultiFab`` is a collection of the boxes that together make up a single level of data in the AMR hierarchy. @@ -550,7 +550,7 @@ Physical boundary conditions are specified by an integer index [2]_ in the ``inputs`` file, using the ``castro.lo_bc`` and ``castro.hi_bc`` runtime parameters. The generally supported boundary conditions are, their corresponding integer key, and the action they take for the normal -velocity, transverse velocity, and generic scalar are shown in +velocity, transverse velocity, and generic scalar are shown in :numref:`table:castro:bcs`. The definition of the specific actions are: diff --git a/Docs/source/sponge.rst b/Docs/source/sponge.rst index cb524e3d5f..6bc7702af9 100644 --- a/Docs/source/sponge.rst +++ b/Docs/source/sponge.rst @@ -61,7 +61,7 @@ There are three sponges, each controlled by different runtime parameters: f_\mathrm{lower} & r < r_\mathrm{lower} \\ f_\mathrm{lower} + \frac{f_\mathrm{upper} - f_\mathrm{lower}}{2} \left [ 1 - \cos \left ( \frac{\pi (r - r_\mathrm{lower})}{\Delta r} \right ) \right ] & r_\mathrm{lower} \le r < r_\mathrm{upper} \\ - f_\mathrm{upper} & r \ge r_\mathrm{upper} + f_\mathrm{upper} & r \ge r_\mathrm{upper} \end{array} \right . @@ -89,7 +89,7 @@ There are three sponges, each controlled by different runtime parameters: f_\mathrm{lower} & \rho > \rho_\mathrm{upper} \\ f_\mathrm{lower} + \frac{f_\mathrm{upper} - f_\mathrm{lower}}{2} \left [ 1 - \cos \left ( \frac{\pi (\rho - \rho_\mathrm{upper})}{\Delta \rho} \right ) \right ] & \rho_\mathrm{upper} \ge \rho > \rho_\mathrm{lower} \\ - f_\mathrm{upper} & \rho < \rho_\mathrm{lower} + f_\mathrm{upper} & \rho < \rho_\mathrm{lower} \end{array} \right . @@ -115,7 +115,7 @@ There are three sponges, each controlled by different runtime parameters: f_\mathrm{lower} & p > p_\mathrm{upper} \\ f_\mathrm{lower} + \frac{f_\mathrm{upper} - f_\mathrm{lower}}{2} \left [ 1 - \cos \left ( \frac{\pi (p - p_\mathrm{upper})}{\Delta p} \right ) \right ] & p_\mathrm{upper} \ge p \ge p_\mathrm{lower} \\ - f_\mathrm{upper} & \rho < \rho_\mathrm{lower} + f_\mathrm{upper} & \rho < \rho_\mathrm{lower} \end{array} \right . diff --git a/Docs/source/timestepping.rst b/Docs/source/timestepping.rst index 33bbf5b768..6317a3c12a 100644 --- a/Docs/source/timestepping.rst +++ b/Docs/source/timestepping.rst @@ -163,7 +163,7 @@ Subcycling ---------- Subcycling with AMR means that coarser grids can take a larger timestep -than finer grids. +than finer grids. Castro supports a number of different modes for subcycling in time, set via ``amr.subcycling_mode``. diff --git a/Docs/source/visualization.rst b/Docs/source/visualization.rst index 2a09c02651..d1337eb59d 100644 --- a/Docs/source/visualization.rst +++ b/Docs/source/visualization.rst @@ -61,6 +61,6 @@ http://yt-project.org/doc/index.html. Example notebook ^^^^^^^^^^^^^^^^ -Using the plotfiles generated in the example in the :doc:`getting_started` section, here we demonstrate how to use ``yt`` to load and visualize data. This section was generated from a Jupyter notebook which can be found in ``Docs/source/yt_example.ipynb`` in the Castro repo. +Using the plotfiles generated in the example in the :doc:`getting_started` section, here we demonstrate how to use ``yt`` to load and visualize data. This section was generated from a Jupyter notebook which can be found in ``Docs/source/yt_example.ipynb`` in the Castro repo. .. include:: yt_example.rst diff --git a/Exec/gravity_tests/DustCollapse/problem_initialize_state_data.H b/Exec/gravity_tests/DustCollapse/problem_initialize_state_data.H index e25b05f341..c8de823d86 100644 --- a/Exec/gravity_tests/DustCollapse/problem_initialize_state_data.H +++ b/Exec/gravity_tests/DustCollapse/problem_initialize_state_data.H @@ -37,7 +37,7 @@ void problem_initialize_state_data (int i, int j, int k, Array4 const& sta #else Real yl = 0.0_rt; #endif - + #if AMREX_SPACEDIM == 3 Real zl = problo[2] + static_cast(k) * dx[2]; #else diff --git a/Exec/gravity_tests/StarGrav/problem_initialize_mhd_data.H b/Exec/gravity_tests/StarGrav/problem_initialize_mhd_data.H index 698925e079..108075b249 100644 --- a/Exec/gravity_tests/StarGrav/problem_initialize_mhd_data.H +++ b/Exec/gravity_tests/StarGrav/problem_initialize_mhd_data.H @@ -5,7 +5,7 @@ /// x component of dipole vector potential /// AMREX_GPU_HOST_DEVICE AMREX_INLINE -Real compute_A_x(const Real x, const Real y, const Real z) +Real compute_A_x(const Real x, const Real y, const Real z) { // this should be called with a node-centered y and z and a cell-centered x @@ -32,7 +32,7 @@ Real compute_A_x(const Real x, const Real y, const Real z) /// y component of dipole vector potential /// AMREX_GPU_HOST_DEVICE AMREX_INLINE -Real compute_A_y(const Real x, const Real y, const Real z) +Real compute_A_y(const Real x, const Real y, const Real z) { // this should be called with a node-centered x and z and a cell-centered y diff --git a/Exec/gravity_tests/hse_convergence/convergence_plm.sh b/Exec/gravity_tests/hse_convergence/convergence_plm.sh index 678314a4bc..285cfed67d 100755 --- a/Exec/gravity_tests/hse_convergence/convergence_plm.sh +++ b/Exec/gravity_tests/hse_convergence/convergence_plm.sh @@ -14,19 +14,19 @@ castro.use_pslope=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -42,19 +42,19 @@ castro.hse_reflect_vels=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -70,19 +70,19 @@ castro.hse_reflect_vels=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -98,19 +98,19 @@ castro.hi_bc=3 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -127,19 +127,19 @@ castro.use_pslope=0 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} diff --git a/Exec/gravity_tests/hse_convergence/convergence_ppm.sh b/Exec/gravity_tests/hse_convergence/convergence_ppm.sh index 7e2ddac9f0..ff6e2c7620 100755 --- a/Exec/gravity_tests/hse_convergence/convergence_ppm.sh +++ b/Exec/gravity_tests/hse_convergence/convergence_ppm.sh @@ -8,19 +8,19 @@ EXEC=./Castro1d.gnu.MPI.ex ofile=ppm.converge.out ${EXEC} inputs.ppm.64 >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -34,19 +34,19 @@ castro.hse_reflect_vels=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -59,19 +59,19 @@ castro.grav_source_type=4 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -85,18 +85,18 @@ castro.hi_bc=3 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} diff --git a/Exec/gravity_tests/hse_convergence/convergence_sdc.sh b/Exec/gravity_tests/hse_convergence/convergence_sdc.sh index c6483a2781..038109dea1 100755 --- a/Exec/gravity_tests/hse_convergence/convergence_sdc.sh +++ b/Exec/gravity_tests/hse_convergence/convergence_sdc.sh @@ -20,19 +20,19 @@ castro.hi_bc=3 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -51,19 +51,19 @@ castro.hi_bc=3 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -80,19 +80,19 @@ castro.use_reconstructed_gamma1=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -110,19 +110,19 @@ castro.use_reconstructed_gamma1=1 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} @@ -141,18 +141,18 @@ castro.hi_bc=3 """ ${EXEC} inputs.ppm.64 ${RUNPARAMS} >& 64.out -pfile=`ls -t | grep -i hse_64_plt | head -1` +pfile=`ls -t | grep -i hse_64_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel > ${ofile} ${EXEC} inputs.ppm.128 ${RUNPARAMS} >& 128.out -pfile=`ls -t | grep -i hse_128_plt | head -1` +pfile=`ls -t | grep -i hse_128_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.256 ${RUNPARAMS} >& 256.out -pfile=`ls -t | grep -i hse_256_plt | head -1` +pfile=`ls -t | grep -i hse_256_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} ${EXEC} inputs.ppm.512 ${RUNPARAMS} >& 512.out -pfile=`ls -t | grep -i hse_512_plt | head -1` +pfile=`ls -t | grep -i hse_512_plt | head -1` fextrema.gnu.ex -v magvel ${pfile} | grep -i magvel >> ${ofile} diff --git a/Exec/gravity_tests/hydrostatic_adjust/problem_source.H b/Exec/gravity_tests/hydrostatic_adjust/problem_source.H index d9d9d370d6..099bdb5b66 100644 --- a/Exec/gravity_tests/hydrostatic_adjust/problem_source.H +++ b/Exec/gravity_tests/hydrostatic_adjust/problem_source.H @@ -76,7 +76,7 @@ void problem_source (int i, int j, int k, auto dist = std::sqrt(x*x + y*y + z*z); - auto Hext = H_0 * std::exp(-((dist - r_0)*(dist - r_0))/(W_0*W_0)) * + auto Hext = H_0 * std::exp(-((dist - r_0)*(dist - r_0))/(W_0*W_0)) * state(i,j,k,UFS+problem::ifuel) / state(i,j,k,URHO); src(i,j,k,UEINT) = state(i,j,k,URHO) * Hext; diff --git a/Exec/hydro_tests/Sedov/problem_initialize.H b/Exec/hydro_tests/Sedov/problem_initialize.H index d6d3834003..b056e41349 100644 --- a/Exec/hydro_tests/Sedov/problem_initialize.H +++ b/Exec/hydro_tests/Sedov/problem_initialize.H @@ -53,7 +53,7 @@ void problem_initialize () for (int n = 0; n < NumSpec; ++n) { eos_state.xn[n] = xn_zone[n]; } - + eos(eos_input_rp, eos_state); problem::e_ambient = eos_state.e; diff --git a/Exec/hydro_tests/Sedov/problem_initialize_state_data.H b/Exec/hydro_tests/Sedov/problem_initialize_state_data.H index 4dc8030c35..8fdb480d29 100644 --- a/Exec/hydro_tests/Sedov/problem_initialize_state_data.H +++ b/Exec/hydro_tests/Sedov/problem_initialize_state_data.H @@ -11,7 +11,7 @@ void problem_initialize_state_data (int i, int j, int k, Array4 const& sta const Real* dx = geomdata.CellSize(); const Real* problo = geomdata.ProbLo(); - + #if AMREX_SPACEDIM == 1 int nsubx = problem::nsub; int nsuby = 1; diff --git a/Exec/hydro_tests/Sedov/testsuite_analysis/sedov_2d_sph_in_cyl.py b/Exec/hydro_tests/Sedov/testsuite_analysis/sedov_2d_sph_in_cyl.py index aa460c8fe5..51b3a7ee88 100755 --- a/Exec/hydro_tests/Sedov/testsuite_analysis/sedov_2d_sph_in_cyl.py +++ b/Exec/hydro_tests/Sedov/testsuite_analysis/sedov_2d_sph_in_cyl.py @@ -23,7 +23,7 @@ def process(castro_dir, plotfile): # find the executable analysis_routine = None for file in os.listdir(build_dir): - if (os.path.isfile(file) and + if (os.path.isfile(file) and file.startswith("sedov_2d") and file.endswith(".ex")): analysis_routine = file diff --git a/Exec/hydro_tests/acoustic_pulse/analysis/slice_multi.py b/Exec/hydro_tests/acoustic_pulse/analysis/slice_multi.py index 05f183c22c..2dfdb4a36f 100755 --- a/Exec/hydro_tests/acoustic_pulse/analysis/slice_multi.py +++ b/Exec/hydro_tests/acoustic_pulse/analysis/slice_multi.py @@ -26,7 +26,7 @@ fig = plt.figure() fig.set_size_inches(12.0, 9.0) -grid = ImageGrid(fig, 111, nrows_ncols=(1, 2), axes_pad=0.75, cbar_pad="2%", +grid = ImageGrid(fig, 111, nrows_ncols=(1, 2), axes_pad=0.75, cbar_pad="2%", label_mode="L", cbar_mode="each") diff --git a/Exec/hydro_tests/acoustic_pulse/convergence_ppm_as_1d.sh b/Exec/hydro_tests/acoustic_pulse/convergence_ppm_as_1d.sh index 48c40a789a..3e3c5362e4 100755 --- a/Exec/hydro_tests/acoustic_pulse/convergence_ppm_as_1d.sh +++ b/Exec/hydro_tests/acoustic_pulse/convergence_ppm_as_1d.sh @@ -55,4 +55,4 @@ RichardsonConvergenceTest${DIM}d.gnu.ex coarFile=acoustic_pulse_64_ppm_plt00081 #RichardsonConvergenceTest${DIM}d.gnu.ex coarFile=acoustic_pulse_128_ppm_plt00161 mediFile=acoustic_pulse_256_ppm_plt00321 fineFile=acoustic_pulse_512_ppm_plt00641 > convergence.${DIM}d.hi.ppm.out - + diff --git a/Exec/hydro_tests/acoustic_pulse/problem_initialize_state_data.H b/Exec/hydro_tests/acoustic_pulse/problem_initialize_state_data.H index 46c2d10fe8..6ea18ace62 100644 --- a/Exec/hydro_tests/acoustic_pulse/problem_initialize_state_data.H +++ b/Exec/hydro_tests/acoustic_pulse/problem_initialize_state_data.H @@ -42,7 +42,7 @@ void problem_initialize_state_data (int i, int j, int k, dist = std::abs(problem::center[2] - zz); } else { -#ifndef AMREX_USE_GPU +#ifndef AMREX_USE_GPU amrex::Error("invalid init_as_1d"); #endif } diff --git a/Exec/hydro_tests/acoustic_pulse_general/analysis/slice_multi.py b/Exec/hydro_tests/acoustic_pulse_general/analysis/slice_multi.py index 5ccc94b638..b9009d3517 100755 --- a/Exec/hydro_tests/acoustic_pulse_general/analysis/slice_multi.py +++ b/Exec/hydro_tests/acoustic_pulse_general/analysis/slice_multi.py @@ -26,7 +26,7 @@ fig = plt.figure() fig.set_size_inches(12.0, 9.0) -grid = ImageGrid(fig, 111, nrows_ncols=(2, 2), axes_pad=0.75, cbar_pad="2%", +grid = ImageGrid(fig, 111, nrows_ncols=(2, 2), axes_pad=0.75, cbar_pad="2%", label_mode="L", cbar_mode="each") diff --git a/Exec/hydro_tests/double_mach_reflection/problem_initialize.H b/Exec/hydro_tests/double_mach_reflection/problem_initialize.H index 88cff7e8a3..d5423e2592 100644 --- a/Exec/hydro_tests/double_mach_reflection/problem_initialize.H +++ b/Exec/hydro_tests/double_mach_reflection/problem_initialize.H @@ -21,7 +21,7 @@ void problem_initialize () // compute the internal energy (erg/cc) for the left and right state - Real xn[NumSpec] = {0.0_rt}; + Real xn[NumSpec] = {0.0_rt}; xn[0] = 1.0_rt; eos_t eos_state; diff --git a/Exec/hydro_tests/gamma_law_bubble/Problem_Derive.cpp b/Exec/hydro_tests/gamma_law_bubble/Problem_Derive.cpp index 78e2d81a96..de815abb96 100644 --- a/Exec/hydro_tests/gamma_law_bubble/Problem_Derive.cpp +++ b/Exec/hydro_tests/gamma_law_bubble/Problem_Derive.cpp @@ -176,7 +176,7 @@ void ca_derrhopert(const Box& bx, FArrayBox& derfab, int dcomp, int /*ncomp*/, if (problem::do_isentropic) { Real z = static_cast(j) * dx[AMREX_SPACEDIM-1]; - density[j] = problem::dens_base * + density[j] = problem::dens_base * std::pow((gravity::const_grav * problem::dens_base * (eos_gamma - 1.0_rt) * z/ (eos_gamma * problem::pres_base) + 1.0_rt), 1.0_rt/(eos_gamma - 1.0_rt)); } else { diff --git a/Exec/hydro_tests/gresho_vortex/problem_initialize.H b/Exec/hydro_tests/gresho_vortex/problem_initialize.H index 6eecf20e75..2dc9f62aae 100644 --- a/Exec/hydro_tests/gresho_vortex/problem_initialize.H +++ b/Exec/hydro_tests/gresho_vortex/problem_initialize.H @@ -1,4 +1,4 @@ -// This sets up the Gresho vortex problem as described in +// This sets up the Gresho vortex problem as described in // Miczek, Roeple, and Edelmann 2015 // // By choosing the reference pressure, p0, we can specify the diff --git a/Exec/hydro_tests/gresho_vortex/problem_initialize_state_data.H b/Exec/hydro_tests/gresho_vortex/problem_initialize_state_data.H index c8246bfb6a..adc5a4c050 100644 --- a/Exec/hydro_tests/gresho_vortex/problem_initialize_state_data.H +++ b/Exec/hydro_tests/gresho_vortex/problem_initialize_state_data.H @@ -1,4 +1,4 @@ -// This sets up the Gresho vortex problem as described in +// This sets up the Gresho vortex problem as described in // Miczek, Roeple, and Edelmann 2015 // // By choosing the reference pressure, p0, we can specify the diff --git a/Exec/hydro_tests/riemann_2d/problem_initialize_state_data.H b/Exec/hydro_tests/riemann_2d/problem_initialize_state_data.H index 9049bd9bdc..95cc0b33f4 100644 --- a/Exec/hydro_tests/riemann_2d/problem_initialize_state_data.H +++ b/Exec/hydro_tests/riemann_2d/problem_initialize_state_data.H @@ -8,16 +8,16 @@ #include AMREX_GPU_HOST_DEVICE AMREX_INLINE -//Declare boxes index i, j, k, the state Array4, and -//the geometry information, which emcompases the -void problem_initialize_state_data(int i, int j, int k, +//Declare boxes index i, j, k, the state Array4, and +//the geometry information, which emcompases the +void problem_initialize_state_data(int i, int j, int k, Array4 const& state, const GeometryData& geomdata) { //The integer "coord_type" represents the coordinate system - int coord_type = geomdata.Coord(); - - //The pointer *dx represents the real cell size value + int coord_type = geomdata.Coord(); + + //The pointer *dx represents the real cell size value const Real* dx = geomdata.CellSize(); //The pointer *problo represents the bottom of each dimension @@ -25,7 +25,7 @@ void problem_initialize_state_data(int i, int j, int k, #if AMREX_SPACEDIM != 2 amrex::Abort("The Riemman Problem considered is 2D."); - + #endif diff --git a/Exec/hydro_tests/test_convect/problem_diagnostics.H b/Exec/hydro_tests/test_convect/problem_diagnostics.H index 1285d2dd8c..d27c19d9ce 100644 --- a/Exec/hydro_tests/test_convect/problem_diagnostics.H +++ b/Exec/hydro_tests/test_convect/problem_diagnostics.H @@ -19,7 +19,7 @@ Castro::problem_diagnostics () Castro& ca_lev = getLevel(lev); mass += ca_lev.volWgtSum("density", time); - + rho_E += ca_lev.volWgtSum("rho_E", time); auto temp_mf = ca_lev.derive("Temp", time, 0); @@ -38,7 +38,7 @@ Castro::problem_diagnostics () } - + if (verbose > 0 && ParallelDescriptor::IOProcessor()) { std::cout << '\n'; diff --git a/Exec/hydro_tests/test_convect/problem_source.H b/Exec/hydro_tests/test_convect/problem_source.H index 274276e72a..1711e078c8 100644 --- a/Exec/hydro_tests/test_convect/problem_source.H +++ b/Exec/hydro_tests/test_convect/problem_source.H @@ -24,9 +24,9 @@ void problem_source (int i, int j, int k, auto y = (Real(j)+0.5e0_rt)*dx[1] + problo[1]; auto ey = std::exp(-(y-y_layer)*(y-y_layer)/1.e14_rt); - auto H = ey * (1.e0_rt + - 0.00625_rt * std::sin( 2*M_PI*x/L_x) - + 0.01875_rt * std::sin((6*M_PI*x/L_x) + M_PI/3.e0_rt) + auto H = ey * (1.e0_rt + + 0.00625_rt * std::sin( 2*M_PI*x/L_x) + + 0.01875_rt * std::sin((6*M_PI*x/L_x) + M_PI/3.e0_rt) + 0.01250_rt * std::sin((8*M_PI*x/L_x) + M_PI/5.e0_rt)); // Source terms diff --git a/Exec/hydro_tests/toy_convect/problem_diagnostics.H b/Exec/hydro_tests/toy_convect/problem_diagnostics.H index 1285d2dd8c..d27c19d9ce 100644 --- a/Exec/hydro_tests/toy_convect/problem_diagnostics.H +++ b/Exec/hydro_tests/toy_convect/problem_diagnostics.H @@ -19,7 +19,7 @@ Castro::problem_diagnostics () Castro& ca_lev = getLevel(lev); mass += ca_lev.volWgtSum("density", time); - + rho_E += ca_lev.volWgtSum("rho_E", time); auto temp_mf = ca_lev.derive("Temp", time, 0); @@ -38,7 +38,7 @@ Castro::problem_diagnostics () } - + if (verbose > 0 && ParallelDescriptor::IOProcessor()) { std::cout << '\n'; diff --git a/Exec/mhd_tests/MagnetosonicWaves/problem_initialize_state_data.H b/Exec/mhd_tests/MagnetosonicWaves/problem_initialize_state_data.H index d7570460a1..9cbd133fe4 100644 --- a/Exec/mhd_tests/MagnetosonicWaves/problem_initialize_state_data.H +++ b/Exec/mhd_tests/MagnetosonicWaves/problem_initialize_state_data.H @@ -46,7 +46,7 @@ void problem_initialize_state_data (int i, int j, int k, Real pressure = problem::p_0 + problem::rho_0 * problem::c_s * pert; - // compute the internal energy (erg/cc) + // compute the internal energy (erg/cc) eos_t eos_state; eos_state.rho = problem::rho_0; diff --git a/Exec/radiation_tests/Rad2Tshock/python/Analytical-Test.py b/Exec/radiation_tests/Rad2Tshock/python/Analytical-Test.py index fe1133fc84..205a831479 100644 --- a/Exec/radiation_tests/Rad2Tshock/python/Analytical-Test.py +++ b/Exec/radiation_tests/Rad2Tshock/python/Analytical-Test.py @@ -18,15 +18,15 @@ plt.switch_backend('agg') parser = argparse.ArgumentParser() -parser.add_argument('plotfile', type=str, help='Path to plotfile for which we will compare') +parser.add_argument('plotfile', type=str, help='Path to plotfile for which we will compare') args = parser.parse_args() def get_x_var(pf, var): ds = yt.load(pf) time = float(ds.current_time) ad = ds.all_data() - srt = np.argsort(ad['x']) - x_coord = np.array(ad['x'][srt]) + srt = np.argsort(ad['x']) + x_coord = np.array(ad['x'][srt]) var = np.array(ad[var][srt]) return time, x_coord, var @@ -39,7 +39,7 @@ def f2_f(T1): def rho1_f(T1): f1 = f1_f(T1) return (f1+np.sqrt(f1**2+f2_f(T1))) / (6.*(gamma-1.)*T1) - def Eq13(T1): + def Eq13(T1): rho1 = rho1_f(T1) return 3.0*rho1*(rho1*T1-1.) + gamma*P0*rho1*(T1**4-1.) - 3.*gamma*(rho1-1.)*M0**2 def T1_smallP0(): @@ -72,10 +72,10 @@ def eeos(T): Cp = 1./(gamma-1.) M_ISP = 1.0/np.sqrt(gamma) # Eq. 28 Km = 3.*(gamma*M0**2+1.) + gamma*P0 # Eq. 16 - + def rho_f(T, theta, s): # Eq. 17 b = Km - gamma*P0*theta**4 - ac4 = 36.*gamma*M0**2*T + ac4 = 36.*gamma*M0**2*T return (b + s*np.sqrt(b**2-ac4))/(6.*T) def dTdtheta(T, theta, rho, M, v, s): # Eq. 54 @@ -89,8 +89,8 @@ def dTdtheta(T, theta, rho, M, v, s): # Eq. 54 dGdtheta = c1 * (12.*Cp*drhodtheta*rho*(T-1.) - 6.*M0**2*rho*drhodtheta + 8.*P0*(drhodtheta*(theta**4-2.*rho)+4.*rho*theta**3)) dFdT = c2 * (4.*v*theta**3*dGdT - 12.*sigma*(gamma*M**2-1.)*T**3) dFdtheta = c2 * (4.*v*theta**3*dGdtheta + 12.*sigma*(gamma*M**2-1.)*theta**3) - S1 = dFdT - dGdtheta - S2 = np.sqrt((dFdT-dGdtheta)**2 + 4.*dGdT*dFdtheta) + S1 = dFdT - dGdtheta + S2 = np.sqrt((dFdT-dGdtheta)**2 + 4.*dGdT*dFdtheta) dTdtheta_tmp = (S1 + S2) / (2.*dGdT) drhodtheta_full = drhodtheta + drhodT * dTdtheta_tmp if (drhodtheta > 0.0): @@ -110,7 +110,7 @@ def dxTdM(xT, M): # Eq. 37 theta = th4**0.25 th3 = th4/theta thetaprime = thetaprime_f(T,theta,rho,v) - foo = 4.*M0*th3*thetaprime + foo = 4.*M0*th3*thetaprime ZD = foo + (gamma-1.)/(gamma+1.)*(gamma*M**2+1.)*r # Eq. 39 ZN = foo + (gamma*M**2-1.)*r # Eq. 24 dxdM = -6.*M0*rho*T/((gamma+1.)*P0*M) * (M**2-1.)/ZD @@ -122,7 +122,7 @@ def dxTdM(xT, M): # Eq. 37 theta0 = 1.0 v0 = M0 rho0 = 1.0 - + rho1, v1, T1 = OneTShock(P0=P0, gamma=gamma, M0=M0) M1 = v1 / np.sqrt(T1) theta1 = T1 @@ -133,7 +133,7 @@ def dxTdM(xT, M): # Eq. 37 s1 = 1. else: s1 = -1. - + # Step 2a of LE08 # i= 0 eps = 1.0e-10 @@ -162,7 +162,7 @@ def dxTdM(xT, M): # Eq. 37 vpre = M0/rhopre thetapre = ((Km-3.*gamma*M0**2/rhopre-3.*Tpre*rhopre) / (gamma*P0))**0.25 # Eq. 41 - + # Step 3a # i= 1 eps = -1.0e-10 @@ -199,7 +199,7 @@ def dxTdM(xT, M): # Eq. 37 vrel = vrel[::-1] rhorel = rhorel[::-1] - + # Step 4 print('') print('thetapre[-1]=', thetapre[-1], ' thetarel[0]=', thetarel[0]) @@ -217,7 +217,7 @@ def dxTdM(xT, M): # Eq. 37 while irel= thetarel[irel]) ilast = index[0]-1 - + rhop = rhopre[ilast] vp = vpre[ilast] Tp = Tpre[ilast] @@ -225,7 +225,7 @@ def dxTdM(xT, M): # Eq. 37 pp = peos(rhop, Tp) ep = eeos(Tp) Ep = ep + 0.5*vp**2 - + rhos = rhorel[irel] vs = vrel[irel] Ts = Trel[irel] @@ -233,15 +233,15 @@ def dxTdM(xT, M): # Eq. 37 ps = peos(rhos, Ts) es = eeos(Ts) Es = es + 0.5*vs**2 - + foo = rhop*vp**2 + pp # Eq. 12b bar = rhos*vs**2 + ps - err1 = abs(foo-bar)/min(foo,bar) - + err1 = abs(foo-bar)/min(foo,bar) + foo = vp*(rhop*Ep+pp) # Eq. 12c bar = vs*(rhos*Es+ps) - err2 = abs(foo-bar)/min(foo,bar) - + err2 = abs(foo-bar)/min(foo,bar) + errs.append(np.sqrt(err1**2+err2**2)) ilasts.append(ilast) irels.append(irel) @@ -254,55 +254,55 @@ def dxTdM(xT, M): # Eq. 37 print('theta near the shock:', thetapre[ilast], thetarel[irel]) print('Jump in T:', Tpre[ilast], Trel[irel]) print('Jump in rho:', rhopre[ilast], rhorel[irel]) - - - #This shifts it so x=0 is the shock. + + + #This shifts it so x=0 is the shock. x0 = x0 - xpre[ilast+1] xpre = xpre - xpre[ilast+1] x1 = x1 - xrel[irel] xrel = xrel - xrel[irel] x = np.append(xpre[0:ilast+1], xrel[irel:]) - - - + + + T = np.append(Tpre[0:ilast+1], Trel[irel:]) theta = np.append(thetapre[0:ilast+1], thetarel[irel:]) M = np.append(Mpre[0:ilast+1], Mrel[irel:]) v = np.append(vpre[0:ilast+1], vrel[irel:]) rho = np.append(rhopre[0:ilast+1], rhorel[irel:]) - + print('test:') print('testx0',x0) print('testx1', x1) - + x = np.append(x0,x) T = np.append(T0,T) theta = np.append(theta0,theta) rho = np.append(rho0,rho) v = np.append(v0,v) - + x = np.append(x,x1) T = np.append(T,T1) theta = np.append(theta,theta1) rho = np.append(rho,rho1) v = np.append(v,v1) - - - + + + return x, T, theta, rho - - + + if __name__ == "__main__": - + P0 = 1.0e-4 gamma = 5./3. sigma = 1.0e6 kappa = 1. M0 = 5. - + x_sol, T_sol, theta_sol, rho_sol = TwoTShock(P0, gamma, sigma, kappa, M0) @@ -317,7 +317,7 @@ def dxTdM(xT, M): # Eq. 37 plt.legend() plt.savefig("{}_Temp_Test.png".format(os.path.basename(args.plotfile))) - + t1, x1, rho1 = get_x_var(args.plotfile, "density") x1 = np.array(x1) - x1[max_index] plt.figure(2) diff --git a/Exec/radiation_tests/Rad2Tshock/python/LowrieEdwardsUnits.py b/Exec/radiation_tests/Rad2Tshock/python/LowrieEdwardsUnits.py index 758ede71cc..07def7d6d2 100755 --- a/Exec/radiation_tests/Rad2Tshock/python/LowrieEdwardsUnits.py +++ b/Exec/radiation_tests/Rad2Tshock/python/LowrieEdwardsUnits.py @@ -2,7 +2,7 @@ import sys, getopt import numpy as np -from phys import c, R +from phys import c, R from phys import a as aRad import cPickle as pickle @@ -25,7 +25,7 @@ def LEunits(P0=1.0e-4, gamma=5./3., uL=1.0e5, uT=100.0, mu=1.0, printmessg=0): if printmessg: print 'units for' print 'uL=', uL - print 'uT=', uT + print 'uT=', uT print 'gamma=', gamma print 'P0=', P0 print 'mu=', mu diff --git a/Exec/radiation_tests/Rad2Tshock/python/RadShock.py b/Exec/radiation_tests/Rad2Tshock/python/RadShock.py index d0e02ee277..4834ae2f70 100755 --- a/Exec/radiation_tests/Rad2Tshock/python/RadShock.py +++ b/Exec/radiation_tests/Rad2Tshock/python/RadShock.py @@ -14,7 +14,7 @@ def f2_f(T1): def rho1_f(T1): f1 = f1_f(T1) return (f1+sqrt(f1**2+f2_f(T1))) / (6.*(gamma-1.)*T1) - def Eq13(T1): + def Eq13(T1): rho1 = rho1_f(T1) return 3.0*rho1*(rho1*T1-1.) + gamma*P0*rho1*(T1**4-1.) - 3.*gamma*(rho1-1.)*M0**2 def T1_smallP0(): @@ -47,10 +47,10 @@ def eeos(T): Cp = 1./(gamma-1.) M_ISP = 1.0/sqrt(gamma) # Eq. 28 Km = 3.*(gamma*M0**2+1.) + gamma*P0 # Eq. 16 - + def rho_f(T, theta, s): # Eq. 17 b = Km - gamma*P0*theta**4 - ac4 = 36.*gamma*M0**2*T + ac4 = 36.*gamma*M0**2*T return (b + s*sqrt(b**2-ac4))/(6.*T) def dTdtheta(T, theta, rho, M, v, s): # Eq. 54 @@ -64,8 +64,8 @@ def dTdtheta(T, theta, rho, M, v, s): # Eq. 54 dGdtheta = c1 * (12.*Cp*drhodtheta*rho*(T-1.) - 6.*M0**2*rho*drhodtheta + 8.*P0*(drhodtheta*(theta**4-2.*rho)+4.*rho*theta**3)) dFdT = c2 * (4.*v*theta**3*dGdT - 12.*sigma*(gamma*M**2-1.)*T**3) dFdtheta = c2 * (4.*v*theta**3*dGdtheta + 12.*sigma*(gamma*M**2-1.)*theta**3) - S1 = dFdT - dGdtheta - S2 = sqrt((dFdT-dGdtheta)**2 + 4.*dGdT*dFdtheta) + S1 = dFdT - dGdtheta + S2 = sqrt((dFdT-dGdtheta)**2 + 4.*dGdT*dFdtheta) dTdtheta_tmp = (S1 + S2) / (2.*dGdT) drhodtheta_full = drhodtheta + drhodT * dTdtheta_tmp if (drhodtheta > 0.0): @@ -85,7 +85,7 @@ def dxTdM(xT, M): # Eq. 37 theta = th4**0.25 th3 = th4/theta thetaprime = thetaprime_f(T,theta,rho,v) - foo = 4.*M0*th3*thetaprime + foo = 4.*M0*th3*thetaprime ZD = foo + (gamma-1.)/(gamma+1.)*(gamma*M**2+1.)*r # Eq. 39 ZN = foo + (gamma*M**2-1.)*r # Eq. 24 dxdM = -6.*M0*rho*T/((gamma+1.)*P0*M) * (M**2-1.)/ZD @@ -106,7 +106,7 @@ def dxTdM(xT, M): # Eq. 37 s1 = 1. else: s1 = -1. - + # Step 2a of LE08 # i= 0 eps = 1.0e-10 @@ -223,11 +223,11 @@ def dxTdM(xT, M): # Eq. 37 # foo = rhop*vp**2 + pp # Eq. 12b bar = rhos*vs**2 + ps - err1 = abs(foo-bar)/min(foo,bar) + err1 = abs(foo-bar)/min(foo,bar) # foo = vp*(rhop*Ep+pp) # Eq. 12c bar = vs*(rhos*Es+ps) - err2 = abs(foo-bar)/min(foo,bar) + err2 = abs(foo-bar)/min(foo,bar) # errs.append(sqrt(err1**2+err2**2)) ilasts.append(ilast) diff --git a/Exec/radiation_tests/Rad2Tshock/python/initincgs.py b/Exec/radiation_tests/Rad2Tshock/python/initincgs.py index 60f6a80236..6189247f1d 100755 --- a/Exec/radiation_tests/Rad2Tshock/python/initincgs.py +++ b/Exec/radiation_tests/Rad2Tshock/python/initincgs.py @@ -48,7 +48,7 @@ def main(): rho = units['rho'] v = M0 * units['v'] kappa_p = sigma * units['sigma'] - kappa_r = c * (1./3.) / (kappa * units['kappa']) + kappa_r = c * (1./3.) / (kappa * units['kappa']) cv = R / (gamma-1.0)/mu rho1, v1, T1 = OneTShock(P0=P0, gamma=gamma, M0=M0) @@ -58,8 +58,8 @@ def main(): print "In cgs units:" print 'Length unit: ', L - print 'Pre-shock: ', 'T=', T, 'rho=', rho, 'v=', v, 'v/c=', v/c - print 'Post-shock: ', 'T=', T1, 'rho=', rho1, 'v=', v1, 'v/c=', v1/c + print 'Pre-shock: ', 'T=', T, 'rho=', rho, 'v=', v, 'v/c=', v/c + print 'Post-shock: ', 'T=', T1, 'rho=', rho1, 'v=', v1, 'v/c=', v1/c print 'kappa_p=', kappa_p, 'kappa_r=', kappa_r print 'cv=', cv, 'gamma=', gamma, 'mu=', mu diff --git a/Exec/radiation_tests/Rad2Tshock/python/paper-M2-mg.py b/Exec/radiation_tests/Rad2Tshock/python/paper-M2-mg.py index 02a59020e1..296873ef3c 100755 --- a/Exec/radiation_tests/Rad2Tshock/python/paper-M2-mg.py +++ b/Exec/radiation_tests/Rad2Tshock/python/paper-M2-mg.py @@ -12,7 +12,7 @@ Temp, x, t = read_gnu_file('../run-M2-mg/Temp_'+n+'.gnu') print t -x += 10 +x += 10 fid = open('M2shock.p', 'rb') xa = pickle.load(fid) diff --git a/Exec/radiation_tests/Rad2Tshock/python/paper-M2.py b/Exec/radiation_tests/Rad2Tshock/python/paper-M2.py index d9275b5765..04fa4b750d 100755 --- a/Exec/radiation_tests/Rad2Tshock/python/paper-M2.py +++ b/Exec/radiation_tests/Rad2Tshock/python/paper-M2.py @@ -11,7 +11,7 @@ Temp, x, t = read_gnu_file('../run-M2/Temp_2000.gnu') print t -x += 10 +x += 10 fid = open('M2shock.p', 'rb') xa = pickle.load(fid) diff --git a/Exec/radiation_tests/Rad2Tshock/python/phys.py b/Exec/radiation_tests/Rad2Tshock/python/phys.py index f58825c479..4c056af274 100644 --- a/Exec/radiation_tests/Rad2Tshock/python/phys.py +++ b/Exec/radiation_tests/Rad2Tshock/python/phys.py @@ -1,5 +1,5 @@ -# physical constants in cgs +# physical constants in cgs # Fundamental constants taken from NIST's 2010 CODATA recommended values @@ -37,6 +37,6 @@ Mbolsun = 4.7554 # Absolute Bolometric Magnitude of Sun # time -year = 3.1556926e7 # year in second +year = 3.1556926e7 # year in second day = 86400.0 # day in second diff --git a/Exec/radiation_tests/RadBlastWave/problem_initialize_rad_data.H b/Exec/radiation_tests/RadBlastWave/problem_initialize_rad_data.H index 8435440930..95e25667c4 100644 --- a/Exec/radiation_tests/RadBlastWave/problem_initialize_rad_data.H +++ b/Exec/radiation_tests/RadBlastWave/problem_initialize_rad_data.H @@ -72,7 +72,7 @@ void problem_initialize_rad_data (int i, int j, int k, #if AMREX_SPACEDIM == 1 // the volume of a subzone is (4/3) pi (xr^3 - xl^3). // we can factor this as: (4/3) pi dr (xr^2 + xl*xr + xl^2) - // The (4/3) pi dr factor is common, so we can neglect it. + // The (4/3) pi dr factor is common, so we can neglect it. if (rr2 <= r2init) { vol_pert += (xr * xr + xl * xr + xl * xl); } diff --git a/Exec/radiation_tests/RadBlastWave/problem_initialize_state_data.H b/Exec/radiation_tests/RadBlastWave/problem_initialize_state_data.H index 8f343a986d..5d9439f9cb 100644 --- a/Exec/radiation_tests/RadBlastWave/problem_initialize_state_data.H +++ b/Exec/radiation_tests/RadBlastWave/problem_initialize_state_data.H @@ -70,7 +70,7 @@ void problem_initialize_state_data (int i, int j, int k, #if AMREX_SPACEDIM == 1 // the volume of a subzone is (4/3) pi (xr^3 - xl^3). // we can factor this as: (4/3) pi dr (xr^2 + xl*xr + xl^2) - // The (4/3) pi dr factor is common, so we can neglect it. + // The (4/3) pi dr factor is common, so we can neglect it. if (rr2 <= r2init) { vol_pert += (xr * xr + xl * xr + xl * xl); } diff --git a/Exec/radiation_tests/RadShestakovBolstad/python/initunits.py b/Exec/radiation_tests/RadShestakovBolstad/python/initunits.py index 3570e7779a..0f9cb1f12a 100755 --- a/Exec/radiation_tests/RadShestakovBolstad/python/initunits.py +++ b/Exec/radiation_tests/RadShestakovBolstad/python/initunits.py @@ -14,7 +14,7 @@ def SBunits(T0, rho0, kap0, printmessg=0): t0 = l0/c u0 = B0*nu0**3 E0 = u0*nu0 - cv = k*u0/(h*rho0) + cv = k*u0/(h*rho0) units = {'L':x0, 'time':t0, 'Temp': T0, 'Enu':u0, 'nu':nu0, 'Eg':E0, 'cv': cv} if printmessg: @@ -48,6 +48,6 @@ def SBunits(T0, rho0, kap0, printmessg=0): kap0 = float(a) T0 = T0 * 1.e3 * eV / k # now in erg - + SBunits(T0, rho0, kap0, 1) diff --git a/Exec/radiation_tests/RadShestakovBolstad/python/paper.py b/Exec/radiation_tests/RadShestakovBolstad/python/paper.py index e5c5abf3c4..8bc6dcedd8 100755 --- a/Exec/radiation_tests/RadShestakovBolstad/python/paper.py +++ b/Exec/radiation_tests/RadShestakovBolstad/python/paper.py @@ -10,7 +10,7 @@ fid = open('SBunits.p', 'rb') units = pickle.load(fid) -fid.close() +fid.close() Tw = (ew/units['cv']) / units['Temp'] Ew = Ew / units['Eg'] @@ -20,8 +20,8 @@ print 't = ', t ex = array([0.0, 0.2, 0.4, 0.46, 0.47, 0.48, 0.49, 0.50, 0.51, 0.52, 0.53, 0.54, 0.6, 0.8, 1.0]) -eT = array([9.9373253e-1, 9.9339523e-1, 9.8969664e-1, 9.8060848e-1, 9.7609654e-1, 9.6819424e-1, - 9.5044751e-1, 4.9704000e-1, 4.3632445e-2, 2.5885608e-2, 1.7983134e-2, 1.3470947e-2, +eT = array([9.9373253e-1, 9.9339523e-1, 9.8969664e-1, 9.8060848e-1, 9.7609654e-1, 9.6819424e-1, + 9.5044751e-1, 4.9704000e-1, 4.3632445e-2, 2.5885608e-2, 1.7983134e-2, 1.3470947e-2, 4.3797848e-3, 6.4654865e-4, 1.9181546e-4]) eE = array([5.6401674e-3, 5.5646351e-3, 5.1047352e-3, 4.5542134e-3, 4.3744933e-3, 4.1294850e-3, 3.7570008e-3, 2.9096931e-3, 2.0623647e-3, 1.6898183e-3, 1.4447063e-3, 1.2648409e-3, diff --git a/Exec/radiation_tests/RadShestakovBolstad/python/phys.py b/Exec/radiation_tests/RadShestakovBolstad/python/phys.py index f58825c479..4c056af274 100644 --- a/Exec/radiation_tests/RadShestakovBolstad/python/phys.py +++ b/Exec/radiation_tests/RadShestakovBolstad/python/phys.py @@ -1,5 +1,5 @@ -# physical constants in cgs +# physical constants in cgs # Fundamental constants taken from NIST's 2010 CODATA recommended values @@ -37,6 +37,6 @@ Mbolsun = 4.7554 # Absolute Bolometric Magnitude of Sun # time -year = 3.1556926e7 # year in second +year = 3.1556926e7 # year in second day = 86400.0 # day in second diff --git a/Exec/radiation_tests/RadSphere/Tools/fradsphere.f90 b/Exec/radiation_tests/RadSphere/Tools/fradsphere.f90 index 29b43ef275..261ae716a4 100644 --- a/Exec/radiation_tests/RadSphere/Tools/fradsphere.f90 +++ b/Exec/radiation_tests/RadSphere/Tools/fradsphere.f90 @@ -1,5 +1,5 @@ ! Print out the radiation quantities at a specified distance from the -! origin, for a 1-d CASTRO run. This is geared toward the radiating +! origin, for a 1-d CASTRO run. This is geared toward the radiating ! sphere problem. program fradsphere @@ -155,7 +155,7 @@ program fradsphere ! completely refined, and allocate enough storage for that, ! although, we won't really need all of this ! - ! note: sv(:,1) will be the coordinate information. + ! note: sv(:,1) will be the coordinate information. ! the variables will be stored in sv(:,2:nvs+1) allocate(sv(max_points,nvs+1), isv(max_points)) @@ -188,10 +188,10 @@ program fradsphere do ii = lbound(p,dim=1), ubound(p,dim=1) if ( any(imask(ii*r1:(ii+1)*r1-1) ) ) then cnt = cnt + 1 - + sv(cnt,1) = rmin + (ii + HALF)*dx(1)/rr sv(cnt,2:) = p(ii,1,1,:) - + imask(ii*r1:(ii+1)*r1-1) = .false. end if end do @@ -251,9 +251,9 @@ program fradsphere write(*,1000) "group #", "group center energy", & "E_rad(nu)*dnu (erg/cm^3)", "E_rad(nu) (erg/cm^3/Hz)" do i = 1, ngroups - write (*,1001) pf%names(irad_begin-1+i)(4:), & - nu_groups(i), & - sv(isv(idx_obs),1+irad_begin-1+i), & + write (*,1001) pf%names(irad_begin-1+i)(4:), & + nu_groups(i), & + sv(isv(idx_obs),1+irad_begin-1+i), & sv(isv(idx_obs),1+irad_begin-1+i)/dnu_groups(i) enddo diff --git a/Exec/radiation_tests/RadSphere/Tools/radbc.f90 b/Exec/radiation_tests/RadSphere/Tools/radbc.f90 index 727d7ae50e..832cff5a9e 100644 --- a/Exec/radiation_tests/RadSphere/Tools/radbc.f90 +++ b/Exec/radiation_tests/RadSphere/Tools/radbc.f90 @@ -1,5 +1,5 @@ ! write out the group dependent boundary conditions -! +! ! This routine takes as input the file "group_structures.dat" which is ! output by RadMultiGroup.cpp. That file defines the group centers ! and weights (widths). @@ -21,7 +21,7 @@ module constants_module ! physical parameters real(rt) , parameter :: T_sphere = 1500.e0_rt*ev2erg/k_B ! sphere temp (K - + end module constants_module @@ -30,7 +30,7 @@ function planck(nu,T) result (B) ! the Planck function for a Blackbody (actually, energy density, ! B = (4 pi / c) I, where I is the normal Planck function - ! + ! ! nu = frequency (Hz) ! T = temperature (K) @@ -63,7 +63,7 @@ program bc integer :: ngroups real(rt) , allocatable :: nu_groups(:), dnu_groups(:) real(rt) :: planck - + integer :: n character(len=256) :: header_line integer :: ipos @@ -88,10 +88,10 @@ program bc do n = 1, ngroups print *, n, nu_groups(n), planck(nu_groups(n), T_sphere)*dnu_groups(n) - enddo + enddo print *, "radiation.lo_bcval0 = ", & ((planck(nu_groups(n), T_sphere)*dnu_groups(n)), n=1,ngroups) end program bc - + diff --git a/Exec/radiation_tests/RadSuOlson/python/paper.py b/Exec/radiation_tests/RadSuOlson/python/paper.py index 9baedfe602..fa02fc1edc 100755 --- a/Exec/radiation_tests/RadSuOlson/python/paper.py +++ b/Exec/radiation_tests/RadSuOlson/python/paper.py @@ -7,7 +7,7 @@ def main(): kappa = 1.0 eps = 0.1 - Finc = 1.0 + Finc = 1.0 xu001 = [0.1, 0.25, 0.5, 0.75, 1.0] u001 = [0.17979, 0.11006, 0.04104, 0.01214, 0.00268] @@ -22,7 +22,7 @@ def main(): Tfilea = '../run-paper/Temp_0035.gnu' Erfileb = '../run-paper/Er_1002.gnu' Tfileb = '../run-paper/Temp_1002.gnu' - + def read_gnu_file(filenm): x = [] y = [] diff --git a/Exec/radiation_tests/RadSuOlsonMG/python/initunits.py b/Exec/radiation_tests/RadSuOlsonMG/python/initunits.py index 3f55f39c43..b6d126ff40 100755 --- a/Exec/radiation_tests/RadSuOlsonMG/python/initunits.py +++ b/Exec/radiation_tests/RadSuOlsonMG/python/initunits.py @@ -42,6 +42,6 @@ def SOunits(eps, printmessg=0): for o, a in opts: if o == "--eps": eps = float(a) - + SOunits(eps, 1) diff --git a/Exec/radiation_tests/RadSuOlsonMG/python/paper.py b/Exec/radiation_tests/RadSuOlsonMG/python/paper.py index d7f5c33755..cb9c1dda5a 100755 --- a/Exec/radiation_tests/RadSuOlsonMG/python/paper.py +++ b/Exec/radiation_tests/RadSuOlsonMG/python/paper.py @@ -55,10 +55,10 @@ xlim(0.2,90) ylim(4.e-4, 0.2) legend((line3,line1,line4,line2), - (r'$\tau = 3$'+' numerical', - r'$\tau = 3$'+' analytic', - r'$\tau = 30$'+' numerical', - r'$\tau = 30$'+' analytic'), + (r'$\tau = 3$'+' numerical', + r'$\tau = 3$'+' analytic', + r'$\tau = 30$'+' numerical', + r'$\tau = 30$'+' analytic'), loc='lower left', prop=matplotlib.font_manager.FontProperties(size=16), handlelength=2.5, diff --git a/Exec/radiation_tests/RadSuOlsonMG/python/phys.py b/Exec/radiation_tests/RadSuOlsonMG/python/phys.py index f58825c479..4c056af274 100644 --- a/Exec/radiation_tests/RadSuOlsonMG/python/phys.py +++ b/Exec/radiation_tests/RadSuOlsonMG/python/phys.py @@ -1,5 +1,5 @@ -# physical constants in cgs +# physical constants in cgs # Fundamental constants taken from NIST's 2010 CODATA recommended values @@ -37,6 +37,6 @@ Mbolsun = 4.7554 # Absolute Bolometric Magnitude of Sun # time -year = 3.1556926e7 # year in second +year = 3.1556926e7 # year in second day = 86400.0 # day in second diff --git a/Exec/reacting_tests/bubble_convergence/analysis/slice_multi.py b/Exec/reacting_tests/bubble_convergence/analysis/slice_multi.py index c47e68930d..d05bd7fba9 100755 --- a/Exec/reacting_tests/bubble_convergence/analysis/slice_multi.py +++ b/Exec/reacting_tests/bubble_convergence/analysis/slice_multi.py @@ -26,7 +26,7 @@ fig = plt.figure() fig.set_size_inches(12.0, 9.0) -grid = ImageGrid(fig, 111, nrows_ncols=(2, 2), axes_pad=0.75, cbar_pad="2%", +grid = ImageGrid(fig, 111, nrows_ncols=(2, 2), axes_pad=0.75, cbar_pad="2%", label_mode="L", cbar_mode="each") diff --git a/Exec/reacting_tests/bubble_convergence/converge_test.sh b/Exec/reacting_tests/bubble_convergence/converge_test.sh index 127e390a0b..0de514eee3 100755 --- a/Exec/reacting_tests/bubble_convergence/converge_test.sh +++ b/Exec/reacting_tests/bubble_convergence/converge_test.sh @@ -5,7 +5,7 @@ set -x EXEC=./Castro2d.gnu.MPI.TRUESDC.ex -CONV_TOOL=RichardsonConvergenceTest2d.gnu.ex +CONV_TOOL=RichardsonConvergenceTest2d.gnu.ex mpiexec -n 8 ${EXEC} inputs_2d.32 amr.plot_file=bubble_32_sdc4_plt >& 32.out mpiexec -n 8 ${EXEC} inputs_2d.64 amr.plot_file=bubble_64_sdc4_plt >& 64.out diff --git a/Exec/reacting_tests/bubble_convergence/problem_initialize_state_data.H b/Exec/reacting_tests/bubble_convergence/problem_initialize_state_data.H index 0400e1b1fb..2cbe924c9b 100644 --- a/Exec/reacting_tests/bubble_convergence/problem_initialize_state_data.H +++ b/Exec/reacting_tests/bubble_convergence/problem_initialize_state_data.H @@ -93,7 +93,7 @@ void problem_initialize_state_data (int i, int j, int k, state(i,j,k,URHO) = eos_state.rho; - // correct the mass fractions and energy with the new density + // correct the mass fractions and energy with the new density state(i,j,k,UEINT) = state(i,j,k,URHO) * eos_state.e; state(i,j,k,UEDEN) = state(i,j,k,UEINT); diff --git a/Exec/reacting_tests/nse_test/analysis/slice_multi.py b/Exec/reacting_tests/nse_test/analysis/slice_multi.py index e567c8c4e9..1b0dea899a 100755 --- a/Exec/reacting_tests/nse_test/analysis/slice_multi.py +++ b/Exec/reacting_tests/nse_test/analysis/slice_multi.py @@ -28,7 +28,7 @@ nrows = 2 ncols = 3 -grid = ImageGrid(fig, 111, nrows_ncols=(nrows, ncols), axes_pad=0.75, cbar_pad="2%", +grid = ImageGrid(fig, 111, nrows_ncols=(nrows, ncols), axes_pad=0.75, cbar_pad="2%", label_mode="L", cbar_mode="each") diff --git a/Exec/reacting_tests/reacting_convergence/analysis/slice_multi.py b/Exec/reacting_tests/reacting_convergence/analysis/slice_multi.py index a050fa6158..8f47cf062b 100755 --- a/Exec/reacting_tests/reacting_convergence/analysis/slice_multi.py +++ b/Exec/reacting_tests/reacting_convergence/analysis/slice_multi.py @@ -26,7 +26,7 @@ fig = plt.figure() fig.set_size_inches(12.0, 9.0) -grid = ImageGrid(fig, 111, nrows_ncols=(3, 2), axes_pad=0.75, cbar_pad="2%", +grid = ImageGrid(fig, 111, nrows_ncols=(3, 2), axes_pad=0.75, cbar_pad="2%", label_mode="L", cbar_mode="each") diff --git a/Exec/reacting_tests/reacting_convergence/problem_initialize.H b/Exec/reacting_tests/reacting_convergence/problem_initialize.H index 010758d711..d0c7d28a2a 100644 --- a/Exec/reacting_tests/reacting_convergence/problem_initialize.H +++ b/Exec/reacting_tests/reacting_convergence/problem_initialize.H @@ -95,7 +95,7 @@ void problem_initialize () xn[ispec6] = problem::spec6_frac; } - // Normalize species + // Normalize species auto sumX = 0.0_rt; for (auto X : xn) { sumX += X; diff --git a/Exec/reacting_tests/toy_flame/Prob.cpp b/Exec/reacting_tests/toy_flame/Prob.cpp index 3a3ea31b06..868982a1bf 100644 --- a/Exec/reacting_tests/toy_flame/Prob.cpp +++ b/Exec/reacting_tests/toy_flame/Prob.cpp @@ -21,7 +21,7 @@ Castro::flame_width_properties (Real time, Real& T_max, Real& T_min, Real& grad_ #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& box = mfi.tilebox(); @@ -73,7 +73,7 @@ Castro::flame_speed_properties (Real time, Real& rho_fuel_dot) #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& box = mfi.tilebox(); diff --git a/Exec/science/Detonation/analysis/shock_speed.py b/Exec/science/Detonation/analysis/shock_speed.py index 9d63c4b9ef..069db08d86 100644 --- a/Exec/science/Detonation/analysis/shock_speed.py +++ b/Exec/science/Detonation/analysis/shock_speed.py @@ -24,12 +24,12 @@ def get_T_profile(plotfile): def find_x_for_T(x, T, T_0=2.e9): """ given a profile x(T), find the x_0 that corresponds to T_0 """ - + # our strategy here assumes that the hot ash is in the early part # of the profile. We then find the index of the first point where # T drops below T_0 idx = np.where(T < T_0)[0][0] - + T1 = T[idx-1] x1 = x[idx-1] @@ -37,7 +37,7 @@ def find_x_for_T(x, T, T_0=2.e9): x2 = x[idx] slope = (x2 - x1)/(T2 - T1) - + return x1 + slope*(T_0 - T1) diff --git a/Exec/science/convective_flame/slice.py b/Exec/science/convective_flame/slice.py index 0bd53a9ba0..bea157f135 100755 --- a/Exec/science/convective_flame/slice.py +++ b/Exec/science/convective_flame/slice.py @@ -12,7 +12,7 @@ sp.set_zlim("Temp", 1.e-3, 100) # now do a contour of density -sp.annotate_contour("density", ncont=2, clim=(0.01, 1.0), +sp.annotate_contour("density", ncont=2, clim=(0.01, 1.0), plot_args={"colors": "red", "linewidths": 2}) sp.save("{}_slice.png".format(os.path.basename(plotfile))) diff --git a/Exec/science/flame/Prob.cpp b/Exec/science/flame/Prob.cpp index aecd4b13ba..4384f803e6 100644 --- a/Exec/science/flame/Prob.cpp +++ b/Exec/science/flame/Prob.cpp @@ -21,7 +21,7 @@ Castro::flame_width_properties (Real time, Real& T_max, Real& T_min, Real& grad_ #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& box = mfi.tilebox(); @@ -86,7 +86,7 @@ Castro::flame_speed_properties (Real time, Real& rho_fuel_dot) #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& box = mfi.tilebox(); diff --git a/Exec/science/flame_wave/analysis/flame_speed.py b/Exec/science/flame_wave/analysis/flame_speed.py index 0ed023737a..79cf8b35d8 100755 --- a/Exec/science/flame_wave/analysis/flame_speed.py +++ b/Exec/science/flame_wave/analysis/flame_speed.py @@ -22,7 +22,7 @@ def measure_and_plot(dat, stab_ind): front has stabilized, and the slope obtained from linear regression will yield an accurate measurement of the front speed. """ - + slopes = dict() radarr = dat["enuc[0.1%]"] @@ -36,44 +36,44 @@ def measure_and_plot(dat, stab_ind): m, b, r, _, sd = linregress(tarr, radarr) print("{:>20}\t{:.2e}\t{:.3f}\t{:.2e}".format("enuc[0.1%]", m, r, sd)) - + if r > 0.8: - + plt.plot(dat["time"] * 1000, m * dat["time"] + b, "k--", linewidth=2) - + ax = plt.gca() ax.ticklabel_format(axis="y", style="sci", scilimits=(0, 0)) ax.yaxis.major.formatter._useMathText = True ax.xaxis.set_major_locator(MaxNLocator(integer=True)) # ax.yaxis.set_major_locator(MaxNLocator(integer=True)) - + plt.xlabel("t [ms]") plt.ylabel("r [cm]") plt.title("Front Position vs. Time", fontsize=24) - + for item in (ax.xaxis.label, ax.yaxis.label): - + item.set_fontsize(20) item.set_color("dimgrey") - + for item in (ax.get_xticklabels() + ax.get_yticklabels()) + [ax.yaxis.offsetText]: - + item.set_fontsize(16) item.set_color("dimgrey") - + return m if __name__ == "__main__": - + try: - + dat = pd.read_csv(sys.argv[1], sep="\s+") stab_ind = int(sys.argv[2]) plt.style.use("ggplot") measure_and_plot(dat, stab_ind) plt.show() - + except (ValueError, IndexError): - + print("Usage: ./fit_speed.py data_file starting_index") diff --git a/Exec/science/flame_wave/analysis/front_tracker.py b/Exec/science/flame_wave/analysis/front_tracker.py index 79cbed4127..58c418f334 100755 --- a/Exec/science/flame_wave/analysis/front_tracker.py +++ b/Exec/science/flame_wave/analysis/front_tracker.py @@ -48,44 +48,44 @@ args = parser.parse_args(sys.argv[1:]) class Transform(Enum): - + SLC = 0 AVG = 1 def process_args(args): - + # Load datasets tf = lambda fname: yt.load(fname.rstrip('/')) args.ts = list(map(tf, args.datasets)) - + # Assume same domain for all datasets ds = args.ts[0] - + if args.xlim is None: args.xlim = ds.domain_left_edge[0], ds.domain_right_edge[0] if args.ylim is None: args.ylim = ds.domain_left_edge[1], ds.domain_right_edge[1] if args.zlim is None: args.zlim = ds.domain_left_edge[2], ds.domain_right_edge[2] - + metrics = dict() - + for item in args.metrics: - + try: ls.append(float(item)) except: ls = metrics.setdefault(item, []) - + args.metrics = metrics - + if args.transform is None: - + args.transform = {Transform.SLC: [2], Transform.AVG: [1]} - + else: - + transform = {tr: [] for tr in Transform} - + for i, item in enumerate(args.transform): - + item = item.split(':') if len(item) == 1: item, = item @@ -95,28 +95,28 @@ def process_args(args): transform[Transform(t)].append(ind) else: raise ValueError("Invalid transform format.") - + args.transform = transform - + if args.res is None: args.res = ds.domain_dimensions if len(args.res) < 3: args.res += [1] * (3 - args.res) - + # Eventually may want to generalize this to allow multiple axes # Then we would just return a point in 2D or 3D space - + transformed = sum(args.transform.values(), []) args.axis, = filter(lambda ax: ax not in transformed, range(3)) - + if ds.geometry == 'spherical': axnames = 'r', elif ds.geometry == 'cylindrical': axnames = 'r', 'z' else: axnames = 'x', 'y', 'z' - + args.axis_name = axnames[args.axis] - + assert len(args.res) == 3 - + process_args(args) ################# @@ -125,7 +125,7 @@ def process_args(args): def get_window_parameters(ds, axis, width=None, center='c'): """ Some parameters controlling the frb window. """ - + width = ds.coordinates.sanitize_width(axis, width, None) center, display_center = ds.coordinates.sanitize_center(center, axis) xax = ds.coordinates.x_axis[axis] @@ -135,7 +135,7 @@ def get_window_parameters(ds, axis, width=None, center='c'): display_center[yax]-width[1] / 2, display_center[yax]+width[1] / 2) return bounds, center, display_center - + def get_width(ds, xlim=None, ylim=None, zlim=None): """ Get the width of the frb. """ @@ -144,7 +144,7 @@ def get_width(ds, xlim=None, ylim=None, zlim=None): if ylim is None: ylim = ds.domain_left_edge[1], ds.domain_right_edge[1] else: ylim = ylim[0], ylim[1] - + if zlim is None: zlim = ds.domain_left_edge[2], ds.domain_right_edge[2] else: zlim = zlim[0], zlim[1] @@ -153,7 +153,7 @@ def get_width(ds, xlim=None, ylim=None, zlim=None): zwidth = (zlim[1] - zlim[0]).in_cgs() return xwidth, ywidth, zwidth - + def get_center(ds, xlim=None, ylim=None, zlim=None): """ Get the coordinates of the center of the frb. """ @@ -162,7 +162,7 @@ def get_center(ds, xlim=None, ylim=None, zlim=None): if ylim is None: ylim = ds.domain_left_edge[1], ds.domain_right_edge[1] else: ylim = ylim[0], ylim[1] - + if zlim is None: zlim = ds.domain_left_edge[2], ds.domain_right_edge[2] else: zlim = zlim[0], zlim[1] @@ -171,64 +171,64 @@ def get_center(ds, xlim=None, ylim=None, zlim=None): zctr = 0.5 * (zlim[0] + zlim[1]).in_cgs() return xctr, yctr, zctr - + def minus_inf(): """ Factory function for negative infinity. """ - + return float("-inf") class Metrics: """ Class for defining different measurements of the position of the flame front. """ - + # Global maxima _globmax = defaultdict(minus_inf) - + def __init__(self, ds, args): - + self.__dict__.update(self.makefrbs(ds, args)) self.time = ds.current_time self._metrics = args.metrics self._upper_branch = args.branch > 0 self._use_global_max = args.use_global_max - + for field in args.metrics.keys(): Metrics._globmax[field] = max(Metrics._globmax[field], self[field].max()) - + def __getitem__(self, field): - + return getattr(self, field) - + @staticmethod def makefrbs(ds, args): - + fields = args.metrics.keys() width = get_width(ds, args.xlim, args.ylim, args.zlim) center = get_center(ds, args.xlim, args.ylim, args.zlim) - + region = \ [ slice(*args.xlim, complex(0, args.res[0])), slice(*args.ylim, complex(0, args.res[1])), slice(*args.zlim, complex(0, args.res[2])) ] - + for axis in args.transform[Transform.SLC]: - + _, center, _ = get_window_parameters(ds, axis, width, center) region[axis] = center[axis] - + # The resolution in yt FixedResolutionBuffers is backwards # If we're doing a slice, we need to swap the steps is_slice = [isinstance(bounds, slice) for bounds in region] dim = sum(is_slice) - + if dim == 2: - + normal = is_slice.index(False) xax = ds.coordinates.x_axis[normal] yax = ds.coordinates.y_axis[normal] xslc, yslc = region[xax], region[yax] - + region[xax] = slice(xslc.start, xslc.stop, yslc.step) region[yax] = slice(yslc.start, yslc.stop, xslc.step) @@ -242,40 +242,40 @@ def makefrbs(ds, args): # Create an FRB for each field and average over the remaining extra dimensions frbs = dict(pos=frr[args.axis_name]) for field in fields: frbs[field] = frr[field] - + axes = sorted([args.axis] + args.transform[Transform.AVG]) - + for i, ax in enumerate(reversed(axes)): - + if ax == args.axis: continue for field in frbs: frbs[field] = frbs[field].mean(axis=i) - + return frbs - - @staticmethod + + @staticmethod def tostring(field, fac): - + return f"{field}[{fac*100}%]" - + @property def fields(self): - + return list(self.metrics.keys()) - + def locate(self, field, fac): """ Returns position where `field` drops to or reaches `fac * max(field)`. """ - + maxind = self[field].argmax() - + if self._use_global_max: maxval = self._globmax[field] elif fac == 1.0: return self.pos[maxind] else: maxval = self[field].max() - + thresh = maxval * fac if self._upper_branch: ind = (self[field][maxind:] < thresh).argmax() @@ -283,18 +283,18 @@ def locate(self, field, fac): else: ind = (self[field][maxind+1:] > thresh).argmax() return self.pos[ind] - + def getall(self): """ Return positions for all metrics, in a dictionary keyed by metric string. """ - + locs = dict() - + for field, facs in self._metrics.items(): - + for fac in facs: - + locs[self.tostring(field, fac)] = self.locate(field, fac) - + return locs ######################################### @@ -308,7 +308,7 @@ def getall(self): loclist = [] while args.ts: - + ds = args.ts.popleft() times.append(ds.current_time) loclist.append(Metrics(ds, args)) @@ -320,12 +320,12 @@ def getall(self): cols = sorted(loclist[0].keys()) with open(args.out, 'w') as file: - + print("time", *cols, file=file) - + for time, locs in zip(times, loclist): - + row = (locs[col].value for col in cols) print(time.value, *row, file=file) - + print("Task completed.") diff --git a/Exec/science/flame_wave/analysis/image_animator.py b/Exec/science/flame_wave/analysis/image_animator.py index 4bb1f0e8b3..20ccf0b291 100644 --- a/Exec/science/flame_wave/analysis/image_animator.py +++ b/Exec/science/flame_wave/analysis/image_animator.py @@ -26,7 +26,7 @@ # Sort if necessary if args.sort is not None: - + # Descending or ascending desc = args.sort < 0 # Starting index @@ -39,21 +39,21 @@ else: key = lambda filename: filename[start:start+nchars] images.sort(key=key, reverse=desc) - + if args.out.endswith(".mp4"): args.out = args.out[:-4] if not args.out: sys.exit("Invalid output file!") with tf.TemporaryDirectory() as dir: - + # The files are numbered # Padding with zeros preserves sort order ndigits = len(str(len(images))) baselink = "__fftemp_{:0%dd}.png" % ndigits for i, image in enumerate(map(os.path.abspath, images)): - + # Create a symlink for each file linkname = baselink.format(i) linkname = os.path.join(dir, linkname) diff --git a/Exec/science/flame_wave/analysis/mpl_image_animator.py b/Exec/science/flame_wave/analysis/mpl_image_animator.py index 24311219f3..ec04fe0a02 100755 --- a/Exec/science/flame_wave/analysis/mpl_image_animator.py +++ b/Exec/science/flame_wave/analysis/mpl_image_animator.py @@ -36,24 +36,24 @@ sys.exit("No images supplied for animation.") if args.stack is not None: - + nsubplots = args.stack[0] groupmode = args.stack[1] - + else: - + nsubplots = 1 groupmode = 0 - + sublist_size = len(images) // nsubplots - + if nsubplots > 1 and groupmode == 0: - + step = sublist_size sublists = [images[i-step:i] for i in range(step, len(images) + 1, step)] - + else: - + sublists = [images] # Sort if necessary @@ -71,9 +71,9 @@ key = lambda img: img[start:start + nchars] for imlist in sublists: imlist.sort(key=key, reverse=desc) - + if nsubplots > 1 and groupmode == 1: - + sublists = [images[i::nsubplots] for i in range(nsubplots)] # Load images and animate @@ -83,12 +83,12 @@ print("Animating...") if nsubplots == 1: - + fig = plt.figure() axes = [plt.gca()] - + else: - + fig, axes = plt.subplots(nsubplots) plt.margins(0, 0) @@ -97,20 +97,20 @@ imobj = [] for ax, sub in zip(axes, sublists): - + ax.set_axis_off() zeros = np.zeros(sub[0].shape) imobj.append(ax.imshow(zeros, origin='lower', alpha=1.0, zorder=1, aspect=1)) def init(): - + for im, sub in zip(imobj, sublists): im.set_data(np.zeros(sub[0].shape)) return imobj, def animate(i): - + for im, sub in zip(imobj, sublists): im.set_data(sub[i][-1::-1]) return imobj diff --git a/Exec/science/flame_wave/analysis/plot_generator.py b/Exec/science/flame_wave/analysis/plot_generator.py index 0d52d448ea..51ca740c79 100644 --- a/Exec/science/flame_wave/analysis/plot_generator.py +++ b/Exec/science/flame_wave/analysis/plot_generator.py @@ -83,17 +83,17 @@ if args.stream is not None: args.stream[2] = int(args.stream[2]) - + if args.contour is not None: - + args.contour[1:] = list(map(float, args.contour[1:])) - + if args.contour_opt is not None: - + contour_opt = {'plot_args': {'colors': args.contour_opt[0], 'linewidths': int(args.contour_opt[1])}} else: - + contour_opt = {} if args.flame_wave: @@ -211,9 +211,9 @@ def _transvel(field, data): # Loop and generate for ds in ts: - + if ("gas", "transvel") not in ds.field_list: - + try: ds.add_field(("gas", "transvel"), function=_transvel, units="cm/s", sampling_type="cell") @@ -237,9 +237,9 @@ def _transvel(field, data): plot.set_log(field, args.log) if args.time: - + time_format = 't = {{time:.{}f}}{{units}}'.format(args.time) - + plot.annotate_timestamp(corner='upper_left', time_format=time_format, time_unit='s', draw_inset_box=True, inset_box_args={'alpha': 0.0}) @@ -256,9 +256,9 @@ def _transvel(field, data): plot.annotate_streamlines(args.stream[0], args.stream[1], factor=args.stream[2], plot_args={'cmap': color_opt.cmap, 'arrowstyle': '->'}, **kw) - + if args.grid is not None: - + opts = dict(zip(args.grid[::2], args.grid[1::2])) plot.annotate_grids(**opts) diff --git a/Exec/science/flame_wave/analysis/profiles.py b/Exec/science/flame_wave/analysis/profiles.py index f14f57ce0d..cf8999a2ed 100755 --- a/Exec/science/flame_wave/analysis/profiles.py +++ b/Exec/science/flame_wave/analysis/profiles.py @@ -98,7 +98,7 @@ def to_atomic_mass(mfrac_field): else: # make the offset text look nice and latex-y # https://stackoverflow.com/questions/31517156/adjust-exponent-text-after-setting-scientific-limits-on-matplotlib-axis - axes[i].yaxis.set_major_formatter(ptick.ScalarFormatter(useMathText=True)) + axes[i].yaxis.set_major_formatter(ptick.ScalarFormatter(useMathText=True)) if i == 0: axes[0].legend(frameon=False) @@ -106,4 +106,4 @@ def to_atomic_mass(mfrac_field): #fig.set_size_inches(10.0, 9.0) plt.tight_layout() plt.savefig("{}_profiles.png".format(os.path.basename(plotfile))) - + diff --git a/Exec/science/flame_wave/analysis/trajectories_info.py b/Exec/science/flame_wave/analysis/trajectories_info.py index fa324f9bcb..9fa2915628 100644 --- a/Exec/science/flame_wave/analysis/trajectories_info.py +++ b/Exec/science/flame_wave/analysis/trajectories_info.py @@ -53,4 +53,4 @@ print("sorting files...") for f in files_to_sort: #sorts lines in files: -g = sort scientific notation, -k 3 = use third column (time), -o = specify output filename - subprocess.run(["sort","-g","-k 3",f,"-o",f], shell=False) \ No newline at end of file + subprocess.run(["sort","-g","-k 3",f,"-o",f], shell=False) \ No newline at end of file diff --git a/Exec/science/flame_wave/scaling/frontier/frontier-scaling-2023-04-06.txt b/Exec/science/flame_wave/scaling/frontier/frontier-scaling-2023-04-06.txt index 962e5627be..34d2a71734 100644 --- a/Exec/science/flame_wave/scaling/frontier/frontier-scaling-2023-04-06.txt +++ b/Exec/science/flame_wave/scaling/frontier/frontier-scaling-2023-04-06.txt @@ -26,4 +26,4 @@ # 384 5.2 128 9.83363 0.352897 # 512 5.2 128 6.99018 0.0698918 #1024 5.2 128 5.2249 0.408811 - + diff --git a/Exec/science/flame_wave/scaling/frontier/frontier-scaling-rkc-2023-05-31.txt b/Exec/science/flame_wave/scaling/frontier/frontier-scaling-rkc-2023-05-31.txt index fedafab8ee..f78f5c0650 100644 --- a/Exec/science/flame_wave/scaling/frontier/frontier-scaling-rkc-2023-05-31.txt +++ b/Exec/science/flame_wave/scaling/frontier/frontier-scaling-rkc-2023-05-31.txt @@ -15,4 +15,4 @@ 384 5.3 128 8.47071 0.059582 512 5.3 128 6.18902 0.0410103 1024 5.3 128 4.40306 0.0512439 -#2048 5.3 128 +#2048 5.3 128 diff --git a/Exec/science/flame_wave/scaling/summit/scaling_20200613.txt b/Exec/science/flame_wave/scaling/summit/scaling_20200613.txt index 20603936fa..f4197c222d 100644 --- a/Exec/science/flame_wave/scaling/summit/scaling_20200613.txt +++ b/Exec/science/flame_wave/scaling/summit/scaling_20200613.txt @@ -14,11 +14,11 @@ 256 64 43.1175 0.255655 1052 652 125.5 100.3 105.9 384 64 30.9885 0.42845 766 447.9 113.8 90.7 73.31 384 96 34.4243 0.336679 830.8 563.1 105.3 72.03 65.85 - 512 64 26.9385 0.255671 660.3 389.9 102 82.28 59.18 + 512 64 26.9385 0.255671 660.3 389.9 102 82.28 59.18 512 128 28.1867 0.127079 682.9 456.9 95.72 68.39 54.63 683 128 19.6767 0.200558 486.2 315.9 59.66 59.43 39.73 768 64 21.6024 0.264194 535.5 308.5 88.73 76.2 44.5 768 128 20.0257 0.178736 495.5 315.9 85.72 69.11 39.09 -1024 64 18.8358 0.137584 463.6 269.6 77.63 67.95 36.82 +1024 64 18.8358 0.137584 463.6 269.6 77.63 67.95 36.82 1024 128 19.5436 0.101079 485.1 324.6 71.49 56.44 38.33 2048 128 14.284 0.131826 354.4 229.8 62.35 55.07 22.28 diff --git a/Exec/science/flame_wave/scaling/summit/scaling_20230407.txt b/Exec/science/flame_wave/scaling/summit/scaling_20230407.txt index a06bf8e661..cd9a79c837 100644 --- a/Exec/science/flame_wave/scaling/summit/scaling_20230407.txt +++ b/Exec/science/flame_wave/scaling/summit/scaling_20230407.txt @@ -28,5 +28,5 @@ # 342 128 12.2387 0.165243 # 512 128 10.476 0.198743 # 683 128 9.29589 0.184105 -# 768 128 -#1366 128 +# 768 128 +#1366 128 diff --git a/Exec/science/massive_star/analysis/initial_model.py b/Exec/science/massive_star/analysis/initial_model.py index d46cc5001b..49f7d347f6 100644 --- a/Exec/science/massive_star/analysis/initial_model.py +++ b/Exec/science/massive_star/analysis/initial_model.py @@ -48,8 +48,8 @@ def find_r_for_rho(r, rho, rho_want): l1 = ax.plot(data[:,0], data[:,idens], label="density") l2 = ax.plot(data[:,0], data[:,itemp], label="temperature") -# show where the refinement kicks in -rho_refine = 1.e4 +# show where the refinement kicks in +rho_refine = 2.e4 r_refine = find_r_for_rho(data[:,0], data[:,idens], rho_refine) diff --git a/Exec/science/massive_star/problem_initialize_state_data.H b/Exec/science/massive_star/problem_initialize_state_data.H index 4276fa879a..ee38f53cab 100644 --- a/Exec/science/massive_star/problem_initialize_state_data.H +++ b/Exec/science/massive_star/problem_initialize_state_data.H @@ -227,7 +227,7 @@ void problem_initialize_state_data (int i, int j, int k, (x + problem::center[0]) / problem::velpert_scale + phix[n]); Real cy = std::cos(2.0_rt * M_PI * Real(jj) * - (y + problem::center[1]) / + (y + problem::center[1]) / problem::velpert_scale + phiy[n]); Real cz = std::cos(2.0_rt * M_PI * Real(kk) * (z + problem::center[2]) / diff --git a/Exec/science/planet/HotJupiter.cpp b/Exec/science/planet/HotJupiter.cpp index 059b255df5..309bde952a 100644 --- a/Exec/science/planet/HotJupiter.cpp +++ b/Exec/science/planet/HotJupiter.cpp @@ -17,7 +17,7 @@ long double Temp(long double P1,long double Pc,long double P_char,long double T_ long double Temp(long double P1,long double Pc,long double P_char,long double T_char,long double Td, long double Lin, long double Lad, long double exp1, long double exp2) //define the function here, ie give the equation { long double Temp; - + if(Pc>P1){ Temp = Td * std::pow(1.0e0 + (Lad / (Lin - Lad)) * std::pow((P1/Pc),exp1),exp2); } @@ -48,7 +48,7 @@ int main(){ int alpha=1, beta=0, count = 0,count_cell,count2=0; bool continuous_P, continuous_rho; long double P[10000],T[10000],den[10000],y[10000]; - + //Declaration Block Td = 1500.0; //T_deep : the temperature at the top of the atmosphere[K] P_char = 1.0e6; @@ -61,13 +61,13 @@ int main(){ exp1=1.0 + alpha; exp2=(1.0/(4.0-beta)); - - + + //Defining the computation box z_top=4.0e9; // the size of the computation box number_cell=1024.0; // the number of cells - - + + //Initializing kappa0 = 6.35e-3 ; dP_factor=1.e5; @@ -87,11 +87,11 @@ int main(){ //Choosing either continuous pressure or density at the boundary between the buffer and the atmosphere continuous_P = true; continuous_rho = false; - + if((continuous_P==true && continuous_rho==true) || (continuous_P==false && continuous_rho==false)){ cout<<"P and rho can not be continuous at the same time." <<'\n'; } - + //Defining the properties of the planet atmosphere // the density limit at the top of the atmosphere P_top=den_top*R*Td ; // the pressure limit at the density limit @@ -99,8 +99,8 @@ int main(){ Pc = P_char * std::pow(Tc/T_char,1.0/Lad); //the pressure at the RCB Pd = std::pow((Lin-Lad)/(2.0*Lin-Lad),1.0/exp1)*Pc; //the characteristic pressure defining the radiative zone - - + + //Defining the properties of the buffer den_buffer=1.3e-15; // the density in the buffer above the atmosphere T_buffer=1.0e-2; // the temperature in the buffer above the atmosphere (not continuous at RCB). -> needs sponge @@ -110,11 +110,11 @@ int main(){ } else if(continuous_P==true){ } - + buffer_height=z_top*2.25/4.0; // the height at which the buffer and the top of the atmosphere meet (not continuous at RCB).-> needs sponge optical_depth_buffer=6.35e-3*T_buffer*std::pow(den_buffer,2.0)*(z_top-buffer_height);// the optical depth in the buffer region [dimensionless] - - + + do{ if(z>buffer_height){ @@ -130,24 +130,24 @@ int main(){ y[count] = z; count_cell++; cout<<"In buffer" << ' '<< count_cell << ' ' << z<<' '<< dz/(z_top/number_cell) << ' '<<"Pressure[P/Pc]="<<' ' << P1/Pc << ' '<<"optical depth ="<< ' '< -2.0*delta_z); - - - + + + //output data cout<<"count= " << count-1<<'\n'; cout<<"At bottom, "<< ' ' <<"density[g/cm^3]= " << ' ' << den[count-1] << ' ' << " T[K]= "<< ' ' << T[count-1] << ' ' << " P[bar]= " << ' ' << P[count-1]/1.e6 << '\n'; cout<<"At optical depta=1, "<< ' ' <<"z[km]=" << ' ' << z_at_1opticaldepth/1e5 << ' ' <<"density[g/cm^3]= " << ' ' << den_at_1opticaldepth << ' ' << " T[K]= "<< ' ' << T_at_1opticaldepth << ' ' << " P[bar]= " << ' ' << P_at_1opticaldepth/1.e6 << '\n'; - + if (optical_depth_buffer > 1.0){ cout<<"Optically [thick] buffer : " << ' ' << "optical depth = " << ' '<0); - - + + //summary cout<<"Pc [dyne/cm^{2}] = "<< ' ' << Pc << '\n'; cout<<"Tc [K] = "<< ' ' << Tc << '\n'; @@ -255,13 +255,13 @@ int main(){ cout<<"optical depth (radiative+ convective) =" <<' ' << optical_depth_atm << '\n'; data_output.close(); return 0; - - - + + + } - - - - + + + + diff --git a/Exec/science/planet/dataset_lineplot.py b/Exec/science/planet/dataset_lineplot.py index 0466148afd..c8fba41114 100644 --- a/Exec/science/planet/dataset_lineplot.py +++ b/Exec/science/planet/dataset_lineplot.py @@ -50,10 +50,10 @@ print('Adding lines at t='+filename_time+'s for $\rho$-height plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -63,13 +63,13 @@ my_ray = ds.ortho_ray(1,(0,0)) srt=np.argsort(my_ray['y']) x_coord=np.array(my_ray['y'][srt])/1.e5 - - - + + + temp=np.array(my_ray['Temp'][srt]) ent=np.array(my_ray['entropy'][srt]) dens=np.array(my_ray['density'][srt]) - + my_ray = ds.ortho_ray(1,(0,0)) plt.semilogy(x_coord,dens,label='t='+filename_time+'s') plt.legend() @@ -92,12 +92,12 @@ ds=load(i) time=float(ds.current_time) filename_time=str(int(time)) - - + + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) srt=np.argsort(my_ray['x']) @@ -113,7 +113,7 @@ average_T=(average_T*float(j)+temp)/float(j+1) average_P=(average_P*float(j)+press)/float(j+1) - + if j==0 : temp0=np.array(my_ray['Temp'][srt]) ent0=np.array(my_ray['entropy'][srt]) @@ -121,7 +121,7 @@ density0=np.array(my_ray['density'][srt]) location1=np.amin(pressure0)/1e10 location2=np.amax(pressure0) - + if time>=old_time+time_difference_T_P and time vs

(average up to t)') plt.savefig("figure_T_P_average.png") - + j=j+1 print("T-P plot average made") plt.close() @@ -146,13 +146,13 @@ ds=load(i) time=float(ds.current_time) filename_time=str(int(time)) - - - + + + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) srt=np.argsort(my_ray['x']) @@ -167,8 +167,8 @@ press=np.array(my_ray['pressure'][srt])/1.e6 average_T=(average_T*float(j)+temp)/float(j+1) average_P=(average_P*float(j)+press)/float(j+1) - - + + if j==0 : temp0=np.array(my_ray['Temp'][srt]) ent0=np.array(my_ray['entropy'][srt]) @@ -194,7 +194,7 @@ #plt.yscale('log') plt.title('<$\Delta$ T> vs

(average up to t)') plt.savefig("figure_T_P_diff_average.png") - + j=j+1 print("T-P difference average plot made") plt.close() @@ -211,8 +211,8 @@ print('Adding lines at t='+filename_time+'s for P-height plot') kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) srt=np.argsort(my_ray['x']) @@ -243,10 +243,10 @@ # plt.xscale('linear') plt.title('P vs height') plt.yscale('log') - + plt.savefig("figure_x_P.png") - - + + j=j+1 @@ -264,11 +264,11 @@ print('Adding lines at t='+filename_time+'s for T-height plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -291,8 +291,8 @@ #plt.legend(loc=3) #plt.yscale('linear') plt.savefig("figure_x_T.png") - - + + j=j+1 print("T plot made") @@ -309,11 +309,11 @@ print('Adding lines at t='+filename_time+'s for $\kappa$-height plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -336,8 +336,8 @@ #plt.legend(loc=3) #plt.yscale('linear') plt.savefig("figure_x_opacity.png") - - + + j=j+1 print("opacity plot made") @@ -356,8 +356,8 @@ print('Adding lines at t='+filename_time+'s for $\mathca{M}$-height plot') kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) srt=np.argsort(my_ray['x']) @@ -371,7 +371,7 @@ dens=np.array(my_ray['density'][srt]) press=np.array(my_ray['pressure'][srt])/1.e6 Mach_number=np.array(my_ray['MachNumber'][srt]) - + if j==0 : temp0=np.array(my_ray['Temp'][srt]) ent0=np.array(my_ray['entropy'][srt]) @@ -379,10 +379,10 @@ density0=np.array(my_ray['density'][srt]) location1=np.amin(pressure0)/1e10 location2=np.amax(pressure0) - + plt.plot(press,Mach_number,label='t='+filename_time+'s') plt.legend() - + plt.ylabel(r'Mach number') plt.xlabel(r'$P\/[\mathrm{bar}]$') #plt.ylim(location1,location2) @@ -414,11 +414,11 @@ print('Adding lines at t='+filename_time+'s for $\kappa$-T plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -444,8 +444,8 @@ plt.ylim(-100,1000) plt.title('Opacity $\kappa $vs T') plt.savefig("figure_T_opacity.png") - - + + j=j+1 print("opacity-T plot made") @@ -464,11 +464,11 @@ print('Adding lines at t='+filename_time+'s for entropy-height plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -482,7 +482,7 @@ ent=np.array(my_ray['entropy'][srt]) dens=np.array(my_ray['density'][srt]) press=np.array(my_ray['pressure'][srt])/1.e6 - + plt.semilogy(x_coord,ent,label='t='+filename_time+'s') plt.legend() plt.ylabel(r'$\mathrm{Entropy}$') @@ -491,8 +491,8 @@ #plt.yscale('linear') plt.title('Entropy $vs height') plt.savefig("figure_x_entropy.png") - - + + j=j+1 print("entropy plot made") @@ -510,11 +510,11 @@ print('Adding lines at t='+filename_time+'s for $U$-height plot') location1=ds.find_max('Temp') location2=ds.find_min('Temp') - + kappa=0.18*1e-9 SB_constant=5.6704*1e-5 - - + + ad=ds.all_data() if Dimension==1: my_ray = ds.ortho_ray(0,(0,0)) @@ -538,8 +538,8 @@ plt.figtext(0.5,0.3,'$\Delta t_{\mathrm{damp}}=7000$s', fontsize=20) plt.title('Radiation energy density $U$ vs height') plt.savefig("figure_x_radiation.png") - - + + j=j+1 print("radiation plot made") @@ -559,12 +559,12 @@ if time>=old_time+time_difference_T_P and time=old_time+time_difference_T_P and time 0.0_rt) { diff --git a/Exec/unit_tests/diffusion_test/Prob.cpp b/Exec/unit_tests/diffusion_test/Prob.cpp index 09822b72b1..93e797fbfc 100644 --- a/Exec/unit_tests/diffusion_test/Prob.cpp +++ b/Exec/unit_tests/diffusion_test/Prob.cpp @@ -53,7 +53,7 @@ void Castro::problem_post_simulation(Vector >& amr_lev MultiFab::Subtract(*analytic, S, UTEMP, 0, 1, 0); err = std::max(err, analytic->norm0()); - + } diff --git a/Exec/unit_tests/diffusion_test/README.md b/Exec/unit_tests/diffusion_test/README.md index c5e7e084d4..7c8fdf0dd4 100644 --- a/Exec/unit_tests/diffusion_test/README.md +++ b/Exec/unit_tests/diffusion_test/README.md @@ -138,14 +138,14 @@ Warning: BoxArray lengths are not the same at level 0 \begin{tabular}{|cccc|} \hline Variable & $e_{4h \rightarrow 2h}$ & Order & $e_{2h \rightarrow h}$\\ \hline -density& 0.000000e+00 & ------------ &0.000000e+00 \\ -xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ -zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -rho_E& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ -rho_e& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ -Temp& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ -rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ +density& 0.000000e+00 & ------------ &0.000000e+00 \\ +xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ +zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +rho_E& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ +rho_e& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ +Temp& 3.479414e-04 & 2.012958966 & 8.620750e-05 \\ +rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ ``` (some bits were edited out) @@ -191,15 +191,15 @@ Warning: BoxArray lengths are not the same at level 0 \begin{tabular}{|cccc|} \hline Variable & $e_{4h \rightarrow 2h}$ & Order & $e_{2h \rightarrow h}$\\ \hline -density& 0.000000e+00 & ------------ &0.000000e+00 \\ -xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ -zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -rho_E& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ -rho_e& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ -Temp& 1.063477e-05 & 3.952987539 & 6.866892e-07 \\ -rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ -pressure& 7.410837e-06 & 3.948910124 & 4.798736e-07 \\ +density& 0.000000e+00 & ------------ &0.000000e+00 \\ +xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ +zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +rho_E& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ +rho_e& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ +Temp& 1.063477e-05 & 3.952987539 & 6.866892e-07 \\ +rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ +pressure& 7.410837e-06 & 3.948910124 & 4.798736e-07 \\ ``` e.g. we see fourth-order convergence in the temperature @@ -242,13 +242,13 @@ Warning: BoxArray lengths are not the same at level 0 \begin{tabular}{|cccc|} \hline Variable & $e_{4h \rightarrow 2h}$ & Order & $e_{2h \rightarrow h}$\\ \hline -density& 0.000000e+00 & ------------ &0.000000e+00 \\ -xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ -zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -rho_E& 1.902161e-06 & 3.957610923 & 1.224299e-07 \\ -rho_e& 1.902161e-06 & 3.957610923 & 1.224299e-07 \\ -Temp& 1.770452e-06 & 3.966033724 & 1.132894e-07 \\ +density& 0.000000e+00 & ------------ &0.000000e+00 \\ +xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ +zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +rho_E& 1.902161e-06 & 3.957610923 & 1.224299e-07 \\ +rho_e& 1.902161e-06 & 3.957610923 & 1.224299e-07 \\ +Temp& 1.770452e-06 & 3.966033724 & 1.132894e-07 \\ ``` e.g. we see fourth-order convergence in the temperature diff --git a/Exec/unit_tests/diffusion_test/convergence_powerlaw_sdc4.txt b/Exec/unit_tests/diffusion_test/convergence_powerlaw_sdc4.txt index 34bcc868c6..7fd0326b3a 100644 --- a/Exec/unit_tests/diffusion_test/convergence_powerlaw_sdc4.txt +++ b/Exec/unit_tests/diffusion_test/convergence_powerlaw_sdc4.txt @@ -27,16 +27,16 @@ Warning: BoxArray lengths are not the same at level 0 \begin{center} \begin{tabular}{|cccc|} \hline Variable & $e_{4h \rightarrow 2h}$ & Order & $e_{2h \rightarrow h}$\\ -\hline -density& 0.000000e+00 & ------------ &0.000000e+00 \\ -xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ -zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ -rho_E& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ -rho_e& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ -Temp& 1.063477e-05 & 3.952987539 & 6.866892e-07 \\ -rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ -pressure& 7.410837e-06 & 3.948910124 & 4.798736e-07 \\ +\hline +density& 0.000000e+00 & ------------ &0.000000e+00 \\ +xmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +ymom& 0.000000e+00 & ------------ &0.000000e+00 \\ +zmom& 0.000000e+00 & ------------ &0.000000e+00 \\ +rho_E& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ +rho_e& 1.111626e-05 & 3.948910124 & 7.198104e-07 \\ +Temp& 1.063477e-05 & 3.952987539 & 6.866892e-07 \\ +rho_X& 0.000000e+00 & ------------ &0.000000e+00 \\ +pressure& 7.410837e-06 & 3.948910124 & 4.798736e-07 \\ e.g. we see fourth-order convergence in the temperature diff --git a/Exec/unit_tests/diffusion_test/problem_initialize_state_data.H b/Exec/unit_tests/diffusion_test/problem_initialize_state_data.H index 9d65f73d04..3e8c9c3a83 100644 --- a/Exec/unit_tests/diffusion_test/problem_initialize_state_data.H +++ b/Exec/unit_tests/diffusion_test/problem_initialize_state_data.H @@ -14,7 +14,7 @@ void problem_initialize_state_data (int i, int j, int k, const Real* dx = geomdata.CellSize(); const Real* problo = geomdata.ProbLo(); - int coord_type = geomdata.Coord(); + int coord_type = geomdata.Coord(); Real r[3] = {0.0_rt}; diff --git a/Source/diffusion/Diffusion.H b/Source/diffusion/Diffusion.H index e257b9f955..aa3a875669 100644 --- a/Source/diffusion/Diffusion.H +++ b/Source/diffusion/Diffusion.H @@ -7,7 +7,7 @@ #include /// -/// @class Diffusion +/// @class Diffusion /// @brief /// class Diffusion { diff --git a/Source/driver/Castro.H b/Source/driver/Castro.H index 11b028f5f9..cbd002f889 100644 --- a/Source/driver/Castro.H +++ b/Source/driver/Castro.H @@ -226,7 +226,7 @@ public: void writeSmallPlotFile (const std::string& dir, ostream& os, amrex::VisMF::How how) override; - + /// /// @param dir directory to write to /// @param os output stream @@ -249,7 +249,7 @@ public: /// -/// Dump build info +/// Dump build info /// static void writeBuildInfo (); @@ -814,7 +814,7 @@ public: #ifdef MHD /// /// Add magnetic contribution to energy density -/// @param Bx magnetic field in x +/// @param Bx magnetic field in x /// @param By magnetic field in y /// @param Bz magnetic field in z /// @param state the state to operate on @@ -827,7 +827,7 @@ public: /// /// Check if divergence of B is zero at initialization -/// @param Bx magnetic field in x +/// @param Bx magnetic field in x /// @param By magnetic field in y /// @param Bz magnetic field in z /// @param state the state to operate on @@ -1003,7 +1003,7 @@ public: // Hydrodynamics #include -// SDC +// SDC #ifdef TRUE_SDC #include #endif @@ -1156,7 +1156,7 @@ public: /// bool oversubscribing() { // NOLINT(readability-convert-member-functions-to-static) #ifdef AMREX_USE_GPU - return (amrex::MultiFab::queryMemUsage("AmrLevel_Level_" + std::to_string(level)) >= + return (amrex::MultiFab::queryMemUsage("AmrLevel_Level_" + std::to_string(level)) >= static_cast(amrex::Gpu::Device::totalGlobalMem())); #else return false; diff --git a/Source/driver/Castro.cpp b/Source/driver/Castro.cpp index a0217208cf..702385e75c 100644 --- a/Source/driver/Castro.cpp +++ b/Source/driver/Castro.cpp @@ -1126,11 +1126,11 @@ Castro::initData () #ifdef MHD - //correct energy density with the magnetic field contribution + //correct energy density with the magnetic field contribution add_magnetic_e(Bx_new, By_new, Bz_new, S_new); - + //check divB - check_div_B(Bx_new, By_new, Bz_new, S_new); + check_div_B(Bx_new, By_new, Bz_new, S_new); #endif @@ -1218,8 +1218,8 @@ Castro::initData () } if (std::abs(S_arr(i,j,k,URHO) - spec_sum) > 1.e-8_rt * S_arr(i,j,k,URHO)) { #ifndef AMREX_USE_GPU - std::cout << "Sum of (rho X)_i vs rho at (i,j,k): " - << i << " " << j << " " << k << " " + std::cout << "Sum of (rho X)_i vs rho at (i,j,k): " + << i << " " << j << " " << k << " " << spec_sum << " " << S_arr(i,j,k,URHO) << std::endl; #endif amrex::Error("Error: failed check of initial species summing to 1"); @@ -3786,11 +3786,11 @@ Castro::reset_internal_energy( #ifdef MHD void Castro::add_magnetic_e( MultiFab& Bx, - MultiFab& By, + MultiFab& By, MultiFab& Bz, MultiFab& State) { - + #ifdef AMREX_USE_OMP #pragma omp parallel #endif @@ -3824,18 +3824,18 @@ Castro::add_magnetic_e( MultiFab& Bx, void Castro::check_div_B( MultiFab& Bx, - MultiFab& By, + MultiFab& By, MultiFab& Bz, MultiFab& State) { - + ReduceOps reduce_op; ReduceData reduce_data(reduce_op); using ReduceTuple = typename decltype(reduce_data)::Type; - + #ifdef AMREX_USE_OMP #pragma omp parallel #endif @@ -3851,28 +3851,28 @@ Castro::check_div_B( MultiFab& Bx, reduce_op.eval(box, reduce_data, [=] AMREX_GPU_DEVICE (int i, int j, int k) -> ReduceTuple { - + Real divB = (Bx_arr(i+1,j,k) - Bx_arr(i,j,k))/dx[0] + - (By_arr(i,j+1,k) - By_arr(i,j,k))/dx[1] + + (By_arr(i,j+1,k) - By_arr(i,j,k))/dx[1] + (Bz_arr(i,j,k+1) - Bz_arr(i,j,k))/dx[2]; - + Real bx_cell_c = 0.5_rt * (Bx_arr(i,j,k) + Bx_arr(i+1,j,k)); Real by_cell_c = 0.5_rt * (By_arr(i,j,k) + By_arr(i,j+1,k)); Real bz_cell_c = 0.5_rt * (Bz_arr(i,j,k) + Bz_arr(i,j,k+1)); - Real magB = std::sqrt(bx_cell_c * bx_cell_c + + Real magB = std::sqrt(bx_cell_c * bx_cell_c + by_cell_c * by_cell_c + bz_cell_c * bz_cell_c); - - + + int fail_divB = 0; if (std::abs(divB) > 1.0e-10*magB){ - fail_divB = 1; + fail_divB = 1; } - - return {fail_divB}; + + return {fail_divB}; }); } @@ -3881,8 +3881,8 @@ Castro::check_div_B( MultiFab& Bx, int init_fail_divB = amrex::get<0>(hv); if (init_fail_divB != 0) { - amrex::Error("Error: initial data has divergence of B not zero"); - } + amrex::Error("Error: initial data has divergence of B not zero"); + } } @@ -3960,7 +3960,7 @@ Castro::computeTemp( enforce_min_density(Stemp, Stemp.nGrow()); reset_internal_energy(Stemp, Stemp.nGrow()); } else { -#endif +#endif reset_internal_energy( #ifdef MHD Bx, By, Bz, diff --git a/Source/driver/Castro_advance.cpp b/Source/driver/Castro_advance.cpp index 405eaafe87..6f9f0b9d07 100644 --- a/Source/driver/Castro_advance.cpp +++ b/Source/driver/Castro_advance.cpp @@ -68,7 +68,7 @@ Castro::advance (Real time, dt_new = std::min(dt_new, subcycle_advance_ctu(time, dt, amr_iteration, amr_ncycle)); -#ifndef MHD +#ifndef MHD #ifndef AMREX_USE_GPU #ifdef TRUE_SDC } else if (time_integration_method == SpectralDeferredCorrections) { @@ -80,7 +80,7 @@ Castro::advance (Real time, #endif // TRUE_SDC #endif // AMREX_USE_GPU -#endif //MHD +#endif //MHD } // If the user requests, indicate that we want a regrid at the end of the step. @@ -158,7 +158,7 @@ Castro::initialize_do_advance (Real time, Real dt) FillPatch(*this, Bx_old_tmp, NUM_GROW, time, Mag_Type_x, 0, 1); FillPatch(*this, By_old_tmp, NUM_GROW, time, Mag_Type_y, 0, 1); FillPatch(*this, Bz_old_tmp, NUM_GROW, time, Mag_Type_z, 0, 1); -#endif +#endif // for the CTU unsplit method, we always start with the old // state note: although clean_state has already been done on // the old state in initialize_advance, we still need to do @@ -175,7 +175,7 @@ Castro::initialize_do_advance (Real time, Real dt) } else if (time_integration_method == SpectralDeferredCorrections) { - // we'll handle the filling inside of do_advance_sdc + // we'll handle the filling inside of do_advance_sdc Sborder.define(grids, dmap, NUM_STATE, NUM_GROW, MFInfo().SetTag("Sborder")); } else { @@ -467,7 +467,7 @@ Castro::initialize_advance(Real time, Real dt, int amr_iteration) get_old_data(Mag_Type_x), get_old_data(Mag_Type_y), get_old_data(Mag_Type_z), -#endif +#endif S_old, time, S_old.nGrow()); diff --git a/Source/driver/Castro_io.cpp b/Source/driver/Castro_io.cpp index ea0336669e..b002bf210e 100644 --- a/Source/driver/Castro_io.cpp +++ b/Source/driver/Castro_io.cpp @@ -80,7 +80,7 @@ Castro::restart (Amr& papa, if (CastroHeaderFile.good()) { char foo[256]; // first line: Checkpoint version: ? - CastroHeaderFile.getline(foo, 256, ':'); + CastroHeaderFile.getline(foo, 256, ':'); CastroHeaderFile >> input_version; CastroHeaderFile.close(); } else { @@ -929,7 +929,7 @@ Castro::plotFileOutput(const std::string& dir, for (const auto & dd : dlist) { - if ((parent->isDerivePlotVar(dd.name()) && is_small == 0) || + if ((parent->isDerivePlotVar(dd.name()) && is_small == 0) || (parent->isDeriveSmallPlotVar(dd.name()) && is_small == 1)) { #ifdef AMREX_PARTICLES @@ -1139,7 +1139,7 @@ Castro::plotFileOutput(const std::string& dir, { for (const auto & dd : dlist) { - if ((parent->isDerivePlotVar(dd.name()) && is_small == 0) || + if ((parent->isDerivePlotVar(dd.name()) && is_small == 0) || (parent->isDeriveSmallPlotVar(dd.name()) && is_small == 1)) { auto derive_dat = derive(dd.variableName(0), cur_time, nGrow); diff --git a/Source/driver/Castro_setup.cpp b/Source/driver/Castro_setup.cpp index 2e3a3c1bfc..c4a5327e64 100644 --- a/Source/driver/Castro_setup.cpp +++ b/Source/driver/Castro_setup.cpp @@ -45,7 +45,7 @@ static int tang_vel_bc[] = }; #ifdef MHD -static int mag_field_bc[] = +static int mag_field_bc[] = { amrex::BCType::int_dir, amrex::BCType::ext_dir, amrex::BCType::foextrap, amrex::BCType::reflect_even, amrex::BCType::foextrap, amrex::BCType::hoextrap }; @@ -356,7 +356,7 @@ Castro::variableSetUp () store_in_checkpoint = true; IndexType xface(IntVect{AMREX_D_DECL(1,0,0)}); desc_lst.addDescriptor(Mag_Type_x, xface, - StateDescriptor::Point, 0, 1, + StateDescriptor::Point, 0, 1, interp, state_data_extrap, store_in_checkpoint); IndexType yface(IntVect{AMREX_D_DECL(0,1,0)}); @@ -554,7 +554,7 @@ Castro::variableSetUp () bcs[UMUN] = bc; name[UMUN] = "mu_n"; #endif - + BndryFunc stateBndryFunc(ca_statefill); stateBndryFunc.setRunOnGPU(true); @@ -641,7 +641,7 @@ Castro::variableSetUp () } #endif // names for the burn_weights that are manually added to the plotfile - + if (store_burn_weights) { #ifdef STRANG @@ -994,9 +994,9 @@ Castro::variableSetUp () derive_lst.add("Div_B", IndexType::TheCellType(), 1, ca_derdivb, the_same_box); derive_lst.addComponent("Div_B", desc_lst, Mag_Type_x, 0, 1); derive_lst.addComponent("Div_B", desc_lst, Mag_Type_y, 0, 1); - derive_lst.addComponent("Div_B", desc_lst, Mag_Type_z, 0, 1); - -#endif + derive_lst.addComponent("Div_B", desc_lst, Mag_Type_z, 0, 1); + +#endif #if NAUX_NET > 0 diff --git a/Source/driver/Derive.H b/Source/driver/Derive.H index 1fdf32f1fd..7dd302da16 100644 --- a/Source/driver/Derive.H +++ b/Source/driver/Derive.H @@ -198,7 +198,7 @@ extern "C" #ifdef __cplusplus } #endif - + /* problem-specific includes */ #include diff --git a/Source/driver/runtime_parameters.H b/Source/driver/runtime_parameters.H index 8fe188fa49..0619070811 100644 --- a/Source/driver/runtime_parameters.H +++ b/Source/driver/runtime_parameters.H @@ -104,7 +104,7 @@ validate_runparams() // "castro" if (ParmParse::hasUnusedInputs(nm)) { amrex::Print() << "Warning: the following " + nm + ".* parameters are ignored\n"; - auto unused = ParmParse::getUnusedInputs(nm); + auto unused = ParmParse::getUnusedInputs(nm); for (const auto& p: unused) { amrex::Print() << p << "\n"; } diff --git a/Source/driver/sum_utils.cpp b/Source/driver/sum_utils.cpp index 438c744f0f..6423b50b70 100644 --- a/Source/driver/sum_utils.cpp +++ b/Source/driver/sum_utils.cpp @@ -39,7 +39,7 @@ Castro::volWgtSum (const MultiFab& mf, int comp, bool local, bool finemask) #ifdef AMREX_USE_OMP #pragma omp parallel -#endif +#endif for (MFIter mfi(mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { auto const& fab = mf[mfi].array(comp); @@ -102,13 +102,13 @@ Castro::locWgtSum (const MultiFab& mf, int comp, int idir, bool local) #ifdef AMREX_USE_OMP #pragma omp parallel -#endif +#endif for (MFIter mfi(mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { auto const& fab = mf[mfi].array(comp); auto const& vol = volume.array(mfi); auto const& mask = mask_available ? mask_mf.array(mfi) : Array4{}; - + const Box& box = mfi.tilebox(); // @@ -196,14 +196,14 @@ Castro::volProductSum (const MultiFab& mf1, #ifdef AMREX_USE_OMP #pragma omp parallel -#endif +#endif for (MFIter mfi(mf1, TilingIfNotGPU()); mfi.isValid(); ++mfi) { auto const& fab1 = mf1[mfi].array(comp1); auto const& fab2 = mf2[mfi].array(comp2); auto const& vol = volume.array(mfi); auto const& mask = mask_available ? mask_mf.array(mfi) : Array4{}; - + const Box& box = mfi.tilebox(); reduce_op.eval(box, reduce_data, @@ -251,12 +251,12 @@ Castro::locSquaredSum (const std::string& name, #ifdef AMREX_USE_OMP #pragma omp parallel -#endif +#endif for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi) { auto const& fab = (*mf).array(mfi); auto const& mask = mask_available ? mask_mf.array(mfi) : Array4{}; - + const Box& box = mfi.tilebox(); reduce_op.eval(box, reduce_data, diff --git a/Source/gravity/Castro_gravity.cpp b/Source/gravity/Castro_gravity.cpp index 7b300310ec..ed8a2406e0 100644 --- a/Source/gravity/Castro_gravity.cpp +++ b/Source/gravity/Castro_gravity.cpp @@ -113,7 +113,7 @@ Castro::construct_old_gravity (Real time) gravity->test_level_grad_phi_prev(level); } - + } // Define the old gravity vector. diff --git a/Source/gravity/Gravity.cpp b/Source/gravity/Gravity.cpp index 35fab221d3..b2f0f90d4e 100644 --- a/Source/gravity/Gravity.cpp +++ b/Source/gravity/Gravity.cpp @@ -396,7 +396,7 @@ void Gravity::swapTimeLevels (int level) { BL_PROFILE("Gravity::swapTimeLevels()"); - + if (gravity::gravity_type == "PoissonGrav") { for (int n=0; n < AMREX_SPACEDIM; n++) { std::swap(grad_phi_prev[level][n], grad_phi_curr[level][n]); @@ -663,7 +663,7 @@ Gravity::GetCrsePhi(int level, Real time ) { BL_PROFILE("Gravity::GetCrsePhi()"); - + BL_ASSERT(level!=0); phi_crse.clear(); @@ -1328,7 +1328,7 @@ void Gravity::interpolate_monopole_grav(int level, RealVector& radial_grav, MultiFab& grav_vector) { BL_PROFILE("Gravity::interpolate_monopole_grav()"); - + int n1d = static_cast(radial_grav.size()); const Geometry& geom = parent->Geom(level); @@ -1647,7 +1647,7 @@ Gravity::init_multipole_grav() for (int n = 0; n < 3; ++n) { multipole::doSymmetricAddLo(n) = false; multipole::doSymmetricAddHi(n) = false; - + multipole::doReflectionLo(n) = false; multipole::doReflectionHi(n) = false; } @@ -1844,11 +1844,11 @@ Gravity::fill_multipole_BCs(int crse_level, int fine_level, const Vector(&(parent->getLevel(lev+1))); - if (castro_level != nullptr) { - const MultiFab& mask = castro_level->build_fine_mask(); - MultiFab::Multiply(source, mask, 0, 0, 1, 0); - } else { + auto *castro_level = dynamic_cast(&(parent->getLevel(lev+1))); + if (castro_level != nullptr) { + const MultiFab& mask = castro_level->build_fine_mask(); + MultiFab::Multiply(source, mask, 0, 0, 1, 0); + } else { amrex::Abort("unable to access mask"); } } @@ -2221,7 +2221,7 @@ Gravity::fill_multipole_BCs(int crse_level, int fine_level, const Vector domhi[2]) { @@ -2341,7 +2341,7 @@ void Gravity::fill_direct_sum_BCs(int crse_level, int fine_level, const Vector& Rhs, MultiFab& phi) { BL_PROFILE("Gravity::fill_direct_sum_BCs()"); - + BL_ASSERT(crse_level==0); const Real strt = ParallelDescriptor::second(); @@ -2973,9 +2973,9 @@ Gravity::set_mass_offset (Real time, bool multi_level) { for (int lev = 0; lev <= parent->finestLevel(); lev++) { auto* cs = dynamic_cast(&parent->getLevel(lev)); - if (cs != nullptr) { - mass_offset += cs->volWgtSum("density", time); - } else { + if (cs != nullptr) { + mass_offset += cs->volWgtSum("density", time); + } else { amrex::Abort("unable to access volWgtSum"); } } @@ -3009,7 +3009,7 @@ void Gravity::add_pointmass_to_gravity (int level, MultiFab& phi, MultiFab& grav_vector) { BL_PROFILE("Gravity::add_pointmass_to_gravity()"); - + const auto dx = parent->Geom(level).CellSizeArray(); const auto problo = parent->Geom(level).ProbLoArray(); @@ -3048,11 +3048,11 @@ Gravity::add_pointmass_to_gravity (int level, MultiFab& phi, MultiFab& grav_vect if(AMREX_SPACEDIM == 1) { x += star_radius; - } + } else if(AMREX_SPACEDIM ==2) { y += star_radius; - } + } else if(AMREX_SPACEDIM == 3) { z += star_radius; @@ -3141,12 +3141,12 @@ Gravity::make_radial_gravity(int level, Real time, RealVector& radial_grav) if (lev < level) { auto* fine_level = dynamic_cast(&(parent->getLevel(lev+1))); - if (fine_level != nullptr) { - const MultiFab& mask = fine_level->build_fine_mask(); - for (int n = 0; n < NUM_STATE; ++n) { - MultiFab::Multiply(S, mask, 0, n, 1, 0); - } - } else { + if (fine_level != nullptr) { + const MultiFab& mask = fine_level->build_fine_mask(); + for (int n = 0; n < NUM_STATE; ++n) { + MultiFab::Multiply(S, mask, 0, n, 1, 0); + } + } else { amrex::Abort("unable to create mask"); } } diff --git a/Source/gravity/binary.H b/Source/gravity/binary.H index 35a8b9ed5d..684d875139 100644 --- a/Source/gravity/binary.H +++ b/Source/gravity/binary.H @@ -155,7 +155,7 @@ void get_lagrange_points (Real mass_1, Real mass_2, const Real* com_1, const Rea r1 = -std::sqrt(com_1[0] * com_1[0] + com_1[1] * com_1[1] + com_1[2] * com_1[2]); r2 = std::sqrt(com_2[0] * com_2[0] + com_2[1] * com_2[1] + com_2[2] * com_2[2]); - // Do a root-find over the quintic equation for L1. + // Do a root-find over the quintic equation for L1. r = 0.0_rt; diff --git a/Source/hydro/Castro_ctu_rad.cpp b/Source/hydro/Castro_ctu_rad.cpp index 464f52226a..626eaab580 100644 --- a/Source/hydro/Castro_ctu_rad.cpp +++ b/Source/hydro/Castro_ctu_rad.cpp @@ -53,7 +53,7 @@ Castro::ctu_rad_consup(const Box& bx, } - // radiation energy update. + // radiation energy update. amrex::ParallelFor(bx, NGROUPS, [=] AMREX_GPU_DEVICE (int i, int j, int k, int g) noexcept @@ -298,7 +298,7 @@ Castro::ctu_rad_consup(const Box& bx, if (NGROUPS > 1) { Real ustar[NGROUPS]; - for (int g = 0; g < NGROUPS; g++) { + for (int g = 0; g < NGROUPS; g++) { ustar[g] = Erout(i,j,k,g) / Erscale[g]; } diff --git a/Source/hydro/Castro_hydro.cpp b/Source/hydro/Castro_hydro.cpp index e0011c6152..0dedbc17aa 100644 --- a/Source/hydro/Castro_hydro.cpp +++ b/Source/hydro/Castro_hydro.cpp @@ -12,7 +12,7 @@ Castro::cons_to_prim(const Real time) { BL_PROFILE("Castro::cons_to_prim()"); - + #ifdef RADIATION AmrLevel::FillPatch(*this, Erborder, NUM_GROW, time, Rad_Type, 0, Radiation::nGroups); @@ -120,7 +120,7 @@ Castro::cons_to_prim_fourth(const Real time) { BL_PROFILE("Castro::cons_to_prim_fourth()"); - + // convert the conservative state cell averages to primitive cell // averages with 4th order accuracy @@ -170,7 +170,7 @@ Castro::cons_to_prim_fourth(const Real time) auto qaux_bar_arr = qaux_bar.array(mfi); ctoprim(qbx, - time, + time, Sborder_arr, q_bar_arr, qaux_bar_arr); diff --git a/Source/hydro/outline.txt b/Source/hydro/outline.txt index cc972524a0..2a7f80919e 100644 --- a/Source/hydro/outline.txt +++ b/Source/hydro/outline.txt @@ -23,7 +23,7 @@ * compute face-centered and face-average fluxes c. separate MFIter: - + * compute final fluxes @@ -37,7 +37,7 @@ Extra MFs: Also needed: - -- for the Riemann solver, we return the interface state of only a subset + -- for the Riemann solver, we return the interface state of only a subset of variable NGDNV, not all NQ -- this means that we will need a separate Riemann solver here to get all interface states diff --git a/Source/hydro/riemann.cpp b/Source/hydro/riemann.cpp index 96d2c2e6f0..db8641a52b 100644 --- a/Source/hydro/riemann.cpp +++ b/Source/hydro/riemann.cpp @@ -144,7 +144,7 @@ Castro::cmpflx_plus_godunov(const Box& bx, if (idir == 0) { is_shock = static_cast(shk(i-1,j,k) + shk(i,j,k)); - } else if (idir == 1) { + } else if (idir == 1) { is_shock = static_cast(shk(i,j-1,k) + shk(i,j,k)); } else { is_shock = static_cast(shk(i,j,k-1) + shk(i,j,k)); @@ -157,7 +157,7 @@ Castro::cmpflx_plus_godunov(const Box& bx, if (idir == 0) { cl = qaux_arr(i-1,j,k,QC); cr = qaux_arr(i,j,k,QC); - } else if (idir == 1) { + } else if (idir == 1) { cl = qaux_arr(i,j-1,k,QC); cr = qaux_arr(i,j,k,QC); } else { diff --git a/Source/mhd/electric.cpp b/Source/mhd/electric.cpp index 7ddd66d471..e9426d0530 100644 --- a/Source/mhd/electric.cpp +++ b/Source/mhd/electric.cpp @@ -24,7 +24,7 @@ Castro::electric_edge_x(const Box& bx, // dEx/dy (Eq. 49), located at (i, j-3/4, k-1/2) // first compute dEx/dy_{i,j-3/4,k-1} using MM Eq. 49 - // note that the face value Ex_{i,j-1/2,k-1} = -F_{i,j-1/2,k-1}(Bz) + // note that the face value Ex_{i,j-1/2,k-1} = -F_{i,j-1/2,k-1}(Bz) // via Faraday's law (MM Eq. 15) for (int n = 0; n < NQ; n++) { diff --git a/Source/mhd/hlld.cpp b/Source/mhd/hlld.cpp index 4725358e6c..3f736a2717 100644 --- a/Source/mhd/hlld.cpp +++ b/Source/mhd/hlld.cpp @@ -239,7 +239,7 @@ Castro::hlld(const Box& bx, } - + UsL(UMX) = UsL(UMX) * UsL(URHO); UsL(UMY) = UsL(UMY) * UsL(URHO); UsL(UMZ) = UsL(UMZ) * UsL(URHO); @@ -259,11 +259,11 @@ Castro::hlld(const Box& bx, // Second Perpendicular dir (Eq. 47) Real denom_bpL = qL(QRHO) * (sL - qL(QVELN)) * (sL - sM) - qL(QMAGN) * qL(QMAGN); - Real denom_bpR = qR(QRHO) * (sR - qR(QVELN)) * (sR - sM) - qR(QMAGN) * qR(QMAGN); + Real denom_bpR = qR(QRHO) * (sR - qR(QVELN)) * (sR - sM) - qR(QMAGN) * qR(QMAGN); if (std::abs(denom_bpL) < 1.e-14_rt) { - UsL(UMAGP1) = 0.0_rt; - UsL(UMAGP2) = 0.0_rt; + UsL(UMAGP1) = 0.0_rt; + UsL(UMAGP2) = 0.0_rt; } else { UsL(UMAGP1) = qL(QMAGP1) * (qL(QRHO) * (sL - qL(QVELN)) * (sL - qL(QVELN)) - qL(QMAGN) * qL(QMAGN)) / @@ -275,7 +275,7 @@ Castro::hlld(const Box& bx, if (std::abs(denom_bpR) < 1.e-14_rt) { UsR(UMAGP1) = 0.0_rt; - UsR(UMAGP2) = 0.0_rt; + UsR(UMAGP2) = 0.0_rt; } else { UsR(UMAGP1) = qR(QMAGP1) * (qR(QRHO) * (sR - qR(QVELN)) * (sR - qR(QVELN)) - qR(QMAGN) * qR(QMAGN)) / @@ -285,7 +285,7 @@ Castro::hlld(const Box& bx, } - + // Energy, eq.(48) UsL(UEDEN) = (sL - qL(QVELN)) * uL(UEDEN) - ptL * qL(QVELN) + pst * sM + @@ -382,7 +382,7 @@ Castro::hlld(const Box& bx, ((UsL(UMX) * UsL(UMAGX) + UsL(UMY) * UsL(UMAGY) + UsL(UMZ) * UsL(UMAGZ)) / UsL(URHO) - (UssL(UMX) * UssL(UMAGX) + UssL(UMY) * UssL(UMAGY) + UssL(UMZ) * UssL(UMAGZ)) / UssL(URHO)) * std::copysign(1.0_rt, qL(QMAGN)); - UssR(UEDEN) = UsR(UEDEN) + std::sqrt(UsR(QRHO)) * + UssR(UEDEN) = UsR(UEDEN) + std::sqrt(UsR(QRHO)) * ((UsR(UMX) * UsR(UMAGX) + UsR(UMY) * UsR(UMAGY) + UsR(UMZ) * UsR(UMAGZ)) / UsR(URHO) - (UssR(UMX) * UssR(UMAGX) + UssR(UMY) * UssR(UMAGY) + UssR(UMZ) * UssR(UMAGZ)) / UssR(URHO)) * std::copysign(1.0_rt, qR(QMAGN)); diff --git a/Source/mhd/mhd_eigen.H b/Source/mhd/mhd_eigen.H index 8ac3a4ee71..3fe6cfd919 100644 --- a/Source/mhd/mhd_eigen.H +++ b/Source/mhd/mhd_eigen.H @@ -85,12 +85,12 @@ evecx(Array2D& leig, Real alf; Real als; - + if (std::abs(cfx-csx) <= 1e-14){ alf = 1.0_rt; als = 0.0_rt; } - + if (as - csx < 0.0) { alf = 0.0_rt; } else { @@ -102,8 +102,8 @@ evecx(Array2D& leig, } else { als = std::sqrt((cfx - as)/(cfx - csx)); } - - + + Real bety; Real betz; @@ -286,7 +286,7 @@ evecy(Array2D& leig, Real alf; Real als; - + if (std::abs(cfy-csy) <= 1e-14){ alf = 1.0_rt; als = 0.0_rt; diff --git a/Source/problems/Prob.cpp b/Source/problems/Prob.cpp index ed1e3f9001..8b0d929280 100644 --- a/Source/problems/Prob.cpp +++ b/Source/problems/Prob.cpp @@ -24,7 +24,7 @@ void Castro::problem_post_simulation(Vector >& amr_lev // Castro* castro = dynamic_cast(&amr_level[0]); // then you can get the data, e.g. for state data as: - + // MultiFab& S = castro->get_new_data(State_Type); // and if needed, the state descriptor: diff --git a/Source/radiation/Castro_radiation.cpp b/Source/radiation/Castro_radiation.cpp index 06e97094ea..5062815ba3 100644 --- a/Source/radiation/Castro_radiation.cpp +++ b/Source/radiation/Castro_radiation.cpp @@ -9,7 +9,7 @@ using std::string; using namespace amrex; void -Castro::final_radiation_call (MultiFab& S_new, int iteration, int ncycle) +Castro::final_radiation_call (MultiFab& S_new, int iteration, int ncycle) { if (do_radiation) { @@ -17,17 +17,17 @@ Castro::final_radiation_call (MultiFab& S_new, int iteration, int ncycle) Castro::computeTemp(S_new, state[State_Type].curTime(), S_new.nGrow()); return; } - + Castro::computeTemp(S_new, state[State_Type].curTime(), S_new.nGrow()); - if (Radiation::filter_prim_int > 0 && Radiation::filter_prim_T>0 + if (Radiation::filter_prim_int > 0 && Radiation::filter_prim_T>0 && iteration==ncycle) { int nstep = parent->levelSteps(0); if (nstep % Radiation::filter_prim_int == 0) { radiation->filter_prim(level, S_new); } } - + if (Radiation::SolverType == Radiation::MGFLDSolver) { if (! Radiation::rad_hydro_combined) { MultiFab& Er_old = get_old_data(Rad_Type); @@ -50,7 +50,7 @@ Castro::final_radiation_call (MultiFab& S_new, int iteration, int ncycle) MultiFab::Copy(Er_new, Er_old, 0, 0, Er_old.nComp(), 0); radiation->single_group_update(level, iteration, ncycle); } - + } } #endif diff --git a/Source/radiation/HABEC.H b/Source/radiation/HABEC.H index 2bd6e7aabb..9419776c0a 100644 --- a/Source/radiation/HABEC.H +++ b/Source/radiation/HABEC.H @@ -12,8 +12,8 @@ namespace HABEC { // habec is Hypre abec, where abec is the form of the linear equation // we are solving: - // - // alpha*phi - div(beta*grad phi) + div(\vec{c}*phi) + // + // alpha*phi - div(beta*grad phi) + div(\vec{c}*phi) AMREX_INLINE void hbflx (Array4 const flux, diff --git a/Source/radiation/HypreABec.cpp b/Source/radiation/HypreABec.cpp index d8ab7d5a4a..5a40d518cf 100644 --- a/Source/radiation/HypreABec.cpp +++ b/Source/radiation/HypreABec.cpp @@ -195,7 +195,7 @@ HypreABec::HypreABec(const BoxArray& grids, int ngrow=0; acoefs.reset(new MultiFab(grids, dmap, ncomp, ngrow)); acoefs->setVal(0.0); - + for (int i = 0; i < AMREX_SPACEDIM; i++) { BoxArray edge_boxes(grids); edge_boxes.surroundingNodes(i); @@ -226,7 +226,7 @@ void HypreABec::aCoefficients(const MultiFab &a) BL_ASSERT( a.boxArray() == acoefs->boxArray() ); MultiFab::Copy(*acoefs, a, 0, 0, 1, 0); } - + void HypreABec::bCoefficients(const MultiFab &b, int dir) { BL_ASSERT( b.ok() ); @@ -238,7 +238,7 @@ void HypreABec::SPalpha(const MultiFab& a) { BL_ASSERT( a.ok() ); if (SPa == 0) { - const BoxArray& grids = a.boxArray(); + const BoxArray& grids = a.boxArray(); const DistributionMapping& dmap = a.DistributionMap(); SPa.reset(new MultiFab(grids,dmap,1,0)); } @@ -249,9 +249,9 @@ void HypreABec::boundaryFlux(MultiFab* Flux, MultiFab& Soln, int icomp, BC_Mode inhom) { BL_PROFILE("HypreABec::boundaryFlux"); - + const BoxArray &grids = Soln.boxArray(); - + const NGBndry& bd = getBndry(); const Box& domain = bd.getDomain(); @@ -260,7 +260,7 @@ void HypreABec::boundaryFlux(MultiFab* Flux, MultiFab& Soln, int icomp, #endif { Real foo=1.e200; - + for (MFIter si(Soln); si.isValid(); ++si) { int i = si.index(); const Box ® = grids[i]; @@ -748,7 +748,7 @@ void HypreABec::hbmat3 (const Box& bx, else { amrex::Error("hbmat3: unsupported boundary type"); } -#endif +#endif mat(i,j,k)[AMREX_SPACEDIM] += bfm - fac * b(i+1,j,k); @@ -1067,7 +1067,7 @@ void HypreABec::setupSolver(Real _reltol, Real _abstol, int maxiter) HYPRE_StructSMGSetNumPreRelax(precond, 1); HYPRE_StructSMGSetNumPostRelax(precond, 1); HYPRE_StructSMGSetLogging(precond, 0); - HYPRE_StructPCGSetPrecond(solver, + HYPRE_StructPCGSetPrecond(solver, HYPRE_StructSMGSolve, HYPRE_StructSMGSetup, precond); @@ -1075,7 +1075,7 @@ void HypreABec::setupSolver(Real _reltol, Real _abstol, int maxiter) HYPRE_StructPCGSetLogging(solver, 1); HYPRE_StructPCGSetup(solver, A, b, x); - } + } else if (solver_flag == 5 || solver_flag == 6) { HYPRE_StructHybridCreate(MPI_COMM_WORLD, &solver); HYPRE_StructHybridSetDSCGMaxIter(solver, maxiter); diff --git a/Source/radiation/HypreExtMultiABec.cpp b/Source/radiation/HypreExtMultiABec.cpp index 0930849b3e..ddbffc88fd 100644 --- a/Source/radiation/HypreExtMultiABec.cpp +++ b/Source/radiation/HypreExtMultiABec.cpp @@ -28,7 +28,7 @@ void HypreExtMultiABec::a2Coefficients(int level, const MultiFab &a2, int dir) if (!a2coefs[level]) { a2coefs[level].reset(new Array); - + for (int i = 0; i < AMREX_SPACEDIM; i++) { BoxArray edge_boxes(grids[level]); edge_boxes.surroundingNodes(i); @@ -41,7 +41,7 @@ void HypreExtMultiABec::a2Coefficients(int level, const MultiFab &a2, int dir) MultiFab::Copy((*a2coefs[level])[dir], a2, 0, 0, ncomp, ngrow); } - + void HypreExtMultiABec::cCoefficients(int level, const MultiFab &c, int dir) { BL_PROFILE("HypreExtMultiABec::cCoefficients"); @@ -53,7 +53,7 @@ void HypreExtMultiABec::cCoefficients(int level, const MultiFab &c, int dir) if (!ccoefs[level]) { ccoefs[level].reset(new Array); - + for (int i = 0; i < AMREX_SPACEDIM; i++) { BoxArray edge_boxes(grids[level]); edge_boxes.surroundingNodes(i); @@ -89,7 +89,7 @@ void HypreExtMultiABec::d1Coefficients(int level, const MultiFab &d1, int dir) MultiFab::Copy((*d1coefs[level])[dir], d1, 0, 0, ncomp, ngrow); } - + void HypreExtMultiABec::d2Coefficients(int level, const MultiFab &d2, int dir) { BL_PROFILE("HypreExtMultiABec::d2Coefficients"); @@ -101,7 +101,7 @@ void HypreExtMultiABec::d2Coefficients(int level, const MultiFab &d2, int dir) if (!d2coefs[level]) { d2coefs[level].reset(new Array); - + for (int i = 0; i < AMREX_SPACEDIM; i++) { BoxArray edge_boxes(grids[level]); edge_boxes.surroundingNodes(i); @@ -115,7 +115,7 @@ void HypreExtMultiABec::d2Coefficients(int level, const MultiFab &d2, int dir) MultiFab::Copy((*d2coefs[level])[dir], d2, 0, 0, ncomp, ngrow); } -static void +static void FaceValue(AuxVarBox& evalue, AuxVarBox& cintrp, const Mask& msk, const Box& reg, const IntVect& vin, int r, int bho, int flevel) @@ -456,7 +456,7 @@ void HypreExtMultiABec::loadMatrix() // If we're upwinding from the interior, just use that value. // If we're upwinding from the exterior, interpolate // (linearly) to the ghost cell center position. - + Real fac = gamma * ofh; int i0 = ori.isLow(); int i1 = ori.isHigh(); diff --git a/Source/radiation/HypreMultiABec.cpp b/Source/radiation/HypreMultiABec.cpp index aa27b902b1..ec4489b305 100644 --- a/Source/radiation/HypreMultiABec.cpp +++ b/Source/radiation/HypreMultiABec.cpp @@ -171,7 +171,7 @@ int BndryAuxVarBase::nextLocal(int i) return i; } -BndryAuxVar::BndryAuxVar(const BoxArray& _grids, +BndryAuxVar::BndryAuxVar(const BoxArray& _grids, const DistributionMapping& _dmap, Location loc) : BndryAuxVarBase(_dmap), grids(_grids) diff --git a/Source/radiation/MGFLD.cpp b/Source/radiation/MGFLD.cpp index 9be9efb67c..a85880885f 100644 --- a/Source/radiation/MGFLD.cpp +++ b/Source/radiation/MGFLD.cpp @@ -14,7 +14,7 @@ using namespace amrex; void Radiation::check_convergence_er(Real& relative, Real& absolute, Real& err_er, - const MultiFab& Er_new, const MultiFab& Er_pi, + const MultiFab& Er_new, const MultiFab& Er_pi, const MultiFab& kappa_p, const MultiFab& etaTz, const MultiFab& temp_new, @@ -78,15 +78,15 @@ void Radiation::check_convergence_er(Real& relative, Real& absolute, Real& err_e } -void Radiation::check_convergence_matt(const MultiFab& rhoe_new, const MultiFab& rhoe_star, - const MultiFab& rhoe_step, const MultiFab& Er_new, - const MultiFab& temp_new, const MultiFab& temp_star, +void Radiation::check_convergence_matt(const MultiFab& rhoe_new, const MultiFab& rhoe_star, + const MultiFab& rhoe_step, const MultiFab& Er_new, + const MultiFab& temp_new, const MultiFab& temp_star, const MultiFab& rho, const MultiFab& kappa_p, const MultiFab& jg, const MultiFab& dedT, - Real& rel_rhoe, Real& abs_rhoe, - Real& rel_FT, Real& abs_FT, - Real& rel_T, Real& abs_T, + Real& rel_rhoe, Real& abs_rhoe, + Real& rel_FT, Real& abs_FT, + Real& rel_T, Real& abs_T, Real delta_t) { ReduceOps reduce_op; @@ -152,7 +152,7 @@ void Radiation::check_convergence_matt(const MultiFab& rhoe_new, const MultiFab& ParallelDescriptor::ReduceRealMax(data, ndata); - rel_rhoe = data[0]; + rel_rhoe = data[0]; abs_rhoe = data[1]; rel_FT = data[2]; abs_FT = data[3]; @@ -191,7 +191,7 @@ void Radiation::compute_coupling(MultiFab& coupT, } -void Radiation::compute_etat(MultiFab& etaT, MultiFab& etaTz, +void Radiation::compute_etat(MultiFab& etaT, MultiFab& etaTz, MultiFab& eta1, MultiFab& djdT, const MultiFab& dkdT, const MultiFab& dedT, const MultiFab& Er_star, const MultiFab& rho, @@ -242,10 +242,10 @@ void Radiation::compute_etat(MultiFab& etaT, MultiFab& etaTz, } -void Radiation::eos_opacity_emissivity(const MultiFab& S_new, +void Radiation::eos_opacity_emissivity(const MultiFab& S_new, const MultiFab& temp_new, const MultiFab& temp_star, - MultiFab& kappa_p, MultiFab& kappa_r, MultiFab& jg, + MultiFab& kappa_p, MultiFab& kappa_r, MultiFab& jg, MultiFab& djdT, MultiFab& dkdT, MultiFab& dedT, int level, int it, int ngrow) { @@ -429,7 +429,7 @@ void Radiation::eos_opacity_emissivity(const MultiFab& S_new, dkdT_arr(i,j,k,g), jg_arr(i,j,k,g), djdT_arr(i,j,k,g)); } }); - } + } if (ngrow == 0 && !lag_opac) { kappa_r.FillBoundary(geom.periodicity()); @@ -437,13 +437,13 @@ void Radiation::eos_opacity_emissivity(const MultiFab& S_new, } -void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, +void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, MultiFab& kappa_p, MultiFab& kappa_r, MultiFab& etaT, MultiFab& eta1, MultiFab& mugT, Array& lambda, - RadSolve* solver, MGRadBndry& mgbd, - const BoxArray& grids, int level, Real time, + RadSolve* solver, MGRadBndry& mgbd, + const BoxArray& grids, int level, Real time, Real delta_t, Real ptc_tau) { const Geometry& geom = parent->Geom(level); @@ -467,7 +467,7 @@ void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(spec, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& bx = mfi.tilebox(); @@ -539,7 +539,7 @@ void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, acoefs_arr(i,j,k) = H1 * kbar * C::c_light + dt1; }); - } + } solver->cellCenteredApplyMetrics(level, acoefs); solver->setLevelACoeffs(level, acoefs); @@ -592,7 +592,7 @@ void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, bcoefs_arr(i,j,k) += 0.5e0_rt * (spec_arr(i,j,k-1) + spec_arr(i,j,k)) * bcgrp_arr(i,j,k); } }); - + if (nGroups > 1) { amrex::ParallelFor(bx, [=] AMREX_GPU_HOST_DEVICE (int i, int j, int k) @@ -702,7 +702,7 @@ void Radiation::gray_accel(MultiFab& Er_new, MultiFab& Er_pi, void Radiation::local_accel(MultiFab& Er_new, const MultiFab& Er_pi, - const MultiFab& kappa_p, + const MultiFab& kappa_p, const MultiFab& etaT, const MultiFab& mugT, Real delta_t, Real ptc_tau) @@ -745,8 +745,8 @@ void Radiation::local_accel(MultiFab& Er_new, const MultiFab& Er_pi, } -void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, - const MultiFab& temp, +void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, + const MultiFab& temp, const BoxArray& grids, Real& derat, Real& dT, int level) { @@ -767,7 +767,7 @@ void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, #ifdef _OPENMP #pragma omp parallel #endif - for (MFIter mfi(msk); mfi.isValid(); ++mfi) + for (MFIter mfi(msk); mfi.isValid(); ++mfi) { msk[mfi].setVal(1.0); @@ -777,7 +777,7 @@ void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, for (int ii = 0; ii < isects.size(); ii++) { msk[mfi].setVal(0.0, isects[ii].second, 0); } - } + } } } @@ -788,7 +788,7 @@ void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, #ifdef _OPENMP #pragma omp parallel #endif - for (MFIter mfi(state,true); mfi.isValid(); ++mfi) + for (MFIter mfi(state,true); mfi.isValid(); ++mfi) { const Box& reg = mfi.tilebox(); @@ -826,16 +826,16 @@ void Radiation::state_energy_update(MultiFab& state, const MultiFab& rhoe, } -void Radiation::update_matter(MultiFab& rhoe_new, MultiFab& temp_new, +void Radiation::update_matter(MultiFab& rhoe_new, MultiFab& temp_new, const MultiFab& Er_new, const MultiFab& Er_pi, const MultiFab& rhoe_star, const MultiFab& rhoe_step, const MultiFab& etaT, const MultiFab& etaTz, const MultiFab& eta1, const MultiFab& coupT, - const MultiFab& kappa_p, const MultiFab& jg, + const MultiFab& kappa_p, const MultiFab& jg, const MultiFab& mugT, - const MultiFab& S_new, + const MultiFab& S_new, int level, Real delta_t, Real ptc_tau, int it, bool conservative_update) { @@ -958,14 +958,14 @@ void Radiation::update_matter(MultiFab& rhoe_new, MultiFab& temp_new, re_n(i,j,k) = eos_state.rho * eos_state.e; }); } - } + } } // ======================================================================== // for the hyperbolic solver void Radiation::compute_limiter(int level, const BoxArray& grids, - const MultiFab &Sborder, + const MultiFab &Sborder, const MultiFab &Erborder, MultiFab &lamborder) { // it works for both single- and multi-group @@ -983,28 +983,28 @@ void Radiation::compute_limiter(int level, const BoxArray& grids, } else { - MultiFab kpr(grids,dmap,Radiation::nGroups,ngrow); + MultiFab kpr(grids,dmap,Radiation::nGroups,ngrow); if (do_multigroup) { - MGFLD_compute_rosseland(kpr, Sborder); + MGFLD_compute_rosseland(kpr, Sborder); } else { - SGFLD_compute_rosseland(kpr, Sborder); + SGFLD_compute_rosseland(kpr, Sborder); } MultiFab Er_wide(grids, dmap, nGroups, ngrow+1); Er_wide.setVal(-1.0); MultiFab::Copy(Er_wide, Erborder, 0, 0, nGroups, 0); - + Er_wide.FillBoundary(parent->Geom(level).periodicity()); - + const Real* dx = parent->Geom(level).CellSize(); using namespace filter; #ifdef _OPENMP #pragma omp parallel -#endif +#endif for (MFIter mfi(Er_wide,false); mfi.isValid(); ++mfi) { FArrayBox lamfilxfab; #if AMREX_SPACEDIM >= 2 @@ -1258,7 +1258,7 @@ void Radiation::compute_limiter(int level, const BoxArray& grids, } -void Radiation::estimate_gamrPr(const FArrayBox& state, const FArrayBox& Er, +void Radiation::estimate_gamrPr(const FArrayBox& state, const FArrayBox& Er, FArrayBox& gPr, const Real*dx, const Box& box) { auto gPr_arr = gPr.array(); @@ -1832,8 +1832,8 @@ void Radiation::MGFLD_compute_scattering(FArrayBox& kappa_s, const FArrayBox& st Gpu::synchronize(); } -void Radiation::bisect_matter(MultiFab& rhoe_new, MultiFab& temp_new, - const MultiFab& rhoe_star, const MultiFab& temp_star, +void Radiation::bisect_matter(MultiFab& rhoe_new, MultiFab& temp_new, + const MultiFab& rhoe_star, const MultiFab& temp_star, const MultiFab& S_new, const BoxArray& grids, int level) { temp_new.plus(temp_star, 0, 1, 0); @@ -1881,7 +1881,7 @@ void Radiation::rhstoEr(MultiFab& rhs, Real dt, int level) #ifdef _OPENMP #pragma omp parallel #endif - for (MFIter ri(rhs, TilingIfNotGPU()); ri.isValid(); ++ri) + for (MFIter ri(rhs, TilingIfNotGPU()); ri.isValid(); ++ri) { const Box& bx = ri.tilebox(); diff --git a/Source/radiation/MGFLDRadSolver.cpp b/Source/radiation/MGFLDRadSolver.cpp index 3bb6187791..b1fab56387 100644 --- a/Source/radiation/MGFLDRadSolver.cpp +++ b/Source/radiation/MGFLDRadSolver.cpp @@ -15,7 +15,7 @@ using namespace amrex; void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) -{ +{ BL_PROFILE("Radiation::MGFLD_implicit_update"); if (verbose) { amrex::Print() << "Radiation MGFLD implicit update, level " << level << "..." << std::endl; @@ -31,7 +31,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) const DistributionMapping& dmap = castro->DistributionMap(); Real delta_t = parent->dtLevel(level); - int ngrow = 1; + int ngrow = 1; Real time = castro->get_state_data(Rad_Type).curTime(); Real oldtime = castro->get_state_data(Rad_Type).prevTime(); @@ -56,7 +56,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) MultiFab& S_lag = fpi_old.get_mf(); MultiFab kpr_lag(grids,dmap,nGroups,1); - MGFLD_compute_rosseland(kpr_lag, S_lag); + MGFLD_compute_rosseland(kpr_lag, S_lag); for (int igroup=0; igroupgetEdgeBoxArray(idim), dmap, 1, 0); lambda[idim].setVal(1./3.); - } + } } // Er_new: work copy @@ -118,16 +118,16 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) temp_new[mfi].copy(S_new_border[mfi], gbx, UTEMP, gbx, 0, 1); } - // Planck mean and Rosseland + // Planck mean and Rosseland MultiFab kappa_p(grids,dmap,nGroups,1); - MultiFab kappa_r(grids,dmap,nGroups,1); + MultiFab kappa_r(grids,dmap,nGroups,1); // emissivity, j_g = \int j_nu dnu // j_nu = 4 pi /c * \eta_0^{th} = \kappa_0 * B_\nu (assuming LTE), // where B_\nu is the usual Planck function \times 4 pi / c - MultiFab jg(grids,dmap,nGroups,1); - MultiFab djdT(grids,dmap,nGroups,1); - MultiFab dkdT(grids,dmap,nGroups,1); + MultiFab jg(grids,dmap,nGroups,1); + MultiFab djdT(grids,dmap,nGroups,1); + MultiFab dkdT(grids,dmap,nGroups,1); MultiFab etaT(grids,dmap,1,0); MultiFab etaTz(grids,dmap,1,0); MultiFab eta1(grids,dmap,1,0); // eta1 = 1 - etaT @@ -179,7 +179,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) flxsave.reset(new MultiFab(grids, dmap, nGroups*AMREX_SPACEDIM, 0)); flxcc = flxsave.get(); icomp_flux = 0; - } + } // Er_step: starting state of the inner iteration (e.g., ^(2)) // There used to be an extra velocity term update @@ -187,7 +187,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) MultiFab& rhoe_step = rhoe_old; Real reltol_in = relInTol; - Real ptc_tau = 0.0; // not being used + Real ptc_tau = 0.0; // not being used // nonlinear loop for all groups int it = 0; @@ -201,9 +201,9 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (it == 1) { eos_opacity_emissivity(S_new_border, temp_new, temp_star, // input - kappa_p, kappa_r, jg, + kappa_p, kappa_r, jg, djdT, dkdT, dedT, // output - level, it, 1); + level, it, 1); // It's OK that temp_star does not have a valid value for it==1 } @@ -221,12 +221,12 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) // lambda now contains flux limiter } } - + // djdT is both input and output compute_etat(etaT, etaTz, - eta1, djdT, + eta1, djdT, dkdT, dedT, - Er_star, rho, + Er_star, rho, delta_t, ptc_tau); // After this, djdT contains mugT. @@ -241,10 +241,10 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) MultiFab::Copy(Er_pi, Er_new, 0, 0, nGroups, 0); - if (radiation::limiter>0 && inner_update_limiter>0) { + if (radiation::limiter>0 && inner_update_limiter>0) { if (innerIteration <= inner_update_limiter) { Er_pi.FillBoundary(parent->Geom(level).periodicity()); - + for (int igroup=0; igrouplevelBndry(mgbd, igroup); - + solver->levelACoeffs(level, kappa_p, delta_t, c, igroup, ptc_tau); int lamcomp = (radiation::limiter==0) ? 0 : igroup; @@ -275,7 +275,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) } { // src and rhd block - + MultiFab rhs(grids,dmap,1,0); solver->levelRhs(level, rhs, jg, mugT, @@ -289,12 +289,12 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) solver->levelFlux(level, Flux, Er_new, igroup); solver->levelFluxReg(level, flux_in, flux_out, Flux, igroup); - - if (icomp_flux >= 0) + + if (icomp_flux >= 0) solver->levelFluxFaceToCenter(level, Flux, *flxcc, icomp_flux+igroup); } // end loop over groups - + // Check for convergence *before* acceleration step: check_convergence_er(relative_in, absolute_in, error_er, Er_new, Er_pi, kappa_p, etaTz, temp_new, delta_t); @@ -302,7 +302,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (verbose >= 2) { int oldprec = std::cout.precision(3); amrex::Print() << "Outer = " << it << ", Inner = " << innerIteration - << ", inner err = " << std::setw(8) << relative_in << " (rel), " + << ", inner err = " << std::setw(8) << relative_in << " (rel), " << std::setw(8) << absolute_in << " (abs)" << std::endl; std::cout.precision(oldprec); } @@ -313,7 +313,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) else if (innerIteration < minInIter) { inner_converged = false; } - else if ( (relative_in <= reltol_in || absolute_in <= absInTol) + else if ( (relative_in <= reltol_in || absolute_in <= absInTol) && error_er <= reltol ) { inner_converged = true; } @@ -321,10 +321,10 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (!inner_converged) { Real accel_fac=1.+1.e-6; if (skipAccelAllowed && - relative_in>accel_fac*relative_in_prev && + relative_in>accel_fac*relative_in_prev && absolute_in>accel_fac*absolute_in_prev) { accel_allowed = false; - if (relative_in>10.*relative_in_prev && + if (relative_in>10.*relative_in_prev && absolute_in>10.*absolute_in_prev) { MultiFab::Copy(Er_new, Er_star, 0, 0, nGroups, 0); } @@ -336,21 +336,21 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (accelerate == 1) { local_accel(Er_new, Er_pi, kappa_p, etaT, mugT, delta_t, ptc_tau); - } + } else if (accelerate == 2) { - gray_accel(Er_new, Er_pi, kappa_p, kappa_r, + gray_accel(Er_new, Er_pi, kappa_p, kappa_r, etaT, eta1, mugT, lambda, solver, mgbd, grids, level, time, delta_t, ptc_tau); - } + } } } - } while(!inner_converged && innerIteration < maxInIter); + } while(!inner_converged && innerIteration < maxInIter); if (verbose == 1) { int oldprec = std::cout.precision(3); amrex::Print() << "Outer = " << it << ", Inner = " << innerIteration - << ", inner tol = " << std::setw(8) << relative_in << " " + << ", inner tol = " << std::setw(8) << relative_in << " " << std::setw(8) << absolute_in << std::endl; std::cout.precision(oldprec); } @@ -401,12 +401,12 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) eos_opacity_emissivity(S_new_border, temp_new, temp_star, // input - kappa_p, kappa_r, jg, + kappa_p, kappa_r, jg, djdT, dkdT, dedT, // output level, it+1, 0); check_convergence_matt(rhoe_new, rhoe_star, rhoe_step, Er_new, - temp_new, temp_star, + temp_new, temp_star, rho, kappa_p, jg, dedT, rel_rhoe, abs_rhoe, rel_FT, abs_FT, rel_T, abs_T, delta_t); @@ -437,13 +437,13 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (verbose >= 2) { int oldprec = std::cout.precision(4); - amrex::Print() << "Update Errors for rhoe, FT, T" + amrex::Print() << "Update Errors for rhoe, FT, T" << std::endl; - amrex::Print() << " Relative = " << std::setw(9) << rel_rhoe << ", " - << std::setw(9) << rel_FT << ", " << std::setw(9) << rel_T + amrex::Print() << " Relative = " << std::setw(9) << rel_rhoe << ", " + << std::setw(9) << rel_FT << ", " << std::setw(9) << rel_T << std::endl; - amrex::Print() << " Absolute = " << std::setw(9) << abs_rhoe << ", " - << std::setw(9) << abs_FT << ", " << std::setw(9) << abs_T + amrex::Print() << " Absolute = " << std::setw(9) << abs_rhoe << ", " + << std::setw(9) << abs_FT << ", " << std::setw(9) << abs_T << std::endl; std::cout.precision(oldprec); } @@ -451,7 +451,7 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) if (it < miniter) { converged = false; } - else if (relative_out <= reltol || absolute_out <= abstol) { + else if (relative_out <= reltol || absolute_out <= abstol) { // || rel_rhoe < 1.e-15) { converged = true; } @@ -471,23 +471,23 @@ void Radiation::MGFLD_implicit_update(int level, int iteration, int ncycle) eos_opacity_emissivity(S_new_border, temp_new, temp_star, // input - kappa_p, kappa_r, jg, + kappa_p, kappa_r, jg, djdT, dkdT, dedT, // output level, it+1, 0); } - + } while ( ((!converged || !inner_converged) && it(face_box)); // We don't care about the bndry values here, only the type array. #if 0 - FORT_RADBNDRY2(BL_TO_FORTRAN(bndry[face][bi]), + FORT_RADBNDRY2(BL_TO_FORTRAN(bndry[face][bi]), bctypearray[face][igrid]->dataPtr(), ARLIM(domain.loVect()), ARLIM(domain.hiVect()), dx, xlo, time); #endif @@ -239,7 +239,7 @@ void MGRadBndry::setBndryFluxConds(const BCRec& bc, const BC_Mode phys_bc_mode) FArrayBox& bnd_fab = bndry[face][bi]; BaseFab& tfab = *(bctypearray[face][i]); - FORT_RADBNDRY2(BL_TO_FORTRAN(bnd_fab), + FORT_RADBNDRY2(BL_TO_FORTRAN(bnd_fab), tfab.dataPtr(), AMREX_ARLIM(domain.loVect()), AMREX_ARLIM(domain.hiVect()), dx, xlo, time); #endif if (p_bcflag == 0) { diff --git a/Source/radiation/RadBndry.cpp b/Source/radiation/RadBndry.cpp index 24079fd85f..3635f8a512 100644 --- a/Source/radiation/RadBndry.cpp +++ b/Source/radiation/RadBndry.cpp @@ -44,7 +44,7 @@ RadBndry::RadBndry(const BoxArray& _grids, const DistributionMapping& _dmap, bctypearray[face][igrid].reset(new BaseFab(face_box)); // We don't care about the bndry values here, only the type array. #if 0 - FORT_RADBNDRY2(BL_TO_FORTRAN(bndry[face][bi]), + FORT_RADBNDRY2(BL_TO_FORTRAN(bndry[face][bi]), bctypearray[face][igrid]->dataPtr(), AMREX_ARLIM(domain.loVect()), AMREX_ARLIM(domain.hiVect()), dx, xlo, time); #endif @@ -212,7 +212,7 @@ void RadBndry::setBndryFluxConds(const BCRec& bc, const BC_Mode phys_bc_mode) if (domain[face] == grd[face] && !geom.isPeriodic(dir)) { if (bcflag[face] <= 1) { if (p_bc == AMREX_LO_MARSHAK || p_bc == AMREX_LO_SANCHEZ_POMRANING || - p_bc == AMREX_LO_DIRICHLET || p_bc == AMREX_LO_NEUMANN) { + p_bc == AMREX_LO_DIRICHLET || p_bc == AMREX_LO_NEUMANN) { setValue(face, i, value); } } @@ -225,7 +225,7 @@ void RadBndry::setBndryFluxConds(const BCRec& bc, const BC_Mode phys_bc_mode) #if 0 FArrayBox& bnd_fab = bndry[face][bi]; BaseFab& tfab = bctypearray[face][i]; - FORT_RADBNDRY2(BL_TO_FORTRAN(bnd_fab), + FORT_RADBNDRY2(BL_TO_FORTRAN(bnd_fab), tfab.dataPtr(), AMREX_ARLIM(domain.loVect()), AMREX_ARLIM(domain.hiVect()), dx, xlo, time); if (p_bcflag == 0) { diff --git a/Source/radiation/RadHydro.H b/Source/radiation/RadHydro.H index e4dbfda00d..3f600a8069 100644 --- a/Source/radiation/RadHydro.H +++ b/Source/radiation/RadHydro.H @@ -131,7 +131,7 @@ dudt(Real* u, Real* a, const Real* dx, const int n, Real* dudt_tmp) { if (use_WENO) { - for (int gg = 2; gg <= NGROUPS+1; gg++) { + for (int gg = 2; gg <= NGROUPS+1; gg++) { fg(gg) = ag(gg) * ug(gg); ag(gg) = std::abs(ag(gg)); } diff --git a/Source/radiation/RadMultiGroup.cpp b/Source/radiation/RadMultiGroup.cpp index 4a8e682d78..d2f4064eba 100644 --- a/Source/radiation/RadMultiGroup.cpp +++ b/Source/radiation/RadMultiGroup.cpp @@ -113,7 +113,7 @@ void Radiation::get_groups(int verbose) for (int i = 0; i < dlognugroup.size(); i++) { groupfile << "group(" << i << ") = " << dlognugroup[i] << std::endl; - } + } } groupfile.close(); diff --git a/Source/radiation/RadPlotvar.cpp b/Source/radiation/RadPlotvar.cpp index 33b90393a7..3eb677f58c 100644 --- a/Source/radiation/RadPlotvar.cpp +++ b/Source/radiation/RadPlotvar.cpp @@ -44,7 +44,7 @@ void Radiation::save_lambda_in_plotvar(int level, const Array& lambda, const MultiFab& Er, const MultiFab& Fr, int iflx, const Real lab_factor) diff --git a/Source/radiation/RadSolve.cpp b/Source/radiation/RadSolve.cpp index 40a84b59a0..cca74cc94d 100644 --- a/Source/radiation/RadSolve.cpp +++ b/Source/radiation/RadSolve.cpp @@ -64,7 +64,7 @@ RadSolve::read_params () } if (Radiation::SolverType == Radiation::SGFLDSolver - && Radiation::Er_Lorentz_term) { + && Radiation::Er_Lorentz_term) { if (radsolve::level_solver_flag < 100) { amrex::Error("To do Lorentz term implicitly level_solver_flag must be >= 100."); @@ -75,7 +75,7 @@ RadSolve::read_params () } } - if (Radiation::SolverType == Radiation::MGFLDSolver && + if (Radiation::SolverType == Radiation::MGFLDSolver && Radiation::accelerate == 2 && Radiation::nGroups > 1) { if (radsolve::level_solver_flag < 100) { @@ -135,7 +135,7 @@ void RadSolve::cellCenteredApplyMetrics(int level, MultiFab& cc) #ifdef _OPENMP #pragma omp parallel #endif - for (MFIter mfi(cc, TilingIfNotGPU()); mfi.isValid(); ++mfi) + for (MFIter mfi(cc, TilingIfNotGPU()); mfi.isValid(); ++mfi) { const Box& bx = mfi.tilebox(); @@ -242,7 +242,7 @@ void RadSolve::levelACoeffs(int level, } } -void RadSolve::levelSPas(int level, Array& lambda, int igroup, +void RadSolve::levelSPas(int level, Array& lambda, int igroup, int lo_bc[3], int hi_bc[3]) { const BoxArray& grids = parent->boxArray(level); @@ -256,9 +256,9 @@ void RadSolve::levelSPas(int level, Array& lambda, int #endif for (MFIter mfi(spa,true); mfi.isValid(); ++mfi) { const Box& reg = mfi.tilebox(); - + spa[mfi].setVal(1.e210,reg,0); - + bool nexttoboundary=false; for (int idim=0; idim& lambda, int break; } } - + if (nexttoboundary) { auto spa_arr = spa[mfi].array(); @@ -324,7 +324,7 @@ void RadSolve::levelSPas(int level, Array& lambda, int hd->SPalpha(spa); } else { - amrex::Abort("Should not be in RadSolve::levelSPas"); + amrex::Abort("Should not be in RadSolve::levelSPas"); } } @@ -644,7 +644,7 @@ void RadSolve::levelFluxFaceToCenter(int level, const ArrayGeom(level); auto geomdata = geom.data(); @@ -991,7 +991,7 @@ void RadSolve::computeBCoeffs(MultiFab& bcoefs, int idim, } } -void RadSolve::levelACoeffs(int level, MultiFab& kpp, +void RadSolve::levelACoeffs(int level, MultiFab& kpp, Real delta_t, Real c, int igroup, Real ptc_tau) { BL_PROFILE("RadSolve::levelACoeffs (MGFLD)"); @@ -1041,7 +1041,7 @@ void RadSolve::levelACoeffs(int level, MultiFab& kpp, } -void RadSolve::levelRhs(int level, MultiFab& rhs, const MultiFab& jg, +void RadSolve::levelRhs(int level, MultiFab& rhs, const MultiFab& jg, const MultiFab& mugT, const MultiFab& coupT, const MultiFab& etaT, @@ -1109,11 +1109,11 @@ void RadSolve::restoreHypreMulti() if (hem) { hem-> cMultiplier() = cMulti; hem->d1Multiplier() = d1Multi; - hem->d2Multiplier() = d2Multi; + hem->d2Multiplier() = d2Multi; } } -void RadSolve::getEdgeMetric(int idim, const Geometry& geom, const Box& edgebox, +void RadSolve::getEdgeMetric(int idim, const Geometry& geom, const Box& edgebox, Vector& r, Vector& s) { const Box& reg = amrex::enclosedCells(edgebox); diff --git a/Source/radiation/SGRadSolver.cpp b/Source/radiation/SGRadSolver.cpp index 0cf0b76904..3a2b1ea5a1 100644 --- a/Source/radiation/SGRadSolver.cpp +++ b/Source/radiation/SGRadSolver.cpp @@ -46,7 +46,7 @@ void Radiation::single_group_update(int level, int iteration, int ncycle) Ff_new[idim].define(castro->getEdgeBoxArray(idim), dmap, 1, 0); } - MultiFab Dterm; + MultiFab Dterm; if (has_dcoefs) { Dterm.define(grids, dmap, AMREX_SPACEDIM, 0); } diff --git a/Source/radiation/_interpbndry/RadBndryData.H b/Source/radiation/_interpbndry/RadBndryData.H index 3f583cccf6..3df1041532 100644 --- a/Source/radiation/_interpbndry/RadBndryData.H +++ b/Source/radiation/_interpbndry/RadBndryData.H @@ -18,7 +18,7 @@ type conversion with the Geometry::Geometry(const Box&) constructor. This class can easily make a Geometry object, but does not have a ProxyGeometry::ProxyGeometry(const Box&) constructor. -*/ +*/ /*@Doc: A ProxyGeometry object is, for most purposes, merely a wrapper to the Geometry class. The Geometry class contains a single-argument @@ -50,7 +50,7 @@ public: /*@Memo: A BndryData stores and manipulates boundary data information on each side of each box in a BoxArray. -*/ +*/ /*@Doc: A BndryData contains a BndryRegister about each side of each grid in a Boxarray. These data are used to store information along the @@ -166,7 +166,7 @@ public: amrex::FabSet &operator[](const amrex::Orientation &_face) { return amrex::BndryRegister::bndry[_face]; } - + private: // diff --git a/Source/radiation/_interpbndry/RadBndryData.cpp b/Source/radiation/_interpbndry/RadBndryData.cpp index 7e607bfa22..850a36e797 100644 --- a/Source/radiation/_interpbndry/RadBndryData.cpp +++ b/Source/radiation/_interpbndry/RadBndryData.cpp @@ -111,7 +111,7 @@ RadBndryData::define(const BoxArray& _grids, const DistributionMapping& _dmap, if (ovlp.ok()) m->setVal(covered,ovlp,0); } // handle special cases if is periodic - if( geom.isAnyPeriodic() && + if( geom.isAnyPeriodic() && !geom.Domain().contains(face_box) ){ Vector pshifts(27); geom.periodicShift( geom.Domain(), face_box, pshifts); diff --git a/Source/radiation/_interpbndry/RadBoundCond.H b/Source/radiation/_interpbndry/RadBoundCond.H index d545c86cb6..fec193e29e 100644 --- a/Source/radiation/_interpbndry/RadBoundCond.H +++ b/Source/radiation/_interpbndry/RadBoundCond.H @@ -6,13 +6,13 @@ //@Man: /*@Memo: Maintain an identifier for boundary condition types. -*/ +*/ /*@Doc: This is a placeholder for more extensive boundary condition implementations, which might include stencils, etc. Presently, boundary conditions are specified via an integer identifier. This class maintains that integer. -*/ +*/ class RadBoundCond { public: diff --git a/Source/radiation/_interpbndry/RadInterpBndryData.H b/Source/radiation/_interpbndry/RadInterpBndryData.H index c797a1d985..3388cc7346 100644 --- a/Source/radiation/_interpbndry/RadInterpBndryData.H +++ b/Source/radiation/_interpbndry/RadInterpBndryData.H @@ -18,7 +18,7 @@ /*@Memo: An InterpBndryData object adds to a BndryData object the ability to manipulate and set the data stored in the boundary cells. -*/ +*/ /*@Doc: The "Interpbndrydata" class is a virtual base class derived from BndryData. It is intended to provide a more physical method for @@ -38,9 +38,9 @@ \item Fills with values interpolated from a coarser FAB that bounds the cells that do not meet the above two criteria \end{enumerate} - + This class does NOT provide a copy constructor or assignment operator. - + */ class RadInterpBndryData : public RadBndryData @@ -66,7 +66,7 @@ public: //@ManDoc: set bndry values at fine level, performing necessary interpolations void setBndryValues(amrex::BndryRegister& crse, int c_start, const amrex::MultiFab& fine, int f_start, - int bnd_start, int num_comp, amrex::IntVect& ratio, + int bnd_start, int num_comp, amrex::IntVect& ratio, const amrex::BCRec& phys_bc); //@ManDoc: set bndry values to provided value void setBndryValues(amrex::Real bv); diff --git a/Source/radiation/fluxlimiter.H b/Source/radiation/fluxlimiter.H index cc19b5bbc4..7414d738f8 100644 --- a/Source/radiation/fluxlimiter.H +++ b/Source/radiation/fluxlimiter.H @@ -25,7 +25,7 @@ amrex::Real Edd_factor(Real lambda) f = 1.0_rt / 3.0_rt; } else if (radiation::limiter < 10) { // approximate LP, [123] - f = 0.5e0_rt * amrex::max(0.0_rt, (1.e0_rt - 3.e0_rt* lambda)) + + f = 0.5e0_rt * amrex::max(0.0_rt, (1.e0_rt - 3.e0_rt* lambda)) + std::sqrt(amrex::max(0.0_rt, (1.e0_rt - 3.e0_rt * lambda)) * (1.e0_rt + 5.e0_rt * lambda)); f = lambda + f * f; diff --git a/Source/rotation/Castro_rotation.H b/Source/rotation/Castro_rotation.H index 7f90a55121..0fec911450 100644 --- a/Source/rotation/Castro_rotation.H +++ b/Source/rotation/Castro_rotation.H @@ -43,7 +43,7 @@ void rsrc(const Box& bx, Array4 const& uold, - Array4 const& source, + Array4 const& source, const Real dt); /// diff --git a/Source/rotation/rotation_sources.cpp b/Source/rotation/rotation_sources.cpp index f9e461775f..3af464f0f3 100644 --- a/Source/rotation/rotation_sources.cpp +++ b/Source/rotation/rotation_sources.cpp @@ -8,7 +8,7 @@ void Castro::rsrc(const Box& bx, Array4 const& uold, - Array4 const& source, + Array4 const& source, const Real dt) { GeometryData geomdata = geom.data(); @@ -328,7 +328,7 @@ Castro::corrrsrc(const Box& bx, // of the dt_omega_matrix. It also has the correct form if we have disabled // the Coriolis force entirely; at that point it reduces to the identity matrix. - Real new_mom[3] = {}; + Real new_mom[3] = {}; // new_mom = matmul(dt_omega_matrix, new_mom) diff --git a/Source/sdc/Castro_sdc.cpp b/Source/sdc/Castro_sdc.cpp index d82d2764e9..3172ef7a6b 100644 --- a/Source/sdc/Castro_sdc.cpp +++ b/Source/sdc/Castro_sdc.cpp @@ -408,7 +408,7 @@ Castro::construct_old_react_source(MultiFab& U_state, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { instantaneous_react(i, j, k, U_state_arr, R_source_arr); - }); + }); } } } diff --git a/Source/sdc/sdc_newton_solve.H b/Source/sdc/sdc_newton_solve.H index 500e31092e..580b3e6c43 100644 --- a/Source/sdc/sdc_newton_solve.H +++ b/Source/sdc/sdc_newton_solve.H @@ -226,7 +226,7 @@ sdc_newton_solve(const Real dt_m, U_new[UEINT] = burn_state.y[SEINT]; - // we want to do a conservative update for (rho E), so first figure out the + // we want to do a conservative update for (rho E), so first figure out the // energy generation rate Real rho_Sdot = (U_new[UEINT] - U_old[UEINT]) / dt_m - C[UEINT]; diff --git a/Util/ConvertCheckpoint/Embiggen.cpp b/Util/ConvertCheckpoint/Embiggen.cpp index 32893be58c..5a26a83b29 100644 --- a/Util/ConvertCheckpoint/Embiggen.cpp +++ b/Util/ConvertCheckpoint/Embiggen.cpp @@ -139,10 +139,10 @@ static void ScanArguments() { if (ref_ratio != 2 && ref_ratio != 4) amrex::Abort("ref_ratio must be 2 or 4"); - if (grown_factor <= 1) + if (grown_factor <= 1) amrex::Abort("must have grown_factor > 1"); - if (star_at_center == 1) + if (star_at_center == 1) if (grown_factor != 2 && grown_factor != 3) amrex::Abort("must have grown_factor = 2 or 3 for star at center"); } @@ -150,10 +150,10 @@ static void ScanArguments() { // --------------------------------------------------------------- static void PrintUsage (char *progName) { cout << "Usage: " << progName << " checkin=filename " - << "checkout=outfilename " - << "ref_ratio= 2 or 4 " - << "grown_factor=integer " - << "star_at_center =0 or 1 " + << "checkout=outfilename " + << "ref_ratio= 2 or 4 " + << "grown_factor=integer " + << "star_at_center =0 or 1 " << "[nfiles=nfilesout] " << "[verbose=trueorfalse]" << endl; exit(1); @@ -205,10 +205,10 @@ static void ReadCheckpointFile(const std::string& fileName) { is >> mx_lev; is >> fakeAmr.finest_level; - if(ParallelDescriptor::IOProcessor()) + if(ParallelDescriptor::IOProcessor()) std::cout << "previous finest_lev is " << fakeAmr.finest_level << std::endl; - // ADDING LEVELS + // ADDING LEVELS int n = num_new_levels; mx_lev = mx_lev + n; fakeAmr.finest_level = fakeAmr.finest_level + n; @@ -253,7 +253,7 @@ static void ReadCheckpointFile(const std::string& fileName) { amrex::Abort("must have domain divisible by 2*ref_ratio"); } - if (grown_factor <= 1) + if (grown_factor <= 1) amrex::Abort("must have grown_factor > 1"); for (i = 1; i < mx_lev; i++) { @@ -298,18 +298,18 @@ static void ReadCheckpointFile(const std::string& fileName) { // ADDING LEVELS - // n_cycle is always equal to 1 at the coarsest level + // n_cycle is always equal to 1 at the coarsest level fakeAmr.n_cycle[0] = 1; - // At the old coarsest level, which is now level 1, we set n_cycle to ref_ratio + // At the old coarsest level, which is now level 1, we set n_cycle to ref_ratio fakeAmr.n_cycle[1] = ref_ratio; - fakeAmr.level_steps[0] = fakeAmr.level_steps[1] / ref_ratio; - if ( (fakeAmr.level_steps[0]*ref_ratio) != fakeAmr.level_steps[1] ) + fakeAmr.level_steps[0] = fakeAmr.level_steps[1] / ref_ratio; + if ( (fakeAmr.level_steps[0]*ref_ratio) != fakeAmr.level_steps[1] ) amrex::Abort("Number of steps in original checkpoint must be divisible by ref_ratio"); // level_count is how many steps we've taken at this level since the last regrid - if (fakeAmr.level_count[1] == fakeAmr.level_steps[1]) + if (fakeAmr.level_count[1] == fakeAmr.level_steps[1]) { fakeAmr.level_count[0] = fakeAmr.level_steps[0]; @@ -322,7 +322,7 @@ static void ReadCheckpointFile(const std::string& fileName) { // READ LEVEL DATA for(int lev(1); lev <= fakeAmr.finest_level; ++lev) { - + FakeAmrLevel &falRef = fakeAmr.fakeAmrLevels[lev]; is >> falRef.level; @@ -434,7 +434,7 @@ static void ReadCheckpointFile(const std::string& fileName) { falRef.geom.define(domain,&prob_domain,coord); - if(falRef.level > 0) + if(falRef.level > 0) falRef.crse_ratio = ref_ratio * IntVect::TheUnitVector(); falRef.fine_ratio = ref_ratio * IntVect::TheUnitVector(); @@ -742,7 +742,7 @@ static void ConvertData() { } else { #endif - if (star_at_center == 1 && grown_factor == 2) + if (star_at_center == 1 && grown_factor == 2) { // Here we tile the domain with tiles smaller than the original domain -- // we first tile with domain-sized pieces, then intersect with the new domain @@ -777,13 +777,13 @@ static void ConvertData() { // Here we tile the domain with tiles the size of the original domain #if (AMREX_SPACEDIM == 3) - for (int jz = 0; jz < grown_factor; jz++) + for (int jz = 0; jz < grown_factor; jz++) #endif #if (AMREX_SPACEDIM >= 2) - for (int jy = 0; jy < grown_factor; jy++) + for (int jy = 0; jy < grown_factor; jy++) #endif - for (int jx = 0; jx < grown_factor; jx++) - for (int n = 0; n < falRef0.grids.size(); n++) + for (int jx = 0; jx < grown_factor; jx++) + for (int n = 0; n < falRef0.grids.size(); n++) { int shiftx(jx*dlenx); #if (AMREX_SPACEDIM >= 2) @@ -810,12 +810,12 @@ static void ConvertData() { int nstatetypes = falRef0.state.size(); - for (int n = 0; n < nstatetypes; n++) + for (int n = 0; n < nstatetypes; n++) falRef0.state[n].grids = newgrids; // Enlarge the ProbDomain (RealBox) of the geom at each level -- // but we only have to do this at level 0 because they are - // actually all the same copy + // actually all the same copy RealBox rb(fakeAmr.geom[0].ProbDomain()); // If this is an octant then we always grow only in the high directions @@ -823,9 +823,9 @@ static void ConvertData() { { // Here we grow only prob_hi, extending the domain in one direction. // This works when the star's center is at the origin - for (int dm = 0; dm < AMREX_SPACEDIM; dm++) + for (int dm = 0; dm < AMREX_SPACEDIM; dm++) rb.setHi(dm,grown_factor*rb.hi(dm)); - } + } // We treat the r-z case with the star in the middle specially #if (AMREX_SPACEDIM == 2) @@ -846,12 +846,12 @@ static void ConvertData() { } #endif - // This has star_at_center = 0 - else + // This has star_at_center = 0 + else { // Here we grow prob_lo and prob_hi, extending the domain in all directions. // This works when the star's center is at the center of the domain. - for (int dm = 0; dm < AMREX_SPACEDIM; dm++) + for (int dm = 0; dm < AMREX_SPACEDIM; dm++) { Real dist = 0.5 * (rb.hi(dm)-rb.lo(dm)); Real center = 0.5 * (rb.hi(dm)+rb.lo(dm)); @@ -883,7 +883,7 @@ static void ConvertData() { { if (coord == 1) // r-z { - for (int i = 0; i <= max_level; i++) + for (int i = 0; i <= max_level; i++) { Box domain(fakeAmr.geom[i].Domain()); // We only handle grown_factor = 2 @@ -891,7 +891,7 @@ static void ConvertData() { shift_iv[i][1] = domain.size()[1] / 2; } } else if (coord == 0) { // x-y - for (int i = 0; i <= max_level; i++) + for (int i = 0; i <= max_level; i++) { Box domain(fakeAmr.geom[i].Domain()); if (grown_factor == 3) { @@ -901,10 +901,10 @@ static void ConvertData() { } } } - } + } // Enlarge the Domain (Box) of the geom at each level - for (int i = 0; i <= max_level; i++) + for (int i = 0; i <= max_level; i++) { Box domain(fakeAmr.geom[i].Domain()); domain.refine(grown_factor); @@ -914,43 +914,43 @@ static void ConvertData() { falRef.geom.Domain(domain); } - // Now fix the state data domain - for (int i = 0; i <= max_level; i++) + // Now fix the state data domain + for (int i = 0; i <= max_level; i++) { FakeAmrLevel &falRef = fakeAmr.fakeAmrLevels[i]; - for (int n = 0; n < nstatetypes; n++) + for (int n = 0; n < nstatetypes; n++) falRef.state[n].domain.refine(grown_factor); } DistributionMapping newdm {newgrids}; // We need to allocate a MultiFab for new data but don't need to fill it - for (int n = 0; n < nstatetypes; n++) + for (int n = 0; n < nstatetypes; n++) { if (falRef0.state[n].new_data != 0) { int ncomps = (falRef0.state[n].new_data)->nComp(); MultiFab * newNewData = new MultiFab(newgrids,newdm,ncomps,1); - newNewData->setVal(0.); + newNewData->setVal(0.); - if (star_at_center == 1) + if (star_at_center == 1) (falRef0.state[n].new_data)->shift(shift_iv[0]); falRef0.state[n].new_data = newNewData; - + // newNewData->copy(*(falRef0.state[n].new_data),0,0,ncomps); } - } + } // If we have old_data as well as new_data - for (int n = 0; n < nstatetypes; n++) + for (int n = 0; n < nstatetypes; n++) { if (falRef0.state[n].old_data != 0) { int ncomps = (falRef0.state[n].old_data)->nComp(); MultiFab * newOldData = new MultiFab(newgrids,newdm,ncomps,1); newOldData->setVal(0.); - if (star_at_center == 1) + if (star_at_center == 1) (falRef0.state[n].old_data)->shift(shift_iv[0]); falRef0.state[n].old_data = newOldData; @@ -961,22 +961,22 @@ static void ConvertData() { // Now shift the data at the higher levels if (star_at_center == 1) { - for (int i = 1; i <= max_level; i++) + for (int i = 1; i <= max_level; i++) { FakeAmrLevel &falRef = fakeAmr.fakeAmrLevels[i]; // Shift the grids associated with each level falRef.grids.shift(shift_iv[i]); - for (int n = 0; n < nstatetypes; n++) + for (int n = 0; n < nstatetypes; n++) { // Shift the grids associated with each StateData falRef.state[n].grids.shift(shift_iv[i]); // Shift the grids associated with the MultiFab in each StateData - if (falRef0.state[n].new_data != 0) + if (falRef0.state[n].new_data != 0) (falRef.state[n].new_data)->shift(shift_iv[i]); - if (falRef0.state[n].old_data != 0) + if (falRef0.state[n].old_data != 0) (falRef.state[n].old_data)->shift(shift_iv[i]); } } @@ -1006,7 +1006,7 @@ int main(int argc, char *argv[]) { cout << " " << std::endl; } - // Read in the original checkpoint directory and add a coarser level covering the same domain + // Read in the original checkpoint directory and add a coarser level covering the same domain ReadCheckpointFile(CheckFileIn); // Enlarge the new level 0 diff --git a/Util/code_checker/clang_static_analysis.py b/Util/code_checker/clang_static_analysis.py index 0e5057864b..0c0fe07881 100644 --- a/Util/code_checker/clang_static_analysis.py +++ b/Util/code_checker/clang_static_analysis.py @@ -2,7 +2,7 @@ import sys def process_analysis(filename): - + with open(filename, 'r') as f: r = re.compile(r'^(.\.\/\.\.\/\.\.\/Source\/[\w/]+\.cpp.*?(?:warning|note).*?)(?=\n\S)', flags=re.M|re.S) diff --git a/Util/code_checker/pr_tab_remover.sh b/Util/code_checker/pr_tab_remover.sh index 614c41a8f2..cf2bac4e8b 100755 --- a/Util/code_checker/pr_tab_remover.sh +++ b/Util/code_checker/pr_tab_remover.sh @@ -40,7 +40,7 @@ fi git commit -m "Tabs have been converted to spaces by tab_exterminator.sh" echo "pushing to $TRAVIS_PULL_REQUEST_BRANCH" git push origin $TRAVIS_PULL_REQUEST_BRANCH -cd +cd # Kill the ssh-agent ssh-agent -k diff --git a/Util/scripts/get_castro.sh b/Util/scripts/get_castro.sh index c557822ba8..bd906041c9 100755 --- a/Util/scripts/get_castro.sh +++ b/Util/scripts/get_castro.sh @@ -46,7 +46,7 @@ if [ -f castro_exports.sh ]; then rm -f castro_exports.sh fi -cat >> castro_exports.sh << EOF +cat >> castro_exports.sh << EOF export CASTRO_HOME="${pwd}/Castro" export MICROPHYSICS_HOME="${pwd}/Microphysics" export AMREX_HOME="${pwd}/amrex" diff --git a/Util/scripts/get_castro_date.sh b/Util/scripts/get_castro_date.sh index 9adfd91736..9f2f04f27d 100755 --- a/Util/scripts/get_castro_date.sh +++ b/Util/scripts/get_castro_date.sh @@ -79,7 +79,7 @@ if [ -f castro_exports.sh ]; then rm -f castro_exports.sh fi -cat >> castro_exports.sh << EOF +cat >> castro_exports.sh << EOF export CASTRO_HOME="${pwd}/Castro" export MICROPHYSICS_HOME="${pwd}/Microphysics" export AMREX_HOME="${pwd}/amrex" diff --git a/Util/yt/README.md b/Util/yt/README.md index f0a522cdcb..19322c01f9 100644 --- a/Util/yt/README.md +++ b/Util/yt/README.md @@ -9,8 +9,8 @@ These were originally written with the WD merger problem in mind. -- vol-wd-spherical.py : this script does a spherical projection (all 4 pi steradians) - with the camera set at the origin. This can be used to create - 360 degree videos for uploading to youtube. + with the camera set at the origin. This can be used to create + 360 degree videos for uploading to youtube. Note to prepare the video for youtube, follow the instructions here: @@ -18,7 +18,7 @@ These were originally written with the WD merger problem in mind. https://support.google.com/youtube/answer/6178631?hl=en In particular, you need to add metadata to the video, which can be - done with the google spatial media metadata injector: + done with the google spatial media metadata injector: https://github.com/google/spatial-media/blob/master/spatialmedia/README.md diff --git a/Util/yt/vol-wd-spherical-stereo.py b/Util/yt/vol-wd-spherical-stereo.py index 13c760f4b6..aaab7083e6 100755 --- a/Util/yt/vol-wd-spherical-stereo.py +++ b/Util/yt/vol-wd-spherical-stereo.py @@ -64,7 +64,7 @@ def doit(plotfile): # look toward the +x initially cam.focus = ds.arr(np.array([ds.domain_left_edge[0], 0.0, 0.0]), 'cm') - + # center of the domain -- eventually we might want to do the # center of mass cam.position = ds.arr(np.array([0.0, 0.0, 0.0]), 'cm') @@ -77,7 +77,7 @@ def doit(plotfile): cam.switch_orientation(normal_vector=normal, north_vector=[0., 0., 1.]) - + # there is no such thing as a camera width -- the entire volume is rendered #cam.set_width(ds.domain_width) diff --git a/Util/yt/vol-wd-spherical.py b/Util/yt/vol-wd-spherical.py index 4718c96cf2..c293df7d11 100755 --- a/Util/yt/vol-wd-spherical.py +++ b/Util/yt/vol-wd-spherical.py @@ -64,7 +64,7 @@ def doit(plotfile): # look toward the +x initially cam.focus = ds.arr(np.array([ds.domain_left_edge[0], 0.0, 0.0]), 'cm') - + # center of the domain -- eventually we might want to do the # center of mass cam.position = ds.arr(np.array([0.0, 0.0, 0.0]), 'cm') @@ -77,7 +77,7 @@ def doit(plotfile): cam.switch_orientation(normal_vector=normal, north_vector=[0., 0., 1.]) - + # there is no such thing as a camera width -- the entire volume is rendered #cam.set_width(ds.domain_width) diff --git a/deploy_docs_action.sh b/deploy_docs_action.sh index 52b4589ac8..d175f96b49 100755 --- a/deploy_docs_action.sh +++ b/deploy_docs_action.sh @@ -9,10 +9,10 @@ TARGET_BRANCH="gh-pages" mkdir out -# if on the dev branch, use the dev_layout.html template to get the +# if on the dev branch, use the dev_layout.html template to get the # links correct if [ "$GITHUB_BRANCH" = "$DEV_BRANCH" ]; then - mv Docs/source/_templates/dev_layout.html Docs/source/_templates/layout.html + mv Docs/source/_templates/dev_layout.html Docs/source/_templates/layout.html fi # Build the Sphinx documentation @@ -24,7 +24,7 @@ mkdir -p out/docs/ if [ "$GITHUB_BRANCH" = "$MAIN_BRANCH" ]; then mkdir -p out/docs mv Docs/build/html/* out/docs -else +else mkdir -p out/docs/dev/ mv Docs/build/html/* out/docs/dev fi diff --git a/license.txt b/license.txt index c2ed7ea27f..588e92bf1b 100644 --- a/license.txt +++ b/license.txt @@ -1,7 +1,7 @@ SOURCE CODE LICENSE AGREEMENT -Castro, Copyright (c) 2015, -The Regents of the University of California, -through Lawrence Berkeley National Laboratory +Castro, Copyright (c) 2015, +The Regents of the University of California, +through Lawrence Berkeley National Laboratory (subject to receipt of any required approvals from the U.S. Dept. of Energy). All rights reserved." From e94d8266521584c2bf96b6675a1079d45916c4e8 Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Tue, 12 Mar 2024 17:42:48 -0400 Subject: [PATCH 20/56] Add cross-ref to section about creating new derived variables (#2772) It took me a little while to find where this is in the docs. --- Docs/source/creating_a_problem.rst | 4 +++- Docs/source/io.rst | 2 ++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/Docs/source/creating_a_problem.rst b/Docs/source/creating_a_problem.rst index 84d471fa9e..9490845a70 100644 --- a/Docs/source/creating_a_problem.rst +++ b/Docs/source/creating_a_problem.rst @@ -200,7 +200,9 @@ each of these in the main source tree. problem which refines a rectangular region (fuel layer) based on a density parameter and the H mass fraction. -- ``Problem_Derives.H``, ``Problem_Derive.H``, and ``Problem_Derives.cpp`` + .. _problem_derives: + +- ``Problem_Derives.H``, ``Problem_Derive.H``, and ``Problem_Derive.cpp`` Together, these provide a mechanism to create derived quantities that can be stored in the plotfile. ``Problem_Derives.H`` diff --git a/Docs/source/io.rst b/Docs/source/io.rst index 2054eb4e1c..e9dc10993c 100644 --- a/Docs/source/io.rst +++ b/Docs/source/io.rst @@ -397,6 +397,8 @@ Derived variables problem-specific plotfile variables ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +See the section on :ref:`Problem_Derives.H ` for more details about defining your own plotfile variables. + +-----------------------------------+---------------------------------------------------+--------------------------------------+ | variable name | description | units | +===================================+===================================================+======================================+ From e2ce5b578525ce8886ba742ded597a6c84c62288 Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Wed, 13 Mar 2024 08:06:57 -0400 Subject: [PATCH 21/56] Add X(ash) as a derived variable for flame_wave (#2773) It's fairly straightforward to calculate in C++, and this lets me include it in small plotfiles. --- Exec/science/flame_wave/Problem_Derive.H | 5 ++ Exec/science/flame_wave/Problem_Derive.cpp | 53 ++++++++++++++++++++++ Exec/science/flame_wave/Problem_Derives.H | 7 +++ 3 files changed, 65 insertions(+) create mode 100644 Exec/science/flame_wave/Problem_Derive.H create mode 100644 Exec/science/flame_wave/Problem_Derive.cpp create mode 100644 Exec/science/flame_wave/Problem_Derives.H diff --git a/Exec/science/flame_wave/Problem_Derive.H b/Exec/science/flame_wave/Problem_Derive.H new file mode 100644 index 0000000000..885d730a57 --- /dev/null +++ b/Exec/science/flame_wave/Problem_Derive.H @@ -0,0 +1,5 @@ +void ca_derxash + (const amrex::Box& bx, amrex::FArrayBox& derfab, int /*dcomp*/, int /*ncomp*/, + const amrex::FArrayBox& datfab, const amrex::Geometry& /*geomdata*/, + amrex::Real /*time*/, const int* /*bcrec*/, int /*level*/); + diff --git a/Exec/science/flame_wave/Problem_Derive.cpp b/Exec/science/flame_wave/Problem_Derive.cpp new file mode 100644 index 0000000000..d1736bcc36 --- /dev/null +++ b/Exec/science/flame_wave/Problem_Derive.cpp @@ -0,0 +1,53 @@ +#include + +#include + +#include +#include + +using namespace amrex; + +void ca_derxash(const Box& bx, FArrayBox& derfab, int /*dcomp*/, int /*ncomp*/, + const FArrayBox& datfab, const Geometry& /*geomdata*/, + Real /*time*/, const int* /*bcrec*/, int /*level*/) +{ + + // determine which species should be considered ash + + std::bitset is_ash{}; + + for (int i = 0; i < NumSpec; ++i) { + // include all elements beyond oxygen + if (zion[i] > 8.0) { + is_ash.set(i); + } + } + + // exclude all of the "ash" species from the input file; they're actually + // used for the star composition and hiding them helps make the flame more + // visible + for (const std::string& ash_name : {problem::ash1_name, + problem::ash2_name, + problem::ash3_name}) { + int i = network_spec_index(ash_name); + if (i != -1) { + is_ash.reset(i); + } + } + + auto const dat = datfab.array(); + auto const der = derfab.array(); + + amrex::ParallelFor(bx, + [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept + { + Real sum = 0.0_rt; + for (int n = 0; n < NumSpec; ++n) { + if (is_ash[n]) { + sum += dat(i,j,k,1+n)/dat(i,j,k,0); + } + } + der(i,j,k,0) = sum; + }); +} + diff --git a/Exec/science/flame_wave/Problem_Derives.H b/Exec/science/flame_wave/Problem_Derives.H new file mode 100644 index 0000000000..d7eefefae9 --- /dev/null +++ b/Exec/science/flame_wave/Problem_Derives.H @@ -0,0 +1,7 @@ + // + // X(ash) from rhoX - sum of all mass fractions for the elements beyond oxygen, + // excluding the species that make up the star + // + derive_lst.add("X(ash)",IndexType::TheCellType(),1,ca_derxash,the_same_box); + derive_lst.addComponent("X(ash)",desc_lst,State_Type,URHO,1); + derive_lst.addComponent("X(ash)",desc_lst,State_Type,UFS,NumSpec); From 9ab585a31df2707f9eee039f0124a47666a787b4 Mon Sep 17 00:00:00 2001 From: Zhi Chen <62574124+zhichen3@users.noreply.github.com> Date: Wed, 13 Mar 2024 08:07:27 -0400 Subject: [PATCH 22/56] add subchandra subch_base input files (#2657) input files for subch_base. Used for NSE_NET runs. --- Exec/science/subchandra/inputs_2d.NSE | 148 + ...handra.M_WD-1.10.M_He-0.050.hse.CO.10.00km | 4119 +++++++++++++++++ 2 files changed, 4267 insertions(+) create mode 100644 Exec/science/subchandra/inputs_2d.NSE create mode 100644 Exec/science/subchandra/sub_chandra.M_WD-1.10.M_He-0.050.hse.CO.10.00km diff --git a/Exec/science/subchandra/inputs_2d.NSE b/Exec/science/subchandra/inputs_2d.NSE new file mode 100644 index 0000000000..9b5aaa6283 --- /dev/null +++ b/Exec/science/subchandra/inputs_2d.NSE @@ -0,0 +1,148 @@ +# ------------------ INPUTS TO MAIN PROGRAM ------------------- +amr.plot_files_output = 1 +amr.checkpoint_files_output = 1 + +max_step = 1000000 +stop_time = 10.0 + +geometry.is_periodic = 0 0 +geometry.coord_sys = 1 # r-z coordinates + +geometry.prob_lo = 0. 0. +geometry.prob_hi = 5.12e9 1.024e10 + +amr.n_cell = 1280 2560 + +amr.max_level = 1 # maximum level number allowed + +castro.lo_bc = 3 2 +castro.hi_bc = 2 2 + +# >>>>>>>>>>>>> BC FLAGS <<<<<<<<<<<<<<<< +# 0 = Interior 3 = Symmetry +# 1 = Inflow 4 = SlipWall +# 2 = Outflow 5 = NoSlipWall +# >>>>>>>>>>>>> BC FLAGS <<<<<<<<<<<<<<<< + +castro.do_hydro = 1 +castro.do_grav = 1 +castro.do_react = 1 +castro.do_sponge = 1 + +castro.react_rho_min = 1.0 +castro.react_T_min = 5.e7 + +castro.ppm_type = 1 +castro.ppm_temp_fix = 0 + +castro.use_flattening = 1 + +castro.riemann_solver = 1 + +# Full self-gravity with the Poisson equation +gravity.gravity_type = PoissonGrav + +# Multipole expansion includes terms up to r**(-max_multipole_order) +gravity.max_multipole_order = 6 + +# Tolerance for multigrid solver for phi solves +gravity.abs_tol = 1.e-10 + +# Use sync solve for gravity after refluxing +#gravity.no_sync = 0 + +# Disable the use of the lagged composite correction for the potential +gravity.do_composite_phi_correction = 0 + +castro.sponge_upper_density = 1.e4 +castro.sponge_lower_density = 1.e2 +castro.sponge_timescale = 1.e-3 + +castro.cfl = 0.2 # cfl number for hyperbolic system +castro.init_shrink = 0.05 # scale back initial timestep by this factor +castro.change_max = 1.025 # factor by which dt is allowed to change each timestep +castro.sum_interval = 0 # timesteps between computing and printing volume averages +castro.update_sources_after_reflux = 0 +castro.time_integration_method = 3 + +castro.use_retry = 1 +castro.retry_subcycle_factor = 0.5 +castro.max_subcycles = 32 + +castro.abundance_failure_rho_cutoff = 1.0 + +#castro.dtnuc_e = 0.25 +#castro.dtnuc_X = 0.25 + +amr.ref_ratio = 2 2 2 2 # refinement ratio +amr.regrid_int = 2 # how often to regrid +amr.n_error_buf = 2 2 2 2 # number of buffer cells in error est +amr.grid_eff = 0.7 # what constitutes an efficient grid + +amr.check_file = subch_chk # root name of checkpoint file +amr.check_int = 50 # number of timesteps between checkpoints +amr.plot_file = subch_plt # root name of plot file +amr.plot_int = -1 # number of timesteps between plotfiles +amr.plot_per = 2.e-3 + +amr.max_grid_size = 256 # maximum grid size allowed -- used to control parallelism +amr.blocking_factor = 32 # block factor in grid generation + +amr.v = 1 # control verbosity in Amr.cpp +castro.v = 1 # control verbosity in Castro.cpp + +amr.derive_plot_vars = ALL +castro.store_burn_weights = 1 + +castro.small_dens = 1.e-5 +castro.small_temp = 1.e5 + +# problem parameters + +problem.model_name = "sub_chandra.M_WD-1.10.M_He-0.050.hse.CO.10.00km" + +problem.pert_temp_factor = 20.0 +problem.pert_rad_factor = 0.5 +problem.R_pert = 1.e7 + +problem.mu_p = -5.0 +problem.mu_n = -12.0 + +# tagging + +amr.refinement_indicators = tempgrad denerr temperr + +amr.refine.tempgrad.relative_gradient = 2.0 +amr.refine.tempgrad.field_name = Temp +amr.refine.tempgrad.max_level = 1 + +amr.refine.denerr.value_greater = 1.0 +amr.refine.denerr.field_name = density +amr.refine.denerr.max_level = 1 + +amr.refine.temperr.value_greater = 1.e8 +amr.refine.temperr.field_name = Temp +amr.refine.temperr.max_level = 3 + +# Microphysics + +network.small_x = 1.e-10 +integrator.SMALL_X_SAFE = 1.e-10 + +integrator.rtol_spec = 1.e-5 +integrator.atol_spec = 1.e-5 +integrator.rtol_enuc = 1.e-5 +integrator.atol_enuc = 1.e-8 +integrator.jacobian = 1 + +integrator.X_reject_buffer = 4.0 + +# disable jacobian caching in VODE +integrator.use_jacobian_caching = 0 + +integrator.ode_max_steps = 500000 + +nse.nse_dx_independent = 1 +nse.nse_molar_independent = 0 +nse.ase_tol = 0.1 +nse.nse_skip_molar = 0 \ No newline at end of file diff --git a/Exec/science/subchandra/sub_chandra.M_WD-1.10.M_He-0.050.hse.CO.10.00km b/Exec/science/subchandra/sub_chandra.M_WD-1.10.M_He-0.050.hse.CO.10.00km new file mode 100644 index 0000000000..d525e8cd5d --- /dev/null +++ b/Exec/science/subchandra/sub_chandra.M_WD-1.10.M_He-0.050.hse.CO.10.00km @@ -0,0 +1,4119 @@ +# npts = 4096 +# num of variables = 21 +# density +# temperature +# pressure +# hydrogen-1 +# helium-4 +# carbon-12 +# nitrogen-13 +# oxygen-16 +# neon-20 +# sodium-23 +# magnesium-24 +# aluminum-27 +# silicon-28 +# phosphorus-31 +# sulfur-32 +# argon-36 +# calcium-40 +# titanium-44 +# chromium-48 +# iron-52 +# nickel-56 + 500000 99062031.3659 10000000 2.0872569946e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1500000 99052540.1969 10000000 2.08698265615e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2500000 99033561.2061 10000000 2.08643410408e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3500000 99005101.1871 10000000 2.08561159089e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4500000 98967170.311 10000000 2.08451549466e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 5500000 98919782.1257 10000000 2.0831463189e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 6500000 98862953.5474 10000000 2.08150469217e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 7500000 98796704.8479 10000000 2.07959136745e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 8500000 98721059.6409 10000000 2.07740722157e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 9500000 98636044.8646 10000000 2.07495325435e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 10500000 98541690.7624 10000000 2.07223058777e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 11500000 98438030.8614 10000000 2.06924046493e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 12500000 98325101.9478 10000000 2.06598424901e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 13500000 98202944.0409 10000000 2.06246342203e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 14500000 98071600.3639 10000000 2.05867958354e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 15500000 97931117.313 10000000 2.05463444923e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 16500000 97781544.4239 10000000 2.05032984946e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 17500000 97622934.3364 10000000 2.04576772759e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 18500000 97455342.7564 10000000 2.04095013836e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 19500000 97278828.4161 10000000 2.03587924604e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 20500000 97093453.0318 10000000 2.03055732263e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 21500000 96899281.26 10000000 2.02498674584e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 22500000 96696380.6515 10000000 2.01916999706e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 23500000 96484821.603 10000000 2.01310965927e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 24500000 96264677.3077 10000000 2.0068084148e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 25500000 96036023.7036 10000000 2.00026904307e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 26500000 95798939.4202 10000000 1.99349441824e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 27500000 95553505.724 10000000 1.98648750678e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 28500000 95299806.4615 10000000 1.97925136503e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 29500000 95037928.0021 10000000 1.97178913658e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 30500000 94767959.1786 10000000 1.96410404973e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 31500000 94489991.2274 10000000 1.95619941482e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 32500000 94204117.7265 10000000 1.9480786215e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 33500000 93910434.5337 10000000 1.93974513596e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 34500000 93609039.723 10000000 1.93120249816e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 35500000 93300033.521 10000000 1.92245431896e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 36500000 92983518.2415 10000000 1.91350427724e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 37500000 92659598.2212 10000000 1.90435611699e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 38500000 92328379.7532 10000000 1.89501364432e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 39500000 91989971.0216 10000000 1.88548072455e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 40500000 91644482.0352 10000000 1.87576127915e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 41500000 91292024.5608 10000000 1.86585928272e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 42500000 90932712.0572 10000000 1.85577876001e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 43500000 90566659.6092 10000000 1.84552378278e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 44500000 90193983.8607 10000000 1.83509846681e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 45500000 89814802.9496 10000000 1.82450696879e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 46500000 89429236.442 10000000 1.81375348325e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 47500000 89037404.8842 10000000 1.80284223953e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 48500000 88639429.5935 10000000 1.79177749873e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 49500000 88235433.8945 10000000 1.7805635507e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 50500000 87825542.1899 10000000 1.76920471086e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 51500000 87409879.8474 10000000 1.75770531727e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 52500000 86988573.1255 10000000 1.74606972755e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 53500000 86561749.1008 10000000 1.73430231592e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 54500000 86129535.5971 10000000 1.72240747024e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 55500000 85692061.1164 10000000 1.71038958909e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 56500000 85249454.7715 10000000 1.69825307885e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 57500000 84801846.2211 10000000 1.68600235083e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 58500000 84349365.6069 10000000 1.67364181843e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 59500000 83892143.492 10000000 1.66117589436e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 60500000 83430310.8028 10000000 1.64860898785e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 61500000 82963998.7719 10000000 1.63594550197e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 62500000 82493338.8833 10000000 1.62318983087e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 63500000 82018462.8202 10000000 1.61034635726e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 64500000 81539502.4142 10000000 1.59741944972e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 65500000 81056589.5966 10000000 1.5844134602e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 66500000 80569856.352 10000000 1.57133272153e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 67500000 80079434.6726 10000000 1.55818154497e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 68500000 79585456.5088 10000000 1.54496421779e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 69500000 79088052.4265 10000000 1.5316850011e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 70500000 78587353.1211 10000000 1.5183481276e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 71500000 78083489.7748 10000000 1.50495779934e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 72500000 77576592.9577 10000000 1.4915181855e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 73500000 77066792.5933 10000000 1.47803342033e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 74500000 76554217.9273 10000000 1.46450760125e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 75500000 76038997.5017 10000000 1.45094478683e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 76500000 75521259.1307 10000000 1.43734899502e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 77500000 75001129.8814 10000000 1.42372420133e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 78500000 74478736.0561 10000000 1.41007433709e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 79500000 73954203.1781 10000000 1.3964032878e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 80500000 73427655.9796 10000000 1.38271489148e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 81500000 72899218.3905 10000000 1.3690129372e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 82500000 72369013.5302 10000000 1.3553011635e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 83500000 71837163.6992 10000000 1.34158325703e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 84500000 71303790.3723 10000000 1.32786285116e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 85500000 70769013.9963 10000000 1.31414352466e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 86500000 70232952.2072 10000000 1.30042880072e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 87500000 69695723.0663 10000000 1.28672214579e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 88500000 69157443.6816 10000000 1.27302696835e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 89500000 68618229.5981 10000000 1.25934661796e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 90500000 68078194.8337 10000000 1.24568438435e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 91500000 67537451.9169 10000000 1.23204349663e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 92500000 66996111.9262 10000000 1.21842712251e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 93500000 66454284.5297 10000000 1.20483836762e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 94500000 65912078.0247 10000000 1.19128027483e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 95500000 65369599.3764 10000000 1.17775582365e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 96500000 64826954.2559 10000000 1.16426792967e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 97500000 64284247.0758 10000000 1.15081944406e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 98500000 63741581.0244 10000000 1.13741315307e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 99500000 63199058.084 10000000 1.12405177766e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 100500000 62656777.1452 10000000 1.11073797326e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 101500000 62114836.2506 10000000 1.09747432971e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 102500000 61573332.7995 10000000 1.08426337082e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 103500000 61032362.1126 10000000 1.07110755426e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 104500000 60492017.5432 10000000 1.0580092715e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 105500000 59952390.5849 10000000 1.04497084792e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 106500000 59413570.9752 10000000 1.03199454286e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 107500000 58875646.7924 10000000 1.01908254969e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 108500000 58338704.5475 10000000 1.00623699595e+25 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 109500000 57802829.2691 10000000 9.93459943532e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 110500000 57268104.5818 10000000 9.80753388783e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 111500000 56734612.7773 10000000 9.6811926276e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 112500000 56202434.7047 10000000 9.5555943144e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 113500000 55671647.6279 10000000 9.43075696256e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 114500000 55142328.7903 10000000 9.3066979452e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 115500000 54614553.925 10000000 9.18343399635e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 116500000 54088396.5242 10000000 9.06098121601e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 117500000 53563928.0189 10000000 8.93935507616e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 118500000 53041217.9465 10000000 8.81857042675e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 119500000 52520334.1047 10000000 8.69864150174e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 120500000 52001342.6923 10000000 8.579581925e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 121500000 51484308.4368 10000000 8.46140471635e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 122500000 50969294.7081 10000000 8.3441222975e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 123500000 50456363.62 10000000 8.22774649804e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 124500000 49945575.5257 10000000 8.11228856217e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 125500000 49436987.5121 10000000 7.99775915795e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 126500000 48930657.0354 10000000 7.88416838442e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 127500000 48426639.4793 10000000 7.77152577761e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 128500000 47924988.0554 10000000 7.65984031953e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 129500000 47425754.0356 10000000 7.54912044743e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 130500000 46928986.9616 10000000 7.43937406262e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 131500000 46434734.8334 10000000 7.33060853915e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 132500000 45943044.2752 10000000 7.22283073219e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 133500000 45453960.6824 10000000 7.11604698616e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 134500000 44967528.3479 10000000 7.0102631428e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 135500000 44483789.9262 10000000 6.90548454969e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 136500000 44002785.0635 10000000 6.80171607128e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 137500000 43524553.8189 10000000 6.69896209766e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 138500000 43049134.2189 10000000 6.59722655214e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 139500000 42576562.26 10000000 6.496512902e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 140500000 42106872.1829 10000000 6.39682416887e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 141500000 41640096.7141 10000000 6.29816293869e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 142500000 41176267.2781 10000000 6.2005313712e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 143500000 40715414.1813 10000000 6.10393120907e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 144500000 40257566.7691 10000000 6.00836378655e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 145500000 39802753.4682 10000000 5.91383003809e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 146500000 39350999.7313 10000000 5.82033050923e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 147500000 38902330.9464 10000000 5.72786536668e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 148500000 38456771.3464 10000000 5.63643440613e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 149500000 38014343.2052 10000000 5.54603706245e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 150500000 37575067.1569 10000000 5.45667242038e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 151500000 37138962.4738 10000000 5.3683392246e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 152500000 36706047.3068 10000000 5.28103588918e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 153500000 36276338.8896 10000000 5.19476050652e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 154500000 35849853.7103 10000000 5.10951085577e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 155500000 35426607.474 10000000 5.02528441109e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 156500000 35006613.1663 10000000 4.94207835227e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 157500000 34589884.0933 10000000 4.85988957395e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 158500000 34176432.2918 10000000 4.77871469317e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 159500000 33766268.0894 10000000 4.69855005922e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 160500000 33359400.4407 10000000 4.61939176357e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 161500000 32955837.2145 10000000 4.54123564913e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 162500000 32555585.4379 10000000 4.4640773187e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 163500000 32158651.4991 10000000 4.38791214293e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 164500000 31765041.3139 10000000 4.31273526774e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 165500000 31374759.3995 10000000 4.23854162257e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 166500000 30987808.7763 10000000 4.1653259298e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 167500000 30604192.7565 10000000 4.09308271207e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 168500000 30223913.0175 10000000 4.02180629976e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 169500000 29846969.9304 10000000 3.95149084022e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 170500000 29473362.8784 10000000 3.88213030615e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 171500000 29103090.5257 10000000 3.81371850331e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 172500000 28736151.0387 10000000 3.74624907748e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 173500000 28372542.2651 10000000 3.67971552094e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 174500000 28012261.2437 10000000 3.61411117911e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 175500000 27655303.2803 10000000 3.54942925893e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 176500000 27301664.2798 10000000 3.48566283536e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 177500000 26951338.7821 10000000 3.42280485741e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 178500000 26604320.1785 10000000 3.36084815617e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 179500000 26260601.042 10000000 3.29978545202e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 180500000 25920173.4011 10000000 3.23960936112e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 181500000 25583028.9635 10000000 3.18031240121e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 182500000 25249159.2935 10000000 3.12188699684e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 183500000 24918555.1248 10000000 3.06432548508e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 184500000 24591206.0183 10000000 3.0076201224e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 185500000 24267102.0059 10000000 2.95176308982e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 186500000 23946231.8941 10000000 2.89674649819e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 187500000 23628583.5836 10000000 2.84256239479e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 188500000 23314144.3881 10000000 2.78920276924e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 189500000 23002901.2947 10000000 2.73665955855e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 190500000 22694841.1723 10000000 2.68492465164e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 191500000 22389950.8997 10000000 2.63398989327e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 192500000 22088215.9639 10000000 2.58384708942e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 193500000 21789622.1058 10000000 2.53448801223e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 194500000 21494154.6891 10000000 2.48590440374e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 195500000 21201798.1226 10000000 2.43808798091e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 196500000 20912536.2111 10000000 2.39103044073e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 197500000 20626352.4429 10000000 2.34472346461e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 198500000 20343230.2189 10000000 2.29915872204e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 199500000 20063153.0323 10000000 2.25432787374e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 200500000 19786103.9317 10000000 2.21022257507e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 201500000 19512065.142 10000000 2.16683448044e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 202500000 19241019.4218 10000000 2.12415524651e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 203500000 18972948.6432 10000000 2.08217653533e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 204500000 18707834.0993 10000000 2.04089001872e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 205500000 18445656.8043 10000000 2.0002873818e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 206500000 18186397.733 10000000 1.9603603259e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 207500000 17930038.0072 10000000 1.92110057091e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 208500000 17676558.6826 10000000 1.88249985756e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 209500000 17425939.8625 10000000 1.84454995086e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 210500000 17178162.3376 10000000 1.80724264257e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 211500000 16933206.2128 10000000 1.77056975343e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 212500000 16691051.086 10000000 1.73452313645e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 213500000 16451676.3471 10000000 1.69909467971e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 214500000 16215061.4156 10000000 1.66427630849e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 215500000 15981185.9244 10000000 1.63005998688e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 216500000 15750029.5283 10000000 1.59643771929e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 217500000 15521571.1007 10000000 1.56340155299e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 218500000 15295790.1844 10000000 1.53094357991e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 219500000 15072665.7464 10000000 1.49905593811e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 220500000 14852176.3631 10000000 1.46773081433e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 221500000 14634300.5051 10000000 1.43696044599e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 222500000 14419016.7618 10000000 1.40673712254e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 223500000 14206304.011 10000000 1.3770531864e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 224500000 13996141.0332 10000000 1.34790103404e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 225500000 13788506.1946 10000000 1.31927311773e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 226500000 13583378.3768 10000000 1.2911619466e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 227500000 13380735.9413 10000000 1.26356008779e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 228500000 13180557.0103 10000000 1.23646016823e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 229500000 12982819.7255 10000000 1.20985487594e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 230500000 12787502.4486 10000000 1.18373696067e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 231500000 12594583.8979 10000000 1.15809923426e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 232500000 12404042.3171 10000000 1.13293457158e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 233500000 12215856.2923 10000000 1.10823591153e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 234500000 12030004.4026 10000000 1.08399625741e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 235500000 11846464.872 10000000 1.06020867801e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 236500000 11665215.8568 10000000 1.03686630875e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 237500000 11486235.6687 10000000 1.01396235216e+24 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 238500000 11309502.9441 10000000 9.91490078012e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 239500000 11134996.4799 10000000 9.6944282341e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 240500000 10962694.6932 10000000 9.47813993485e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 241500000 10792576.5678 10000000 9.26597061706e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 242500000 10624620.7469 10000000 9.05785570083e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 243500000 10458805.7407 10000000 8.85373130033e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 244500000 10295110.1659 10000000 8.65353422766e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 245500000 10133512.9276 10000000 8.45720199228e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 246500000 9973993.2905 10000000 8.26467279778e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 247500000 9816530.13968 10000000 8.0758855447e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 248500000 9661102.87671 10000000 7.89077983163e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 249500000 9507690.77017 10000000 7.70929595365e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 250500000 9356272.92215 10000000 7.53137490692e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 251500000 9206828.51406 10000000 7.35695839102e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 252500000 9059336.99417 10000000 7.18598880688e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 253500000 8913778.20461 10000000 7.01840925154e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 254500000 8770131.76986 10000000 6.8541635173e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 255500000 8628377.66596 10000000 6.69319609091e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 256500000 8488495.91082 10000000 6.53545215029e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 257500000 8350466.35705 10000000 6.38087756564e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 258500000 8214268.93549 10000000 6.22941890014e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 259500000 8079883.84059 10000000 6.08102340636e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 260500000 7947291.65968 10000000 5.9356390197e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 261500000 7816472.84023 10000000 5.79321435535e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 262500000 7687408.14568 10000000 5.65369870577e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 263500000 7560078.41328 10000000 5.51704203608e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 264500000 7434464.35074 10000000 5.38319498329e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 265500000 7310546.76878 10000000 5.25210885509e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 266500000 7188306.7569 10000000 5.12373562482e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 267500000 7067725.78444 10000000 4.9980279239e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 268500000 6948785.1668 10000000 4.87493903794e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 269500000 6831466.61733 10000000 4.75442290262e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 270500000 6715751.8352 10000000 4.63643409821e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 271500000 6601622.45627 10000000 4.520927848e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 272500000 6489060.26666 10000000 4.40786001513e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 273500000 6378047.3623 10000000 4.29718709616e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 274500000 6268566.15124 10000000 4.18886621307e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 275500000 6160598.9132 10000000 4.08285510902e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 276500000 6054128.35415 10000000 3.97911214311e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 277500000 5949137.07225 10000000 3.87759628474e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 278500000 5845607.69169 10000000 3.77826711142e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 279500000 5743523.05062 10000000 3.68108480369e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 280500000 5642866.33879 10000000 3.58601013724e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 281500000 5543620.846 10000000 3.49300447601e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 282500000 5445769.98735 10000000 3.40202976705e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 283500000 5349297.38799 10000000 3.31304853452e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 284500000 5254186.5921 10000000 3.22602387527e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 285500000 5160421.2727 10000000 3.14091945507e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 286500000 5067985.38888 10000000 3.05769950168e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 287500000 4976863.20393 10000000 2.97632879664e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 288500000 4887038.92115 10000000 2.89677266971e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 289500000 4798497.1052 10000000 2.8189969929e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 290500000 4711222.24831 10000000 2.74296817461e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 291500000 4625198.90582 10000000 2.66865315601e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 292500000 4540411.86729 10000000 2.59601940503e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 293500000 4456846.25983 10000000 2.52503490813e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 294500000 4374487.19528 10000000 2.45566816407e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 295500000 4293320.09301 10000000 2.38788817788e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 296500000 4213330.37845 10000000 2.3216644547e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 297500000 4134503.50014 10000000 2.25696699582e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 298500000 4056825.10845 10000000 2.19376629315e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 299500000 3980281.17899 10000000 2.13203332137e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 300500000 3904857.72884 10000000 2.07173953132e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 301500000 3830541.02121 10000000 2.01285684408e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 302500000 3757317.37148 10000000 1.95535764488e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 303500000 3685173.10811 10000000 1.89921477887e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 304500000 3614094.75152 10000000 1.84440154579e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 305500000 3544069.13393 10000000 1.79089169236e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 306500000 3475083.13024 10000000 1.73865940589e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 307500000 3407123.86164 10000000 1.68767930838e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 308500000 3340178.4793 10000000 1.63792645074e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 309500000 3274234.16821 10000000 1.58937630859e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 310500000 3209278.31865 10000000 1.54200477675e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 311500000 3145298.61176 10000000 1.4957881619e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 312500000 3082282.74984 10000000 1.45070317664e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 313500000 3020218.69335 10000000 1.40672693374e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 314500000 2959094.38206 10000000 1.36383694088e+23 1e-10 0 0.49999999895 0 0.49999999895 0 0 0 0 0 0 0 0 0 0 0 0 0 + 315500000 2898848.67676 10055332.7715 1.32201144746e+23 1e-10 0.000331996628491 0.499832323885 0 0.499832323885 0 0 0 0 0 0 0 0 0 0 0 0 0 + 316500000 2839546.07324 10082533.1827 1.28122889165e+23 1e-10 0.000495199095008 0.499749898397 0 0.499749898397 0 0 0 0 0 0 0 0 0 0 0 0 0 + 317500000 2781137.61399 10123094.7576 1.24146781227e+23 1e-10 0.000738568544006 0.499626984534 0 0.499626984534 0 0 0 0 0 0 0 0 0 0 0 0 0 + 318500000 2723606.9984 10183568.4454 1.20270742011e+23 1e-10 0.00110141067031 0.499443730935 0 0.499443730935 0 0 0 0 0 0 0 0 0 0 0 0 0 + 319500000 2666935.86365 10273702.1782 1.16492737455e+23 1e-10 0.00164221306606 0.499170598412 0 0.499170598412 0 0 0 0 0 0 0 0 0 0 0 0 0 + 320500000 2611102.56317 10407982.8208 1.12810781588e+23 1e-10 0.00244789692012 0.498763687374 0 0.498763687374 0 0 0 0 0 0 0 0 0 0 0 0 0 + 321500000 2556080.88195 10607899.5834 1.09222941427e+23 1e-10 0.00364739749307 0.498157879004 0 0.498157879004 0 0 0 0 0 0 0 0 0 0 0 0 0 + 322500000 2501838.08947 10905239.3184 1.05727343988e+23 1e-10 0.00543143589948 0.497256849506 0 0.497256849506 0 0 0 0 0 0 0 0 0 0 0 0 0 + 323500000 2448331.85224 11346824.2403 1.02322186586e+23 1e-10 0.0080809454253 0.495918713382 0 0.495918713382 0 0 0 0 0 0 0 0 0 0 0 0 0 + 324500000 2395506.49054 12001191.7724 9.9005751588e+22 1e-10 0.0120071506102 0.493935781471 0 0.493935781471 0 0 0 0 0 0 0 0 0 0 0 0 0 + 325500000 2343287.63829 12967724.6437 9.57764269934e+22 1e-10 0.0178063478265 0.491006893988 0 0.491006893988 0 0 0 0 0 0 0 0 0 0 0 0 0 + 326500000 2291575.90628 14388503.9402 9.2632734474e+22 1e-10 0.0263310235879 0.486701502189 0 0.486701502189 0 0 0 0 0 0 0 0 0 0 0 0 0 + 327500000 2240239.41079 16462344.2615 8.95733660762e+22 1e-10 0.0387740654905 0.480417137593 0 0.480417137593 0 0 0 0 0 0 0 0 0 0 0 0 0 + 328500000 2189105.12837 19458489.0233 8.6597230901e+22 1e-10 0.0567509340252 0.471337911061 0 0.471337911061 0 0 0 0 0 0 0 0 0 0 0 0 0 + 329500000 2137950.09914 23723494.9215 8.37035123547e+22 1e-10 0.0823409693626 0.45841365079 0 0.45841365079 0 0 0 0 0 0 0 0 0 0 0 0 0 + 330500000 2086493.51726 29668482.1336 8.08917351667e+22 1e-10 0.118010892563 0.440398538064 0 0.440398538064 0 0 0 0 0 0 0 0 0 0 0 0 0 + 331500000 2034395.59274 37716966.4529 7.81618367991e+22 1e-10 0.166301798381 0.416009191693 0 0.416009191693 0 0 0 0 0 0 0 0 0 0 0 0 0 + 332500000 1981281.63283 48193410.7227 7.55142219844e+22 1e-10 0.229160463873 0.384262390943 0 0.384262390943 0 0 0 0 0 0 0 0 0 0 0 0 0 + 333500000 1926829.56863 61154210.6139 7.29497425944e+22 1e-10 0.306925263064 0.344987239839 0 0.344987239839 0 0 0 0 0 0 0 0 0 0 0 0 0 + 334500000 1870956.93446 76216536.0814 7.04694983948e+22 1e-10 0.397299215686 0.299343829428 0 0.299343829428 0 0 0 0 0 0 0 0 0 0 0 0 0 + 335500000 1814059.17528 92500000 6.80743655177e+22 1e-10 0.494999999 0.249999999475 0 0.249999999475 0 0 0 0 0 0 0 0 0 0 0 0 0 + 336500000 1757115.81122 108783463.919 6.57643125241e+22 1e-10 0.592700782314 0.200656169522 0 0.200656169522 0 0 0 0 0 0 0 0 0 0 0 0 0 + 337500000 1701471.16261 123845789.386 6.35378049568e+22 1e-10 0.683074734936 0.155012759111 0 0.155012759111 0 0 0 0 0 0 0 0 0 0 0 0 0 + 338500000 1648387.30451 136806589.277 6.13916511023e+22 1e-10 0.760839534127 0.115737608007 0 0.115737608007 0 0 0 0 0 0 0 0 0 0 0 0 0 + 339500000 1598672.27025 147283033.547 5.93213744735e+22 1e-10 0.823698199619 0.0839908072567 0 0.0839908072567 0 0 0 0 0 0 0 0 0 0 0 0 0 + 340500000 1552519.80933 155331517.866 5.73219162936e+22 1e-10 0.871989105437 0.0596014608859 0 0.0596014608859 0 0 0 0 0 0 0 0 0 0 0 0 0 + 341500000 1509670.43181 161276505.079 5.5388321808e+22 1e-10 0.907659028637 0.0415863481596 0 0.0415863481596 0 0 0 0 0 0 0 0 0 0 0 0 0 + 342500000 1469642.38156 165541510.977 5.35161643646e+22 1e-10 0.933249063975 0.0286620878892 0 0.0286620878892 0 0 0 0 0 0 0 0 0 0 0 0 0 + 343500000 1431912.50921 168537655.739 5.17017018119e+22 1e-10 0.95122593251 0.0195828613573 0 0.0195828613573 0 0 0 0 0 0 0 0 0 0 0 0 0 + 344500000 1396015.43656 170611496.06 4.99418546196e+22 1e-10 0.963668974412 0.0132984967605 0 0.0132984967605 0 0 0 0 0 0 0 0 0 0 0 0 0 + 345500000 1361578.39532 172032275.356 4.82341011902e+22 1e-10 0.972193650174 0.00899310496216 0 0.00899310496216 0 0 0 0 0 0 0 0 0 0 0 0 0 + 346500000 1328320.77528 172998808.228 4.65763541639e+22 1e-10 0.97799284739 0.0060642174794 0 0.0060642174794 0 0 0 0 0 0 0 0 0 0 0 0 0 + 347500000 1296038.92845 173653175.76 4.49668490261e+22 1e-10 0.981919052575 0.00408128556801 0 0.00408128556801 0 0 0 0 0 0 0 0 0 0 0 0 0 + 348500000 1264588.34682 174094760.682 4.34040553415e+22 1e-10 0.984568562101 0.00274314944396 0 0.00274314944396 0 0 0 0 0 0 0 0 0 0 0 0 0 + 349500000 1233867.57798 174392100.417 4.18866105714e+22 1e-10 0.986352600507 0.00184211994585 0 0.00184211994585 0 0 0 0 0 0 0 0 0 0 0 0 0 + 350500000 1203805.47662 174592017.179 4.04132728079e+22 1e-10 0.98755210108 0.00123631157572 0 0.00123631157572 0 0 0 0 0 0 0 0 0 0 0 0 0 + 351500000 1174351.80742 174726297.822 3.89828878942e+22 1e-10 0.988357784934 0.000829400538345 0 0.000829400538345 0 0 0 0 0 0 0 0 0 0 0 0 0 + 352500000 1145470.57935 174816431.555 3.75943669028e+22 1e-10 0.98889858733 0.000556268015262 0 0.000556268015262 0 0 0 0 0 0 0 0 0 0 0 0 0 + 353500000 1116994.78798 175000000 3.62467546129e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 354500000 1091096.57705 172540638.92 3.49379183511e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 355500000 1065601.44597 170094666.085 3.36657531803e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 356500000 1040504.50459 167661993.413 3.24294616357e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 357500000 1015800.92619 165242531.62 3.12282611874e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 358500000 991486.045897 162836200.935 3.00613839158e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 359500000 967555.233964 160442919.444 2.89280762085e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 360500000 944003.955893 158062609.186 2.78275984999e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 361500000 920827.640404 155695182.104 2.67592250568e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 362500000 898021.814009 153340552.674 2.57222437634e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 363500000 875582.138314 150998643.363 2.47159558133e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 364500000 853504.31925 148669375.564 2.37396754355e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 365500000 831784.101122 146352669.136 2.27927296791e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 366500000 810417.227431 144048436.537 2.18744582264e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 367500000 789399.589503 141756599.113 2.09842131471e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 368500000 768727.135754 139477078.726 2.01213586242e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 369500000 748395.894084 137209800.384 1.92852707214e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 370500000 728401.857156 134954678.482 1.84753372056e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 371500000 708741.124044 132711631.678 1.76909573555e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 372500000 689409.89421 130480584.075 1.69315417004e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 373500000 670404.435076 128261461.802 1.6196511783e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 374500000 651720.993932 126054182.262 1.5485299991e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 375500000 633355.888474 123858663.044 1.47973493896e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 376500000 615305.558154 121674829.866 1.41321134807e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 377500000 597566.49817 119502609.233 1.3489055973e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 378500000 580135.193161 117341919.872 1.28676506262e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 379500000 563008.195392 115192680.462 1.22673810908e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 380500000 546182.170239 113054817.17 1.1687740685e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 381500000 529653.843177 110928257.653 1.11282321795e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 382500000 513419.915145 108812919.27 1.05883676569e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 383500000 497477.187155 106708723.635 1.00676683517e+22 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 384500000 481822.551055 104615597.668 9.56566443414e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 385500000 466452.943542 102533467.883 9.08189482515e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 386500000 451365.285776 100462250.065 8.61590706836e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 387500000 436556.636494 98401870.3056 8.16725715681e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 388500000 422024.116005 96352256.5693 7.73550932343e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 389500000 407764.839031 94313328.322 7.32023590672e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 390500000 393775.998486 92285006.3027 6.92101720984e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 391500000 380054.890262 90267218.4556 6.53744130793e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 392500000 366598.833779 88259888.6135 6.16910388546e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 393500000 353405.171656 86262933.6348 5.81560811539e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 394500000 340471.372778 84276280.3547 5.47656448957e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 395500000 327794.948046 82299854.1424 5.15159064276e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 396500000 315373.413332 80333570.1446 4.84031123825e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 397500000 303204.417246 78377354.0776 4.54235781127e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 398500000 291285.653033 76431130.0346 4.25736859587e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 399500000 279399.526873 75000000 3.9850911328e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 400500000 267177.094783 75000000 3.72555437771e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 401500000 255261.181599 75000000 3.47865683724e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 402500000 243649.037916 75000000 3.24399664558e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 403500000 232338.06532 75000000 3.0211794059e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 404500000 221325.680713 75000000 2.80981801962e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 405500000 210609.494693 75000000 2.60953249831e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 406500000 200187.159149 75000000 2.41994976682e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 407500000 190056.472169 75000000 2.24070349132e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 408500000 180215.341738 75000000 2.07143387878e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 409500000 170661.773354 75000000 1.91178750195e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 410500000 161393.933797 75000000 1.76141710401e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 411500000 152410.064837 75000000 1.61998141663e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 412500000 143708.595693 75000000 1.48714496941e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 413500000 135288.032246 75000000 1.36257790187e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 414500000 127147.067632 75000000 1.24595577884e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 415500000 119284.49531 75000000 1.13695939853e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 416500000 111699.268213 75000000 1.03527461633e+21 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 417500000 104390.477142 75000000 9.40592155225e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 418500000 97357.3218611 75000000 8.52607441635e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 419500000 90599.1748755 75000000 7.71020429016e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 420500000 84115.469445 75000000 6.95535445417e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 421500000 77905.7585891 75000000 6.25861066472e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 422500000 71969.6686633 75000000 5.61709985042e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 423500000 66306.8262767 75000000 5.02798933927e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 424500000 60916.8491512 75000000 4.48848644357e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 425500000 55799.2848263 75000000 3.99583834318e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 426500000 50953.4951179 75000000 3.54733270571e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 427500000 46378.5886665 75000000 3.14029904894e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 428500000 42073.3011427 75000000 2.7721108423e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 429500000 38035.8731588 75000000 2.44018855289e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 430500000 34263.9018185 75000000 2.14200372757e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 431500000 30754.1916224 75000000 1.87508419267e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 432500000 27502.6078 75000000 1.63702033213e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 433500000 24503.9398148 75000000 1.42547236225e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 434500000 21751.7876729 75000000 1.23817844065e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 435500000 19238.4850475 75000000 1.07296334486e+20 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 436500000 16955.0718639 75000000 9.27747357398e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 437500000 14891.3259516 75000000 8.00554916601e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 438500000 13035.85908 75000000 6.89522547385e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 439500000 11376.2768939 75000000 5.92905582517e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 440500000 9899.39384655 75000000 5.0908323775e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 441500000 8591.48306598 75000000 4.36561731977e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 442500000 7438.55288857 75000000 3.73975264384e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 443500000 6426.61850964 75000000 3.20084821769e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 444500000 5541.96921911 75000000 2.73774910824e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 445500000 4771.39202418 75000000 2.34048456869e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 446500000 4102.35297204 75000000 2.00020248702e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 447500000 3523.13602935 75000000 1.70909293259e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 448500000 3022.93643071 75000000 1.46030444979e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 449500000 2591.90207178 75000000 1.24785699595e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 450500000 2221.14263205 75000000 1.06655480122e+19 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 451500000 1902.71230716 75000000 9.11901367775e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 452500000 1629.56239185 75000000 7.80018677775e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 453500000 1395.4834244 75000000 6.67572021635e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 454500000 1195.03956162 75000000 5.71700985243e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 455500000 1023.49372361 75000000 4.89957072306e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 456500000 876.736273965 75000000 4.20248007158e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 457500000 751.215443696 75000000 3.60788359612e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 458500000 643.869301732 75000000 3.10056215234e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 459500000 552.065567617 75000000 2.66755400647e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 460500000 473.546070773 75000000 2.2978267532e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 461500000 406.375928503 75000000 1.98199430118e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 462500000 348.899964247 75000000 1.71207353036e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 463500000 299.703763102 75000000 1.48127540873e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 464500000 257.579130911 75000000 1.28382650949e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 465500000 221.49485006 75000000 1.11481675262e+18 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 466500000 190.571195005 75000000 9.70069540144e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 467500000 164.057606802 75000000 8.46031311533e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 468500000 141.313809199 75000000 7.3967774112e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 469500000 121.7937701 75000000 6.484339871e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 470500000 105.031646663 75000000 5.70106979105e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 471500000 90.6298634715 75000000 5.02828033275e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 472500000 78.2491686065 75000000 4.45004134159e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 473500000 67.5999270314 75000000 3.95276575306e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 474500000 58.4347434088 75000000 3.52485907535e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 475500000 50.5422226354 75000000 3.15642207131e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 476500000 43.7417059928 75000000 2.83899823154e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 477500000 37.8786892725 75000000 2.56535939507e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 478500000 32.8209639374 75000000 2.32932390363e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 479500000 28.4553535563 75000000 2.12560212039e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 480500000 24.6849427051 75000000 1.94966505232e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 481500000 21.4266763983 75000000 1.79763267508e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 482500000 18.6093394056 75000000 1.66617902347e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 483500000 16.1718335437 75000000 1.55245142931e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 484500000 14.061724146 75000000 1.45400172174e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 485500000 12.2339770305 75000000 1.36872761377e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 486500000 10.6498946783 75000000 1.2948227741e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 487500000 9.27620010579 75000000 1.23073426203e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 488500000 8.08426632455 75000000 1.17512621151e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 489500000 7.04945472616 75000000 1.12684880454e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 490500000 6.15054310877 75000000 1.08491177812e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 491500000 5.36924373487 75000000 1.04846178961e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 492500000 4.68978606885 75000000 1.01676306205e+17 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 493500000 4.09856403139 75000000 9.89180827097e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 494500000 3.58383323446 75000000 9.65167142153e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 495500000 3.13545013401 75000000 9.44248740097e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 496500000 2.7446477953 75000000 9.26016620753e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 497500000 2.40384591367 75000000 9.1011712469e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 498500000 2.10648555107 75000000 8.96244273561e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 499500000 1.84688885343 75000000 8.84133195366e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 500500000 1.62013817556 75000000 8.73554474128e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 501500000 1.42197195004 75000000 8.64309292764e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 502500000 1.24869493493 75000000 8.56225256682e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 503500000 1.09710107375 75000000 8.4915280108e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 504500000 0.964407541451 75000000 8.42962097088e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 505500000 0.848197285776 75000000 8.37540386462e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 506500000 0.746369921126 75000000 8.32789684853e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 507500000 0.65709930981 75000000 8.28624800601e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 508500000 0.57879691823 75000000 8.24971625056e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 509500000 0.510080165798 75000000 8.21765656539e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 510500000 0.449745081921 75000000 8.18950725385e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 511500000 0.396742663908 75000000 8.16477892112e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 512500000 0.350158430854 75000000 8.14304494754e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 513500000 0.309194837484 75000000 8.12393324427e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 514500000 0.273155912045 75000000 8.10711911577e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 515500000 0.241434015447 75000000 8.09231907935e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 516500000 0.213498366801 75000000 8.07928550873e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 517500000 0.188885090242 75000000 8.06780198974e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 518500000 0.16718857873 75000000 8.05767929124e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 519500000 0.148053997695 75000000 8.04875186821e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 520500000 0.131170775232 75000000 8.04087482512e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 521500000 0.11626694634 75000000 8.03392127766e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 522500000 0.103104236745 75000000 8.02778005938e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 523500000 0.0914737874463 75000000 8.02235372724e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 524500000 0.0811924345797 75000000 8.01755682602e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 525500000 0.0720994708467 75000000 8.01331437753e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 526500000 0.0640538247322 75000000 8.00956056455e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 527500000 0.0569316023902 75000000 8.00623758404e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 528500000 0.050623944501 75000000 8.00329464728e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 529500000 0.0450351568228 75000000 8.00068710766e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 530500000 0.0400810786886 75000000 7.99837569956e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 531500000 0.0356876584733 75000000 7.9963258737e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 532500000 0.0317897091797 75000000 7.99450721656e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 533500000 0.0283298208505 75000000 7.99289294305e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 534500000 0.0252574095922 75000000 7.99145945274e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 535500000 0.0225278856615 75000000 7.99018594183e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 536500000 0.0201019253655 75000000 7.98905406338e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 537500000 0.0179448335254 75000000 7.98804762994e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 538500000 0.0160259849802 75000000 7.98715235295e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 539500000 0.0143183351052 75000000 7.98635561438e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 540500000 0.0127979906205 75000000 7.98564626648e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 541500000 0.0114438330916 75000000 7.98501445615e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 542500000 0.0102371885019 75000000 7.98445147075e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 543500000 0.00916153712906 75000000 7.98394960276e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 544500000 0.00820225869353 75000000 7.98350203083e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 545500000 0.00734640839048 75000000 7.98310271538e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 546500000 0.00658251997532 75000000 7.98274630661e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 547500000 0.00590043255742 75000000 7.98242806377e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 548500000 0.00529113818052 75000000 7.98214378405e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 549500000 0.00474664763619 75000000 7.9818897399e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 550500000 0.00425987227752 75000000 7.98166262397e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 551500000 0.00382451987997 75000000 7.98145950048e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 552500000 0.00343500284001 75000000 7.98127776243e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 553500000 0.00308635721514 75000000 7.98111509377e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 554500000 0.00277417129433 75000000 7.98096943615e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 555500000 0.00249452255017 75000000 7.98083895945e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 556500000 0.00224392196556 75000000 7.98072203585e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 557500000 0.0020192650521 75000000 7.98061721686e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 558500000 0.00181778824933 75000000 7.98052321307e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 559500000 0.00163703036038 75000000 7.98043887617e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 560500000 0.00147479877294 75000000 7.98036318319e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 561500000 0.0013291393679 75000000 7.98029522236e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 562500000 0.00119830988125 75000000 7.98023418078e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 563500000 0.00108075631323 75000000 7.98017933337e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 564500000 0.000975092027771 75000000 7.98013003315e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 565500000 0.000880079227921 75000000 7.9800857026e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 566500000 0.000794612530533 75000000 7.98004582602e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 567500000 0.000717704498191 75000000 7.98000994269e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 568500000 0.00064847276335 75000000 7.97997764092e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 569500000 0.000586128398259 75000000 7.97994855264e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 570500000 0.000529965888897 75000000 7.97992234866e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 571500000 0.000479354060968 75000000 7.9798987345e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 572500000 0.000433728012968 75000000 7.97987744655e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 573500000 0.00039258194433 75000000 7.97985824883e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 574500000 0.000355462776716 75000000 7.97984092995e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 575500000 0.000321964571364 75000000 7.97982530053e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 576500000 0.000291723495747 75000000 7.9798111908e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 577500000 0.000264413290793 75000000 7.97979844855e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 578500000 0.000239741351295 75000000 7.97978693726e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 579500000 0.000217445135298 75000000 7.97977653442e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 580500000 0.000197288964006 75000000 7.97976713005e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 581500000 0.00017906117206 75000000 7.97975862541e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 582500000 0.000162571660457 75000000 7.97975093181e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 583500000 0.000147649593403 75000000 7.97974396955e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 584500000 0.000134141423846 75000000 7.97973766698e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 585500000 0.000121909103376 75000000 7.97973195969e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 586500000 0.00011082844919 75000000 7.97972678973e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 587500000 0.000100787688044 75000000 7.97972210496e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 588500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 589500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 590500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 591500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 592500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 593500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 594500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 595500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 596500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 597500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 598500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 599500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 600500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 601500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 602500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 603500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 604500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 605500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 606500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 607500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 608500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 609500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 610500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 611500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 612500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 613500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 614500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 615500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 616500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 617500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 618500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 619500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 620500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 621500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 622500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 623500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 624500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 625500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 626500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 627500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 628500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 629500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 630500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 631500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 632500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 633500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 634500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 635500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 636500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 637500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 638500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 639500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 640500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 641500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 642500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 643500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 644500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 645500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 646500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 647500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 648500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 649500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 650500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 651500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 652500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 653500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 654500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 655500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 656500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 657500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 658500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 659500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 660500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 661500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 662500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 663500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 664500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 665500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 666500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 667500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 668500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 669500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 670500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 671500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 672500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 673500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 674500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 675500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 676500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 677500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 678500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 679500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 680500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 681500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 682500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 683500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 684500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 685500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 686500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 687500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 688500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 689500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 690500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 691500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 692500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 693500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 694500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 695500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 696500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 697500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 698500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 699500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 700500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 701500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 702500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 703500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 704500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 705500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 706500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 707500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 708500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 709500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 710500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 711500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 712500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 713500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 714500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 715500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 716500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 717500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 718500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 719500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 720500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 721500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 722500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 723500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 724500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 725500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 726500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 727500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 728500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 729500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 730500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 731500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 732500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 733500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 734500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 735500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 736500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 737500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 738500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 739500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 740500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 741500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 742500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 743500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 744500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 745500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 746500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 747500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 748500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 749500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 750500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 751500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 752500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 753500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 754500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 755500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 756500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 757500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 758500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 759500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 760500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 761500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 762500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 763500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 764500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 765500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 766500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 767500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 768500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 769500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 770500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 771500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 772500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 773500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 774500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 775500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 776500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 777500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 778500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 779500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 780500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 781500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 782500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 783500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 784500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 785500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 786500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 787500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 788500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 789500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 790500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 791500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 792500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 793500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 794500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 795500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 796500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 797500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 798500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 799500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 800500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 801500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 802500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 803500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 804500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 805500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 806500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 807500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 808500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 809500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 810500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 811500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 812500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 813500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 814500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 815500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 816500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 817500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 818500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 819500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 820500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 821500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 822500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 823500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 824500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 825500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 826500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 827500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 828500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 829500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 830500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 831500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 832500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 833500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 834500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 835500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 836500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 837500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 838500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 839500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 840500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 841500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 842500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 843500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 844500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 845500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 846500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 847500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 848500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 849500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 850500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 851500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 852500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 853500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 854500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 855500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 856500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 857500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 858500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 859500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 860500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 861500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 862500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 863500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 864500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 865500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 866500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 867500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 868500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 869500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 870500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 871500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 872500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 873500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 874500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 875500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 876500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 877500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 878500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 879500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 880500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 881500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 882500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 883500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 884500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 885500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 886500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 887500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 888500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 889500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 890500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 891500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 892500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 893500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 894500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 895500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 896500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 897500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 898500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 899500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 900500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 901500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 902500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 903500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 904500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 905500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 906500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 907500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 908500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 909500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 910500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 911500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 912500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 913500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 914500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 915500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 916500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 917500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 918500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 919500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 920500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 921500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 922500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 923500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 924500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 925500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 926500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 927500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 928500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 929500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 930500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 931500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 932500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 933500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 934500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 935500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 936500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 937500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 938500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 939500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 940500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 941500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 942500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 943500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 944500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 945500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 946500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 947500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 948500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 949500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 950500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 951500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 952500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 953500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 954500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 955500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 956500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 957500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 958500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 959500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 960500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 961500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 962500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 963500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 964500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 965500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 966500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 967500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 968500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 969500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 970500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 971500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 972500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 973500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 974500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 975500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 976500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 977500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 978500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 979500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 980500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 981500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 982500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 983500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 984500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 985500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 986500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 987500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 988500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 989500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 990500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 991500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 992500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 993500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 994500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 995500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 996500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 997500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 998500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 999500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1000500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1001500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1002500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1003500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1004500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1005500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1006500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1007500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1008500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1009500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1010500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1011500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1012500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1013500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1014500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1015500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1016500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1017500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1018500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1019500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1020500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1021500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1022500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1023500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1024500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1025500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1026500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1027500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1028500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1029500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1030500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1031500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1032500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1033500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1034500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1035500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1036500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1037500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1038500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1039500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1040500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1041500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1042500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1043500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1044500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1045500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1046500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1047500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1048500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1049500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1050500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1051500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1052500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1053500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1054500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1055500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1056500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1057500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1058500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1059500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1060500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1061500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1062500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1063500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1064500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1065500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1066500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1067500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1068500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1069500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1070500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1071500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1072500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1073500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1074500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1075500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1076500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1077500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1078500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1079500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1080500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1081500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1082500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1083500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1084500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1085500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1086500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1087500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1088500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1089500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1090500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1091500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1092500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1093500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1094500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1095500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1096500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1097500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1098500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1099500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1100500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1101500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1102500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1103500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1104500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1105500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1106500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1107500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1108500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1109500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1110500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1111500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1112500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1113500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1114500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1115500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1116500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1117500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1118500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1119500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1120500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1121500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1122500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1123500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1124500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1125500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1126500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1127500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1128500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1129500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1130500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1131500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1132500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1133500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1134500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1135500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1136500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1137500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1138500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1139500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1140500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1141500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1142500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1143500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1144500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1145500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1146500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1147500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1148500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1149500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1150500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1151500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1152500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1153500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1154500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1155500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1156500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1157500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1158500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1159500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1160500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1161500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1162500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1163500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1164500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1165500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1166500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1167500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1168500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1169500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1170500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1171500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1172500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1173500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1174500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1175500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1176500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1177500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1178500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1179500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1180500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1181500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1182500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1183500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1184500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1185500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1186500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1187500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1188500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1189500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1190500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1191500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1192500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1193500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1194500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1195500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1196500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1197500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1198500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1199500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1200500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1201500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1202500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1203500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1204500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1205500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1206500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1207500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1208500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1209500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1210500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1211500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1212500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1213500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1214500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1215500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1216500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1217500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1218500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1219500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1220500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1221500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1222500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1223500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1224500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1225500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1226500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1227500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1228500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1229500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1230500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1231500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1232500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1233500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1234500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1235500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1236500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1237500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1238500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1239500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1240500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1241500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1242500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1243500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1244500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1245500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1246500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1247500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1248500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1249500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1250500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1251500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1252500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1253500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1254500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1255500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1256500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1257500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1258500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1259500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1260500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1261500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1262500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1263500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1264500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1265500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1266500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1267500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1268500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1269500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1270500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1271500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1272500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1273500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1274500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1275500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1276500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1277500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1278500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1279500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1280500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1281500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1282500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1283500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1284500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1285500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1286500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1287500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1288500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1289500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1290500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1291500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1292500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1293500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1294500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1295500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1296500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1297500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1298500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1299500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1300500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1301500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1302500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1303500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1304500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1305500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1306500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1307500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1308500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1309500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1310500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1311500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1312500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1313500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1314500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1315500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1316500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1317500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1318500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1319500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1320500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1321500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1322500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1323500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1324500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1325500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1326500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1327500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1328500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1329500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1330500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1331500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1332500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1333500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1334500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1335500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1336500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1337500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1338500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1339500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1340500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1341500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1342500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1343500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1344500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1345500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1346500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1347500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1348500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1349500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1350500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1351500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1352500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1353500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1354500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1355500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1356500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1357500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1358500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1359500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1360500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1361500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1362500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1363500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1364500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1365500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1366500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1367500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1368500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1369500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1370500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1371500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1372500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1373500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1374500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1375500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1376500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1377500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1378500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1379500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1380500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1381500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1382500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1383500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1384500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1385500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1386500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1387500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1388500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1389500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1390500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1391500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1392500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1393500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1394500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1395500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1396500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1397500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1398500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1399500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1400500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1401500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1402500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1403500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1404500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1405500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1406500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1407500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1408500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1409500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1410500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1411500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1412500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1413500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1414500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1415500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1416500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1417500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1418500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1419500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1420500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1421500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1422500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1423500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1424500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1425500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1426500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1427500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1428500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1429500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1430500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1431500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1432500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1433500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1434500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1435500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1436500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1437500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1438500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1439500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1440500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1441500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1442500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1443500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1444500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1445500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1446500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1447500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1448500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1449500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1450500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1451500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1452500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1453500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1454500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1455500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1456500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1457500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1458500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1459500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1460500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1461500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1462500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1463500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1464500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1465500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1466500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1467500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1468500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1469500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1470500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1471500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1472500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1473500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1474500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1475500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1476500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1477500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1478500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1479500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1480500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1481500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1482500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1483500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1484500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1485500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1486500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1487500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1488500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1489500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1490500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1491500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1492500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1493500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1494500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1495500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1496500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1497500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1498500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1499500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1500500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1501500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1502500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1503500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1504500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1505500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1506500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1507500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1508500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1509500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1510500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1511500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1512500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1513500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1514500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1515500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1516500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1517500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1518500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1519500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1520500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1521500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1522500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1523500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1524500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1525500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1526500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1527500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1528500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1529500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1530500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1531500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1532500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1533500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1534500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1535500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1536500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1537500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1538500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1539500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1540500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1541500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1542500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1543500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1544500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1545500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1546500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1547500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1548500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1549500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1550500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1551500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1552500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1553500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1554500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1555500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1556500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1557500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1558500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1559500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1560500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1561500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1562500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1563500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1564500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1565500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1566500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1567500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1568500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1569500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1570500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1571500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1572500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1573500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1574500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1575500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1576500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1577500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1578500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1579500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1580500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1581500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1582500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1583500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1584500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1585500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1586500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1587500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1588500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1589500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1590500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1591500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1592500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1593500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1594500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1595500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1596500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1597500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1598500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1599500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1600500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1601500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1602500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1603500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1604500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1605500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1606500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1607500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1608500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1609500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1610500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1611500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1612500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1613500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1614500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1615500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1616500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1617500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1618500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1619500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1620500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1621500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1622500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1623500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1624500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1625500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1626500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1627500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1628500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1629500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1630500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1631500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1632500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1633500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1634500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1635500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1636500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1637500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1638500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1639500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1640500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1641500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1642500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1643500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1644500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1645500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1646500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1647500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1648500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1649500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1650500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1651500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1652500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1653500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1654500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1655500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1656500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1657500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1658500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1659500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1660500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1661500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1662500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1663500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1664500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1665500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1666500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1667500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1668500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1669500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1670500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1671500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1672500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1673500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1674500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1675500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1676500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1677500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1678500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1679500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1680500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1681500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1682500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1683500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1684500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1685500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1686500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1687500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1688500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1689500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1690500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1691500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1692500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1693500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1694500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1695500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1696500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1697500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1698500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1699500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1700500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1701500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1702500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1703500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1704500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1705500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1706500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1707500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1708500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1709500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1710500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1711500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1712500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1713500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1714500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1715500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1716500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1717500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1718500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1719500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1720500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1721500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1722500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1723500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1724500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1725500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1726500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1727500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1728500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1729500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1730500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1731500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1732500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1733500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1734500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1735500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1736500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1737500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1738500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1739500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1740500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1741500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1742500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1743500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1744500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1745500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1746500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1747500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1748500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1749500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1750500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1751500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1752500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1753500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1754500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1755500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1756500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1757500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1758500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1759500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1760500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1761500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1762500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1763500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1764500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1765500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1766500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1767500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1768500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1769500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1770500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1771500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1772500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1773500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1774500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1775500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1776500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1777500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1778500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1779500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1780500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1781500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1782500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1783500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1784500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1785500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1786500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1787500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1788500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1789500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1790500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1791500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1792500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1793500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1794500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1795500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1796500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1797500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1798500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1799500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1800500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1801500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1802500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1803500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1804500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1805500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1806500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1807500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1808500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1809500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1810500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1811500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1812500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1813500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1814500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1815500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1816500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1817500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1818500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1819500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1820500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1821500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1822500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1823500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1824500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1825500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1826500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1827500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1828500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1829500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1830500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1831500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1832500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1833500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1834500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1835500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1836500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1837500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1838500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1839500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1840500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1841500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1842500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1843500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1844500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1845500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1846500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1847500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1848500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1849500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1850500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1851500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1852500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1853500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1854500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1855500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1856500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1857500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1858500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1859500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1860500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1861500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1862500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1863500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1864500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1865500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1866500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1867500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1868500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1869500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1870500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1871500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1872500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1873500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1874500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1875500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1876500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1877500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1878500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1879500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1880500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1881500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1882500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1883500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1884500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1885500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1886500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1887500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1888500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1889500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1890500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1891500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1892500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1893500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1894500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1895500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1896500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1897500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1898500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1899500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1900500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1901500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1902500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1903500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1904500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1905500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1906500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1907500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1908500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1909500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1910500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1911500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1912500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1913500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1914500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1915500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1916500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1917500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1918500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1919500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1920500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1921500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1922500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1923500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1924500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1925500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1926500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1927500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1928500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1929500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1930500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1931500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1932500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1933500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1934500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1935500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1936500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1937500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1938500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1939500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1940500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1941500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1942500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1943500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1944500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1945500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1946500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1947500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1948500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1949500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1950500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1951500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1952500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1953500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1954500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1955500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1956500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1957500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1958500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1959500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1960500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1961500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1962500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1963500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1964500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1965500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1966500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1967500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1968500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1969500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1970500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1971500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1972500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1973500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1974500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1975500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1976500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1977500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1978500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1979500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1980500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1981500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1982500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1983500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1984500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1985500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1986500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1987500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1988500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1989500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1990500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1991500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1992500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1993500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1994500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1995500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1996500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1997500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1998500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 1999500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2000500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2001500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2002500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2003500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2004500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2005500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2006500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2007500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2008500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2009500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2010500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2011500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2012500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2013500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2014500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2015500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2016500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2017500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2018500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2019500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2020500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2021500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2022500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2023500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2024500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2025500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2026500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2027500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2028500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2029500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2030500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2031500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2032500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2033500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2034500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2035500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2036500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2037500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2038500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2039500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2040500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2041500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2042500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2043500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2044500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2045500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2046500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2047500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2048500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2049500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2050500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2051500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2052500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2053500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2054500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2055500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2056500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2057500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2058500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2059500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2060500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2061500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2062500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2063500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2064500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2065500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2066500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2067500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2068500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2069500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2070500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2071500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2072500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2073500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2074500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2075500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2076500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2077500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2078500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2079500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2080500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2081500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2082500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2083500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2084500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2085500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2086500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2087500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2088500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2089500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2090500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2091500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2092500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2093500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2094500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2095500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2096500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2097500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2098500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2099500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2100500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2101500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2102500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2103500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2104500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2105500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2106500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2107500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2108500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2109500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2110500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2111500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2112500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2113500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2114500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2115500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2116500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2117500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2118500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2119500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2120500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2121500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2122500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2123500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2124500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2125500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2126500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2127500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2128500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2129500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2130500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2131500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2132500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2133500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2134500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2135500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2136500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2137500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2138500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2139500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2140500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2141500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2142500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2143500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2144500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2145500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2146500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2147500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2148500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2149500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2150500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2151500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2152500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2153500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2154500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2155500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2156500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2157500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2158500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2159500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2160500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2161500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2162500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2163500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2164500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2165500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2166500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2167500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2168500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2169500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2170500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2171500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2172500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2173500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2174500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2175500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2176500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2177500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2178500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2179500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2180500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2181500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2182500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2183500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2184500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2185500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2186500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2187500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2188500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2189500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2190500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2191500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2192500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2193500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2194500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2195500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2196500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2197500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2198500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2199500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2200500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2201500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2202500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2203500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2204500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2205500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2206500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2207500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2208500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2209500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2210500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2211500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2212500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2213500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2214500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2215500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2216500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2217500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2218500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2219500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2220500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2221500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2222500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2223500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2224500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2225500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2226500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2227500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2228500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2229500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2230500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2231500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2232500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2233500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2234500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2235500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2236500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2237500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2238500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2239500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2240500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2241500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2242500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2243500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2244500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2245500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2246500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2247500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2248500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2249500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2250500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2251500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2252500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2253500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2254500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2255500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2256500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2257500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2258500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2259500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2260500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2261500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2262500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2263500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2264500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2265500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2266500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2267500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2268500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2269500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2270500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2271500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2272500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2273500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2274500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2275500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2276500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2277500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2278500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2279500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2280500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2281500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2282500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2283500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2284500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2285500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2286500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2287500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2288500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2289500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2290500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2291500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2292500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2293500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2294500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2295500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2296500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2297500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2298500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2299500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2300500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2301500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2302500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2303500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2304500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2305500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2306500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2307500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2308500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2309500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2310500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2311500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2312500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2313500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2314500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2315500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2316500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2317500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2318500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2319500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2320500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2321500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2322500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2323500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2324500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2325500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2326500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2327500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2328500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2329500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2330500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2331500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2332500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2333500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2334500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2335500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2336500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2337500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2338500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2339500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2340500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2341500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2342500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2343500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2344500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2345500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2346500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2347500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2348500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2349500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2350500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2351500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2352500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2353500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2354500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2355500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2356500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2357500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2358500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2359500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2360500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2361500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2362500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2363500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2364500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2365500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2366500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2367500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2368500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2369500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2370500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2371500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2372500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2373500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2374500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2375500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2376500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2377500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2378500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2379500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2380500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2381500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2382500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2383500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2384500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2385500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2386500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2387500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2388500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2389500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2390500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2391500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2392500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2393500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2394500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2395500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2396500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2397500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2398500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2399500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2400500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2401500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2402500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2403500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2404500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2405500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2406500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2407500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2408500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2409500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2410500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2411500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2412500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2413500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2414500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2415500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2416500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2417500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2418500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2419500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2420500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2421500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2422500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2423500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2424500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2425500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2426500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2427500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2428500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2429500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2430500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2431500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2432500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2433500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2434500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2435500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2436500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2437500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2438500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2439500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2440500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2441500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2442500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2443500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2444500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2445500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2446500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2447500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2448500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2449500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2450500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2451500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2452500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2453500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2454500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2455500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2456500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2457500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2458500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2459500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2460500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2461500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2462500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2463500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2464500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2465500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2466500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2467500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2468500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2469500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2470500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2471500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2472500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2473500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2474500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2475500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2476500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2477500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2478500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2479500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2480500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2481500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2482500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2483500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2484500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2485500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2486500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2487500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2488500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2489500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2490500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2491500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2492500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2493500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2494500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2495500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2496500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2497500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2498500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2499500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2500500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2501500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2502500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2503500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2504500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2505500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2506500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2507500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2508500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2509500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2510500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2511500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2512500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2513500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2514500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2515500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2516500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2517500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2518500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2519500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2520500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2521500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2522500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2523500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2524500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2525500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2526500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2527500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2528500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2529500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2530500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2531500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2532500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2533500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2534500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2535500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2536500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2537500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2538500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2539500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2540500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2541500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2542500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2543500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2544500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2545500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2546500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2547500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2548500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2549500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2550500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2551500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2552500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2553500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2554500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2555500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2556500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2557500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2558500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2559500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2560500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2561500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2562500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2563500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2564500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2565500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2566500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2567500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2568500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2569500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2570500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2571500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2572500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2573500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2574500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2575500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2576500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2577500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2578500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2579500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2580500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2581500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2582500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2583500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2584500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2585500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2586500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2587500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2588500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2589500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2590500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2591500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2592500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2593500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2594500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2595500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2596500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2597500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2598500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2599500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2600500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2601500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2602500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2603500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2604500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2605500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2606500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2607500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2608500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2609500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2610500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2611500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2612500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2613500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2614500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2615500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2616500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2617500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2618500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2619500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2620500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2621500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2622500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2623500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2624500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2625500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2626500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2627500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2628500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2629500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2630500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2631500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2632500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2633500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2634500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2635500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2636500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2637500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2638500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2639500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2640500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2641500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2642500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2643500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2644500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2645500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2646500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2647500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2648500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2649500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2650500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2651500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2652500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2653500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2654500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2655500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2656500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2657500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2658500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2659500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2660500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2661500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2662500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2663500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2664500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2665500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2666500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2667500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2668500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2669500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2670500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2671500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2672500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2673500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2674500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2675500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2676500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2677500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2678500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2679500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2680500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2681500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2682500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2683500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2684500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2685500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2686500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2687500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2688500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2689500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2690500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2691500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2692500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2693500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2694500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2695500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2696500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2697500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2698500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2699500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2700500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2701500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2702500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2703500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2704500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2705500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2706500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2707500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2708500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2709500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2710500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2711500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2712500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2713500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2714500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2715500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2716500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2717500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2718500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2719500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2720500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2721500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2722500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2723500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2724500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2725500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2726500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2727500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2728500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2729500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2730500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2731500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2732500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2733500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2734500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2735500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2736500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2737500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2738500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2739500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2740500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2741500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2742500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2743500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2744500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2745500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2746500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2747500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2748500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2749500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2750500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2751500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2752500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2753500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2754500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2755500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2756500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2757500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2758500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2759500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2760500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2761500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2762500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2763500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2764500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2765500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2766500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2767500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2768500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2769500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2770500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2771500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2772500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2773500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2774500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2775500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2776500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2777500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2778500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2779500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2780500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2781500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2782500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2783500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2784500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2785500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2786500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2787500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2788500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2789500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2790500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2791500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2792500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2793500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2794500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2795500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2796500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2797500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2798500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2799500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2800500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2801500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2802500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2803500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2804500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2805500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2806500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2807500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2808500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2809500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2810500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2811500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2812500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2813500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2814500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2815500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2816500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2817500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2818500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2819500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2820500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2821500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2822500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2823500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2824500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2825500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2826500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2827500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2828500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2829500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2830500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2831500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2832500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2833500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2834500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2835500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2836500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2837500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2838500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2839500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2840500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2841500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2842500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2843500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2844500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2845500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2846500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2847500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2848500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2849500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2850500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2851500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2852500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2853500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2854500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2855500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2856500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2857500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2858500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2859500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2860500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2861500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2862500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2863500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2864500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2865500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2866500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2867500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2868500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2869500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2870500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2871500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2872500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2873500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2874500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2875500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2876500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2877500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2878500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2879500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2880500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2881500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2882500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2883500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2884500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2885500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2886500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2887500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2888500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2889500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2890500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2891500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2892500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2893500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2894500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2895500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2896500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2897500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2898500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2899500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2900500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2901500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2902500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2903500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2904500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2905500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2906500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2907500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2908500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2909500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2910500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2911500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2912500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2913500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2914500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2915500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2916500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2917500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2918500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2919500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2920500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2921500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2922500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2923500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2924500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2925500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2926500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2927500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2928500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2929500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2930500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2931500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2932500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2933500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2934500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2935500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2936500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2937500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2938500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2939500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2940500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2941500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2942500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2943500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2944500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2945500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2946500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2947500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2948500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2949500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2950500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2951500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2952500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2953500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2954500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2955500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2956500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2957500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2958500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2959500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2960500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2961500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2962500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2963500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2964500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2965500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2966500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2967500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2968500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2969500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2970500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2971500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2972500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2973500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2974500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2975500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2976500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2977500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2978500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2979500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2980500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2981500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2982500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2983500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2984500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2985500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2986500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2987500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2988500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2989500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2990500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2991500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2992500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2993500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2994500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2995500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2996500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2997500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2998500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 2999500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3000500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3001500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3002500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3003500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3004500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3005500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3006500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3007500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3008500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3009500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3010500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3011500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3012500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3013500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3014500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3015500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3016500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3017500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3018500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3019500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3020500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3021500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3022500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3023500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3024500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3025500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3026500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3027500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3028500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3029500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3030500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3031500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3032500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3033500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3034500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3035500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3036500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3037500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3038500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3039500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3040500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3041500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3042500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3043500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3044500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3045500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3046500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3047500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3048500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3049500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3050500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3051500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3052500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3053500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3054500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3055500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3056500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3057500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3058500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3059500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3060500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3061500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3062500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3063500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3064500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3065500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3066500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3067500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3068500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3069500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3070500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3071500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3072500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3073500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3074500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3075500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3076500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3077500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3078500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3079500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3080500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3081500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3082500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3083500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3084500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3085500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3086500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3087500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3088500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3089500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3090500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3091500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3092500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3093500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3094500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3095500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3096500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3097500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3098500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3099500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3100500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3101500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3102500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3103500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3104500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3105500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3106500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3107500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3108500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3109500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3110500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3111500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3112500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3113500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3114500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3115500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3116500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3117500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3118500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3119500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3120500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3121500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3122500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3123500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3124500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3125500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3126500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3127500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3128500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3129500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3130500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3131500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3132500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3133500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3134500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3135500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3136500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3137500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3138500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3139500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3140500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3141500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3142500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3143500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3144500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3145500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3146500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3147500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3148500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3149500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3150500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3151500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3152500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3153500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3154500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3155500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3156500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3157500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3158500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3159500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3160500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3161500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3162500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3163500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3164500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3165500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3166500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3167500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3168500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3169500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3170500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3171500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3172500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3173500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3174500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3175500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3176500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3177500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3178500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3179500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3180500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3181500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3182500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3183500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3184500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3185500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3186500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3187500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3188500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3189500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3190500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3191500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3192500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3193500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3194500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3195500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3196500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3197500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3198500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3199500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3200500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3201500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3202500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3203500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3204500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3205500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3206500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3207500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3208500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3209500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3210500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3211500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3212500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3213500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3214500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3215500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3216500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3217500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3218500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3219500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3220500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3221500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3222500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3223500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3224500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3225500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3226500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3227500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3228500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3229500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3230500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3231500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3232500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3233500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3234500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3235500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3236500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3237500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3238500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3239500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3240500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3241500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3242500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3243500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3244500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3245500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3246500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3247500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3248500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3249500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3250500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3251500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3252500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3253500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3254500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3255500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3256500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3257500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3258500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3259500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3260500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3261500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3262500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3263500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3264500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3265500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3266500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3267500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3268500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3269500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3270500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3271500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3272500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3273500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3274500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3275500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3276500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3277500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3278500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3279500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3280500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3281500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3282500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3283500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3284500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3285500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3286500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3287500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3288500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3289500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3290500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3291500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3292500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3293500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3294500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3295500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3296500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3297500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3298500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3299500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3300500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3301500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3302500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3303500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3304500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3305500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3306500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3307500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3308500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3309500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3310500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3311500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3312500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3313500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3314500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3315500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3316500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3317500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3318500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3319500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3320500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3321500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3322500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3323500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3324500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3325500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3326500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3327500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3328500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3329500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3330500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3331500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3332500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3333500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3334500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3335500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3336500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3337500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3338500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3339500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3340500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3341500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3342500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3343500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3344500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3345500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3346500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3347500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3348500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3349500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3350500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3351500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3352500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3353500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3354500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3355500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3356500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3357500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3358500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3359500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3360500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3361500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3362500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3363500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3364500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3365500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3366500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3367500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3368500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3369500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3370500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3371500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3372500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3373500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3374500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3375500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3376500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3377500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3378500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3379500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3380500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3381500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3382500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3383500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3384500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3385500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3386500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3387500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3388500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3389500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3390500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3391500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3392500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3393500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3394500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3395500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3396500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3397500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3398500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3399500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3400500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3401500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3402500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3403500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3404500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3405500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3406500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3407500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3408500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3409500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3410500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3411500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3412500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3413500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3414500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3415500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3416500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3417500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3418500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3419500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3420500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3421500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3422500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3423500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3424500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3425500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3426500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3427500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3428500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3429500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3430500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3431500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3432500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3433500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3434500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3435500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3436500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3437500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3438500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3439500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3440500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3441500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3442500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3443500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3444500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3445500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3446500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3447500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3448500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3449500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3450500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3451500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3452500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3453500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3454500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3455500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3456500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3457500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3458500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3459500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3460500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3461500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3462500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3463500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3464500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3465500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3466500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3467500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3468500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3469500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3470500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3471500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3472500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3473500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3474500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3475500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3476500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3477500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3478500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3479500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3480500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3481500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3482500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3483500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3484500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3485500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3486500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3487500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3488500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3489500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3490500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3491500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3492500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3493500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3494500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3495500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3496500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3497500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3498500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3499500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3500500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3501500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3502500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3503500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3504500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3505500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3506500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3507500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3508500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3509500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3510500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3511500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3512500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3513500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3514500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3515500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3516500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3517500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3518500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3519500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3520500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3521500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3522500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3523500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3524500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3525500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3526500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3527500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3528500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3529500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3530500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3531500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3532500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3533500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3534500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3535500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3536500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3537500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3538500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3539500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3540500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3541500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3542500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3543500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3544500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3545500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3546500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3547500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3548500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3549500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3550500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3551500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3552500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3553500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3554500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3555500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3556500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3557500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3558500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3559500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3560500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3561500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3562500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3563500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3564500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3565500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3566500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3567500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3568500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3569500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3570500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3571500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3572500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3573500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3574500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3575500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3576500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3577500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3578500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3579500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3580500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3581500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3582500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3583500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3584500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3585500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3586500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3587500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3588500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3589500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3590500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3591500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3592500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3593500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3594500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3595500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3596500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3597500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3598500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3599500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3600500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3601500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3602500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3603500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3604500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3605500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3606500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3607500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3608500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3609500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3610500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3611500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3612500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3613500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3614500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3615500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3616500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3617500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3618500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3619500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3620500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3621500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3622500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3623500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3624500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3625500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3626500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3627500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3628500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3629500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3630500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3631500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3632500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3633500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3634500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3635500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3636500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3637500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3638500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3639500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3640500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3641500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3642500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3643500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3644500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3645500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3646500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3647500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3648500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3649500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3650500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3651500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3652500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3653500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3654500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3655500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3656500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3657500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3658500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3659500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3660500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3661500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3662500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3663500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3664500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3665500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3666500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3667500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3668500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3669500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3670500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3671500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3672500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3673500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3674500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3675500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3676500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3677500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3678500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3679500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3680500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3681500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3682500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3683500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3684500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3685500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3686500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3687500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3688500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3689500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3690500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3691500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3692500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3693500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3694500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3695500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3696500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3697500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3698500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3699500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3700500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3701500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3702500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3703500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3704500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3705500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3706500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3707500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3708500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3709500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3710500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3711500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3712500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3713500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3714500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3715500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3716500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3717500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3718500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3719500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3720500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3721500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3722500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3723500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3724500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3725500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3726500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3727500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3728500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3729500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3730500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3731500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3732500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3733500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3734500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3735500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3736500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3737500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3738500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3739500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3740500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3741500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3742500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3743500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3744500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3745500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3746500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3747500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3748500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3749500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3750500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3751500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3752500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3753500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3754500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3755500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3756500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3757500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3758500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3759500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3760500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3761500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3762500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3763500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3764500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3765500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3766500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3767500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3768500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3769500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3770500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3771500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3772500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3773500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3774500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3775500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3776500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3777500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3778500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3779500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3780500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3781500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3782500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3783500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3784500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3785500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3786500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3787500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3788500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3789500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3790500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3791500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3792500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3793500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3794500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3795500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3796500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3797500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3798500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3799500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3800500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3801500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3802500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3803500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3804500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3805500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3806500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3807500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3808500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3809500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3810500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3811500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3812500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3813500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3814500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3815500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3816500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3817500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3818500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3819500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3820500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3821500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3822500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3823500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3824500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3825500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3826500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3827500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3828500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3829500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3830500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3831500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3832500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3833500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3834500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3835500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3836500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3837500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3838500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3839500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3840500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3841500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3842500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3843500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3844500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3845500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3846500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3847500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3848500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3849500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3850500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3851500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3852500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3853500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3854500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3855500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3856500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3857500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3858500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3859500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3860500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3861500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3862500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3863500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3864500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3865500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3866500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3867500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3868500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3869500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3870500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3871500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3872500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3873500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3874500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3875500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3876500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3877500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3878500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3879500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3880500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3881500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3882500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3883500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3884500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3885500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3886500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3887500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3888500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3889500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3890500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3891500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3892500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3893500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3894500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3895500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3896500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3897500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3898500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3899500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3900500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3901500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3902500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3903500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3904500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3905500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3906500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3907500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3908500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3909500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3910500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3911500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3912500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3913500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3914500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3915500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3916500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3917500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3918500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3919500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3920500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3921500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3922500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3923500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3924500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3925500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3926500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3927500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3928500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3929500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3930500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3931500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3932500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3933500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3934500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3935500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3936500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3937500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3938500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3939500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3940500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3941500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3942500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3943500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3944500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3945500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3946500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3947500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3948500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3949500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3950500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3951500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3952500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3953500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3954500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3955500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3956500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3957500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3958500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3959500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3960500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3961500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3962500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3963500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3964500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3965500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3966500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3967500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3968500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3969500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3970500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3971500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3972500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3973500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3974500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3975500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3976500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3977500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3978500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3979500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3980500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3981500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3982500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3983500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3984500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3985500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3986500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3987500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3988500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3989500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3990500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3991500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3992500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3993500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3994500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3995500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3996500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3997500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3998500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 3999500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4000500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4001500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4002500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4003500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4004500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4005500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4006500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4007500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4008500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4009500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4010500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4011500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4012500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4013500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4014500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4015500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4016500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4017500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4018500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4019500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4020500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4021500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4022500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4023500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4024500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4025500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4026500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4027500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4028500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4029500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4030500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4031500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4032500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4033500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4034500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4035500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4036500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4037500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4038500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4039500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4040500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4041500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4042500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4043500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4044500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4045500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4046500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4047500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4048500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4049500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4050500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4051500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4052500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4053500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4054500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4055500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4056500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4057500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4058500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4059500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4060500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4061500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4062500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4063500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4064500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4065500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4066500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4067500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4068500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4069500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4070500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4071500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4072500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4073500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4074500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4075500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4076500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4077500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4078500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4079500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4080500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4081500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4082500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4083500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4084500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4085500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4086500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4087500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4088500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4089500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4090500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4091500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4092500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4093500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4094500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 + 4095500000 0.0001 75000000 7.97972173744e+16 1e-10 0.989999998 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 \ No newline at end of file From e19c0bdaafa74ce6b3a2f773d2087b84d373628b Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Thu, 14 Mar 2024 15:54:10 -0400 Subject: [PATCH 23/56] add a readme for subchandra (#2776) also fix a typo and formatting in the flame_wave readme --- Exec/science/flame_wave/README.md | 26 ++++++++++++++++---------- Exec/science/subchandra/README.md | 24 ++++++++++++++++++++++++ 2 files changed, 40 insertions(+), 10 deletions(-) create mode 100644 Exec/science/subchandra/README.md diff --git a/Exec/science/flame_wave/README.md b/Exec/science/flame_wave/README.md index 8deea3ff37..d062c58f61 100644 --- a/Exec/science/flame_wave/README.md +++ b/Exec/science/flame_wave/README.md @@ -1,19 +1,23 @@ # flame_wave -This is the XRB flame setup. I has been used for several -papers, including: +This is the XRB flame setup. It has been used for several papers, +including: -* Eiden et al. 2020 (https://ui.adsabs.harvard.edu/abs/2020ApJ...894....6E) +* Eiden et al. 2020 + (https://ui.adsabs.harvard.edu/abs/2020ApJ...894....6E) This modeled pure He flames and used "boosted" flames, which were artificially sped up. -* Harpole et al. 2021 (https://ui.adsabs.harvard.edu/abs/2021ApJ...912...36H/abstract) +* Harpole et al. 2021 + (https://ui.adsabs.harvard.edu/abs/2021ApJ...912...36H/abstract) - This also modeled pure He flames, but without any boosting. A variety of - rotation rates were explored. The inputs files for this are in `inputs_He/` + This also modeled pure He flames, but without any boosting. A + variety of rotation rates were explored. The inputs files for this + are in `inputs_He/` -* Zingale et al. 2023 (https://ui.adsabs.harvard.edu/abs/2023ApJ...952..160Z/abstract) +* Zingale et al. 2023 + (https://ui.adsabs.harvard.edu/abs/2023ApJ...952..160Z/abstract) This explored both 2D and 3D pure He flames. Another change was in the lower boundary condition -- a reflecting boundary was used an @@ -21,8 +25,10 @@ papers, including: `inputs_He/` and also available on Zenodo: https://zenodo.org/record/7692201 -* Chen et al. 2023 (https://ui.adsabs.harvard.edu/abs/2023ApJ...955..128C/abstract) +* Chen et al. 2023 + (https://ui.adsabs.harvard.edu/abs/2023ApJ...955..128C/abstract) - This looked at 2D pure He flames and explored different reaction networks. - The inputs files are available on Zenodo: https://zenodo.org/record/8117761 + This looked at 2D pure He flames and explored different reaction + networks. The inputs files are available on Zenodo: + https://zenodo.org/record/8117761 diff --git a/Exec/science/subchandra/README.md b/Exec/science/subchandra/README.md new file mode 100644 index 0000000000..d0f2c17c84 --- /dev/null +++ b/Exec/science/subchandra/README.md @@ -0,0 +1,24 @@ +# subchandra + +This is the double detonation Type Ia supernova setup. It takes a 1-d +initial model representing a sub-Chandra WD and a surface He layer and +initializes a small perturbation at the pole in the He layer. + +Initial models for this setup can be created via +https://github.com/AMReX-Astro/initial_models in the sub_chandra/ directory. + +This setup has been used in the following papers: + +* Zingale et al. 2022 + (https://ui.adsabs.harvard.edu/abs/2022ApJ...936....6Z/abstract) + + This paper introduced the simplified-SDC time-integration method and + used the double detonation setup as a test problem. + +* Zingale et al. 2024 + (https://ui.adsabs.harvard.edu/abs/2023arXiv230901802Z/abstract) + + This paper showed that the simplified-SDC method can model double + detonations without cutting the timestep or limiting the reaction + rates. It also explored disabling burning in shocks for this + problem. From 46ece2f8ac04d90fdf984ac65d93c19fc2e0b118 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Fri, 15 Mar 2024 08:48:31 -0400 Subject: [PATCH 24/56] fix a bounds issue in sources in true SDC (#2775) We were sometimes reading invalid data depending on what options were set. --- Source/driver/Castro_advance_sdc.cpp | 74 ++++++++++++++-------------- Source/hydro/Castro_mol_hydro.cpp | 5 +- 2 files changed, 40 insertions(+), 39 deletions(-) diff --git a/Source/driver/Castro_advance_sdc.cpp b/Source/driver/Castro_advance_sdc.cpp index 2d0463aa1f..83b226c7bc 100644 --- a/Source/driver/Castro_advance_sdc.cpp +++ b/Source/driver/Castro_advance_sdc.cpp @@ -94,54 +94,54 @@ Castro::do_advance_sdc (Real time, #endif if (apply_sources()) { - if (sdc_order == 4) { - // if we are 4th order, convert to cell-center Sborder -> Sborder_cc - // we'll use Sburn for this memory buffer at the moment + if (sdc_order == 4) { + // if we are 4th order, convert to cell-center Sborder -> Sborder_cc + // we'll use Sburn for this memory buffer at the moment - for (MFIter mfi(S_new); mfi.isValid(); ++mfi) { - const Box& gbx = mfi.growntilebox(1); + for (MFIter mfi(S_new); mfi.isValid(); ++mfi) { + const Box& gbx = mfi.growntilebox(1); - make_cell_center(gbx, Sborder.array(mfi), Sburn.array(mfi), domain_lo, domain_hi); + make_cell_center(gbx, Sborder.array(mfi), Sburn.array(mfi), domain_lo, domain_hi); - } + } + + // we pass in the stage time here + do_old_sources(old_source, Sburn, Sburn, node_time, dt, apply_sources_to_state); - // we pass in the stage time here - do_old_sources(old_source, Sburn, Sburn, node_time, dt, apply_sources_to_state); + // fill the ghost cells for the sources -- note since we have + // not defined the new_source yet, we either need to copy this + // into new_source for the time-interpolation in the ghost + // fill to make sense, or so long as we are not multilevel, + // just use the old time (prev_time) in the fill instead of + // the node time (time) + AmrLevel::FillPatch(*this, old_source, old_source.nGrow(), prev_time, Source_Type, 0, NSRC); - // fill the ghost cells for the sources -- note since we have - // not defined the new_source yet, we either need to copy this - // into new_source for the time-interpolation in the ghost - // fill to make sense, or so long as we are not multilevel, - // just use the old time (prev_time) in the fill instead of - // the node time (time) - AmrLevel::FillPatch(*this, old_source, old_source.nGrow(), prev_time, Source_Type, 0, NSRC); + // Now convert to cell averages. This loop cannot be tiled. + FArrayBox tmp; - // Now convert to cell averages. This loop cannot be tiled. - FArrayBox tmp; + for (MFIter mfi(S_new); mfi.isValid(); ++mfi) { + const Box& bx = mfi.tilebox(); - for (MFIter mfi(S_new); mfi.isValid(); ++mfi) { - const Box& bx = mfi.tilebox(); + tmp.resize(bx, 1, The_Async_Arena()); + auto tmp_arr = tmp.array(); - tmp.resize(bx, 1, The_Async_Arena()); - auto tmp_arr = tmp.array(); + make_fourth_in_place(bx, old_source.array(mfi), tmp_arr, domain_lo, domain_hi); + } - make_fourth_in_place(bx, old_source.array(mfi), tmp_arr, domain_lo, domain_hi); + } else { + // there is a ghost cell fill hidden in diffusion, so we need + // to pass in the time associate with Sborder + do_old_sources(old_source, Sborder, Sborder, cur_time, dt, apply_sources_to_state); } - } else { - // there is a ghost cell fill hidden in diffusion, so we need - // to pass in the time associate with Sborder - do_old_sources(old_source, Sborder, Sborder, cur_time, dt, apply_sources_to_state); - } - - // note: we don't need a FillPatch on the sources, since they - // are only used in the valid box in the conservative flux - // update construction. The only exception is if we are doing - // the well-balanced method in the reconstruction of the - // pressure. - if (sdc_order == 2 && use_pslope == 1) { - AmrLevel::FillPatch(*this, old_source, old_source.nGrow(), prev_time, Source_Type, 0, NSRC); - } + // note: we don't need a FillPatch on the sources, since they + // are only used in the valid box in the conservative flux + // update construction. The only exception is if we are doing + // the well-balanced method in the reconstruction of the + // pressure. + if (sdc_order == 2 && use_pslope == 1) { + AmrLevel::FillPatch(*this, old_source, old_source.nGrow(), prev_time, Source_Type, 0, NSRC); + } } // Now compute the advective term for the current node -- this diff --git a/Source/hydro/Castro_mol_hydro.cpp b/Source/hydro/Castro_mol_hydro.cpp index b73e6b7047..4d7e0f32db 100644 --- a/Source/hydro/Castro_mol_hydro.cpp +++ b/Source/hydro/Castro_mol_hydro.cpp @@ -93,6 +93,7 @@ Castro::construct_mol_hydro_source(Real time, Real dt, MultiFab& A_update) const Box& obx = amrex::grow(bx, 1); const Box& obx2 = amrex::grow(bx, 2); + const Box& srcbx = amrex::grow(bx, old_source.nGrow()); Array4 const uin_arr = Sborder.array(mfi); @@ -140,12 +141,12 @@ Castro::construct_mol_hydro_source(Real time, Real dt, MultiFab& A_update) // primitive variable source terms const Box& qbx = amrex::grow(bx, NUM_GROW_SRC); - src_q.resize(qbx, NQSRC); + src_q.resize(srcbx, NQSRC); Array4 const src_q_arr = src_q.array(); if (sdc_order == 2) { - amrex::ParallelFor(qbx, + amrex::ParallelFor(srcbx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { hydro::src_to_prim(i, j, k, dt, uin_arr, q_arr, source_in_arr, src_q_arr); From 50f61c2d0084d5f9f8865267d16f3bc8ce094197 Mon Sep 17 00:00:00 2001 From: Max Katz Date: Sun, 17 Mar 2024 11:57:04 -0400 Subject: [PATCH 25/56] Fix some calls to volWgtSum (#2779) --- Source/driver/sum_integrated_quantities.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Source/driver/sum_integrated_quantities.cpp b/Source/driver/sum_integrated_quantities.cpp index 2398480765..5a41f9242c 100644 --- a/Source/driver/sum_integrated_quantities.cpp +++ b/Source/driver/sum_integrated_quantities.cpp @@ -75,9 +75,9 @@ Castro::sum_integrated_quantities () ang_mom[2] += ca_lev.volWgtSum("angular_momentum_z", time, local_flag); #ifdef HYBRID_MOMENTUM - hyb_mom[0] += ca_lev.volWgtSum(S_new, UMR, time, local_flag); - hyb_mom[1] += ca_lev.volWgtSum(S_new, UML, time, local_flag); - hyb_mom[2] += ca_lev.volWgtSum(S_new, UMP, time, local_flag); + hyb_mom[0] += ca_lev.volWgtSum(S_new, UMR, local_flag); + hyb_mom[1] += ca_lev.volWgtSum(S_new, UML, local_flag); + hyb_mom[2] += ca_lev.volWgtSum(S_new, UMP, local_flag); #endif com[0] += ca_lev.locWgtSum(S_new, URHO, 0, local_flag); From 3a323186ea519f02000b4761a54ea2413d36bbca Mon Sep 17 00:00:00 2001 From: Khanak Bhargava <56127611+khanakbhargava@users.noreply.github.com> Date: Sun, 17 Mar 2024 12:24:10 -0400 Subject: [PATCH 26/56] Latest inputs for wdmerger runs (#2778) --- .../tests/{pakmor_inputs => inputs_pakmor} | 41 +++++++++++++------ 1 file changed, 28 insertions(+), 13 deletions(-) rename Exec/science/wdmerger/tests/{pakmor_inputs => inputs_pakmor} (93%) diff --git a/Exec/science/wdmerger/tests/pakmor_inputs b/Exec/science/wdmerger/tests/inputs_pakmor similarity index 93% rename from Exec/science/wdmerger/tests/pakmor_inputs rename to Exec/science/wdmerger/tests/inputs_pakmor index b297967cc5..8cfa6d6027 100644 --- a/Exec/science/wdmerger/tests/pakmor_inputs +++ b/Exec/science/wdmerger/tests/inputs_pakmor @@ -1,3 +1,5 @@ +## Latest inputs file being used to reproduce initial conditions from Pakmor et al. 2022 +## with 50 km resolution ############################## CASTRO INPUTS ############################################### @@ -55,10 +57,10 @@ castro.hi_bc = 2 2 2 # Timestepping ############################################################################################ -# Maximum coarse timestep +# Maximum number of level 0 steps max_step = 10000000 -# Simulation time to stop at +# Simulation end time stop_time = 200.0 # CFL number for hyperbolic system @@ -85,6 +87,11 @@ castro.retry_small_density_cutoff = 1.0e0 # Don't abort for invalid X if the zone density is less than this threshold castro.abundance_failure_rho_cutoff = 1.0e0 +# Maximum number of subcycles +# Default is 10, 16 is recommended value +castro.max_subcycles = 16 + + ############################################################################################ # Resolution, gridding and AMR ############################################################################################ @@ -102,10 +109,10 @@ castro.abundance_failure_rho_cutoff = 1.0e0 #endif # Maximum level number allowed -amr.max_level = 1 +amr.max_level = 2 # Refinement ratio -amr.ref_ratio = 4 4 4 4 4 4 4 4 4 +amr.ref_ratio = 4 2 # How many coarse timesteps between regridding amr.regrid_int = 2 @@ -132,17 +139,22 @@ castro.state_interp_order = 0 castro.lin_limit_state_interp = 1 # Add refinement indicators -amr.refinement_indicators = density temperature +amr.refinement_indicators = density density2 temperature # Density refinement criterion amr.refine.density.value_greater = 1.0e0 amr.refine.density.field_name = density -amr.refine.density.max_level = 20 +amr.refine.density.max_level = 1 + +# Density2 refinement criterion +amr.refine.density2.value_greater = 1.0e5 +amr.refine.density2.field_name = density +amr.refine.density2.max_level = 20 # Temperature refinement criterion amr.refine.temperature.value_greater = 5.0e8 amr.refine.temperature.field_name = Temp -amr.refine.temperature.max_level = 0 +amr.refine.temperature.max_level = 3 # Avoid tagging near the domain boundary castro.max_tagging_radius = 0.75e0 @@ -244,10 +256,10 @@ castro.clamp_ambient_temp = 1 ############################################################################################ # Limit timestep based on nuclear burning considerations (changes in internal energy) -castro.dtnuc_e = 0.1 +castro.dtnuc_e = 1.e200 -# Limit timestep based on nuclear burning considerations (changes in species) -castro.dtnuc_X = 0.1 +#Limit timestep based on nuclear burning considerations (changes in species) +castro.dtnuc_X = 1.e200 # Minimum temperature for allowing nuclear burning castro.react_T_min = 1.0e8 @@ -393,7 +405,7 @@ amr.plotfile_on_restart = 1 amr.checkpoint_on_restart = 1 # Restart from last run -amr.restart = chk00528 +#amr.restart = # Control verbosity in Amr.cpp amr.v = 1 @@ -408,10 +420,13 @@ gravity.v = 1 amr.plot_vars = ALL # Derived variables to add to plot files -amr.derive_plot_vars = pressure X(q) +amr.derive_plot_vars = pressure # State variables to add to small plot files -amr.small_plot_vars = density Temp +amr.small_plot_vars = density Temp + +# Derived variables to add to small plot files +amr.derive_small_plot_vars = enuc X(He4) X(C12) X(O16) # Name of the diagnostic sum output files amr.data_log = star_diag.out primary_diag.out secondary_diag.out rotation_diag.out From 228a69ee46fb3eb7ebfc765b36e3bc0d2fb84b31 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 18 Mar 2024 19:04:17 -0400 Subject: [PATCH 27/56] don't have clang-tidy yell about do-while and recursion (#2780) these patterns are used a lot in AMReX --- .clang-tidy | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.clang-tidy b/.clang-tidy index 391149e1da..289d1ebbce 100644 --- a/.clang-tidy +++ b/.clang-tidy @@ -7,6 +7,7 @@ Checks: > clang-diagnostic-*, cppcoreguidelines-*, -cppcoreguidelines-avoid-c-arrays, + -cppcoreguidelines-avoid-do-while, -cppcoreguidelines-avoid-magic-numbers, -cppcoreguidelines-avoid-non-const-global-variables, -cppcoreguidelines-init-variables, @@ -20,6 +21,7 @@ Checks: > -misc-const-correctness, -misc-include-cleaner, -misc-non-private-member-variables-in-classes, + -misc-no-recursion, modernize-*, -modernize-avoid-c-arrays, -modernize-use-trailing-return-type, From 2e8fb11454a8886ceb9f51d292fda58e15b2a9b7 Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Mon, 18 Mar 2024 19:04:53 -0400 Subject: [PATCH 28/56] flame_wave: error out if atm_delta is too small (#2782) If atm_delta is significantly smaller than the finest-level resolution, the peak temperature gets reset to T_star instead of T_hi, and the hot and cool zones end up with the same temperature profiles. I'm not entirely sure how it happens, and it's probably fixable, but we shouldn't be doing any actual runs with such a low resolution anyways. I only ran into this when I was using a single level for local testing. --- Exec/science/flame_wave/ci-benchmarks/grid_diag.out | 6 +++--- Exec/science/flame_wave/ci-benchmarks/species_diag.out | 6 +++--- Exec/science/flame_wave/initial_model.H | 3 +++ Exec/science/flame_wave/inputs_2d.testsuite | 2 +- 4 files changed, 10 insertions(+), 7 deletions(-) diff --git a/Exec/science/flame_wave/ci-benchmarks/grid_diag.out b/Exec/science/flame_wave/ci-benchmarks/grid_diag.out index 2f054f110b..cb9fda8caa 100644 --- a/Exec/science/flame_wave/ci-benchmarks/grid_diag.out +++ b/Exec/science/flame_wave/ci-benchmarks/grid_diag.out @@ -1,5 +1,5 @@ # COLUMN 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 # TIMESTEP TIME MASS XMOM YMOM ZMOM ANG. MOM. X ANG. MOM. Y ANG. MOM. Z KIN. ENERGY INT. ENERGY GAS ENERGY GRAV. ENERGY TOTAL ENERGY CENTER OF MASS X-LOC CENTER OF MASS Y-LOC CENTER OF MASS Z-LOC CENTER OF MASS X-VEL CENTER OF MASS Y-VEL CENTER OF MASS Z-VEL MAXIMUM TEMPERATURE MAXIMUM DENSITY MAXIMUM T_S / T_E - 0 0.0000000000000000 1.4902024346464787e+20 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 2.9583337617665660e+37 2.9583337617665660e+37 0.0000000000000000e+00 2.9583337617665660e+37 2.7306640614148750e+04 6.8067773166795473e+02 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.0000000000156899e+08 3.1017131702472486e+07 0.0000000000000000e+00 - 1 5.9694928185132600e-08 1.4902038799260451e+20 -9.8852814000373391e+18 7.0758681407801342e+23 -3.7077151119947915e+15 -7.8559831403383900e+18 7.9789428550115738e+19 1.9321854546506743e+28 2.7622571688115688e+29 2.9583392229687520e+37 2.9583392505913144e+37 0.0000000000000000e+00 2.9583392505913144e+37 2.7306640614147251e+04 6.8067725884159722e+02 0.0000000000000000e+00 -6.6335093695554737e-02 4.7482550784469113e+03 -2.4880589575292177e-05 1.0000972452758998e+08 3.1017431302318867e+07 2.1834522208251888e-12 - 2 1.2535934918877847e-07 1.4902056479398969e+20 -2.0759055857352421e+19 1.4862415462814437e+24 -1.6351019861504854e+16 -3.4644556500407476e+19 3.5187152219157529e+20 4.0584338401784253e+28 5.5823502529036681e+29 2.9583452181108315e+37 2.9583452739343125e+37 0.0000000000000000e+00 2.9583452739343125e+37 2.7306640614140484e+04 6.8067697458182033e+02 0.0000000000000000e+00 -1.3930329606554864e-01 9.9733989623248763e+03 -1.0972324446702355e-04 1.0003863648118678e+08 3.1017667549506564e+07 1.8217100523183610e-12 + 0 0.0000000000000000 1.4700685690736437e+20 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 2.9163021935541997e+37 2.9163021935541997e+37 0.0000000000000000e+00 2.9163021935541997e+37 2.7306641645125415e+04 6.8087525965685256e+02 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.3928678114307070e+09 3.0715027784567930e+07 0.0000000000000000e+00 + 1 5.9806047036494849e-08 1.4700700110495903e+20 3.3564221294760178e+23 7.2876252590129013e+23 1.2612378576902532e+20 3.1318392026636616e+23 -2.7141686393328650e+24 1.9066097490832445e+28 7.8605333893026802e+29 2.9163081863790971e+37 2.9163082649844082e+37 0.0000000000000000e+00 2.9163082649844082e+37 2.7306641717925890e+04 6.8087482283157362e+02 0.0000000000000000e+00 2.2831716205676648e+03 4.9573321027137572e+03 8.5794407627549896e-01 1.3929561430929687e+09 3.0715326643214259e+07 3.3873763068343888e-04 + 2 1.2559269877663918e-07 1.4700717750115456e+20 7.0484895627215180e+23 1.5304335700608418e+24 5.5619062084401319e+20 1.3810901029080806e+24 -1.1969287510263666e+25 4.0039912973182075e+28 3.0853296206485770e+30 2.9163145904134766e+37 2.9163148989464290e+37 0.0000000000000000e+00 2.9163148989464290e+37 2.7306641954244220e+04 6.8087461718998884e+02 0.0000000000000000e+00 4.7946567525018709e+03 1.0410604407725754e+04 3.7834249340624542e+00 1.3933944931271181e+09 3.0715562157661017e+07 3.3857586853705914e-04 diff --git a/Exec/science/flame_wave/ci-benchmarks/species_diag.out b/Exec/science/flame_wave/ci-benchmarks/species_diag.out index b56e8bb348..c71ebacc2e 100644 --- a/Exec/science/flame_wave/ci-benchmarks/species_diag.out +++ b/Exec/science/flame_wave/ci-benchmarks/species_diag.out @@ -1,5 +1,5 @@ # COLUMN 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 # TIMESTEP TIME Mass He4 Mass C12 Mass O16 Mass Ne20 Mass Mg24 Mass Si28 Mass S32 Mass Ar36 Mass Ca40 Mass Ti44 Mass Cr48 Mass Fe52 Mass Ni56 - 0 0.0000000000000000 3.5899765861250859e-15 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.4944801491560746e-24 7.1354824912929246e-14 - 1 5.9694928185132600e-08 3.5899765861251656e-15 7.4944874211898590e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.4944874177116286e-24 7.1354897598484802e-14 - 2 1.2535934918877847e-07 3.5899765861253060e-15 7.4944963166333664e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.4944963093524191e-24 7.1354986514892597e-14 + 0 0.0000000000000000 2.8142378112400895e-15 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.1117997526547418e-14 + 1 5.9806047036494849e-08 2.8142323856670296e-15 5.4329394513687282e-21 7.4194476167127106e-24 7.3934515289195991e-24 7.3935541950036108e-24 7.3933935990475538e-24 7.3932321468746301e-24 7.3932312019180565e-24 7.3932308328287436e-24 7.3932307869393029e-24 7.3932307850741563e-24 7.3932307849933102e-24 7.1118070045957091e-14 + 2 1.2559269877663918e-07 2.8142264165380905e-15 1.1401993461614438e-20 7.4929577845086585e-24 7.3944696393124482e-24 7.3939305113509452e-24 7.3935838899709814e-24 7.3932425308155010e-24 7.3932405326302037e-24 7.3932397568503172e-24 7.3932396603620439e-24 7.3932396564405536e-24 7.3932396562705448e-24 7.1118158758588142e-14 diff --git a/Exec/science/flame_wave/initial_model.H b/Exec/science/flame_wave/initial_model.H index 7deae43d94..27d7f2b5ca 100644 --- a/Exec/science/flame_wave/initial_model.H +++ b/Exec/science/flame_wave/initial_model.H @@ -236,6 +236,9 @@ generate_initial_model(const int npts_model, const Real xmin, const Real xmax, for (int i = index_base+1; i < npts_model; i++) { if ((model::profile(model_num).r(i) > xmin + model_params.H_star + 3.0_rt * model_params.atm_delta) && !flipped) { + if (i == index_base + 1) { + amrex::Error("atm_delta is too small for the grid spacing (at least one transition zone is required)"); + } isentropic = true; flipped = true; diff --git a/Exec/science/flame_wave/inputs_2d.testsuite b/Exec/science/flame_wave/inputs_2d.testsuite index 347d66e14c..f4f04d5aed 100644 --- a/Exec/science/flame_wave/inputs_2d.testsuite +++ b/Exec/science/flame_wave/inputs_2d.testsuite @@ -102,7 +102,7 @@ problem.T_hi = 2.e8 problem.T_lo = 8.e6 problem.H_star = 2000.e0 -problem.atm_delta = 50.0 +problem.atm_delta = 100.0 problem.fuel1_name = "helium-4" problem.fuel1_frac = 1.0e0 From 2893e8dd5af870eed2a223d3e05fa71eca005739 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 18 Mar 2024 19:05:12 -0400 Subject: [PATCH 29/56] fix mismatch between fill_hybrid_hydro_source prototype and implementation (#2781) we have arguments swapped also mark the incoming state const --- Source/hydro/Castro_hybrid.cpp | 4 ++-- Source/hydro/Castro_hydro.H | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Source/hydro/Castro_hybrid.cpp b/Source/hydro/Castro_hybrid.cpp index afff6949b3..b1bdabc4f9 100644 --- a/Source/hydro/Castro_hybrid.cpp +++ b/Source/hydro/Castro_hybrid.cpp @@ -84,7 +84,7 @@ Castro::construct_new_hybrid_source(MultiFab& source, MultiFab& state_old, Multi void -Castro::fill_hybrid_hydro_source(MultiFab& sources, MultiFab& state_in, Real mult_factor) +Castro::fill_hybrid_hydro_source(MultiFab& sources, const MultiFab& state_in, Real mult_factor) { BL_PROFILE("Castro::fill_hybrid_hydro_source()"); @@ -97,7 +97,7 @@ Castro::fill_hybrid_hydro_source(MultiFab& sources, MultiFab& state_in, Real mul { const Box& bx = mfi.tilebox(); - auto u = state_in.array(mfi); + const auto u = state_in.array(mfi); auto src = sources.array(mfi); amrex::ParallelFor(bx, diff --git a/Source/hydro/Castro_hydro.H b/Source/hydro/Castro_hydro.H index 94093c6392..95cb91dda1 100644 --- a/Source/hydro/Castro_hydro.H +++ b/Source/hydro/Castro_hydro.H @@ -856,7 +856,7 @@ /// @param source MultiFab to save source to /// @param mult_factor /// - void fill_hybrid_hydro_source(amrex::MultiFab& state, amrex::MultiFab& source, const amrex::Real mult_factor); + void fill_hybrid_hydro_source(amrex::MultiFab& source, const amrex::MultiFab& state, const amrex::Real mult_factor); /// From 710213e7dd695f59e0a2d7d0716e2bb2e59ace33 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 18 Mar 2024 19:05:47 -0400 Subject: [PATCH 30/56] fix some duplicate branches in sum_integrated_quantities (#2784) --- Source/driver/sum_integrated_quantities.cpp | 24 ++++++--------------- 1 file changed, 6 insertions(+), 18 deletions(-) diff --git a/Source/driver/sum_integrated_quantities.cpp b/Source/driver/sum_integrated_quantities.cpp index 5a41f9242c..1a38867a05 100644 --- a/Source/driver/sum_integrated_quantities.cpp +++ b/Source/driver/sum_integrated_quantities.cpp @@ -375,13 +375,9 @@ Castro::sum_integrated_quantities () data_log1 << std::setw(intwidth) << timestep; - if (time == 0.0_rt) { - data_log1 << std::fixed; - } - else if (time < 1.e-4_rt || time > 1.e4_rt) { + if (time < 1.e-4_rt || time > 1.e4_rt) { data_log1 << std::scientific; - } - else { + } else { data_log1 << std::fixed; } @@ -616,13 +612,9 @@ Castro::sum_integrated_quantities () log << std::setw(intwidth) << timestep; - if (time == 0.0_rt) { - log << std::fixed; - } - else if (time < 1.e-4_rt || time > 1.e4_rt) { + if (time < 1.e-4_rt || time > 1.e4_rt) { log << std::scientific; - } - else { + } else { log << std::fixed; } @@ -717,13 +709,9 @@ Castro::sum_integrated_quantities () log << std::setw(intwidth) << timestep; - if (time == 0.0_rt) { - log << std::fixed; - } - else if (time < 1.e-4_rt || time > 1.e4_rt) { + if (time < 1.e-4_rt || time > 1.e4_rt) { log << std::scientific; - } - else { + } else { log << std::fixed; } From f28d8a8cc26dfdc11fd8e7f955f9889ba8512164 Mon Sep 17 00:00:00 2001 From: Khanak Bhargava <56127611+khanakbhargava@users.noreply.github.com> Date: Tue, 19 Mar 2024 07:39:14 -0400 Subject: [PATCH 31/56] Modified wdmerger_util to print star composition for user in output file (#2767) I wanted us to also print the star composition in addition to the masses, densities and radii so the user is sure of the initial composition of both stars. --- Exec/science/wdmerger/wdmerger_util.H | 2 +- Exec/science/wdmerger/wdmerger_util.cpp | 18 ++++++++++++++---- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/Exec/science/wdmerger/wdmerger_util.H b/Exec/science/wdmerger/wdmerger_util.H index 1b61f934d3..d2c28b3bfa 100644 --- a/Exec/science/wdmerger/wdmerger_util.H +++ b/Exec/science/wdmerger/wdmerger_util.H @@ -16,7 +16,7 @@ void kepler_third_law (Real radius_1, Real mass_1, Real radius_2, Real mass_2, Real& period, Real eccentricity, Real phi, Real& a, Real& r_1, Real& r_2, Real& v_1r, Real& v_2r, Real& v_1p, Real& v_2p); -void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec], Real envelope_comp[NumSpec]); +void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec], Real envelope_comp[NumSpec], const std::string& star_type); void ensure_primary_mass_larger (); diff --git a/Exec/science/wdmerger/wdmerger_util.cpp b/Exec/science/wdmerger/wdmerger_util.cpp index d2a5b46193..65b09f89e5 100644 --- a/Exec/science/wdmerger/wdmerger_util.cpp +++ b/Exec/science/wdmerger/wdmerger_util.cpp @@ -73,7 +73,7 @@ void kepler_third_law (Real radius_1, Real mass_1, Real radius_2, Real mass_2, // Given a WD mass, set its core and envelope composition. -void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec], Real envelope_comp[NumSpec]) +void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec], Real envelope_comp[NumSpec], const std::string& star_type) { int iHe4 = network_spec_index("helium-4"); int iC12 = network_spec_index("carbon-12"); @@ -98,6 +98,8 @@ void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec] core_comp[iHe4] = 1.0_rt; + amrex::Print() << "Created a pure He " << star_type << "." << std::endl; + for (int n = 0; n < NumSpec; ++n) { envelope_comp[n] = core_comp[n]; } @@ -117,6 +119,10 @@ void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec] envelope_mass = problem::hybrid_wd_he_shell_mass; + amrex::Print()<< "Creating " << star_type << "with CO core with mass fractions C = "<< problem::hybrid_wd_c_frac << "and O = " + << problem::hybrid_wd_o_frac <<" and a He shell of solar mass =" << problem::hybrid_wd_he_shell_mass << "." << std::endl; + + if (envelope_mass > 0.0_rt) { if (iHe4 < 0) { amrex::Error("Must have He4 in the nuclear network."); @@ -128,7 +134,6 @@ void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec] envelope_comp[n] = core_comp[n]; } } - } else if (mass >= problem::max_hybrid_wd_mass && mass < problem::max_co_wd_mass) { @@ -144,6 +149,9 @@ void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec] envelope_mass = problem::co_wd_he_shell_mass; + amrex::Print()<<"Creating " << star_type << " with CO core with mass fractions C = "< 0.0_rt) { if (iHe4 < 0) { amrex::Error("Must have He4 in the nuclear network."); @@ -173,6 +181,8 @@ void set_wd_composition (Real mass, Real& envelope_mass, Real core_comp[NumSpec] core_comp[iNe20] = problem::onemg_wd_ne_frac; core_comp[iMg24] = problem::onemg_wd_mg_frac; + amrex::Print()<<"Creating an ONeMg " << star_type << "." < Date: Tue, 19 Mar 2024 09:15:02 -0400 Subject: [PATCH 32/56] fix name mismatch in shock header arguments (#2787) this was flagged by clang-tidy --- Source/hydro/Castro_hydro.H | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/Source/hydro/Castro_hydro.H b/Source/hydro/Castro_hydro.H index 95cb91dda1..c266e17d78 100644 --- a/Source/hydro/Castro_hydro.H +++ b/Source/hydro/Castro_hydro.H @@ -135,13 +135,14 @@ /// /// A multidimensional shock detection algorithm /// -/// @param bx the box to operate over -/// @param q_arr the primitive variable state -/// @param shk the shock flag (1 = shock, 0 = no shock) +/// @param bx the box to operate over +/// @param q_arr the primitive variable state +/// @param U_scr_arr the conservative state sources +/// @param shk the shock flag (1 = shock, 0 = no shock) /// void shock(const amrex::Box& bx, amrex::Array4 const& q_arr, - amrex::Array4 const& q_src_arr, + amrex::Array4 const& U_src_arr, amrex::Array4 const& shk); /// From 0d8acc5b94ecc838f0e09d6186a4069439fffa4e Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 10:22:39 -0400 Subject: [PATCH 33/56] fix Sedov and flame_wave CI (#2788) --- Exec/hydro_tests/Sedov/ci-benchmarks/grid_diag.out | 2 +- Exec/science/flame_wave/ci-benchmarks/grid_diag.out | 2 +- Exec/science/flame_wave/ci-benchmarks/species_diag.out | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Exec/hydro_tests/Sedov/ci-benchmarks/grid_diag.out b/Exec/hydro_tests/Sedov/ci-benchmarks/grid_diag.out index d27e6e4892..61946ff5b3 100644 --- a/Exec/hydro_tests/Sedov/ci-benchmarks/grid_diag.out +++ b/Exec/hydro_tests/Sedov/ci-benchmarks/grid_diag.out @@ -1,6 +1,6 @@ # COLUMN 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 # TIMESTEP TIME MASS XMOM YMOM ZMOM ANG. MOM. X ANG. MOM. Y ANG. MOM. Z KIN. ENERGY INT. ENERGY GAS ENERGY CENTER OF MASS X-LOC CENTER OF MASS Y-LOC CENTER OF MASS Z-LOC CENTER OF MASS X-VEL CENTER OF MASS Y-VEL CENTER OF MASS Z-VEL MAXIMUM TEMPERATURE MAXIMUM DENSITY - 0 0.0000000000000000 1.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 9.9540123498075317e-01 9.9540123498075317e-01 5.0000000000000000e-01 5.0000000000000000e-01 5.0000000000000000e-01 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.6844909478137644e-03 1.0000000000000000e+00 + 0 0.0000000000000000e+00 1.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 9.9540123498075317e-01 9.9540123498075317e-01 5.0000000000000000e-01 5.0000000000000000e-01 5.0000000000000000e-01 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.6844909478137644e-03 1.0000000000000000e+00 1 3.2340315269509180e-07 1.0000000000000000e+00 -1.2207196712653843e-22 -2.4091738146955404e-21 1.5915318696162594e-21 -6.8657515920158759e-26 -6.1490168351429670e-25 3.2333634833518791e-26 8.9703654836411012e-05 9.9531153132591343e-01 9.9540123498075073e-01 5.0000000000000000e-01 5.0000000000000000e-01 5.0000000000000000e-01 -1.2207196712653843e-22 -2.4091738146955404e-21 1.5915318696162594e-21 1.6858365601187205e-03 1.0027049946567383e+00 2 6.7914662065969288e-07 1.0000000000000000e+00 -4.8211172704689422e-22 -1.0918949986942682e-21 7.0508219992330420e-22 -1.8798232765775811e-24 8.0820625471129870e-25 -1.7707803610263417e-24 3.8423927161269466e-04 9.9501699570913438e-01 9.9540123498074762e-01 5.0000000000000000e-01 5.0000000000000000e-01 5.0000000000000000e-01 -4.8211172704689422e-22 -1.0918949986942682e-21 7.0508219992330420e-22 1.6864495062059968e-03 1.0056668439067880e+00 3 1.0704644354207541e-06 1.0000000000000000e+00 -2.9813388912628283e-22 -1.7291596040867426e-21 2.2238460006813763e-21 4.4807723826432593e-24 3.0419916181484195e-26 -1.1783993498209245e-25 9.2349575408761178e-04 9.9447773922665816e-01 9.9540123498074684e-01 5.0000000000000000e-01 5.0000000000000000e-01 5.0000000000000000e-01 -2.9813388912628283e-22 -1.7291596040867426e-21 2.2238460006813763e-21 1.6861149214870039e-03 1.0089335120072900e+00 diff --git a/Exec/science/flame_wave/ci-benchmarks/grid_diag.out b/Exec/science/flame_wave/ci-benchmarks/grid_diag.out index cb9fda8caa..973d3f2aba 100644 --- a/Exec/science/flame_wave/ci-benchmarks/grid_diag.out +++ b/Exec/science/flame_wave/ci-benchmarks/grid_diag.out @@ -1,5 +1,5 @@ # COLUMN 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 # TIMESTEP TIME MASS XMOM YMOM ZMOM ANG. MOM. X ANG. MOM. Y ANG. MOM. Z KIN. ENERGY INT. ENERGY GAS ENERGY GRAV. ENERGY TOTAL ENERGY CENTER OF MASS X-LOC CENTER OF MASS Y-LOC CENTER OF MASS Z-LOC CENTER OF MASS X-VEL CENTER OF MASS Y-VEL CENTER OF MASS Z-VEL MAXIMUM TEMPERATURE MAXIMUM DENSITY MAXIMUM T_S / T_E - 0 0.0000000000000000 1.4700685690736437e+20 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 2.9163021935541997e+37 2.9163021935541997e+37 0.0000000000000000e+00 2.9163021935541997e+37 2.7306641645125415e+04 6.8087525965685256e+02 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.3928678114307070e+09 3.0715027784567930e+07 0.0000000000000000e+00 + 0 0.0000000000000000e+00 1.4700685690736437e+20 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 2.9163021935541997e+37 2.9163021935541997e+37 0.0000000000000000e+00 2.9163021935541997e+37 2.7306641645125415e+04 6.8087525965685256e+02 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 0.0000000000000000e+00 1.3928678114307070e+09 3.0715027784567930e+07 0.0000000000000000e+00 1 5.9806047036494849e-08 1.4700700110495903e+20 3.3564221294760178e+23 7.2876252590129013e+23 1.2612378576902532e+20 3.1318392026636616e+23 -2.7141686393328650e+24 1.9066097490832445e+28 7.8605333893026802e+29 2.9163081863790971e+37 2.9163082649844082e+37 0.0000000000000000e+00 2.9163082649844082e+37 2.7306641717925890e+04 6.8087482283157362e+02 0.0000000000000000e+00 2.2831716205676648e+03 4.9573321027137572e+03 8.5794407627549896e-01 1.3929561430929687e+09 3.0715326643214259e+07 3.3873763068343888e-04 2 1.2559269877663918e-07 1.4700717750115456e+20 7.0484895627215180e+23 1.5304335700608418e+24 5.5619062084401319e+20 1.3810901029080806e+24 -1.1969287510263666e+25 4.0039912973182075e+28 3.0853296206485770e+30 2.9163145904134766e+37 2.9163148989464290e+37 0.0000000000000000e+00 2.9163148989464290e+37 2.7306641954244220e+04 6.8087461718998884e+02 0.0000000000000000e+00 4.7946567525018709e+03 1.0410604407725754e+04 3.7834249340624542e+00 1.3933944931271181e+09 3.0715562157661017e+07 3.3857586853705914e-04 diff --git a/Exec/science/flame_wave/ci-benchmarks/species_diag.out b/Exec/science/flame_wave/ci-benchmarks/species_diag.out index c71ebacc2e..6baaafc600 100644 --- a/Exec/science/flame_wave/ci-benchmarks/species_diag.out +++ b/Exec/science/flame_wave/ci-benchmarks/species_diag.out @@ -1,5 +1,5 @@ # COLUMN 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 # TIMESTEP TIME Mass He4 Mass C12 Mass O16 Mass Ne20 Mass Mg24 Mass Si28 Mass S32 Mass Ar36 Mass Ca40 Mass Ti44 Mass Cr48 Mass Fe52 Mass Ni56 - 0 0.0000000000000000 2.8142378112400895e-15 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.1117997526547418e-14 + 0 0.0000000000000000e+00 2.8142378112400895e-15 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.3932235330395157e-24 7.1117997526547418e-14 1 5.9806047036494849e-08 2.8142323856670296e-15 5.4329394513687282e-21 7.4194476167127106e-24 7.3934515289195991e-24 7.3935541950036108e-24 7.3933935990475538e-24 7.3932321468746301e-24 7.3932312019180565e-24 7.3932308328287436e-24 7.3932307869393029e-24 7.3932307850741563e-24 7.3932307849933102e-24 7.1118070045957091e-14 2 1.2559269877663918e-07 2.8142264165380905e-15 1.1401993461614438e-20 7.4929577845086585e-24 7.3944696393124482e-24 7.3939305113509452e-24 7.3935838899709814e-24 7.3932425308155010e-24 7.3932405326302037e-24 7.3932397568503172e-24 7.3932396603620439e-24 7.3932396564405536e-24 7.3932396562705448e-24 7.1118158758588142e-14 From 33bd03372d1ed9dc549d8eac80f7341bc220d1e3 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 11:19:24 -0400 Subject: [PATCH 34/56] clean the constructor of advance_status (#2790) this addresses clang-tidy cppcoreguidelines-use-default-member-init --- Source/driver/Castro.H | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Source/driver/Castro.H b/Source/driver/Castro.H index cbd002f889..574456bc53 100644 --- a/Source/driver/Castro.H +++ b/Source/driver/Castro.H @@ -112,10 +112,10 @@ enum int_method { CornerTransportUpwind = 0, // why an advance failed. struct advance_status { - bool success; - Real suggested_dt; - std::string reason; - advance_status() : success(true), suggested_dt(0.0_rt), reason("") {} + bool success{true}; + Real suggested_dt{}; + std::string reason{}; + advance_status() = default; }; /// From bfce27d63c286bea808f78969bc1f74b7480e4c2 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 11:20:23 -0400 Subject: [PATCH 35/56] Ggravity does not need to be static. (#2791) Compute it as const -- we always use C::Gconst --- Source/gravity/Gravity.cpp | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/Source/gravity/Gravity.cpp b/Source/gravity/Gravity.cpp index b2f0f90d4e..606562c843 100644 --- a/Source/gravity/Gravity.cpp +++ b/Source/gravity/Gravity.cpp @@ -39,7 +39,7 @@ Real Gravity::mass_offset = 0.0; // ************************************************************************************** // -static Real Ggravity = 0.; +const Real Ggravity = 4.0 * M_PI * C::Gconst; /// /// Multipole gravity data @@ -264,13 +264,6 @@ Gravity::read_params () } - Ggravity = 4.0 * M_PI * C::Gconst; - if (gravity::verbose > 1 && ParallelDescriptor::IOProcessor()) - { - std::cout << "Getting Gconst from constants: " << C::Gconst << std::endl; - std::cout << "Using " << Ggravity << " for 4 pi G in Gravity.cpp " << std::endl; - } - done = true; } } From c7f497f011da4dade5cb4d6eb0d8f359d0712521 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 15:01:45 -0400 Subject: [PATCH 36/56] add a note about CLANG_TIDY_IGNORE_SOURCES to docs (#2789) Co-authored-by: Eric T. Johnson --- Docs/source/debugging.rst | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/Docs/source/debugging.rst b/Docs/source/debugging.rst index 4baf52c717..3341984d51 100644 --- a/Docs/source/debugging.rst +++ b/Docs/source/debugging.rst @@ -85,6 +85,12 @@ You can also use ask it to fix errors automatically via: and you can treat warnings as errors by adding ``CLANG_TIDY_WARN_ERROR=TRUE``. +.. note:: + + Building a Castro problem with ``clang-tidy`` will suppress the + checks in AMReX and Microphysics sources and headers. This is set by + the parameter ``CLANG_TIDY_IGNORE_SOURCES`` in ``Make.Castro``, and + the ``HeaderFilterRegex`` whitelist in ``.clang-tidy``. Thread sanitizer @@ -121,5 +127,3 @@ to operate over. Physics issues ============== - - From ae7a0610582dd38267356d15af162a38318e4e03 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 15:52:58 -0400 Subject: [PATCH 37/56] add CI for fsanitizer (#2771) --- .github/workflows/fsanitizer.yml | 37 ++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 .github/workflows/fsanitizer.yml diff --git a/.github/workflows/fsanitizer.yml b/.github/workflows/fsanitizer.yml new file mode 100644 index 0000000000..7267a62488 --- /dev/null +++ b/.github/workflows/fsanitizer.yml @@ -0,0 +1,37 @@ +name: fsanitizer + +on: [push, pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-fsanitizer + cancel-in-progress: true + +jobs: + fsanitizer: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: Get submodules + run: | + git submodule update --init + cd external/Microphysics + git fetch; git checkout development + cd ../amrex + git fetch; git checkout development + cd ../.. + + - name: Install dependencies + run: | + sudo apt-get update -y -qq + sudo apt-get -qq -y install curl cmake jq clang g++>=9.3.0 + + - name: Compile subchandra + run: | + cd Exec/science/subchandra + make FSANITIZER=TRUE USE_MPI=FALSE -j 4 + + - name: Run subchandra + run: | + cd Exec/science/subchandra + ./Castro2d.gnu.SMPLSDC.ex inputs_2d.N14.coarse amr.max_level=1 max_step=1 amr.n_cell=320 640 From 3942b71e5ab61d6fa63b54f2997373a7c312eaff Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 18:55:38 -0400 Subject: [PATCH 38/56] get rid of asctime -- it is unsafe (#2793) flagged by clang-tidy bugprone-unsafe-functions --- Source/driver/Castro_io.cpp | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/Source/driver/Castro_io.cpp b/Source/driver/Castro_io.cpp index b002bf210e..e66a8b5ac9 100644 --- a/Source/driver/Castro_io.cpp +++ b/Source/driver/Castro_io.cpp @@ -574,11 +574,9 @@ Castro::writeJobInfo (const std::string& dir, const Real io_time) jobInfoFile << " Plotfile Information\n"; jobInfoFile << PrettyLine; - time_t now = time(nullptr); - - // Convert now to tm struct for local timezone - tm* localtm = localtime(&now); - jobInfoFile << "output date / time: " << asctime(localtm); + const std::time_t now = time(nullptr); + jobInfoFile << "output date / time: " + << std::put_time(std::localtime(&now), "%c\n") << "\n"; char currentDir[FILENAME_MAX]; if (getcwd(currentDir, FILENAME_MAX) != nullptr) { From ad81d926a1492d3889cee8444bf97c4948a4672b Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 20:03:25 -0400 Subject: [PATCH 39/56] remove mutable keyword on LoopOnCpu we capture by reference, so this doesn't seem required and updates to the AMReX interfaces mean it doesn't work anymore --- Source/reactions/Castro_react.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/reactions/Castro_react.cpp b/Source/reactions/Castro_react.cpp index 73c5a3c873..bc070c7359 100644 --- a/Source/reactions/Castro_react.cpp +++ b/Source/reactions/Castro_react.cpp @@ -213,7 +213,7 @@ Castro::react_state(MultiFab& s, MultiFab& r, Real time, Real dt, const int stra #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) mutable + LoopOnCpu(bx, [&] (int i, int j, int k) #endif { @@ -558,7 +558,7 @@ Castro::react_state(Real time, Real dt) #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) mutable + LoopOnCpu(bx, [&] (int i, int j, int k) #endif { burn_t burn_state; From bc483ba161cd0818b1fc424c4a3a744ce8f3c108 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 19 Mar 2024 20:05:24 -0400 Subject: [PATCH 40/56] Revert "remove mutable keyword on LoopOnCpu" This reverts commit ad81d926a1492d3889cee8444bf97c4948a4672b. --- Source/reactions/Castro_react.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/reactions/Castro_react.cpp b/Source/reactions/Castro_react.cpp index bc070c7359..73c5a3c873 100644 --- a/Source/reactions/Castro_react.cpp +++ b/Source/reactions/Castro_react.cpp @@ -213,7 +213,7 @@ Castro::react_state(MultiFab& s, MultiFab& r, Real time, Real dt, const int stra #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) + LoopOnCpu(bx, [&] (int i, int j, int k) mutable #endif { @@ -558,7 +558,7 @@ Castro::react_state(Real time, Real dt) #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) + LoopOnCpu(bx, [&] (int i, int j, int k) mutable #endif { burn_t burn_state; From 09bde5faec2966ac0e0c1a78f8bb5f30c3589f21 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 20 Mar 2024 13:09:56 -0400 Subject: [PATCH 41/56] remove mutable keyword on LoopOnCpu (#2794) we capture by reference, so this doesn't seem required and updates to the AMReX interfaces mean it doesn't work anymore --- Source/reactions/Castro_react.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/reactions/Castro_react.cpp b/Source/reactions/Castro_react.cpp index 73c5a3c873..bc070c7359 100644 --- a/Source/reactions/Castro_react.cpp +++ b/Source/reactions/Castro_react.cpp @@ -213,7 +213,7 @@ Castro::react_state(MultiFab& s, MultiFab& r, Real time, Real dt, const int stra #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) mutable + LoopOnCpu(bx, [&] (int i, int j, int k) #endif { @@ -558,7 +558,7 @@ Castro::react_state(Real time, Real dt) #if defined(AMREX_USE_GPU) ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) #else - LoopOnCpu(bx, [&] (int i, int j, int k) mutable + LoopOnCpu(bx, [&] (int i, int j, int k) #endif { burn_t burn_state; From 5707c0c2f5f4b86cae9b990d18b87348292a45d6 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Thu, 21 Mar 2024 11:31:31 -0400 Subject: [PATCH 42/56] use anon namespace instead of static in Castro_setup.cpp (#2786) this addresses some clang-tidy concerns --- Source/driver/Castro_setup.cpp | 216 ++++++++++++++++++--------------- 1 file changed, 116 insertions(+), 100 deletions(-) diff --git a/Source/driver/Castro_setup.cpp b/Source/driver/Castro_setup.cpp index c4a5327e64..0d3c8190d3 100644 --- a/Source/driver/Castro_setup.cpp +++ b/Source/driver/Castro_setup.cpp @@ -20,137 +20,153 @@ using std::string; using namespace amrex; -static Box the_same_box (const Box& b) { return b; } -static Box grow_box_by_one (const Box& b) { return amrex::grow(b,1); } +using BndryFunc = StateDescriptor::BndryFunc; -typedef StateDescriptor::BndryFunc BndryFunc; +namespace { -// -// Components are: -// Interior, Inflow, Outflow, Symmetry, SlipWall, NoSlipWall -// -static int scalar_bc[] = - { - amrex::BCType::int_dir, amrex::BCType::ext_dir, amrex::BCType::foextrap, amrex::BCType::reflect_even, amrex::BCType::reflect_even, amrex::BCType::reflect_even - }; - -static int norm_vel_bc[] = - { - amrex::BCType::int_dir, amrex::BCType::ext_dir, amrex::BCType::foextrap, amrex::BCType::reflect_odd, amrex::BCType::reflect_odd, amrex::BCType::reflect_odd - }; + Box the_same_box (const Box& b) { return b; } + Box grow_box_by_one (const Box& b) { return amrex::grow(b,1); } -static int tang_vel_bc[] = - { - amrex::BCType::int_dir, amrex::BCType::ext_dir, amrex::BCType::foextrap, amrex::BCType::reflect_even, amrex::BCType::reflect_even, amrex::BCType::reflect_even - }; + // + // Components are: + // Interior, Inflow, Outflow, Symmetry, SlipWall, NoSlipWall + // + int scalar_bc[] = + { + amrex::BCType::int_dir, + amrex::BCType::ext_dir, + amrex::BCType::foextrap, + amrex::BCType::reflect_even, + amrex::BCType::reflect_even, + amrex::BCType::reflect_even + }; + + int norm_vel_bc[] = + { + amrex::BCType::int_dir, + amrex::BCType::ext_dir, + amrex::BCType::foextrap, + amrex::BCType::reflect_odd, + amrex::BCType::reflect_odd, + amrex::BCType::reflect_odd + }; + + int tang_vel_bc[] = + { + amrex::BCType::int_dir, + amrex::BCType::ext_dir, + amrex::BCType::foextrap, + amrex::BCType::reflect_even, + amrex::BCType::reflect_even, + amrex::BCType::reflect_even + }; #ifdef MHD -static int mag_field_bc[] = -{ - amrex::BCType::int_dir, amrex::BCType::ext_dir, amrex::BCType::foextrap, amrex::BCType::reflect_even, amrex::BCType::foextrap, amrex::BCType::hoextrap -}; + int mag_field_bc[] = + { + amrex::BCType::int_dir, + amrex::BCType::ext_dir, + amrex::BCType::foextrap, + amrex::BCType::reflect_even, + amrex::BCType::foextrap, + amrex::BCType::hoextrap + }; #endif -static -void -set_scalar_bc (BCRec& bc, const BCRec& phys_bc) -{ - const int* lo_bc = phys_bc.lo(); - const int* hi_bc = phys_bc.hi(); - for (int i = 0; i < AMREX_SPACEDIM; i++) + void + set_scalar_bc (BCRec& bc, const BCRec& phys_bc) { - bc.setLo(i,scalar_bc[lo_bc[i]]); - bc.setHi(i,scalar_bc[hi_bc[i]]); + const int* lo_bc = phys_bc.lo(); + const int* hi_bc = phys_bc.hi(); + for (int i = 0; i < AMREX_SPACEDIM; i++) + { + bc.setLo(i,scalar_bc[lo_bc[i]]); + bc.setHi(i,scalar_bc[hi_bc[i]]); + } } -} -static -void -set_x_vel_bc(BCRec& bc, const BCRec& phys_bc) -{ - const int* lo_bc = phys_bc.lo(); - const int* hi_bc = phys_bc.hi(); - bc.setLo(0,norm_vel_bc[lo_bc[0]]); - bc.setHi(0,norm_vel_bc[hi_bc[0]]); + void + set_x_vel_bc(BCRec& bc, const BCRec& phys_bc) + { + const int* lo_bc = phys_bc.lo(); + const int* hi_bc = phys_bc.hi(); + bc.setLo(0,norm_vel_bc[lo_bc[0]]); + bc.setHi(0,norm_vel_bc[hi_bc[0]]); #if (AMREX_SPACEDIM >= 2) - bc.setLo(1,tang_vel_bc[lo_bc[1]]); - bc.setHi(1,tang_vel_bc[hi_bc[1]]); + bc.setLo(1,tang_vel_bc[lo_bc[1]]); + bc.setHi(1,tang_vel_bc[hi_bc[1]]); #endif #if (AMREX_SPACEDIM == 3) - bc.setLo(2,tang_vel_bc[lo_bc[2]]); - bc.setHi(2,tang_vel_bc[hi_bc[2]]); + bc.setLo(2,tang_vel_bc[lo_bc[2]]); + bc.setHi(2,tang_vel_bc[hi_bc[2]]); #endif -} + } -static -void -set_y_vel_bc(BCRec& bc, const BCRec& phys_bc) -{ - const int* lo_bc = phys_bc.lo(); - const int* hi_bc = phys_bc.hi(); - bc.setLo(0,tang_vel_bc[lo_bc[0]]); - bc.setHi(0,tang_vel_bc[hi_bc[0]]); + void + set_y_vel_bc(BCRec& bc, const BCRec& phys_bc) + { + const int* lo_bc = phys_bc.lo(); + const int* hi_bc = phys_bc.hi(); + bc.setLo(0,tang_vel_bc[lo_bc[0]]); + bc.setHi(0,tang_vel_bc[hi_bc[0]]); #if (AMREX_SPACEDIM >= 2) - bc.setLo(1,norm_vel_bc[lo_bc[1]]); - bc.setHi(1,norm_vel_bc[hi_bc[1]]); + bc.setLo(1,norm_vel_bc[lo_bc[1]]); + bc.setHi(1,norm_vel_bc[hi_bc[1]]); #endif #if (AMREX_SPACEDIM == 3) - bc.setLo(2,tang_vel_bc[lo_bc[2]]); - bc.setHi(2,tang_vel_bc[hi_bc[2]]); + bc.setLo(2,tang_vel_bc[lo_bc[2]]); + bc.setHi(2,tang_vel_bc[hi_bc[2]]); #endif -} + } -static -void -set_z_vel_bc(BCRec& bc, const BCRec& phys_bc) -{ - const int* lo_bc = phys_bc.lo(); - const int* hi_bc = phys_bc.hi(); - bc.setLo(0,tang_vel_bc[lo_bc[0]]); - bc.setHi(0,tang_vel_bc[hi_bc[0]]); + void + set_z_vel_bc(BCRec& bc, const BCRec& phys_bc) + { + const int* lo_bc = phys_bc.lo(); + const int* hi_bc = phys_bc.hi(); + bc.setLo(0,tang_vel_bc[lo_bc[0]]); + bc.setHi(0,tang_vel_bc[hi_bc[0]]); #if (AMREX_SPACEDIM >= 2) - bc.setLo(1,tang_vel_bc[lo_bc[1]]); - bc.setHi(1,tang_vel_bc[hi_bc[1]]); + bc.setLo(1,tang_vel_bc[lo_bc[1]]); + bc.setHi(1,tang_vel_bc[hi_bc[1]]); #endif #if (AMREX_SPACEDIM == 3) - bc.setLo(2,norm_vel_bc[lo_bc[2]]); - bc.setHi(2,norm_vel_bc[hi_bc[2]]); + bc.setLo(2,norm_vel_bc[lo_bc[2]]); + bc.setHi(2,norm_vel_bc[hi_bc[2]]); #endif -} - + } #ifdef MHD -static -void -set_mag_field_bc(BCRec& bc, const BCRec& phys_bc) -{ - const int* lo_bc = phys_bc.lo(); - const int* hi_bc = phys_bc.hi(); - for (int i = 0; i < AMREX_SPACEDIM; i++) + void + set_mag_field_bc(BCRec& bc, const BCRec& phys_bc) { - bc.setLo(i, mag_field_bc[lo_bc[i]]); - bc.setHi(i, mag_field_bc[hi_bc[i]]); + const int* lo_bc = phys_bc.lo(); + const int* hi_bc = phys_bc.hi(); + for (int i = 0; i < AMREX_SPACEDIM; i++) + { + bc.setLo(i, mag_field_bc[lo_bc[i]]); + bc.setHi(i, mag_field_bc[hi_bc[i]]); + } } -} #endif -// In some cases we want to replace inflow boundaries with -// first-order extrapolation boundaries. This is intended to -// be used for state data that the user is not going to -// provide inflow boundary conditions for, like gravity -// and reactions, and it works in conjunction with the -// generic_fill boundary routine. + // In some cases we want to replace inflow boundaries with + // first-order extrapolation boundaries. This is intended to + // be used for state data that the user is not going to + // provide inflow boundary conditions for, like gravity + // and reactions, and it works in conjunction with the + // generic_fill boundary routine. -static -void -replace_inflow_bc (BCRec& bc) -{ - for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) { - if (bc.lo(dir) == amrex::BCType::ext_dir) { - bc.setLo(dir, amrex::BCType::foextrap); - } - if (bc.hi(dir) == amrex::BCType::ext_dir) { - bc.setHi(dir, amrex::BCType::foextrap); + void + replace_inflow_bc (BCRec& bc) + { + for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) { + if (bc.lo(dir) == amrex::BCType::ext_dir) { + bc.setLo(dir, amrex::BCType::foextrap); + } + if (bc.hi(dir) == amrex::BCType::ext_dir) { + bc.setHi(dir, amrex::BCType::foextrap); + } } } } From 215963a1c54a10bbde1cb6b9d1dad77d742cb794 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 26 Mar 2024 14:10:25 -0400 Subject: [PATCH 43/56] change MAX_LEV to constexpr (#2798) --- Source/driver/castro_limits.H | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/driver/castro_limits.H b/Source/driver/castro_limits.H index 0111b43432..31ddeb93a9 100644 --- a/Source/driver/castro_limits.H +++ b/Source/driver/castro_limits.H @@ -1,6 +1,6 @@ #ifndef CASTRO_LIMITS_H #define CASTRO_LIMITS_H -#define MAX_LEV 15 +constexpr int MAX_LEV{15}; #endif From 2641dc67961483fbb35cab900ad892252b8184d9 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 26 Mar 2024 14:11:11 -0400 Subject: [PATCH 44/56] use ranged-for for problem parameter array init (#2799) --- Util/scripts/write_probdata.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Util/scripts/write_probdata.py b/Util/scripts/write_probdata.py index 68cb716aac..2cd7cdd398 100755 --- a/Util/scripts/write_probdata.py +++ b/Util/scripts/write_probdata.py @@ -237,8 +237,8 @@ def write_probin(prob_param_files, cxx_prefix): size = p.size if (size == "nspec"): size = "NumSpec" - fout.write(f" for (int n = 0; n < {size}; n++) {{\n") - fout.write(f" problem::{p.name}[n] = {p.default_format(lang='C++')};\n") + fout.write(f" for (auto & e : problem::{p.name}) {{\n") + fout.write(f" e = {p.default_format(lang='C++')};\n") fout.write(f" }}\n") else: fout.write(f" {p.get_default_string()}") From e6c2da105d0852162400144c67411e130f806fdd Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 26 Mar 2024 14:19:28 -0400 Subject: [PATCH 45/56] address some clang-tidy MHD warnings (#2792) --- Source/mhd/Castro_mhd.H | 2 +- Source/mhd/mhd_util.H | 6 +++--- Source/sources/Castro_sources.cpp | 3 +++ 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/Source/mhd/Castro_mhd.H b/Source/mhd/Castro_mhd.H index 3451fefe37..a15a323207 100644 --- a/Source/mhd/Castro_mhd.H +++ b/Source/mhd/Castro_mhd.H @@ -31,7 +31,7 @@ void consup_mhd(const amrex::Box& bx, const Real dt, - amrex::Array4 const& update, + amrex::Array4 const& U_new, amrex::Array4 const& flux0, amrex::Array4 const& flux1, amrex::Array4 const& flux2); diff --git a/Source/mhd/mhd_util.H b/Source/mhd/mhd_util.H index 7b7cce3eba..7f9097e4f5 100644 --- a/Source/mhd/mhd_util.H +++ b/Source/mhd/mhd_util.H @@ -23,7 +23,7 @@ eos_soundspeed_mhd(Real& c, Real as, Real ca, Real bd) { AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void -qflux(Real* qflx, Real* flx, Real* q_zone) { +qflux(Real* qflx, const Real* flx, const Real* q_zone) { // Calculate the C to P Jacobian applied to the fluxes @@ -78,7 +78,7 @@ qflux(Real* qflx, Real* flx, Real* q_zone) { AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void -electric(Real* q_zone, Real& E_zone, const int comp) { +electric(const Real* q_zone, Real& E_zone, const int comp) { // this takes the cell-center primitive state, q_zone, and computes the cell-center // electric field, E_zone, using Faraday's law: @@ -99,7 +99,7 @@ electric(Real* q_zone, Real& E_zone, const int comp) { AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void -ConsToPrim(Real* q_zone, Real* U_zone) { +ConsToPrim(Real* q_zone, const Real* U_zone) { // calculate the primitive variables from the conserved // U has NUM_STATE+3 components diff --git a/Source/sources/Castro_sources.cpp b/Source/sources/Castro_sources.cpp index f99aac52dc..fc5dddce4f 100644 --- a/Source/sources/Castro_sources.cpp +++ b/Source/sources/Castro_sources.cpp @@ -606,6 +606,9 @@ Castro::post_advance_operators (Real time, Real dt) { advance_status status {}; + amrex::ignore_unused(time); + amrex::ignore_unused(dt); + #ifndef TRUE_SDC #ifdef REACTIONS status = do_new_reactions(time, dt); From d86384adf43fc6fa7b7e4e1884a20075e4ff6c07 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 26 Mar 2024 14:19:47 -0400 Subject: [PATCH 46/56] fix another repeated branch in the logs (#2800) this was missed earlier because we didn't have gravity enabled --- Source/driver/sum_integrated_quantities.cpp | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/Source/driver/sum_integrated_quantities.cpp b/Source/driver/sum_integrated_quantities.cpp index 1a38867a05..a92c65d885 100644 --- a/Source/driver/sum_integrated_quantities.cpp +++ b/Source/driver/sum_integrated_quantities.cpp @@ -511,10 +511,7 @@ Castro::sum_integrated_quantities () log << std::setw(intwidth) << timestep; - if (time == 0.0_rt) { - log << std::fixed; - } - else if (time < 1.e-4_rt || time > 1.e4_rt) { + if (time < 1.e-4_rt || time > 1.e4_rt) { log << std::scientific; } else { From 760ecc4165d56c0e413d2f8038afe659be1ee048 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Tue, 26 Mar 2024 15:25:55 -0400 Subject: [PATCH 47/56] define runtime params in .cpp instead of *_declares.H (#2797) Co-authored-by: Eric T. Johnson --- Exec/Make.auto_source | 2 + Source/diffusion/Make.package | 1 - Source/diffusion/diffusion_params.cpp | 7 -- Source/driver/Make.package | 2 +- Source/driver/parse_castro_params.py | 100 +++++++++++++++----------- Source/driver/runparams_defaults.cpp | 6 -- Source/gravity/Make.package | 1 - Source/gravity/gravity_params.cpp | 9 --- Source/radiation/Make.package | 1 - Source/radiation/radiation_params.cpp | 9 --- 10 files changed, 61 insertions(+), 77 deletions(-) delete mode 100644 Source/diffusion/diffusion_params.cpp delete mode 100644 Source/driver/runparams_defaults.cpp delete mode 100644 Source/gravity/gravity_params.cpp delete mode 100644 Source/radiation/radiation_params.cpp diff --git a/Exec/Make.auto_source b/Exec/Make.auto_source index 178e0f43e2..596542809d 100644 --- a/Exec/Make.auto_source +++ b/Exec/Make.auto_source @@ -67,6 +67,8 @@ AUTO_BUILD_SOURCES += $(CASTRO_AUTO_SOURCE_DIR)/castro_params.H CPP_PARAMETERS := $(TOP)/Source/driver/_cpp_parameters +$(CASTRO_AUTO_SOURCE_DIR)/runtime_params.cpp: $(CASTRO_AUTO_SOURCE_DIR)/castro_params.H + $(CASTRO_AUTO_SOURCE_DIR)/castro_params.H: $(CPP_PARAMETERS) @if [ ! -d $(CASTRO_AUTO_SOURCE_DIR) ]; then mkdir -p $(CASTRO_AUTO_SOURCE_DIR); fi PYTHONPATH=$(MICROPHYSICS_HOME)/util/build_scripts $(TOP)/Source/driver/parse_castro_params.py -o $(CASTRO_AUTO_SOURCE_DIR) $(CPP_PARAMETERS) diff --git a/Source/diffusion/Make.package b/Source/diffusion/Make.package index d39ddec718..be1fe61fbe 100644 --- a/Source/diffusion/Make.package +++ b/Source/diffusion/Make.package @@ -8,5 +8,4 @@ CEXE_sources += diffusion_util.cpp CEXE_sources += Castro_diffusion.cpp CEXE_sources += Diffusion.cpp -CEXE_sources += diffusion_params.cpp CEXE_headers += Diffusion.H diff --git a/Source/diffusion/diffusion_params.cpp b/Source/diffusion/diffusion_params.cpp deleted file mode 100644 index 2518c14740..0000000000 --- a/Source/diffusion/diffusion_params.cpp +++ /dev/null @@ -1,7 +0,0 @@ -#include - -#include - -#include - -#include diff --git a/Source/driver/Make.package b/Source/driver/Make.package index c4ca1e4313..85febd5698 100644 --- a/Source/driver/Make.package +++ b/Source/driver/Make.package @@ -1,7 +1,7 @@ # these are the files that should be needed for any Castro build CEXE_sources += Castro.cpp -CEXE_sources += runparams_defaults.cpp +CEXE_sources += runtime_params.cpp CEXE_sources += Castro_advance.cpp CEXE_sources += Castro_advance_ctu.cpp ifeq ($(USE_TRUE_SDC), TRUE) diff --git a/Source/driver/parse_castro_params.py b/Source/driver/parse_castro_params.py index aedeea6624..89f91a8ea7 100755 --- a/Source/driver/parse_castro_params.py +++ b/Source/driver/parse_castro_params.py @@ -1,9 +1,9 @@ #!/usr/bin/env python3 -""" -This script parses the list of C++ runtime parameters and writes the -necessary header files and Fortran routines to make them available -in Castro's C++ routines. +"""This script parses the list of C++ runtime parameters and writes +the necessary header and source files to make them available in +Castro's C++ routines. They are available in 2 ways: as global +parameter and in the form of a single struct. parameters have the format: @@ -41,9 +41,6 @@ -- name_params.H (for castro, included in Castro.H): sets up the namespace and extern parameters - -- name_declares.H (for castro, included in Castro.cpp): - declares the runtime parameters - -- name_queries.H (for castro, included in Castro.cpp): does the parmparse query to override the default in C++ @@ -51,6 +48,9 @@ this tests the current value against the default and outputs into a file + -- runtime_params.cpp + has the actual definition of the variables (without extern) + """ import argparse @@ -129,12 +129,12 @@ def read_param_file(infile): return params -def write_headers(params, out_directory, struct_name): +def write_headers_and_source(params, out_directory, struct_name): # output # find all the namespaces - namespaces = {q.namespace for q in params} + namespaces = sorted({q.namespace for q in params}) for nm in namespaces: @@ -142,32 +142,6 @@ def write_headers(params, out_directory, struct_name): # sort by repr since None may be present ifdefs = sorted({q.ifdef for q in params_nm}, key=repr) - # write name_declares.H - try: - cd = open(f"{out_directory}/{nm}_declares.H", "w", encoding="UTF-8") - except OSError: - sys.exit(f"unable to open {nm}_declares.H for writing") - - cd.write(CWARNING) - cd.write(f"#ifndef {nm.upper()}_DECLARES_H\n") - cd.write(f"#define {nm.upper()}_DECLARES_H\n") - - cd.write("\n") - cd.write(f"namespace {nm} {{\n") - - for ifdef in ifdefs: - if ifdef is None: - for p in [q for q in params_nm if q.ifdef is None]: - cd.write(p.get_declare_string()) - else: - cd.write(f"#ifdef {ifdef}\n") - for p in [q for q in params_nm if q.ifdef == ifdef]: - cd.write(p.get_declare_string()) - cd.write("#endif\n") - cd.write("}\n\n") - cd.write("#endif\n") - cd.close() - # write name_params.H try: cp = open(f"{out_directory}/{nm}_params.H", "w", encoding="UTF-8") @@ -238,7 +212,44 @@ def write_headers(params, out_directory, struct_name): jo.close() + # write a single C++ source file that actually defines the parameters + # (one file for all namespaces) + try: + pf = open(f"{out_directory}/runtime_params.cpp", "w", encoding="UTF-8") + except OSError: + sys.exit(f"unable to open runtime_params.cpp") + + pf.write("#include \n") + pf.write("#include \n") + pf.write("#include \n\n") + + for nm in namespaces: + pf.write(f"#include <{nm}_params.H>\n") + pf.write("\n") + + for nm in namespaces: + params_nm = [q for q in params if q.namespace == nm] + # sort by repr since None may be present + ifdefs = sorted({q.ifdef for q in params_nm}, key=repr) + + pf.write(f"namespace {nm} {{\n") + + for ifdef in ifdefs: + if ifdef is None: + for p in [q for q in params_nm if q.ifdef is None]: + pf.write(p.get_declare_string()) + else: + pf.write(f"#ifdef {ifdef}\n") + for p in [q for q in params_nm if q.ifdef == ifdef]: + pf.write(p.get_declare_string()) + pf.write("#endif\n") + pf.write("}\n\n") + + pf.close() + # now write a single file that contains all of the parameter structs + # to minimize padding, we want to sort on type + try: sf = open(f"{out_directory}/{struct_name}_type.H", "w", encoding="UTF-8") except OSError: @@ -255,20 +266,25 @@ def write_headers(params, out_directory, struct_name): params_nm = [q for q in params if q.namespace == nm] # sort by repr since None may be present ifdefs = sorted({q.ifdef for q in params_nm}, key=repr) - sf.write(f"struct {nm}_t {{\n") print("namespace = ", nm) for ifdef in ifdefs: + params_if = [q for q in params_nm if q.ifdef == ifdef] + types = sorted(set(q.dtype for q in params_if)) + if ifdef is None: - for p in [q for q in params_nm if q.ifdef is None]: - sf.write(p.get_struct_entry()) + for tt in types: + params_type = [q for q in params_if if q.dtype == tt] + for p in params_type: + sf.write(p.get_struct_entry()) else: sf.write(f"#ifdef {ifdef}\n") - for p in [q for q in params_nm if q.ifdef == ifdef]: - sf.write(p.get_struct_entry()) + for tt in types: + params_type = [q for q in params_if if q.dtype == tt] + for p in params_type: + sf.write(p.get_struct_entry()) sf.write("#endif\n") - sf.write("};\n\n") # now the parent struct @@ -295,7 +311,7 @@ def main(): args = parser.parse_args() p = read_param_file(args.input_file[0]) - write_headers(p, args.o, args.s) + write_headers_and_source(p, args.o, args.s) if __name__ == "__main__": main() diff --git a/Source/driver/runparams_defaults.cpp b/Source/driver/runparams_defaults.cpp deleted file mode 100644 index c9f5ed1de6..0000000000 --- a/Source/driver/runparams_defaults.cpp +++ /dev/null @@ -1,6 +0,0 @@ -#include - -#include - -#include - diff --git a/Source/gravity/Make.package b/Source/gravity/Make.package index f94894307f..6708aab63d 100644 --- a/Source/gravity/Make.package +++ b/Source/gravity/Make.package @@ -2,7 +2,6 @@ # this is included if USE_GRAV = TRUE CEXE_sources += Gravity.cpp -CEXE_sources += gravity_params.cpp CEXE_headers += Gravity.H CEXE_headers += Gravity_util.H CEXE_headers += Castro_gravity.H diff --git a/Source/gravity/gravity_params.cpp b/Source/gravity/gravity_params.cpp deleted file mode 100644 index c80baeadc7..0000000000 --- a/Source/gravity/gravity_params.cpp +++ /dev/null @@ -1,9 +0,0 @@ -#include - -#include - -#include - -#include - - diff --git a/Source/radiation/Make.package b/Source/radiation/Make.package index 5a0023f4da..dfaa525b1b 100644 --- a/Source/radiation/Make.package +++ b/Source/radiation/Make.package @@ -5,7 +5,6 @@ CEXE_sources += HypreExtMultiABec.cpp CEXE_sources += HypreMultiABec.cpp CEXE_sources += HypreABec.cpp CEXE_sources += Radiation.cpp -CEXE_sources += radiation_params.cpp CEXE_sources += RadSolve.cpp CEXE_sources += RadBndry.cpp CEXE_sources += RadMultiGroup.cpp diff --git a/Source/radiation/radiation_params.cpp b/Source/radiation/radiation_params.cpp deleted file mode 100644 index 5c10888946..0000000000 --- a/Source/radiation/radiation_params.cpp +++ /dev/null @@ -1,9 +0,0 @@ -#include - -#include - -#include - -#include - -#include From aa8d3b2a3bd762ac53a24e25768a4aef3a8b44fa Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 27 Mar 2024 08:30:04 -0400 Subject: [PATCH 48/56] a few more clang-tidy fixes (#2804) --- Source/driver/Castro_advance_ctu.cpp | 5 ++++- Source/driver/Castro_advance_sdc.cpp | 3 +++ Source/hydro/Castro_ctu_hydro.cpp | 5 ++++- Source/hydro/Castro_mol_hydro.cpp | 4 ++++ Source/hydro/advection_util.H | 3 +++ 5 files changed, 18 insertions(+), 2 deletions(-) diff --git a/Source/driver/Castro_advance_ctu.cpp b/Source/driver/Castro_advance_ctu.cpp index 911a2780e9..44b5cc57a8 100644 --- a/Source/driver/Castro_advance_ctu.cpp +++ b/Source/driver/Castro_advance_ctu.cpp @@ -12,13 +12,16 @@ using namespace amrex; advance_status -Castro::do_advance_ctu (Real time, Real dt) +Castro::do_advance_ctu (Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { // this routine will advance the old state data (called Sborder here) // to the new time, for a single level. The new data is called // S_new here. The update includes reactions (if we are not doing // SDC), hydro, and the source terms. + amrex::ignore_unused(time); + amrex::ignore_unused(dt); + BL_PROFILE("Castro::do_advance_ctu()"); advance_status status {}; diff --git a/Source/driver/Castro_advance_sdc.cpp b/Source/driver/Castro_advance_sdc.cpp index 83b226c7bc..01c5f653be 100644 --- a/Source/driver/Castro_advance_sdc.cpp +++ b/Source/driver/Castro_advance_sdc.cpp @@ -30,6 +30,9 @@ Castro::do_advance_sdc (Real time, // this is the new "formal" SDC integration routine. + amrex::ignore_unused(amr_iteration); + amrex::ignore_unused(amr_ncycle); + // this does the entire update in time for 1 SDC iteration. BL_PROFILE("Castro::do_advance_sdc()"); diff --git a/Source/hydro/Castro_ctu_hydro.cpp b/Source/hydro/Castro_ctu_hydro.cpp index c1a29ae0c2..0ad62f029b 100644 --- a/Source/hydro/Castro_ctu_hydro.cpp +++ b/Source/hydro/Castro_ctu_hydro.cpp @@ -14,8 +14,11 @@ using namespace amrex; advance_status -Castro::construct_ctu_hydro_source(Real time, Real dt) +Castro::construct_ctu_hydro_source(Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { + amrex::ignore_unused(time); + amrex::ignore_unused(dt); + advance_status status {}; if (!do_hydro) { diff --git a/Source/hydro/Castro_mol_hydro.cpp b/Source/hydro/Castro_mol_hydro.cpp index 4d7e0f32db..fbcc8c6171 100644 --- a/Source/hydro/Castro_mol_hydro.cpp +++ b/Source/hydro/Castro_mol_hydro.cpp @@ -21,6 +21,8 @@ void Castro::construct_mol_hydro_source(Real time, Real dt, MultiFab& A_update) { + amrex::ignore_unused(time); + #ifdef RADIATION amrex::Abort("Error: radiation not supported for the MOL hydro source term"); #else @@ -648,6 +650,8 @@ Castro::construct_mol_hydro_source(Real time, Real dt, MultiFab& A_update) } Array4 pradial_fab = pradial.array(); +#endif +#if AMREX_SPACEDIM == 1 Array4 const qex_arr = qe[0].array(); #endif diff --git a/Source/hydro/advection_util.H b/Source/hydro/advection_util.H index 1669869dc4..cde9eaaba6 100644 --- a/Source/hydro/advection_util.H +++ b/Source/hydro/advection_util.H @@ -23,6 +23,9 @@ void src_to_prim(int i, int j, int k, const Real dt, #endif Array4 const& srcQ) { + + amrex::ignore_unused(dt); + for (int n = 0; n < NQSRC; ++n) { srcQ(i,j,k,n) = 0.0_rt; } From 07c4e95b2469eef846210bcfa835ebeb1ffbf602 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 27 Mar 2024 16:44:52 -0400 Subject: [PATCH 49/56] address some clang-tidy warnings in gravity (#2801) --- Source/gravity/Castro_gravity.cpp | 2 +- Source/gravity/Gravity.H | 32 +++++++++++++++---------------- Source/gravity/Gravity.cpp | 25 ++++++++++++------------ Source/reactions/Castro_react.cpp | 4 ++-- 4 files changed, 31 insertions(+), 32 deletions(-) diff --git a/Source/gravity/Castro_gravity.cpp b/Source/gravity/Castro_gravity.cpp index ed8a2406e0..bf9dc4f6b7 100644 --- a/Source/gravity/Castro_gravity.cpp +++ b/Source/gravity/Castro_gravity.cpp @@ -388,7 +388,7 @@ void Castro::construct_old_gravity_source(MultiFab& source, MultiFab& state_in, Real SrE{}; - if (castro::grav_source_type == 1 || castro::grav_source_type == 2) { + if (castro::grav_source_type == 1 || castro::grav_source_type == 2) { // NOLINT(bugprone-branch-clone) // Src = rho u dot g, evaluated with all quantities at t^n diff --git a/Source/gravity/Gravity.H b/Source/gravity/Gravity.H index af7ff177fa..0f6aba88ac 100644 --- a/Source/gravity/Gravity.H +++ b/Source/gravity/Gravity.H @@ -127,7 +127,7 @@ public: /// @param time Current time /// @param multi_level boolean, do we iterate over all levels or mask off fine grids? /// - void set_mass_offset(amrex::Real time, bool multi_level=true); + void set_mass_offset(amrex::Real time, bool multi_level=true) const; /// /// Return ``grad_phi_prev`` at given level @@ -242,17 +242,17 @@ public: /// /// Compute the difference between level and composite solves /// -/// @param level level index -/// @param comp_phi MultiFab containing computed phi -/// @param comp_gphi Vector of MultiFabs containing computed grad phi -/// @param cml_phi MultiFab, computed minus level phi -/// @param cml_gphi Vector of MultiFabs, computed minus level grad phi +/// @param level level index +/// @param comp_phi MultiFab containing computed phi +/// @param comp_gphi Vector of MultiFabs containing computed grad phi +/// @param comp_minus_level_phi MultiFab, computed minus level phi +/// @param comp_minus_level_grad_phi Vector of MultiFabs, computed minus level grad phi /// void create_comp_minus_level_grad_phi(int level, amrex::MultiFab& comp_phi, const amrex::Vector& comp_gphi, - amrex::MultiFab& cml_phi, - amrex::Vector >& cml_gphi); + amrex::MultiFab& comp_minus_level_phi, + amrex::Vector >& comp_minus_level_grad_phi); /// @@ -348,7 +348,7 @@ public: /// @param radial_grav Radial gravity /// @param grav_vector Gravity vector /// - void interpolate_monopole_grav(int level, RealVector& radial_grav, amrex::MultiFab& grav_vector); + void interpolate_monopole_grav(int level, RealVector& radial_grav, amrex::MultiFab& grav_vector) const; /// /// Integrate radially outward to find radial mass distribution @@ -368,7 +368,7 @@ public: #ifdef GR_GRAV RealVector& radial_pres, #endif - int n1d, int level); + int n1d, int level) const; /// /// Implement multipole boundary conditions @@ -383,7 +383,7 @@ public: /// /// Initialize multipole gravity /// - void init_multipole_grav(); + void init_multipole_grav() const; #if (AMREX_SPACEDIM == 3) @@ -480,7 +480,7 @@ public: /// @param Rhs MultiFab /// @param coeffs Vector of MultiFabs /// - void applyMetricTerms(int level,amrex::MultiFab& Rhs, const amrex::Vector& coeffs); + void applyMetricTerms(int level,amrex::MultiFab& Rhs, const amrex::Vector& coeffs) const; /// /// @@ -488,7 +488,7 @@ public: /// @param level Index of level /// @param cc Cell-centered data /// - void unweight_cc(int level,amrex::MultiFab& cc); + void unweight_cc(int level,amrex::MultiFab& cc) const; /// /// @@ -496,7 +496,7 @@ public: /// @param level Index of level /// @param edges Edge-based data /// - void unweight_edges(int level, const amrex::Vector& edges); + void unweight_edges(int level, const amrex::Vector& edges) const; #endif /// @@ -504,7 +504,7 @@ public: /// @param phi Gravitational potential /// @param grav_vector Gravity vector /// - void add_pointmass_to_gravity (int level, amrex::MultiFab& phi, amrex::MultiFab& grav_vector); + void add_pointmass_to_gravity (int level, amrex::MultiFab& phi, amrex::MultiFab& grav_vector) const; /// /// Get the rhs @@ -546,7 +546,7 @@ public: const amrex::Vector >& grad_phi, const amrex::Vector& res, const amrex::MultiFab* const crse_bcdata, - amrex::Real rel_eps, amrex::Real abs_eps); + amrex::Real rel_eps, amrex::Real abs_eps) const; /// diff --git a/Source/gravity/Gravity.cpp b/Source/gravity/Gravity.cpp index 606562c843..02c02c0ea0 100644 --- a/Source/gravity/Gravity.cpp +++ b/Source/gravity/Gravity.cpp @@ -1318,7 +1318,7 @@ Gravity::test_composite_phi (int crse_level) } void -Gravity::interpolate_monopole_grav(int level, RealVector& radial_grav, MultiFab& grav_vector) +Gravity::interpolate_monopole_grav(int level, RealVector& radial_grav, MultiFab& grav_vector) const { BL_PROFILE("Gravity::interpolate_monopole_grav()"); @@ -1434,7 +1434,7 @@ Gravity::compute_radial_mass(const Box& bx, #ifdef GR_GRAV RealVector& radial_pres_local, #endif - int n1d, int level) + int n1d, int level) const { const Geometry& geom = parent->Geom(level); @@ -1599,7 +1599,7 @@ Gravity::compute_radial_mass(const Box& bx, } void -Gravity::init_multipole_grav() +Gravity::init_multipole_grav() const { if (gravity::lnum < 0) { amrex::Abort("lnum negative"); @@ -1691,7 +1691,7 @@ Gravity::init_multipole_grav() multipole::parity_q0(l) = 1.0_rt; if (l % 2 != 0) { - if (AMREX_SPACEDIM == 3 && (multipole::doReflectionLo(2) || multipole::doReflectionHi(2))) { + if (AMREX_SPACEDIM == 3 && (multipole::doReflectionLo(2) || multipole::doReflectionHi(2))) { // NOLINT(bugprone-branch-clone) multipole::parity_q0(l) = 0.0_rt; } else if (AMREX_SPACEDIM == 2 && parent->Geom(0).Coord() == 1) { @@ -1725,7 +1725,7 @@ Gravity::init_multipole_grav() if (AMREX_SPACEDIM == 3) { multipole::parity_qC_qS(l,m) = 1.0_rt; } - else if (AMREX_SPACEDIM == 2 && parent->Geom(0).Coord() == 1) { + else if (AMREX_SPACEDIM == 2 && parent->Geom(0).Coord() == 1) { // NOLINT(bugprone-branch-clone) multipole::parity_qC_qS(l,m) = 0.0_rt; } else if (AMREX_SPACEDIM == 1 && parent->Geom(0).Coord() == 2) { @@ -2847,7 +2847,7 @@ Gravity::fill_direct_sum_BCs(int crse_level, int fine_level, const Vector& coeffs) +Gravity::applyMetricTerms(int level, MultiFab& Rhs, const Vector& coeffs) const { BL_PROFILE("Gravity::applyMetricTerms()"); @@ -2877,7 +2877,7 @@ Gravity::applyMetricTerms(int level, MultiFab& Rhs, const Vector& coe } void -Gravity::unweight_cc(int level, MultiFab& cc) +Gravity::unweight_cc(int level, MultiFab& cc) const { BL_PROFILE("Gravity::unweight_cc()"); @@ -2896,7 +2896,7 @@ Gravity::unweight_cc(int level, MultiFab& cc) } void -Gravity::unweight_edges(int level, const Vector& edges) +Gravity::unweight_edges(int level, const Vector& edges) const { BL_PROFILE("Gravity::unweight_edges()"); @@ -2949,7 +2949,7 @@ Gravity::make_mg_bc () } void -Gravity::set_mass_offset (Real time, bool multi_level) +Gravity::set_mass_offset (Real time, bool multi_level) const { BL_PROFILE("Gravity::set_mass_offset()"); @@ -2999,7 +2999,7 @@ Gravity::set_mass_offset (Real time, bool multi_level) } void -Gravity::add_pointmass_to_gravity (int level, MultiFab& phi, MultiFab& grav_vector) +Gravity::add_pointmass_to_gravity (int level, MultiFab& phi, MultiFab& grav_vector) const { BL_PROFILE("Gravity::add_pointmass_to_gravity()"); @@ -3094,8 +3094,7 @@ Gravity::make_radial_gravity(int level, Real time, RealVector& radial_grav) // Create MultiFab with NUM_STATE components and no ghost cells MultiFab S(grids[lev],dmap[lev],NUM_STATE,0); - if ( eps == 0.0 ) - { + if ( eps == 0.0 ) { // NOLINT(bugprone-branch-clone,-warnings-as-errors) // Old and new time are identical; this should only happen if // dt is smaller than roundoff compared to the current time, // in which case we're probably in trouble anyway, @@ -3713,7 +3712,7 @@ Gravity::actual_solve_with_mlmg (int crse_level, int fine_level, const amrex::Vector >& grad_phi, const amrex::Vector& res, const amrex::MultiFab* const crse_bcdata, - amrex::Real rel_eps, amrex::Real abs_eps) + amrex::Real rel_eps, amrex::Real abs_eps) const { BL_PROFILE("Gravity::actual_solve_with_mlmg()"); diff --git a/Source/reactions/Castro_react.cpp b/Source/reactions/Castro_react.cpp index bc070c7359..3e6ff3949b 100644 --- a/Source/reactions/Castro_react.cpp +++ b/Source/reactions/Castro_react.cpp @@ -12,8 +12,8 @@ using namespace amrex; #ifndef TRUE_SDC advance_status -Castro::do_old_reactions (Real time, Real dt) -{ +Castro::do_old_reactions (Real time, Real dt) { // NOLINT(readability-convert-member-functions-to-static) + amrex::ignore_unused(time); amrex::ignore_unused(dt); From 21c2bc578acb482cc89988cb5f72e0c3cc3e0c9f Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Wed, 27 Mar 2024 16:45:31 -0400 Subject: [PATCH 50/56] Fix initial He4 mass fraction in Detonation (#2806) There were two separate issues with the helium mass fraction calculation: If any of cfrac, nfrac, or ofrac were zero, the corresponding mass fractions would be clamped to smallx, but the helium mass fraction didn't account for this. The number of remaining species was one too high, as it should also exclude He4. --- .../sdc_det_plt00040_extrema.out | 138 +++++++++--------- Exec/science/Detonation/problem_initialize.H | 9 +- 2 files changed, 76 insertions(+), 71 deletions(-) diff --git a/Exec/science/Detonation/ci-benchmarks/sdc_det_plt00040_extrema.out b/Exec/science/Detonation/ci-benchmarks/sdc_det_plt00040_extrema.out index b23a288448..5d48f26c1b 100644 --- a/Exec/science/Detonation/ci-benchmarks/sdc_det_plt00040_extrema.out +++ b/Exec/science/Detonation/ci-benchmarks/sdc_det_plt00040_extrema.out @@ -1,79 +1,79 @@ plotfile = det_x_plt00040 - time = 5.1558159133685604e-06 + time = 5.1558159140336702e-06 variables minimum value maximum value - density 185259613.21 216639295.98 - xmom -76364812859 2.9487648003e+16 + density 185259659.3 216625503.34 + xmom -13760057465 2.9527146771e+16 ymom 0 0 zmom 0 0 - rho_E 1.3062473824e+26 2.7890630574e+26 - rho_e 1.3062473824e+26 2.7748033958e+26 - Temp 50000004.458 7845854782 - rho_H1 2.1207015241e-22 0.020000144873 - rho_He3 0.0017224909604 0.021023115362 - rho_He4 94365290.111 200001891.25 - rho_C12 0.020000000212 21243051.967 - rho_N14 1.9999977239e-22 0.020000190213 - rho_O16 0.019999999996 19209.485639 - rho_Ne20 0.019999999996 9734.6358293 - rho_Mg24 0.019999999996 23306.635461 - rho_Si28 0.019999999996 2013766.0467 - rho_S32 0.019999999996 1654854.387 - rho_Ar36 0.019999999996 821077.40202 - rho_Ca40 0.019999999996 724428.55057 - rho_Ti44 0.019999999996 34137.672926 - rho_Cr48 0.019999999996 78094.207516 - rho_Fe52 0.019999999996 277975.05929 - rho_Fe54 0.019999999996 94999519.274 - rho_Ni56 0.019999999996 2236723.6985 - rho_n 2.1207015241e-22 234580.251 - rho_p 0.019999995434 3609846.1745 - rho_enuc -4.6916352344e+29 3.5793978339e+32 - pressure 5.5236728673e+25 1.1610546577e+26 - kineng 0 2.0430835425e+24 - soundspeed 612864631.35 895226082.4 - Gamma_1 1.359975607 1.3820247131 - MachNumber 0 0.16100811998 - uplusc 612864631.35 999536286.21 - uminusc -895226453.03 -612859846.92 - entropy 98214771.47 336273518.24 + rho_E 1.3062473821e+26 2.7889438781e+26 + rho_e 1.3062473821e+26 2.7747059271e+26 + Temp 50000000.026 7845854559 + rho_H1 2.1203665799e-22 0.020000114043 + rho_He3 0.0017224849005 0.021021778892 + rho_He4 94384549.451 200001582.65 + rho_C12 0.020000000216 21181006.118 + rho_N14 1.9999997268e-22 0.020000159166 + rho_O16 0.02 19209.472033 + rho_Ne20 0.02 3403.302453 + rho_Mg24 0.02 23330.215568 + rho_Si28 0.02 2016074.1508 + rho_S32 0.02 1656865.76 + rho_Ar36 0.02 822126.88981 + rho_Ca40 0.02 725125.60248 + rho_Ti44 0.02 34184.806642 + rho_Cr48 0.02 78126.082381 + rho_Fe52 0.02 278040.09021 + rho_Fe54 0.02 94986843.638 + rho_Ni56 0.02 2239055.987 + rho_n 0.020000004562 234580.08802 + rho_p 0.019999995438 3609282.9073 + rho_enuc -4.6902991452e+29 3.5778382148e+32 + pressure 5.5236728651e+25 1.1610543806e+26 + kineng 0 2.047804488e+24 + soundspeed 612864631.21 895226062.8 + Gamma_1 1.3599756296 1.3819790602 + MachNumber 0 0.16114515958 + uplusc 612864631.21 999634014.46 + uminusc -895226128.14 -612860627.32 + entropy 98214767.758 336273492.62 magvort 0 0 - divu -97902.982158 33744.686211 - eint_E 6.5312369121e+17 1.3804344246e+18 - eint_e 6.5312369121e+17 1.3804344246e+18 - logden 8.267780753 8.3357372357 - StateErr_0 185259613.21 216639295.98 - StateErr_1 50000004.458 7845854782 - StateErr_2 1e-30 9.9999779304e-11 - X(H1) 1e-30 9.9999779304e-11 - X(He3) 8.9859771063e-12 9.9999601234e-11 - X(He4) 0.48406305162 0.9999999982 - X(C12) 1.0000000106e-10 0.10016992833 - X(N14) 1e-30 1.0000000525e-10 - X(O16) 9.999999998e-11 9.6047401986e-05 - X(Ne20) 9.999999998e-11 4.5902903915e-05 - X(Mg24) 9.999999998e-11 0.00011109993006 - X(Si28) 9.999999998e-11 0.010051430746 - X(S32) 9.999999998e-11 0.0083423100958 - X(Ar36) 9.999999998e-11 0.004162785426 - X(Ca40) 9.999999998e-11 0.0037083550771 - X(Ti44) 9.999999998e-11 0.00017290662768 - X(Cr48) 9.999999998e-11 0.00040059772358 - X(Fe52) 9.999999998e-11 0.001337522714 - X(Fe54) 9.999999998e-11 0.46488979858 - X(Ni56) 9.999999998e-11 0.010324644421 - X(n) 1e-30 0.0011729007238 - X(p) 9.9999977087e-11 0.017592929732 - abar 4.000000001 6.7312458561 - Ye 0.49998677577 0.50001556472 - x_velocity -381.82392939 138572160.27 + divu -97879.954761 33763.419428 + eint_E 6.5312369103e+17 1.3804343698e+18 + eint_e 6.5312369103e+17 1.3804343698e+18 + logden 8.267780861 8.3357095848 + StateErr_0 185259659.3 216625503.34 + StateErr_1 50000000.026 7845854559 + StateErr_2 1e-30 9.9999779324e-11 + X(H1) 1e-30 9.9999779324e-11 + X(He3) 8.9862145938e-12 9.9999601254e-11 + X(He4) 0.48407561714 0.9999999982 + X(C12) 1.0000000108e-10 0.099893133188 + X(N14) 1e-30 1.0000000432e-10 + X(O16) 1e-10 9.6047335509e-05 + X(Ne20) 1e-10 1.6050538078e-05 + X(Mg24) 1e-10 0.00011120690546 + X(Si28) 1e-10 0.010059247336 + X(S32) 1e-10 0.0083490446432 + X(Ar36) 1e-10 0.0041662673673 + X(Ca40) 1e-10 0.0037091533301 + X(Ti44) 1e-10 0.00017295101573 + X(Cr48) 1e-10 0.00040068985616 + X(Fe52) 1e-10 0.0013377863567 + X(Fe54) 1e-10 0.46486808681 + X(Ni56) 1e-10 0.010336068249 + X(n) 1.0000002281e-10 0.001172900139 + X(p) 9.9999977027e-11 0.017594951746 + abar 4.000000001 6.7310197958 + Ye 0.49998669648 0.50001557929 + x_velocity -68.800275809 138706560.7 y_velocity 0 0 z_velocity 0 0 - t_sound_t_enuc 3.4412406672e-13 0.97497430527 - enuc -2.4944881551e+21 1.6522384906e+24 - magvel 0 138572160.27 - radvel -381.82392939 138572160.27 - circvel 0 2 - magmom 0 2.9487648003e+16 + t_sound_t_enuc 3.4412406685e-13 0.97470686938 + enuc -2.4937801624e+21 1.6516237283e+24 + magvel 0 138706560.7 + radvel -68.800275809 138706560.7 + circvel 0 2.8284271247 + magmom 0 2.9527146771e+16 angular_momentum_x 0 0 angular_momentum_y 0 0 angular_momentum_z 0 0 diff --git a/Exec/science/Detonation/problem_initialize.H b/Exec/science/Detonation/problem_initialize.H index 58205bbf24..c625a16440 100644 --- a/Exec/science/Detonation/problem_initialize.H +++ b/Exec/science/Detonation/problem_initialize.H @@ -55,10 +55,15 @@ void problem_initialize () if (problem::in14 >= 0) { problem::xn[problem::in14] = amrex::max(problem::nfrac, problem::smallx); - problem::xn[problem::ihe4] = 1.0_rt - problem::cfrac - problem::nfrac - problem::ofrac - (NumSpec - 3) * problem::smallx; + problem::xn[problem::ihe4] = 1.0_rt - problem::xn[problem::ic12] + - problem::xn[problem::in14] + - problem::xn[problem::io16] + - (NumSpec - 4) * problem::smallx; } else { - problem::xn[problem::ihe4] = 1.0_rt - problem::cfrac - problem::ofrac - (NumSpec - 2) * problem::smallx; + problem::xn[problem::ihe4] = 1.0_rt - problem::xn[problem::ic12] + - problem::xn[problem::io16] + - (NumSpec - 3) * problem::smallx; } // Set the ambient material From 931e173a32f097fd63e0b3c89844fca9bb7f3317 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 27 Mar 2024 17:16:18 -0400 Subject: [PATCH 51/56] Enforce clang-tidy via CI (#2802) --- .github/workflows/clang-tidy.yml | 31 +++++++++++++++++++ .../dependencies_clang-tidy-apt-llvm.sh | 22 +++++++++++++ Exec/hydro_tests/Sedov/problem_initialize.H | 12 +++---- Source/hydro/Castro_mol.cpp | 2 +- Source/hydro/trans.cpp | 4 +-- Source/sources/Castro_sources.cpp | 12 +++---- 6 files changed, 68 insertions(+), 15 deletions(-) create mode 100644 .github/workflows/clang-tidy.yml create mode 100755 .github/workflows/dependencies_clang-tidy-apt-llvm.sh diff --git a/.github/workflows/clang-tidy.yml b/.github/workflows/clang-tidy.yml new file mode 100644 index 0000000000..1a4435a650 --- /dev/null +++ b/.github/workflows/clang-tidy.yml @@ -0,0 +1,31 @@ +name: "clang-tidy" + +on: [pull_request] +jobs: + clang_tidy: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: Get submodules + run: | + git submodule update --init + cd external/Microphysics + git fetch; git checkout development + echo "MICROPHYSICS_HOME=$(pwd)" >> $GITHUB_ENV + cd ../amrex + git fetch; git checkout development + echo "AMREX_HOME=$(pwd)" >> $GITHUB_ENV + cd ../.. + + - name: Install dependencies + run: | + .github/workflows/dependencies_clang-tidy-apt-llvm.sh 17 + + - name: Compile flame_wave + run: | + echo $AMREX_HOME + echo $MICROPHYSICS_HOME + cd Exec/science/subchandra + make USE_MPI=FALSE USE_CLANG_TIDY=TRUE CLANG_TIDY=clang-tidy-17 CLANG_TIDY_WARN_ERROR=TRUE -j 4 + diff --git a/.github/workflows/dependencies_clang-tidy-apt-llvm.sh b/.github/workflows/dependencies_clang-tidy-apt-llvm.sh new file mode 100755 index 0000000000..b64cd619eb --- /dev/null +++ b/.github/workflows/dependencies_clang-tidy-apt-llvm.sh @@ -0,0 +1,22 @@ +#!/usr/bin/env bash + +set -eu -o pipefail + +# `man apt.conf`: +# Number of retries to perform. If this is non-zero APT will retry +# failed files the given number of times. +echo 'Acquire::Retries "3";' | sudo tee /etc/apt/apt.conf.d/80-retries + +if [[ ! -f /etc/apt/trusted.gpg.d/apt.llvm.org.asc ]]; then + wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | sudo tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc +fi + +source /etc/os-release # set UBUNTU_CODENAME + +sudo add-apt-repository "deb http://apt.llvm.org/${UBUNTU_CODENAME}/ llvm-toolchain-${UBUNTU_CODENAME} main" +sudo add-apt-repository "deb http://apt.llvm.org/${UBUNTU_CODENAME}/ llvm-toolchain-${UBUNTU_CODENAME}-$1 main" + +sudo apt-get update + +sudo apt-get install -y --no-install-recommends \ + clang-tidy-$1 libomp-$1-dev diff --git a/Exec/hydro_tests/Sedov/problem_initialize.H b/Exec/hydro_tests/Sedov/problem_initialize.H index b056e41349..fb0eb76814 100644 --- a/Exec/hydro_tests/Sedov/problem_initialize.H +++ b/Exec/hydro_tests/Sedov/problem_initialize.H @@ -22,10 +22,7 @@ void problem_initialize () } } - Real xn_zone[NumSpec]; - for (int n = 0; n < NumSpec; ++n) { - xn_zone[n] = 0.0_rt; - } + Real xn_zone[NumSpec] = {0.0}; xn_zone[0] = 1.0_rt; eos_t eos_state; @@ -96,17 +93,20 @@ void problem_initialize () vctr = (4.0_rt / 3.0_rt) * M_PI * problem::r_init * problem::r_init * problem::r_init; #else - amrex::Abort("Sedov problem unsupported in 3D axisymmetric geometry."); - #endif } else if (coord_type == 2) { + +#if AMREX_SPACEDIM == 1 // Must have AMREX_SPACEDIM == 1 for this coord_type. vctr = (4.0_rt / 3.0_rt) * M_PI * problem::r_init * problem::r_init * problem::r_init; +#else + amrex::Abort("Sedov problem unsupported in 2-D or 3-D spherical geometry."); +#endif } diff --git a/Source/hydro/Castro_mol.cpp b/Source/hydro/Castro_mol.cpp index 23a004c719..eb6314769c 100644 --- a/Source/hydro/Castro_mol.cpp +++ b/Source/hydro/Castro_mol.cpp @@ -199,7 +199,7 @@ Castro::mol_ppm_reconstruct(const Box& bx, void -Castro::mol_consup(const Box& bx, +Castro::mol_consup(const Box& bx, // NOLINT(readability-convert-member-functions-to-static) #ifdef SHOCK_VAR Array4 const& shk, #endif diff --git a/Source/hydro/trans.cpp b/Source/hydro/trans.cpp index 9c85de9df1..acbc4947df 100644 --- a/Source/hydro/trans.cpp +++ b/Source/hydro/trans.cpp @@ -64,7 +64,7 @@ Castro::trans_single(const Box& bx, void -Castro::actual_trans_single(const Box& bx, +Castro::actual_trans_single(const Box& bx, // NOLINT(readability-convert-member-functions-to-static) int idir_t, int idir_n, int d, Array4 const& q_arr, Array4 const& qo_arr, @@ -521,7 +521,7 @@ Castro::trans_final(const Box& bx, void -Castro::actual_trans_final(const Box& bx, +Castro::actual_trans_final(const Box& bx, // NOLINT(readability-convert-member-functions-to-static) int idir_n, int idir_t1, int idir_t2, int d, Array4 const& q_arr, Array4 const& qo_arr, diff --git a/Source/sources/Castro_sources.cpp b/Source/sources/Castro_sources.cpp index fc5dddce4f..67d736a6d7 100644 --- a/Source/sources/Castro_sources.cpp +++ b/Source/sources/Castro_sources.cpp @@ -522,7 +522,7 @@ Castro::print_all_source_changes(Real dt, bool is_new) // and the hydro advance. advance_status -Castro::pre_advance_operators (Real time, Real dt) +Castro::pre_advance_operators (Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { amrex::ignore_unused(time); amrex::ignore_unused(dt); @@ -560,7 +560,7 @@ Castro::pre_advance_operators (Real time, Real dt) // but before the hydro advance. advance_status -Castro::pre_hydro_operators (Real time, Real dt) +Castro::pre_hydro_operators (Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { amrex::ignore_unused(time); amrex::ignore_unused(dt); @@ -585,7 +585,7 @@ Castro::pre_hydro_operators (Real time, Real dt) // but before the corrector sources. advance_status -Castro::post_hydro_operators (Real time, Real dt) +Castro::post_hydro_operators (Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { amrex::ignore_unused(time); amrex::ignore_unused(dt); @@ -602,13 +602,13 @@ Castro::post_hydro_operators (Real time, Real dt) // Perform all operations that occur after the corrector sources. advance_status -Castro::post_advance_operators (Real time, Real dt) +Castro::post_advance_operators (Real time, Real dt) // NOLINT(readability-convert-member-functions-to-static) { - advance_status status {}; - amrex::ignore_unused(time); amrex::ignore_unused(dt); + advance_status status {}; + #ifndef TRUE_SDC #ifdef REACTIONS status = do_new_reactions(time, dt); From 52936fe58f1b5731cb5c5f6516668868b9ad26f2 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Wed, 27 Mar 2024 17:31:19 -0400 Subject: [PATCH 52/56] use std::filesystem::current_path in job_info (#2805) this eliminates a C routine with a buffer Co-authored-by: Eric T. Johnson --- Source/driver/Castro_io.cpp | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/Source/driver/Castro_io.cpp b/Source/driver/Castro_io.cpp index e66a8b5ac9..9b08cc95a3 100644 --- a/Source/driver/Castro_io.cpp +++ b/Source/driver/Castro_io.cpp @@ -7,6 +7,7 @@ #include #include #include +#include #include #include @@ -578,10 +579,7 @@ Castro::writeJobInfo (const std::string& dir, const Real io_time) jobInfoFile << "output date / time: " << std::put_time(std::localtime(&now), "%c\n") << "\n"; - char currentDir[FILENAME_MAX]; - if (getcwd(currentDir, FILENAME_MAX) != nullptr) { - jobInfoFile << "output dir: " << currentDir << "\n"; - } + jobInfoFile << "output dir: " << std::filesystem::current_path() << "\n"; jobInfoFile << "I/O time (s): " << io_time << "\n"; From 6b90dd1c029eec1655d5348810b283bd0fe764d6 Mon Sep 17 00:00:00 2001 From: "Eric T. Johnson" Date: Wed, 27 Mar 2024 18:23:17 -0400 Subject: [PATCH 53/56] Add concurrency groups to the slow CI actions (#2807) This will cancel any running actions when new commits are pushed to a PR branch. --- .github/workflows/c-linter.yml | 4 ++++ .github/workflows/clang-tidy.yml | 5 +++++ .github/workflows/compiler-warnings.yml | 5 +++++ .github/workflows/detonation-sdc-compare.yml | 5 +++++ .github/workflows/flame_wave-compare.yml | 5 +++++ .github/workflows/gpu_action.yml | 5 +++++ .github/workflows/wdmerger_collision-compare.yml | 5 +++++ 7 files changed, 34 insertions(+) diff --git a/.github/workflows/c-linter.yml b/.github/workflows/c-linter.yml index d575a2f236..a779df810a 100644 --- a/.github/workflows/c-linter.yml +++ b/.github/workflows/c-linter.yml @@ -2,6 +2,10 @@ name: cpp-linter on: [pull_request] +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: cpp-linter: runs-on: ubuntu-latest diff --git a/.github/workflows/clang-tidy.yml b/.github/workflows/clang-tidy.yml index 1a4435a650..f712591a4b 100644 --- a/.github/workflows/clang-tidy.yml +++ b/.github/workflows/clang-tidy.yml @@ -1,6 +1,11 @@ name: "clang-tidy" on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: clang_tidy: runs-on: ubuntu-latest diff --git a/.github/workflows/compiler-warnings.yml b/.github/workflows/compiler-warnings.yml index e8092be3d3..bdc0c627ac 100644 --- a/.github/workflows/compiler-warnings.yml +++ b/.github/workflows/compiler-warnings.yml @@ -1,6 +1,11 @@ name: "compiler warnings" on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: compiler_warnings: runs-on: ubuntu-latest diff --git a/.github/workflows/detonation-sdc-compare.yml b/.github/workflows/detonation-sdc-compare.yml index b8fe7e8568..46038aa534 100644 --- a/.github/workflows/detonation-sdc-compare.yml +++ b/.github/workflows/detonation-sdc-compare.yml @@ -1,6 +1,11 @@ name: detonation-sdc on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: detonation-sdc: runs-on: ubuntu-latest diff --git a/.github/workflows/flame_wave-compare.yml b/.github/workflows/flame_wave-compare.yml index 46ad5b4285..e7cf5cbc4b 100644 --- a/.github/workflows/flame_wave-compare.yml +++ b/.github/workflows/flame_wave-compare.yml @@ -1,6 +1,11 @@ name: flame_wave on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: flame_wave-2d: runs-on: ubuntu-latest diff --git a/.github/workflows/gpu_action.yml b/.github/workflows/gpu_action.yml index 95d65496b0..3c6af431e1 100644 --- a/.github/workflows/gpu_action.yml +++ b/.github/workflows/gpu_action.yml @@ -1,6 +1,11 @@ name: GPU compilation on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: gpu-compilation: runs-on: ubuntu-latest diff --git a/.github/workflows/wdmerger_collision-compare.yml b/.github/workflows/wdmerger_collision-compare.yml index 99551f09dd..8f12f71c89 100644 --- a/.github/workflows/wdmerger_collision-compare.yml +++ b/.github/workflows/wdmerger_collision-compare.yml @@ -1,6 +1,11 @@ name: wdmerger_collision on: [pull_request] + +concurrency: + group: ${{ github.ref }}-${{ github.head_ref }}-${{ github.workflow }} + cancel-in-progress: true + jobs: wdmerger_collision-2d: runs-on: ubuntu-latest From cd731a3af3f04563f58ff2b18900be93c57c1cc3 Mon Sep 17 00:00:00 2001 From: Khanak Bhargava <56127611+khanakbhargava@users.noreply.github.com> Date: Fri, 29 Mar 2024 14:10:51 -0400 Subject: [PATCH 54/56] Added abar to derived variables in doc and rearranged enuc (#2785) --- Docs/source/io.rst | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Docs/source/io.rst b/Docs/source/io.rst index e9dc10993c..1e6191f6f4 100644 --- a/Docs/source/io.rst +++ b/Docs/source/io.rst @@ -304,6 +304,8 @@ Derived variables +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ | variable name | description | derive routine | units | +===================================+===================================================+=============================+=========================================+ +| ``abar`` | Mean atomic mass | ``derabar`` | :math:`\amu` | ++-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ | ``angular_momentum_x``, | Angular momentum / volume in the x, y, or z dir | ``derangmomx``, | :math:`{\rm g~cm^{-1}~s^{-1}}` | | ``angular_momentum_y``, | computed as :math:`[(\rho \ub) \times {\bf r}]_n` | ``derangmomy``, | | | ``angular_momentum_z`` | where :math:`{\bf r}` is the distance from | ``derangmomz`` | | @@ -328,6 +330,8 @@ Derived variables | | :math:`s = s(\rho, e, X_k)`, where `e` is | | | | | computed from :math:`(\rho e)` | | | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ +| ``enuc`` | Nuclear energy generation rate / gram | ``derenuc`` | :math:`{\rm erg~g^{-1}~s^{-1}}` | ++-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ | ``Ertot`` | Total radiation energy density | ``derertot`` | | | | (for multigroup radiation problems) | | | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ @@ -391,8 +395,6 @@ Derived variables | ``y_velocity``, | :math:`\ub = (\rho \ub)/\rho` | | | | ``z_velocity`` | | | | +-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ -| ``enuc`` | Nuclear energy generation rate / gram | ``derenuc`` | :math:`{\rm erg~g^{-1}~s^{-1}}` | -+-----------------------------------+---------------------------------------------------+-----------------------------+-----------------------------------------+ problem-specific plotfile variables ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ From 4c968c3cfd028f1ef321269b6ff2357d89f566ae Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 1 Apr 2024 13:58:36 -0400 Subject: [PATCH 55/56] update changes for 24.04 (#2808) --- CHANGES.md | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/CHANGES.md b/CHANGES.md index 7aeb11c743..d9ec031954 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,3 +1,20 @@ +# 24.04 + + * Some clang-tidy fixes (#2779, #2780, #2781, #2784, #2786, #2787, #2790, + #2791, #2792, #2793, #2797, #2798, #2799, #2800, #2801, #2804) + + * Fix species initialization in the Detonation problem (#2806) + and let it work with NSE (#2765) + + * Sync up with AMReX changes (#2794) + + * wdmerger now reports composition of initial stars (#2767) + + * flame_wave now checks if the `atm_delta` is too small (#2782) + and stores X(ash) (#2773) + + * a bounds issue in the true SDC integration was fixed (#2775) + # 24.03 * Documentation updates (#2742, #2752, #2753) From 4956d32be4cafbe0f7cff7d3697d411c21cd4494 Mon Sep 17 00:00:00 2001 From: Michael Zingale Date: Mon, 1 Apr 2024 14:42:36 -0400 Subject: [PATCH 56/56] update to 24.04 --- external/Microphysics | 2 +- external/amrex | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/external/Microphysics b/external/Microphysics index 02d46a67cf..dfc746f5f3 160000 --- a/external/Microphysics +++ b/external/Microphysics @@ -1 +1 @@ -Subproject commit 02d46a67cf5852509cc35db7850e5f87da495679 +Subproject commit dfc746f5f35ab0e9a32025ca325f83232826f420 diff --git a/external/amrex b/external/amrex index d737886d57..bb7d5cfbfd 160000 --- a/external/amrex +++ b/external/amrex @@ -1 +1 @@ -Subproject commit d737886d574d4f1c0cf76323337b666ecd5bb4e0 +Subproject commit bb7d5cfbfd503f2f014746c32a9646a6ef6dcc5b