2D与3D图形的基本变换

1. 2d transformations

1.1缩放(Scaling)

在这里插入图片描述

其实这个转换非常简单,如图所示就是把x与y进行s倍的缩放,而我们图中的这个矩阵正好满足这一算法。

1.2镜像(Reflection)

在这里插入图片描述

这个镜像变换可以和上面的做类比,简单看一下就行。

1.3错切(Shearing)

在这里插入图片描述

当然这里不得不提两句,这个错切可以这么看,如左图未转换前最左边的一条竖直直线,按照这样的转换思路在右边就变成了一条斜线,其他线段以此类推。

其实可以想象成如左边这条x等于0的竖直线,这上面的一个个点往右边平移了ay个单位,变成了这样一条斜线。

这里提一个有趣的想法:

如果把一条直线看成是由有限的等大小的点组成(在计算机中当然实际当中我们对直线的定义还是无数个点组成的图形),那么经过我们如上线性变换的时候,每个点的坐标发生了变换最后构成了一条斜线(比如说3个点构成了一条直线,现在把这三个点的位置挪动了下,这样点与点之间实际上会有距离间隔,但是实际我们的屏幕看不出这个距离间隔)

让我们在更加形象的来了解一下

我们知道计算机是由一个个像素组成的,如下图所示:

在这里插入图片描述

一条直线的长度等于这一个个正方形小像素的变成之和,而通过我们的图形变换我们改变了这一个个小像素的实际位置(可以把一个小像素看成一个单位坐标),如我们上面转换成的斜线的长度就是这一个个小像素的斜边加起来的值。

1.4旋转(Rotation)

在这里插入图片描述

