-
Notifications
You must be signed in to change notification settings - Fork 3
Feature Surface
This package has been created to automatically identify inlet and outlet of meshes. Such inlet/outlet are geometrically distinguished from other boundary surfaces. Specifically, they are encircled by a closed curve that has sharper normal change and inside area of the curve has more flattened surface. We call these boundaries Feature Surfaces. An example is both ends of a cylinder. Each end is a flat surface that is engulfed with a circle. The two end circles on a cylinder mesh have sharper normal vector change across their points. Figure 1 shows detection of two featured surfaces on a mesh model.
The Feature Surface can be used either as a a plugin for ParaView, a filter in a VTK code or as a standalone application. The program accepts various cell types. Multiple file formats are supported as well. Common file formats are legacy *.vtk
and binary *.vtu
extensions.
User can build the code from source. You can obtain the source code from github repository. Please install git
package:
$ sudo apt-get install git
Then, create a build directory and download the source code inside the build directory:
$ mkdir /tmp/FeatureSurface
$ cd /tmp/FeatureSurface
$ git clone git://github.com/ameli/feature-surface
Now, build the code:
$ cmake .
$ make
$ sudo make install
$ cd ..
$ rm -r /tmp/feature-surface
Installation is system-wide for all users.
You can use the program either in terminal or as a ParaView plugin. Here are examples to use it in terminal:
$ featuresurface /input-path/inputfile.vtk outputfile.vtk
For help, use -h
, for get program information use -i
and for see the license, use -l
options.
$ featuresurface -h
$ featuresurface -i
$ featuresurface -l
After loading the plugin in ParaView, you can use the filter in Filter
menu under Extensions
. Figures 2 shows how to apply the plugin inside ParaView.
Figure 3 illustrated the options that can be set in ParaView for this filter. Filter has the following options:
-
Feature angle is the threshold angle degree for which the edges are detected. Smaller feature angle is less restrictive.
-
Surface color can be one of the followings:
- Body color: Assigns the color 0 to all featured surface points. This is the same color as body.
- Mono color: Assigns color 1 for all features surface points.
- Poly color: For each group of points in a features surface area, it assigns an integer, starting from 1. Thus the n-th features surface has the color n.
-
Edge color can be one of the followings:
- Body color: Assigns the color 0 to all edge points. This is the same color as body.
- Mono color: Assigns color 1 for all edge points.
- Surface color: Assigns the color of the surface that the edge is belonging to.
- Opposite Surface color: Assigns opposite of the color of surface that edge is belonging to. For instants, if the surface has color n, then its edge has color -n.
The algorithm that is used for this filter is robust in variety of ways. Such robustness was gained by both geometrical and topological checks on edge extraction. The following are a brief description.
First, the algorithm is not sensitive on Edge Angle. Majority of function were used to eliminate this dependency, so a broad range of edge angle can lead to reasonable edge detection. Figure 4 shows two violations of edge angles in critical situations. In the left highlighted spot, edge angle is small, and an rudimentary search might not detect the edge and featured surface at all. User might lower the edge angle threshold in settings, but it comes with the cost of detecting some edges that are not belong to an interesting featured surface. For instance, the right highlighted spot has a large edge angle but it is not considered as inlet or outlet. However a simple algorithm might detect the edge and try to extract a spurious feature surface. By using a geometrical checks we eliminate such spurious edges.
A more basic issue with edge extraction is the topology of edge itself. Some edges are not closed curve, some are having more than two connectivities at each points, or multiple closed curves are sharing a set of common points. Few of these unusual edges are not accepted as an edge for a featured surface, and some needs trimming of excessive points. Since excessive points are not known priori, all possible routes on the edges should be checked for finding a nice curve that can be a candidate for a featured surface. Figure 5 illustrate such spurious edges that should take out of results. This listing is the program output applied on data in figure 5.
Output of program $ ./FeatureSurface
Closed polygon found. Number of points: 21
Closed polygon found. Number of points: 48
Closed polygon found. Number of points: 60
Closed polygon found. Number of points: 118
Closed polygon found. Number of points: 37
Closed polygon found. Number of points: 18
Fatal Point: 19, Number of connectivities: 3
Fatal Point: 19, Number of connectivities: 3
Fatal Point: 33, Number of connectivities: 3
Fatal Point: 32, Number of connectivities: 1
Fatal Point: 39, Number of connectivities: 1
Fatal Point: 64, Number of connectivities: 1
Total number of closed polygons: 6
Closed Edge: 1, Surface points found: 39
Closed Edge: 2, Surface points found: 206
Closed Edge: 3, Surface points found: 315
Closed Edge: 4, Surface points found: 1270
Closed Edge: 5, Surface points found: 120
Closed Edge: 6, Surface points found: 23
An important issue after extracting a candidate edge curve is to find an appropriate orientation on edge; that is, finding which side is interior or exterior of the closed curve. Topologically, both sides ca be interior since a smooth homotopy can make both side identical. Rather using topologically distinct sides, we use geometrically distinct regions. We define an interior side where the surface is tend to be more flattened. This assumption is natural in inlet and outlets of computational meshes. The algorithm that is used in the filter can decide which surface to be interior.
However, in rare cases, due to incorrect meshing or unusual cases the interior and exterior surfaces of an edge can be related with a path other than the edge itself. The current code can identify such cases and avoid colorizing the while domain. This feature makes the algorithm very robust in colorizing domains correctly.
The filter's performance has been tested on two mesh models on both Linux and Mac OS X operating systems using both command line and ParaView plugin. Figure 6 shows the application of filter on AAA mesh model. The mesh has 11 inlet and outlets that all of them has been detected by the filter. With no surprise, the performance was not sensitive to selecting the Edge angle, thus all features identified without including any noisy edge or non-interesting edges. Figure 7 illustrates the application of the filter on Aortic mesh model, which all 6 inlet or outlets were detected. Since the algorithm re-uses all of its computed data during process at each iterative search on edges, the algorithm is fast. It takes only 4 or 5 seconds for a million element Aortic mesh to finish the computation.
As described in this section, the plugin has options to colorize the edges and/or surfaces in multiple ways. Edges and their corresponding surfaces can be colorized with the same color, body color or independently.
Copyright 2013 Siavash Ameli
This source code is provided as-is, without any express or implied warranty. In no event will the author be held liable for any damages arising from the use of this software.
Permission is granted to anyone to use this software for non commercial purpose, to alter it and redistribute it freely, subject to the following restrictions:
-
The origin of this source code must not be misrepresented; you must not claim that you wrote the original source code.
-
You may modify or alter the source code at your own risk, provided that such modifications are extensively commented. Altered source versions must not be misrepresented as being the original source code.
-
Source code may not be redistributed in any way. You may distribute the target binary for non-commercial purposes.
-
If you use this source code in a non-commercial product, an acknowledgment in the product documentation would be appreciated.
-
This notice may not be removed or altered from any source distribution.
Any bug reports and comments are appreciated. You may report bugs in github, Launchpad or send email.
This work was supported by the National Science Foundation, award number 1047963.