]> git.openstreetmap.org Git - nominatim.git/blobdiff - lib-sql/functions/utils.sql
simplify very large polygons non used in addresses
[nominatim.git] / lib-sql / functions / utils.sql
index ff2f037d01dabdb86b40212fff372738727bfb0e..75e83e7f8da6e931fb269736f9a149ce78df13c3 100644 (file)
@@ -416,6 +416,20 @@ END;
 $$
 LANGUAGE plpgsql IMMUTABLE;
 
+CREATE OR REPLACE FUNCTION simplify_large_polygons(geometry GEOMETRY)
+  RETURNS GEOMETRY
+  AS $$
+BEGIN
+  IF ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon')
+     and ST_MemSize(geometry) > 3000000
+  THEN
+    geometry := ST_SimplifyPreserveTopology(geometry, 0.0001);
+  END IF;
+  RETURN geometry;
+END;
+$$
+LANGUAGE plpgsql IMMUTABLE;
+
 
 CREATE OR REPLACE FUNCTION place_force_delete(placeid BIGINT)
   RETURNS BOOLEAN