羅月童,韓承村,杜華,嚴(yán)伊蔓
(1.合肥工業(yè)大學(xué)計(jì)算機(jī)與信息學(xué)院,安徽合肥 230601; 2.中國(guó)科學(xué)院 等離子體物理研究所,安徽合肥 230031; 3.國(guó)家電投集團(tuán)科學(xué)技術(shù)研究院有限公司,北京 100033)
邊界表示(boundary representation,B-Rep)法和構(gòu)造實(shí)體幾何(construction solid geometry,CSG)法是使用最廣泛的2 種實(shí)體表示法,其中B-Rep 法已廣泛應(yīng)用于各種商用CAD 軟件,借助商用CAD軟件強(qiáng)大的造型功能,用戶能方便快捷地構(gòu)建三維B-Rep 模型。也有很多科學(xué)計(jì)算程序用CSG 法,如粒子輸運(yùn)程序MCNP[1]、cosRMC[2]等,這是因?yàn)镃SG 法具有對(duì)科學(xué)計(jì)算程序非常重要的穩(wěn)定、簡(jiǎn)單等優(yōu)點(diǎn)。目前市場(chǎng)上能直接構(gòu)建CSG 模型的成熟軟件較少,因此希望借助商業(yè)CAD 軟件建立B-Rep模型,然后將B-Rep 模型自動(dòng)轉(zhuǎn)換為CSG 模型,以減輕建模工作量。如面向MCNP、cosRMC 等粒子輸 運(yùn) 程 序 的cosVMPT[3]、MCAM[4]、McCAD[5]等軟件,這些軟件的核心功能都是將B-Rep 模型轉(zhuǎn)換為CSG 模型,即B-Rep→CSG 轉(zhuǎn)換算法。本文源于自主研發(fā)的粒子輸運(yùn)COSINE 可視建模(COSINE visual modelling of particle transport,cosVMPT)軟件,旨在基于拉伸特征提升B-Rep→CSG 轉(zhuǎn)換算法的穩(wěn)定性和速度,以提高cosVMPT 軟件對(duì)大規(guī)模模型的處理能力。
B-Rep→CSG 轉(zhuǎn)換問(wèn)題備受關(guān)注[6],主要有三類轉(zhuǎn)換方法:(1)半空間分割法[7],通常利用某些面分割B-Rep 模型,基于面的半空間分割組合獲得CSG 表示,其核心是分割面的選擇,較常見(jiàn)的做法是從B-Rep 模型中提取分割面。文獻(xiàn)[8-9]利用CLoop 環(huán)構(gòu)造分割面以改善分割效果,但CLoop 環(huán)的識(shí)別比較復(fù)雜。(2)交替和差分解法[10],通過(guò)求BRep 模型的凸包并與之做布爾減運(yùn)算得到差體,繼續(xù)對(duì)差體求凸包并與之做布爾差運(yùn)算,如此反復(fù)循環(huán)直至差體為空,將凸包和差體組合得到B-Rep 模型的CSG 表示。(3)單元分解法[11-12],將B-Rep 模型分解為一組單元體,用優(yōu)化方法求解相關(guān)單元體組合,實(shí)現(xiàn)B-Rep→CSG 轉(zhuǎn)換,但此類方法通常存在過(guò)分割問(wèn)題。半空間分割法因其具有直觀、易實(shí)現(xiàn)等優(yōu)點(diǎn)廣受關(guān)注,其中,cosVMPT、MCAM、McCAD 采用的均為半空間分割法。
圖1 半空間分割法示意圖Fig.1 Schematic diagram of half space partition method
半空間分割法,沿一系列面將B-Rep 模型分解為若干簡(jiǎn)單模型,然后基于簡(jiǎn)單模型實(shí)現(xiàn)B-Rep→CSG 轉(zhuǎn)換,圖1 展示的為模型的分割過(guò)程。對(duì)復(fù)雜的B-Rep 模型分割量較大,通常通過(guò)造型引擎的布爾交/減運(yùn)算實(shí)現(xiàn)分割,如MCAM 采用商業(yè)造型引擎ACIS[13],cosVMPT 和McCAD 采用開(kāi)源造型引擎OpenCascade[14]。經(jīng)過(guò)多年發(fā)展,雖然ACIS、OpenCascade 引擎已較成熟,但因?yàn)椴紶栠\(yùn)算涉及復(fù)雜的數(shù)值運(yùn)算,所以仍然存在布爾運(yùn)算失敗的概率。 筆者在實(shí)踐中發(fā)現(xiàn),開(kāi)源造型引擎OpenCascade 失敗概率更高,從而降低了B-Rep→CSG 轉(zhuǎn)換算法的穩(wěn)定性。因?yàn)閏osVMPT 等軟件經(jīng)常需要一次性轉(zhuǎn)換數(shù)萬(wàn)個(gè)B-Rep 模型,中國(guó)聚變工程 實(shí)驗(yàn)堆(China fusion engineering test reactor,CFETR)模型由50 000 多個(gè)B-Rep 模型組成,如圖2 所示,存在布爾運(yùn)算失敗導(dǎo)致轉(zhuǎn)換失敗的概率,因此,在實(shí)際應(yīng)用中,不得不對(duì)模型進(jìn)行預(yù)處理,如將復(fù)雜的B-Rep 模型預(yù)先分解為若干簡(jiǎn)單的B-Rep模型,這不僅需耗費(fèi)大量時(shí)間,而且對(duì)用戶的CAD建模技能有很高要求,嚴(yán)重影響cosVMPT 等軟件的易用性和友好性。因此,降低B-Rep→CSG 轉(zhuǎn)換算法對(duì)布爾運(yùn)算的依賴性、提升B-Rep→CSG 轉(zhuǎn)換算法的穩(wěn)定性、改善相關(guān)軟件的可用性和易用性等研究具有一定的理論意義和實(shí)用價(jià)值[15-16]。
圖2 CFETR 聚變堆模型Fig.2 CFETR fusion reactor model
自主研發(fā)的cosVMPT 軟件常常用于處理裂變堆模型和聚變堆模型,圖2 為CFETR 聚變堆模型,圖3 為AP1000 裂變堆堆芯模型。筆者觀察到這類模型中存在大量掃略體,即二維圖形通過(guò)拉伸或旋轉(zhuǎn)所形成的三維對(duì)象?;诖?,提出利用掃略體特點(diǎn)優(yōu)化B-Rep→CSG 轉(zhuǎn)換:對(duì)二維圖形進(jìn)行B-Rep→CSG轉(zhuǎn)換,然后將轉(zhuǎn)換映射至三維模型。因二維圖形的B-Rep→CSG 轉(zhuǎn)換不需要布爾運(yùn)算,通過(guò)大幅度減少布爾運(yùn)算,提升B-Rep→CSG 轉(zhuǎn)換算法的穩(wěn)定性。掃略體通常包括拉伸體和旋轉(zhuǎn)體,本文以拉伸體為例探討優(yōu)化B-Rep→CSG 轉(zhuǎn)換算法。拉伸特征是指單獨(dú)存在的完整拉伸體、部分拉伸體,或作為模型一部分的完整拉伸體、部分拉伸體,圖4 給出了典型拉伸特征的各種存在形式,轉(zhuǎn)換流程的關(guān)鍵是拉伸特征的識(shí)別和二維圖形的B-Rep→CSG轉(zhuǎn)換。
本文的主要貢獻(xiàn)包括:
(1)提出了基于拉伸特征的B-Rep→CSG 轉(zhuǎn)換算法,以減少轉(zhuǎn)換算法對(duì)布爾運(yùn)算的依賴,提升了算法的穩(wěn)定性;
(2)給出了拉伸特征的定義及其識(shí)別方法,解決了基于拉伸特征的B-Rep→CSG 轉(zhuǎn)換算法的關(guān)鍵問(wèn)題;
(3)將所提算法集成至自主研發(fā)的cosVMPT軟件,并投入實(shí)際應(yīng)用。
圖3 AP1000 裂變堆堆芯模型Fig.3 AP1000 fission core model
圖4 拉伸特征的各種存在形式Fig.4 Various existing forms of stretch feature
由圖4 可知,拉伸特征可看作由二維圖形沿一定方向拉伸形成的三維圖形(本文稱其為拉伸體)或其一部分。其中,由二維圖形的邊拉伸形成的面稱為拉伸面,由二維圖形的頂點(diǎn)拉伸形成的邊稱為拉伸邊,且所有拉伸邊均為直線,如圖5(a)所示。
雖然拉伸特征可能是拉伸體的一部分,但本文要求保留拉伸體所有拉伸邊的全部或部分。圖5(b)中,因?yàn)槔爝叡煌耆懈?,所以其為無(wú)效拉伸體。拉伸特征包含相應(yīng)拉伸體的所有拉伸邊,可通過(guò)拉伸邊識(shí)別拉伸特征,其核心是提取拉伸特征所包含的一組拉伸邊,本文稱其為拉伸邊集。
圖5 拉伸體、拉伸面、拉伸邊示意Fig.5 Schematic diagram of extruded body,extruded surface and extruded edge
為準(zhǔn)確識(shí)別拉伸邊集,筆者對(duì)拉伸邊集進(jìn)行了觀察、分析和總結(jié),得到以下條件。
(1)相互平行性:拉伸邊集中的所有邊相互平行,拉伸邊集由一組平行邊構(gòu)成。
(2)首尾相連性:如果兩條邊共享一個(gè)面,則稱這兩條邊相連。拉伸邊集中的任何一條邊與且僅與另外兩條邊相連,拉伸邊集中所有邊將形成一個(gè)首尾相連的環(huán)。
(3)方向相反性:按順時(shí)針或逆時(shí)針遍歷所有邊,按遍歷順序定義邊的方向。若拉伸邊集中的兩條邊共享一個(gè)面,則此兩條邊方向相反。
(4)唯一連接性:拉伸邊集中最多有兩條邊共享一個(gè)面。由拉伸特征的定義可知,兩條邊共享的面為拉伸特征的側(cè)面,只出現(xiàn)一次。
上述4 條均為拉伸邊集的必要而非充分條件,若一組邊同時(shí)滿足上述條件,則構(gòu)成一個(gè)拉伸邊集。本文雖然未能給出嚴(yán)格的理論證明,但從大量的觀察、實(shí)驗(yàn)和實(shí)際應(yīng)用中已得到驗(yàn)證。并基于上述結(jié)論設(shè)計(jì)了拉伸邊集提取算法。
對(duì) B-Rep 模 型M=(EM,F(xiàn)),其 中EM=表示模型M中所有邊的集合,F(xiàn)={f1,f2,…,fm}表示模型M中所有面的集合。
提取拉伸邊集算法:
(i)從EM中提取所有平行邊組:P1,P2,…,PK。因?yàn)橄嗷テ叫行允抢爝吋谋匾獥l件,所以M的所有拉伸邊集均包含P1,P2,…,PK,每個(gè)Pi可能包含0 個(gè)或多個(gè)拉伸邊集。
(ii)利用拉伸邊集的首尾相連性、方向相反性和唯一連接性,從平行邊組Pi中提取0 個(gè)或多個(gè)拉伸邊集。
因算法(i)提取平行邊組的方法比較成熟,不再贅述,下文主要討論算法(ii)。
因?yàn)槔爝吋氖孜蚕噙B性與圖的簡(jiǎn)單回路特點(diǎn)非常相似,所以采用基于簡(jiǎn)單回路的算法提取拉伸邊集。提出用平行邊連接圖G=(V,EG)刻畫(huà)平行邊組各元素的連接關(guān)系,并在圖G=(V,EG)中由拉伸邊集的方向相反性和唯一連接性準(zhǔn)確提取拉伸邊集。
平行邊連接圖G=(V,EG)的構(gòu)造過(guò)程:
(2)如 果vi,vj∈V所 對(duì) 應(yīng) 的 平 行 邊滿足:
則創(chuàng)建邊(vi,vj)∈EG;
(3)將共享面f作為邊(vi,vj) 的屬性,即令attr(vi,vj)=f。
如圖6(a)所示,B-Rep 模型垂直方向平行邊P={A,B,C,D,E,F(xiàn),G,H},其中,A-B,B-C,CD,D-A,E-F,F(xiàn)-G,G-H,H-E,A-F,B-E,A-E和B-F共12 對(duì)平行邊共享某個(gè)面,但A-E以及B-F的共享面為f1且方向相同,其對(duì)應(yīng)平行邊連接圖如圖6(c)所示,包括8 個(gè)頂點(diǎn)、10 條邊及邊的屬性。
完成平行邊連接圖G=(V,EG)構(gòu)建后,按以下步驟提取拉伸邊集:
(1)基于深度優(yōu)先搜索的改進(jìn)算法[8]求G=(V,EG)中所有簡(jiǎn)單回路{L1,L2,…,Ln},其中,回路Li中的節(jié)點(diǎn)記為{v1,v2,…,vm},所有邊記為
圖6 拉伸特征及其平行邊連接圖Fig.6 Stretch feature and its parallel edge connection graph
上述步驟可輸出0 個(gè)或多個(gè)平行邊集,可以證明,所輸出的每個(gè)平行邊集均滿足1.1 節(jié)中的4 個(gè)條件,因此均構(gòu)成拉伸邊集。
證明過(guò)程如下:
(1)相互平行性:因?yàn)槠叫羞呥B接圖的所有節(jié)點(diǎn)對(duì)應(yīng)模型中的一組平行邊,所以輸出的邊集為一組平行邊,滿足相互平行性;
(2)首尾相連性:因?yàn)檫@組平行邊對(duì)應(yīng)圖中的簡(jiǎn)單回路,所以滿足首尾連接性;
(3)方向相反性:由平行邊連接圖構(gòu)建方法可知,圖中邊所連接的兩個(gè)頂點(diǎn)對(duì)應(yīng)的平行邊方向相反,所以滿足方向相反性;
(4)唯一連接性:由提取拉伸邊集算法(ii),可排除不滿足該條件的簡(jiǎn)單回路,因此,最終輸出結(jié)果均滿足唯一連接性。
圖6(c)為平行邊連接圖,有3 個(gè)簡(jiǎn)單回路{A,B,C,D}、{A,B,E,F(xiàn)}和{E,F(xiàn),G,H},如 圖6(d)所 示,但 由 于{A,B,E,F(xiàn)} 中,attr(A,F(xiàn))=attr(B,E)=f1,因此將其剔除,最后只保留有效簡(jiǎn)單 回 路{A,B,C,D}和{E,F(xiàn),G,H},見(jiàn) 圖6(e),其分別對(duì)應(yīng)圖6(b)中紅色和黃色所示的拉伸特征。
如果B-Rep 模型M的部分或全部是一個(gè)或多個(gè)拉伸特征F1,F(xiàn)2,…,F(xiàn)n,那么,首先將模型M分解為模型MF1,MF2,…,MFn和MR,其中,MFi表示拉伸特征Fi對(duì)應(yīng)的模型,MR表示分離所有拉伸特征后的剩余部分,圖7(a)模型的分解結(jié)果見(jiàn)圖7(b)。然后對(duì)MFi和MR實(shí)施B-Rep→CSG 轉(zhuǎn)換獲得相應(yīng)的CSG 表示CSG(MFi)和CSG(MR),于是B-Rep 模型M的B-Rep→CSG 轉(zhuǎn)換結(jié)果可表示為CSG(M) =CSG(MR)+CSG(MFi)。
圖7 拉伸特征分解過(guò)程示意Fig.7 Schematic diagram of feature decomposition process of stretch
剩余部分MR為一般的B-Rep 模型,因此采用文獻(xiàn)[3]所述的B-Rep→CSG 算法。
拉伸特征是B-Rep 模型的一部分,可按各種方式與模型其余部分連接,圖8(a)中,連接處只有一個(gè)平面,較簡(jiǎn)單,但圖8(b)中,連接處涉及多個(gè)面,較復(fù)雜。無(wú)論連接處較簡(jiǎn)單還是較復(fù)雜,拉伸特征體MF和模型M之間的邊界都只有一個(gè)環(huán),而文獻(xiàn)[9]提出基于環(huán)收縮的面殼封閉法,可依據(jù)環(huán)分離B-Rep 模型的多個(gè)部分,圖8(c)展示的為相關(guān)例題,本文用環(huán)收縮算法分離拉伸特征。
文獻(xiàn)[9]詳細(xì)介紹了環(huán)收縮算法,筆者在前期工作中也已實(shí)現(xiàn)環(huán)收縮算法[17]。本節(jié)主要討論拉伸特征體MF和模型M連接處環(huán)的提取,環(huán)提取后即可運(yùn)用環(huán)收縮算法對(duì)拉伸特征體進(jìn)行分類。本文稱拉伸特征體MF和模型M連接處的環(huán)為分割環(huán)。
由圖8 可知,拉伸特征邊的分割環(huán)具有以下特點(diǎn):
(1)每個(gè)拉伸特征有且僅有2 個(gè)分割環(huán),分別在拉伸特征體的兩端;
(2)分割環(huán)由拉伸面的邊組成,且不包括拉伸邊。
圖8 切割環(huán)示意Fig.8 Schematic diagram of cutting ring
基于以上觀察,對(duì)拉伸特征F,如果其拉伸邊面集和邊集分別為{f1,f2,…,fn}和{e1,e2,…,en},則提取分割環(huán)的過(guò)程如下:
(1)提取所有拉伸面的邊,組成集合E=其中edge(fi)表示面fi的所有邊;
(2)去除所有拉伸邊,形成新邊集E′=E?{e1,e2,…,en};
(3)依據(jù)E′中邊的連接關(guān)系,提取分割環(huán)。
在如圖9(a)所示的模型中,上面黃色部分為拉伸特征,其所對(duì)應(yīng)的分割環(huán)如圖9(b)所示,運(yùn)用環(huán)收縮分離可獲得如圖9(c)所示的2 個(gè)模型。
圖9 基于環(huán)搜索的分割過(guò)程Fig.9 Segmentation process based on ring search
基于拉伸特征,將二維圖形沿一定方向拉伸,將三維拉伸特征的B-Rep→CSG 問(wèn)題轉(zhuǎn)換為二維圖形的B-Rep→CSG 問(wèn)題。如圖10 所示,在采用半空間分割法進(jìn)行B-Rep→CSG 轉(zhuǎn)換時(shí),可先對(duì)二維圖形進(jìn)行轉(zhuǎn)換,然后將轉(zhuǎn)換結(jié)果映射至三維空間,如將圖10 所示輪廓面的邊映射為拉伸特征的面,再添加端面即可獲得拉伸特征的CSG 表示。本文采用半空間分解法,其拉伸特征MF的B-Rep→CSG 轉(zhuǎn)換步驟如下:
(1)獲取拉伸特征體對(duì)應(yīng)的二維圖形,并對(duì)二維圖形進(jìn)行B-Rep→CSG 轉(zhuǎn)換,獲得二維圖形的CSG表示,見(jiàn)圖10(b)。
(2)將二維圖形CSG 表達(dá)式中的邊映射至面,如直線映射為平面、圓弧映射為圓柱面,獲得兩端無(wú)界的拉伸體的CSG 表示,見(jiàn)圖10(c)。
(3)根據(jù)拉伸特征的端面情況,為步驟(2)所得的CSG 表達(dá)式添加端面,最終獲得拉伸特征的完整CSG 表示,見(jiàn)圖10(d)。
因步驟(2)可根據(jù)拉伸特征的定義直接完成映射,不再贅述。若拉伸特征的端面為單個(gè)平面,則步驟(3)可直接解決,若端面由多個(gè)面組成,則比較復(fù)雜,筆者在工程實(shí)踐中采用的是遞歸半空間分割法。因?yàn)楸疚牡暮诵氖抢焯卣鞯淖R(shí)別和應(yīng)用,且在工程實(shí)踐中,端面多為平面,所以僅考慮端面為平面的情況,對(duì)步驟(2)和(3)不再做詳細(xì)討論。
圖10 拉伸特征B-Rep→CSG 轉(zhuǎn)換過(guò)程示意Fig.10 Schematic diagram of B-Rep→CSG conversion process of stretch feature
由文獻(xiàn)[18]知,在半空間分割方法中,二維圖形B-Rep→CSG 轉(zhuǎn)換的難點(diǎn)是如何將復(fù)雜的二維圖形分解為一組簡(jiǎn)單圖形。如果二維圖形是多邊形,則將多邊形分解為一組凸多邊形。因?yàn)閷⑷我舛噙呅畏纸鉃橐唤M凸多邊形是圖形學(xué)領(lǐng)域的經(jīng)典問(wèn)題,有大量?jī)?yōu)秀成果可以利用,本文僅考慮利用相關(guān)算法解決二維圖形的B-Rep→CSG 轉(zhuǎn)換問(wèn)題。文獻(xiàn)[19]中的多邊形分解算法具有計(jì)算量小、分解所得的凸多邊形邊少等優(yōu)點(diǎn),能簡(jiǎn)化多邊形的CSG 表示。如圖11(a)所示的復(fù)雜多邊形,用文獻(xiàn)[19]中的基于頂點(diǎn)可見(jiàn)的多邊形分解算法,得到如圖11(b)所示的結(jié)果,而任意分解結(jié)果如圖11(c)所示,可見(jiàn)文獻(xiàn)[19]算法的分解結(jié)果更優(yōu)。
圖11 不同多邊形分解算法效果對(duì)比Fig.11 Comparison of different polygon decomposition methods
因?yàn)閏osVMPT 軟件要求B-Rep 模型只能包含平面、球面、圓柱面、圓錐面和圓環(huán)面,所以當(dāng)拉伸特征的拉伸面為平面或圓柱面時(shí),所對(duì)應(yīng)的二維圖形的邊為圓弧或直線。如圖12 所示,若二維圖形M2D中包含圓弧,則可通過(guò)以下方法將其轉(zhuǎn)換為多邊形,再采用多邊形分解算法(不考慮出現(xiàn)自交多邊形的情況):
(1)用弦代替對(duì)應(yīng)圓弧,形成多邊形P2D。
(2)記錄圓弧和弦包圍形成的二維圖形,將所有凸圓弧和凹圓弧對(duì)應(yīng)的圖形分別記為{conf1,conf2,…,confn} 和{concf1,concf2,…,concfm}。
那么M2D的CSG 表示為
圖12 輪廓面的多邊形化過(guò)程Fig.12 Polygonization process of profile
本文算法已應(yīng)用于我國(guó)自主核能設(shè)計(jì)軟件包COSINE 的輔助建模cosVMPT 軟件,其主界面如圖 13 所示。 該軟件基于開(kāi)源造型引擎OpenCascade 7.3.0,在windows 平 臺(tái) 采 用visual studio 2017 開(kāi)發(fā)。 本文中的所有實(shí)驗(yàn)均基于cosVMPT 完成。
圖13 cosVMPT 主界面Fig.13 The main interface of cosVMPT
首先由簡(jiǎn)單到復(fù)雜構(gòu)造3 個(gè)模型,見(jiàn)圖14 中的(1)、(2)和(3)。分別對(duì)模型進(jìn)行測(cè)試,并對(duì)采用本文算法前后的轉(zhuǎn)換時(shí)間和轉(zhuǎn)換效果進(jìn)行比較,見(jiàn)表1 和圖14。因?yàn)榘肟臻g分割法B-Rep→CSG 轉(zhuǎn)換的核心是分解復(fù)雜模型,所以圖14 未采用最終的CSG表達(dá)式,而是以分解結(jié)果表示轉(zhuǎn)換效果。
表1 轉(zhuǎn)換時(shí)間比較Table 1 Time comparison of conversion
由圖14 可知,本文算法的分解結(jié)果更簡(jiǎn)潔或其CSG 表示更簡(jiǎn)潔。如本文算法可將模型(2)分解為4 個(gè)子模型,而半空間分割法則將模型(2)分解為9個(gè)子模型,且本文算法分解結(jié)果更符合模型的特點(diǎn),即具有更強(qiáng)的語(yǔ)義性;雖然用半空間分割法分解模型(1),子模型數(shù)更少,但其分解結(jié)果的CSG 表示更復(fù)雜,需要添加輔助分割面。由表1 可知,在轉(zhuǎn)換時(shí)間上,本文算法也具明顯優(yōu)勢(shì),3 個(gè)模型均提速30%以上,且模型越復(fù)雜,提速效果越明顯。
圖14 測(cè)試分解結(jié)果展示Fig.14 Display of test results
用具有代表性的AP1000 裂變堆堆芯模型進(jìn)行測(cè)試(如圖3 所示)。AP1000 是我國(guó)引進(jìn)的由美國(guó)西屋公司設(shè)計(jì)的第3 代先進(jìn)反應(yīng)堆,其包含665 個(gè)B-Rep 模型,所有模型均為拉伸體,采用本文算法后,B-Rep→CSG 轉(zhuǎn)換時(shí)間由130 079 ms 降至7 781 ms,速度提升了39%。但由于此案例中的BRep 對(duì)象均較簡(jiǎn)單,尚難體現(xiàn)本文算法的優(yōu)勢(shì)。
本文算法的主要優(yōu)勢(shì)是降低了對(duì)布爾運(yùn)算的依賴,提高了算法的穩(wěn)定性。但因布爾運(yùn)算失敗具有偶然性,難以準(zhǔn)確復(fù)現(xiàn),本文尚無(wú)法用實(shí)驗(yàn)證明此優(yōu)勢(shì)。
半空間分割法是應(yīng)用最廣泛的B-Rep→CSG轉(zhuǎn)換算法之一,其核心是將B-Rep 模型分解為一組簡(jiǎn)單模型,在實(shí)現(xiàn)過(guò)程中,依賴三維造型引擎的布爾運(yùn)算,但因造型引擎的布爾運(yùn)算存在失敗概率,從而影響B(tài)-Rep→CSG 轉(zhuǎn)換算法的穩(wěn)定性,尤其對(duì)批量轉(zhuǎn)換軟件,不穩(wěn)定性會(huì)嚴(yán)重影響軟件的可用性和友好性。本文利用拉伸特征,將三維B-Rep 模型的B-Rep→CSG 轉(zhuǎn)換問(wèn)題轉(zhuǎn)變?yōu)槎S圖形的B-Rep→CSG 轉(zhuǎn)換問(wèn)題,從而降低對(duì)布爾運(yùn)算的依賴,提高轉(zhuǎn)換算法的穩(wěn)定性,同時(shí)提高了轉(zhuǎn)換算法的速度。
提出了基于拉伸邊的拉伸特征識(shí)別方法,通過(guò)觀察和總結(jié),得到拉伸邊的相互平行性、首尾相連性、方向相反性、唯一連接性4 個(gè)特征,在此基礎(chǔ)上提出基于平行邊連接圖的拉伸特征識(shí)別算法。在拉伸特征識(shí)別算法的基礎(chǔ)上,結(jié)合基于環(huán)收縮的模型分割算法和基于頂點(diǎn)可見(jiàn)的多邊形分解算法,實(shí)現(xiàn)了三維模型的B-Rep→CSG 轉(zhuǎn)換,并在cosVMPT軟件中進(jìn)行了測(cè)試,測(cè)試結(jié)果驗(yàn)證了算法的有效性和優(yōu)越性。
本文的拉伸特征識(shí)別算法依賴相互平行性、首尾相連性、方向相反性、唯一連接性等實(shí)踐經(jīng)驗(yàn),沒(méi)能對(duì)算法的完備性進(jìn)行嚴(yán)格證明,有待今后進(jìn)一步研究;另外,本文討論的是拉伸特征,在實(shí)踐中存在大量旋轉(zhuǎn)特征,將旋轉(zhuǎn)特征的三維問(wèn)題轉(zhuǎn)換為二維問(wèn)題,也有待下一步研究,以進(jìn)一步擴(kuò)大本文算法的應(yīng)用領(lǐng)域。