#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/Polygon_mesh_processing/approximated_centroidal_Voronoi_diagram_remeshing.h>
#include <CGAL/Polygon_mesh_processing/connected_components.h>
#include <CGAL/Polygon_mesh_processing/IO/polygon_mesh_io.h>
#include <CGAL/Surface_mesh.h>
#include <iostream>
#include <filesystem>
namespace PMP = CGAL::Polygon_mesh_processing;
int main(int argc, char* argv[])
{
Mesh smesh;
const std::string filename = (argc > 1) ?
argv[1] :
const std::string stem = std::filesystem::path(filename).stem().string();
const std::string extension = std::filesystem::path(filename).extension().string();
const int nb_clusters = (argc > 2) ? atoi(argv[2]) : 3000;
const std::string nbc = std::to_string(nb_clusters);
{
std::cerr << "Invalid input file." << std::endl;
return EXIT_FAILURE;
}
auto fcm = smesh.add_property_map<Mesh::Face_index, std::size_t>("fcm", 0).first;
if (nbcc!=1)
{
std::cerr << "The input is not a single connected component mesh." << std::endl;
return EXIT_FAILURE;
}
std::cout << "Uniform Isotropic ACVD ...." << std::endl;
Mesh acvd_mesh = smesh;
std::cout << "Completed" << std::endl;
std::cout << "Uniform Isotropic ACVD with QEM optimization ...." << std::endl;
Mesh acvd_mesh_qem_pp = smesh;
std::cout << "Completed" << std::endl;
std::cout << "Uniform QEM ACVD ...." << std::endl;
Mesh acvd_mesh_qem = smesh;
std::cout << "Adaptive Isotropic ACVD ...." << std::endl;
const double gradation_factor = 2;
Mesh adaptive_acvd_mesh = smesh;
std::cout << "Completed" << std::endl;
return 0;
}
unsigned int get_seed() const
boost::property_traits< FaceComponentMap >::value_type connected_components(const PolygonMesh &pmesh, FaceComponentMap fcm, const NamedParameters &np=parameters::default_values())
bool approximated_centroidal_Voronoi_diagram_remeshing(TriangleMesh &tmesh, std::size_t nb_vertices, const NamedParameters &np=parameters::default_values())
performs Approximated Centroidal Voronoi Diagram (ACVD) remeshing on a triangle mesh.
Definition: approximated_centroidal_Voronoi_diagram_remeshing.h:1401
bool read_polygon_mesh(const std::string &fname, Graph &g, const NamedParameters &np=parameters::default_values())
bool write_polygon_mesh(const std::string &fname, Graph &g, const NamedParameters &np=parameters::default_values())
Random & get_default_random()
std::string data_file_path(const std::string &filename)