libcuspatial  24.02.00
Loading...
Searching...
No Matches
Functions
distance.hpp File Reference
#include <cuspatial/column/geometry_column_view.hpp>
#include <cuspatial/constants.hpp>
#include <cudf/column/column.hpp>
#include <cudf/column/column_view.hpp>
#include <cudf/table/table_view.hpp>
#include <cudf/utilities/span.hpp>
#include <rmm/mr/device/per_device_resource.hpp>
#include <optional>

Go to the source code of this file.

Functions

std::unique_ptr< cudf::column > cuspatial::haversine_distance (cudf::column_view const &a_lon, cudf::column_view const &a_lat, cudf::column_view const &b_lon, cudf::column_view const &b_lat, double const radius=EARTH_RADIUS_KM, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute haversine distances between points in set A and the corresponding points in set B.
 
std::pair< std::unique_ptr< cudf::column >, cudf::table_view > cuspatial::directed_hausdorff_distance (cudf::column_view const &xs, cudf::column_view const &ys, cudf::column_view const &space_offsets, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 computes Hausdorff distances for all pairs in a collection of spaces
 
std::unique_ptr< cudf::column > cuspatial::pairwise_point_distance (geometry_column_view const &multipoints1, geometry_column_view const &multipoints2, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)point-to-(multi)point Cartesian distance.
 
std::unique_ptr< cudf::column > cuspatial::pairwise_point_linestring_distance (geometry_column_view const &multipoints, geometry_column_view const &multilinestrings, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)points-to-(multi)linestrings Cartesian distance.
 
std::unique_ptr< cudf::column > cuspatial::pairwise_point_polygon_distance (geometry_column_view const &multipoints, geometry_column_view const &multipolygons, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)point-to-(multi)polygon Cartesian distance.
 
std::unique_ptr< cudf::column > cuspatial::pairwise_linestring_distance (geometry_column_view const &multilinestrings1, geometry_column_view const &multilinestrings2, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)linestring-to-(multi)linestring Cartesian distance.
 
std::unique_ptr< cudf::column > cuspatial::pairwise_linestring_polygon_distance (geometry_column_view const &multilinestrings, geometry_column_view const &multipolygons, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)linestring-to-(multi)polygon Cartesian distance.
 
std::unique_ptr< cudf::column > cuspatial::pairwise_polygon_distance (geometry_column_view const &multipolygons1, geometry_column_view const &multipolygons2, rmm::mr::device_memory_resource *mr=rmm::mr::get_current_device_resource())
 Compute pairwise (multi)polygon-to-(multi)polygon Cartesian distance.
 

Function Documentation

◆ directed_hausdorff_distance()

std::pair< std::unique_ptr< cudf::column >, cudf::table_view > cuspatial::directed_hausdorff_distance ( cudf::column_view const & xs,
cudf::column_view const & ys,
cudf::column_view const & space_offsets,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

computes Hausdorff distances for all pairs in a collection of spaces

https://en.wikipedia.org/wiki/Hausdorff_distance

Example in 1D (this function operates in 2D):

spaces
[0 2 5] [9] [3 7]
spaces represented as points per space and concatenation of all points
[0 2 5 9 3 7] [3 1 2]
note: the following matrices are visually separated to highlight the relationship of a pair of
points with the pair of spaces from which it is produced
cartesian product of all
points by pair of spaces distance between points
+----------+----+-------+ +---------+---+------+
: 00 02 05 : 09 : 03 07 : : 0 2 5 : 9 : 3 7 :
: 20 22 25 : 29 : 23 27 : : 2 0 3 : 7 : 1 5 :
: 50 52 55 : 59 : 53 57 : : 5 3 0 : 4 : 2 2 :
+----------+----+-------+ +---------+---+------+
: 90 92 95 : 99 : 93 97 : : 9 7 4 : 0 : 6 2 :
+----------+----+-------+ +---------+---+------+
: 30 32 35 : 39 : 33 37 : : 3 1 2 : 6 : 0 4 :
: 70 72 75 : 79 : 73 77 : : 7 5 2 : 2 : 4 0 :
+----------+----+-------+ +---------+---+------+
minimum distance from
every point in one Hausdorff distance is
space to any point in the maximum of the
the other space minimum distances
+----------+----+-------+ +---------+---+------+
: 0 : 9 : 3 : : 0 : 9 : 3 :
: 0 : 7 : 1 : : : : :
: 0 : 4 : 2 : : : : :
+----------+----+-------+ +---------+---+------+
: 4 : 0 : 2 : : 4 : 0 : 2 :
+----------+----+-------+ +---------+---+------+
: 1 : 6 : 0 : : : 6 : 0 :
: 2 : 2 : 0 : : 2 : : :
+----------+----+-------+ +---------+---+------+
Returns:
column: [0 4 2 9 0 6 3 2 0]
table_view: [0 4 2] [9 0 6] [3 2 0]
Parameters
[in]xsx component of points
[in]ysy component of points
[in]space_offsetsbeginning index of each space, plus the last space's end offset.
Returns
An owning object of the result of the hausdorff distances. A table view containing the split view for each input space.
Exceptions
cudf::cuda_errorif xs and ys lengths differ
cudf::cuda_errorif xs and ys types differ
cudf::cuda_errorif space_offsets size is less than xs and xy
cudf::cuda_errorif xs, ys, or space_offsets has nulls
Note
Hausdorff distances are asymmetrical

◆ haversine_distance()

std::unique_ptr< cudf::column > cuspatial::haversine_distance ( cudf::column_view const & a_lon,
cudf::column_view const & a_lat,
cudf::column_view const & b_lon,
cudf::column_view const & b_lat,
double const radius = EARTH_RADIUS_KM,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute haversine distances between points in set A and the corresponding points in set B.

https://en.wikipedia.org/wiki/Haversine_formula

Parameters
[in]a_lonlongitude of points in set A
[in]a_latlatitude of points in set A
[in]b_lonlongitude of points in set B
[in]b_latlatitude of points in set B
[in]radiusradius of the sphere on which the points reside. default: 6371.0 (aprx. radius of earth in km)
Returns
array of distances for all (a_lon[i], a_lat[i]) and (b_lon[i], b_lat[i]) point pairs

◆ pairwise_linestring_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_linestring_distance ( geometry_column_view const & multilinestrings1,
geometry_column_view const & multilinestrings2,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)linestring-to-(multi)linestring Cartesian distance.

The distance between a pair of multilinestrings is the shortest Cartesian distance between any pair of segments in the two multilinestrings. If any of the segments intersects, the distance is 0.

Parameters
multilinestrings1First column of multilinestrings to compute distances
multilinestrings2Second column of multilinestrings to compute distances
mrDevice memory resource used to allocate the returned column's device memory
Returns
A column containing the distance between each pair of input (multi)linestrings
Exceptions
cuspatial::logic_errorif multilinestrings1 and multilinestrings2 sizes differ
cuspatial::logic_errorif either multilinestrings1 or multilinestrings2 is not a linestring column.
cuspatial::logic_errorif multilinestrings1 and multilinestrings2 coordinate types

◆ pairwise_linestring_polygon_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_linestring_polygon_distance ( geometry_column_view const & multilinestrings,
geometry_column_view const & multipolygons,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)linestring-to-(multi)polygon Cartesian distance.

The distance between a pair of (multi)linestring and (multipolygon) is the shortest Cartesian distance between any pair of segments in the multilinestring and edges in the multipolygon. If any of the segments intersects, or if any linestring is contained in any polygon, the distance is 0.

Parameters
multilinestringsGeometry column of multilinestrings
multipolygonsGeometry column of multipolygons
mrDevice memory resource used to allocate the returned column.
Returns
Column of distances between each pair of input geometries, same type as input coordinate types.
Exceptions
cuspatial::logic_errorif multilinestrings and multipolygons sizes differ
cuspatial::logic_errorif either multilinestrings is not a linestrings column or multipolygons is not a polygon column.
cuspatial::logic_errorif multilinestrings and multipolygons has different coordinate types.

◆ pairwise_point_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_point_distance ( geometry_column_view const & multipoints1,
geometry_column_view const & multipoints2,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)point-to-(multi)point Cartesian distance.

The distance between a pair of multipoints is the shortest Cartesian distance between any pair of points in the two multipoints.

Parameters
points1First column of (multi)points to compute distances
points2Second column of (multi)points to compute distances
Returns
Column of distances between each pair of input points
Exceptions
cuspatial::logic_errorif multipoints1 and multipoints2 sizes differ
cuspatial::logic_errorif either multipoints1 or multipoints2 is not a multipoint column
cuspatial::logic_errorif multipoints1 and multipoints2 coordinate types differ

◆ pairwise_point_linestring_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_point_linestring_distance ( geometry_column_view const & multipoints,
geometry_column_view const & multilinestrings,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)points-to-(multi)linestrings Cartesian distance.

The distance between a point and a linestring is defined as the minimum Cartesian distance between the point and any segment of the linestring.

Parameters
multipointsColumn of multipoints to compute distances
multilinestringsColumn of multilinestrings to compute distances
mrDevice memory resource used to allocate the returned column.
Returns
A column containing the distance between each pair of input (multi)points and (multi)linestrings
Exceptions
cuspatial::logic_errorif multipoints and multilinestrings sizes differ
cuspatial::logic_errorif multipoints is not a multipoints column or multilinestrings is not a multilinestrings column
cuspatial::logic_errorif multipoints and multilinestrings coordinate types differ

◆ pairwise_point_polygon_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_point_polygon_distance ( geometry_column_view const & multipoints,
geometry_column_view const & multipolygons,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)point-to-(multi)polygon Cartesian distance.

The distance between a point and a polygon is defined as the minimum Cartesian distance between the point and any segment of the polygon. If the any point of the multipoint is contained in the polygon, the distance is 0.

Parameters
multipointsGeometry column of multipoints
multipolygonsGeometry column of multipolygons
mrDevice memory resource used to allocate the returned column.
Returns
A column containing the distance between each pair of input (multi)points and (multi)polygons
Exceptions
cuspatial::logic_errorif multipoints and multipolygons sizes differ
cuspatial::logic_errorif multipoints is not a point column and multipolygons is not a polygon column.
cuspatial::logic_errorif multipoints and multipolygons coordinate types differ

◆ pairwise_polygon_distance()

std::unique_ptr< cudf::column > cuspatial::pairwise_polygon_distance ( geometry_column_view const & multipolygons1,
geometry_column_view const & multipolygons2,
rmm::mr::device_memory_resource * mr = rmm::mr::get_current_device_resource() )

Compute pairwise (multi)polygon-to-(multi)polygon Cartesian distance.

The distance between a pair of (multi)polygon and (multi)polygon is the shortest Cartesian distance between any pair of edges in the multipolygons. If any edges intersects, or if any polygon is contained in any other polygon, the distance is 0.

Parameters
multipolygons1Geometry column of the multipolygons to compute distance from
multipolygons2Geometry column of the multipolygons to compute distance to
mrDevice memory resource used to allocate the returned column.
Returns
Column of distances between each pair of input geometries, same type as input coordinate types.