|  | Home | Libraries | People | FAQ | More | 
Enumerates the possible validity failure types for a geometry.
The enumeration validity_failure_type enumerates the possible reasons for which a geometry may be found as invalid by the is_valid algorithm. Besides the values that indicate invalidity, there is an additional value (no_failure) that indicates validity.
enum validity_failure_type { no_failure = 0, failure_few_points = 10, failure_wrong_topological_dimension = 11, failure_spikes = 12, failure_duplicate_points = 13, failure_not_closed = 20, failure_self_intersections = 21, failure_wrong_orientation = 22, failure_interior_rings_outside = 30, failure_nested_interior_rings = 31, failure_disconnected_interior = 32, failure_intersecting_interiors = 40, failure_wrong_corner_order = 50, failure_invalid_coordinate = 60 };
| Value | Description | 
|---|---|
| no_failure | The geometry is valid | 
| failure_few_points | The geometry has a very small number of points, e.g., less than 2 for linestrings, less than 3 for open rings, a closed multi-polygon that contains a polygon with less than 4 points, etc. (applies to linestrings, rings, polygons, multi-linestrings and multi-polygons) | 
| failure_wrong_topological_dimension | The topological dimension of the geometry is smaller than its dimension, e.g., a linestring with 3 identical points, an open polygon with an interior ring consisting of 3 collinear points, etc. (applies to linear and areal geometries, including segments and boxes) | 
| failure_spikes | The geometry contains spikes (applies to linear and areal geometries) | 
| failure_duplicate_points | The geometry has (consecutive) duplicate points (applies to areal geometries only) | 
| failure_not_closed | The geometry is defined as closed, the starting/ending points are not equal (applies to areal geometries only) | 
| failure_self_intersections | The geometry has invalid self-intersections. (applies to areal geometries only) | 
| failure_wrong_orientation | The actual orientation of the geometry is different from the one defined (applies to areal geometries only) | 
| failure_interior_rings_outside | The geometry contains interior rings that lie outside the exterior ring (applies to polygons and multi-polygons only) | 
| failure_nested_interior_rings | The geometry has nested interior rings (applies to polygons and multi-polygons only) | 
| failure_disconnected_interior | The interior of the geometry is disconnected (applies to polygons and multi-polygons only) | 
| failure_intersecting_interiors | The multi-polygon contains polygons whose interiors are not disjoint (applies to multi-polygons only) | 
| failure_wrong_corner_order | The top-right corner of the box is lexicographically smaller than its bottom-left corner (applies to boxes only) | 
| failure_invalid_coordinate | The geometry has at least one point with an invalid coordinate (for example, the coordinate is a NaN) | 
          #include <boost/geometry/algorithms/validity_failure_type.hpp>
        
The is_valid algorithm taking a reference to validity_failure_type as second argument