B样条曲线曲面

1 B样条曲线

1.1 B样条曲线方程

B样条方法具有表示与设计自由型曲线曲面的强大功能,是形状数学描述的主流方法之一,另外B样条方法是目前工业产品几何定义国际标准——有理B样条方法 (NURBS)的基础。B样条方法兼备了Bezier方法的一切优点,包括几何不变性,仿射不变性等等,同时克服了Bezier方法中由于整体表示带来不 具有局部性质的缺点(移动一个控制顶点将会影响整个曲线)。B样条曲线方程可表示为

其中,di(i=0,1...n)为控制顶点(坐标),Ni,k(i=0,1...n)为k次规范B样条基函数,最高次数是k。基函数是由一个称为节点矢量的非递减参数u的序列Uu0u1≤...≤un+k+1所决定的k次分段多项式。

B样条的基函数通常采用Cox-deBoor递推公式:

(2)

式中 i 为节点序号, k 是基函数的次数,共有n+1个控制顶点。注意区分节点和控制顶点,节点是在节点矢量U中取得,控制顶点则是坐标点,决定B样条的控制多边形。Cox-deBoor递推公式是B样条曲线的定义的核心,该公式在程序中的实现可采用递归的方式:

##Cox-deBoor 公式

所给程序可用于计算基函数Ni,k(u)的值,程序中对不同类型的B样条曲线区别在于节点矢量 NodeVector 的取值不同。

1.2 B样条曲线的分类

根据节点矢量中节点的分布情况不同,可以划分4中类型的B样条曲线。不同类型的B样条曲线区别主要在于节点矢量,对于具有n+1个控制顶点

1 B样条曲线

1.1 B样条曲线方程

B样条方法具有表示与设计自由型曲线曲面的强大功能,是形状数学描述的主流方法之一,另外B样条方法是目前工业产品几何定义国际标准——有理B样条方法 (NURBS)的基础。B样条方法兼备了Bezier方法的一切优点,包括几何不变性,仿射不变性等等,同时克服了Bezier方法中由于整体表示带来不 具有局部性质的缺点(移动一个控制顶点将会影响整个曲线)。B样条曲线方程可表示为

其中,di(i=0,1...n)为控制顶点(坐标),Ni,k(i=0,1...n)为k次规范B样条基函数,最高次数是k。基函数是由一个称为节点矢量的非递减参数u的序列Uu0u1≤...≤un+k+1所决定的k次分段多项式。

B样条的基函数通常采用Cox-deBoor递推公式:

    (2)

式中 i 为节点序号, k 是基函数的次数,共有n+1个控制顶点。注意区分节点和控制顶点,节点是在节点矢量U中取得,控制顶点则是坐标点,决定B样条的控制多边形。Cox-deBoor递推公式是B样条曲线的定义的核心,该公式在程序中的实现可采用递归的方式:

##Cox-deBoor 公式

所给程序可用于计算基函数Ni,k(u)的值,程序中对不同类型的B样条曲线区别在于节点矢量 NodeVector 的取值不同。

1.2 B样条曲线的分类

根据节点矢量中节点的分布情况不同,可以划分4中类型的B样条曲线。不同类型的B样条曲线区别主要在于节点矢量,对于具有n+1个控制顶点的 k 次B样条曲线,无论是哪种类型都具有n+k+2个节点

均匀B样条曲线

节点矢量中节点为沿参数轴均匀或等距分布。

对应的节点矢量:

准均匀B样条曲线

其节点矢量中两端节点具有重复度k+1,即u0=u1=...=uk,un+1=un+2=...=un+k+1,所有的内节点均匀分布,具有重复度1。

对应的节点矢量:

分段Bezier曲线

其节点矢量中两端节点的重复度与类型2相同,为k+1。不同的是内节点重复度为k。该类型有限制条件,控制顶点数减1必须等于次数的正整数倍,即必须满足  正整数。

对应的节点矢量:

一般非均匀B样条曲线

对任意分布的节点矢量,只要在数学上成立都可选取。

这里给出准均匀B样条和分段Bezier曲线的生成节点矢量的代码,均匀B样条的很简单就不列出了。假设共n+1个控制顶点,k次B样条,输入参数为 n, k ,输出节点矢量到NodeVector中。

!!! 代码

1.3 B样条曲线的计算

根据B样条曲线的定义公式(1),曲线上任一点坐标值是参数变量u的函数,用矩阵形式表示

     (3)

可以看出只要已知控制顶点坐标、曲线的次数 以及基函数,就完全确定了B样条曲线,其中基函数由Cox-deBoor 公式(2)递推计算。

2 B样条曲面

