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

别再死记硬背了!用Python+NumPy可视化理解向量内积的几何意义

用PythonNumPy可视化理解向量内积的几何意义线性代数中的向量内积公式a·b|a||b|cosθ对初学者来说往往是个抽象的概念。今天我们将用Python和NumPy通过动态可视化的方式让你亲手看到这个公式背后的几何直觉。1. 准备工作搭建可视化环境首先确保你的Python环境已安装以下库import numpy as np import matplotlib.pyplot as plt from matplotlib.animation import FuncAnimation %matplotlib notebook # 在Jupyter中启用交互式绘图我们将创建一个二维坐标系来演示两个向量的内积。初始化两个示例向量a np.array([3, 1]) b np.array([2, 2])计算它们的夹角θ和内积theta np.arccos(np.dot(a, b) / (np.linalg.norm(a) * np.linalg.norm(b))) dot_product np.dot(a, b)2. 静态可视化理解基础概念让我们先绘制这两个向量fig, ax plt.subplots(figsize(8,6)) ax.quiver(0, 0, a[0], a[1], anglesxy, scale_unitsxy, scale1, colorr) ax.quiver(0, 0, b[0], b[1], anglesxy, scale_unitsxy, scale1, colorb) ax.set_xlim(-1, 4); ax.set_ylim(-1, 4) ax.grid(); ax.set_aspect(equal) plt.show()此时你会看到红色向量a和蓝色向量b从原点出发。内积的几何意义是什么我们可以从两个角度理解投影视角a在b方向上的投影长度乘以b的长度坐标旋转视角旋转坐标系使b与x轴重合时a的新x坐标乘以b的长度3. 动态演示坐标系旋转让我们创建一个动画展示坐标系旋转过程中内积保持不变的性质def update(frame): ax.clear() angle frame * np.pi / 180 # 转换为弧度 rotation_matrix np.array([ [np.cos(angle), -np.sin(angle)], [np.sin(angle), np.cos(angle)] ]) # 旋转向量b使其与x轴对齐 rotated_b rotation_matrix b rotated_a rotation_matrix a # 绘制旋转后的向量 ax.quiver(0, 0, rotated_a[0], rotated_a[1], anglesxy, scale_unitsxy, scale1, colorr) ax.quiver(0, 0, rotated_b[0], rotated_b[1], anglesxy, scale_unitsxy, scale1, colorb) # 计算并显示内积 current_dot np.dot(rotated_a, rotated_b) ax.set_title(f旋转角度: {frame}°\n内积值: {current_dot:.2f} (理论值: {dot_product:.2f})) ax.set_xlim(-3, 3); ax.set_ylim(-3, 3) ax.grid(); ax.set_aspect(equal) fig, ax plt.subplots(figsize(8,6)) ani FuncAnimation(fig, update, framesnp.arange(0, 360, 2), interval50) plt.show()观察动画你会发现无论坐标系如何旋转两个向量的内积始终保持不变当b旋转到与x轴重合时b的新坐标为(|b|, 0)a的新坐标为(|a|cosθ, |a|sinθ)此时内积计算简化为|a|cosθ × |b| 0 × |a|sinθ |a||b|cosθ4. 数学原理与代码验证为什么旋转后内积不变让我们用代码验证旋转矩阵的正交性def is_orthogonal(matrix): return np.allclose(matrix matrix.T, np.eye(2)) angle np.pi/4 # 45度 R np.array([ [np.cos(angle), -np.sin(angle)], [np.sin(angle), np.cos(angle)] ]) print(f旋转矩阵R:\n{R}) print(fR的转置:\n{R.T}) print(fR·Rᵀ是否等于单位矩阵: {is_orthogonal(R)})输出结果验证了旋转矩阵的正交性RᵀRI。这正是内积在旋转下保持不变的关键a·b (Ra)ᵀ(Rb) aᵀRᵀRb aᵀIb aᵀb a·b5. 交互式探索改变向量参数为了更深入理解让我们创建一个交互式工具可以动态调整向量并观察内积变化from ipywidgets import interact, FloatSlider interact def interactive_dot_product( a_xFloatSlider(min-5, max5, step0.1, value3), a_yFloatSlider(min-5, max5, step0.1, value1), b_xFloatSlider(min-5, max5, step0.1, value2), b_yFloatSlider(min-5, max5, step0.1, value2) ): a np.array([a_x, a_y]) b np.array([b_x, b_y]) # 计算理论值 theta np.arccos(np.dot(a, b) / (np.linalg.norm(a) * np.linalg.norm(b))) theory np.linalg.norm(a) * np.linalg.norm(b) * np.cos(theta) # 绘图 fig, ax plt.subplots(figsize(8,6)) ax.quiver(0, 0, a[0], a[1], anglesxy, scale_unitsxy, scale1, colorr, labelfa{a}) ax.quiver(0, 0, b[0], b[1], anglesxy, scale_unitsxy, scale1, colorb, labelfb{b}) # 计算并显示内积 dot np.dot(a, b) ax.set_title(f直接计算: {dot:.2f} | 理论公式: {theory:.2f}) ax.set_xlim(-5, 5); ax.set_ylim(-5, 5) ax.grid(); ax.set_aspect(equal); ax.legend() plt.show()通过这个交互式工具你可以任意调整两个向量的坐标观察直接计算的内积值与理论公式结果的一致性直观感受当向量垂直时内积为零的特例6. 应用实例相似性度量内积的一个重要应用是衡量向量相似度。让我们用代码比较三个文档的相似性# 三个文档的词频向量 doc1 np.array([3, 1, 2]) # 技术, 科学, 编程 doc2 np.array([1, 3, 1]) # 科学, 艺术, 文化 doc3 np.array([2, 1, 3]) # 编程, 技术, 开发 # 计算归一化内积(余弦相似度) def cosine_sim(a, b): return np.dot(a, b) / (np.linalg.norm(a) * np.linalg.norm(b)) print(文档1与文档2相似度:, cosine_sim(doc1, doc2)) print(文档1与文档3相似度:, cosine_sim(doc1, doc3)) print(文档2与文档3相似度:, cosine_sim(doc2, doc3))输出结果显示文档1与文档3的相似度最高这与它们都侧重技术主题的直觉一致。这种相似性度量正是基于内积的余弦相似度广泛应用于信息检索和推荐系统。