这里的推导非常简单,通过两个特例点`来将变换的矩阵推导出来,因为过于简单这里就不做过多赘述。(旋转我们默认是按圆点逆时针旋转)

这里留一个问题给大家,你怎么知道你特例点推出来矩阵后,你的图像整体都是如图上的规律变换的?

1.5平移(Translation)

在这里插入图片描述

按照我们上面的例子依葫芦画瓢就可以很轻易的得出如图所示的式子,但是这个式子后面多了一个矩阵,这样的表达式看着不是很简明了,为了处理这样的问题,我们的图形学引入了对向量和点的新的表达形式来解决了这一问题。

在这里插入图片描述

1.6逆变换(Inverse Transform)

在这里插入图片描述

2. 3d transformations

2.1 3d空间中点与向量的表达方式

在这里插入图片描述

2.2 3d空间当中的旋转
绕轴旋转:

在这里插入图片描述

上面的式子分别是一个实际的物体绕着不同轴旋转所对应的线性变换,那么实际应用当中我们是如何处理旋转的呢?

物体实际旋转的处理公式:

在这里插入图片描述

实际我们在处理一个物理旋转时,我们会将其拆分为该物体与各个轴之间的旋转变换,我们把如图上的那三个角称作欧拉角。

罗德里格旋转公式(Rodrigues’ rotation formula)

在这里插入图片描述

解释一下这个公式的一些参数:n为物体绕着旋转的轴(默认起点为原点,默认旋转方向为逆时针),a为旋转角度。

2.3四元数

最基本的定义:i的二次方 = j的二次方 = -1 且 ij = -ji = k (意味着不满足交换律)

q(四元数) = a + bi + cj + dk 且满足 i的平方 = j的平法 = k的平方 = ijk = -1

这里只展示四元数最基本的定义,后面我会出一篇文章详细讲解一下四元数的实际运用。

3.视图变换(ViewingTransformation)

​ 思考我们拍照的过程:我们的现实是3d坐标系,而我们用相机所拍摄到的照片是二维的,那么如何3d坐标系的影像处理成二维照片呢?这就是我们视图变换所做的事情。

在这里插入图片描述

如这副图所示,为了完成我们的变换我们首先得确定相机的位置和确定一个相机的正方向。

当然在我们的实际使用当中我们默认相机固定在原点,y轴为正方向,往-Z轴看。

3.1相机的摆放问题( 摄像机变换(camera tranformation))

在这里插入图片描述

​ 当然我们的相机不可能一直会在原点,就比如如图这样的情况,我们应该如何把相机回归原点呢?(实际上就是把etg坐标系所对应的图像对应到xy-z坐标所对应的图像)

这里可以这么理解:将我们etg坐标系的三个方向进行线性转换变成了xy-z坐标系的三个方向,那么其所对应到的图片经过这样的转换后效果是不变的(不同坐标系与图像的对应关系没有发生变化),这样的过程就好比把计算机从一个随机的位置移动到了原点。

当然我们求etg到对应xy-z这样过程比较困难,不妨先求其逆,也就是xy-z到etg这一线性变换的过程。

在这里插入图片描述

正交矩阵的逆等于其转置矩阵,为什么呢?

这里偷一张大佬的图

在这里插入图片描述

3.2 投影变换(projection tranformation)
3.21正交投影(Orthographic projection)

在这里插入图片描述

按照视觉效果来说正交投影应该是如上图所示的样子,但是实际处理起来太麻烦,因此我们在实际当中采用如下步骤:

在这里插入图片描述

实际上就是先进行了一个平移和一个缩放(缩放成一个边长为2中心在原点的正方形)

3.22透视投影(Perspective projection)

在这里插入图片描述

透视投影这一过程其实分为两个部分如上图所示先进行挤压,然后在进行我们上面所说的正交投影来完成这一过程,需要说明的是透视投影在挤压过程中,整个图像上的各个点z坐标是不变的,只是x和y轴上的坐标在发生变化。

那么究竟如何得到这一挤压矩阵呢?不急我们分成了3个步骤。

步骤1

在这里插入图片描述

首先在上面我们就强调了没个点的z值不会变化,通过观察我们得到了如上图所示的规律,因此我们可以获得我们的第一个特例,在我们获得的这个特里中乘以z,在通过推导可知,我们能够已知的矩阵信息如右边的矩阵图示。

(这里的乘以z其实两边应该都乘以z等式才能成立,这个乘以z的效果隐藏在那个4乘4矩阵里)

步骤2

在这里插入图片描述

​ 当z等于n时,也就是对应最上面那个挤压图最左边小的那个面,这个时候我们同样在右边乘以z(当然我们这边的z这个常数等于常数n)

步骤三

远处最中心的点在挤压过程中没有改变因此有了如图以下推导:
在这里插入图片描述

(tips:中心点的坐标得看坐标系,这里是特意这么设计的)

至此推导结束。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/219977.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【力扣】54. 螺旋矩阵

题解: 这里当然就不能只是通过双循环来解题了,因为会烦死。这道题的关键点在于左右边界的确定,参考官方解题法在这里写出我的解题思路。 首先看图,螺旋且顺时针,所以我们可以先遍历从左至右的,上边界加一…

科技论文中的Assumption、Remark、Property、Lemma、Theorem、Proof含义

一、背景 学控制、数学、自动化专业的学生在阅读论文时,经常会看到Assumption、Remark、Property、Lemma、Theorem、Proof等单词,对于初学者可能不太清楚他们之间的区别,因此这里做一下详细的说明。 以机器人领域的论文为例。 论文题目&…

IO / day03 作业

1. 使用文件IO完成对图像的读写操作 代码 #include<myhead.h>int main(int argc, const char *argv[]) {int fd-1;if((fd open("./bird.bmp", O_RDWR)) -1){perror("fopen error");return -1;}//读取该图片的大小&#xff0c;需要将光标向后偏移…

Game-On论文阅读

异质性是多模态研究中最重要的关注点 文章目录 Abstract1. Introduction2. Related Work2.1 多模态假新闻检测 **以往的研究方法**2.2 GNNs在多模态研究中的地位3. 方法论3.1 视觉和文本特征编码器3.2 共享多模态空间和多模态图构建3.3 图注意层3.4 假新闻检测器4. 实验与结果4…

Linux的IO模型——阻塞IO

当要读数据recvfrom时&#xff0c;其实就需要两个阶段&#xff0c;一是将硬盘数据读到内核缓冲区&#xff0c;二是将内核缓冲区数据拷贝到用户缓冲区。而阻塞IO就是在两个阶段中用户进程都必须阻塞等待。

2024年天津财经大学珠江学院专升本专业课《管理学原理》考试大纲

天津财经大学珠江学院2024年高职升本科专业课考试《管理学原理》考试大纲 一、本大纲系天津财经大学珠江学院2024年高职升本科《管理学原理》课程考试大纲。所列考试范围出自徐碧琳主编的教材《管理学原理&#xff08;第二版&#xff09;》&#xff0c;机械工业出版社&#xff…

一篇吃透大厂面试题,2024找工作一帆风顺。

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

企业持续绿色创新水平数据集(1999-2022年)

参考何郁冰&#xff08;2017&#xff09;的做法&#xff0c;计算持续创新水平。将绿色专利申请的前后期对比来反映创新的持续程度。创新持续性企业在第t&#xff0d;1与t年间的专利申请量之和较第t&#xff0d;2与t&#xff0d;1年间的专利申请量之和的环比增长率&#xff0c;再…

【广州华锐互动】VR沉浸式体验铝厂安全事故让伤害教育更加深刻

随着科技的不断发展&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经逐渐渗透到各个领域&#xff0c;为我们的生活带来了前所未有的便捷和体验。在安全生产领域&#xff0c;VR技术的应用也日益受到重视。 VR公司广州华锐互动就开发了多款VR安全事故体验系统&#xff0c…

python 堆与栈

【一】堆与栈 【 1 】简介 栈&#xff08;stack&#xff09;&#xff0c;有些地方称为堆栈&#xff0c;是一种容器&#xff0c;可存入数据元素、访问元素、删除元素&#xff0c;它的特点在于只能允许在容器的一端&#xff08;称为栈顶端指标&#xff0c;英语&#xff1a;top&a…

基于混沌算法的图像加密解密系统

1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 研究背景与意义&#xff1a; 随着信息技术的迅猛发展&#xff0c;图像的传输和存储已经成为现代社会中不可或缺的一部分。然而&#xff0c;随着互联网的普及和信息的快速传播&am…

什么是CAS, 什么是AQS

文章目录 什么是CAS, 什么是AQSCASAQS 什么是CAS, 什么是AQS CAS AQS AQS 全称是AbstractQueuedSynchronizer&#xff0c; 是juc 下一个核心的抽象类&#xff0c;用于构建各种同步器和锁 比如我们熟悉的 ReentrantLock、ReadWriteLock、CountDownLatch等等是基于AQS. 首先在…

单机无锁线程安全队列-Disruptor

Disruptor 1、基本介绍 说到队列&#xff0c;除了常见的mq中间件&#xff0c;java中也自带线程安全的BlockingQueue&#xff0c;但是BlockingQueue通过在入队和出队时加锁的方式避免并发操作&#xff0c;性能上会大打折扣。 而Disruptor是一个线程安全、低延迟、吞吐量高的队…

波奇学C++:类型转换和IO流

隐式类型转换 int i0; double pi; 强制类型转换 int* pnullptr; int a(int)p; 单参数构造函数支持隐式类型转换 class A { public:A(string a):_a(a){} private:string _a; }; A a("xxxx"); //"xxx" const char* 隐式转换为string 多参数也可以通过{…

深入理解强化学习——马尔可夫决策过程:占用度量-[基础知识]

分类目录&#xff1a;《深入理解强化学习》总目录 文章《深入理解强化学习——马尔可夫决策过程&#xff1a;贝尔曼期望方程-[基础知识]》中提到&#xff0c;不同策略的价值函数是不一样的。这是因为对于同一个马尔可夫决策过程&#xff0c;不同策略会访问到的状态的概率分布是…

园区规划技术要点

&#xff08;一&#xff09;技术点介绍 1.WLAN&#xff1a;无线局域网WLAN&#xff08;Wireless Local Area Network&#xff09;是一种无线计算机网络&#xff0c;使用无线信道代替有线传输介质连接两个或多个设备形成一个局域网LAN&#xff08;Local Area Network&#xff09…

【亲测有效,超详细】收到微信小程序限期完成微信认证通知怎么处理?微信小程序年审认证都需要哪些资料?

背景&#xff1a;近期部分微信小程序管理员最近收到了年审认证通知如下图 微信官方通知 微信小程序认证流程 第一步&#xff1a;登录微信公众平台 网址&#xff1a;微信公众平台 第二步&#xff1a;登录进入后会看到年审通知弹窗&#xff0c;点击去年审 第二步&#xff1a;登…

java中Random随机数使用和生成随机数的多个示例

在 Java 中&#xff0c;我们可以使用 java.util.Random 类生成伪随机数。伪随机数的特性是&#xff0c;虽然它们看起来是随机的&#xff0c;但实际上它们是由一个固定的算法生成的。只要我们提供相同的种子&#xff0c;这个算法就会生成相同的数字序列。 首先&#xff0c;我们…

HarmonyOS开发基础(一)

HarmonyOS开发基础&#xff08;一&#xff09; // &#xff1a;装饰器&#xff1a;用来装饰类结构、方法、变量 Entry // Entry&#xff1a;标记当前组件为入口组件 Component // Component&#xff1a;标记为自定义组件 // struct&#xff1a;自定义组件&#xff0c;可复用的…

winform使用串口通信读取压力传感装置(CFM)的数据

一、简介 目的&#xff1a;获取CFM的 “hi” 报文&#xff0c;解析出如下数据并绘制波形图。 实现&#xff1a;使用c#打开CFM串口&#xff0c;发送 02 00 02 4C 49 0D 请求到串口&#xff0c;CFM就会不断返回不同类型的报文&#xff0c;我解析的是 “hi” 报文&#xff08;至…