当前位置: 首页 > news >正文

sklearn 笔记: neighbors.BallTree

球树结构

1 基本使用方法

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个邻居

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 位于查询点指定半径内的所有邻居点

  • 查找位于每个查询点半径内的点的索引
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_distancebool,默认为 False。如果为 True,则返回每个查询点到其邻居点的距离列表

 

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)
'''
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))
'''

http://www.lryc.cn/news/147169.html

相关文章:

  • 【java】【已解决】IDEA启动报错:Lombok Requires Annotation Processing
  • 生物笔记——暑期学习笔记(三)
  • EPICS自定义设备支持--longin记录的设备支持编写
  • SpringCloud(十)——ElasticSearch简单了解(二)DSL查询语句及RestClient查询文档
  • Python Flask Web开发一:环境搭建
  • DataTable扩展 列转行方法(2*2矩阵转换)
  • Decomposed Prompting: A MODULAR APPROACH FOR SOLVING COMPLEX TASKS
  • ​无需测试环境!如何利用测试脚手架隔离微服务,实现功能自动化
  • HOperatorSet.Connection 有内存泄漏或缓存
  • 力扣2. 两数相加
  • 无涯教程-Android Intent Standard Extra Data函数
  • STM32 CAN 波特率计算分析
  • 每日后端面试5题 第十天
  • 荷兰国旗问题之快速分组
  • 只允许程序单实例运行
  • 巨人互动|Facebook海外户Facebook游戏全球发布实用策略
  • 【Java架构-版本控制】-Git进阶
  • 业务需要咨询?开发遇到 bug 想反馈?开发者在线提单功能上线!
  • MybatisPlus插件篇—逻辑删除+p6spy
  • Android studio中EditText设置默认值
  • 《Java面向对象程序设计》学习笔记——第 13 章 泛型与集合框架
  • python进阶--魔法方法之类的表示
  • JVM 创建对象时分配内存的几种方法、分配方法的选择
  • 08-Vue基础之组件
  • Kotlin学习之密封类
  • opencv鼠标事件函数setMouseCallback()详解
  • 硬件知识积累 USB 接口 type - A type - B type - C 的介绍与功能说明 (简单介绍)
  • 【LeetCode】290. 单词规律
  • 研磨设计模式day12迭代器模式
  • Python3不支持sqlite3的解决方法