Validate Topology is to return objects in point, line, region dataset that violate the specified topology rule. Validate Topology is usually performed before data editing and topology analysis.
In SuperMap, there are 6 topology rules defined for point datasets, 14 for line datasets, and 10 for region datasets. Besides, there are 5 kinds of topology rules that can be used for different types of topology rule.
The topology rules used for point, line and region dataset and the rules used for multiple kinds of datasets are introduced below.
The rules used for point dataset
The following rules are appropriate for point datasets.
ID | Description | Illustration |
Must Be Covered By Line | Requires that points in a point dataset fall on the lines in a line dataset. The points can overlap with the endpoints of the lines. The points that are not touched by any line in the line dataset will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Must Be Covered By Boundary Of Region | Requires that points must fall on the boundaries of region objects in a region dataset. The points that are not on any boundary in the region dataset will be returned in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
Must Be Properly Inside Polygons | Requires that points must fall within regions in a region dataset. The points that are not contained by any region in the region dataset will be returned in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
Must Be Covered By Endpoint Of Line | Requires that points in a point dataset must be covered by the endpoints of lines in a line dataset. The points in the point dataset that are not covered by any endpoint will be returned in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
No Identical Points | Requires that points in the same point dataset not overlap. The duplicate points will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Point No Contained By Polygon | Requires that points in the point dataset not contained by the interior of any region in the region dataset. The points contained by the interior of any regions will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
The rules used for line dataset
The following rules are appropriate for line datasets.
ID | Description | Illustration |
Must Not Intersect With Each Other | Requires lines in one line dataset must not intersect with lines in another line dataset. The intersections will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Must Not Intersect Within The Line Itself | Requires that line objects in the same line dataset not cross or overlap each other. Lines can share endpoints. The intersections will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Must Not Self Overlap | No self overlap in the same line dataset. Requires that line objects not overlap themselves. The self overlapped segments will be returned in the result dataset. Error dataset type: Line dataset. |
![]() ![]() |
Must Not Have Dangles | Requires that a line object must touch lines from the same dataset at both endpoints; otherwise it will be an error. Endpoints that are not shared will be returned in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
Must Not Have Pseudo nodes | Requires that each shared endpoint must have at least three lines connected to it; otherwise it will be an error. Shared endpoints that have only two lines connected to it will be returned as errors in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
Must Not Overlap With | Requires that a line from one dataset not overlap with line(s) in another dataset. The self overlapped segments will be returned in the result dataset. Error dataset type: Line dataset. |
![]() ![]() |
Must Not Intersect Or Touch Interior | Requires that a line in one dataset must only touch other lines of the same dataset at endpoints. The intersections will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Must Not Self Overlap | No self overlap in the same line dataset. Requires that line objects not overlap themselves. The self overlapped segments will be returned in the result dataset. Error dataset type: Line dataset. |
![]() ![]() |
Must Not Self Intersect | Line can not intersect with themselves. Requires that line objects not cross or overlap themselves. The self intersection points and the vertices of the self overlapped line segments will be returned as errors in the result dataset. Error dataset type: Point dataset. |
![]() ![]() |
Must Be Covered By Lines Of | Requires that lines from one dataset be covered by the lines in another dataset. Lines or line segments in other dataset that are not covered by any line in the other dataset will be returned as errors in the result dataset. Error dataset type: Line dataset. |
![]() ![]() |
Must Be Covered By Boundary Of | Requires that lines in the line dataset must be covered by boundaries of regions in the region dataset. Lines or line segments in the line dataset that are not covered by any boundary in the region dataset will be returned in the result dataset as errors Error dataset type: Line dataset. |
![]() ![]() |
Endpoint Must Be Covered By | Requires that the endpoints of lines in a line dataset must be covered by points in a point dataset. The endpoints that are not covered by any point in the point dataset will be returned in the result dataset as errors. Error dataset type: Point dataset. |
![]() ![]() |
Line not intersected with or contained by regions | Checks whether the line dataset intersects with the reference region dataset, or there are line objects contained by regions. Requires that the line dataset and the region dataset can't has intersections. The intersection part of the line dataset and the region dataset will be returned in the result dataset as errors Error dataset type: Line dataset. |
![]() ![]() |
Line Not MiniBend | Requires that the two angles constructed by four successive vertices larger than the given angle tolerance. As long as there are two angles constructed by four successive vertices less than the given angle tolerance, the line would be identified as an extrusion at that place. The first vertex of the angle will be returned as errors. Error dataset type: Point dataset. |
![]() ![]() |
The rules are used for region datasets
The following rules are supported only by region dataset.
The following topology rules applies to one or more types of datasets, including point, line or region dataset or the combination of them.