计算机图形学中的曲线问题——拉格朗日插值曲线绘制实践

这篇具有很好参考价值的文章主要介绍了计算机图形学中的曲线问题——拉格朗日插值曲线绘制实践。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

拉格朗日插值曲线的绘制

限于篇幅,我们将在这篇文章中介绍拉格朗日插值曲线绘制实践,主文章链接:

GGN_2015
计算机图形学中的曲线问题

在主文章中我们已经介绍了拉格朗日插值函数的绘制方法。给定一个函数必须通过的点的集合,保证任意两点 x x x 指不同,我们就能构造出一条拉格朗日插值函数。但是函数图象作为一种特殊的曲线,有着很多的我们不想要的约束,例如:

  1. 函数曲线上每个 x x x 至多只有一个 y y y 与之对应;
  2. 函数难以描述斜率不存在的位置;

因此,假如我们先要描述一条在平面甚至空间中任意“蜿蜒”的曲线,我们需要使用参数方程的方式。我们可以把平面上的参数方程理解成一个从 R \R R 映射到 R 2 \R^2 R2 的映射,每一个自变量 t t t 对应着参数方程中的一个点对 ( X t , Y t ) (X_t, Y_t) (Xt,Yt)

拉格朗日插值曲线的表示

假设我们希望我们的曲线能够依次通过 P 1 ( x 1 , y 1 ) , P 2 ( x 2 , y 2 ) , ⋯   , P n ( x n , y n ) P_1(x_1, y_1), P_2(x_2, y_2), \cdots, P_n(x_n, y_n) P1(x1,y1),P2(x2,y2),,Pn(xn,yn),那么我们不妨定义一个这样的参数方程:
M ( t ) = P 1 ⋅ f 1 ( t ) + P 2 ⋅ f 2 ( t ) ⋯ + P n ⋅ f n ( t ) , t ∈ [ 1 , n ] (1) M(t)=P_1\cdot f_1(t)+P_2\cdot f_2(t)\cdots +P_n\cdot f_n(t), t\in[1, n] \tag{1} M(t)=P1f1(t)+P2f2(t)+Pnfn(t),t[1,n](1)

其中 f i f_i fi 的是一个在 x = i x=i x=i 处取值为 1 1 1,在 x ∈ { 1 , 2 , ⋯   , n } 且 x ≠ i x\in\{1, 2, \cdots, n\} 且 x\neq i x{1,2,,n}x=i f i ( x ) = 0 f_i(x)=0 fi(x)=0,这种函数的构造方法在主文章中介绍过,在此不再赘述。 ( 1 ) (1) (1) 式中,我们将 P i P_i Pi f i ( t ) f_i(t) fi(t) 依次对应相乘,这里的点 ‘ ⋅ \cdot ’ 表示数乘向量,其中 P i P_i Pi 是二维空间的点坐标,也就是一个二维向量, f i ( t ) ∈ R f_i(t)\in \R fi(t)R 是一个实数。最终我们得到的 M ( t ) ∈ R 2 M(t)\in \R^2 M(t)R2 是一个二维向量,我们把它视为平面中的一个动点,这个动点的轨迹就是我们的插值曲线。

根据我们之前对一般的拉格朗日插值函数的介绍,我们可以得知:
M ( 1 ) = P 1 ⋅ 1 + P 2 ⋅ 0 ⋯ + P n ⋅ 0 = P 1 M ( 2 ) = P 1 ⋅ 0 + P 2 ⋅ 1 ⋯ + P n ⋅ 0 = P 2 ⋮ M ( n ) = P 1 ⋅ 0 + P 2 ⋅ 0 ⋯ + P n ⋅ 1 = P n M(1)=P_1\cdot 1+P_2\cdot 0\cdots +P_n\cdot0=P_1\\ M(2)=P_1\cdot 0+P_2\cdot 1\cdots +P_n\cdot0=P_2\\ \vdots\\ M(n)=P_1\cdot 0+P_2\cdot 0\cdots +P_n\cdot1=P_n\\ M(1)=P11+P20+Pn0=P1M(2)=P10+P21+Pn0=P2M(n)=P10+P20+Pn1=Pn

换言之,当 t t t 1 1 1 变化到 n n n 的过程中参数方程曲线 M ( t ) M(t) M(t) 能够依次通过 P 1 , P 2 , ⋯   , P n P_1, P_2, \cdots, P_n P1,P2,,Pn 中的每一个点。下面给出了一个包含五个结点的拉格朗日插值函数的示例:

如何画出拉格朗日插值函数,数学,计算机图形学,算法导论,线性代数,算法,计算机图形学
我们会看到,上图中红色的曲线确实忠实地穿过了 P 1 , P 2 , ⋯   , P 5 P_1, P_2, \cdots, P_5 P1,P2,,P5 这五个控制点,但是当我们改变其中一个点的坐标时,整条曲线都扭得很厉害,而这也正是插值曲线不适合做工业设计的原因。在大多数时刻我们都不仅需要曲线经过一些指定的定点,还希望曲线能在控制点变化时尽可能保持一个较为稳定的形态,否则我们将很难实现对曲线形状的自由控制。

