




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
引言三维图形在科学研究和工程技术中有着广泛的应用。在CAD中,需要对所设计的作品从不同的角度进行审视。计算机几何造型就是用计算机系统来表示、控制、分析和输出三维形体。所以几何造型是计算机图形学中一个十分重要的应用领域,它是CAD/CAM和CIMS系统的核心技术,也是用来实现计算机辅助设计的基本手段。几何造型的功能:形体输入,即把形体从用户格式转换成计算机内部格式;图形数据的存储和管理;图形控制,如对形体进行平移、缩放、旋转等几何变换;图形修改,如应用集合运算、欧拉运算、有理B样条操作及其交互手段实现对形体局部或整体修改;图形分析,如形体的容差分析,物质特性分析等;图形显示输出,如消隐、光照、颜色的控制等;询问形体的属性及其有关参数引言三维图形在科学研究和工程技术中有着广泛的应用。在CA1形体在计算机形体一般定义为六层拓扑结构,首先介绍在三维空间中基本术语的定义。形体(object)外壳(shell)面(face)环(loop)边(loop)顶点(vertex)曲线和直线方程点的几何坐标形体在计算机形体一般定义为六层拓扑结构,首先介绍在三维空2形体体
由封闭表面围成的有效空间称为体;一个形体Q是R3空间中非空、有界的封闭子集。其边界(记为∂Q)是有限个面的并集,而外壳是形体的最大边界。一个单位立方体可定义为: {(x,y,z)∈R3|0≤x≤1,0≤y≤1,0≤z≤1}
其中一个表面可表示为:
{(1,y,z)∈R3|0≤y≤1,0≤z≤1} 必须注意:并没有规定形体必须是一个连续的封闭集合,目的是用这样的定义来扩大几何造型的域,使得形体可以由不连续的体素,或是仅有某些相交的形体组成。xzy形体体
由封闭表面围成的有效空间称为体;一个形体Q是R33形体面
R3中非空、连续、共面且封闭的子集称为面F,
其边界(记为∂F)是有限条线段的并集,
Pt表示含有F的唯一平面。
面是形体表面的一部分,且具有方向性.FPt形体面
R3中非空、连续、共面且封闭的子集称为面F,
4形体环
由有序、有向边组成的面的封闭边界称为环,环中任意边都不能自交,相邻两条边共享一个端点,环又分为内环和外环。内环是在已知面中的内孔或凸台面边界的环,其边按逆时针方向。外环是已知面的最大外边界的环,其边按顺时针方向,按这种方式定义,在面上沿着边的方向前进,面的内部始终在走向的右侧。形体环
由有序、有向边组成的面的封闭边界称为环,环中任意5形体边
形体内两个相邻面的交界称为边,一条边有且仅有两个相邻面。两个端点确定一条边,这两个端点分别称为该边的起点和终点。假设Q是一个形体,E(Q)是形体边的集合,则在∂Q(形体的边界)中E(Q)满足下属条件的所有线段的集合:边e的两个端点属于V(Q);边e中没有一个内部点属于V(Q)(所有顶点的集合)边e上每个点,都有两个不同的面,即存在两个面fi,fi≤∂Q使得边e∈fi∩fj;形体Q的边框线WF(Q)是由有序对(V(Q),E(Q))所组成。v1v2ef1f2形体边
形体内两个相邻面的交界称为边,一条边有且仅有两个6形体点
边的端点称为点,点不能出现在边的内部,也不能孤立地位于物体内、物体外或面内,顶点又是∂F(面边界)中两条不共线的线段的交点。v1v2ef1f2形体点
边的端点称为点,点不能出现在边的内部,也不能孤立7形体体素
具有有限个参数定义,且简单
的连续封闭的形体称为体素,
如长方体、圆柱体、圆锥、球、环等。半空间
集合{P|F(P)≤0}成为半空间,其中P为R3中的一点,F为一个平面,当F=0时,表示一个平面,这个平面的半空间可以由F(P)=ax+by+cz+d定义的平面加上在平面某一侧的所有点组成。显然一个长方体可以看成是6个平面半空间的交。几何信息
用来表示形体的几何性质和度量关系称为几何信息。拓扑信息
用来表示形体之间的连接关系称为拓扑信息。形体体素
具有有限个参数定义,且简单
的连续封闭的形体称8表示形体的两种模型数据模型完全以数据描述例如用以8个顶点表示的立方体以中心点和半径表示的球以数据文件的形式存在包括----特征表示、空间分割表示、推移表示、边界表示、构造实体几何表示等进一步分为线框模型表面模型实体模型表示形体的两种模型数据模型9线框模型线框模型:将形体表示成一组轮廓线的集合。一般地,画出了形体的棱线与轮廓线就能唯一地表示出来。如图,八个顶点可以定义一个长方体,但还不足以识别它,如果定义了棱线,则无论如何放置长方体都能唯一地表示了。对于多面体由于其轮廓线和棱线通常是一致的,所以多面体的线模型更便于识别,且简单。e12v4v8s3e2e4e6e8e2e7e11e10e9e3e1v2v3v1v7v5v6s2s6s5s1s4线框模型线框模型:将形体表示成e12v4v8s3e2e4e610线框模型优点:简单、处理速度快缺点:1、对于非平面多面体,如圆柱、球等形体,其轮廓线随观察方向的改变而改变,无法用一组固定的轮廓线来表示它们。2、线框模型与形体之间不存在一一对应关系:它仅仅通过给定的轮廓线约束所表示形体的边界面,而在轮廓线之间的地方,形体的表面可以任意变化。3、没有形体的表面信息,不适于真实感显示,由此导致表示的形体可能产生二义性。线框模型优点:简单、处理速度快11表面模型表面模型将形体表示成一组表面的集合如果把线框模型中的棱线包围的部分定义为面,所形成的模型便是表面模型。其数据结构是在线模型的基础上附加一些指针,有序地连接棱线。下图中表面编号表示第几个表面,表面特征表面是平面还是曲面。形体与其表面一一对应,适合于真实感显示4顶点个数1起始指针0表面特征5表面编接指针属性顶点号14232341表面模型表面模型4顶点个数1起始指针0表面特征5表面编号1412表面模型缺点:不能有效的用来表示实体原因:1、表面模型中的所有面未必形成一个封闭的边界2、各个面的侧向没有明确定义,即不知道实体位于面的哪一侧表面模型缺点:13实体模型实体模型用来描述实体,主要用于CAD/CAM包含了描述一个实体所需的较多信息,如几何信息、拓扑信息,可以支持多种运算,如欧拉运算等。实体模型实体模型14表示形体的两种模型过程模型以一个过程和相应的控制参数描述例如用一些控制参数和一个生成规则描述的植物以一个数据文件和一段代码的形式存在包括----粒子系统、L系统、迭代函数系统等表示形体的两种模型过程模型15表示形体的两种模型模型分类表示形体的两种模型模型分类16实体的定义抽象带来的问题计算机中表示的物体是无效的不能够客观存在为什么要求客观存在CAD/CAM的需求什么是客观存在(有效)—实体的定义具有一定的形状具有封闭的边界(表面)内部连通占据有限的空间经过运算后,仍然是有效的物体实体的定义抽象带来的问题17实体的定义将三维物体看做一个点集,它由内点和边界点共同组成。内点:具有完全包含于该点集的充分小的邻域边界点:不具有内点性质的点集实体的定义将三维物体看做一个点集,它由内点和边界点共同组成。18实体的定义
A是一个点集,定义点集的正则运算如下:i:取内点运算c:取闭包运算正则运算riA:A的全体内点组成的集合,称为A的内部ciA为A的内部的闭包的运算,是iA与其边界点的并集。实体的定义19实体的定义正则点集称为A的正则点集称A为正则点集,如果它满足问题:正则点集是实体?实体的定义正则点集20实体的定义-举例说明阴影部分:物体的内部区域黑色部分:边界(a)图取内点->(b)图求闭包->(c)图正则运算:去除与物体维数不一致的悬挂部分或孤立部分。实体的定义-举例说明阴影部分:物体的内部区域21实体的定义实体的定义—可计算的条件正则点集表面是二维流形二维流形其上任意一点存在充分小的领域与圆盘同构(存在连续的一一映射)实体的定义实体的定义—可计算的条件22正则集合运算为什么需要正则集合运算正则集合运算是构造复杂物体的有效方法普通的集合运算会产生无效物体(b):A∩B(c):普通A∩B(d):正则A∩B正则集合运算为什么需要正则集合运算23正则集合运算集合运算(并、交、差)是构造形体的基本方法。正则形体经过集合运算后,可能会产生悬边、悬面等低于三维的形体。Requicha在引入正则形体概念的同时,还定义了正则集合运算的概念。正则集合运算保证集合运算的结果仍是一个正则形体,即丢弃悬边、悬面等。正则集合运算集合运算(并、交、差)是构造形体的基本方法。正则24正则集合运算正则集合运算的定义正则并正则交正则差正则集合运算正则集合运算的定义25
任一实体S可以用它的边界bS和它的内部iS来表示,即
S=bS∪iS
由实体的定义可知,bS是封闭的,它将整个三维空间分成了三个区域:S的内部iS,S的边界bS,S的外部eS。边界bS与实体S是一一对应的。确定了边界,也就唯一确定了一个实体。因此,为了求实体A,B的正则集合运算结果Aop*B,只要求出其边界b(Aop*B)即可。
正则集合运算任一实体S可以用它的边界bS和它的内部iS来表26正则集合运算考察A,B两物体的交所形成拼合体的边界,由于A,B为正则点集,它们均可表示为边界点与体内点的集合,即A=bA∪iA;B=bB∪iBA物体的边界bA可按其位于B物体内、B物体上、B物体外而分别表示为
bA=(bA∩iB)∪(bA∩bB)∪(bA∩eB)
同理,bB=(bB∩iA)∪(bB∩bA)∪(bB∩eA)
A正则集合运算考察A,B两物体的交所形成拼合体的边界,A27正则集合运算其中bA∩bB=bB∩bA是A与B的公共边界,它可以分成两部分:(bA∩bB)同侧、(bA∩bB)异侧(bA∩bB)同侧由这样一些边界构成:A、B位于边界的同侧(bA∩bB)异侧由这样一些边界构成:A、B位于边界的异侧正则集合运算其中bA∩bB=bB∩bA是A与B的28正则集合运算对于A∩*B,由交的定义可知:1)A、B两物体的边界位于对方内部的部分,即bA∩iB和bB∩iA是b(A∩*B)的组成部分。2)A、B两物体的边界位于对方外部的部分,即bA∩eB和bB∩eA不是b(A∩*B)的组成部分。3)对于A、B的重合边界有:(bA∩bB)同侧属于b(A∩*B);(bA∩bB)异侧不属于b(A∩*B)因此:b(A∩*B)=(bA∩iB)∪(bB∩iA)∪(bA∩bB)同侧正则集合运算对于A∩*B,由交的定义可知:29正则集合运算同理:b(A∪*B)=(bA∩eB)∪(bB∩eA)∪(bA∩bB)同侧b(A-*B)=(bA∩eB)∪(bB∩iA)∪(bA∩bB)异侧正则集合运算同理:30一些非正则形体的实例一些非正则形体的实例一些非正则形体的实例一些非正则形体的实例31为了能够处理非正则形体,产生了非正则造型技术。九十年代以来,基于约束的参数化、变量化造型和支持线框、曲面、实体统一表示的非正则形体造型技术已成为几何造型技术的主流。为了能够处理非正则形体,产生了非正则造型技术。32形体表示模型在实体模型的表示中,基本上可以分为分解表示、构造表示和边界表示三大类。1、分解表示将形体按某种规则分解为小的更易于描述的部分,每一小部分又可分为更小的部分,这种分解过程直至每一小部分都能够直接描述为止。形体表示模型在实体模型的表示中,基本上可以分为分解表示、构造33分解表示-空间位置枚举表示形体空间细分为小的均匀的立方体单元。用三维数组C[I][J][K]表示物体,数组中的元素与单位小立方体一一对应当C[I][J][K]=1时,表示对应的小立方体被物体占据当C[I][J][K]=0时,表示对应的小立方体没有被物体占据分解表示-空间位置枚举表示形体空间细分为小的均匀的立方体单元34分解表示-空间位置枚举表示优点简单,可以表示任何物体容易实现物体间的交、并、差集合运算容易计算物体的整体性质,如体积等缺点占用大量的存储空间,如1024*1024*1024=1Gbits物体的边界面没有显式的解析表达式,不适于图形显示对物体进行几何变换困难,如非90度的旋转变换是物体的非精确表示分解表示-空间位置枚举表示优点35分解表示-八叉树表示八叉树表示对空间位置枚举表示的空间分割方法作了改进:均匀分割自适应分割八叉树建立过程八叉树的根节点对应整个物体空间如果它完全被物体占据,将该节点标记为F(Full),算法结束;如果它内部没有物体,将该节点标记为E(Empty),算法结束;如果它被物体部分占据,将该节点标记为P(Partial),并将它分割成8个子立方体,对每一个子立方体进行同样的处理分解表示-八叉树表示八叉树表示八叉树的根节点对应整个物体空间36分解表示-八叉树表示8叉树的表示应用三维形体的分解,它对一个外接立方体的形体进行前后、左右、上下等部分8个小立方体,如果小立方体单元为满或为空,表示该立方体完全在形体中或完全不在形体中,则其停止分解;对部分形体占有的小立方体需进一步分解为8个子立方体,直至所有小立方体单元要么全部满,要么全部空,或已分解到规定的分解精度为止。236720131375具有子孙的节点(P)空节点(E)实节点(F)分解表示-八叉树表示8叉树的表示应用三维形体的分解,它对一个37分解表示-八叉树表示优点可以表示任何物体,且形体表示的数据结构简单简化了形体的集合运算。只需同时遍历参加集合运算的两形体相应的八叉树,无需进行复杂的求交运算。简化了隐藏线(或面)的消除,因为在八叉树表示中,形体上各元素已按空间位置排成了一定的顺序。分析算法适合于并行处理。缺点没有边界信息,不适于图形显示对物体进行几何变换困难是物体的非精确表示占用大量存储。实际上,八叉树表示是以存储空间换取算法的效率分解表示-八叉树表示优点38分解表示-线性八叉树表示线性八叉树:用一可变长度的一维数组来存储一棵八叉树。数组中仅存储八叉树的性质为FULL的终端结点。并用一个八进制数表示该结点在八叉树中的位置。编码方式为:Q1Q2…Qm,其中Q1表示该结点所属的一级父结点的编号(0-7),以此类推。例右图为:{1X,30X,31X,323X,33X}
3
2031
75具有子孙的节点(P)空节点(E)实节点(F)分解表示-线性八叉树表示线性八叉树:用一可变长度的一维数组来39分解表示-单元分解表示单元分解表示对空间位置枚举表示的空间分割方法作了改进:单一体素多种体素三种空间分割方法的比较空间位置枚举表示----同样大小立方体粘合在一起表示物体八叉树表示----不同大小的立方体粘合在一起表示物体单元分解表示----多种体素粘合在一起表示物体分解表示-单元分解表示单元分解表示40分解表示-单元分解表示优点表示简单容易实现几何变换基本体素可以按需选择,表示范围较广可以精确表示物体缺点物体的表示不唯一物体的有效性难以保证分解表示-单元分解表示优点41构造表示扫描表示构造实体几何表示(CSG)特征表示构造表示扫描表示42构造表示-推移表示将物体A沿着轨迹P推移得到物体B,称B为sweep体平移sweep----将一个二维区域沿着一个矢量方向推移构造表示-推移表示将物体A沿着轨迹P推移得到物体B,称B为s43构造表示-推移表示旋转sweep----将一个二维区域绕旋转轴旋转一周构造表示-推移表示旋转sweep----将一个二维区域绕旋转44 三维形体也能在空间通过扫 描变换生成新的形体:如左 图,一个圆柱体按指定方向 在长方体上运动生成新的形 体,这个过程犹如长方体与 运动者的圆柱体不断的作差 运算操作。
有时经过扫描变换所生成的形体可能会出现维数不一致问题。构造表示-推移表示扫描线方向U 三维形体也能在空间通过扫 描变换生成新的形45构造表示-推移表示广义sweep任意物体沿着任意轨迹推移推移过程中物体可以变形构造表示-推移表示广义sweep46构造表示-推移表示优点表示简单、直观适合做图形输入手段缺点作几何变换困难对几何运算不封闭用扫描变换产生的形体可能出现维数不一致的问题。扫描方法不能直接获取形体的边界信息,表示形体的覆盖域非常有限。构造表示-推移表示优点47构造表示-构造实体几何表示(CSG).通过对体素定义运算而得到新的形体的一种表示方法。体素可以是立方体、圆柱、圆锥等,也可以是半空间,其运算为变换或正则集合运算并、交、差。CSG表示可以看成是一棵有序的二叉树。其终端节点或是体素、或是形体变换参数。非终端结点或是正则的集合运算,或是变换(平移和/或旋转)操作,这种运算或变换只对其紧接着的子结点(子形体)起作用。构造表示-构造实体几何表示(CSG).通过对体素定义运算而得48构造表示-构造实体几何表示(CSG)构造表示-构造实体几何表示(CSG)49构造表示-构造实体几何表示(CSG)CSG树是无二义性的,但不是唯一的.CSG表示的优点:数据结构比较简单,数据量比较小,内部数据的管理比较容易;物体的有效性自动得到保证;CSG方法表示的形体的形状,比较容易修改。构造表示-构造实体几何表示(CSG)CSG树是无二义性的,但50构造表示-构造实体几何表示(CSG)CSG表示的缺点:对形体的表示受体素的种类和对体素操作的种类的限制,也就是说,CSG方法表示形体的覆盖域有较大的局限性。对形体的局部操作不易实现,例如,不能对基本体素的交线倒圆角;由于形体的边界几何元素(点、边、面)是隐含地表示在CSG中,故显示与绘制CSG表示的形体需要较长的时间。表示不唯一
构造表示-构造实体几何表示(CSG)CSG表示的缺点:51构造表示-特征表示用一组特征参数表示一组类似的物体特征包括形状特征、材料特征等适用于工业上标准件的表示构造表示-特征表示用一组特征参数表示一组类似的物体52构造表示-特征表示从应用层来定义形体,因而可以较好的表达设计者的意图。从功能上可分为形状、精度、材料和技术特征。特征是面向应用、面向用户的。特征模型的表示仍然要通过传统的几何造型系统来实现。不同的应用领域,具有不同的应用特征。在几何造型系统中,根据特征的参数我们并不能直接得到特征的几何元素信息,而在对特征及在特征之间进行操作时需要这些信息。特征方法表示形体的覆盖域受限于特征的种类。构造表示-特征表示从应用层来定义形体,因而可以较好的表达设计53构造表示的特点构造表示的特点:构造表示通常具有不便于直接获取形体几何元素的信息、覆盖域有限等缺点,但是,便于用户输入形体,在CAD/CAM系统中,通常作为辅助表示方法。构造表示的特点构造表示的特点:54边界表示边界表示(BR表示或BRep表示)按照体-面-环-边-点的层次,详细记录了构成形体的所有几何元素的几何信息及其相互连接的拓扑关系。边界表示的一个重要特点是在该表示法中,描述形体的信息包括几何信息(Geometry)和拓扑信息(Topology)两个方面。拓扑信息描述形体上的顶点、边、面的连接关系,拓扑信息形成物体边界表示的“骨架”。形体的几何信息犹如附着在“骨架”上的肌肉。边界表示边界表示(BR表示或BRep表示)55边界表示边界模型表达形体的基本拓扑实体包括:1.顶点2.边。边有方向,它由起始顶点和终止顶点来界定。边的形状(Curve)由边的几何信息来表示,可以是直线或曲线,曲线边可用一系列控制点或型值点来描述,也可用显式、隐式或参数方程来描述。边界表示边界模型表达形体的基本拓扑实体包括:56边界表示3.环。环(Loop)是有序、有向边(Edge)组成的封闭边界。环有方向、内外之分,外环边通常按逆时针方向排序,内环边通常按顺时针方向排序。4.面。面(Face)由一个外环和若干个内环(可以没有内环)来表示,内环完全在外环之内。若一个面的外法矢向外,称为正向面;反之,称为反向面。边界表示3.环。环(Loop)是有序、有向边(Edge)组57边界表示面的形状可以是平面或曲面。平面可用平面方程来描述,曲面可用控制多边形或型值点来描述,也可用曲面方程(隐式、显式或参数形式)来描述。对于参数曲面,通常在其二维参数域上定义环,这样就可由一些二维的有向边来表示环,集合运算中对面的分割也可在二维参数域上进行。5.体。体(Body)是面的并集。边界表示面的形状可以是平面或曲面。平面可用平面方程来描述,曲58边界表示边界表示模型是一种采用描述形体表面的方法来描述的几何表示模型。一个形体一般可以通过其边界拆成一些有界的“面”或“小片”的子集来表示,而每一个面又可以通过其边界的边和顶点来表示。若面的表示无二义性,则其边界表示模型也无二义性,但通常不一定只有唯一的表示。边界表示边界表示模型是一种采用描述形体表面的方法来描述的几何59边界表示的数据结构边界表示法的数据结构有四种方法:以面为基础、以顶点为基础、以边为基础和翼边结构;以面为基础的数据结构 以面为基础,按照体、面、顶点坐标的树结构层次组织元素数据;如面顶点坐标F1(X1Y1Z1,X2Y2Z2,X3Y3Z3,X4Y4Z4)F2(X1Y1Z1,X2Y2Z2,X6Y6Z6,X5Y5Z5)
…
……..
其中顶点按照外观顺时针顺序;边界表示的数据结构边界表示法的数据结构有四种方法:以面为基础60边界表示的数据结构2.以顶点为基础的数据结构 以顶点/坐标和面/顶点序列两张关系表表示,如:顶点坐标面顶点序列V1X1Y1Z1F1V1V2V3V4…………………..3.以边为基础的数据结构 以边/顶点,顶点/坐标,面/边三张关系表表示;边界表示的数据结构2.以顶点为基础的数据结构61边界表示模型四棱椎边界表示的例子如右,由4个面组成,且这种表示可以看作是含有体、面、边、顶点为节点的有向图四棱椎边界表示也可以基于边界的三角形分解,即把形体的边界拆成一些互不重叠的三角形。v1v2v3v4v5v2v3v4v5e1e2e3f1v1四棱柱面节点边节点顶点坐标f1f2f3….e1e2e3e4….v1v2v3….(x1,y1,z1) 组合
结构 坐标
信息….边界表示模型v1v2v3v4v5v2v3v4v5e1e2e362边界表示的数据结构-翼边数据结构翼边数据结构:在1972年,由美国斯坦福大学Baumgart作为多面体的表示模式提出。它用指针记录了每一边的两个邻面(即左外环和右外环)、两个顶点、两侧各自相邻的两个邻边(即左上边、左下边、右上边和右下边),用这一数据结构表示多面体模型是完备的,但它不能表示带有精确曲面边界的实体。边界表示的数据结构-翼边数据结构翼边数据结构:在1972年,63边界表示的数据结构-翼边数据结构翼边结构由四种结点Solid,Face,edge和Vertex组成的,各结点描述如下:
Solid构成引用的根节点。在任意时刻,会存在几个数据结构引用;为了存取其中的任何一个,需要指向其Solid节点的指针。通过指向三个双向链表的指针,Solid节点给出对该模型的面、边和顶点的访问。所有实体被链接到一个双向链表中,这个表通过指向该表的后继和前趋实体的指针来实现的。具体包括:
边界表示的数据结构-翼边数据结构翼边结构由四种结点Solid64边界表示的数据结构-翼边数据结构SolidID;
指向face的链表指针;指向edge的链表指针;指向vertex的链表指针;
边界表示的数据结构-翼边数据结构SolidID;65边界表示的数据结构-翼边数据结构Face表示多面体的一个小平面,包括:
FaceID;
指向face的链表首元素的指针;指向face的下一元素的指针;
边界表示的数据结构-翼边数据结构Face表示多面体的一个66边界表示的数据结构-翼边数据结构Edge由Edge节点构成,是整个数据结构的核心,每个Edge结点代表一条边,包括:
EdgeID; Edge的起始顶点指针;
Edge的终止顶点指针;
Edge的右邻面的指针;
Edge的左邻面的指针;
Edge的右方向向前邻边指针;
Edge的右方向向后邻边指针;
Edge的左方向向前邻边指针;
Edge的左方向向后邻边指针;
边界表示的数据结构-翼边数据结构Edge由Edge节点构67边界表示的数据结构-翼边数据结构Vertex由vertex节点构成,包括:
VertexID;
顶点坐标(x,y,z);
指向与该vertex相连的第一条边指针; 指向下一个Vertex结点指针;
边界表示的数据结构-翼边数据结构Vertex由verte68边界表示的数据结构-半边数据结构半边数据结构,是在80年代提出的,作为一种多面体的表示方法。在构成多面体的三要素(顶点、边、面)中,半边数据结构以边为核心。一条边表示成拓扑意义上方向相反的两条“半边”,所以称为半边数据结构。其中各节点的数据结构及含义如下:边界表示的数据结构-半边数据结构半边数据结构,是在80年代提69边界表示的数据结构-半边数据结构typedeffloatvector[4];typedefshortID;typedefstructsolidSolid;typedefstructfaceFace;typedefstructloopLoop;typedefstructedgeEdge;typedefstructhalfedgeHalfEdge;typedefstructvertexVertex;边界表示的数据结构-半边数据结构typedeffloat70边界表示的数据结构-半边数据结构多面体structsolid{IDsolidno;//多面体序号
Face*sfaces;//指向多面体的面;
Edge*sedges;//指向多面体的边;
Vertex*sverts;//指向多面体的顶点
Solid*nexts;//指向后一个多面体
Solid*prevs;//指向前一个多面体
};边界表示的数据结构-半边数据结构多面体71边界表示的数据结构-半边数据结构面Structface{IDfaceno;//面序号
Solid*fsolid;//指向该面所属的多面体
Loop*floops;//指向构成该面的环
Vectorfeq;//平面方程
Face*prevf;//指向前一个面;
Face*nextf;//指向后一个面;};边界表示的数据结构-半边数据结构面Structface72边界表示的数据结构-半边数据结构环structloop{HalfEdge*ledge;//指向构成环的半边
Face*lface;//指向该环所属的面
Loop*prevl;//指向前一个环
Loop*nextl;//指向后一个环}
边界表示的数据结构-半边数据结构环structloop73边界表示的数据结构-半边数据结构边structedge{IDedgeno;//边的序号
HalfEdge*he1;//指向左半边
HalfEdge*he2;//指向右半边
Edge*preve;//指向前一条边
Edge*nexte;//指向后一条边}边界表示的数据结构-半边数据结构边structedge74边界表示的数据结构-半边数据结构半边structhalfedge{Edge*edge;//指向半边的父边
Vertex*vtx;//指向半边的起始顶点
Loop*wloop;//指向半边所属的环
HalEdge*prv;//指向前一条半边
HalfEdge*nxt;//指向后一条半边}边界表示的数据结构-半边数据结构半边structhalf75边界表示的数据结构-半边数据结构顶点structvertex{IDvertexno;//顶点序号
HalfEdge*vedge;//指向以该顶点为起点的半边
Vectorvcoord;//顶点坐标
Vertex*nextv;//指向前一个顶点
Vertex*prevv;//指向后一个顶点}边界表示的数据结构-半边数据结构顶点structvert76欧拉运算和正则集合运算在边界表示法中,可以定义一系列运算来构造或修改三维实体,常用的这类运算有:欧拉运算正则集合运算欧拉运算和正则集合运算在边界表示法中,可以定义一系列运算来构77欧拉运算欧拉运算是三维物体边界表示数据结构的生成操作。运用欧拉运算,可以正确、有效构建三维物体边界表示中的所有拓扑元素和拓扑关系。该运算之所以称为欧拉运算,是因为每一种运算所构建的拓扑元素和拓扑关系均要满足欧拉公式。欧拉运算欧拉运算是三维物体边界表示数据结构的生成操作。运用欧78欧拉运算欧拉公式V:顶点数E:棱线数F:面数凡是满足欧拉公式的形体均称为欧拉形体欧拉公式是简单多面体的必要条件。附加条件:每边连接两个顶点每条边只被两个面共享等来保证有效性至少要有三条边交于一个顶点。V-e+f=2欧拉运算欧拉公式V-e+f=279欧拉运算广义欧拉公式(P204)V-e+f-r=2(s-h)V:顶点数,E:棱线数,F:面数r:多面体表面上孔的个数s:相互分离的多面体数h:贯穿多面体的孔洞个数欧拉运算广义欧拉公式(P204)V-e+f-r=2(s-h)80欧拉运算若将广义欧拉公式中的v,e,f,h,r,s分别看作独立的坐标变量,则上式在六维空间中定义了一张平面(平面是五维的),该平面通过原点。由于各坐标变量的取值只能是非负的整数,所以上式实际上对应了一张五维平面上的网格,每个多面体都对应一个网格点。但并不是每个网格都对应一个有效的多面体(只是必要条件)。如果要构造的多面体对应的网格点的坐标是(v,e,f,h,r,s),那么构造该实体的过程就是从原点开始沿网格一步一步向这个坐标点前进的过程。由于网格上的每点都满足欧拉公式,最后的多面体也必然满足它。V-e+f-r=2(s-h)欧拉运算若将广义欧拉公式V-e+f-r=2(s-h)81欧拉运算前进的“走法”是多种多样的,因为只有五个自由变量,所以只需五种基本走法就可以了。要求:每一步至多只能使某一坐标变量增(减)一个单位。每一步行走都有明显的几何意义。欧拉运算是对形体进行增加,删除点、边、面而生成的一个新的欧拉形的处理。最基本的五种欧拉运算是:增加一条边和一个顶点;增加一个面和一条边;增加一条边,一个面和一个顶点;增加一条边和一个顶点;增加一条边,且删除一个孔穴。欧拉运算前进的“走法”是多种多样的,因为只有五个自由变量,所82欧拉运算相应的五种补运算是:删除一条边和一个顶点;删除一个面和一条顶点;删除一个体,一个面和一个顶点;删除一个孔洞和一个体;删除一条边,且增加一个孔穴;任何一种欧拉形体(或欧拉运算)都可以用最基本的欧拉运算的现行组合来表示。用最基本的欧拉运算操作生成的形体必定是一个欧拉形体。欧拉运算相应的五种补运算是:83正则集合运算通过对边界表示的物体做正则集合运算可以构造新的边界表示的物体。对具有平面边界、曲面边界的物体进行集合运算的算法有很多,算法的大致步骤如下:(1)预检查两物体是否相交第一步:计算两个待求交物体的包围盒,若两包围盒不相交,则两物体不相交,正则集合运算结束,否则进行下一层。第二步:计算两物体每一个表面片的包围盒,当某个面片的包围盒与另一物体的包围盒相交时,将该面片与另一物体的所有表面片一一求交,否则该面片与另一物体的所有表面片都无交。同样,只有在用边界盒法无法判断时才进行求交计算,从而避免许多不必要的复杂的求交计算。
正则集合运算通过对边界表示的物体做正则集合运算可以构造新的边84正则集合运算(2)计算两物体各表面之间的交线。由于物体表面均为有界表面,因此物体表面之间的交线是有界的直线或曲线。计算两物体表面之间的交线的一般步骤如下
a.基于两相交表面的方程,建立交线的方程,确定出初始交线。初始交线可能为无界。
b.分别确定初始交线位于两相交表面内部的部分。
c.计算位于两相交表面内部的两相交区段的重叠部分,即为两相交表面之间的真正交线。正则集合运算(2)计算两物体各表面之间的交线。85(3)对物体的表面进行分类两物体之间的交线将它们的表面分割成两部分,其中一部分落在拼合体的表面上,形成新的边界,另一部分位于拼合体内或拼合体外,应在集合运算最后一步予以删除。(4)建立结果物体的边界表示。正则集合运算(3)对物体的表面进行分类正则集合运算86边界表示Brep表示覆盖域大,原则上能表示所有的形体,而且易于支持形体的特征表示等,Brep表示已成为当前CAD/CAM系统的主要表示方法。Brep表示的优点是:表示形体的点、边、面等几何元素是显式表示的,使得绘制Brep表示的形体的速度较快,而且比较容易确定几何元素间的连接关系;容易支持对物体的各种局部操作,比如进行倒角。便于在数据结构上附加各种非几何信息,如精度、表面粗糙度等。边界表示Brep表示覆盖域大,原则上能表示所有的形体,而且易87边界表示Brep表示的缺点是:数据结构复杂,需要大量的存储空间,维护内部数据结构的程序比较复杂;Brep表示不一定对应一个有效形体,通常运用欧拉操作来保证Brep表示形体的有效性、正则性等。边界表示Brep表示的缺点是:88各种表示方法的比较精确性:能否精确的表示实体。特征表示-能够精确表示一个实体。构造实体几何表示-依赖于它所采用的基本体素,如果基本体素足够丰富,则能精确描述较大范围内的实体。边界表示-如果以多面体表示实体,则仅是一种近似表示;若允许曲面边界,则可以精确表示实体。推移表示-与边界表示类似。空间分割表示-近似表示一个实体。各种表示方法的比较精确性:能否精确的表示实体。89各种表示方法的比较表示域:指一种表示法所能表示的实体的范围。表示域越大,表示能力越强。特征表示法、推移表示法:表示能力有限空间分割表示法:可以表示任何实体。边界表示法:理论上说,可以表示所有实体。但若将边界表示法中的边界限制在某个范围之内(如平面多边形),则表示能力降低。实体构造表示法:依赖其基本体素的范围。各种表示方法的比较表示域:指一种表示法所能表示的实体的范围。90各种表示方法的比较唯一性:实体的表示形式唯一。只有空间位置枚举方法和八叉树具有唯一性。各种表示方法的比较唯一性:实体的表示形式唯一。91各种表示方法的比较封闭性:若其表示域内的实体经过某种运算(如正则集合运算,几何变换)后,结果实体仍然落在表示域之内。特征表示:实体之间不能进行集合运算。简单推移表示,单元分解表示:不封闭。空间位置枚举表示,八叉树表示,CSG树表示封闭。边界表示虽然对正则集合运算不封闭,但可以附加约束条件避免。各种表示方法的比较封闭性:若其表示域内的实体经过某种运算(如92各种表示方法的比较有效性:通常,边界表示(包括推移表示)物体的有效性难以检验。特征表示的物体有效性自动得到保证。其它表示方法的有效性验证也比较简单。各种表示方法的比较有效性:93各种表示方法的比较简洁性:空间分割表示:占用空间大特征表示、推移表示、CSG树表示较简洁。边界表示介于其间。各种表示方法的比较简洁性:94各种表示方法的比较输入:特征表示、推移表示、CSG树表示和单元分解表示都是面向用户的,只需输入少量参数,即可生成所需实体。空间位置枚举和八叉树表示很难由用户直接建立,一般都由其它表示形式转化过来。若采用边界表示作为输入手段,则一方面用户能方便的控制实体的形状,另一方面,需输入大量数据,且数据一致性很难保证。各种表示方法的比较输入:95各种表示方法的比较输出:实体造型的输出包括图形、计算机辅助制造系统进行数控加工所需的数据以及实体的性质(重量、体积等)。图形显示和数控加工主要要求实体的边界信息,所以边界表示较好。若需实体性质等方面的计算,则空间分割表示、CSG树表示更好。各种表示方法的比较输出:96模型的考虑模型的考虑
必须考虑以下一些问题:根据形体边界给定的信息,是否能自动的获取形体的几何特征?如何确定对形体操作数据的有效性?形体的表示模型是否唯一?不同的表示模型是否可以转换?是否最佳表示模型?对于几何造型系统来说,按照不同的目的可以采用不同的最佳表示模型。模型的考虑模型的考虑
必须考虑以下一些问题:97不规则形体的建模方法迭代函数系统基于文法的模型粒子系统动力系统不规则形体的建模方法迭代函数系统98L系统由生物学家Lindenmayer创立基本思想:用文法表示植物的拓扑结构通过图形学方法生成逼真的画面DOL系统(确定的上下文无关的L系统)定义为三元组<V,w,P>,其中
V----表示字母集合
V*----表示V上所有单词的集合
w----是一个非空单词,称为公理
P----产生式集合 ,使得 如果没有明显的产生式,则令L系统由生物学家Lindenmayer创立99L系统例子----Koch雪花曲线V:{F,+,-}w:FP:F->F-F++F-F几何解释F:向前画一条线+:右转-:左转
L系统例子----Koch雪花曲线100L系统BracketedL系统增加如下两个字符[:压栈]:出栈例子----植物w:FP:F->F[+F]F[-F]FL系统BracketedL系统101L系统L系统102引言三维图形在科学研究和工程技术中有着广泛的应用。在CAD中,需要对所设计的作品从不同的角度进行审视。计算机几何造型就是用计算机系统来表示、控制、分析和输出三维形体。所以几何造型是计算机图形学中一个十分重要的应用领域,它是CAD/CAM和CIMS系统的核心技术,也是用来实现计算机辅助设计的基本手段。几何造型的功能:形体输入,即把形体从用户格式转换成计算机内部格式;图形数据的存储和管理;图形控制,如对形体进行平移、缩放、旋转等几何变换;图形修改,如应用集合运算、欧拉运算、有理B样条操作及其交互手段实现对形体局部或整体修改;图形分析,如形体的容差分析,物质特性分析等;图形显示输出,如消隐、光照、颜色的控制等;询问形体的属性及其有关参数引言三维图形在科学研究和工程技术中有着广泛的应用。在CA103形体在计算机形体一般定义为六层拓扑结构,首先介绍在三维空间中基本术语的定义。形体(object)外壳(shell)面(face)环(loop)边(loop)顶点(vertex)曲线和直线方程点的几何坐标形体在计算机形体一般定义为六层拓扑结构,首先介绍在三维空104形体体
由封闭表面围成的有效空间称为体;一个形体Q是R3空间中非空、有界的封闭子集。其边界(记为∂Q)是有限个面的并集,而外壳是形体的最大边界。一个单位立方体可定义为: {(x,y,z)∈R3|0≤x≤1,0≤y≤1,0≤z≤1}
其中一个表面可表示为:
{(1,y,z)∈R3|0≤y≤1,0≤z≤1} 必须注意:并没有规定形体必须是一个连续的封闭集合,目的是用这样的定义来扩大几何造型的域,使得形体可以由不连续的体素,或是仅有某些相交的形体组成。xzy形体体
由封闭表面围成的有效空间称为体;一个形体Q是R3105形体面
R3中非空、连续、共面且封闭的子集称为面F,
其边界(记为∂F)是有限条线段的并集,
Pt表示含有F的唯一平面。
面是形体表面的一部分,且具有方向性.FPt形体面
R3中非空、连续、共面且封闭的子集称为面F,
106形体环
由有序、有向边组成的面的封闭边界称为环,环中任意边都不能自交,相邻两条边共享一个端点,环又分为内环和外环。内环是在已知面中的内孔或凸台面边界的环,其边按逆时针方向。外环是已知面的最大外边界的环,其边按顺时针方向,按这种方式定义,在面上沿着边的方向前进,面的内部始终在走向的右侧。形体环
由有序、有向边组成的面的封闭边界称为环,环中任意107形体边
形体内两个相邻面的交界称为边,一条边有且仅有两个相邻面。两个端点确定一条边,这两个端点分别称为该边的起点和终点。假设Q是一个形体,E(Q)是形体边的集合,则在∂Q(形体的边界)中E(Q)满足下属条件的所有线段的集合:边e的两个端点属于V(Q);边e中没有一个内部点属于V(Q)(所有顶点的集合)边e上每个点,都有两个不同的面,即存在两个面fi,fi≤∂Q使得边e∈fi∩fj;形体Q的边框线WF(Q)是由有序对(V(Q),E(Q))所组成。v1v2ef1f2形体边
形体内两个相邻面的交界称为边,一条边有且仅有两个108形体点
边的端点称为点,点不能出现在边的内部,也不能孤立地位于物体内、物体外或面内,顶点又是∂F(面边界)中两条不共线的线段的交点。v1v2ef1f2形体点
边的端点称为点,点不能出现在边的内部,也不能孤立109形体体素
具有有限个参数定义,且简单
的连续封闭的形体称为体素,
如长方体、圆柱体、圆锥、球、环等。半空间
集合{P|F(P)≤0}成为半空间,其中P为R3中的一点,F为一个平面,当F=0时,表示一个平面,这个平面的半空间可以由F(P)=ax+by+cz+d定义的平面加上在平面某一侧的所有点组成。显然一个长方体可以看成是6个平面半空间的交。几何信息
用来表示形体的几何性质和度量关系称为几何信息。拓扑信息
用来表示形体之间的连接关系称为拓扑信息。形体体素
具有有限个参数定义,且简单
的连续封闭的形体称110表示形体的两种模型数据模型完全以数据描述例如用以8个顶点表示的立方体以中心点和半径表示的球以数据文件的形式存在包括----特征表示、空间分割表示、推移表示、边界表示、构造实体几何表示等进一步分为线框模型表面模型实体模型表示形体的两种模型数据模型111线框模型线框模型:将形体表示成一组轮廓线的集合。一般地,画出了形体的棱线与轮廓线就能唯一地表示出来。如图,八个顶点可以定义一个长方体,但还不足以识别它,如果定义了棱线,则无论如何放置长方体都能唯一地表示了。对于多面体由于其轮廓线和棱线通常是一致的,所以多面体的线模型更便于识别,且简单。e12v4v8s3e2e4e6e8e2e7e11e10e9e3e1v2v3v1v7v5v6s2s6s5s1s4线框模型线框模型:将形体表示成e12v4v8s3e2e4e6112线框模型优点:简单、处理速度快缺点:1、对于非平面多面体,如圆柱、球等形体,其轮廓线随观察方向的改变而改变,无法用一组固定的轮廓线来表示它们。2、线框模型与形体之间不存在一一对应关系:它仅仅通过给定的轮廓线约束所表示形体的边界面,而在轮廓线之间的地方,形体的表面可以任意变化。3、没有形体的表面信息,不适于真实感显示,由此导致表示的形体可能产生二义性。线框模型优点:简单、处理速度快113表面模型表面模型将形体表示成一组表面的集合如果把线框模型中的棱线包围的部分定义为面,所形成的模型便是表面模型。其数据结构是在线模型的基础上附加一些指针,有序地连接棱线。下图中表面编号表示第几个表面,表面特征表面是平面还是曲面。形体与其表面一一对应,适合于真实感显示4顶点个数1起始指针0表面特征5表面编接指针属性顶点号14232341表面模型表面模型4顶点个数1起始指针0表面特征5表面编号14114表面模型缺点:不能有效的用来表示实体原因:1、表面模型中的所有面未必形成一个封闭的边界2、各个面的侧向没有明确定义,即不知道实体位于面的哪一侧表面模型缺点:115实体模型实体模型用来描述实体,主要用于CAD/CAM包含了描述一个实体所需的较多信息,如几何信息、拓扑信息,可以支持多种运算,如欧拉运算等。实体模型实体模型116表示形体的两种模型过程模型以一个过程和相应的控制参数描述例如用一些控制参数和一个生成规则描述的植物以一个数据文件和一段代码的形式存在包括----粒子系统、L系统、迭代函数系统等表示形体的两种模型过程模型117表示形体的两种模型模型分类表示形体的两种模型模型分类118实体的定义抽象带来的问题计算机中表示的物体是无效的不能够客观存在为什么要求客观存在CAD/CAM的需求什么是客观存在(有效)—实体的定义具有一定的形状具有封闭的边界(表面)内部连通占据有限的空间经过运算后,仍然是有效的物体实体的定义抽象带来的问题119实体的定义将三维物体看做一个点集,它由内点和边界点共同组成。内点:具有完全包含于该点集的充分小的邻域边界点:不具有内点性质的点集实体的定义将三维物体看做一个点集,它由内点和边界点共同组成。120实体的定义
A是一个点集,定义点集的正则运算如下:i:取内点运算c:取闭包运算正则运算riA:A的全体内点组成的集合,称为A的内部ciA为A的内部的闭包的运算,是iA与其边界点的并集。实体的定义121实体的定义正则点集称为A的正则点集称A为正则点集,如果它满足问题:正则点集是实体?实体的定义正则点集122实体的定义-举例说明阴影部分:物体的内部区域黑色部分:边界(a)图取内点->(b)图求闭包->(c)图正则运算:去除与物体维数不一致的悬挂部分或孤立部分。实体的定义-举例说明阴影部分:物体的内部区域123实体的定义实体的定义—可计算的条件正则点集表面是二维流形二维流形其上任意一点存在充分小的领域与圆盘同构(存在连续的一一映射)实体的定义实体的定义—可计算的条件124正则集合运算为什么需要正则集合运算正则集合运算是构造复杂物体的有效方法普通的集合运算会产生无效物体(b):A∩B(c):普通A∩B(d):正则A∩B正则集合运算为什么需要正则集合运算125正则集合运算集合运算(并、交、差)是构造形体的基本方法。正则形体经过集合运算后,可能会产生悬边、悬面等低于三维的形体。Requicha在引入正则形体概念的同时,还定义了正则集合运算的概念。正则集合运算保证集合运算的结果仍是一个正则形体,即丢弃悬边、悬面等。正则集合运算集合运算(并、交、差)是构造形体的基本方法。正则126正则集合运算正则集合运算的定义正则并正则交正则差正则集合运算正则集合运算的定义127
任一实体S可以用它的边界bS和它的内部iS来表示,即
S=bS∪iS
由实体的定义可知,bS是封闭的,它将整个三维空间分成了三个区域:S的内部iS,S的边界bS,S的外部eS。边界bS与实体S是一一对应的。确定了边界,也就唯一确定了一个实体。因此,为了求实体A,B的正则集合运算结果Aop*B,只要求出其边界b(Aop*B)即可。
正则集合运算任一实体S可以用它的边界bS和它的内部iS来表128正则集合运算考察A,B两物体的交所形成拼合体的边界,由于A,B为正则点集,它们均可表示为边界点与体内点的集合,即A=bA∪iA;B=bB∪iBA物体的边界bA可按其位于B物体内、B物体上、B物体外而分别表示为
bA=(bA∩iB)∪(bA∩bB)∪(bA∩eB)
同理,bB=(bB∩iA)∪(bB∩bA)∪(bB∩eA)
A正则集合运算考察A,B两物体的交所形成拼合体的边界,A129正则集合运算其中bA∩bB=bB∩bA是A与B的公共边界,它可以分成两部分:(bA∩bB)同侧、(bA∩bB)异侧(bA∩bB)同侧由这样一些边界构成:A、B位于边界的同侧(bA∩bB)异侧由这样一些边界构成:A、B位于边界的异侧正则集合运算其中bA∩bB=bB∩bA是A与B的130正则集合运算对于A∩*B,由交的定义可知:1)A、B两物体的边界位于对方内部的部分,即bA∩iB和bB∩iA是b(A∩*B)的组成部分。2)A、B两物体的边界位于对方外部的部分,即bA∩eB和bB∩eA不是b(A∩*B)的组成部分。3)对于A、B的重合边界有:(bA∩bB)同侧属于b(A∩*B);(bA∩bB)异侧不属于b(A∩*B)因此:b(A∩*B)=(bA∩iB)∪(bB∩iA)∪(bA∩bB)同侧正则集合运算对于A∩*B,由交的定义可知:131正则集合运算同理:b(A∪*B)=(bA∩eB)∪(bB∩eA)∪(bA∩bB)同侧b(A-*B)=(bA∩eB)∪(bB∩iA)∪(bA∩bB)异侧正则集合运算同理:132一些非正则形体的实例一些非正则形体的实例一些非正则形体的实例一些非正则形体的实例133为了能够处理非正则形体,产生了非正则造型技术。九十年代以来,基于约束的参数化、变量化造型和支持线框、曲面、实体统一表示的非正则形体造型技术已成为几何造型技术的主流。为了能够处理非正则形体,产生了非正则造型技术。134形体表示模型在实体模型的表示中,基本上可以分为分解表示、构造表示和边界表示三大类。1、分解表示将形体按某种规则分解为小的更易于描述的部分,每一小部分又可分为更小的部分,这种分解过程直至每一小部分都能够直接描述为止。形体表示模型在实体模型的表示中,基本上可以分为分解表示、构造135分解表示-空间位置枚举表示形体空间细分为小的均匀的立方体单元。用三维数组C[I][J][K]表示物体,数组中的元素与单位小立方体一一对应当C[I][J][K]=1时,表示对应的小立方体被物体占据当C[I][J][K]=0时,表示对应的小立方体没有被物体占据分解表示-空间位置枚举表示形体空间细分为小的均匀的立方体单元136分解表示-空间位置枚举表示优点简单,可以表示任何物体容易实现物体间的交、并、差集合运算容易计算物体的整体性质,如体积等缺点占用大量的存储空间,如1024*1024*1024=1Gbits物体的边界面没有显式的解析表达式,不适于图形显示对物体进行几何变换困难,如非90度的旋转变换是物体的非精确表示分解表示-空间位置枚举表示优点137分解表示-八叉树表示八叉树表示对空间位置枚举表示的空间分割方法作了改进:均匀分割自适应分割八叉树建立过程八叉树的根节点对应整个物体空间如果它完全被物体占据,将该节点标记为F(Full),算法结束;如果它内部没有物体,将该节点标记为E(Empty),算法结束;如果它被物体部分占据,将该节点标记为P(Partial),并将它分割成8个子立方体,对每一个子立方体进行同样的处理分解表示-八叉树表示八叉树表示八叉树的根节点对应整个物体空间138分解表示-八叉树表示8叉树的表示应用三维形体的分解,它对一个外接立方体的形体进行前后、左右、上下等部分8个小立方体,如果小立方体单元为满或为空,表示该立方体完全在形体中或完全不在形体中,则其停止分解;对部分形体占有的小立方体需进一步分解为8个子立方体,直至所有小立方体单元要么全部满,要么全部空,或已分解到规定的分解精度为止。236720131375具有子孙的节点(P)空节点(E)实节点(F)分解表示-八叉树表示8叉树的表示应用三维形体的分解,它对一个139分解表示-八叉树表示优点可以表示任何物体,且形体表示的数据结构简单简化了形体的集合运算。只需同时遍历参加集合运算的两形体相应的八叉树,无需进行复杂的求交运算。简化了隐藏线(或面)的消除,因为在八叉树表示中,形体上各元素已按空间位置排成了一定的顺序。分析算法适合于并行处理。缺点没有边界信息,不适于图形显示对物体进行几何变换困难是物体的非精确表示占用大量存储。实际上,八叉树表示是以存储空间换取算法的效率分解表示-八叉树表示优点140分解表示-线性八叉树表示线性八叉树:用一可变长度的一维数组来存储一棵八叉树。数组中仅存储八叉树的性质为FULL的终端结点。并用一个八进制数表示该结点在八叉树中的位置。编码方式为:Q1Q2…Qm,其中Q1表示该结点所属的一级父结点的编号(0-7),以此类推。例右图为:{1X,30X,31X,323X,33X}
3
2031
75具有子孙的节点(P)空节点(E)实节点(F)分解表示-线性八叉树表示线性八叉树:用一可变长度的一维数组来141分解表示-单元分解表示单元分解表示对空间位置枚举表示的空间分割方法作了改进:单一体素多种体素三种空间分割方法的比较空间位置枚举表示----同样大小立方体粘合在一起表示物体八叉树表示----不同大小的立方体粘合在一起表示物体单元分解表示----多种体素粘合在一起表示物体分解表示-单元分解表示单元分解表示142分解表示-单元分解表示优点表示简单容易实现几何变换基本体素可以按需选择,表示范围较广可以精确表示物体缺点物体的表示不唯一物体的有效性难以保证分解表示-单元分解表示优点143构造表示扫描表示构造实体几何表示(CSG)特征表示构造表示扫描表示144构造表示-推移表示将物体A沿着轨迹P推移得到物体B,称B为sweep体平移sweep----将一个二维区域沿着一个矢量方向推移构造表示-推移表示将物体A沿着轨迹P推移得到物体B,称B为s145构造表示-推移表示旋转sweep----将一个二维区域绕旋转轴旋转一周构造表示-推移表示旋转sweep----将一个二维区域绕旋转146 三维形体也能在空间通过扫 描变换生成新的形体:如左 图,一个圆柱体按指定方向 在长方体上运动生成新的形 体,这个过程犹如长方体与 运动者的圆柱体不断的作差 运算操作。
有时经过扫描变换所生成的形体可能会出现维数不一致问题。构造表示-推移表示扫描线方向U 三维形体也能在空间通过扫 描变换生成新的形147构造表示-推移表示广义sweep任意物体沿着任意轨迹推移推移过程中物体可以变形构造表示-推移表示广义sweep148构造表示-推移表示优点表示简单、直观适合做图形输入手段缺点作几何变换困难对几何运算不封闭用扫描变换产生的形体可能出现维数不一致的问题。扫描方法不能直接获取形体的边界信息,表示形体的覆盖域非常有限。构造表示-推移表示优点149构造表示-构造实体几何表示(CSG).通过对体素定义运算而得到新的形体的一种表示方法。体素可以是立方体、圆柱、圆锥等,也可以是半空间,其运算为变换或正则集合运算并、交、差。CSG表示可以看成是一棵有序的二叉树。其终端节点或是体素、或是形体变换参数。非终端结点或是正则的集合运算,或是变换(平移和/或旋转)操作,这种运算或变换只对其紧接着的子结点(子形体)起作用。构造表示-构造实体几何表示(CSG).通过对体素定义运算而得150构造表示-构造实体几何表示(CSG)构造表示-构造实体几何表示(CSG)151构造表示-构造实体几何表示(CSG)CSG树是无二义性的,但不是唯一的.CSG表示的优点:数据结构比较简单,数据量比较小,内部数据的管理比较容易;物体的有效性自动得到保证;CSG方法表示的形体的形状,比较容易修改。构造表示-构造实体几何表示(CSG)CSG树是无二义性的,但152构造表示-构造实体几何表示(CSG)CSG表示的缺点:对形体的表示受体素的种类和对体素操作的种类的限制,也就是说,CSG方法表示形体的覆盖域有较大的局限性。对形体的局部操作不易实现,例如,不能对基本体素的交线倒圆角;由于形体的边界几何元素(点、边、面)是隐含地表示在CSG中,故显示与绘制CSG表示的形体需要较长的时间。表示不唯一
构造表示-构造实体几何表示(CSG)CSG表示的缺点:153构造表示-特征表示用一组特征参数表示一组类似的物体特征包括形状特征、材料特征等适用于工业上标准件的表示构造表示-特征表示用一组特征参数表示一组类似的物体154构造表示-特征表示从应用层来定义形体,因而可以较好的表达设计者的意图。从功能上可分为形状、精度、材料和技术特征。特征是面向应用、面向用户的。特征模型的表示仍然要通过传统的几何造型系统来实现。不同的应用领域,具有不同的应用特征。在几何造型系统中,根据特征的参数我们并不能直接得到特征的几何元素信息,而在对特征及在特征之间进行操作时需要这些信息。特征方法表示形体的覆盖域受限于特征的种类。构造表示-特征表示从应用层来定义形体,因而可以较好的表达设计155构造表示的特点构造表示的特点:构造表示通常具有不便于直接获取形体几何元素的信息、覆盖域有限等缺点,但是,便于用户输入形体,在CAD/CAM系统中,通常作为辅助表示方法。构造表示的特点构造表示的特点:156边界表示边界表示(BR表示或BRep表示)按照体-面-环-边-点的层次,详细记录了构成形体的所有几何元素的几何信息及其相互连接的拓扑关系。边界表示的一个重要特点是在该表示法中,描述形体的信息包括几何信息(Geometry)和拓扑信息(Topology)两个方面。拓扑信息描述形体上的顶点、边、面的连接关系,拓扑信息形成物体边界表示的“骨架”。形体的几何信息犹如附着在“骨架”上的肌肉。边界表示边界表示(BR表示或BRep表示)157边界表示边界模型表达形体的基本拓扑实体包括:1.顶点2.边。边有方向,它由起始顶点和终止顶点来界定。边的形状(Curve)由边的几何信息来表示,可以是直线或曲线,曲线边可用一系列控制点或型值点来描述,也可用显式、隐式或参数方程来描述。边界表示边界模型表达形体的基本拓扑实体包括:158边界表示3.环。环(Loop)是有序、有向边(Edge)组成的封闭边界。环有方向、内外之分,外环边通常按逆时针方向排序,内环边通常按顺时针方向排序。4.面。面(Face)由一个外环和若干个内环(可以没有内环)来表示,内环完全在外环之内。若一个面的外法矢向外,称为正向面;反之,称为反向面。边界表示3.环。环(Loop)是有序、有向边(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 科技产品电商平台会员营销策略分析
- 2025年广西卫生职业技术学院单招职业技能测试题库及答案1套
- 2025年贵州航天职业技术学院单招职业倾向性测试题库学生专用
- 2025年福州英华职业学院单招职业适应性测试题库带答案
- 电竞玩家专属福利电竞酒店会员制度详解
- 2025年贵州盛华职业学院单招职业技能测试题库完整版
- 全球航路的开辟课件-2024-2025学年高一下学期统编版(2019)必修中外历史纲要下册
- 2025年湖南省株洲市单招职业适应性测试题库新版
- 2025年广东省单招职业适应性测试题库汇编
- 知识产权国际化发展路径的案例分析
- 大同大学综测细则
- 生活会前谈心谈话提纲
- 比较思想政治教育(第二版)第十二章课件
- 普通外科常见疾病临床路径
- 人教版区域地理课件世界地理之中亚五国【公开课教学PPT课件】高中地理
- 人教版九年级下册初中英语全册作业设计一课一练(课时练)
- 2021新版GJB9001C-2017体系文件内审检查表
- 风筛式清选机的使用与维护
- 《计算流体力学CFD》
- 马克思主义宗教观课件
- 语文版九年级下册课外阅读练习
评论
0/150
提交评论