Hello,<br><br>I am facing problem in triangulation for few datasets. I have VTK compiled for 64-bit machine and some datasets get triangulated and some do not. I went through the doxygen help for vtkDelaunay2D which says that<br>
<br><b>The Delaunay triangulation can be numerically sensitive in some cases. 
To prevent problems, try to avoid injecting points that will result in 
triangles with bad aspect ratios (1000:1 or greater). In practice this 
means inserting points that are &quot;widely dispersed&quot;, and enables smooth 
transition of triangle sizes throughout the mesh. (You may even want to 
add extra points to create a better point distribution.) If numerical 
problems are present, you will see a warning message to this effect at 
the end of the triangulation process.<br><br></b>Now how can I verify or make sure that there are no numerical problems in the input dataset? I am reading input dataset from a file. Is there any direct or indirect way to remove such problems if they exists?<br>
<br>At very first point I thought of vtkCleanPolyData filter to use. But this takes very long time for large data. If this is the only way to remove numerical problems, then can vtkCleanPolyData filter be made to execute faster?<br>
<br>Please suggest me something. Below is the code I am using<br><br>#include &lt;iostream&gt;<br>#include &lt;vtkPoints.h&gt;<br>#include &lt;vtkDoubleArray.h&gt;<br>#include &lt;vtkPointData.h&gt;<br>#include &lt;vtkPolyData.h&gt;<br>
#include &lt;vtkDelaunay2D.h&gt;<br>#include &lt;vtkCellArray.h&gt;<br>#include &lt;vtkSmartPointer.h&gt;<br>#include &lt;vtkPolyDataMapper.h&gt;<br>#include &lt;vtkRenderer.h&gt;<br>#include &lt;vtkRenderWindowInteractor.h&gt;<br>
#include &lt;vtkRenderWindow.h&gt;<br>#include &lt;vtkCleanPolyData.h&gt;<br><br>int main()<br>{<br>    vtkPoints *points = vtkPoints::New();<br>    vtkDoubleArray *scalarArray = vtkDoubleArray::New();<br>    vtkCellArray *polyVertex = vtkCellArray::New();<br>
    <br>    std::string filename=&quot;carto-gebco.pts&quot;;<br><br>    FILE *fp = fopen(filename.c_str(), &quot;r&quot;);<br>    if(!fp){<br>        std::cout &lt;&lt; &quot;Unable to open file&quot; &lt;&lt; std::endl;<br>
        return -1 ;<br>    }<br><br>    char buffer[256];<br>    char str[256];<br>    double xval, yval, zval;<br>    vtkIdType i = 0;<br>    <br>    while(fgets(buffer, 256, fp)) //return false;<br>    {<br>        str[0]=&#39;\0&#39;;<br>
        sscanf(buffer, &quot;%lf%lf%lf&quot;, &amp;xval, &amp;yval, &amp;zval);<br><br>        points-&gt;InsertPoint(i, xval, <br>            yval,0);<br>        scalarArray-&gt;InsertTuple1(i, zval);<br>        polyVertex-&gt;InsertNextCell(1, &amp;i);<br>
                <br>        i++;<br>    }<br>    std::cout &lt;&lt; &quot;Completed reading input data&quot; &lt;&lt; std::endl;<br>    points-&gt;Modified();<br>    scalarArray-&gt;Modified();<br>    polyVertex-&gt;Modified();<br>
<br>    vtkPolyData *pd = vtkPolyData::New();<br>    pd-&gt;SetPoints(points);<br>    pd-&gt;GetPointData()-&gt;SetScalars(scalarArray);<br>    pd-&gt;SetVerts(polyVertex);<br>    <br>    points-&gt;Delete();<br>    scalarArray-&gt;Delete();<br>
    polyVertex-&gt;Delete();<br><br>    std::cout &lt;&lt; &quot;Checking duplicate points&quot; &lt;&lt; std::endl;<br>    vtkSmartPointer&lt;vtkCleanPolyData&gt; cpd = vtkSmartPointer&lt;vtkCleanPolyData&gt;::New();<br>
    cpd-&gt;SetInput(pd);<br>    pd-&gt;Delete();<br>    cpd-&gt;SetTolerance(0.00001);<br>    cpd-&gt;Update();<br><br>    std::cout &lt;&lt; &quot;Triangulating data&quot; &lt;&lt; std::endl;<br>    vtkDelaunay2D *del = vtkDelaunay2D::New();<br>
    del-&gt;SetInputConnection(cpd-&gt;GetOutputPort());    <br>    del-&gt;SetTolerance(0.00001);<br>    del-&gt;Update();<br><br>    std::cout &lt;&lt; &quot;Completed triangulation&quot; &lt;&lt; std::endl;<br>    vtkSmartPointer&lt;vtkPolyDataMapper&gt; triangulatedMapper =<br>
    vtkSmartPointer&lt;vtkPolyDataMapper&gt;::New();<br>  triangulatedMapper-&gt;SetInputConnection(del-&gt;GetOutputPort());<br>  del-&gt;Delete();<br>  vtkSmartPointer&lt;vtkActor&gt; triangulatedActor =<br>    vtkSmartPointer&lt;vtkActor&gt;::New();<br>
  triangulatedActor-&gt;SetMapper(triangulatedMapper);<br> <br>  // Create a renderer, render window, and interactor<br>  vtkSmartPointer&lt;vtkRenderer&gt; renderer =<br>    vtkSmartPointer&lt;vtkRenderer&gt;::New();<br>
  vtkSmartPointer&lt;vtkRenderWindow&gt; renderWindow =<br>    vtkSmartPointer&lt;vtkRenderWindow&gt;::New();<br>  renderWindow-&gt;AddRenderer(renderer);<br>  vtkSmartPointer&lt;vtkRenderWindowInteractor&gt; renderWindowInteractor =<br>
    vtkSmartPointer&lt;vtkRenderWindowInteractor&gt;::New();<br>  renderWindowInteractor-&gt;SetRenderWindow(renderWindow);<br> <br>  // Add the actor to the scene<br>  renderer-&gt;AddActor(triangulatedActor);<br> // renderer-&gt;AddActor(triangulatedActor);<br>
  renderer-&gt;SetBackground(.3, .6, .3); // Background color green<br> <br>  // Render and interact<br>  renderWindow-&gt;Render();<br>  renderWindowInteractor-&gt;Start();<br><br>    fclose(fp);<br>        <br>    return 0;<br>
}<br><br>Here is a sample input data<br><br><a id="HyperLink1" href="http://www.fileflyer.com/view/dkhbrBR" style="display:inline-block;width:331px">http://www.fileflyer.com/view/dkhbrBR</a><br><br>Thanks<br><br>Regards<br>
Rakesh Patil <b> <br></b>