PostGIS 3.7.0dev-r@@SVN_REVISION@@
Loading...
Searching...
No Matches

◆ test_lwpoly_construct_circle()

static void test_lwpoly_construct_circle ( void  )
static

Definition at line 1688 of file cu_algorithm.c.

1689{
1690 LWPOLY* p;
1691 const GBOX* g;
1692 const int32_t srid = 4326;
1693 const uint32_t segments_per_quad = 17;
1694 const int x = 10;
1695 const int y = 20;
1696 const int r = 5;
1697
1698 /* With normal arguments you should get something circle-y */
1699 p = lwpoly_construct_circle(srid, x, y, r, segments_per_quad, LW_TRUE);
1700
1701 ASSERT_INT_EQUAL(lwgeom_count_vertices(lwpoly_as_lwgeom(p)), segments_per_quad * 4 + 1);
1703
1705 CU_ASSERT_DOUBLE_EQUAL(g->xmin, x-r, 0.1);
1706 CU_ASSERT_DOUBLE_EQUAL(g->xmax, x+r, 0.1);
1707 CU_ASSERT_DOUBLE_EQUAL(g->ymin, y-r, 0.1);
1708 CU_ASSERT_DOUBLE_EQUAL(g->ymax, y+r, 0.1);
1709
1710 CU_ASSERT_DOUBLE_EQUAL(lwgeom_area(lwpoly_as_lwgeom(p)), M_PI*5*5, 0.1);
1711
1712 lwpoly_free(p);
1713
1714 /* No segments? No circle. */
1715 p = lwpoly_construct_circle(srid, x, y, r, 0, LW_TRUE);
1716 CU_ASSERT_TRUE(p == NULL);
1717
1718 /* Negative radius? No circle. */
1719 p = lwpoly_construct_circle(srid, x, y, -1e-3, segments_per_quad, LW_TRUE);
1720 CU_ASSERT_TRUE(p == NULL);
1721
1722 /* Zero radius? Invalid circle */
1723 p = lwpoly_construct_circle(srid, x, y, 0, segments_per_quad, LW_TRUE);
1724 CU_ASSERT_TRUE(p != NULL);
1725 lwpoly_free(p);
1726}
char * r
Definition cu_in_wkt.c:24
#define ASSERT_INT_EQUAL(o, e)
int32_t lwgeom_get_srid(const LWGEOM *geom)
Return SRID number.
Definition lwgeom.c:955
LWPOLY * lwpoly_construct_circle(int32_t srid, double x, double y, double radius, uint32_t segments_per_quarter, char exterior)
Definition lwpoly.c:120
double lwgeom_area(const LWGEOM *geom)
Definition lwgeom.c:1999
uint32_t lwgeom_count_vertices(const LWGEOM *geom)
Count the total number of vertices in any LWGEOM.
Definition lwgeom.c:1337
void lwpoly_free(LWPOLY *poly)
Definition lwpoly.c:175
#define LW_TRUE
Return types for functions with status returns.
Definition liblwgeom.h:93
const GBOX * lwgeom_get_bbox(const LWGEOM *lwgeom)
Get a non-empty geometry bounding box, computing and caching it if not already there.
Definition lwgeom.c:771
LWGEOM * lwpoly_as_lwgeom(const LWPOLY *obj)
Definition lwgeom.c:357
double ymax
Definition liblwgeom.h:357
double xmax
Definition liblwgeom.h:355
double ymin
Definition liblwgeom.h:356
double xmin
Definition liblwgeom.h:354

References ASSERT_INT_EQUAL, LW_TRUE, lwgeom_area(), lwgeom_count_vertices(), lwgeom_get_bbox(), lwgeom_get_srid(), lwpoly_as_lwgeom(), lwpoly_construct_circle(), lwpoly_free(), r, GBOX::xmax, GBOX::xmin, GBOX::ymax, and GBOX::ymin.

Referenced by algorithms_suite_setup().

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