相关文章:

别再死记硬背了!用Python+NumPy可视化理解向量内积的几何意义

用PythonNumPy可视化理解向量内积的几何意义 线性代数中的向量内积公式ab|a||b|cosθ,对初学者来说往往是个抽象的概念。今天我们将用Python和NumPy,通过动态可视化的方式,让你亲手"看到"这个公式背后的几何直觉。 1. 准备工作&…...

XGBoost实战:Python梯度提升框架入门与优化

1. XGBoost入门实战:从零开始掌握Python中的梯度提升框架如果你正在寻找一个能在机器学习竞赛中屡获佳绩的算法,XGBoost无疑是你的首选武器。作为一名长期使用Python进行机器学习开发的从业者,我见证了XGBoost从默默无闻到成为行业标准的过程…...

取证人员必备:弘连/美亚物联网取证软件分析无人机日志全流程

无人机飞行日志取证全流程:从数据提取到3D轨迹重建 无人机早已不再是单纯的航拍玩具,在物流配送、农业植保、应急救援等领域发挥着重要作用。但与此同时,不法分子也开始利用无人机进行违禁品运输、隐私窥探甚至攻击行为。去年某地破获的一起案…...

OpenWrt V23.05安全加固:修改默认UI登录用户的完整流程

OpenWrt V23.05安全加固:修改默认UI登录用户的完整流程 在网络安全日益重要的今天,路由器作为家庭和企业网络的第一道防线,其安全性不容忽视。OpenWrt作为一款开源的嵌入式操作系统,因其高度可定制性和强大的功能而广受欢迎。然而…...

从‘宇宙第一IDE’之争到黄金搭档:手把手教你用JetBrains工具为Visual Studio 2022赋能

从‘宇宙第一IDE’之争到黄金搭档:手把手教你用JetBrains工具为Visual Studio 2022赋能 在当今快节奏的软件开发领域,效率和质量是每个技术团队的生命线。作为Visual Studio的资深用户,你可能已经习惯了这款"宇宙第一IDE"的强大功能…...

Office和Visio密钥管理指南:一招查看所有安装密钥,并安全清理Visio 2019/2021残留

Office与Visio密钥全生命周期管理:从精准识别到安全清理 引言:为什么需要系统化密钥管理? 在日常办公环境中,微软Office套件的许可证管理往往被忽视,直到遇到激活问题或需要清理残留密钥时才手忙脚乱。特别是像Visio这…...

别再一关了之!手把手教你配置SELinux宽容模式,让服务跑起来(附CentOS 8/RHEL 8实战)

