From 919722381044f15d930f864c9408f0788bc92383 Mon Sep 17 00:00:00 2001 From: Timo Heister Date: Wed, 14 Feb 2024 16:28:13 -0500 Subject: [PATCH] gwb-grid: support for filtering cells Add a new option --by-tag that enables filtering of cells inside gwb-grid. To actually do something useful, we need support inside GWB to provide tag information. So, right now, this option randomly selects some cells to be shown. fix warning fix bugs --- source/gwb-grid/main.cc | 98 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 96 insertions(+), 2 deletions(-) diff --git a/source/gwb-grid/main.cc b/source/gwb-grid/main.cc index f561fb952..3e6fe922d 100644 --- a/source/gwb-grid/main.cc +++ b/source/gwb-grid/main.cc @@ -33,6 +33,9 @@ #include "world_builder/world.h" #include "world_builder/config.h" +#include + + #include "vtu11/vtu11.hpp" #undef max #undef min @@ -61,6 +64,71 @@ using namespace WorldBuilder; using namespace WorldBuilder::Utilities; + +/** + * Filter the cells of a VTU mesh based on a given tag. All tags with smaller value than @p first_tag will be removed + */ +void filter_vtu_mesh(int dim, + int first_tag, + vtu11::Vtu11UnstructuredMesh &input_mesh, + const std::vector &input_data, + vtu11::Vtu11UnstructuredMesh &output_mesh, + std::vector &output_data); + +void filter_vtu_mesh(int dim, + int first_tag, + vtu11::Vtu11UnstructuredMesh &input_mesh, + const std::vector &input_data, + vtu11::Vtu11UnstructuredMesh &output_mesh, + std::vector &output_data) +{ + output_data.resize(input_data.size()); + const std::int64_t invalid = static_cast(-1); + std::vector vertex_index_map(input_mesh.points().size(), invalid); + + const unsigned int n_vert_per_cell = (dim==3)?8:4; + + const std::size_t n_cells = input_mesh.types().size(); + std::uint64_t dst_cellid = 0; + for (std::size_t cellidx = 0; cellidx (input_data[2][src_vid])); + } + if (highest_tag < first_tag) + continue; + + ++dst_cellid; + + for (unsigned int idx=cellidx*n_vert_per_cell; idx<(cellidx+1)*n_vert_per_cell; ++idx) + { + const std::int64_t src_vid = input_mesh.connectivity()[idx]; + + std::int64_t dst_vid = vertex_index_map[src_vid]; + if (dst_vid == invalid) + { + dst_vid = output_mesh.points().size()/3; + vertex_index_map[src_vid] = dst_vid; + + for (int i=0; i<3; ++i) + output_mesh.points().push_back(input_mesh.points()[src_vid*3+i]); + + for (unsigned int d=0; d::difference_type>(i)); options_vector.erase(options_vector.begin()+static_cast::difference_type>(i)); } + if (options_vector[i] == "--by-tag") + { + output_by_tag = true; + options_vector.erase(options_vector.begin()+static_cast::difference_type>(i)); + } } if (options_vector.size() != 2) @@ -1505,9 +1582,26 @@ int main(int argc, char **argv) std::cout << "[6/6] Writing the paraview file \r"; std::cout.flush(); - vtu11::Vtu11UnstructuredMesh mesh { points, connectivity, offsets, types }; - vtu11::writeVtu( file_without_extension + ".vtu", mesh, dataSetInfo, data_set, vtu_output_format ); + { + vtu11::Vtu11UnstructuredMesh mesh { points, connectivity, offsets, types }; + vtu11::writeVtu( file_without_extension + ".vtu", mesh, dataSetInfo, data_set, vtu_output_format ); + if (output_by_tag) + { + std::vector filtered_points; + std::vector filtered_connectivity; + std::vector filtered_offsets; + std::vector filtered_types; + + vtu11::Vtu11UnstructuredMesh filtered_mesh {filtered_points, filtered_connectivity, filtered_offsets, filtered_types}; + std::vector filtered_data_set; + + int first_tag = 0; + filter_vtu_mesh(dim, first_tag, mesh, data_set, filtered_mesh, filtered_data_set); + + vtu11::writeVtu( file_without_extension + ".filtered.vtu", filtered_mesh, dataSetInfo, filtered_data_set, vtu_output_format ); + } + } std::cout << " \r"; std::cout.flush(); }