<div dir="ltr">Hi Wen,<br><br>Many thanks for your helpful ideas.<br>I've tried to manage with those ideas and got to the following algorithm and code:<br><br>generaly, I'd like to divide my poly (actually, the outer skin of the head) to regions such that each point in the surface will be in a region. after that I'd like to select from each region the point with the lower value (scalar).<br>
The head is represented with vtkPolyData and vtkFloatArray such that indexes is locations(address) in the head and scalars are values as described below.<br><br>the technique to do that is to divide my poly by vtkOctree to X regions:<br>
<br> vtkSmartPointer<vtkOctreePointLocator> octree = vtkSmartPointer<vtkOctreePointLocator>::New();<br> octree->SetDataSet(polyHead);<br> octree->SetMaximumPointsPerRegion(polyHead->GetNumberOfPoints()/divisionFactor);//divisionFactor is the number of regions that I'd like to divide my head<br>
octree->BuildLocator();<br><br>go to each region and find the point with the lowest value by vtkFloatArray <br> for(int i=1; i<divisionFactor; i++)//division factor is number of regions of the head<br> {<br>
vtkIdTypeArray* points = octree->GetPointsInRegion(i);<br> minValInRegion=1000000;<br><br> //get address that represents location on the head, go to that index in the array and get its value<br> for(vtkIdType idx=1; idx< points->GetSize(); idx++)<br>
{<br> curIdxInRegion = points->GetValue(idx);<br> curValInRegion = headArray->GetValue(curIdxInRegion);<br> if(curValInRegion < minValInRegion)<br> {<br> minValInRegion = curValInRegion; <br>
minIdxInRegion = curIdxInRegion;<br> }<br> }<br> }<br><br>With this code, I don't get distinct indexes which are far away from each other. <br>I want to get indexes in each region ...<br>
<br>How do I get that ?<br><br>Thanks in advance.<br>Hila<br><br><div class="gmail_quote">On Wed, May 2, 2012 at 12:07 AM, Li, Wen <span dir="ltr"><<a href="mailto:wen-li@uiowa.edu" target="_blank">wen-li@uiowa.edu</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word">
Hi Hila,
<div><br>
</div>
<div>I understand better about your problem now.</div>
<div><br>
</div>
<div>You want to group your vertices on a surface according to some distance?</div>
<div>Can you search of a seed vertex(point) with extreme coordinates along one axis (x, or y, or z).</div>
<div>And then use the Euclidean distance to classify vertices?</div>
<div><br>
</div>
<div>Maybe the problem you are facing is more complicated than this.</div>
<div><br>
</div>
<div>Hope it helps though,</div>
<div>Wen</div><div><div class="h5">
<div><br>
</div>
<div>
<div>
<div>On May 1, 2012, at 7:49 AM, Hila Hiler wrote:</div>
<br>
<blockquote type="cite">
<div dir="ltr"><br>
Hi Wen, <br>
many thanks for your answer.<br>
<br>
I've read about kDTree and wondered if the OcTree is better (I have a 3D image).<br>
please detail (if you know) why KdTree is better than OcTree or the opposite ...<br>
<br>
regarding my first q: <br>
-------------------------<br>
my data structure:<br>
vtkPolyData <=> vtkFloatArray <=> Scalars<br>
<br>
I'm searching for a method that divides the poly to regions (how do I insert the number of the required regions) and returns the indexes (vtkIdType) + its corresponding scalar (float) in each region.
<br>
<br>
How I can get this?<br>
<br>
Best and thanks in advance.<br>
Hila<br>
<br>
<br>
<br>
<div class="gmail_quote">On Sun, Apr 29, 2012 at 10:32 PM, Li, Wen <span dir="ltr">
<<a href="mailto:wen-li@uiowa.edu" target="_blank">wen-li@uiowa.edu</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word">Hila,
<div><br>
</div>
<div>Is <span style="white-space:nowrap">vtkKdTreePointLocator::FindPointsWithinRadius going to help you?</span></div>
<div><span style="font-weight:bold;white-space:nowrap"><br>
</span></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap">You can exclude points within a specific radius and the rest points on the surface are beyond that value.</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap"><br>
</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap">You are right about the point ids. neighboring points could have very different point Ids.</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap"><br>
</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap">Good Luck,</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap">Wen</span></font></div>
<div><font face="Geneva, Arial, Helvetica, sans-serif"><span style="white-space:nowrap"><br>
</span></font></div>
<div>
<div>
<div>
<div>
<div>On Apr 29, 2012, at 2:21 PM, Hila Hiler wrote:</div>
<br>
</div>
</div>
<blockquote type="cite">
<div>
<div>
<div dir="ltr">Hi All,<br>
<br>
I'd like to get some <b>distant points</b> on a surface (in this case, a head).<br>
How do I know what the distance value should be?<br>
<br>
Actually, in my program I use this type: vtkIdType and with a loop move on a vtkPolyData.<br>
I tried to guess a number (5000), presented the points on the surface but realized that even that those points look very close, their indexes are faraway from each other- so I guess that I don't have a clue about it :-)<br>
<br>
<br>
so, any idea how I should find indexes/points which are faraway from each other on a surface ?<br>
<br>
<br>
Thanks in advance.<br>
<br>
Hila <br>
</div>
</div>
</div>
_______________________________________________<br>
Powered by <a href="http://www.kitware.com/" target="_blank">www.kitware.com</a><br>
<br>
Visit other Kitware open-source projects at <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">
http://www.kitware.com/opensource/opensource.html</a><br>
<br>
Please keep messages on-topic and check the VTK FAQ at: <a href="http://www.vtk.org/Wiki/VTK_FAQ" target="_blank">
http://www.vtk.org/Wiki/VTK_FAQ</a><br>
<br>
Follow this link to subscribe/unsubscribe:<br>
<a href="http://www.vtk.org/mailman/listinfo/vtkusers" target="_blank">http://www.vtk.org/mailman/listinfo/vtkusers</a><br>
</blockquote>
</div>
<br>
</div>
</div>
</blockquote>
</div>
<br>
</div>
</blockquote>
</div>
<br>
</div>
</div></div></div>
</blockquote></div><br></div>