Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > d5e74628f0e673bb8680aebce32b2c04 > files > 17289

itk-doc-3.12.0-1mdv2010.0.i586.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html><head><meta name="robots" content="noindex">
<meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>ITK: itkSimplexMeshAdaptTopologyFilter.h Source File</title>
<link href="DoxygenStyle.css" rel="stylesheet" type="text/css">
</head><body bgcolor="#ffffff">


<!--  Section customized for INSIGHT : Tue Jul 17 01:02:45 2001 -->
<center>
<a href="index.html" class="qindex">Main Page</a>&nbsp;&nbsp; 
<a href="modules.html" class="qindex">Groups</a>&nbsp;&nbsp;
<a href="namespaces.html" class="qindex">Namespace List</a>&nbsp;&nbsp;
<a href="hierarchy.html" class="qindex">Class Hierarchy</a>&nbsp;&nbsp;
<a href="classes.html" class="qindex">Alphabetical List</a>&nbsp;&nbsp;
<a href="annotated.html" class="qindex">Compound List</a>&nbsp;&nbsp; 
<a href="files.html" class="qindex">File
List</a>&nbsp;&nbsp; 
<a href="namespacemembers.html" class="qindex">Namespace Members</a>&nbsp;&nbsp; 
<a href="functions.html" class="qindex">Compound Members</a>&nbsp;&nbsp; 
<a href="globals.html" class="qindex">File Members</a>&nbsp;&nbsp;
<a href="pages.html" class="qindex">Concepts</a></center>


<!-- Generated by Doxygen 1.5.9 -->
  <div class="navpath"><a class="el" href="dir_02e23d841c198393a6e961e9a0678fff.html">Code</a>&nbsp;&raquo&nbsp;<a class="el" href="dir_00ffda33c24cbbf617b202f4f3bcb7e8.html">BasicFilters</a>
  </div>
