Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Isotropic Remeshing Part 2 (Works without MM) #812

Draft
wants to merge 125 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
125 commits
Select commit Hold shift + click to select a range
66760d0
isotropic remeshing updates for future component updates
mtao Oct 6, 2024
1fdc217
Merge remote-tracking branch 'base/main' into mtao/isotropic_remeshing_2
mtao Oct 7, 2024
def8afc
enabling isotropic remeshing by default
mtao Oct 7, 2024
9166970
Updating input options to allow for custom working directories
mtao Oct 8, 2024
dcd7a75
adding more verbose output to integration test script
mtao Oct 8, 2024
6649181
removing spearation between uv and 3d isotropic remeshing
mtao Oct 8, 2024
e1d9539
updating procedural for updated output spec and removing integration …
mtao Oct 8, 2024
b214c08
robustness in input, adding tet example
mtao Oct 8, 2024
0b81f7e
blindly enabling isotropic remeshing in 3d
mtao Oct 8, 2024
91b69cb
removing input statement
mtao Oct 8, 2024
d780482
added smaller example to debug
danielepanozzo Oct 9, 2024
1dc359a
Merge branch 'mtao/isotropic_remeshing_2' of github.com:wildmeshing/w…
danielepanozzo Oct 9, 2024
da75dd2
valence improvement checks for boundary now, isotropic doesnt always …
mtao Oct 9, 2024
d32544b
updating trimesh names
mtao Oct 9, 2024
a47fee4
starting to check for tri vs tet swaps
mtao Oct 9, 2024
d0c7117
adding EdgeSwap basic class to represent splitt collapse pairs
mtao Oct 10, 2024
ef62e83
making things compile
mtao Oct 10, 2024
cb8f2dd
adding const getters and removing superfluous inline in edgeswap
mtao Oct 10, 2024
488777e
adding stuff
mtao Oct 12, 2024
adda62b
builds again now
mtao Oct 13, 2024
b312e6d
temporarily moving periodic opt into isotropic to merge together
mtao Oct 17, 2024
283b35a
cleaning up procedural and isotropic argument parsing to lie in imlem…
mtao Oct 18, 2024
553cac3
fixing procedural options setting
mtao Oct 19, 2024
f7e24f3
updates
mtao Oct 21, 2024
e45cb59
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Oct 24, 2024
03d741a
fixing types of meshes in wildmeshing
mtao Oct 24, 2024
d2c8bd9
fixing noexcept compilation errors on gcc13
mtao Oct 24, 2024
4c577c6
cleaning up use of auto_size variable
mtao Oct 24, 2024
cbc79c3
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Oct 26, 2024
719c123
fixing procedural main
mtao Oct 26, 2024
fe4e076
updating procedural run
mtao Oct 26, 2024
12115f2
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Oct 27, 2024
6d5bfec
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 2, 2024
c72e19c
minor refactor in integration test runTest func
mtao Nov 2, 2024
a7a303b
trying to debug examples
mtao Nov 2, 2024
98b1b4e
reversing order of trimesh is_ccw autogen funcs to silence a warning
mtao Nov 2, 2024
9f94ea7
updates to isotropic remeshing
mtao Nov 2, 2024
21b7b67
still chasing why collapse is bad
mtao Nov 2, 2024
1cacdef
test configuration is redone if config_path is updated
mtao Nov 3, 2024
bb9282e
adding raw examples of isotropci remeshing despite not working yet
mtao Nov 4, 2024
76d2c17
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 5, 2024
c35b502
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 7, 2024
6cbc3d0
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 15, 2024
4ffdf75
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 16, 2024
09a7027
fixing input
mtao Nov 16, 2024
3e60ec6
formatting procedural examples
mtao Nov 16, 2024
49ca650
temporarily clearing test on cli11 callbacks in procedural
mtao Nov 16, 2024
fa4fe9d
fixing test ocnfig path in examples
mtao Nov 17, 2024
ef996c3
re-enabling collapse
mtao Nov 17, 2024
a4fd80e
adding element count report for isotropic remeshing and adding 100071…
mtao Nov 17, 2024
ea5dc3e
adding verbose flag for integration test script
mtao Nov 17, 2024
31759fb
clearing print statements on integration failure in verbose mode
mtao Nov 17, 2024
e673401
updates
mtao Nov 19, 2024
1f453ab
Moving utils to new folder
mtao Nov 19, 2024
5f65e69
update
mtao Nov 19, 2024
6be156c
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 21, 2024
c116daa
updates to tetmesh swap
mtao Nov 22, 2024
8f989b0
adding minor options to camel isotropic example
mtao Nov 22, 2024
b80f6c6
Merge branch 'mtao/isotropic_remeshing_2' of github.com:wildmeshing/w…
mtao Nov 22, 2024
fb3403a
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 22, 2024
aa7980c
builds now
mtao Nov 22, 2024
697e475
Merge branch 'mtao/isotropic_remeshing_2' of github.com:wildmeshing/w…
mtao Nov 22, 2024
1e1a6b8
Merge branch 'mtao/attribute_fetcher' into mtao/isotropic_remeshing_2
mtao Nov 22, 2024
726031a
Merge remote-tracking branch 'upstream/mtao/isotropic_remeshing_2' in…
mtao Nov 22, 2024
1ed2a34
update
mtao Nov 23, 2024
0fbdc06
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 25, 2024
0644b92
compiles agagian
mtao Nov 25, 2024
8a3d88e
adding get_integration_test stuff
mtao Nov 25, 2024
323df07
adding resolver path adding
mtao Nov 26, 2024
858bb3a
updating input and output to use path instead of file
mtao Nov 26, 2024
4c1b344
moving home, named multimesh default injection broken
mtao Nov 26, 2024
21b4806
updating some logic
mtao Nov 28, 2024
d3f70c5
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Nov 28, 2024
2c47a4c
fixing default naming in multimesh naming scheme
mtao Nov 29, 2024
413ed13
making output capable of default handling many outputs
mtao Nov 29, 2024
70cf1b9
updating isotropic examples to complete in a sane amount of time
mtao Dec 1, 2024
b011a32
increasing iterations done by small example
mtao Dec 1, 2024
c327776
adding format to output component
mtao Dec 1, 2024
ae8526c
adding more json and updating convert and isometric
mtao Dec 2, 2024
521b1cd
moving isotropic remeshing to be class based
mtao Dec 3, 2024
fda9161
minor fix
mtao Dec 3, 2024
7389dbf
updates
mtao Dec 3, 2024
4e8fdfa
commiting to show some diff
mtao Dec 4, 2024
9670b86
changing simpelx constructor
mtao Dec 4, 2024
46e24f4
adding func to get attr description
mtao Dec 5, 2024
caa7087
Merge branch 'mtao/test_config_reconfigure' into mtao/isotropic_remes…
mtao Dec 5, 2024
15d6bc6
Merge branch 'mtao/autogen_tests' into mtao/isotropic_remeshing_2
mtao Dec 5, 2024
64b15f4
adding is_Valid to mesh naming to validate that the mesh structures m…
mtao Dec 6, 2024
f55952e
minor updates
mtao Dec 6, 2024
04480fe
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Dec 6, 2024
458933f
Merge branch 'mtao/flag_accessor' into mtao/isotropic_remeshing_2
mtao Dec 7, 2024
9a7153a
minor update
mtao Dec 8, 2024
1cf0627
Merge branch 'mtao/flag_accessor' into mtao/isotropic_remeshing_2
mtao Dec 8, 2024
e5439b8
adding typedefs to DynamicArray to satisfy iterator traits
mtao Dec 9, 2024
111be95
adding disjoint set impl
mtao Dec 9, 2024
3f63919
adding equality comparison to DynamicArray
mtao Dec 9, 2024
851e5a5
adding debug option for extra verbose outputs
mtao Dec 9, 2024
c1ea3b1
update
mtao Dec 9, 2024
21bf802
changing header parameters to more clearly indicate that params are
mtao Dec 9, 2024
936662c
starting tool for checking valences
mtao Dec 10, 2024
48473af
adding independent simplex indexing tool
mtao Dec 10, 2024
db79155
adding an index-based manifoldy checker
mtao Dec 10, 2024
750704a
update
mtao Dec 10, 2024
008fd84
removing global id stuff that was breaking tupleinspector
mtao Dec 10, 2024
7556bfd
Adding a validation flag for the InputOptions
mtao Dec 10, 2024
1439678
adding validation flag usage to the inputoptions
mtao Dec 10, 2024
0f866e5
adding instantiations for indexsimplexmapper
mtao Dec 10, 2024
e03ee31
adding print support to AttributeType
mtao Dec 11, 2024
507c163
more verbose updates
mtao Dec 11, 2024
22746e5
updates
mtao Dec 12, 2024
869a3ef
adding extra ways to construct envelope invariants
mtao Dec 13, 2024
a2d8f7f
adding extra isotropic remeshing files
mtao Dec 13, 2024
d7bac6d
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Dec 13, 2024
8a5669d
cleaning up mah and making attributetype printable
mtao Dec 13, 2024
09d6105
adding test for attribute type name functions
mtao Dec 15, 2024
f58b053
converting string_view to string in catch2
mtao Dec 15, 2024
01aa6a1
making input component only do tests if component test flag is active
mtao Dec 15, 2024
28f8005
Merge branch 'mtao/attribute_types' into mtao/isotropic_remeshing_2
mtao Dec 15, 2024
7c72659
updates
mtao Dec 17, 2024
ccc7f02
Merge remote-tracking branch 'upstream/main' into mtao/isotropic_reme…
mtao Dec 17, 2024
e365652
setting fusion of up for building
mtao Dec 17, 2024
05f8f7c
adding controls for ignoring swap
mtao Dec 17, 2024
0d882ba
asdf
mtao Dec 20, 2024
4dd7919
adding example raws
mtao Dec 20, 2024
b124232
abstracting simplex inversion invariant to allow for inverted meshes
mtao Dec 23, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,10 @@ else()
target_compile_features(wildmeshing_toolkit PUBLIC cxx_std_17)
endif()

