1245 double maxdist2 = maxdist * maxdist;
1250 lwerror(
"Both input geometries must have a measure dimension");
1259 lwerror(
"Both input geometries must be linestrings");
1266 lwerror(
"Both input lines must have at least 2 points");
1286 LWDEBUG(1,
"Inputs never exist at the same time");
1294 mvals =
lwalloc(
sizeof(
double) *
1305 nmvals =
uniq(mvals, nmvals);
1310 double t0 = mvals[0];
1312 LWDEBUGF(1,
"Inputs only exist both at a single time (%g)", t0);
1315 lwnotice(
"Could not find point with M=%g on first geom", t0);
1320 lwnotice(
"Could not find point with M=%g on second geom", t0);
1333 for (i=1; i<nmvals; ++i)
1335 double t0 = mvals[i-1];
1336 double t1 = mvals[i];
1337 #if POSTGIS_DEBUG_LEVEL >= 1 1347 if ( -1 == seg )
continue;
1351 if ( -1 == seg )
continue;
1355 if ( -1 == seg )
continue;
1359 if ( -1 == seg )
continue;
1362 #if POSTGIS_DEBUG_LEVEL >= 1 1373 dist2 = ( q0.
x - p0.
x ) * ( q0.
x - p0.
x ) +
1374 ( q0.
y - p0.
y ) * ( q0.
y - p0.
y ) +
1375 ( q0.
z - p0.
z ) * ( q0.
z - p0.
z );
1376 if ( dist2 <= maxdist2 )
1378 LWDEBUGF(1,
"Within distance %g at time %g, breaking", sqrt(dist2), t);
void lwnotice(const char *fmt,...)
Write a notice out to the notice handler.
static int uniq(double *vals, int nvals)
static int compare_double(const void *pa, const void *pb)
#define LWDEBUG(level, msg)
int lwgeom_calculate_gbox(const LWGEOM *lwgeom, GBOX *gbox)
Calculate bounding box of a geometry, automatically taking into account whether it is cartesian or ge...
static int ptarray_collect_mvals(const POINTARRAY *pa, double tmin, double tmax, double *mvals)
#define LW_TRUE
Return types for functions with status returns.
static int ptarray_locate_along_linear(const POINTARRAY *pa, double m, POINT4D *p, int from)
LWLINE * lwgeom_as_lwline(const LWGEOM *lwgeom)
double distance3d_pt_pt(const POINT3D *p1, const POINT3D *p2)
void * lwalloc(size_t size)
#define LWDEBUGF(level, msg,...)
int lwgeom_has_m(const LWGEOM *geom)
Return LW_TRUE if geometry has M ordinates.
static double segments_tcpa(POINT4D *p0, const POINT4D *p1, POINT4D *q0, const POINT4D *q1, double t0, double t1)
void lwerror(const char *fmt,...)
Write a notice out to the error handler.