sklearn 笔记: neighbors.BallTree

球树结构

1 基本使用方法

python 复制代码
sklearn.neighbors.BallTree(
    X, 
    leaf_size=40, 
    metric='minkowski', 
    **kwargs)

2 主要参数说明

|-----------|--------------------------------------------------------------------------------|
| X | * 输入数据,维度为 (n_samples, n_features) * n_samples 是数据集中点的数量 * n_features 是参数空间的维数 |
| leaf_size | * 点数少于多少时,切换到暴力搜索 * 更改 leaf_size 不会影响查询结果,但可能会显著影响查询速度和构建树所需的内存 |
| metric | 度量距离 |

3 举例

3.1 最近的K个邻居

python 复制代码
import numpy as np
from sklearn.neighbors import BallTree
X = np.random.randn(10,3)
tree = BallTree(X, leaf_size=2)              
dist, ind = tree.query(X[:2], k=3)                

print(ind)  
# 最近的k个邻居的index
'''
[[0 4 5]
 [1 2 8]]
'''

print(dist)  
# 最近的k个邻居的距离
'''
[[0.         0.86677441 1.16406937]
 [0.         0.95190704 1.32997164]]
'''

3.2 位于查询点指定半径内的所有邻居点

  • 查找位于每个查询点半径内的点的索引
python 复制代码
query_radius(
    X, 
    r, 
    return_distance=False, 
    count_only=False, 
    sort_results=False)

|-------------------|------------------------------------------------------|
| X | * 查询点的坐标(n_queries, n_features) |
| r | float 或一维数组,表示查询半径 |
| count_only | bool,默认为 False。 如果为 True,则只返回每个查询点内邻居点的数量,而不返回邻居点的索引 |
| return_distance | bool,默认为 False。如果为 True,则返回每个查询点到其邻居点的距离列表 |

python 复制代码
import numpy as np
from sklearn.neighbors import BallTree
X = np.random.randn(10,3)
tree = BallTree(X, leaf_size=2)              

tree.query_radius(X[:2],r=[0.1,5])
'''
array([array([0], dtype=int64),
       array([6, 2, 4, 7, 8, 1, 0, 3, 9, 5], dtype=int64)], dtype=object)
'''
python 复制代码
import numpy as np
from sklearn.neighbors import BallTree
X = np.random.randn(10,3)
tree = BallTree(X, leaf_size=2)              

tree.query_radius(X[:2],r=[0.1,5],return_distance=True)
'''
(array([array([0], dtype=int64),
        array([8, 2, 3, 6, 1, 9, 7, 0, 5, 4], dtype=int64)], dtype=object),
 array([array([0.]),
        array([2.18948629, 1.05002031, 1.48036256, 1.54854719, 0.        ,
               2.37799982, 3.36371823, 2.63138373, 2.54630893, 3.57322436])],
       dtype=object))
'''
相关推荐
??tobenewyorker40 分钟前
力扣打卡第二十一天 中后遍历+中前遍历 构造二叉树
数据结构·c++·算法·leetcode
future14121 小时前
每日问题总结
经验分享·笔记
贾全1 小时前
第十章:HIL-SERL 真实机器人训练实战
人工智能·深度学习·算法·机器学习·机器人
GIS小天1 小时前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年7月4日第128弹
人工智能·算法·机器学习·彩票
满分观察网友z2 小时前
开发者的“右”眼:一个树问题如何拯救我的UI设计(199. 二叉树的右视图)
算法
森焱森3 小时前
无人机三轴稳定化控制(1)____飞机的稳定控制逻辑
c语言·单片机·算法·无人机
循环过三天3 小时前
3-1 PID算法改进(积分部分)
笔记·stm32·单片机·学习·算法·pid
闪电麦坤953 小时前
数据结构:二维数组(2D Arrays)
数据结构·算法
之歆3 小时前
Python-封装和解构-set及操作-字典及操作-解析式生成器-内建函数迭代器-学习笔记
笔记·python·学习
凌肖战4 小时前
力扣网C语言编程题:快慢指针来解决 “寻找重复数”
c语言·算法·leetcode