PostGIS
3.0.6dev-r@@SVN_REVISION@@
|
#include "liblwgeom_internal.h"
#include "lwgeodetic.h"
#include "lwgeom_log.h"
#include <stdlib.h>
#include <math.h>
Go to the source code of this file.
Functions | |
GBOX * | gbox_new (lwflags_t flags) |
Create a new gbox with the dimensionality indicated by the flags. More... | |
void | gbox_init (GBOX *gbox) |
Zero out all the entries in the GBOX. More... | |
GBOX * | gbox_clone (const GBOX *gbox) |
BOX3D * | box3d_from_gbox (const GBOX *gbox) |
GBOX * | box3d_to_gbox (const BOX3D *b3d) |
void | gbox_expand (GBOX *g, double d) |
Move the box minimums down and the maximums up by the distance provided. More... | |
void | gbox_expand_xyzm (GBOX *g, double dx, double dy, double dz, double dm) |
Move the box minimums down and the maximums up by the distances provided. More... | |
int | gbox_union (const GBOX *g1, const GBOX *g2, GBOX *gout) |
Update the output GBOX to be large enough to include both inputs. More... | |
int | gbox_same (const GBOX *g1, const GBOX *g2) |
Check if 2 given Gbox are the same. More... | |
int | gbox_same_2d (const GBOX *g1, const GBOX *g2) |
Check if 2 given GBOX are the same in x and y. More... | |
int | gbox_same_2d_float (const GBOX *g1, const GBOX *g2) |
Check if two given GBOX are the same in x and y, or would round to the same GBOX in x and if serialized in GSERIALIZED. More... | |
int | gbox_is_valid (const GBOX *gbox) |
Return false if any of the dimensions is NaN or infinite. More... | |
int | gbox_merge_point3d (const POINT3D *p, GBOX *gbox) |
Update the GBOX to be large enough to include itself and the new point. More... | |
int | gbox_init_point3d (const POINT3D *p, GBOX *gbox) |
Initialize a GBOX using the values of the point. More... | |
int | gbox_contains_point3d (const GBOX *gbox, const POINT3D *pt) |
Return true if the point is inside the gbox. More... | |
int | gbox_merge (const GBOX *new_box, GBOX *merge_box) |
Update the merged GBOX to be large enough to include itself and the new box. More... | |
int | gbox_overlaps (const GBOX *g1, const GBOX *g2) |
Return LW_TRUE if the GBOX overlaps, LW_FALSE otherwise. More... | |
int | gbox_overlaps_2d (const GBOX *g1, const GBOX *g2) |
Return LW_TRUE if the GBOX overlaps on the 2d plane, LW_FALSE otherwise. More... | |
int | gbox_contains_2d (const GBOX *g1, const GBOX *g2) |
Return LW_TRUE if the first GBOX contains the second on the 2d plane, LW_FALSE otherwise. More... | |
int | gbox_contains_point2d (const GBOX *g, const POINT2D *p) |
GBOX * | gbox_from_string (const char *str) |
Warning, this function is only good for x/y/z boxes, used in unit testing of geodetic box generation. More... | |
char * | gbox_to_string (const GBOX *gbox) |
Allocate a string representation of the GBOX, based on dimensionality of flags. More... | |
GBOX * | gbox_copy (const GBOX *box) |
Return a copy of the GBOX, based on dimensionality of flags. More... | |
void | gbox_duplicate (const GBOX *original, GBOX *duplicate) |
Copy the values of original GBOX into duplicate. More... | |
size_t | gbox_serialized_size (lwflags_t flags) |
Return the number of bytes necessary to hold a GBOX of this dimension in serialized form. More... | |
int | lw_arc_calculate_gbox_cartesian_2d (const POINT2D *A1, const POINT2D *A2, const POINT2D *A3, GBOX *gbox) |
static int | lw_arc_calculate_gbox_cartesian (const POINT4D *p1, const POINT4D *p2, const POINT4D *p3, GBOX *gbox) |
static void | ptarray_calculate_gbox_cartesian_2d (const POINTARRAY *pa, GBOX *gbox) |
static void | ptarray_calculate_gbox_cartesian_3d (const POINTARRAY *pa, GBOX *gbox) |
static void | ptarray_calculate_gbox_cartesian_4d (const POINTARRAY *pa, GBOX *gbox) |
int | ptarray_calculate_gbox_cartesian (const POINTARRAY *pa, GBOX *gbox) |
Calculate box (x/y) and add values to gbox. More... | |
static int | lwcircstring_calculate_gbox_cartesian (LWCIRCSTRING *curve, GBOX *gbox) |
static int | lwpoint_calculate_gbox_cartesian (LWPOINT *point, GBOX *gbox) |
static int | lwline_calculate_gbox_cartesian (LWLINE *line, GBOX *gbox) |
static int | lwtriangle_calculate_gbox_cartesian (LWTRIANGLE *triangle, GBOX *gbox) |
static int | lwpoly_calculate_gbox_cartesian (LWPOLY *poly, GBOX *gbox) |
static int | lwcollection_calculate_gbox_cartesian (LWCOLLECTION *coll, GBOX *gbox) |
int | lwgeom_calculate_gbox_cartesian (const LWGEOM *lwgeom, GBOX *gbox) |
Calculate the 2-4D bounding box of a geometry. More... | |
void | gbox_float_round (GBOX *gbox) |
Round given GBOX to float boundaries. More... | |
static uint64_t | uint64_interleave_2 (uint64_t x, uint64_t y) |
static uint64_t | uint32_hilbert (uint32_t px, uint32_t py) |
uint64_t | gbox_get_sortable_hash (const GBOX *g, const int32_t srid) |
Return a sortable key based on the center point of the GBOX. More... | |