option(WMTK_MTAO_CONSTANTLY_VERIFY_MESH "verify mesh" OFF)
if(WMTK_MTAO_CONSTANTLY_VERIFY_MESH)
target_compile_options(wildmeshing_toolkit PUBLIC -DMTAO_CONSTANTLY_VERIFY_MESH)
endif()
#target_compile_options(wildmeshing_toolkit PUBLIC -fconcepts)

# the max dimension an attribute can be - default is to be any size (a dynamic size), but this can be set to a number like 6
Expand Down
2 changes: 1 addition & 1 deletion applications/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ add_application(delaunay ON)
add_application(marching ON)
add_application(procedural ON)
add_application(multimesh OFF)
add_application(isotropic_remeshing OFF)
add_application(isotropic_remeshing ON)
add_application(tetwild_simplification ON)
add_application(triwild ON)
add_application(tetwild ON)
Expand Down
11 changes: 6 additions & 5 deletions applications/cmake/wmtk_generate_test_config.cmake
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
function(wmtk_generate_test_config CFG)
FILE(WRITE ${CMAKE_BINARY_DIR}/test_config.json "{\n")


set(FILE_CONTENTS "{\n")
foreach(TEST_CONFIG ${CFG})
FILE(APPEND ${CMAKE_BINARY_DIR}/test_config.json "${TEST_CONFIG},\n")
string(APPEND FILE_CONTENTS "${TEST_CONFIG},\n")
endforeach()

