python之向量、向量和、向量点积

import matplotlib.pyplot as plt

import numpy as np

设置Matplotlib字体以支持中文

plt.rcParams'font.sans-serif' = 'SimHei' # 设置中文显示

plt.rcParams'axes.unicode_minus' = False # 解决负号显示问题

设置绘图

fig = plt.figure(figsize=(10, 8))

ax = fig.add_subplot(111, projection='3d')

定义向量 a 和 b

a = np.array(1, 2, 3)

b = np.array(4, 5, 6)

origin = np.array(0, 0, 0)

计算向量和

c = a + b

计算向量点积

dot_product = np.dot(a, b)

计算向量叉积

cross_product = np.cross(a, b)

绘制向量

ax.quiver(*origin, *a, color='r', label='向量 a = 1, 2, 3', linewidth=2, arrow_length_ratio=0.1)

ax.quiver(*origin, *b, color='b', label='向量 b = 4, 5, 6', linewidth=2, arrow_length_ratio=0.1)

ax.quiver(*origin, *c, color='g', label=f'向量 a+b = {c.tolist()}', linewidth=2, arrow_length_ratio=0.1)

ax.quiver(*origin, *cross_product, color='purple', label=f'向量 a×b = {cross_product.tolist()}', linewidth=2, arrow_length_ratio=0.1)

添加点积信息

ax.text2D(0.05, 0.95, f'向量a·向量b = {dot_product}', transform=ax.transAxes, fontsize=10, verticalalignment='top', bbox=dict(boxstyle='round', alpha=0.1))

添加辅助线 - 向量a的投影和垂线

向量a在x轴的投影

ax.plot(origin\[0, a0], origin\[1, origin1], origin\[2, origin2], 'r--', alpha=0.5)

向量a在y轴的投影

ax.plot(origin\[0, origin0], origin\[1, a1], origin\[2, origin2], 'r--', alpha=0.5)

向量a在z轴的投影

ax.plot(origin\[0, origin0], origin\[1, origin1], origin\[2, a2], 'r--', alpha=0.5)

从向量a终点到x轴的垂线

ax.plot(a\[0, a0], a\[1, origin1], a\[2, origin2], 'r--', alpha=0.5)

从向量a终点到y轴的垂线

ax.plot(a\[0, origin0], a\[1, a1], a\[2, origin2], 'r--', alpha=0.5)

从向量a终点到z轴的垂线

ax.plot(a\[0, origin0], a\[1, origin1], a\[2, a2], 'r--', alpha=0.5)

添加辅助线 - 向量b的投影和垂线

向量b在x轴的投影

ax.plot(origin\[0, b0], origin\[1, origin1], origin\[2, origin2], 'b--', alpha=0.5)

向量b在y轴的投影

ax.plot(origin\[0, origin0], origin\[1, b1], origin\[2, origin2], 'b--', alpha=0.5)

向量b在z轴的投影

ax.plot(origin\[0, origin0], origin\[1, origin1], origin\[2, b2], 'b--', alpha=0.5)

从向量b终点到x轴的垂线

ax.plot(b\[0, b0], b\[1, origin1], b\[2, origin2], 'b--', alpha=0.5)

从向量b终点到y轴的垂线

ax.plot(b\[0, origin0], b\[1, b1], b\[2, origin2], 'b--', alpha=0.5)

从向量b终点到z轴的垂线

ax.plot(b\[0, origin0], b\[1, origin1], b\[2, b2], 'b--', alpha=0.5)

添加向量a和b之间的连线

ax.plot(a\[0, b0], a\[1, b1], a\[2, b2], 'g--', alpha=0.7, label='向量a和b的连线')

设置坐标轴范围

all_values = np.concatenate(a, b, c, cross_product)

min_range = all_values.min()

max_range = all_values.max()

ax.set_xlim(min_range - 1, max_range + 1)

ax.set_ylim(min_range - 1, max_range + 1)

ax.set_zlim(min_range - 1, max_range + 1)

添加标签和标题

ax.set_xlabel('X 轴')

ax.set_ylabel('Y 轴')

ax.set_zlabel('Z 轴')

ax.set_title('三维向量 a 和 b 的空间示意图')

ax.legend()

ax.grid(True)

显示图形

plt.show()

相关推荐
阿耶同学41 分钟前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田17 小时前
Pydantic校验配置文件
python
hboot17 小时前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi1 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi1 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽1 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187911 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
Warson_L2 天前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅2 天前
海天线算法的前世今生
python·计算机视觉
韩师傅2 天前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