但拉格朗日插值曲线也有它的优势,一方面他是插值曲线,能够通过指定的所有控制点,而拟合曲线只能近似通过某些控制点。另一方面就是拉格朗日插值曲线无穷阶可导连续,而这一点是一般的分段函数很难实现的。文章来源地址https://www.toymoban.com/news/detail-627980.html

到了这里,关于计算机图形学中的曲线问题——拉格朗日插值曲线绘制实践的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【计算机图形学】【实验报告】太阳系绘制、B样条曲线绘制(附代码)

    实 验 报 告 一、实验目的 掌握三维图形的显示原理和方法,掌握三维观察的原理和方法; 掌握OpenGL中矩阵堆栈函数的使用,会使用堆栈函数进行复杂场景的组装。 掌握OpenGL中三维观察变换常用的函数的使用方法,了解三维模型的贴图方法; 掌握自由曲线的生成方法,熟练

    2024年02月10日
    浏览(31)
  • 【计算机图形学】【代码复现】A-SDF中的数据集制作与数据生成

    Follow A-SDF 的 Data Generation 部分: We follow (1) ANSCH to create URDF for shape2motion dataset (1-2) URDF2OBJ(本人认为是1-2之间需要进行的重要的过渡部分) (2) Manifold to create watertight meshes (3) and modified mesh_to_sdf for generating sampled points and sdf values. follow这个github: ANSCH 在 global_info.py 中,主要修改

    2024年02月08日
    浏览(45)
  • 【计算机图形学】二维图形裁剪算法

    Cohen-Sutherland算法 Cohen-Sutherland是最早最流行的算法。 核心思想:通过 编码测试 来减少计算交点的次数。(编码算法) 1. 区域码: 线段端点以区域赋值以四位二进制码。 编码顺序:四位从右到左分别为:左边界、右边界、下边界、上边界。 编码值:落在相应位置为1,否则

    2024年02月02日
    浏览(38)
  • 初识计算机图形学

    笔记来源:【老奇】阴差阳错 撼动世界的游戏引擎 详见本人博客: 1.Transformation 2.梳理从MVP变换到光栅化的过程 MVP变换将空间中3D物体投影到2D屏幕 详见本人博客: 1.Rasterization(光栅化) 2.梳理从MVP变换到光栅化的过程 场景是一个个由三角面组成的模型 将模型投射到像素就

    2024年01月21日
    浏览(39)
  • 计算机图形学——大作业

    绘制一个简单的三维场景,可以是室内:卧室,办公室,教室,也可以是室外:运动场,公园等,加上光照效果,简单的纹理映射,透视投影;不能过于简单;可以加动画、鼠标和键盘交互。     上交材料: project和word文档(具体内容展示,思路和心得) 首先初始化窗口,

    2024年02月11日
    浏览(37)
  • 计算机图形与图像技术

    可以使用Python、Java等语言。 下图中,图中各事物比例失调 如何使用代码去掉某个人(不允许使用抠图工具)?         像素(Pixel)是“图像元素”的缩写, 指的是图像的最小单位 。 它是构成数码图像或屏幕显示图像的基本单元,代表了图像中的一个小点或一个小方块

    2024年02月07日
    浏览(39)
  • 计算机图形学 | 变换与观察

    华中科技大学《计算机图形学》课程 MOOC地址:计算机图形学(HUST) 回顾几何阶段 整体流程: 这其中存在3种变换: 坐标系的变换 模型本身的运动 观察者的运动 几何变换 以上各种变换都可以通过以下变换的复合来计算: 平移 比例 旋转 对称 错切 图形的几何变换是指对图

    2023年04月27日
    浏览(35)
  • 【计算机图形学01】坐标变换

             将坐标变换为标准化设备坐标,接着再转化为屏幕坐标的过程通常是分步进行的,也就是类似于流水线那样子。在流水线中,物体的顶点在最终转化为屏幕坐标之前还会被变换到多个坐标系统(Coordinate System)。将物体的坐标变换到几个 过渡 坐标系(Intermediate Coor

    2024年02月10日
    浏览(31)
  • 计算机图形学(三) -- 3D 变换

    同样引入齐次坐标: 3D 点 = ( x , y , z , 1 ) T (x, y, z, 1)^T ( x , y , z , 1 ) T 3D 向量 = ( x , y , z , 0 ) T (x, y, z, 0)^T ( x , y , z , 0 ) T 通常, ( x , y , z , w ) (x, y, z, w) ( x , y , z , w ) (w != 0) 表示一个坐标为 ( x / w , y / w , z / w ) (x/w, y/w, z/w) ( x / w , y / w , z / w ) 的 3D 点 用一个 4x4 的矩阵来表示

    2024年02月08日
    浏览(28)
  • 计算机图形学 期末复习笔记

    目录 第一章-导论 1. 计算机图形学的定义 2. 计算机图形学的应用领域 2.1 计算机图形学与其他学科的关系 3. 图形显示器的发展及其工作原理 3.1 阴极射线管(CRT) 3.2 随机扫描显示器 3.3 直视存储管显示器 3.4 光栅扫描显示器 4. 图形软件标准的形成 5. 三维图形渲染管线 第二章

    2024年02月12日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包