SELinux实战:从权限拒绝到精准配置的完整指南 当你在Linux服务器上部署新服务时,是否经常遇到各种"Permission denied"错误?面对SELinux的拦截,很多管理员的第一反应是直接禁用这个安全模块。但今天我要告诉你&#xff…...

3个秘诀解锁Windows/Linux上的AirPods完整体验:告别电量焦虑与音画不同步

3个秘诀解锁Windows/Linux上的AirPods完整体验:告别电量焦虑与音画不同步 【免费下载链接】AirPodsDesktop ☄️ AirPods desktop user experience enhancement program, for Windows and Linux (WIP) 项目地址: https://gitcode.com/gh_mirrors/ai/AirPodsDeskto…...

终极显卡驱动清理教程:Display Driver Uninstaller (DDU) 完整指南

终极显卡驱动清理教程:Display Driver Uninstaller (DDU) 完整指南 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-…...

Minecraft世界管理终极指南:使用MCA Selector轻松清理和优化区块

Minecraft世界管理终极指南:使用MCA Selector轻松清理和优化区块 【免费下载链接】mcaselector A tool to select chunks from Minecraft worlds for deletion or export. 项目地址: https://gitcode.com/gh_mirrors/mc/mcaselector 你是否曾为Minecraft世界…...

跨越数字边界的文化守护者:AO3-Mirror-Site开源镜像网络革命

跨越数字边界的文化守护者:AO3-Mirror-Site开源镜像网络革命 【免费下载链接】AO3-Mirror-Site 项目地址: https://gitcode.com/gh_mirrors/ao/AO3-Mirror-Site 当一位中国同人创作者在深夜试图访问AO3却遭遇连接失败,当一位研究者需要引用特定同…...

TrollInstallerX终极指南:在iOS 14.0-16.6.1设备上轻松安装TrollStore

TrollInstallerX终极指南:在iOS 14.0-16.6.1设备上轻松安装TrollStore 【免费下载链接】TrollInstallerX A TrollStore installer for iOS 14.0 - 16.6.1 项目地址: https://gitcode.com/gh_mirrors/tr/TrollInstallerX TrollInstallerX是一款专为iOS 14.0至…...

别再只会AB实验了!数据分析师必懂的5种因果推断方法(含PSM/DID实战避坑)

数据分析师进阶指南:5种超越AB实验的因果推断实战方法 当业务团队追问"这个功能上线后究竟带来了多少增量价值"时,你是否还在为无法进行随机分组实验而苦恼?作为经历过数百次业务分析的老兵,我深刻理解数据分析师面对非…...

Claude Code MCP Server 配置教程:用 MCP 协议扩展 AI 的能力边界

MCP(Model Context Protocol)是 Anthropic 推出的开放协议,让 AI 工具能够连接外部数据源和服务。通过配置 MCP Server,你可以让 Claude Code 直接操作数据库、访问 GitHub、管理文件系统,甚至发送 Slack 消息。本文带…...

精准分割字符串:PHP字符串处理技巧

在开发过程中,字符串处理是一个常见的需求。尤其是当我们需要对字符串进行分段处理时,如何准确地分割字符串成为一个关键问题。本文将详细介绍如何在PHP中实现字符串的精准分割,并通过实际例子展示如何将字符串均匀分成两部分,同时处理奇数个单词的情况。 基本概念 在PHP…...

数据资产盘点与治理全景指南:从概念厘清到落地实战的完整方法论(PPT)

我在做数字化咨询这些年,遇到最多的一类问题是这样的:企业IT部门买了大数据平台,用了两三年,系统里存了海量的数据,但业务部门一要报表,还是要手工汇总;老板问一个经营指标,下面给出…...

深扒多Agent协作的“隐形陷阱”:为什么你的AI团队像个“烧钱草台班子”?业内专家揭秘破局真相

2026年的春天,AI开发圈正经历着一场巨大的“认知撕裂”。 一边是各种Agent编排框架宣称的“革命”:只要拖拖拽拽,产品经理、架构师、测试自动上岗,仿佛一夜之间就能用Token堆砌出一个软件工厂。 另一边却是开发者们在社区里的真实吐槽:“Token消耗是单Agent的好几倍,开…...

如何防御SQL注入攻击_禁止应用账号执行DDL操作

