這些步驟應(yīng)用于計(jì)算云邊界 點(diǎn)的位置。步驟Ul至Ull應(yīng)用于在步驟M6算出的每一單獨(dú)的邊界多邊形。應(yīng)指出,在步 驟U4和U8規(guī)定的節(jié)點(diǎn)A和B可以在步驟M6存儲(chǔ)或者可通過(guò)比較邊界多邊形中前一邊緣 與下一邊緣的頂點(diǎn)推導(dǎo)得出。
[0143] UL將當(dāng)前邊緣設(shè)定為邊界多邊形中的第一邊緣。
[0144] U2.將當(dāng)前立方體設(shè)定為當(dāng)前邊緣所在的立方體。在跟蹤邊界多邊形時(shí),已在步驟 10存儲(chǔ)任一邊緣所在立方體的標(biāo)識(shí)。立方體是面立方體集合的成員。
[0145] U3.將居首的邊緣設(shè)定為當(dāng)前邊緣。
[0146] U4.將P設(shè)定為當(dāng)前邊緣的A節(jié)點(diǎn)。
[0147] U5.若當(dāng)前邊緣未邊界多邊形中的最后一邊緣,則轉(zhuǎn)至步驟U8。
[0148] U6.從邊界多邊形獲取下一邊緣。
[0149] U7.若下一邊緣位于當(dāng)前立方體中,則將當(dāng)前邊緣設(shè)定為下一邊緣,轉(zhuǎn)至步驟U6。 在跟蹤邊界多邊形時(shí),已在步驟10存儲(chǔ)任一邊緣所在立方體的標(biāo)識(shí)。重復(fù)步驟U6和U7,直 至當(dāng)前邊緣為當(dāng)前立方體中的最后一邊緣。
[0150] U8.將Q設(shè)定為當(dāng)前邊緣的B節(jié)點(diǎn)。
[0151] U9.將云邊界點(diǎn)設(shè)定為到線PQ的有向距離最大的投影點(diǎn)云點(diǎn)。利用步驟Y4的公 式將點(diǎn)云點(diǎn)投射至平面。可通過(guò)dk= V T(p(k)_q)計(jì)算投影點(diǎn)p(k)的有向距離d k,其中q為 線PQ中的任意點(diǎn)(最簡(jiǎn)單為P或Q),其中V是到PQ的法線,位于公共面內(nèi)并具單位長(zhǎng)度。 應(yīng)指出,-V同樣滿足這些條件。通過(guò)測(cè)定4對(duì)當(dāng)前正交多邊形的任意頂點(diǎn)(同樣也是邊界 多邊形的頂點(diǎn))非負(fù)以及4對(duì)任何其他頂點(diǎn)非正,做出對(duì)V和-V的正確選擇。相交多邊 形始終存在至少一個(gè)d k在其上非零的頂點(diǎn),從而其標(biāo)志可以得到區(qū)分。步驟U9的幾何圖 形如圖17至19所示。在這三個(gè)附圖中,相交多邊形為PCQBA,邊界多邊形的邊緣為QB、BA 和AP。唯有頂點(diǎn)C并不位于邊界多邊形上。如圖所示,法向量V指向dk必然增大的方向。 由陰影部分表示點(diǎn)云。使有向距離最大化的投影點(diǎn)云點(diǎn)標(biāo)記為X,KL是穿過(guò)X并平行于PQ 的線。
[0152] U10.若在相交多邊形內(nèi)還有其他投影點(diǎn)云點(diǎn)接近穿過(guò)云邊界點(diǎn)且平行于PQ的直 線,則將云邊界點(diǎn)設(shè)定為充分接近穿過(guò)在步驟U9中算出的云邊界點(diǎn)位置的平行線的全部 投影點(diǎn)云點(diǎn)的平均數(shù)。在此,"充分接近"意指全部投影點(diǎn)云點(diǎn)到平行線的距離小于特定公 差,其所占比例很小,如分辨率的四分之一或十分之一。步驟UlO的幾何圖形如圖19所示, 其中KL為投影點(diǎn)云的邊緣。假設(shè)點(diǎn)云點(diǎn)均勻分布,則在PCQBA內(nèi)充分接近KL的點(diǎn)的平均 點(diǎn)大約會(huì)在X。
[0153] UlL若當(dāng)前邊緣并非邊界多邊形中的最后一邊緣,則將當(dāng)前邊緣設(shè)定為邊界多邊 形中的下一邊緣,轉(zhuǎn)至步驟U2,反之則停止。
[0154] 圖9是步驟M8的流程圖,具體示出步驟Vl至V14,這些步驟應(yīng)用于將云邊界點(diǎn)移 至成對(duì)公共面之間的交線。
[0155] VI.創(chuàng)建全部面立方體集合的公共面的列表。該列表包含公共面的法向量及平均 值。
[0156] V2.若公共面列表為空,則停止。
[0157] V3.將當(dāng)前面設(shè)定為公共面列表中的第一公共面。
[0158] V4.將當(dāng)前云邊界點(diǎn)設(shè)定為當(dāng)前面中的第一云邊界點(diǎn)。為進(jìn)行步驟M8,云邊界點(diǎn) 可以任意次序列出。特別地,與不同邊界多邊形相關(guān)的云邊界點(diǎn)毋須存在區(qū)別。
[0159] V5.將最小距離設(shè)定為無(wú)窮。在此,"無(wú)窮"意指任意絕對(duì)大于云邊界點(diǎn)與任意公 共面間距離的正數(shù)。無(wú)窮的適當(dāng)值為10至30次冪。
[0160] V6.將相鄰面設(shè)定為公共面列表中的第一公共面。
[0161] V7.若相鄰面與當(dāng)前面相同,則轉(zhuǎn)至步驟VII。
[0162] V8.若當(dāng)前與相鄰面的法向量間的角度充分?。ㄈ缧∮?度),則轉(zhuǎn)至步驟VII。 該測(cè)試的目的在于,防止意圖計(jì)算近乎平行平面的相交處。
[0163] V9.將當(dāng)前云邊界點(diǎn)投射至相鄰面上,更確切而言,將其投射至由當(dāng)前及相鄰面相 交形成的直線上。將當(dāng)前云邊界點(diǎn)x(k)投射至點(diǎn)
[0164]
[0165] 該點(diǎn)位于由以下兩個(gè)公共面相交形成的直線上,
[0166]
[0167] 其中 a = [u⑴]T(u(i)),於,廣)]、山-戶0)且 A (,-
[0168] 在幾何圖形上,p(k)是直線上到x(k)的最近點(diǎn)。應(yīng)指出,兩個(gè)法向量u (1)和u(D須 具單位長(zhǎng)度。
[0169] V10.若當(dāng)前云邊界點(diǎn)與其投影處之間的距離D小于最小距離,則將最小距離設(shè)定 為D并將最佳投影點(diǎn)設(shè)定為當(dāng)前投影點(diǎn)。
[0170] VlL若相鄰面并非公共面列表中的最后一面,則將相鄰面設(shè)定為公共面列表中的 下一面,轉(zhuǎn)至步驟V7。
[0171] V12.若最小距離充分小,則將當(dāng)前云邊界點(diǎn)的位置移至最佳投影點(diǎn)的位置,轉(zhuǎn)至 步驟V13。在此,"充分小"意指所占比例很小,如分辨率的四分之一或十分之一。在表示幾 何圖形的圖20中,ABCD是特定面立方體集合的公共面,DCFE和ADEG是兩個(gè)沿DC和AD相 交于ABCD的鄰近面立方體集合的公共面。短劃線MN和KL平行于DC和AD且表明視為充 分接近交線的點(diǎn)的距離。點(diǎn)? 112、?3和?4是云邊界點(diǎn)的示例位置。?2和? 4到〇(:的距離充 分小,從而將其移至其投影處QjPQ 4上。云邊界點(diǎn)P :充分接近DC和AD。然而,其更接近 AD,由此將其移至Q1。與之相反,P2并未充分接近任何相交處,由此并未移動(dòng)。
[0172] V13.若當(dāng)前云邊界點(diǎn)并非當(dāng)前面的云邊界點(diǎn)列表中最后一云邊界點(diǎn),則將當(dāng)前云 邊界點(diǎn)設(shè)定為列表中的下一云邊界點(diǎn),轉(zhuǎn)至步驟V5。
[0173] V14.若當(dāng)前面并非公共面列表中的最后一面,則將當(dāng)前面設(shè)定為公共面列表中的 下一面,轉(zhuǎn)至步驟V3。反之則停止。
[0174] 圖10是表示步驟Wl至W24的流程圖,其形成與公共直線(稱為公共線)相交 的連續(xù)共線立方體的集合。以這種方式形成的共線立方體的每一集合均稱為線立方體 集合。計(jì)算累加線立方體集合中點(diǎn)的數(shù)目《ζΣ"/?其中ηι是共線立方體1中點(diǎn)的數(shù) 目。計(jì)算還累加點(diǎn)云點(diǎn)的總數(shù)p Σ w,其中#}=? f>且外積的和妒=Σ %,其中 7 /碎 1 /
并且在這兩種情況下,總和為線立方體集合內(nèi)全部共線立方體1中的 ,Α·=1 全部點(diǎn)云點(diǎn),其中χ(Μ)= (Xkl,Ykl,Zkl)是共線立方體1中的第k個(gè)點(diǎn)云點(diǎn)。
[0175] 可通過(guò)
f算出線立方體集合內(nèi)全部共線立方體中點(diǎn)云點(diǎn) 的平均值$及協(xié)方差矩陣V。
[0176] 同理,可通i3j
1 十算出共線立方體1中點(diǎn)云點(diǎn) 的平均值及協(xié)方差矩陣V(I)。
[0177] 在穿過(guò)共線立方體1中全部點(diǎn)云點(diǎn)的數(shù)學(xué)線上的任意點(diǎn)X均可寫為 λ- = #1+??#,其中α是標(biāo)量參數(shù),其中u(1)是對(duì)應(yīng)于協(xié)方差矩陣V(1)的唯一最大特征值的 協(xié)方差矩陣V (1)的特征向量并且在用于計(jì)算V (1)的特征向量時(shí)通過(guò)雅可比方法作為附帶結(jié) 果算出。
[0178] 同理,在穿過(guò)面立方體集合的全部立方體中全部點(diǎn)云點(diǎn)的數(shù)學(xué)面上的任意點(diǎn)均可 寫為X = If O?,其中u是垂直于公共線的單位向量,其等于對(duì)應(yīng)于協(xié)方差矩陣V的唯一最 大特征值的累加協(xié)方差矩陣V的特征向量并且可通過(guò)雅可比方法算出。在步驟W14及W21, 所述方法將當(dāng)前累加的線立方體集合中的數(shù)學(xué)直線與擬合穿過(guò)當(dāng)前共線立方體1的線相 比較,以確定兩直線是否本身共線。在這兩個(gè)步驟中使用不同標(biāo)準(zhǔn)。
[0179] 標(biāo)準(zhǔn)A用于步驟W14且規(guī)定uTu(1)> cos Θ。,其確保兩平面間的角度小于Θ?;《龋?并規(guī)定-幻I < 4,其確保平均值#?的距離小于山距離單位。在此,標(biāo)準(zhǔn)A等同于在 步驟B14中所用的標(biāo)準(zhǔn)A,只不過(guò)此處u為公共線上的向量,而非公共面的法向量。可以該 角度重新解讀圖13。
[0180] 標(biāo)準(zhǔn)C用于步驟W21并規(guī)定
[0181]
[0182] 其確保共線立方體1中每一點(diǎn)x(M)到公共線的平均平方距離均小于d2距離單位。
[0183] WL創(chuàng)建未使用的立方體列表,其包含在步驟M2中標(biāo)識(shí)的全部共線立方體。在該 列表中的任意立方體均稱為未使用立方體。
[0184] W2.若未使用列表為空,則停止。
[0185] W3.創(chuàng)建稱作線立方體集合的空白立方體列表。該線立方體集合將擴(kuò)展為包含由 公共直線相交的全部共線立方體。最終,當(dāng)前處于未使用立方體列表中的各立方體均將移 至線立方體集合中,即便在該線立方體集合僅包含唯一立方體的情況下亦然。
[0186] W4.將當(dāng)前立方體設(shè)定為未使用列表中的第一立方體。
[0187] W5.創(chuàng)建稱作候選列表的空白立方體列表。該列表會(huì)包含視為納入線立方體集合 的候補(bǔ)者的未使用共線立方體。
[0188] W6.創(chuàng)建稱作特殊列表的空白立方體列表。該列表會(huì)包含新近拒為納入線立方體 集合的候補(bǔ)者的未使用共線立方體。
[0189] W7.將當(dāng)前立方體從未使用列表移入線立方體集合。因而,各線立方體集合均包含 至少一個(gè)立方體。
[0190] W8.將線立方體集合中點(diǎn)的總數(shù)設(shè)定為等于當(dāng)前立方體中點(diǎn)的總數(shù)。
[0191] W9.將線立方體集合中點(diǎn)的外積和設(shè)定為等于當(dāng)前立方體中點(diǎn)的外積和。
[0192] W10.將未使用列表中的當(dāng)前立方體的全部相鄰立方體都添加至候補(bǔ)列表。在此, 若立方體與當(dāng)前立方體共享表面或頂點(diǎn),則其即為當(dāng)前立方體的相鄰者。
[0193] WlL若候補(bǔ)列表為空,則轉(zhuǎn)至步驟W18。
[0194] W12.將當(dāng)前立方體設(shè)定為候補(bǔ)列表中的第一立方體。
[0195] W13.將當(dāng)前立方體移出候補(bǔ)列表。
[0196] W14.若當(dāng)前立方體并未達(dá)到標(biāo)準(zhǔn)A,則將該當(dāng)前立方體添加至特殊列表,轉(zhuǎn)至步 驟 W11。
[0197] W15.將當(dāng)前立方體從未使用列表移至線立方體集合。
[0198] W16.將當(dāng)前立方體1中點(diǎn)的總數(shù)S1添加至線立方體集合中點(diǎn)的累加和s。
[0199] W17.將當(dāng)前立方體1中點(diǎn)的外積和W1添加至線立方體集合中點(diǎn)的外積的累加和 W,轉(zhuǎn)至步驟WlO。
[0200] W18.若特殊列表為空,則輸出線立方體集合的數(shù)據(jù),轉(zhuǎn)至步驟W2。
[0201] W19.將當(dāng)前立方體設(shè)定為特殊列表中的第一立方體。
[0202] W20.將當(dāng)前立方體移出特殊列表。
[0203] W21.若當(dāng)前立方體并未達(dá)到標(biāo)準(zhǔn)C,則轉(zhuǎn)至步驟W18。
[0204] W22.將當(dāng)前立方體從未使用列表移至線立方體集合。
[0205] W23.將當(dāng)前立方體1中點(diǎn)的總數(shù)