PostGIS  2.2.8dev-r@@SVN_REVISION@@

## ◆ vector_rotate()

 void vector_rotate ( const POINT3D * v1, const POINT3D * v2, double angle, POINT3D * n )

Rotates v1 through an angle (in radians) within the plane defined by v1/v2, returns the rotated vector in n.

Definition at line 523 of file lwgeodetic.c.

References normalize(), unit_normal(), POINT3D::x, POINT3D::y, and POINT3D::z.

Referenced by test_vector_rotate().

524 {
525  POINT3D u;
526  double cos_a = cos(angle);
527  double sin_a = sin(angle);
528  double uxuy, uyuz, uxuz;
529  double ux2, uy2, uz2;
530  double rxx, rxy, rxz, ryx, ryy, ryz, rzx, rzy, rzz;
531
532  /* Need a unit vector normal to rotate around */
533  unit_normal(v1, v2, &u);
534
535  uxuy = u.x * u.y;
536  uxuz = u.x * u.z;
537  uyuz = u.y * u.z;
538
539  ux2 = u.x * u.x;
540  uy2 = u.y * u.y;
541  uz2 = u.z * u.z;
542
543  rxx = cos_a + ux2 * (1 - cos_a);
544  rxy = uxuy * (1 - cos_a) - u.z * sin_a;
545  rxz = uxuz * (1 - cos_a) + u.y * sin_a;
546
547  ryx = uxuy * (1 - cos_a) + u.z * sin_a;
548  ryy = cos_a + uy2 * (1 - cos_a);
549  ryz = uyuz * (1 - cos_a) - u.x * sin_a;
550
551  rzx = uxuz * (1 - cos_a) - u.y * sin_a;
552  rzy = uyuz * (1 - cos_a) + u.x * sin_a;
553  rzz = cos_a + uz2 * (1 - cos_a);
554
555  n->x = rxx * v1->x + rxy * v1->y + rxz * v1->z;
556  n->y = ryx * v1->x + ryy * v1->y + ryz * v1->z;
557  n->z = rzx * v1->x + rzy * v1->y + rzz * v1->z;
558
559  normalize(n);
560 }
void normalize(POINT3D *p)
Normalize to a unit vector.
Definition: lwgeodetic.c:565
double y
Definition: liblwgeom.h:324
double x
Definition: liblwgeom.h:324
double z
Definition: liblwgeom.h:324
void unit_normal(const POINT3D *P1, const POINT3D *P2, POINT3D *normal)
Calculates the unit normal to two vectors, trying to avoid problems with over-narrow or over-wide cas...
Definition: lwgeodetic.c:491
Here is the call graph for this function:
Here is the caller graph for this function: