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

◆ ptarray_grid_in_place()

void ptarray_grid_in_place ( POINTARRAY pa,
gridspec grid 
)

Snap to grid.

Definition at line 2222 of file ptarray.c.

2223{
2224 uint32_t j = 0;
2225 POINT4D *p, *p_out = NULL;
2226 double x, y, z = 0, m = 0;
2227 uint32_t ndims = FLAGS_NDIMS(pa->flags);
2228 uint32_t has_z = FLAGS_GET_Z(pa->flags);
2229 uint32_t has_m = FLAGS_GET_M(pa->flags);
2230
2231 for (uint32_t i = 0; i < pa->npoints; i++)
2232 {
2233 /* Look straight into the abyss */
2234 p = (POINT4D *)(getPoint_internal(pa, i));
2235 x = p->x;
2236 y = p->y;
2237 if (ndims > 2)
2238 z = p->z;
2239 if (ndims > 3)
2240 m = p->m;
2241
2242 /*
2243 * See https://github.com/libgeos/geos/pull/956
2244 * We use scale for rounding when gridsize is < 1 and
2245 * gridsize for rounding when scale < 1.
2246 */
2247 if (grid->xsize > 0) {
2248 if (grid->xsize < 1)
2249 x = rint((x - grid->ipx) * grid->xscale) / grid->xscale + grid->ipx;
2250 else
2251 x = rint((x - grid->ipx) / grid->xsize) * grid->xsize + grid->ipx;
2252 }
2253
2254 if (grid->ysize > 0) {
2255 if (grid->ysize < 1)
2256 y = rint((y - grid->ipy) * grid->yscale) / grid->yscale + grid->ipy;
2257 else
2258 y = rint((y - grid->ipy) / grid->ysize) * grid->ysize + grid->ipy;
2259 }
2260
2261 /* Read and round this point */
2262 /* Z is always in third position */
2263 if (has_z && grid->zsize > 0)
2264 z = rint((z - grid->ipz) / grid->zsize) * grid->zsize + grid->ipz;
2265
2266 /* M might be in 3rd or 4th position */
2267 if (has_m && grid->msize > 0)
2268 {
2269 /* In POINT ZM, M is in 4th position, in POINT M, M is in 3rd position which is Z in POINT4D */
2270 if (has_z)
2271 m = rint((m - grid->ipm) / grid->msize) * grid->msize + grid->ipm;
2272 else
2273 z = rint((z - grid->ipm) / grid->msize) * grid->msize + grid->ipm;
2274 }
2275
2276 /* Skip duplicates */
2277 if (p_out &&
2278 p_out->x == x &&
2279 p_out->y == y &&
2280 (ndims > 2 ? p_out->z == z : 1) &&
2281 (ndims > 3 ? p_out->m == m : 1))
2282 {
2283 continue;
2284 }
2285
2286 /* Write rounded values into the next available point */
2287 p_out = (POINT4D *)(getPoint_internal(pa, j++));
2288 p_out->x = x;
2289 p_out->y = y;
2290 if (ndims > 2)
2291 p_out->z = z;
2292 if (ndims > 3)
2293 p_out->m = m;
2294 }
2295
2296 /* Update output ptarray length */
2297 pa->npoints = j;
2298 return;
2299}
#define FLAGS_GET_Z(flags)
Definition liblwgeom.h:165
#define FLAGS_NDIMS(flags)
Definition liblwgeom.h:179
#define FLAGS_GET_M(flags)
Definition liblwgeom.h:166
static uint8_t * getPoint_internal(const POINTARRAY *pa, uint32_t n)
Definition lwinline.h:75
double m
Definition liblwgeom.h:414
double x
Definition liblwgeom.h:414
double z
Definition liblwgeom.h:414
double y
Definition liblwgeom.h:414
lwflags_t flags
Definition liblwgeom.h:431
uint32_t npoints
Definition liblwgeom.h:427
double xscale
Definition liblwgeom.h:1407
double ipm
Definition liblwgeom.h:1402
double zsize
Definition liblwgeom.h:1405
double ysize
Definition liblwgeom.h:1404
double xsize
Definition liblwgeom.h:1403
double yscale
Definition liblwgeom.h:1408
double ipx
Definition liblwgeom.h:1399
double msize
Definition liblwgeom.h:1406
double ipy
Definition liblwgeom.h:1400
double ipz
Definition liblwgeom.h:1401

References POINTARRAY::flags, FLAGS_GET_M, FLAGS_GET_Z, FLAGS_NDIMS, getPoint_internal(), gridspec_t::ipm, gridspec_t::ipx, gridspec_t::ipy, gridspec_t::ipz, POINT4D::m, gridspec_t::msize, POINTARRAY::npoints, POINT4D::x, gridspec_t::xscale, gridspec_t::xsize, POINT4D::y, gridspec_t::yscale, gridspec_t::ysize, POINT4D::z, and gridspec_t::zsize.

Referenced by lwgeom_grid_in_place().

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