FILE(APPEND ${CMAKE_BINARY_DIR}/test_config.json "\"skip\":{}}\n")
string(APPEND FILE_CONTENTS "\"skip\":{}}\n")

FILE(WRITE ${CMAKE_BINARY_DIR}/test_config.json "${FILE_CONTENTS}")
endfunction()


2 changes: 2 additions & 0 deletions applications/cmake/wmtk_register_integration_test.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ macro(wmtk_register_integration_test )
\"extra_flags\":\"${_EXTRA_ARGUMENTS}\"
}")

set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/.." APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS "${_CONFIG_PATH}")

SET(WMTK_TEST_CONFIG ${WMTK_TEST_CONFIG} PARENT_SCOPE)
SET(WMTK_APPLICATION_TEST_NAMES ${WMTK_APPLICATION_TEST_NAMES} PARENT_SCOPE)
endmacro()
2 changes: 1 addition & 1 deletion applications/convert/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,5 @@ wmtk_register_integration_test(
CONFIG_PATH ${CMAKE_CURRENT_SOURCE_DIR}/examples
GIT_REPOSITORY "https://github.com/wildmeshing/data.git"
GIT_TAG 363f8e860673a4e4f68df6465b99e86809c96283
#EXTRA_ARGUMENTS run
EXTRA_ARGUMENTS json
)
145 changes: 113 additions & 32 deletions applications/convert/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
#include <filesystem>
#include <nlohmann/json.hpp>
#include <wmtk/applications/utils/element_count_report.hpp>
#include <wmtk/applications/utils/get_integration_test_data_root.hpp>

