split_polygon - ObjectVision/GeoDMS GitHub Wiki
Geometric functions split_polygon
- split_polygon(polygon_data_item)
split_polygon(polygon_data_item) results in a new uint32 domain unit with single polygons for each (multi)polygon in the polygon_data_item argument.
If the original polygon_data_item only contains single polygons, the resulting domain unit has the same number of elements as the domain unit of the polygon_data_item argument.
The figure illustrates a source polygon_data_item (left image) of a domain unit with four entries.
Each color represents an entry in the polygon_data_item, the red and green areas are multipolygons.
The resulting domain unit of the split_polygon function for this polygon_data_item will contain seven entries, with a single polygon for each entry (right image).
The split_polygon functions generates two (and since GeoDMS 8) 3 subitems:
- geometry: the geometry of the single polygons. This attribute has the same values unit as the polygon_data_item argument.
- nr_OrgEntity: a relation for the new domain towards the domain of the polygon_data_item argument.
- polygon_rel: a relation for the new domain towards the domain of the polygon_data_item argument. This data item is a copy of the nr_OrgEntity, but whith a name that meets our naming conventions. The nr_OrgEntity argument is still generated for backward compatibility.
We advice to use the polygon_rel argument, the nr_OrgEntity argument will be phased out.
attribute polygon_data_item with an ipoint or spoint value type
- The composition type of the polygon_data_item argument needs to be polygon.
- The domain unit of the polygon_data_item argument must be of value type uint32.
This function results in problems for (integer) coordinates larger than 2^25 (after translation where the first point is moved to (0, 0)). If your integer coordinates for instance represent mm, 2^25[mm] = about 33 [km]. The reason is that for calculating intersections, products of coordinates are calculated and casted to float64 with a 53 bits mantissa (in the development/test environment of boost::polygon these were float80 values with a 64 bits mantissa). We advise to keep the size of your integer coordinates for polygons limited and for instance do not use a mm precision for country borders (meter or kilometer might be sufficient).
7.042
unit<uint32> split_polygons := split_polygon(geometry);
The number or resulting entries is based on the number of null coordinates plus 1.