DX12龙书 01 - 向量在几何学和数学中的表示以及运算定义
0x00 向量
向量 ( vector ) 是一种兼具大小 ( magnitude ) 和方向的量。
0x01 几何表示
几何方法中用一条有向线段来表示一个向量,其中,线段长度代表向量的模,箭头的指向代表向量的方向。
改变向量的位置不会改变其大小和方向,所以向量与其位置无关。当我们说两个向量相等,当且仅当它们的长度相等且方向相同。
0x02 数学表示
数学中使用坐标系来描述向量,通过平移操作将向量的尾部移动到原点,就可以通过坐标来确定该向量。
每当我们根据坐标来确定一个向量时,其对应的坐标总是相对于某一参考系而言的。
标量和向量都可以用坐标 (x, y, z) 来表示。但它们的意义截然不同:点仅表示位置,而向量表示大小与方向。
0x03 向量的基本运算
设有向量 \(u = (u_x, u_y, y_z)\) 和 \(v = (v_x, v_y, v_z)\):
- 两个向量相等,当且仅当它们对应的分量分别相等。
- 向量加法:\(u + v = (u_x + v_x, u_y + v_y, u_z + v_z)\)。
- 标量乘法 ( scalar multiplication ),设 k 是一个标量,则 \(ku = (ku_x, ku_y, ku_z)\)。
- 向量减法:\(u - v = (u_x - v_x, u_y - v_y, u_z - v_z)\)。
- \((0, 0, 0)\) 称为零向量 (zero-vector),可简记为 0。
0x04 向量的长度和单位向量
向量的大小(即模)的几何意义是对应有向线段的擦汗高难度,用双竖线表示(如 \(||u||\))。
代数计算方法:\(\|u\| = \sqrt{x^2 + y^2 + z^2}\)
规范化 (normalizing) :
将向量的长度变为单位长度,将向量的每个分量分别除以该向量的模:\(\hat{u} = \frac{u}{\|u\|} = (\frac{x}{\|u\|},\frac{y}{\|u\|}\frac{z}{\|u\|})\)。
规范化又称标准化、归一化、正常化、规格化、正态化、单位化……不必拘泥于名词译法。
0x05 点积
点积 ( dot product ,也称为数量积或内积 ) 是一种计算结果为标量值的向量乘法运算,因此也称标量积 ( scalar product )。设 \(u = (u_x, u_y, y_z)\) 和 \(v = (v_x, v_y, v_z)\),则点积的定义为:\(u \cdot v = u_xv_x + u_yv_y + u_zv_z\)
点积的几何意义是:\(u \cdot v = \|u\| \|v\| \cos{\theta}\)
点积的一些几何性质:
- \(u \cdot v = 0\),那么 \(u \perp v\) (即两个向量正交)。
- \(u \cdot v \gt 0\),那么两向量之间的夹角 θ 小于 90°(即两向量间的夹角为一锐角)。
- \(u \cdot v \lt 0\),那么两向量之间的夹角 θ 大于 90°(即两向量间的夹角为一钝角)。
正交 (orthogonal)与垂直(perendicular)为同义词。
0x06 正交
给出向量 v 和单位向量 n,用点积公式求出 p。

