PostGIS 3.0.6dev-r@@SVN_REVISION@@
Loading...
Searching...
No Matches

◆ test_lw_dist2d_seg_arc()

static void test_lw_dist2d_seg_arc ( void  )
static

Definition at line 807 of file cu_measures.c.

808{
809 /* int lw_dist2d_seg_arc(const POINT2D *A1, const POINT2D *A2, const POINT2D *B1, const POINT2D *B2, const POINT2D *B3, DISTPTS *dl) */
810
811 DISTPTS dl;
812 POINT2D A1, A2, B1, B2, B3;
813 int rv;
814
815 /* Unit semicircle */
816 B1.x = -1; B1.y = 0;
817 B2.x = 0 ; B2.y = 1;
818 B3.x = 1 ; B3.y = 0;
819
820 /* Edge above the unit semicircle */
822 A1.x = -2; A1.y = 2;
823 A2.x = 2 ; A2.y = 2;
824 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
825 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
826 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 1, 0.000001);
827
828 /* Edge to the right of the unit semicircle */
830 A1.x = 2; A1.y = -2;
831 A2.x = 2; A2.y = 2;
832 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
833 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
834 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 1, 0.000001);
835
836 /* Edge to the left of the unit semicircle */
838 A1.x = -2; A1.y = -2;
839 A2.x = -2; A2.y = 2;
840 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
841 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
842 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 1, 0.000001);
843
844 /* Edge within the unit semicircle */
846 A1.x = 0; A1.y = 0;
847 A2.x = 0; A2.y = 0.5;
848 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
849 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
850 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 0.5, 0.000001);
851
852 /* Edge grazing the unit semicircle */
854 A1.x = -2; A1.y = 1;
855 A2.x = 2; A2.y = 1;
856 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
857 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
858 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 0., 0.000001);
859
860 /* Line grazing the unit semicircle, but edge not */
862 A1.x = 1; A1.y = 1;
863 A2.x = 2; A2.y = 1;
864 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
865 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
866 CU_ASSERT_DOUBLE_EQUAL(dl.distance, sqrt(2.0)-1, 0.000001);
867
868 /* Edge intersecting the unit semicircle */
870 A1.x = 0; A1.y = 0;
871 A2.x = 2; A2.y = 2;
872 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
873 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
874 CU_ASSERT_DOUBLE_EQUAL(dl.distance, 0, 0.000001);
875
876 /* Line intersecting the unit semicircle, but edge not */
878 A1.x = -1; A1.y = 1;
879 A2.x = -2; A2.y = 2;
880 rv = lw_dist2d_seg_arc(&A1, &A2, &B1, &B2, &B3, &dl);
881 //printf("distance %g\n", dl.distance);
882 CU_ASSERT_EQUAL( rv, LW_SUCCESS );
883 CU_ASSERT_DOUBLE_EQUAL(dl.distance, sqrt(2.0)-1, 0.000001);
884}
#define LW_SUCCESS
Definition liblwgeom.h:111
int lw_dist2d_seg_arc(const POINT2D *A1, const POINT2D *A2, const POINT2D *B1, const POINT2D *B2, const POINT2D *B3, DISTPTS *dl)
Calculate the shortest distance between an arc and an edge.
Definition measures.c:1362
void lw_dist2d_distpts_init(DISTPTS *dl, int mode)
Definition measures.c:64
#define DIST_MIN
Definition measures.h:44
double distance
Definition measures.h:51
Structure used in distance-calculations.
Definition measures.h:50
double y
Definition liblwgeom.h:376
double x
Definition liblwgeom.h:376

References DIST_MIN, DISTPTS::distance, lw_dist2d_distpts_init(), lw_dist2d_seg_arc(), LW_SUCCESS, POINT2D::x, and POINT2D::y.

Referenced by measures_suite_setup().

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