KDTree for longitude/latitude

后端 未结 2 1955
悲&欢浪女
悲&欢浪女 2020-12-09 06:11

Are there any packages in Python that allow one to do kdtree-like operations for longitude/latitudes on the surface of a sphere? (this would need to take into account the sp

相关标签:
2条回答
  • 2020-12-09 06:14

    A binary search tree cannot handle the wraparound of the polar representation by design. You might need to transform the coordinates to a 3D cartesian space and then apply your favorite search algorithm, e.g., kD-Tree, Octree etc.

    Alternatively, if you could limit the input range of coordinates to a small region on the surface, you could apply an appropriate map projection to this region, i.e., one that does not distort the shape of your area too much, and apply a standard binary search tree on these no-wrap-around cartesian map coordinates.

    0 讨论(0)
  • 2020-12-09 06:22

    I believe that the BallTree from scikit-learn with the Haversine metric should do the trick for you.

    As an example:

    from sklearn.neighbors import BallTree
    import numpy as np
    import pandas as pd
    
    cities = pd.DataFrame(data={
        'name': [...],
        'lat': [...],
        'lon': [...]
    })
    
    query_lats = [...]
    query_lons = [...]
    
    bt = BallTree(np.deg2rad(cities[['lat', 'lon']].values), metric='haversine')
    distances, indices = bt.query(np.deg2rad(np.c_[query_lats, query_lons]))
    
    nearest_cities = cities['name'].iloc[indices]
    

    Note this returns distances assuming a sphere of radius 1 - to get the distances on the earth multiply by radius = 6371km

    see:

    • https://jakevdp.github.io/blog/2013/04/29/benchmarking-nearest-neighbor-searches-in-python/
    • https://scikit-learn.org/stable/modules/generated/sklearn.neighbors.BallTree.html
    • https://scikit-learn.org/stable/modules/generated/sklearn.metrics.pairwise.haversine_distances.html#sklearn.metrics.pairwise.haversine_distances
    0 讨论(0)
提交回复
热议问题