因为 n 是单位向量,所以:\(p = (\|v\| \cos{\theta}) n = (v \cdot n)n\)。我们称 p 为向量 v 落在向量 n 上的正交投影(orhogonal projection),通常将它表示为:\(p = proj_n(v)\)。
如果 n 不具有单位长度,就先对它进行规划法处理,使之成为单位向量。可以得到更一般的投影公式:\(p = proj_n(v) = (v \cdot \frac{n}{\|n\|}) \frac{n}{\|n\|} = \frac{(v \cdot n)}{\|n\|^2}n\)。
如果向量集合中每个向量都是相互正交且皆具单位长度,我们就称此集合是规范正交(orhonormal)的。
有一种常见的工作,将非规范正交集正交化。
1.2D 正交化处理
假设有一个向量集合 \(\{v_0, v_1\}\),现在要将它正交化为 \(\{w_0, w_1\}\)。首先设 \(w_0=v_0\),通过使 \(v_1\) 减去它在 \(w_0\) 上的分量来令它正交于 \(w_0\):\(w_1 = v_1 - proj_{w_0}(v_1)\)。
此时我们就得到一个元素相互正交的向量集合 \(\{w_0, w_1\}\);最后将其中的元素规范化为单位向量即可。
2.3D 正交化处理
与 2D 的处理方式类似,只不过要多一些步骤。
3.格拉姆-施密特正交化(Gram-Schmidt Orthogonalization)
对于具有 n 个向量的一般集合 \(\{ v_0, ..., v_{n-1}\}\) 来说,基本步骤:
设 \(w_0 = v_0\),对于 \(1 \le i \le n - 1\),令 \(w_i=v_i - \sum_{j=0}^{i-1}proj_{w_j}(v_i)\)。
规范化步骤:令 \(w_i=\frac{w_i}{\|w_i\|}\)
将给定集合内的向量 \(v_i\) 添加到规范正交集中时,需要令 \(v_i\) 减去它在现有规范正交集中的其他向量方向上的分量,这样可以确保新加入规范正交集的向量与该集合中的其他向量相互正交。
0x07 叉积
假设 3D 向量 u 与 v 的叉积为 w,则 w 与向量 u、v 彼此正交。
\(w = u \times v = (u_yv_z - u_zv_y, u_zv_x - u_xv_z, u_xv_y - u_yv_x)\)
通过叉积来进行正交化
流程如下:
- 令 \(w_0 = \frac{v_0}{\|v_0\|}\)。
- 令 \(w_2 = \frac{w_0 \times v_1}{\|w_0 \times v_1\|}\)。
- 令 \(w_1 = w_2 \times w_0\)。
此时,向量集 \(\{ w_0, w_1, w_2 \}\) 是规范正交的。
DX12龙书 01 - 向量在几何学和数学中的表示以及运算定义的更多相关文章
- DX12龙书第6章习题
1. { { , DXGI_FORMAT_R32G32B32_FLOAT, , , D3D12_INPUT_CLASSIFICATION_PER_VERTEX_DATA, }, { , DXGI_FO ...
- DX12龙书 02 - DirectXMath 库中与向量有关的类和函数
0x00 需要用到的头文件 #include <DirectXMath> #include <DirectXPackedVector.h> using namespace Di ...
- DX12龙书 00 - 环境配置:通过 Visual Studio 2019 运行示例项目
0x00 安装 Visual Studio 2019 安装 Visual Studio 2019 以及相关组件. 注:安装组件时带的 Windows 10 SDK 可以在 Individual com ...
- 正则表达式引擎的构建——基于编译原理DFA(龙书第三章)——3 计算4个函数
整个引擎代码在github上,地址为:https://github.com/sun2043430/RegularExpression_Engine.git nullable, firstpos, la ...
- [HLSL]HLSL 入门参考 (dx11龙书附录B译文)
原文:[HLSL]HLSL 入门参考 (dx11龙书附录B译文) HLSL 高级着色语言 参考文档 龙书DirectX12现已推出中文版,其附录B的高级着色器语言参考的翻译质量比本文更高,有条件的读者 ...
- 龙书(Dragon book) +鲸书(Whale book)+虎书(Tiger book)
1.龙书(Dragon book)书名是Compilers: Principles,Techniques,and Tools作者是:Alfred V.Aho,Ravi Sethi,Jeffrey D. ...
- 编译原理 #03# 龙书中缀转后缀JS实现版
// 来自龙书第2章2.5小节-简单表达式的翻译器 笔记 既然是语法制导翻译(Syntax-directed translation),那么最重要的东西当然是描述该语言语法的文法,以下为中缀表达式文法 ...
- Directx11学习笔记【八】 龙书D3DApp的实现
原文:Directx11学习笔记[八] 龙书D3DApp的实现 directx11龙书中的初始化程序D3DApp跟我们上次写的初始化程序大体一致,只是包含了计时器的内容,而且使用了深度模板缓冲. D3 ...
- 线性代数的本质与几何意义 01. 向量是什么?(3blue1brown 咪博士 图文注解版)
向量是线性代数最基础.最基本的概念之一,要深入理解线性代数的本质,首先就要搞清楚向量到底是什么? 向量之所以让人迷糊,是因为我们在物理.数学,以及计算机等许多地方都见过它,但又没有彻底弄懂,以至于似是 ...
随机推荐
- [BUUOJ记录] [BJDCTF 2nd]文件探测
感觉算是这次比赛里面综合性很强的一道题了,主要考察SSRF.PHP伪协议包含.挖掘逻辑漏洞和一个小tirck.委屈的是第一天晚上就做到了最后一步,想到了SESSION置空即可绕过,但是最后读Flag姿 ...
- JVM—01
目录 1.1 JVM系统架构图 2.1 类加载器 2.1.1 双亲委派机制 2.1.2 沙箱安全机制 3.1 Native 4.1 PC寄存器 1.1 JVM系统架构图 JVM是什么? JVM是Jav ...
- latex tips
latex tips latex 插入图片 主要是插入图片位置的问题,代码中的 bb= 决定了插入 fig2.eps 图片的某一方形区域,其中 表示该方形区域的左下角像素坐标是 0 0 ...
- 2020云栖大会智慧出行专场:聚焦高精地图/算法、智能模型、自动驾驶、AR导航
2020云栖大会将于9月17日-18日在线举行,届时将通过官网为全球科技人带来前沿科技.技术产品.产业应用等领域的系列重要分享. 阿里巴巴高德地图携手合作伙伴精心筹备了“智慧出行”专场.我们将为大 ...
- element封装表格
<template> <div> <el-scrollbar class="table-wrap"> <el-table v-loadin ...
- 将虚拟机IP与主机IP设置在同一网段的方法
一.查看主机的网卡名称.IP地址.子网掩码 二.设置VMware Workstation软件 打开虚拟网络编辑器 弹出对话框,选择"更改设置"按钮. 进入虚拟网络编辑器 单选项选择 ...
- Netty之旅三:Netty服务端启动源码分析,一梭子带走!
Netty服务端启动流程源码分析 前记 哈喽,自从上篇<Netty之旅二:口口相传的高性能Netty到底是什么?>后,迟迟两周才开启今天的Netty源码系列.源码分析的第一篇文章,下一篇我 ...
- [LeetCode] 207. 课程表(拓扑排序,BFS)
题目 现在你总共有 n 门课需要选,记为 0 到 n-1. 在选修某些课程之前需要一些先修课程. 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1] 给定课程总量 ...
- H5C3综合案例
案例:实现步骤 1. 搭建HTML结构 <section> <div></div> <div></div> <div></ ...
- 用H5自带拖拽做出购物车效果的作业题
效果描述: 图片代表物品,图片在有宽高的div上方显示,把图片拖放到设置好的div里面,并且在div里面显示图片的信息:价格,物品名,数量.如果拖放有重复,只是在div里面让物品的数量加1,最后计算出 ...