<div class="contents">
<h1>itkSimplexMeshAdaptTopologyFilter.h</h1><a href="itkSimplexMeshAdaptTopologyFilter_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*=========================================================================</span>
<a name="l00002"></a>00002 <span class="comment"></span>
<a name="l00003"></a>00003 <span class="comment">Program:   Insight Segmentation &amp; Registration Toolkit</span>
<a name="l00004"></a>00004 <span class="comment">Module:    $RCSfile: itkSimplexMeshAdaptTopologyFilter.h,v $</span>
<a name="l00005"></a>00005 <span class="comment">Language:  C++</span>
<a name="l00006"></a>00006 <span class="comment">Date:      $Date: 2008-10-17 20:49:56 $</span>
<a name="l00007"></a>00007 <span class="comment">Version:   $Revision: 1.12 $</span>
<a name="l00008"></a>00008 <span class="comment"></span>
<a name="l00009"></a>00009 <span class="comment">Copyright (c) Insight Software Consortium. All rights reserved.</span>
<a name="l00010"></a>00010 <span class="comment">See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.</span>
<a name="l00011"></a>00011 <span class="comment"></span>
<a name="l00012"></a>00012 <span class="comment">This software is distributed WITHOUT ANY WARRANTY; without even </span>
<a name="l00013"></a>00013 <span class="comment">the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR </span>
<a name="l00014"></a>00014 <span class="comment">PURPOSE.  See the above copyright notices for more information.</span>
<a name="l00015"></a>00015 <span class="comment"></span>
<a name="l00016"></a>00016 <span class="comment">=========================================================================*/</span>
<a name="l00017"></a>00017 <span class="preprocessor">#ifndef __itkSimplexMeshAdaptTopologyFilter_h</span>
<a name="l00018"></a>00018 <span class="preprocessor"></span><span class="preprocessor">#define __itkSimplexMeshAdaptTopologyFilter_h</span>
<a name="l00019"></a>00019 <span class="preprocessor"></span>
<a name="l00020"></a>00020 <span class="preprocessor">#include "<a class="code" href="itkMesh_8h.html">itkMesh.h</a>"</span>
<a name="l00021"></a>00021 <span class="preprocessor">#include "<a class="code" href="itkPolygonCell_8h.html">itkPolygonCell.h</a>"</span>
<a name="l00022"></a>00022 <span class="preprocessor">#include "<a class="code" href="itkMapContainer_8h.html">itkMapContainer.h</a>"</span>
<a name="l00023"></a>00023 <span class="preprocessor">#include "<a class="code" href="itkCellInterfaceVisitor_8h.html">itkCellInterfaceVisitor.h</a>"</span>
<a name="l00024"></a>00024 
<a name="l00025"></a>00025 <span class="preprocessor">#include "<a class="code" href="itkSimplexMesh_8h.html">itkSimplexMesh.h</a>"</span>
<a name="l00026"></a>00026 <span class="preprocessor">#include "<a class="code" href="itkSimplexMeshGeometry_8h.html">itkSimplexMeshGeometry.h</a>"</span>
<a name="l00027"></a>00027 <span class="preprocessor">#include "<a class="code" href="itkMeshToMeshFilter_8h.html">itkMeshToMeshFilter.h</a>"</span>
<a name="l00028"></a>00028 <span class="preprocessor">#include "<a class="code" href="itkVectorContainer_8h.html">itkVectorContainer.h</a>"</span>
<a name="l00029"></a>00029 <span class="preprocessor">#include &lt;<a class="code" href="itkCovariantVector_8h.html">itkCovariantVector.h</a>&gt;</span>
<a name="l00030"></a>00030 
<a name="l00031"></a>00031 <span class="preprocessor">#include &lt;vxl_version.h&gt;</span>
<a name="l00032"></a>00032 <span class="preprocessor">#if VXL_VERSION_DATE_FULL &gt; 20040406</span>
<a name="l00033"></a>00033 <span class="preprocessor"></span><span class="preprocessor"># include &lt;vnl/vnl_cross.h&gt;</span>
<a name="l00034"></a>00034 <span class="preprocessor"># define itk_cross_3d vnl_cross_3d</span>
<a name="l00035"></a>00035 <span class="preprocessor"></span><span class="preprocessor">#else</span>
<a name="l00036"></a><a class="code" href="itkSimplexMeshAdaptTopologyFilter_8h.html#0fbefe4c7b27f890824182089e21d0f9">00036</a> <span class="preprocessor"></span><span class="preprocessor"># define itk_cross_3d cross_3d</span>
<a name="l00037"></a>00037 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
<a name="l00038"></a>00038 <span class="preprocessor"></span>
<a name="l00039"></a>00039 <span class="keyword">namespace </span>itk
<a name="l00040"></a>00040 {
<a name="l00051"></a>00051 <span class="keyword">template</span> &lt;<span class="keyword">class</span> TInputMesh, <span class="keyword">class</span> TOutputMesh&gt;
<a name="l00052"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html">00052</a> <span class="keyword">class </span><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">SimplexMeshAdaptTopologyFilter</a> : <span class="keyword">public</span> <a class="code" href="classitk_1_1MeshToMeshFilter.html" title="MeshToMeshFilter is the base class for all process objects that output mesh data...">MeshToMeshFilter</a>&lt;TInputMesh, TOutputMesh&gt;
<a name="l00053"></a>00053 {
<a name="l00054"></a>00054 
<a name="l00055"></a>00055 <span class="keyword">public</span>:
<a name="l00057"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#2ba93cdd521de4c92f65040c15d05659">00057</a>   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">SimplexMeshAdaptTopologyFilter</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">Self</a>;
<a name="l00058"></a>00058 
<a name="l00060"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#0132ee3065400209cf2ad0c2f1a507d2">00060</a>   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1MeshToMeshFilter.html">MeshToMeshFilter&lt;TInputMesh, TOutputMesh&gt;</a> <a class="code" href="classitk_1_1MeshToMeshFilter.html">Superclass</a>;
<a name="l00061"></a>00061 
<a name="l00063"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#39660941849e850e4f39e7bdf444202b">00063</a>   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1SmartPointer.html">SmartPointer&lt;Self&gt;</a>  <a class="code" href="classitk_1_1SmartPointer.html">Pointer</a>;
<a name="l00064"></a>00064 
<a name="l00066"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#35418c8e8d769bac0101b8af5245ed74">00066</a>   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1SmartPointer.html">SmartPointer&lt;const Self&gt;</a>  <a class="code" href="classitk_1_1SmartPointer.html">ConstPointer</a>;
<a name="l00067"></a>00067 
<a name="l00069"></a>00069   <a class="code" href="itkMacro_8h.html#0fdc15685afa271857c57e7cd482f30c">itkNewMacro</a>(<a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">Self</a>);
<a name="l00070"></a>00070 
<a name="l00072"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#aa3c5f8130472fc6755c817bc07e4101">00072</a>   <a class="code" href="itkMacro_8h.html#574c1f86661d409dd32c742307a0e96a">itkTypeMacro</a>(<a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">SimplexMeshAdaptTopologyFilter</a>,<a class="code" href="classitk_1_1MeshToMeshFilter.html" title="MeshToMeshFilter is the base class for all process objects that output mesh data...">MeshToMeshFilter</a>);
<a name="l00073"></a>00073 
<a name="l00074"></a>00074   <span class="keyword">typedef</span> TInputMesh                                              <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#aa3c5f8130472fc6755c817bc07e4101">InputMeshType</a>;
<a name="l00075"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d4e8bf24e5bac5b24750e4a8744f3d07">00075</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="itkFEMMacro_8h.html#539cce1a3282ba59952dedcbf9cdb23f">InputMeshType::Pointer</a>                         <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d4e8bf24e5bac5b24750e4a8744f3d07">InputMeshPointer</a>;
<a name="l00076"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#44f416df0e9172f957172b25674c9c75">00076</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::PointType                       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#44f416df0e9172f957172b25674c9c75">InputPointType</a>;
<a name="l00077"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#14b539359fdc858b3bde5acbac810055">00077</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::VectorType                      <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#14b539359fdc858b3bde5acbac810055">InputVectorType</a>;
<a name="l00078"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#99046081db166e11c1edd30528656de6">00078</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::PixelType                       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#99046081db166e11c1edd30528656de6">InputPixelType</a>;
<a name="l00079"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#87eeecddde5ef40dbb50e8388236c0a1">00079</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::MeshTraits::CellTraits          <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#87eeecddde5ef40dbb50e8388236c0a1">InputCellTraitsType</a>;
<a name="l00080"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#a80dd8fc8bf58f79abdf24dc2a7e9200">00080</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::CellType                        <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#a80dd8fc8bf58f79abdf24dc2a7e9200">InputCellType</a>;
<a name="l00081"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#e6aea8952134c477b9dc8c029b3bc010">00081</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputCellType::PointIdIterator                 <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#e6aea8952134c477b9dc8c029b3bc010">InputCellPointIdIterator</a>;
<a name="l00082"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#25374a882104be92ed87a25d524c3932">00082</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputCellType::CellAutoPointer                 <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#25374a882104be92ed87a25d524c3932">InputCellAutoPointer</a>;
<a name="l00083"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#bb7c329c5907e9619836ad849300358e">00083</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputMeshType::CellAutoPointer                 <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#bb7c329c5907e9619836ad849300358e">CellAutoPointer</a>;
<a name="l00084"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#88922e69b77a3718a26609db95af0a51">00084</a>   <span class="keyword">typedef</span>          <a class="code" href="classitk_1_1PolygonCell.html">itk::PolygonCell&lt;InputCellType&gt;</a>                <a class="code" href="classitk_1_1PolygonCell.html">InputPolygonType</a>;
<a name="l00085"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#1fc8ad6a809d0c3cf06ae740dd011101">00085</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> InputPolygonType::PointIdIterator              <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#1fc8ad6a809d0c3cf06ae740dd011101">InputPolygonPointIdIterator</a>;
<a name="l00086"></a>00086   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1CovariantVector.html" title="A templated class holding a n-Dimensional covariant vector.">CovariantVector</a>&lt; 
<a name="l00087"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d8857843489964def688aab2e2e62c8d">00087</a>     <span class="keyword">typename</span> InputVectorType::ValueType, 3 &gt;                      <a class="code" href="classitk_1_1CovariantVector.html" title="A templated class holding a n-Dimensional covariant vector.">CovariantVectorType</a>;
<a name="l00088"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#e35fc9cac82282eb5518761e288d9c0e">00088</a>   <span class="keyword">typedef</span>  TOutputMesh                                            <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#e35fc9cac82282eb5518761e288d9c0e">OutputMeshType</a>;
<a name="l00089"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d932d49ec1424f4475db0f3f0d3184d1">00089</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="itkFEMMacro_8h.html#539cce1a3282ba59952dedcbf9cdb23f">OutputMeshType::Pointer</a>                        <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d932d49ec1424f4475db0f3f0d3184d1">OutputMeshPointer</a>;
<a name="l00090"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#2efb33a8fe10175daf437410e02838c7">00090</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> OutputMeshType::CellType                       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#2efb33a8fe10175daf437410e02838c7">OutputCellType</a>;
<a name="l00091"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#ac85430aff988975405ec7cad2d4637d">00091</a>   <span class="keyword">typedef</span>          <a class="code" href="classitk_1_1PolygonCell.html">itk::PolygonCell&lt;OutputCellType&gt;</a>               <a class="code" href="classitk_1_1PolygonCell.html">OutputPolygonType</a>;
<a name="l00092"></a>00092   
<a name="l00093"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#06c41ed35f63d7acf9c6e69b00bea6a3">00093</a>   <span class="keyword">typedef</span>          <a class="code" href="classitk_1_1MapContainer.html">itk::MapContainer&lt;unsigned long, double&gt;</a>       <a class="code" href="classitk_1_1MapContainer.html">DoubleValueMapType</a>;
<a name="l00094"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#5a4f29fea5e5bbc23af69b1810d72f04">00094</a>   <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="classitk_1_1MapContainer_1_1Iterator.html" title="The non-const iterator type for the map.">DoubleValueMapType::Iterator</a>                   <a class="code" href="classitk_1_1MapContainer_1_1Iterator.html" title="The non-const iterator type for the map.">DoubleContainerIterator</a>;
<a name="l00095"></a>00095 
<a name="l00096"></a>00096 
<a name="l00103"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html">00103</a>   <span class="keyword">class </span><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html">SimplexCellVisitor</a>
<a name="l00104"></a>00104     {
<a name="l00105"></a>00105 
<a name="l00106"></a>00106     <span class="keyword">public</span>:
<a name="l00107"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">00107</a>       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d4e8bf24e5bac5b24750e4a8744f3d07">InputMeshPointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>;
<a name="l00108"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#90d52f0215782676b16cfdc2d473bb8b">00108</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#90d52f0215782676b16cfdc2d473bb8b">totalArea</a>;
<a name="l00109"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#235d19ec852e0a90f8401f8ecd5b1d32">00109</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#235d19ec852e0a90f8401f8ecd5b1d32">totalCurvature</a>;
<a name="l00110"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">00110</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">minCellSize</a>;
<a name="l00111"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">00111</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">maxCellSize</a>;
<a name="l00112"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6e1cbf482c8e8d1c3894561691968b70">00112</a>       <a class="code" href="classitk_1_1SmartPointer.html">DoubleValueMapType::Pointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6e1cbf482c8e8d1c3894561691968b70">areaMap</a>;
<a name="l00113"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">00113</a>       <a class="code" href="classitk_1_1SmartPointer.html">DoubleValueMapType::Pointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">curvatureMap</a>;
<a name="l00114"></a>00114 
<a name="l00115"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">00115</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">minCurvature</a>;
<a name="l00116"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">00116</a>       <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">maxCurvature</a>;
<a name="l00117"></a>00117   
<a name="l00118"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#9824f1c8359696a5348c68ba7859b573">00118</a>     <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#9824f1c8359696a5348c68ba7859b573">SimplexCellVisitor</a>()
<a name="l00119"></a>00119       {
<a name="l00120"></a>00120       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6e1cbf482c8e8d1c3894561691968b70">areaMap</a> = <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#3201df05dd5f7f77674c2289d5d4a545">DoubleValueMapType::New</a>();
<a name="l00121"></a>00121       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">curvatureMap</a> = <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#3201df05dd5f7f77674c2289d5d4a545">DoubleValueMapType::New</a>();
<a name="l00122"></a>00122       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#90d52f0215782676b16cfdc2d473bb8b">totalArea</a> = 0;
<a name="l00123"></a>00123       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#235d19ec852e0a90f8401f8ecd5b1d32">totalCurvature</a> = 0;
<a name="l00124"></a>00124       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">minCellSize</a> = NumericTraits&lt;double&gt;::max();
<a name="l00125"></a>00125       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">maxCellSize</a> = 0;
<a name="l00126"></a>00126       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">minCurvature</a> = NumericTraits&lt;double&gt;::max();
<a name="l00127"></a>00127       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">maxCurvature</a> = 0;
<a name="l00128"></a>00128       }
<a name="l00129"></a>00129 
<a name="l00133"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#909f516def521294933d5f04e5544f76">00133</a>     <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#909f516def521294933d5f04e5544f76" title="visits all polygon cells and computes the area, NOTE: works for convex polygons only!!!...">Visit</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cellId, <a class="code" href="classitk_1_1PolygonCell.html">InputPolygonType</a> * poly)
<a name="l00134"></a>00134       {
<a name="l00135"></a>00135       <span class="keyword">typename</span> InputPolygonType::PointIdIterator it =  poly-&gt;<a class="code" href="classitk_1_1PolygonCell.html#b5b8fa8bd6661e1da4e7e1d6f8e94425">PointIdsBegin</a>();
<a name="l00136"></a>00136       
<a name="l00137"></a>00137       <span class="keywordtype">double</span> meanCurvature = 0;
<a name="l00138"></a>00138       <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> refPoint = *it;
<a name="l00139"></a>00139       <span class="keywordtype">double</span> val = <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetMeanCurvature(*it++);
<a name="l00140"></a>00140       meanCurvature += vcl_abs(val);
<a name="l00141"></a>00141 
<a name="l00142"></a>00142       <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> id1 = *it;
<a name="l00143"></a>00143       val = <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetMeanCurvature(*it++);
<a name="l00144"></a>00144       meanCurvature += vcl_abs(val);
<a name="l00145"></a>00145 
<a name="l00146"></a>00146       <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> id2;
<a name="l00147"></a>00147       
<a name="l00148"></a>00148       <span class="keywordtype">double</span> area = 0;
<a name="l00149"></a>00149       
<a name="l00150"></a>00150       <span class="keywordtype">int</span> cnt = 0; 
<a name="l00151"></a>00151         
<a name="l00152"></a>00152       <span class="keywordflow">while</span> ( it != poly-&gt;<a class="code" href="classitk_1_1PolygonCell.html#6d7b6f2bf0a1db7212f0d0fa91a31bd4">PointIdsEnd</a>() )
<a name="l00153"></a>00153         {
<a name="l00154"></a>00154         id2 = *it;
<a name="l00155"></a>00155         area += <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#e1f85d934d0f7cd793b1deae34b838b5">ComputeArea</a>(refPoint,id1,id2);
<a name="l00156"></a>00156         id1 = id2;
<a name="l00157"></a>00157         val = <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetMeanCurvature(*it);
<a name="l00158"></a>00158         meanCurvature += vcl_abs(val);
<a name="l00159"></a>00159         cnt++;
<a name="l00160"></a>00160         it++;
<a name="l00161"></a>00161         }
<a name="l00162"></a>00162 
<a name="l00163"></a>00163       meanCurvature /= (double)cnt;
<a name="l00164"></a>00164       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#90d52f0215782676b16cfdc2d473bb8b">totalArea</a> += area;
<a name="l00165"></a>00165       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#235d19ec852e0a90f8401f8ecd5b1d32">totalCurvature</a> += meanCurvature;
<a name="l00166"></a>00166 
<a name="l00167"></a>00167       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6e1cbf482c8e8d1c3894561691968b70">areaMap</a>-&gt;InsertElement(cellId, area);
<a name="l00168"></a>00168       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">curvatureMap</a>-&gt;InsertElement(cellId, meanCurvature);
<a name="l00169"></a>00169 
<a name="l00170"></a>00170       <span class="keywordflow">if</span> (area &gt; <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">maxCellSize</a> ) <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">maxCellSize</a> = area;
<a name="l00171"></a>00171       <span class="keywordflow">if</span> (area &lt; <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">minCellSize</a> ) <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">minCellSize</a> = area;
<a name="l00172"></a>00172       <span class="keywordflow">if</span> (meanCurvature &gt; <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">maxCurvature</a> ) <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">maxCurvature</a> = meanCurvature;
<a name="l00173"></a>00173       <span class="keywordflow">if</span> (meanCurvature &lt; <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">minCurvature</a> ) <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">minCurvature</a> = meanCurvature;
<a name="l00174"></a>00174       }
<a name="l00175"></a>00175 
<a name="l00176"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#e1f85d934d0f7cd793b1deae34b838b5">00176</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#e1f85d934d0f7cd793b1deae34b838b5">ComputeArea</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> p1,<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> p2, <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> p3)
<a name="l00177"></a>00177       {
<a name="l00178"></a>00178       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#44f416df0e9172f957172b25674c9c75">InputPointType</a> v1,v2,v3;
<a name="l00179"></a>00179       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetPoint(p1, &amp;v1);
<a name="l00180"></a>00180       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetPoint(p2, &amp;v2);
<a name="l00181"></a>00181       <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#33ebce4a473eed6dc7dd981a36fd49fb">mesh</a>-&gt;GetPoint(p3, &amp;v3);
<a name="l00182"></a>00182       <span class="keywordflow">return</span> vcl_abs (<a class="code" href="itkSimplexMeshAdaptTopologyFilter_8h.html#0fbefe4c7b27f890824182089e21d0f9">itk_cross_3d</a>((v2-v1).GetVnlVector(), (v3-v1).GetVnlVector()).two_norm() /2.0);
<a name="l00183"></a>00183       }
<a name="l00184"></a>00184 
<a name="l00185"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#54253c6a412cbf572b7f2f9d62c99914">00185</a>     <a class="code" href="classitk_1_1SmartPointer.html">DoubleValueMapType::Pointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#54253c6a412cbf572b7f2f9d62c99914">GetAreaMap</a>()
<a name="l00186"></a>00186       {
<a name="l00187"></a>00187       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6e1cbf482c8e8d1c3894561691968b70">areaMap</a>;
<a name="l00188"></a>00188       }
<a name="l00189"></a>00189 
<a name="l00190"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#51e9d62e00687f1582a2382b5d9213ac">00190</a>     <a class="code" href="classitk_1_1SmartPointer.html">DoubleValueMapType::Pointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#51e9d62e00687f1582a2382b5d9213ac">GetCurvatureMap</a>()
<a name="l00191"></a>00191       {
<a name="l00192"></a>00192       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">curvatureMap</a>;
<a name="l00193"></a>00193       }
<a name="l00194"></a>00194 
<a name="l00195"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#e93c3bd0cf4b925c4f595cfce3afff45">00195</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#e93c3bd0cf4b925c4f595cfce3afff45">GetTotalMeshArea</a>()
<a name="l00196"></a>00196       {
<a name="l00197"></a>00197       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#90d52f0215782676b16cfdc2d473bb8b">totalArea</a>;
<a name="l00198"></a>00198       }
<a name="l00199"></a>00199 
<a name="l00200"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#2db29b37005b46d6310cdc4e6396ffc7">00200</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#2db29b37005b46d6310cdc4e6396ffc7">GetTotalMeanCurvature</a>()
<a name="l00201"></a>00201       {
<a name="l00202"></a>00202       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#235d19ec852e0a90f8401f8ecd5b1d32">totalCurvature</a>/(<a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#26fb426cd4a82566b76acd7d7cf1900b">curvatureMap</a>-&gt;Size());
<a name="l00203"></a>00203       }
<a name="l00204"></a>00204 
<a name="l00205"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#cf82f87629357bdd2436c2d76567b966">00205</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#cf82f87629357bdd2436c2d76567b966">GetMaximumCellSize</a>()
<a name="l00206"></a>00206       {
<a name="l00207"></a>00207       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#6b7c736080a3d35d93bee36ba67ee051">maxCellSize</a>;
<a name="l00208"></a>00208       }
<a name="l00209"></a>00209 
<a name="l00210"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#89d7e9c46992dcf4f7e93503b7d9b954">00210</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#89d7e9c46992dcf4f7e93503b7d9b954">GetMinimumCellSize</a>()
<a name="l00211"></a>00211       {
<a name="l00212"></a>00212       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#343dc24b05022dd6904c9adbbe95a408">minCellSize</a>;
<a name="l00213"></a>00213       }
<a name="l00214"></a>00214 
<a name="l00215"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#891898d96e361940967fecc149a64afa">00215</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#891898d96e361940967fecc149a64afa">GetMaximumCurvature</a>()
<a name="l00216"></a>00216       {
<a name="l00217"></a>00217       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#bdf8d1faf491c00c0b48f365b03161b8">maxCurvature</a>;
<a name="l00218"></a>00218       }
<a name="l00219"></a>00219 
<a name="l00220"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#607d91cfe691f4259c74dc754b280f2b">00220</a>     <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#607d91cfe691f4259c74dc754b280f2b">GetMinimumCurvature</a>()
<a name="l00221"></a>00221       {
<a name="l00222"></a>00222       <span class="keywordflow">return</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter_1_1SimplexCellVisitor.html#5de7316e491e8fc44d29ff1a3aa3ee69">minCurvature</a>;
<a name="l00223"></a>00223       }
<a name="l00224"></a>00224     };
<a name="l00225"></a>00225 
<a name="l00226"></a>00226   <span class="comment">// cell visitor stuff</span>
<a name="l00227"></a>00227   <span class="keyword">typedef</span> <a class="code" href="classitk_1_1CellInterfaceVisitorImplementation.html">itk::CellInterfaceVisitorImplementation</a>&lt;<a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#99046081db166e11c1edd30528656de6">InputPixelType</a>,
<a name="l00228"></a>00228                                                   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#87eeecddde5ef40dbb50e8388236c0a1">InputCellTraitsType</a>,
<a name="l00229"></a>00229                                                   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#88922e69b77a3718a26609db95af0a51">InputPolygonType</a>,
<a name="l00230"></a>00230                                                   SimplexCellVisitor&gt;
<a name="l00231"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#afa53801b7f06694d79f64ac5948c760">00231</a>                              <a class="code" href="classitk_1_1CellInterfaceVisitorImplementation.html">SimplexVisitorInterfaceType</a>;
<a name="l00232"></a>00232 
<a name="l00233"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#fadf6fb621cae020a117d949395990c2">00233</a>     <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="classitk_1_1SmartPointer.html">SimplexVisitorInterfaceType::Pointer</a>   <a class="code" href="classitk_1_1SmartPointer.html">SimplexVisitorInterfacePointer</a>;
<a name="l00234"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#bcd771d7852b291d2576794a53b201fe">00234</a>     <span class="keyword">typedef</span> <span class="keyword">typename</span> InputCellType::MultiVisitor            <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#bcd771d7852b291d2576794a53b201fe">CellMultiVisitorType</a>;
<a name="l00235"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#735964ba52e5cbe2d9d2f035c3d2c39e">00235</a>     <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="itkFEMMacro_8h.html#539cce1a3282ba59952dedcbf9cdb23f">CellMultiVisitorType::Pointer</a>          <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#735964ba52e5cbe2d9d2f035c3d2c39e">CellMultiVisitorPointer</a>;
<a name="l00236"></a>00236 
<a name="l00237"></a>00237 
<a name="l00238"></a>00238     <a class="code" href="itkMacro_8h.html#7ebdd33cc5e7d74720ced9099c034faa">itkSetMacro</a>(Threshold, <span class="keywordtype">double</span>);
<a name="l00239"></a>00239     <a class="code" href="itkMacro_8h.html#1600305bb01e39e87c472d8bf29bd1cf">itkGetMacro</a>(Threshold, <span class="keywordtype">double</span>);
<a name="l00240"></a>00240 
<a name="l00241"></a>00241     <a class="code" href="itkMacro_8h.html#7ebdd33cc5e7d74720ced9099c034faa">itkSetMacro</a>(SelectionMethod, <span class="keywordtype">int</span>);
<a name="l00242"></a>00242     <a class="code" href="itkMacro_8h.html#1600305bb01e39e87c472d8bf29bd1cf">itkGetMacro</a>(SelectionMethod, <span class="keywordtype">int</span>);
<a name="l00243"></a>00243 
<a name="l00244"></a>00244     <a class="code" href="itkMacro_8h.html#1600305bb01e39e87c472d8bf29bd1cf">itkGetMacro</a>(ModifiedCount, <span class="keywordtype">int</span>);
<a name="l00245"></a>00245 
<a name="l00246"></a>00246 
<a name="l00247"></a>00247 <span class="keyword">protected</span>:
<a name="l00248"></a>00248 
<a name="l00249"></a>00249   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d95157161a171503d6dddcd12eb8012a">SimplexMeshAdaptTopologyFilter</a>();
<a name="l00250"></a>00250   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#7ff67b6cb27279ee4e8bfcd0ffd0fb4a">~SimplexMeshAdaptTopologyFilter</a>();
<a name="l00251"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#dd402520267f5439988971c7eb7ef3f0">00251</a>   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#dd402520267f5439988971c7eb7ef3f0">SimplexMeshAdaptTopologyFilter</a>(<span class="keyword">const</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">Self</a>&amp;) {}
<a name="l00252"></a>00252 
<a name="l00253"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#ba382ecf06d0aba47c0bef54e566fd17">00253</a>   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#ba382ecf06d0aba47c0bef54e566fd17">operator=</a>(<span class="keyword">const</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html" title="This filter changes the topology of a 2-simplex mesh.">Self</a>&amp;) {}
<a name="l00254"></a>00254 
<a name="l00255"></a>00255   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#43e2e07218b15f2d14c8aedc4237085f">PrintSelf</a>(std::ostream&amp; os, <a class="code" href="classitk_1_1Indent.html" title="Control indentation during Print() invocation.">Indent</a> indent) <span class="keyword">const</span>;
<a name="l00256"></a>00256 
<a name="l00257"></a>00257   <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#64e16d99139e99ba0a93e712ccc7a0e5">GenerateData</a>();
<a name="l00258"></a>00258 
<a name="l00259"></a>00259   
<a name="l00263"></a>00263   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#761172357ae497437a3ae5b5ed2a8b36">Initialize</a>();
<a name="l00264"></a>00264 
<a name="l00270"></a>00270   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#05e9f2cfe0a00d0354f2496359503819">ComputeCellParameters</a>();
<a name="l00271"></a>00271 
<a name="l00275"></a>00275   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#e6b0abaebc46c22937e4072809fc21a5">InsertNewCells</a>();
<a name="l00276"></a>00276 
<a name="l00282"></a>00282   <span class="keywordtype">void</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#12c58287a28a596d8428454af75412e6">ModifyNeighborCells</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> id1, <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> id2, <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> insertPointId);
<a name="l00283"></a>00283 
<a name="l00287"></a>00287   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#44f416df0e9172f957172b25674c9c75">InputPointType</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#fbe34d51a4cd10d701beaa561ad0b678">ComputeCellCenter</a>(<a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#25374a882104be92ed87a25d524c3932">InputCellAutoPointer</a> &amp;simplexCell);
<a name="l00288"></a>00288 
<a name="l00292"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d5a19374dc0c6dc3085fcef83606e8f1">00292</a>   <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d5a19374dc0c6dc3085fcef83606e8f1">m_IdOffset</a>;
<a name="l00293"></a>00293 
<a name="l00298"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#c6ac3dead84ac2ca3db49cbc93283b55">00298</a>   <span class="keywordtype">double</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#c6ac3dead84ac2ca3db49cbc93283b55">m_Threshold</a>;
<a name="l00299"></a>00299 
<a name="l00303"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#a9325b6b006b91999f075bcdc6b0cf14">00303</a>   <span class="keywordtype">int</span>  <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#a9325b6b006b91999f075bcdc6b0cf14">m_SelectionMethod</a>;
<a name="l00304"></a>00304 
<a name="l00309"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#215aa9ed8b1e5e4aed694eb40bb0662c">00309</a>   <span class="keywordtype">int</span> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#215aa9ed8b1e5e4aed694eb40bb0662c">m_ModifiedCount</a>;
<a name="l00310"></a>00310 
<a name="l00315"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#4a11fefddad8684599fe3e59e348be64">00315</a>   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#d932d49ec1424f4475db0f3f0d3184d1">OutputMeshPointer</a> <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#4a11fefddad8684599fe3e59e348be64" title="member for accessing the filter result during creation">m_Output</a>;
<a name="l00316"></a>00316 
<a name="l00317"></a><a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#cf1b1a9412e170df856981c281430beb">00317</a>   <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#25374a882104be92ed87a25d524c3932">InputCellAutoPointer</a>  <a class="code" href="classitk_1_1SimplexMeshAdaptTopologyFilter.html#cf1b1a9412e170df856981c281430beb">m_NewSimplexCellPointer</a>;
<a name="l00318"></a>00318 
<a name="l00319"></a>00319 };
<a name="l00320"></a>00320 
<a name="l00321"></a>00321 } <span class="comment">//end of namespace</span>
<a name="l00322"></a>00322 
<a name="l00323"></a>00323 <span class="preprocessor">#ifndef ITK_MANUAL_INSTANTIATION</span>
<a name="l00324"></a>00324 <span class="preprocessor"></span><span class="preprocessor">#include "itkSimplexMeshAdaptTopologyFilter.txx"</span>
<a name="l00325"></a>00325 <span class="preprocessor">#endif</span>
<a name="l00326"></a>00326 <span class="preprocessor"></span>
<a name="l00327"></a>00327 <span class="preprocessor">#endif // __itkSimplexMeshAdaptTopologyFilter_h</span>
<a name="l00328"></a>00328 <span class="preprocessor"></span>
</pre></div></div>
<hr><address><small>
Generated at Fri May 8 00:15:10 2009 for ITK  by <a href="http://www.stack.nl/~dimitri/doxygen/index.html"> <img 
src="http://www.stack.nl/~dimitri/doxygen/doxygen.png" alt="doxygen"
align="middle" border=0 width=110 height=53>
</a> 1.5.9 written by <a href="mailto:dimitri@stack.nl">Dimitri van Heesch</a>,
 &copy;&nbsp;1997-2000</small></address>
</body>
</html>