Subject: CGAL users discussion list
List archive
[cgal-discuss] remove_self_intersections changes the mesh and the reparation is less than when i build my application in Debug
Chronological Thread
- From: sergio <>
- To:
- Subject: [cgal-discuss] remove_self_intersections changes the mesh and the reparation is less than when i build my application in Debug
- Date: Wed, 4 Jul 2018 02:24:41 -0700 (MST)
- Authentication-results: mail3-smtp-sop.national.inria.fr; spf=None ; spf=SoftFail ; spf=Pass
- Ironport-phdr: 9a23:tGFnvRBY40PSv2xvhZntUyQJP3N1i/DPJgcQr6AfoPdwSPv/oMbcNUDSrc9gkEXOFd2Cra4c1ayO6+jJYi8p2d65qncMcZhBBVcuqP49uEgeOvODElDxN/XwbiY3T4xoXV5h+GynYwAOQJ6tL1LdrWev4jEMBx7xKRR6JvjvGo7Vks+7y/2+94fcbglUhTexe69+IAmrpgjNq8cahpdvJLwswRXTuHtIfOpWxWJsJV2Nmhv3+9m98p1+/SlOovwt78FPX7n0cKQ+VrxYES8pM3sp683xtBnMVhWA630BWWgLiBVIAgzF7BbnXpfttybxq+Rw1DWGMcDwULs5Xymp4aV2Rx/ykCoJOT43/n/UhMJtg61UvB2vqgdjw4PWfI2ZKOZycr/Dcd4cWGFPXtxRVytEAo6kdIsAEfABPelZr4n6ulADqgW+ChOwC+PuzD9IiXH23aog0+QmCgzG0wkgEMgPsHTQttn6KKASUeWswaTO0D7NYfRW2TLn54jJdBAsufeMUqhrfsXKzUkgCRnJgUmXqYzgJz+V2eMNs2+U7+pkS+2jkXIoqwZ0ojS32sgshZPGhoYPxlDD7yV5z4A4LsC7Rk5jedOoDZpduz+AO4doQs4vTXtktDs0x7AIo5K2fjYGxZI6zBDFcfOHaZKH4hf7WeaRPzh4gHVldaq5hxu960SgzPfzWdKv31ZOsCVJiMXDtncI1xDL68iHTOVy/lu51DqS1g3f9PtILV40mKfVMZIt37A9m5QJvUnBACP6gED2g7WXdkUg9Oio8ePnYrD+q5+CLYB7lgD+MqIhmsyxBuQ4KA8OUnOU+eS5zrLj/En5TK9Wgf0xl6nVqIraKtgDpq6lHw9V1Z4u5AqwDzi81NQUhGQILFNeeB2bkojpIErOLevjDfa/hlSsiC1ky+rHPr3nGJXNL2LMnK3vfbZnuAZgz184wtlbop5VEbocO+nbW0nrtdWeAAVqHRazxrP8Bc9y14RWDXyGCa6fP63Vq1ig6ecmIu3Kb4gQ7mWuY8M57uLj2Cdq0WQWerOkiMNOOSKIW89+KkDcWkLCx9IIEGMEpA07FbW4h1iLUDoVbHG3DfllumMLTbm+BIKGfbiDxaSb1X7iTJJTb2FCTFuLFCWwLtjWa7I3cCuXZ/RZvHkEWLymEtJz003osgbwwb5qaOHT/39BuA==
This is may application that i compile in windows in Release with the showed
CMakeList.txt and cgal_vtk_test.cpp files. When I try to repair this file:
Number intersection: 290
https://drive.google.com/file/d/1uqcbZqgtbiiXYjKnzzb5d-OXm4JAHqdx/view?usp=sharing
1. my application build in Release generate the following file:
Number intersections: 179
Add some visible holes and some deformations.
Repairing time:..................201.128 seconds.
https://drive.google.com/file/d/13Vfw0pP5Ymw0oo4RnfRjKTI_aTndb6P4/view?usp=sharing
2. my application compiled in Debug, it generate the following file:
Number intersections: 4
Repairing time:..................1072.96 seconds.
https://drive.google.com/file/d/1x1Z7qaNcnfGC8a24qzJI-DZEF3qqeLqq/view?usp=sharing
with warnings:
Expression : !"Returning no output. Filling hole with extra triangles is not
successful!"
File :
C:\dev\CGAL-4.12\include\CGAL/Polygon_mesh_processing/internal/Hole_filling/Triangulate_hole_polyline.h
Line : 1103
Explanation:
Refer to the bug-reporting instructions at
https://www.cgal.org/bug_report.html
The problem is that in debug build it takes around 17 min for reparacion and
in Release it only takes 3 minutes.
What's wrong?
-------------------------------------------------------------------------------
CMakeList.txt
-------------------------------------------------------------------------------
cmake_minimum_required(VERSION 2.8.4)
project( cgal_vtk_test )
# Find CGAL
find_package(CGAL REQUIRED COMPONENTS Core) # If the dependency is required,
use REQUIRED option - if it's not found CMake will issue an error
include( ${CGAL_USE_FILE} )
# Find VTK
find_package(VTK REQUIRED)
include(${VTK_USE_FILE})
# Setup your executable
#include_directories (BEFORE "include")
include( CGAL_CreateSingleSourceCGALProgram )
create_single_source_cgal_program( "cgal_vtk_test.cpp" ) # This will create
an executable target with name 'cgal_vtk_test'
# Add VTK link libraries to your executable target
target_link_libraries(cgal_vtk_test ${VTK_LIBRARIES})
#target_link_libraries(cgal_vtk_test)
-------------------------------------------------------------------------------
cgal_vtk_test.cpp
-------------------------------------------------------------------------------
#include <fstream>
#include <iomanip>
#include <ctime>
//
----------------------------------------------------------------------------
// CGAL
// ----------------------------------------------------------------------
#include <limits>
#include <CGAL/Polygon_mesh_processing/repair.h>
#include <CGAL/Polygon_mesh_processing/internal/repair_extra.h>
#include <CGAL/Polygon_mesh_processing/corefinement.h>
#include <CGAL/Polygon_mesh_processing/polygon_soup_to_polygon_mesh.h>
#include <CGAL/Polyhedron_3.h>
#include <CGAL/Surface_mesh/Surface_mesh.h>
#include <CGAL/Polygon_mesh_processing/corefinement.h>
#include <CGAL/IO/print_wavefront.h>
#include <CGAL/IO/OBJ_reader.h>
#include <CGAL/IO/print_wavefront.h>
#include <CGAL/assertions.h>
#include <CGAL/IO/STL_reader.h>
#include <CGAL/IO/STL_writer.h>
typedef CGAL::Exact_predicates_inexact_constructions_kernel Kernel;
typedef CGAL::Surface_mesh<Kernel::Point_3> Mesh;
typedef CGAL::Polyhedron_3<Kernel> Polyhedron;
void addStringToFileName(std::string & fileName, const std::string & str)
{
size_t lastindex = fileName.find_last_of(".");
std::string name = fileName.substr(0, lastindex);
fileName = name + str;
}
bool repairOBJFile(std::string & fileName)
{
clock_t begin = clock();
std::cout << std::endl;
std::cout << std::endl;
std::cout <<
"..........................................................."
<< std::endl;
std::cout << ". Repairing
."
<< std::endl;
std::cout <<
"..........................................................."
<< std::endl;
std::ifstream input(fileName);
if (!input)
{
std::cerr << "Cannot open file " << std::endl;
return false;
}
std::vector<Kernel::Point_3> points;
std::vector< std::vector<std::size_t> > polygons;
if (!CGAL::read_OBJ(input, points, polygons))
{
std::cerr << "Error parsing the OFF file " << std::endl;
return false;
}
//Mesh mesh;
Polyhedron mesh;
CGAL::Polygon_mesh_processing::orient_polygon_soup(points, polygons);
CGAL::Polygon_mesh_processing::polygon_soup_to_polygon_mesh(points,
polygons, mesh);
bool solved =
CGAL::Polygon_mesh_processing::remove_self_intersections(mesh);
if (!solved)
{
std::cout << "Some self-intersection could not be fixed" <<
std::endl;
//return false;
}
addStringToFileName(fileName, "_fixed.obj");
std::ofstream ofs(fileName);
CGAL::print_polyhedron_wavefront(ofs, mesh);
clock_t end = clock();
double elapsed_secs = double(end - begin) / CLOCKS_PER_SEC;
std::cout << std::endl;
std::cout << std::endl;
std::cout << "Repairing time:.................." << elapsed_secs << "
seconds."<< std::endl;
return true;
}
int main(int argc, char* argv[])
{
std::string fileName = argv[1];
repairOBJFile(fileName);
return 0;
}
--
Sent from: http://cgal-discuss.949826.n4.nabble.com/
- [cgal-discuss] remove_self_intersections changes the mesh and the reparation is less than when i build my application in Debug, sergio, 07/04/2018
Archive powered by MHonArc 2.6.18.