形体在计算机内的表示.ppt
3.5形体在计算机内的表示,几何造型形体表示边界表示模型,3.5.1 引言,计算机中表示形体,通常用线框、表面和实体三种模型。几何造型历史:早期的线框表示 实体造型与曲面造型70 独立发展 到 互相溶合 NURBS 边界表示,正则形体,对于任一形体,如果它是3维欧氏空间中非空、有界的封闭子集,且其边界是二维流形(即该形体是连通的),我们称该形体为正则形体,否则称为非正则形体。,一些非正则形体的实例,集合运算(并、交、差)是构造形体的基本方法。正则形体经过集合运算后,可能会产生悬边、悬面等低于三维的形体。Requicha在引入正则形体概念的同时,还定义了正则集合运算的概念。正则集合运算保证集合运算的结果仍是一个正则形体,即丢弃悬边、悬面等。,集合运算举列,为了能够处理非正则形体,产生了非正则造型技术。九十年代以来,基于约束的参数化、变量化造型和支持线框、曲面、实体统一表示的非正则形体造型技术已成为几何造型技术的主流。,3.5.2 形体表示模型,在实体模型的表示中,基本上可以分为分解表示、构造表示和边界表示三大类。1、分解表示将形体按某种规则分解为小的更易于描述的部分,每一小部分又可分为更小的部分,这种分解过程直至每一小部分都能够直接描述为止。(a)将形体空间细分为小的立方体单元。这种表示方法的优点是简单,容易实现形体的交、并、差计算,但是占用的存储量太大,物体的边界面没有显式的解析表达式,不便于运算。,(b)八叉树法表示形体.首先对形体定义一个外接立方体,再把它分解成八个子立方体,并对立方体依次编号为0,1,2,7。如果子立方体单元已经一致,即为满(该立方体充满形体)或为空(没有形体在其中),则该子立方体可停止分解;否则,需要对该立方体作进一步分解,再一分为八个子立方体。在八叉树中,非叶结点的每个结点都有八个分支。优点主要是:(1)形体表示的数据结构简单。,(2)简化了形体的集合运算。只需同时遍历参加集合运算的两形体相应的八叉树,无需进行复杂的求交运算。(3)简化了隐藏线(或面)的消除,因为在八叉树表示中,形体上各元素已按空间位置排成了一定的顺序。(4)分析算法适合于并行处理。八叉树表示的缺点:占用的存储多,只能近似表示形体,以及不易获取形体的边界信息等。,2构造表示。通常有扫描表示、构造实体几何表示和特征表示三种。(a)扫描表示。基于一个基体(一般是一个封闭的平面轮廓)沿某一路径运动而产生形体。扫描是生成三维形体的有效方法用扫描变换产生的形体可能出现维数不一致的问题。扫描方法不能直接获取形体的边界信息,表示形体的覆盖域非常有限。,(b)构造实体几何表示(CSG).通过对体素定义运算而得到新的形体的一种表示方法。体素可以是立方体、圆柱、圆锥等,也可以是半空间,其运算为变换或正则集合运算并、交、差。CSG表示可以看成是一棵有序的二叉树。其终端节点或是体素、或是形体变换参数。非终端结点或是正则的集合运算,或是变换(平移和/或旋转)操作,这种运算或变换只对其紧接着的子结点(子形体)起作用。,CSG树是无二义性的,但不是唯一的.CSG表示的优点:数据结构比较简单,数据量比较小,内部数据的管理比较容易;CSG表示可方便地转换成边界(Brep)表示;CSG方法表示的形体的形状,比较容易修改。CSG表示的缺点:对形体的表示受体素的种类和对体素操作的种类的限制,也就是说,CSG方法表示形体的覆盖域有较大的局限性。,对形体的局部操作不易实现,例如,不能对基本体素的交线倒圆角;由于形体的边界几何元素(点、边、面)是隐含地表示在CSG中,故显示与绘制CSG表示的形体需要较长的时间。,(c)特征表示从应用层来定义形体,因而可以较好的表达设计者的意图。从功能上可分为形状、精度、材料和技术特征。特征是面向应用、面向用户的。特征模型的表示仍然要通过传统的几何造型系统来实现。不同的应用领域,具有不同的应用特征。,在几何造型系统中,根据特征的参数我们并不能直接得到特征的几何元素信息,而在对特征及在特征之间进行操作时需要这些信息。特征方法表示形体的覆盖域受限于特征的种类。,构造表示的特点:构造表示通常具有不便于直接获取形体几何元素的信息、覆盖域有限等缺点,但是,便于用户输入形体,在CAD/CAM系统中,通常作为辅助表示方法。,3边界表示(BR表示或BRep表示)按照体面环边点的层次,详细记录了构成形体的所有几何元素的几何信息及其相互连接的拓扑关系。边界表示的一个重要特点是在该表示法中,描述形体的信息包括几何信息(Geometry)和拓扑信息(Topology)两个方面。拓扑信息描述形体上的顶点、边、面的连接关系,拓扑信息形成物体边界表示的“骨架”。形体的几何信息犹如附着在“骨架”上的肌肉。,Brep表示的优点是:表示形体的点、边、面等几何元素是显式表示的,使得绘制Brep表示的形体的速度较快,而且比较容易确定几何元素间的连接关系;容易支持对物体的各种局部操作,比如进行倒角。便于在数据结构上附加各种非几何信息,如精度、表面粗糙度等。,Brep表示的缺点是:数据结构复杂,需要大量的存储空间,维护内部数据结构的程序比较复杂;Brep表示不一定对应一个有效形体,通常运用欧拉操作来保证Brep表示形体的有效性、正则性等。Brep表示覆盖域大,原则上能表示所有的形体,而且易于支持形体的特征表示等,Brep表示已成为当前CAD/CAM系统的主要表示方法。,CSG 与边界表示成为两大主流方法 80 ACM Solid modeling 欧洲CSG会议 边界表示 一统天下 欧洲CSG会议 亚州GMP,3.5.3 形体的边界表示模型,3.5.3.1 边界表示的基本实体边界模型表达形体的基本拓扑实体包括:1.顶点2.边。边有方向,它由起始顶点和终止顶点来界定。边的形状(Curve)由边的几何信息来表示,可以是直线或曲线,曲线边可用一系列控制点或型值点来描述,也可用显式、隐式或参数方程来描述。,3.环。环(Loop)是有序、有向边(Edge)组成的封闭边界。环有方向、内外之分,外环边通常按逆时针方向排序,内环边通常按顺时针方向排序。4.面。面(Face)由一个外环和若干个内环(可以没有内环)来表示,内环完全在外环之内。若一个面的外法矢向外,称为正向面;反之,称为反向面。,面的形状可以是平面或曲面。平面可用平面方程来描述,曲面可用控制多边形或型值点来描述,也可用曲面方程(隐式、显式或参数形式)来描述。对于参数曲面,通常在其二维参数域上定义环,这样就可由一些二维的有向边来表示环,集合运算中对面的分割也可在二维参数域上进行。5.体。体(Body)是面的并集。,3.5.3.2 边界表示的数据结构,翼边数据结构:在1972年,由美国斯坦福大学Baumgart作为多面体的表示模式提出。它用指针记录了每一边的两个邻面(即左外环和右外环)、两个顶点、两侧各自相邻的两个邻边(即左上边、左下边、右上边和右下边),用这一数据结构表示多面体模型是完备的,但它不能表示带有精确曲面边界的实体。,辐射边:为了表示非正则形体,1986年,Weiler提出了辐射边(Radial Edge)数据结构。辐射边结构的形体模型由几何信息和拓扑信息两部分组成。几何信息有面(face)、环(loop)、边(edge)和点(vertex)拓扑信息有模型(model)、区域(region)、外壳(shell)、面引用(face use)、环引用(loop use)、边引用(edge use)和点引用(vertex use)。,点是三维空间的一个位置边可以是直线边或曲线边,边的端点可以重合。环是由首尾相接的一些边组成,而且最后一条边的终点与第一条边的起点重合;环也可以是一个孤立点。外壳是一些点、边、环、面的集合;外壳是一些点、边、环、面的集合。区域由一组外壳组成。模型由区域组成。,清华大学开发的几何造型系统GEMS5.0中,采用的数据结构如图,欧拉操作 选读集合运算 选读,3.5.3.3 欧拉操作,对于任意的简单多面体,其面(f)、边(e)、顶点(v)的数目满足 欧拉公式 v-e+f=2对于任意的正则形体,引入形体的其它几个参数:形体所有面上的内孔总数(r)、穿透形体的孔洞数(h)和形体非连通部分总数(s),则形体满足公式:v-e+f=2(s-h)+r,修改过程中保证各几何元素的数目保持这个关系式不变,这一套操作就是欧拉操作。最为常用的几种欧拉操作有:(1)mvsf(v,f),生成含有一个点的面,并且构成一个新的体。(2)kvsf,删除一个体,该体仅含有一个点的面。(3)mev(v1,v2,e),生成一个新的点v2,连接该点到已有的点v1,构成一条新的边。(4)kev(e,v),删除一条边e和该边的一个端点v。(5)mef(v1,v2,f1,f2,e),连接面f1上的两个点v1、v2,生成一条新的边e,并产生一个新的面。,(6)kef(e),删除一条边e和该边的一个邻面f。(7)kemr(e),删除一条边e,生成该边某一邻面上的一新的内环。(8)mekr(v1,v2,e),连接两个点v1、v2,生成一条新的边e,并删除掉v1和v2所在面上的一个内环。(9)kfmrh(f1,f2),删除与面f1相接触的一个面f2,生成面f1上的一个内环,并形成体上的一个通孔。(10)mfkrh(f1,f2),删除面f1上的一个内环,生成一个新的面f2,由此也删除了体上的一个通孔。,为了方便对形体的修改,还定义了两个辅助的操作:公共端点。(11)semv(e1,v,e2),将边e1分割成两段,生成一个新的点v和一条新的边e2。(12)jekv(e1,e2),合并两条相邻的边e1、e2,删除它们的公共端点。以上十种欧拉操作和两个辅助操作,每两个一组,构成了六组互为可逆的操作。可以证明:欧拉操作是有效的,即用欧拉操作对形体操作的结果在物理上是可实现的;欧拉操作是完备的,即任何形体都可用有限步骤的欧拉操作构造出来。,3.5.3.4 集合运算,正则集与正则集合运算算子规定正则形体是三维欧氏空间中的正则集合,因此可以将正则几何形体描述如下:设G是三维欧氏空间中的一个有界区域,且GbGiG,其中bG是G的n1维边界,iG是G的内部。G的补空间cG称为G的外部,此时正则形体G需满足:1)bG将iG和cG分为两个互不连通的子空间;2)bG中的任意一点可以使iG和bG连通;3)bG中任一点存在切平面,其法矢指向cG子空间4)bG是二维流形。,设是集合运算算子(交、并或差),R3中任意两个正则形体A、B作集合运算:R=AB 运算结果R仍是R3中的正则形体,则称为正则集合算子。正则并、正则交、正则差分别记为*,*、-*。分类,Tilove对分类问题的定义为:设S为待分类元素组成的集合,G为一正则集合,则S相对于G的成员分类函数为:C(S,G)=S in G,S out G,S on G其中,S in G=SiG,S out G=ScG,S on G=SbG,,集合运算算法包括以下几部分:(1)求交:参与运算的一个形体的各拓扑元素求交,求交的顺序采用低维元素向高维元素进行。用求交结果产生的新元素(维数低于参与求交的元素)对求交元素进行划分,形成一些子元素。(2)成环:由求交得到的交线将原形体的面进行分割,形成一些新的面环。再加上原形体的悬边、悬点经求交后得到的各子拓扑元素,形成一拓扑元素生成集。,(3)分类:对形成的拓扑元素生成集中的每一拓扑元素,取其上的一个代表点,根据点/体分类的原则,决定该点相对于另一形体的位置关系,同时考虑该点代表的拓扑元素的类型(即其维数),来决定该拓扑元素相对于另一形体的分类关系。(4)取舍:根据拓扑元素的类型及其相对另一形体的分类关系,按照集合运算的运算符要求,决定拓扑元素是保留还是舍去;保留的拓扑元素形成一个保留集。(5)合并:对保留集中同类型可合并的拓扑元素进行合并,包括面环的合并和边的合并。,(6)拼接:以拓扑元素的共享边界作为其连接标志,按照从高维到低维的顺序,收集分类后保留的拓扑元素,形成结果形体的边界表示数据结构。,3.6归类求交,几何造型中,通常利用集合运算(并、交、差运算)实现复杂形体的构造。集合运算需要大量的求交运算。如何提高求交的实用性、稳定性、速度、精度等,对几何造型系统至关重要。历史上的观念变化:简单体素的精确求交,NURBS统一求交-归类求交,3.6.1求交分类简介,多面体模型这种模型的求交计算主要是线段和平面的求交,求交问题的解决相对简单。多面体模型的缺点是明显的。它只能近似表示形体,同时,复杂形体表面的离散会带来巨大的数据量。CSG模型在这种模型中,形体通过基本体素的组合来实现。二次曲面的求交是这些造型系统中必不可少的。,当前的几何造型系统,大多采用精确的边界表示模型。在这种表示法中,形体的边界元素和某类几何元素相对应,它们可以是直线、圆(圆弧)、二次曲线、Bezier曲线、B样条曲线等,也可以是平面、球面、二次曲面、Bezier曲面、B样条曲面等,求交情况十分复杂。二次曲面与各种自由曲面并存的混合表示模型的采用,导致了归类求交思想的产生。,“无处不在的求交”:GEMS实例!,实体建模步骤剖析:草图拉伸、填“体、面、环、点”结构打孔,直径为20cm:圆柱与立方体的所有面求交线,成环、重填“体面环点”结构打第二个孔,直径为18cm:圆柱与立方体的所有面、及第一个圆柱面求交线,成环、重填“体面环点”结构,3.6.2归类求交策略,几何造型系统中,用到的几何元素:(25种)点:3D点。线:3D直线段、二次曲线(包括圆弧和整圆、椭圆弧和椭圆、抛物线段、双曲线段)、Bezier曲线(有理和非有理)、B样条曲线、NURBS曲线。面:平面、二次曲面(包括球面、圆柱面、圆锥/台面、双曲面、抛物面、椭球面和椭圆柱面)、Bezier曲面(有理和非有理)、B样条曲面、NURBS曲面。,将几何元素进行归类,利用同一类元素之间的共性来研究求交算法。同时对每一类元素,在具体求交算法中要考虑它们的特性,以提高算法的效率,发挥混合表示方法的优势。求交方法可分为:点点、点线、点面、线线、线面六种。,清华大学的GEMS5.0系统采用点、直线、平面、二次曲线等简单的几何元素之间的求交直线、平面、二次曲线等简单的几何元素与二次曲面之间的求交三维点与二次曲线/曲面之间的求交三维点与自由曲线、曲面之间的求交二次曲面与二次曲面之间的求交直线自由曲线/自由曲面的求交,平面自由曲线/自由曲面的求交自由曲线自由曲线的求交自由曲线自由曲面的求交二次曲线自由曲线的求交 二次曲线自由曲面的求交自由曲面自由曲面的求交二次曲面自由曲线的求交二次曲面自由曲面的求交,3.6.3基本的求交算法,曲线曲面求交的基本方法主要有:代数方法几何方法离散方法跟踪方法,1代数方法利用代数运算,特别是求解代数方程的方法求出曲面的交线。根据参与求交的两曲面的表示形式的不同,可以把求交分为三种情况。,隐式表示和参数表示的曲面求交,通过把参数方程代入隐式方程的方法,可以将交线表示为g(u,v)=0的形式。此时得到的交线方程是平面代数曲线方程,可根据平面代数曲线理论的方法求解交线。两个曲面都是参数表示的情形,只需要将其中之一隐式化,然后用前面的方法求解。而参数多项式或有理多项式曲面的隐式化通过消元来实现。,两个曲面都是隐式曲面。一种方法是将其中一个曲面参数化,然后用第一种情况来求解。但是,一般情况下这种参数化很困难,对于某些情况可以采用另外的方法计算参数化的曲面。代数法的弱点是对误差很敏感这是因为代数法经常需要判别某些量是否大于零、等于零或小于零,而在计算机中的浮点数近似表示的误差常常会使这种判别出现错误。,代数法实例:园与椭圆求交,化为求解4次方程,有公式解。园与圆环求交,化为求解8次方程,迭代求解。8次方程达到求解,不稳定。,2几何方法利用几何的方法,对参与求交的曲面的形状大小、相互位置以及方向等进行计算和判断,识别出交线的形状和类型,从而可精确求出交线。几何求交适应性不是很广,一般仅用于平面以及二次曲面等简单曲面的求交,对于一些交线退化或相切的情形,交线往往是点、直线或圆锥曲线,用几何方法求交可以更加迅速和可靠。,几何法实例:平面与圆柱求交1.平面、圆柱参数的合法性检查2.平面变换到圆柱的局部坐标系 3.几何求交:如果平面与圆柱平行,不交或交于两条直线 如果平面与圆柱垂直,不交或交于一个圆,否则,交于椭圆或椭圆弧 先求出平面与无限长圆柱交得的椭圆(在圆柱的局部坐标系下)根据椭圆在长轴上的两点与圆柱的 关系,确定交于点、椭圆、椭圆弧等,3离散方法离散方法求交是利用分割的方法,将曲面不断离散成较小的曲面片,直到每一子曲面片均可用比较简单的面片,然后用这些简单面片求交得一系列交线段,连接这些交线段即得到精确交线的近似结果。,离散求交一般包括下面的过程:用包围盒作分离性检查排除无交区域;根据平坦性检查判断是否终止离散过程;连接求出的交线段作为求交结果。由于Bezier曲面,B样条曲面具有离散性质,使得它们最适合于离散法求交。,缺点:离散法求出的交线逼近精度不高。如果要求的精度较高,需要增加离散层数。这将大大增加了数据储存量和计算量。处于不同离散层数的相邻子曲面片,由它们产生的交线段可能会出现裂缝。,高度估计问题 H,4跟踪方法通过先求出初始交点,然后从已知的初始交点出发,相继跟踪计算出下一交点,从而求出整条交线的方法。跟踪法的本质是构造交线满足的微分方程组,先求出满足方程组的某个某个初值解,通过数值求解微分方程组的方法来计算整个交线。,跟踪方法在计算相继交点的时候,利用了曲面的局部微分性质,一般采用数值迭代的方法求解,使得计算效率较高。,跟踪法求交中考虑的主要问题包括:如何求出初始交点并保证每一交线分支都有初始交点被求出;如何计算奇异情况下的跟踪方向以及合理选取跟踪的前进步长;如何处理相切的情况。,跟踪法实例:MAF方法曲线曲线求交近似交点,切线求交,投影,MAF与Newton法的比较,Newton法,MAF与Newton法的比较,MAF法,假设 为初始交点,为两切线的交点;由于在曲线 在 的切线上,有 于是 由此得到新交点,如此反复迭代。,3.7 实体造型系统简介,在早期开发的实体造型系统中,值得提及的是剑桥大学的BUILD-1系统。该研究小组的一部分人组建了Shape Data公司,并开发出实体造型系统Romulus,Romulus孕育了最著名的两个实体造型系统开发环境:Parasolid和ACIS。3.7.1 Parasolid系统:Solidworks3.7.2 ACIS系统:Autodesk,Solidedge,3.7.1.1 Parasolid的主要功能,Parasolid有较强的造型功能,但是只能支持正则实体造型。主要功能包括:1Parasolid采用自由曲面和解析曲面的混合表示,共提供了10种标准的曲面类型和7种标准的曲线类型,并且是完全集成的。2Parasolid可用简单的方法生成复杂的实体,实体之间可有多种方式的操作。3.用户可用自己理解的工程特征进行设计4.能够提供非拓扑和非几何数据,称为属性,属性包括系统定义的属性和用户定义的属性两种,且依附于模型实体(Entities)。5.支持局部操作。包括:改变面几何、变换面几何、使面成锥形、摆动面、扫描面及删除面。提供了多半径、变半径的过渡功能。,3.7.1.2 Parasolid的模型结构,模型实体包括三种:拓扑、几何和相关数据,1拓扑实体(1)体(Body):Parasolid模型通常包括一个或多个体(Bodies)(2)壳(Shell):壳是实体(Solid)和空气之间封闭的边界(3)面(Face)、边(Edge)和顶点(Vetex)(4)翼(Fin):翼(Fins)表示一条边的一侧每一条边有一个左翼和一个右翼(5)环(Loop):由一个面上封闭的翼组成。,(7)装配件(Assembly)和实例(Instance):一个装配件是一个对其它装配件或体的指针的集合。每一个指针被称为一个实例。(8)世界(World):世界是一个独特的实体(Entity),它包含模型中的所有的体(Bodies)和装配件(Assemblies)。,2几何实体(Entities)点。主要依附于顶点,它们也依附于体和装配件作为构造几何。曲线。主要依附于面,但也依附于体和装配件作为构造几何。曲面。主要依附于模型的边或翼,但也依附于体和装配件作为构造几何。变换。变换表示几何操作:平移、修剪等,主要依附于实例。,3相关的数据实体(1)特征(feature):是实体的集合,依附于体和装配件。(2)表(List):提供了结构化数据的方法,它们一般独立使用,也可依附于体和装配件。表有三种:整数表(Integer)、实数表(Real)和标志表(Tag)。(3)属性(Attribute):是用于附着信息到实体的数据结构。,3.7.1.3 Parasolid的界面,Parasolid有两个界面。一个在造型器顶部,称为核心界面(KI),通过KI,用户可以造型、操作对象和控制造型器。另一个在造型器下部,它包括三个部分:Frustrum、GO(Graphics Output)和FG(Foreign Geometry)。,Frustrum:Frustrum是用户写的函数集,当数据被存储、提取,或进行内存分配时,它们被核心调用。图形输出(GO):图形输出(GO)函数也是被用户写的。从这些函数输出的通是要求核心(Kernel)绘图的指令。外部几何(FG):Parasolid通过FG模块界面访问用户定义的曲线、曲面,使得用户可以使用Parasolid造型出的曲线、曲面及标准的Parasolid曲线、曲面类型。,3.7.2 ACIS系统,ACIS是由美国Spatial Technology于1990年首次推出。ACIS的重要特点是支持线框、曲面、实体统一表示的非正则形体造型技术,能够处理非流形形体。ACIS产品采用了组件技术,其核心是几何造型器(Geometric Modeler),还包括一些可与核心集成的组件,称为外壳(Husk)。,3.7.2.1 ACIS的结构,核心只提供一些基本的几何造型功能,其它高级功能在外壳中提供。外壳可以是Spatial Technology公司提供的,如高级渲染(Advanced Rendering)外壳、三维工具箱(3D Toolkit)外壳等,也可以是用户开发的。,3.7.2.2 ACIS的模型表示,ACIS模型表示由各种属性(Attributes)、几何(Geometries)和拓扑(Topologies)成。几何是指模型的物理描述,如点、曲线、曲面、直线、椭圆等;拓扑是指各种几何实体在空间的关联,如体、壳、面、环、边和顶点等;属性依附于模型实体。ACIS是用C+开发的,C+类的层次如图所示。,3.7.2.3 ACIS的几何总线,ACIS核心提供了一个几何总线,以连接其它的外壳与应用程序,3.7.2.3 ACIS的界面,1API函数API(Application Procedural Interface)函数是一个函数集,应用程序通过调用这些函数可以操作模型。2属性ACIS属性(Attributes)机制向开发者提供了具体的应用程序数据到ACIS几何或拓扑实体(ENTITY)的方法。属性与模型数据一起存储或恢复。,3类类(Classes)界面是定义ACIS几何和拓扑模型及其它ACIS特征的C+类的集合,开发者可以直接利用这些类和方法,为特定的用途导出新的类和方法。4.宏预处理器宏(Macros)用于简化通常的编码任务。,谢谢!,