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

自己建购物网站汕头网站建设运营团队

自己建购物网站,汕头网站建设运营团队,网站开发技术历史,建站快车管理由NearestNeighbors类包装 1 主要使用方法 sklearn.neighbors.BallTree(X, leaf_size40, metricminkowski, **kwargs) X数据集中的点数leaf_size改变 leaf_size 不会影响查询的结果,但可以显著影响查询的速度和构建树所需的内存metric用于距离计算的度量。默认为…

由NearestNeighbors类包装

1 主要使用方法

sklearn.neighbors.BallTree(X, leaf_size=40, metric='minkowski', **kwargs)
X数据集中的点数
leaf_size改变 leaf_size 不会影响查询的结果,但可以显著影响查询的速度和构建树所需的内存
metric用于距离计算的度量。默认为 "minkowski"

2 主要方法

2.1 get_arrays

import numpy as np
from sklearn.neighbors import BallTree
X = np.random.random((10, 3))
tree = BallTree(X)                
tree.get_arrays()'''
(array([[0.90651098, 0.68471698, 0.6299996 ],[0.82751465, 0.31739009, 0.61572299],[0.22778906, 0.63614041, 0.73672184],[0.64655758, 0.9729849 , 0.68232389],[0.94992886, 0.72604933, 0.45649069],[0.34932115, 0.95985124, 0.41451989],[0.45131894, 0.21650206, 0.82466273],[0.87047096, 0.48403116, 0.58119046],[0.94468825, 0.14985636, 0.12132986],[0.62717326, 0.12924198, 0.23928098]]),array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9], dtype=int64),array([(0, 10, 1, 0.61638879)],dtype=[('idx_start', '<i8'), ('idx_end', '<i8'), ('is_leaf', '<i8'), ('radius', '<f8')]),array([[[0.68012737, 0.52767645, 0.53022429]]]))
'''
  • 返回了4个数组
    • 第一个数组:原始数据点数组

    • 第二个数组:整数数组,代表每个点的索引

    • 第三个数组:结构化数组,包含了 BallTree 的内部树结构的信息

      • idx_startidx_end:定义了存储在当前节点的点的索引范围。
      • is_leaf:表明当前节点是否是叶节点。
      • radius:当前节点中所有点到节点中心点的最大距离
    • 第四个数组:树的每个节点的中心点

2.2 get_tree_stats

获取 BallTree 的状态信息:树的剪枝次数、叶节点的数量、分裂次数

2.3 query

查询树以找到 k 个最近邻居

query(X, k=1, return_distance=True, dualtree=False, breadth_first=False)
X要查询的点的数组
k

(int,默认为1)

要返回的最近邻居的数量

return_distance

(bool,默认为True)

如果为 True,返回一个包含距离和索引的元组 (d, i);

如果为 False,只返回数组 i

dualtree

(bool,默认为False):

如果为 True,使用双树形式进行查询:为查询点构建一个树,并使用这对树来高效地搜索这个空间当点的数量变得很大时,这可以带来更好的性能

breadth_first

(bool,默认为False)

如果为 True,则以广度优先的方式查询节点。否则,以深度优先的方式查询

sort_results

(bool,默认为True)

如果为 True,则在返回时对每个点的距离和索引进行排序,使得第一列包含最近的点

import numpy as np
from sklearn.neighbors import BallTree
X = np.random.random((100, 3))
tree = BallTree(X)                
tree.query(X[:3],k=3)
'''
(array([[0.        , 0.08335798, 0.15625817],[0.        , 0.06843236, 0.10825558],[0.        , 0.0968137 , 0.10245125]]),array([[ 0, 59, 88],[ 1, 70,  5],[ 2, 43, 20]], dtype=int64))
'''

2.4 query_radius

  • 进行半径查询的功能
  • 查询树,以找出在指定半径 r 内的邻居点
query_radius(X, r, return_distance=False, count_only=False, sort_results=False)
X要查询的点的数组
r

返回邻居的距离范围

