【scipy 基础】--空间计算
scipy.spatial
子模块提供了一系列用于处理和计算空间数据和几何形状的算法和工具,在许多领域都有广泛的应用,例如计算机视觉、地理信息系统、机器人学、医学影像分析等。
下面,来具体看看scipy.spatial
子模块为我们提供的主要功能分类。
1. 主要功能
scipy.spatial
子模块中主要包含的功能有:
类别 | 说明 |
---|---|
空间变换类 | 目前主要是三维旋转类的函数 |
最近邻查询类 | 提供了基于树结构的最近邻搜索算法,如K-d树、球树等,用于在大型空间数据集中快速找到最近邻对象 |
距离度量类 | 提供了计算点、线、面等几何形状之间的距离的函数,包括欧几里得距离、曼哈顿距离、切比雪夫距离等。 |
三角剖分、凸包类 | 提供了计算二维数据点的凸包的函数,即找到最小的凸多边形来包含所有数据点等 |
单纯形表示类 | 提供了三维几何对象的方法,如三维点、向量、矩阵 |
2. 使用示例
下面演示两个用scipy.spatial
子模块中的函数实现的示例。
2.1. 凸包计算示例
给定任意个点,计算凸包就是计算包含给定点集中所有点的最小凸对象。
from scipy.spatial import ConvexHull
import numpy as np
import matplotlib.pyplot as plt
# 随机生成100个点
points = np.random.rand(100, 2)
# 计算这些点的凸包
hull = ConvexHull(points)
# 绘制一个随机点
plt.scatter(points[:, 0], points[:, 1], marker='o')
# 将位于凸包上的点用红色线连接起来
for simplex in hull.simplices:
plt.plot(points[simplex, 0], points[simplex, 1], 'r-')
plt.show()
2.2. 三维旋转示例
使用scipy.spatial
子模块来做三维旋转非常简单,它提了多种旋转三维物体的方法,
可以通过欧拉角,轴角,旋转向量,四元组,以及旋转矩阵。
使用方式类似,下面演示的是用欧拉角来旋转一个三维球体。
首先绘制一个球体:
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.add_subplot(projection='3d')
# 球面点的数据
u = np.linspace(0, 2 * np.pi, 100)
v = np.linspace(0, np.pi, 100)
x = 10 * np.outer(np.cos(u), np.sin(v))
y = 10 * np.outer(np.sin(u), np.sin(v))
z = 10 * np.outer(np.ones(np.size(u)), np.cos(v))
ax.plot_surface(x, y, z, cmap=plt.cm.rainbow)
ax.set_aspect('equal')
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
然后用 scipy.spatial 中的方法分别沿X轴旋转45度,沿Y轴旋转90度。
from scipy.spatial.transform import Rotation
# 沿着 "axis" 轴旋转 "degree" 角度
def rotate(axis, degree):
r = Rotation.from_euler(axis, degree, degrees=True)
v = np.dstack((x, y, z))
v = r.apply(v.reshape(-1, 3))
v = v.reshape((*z.shape, 3))
return v
fig, ax = plt.subplots(1, 2, subplot_kw={"projection": "3d"})
v = rotate('x', 45)
ax[0].plot_surface(v[:, :, 0], v[:, :, 1], v[:, :, 2],
cmap=plt.cm.rainbow)
ax[0].set_aspect('equal')
ax[0].set_title("沿X轴旋转45度")
v = rotate('y', 90)
ax[1].plot_surface(v[:, :, 0], v[:, :, 1], v[:, :, 2],
cmap=plt.cm.rainbow)
ax[1].set_aspect('equal')
ax[1].set_title("沿Y轴旋转90度")
plt.show()
3. 总结
总之,scipy.spatial
子模块的重点应用领域有:
距离计算问题,通过计算点、线、面等几何形状之间的距离,可以用于图像配准、碰撞检测、空间聚类等应用;
还有空间插值方法,可以将离散的空间数据转换为连续的函数,用于图像处理、数值分析等领域;
凸包算法,用于图像处理中的对象识别、区域提取等任务;
几何形状操作方法,可以对二维或三维的几何对象进行合并、相交、相减等操作,用于计算机图形学、机器人路径规划等应用;
最近邻搜索算法,在大型空间数据集中快速找到最近邻对象,用于推荐系统、空间索引等应用;
此外,该子模块还提供了排列组合、阶乘和伽马函数等数学计算操作。
【scipy 基础】--空间计算的更多相关文章
- Java基础-时间复杂度计算方式
Java基础-时间复杂度计算方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 时间复杂度通常是衡量算法的优劣的,衡量算法的时间严格来讲是很难衡量的,由于不同的机器性能不用环境 ...
- (数据科学学习手札84)基于geopandas的空间数据分析——空间计算篇(上)
本文示例代码.数据及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在本系列之前的文章中我们主要讨论了g ...
- (数据科学学习手札88)基于geopandas的空间数据分析——空间计算篇(下)
本文示例代码及数据已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在基于geopandas的空间数据分析系列 ...
- SQL Server 2008空间数据应用系列四:基础空间对象与函数应用
原文:SQL Server 2008空间数据应用系列四:基础空间对象与函数应用 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Server 2008 R2调测. ...
- Linux 64位下一键安装scipy等科学计算环境
Linux 64位下一键安装scipy等科学计算环境 采用scipy.org的各种方法试过了,安装还是失败.找到了一键式安装包Anaconda,基本python要用到的库都齐了,而且还可以选择安装到其 ...
- SciPy 基础功能
章节 SciPy 介绍 SciPy 安装 SciPy 基础功能 SciPy 特殊函数 SciPy k均值聚类 SciPy 常量 SciPy fftpack(傅里叶变换) SciPy 积分 SciPy ...
- Scipy教程 - 距离计算库scipy.spatial.distance
http://blog.csdn.net/pipisorry/article/details/48814183 在scipy.spatial中最重要的模块应该就是距离计算模块distance了. fr ...
- Windows下安装python的scipy等科学计算包(转)
如果要使用python进行科学计算.数据分析等,一定要安装scipy.seaborn.numpy等等包. 但Windows下安装python的第三方库经常会出现问题.此前,已介绍过Windows下如何 ...
- sql 基础练习 计算7天各个时间点的总和 group by order mysql一次查询多个表
SQL 基础练习 -- 创建数据库 CREATE DATABASE school CHARACTER SET UTF8; -- 使用数据库 USE school; -- id: 学生的id -- na ...
- 03 . Vue基础之计算属性,组件基础定义和使用
vue组件 fetch请求组件 fetch XMLHttpRequest是一个设计粗糙的API, 配置和调用方式非常混乱,而且基于事件的异步模型写起来不友好,兼容性不好. <!DOCTYPE h ...
随机推荐
- Oracle 11gR2 单实例 For linux6
第一章 准备工作 1.1 系统硬件和软件环境检查 Ø 物理内存至少1G # grep MemTotal /proc/meminfo Ø swap物理内存小于2G时设置为物理内存 ...
- grub加密与解密
前言 grub默认无加密,用户可免密以单用户模式进入系统修改root密码.若想增强其安全性,可以将grub加密. GRUB2提供两种类型的密码保护: 修改菜单条目时需要密码,但启动菜单条目时不需要密码 ...
- Nginx Ingress Contoller 通过 Envoy 代理和 Jaeger 进行分布式追踪(二)
1.概述 在<应用程序通过 Envoy 代理和 Jaeger 进行分布式追踪(一)>一文中,我们详细介绍了单个应用程序如何通过 Envoy 和 Jaeger 实现链路追踪的过程.然而,单独 ...
- C#是否应该限制链式重载的设计模式?
1.代码的可阅读性 一眼看懂是什么意思,并且能看出生成的SQL是什么样的 var list = db.Queryable<Student>() .GroupBy(it => it.N ...
- Vue【原创】基于【日历组件Calendar】的【节假日管理】功能整合
基于日历组件(lilo-calendar)的节假日管理功能整合. 效果图: 完整代码: 1 <template> 2 <div class="root-calendar&q ...
- (2023.8.28)Hi铁布衫-CM Ver 0.001 - Cracked-writeup
Hi铁布衫-CM Ver 0.001 WriteUp 本文作者:XDbgPYG(小吧唧) 发布时间:2023年8月28日 内容概要:Hi铁布衫-CM Ver 0.001 WriteUp 收集信息 有一 ...
- 商品详情api接口的应用方向有哪些?
商品详情API接口的应用方向非常广泛,可以应用于以下领域: 电子商务平台:商品详情API接口可以提供商品的基本信息,如名称.描述.价格.图片等,帮助电子商务平台展示和推荐商品.此外,还可以提供商品 ...
- OpenStack-T版+Ceph
OpenStack OpenStack 中有哪些组件 keystone:授权 [授权后各个组件才可以进行相应的功能] Keystone 认证所有 OpenStack 服务并对其进行授权.同时,它也是所 ...
- gitlab与LDAP 联调
gitlab整理 目录 gitlab整理 1.安装Gitlab依赖包 2.下载,安装 3.配置,访问域名及邮箱 4.初始化,启动 5.访问,以及邮箱测试 5.1汉化 6.问题总结处理 6.1安装时出现 ...
- 安卓APK签名注入大师(APP注入弹窗,注入打开密码,注入过期时间, 注入提示信息,一机一码)
安卓APK签名注入大师可以给安卓APK文件一键注入APP注入弹窗,注入打开密码,注入过期时间, 注入提示信息,一机一码等功能,方便开发人员给自己的APK文件添加消息提示, 密码等功能. 可以保护文件安 ...