From 8418fff6cb051496785f9fc02458a543397f8b41 Mon Sep 17 00:00:00 2001 From: "H. Thomson Comer" Date: Thu, 10 Aug 2023 18:26:47 -0500 Subject: [PATCH 1/3] Move necessary data to cuspatial.testing package. --- .../tests/binpreds/binpred_test_dispatch.py | 588 +----------------- .../test_binpred_cartesian_dispatch_list.py | 7 +- .../test_binpred_each_dispatch_list.py | 7 +- 3 files changed, 15 insertions(+), 587 deletions(-) diff --git a/python/cuspatial/cuspatial/tests/binpreds/binpred_test_dispatch.py b/python/cuspatial/cuspatial/tests/binpreds/binpred_test_dispatch.py index 05b38d702..d9babbb79 100644 --- a/python/cuspatial/cuspatial/tests/binpreds/binpred_test_dispatch.py +++ b/python/cuspatial/cuspatial/tests/binpreds/binpred_test_dispatch.py @@ -4,6 +4,15 @@ from shapely.geometry import LineString, Point, Polygon import cuspatial +from cuspatial.testing.test_geometries import ( # noqa: F401 + features, + linestring_linestring_dispatch_list, + linestring_polygon_dispatch_list, + point_linestring_dispatch_list, + point_point_dispatch_list, + point_polygon_dispatch_list, + polygon_polygon_dispatch_list, +) """Test Dispatch""" @@ -35,585 +44,6 @@ def predicate(request): return request.param -"""The fundamental set of tests. This section is dispatched based -on the feature type. Each feature pairing has a specific set of -comparisons that need to be performed to cover the entire test -space. This section contains specific feature representations -that cover all possible geometric combinations.""" - - -point_polygon = Polygon([(0.0, 0.0), (0.0, 1.0), (1.0, 1.0), (1.0, 0.0)]) -features = { - "point-point-disjoint": ( - """Two points apart.""", - Point(0.0, 0.0), - Point(1.0, 0.0), - ), - "point-point-equal": ( - """Two points together.""", - Point(0.0, 0.0), - Point(0.0, 0.0), - ), - "point-linestring-disjoint": ( - """Point and linestring are disjoint.""", - Point(0.0, 0.0), - LineString([(1.0, 0.0), (2.0, 0.0)]), - ), - "point-linestring-point": ( - """Point and linestring share a point.""", - Point(0.0, 0.0), - LineString([(0.0, 0.0), (2.0, 0.0)]), - ), - "point-linestring-edge": ( - """Point and linestring intersect.""", - Point(0.5, 0.0), - LineString([(0.0, 0.0), (1.0, 0.0)]), - ), - "point-polygon-disjoint": ( - """Point and polygon are disjoint.""", - Point(-0.5, 0.5), - point_polygon, - ), - "point-polygon-point": ( - """Point and polygon share a point.""", - Point(0.0, 0.0), - point_polygon, - ), - "point-polygon-edge": ( - """Point and polygon intersect.""", - Point(0.5, 0.0), - point_polygon, - ), - "point-polygon-in": ( - """Point is in polygon interior.""", - Point(0.5, 0.5), - point_polygon, - ), - "linestring-linestring-disjoint": ( - """ - x---x - - x---x - """, - LineString([(0.0, 0.0), (1.0, 0.0)]), - LineString([(0.0, 1.0), (1.0, 1.0)]), - ), - "linestring-linestring-same": ( - """ - x---x - """, - LineString([(0.0, 0.0), (1.0, 0.0)]), - LineString([(0.0, 0.0), (1.0, 0.0)]), - ), - "linestring-linestring-covers": ( - """ - x - x - / - x - x - """, - LineString([(0.0, 0.0), (1.0, 1.0)]), - LineString([(0.25, 0.25), (0.5, 0.5)]), - ), - "linestring-linestring-touches": ( - """ - x - | - | - | - x---x - """, - LineString([(0.0, 0.0), (0.0, 1.0)]), - LineString([(0.0, 0.0), (1.0, 0.0)]), - ), - "linestring-linestring-touch-interior": ( - """ - x x - | / - | / - |/ - x---x - """, - LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.0)]), - LineString([(0.0, 0.0), (1.0, 1.0)]), - ), - "linestring-linestring-touch-edge": ( - """ - x - | - | - | - x-x-x - """, - LineString([(0.0, 0.0), (1.0, 0.0)]), - LineString([(0.5, 0.0), (0.5, 1.0)]), - ), - "linestring-linestring-touch-edge-twice": ( - """ - x - x - / \\ - x---x - x - """, - LineString([(0.0, 0.0), (1.0, 1.0), (2.0, 2.0)]), - LineString([(0.25, 0.25), (1.0, 0.0), (0.5, 0.5)]), - ), - "linestring-linestring-crosses": ( - """ - x - | - x-|-x - | - x - """, - LineString([(0.5, 0.0), (0.5, 1.0)]), - LineString([(0.0, 0.5), (1.0, 0.5)]), - ), - "linestring-linestring-touch-and-cross": ( - """ - x - | - x - |\\ - x---x - x - """, - LineString([(0.0, 0.0), (1.0, 1.0)]), - LineString([(0.5, 0.5), (1.0, 0.1), (-1.0, 0.1)]), - ), - "linestring-polygon-disjoint": ( - """ - point_polygon above is drawn as - ----- - | | - | | - | | - ----- - and the corresponding linestring is drawn as - x---x - or - x - | - | - | - x - """ - """ - x ----- - | | | - | | | - | | | - x ----- - """, - LineString([(-0.5, 0.0), (-0.5, 1.0)]), - point_polygon, - ), - "linestring-polygon-touch-point": ( - """ - x---x---- - | | - | | - | | - ----- - """, - LineString([(-1.0, 0.0), (0.0, 0.0)]), - point_polygon, - ), - "linestring-polygon-touch-edge": ( - """ - ----- - | | - x---x | - | | - ----- - """, - LineString([(-1.0, 0.5), (0.0, 0.5)]), - point_polygon, - ), - "linestring-polygon-overlap-edge": ( - """ - x---- - | | - | | - | | - x---- - """, - LineString([(0.0, 0.0), (0.0, 1.0)]), - point_polygon, - ), - "linestring-polygon-intersect-edge": ( - """ - ----- - | | - | | - | | - x---x-- - """, - LineString([(-0.5, 0.0), (0.5, 0.0)]), - point_polygon, - ), - "linestring-polygon-intersect-inner-edge": ( - """ - ----- - x | - | | - x | - ----- - - The linestring in this case is shorter than the corners of the polygon. - """, - LineString([(0.25, 0.0), (0.75, 0.0)]), - point_polygon, - ), - "linestring-polygon-point-interior": ( - """ - ----x - | /| - | / | - |/ | - x---- - """, - LineString([(0.0, 0.0), (1.0, 1.0)]), - point_polygon, - ), - "linestring-polygon-edge-interior": ( - """ - --x-- - | | | - | | | - | | | - --x-- - """, - LineString([(0.5, 0.0), (0.5, 1.0)]), - point_polygon, - ), - "linestring-polygon-in": ( - """ - ----- - | x | - | | | - | x | - ----- - """, - LineString([(0.5, 0.25), (0.5, 0.75)]), - point_polygon, - ), - "linestring-polygon-in-out": ( - """ - ----- - | | - | x | - | | | - --|-- - | - x - """, - LineString([(0.5, 0.5), (0.5, -0.5)]), - point_polygon, - ), - "linestring-polygon-crosses": ( - """ - x - --|-- - | | | - | | | - | | | - --|-- - x - """, - LineString([(0.5, 1.25), (0.5, -0.25)]), - point_polygon, - ), - "linestring-polygon-cross-concave-edge": ( - """ - x x x - |\\ | /| - | xx- | - | | | - ---x--- - """, - LineString([(0.5, 0.0), (0.5, 1.0)]), - Polygon([(0, 0), (0, 1), (0.3, 0.4), (1, 1), (1, 0)]), - ), - "linestring-polygon-half-in": ( - """ - ----- - | | - | x | - |/ \\| - xx-xx - """, - LineString( - [(0.0, 0.0), (0.25, 0.0), (0.5, 0.5), (0.75, 0.0), (1.0, 0.0)] - ), - point_polygon, - ), - "linestring-polygon-half-out": ( - """ - ----- - | | - | | - | | - xx-xx - \\/ - x - """, - LineString( - [(0.0, 0.0), (0.25, 0.0), (0.5, -0.5), (0.75, 0.0), (1.0, 0.0)] - ), - point_polygon, - ), - "linestring-polygon-two-edges": ( - """ - x---- - | | - | | - | | - x---x - """, - LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.0)]), - point_polygon, - ), - "linestring-polygon-edge-to-interior": ( - """ - x---- - | | - | -x - |-/ | - x---- - """, - LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.5)]), - point_polygon, - ), - "linestring-polygon-edge-cross-to-exterior": ( - """ - x------ - | | - | ---x - | --- | - x------ - """, - LineString([(0.0, 1.0), (0.0, 0.0), (1.5, 0.5)]), - point_polygon, - ), - "polygon-polygon-disjoint": ( - """ - Polygon polygon tests use a triangle for the lhs and a square for the rhs. - The triangle is drawn as - x---x - | / - | / - |/ - x - - The square is drawn as - - ----- - | | - | | - | | - ----- - """, - Polygon([(0.0, 2.0), (0.0, 3.0), (1.0, 3.0)]), - point_polygon, - ), - "polygon-polygon-touch-point": ( - """ - x---x - | / - | / - |/ - x---- - | | - | | - | | - ----- - """, - Polygon([(0.0, 1.0), (0.0, 2.0), (1.0, 2.0)]), - point_polygon, - ), - "polygon-polygon-touch-edge": ( - """ - x---x - | / - | / - |/ - -x--x - | | - | | - | | - ----- - """, - Polygon([(0.25, 1.0), (0.25, 2.0), (1.25, 2.0)]), - point_polygon, - ), - "polygon-polygon-overlap-edge": ( - """ - x - |\\ - | \\ - | \\ - x---x - | | - | | - | | - ----- - """, - Polygon([(0.0, 1.0), (0.0, 2.0), (1.0, 2.0)]), - point_polygon, - ), - "polygon-polygon-overlap-inside-edge": ( - """ - x - /| - x---x | - \\ / | - x | - / | - x-----x - """, - Polygon([(0, 0), (1, 0), (1, 1), (0, 0)]), - Polygon([(0.25, 0.25), (0.5, 0.5), (0, 0.5), (0.25, 0.25)]), - ), - "polygon-polygon-point-inside": ( - """ - x---x - | / - --|-/ - | |/| - | x | - | | - ----- - """, - Polygon([(0.5, 0.5), (0.5, 1.5), (1.5, 1.5)]), - point_polygon, - ), - "polygon-polygon-point-outside": ( - """ - x - -|\\-- - |x-x| - | | - | | - ----- - """, - Polygon([(0.25, 0.75), (0.25, 1.25), (0.75, 0.75)]), - point_polygon, - ), - "polygon-polygon-in-out-point": ( - """ - x - |\\ - --|-x - | |/| - | x | - | | - x---- - """, - Polygon([(0.5, 0.5), (0.5, 1.5), (1.0, 1.0)]), - point_polygon, - ), - "polygon-polygon-in-point-point": ( - """ - x---- - |\\ | - | x | - |/ | - x---- - """, - Polygon([(0.0, 0.0), (0.0, 1.0), (0.5, 0.5)]), - point_polygon, - ), - "polygon-polygon-contained": ( - """ - ----- - | x| - | /|| - |x-x| - ----- - """, - Polygon([(0.25, 0.25), (0.75, 0.75), (0.75, 0.25)]), - point_polygon, - ), - "polygon-polygon-same": ( - """ - x---x - | | - | | - | | - x---x - """, - point_polygon, - point_polygon, - ), -} - -point_point_dispatch_list = [ - "point-point-disjoint", - "point-point-equal", -] - -point_linestring_dispatch_list = [ - "point-linestring-disjoint", - "point-linestring-point", - "point-linestring-edge", -] - -point_polygon_dispatch_list = [ - "point-polygon-disjoint", - "point-polygon-point", - "point-polygon-edge", - "point-polygon-in", -] - -linestring_linestring_dispatch_list = [ - "linestring-linestring-disjoint", - "linestring-linestring-same", - "linestring-linestring-covers", - "linestring-linestring-touches", - "linestring-linestring-touch-interior", - "linestring-linestring-touch-edge", - "linestring-linestring-touch-edge-twice", - "linestring-linestring-crosses", - "linestring-linestring-touch-and-cross", -] - -linestring_polygon_dispatch_list = [ - "linestring-polygon-disjoint", - "linestring-polygon-touch-point", - "linestring-polygon-touch-edge", - "linestring-polygon-overlap-edge", - "linestring-polygon-intersect-edge", - "linestring-polygon-intersect-inner-edge", - "linestring-polygon-point-interior", - "linestring-polygon-edge-interior", - "linestring-polygon-in", - "linestring-polygon-crosses", - "linestring-polygon-cross-concave-edge", - "linestring-polygon-half-in", - "linestring-polygon-half-out", - "linestring-polygon-two-edges", - "linestring-polygon-edge-to-interior", - "linestring-polygon-edge-cross-to-exterior", -] - -polygon_polygon_dispatch_list = [ - "polygon-polygon-disjoint", - "polygon-polygon-touch-point", - "polygon-polygon-touch-edge", - "polygon-polygon-overlap-edge", - "polygon-polygon-overlap-inside-edge", - "polygon-polygon-point-inside", - "polygon-polygon-point-outside", - "polygon-polygon-in-out-point", - "polygon-polygon-in-point-point", - "polygon-polygon-contained", - "polygon-polygon-same", -] - - def object_dispatch(name_list): """Generate a list of test cases for a given set of test names.""" for name in name_list: diff --git a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py index 772853ef2..55407133c 100644 --- a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py +++ b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py @@ -2,7 +2,9 @@ import geopandas import numpy as np -from binpred_test_dispatch import ( # noqa: F401 + +import cuspatial +from cuspatial.testing.test_geometries import ( # noqa: F401 features, linestring_linestring_dispatch_list, linestring_polygon_dispatch_list, @@ -10,11 +12,8 @@ point_point_dispatch_list, point_polygon_dispatch_list, polygon_polygon_dispatch_list, - predicate, ) -import cuspatial - def sample_test_data(features, dispatch_list, size, lib=cuspatial): """Creates either a cuspatial or geopandas GeoSeries object using the diff --git a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py index 9f7aa3219..ee67ce617 100644 --- a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py +++ b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py @@ -1,7 +1,9 @@ # Copyright (c) 2023, NVIDIA CORPORATION. import geopandas -from binpred_test_dispatch import ( # noqa: F401 + +import cuspatial +from cuspatial.testing.test_geometries import ( # noqa: F401 features, linestring_linestring_dispatch_list, linestring_polygon_dispatch_list, @@ -9,11 +11,8 @@ point_point_dispatch_list, point_polygon_dispatch_list, polygon_polygon_dispatch_list, - predicate, ) -import cuspatial - def sample_test_data(features, dispatch_list, lib=cuspatial): """Creates either a cuSpatial or geopandas GeoSeries object using the From eced3f28926d537e4330200b2158571cf67d80cd Mon Sep 17 00:00:00 2001 From: "H. Thomson Comer" Date: Thu, 17 Aug 2023 14:56:54 -0500 Subject: [PATCH 2/3] Forgot testing package whoops. --- .../cuspatial/cuspatial/testing/__init__.py | 0 .../cuspatial/testing/test_geometries.py | 580 ++++++++++++++++++ 2 files changed, 580 insertions(+) create mode 100644 python/cuspatial/cuspatial/testing/__init__.py create mode 100644 python/cuspatial/cuspatial/testing/test_geometries.py diff --git a/python/cuspatial/cuspatial/testing/__init__.py b/python/cuspatial/cuspatial/testing/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/python/cuspatial/cuspatial/testing/test_geometries.py b/python/cuspatial/cuspatial/testing/test_geometries.py new file mode 100644 index 000000000..c4f934a22 --- /dev/null +++ b/python/cuspatial/cuspatial/testing/test_geometries.py @@ -0,0 +1,580 @@ +# Copyright (c) 2023, NVIDIA CORPORATION. +from shapely.geometry import LineString, Point, Polygon + +"""The fundamental set of tests. This section is dispatched based +on the feature type. Each feature pairing has a specific set of +comparisons that need to be performed to cover the entire test +space. This section contains specific feature representations +that cover all possible geometric combinations.""" + + +point_polygon = Polygon([(0.0, 0.0), (0.0, 1.0), (1.0, 1.0), (1.0, 0.0)]) +features = { + "point-point-disjoint": ( + """Two points apart.""", + Point(0.0, 0.0), + Point(1.0, 0.0), + ), + "point-point-equal": ( + """Two points together.""", + Point(0.0, 0.0), + Point(0.0, 0.0), + ), + "point-linestring-disjoint": ( + """Point and linestring are disjoint.""", + Point(0.0, 0.0), + LineString([(1.0, 0.0), (2.0, 0.0)]), + ), + "point-linestring-point": ( + """Point and linestring share a point.""", + Point(0.0, 0.0), + LineString([(0.0, 0.0), (2.0, 0.0)]), + ), + "point-linestring-edge": ( + """Point and linestring intersect.""", + Point(0.5, 0.0), + LineString([(0.0, 0.0), (1.0, 0.0)]), + ), + "point-polygon-disjoint": ( + """Point and polygon are disjoint.""", + Point(-0.5, 0.5), + point_polygon, + ), + "point-polygon-point": ( + """Point and polygon share a point.""", + Point(0.0, 0.0), + point_polygon, + ), + "point-polygon-edge": ( + """Point and polygon intersect.""", + Point(0.5, 0.0), + point_polygon, + ), + "point-polygon-in": ( + """Point is in polygon interior.""", + Point(0.5, 0.5), + point_polygon, + ), + "linestring-linestring-disjoint": ( + """ + x---x + + x---x + """, + LineString([(0.0, 0.0), (1.0, 0.0)]), + LineString([(0.0, 1.0), (1.0, 1.0)]), + ), + "linestring-linestring-same": ( + """ + x---x + """, + LineString([(0.0, 0.0), (1.0, 0.0)]), + LineString([(0.0, 0.0), (1.0, 0.0)]), + ), + "linestring-linestring-covers": ( + """ + x + x + / + x + x + """, + LineString([(0.0, 0.0), (1.0, 1.0)]), + LineString([(0.25, 0.25), (0.5, 0.5)]), + ), + "linestring-linestring-touches": ( + """ + x + | + | + | + x---x + """, + LineString([(0.0, 0.0), (0.0, 1.0)]), + LineString([(0.0, 0.0), (1.0, 0.0)]), + ), + "linestring-linestring-touch-interior": ( + """ + x x + | / + | / + |/ + x---x + """, + LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.0)]), + LineString([(0.0, 0.0), (1.0, 1.0)]), + ), + "linestring-linestring-touch-edge": ( + """ + x + | + | + | + x-x-x + """, + LineString([(0.0, 0.0), (1.0, 0.0)]), + LineString([(0.5, 0.0), (0.5, 1.0)]), + ), + "linestring-linestring-touch-edge-twice": ( + """ + x + x + / \\ + x---x + x + """, + LineString([(0.0, 0.0), (1.0, 1.0), (2.0, 2.0)]), + LineString([(0.25, 0.25), (1.0, 0.0), (0.5, 0.5)]), + ), + "linestring-linestring-crosses": ( + """ + x + | + x-|-x + | + x + """, + LineString([(0.5, 0.0), (0.5, 1.0)]), + LineString([(0.0, 0.5), (1.0, 0.5)]), + ), + "linestring-linestring-touch-and-cross": ( + """ + x + | + x + |\\ + x---x + x + """, + LineString([(0.0, 0.0), (1.0, 1.0)]), + LineString([(0.5, 0.5), (1.0, 0.1), (-1.0, 0.1)]), + ), + "linestring-polygon-disjoint": ( + """ + point_polygon above is drawn as + ----- + | | + | | + | | + ----- + and the corresponding linestring is drawn as + x---x + or + x + | + | + | + x + """ + """ + x ----- + | | | + | | | + | | | + x ----- + """, + LineString([(-0.5, 0.0), (-0.5, 1.0)]), + point_polygon, + ), + "linestring-polygon-touch-point": ( + """ + x---x---- + | | + | | + | | + ----- + """, + LineString([(-1.0, 0.0), (0.0, 0.0)]), + point_polygon, + ), + "linestring-polygon-touch-edge": ( + """ + ----- + | | + x---x | + | | + ----- + """, + LineString([(-1.0, 0.5), (0.0, 0.5)]), + point_polygon, + ), + "linestring-polygon-overlap-edge": ( + """ + x---- + | | + | | + | | + x---- + """, + LineString([(0.0, 0.0), (0.0, 1.0)]), + point_polygon, + ), + "linestring-polygon-intersect-edge": ( + """ + ----- + | | + | | + | | + x---x-- + """, + LineString([(-0.5, 0.0), (0.5, 0.0)]), + point_polygon, + ), + "linestring-polygon-intersect-inner-edge": ( + """ + ----- + x | + | | + x | + ----- + + The linestring in this case is shorter than the corners of the polygon. + """, + LineString([(0.25, 0.0), (0.75, 0.0)]), + point_polygon, + ), + "linestring-polygon-point-interior": ( + """ + ----x + | /| + | / | + |/ | + x---- + """, + LineString([(0.0, 0.0), (1.0, 1.0)]), + point_polygon, + ), + "linestring-polygon-edge-interior": ( + """ + --x-- + | | | + | | | + | | | + --x-- + """, + LineString([(0.5, 0.0), (0.5, 1.0)]), + point_polygon, + ), + "linestring-polygon-in": ( + """ + ----- + | x | + | | | + | x | + ----- + """, + LineString([(0.5, 0.25), (0.5, 0.75)]), + point_polygon, + ), + "linestring-polygon-in-out": ( + """ + ----- + | | + | x | + | | | + --|-- + | + x + """, + LineString([(0.5, 0.5), (0.5, -0.5)]), + point_polygon, + ), + "linestring-polygon-crosses": ( + """ + x + --|-- + | | | + | | | + | | | + --|-- + x + """, + LineString([(0.5, 1.25), (0.5, -0.25)]), + point_polygon, + ), + "linestring-polygon-cross-concave-edge": ( + """ + x x x + |\\ | /| + | xx- | + | | | + ---x--- + """, + LineString([(0.5, 0.0), (0.5, 1.0)]), + Polygon([(0, 0), (0, 1), (0.3, 0.4), (1, 1), (1, 0)]), + ), + "linestring-polygon-half-in": ( + """ + ----- + | | + | x | + |/ \\| + xx-xx + """, + LineString( + [(0.0, 0.0), (0.25, 0.0), (0.5, 0.5), (0.75, 0.0), (1.0, 0.0)] + ), + point_polygon, + ), + "linestring-polygon-half-out": ( + """ + ----- + | | + | | + | | + xx-xx + \\/ + x + """, + LineString( + [(0.0, 0.0), (0.25, 0.0), (0.5, -0.5), (0.75, 0.0), (1.0, 0.0)] + ), + point_polygon, + ), + "linestring-polygon-two-edges": ( + """ + x---- + | | + | | + | | + x---x + """, + LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.0)]), + point_polygon, + ), + "linestring-polygon-edge-to-interior": ( + """ + x---- + | | + | -x + |-/ | + x---- + """, + LineString([(0.0, 1.0), (0.0, 0.0), (1.0, 0.5)]), + point_polygon, + ), + "linestring-polygon-edge-cross-to-exterior": ( + """ + x------ + | | + | ---x + | --- | + x------ + """, + LineString([(0.0, 1.0), (0.0, 0.0), (1.5, 0.5)]), + point_polygon, + ), + "polygon-polygon-disjoint": ( + """ + Polygon polygon tests use a triangle for the lhs and a square for the rhs. + The triangle is drawn as + x---x + | / + | / + |/ + x + + The square is drawn as + + ----- + | | + | | + | | + ----- + """, + Polygon([(0.0, 2.0), (0.0, 3.0), (1.0, 3.0)]), + point_polygon, + ), + "polygon-polygon-touch-point": ( + """ + x---x + | / + | / + |/ + x---- + | | + | | + | | + ----- + """, + Polygon([(0.0, 1.0), (0.0, 2.0), (1.0, 2.0)]), + point_polygon, + ), + "polygon-polygon-touch-edge": ( + """ + x---x + | / + | / + |/ + -x--x + | | + | | + | | + ----- + """, + Polygon([(0.25, 1.0), (0.25, 2.0), (1.25, 2.0)]), + point_polygon, + ), + "polygon-polygon-overlap-edge": ( + """ + x + |\\ + | \\ + | \\ + x---x + | | + | | + | | + ----- + """, + Polygon([(0.0, 1.0), (0.0, 2.0), (1.0, 2.0)]), + point_polygon, + ), + "polygon-polygon-overlap-inside-edge": ( + """ + x + /| + x---x | + \\ / | + x | + / | + x-----x + """, + Polygon([(0, 0), (1, 0), (1, 1), (0, 0)]), + Polygon([(0.25, 0.25), (0.5, 0.5), (0, 0.5), (0.25, 0.25)]), + ), + "polygon-polygon-point-inside": ( + """ + x---x + | / + --|-/ + | |/| + | x | + | | + ----- + """, + Polygon([(0.5, 0.5), (0.5, 1.5), (1.5, 1.5)]), + point_polygon, + ), + "polygon-polygon-point-outside": ( + """ + x + -|\\-- + |x-x| + | | + | | + ----- + """, + Polygon([(0.25, 0.75), (0.25, 1.25), (0.75, 0.75)]), + point_polygon, + ), + "polygon-polygon-in-out-point": ( + """ + x + |\\ + --|-x + | |/| + | x | + | | + x---- + """, + Polygon([(0.5, 0.5), (0.5, 1.5), (1.0, 1.0)]), + point_polygon, + ), + "polygon-polygon-in-point-point": ( + """ + x---- + |\\ | + | x | + |/ | + x---- + """, + Polygon([(0.0, 0.0), (0.0, 1.0), (0.5, 0.5)]), + point_polygon, + ), + "polygon-polygon-contained": ( + """ + ----- + | x| + | /|| + |x-x| + ----- + """, + Polygon([(0.25, 0.25), (0.75, 0.75), (0.75, 0.25)]), + point_polygon, + ), + "polygon-polygon-same": ( + """ + x---x + | | + | | + | | + x---x + """, + point_polygon, + point_polygon, + ), +} + +point_point_dispatch_list = [ + "point-point-disjoint", + "point-point-equal", +] + +point_linestring_dispatch_list = [ + "point-linestring-disjoint", + "point-linestring-point", + "point-linestring-edge", +] + +point_polygon_dispatch_list = [ + "point-polygon-disjoint", + "point-polygon-point", + "point-polygon-edge", + "point-polygon-in", +] + +linestring_linestring_dispatch_list = [ + "linestring-linestring-disjoint", + "linestring-linestring-same", + "linestring-linestring-covers", + "linestring-linestring-touches", + "linestring-linestring-touch-interior", + "linestring-linestring-touch-edge", + "linestring-linestring-touch-edge-twice", + "linestring-linestring-crosses", + "linestring-linestring-touch-and-cross", +] + +linestring_polygon_dispatch_list = [ + "linestring-polygon-disjoint", + "linestring-polygon-touch-point", + "linestring-polygon-touch-edge", + "linestring-polygon-overlap-edge", + "linestring-polygon-intersect-edge", + "linestring-polygon-intersect-inner-edge", + "linestring-polygon-point-interior", + "linestring-polygon-edge-interior", + "linestring-polygon-in", + "linestring-polygon-crosses", + "linestring-polygon-cross-concave-edge", + "linestring-polygon-half-in", + "linestring-polygon-half-out", + "linestring-polygon-two-edges", + "linestring-polygon-edge-to-interior", + "linestring-polygon-edge-cross-to-exterior", +] + +polygon_polygon_dispatch_list = [ + "polygon-polygon-disjoint", + "polygon-polygon-touch-point", + "polygon-polygon-touch-edge", + "polygon-polygon-overlap-edge", + "polygon-polygon-overlap-inside-edge", + "polygon-polygon-point-inside", + "polygon-polygon-point-outside", + "polygon-polygon-in-out-point", + "polygon-polygon-in-point-point", + "polygon-polygon-contained", + "polygon-polygon-same", +] From e41bbec1e6e050a379edc02b7b3eeb03563e0bb7 Mon Sep 17 00:00:00 2001 From: "H. Thomson Comer" Date: Fri, 18 Aug 2023 10:58:16 -0500 Subject: [PATCH 3/3] Fix missing predicate import in binpred tests. --- .../tests/binpreds/test_binpred_cartesian_dispatch_list.py | 3 ++- .../tests/binpreds/test_binpred_each_dispatch_list.py | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py index 55407133c..d2a9a841f 100644 --- a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py +++ b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_cartesian_dispatch_list.py @@ -2,9 +2,10 @@ import geopandas import numpy as np +from binpred_test_dispatch import predicate # noqa: F401 import cuspatial -from cuspatial.testing.test_geometries import ( # noqa: F401 +from cuspatial.testing.test_geometries import ( features, linestring_linestring_dispatch_list, linestring_polygon_dispatch_list, diff --git a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py index ee67ce617..f5ea64e3c 100644 --- a/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py +++ b/python/cuspatial/cuspatial/tests/binpreds/test_binpred_each_dispatch_list.py @@ -1,9 +1,10 @@ # Copyright (c) 2023, NVIDIA CORPORATION. import geopandas +from binpred_test_dispatch import predicate # noqa: F401 import cuspatial -from cuspatial.testing.test_geometries import ( # noqa: F401 +from cuspatial.testing.test_geometries import ( features, linestring_linestring_dispatch_list, linestring_polygon_dispatch_list,