Find the time of closest point of approach. 
 1159         double mindist2 = FLT_MAX; 
 
 1163                 lwerror(
"Both input geometries must have a measure dimension");
 
 1172                 lwerror(
"Both input geometries must be linestrings");
 
 1178                 lwerror(
"Both input lines must have at least 2 points");
 
 1198                 LWDEBUG(1, 
"Inputs never exist at the same time");
 
 1218         nmvals = 
uniq(mvals, nmvals);
 
 1224                         double t0 = mvals[0];
 
 1226                         LWDEBUGF(1, 
"Inputs only exist both at a single time (%g)", t0);
 
 1232                                         lwerror(
"Could not find point with M=%g on first geom", t0);
 
 1238                                         lwerror(
"Could not find point with M=%g on second geom", t0);
 
 1253         for (i = 1; i < nmvals; ++i)
 
 1255                 double t0 = mvals[i - 1];
 
 1256                 double t1 = mvals[i];
 
 1292                 dist2 = (q0.
x - p0.
x) * (q0.
x - p0.
x) + (q0.
y - p0.
y) * (q0.
y - p0.
y) + (q0.
z - p0.
z) * (q0.
z - p0.
z);
 
 1293                 if (dist2 < mindist2)
 
 1309                 *mindist = sqrt(mindist2);
 
LWLINE * lwgeom_as_lwline(const LWGEOM *lwgeom)
double distance3d_pt_pt(const POINT3D *p1, const POINT3D *p2)
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...
void * lwalloc(size_t size)
int lwgeom_has_m(const LWGEOM *geom)
Return LW_TRUE if geometry has M ordinates.
#define LWDEBUG(level, msg)
#define LWDEBUGF(level, msg,...)
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
static int ptarray_collect_mvals(const POINTARRAY *pa, double tmin, double tmax, double *mvals)
static int compare_double(const void *pa, const void *pb)
static double segments_tcpa(POINT4D *p0, const POINT4D *p1, POINT4D *q0, const POINT4D *q1, double t0, double t1)
static int ptarray_locate_along_linear(const POINTARRAY *pa, double m, POINT4D *p, uint32_t from)
static int uniq(double *vals, int nvals)