2.1 B样条曲面方程

确定一张次张量积B样条曲面需要三个信息:

ü  给定个控制顶点构成控制网格

ü  给定参数的次数

ü  u向和v向的节点矢量

定义的次张量积B样条曲面其方程为:

,B样条基分别由节点矢量按Cox-deBoor递推公式(2)计算。

B样条曲面按照沿参数方向u, v所取的节点矢量不同,也可以划分成不同的类型:均匀、准均匀、分片Bezier和非均匀B样条曲面。

2.2 B样条曲面的计算

给定曲面的控制顶点并确定次数后,还需要根据不同类型的B样条曲面沿参数方向的节点矢量才能完全定义一张B样条曲面。

要计算B样条曲面上的顶点坐标,首先沿一个参数方向如u向或v向,计算出该方向由控制顶点确定的B样条曲线,如下图中的红色曲线是沿u向生成的二次均匀B样条曲线,一共有四条。

之后将沿u向计算得到的B样条曲线上的点作为新的控制顶点,得到张量网格沿v向计算,得到的曲线就是B样条曲面上的,下图中绿色线段组成的就是沿v向的控制的顶点,蓝颜色的曲线是沿v向的二次均匀B样条曲线构成了一张二次均匀B样条曲面。

的 k 次B样条曲线,无论是哪种类型都具有n+k+2个节点

均匀B样条曲线

节点矢量中节点为沿参数轴均匀或等距分布。

对应的节点矢量:

准均匀B样条曲线

其节点矢量中两端节点具有重复度k+1,即u0=u1=...=uk,un+1=un+2=...=un+k+1,所有的内节点均匀分布,具有重复度1。

对应的节点矢量:

分段Bezier曲线

其节点矢量中两端节点的重复度与类型2相同,为k+1。不同的是内节点重复度为k。该类型有限制条件,控制顶点数减1必须等于次数的正整数倍,即必须满足 正整数。

对应的节点矢量:

一般非均匀B样条曲线

对任意分布的节点矢量,只要在数学上成立都可选取。

这里给出准均匀B样条和分段Bezier曲线的生成节点矢量的代码,均匀B样条的很简单就不列出了。假设共n+1个控制顶点,k次B样条,输入参数为 n, k ,输出节点矢量到NodeVector中。

!!! 代码

1.3 B样条曲线的计算

根据B样条曲线的定义公式(1),曲线上任一点坐标值是参数变量u的函数,用矩阵形式表示

(3)

可以看出只要已知控制顶点坐标、曲线的次数 以及基函数,就完全确定了B样条曲线,其中基函数由Cox-deBoor 公式(2)递推计算。

2 B样条曲面

2.1 B样条曲面方程

确定一张次张量积B样条曲面需要三个信息:

ü 给定个控制顶点构成控制网格

ü 给定参数的次数

ü u向和v向的节点矢量

定义的次张量积B样条曲面其方程为:

,B样条基分别由节点矢量按Cox-deBoor递推公式(2)计算。

B样条曲面按照沿参数方向u, v所取的节点矢量不同,也可以划分成不同的类型:均匀、准均匀、分片Bezier和非均匀B样条曲面。

2.2 B样条曲面的计算

给定曲面的控制顶点并确定次数后,还需要根据不同类型的B样条曲面沿参数方向的节点矢量才能完全定义一张B样条曲面。

要计算B样条曲面上的顶点坐标,首先沿一个参数方向如u向或v向,计算出该方向由控制顶点确定的B样条曲线,如下图中的红色曲线是沿u向生成的二次均匀B样条曲线,一共有四条。

之后将沿u向计算得到的B样条曲线上的点作为新的控制顶点,得到张量网格沿v向计算,得到的曲线就是B样条曲面上的,下图中绿色线段组成的就是沿v向的控制的顶点,蓝颜色的曲线是沿v向的二次均匀B样条曲线构成了一张二次均匀B样条曲面。

时间: 2024-12-14 18:43:43

B样条曲线曲面的相关文章

Atitit.计算机图形图像图片处理原理与概论attilax总结

计算机图形1 图像处理.分析与机器视觉(第3版)1 数字图像处理(第六版)2 图像处理基础(第2版)2 发展沿革 1963年,伊凡·苏泽兰(Ivan Sutherland)在麻省理工学院发表了名为<画板>的博士论文, 它标志着计算机图形学的正式诞生.至今已有五十多年的历史.此前的计算机主要是符号处理系统,自从有了计算机图形学,计算机可以部分地表现人的右脑功能了,所以计算机图形学的建立具有重要的意义.计算机图形学在如下几方面有了长足的进展 第二章 颜色模型.图像基本知识.Phong光照模型 2.

