1608         uint32_t split = it_first;
 
 1609         if ((it_first - it_last) < 2)
 
 1618                 for (uint32_t itk = it_first + 1; itk < it_last; itk++)
 
 1622                         if (distance_sqr > max_distance_sqr)
 
 1625                                 max_distance_sqr = distance_sqr;
 
 1632         double ba_x = (B->
x - A->
x);
 
 1633         double ba_y = (B->
y - A->
y);
 
 1634         double ab_length_sqr = (ba_x * ba_x + ba_y * ba_y);
 
 1637         max_distance_sqr *= ab_length_sqr;
 
 1638         for (uint32_t itk = it_first + 1; itk < it_last; itk++)
 
 1641                 double distance_sqr;
 
 1642                 double ca_x = (C->
x - A->
x);
 
 1643                 double ca_y = (C->
y - A->
y);
 
 1644                 double dot_ac_ab = (ca_x * ba_x + ca_y * ba_y);
 
 1646                 if (dot_ac_ab <= 0.0)
 
 1650                 else if (dot_ac_ab >= ab_length_sqr)
 
 1656                         double s_numerator = ca_x * ba_y - ca_y * ba_x;
 
 1657                         distance_sqr = s_numerator * s_numerator; 
 
 1660                 if (distance_sqr > max_distance_sqr)
 
 1663                         max_distance_sqr = distance_sqr;
 
static const POINT2D * getPoint2d_cp(const POINTARRAY *pa, uint32_t n)
Returns a POINT2D pointer into the POINTARRAY serialized_ptlist, suitable for reading from.
static double distance2d_sqr_pt_pt(const POINT2D *p1, const POINT2D *p2)