1491 POINT3D q1, q2, qMid, qCross, qSum;
1495 if (poly->nrings < 1)
1497 pa = poly->rings[0];
int getPoint4d_p(const POINTARRAY *pa, uint32_t n, POINT4D *point)
void normalize(POINT3D *p)
Normalize to a unit vector.
void vector_scale(POINT3D *n, double scale)
Scale a vector out by a factor.
void cart2geog(const POINT3D *p, GEOGRAPHIC_POINT *g)
Convert cartesian coordinates on unit sphere to spherical coordinates.
void geographic_point_init(double lon, double lat, GEOGRAPHIC_POINT *g)
Initialize a geographic point.
static void cross_product(const POINT3D *a, const POINT3D *b, POINT3D *n)
Calculate the cross product of two vectors.
void vector_sum(const POINT3D *a, const POINT3D *b, POINT3D *n)
Calculate the sum of two vectors.
void geog2cart(const GEOGRAPHIC_POINT *g, POINT3D *p)
Convert spherical coordinates to cartesian coordinates on unit sphere.
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)
Point in spherical coordinates on the world.