PostGIS  3.2.2dev-r@@SVN_REVISION@@

◆ ptarray_length_spheroid()

double ptarray_length_spheroid ( const POINTARRAY pa,
const SPHEROID s 
)

Definition at line 3218 of file lwgeodetic.c.

3219 {
3220  GEOGRAPHIC_POINT a, b;
3221  double za = 0.0, zb = 0.0;
3222  POINT4D p;
3223  uint32_t i;
3224  int hasz = LW_FALSE;
3225  double length = 0.0;
3226  double seglength = 0.0;
3227 
3228  /* Return zero on non-sensical inputs */
3229  if ( ! pa || pa->npoints < 2 )
3230  return 0.0;
3231 
3232  /* See if we have a third dimension */
3233  hasz = FLAGS_GET_Z(pa->flags);
3234 
3235  /* Initialize first point */
3236  getPoint4d_p(pa, 0, &p);
3237  geographic_point_init(p.x, p.y, &a);
3238  if ( hasz )
3239  za = p.z;
3240 
3241  /* Loop and sum the length for each segment */
3242  for ( i = 1; i < pa->npoints; i++ )
3243  {
3244  seglength = 0.0;
3245  getPoint4d_p(pa, i, &p);
3246  geographic_point_init(p.x, p.y, &b);
3247  if ( hasz )
3248  zb = p.z;
3249 
3250  /* Special sphere case */
3251  if ( s->a == s->b )
3252  seglength = s->radius * sphere_distance(&a, &b);
3253  /* Spheroid case */
3254  else
3255  seglength = spheroid_distance(&a, &b, s);
3256 
3257  /* Add in the vertical displacement if we're in 3D */
3258  if ( hasz )
3259  seglength = sqrt( (zb-za)*(zb-za) + seglength*seglength );
3260 
3261  /* Add this segment length to the total */
3262  length += seglength;
3263 
3264  /* B gets incremented in the next loop, so we save the value here */
3265  a = b;
3266  za = zb;
3267  }
3268  return length;
3269 }
char * s
Definition: cu_in_wkt.c:23
#define LW_FALSE
Definition: liblwgeom.h:108
#define FLAGS_GET_Z(flags)
Definition: liblwgeom.h:179
int getPoint4d_p(const POINTARRAY *pa, uint32_t n, POINT4D *point)
Definition: lwgeom_api.c:126
void geographic_point_init(double lon, double lat, GEOGRAPHIC_POINT *g)
Initialize a geographic point.
Definition: lwgeodetic.c:180
double sphere_distance(const GEOGRAPHIC_POINT *s, const GEOGRAPHIC_POINT *e)
Given two points on a unit sphere, calculate their distance apart in radians.
Definition: lwgeodetic.c:948
double spheroid_distance(const GEOGRAPHIC_POINT *a, const GEOGRAPHIC_POINT *b, const SPHEROID *spheroid)
Computes the shortest distance along the surface of the spheroid between two points,...
Definition: lwspheroid.c:79
Point in spherical coordinates on the world.
Definition: lwgeodetic.h:54
double x
Definition: liblwgeom.h:428
double z
Definition: liblwgeom.h:428
double y
Definition: liblwgeom.h:428
lwflags_t flags
Definition: liblwgeom.h:445
uint32_t npoints
Definition: liblwgeom.h:441

References POINTARRAY::flags, FLAGS_GET_Z, geographic_point_init(), getPoint4d_p(), LW_FALSE, POINTARRAY::npoints, s, sphere_distance(), spheroid_distance(), POINT4D::x, POINT4D::y, and POINT4D::z.

Referenced by lwgeom_length_spheroid().

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