计算机图形学

计算机图形学学习网站: 清华大学计算机图形学课程 第一章 图形学简介 1.1 计算机图形学的研究内容1.2 发展的历史回顾1.3 应用及研究前沿1.4 图形设备 2学时 第二章 颜色模型.图像基本知识.Phong光照模型 2.1 颜色模型    2.1.1 颜色模型的视觉基础    2.1.2 RGB颜色模型    2.1.3 HSV颜色模型    2.1.4 其它颜色模型2.2 图像基本知识2.3 Phong光照模型 2学时 第三章 视图模型变换 3.1 视图模型变换和视点的意义3.2 视图变

名校计算机科学与技术专业培养方案

PS:清华大学计算机科学与技术专业本科生培养方案 计算机科学与技术(0812) 一.研究方向 1.通信软件工程 2.网络技术与应用 3.分布计算理论与技术 4.信息安全与多媒体技术 二.课程设置 类别 课程编号 课程名称 学时 学分 学期 学位课 公共必修课 512.8*704 自然辩证法概论 54 2 秋 521.8*300 科学社会主义理论与实践 36 1 春 534.8*445 英语 144 4 秋/春 基础理论课(至少选1门) 813.8*279 近世代数及其应用 54 3 秋 513.

OpenCASCADE BRep vs. OpenNURBS BRep

OpenCASCADE BRep vs. OpenNURBS BRep [email protected] Abstract. BRep short for Boundary Representation. First give the definition of the BRep, then compare the BRep mode between OpenCASCADE and OpenNURBS. There are 3 main representation method: use f

OpenCASCADE入门指南

OpenCASCADE入门指南 [email protected] 一.概述 荀子说“君子性非异也,善假于物也”.当你会用英语,就可以与世界各国的人交流:当你会用编程语言,就可以与计算机交流:当你会用数学语言,就可以精确的描述世界.当你会用OpenCASCADE这个开发包(SDK),就可以在计算机中创造一个三维世界.大学期间,偶然在图书馆翻到一本发黄的书,讲的是用Turbo C2.0 C语言graphics.h头文件来画图的计算机图形学的书,随即对计算机图形学有了兴趣.后来一直在图书馆里面看计算

清华大学计算机研究生课程表

清华大学计算机研究生课程表 计算机系研究生课程介绍 组合数学课程名称:组合数学 课程编号:60240013 课内学时: 48 开课学期: 秋 任课教师:黄连生 [主要内容] 主要介绍组合数学的基本内容,包括基本记数方法.母函数与递推关系.容斥 原理与鸽巢原理.Burnside引理与Polya定理.区组设计与编码的初步概念.线性规划问题的单纯形算法. 数据结构课程名称:数据结构 课程编号:60240023 课内学时: 48 开课学期: 春秋 任课教师:严蔚敏 [主要内容] 线性表.树.图等各种基本

TWaver3D直线、曲线、曲面的绘制

插播一则广告(长期有效) TWaver需要在武汉招JavaScript工程师若干 要求:对前端技术(JavasScript.HTML.CSS),对可视化技术(Canvas.WebGL)有浓厚的兴趣 基础不好的可培养,基础好的可共谋大事 感兴趣的给我发邮件:[email protected] ————————————————————正文的分割线—————————————————————- 今天来说关于绘图的那些事儿. 先说说绘图引擎的种类.目前市面上绘图引擎大致可以分为两类.一类基于HTML技术,

用OpenGL进行曲线、曲面的绘制

实验目的 1)理解Bezier曲线.曲面绘制的基本原理:理解OpenGL中一维.二维插值求值器的用法. 2)掌握OpenGL中曲线.曲面绘图的方法,对比不同参数下的绘图效果差异: 代码1:用四个控制点绘制一条三次Bezier曲线 #include "stdafx.h" #include <stdlib.h> #include <time.h> #include <GL/glut.h> //4个控制点的3D坐标--z坐标全为0 GLfloat ctrl

Tessellation (曲面细分) Displacement Mapping (贴图置换)

DirectX 11 Tessellation (曲面细分)-什么是 Tessellation (曲面细分) ?它为什么能够起到如此重要的作用? 随着最近人们对 DirectX 11 的议论纷纷,你可能已经听说了有关 DirectX 11 最大新特性 Tessellation (曲面细分) 的大量介绍.作为一个概念, Tessellation (曲面细分) 非常直截了当,就是处理一个多边形分成诸多小碎片.但是为什么这样的处理方式能够备受瞩目呢?它是如何帮助提升游戏画质的呢?本文中,我们将分析 T