diff --git a/Exec/LyA/ascent_actions.yaml b/Exec/LyA/ascent_actions.yaml index 8fbab5703..1b26889bd 100644 --- a/Exec/LyA/ascent_actions.yaml +++ b/Exec/LyA/ascent_actions.yaml @@ -1,35 +1,14 @@ --- -- - action: add_pipelines - pipelines: - slice: - f1: - params: - normal: - x: 0.0 - ? "y" - : 0.0 - z: 1.0 - point: - x: 0.0 - ? "y" - : 0.0 - z: 0.0 - topology: topo - type: exaslice - action: add_extracts extracts: e1: + type: volume + params: + field: xh + filename: xh_pic + e2: + type: volume params: - fields: - - Density - - Xmom - - Ymom - - Zmom - - rho_E - - rho_e - path: the_slice - protocol: blueprint/mesh/hdf5 - pipeline: slice - type: relay + field: density + filename: density_pic diff --git a/Source/IO/Nyx_output.cpp b/Source/IO/Nyx_output.cpp index fdc708329..eac9c122a 100644 --- a/Source/IO/Nyx_output.cpp +++ b/Source/IO/Nyx_output.cpp @@ -1086,7 +1086,7 @@ Nyx::updateInSitu () #endif #ifdef REEBER - amrex::Vector& reeber_halos); + amrex::Vector reeber_halos; halo_find(parent->dtLevel(level), reeber_halos); halo_print(reeber_halos); #endif diff --git a/Util/reeber/src/reeber.cpp b/Util/reeber/src/reeber.cpp index 7e193c868..9d0e3cfa8 100644 --- a/Util/reeber/src/reeber.cpp +++ b/Util/reeber/src/reeber.cpp @@ -159,7 +159,7 @@ void prepare_master_reader( int finest_level, const Vector& level_refinements, const amrex::Geometry geom_in, - std::vector>& pointers_to_copied_data) + std::vector& pointers_to_copied_data) { std::vector new_state_vars { "density", "xmom", "ymom", "zmom" }; const size_t density_var_idx = 0; @@ -227,7 +227,10 @@ void prepare_master_reader( gid_to_fab_size[gid] = core_fab_size; pointers_to_copied_data.emplace_back(new Real[core_fab_size]); - Real* core_fab_ptr = pointers_to_copied_data.back().get(); + // Real* core_fab_ptr = pointers_to_copied_data.back().get(); + + // HACK: use raw pointer to avoid double free + Real* core_fab_ptr = pointers_to_copied_data.back(); GridRef core_grid_ref(core_fab_ptr, core_shape, false); @@ -266,7 +269,10 @@ void prepare_master_reader( // reserve memory for dm_density pointers_to_copied_data.emplace_back(new Real[core_fab_size]); - Real* extra_ptr_copy = pointers_to_copied_data.back().get(); + // Real* extra_ptr_copy = pointers_to_copied_data.back().get(); + + // HACK: use raw pointer to avoid double free + Real* extra_ptr_copy = pointers_to_copied_data.back(); extra_pointers.push_back(extra_ptr_copy); // reserve memory for variables in new_state @@ -430,7 +436,7 @@ std::vector compute_halos(diy::mpi::communicator& world, new Block(b->fab, b->extra_names_, b->extra_fabs_, local_ref, local_lev, diy_domain, l->bounds(), l->core(), cp.gid(), - new_link, absolute_rho, negate, /*absolute = */ true, cell_volume), + new_link, absolute_rho, negate, /* wrap = */ true, /*absolute = */ true, cell_volume), new_link); //if (debug) fmt::print(std::cerr, "Added block gid = {}\n", cp.gid()); @@ -571,7 +577,8 @@ void Nyx::runReeberAnalysis(Vector& new_state, // store pointers to all dynamically allocated arrays, so that // data will be freed automatically after exiting compute_halos - std::vector> pointers_to_copied_data; + // std::vector> pointers_to_copied_data; + std::vector pointers_to_copied_data; // HACK: avoid double free diy::mpi::communicator world = ParallelDescriptor::Communicator();