根本原因是container响应式定宽而container-fluid需父容器无宽度限制;Bootstrap 5中其默认12px内边距导致不贴边,须用自定义CSS清除,且需排查viewport、全局样式及嵌套逻辑。为什么container在小屏上留白多,而container-fluid没效…...

5分钟快速上手:FigmaCN中文汉化插件完整使用指南

5分钟快速上手:FigmaCN中文汉化插件完整使用指南 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 还在为Figma的英文界面感到困扰吗?作为一名中文设计师&#xff…...

深度解析Get cookies.txt LOCALLY:本地Cookie导出工具的技术实现与安全架构

深度解析Get cookies.txt LOCALLY:本地Cookie导出工具的技术实现与安全架构 【免费下载链接】Get-cookies.txt-LOCALLY Get cookies.txt, NEVER send information outside. 项目地址: https://gitcode.com/gh_mirrors/ge/Get-cookies.txt-LOCALLY 在Web开发和…...

别再傻傻分不清了!一文搞懂手机里的SIM、USIM、UICC卡到底有啥区别

别再傻傻分不清了!一文搞懂手机里的SIM、USIM、UICC卡到底有啥区别 每次换手机卡时,营业厅工作人员问"要换USIM卡吗",总让人一头雾水——这和SIM卡有什么区别?为什么5G套餐必须换卡?那些年剪过的标准卡、Mic…...

Windows Cleaner:你的Windows系统智能管家,告别C盘爆红卡顿烦恼

Windows Cleaner:你的Windows系统智能管家,告别C盘爆红卡顿烦恼 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 还在为Windows电脑越用越慢…...

Sunshine游戏串流:三步打造你的家庭游戏服务器

Sunshine游戏串流:三步打造你的家庭游戏服务器 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款开源自托管的游戏串流服务器,专为Moonlight客…...

C#上位机与欧姆龙PLC通信实战:打造企业级FinsTCP调试工具(Winform)

1. 为什么需要FinsTCP调试工具? 在工业自动化现场,工程师经常需要与PLC进行数据交互。想象一下这样的场景:生产线突然停机,电气工程师怀疑是PLC某个寄存器值异常,但传统方式需要打开编程软件、连接PLC、查找地址...整个…...

GA/T1400与GB/T28181:从协议本质到实战选型,一文读懂安防两大国标

1. 两大国标的前世今生:为什么我们需要它们? 第一次接触GA/T1400和GB/T28181时,我完全被这两个编号搞晕了。后来在参与某智慧园区项目时才发现,选错协议会导致整个监控系统推倒重来。这两个看似枯燥的标准,实际上决定了…...

保姆级图解:用Wireshark抓包实战分析PCIe链路训练全过程(LTSSM状态机)

从零开始:用Wireshark解码PCIe链路训练的每一个状态跳转 当两块PCIe设备首次相遇时,它们会经历一场精密的"握手仪式"——链路训练。这个过程就像两个陌生人初次见面时的试探与磨合,只不过发生在纳秒级的时间尺度上。本文将带你用Wi…...

你的全能系统维护盘:除了装系统,Ventoy U盘还能这样玩(附插件配置)

Ventoy U盘:解锁系统维护工具的终极潜力 你是否曾经遇到过这样的情况:电脑突然蓝屏,重要文件无法访问,或者需要快速测试一个新系统?传统的U盘启动盘往往只能解决单一问题,而Ventoy则完全不同。这个看似简单…...

区块链身份深度学习驾驶

区块链身份深度学习驾驶:未来出行的智能革命 在数字化浪潮下,区块链技术与深度学习的结合正在重塑驾驶领域。区块链为身份验证和数据安全提供了去中心化解决方案,而深度学习则赋予车辆自主决策的能力。两者的融合不仅提升了驾驶安全性&#…...

别再死记硬背公式了!用OpenCV的getPerspectiveTransform函数5分钟搞定透视变换

透视变换实战:5分钟用OpenCV矫正倾斜文档与车牌 每次看到歪斜的文档照片或扭曲的车牌图像,你是否会感到束手无策?作为计算机视觉中最实用的几何变换技术之一,透视变换能完美解决这类问题。不同于简单的旋转和缩放,透视…...

CSS如何让Bootstrap容器自适应屏幕_使用container-fluid类

根本原因是container响应式定宽而container-fluid需父容器无宽度限制;Bootstrap 5中其默认12px内边距导致不贴边,须用自定义CSS清除,且需排查viewport、全局样式及嵌套逻辑。为什么container在小屏上留白多,而container-fluid没效…...