如何在 Matplotlib 3D 图中为矢量添加箭头?
时间:2024-11-23 13:08:17 288浏览 收藏
大家好,我们又见面了啊~本文《如何在 Matplotlib 3D 图中为矢量添加箭头?》的内容中将会涉及到等等。如果你正在学习文章相关知识,欢迎关注我,以后会给大家带来更多文章相关文章,希望我们能一起进步!下面就开始本文的正式内容~
在 matplotlib 3d 图中将箭头放在矢量上
在绘制 3d 数据的特征向量时,我们希望在这些向量上放置箭头。为了实现这一目标,我们可以使用一个名为 arrow3d 的自定义箭头补丁类,该类扩展了 matplotlib 的 fancyarrowpatch。
arrow3d 类覆盖了 fancyarrowpatch 中的 posa 和 posb 属性,并将这些属性投影到 2d 以在 3d 图中绘制箭头。
步骤:
- 从 3d 坐标创建 arrow3d 对象。
- 使用 proj3d 模块将 3d 坐标投影到 2d。
- 将投影的 2d 坐标分配给 posa 和 posb 属性。
示例:
我们修改了原始示例代码,添加了 arrow3d 箭头艺术家:
import numpy as np from mpl_toolkits.mplot3d import Axes3D from matplotlib.patches import FancyArrowPatch from mpl_toolkits.mplot3d import proj3d class Arrow3D(FancyArrowPatch): def __init__(self, xs, ys, zs, *args, **kwargs): FancyArrowPatch.__init__(self, (0,0), (0,0), *args, **kwargs) self._verts3d = xs, ys, zs def draw(self, renderer): xs3d, ys3d, zs3d = self._verts3d xs, ys, zs = proj3d.proj_transform(xs3d, ys3d, zs3d, renderer.M) self.set_positions((xs[0],ys[0]),(xs[1],ys[1])) FancyArrowPatch.draw(self, renderer) samples, eig_vec = ... # 样本数据和特征向量计算 fig = plt.figure(...) ax = fig.add_subplot(111, projection='3d') ... # 绘制散点和球心 for v in eig_vec: a = Arrow3D([mean_x, v[0]], [mean_y, v[1]], [mean_z, v[2]], mutation_scale=20, lw=3, arrowstyle="-|>", color="r") ax.add_artist(a)
输出:
在 3d 散点图上,每个特征向量现在都绘制有一个指向其方向的箭头。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
457 收藏
-
385 收藏
-
206 收藏
-
439 收藏
-
466 收藏
-
167 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习