如何在 Matplotlib 的 3D 图中绘制矢量上的箭头?
时间:2024-11-12 13:21:51 299浏览 收藏
你在学习文章相关的知识吗?本文《如何在 Matplotlib 的 3D 图中绘制矢量上的箭头?》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
在 matplotlib 的 3d 图中绘制矢量上的箭头
想要将箭头放置在 3d 图形中绘制的特征向量上。
解决方案
创建自定义箭头补丁类
由于 matplotlib 的 fancyarrowpatch 类仅适用于 2d 图形,因此需要创建一个新的箭头补丁类 arrow3d,该类继承自 fancyarrowpatch。覆盖 posa 和 posb 方法,将 3d 坐标投影到 2d,然后将其分配给 posa 和 posb。
修改绘图代码
在绘图代码中,将箭头艺术家添加到包含特征向量的绘图对象中。使用自定义的 arrow3d 类,为每个特征向量绘制一个箭头,从平均位置延伸到特征向量末端。
最终代码
import numpy as np import matplotlib.pyplot as plt 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) # 数据生成和特征向量计算 ... # 绘图 fig = plt.figure(figsize=(15,15)) 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 图中。
今天关于《如何在 Matplotlib 的 3D 图中绘制矢量上的箭头?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
255 收藏
-
179 收藏
-
117 收藏
-
307 收藏
-
485 收藏
-
400 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习