#include <wmtk/Mesh.hpp>
#include <wmtk/utils/Logger.hpp>
Expand All @@ -18,8 +19,11 @@

#include "CLI/CLI.hpp"
#include "wmtk/components/multimesh/MeshCollection.hpp"
#include "wmtk/components/multimesh/axis_aligned_fusion.hpp"
#include "wmtk/components/multimesh/from_boundary.hpp"
#include "wmtk/components/multimesh/from_facet_bijection.hpp"
#include "wmtk/components/multimesh/utils/AttributeDescription.hpp"
#include "wmtk/components/multimesh/utils/get_attribute.hpp"
#include "wmtk/components/utils/PathResolver.hpp"

using namespace wmtk::components;
Expand Down Expand Up @@ -74,32 +78,57 @@ std::shared_ptr<wmtk::Mesh> merge_meshes(
parent_named_mesh.append_child_mesh_names(parent_mesh, child_named_mesh);

return parent_mesh.shared_from_this();
} else if (type == "axis_aligned_periodic") {
std::string position_attr_path = child_datas["position_attribute"];
wmtk::components::multimesh::utils::AttributeDescription ad;
ad.path = position_attr_path;
auto mah = wmtk::components::multimesh::utils::get_attribute(mc, ad);

std::vector<bool> mask = child_datas["axes"];
std::string output_mesh_name = child_datas["fused_mesh_name"];
std::optional<double> eps;
if (child_datas.contains("epsilon")) {
eps = child_datas["epsilon"].get<double>();
}
if (!eps.has_value()) {
eps = 1e-10;
}
auto mptr = components::multimesh::axis_aligned_fusion(mah, mask, eps.value());
const auto& nmm = mc.get_named_multimesh(position_attr_path);

nlohmann::json jsout;
jsout[output_mesh_name] = *nmm.get_names_json();
mc.add_mesh(wmtk::components::multimesh::NamedMultiMesh(*mptr, jsout));

return mptr;
}
}
}
return nullptr;
}
} // namespace

