PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ lwgeom_delaunay_triangulation()

LWGEOM* lwgeom_delaunay_triangulation ( const LWGEOM geom,
double  tolerance,
int32_t  edgeOnly 
)

Take vertices of a geometry and build a delaunay triangulation on them.

Parameters
geomthe input geometry
tolerancean optional snapping tolerance for improved robustness
edgeOnlyif non-zero the result will be a MULTILINESTRING, otherwise it'll be a COLLECTION of polygons.

Definition at line 1976 of file liblwgeom/lwgeom_geos.c.

1977 {
1978  LWGEOM* result;
1979  int32_t srid = RESULT_SRID(geom);
1980  uint8_t is3d = FLAGS_GET_Z(geom->flags);
1981  GEOSGeometry *g1, *g3;
1982 
1983  if (output < 0 || output > 2)
1984  {
1985  lwerror("%s: invalid output type specified %d", __func__, output);
1986  return NULL;
1987  }
1988 
1989  if (srid == SRID_INVALID) return NULL;
1990 
1991  initGEOS(lwnotice, lwgeom_geos_error);
1992 
1993  if (!(g1 = LWGEOM2GEOS(geom, AUTOFIX))) GEOS_FAIL();
1994 
1995  /* if output != 1 we want polys */
1996  g3 = GEOSDelaunayTriangulation(g1, tolerance, output == 1);
1997 
1998  if (!g3) GEOS_FREE_AND_FAIL(g1);
1999  GEOSSetSRID(g3, srid);
2000 
2001  if (output == 2)
2002  {
2003  result = (LWGEOM*)lwtin_from_geos(g3, is3d);
2004  if (!result)
2005  {
2006  GEOS_FREE(g1, g3);
2007  lwerror("%s: cannot convert output geometry", __func__);
2008  return NULL;
2009  }
2010  lwgeom_set_srid(result, srid);
2011  }
2012  else if (!(result = GEOS2LWGEOM(g3, is3d)))
2013  GEOS_FREE_AND_FAIL(g1, g3);
2014 
2015  GEOS_FREE(g1, g3);
2016  return result;
2017 }
char result[OUT_DOUBLE_BUFFER_SIZE]
Definition: cu_print.c:267
#define GEOS_FREE(...)
#define AUTOFIX
#define RESULT_SRID(...)
#define GEOS_FAIL()
#define GEOS_FREE_AND_FAIL(...)
GEOSGeometry * LWGEOM2GEOS(const LWGEOM *lwgeom, uint8_t autofix)
LWGEOM * GEOS2LWGEOM(const GEOSGeometry *geom, uint8_t want3d)
void lwgeom_geos_error(const char *fmt,...)
LWTIN * lwtin_from_geos(const GEOSGeometry *geom, uint8_t want3d)
#define SRID_INVALID
Definition: liblwgeom.h:234
void lwgeom_set_srid(LWGEOM *geom, int32_t srid)
Set the SRID on an LWGEOM For collections, only the parent gets an SRID, all the children get SRID_UN...
Definition: lwgeom.c:1547
#define FLAGS_GET_Z(flags)
Definition: liblwgeom.h:180
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
Definition: lwutil.c:190
void lwnotice(const char *fmt,...)
Write a notice out to the notice handler.
Definition: lwutil.c:177
lwflags_t flags
Definition: liblwgeom.h:476

References AUTOFIX, LWGEOM::flags, FLAGS_GET_Z, GEOS2LWGEOM(), GEOS_FAIL, GEOS_FREE, GEOS_FREE_AND_FAIL, lwerror(), LWGEOM2GEOS(), lwgeom_geos_error(), lwgeom_set_srid(), lwnotice(), lwtin_from_geos(), result, RESULT_SRID, and SRID_INVALID.

Referenced by ST_DelaunayTriangles(), and test_lwgeom_delaunay_triangulation().

Here is the call graph for this function:
Here is the caller graph for this function: