Mathematics for Computer Graphics
数学在计算机图形学中的应用
Greg Turk, August 1997
“学习计算机图形学需要多少的数学?”这是初学者最经常问的问题。答案取决于你想在计算机图形学领域钻研多深。如果仅仅使用周围唾手可得的图形软件,你不需要知道多少数学知识。如果想学习计算机图形学的入门知识,我建议你读一读下面所写的前两章(代数,三角学和线性代数)。如果想成为一名图形学的研究者,那么对数学的学习将是活到老,学到老。
如果你并不特别喜欢数学,是否仍有在计算机图形学领域工作的机会?是的,计算机图形学的确有一些方面不需要考虑太多的数学问题。你不应该因为数学成绩不好而放弃它。不过,如果学习了更多的数学知识,似乎你将在研究课题上有更多的选择余地。
对于在计算机图形学中哪些数学才是重要的还没有明确的答案。这领域里不同的方面要求掌握不同的数学知识,也许兴趣将会决定了你的方向。以下介绍我认为对于计算机图形学有用的数学。别以为想成为一名图形学的研究者就必须精通各门数学!为了对用于图形学的数学有一个全面的看法,我特地列出了很多方面。但是许多研究者从不需要考虑下面提到的数学。
最后,虽然读了这篇文章后,你应该会对数学在计算机图形学中的应用有所了解,不过这些观点完全是我自己的。也许你应该阅读更多的此类文章,或者至少从其他从事计算机图形学工作的人那里了解不同的学习重点。现在开始切入正题。
代数和三角学
对于计算机图形学的初学者来说,高中的代数和三角学可能是最重要的数学。日复一日,我从简单的方程解出一个或更多的根。我时常还要解决类似求一些几何图形边长的简单三角学问题。代数和三角学是计算机图形学的最基础的知识。
那么高中的几何学怎么样呢?可能让人惊讶,不过在多数计算机图形学里,高中的几何学并不经常被用到。原因是许多学校教的几何学实际上是如何建立数学证明的课程。虽然证明题对提高智力显然是有用的,但对于计算机图形学来说,那些与几何课有关的定理和证明并不常被用到。如果你毕业于数学相关领域(包括计算机图形学),就会发现虽然你在证明定理,不过这对开始学习图形学不是必要的。
如果精通代数和三角学,就可以开始读一本计算机图形学的入门书了。下一个重要的用于计算机图形学的数学——线性代数,多数此类书籍至少包含了一个对线性代数的简要介绍。
Book recommendation:
Computer Graphics: Principles and Practice
James Foley, Andries van Dam, Steven Feiner, John Hughes
Addison-Wesley
[a huge book, but still my favorite]
线性代数
线性代数的思想贯穿于计算机图形学。事实上,只要牵涉到几何数值表示法,就常常抽象出例如x,y,z坐标之类的数值,我们称之为矢量。图形学自始至终离不开矢量和矩阵。用矢量和矩阵来描述旋转,平移,或者缩放是再好不过了。高中和大学都有线性代数的课程。只要想在计算机图形学领域工作,就应该打下坚实的线性代数基础。我刚才提到,许多图形学的书都有关于线性代数的简要介绍——足够教给你图形学的第一门课。
Book recommendation:
Linear Algebra and Its Applications
Gilbert Strang
Academic Press
微积分学
微积分学是高级计算机图形学的重要成分。如果打算研究图形学,我强烈建议你应该对微积分学有初步认识。理由不仅仅是微积分学是一种很有用的工具,还有许多研究员用微积分学的术语来描述他们的问题和解决办法。另外,在许多重要的数学领域,微积分学被作为进一步学习的前提。学习了基本代数之后,微积分学又是一种能为你打开多数计算机图形学与后继的数学学习之门的课程。
微积分学是我介绍的最后一个中学课程,以下提及的科目几乎全部是大学的课程。
微分几何学
微分几何学研究支配光滑曲线,曲面的方程组。如果你要计算出经过某个远离曲面的点并垂直于曲面的矢量(法向矢量)就会用到微分几何学。让一辆汽车以特定速度在曲线上行驶也牵涉到微分几何学。有一种通用的绘制光滑曲面的图形学技术,叫做“凹凸帖图”,这个技术用到了微分几何学。如果要着手于用曲线和曲面来创造形体(在图形学里称之为建模)你至少应该学习微分几何学的基础。
Book recommendation:
Elementary Differential Geometry
Barrett O'Neill
Academic Press
数值方法
几乎任何时候,我们在计算机里用近似值代替精确值来表示和操作数值,所以计算过程总是会有误差。而且对于一个给定的数值问题,常常有多种解决的方法,一些方法会更块,更精确或者对内存的需求更少。数值方法研究的对象包括“计算方法”和“科学计算”等等。这是一个很广阔的领域,而且我将提及的其他几门数学其实是数值方法的一些分支。这些分支包括抽样法理论,矩阵方程组,数值微分方程组和最优化。
Book recommendation:
Numerical Recipes in C: The Art of Scientific Computing
William Press, Saul Teukolsky, William Vetterling and Brian Flannery
Cambridge University Press
[this is a very valuable reference but is not normally used as a textbook]
抽样法理论和信号处理
在计算机图形学里我们反复使用储存在正规二维数组里的数字集合来表示一些对象,例如一张图片或者一个曲面。每当这样做的时候,我们就要用抽样法来表示这些对象。如果要控制这些对象的品质,抽样法理论就变得尤为重要。一个抽样法应用于图形学的常见例子是当物体被绘制在屏幕上时,它的轮廓呈现锯齿状的边缘。这锯齿状的边缘(被认为是“混淆”现象)是非常让人分散注意力的,用抽样法中著名的技术例如回旋,傅立叶变换,空间和频率的函数表示就能把这个现象减少到最小。这些思想在图像和音频处理领域是同样重要的。
Book recommendation:
The Fourier Transform and Its Applications
Ronald N. Bracewell
McGraw Hill
矩阵方程组
计算机图形学的许多问题要用到矩阵方程组的数值解法。一些涉及矩阵的问题包括:找出最好的位置与方向以使对象们互相匹配(一个最小二乘法的例子),创建一个覆盖所给点集的曲面,并使皱折程度最小(薄板样条算法),还有材质模拟,例如水和衣服等。在图形学里矩阵表述相当流行,因此在用于图形学的数学中我对矩阵方程组的评价是很高的。
Book recommendation:
Matrix Computations
Gene Golub and Charles Van Loan
Johns Hopkins University Press
物理学
物理学显然不是数学的分支,它是自成一家的学科。但是在计算机图形学的某些领域,物理学和数学是紧密联系的。在图形学里,牵涉物理学的问题包括光与物体的表面是怎样互相影响的,人与动物的移动方式,水与空气的流动。为了模拟这些自然现象,物理学的知识是必不可少的。这和解微分方程紧密联系,我将会在下一节提到微分方程。
微分方程的数值解法
我相信对于计算机图形学来说,解微分方程的技巧是非常重要的。像我们刚才讨论的,计算机图形学致力于模拟源于真实世界的物理系统。波浪是怎样在水里形成的,一个动物是怎样在地面上行走的,这就是两个模拟物理系统的例子。模拟物理系统的问题经常就是怎样解微分方程的数值解。请注意,微分方程的数值解法与微分方程的符号解法是有很大差异的。符号解法求出没有误差的解,而且时常只用于一些非常简单的方程。有时大学课程里的“微分方程”只教符号解法,不过这并不会对多数计算机图形学的问题
有帮助。
在对物理系统的模拟中,我们把世界细分为许多表示成矢量的小元素。然后这些元素之间的关系就可以用矩阵来描述。虽然要处理的矩阵方程组往往没有很精确的解,但是取而代之的是执行了一系列的计算,这些计算产生一个表示成数列的近似解。这就是微分方程的数值解法。请注意,矩阵方程的解法与微分方程数值解法的关系是很密切的。
最优化
在计算机图形学里,我们常常为了期望的目标寻求一种合适的描述对象或者对象集的方法。例如安排灯的位置使得房间的照明看起来有种特殊的“感觉”,动画里的人物要怎样活动四肢才能实现一个特殊的动作,怎样排版才不会使页面混乱。以上这些例子可以归结为最优化问题。十年前的计算机图形学几乎没有最优化技术的文献,不过最近这个领域越来越重视最优化理论。我认为在计算机图形学里,最优化的重要性将会日益增加。
概率论与统计学
计算机图形学的许多领域都要用到概率论与统计学。当研究员涉及人类学科时,他们当然需要统计学来分析数据。图形学相关领域涉及人类学科,例如虚拟现实和人机交互(HCI)。另外,许多用计算机描绘真实世界的问题牵涉到各种未知事件的概率。
两个例子:一棵成长期的树,它的树枝分杈的概率;虚拟的动物如何决定它的行走路线。最后,一些解高难度方程组的技巧用了随机数来估计他们的解。一个重要的例子:一种称作蒙特卡罗方法的技术经常用于光如何传播的问题。以上仅是部分一些在计算机图形学里使用概率论和统计学的方法。
计算几何学
计算几何学研究如何用计算机高效地表示与操作几何体。典型问题如,碰撞检测,把多边形分解为三角形,找出最靠近某个位置的点,这个学科包括了运算法则,数据结构和数学。图形学的研究员,只要涉足创建形体(建模),就要大量用到计算几何学。
Book recommendations:
Computational Geometry in C
Joseph O'Rourke
Cambridge University Press
[undergraduate text]
Computational Geometry: An Introduction
Franco Preparata and Michael Shamos
Springer-Verlag
[the classic text, somewhat dated]
总结:数学应用和数学理论
对于图形学来说,以上提到的许多数学学科都有个共同点:比起这些数学的理论价值,我们更倾向于发掘它们的应用价值。不要惊讶。图形学的许多问题和物理学者与工程师们研究的问题是紧密联系的,并且物理学者与工程师们使用的数学工具正是图形学研究者们使用的。多数研究纯数学理论的学科从不被用于计算机图形学。不过这不是绝对的。请注意这些特例:分子生物学正利用节理论来研究DNA分子动力学,亚原子物理学用到了抽象群论。也许有一天,纯数学理论也能推动计算机图形学的发展,谁知道呢?
有些看来重要的数学实际上在计算机图形学里不常被用到。可能拓扑学是此类数学中最有意思的。用一句话来形容拓扑学,它研究油炸圈饼与咖啡杯为什么在本质上是相同的。答案是他们都是只有一个洞的曲面。我们来讨论一下拓扑学的思想。虽然曲面是计算机图形学的重要成分,不过微分几何学的课程已经涵盖了多数对图形学有用的拓扑学知识。微分几何学研究曲面的造型,可是拓扑学研究曲面的相邻关系。我觉得拓扑学对于图形学来说几乎没用,这是由于拓扑学关心抽象的事物,而且拓扑学远离了多数图形学的核心——三维欧氏空间的概念。对于图形学来说,拓扑学的形式(符号表示法)是表达思想的简便方法,不过图形学很少用到抽象拓扑学的实际工具。对图形学来说,拓扑学像一个好看的花瓶,不过别指望它能立即带给你回报。
有人曾经这么问我,计算机图形学是否用到了抽象代数(群论,环,等等….)或者数论。我没怎么遇到过。和拓扑学一样,这些学科有很多美好的思想。可是很不幸的,这些思想很少用于计算机图形学。
分享到:
相关推荐
它探讨了为什么我们需要计算机图形学,以及它在现实世界中的各种应用,如游戏开发、电影特效、工程设计和虚拟现实等。此外,还会介绍计算机图形学的基本任务,包括几何建模、渲染、动画以及交互技术。 **第二章 ...
在这些领域中,计算机图形学都扮演着重要的角色,帮助人们更好地设计、模拟和交互。 6. 在计算机图形学中,图形生成技术是指生成图形的技术,包括直线生成、圆形生成、曲线生成等。例如,使用 DDA 算法可以生成斜率...
【图形学】是计算机科学的一个重要分支,主要研究如何在屏幕上生成、操作和显示图像。在计算机图形学中,【填充】是一种常见的技术,用于给图形内部涂色或赋予特定的纹理。它使得我们可以创建出复杂的图形和图像,...
计算机图形学 计算机图形学 计算机图形学
计算机图形学是计算机科学的一个重要分支,主要研究如何利用计算机生成、处理和显示图像。这份压缩包文件包含的是一系列关于计算机图形学的试题及答案,涵盖了从基础理论到实践应用的广泛知识领域。以下是对这些文件...
计算机图形学 计算机图形学是一门研究如何使用数字计算机生成、处理和显示图形的学科,是计算机科学中最为活跃、得到广泛应用的一门分支。计算机图形学的主要研究内容包括图形硬件、图形标准、图形交互技术、光栅...
计算机图形学绘图软件是指利用计算机图形学技术来绘制图形的软件,需要选择合适的开发工具和平台,了解基本图形元素的绘制原理,并掌握CDC类和Bresenham算法的使用方式,并处理鼠标消息以响应用户的鼠标动作。
在面试中,应聘者需要对以上知识点有较为深入的理解,同时也要掌握图形学中的算法和编程技能,这样才能在实际工作中高效地解决问题。例如,如何实现二维图形的基本操作,如何处理和分析科学计算数据以可视化方式呈现...
计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机图形学 直线DDA算法计算机...
此外,掌握图形学的基本问题、概念和算法也是至关重要的,例如扫描转换、裁减、反走样和消影等基本技术,这些都是实现高质量图形显示的基础。 光栅图形学是计算机图形学的一个重要分支,关注如何在像素级别上处理...
每个章节都可能深入探讨一个特定的图形学概念,帮助学生逐步深化对图形学的理解。 4. **计算机图形学.ppt**: 这可能是一个PPT演示文稿,通常用于课堂讲解,包含了图形学的关键概念和示例。PPT可能包含清晰的图表...
接着,“计算机图形学ch2.pdf”可能深入介绍了图形学中的线性代数知识,如向量、矩阵和行列式,这些都是图形渲染和动画的基础。矩阵在图形学中的应用包括坐标变换、光照计算和纹理映射等。 “计算机图形学ch4.pdf”...
学习计算机图形学不仅仅是了解这些概念,还需要掌握相关的算法和技术。例如,直线和圆的绘制算法、图形变换的矩阵表示、不同投影方法的应用、颜色空间转换、图形的裁剪和消隐技术等。这些都是在实际应用中经常用到的...
这些技术都是图形学的基础知识,理解这些技术对于学习图形学是非常重要的。 此外,程序还使用了一些数据结构,例如结构体`struct windows`,该结构体用于存储窗口和按钮的信息。这种数据结构的使用是图形学中非常...
这需要综合运用所学的图形学理论,并通过编程实现。这个过程中,可能会涉及文件的读取、存储,图形数据的组织,以及用户输入的处理等方面。从压缩包的文件名"图形学综合"来看,很可能包含的是学生们完成的综合项目...
计算机图形学是一门涵盖广泛的学科,它涉及到计算机生成和处理图像的各种技术和算法。在计算机图形学中,图形裁剪是一项核心的技术,它用于确定哪些图形元素应该被显示,哪些应该被隐藏,以此来创建出更加精确和有...
总之,“计算机图形学源码MFC实现”是学习和实践计算机图形学的理想资源,无论你是初学者还是有经验的开发者,都能从中受益。通过实际操作和调试代码,你将更好地掌握计算机图形学的精髓,并能够将理论知识应用到...
计算机图形学是一门深入研究如何在计算设备上生成、处理和显示图像的学科。它广泛应用于游戏开发、电影特效、虚拟现实、科学可视化、工程设计等多个领域。在这个"计算机图形学课程设计"项目中,开发者使用Java编程...
计算机图形学是一门涵盖广泛的学科,它涉及到计算机如何创建、处理和显示图像。在这个领域,我们研究算法和技术,用于在二维(2D)和三维(3D)空间中生成、编辑和展示图形数据。计算机图形学的应用无处不在,包括...