r 可以是单个值,也可以是一个数组,形状为 x.shape[:-1],如果每个点需要不同的半径

return_distance

(bool,默认为False)

如果为 True,则返回每个点的邻居距离;如果为 False,则只返回邻居

query() 方法不同,这里设置 return_distance=True 会增加计算时间。如果 return_distance=False,并不需要显式计算所有距离

count_only

(bool,默认为False)

如果为 True,则只返回距离 r 内的点的数量;

如果为 False,则返回距离 r 内所有点的索引

sort_results

(bool,默认为False)

如果为 True,则在返回之前对距离和索引进行排序。如果为 False,则结果不排序

import numpy as np
from sklearn.neighbors import BallTree
X = np.random.random((100, 3))
tree = BallTree(X)                
tree.query_radius(X[:3],r=0.3)
'''
array([array([ 0, 68, 11, 31, 46, 19, 36, 63, 16, 86, 79], dtype=int64),array([26, 64, 20, 94,  1,  4, 13,  3], dtype=int64),array([35, 50, 30, 83, 85, 18, 15, 53,  2, 96, 81], dtype=int64)],dtype=object)
'''

2.5 two_point_correlation

计算距离小于等于r[i]的点的数量

two_point_correlation(X, r, dualtree=False)
X要查询的点集
r一维数组,包含距离值
dualtree

如果为 True,则使用双树算法;否则,使用单树算法。

对于大量数据点(N),双树算法可能有更好的扩展性

返回值

counts (ndarray): counts[i] 包含距离小于或等于 r[i] 的点对数

import numpy as np
from sklearn.neighbors import BallTree
X = np.random.random((100, 3))
r=np.linspace(0.1,1,5)
tree = BallTree(X)                
tree.two_point_correlation(X[:3],r=r)
#array([  4,  34,  99, 196, 263], dtype=int64)
'''
返回的第一个值:和X[0]的距离小于r[0]的数量+和X[1]的距离小于r[0]的数量+和X[2]的距离小于r[0]的数量
'''

3 KD-Tree

和Ball-Tree 一模一样

http://www.yayakq.cn/news/571810/

相关文章:

  • 广东华电建设股份有限公司网站昆明网站建设企业
  • 有哪些官网做的比较好的网站珠海斗门网站建设
  • 成都网站建设好免费建站自助建站
  • 龙岗网站制作中型企业查询系统
  • 做网站需要字体授权wordpress 定时任务
  • 医院网站建设技术方案ppt网站备案到
  • 做3d在哪个网站上接单比较好wordpress远程保存图片
  • 成都专业的网站设计公司WordPress自动推送到公众号
  • 网站开发部组织架构网站排行查询
  • 做服装必须看的十大网站中建八局第一建设有限公司是国企吗
  • 中英双语网站建设太仓网页制作招聘
  • 优化比较好的网站滕州网站搜索引擎优化
  • 高端网站建设seo门户网站是什么意思?
  • asp做的网站企业名称怎么取名
  • 小鱼儿网站做啥用的免费网站开发模板
  • 企业网站建立答辩问题微博上如何做网站推广
  • 网站商城网络整合营销常平到东莞
  • 网站用什么格式做网络互联网推广
  • 网站的上传与发布seo页面优化的方法
  • 淘宝网站用什么语言做的烟台网站建设 共赢
  • 微信生活门户网站源码什么软件比百度搜索好
  • 创造你魔法官方网站起做欢的事龙江网站建设
  • 企业网站运营推广老铁seo外链工具
  • 如何向搜索引擎提交网站wordpress 所有文章404
  • 广州网站设计成功柚米有没有做美食的小视频网站
  • 网上购物网站建设方案保健品网站建设方案书模板
  • 电商网站 性能目标有哪些辽宁造价工程造价信息网
  • 建设银行官方网站注册长沙专业网站制作设计
  • 国内最大网站制作公司创建全国文明城市总结
  • 网站服务器设置简述建设一个网站的基本步骤