/usr/share/vtk/Modelling/Cxx/Delaunay3D.cxx is in vtk-examples 5.8.0-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | //
// Delaunay3D
// Usage: Delaunay3D InputFile(.vtp) OutputFile(.vtu)
// where
// InputFile is an XML PolyData file with extension .vtp
// OutputFile is an XML Unstructured Grid file with extension .vtu
//
#include <vtkSmartPointer.h>
#include <vtkCleanPolyData.h>
#include <vtkDelaunay3D.h>
#include <vtkXMLDataSetWriter.h>
#include <vtkXMLPolyDataReader.h>
int main ( int argc, char *argv[] )
{
if (argc != 3)
{
cout << "Usage: " << argv[0]
<< " InputPolyDataFile OutputDataSetFile" << endl;
return EXIT_FAILURE;
}
//Read the file
vtkSmartPointer<vtkXMLPolyDataReader> reader =
vtkSmartPointer<vtkXMLPolyDataReader>::New();
reader->SetFileName (argv[1]);
// Clean the polydata. This will remove duplicate points that may be
// present in the input data.
vtkSmartPointer<vtkCleanPolyData> cleaner =
vtkSmartPointer<vtkCleanPolyData>::New();
cleaner->SetInputConnection (reader->GetOutputPort());
// Generate a tetrahedral mesh from the input points. By
// default, the generated volume is the convex hull of the points.
vtkSmartPointer<vtkDelaunay3D> delaunay3D =
vtkSmartPointer<vtkDelaunay3D>::New();
delaunay3D->SetInputConnection (cleaner->GetOutputPort());
// Write the mesh as an unstructured grid
vtkSmartPointer<vtkXMLDataSetWriter> writer =
vtkSmartPointer<vtkXMLDataSetWriter>::New();
writer->SetFileName ( argv[2] );
writer->SetInputConnection ( delaunay3D->GetOutputPort() );
writer->Write();
return EXIT_SUCCESS;
}
|