int run(const fs::path& config_path /*, const std::optional<fs::path>& name_spec_file*/)
int run_js(
const std::string_view& app_name,
const nlohmann::json& j,
const std::optional<fs::path>& name_spec_file,
const std::optional<fs::path>& integration_test_config_file)
{
nlohmann::json j;
{
std::ifstream ifs(config_path);
j = nlohmann::json::parse(ifs);
// if (name_spec_file.has_value()) {
// j["name"] = nlohmann::json::parse(std::ifstream(name_spec_file.value()));
// }
}

spdlog::warn("{}", j.dump(2));

// if (name_spec_file.has_value()) {
// j["name"] = nlohmann::json::parse(std::ifstream(name_spec_file.value()));
// }
wmtk::components::multimesh::MeshCollection meshes;
components::utils::PathResolver path_resolver;

if (j.contains("root")) {
path_resolver = j["root"];
}
if (integration_test_config_file.has_value()) {
auto path = wmtk::applications::utils::get_integration_test_data_root(
integration_test_config_file.value(),
app_name);
path_resolver.add_path(path);
}

std::shared_ptr<wmtk::Mesh> output_mesh;
if (j["input"].is_array()) {
Expand All @@ -120,29 +149,22 @@ int run(const fs::path& config_path /*, const std::optional<fs::path>& name_spec

if (!j.contains("output")) {
wmtk::logger().info("convert: No output path provided");
} else if (j["output"].is_object()) {
for (const auto& [mesh_path, out_opts_js] : j["output"].items()) {
auto opts = out_opts_js.get<wmtk::components::output::OutputOptions>();

wmtk::components::output::output(meshes.get_mesh(mesh_path), opts);
}
} else {
auto opts = j["output"].get<wmtk::components::output::OutputOptions>();
wmtk::components::output::output(*output_mesh, opts);
std::map<std::string, wmtk::components::output::OutputOptions> output_opts = j["output"];
wmtk::components::output::output(meshes, output_opts);
}


if (j.contains("report")) {
nlohmann::json jnew = j;
const std::string report = j["report"];
meshes.make_canonical();
if (!report.empty()) {
nlohmann::json out_json;
auto& stats = out_json["stats"];
for (const auto& [name, mesh] : meshes.all_meshes()) {
stats[name] = wmtk::applications::utils::element_count_report_named(mesh);
}
j.erase("report");
out_json["input"] = j;
stats = wmtk::applications::utils::element_count_report_named(meshes);
jnew.erase("report");
out_json["input"] = jnew;


std::ofstream ofs(report);
Expand All @@ -152,6 +174,18 @@ int run(const fs::path& config_path /*, const std::optional<fs::path>& name_spec
return 0;
}

int run(
const std::string_view& app_name,
const fs::path& config_path,
const std::optional<fs::path>& name_spec_file,
const std::optional<fs::path>& integration_test_config_file)
{
nlohmann::json j;
std::ifstream ifs(config_path);
j = nlohmann::json::parse(ifs);

return run_js(app_name, j, name_spec_file, integration_test_config_file);
}

int main(int argc, char* argv[])
{
Expand All @@ -160,21 +194,50 @@ int main(int argc, char* argv[])
app.ignore_case();

fs::path json_input_file;
std::optional<fs::path> json_integration_config_file;
std::optional<std::string> json_integration_app_name;
std::optional<fs::path> name_spec_file;

CLI::App* run_cmd; // = app.add_subcommand("run", "Run application");
run_cmd = &app;
run_cmd->add_option("-j, --json", json_input_file, "json specification file")
auto add_it_path = [&](CLI::App& a) {
a.add_option(
"-c, --integration-test-config",
json_integration_config_file,
"Test config file for integration test")
->check(CLI::ExistingFile);
a.add_option(
"-a, --integration-test-app",
json_integration_config_file,
"Test config file for integration test")
->check(CLI::ExistingFile);
};

CLI::App* json_cmd = app.add_subcommand("json", "Run application using a json");
json_cmd->add_option("-j, --json", json_input_file, "json specification file")
->required(true)
->check(CLI::ExistingFile);

add_it_path(*json_cmd);


fs::path input;
fs::path output;
std::string type;
CLI::App* run_cmd = app.add_subcommand("run", "Convert mesh to another type");
run_cmd->add_option("-i, --input", input, "input file")
->required(true)
->check(CLI::ExistingFile);

// run_cmd->add_option("-n, --name_spec", name_spec_file, "json specification file")
run_cmd->add_option("-o, --output", output, "output file");
run_cmd->add_option("-t, --type", type, "output file type, knows [vtu,hdf5]");
add_it_path(*run_cmd);


// json_cmd->add_option("-n, --name_spec", name_spec_file, "json specification file")
// ->check(CLI::ExistingFile);

CLI11_PARSE(app, argc, argv);

// someday may add other suboptions
assert(run_cmd->parsed());

// if (!json_input_file.has_value() && !fill_config_path.has_value()) {
// wmtk::logger().error("An input json file with [-j] is required unless blank config "
Expand All @@ -184,12 +247,30 @@ int main(int argc, char* argv[])

int exit_mode = -1;

// run_cmd->callback([&]() {
// json_cmd->callback([&]() {
// spdlog::warn("YOW!");
// assert(json_input_file.has_value());
// exit_mode = run(json_input_file.value());
// });
exit_mode = run(json_input_file /*, name_spec_file*/);
if (json_cmd->parsed()) {
exit_mode = run(argv[0], json_input_file, name_spec_file, json_integration_config_file);
} else {
wmtk::components::input::InputOptions in;
in.path = input;
wmtk::components::output::OutputOptions out;
out.path = output;
out.position_attribute = "vertices";
if (!type.empty() && type[0] != '.') {
type = '.' + type;
}
out.type = type;

nlohmann::json js;
js["input"] = in;
js["output"][""] = out;

exit_mode = run_js(argv[0], js, name_spec_file, json_integration_config_file);
}


assert(exit_mode != -1); // "Some subcommand should have updated the exit mode"
Expand Down
Loading
Loading