青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-4  評論-40  文章-117  trackbacks-0

  
     在進行圖形求交時,常常需要判定兩個圖形間是否有包含關系。如點是否包含在線段、平面區域、三維形體中,線段是否包含在平面區域、三維形體中,等等。許多包含判定問題可轉化為點的包含判定問題,如判斷線段是否在平面上可以轉化為判斷其兩端點是否在平面上。因此下面主要討論關于點的包含判定算法。

判斷點與線段的包含關系,也就是判斷點與線的最短距離是否位于容差范圍內。造型中常用的線段有三種:

(1)直線段,(2)圓錐曲線段(主要是圓弧),(3)參數曲線(主要是Bezier,B樣條與NURBS曲線)。點與面的包含判定也類似地分為三種情況。下面分別討論。

1、點與直線段的包含判定

假設點坐標為P(x, y, z),直線段端點為P1(x1, y1, z1),P2(x2,y2,z2),則點P到線段P1P2的距離的平方為

d2=(x-x1)2+(y-y1)2+(z-z1)2-[(x2-x1)(x-x1)+(y2-y1)(y-y1)+(z2-z1)(z-z1)]2/[(x2-x1)2+(y2-y1)2+(z2-z1)2]

當d2<a2時,認為點在線段(或其延長線)上,這時還需進一步判斷點是否落在直線段的有效區間內。只要對坐標分量進行比較,假設線段兩端點的x分量不等(否則所有分量均相等,那么線段兩端點重合,線段退化為一點),那么當x-x1與x-x2反號時,點P在線段的有效區間內。

2、點與圓錐曲線段的包含判定

以圓弧為例,假設點的坐標為(x, y, z),圓弧的中心為(x0, y0, z0),半徑為r,起始角a1,終止角a2。這些角度都是相對于局部坐標系x軸而言。圓弧所在平面為

    ax+by+cz+d=0

先判斷點是否在該平面上,若不在,則點不可能被包含。若在,則通過坐標變換,把問題轉換到二維的問題。

給定中心為(x0, y0),半徑為r,起始角a1,終止角a2的圓弧,對平面上一點P(x, y),判斷P是否在圓弧上,可分二步進行。第一步判斷P是否在圓心為(x0, y0),半徑為r的圓的圓周上,即下式是否成立:

    

第二步判斷P是否在有效的圓弧段內。

3、點與參數曲線的包含判定

設點坐標為P(x, y, z),參數曲線為Q(t)=(x(t), y(t), z(t))。點也參數曲線的求交計算包括三個步驟:

(1)計算參數t值,使P到Q(t)的距離最小;

(2)判斷t是否在有效參數區間內(通常為[0,1]);

(3)判斷Q(t)與P的距離是否小于a 。若(2),(3)步的判斷均為“是”,則點在曲線上;否則點不在曲線上。

第一步應計算t,使得|P-Q(t)|最小,

即 R(t)=(P-Q(t))(P-Q(t))=|P-Q(t)|2最小

根據微積分知識,在該處R'(t)=0即

Q'(t)[P-Q(t)]=0

用數值方法解出t值,再代入曲線參數方程可求出曲線上對應點的坐標。第(2)、(3)步的處理比較簡單,不再詳述。

4、點與平面區域的包含判定

設點坐標為P(x, y, z),平面方程為ax+by+cz+d=0。則點到平面的距離為

    d=

若d<a ,則認為點在平面上,否則認為點不在平面上。在造型系統中,通常使用平面上的有界區域作為形體的表面。在這種情況下,對落在平面上的點還應進一步判別它是否落在有效區域內。若點落在該區域內,則認為點與該面相交,否則不相交。下面以平面區域多邊形為例,介紹有關算法。

判斷平面上一個點是否包含在同平面的一個多邊形內,有許多種算法,這里僅介紹常用的三種:叉積判斷法、夾角之和檢驗法以及交點計數檢驗法。

(1)叉積判斷法

假設判斷點為P0。多邊形頂點按順序排列為P1P2…Pn。如圖2.5.2所示。令Vi=Pi-P0, i=1, 2, …, n, Vn+1=V1

那么,P0在多邊形內的充要條件是叉積ViXVi+1(i=1, 2, …, n)的符號相同。叉積判斷法僅適用于凸多邊形。當多邊形為凹時,盡管點在多邊形內也不能保證上述叉積符號都相同。這時可采用后面介紹的兩種方法。

2_5_2.gif (4875 bytes)

圖2.5.2 叉積判斷法

(2)夾角之和檢驗法

假設某平面上有點P0和多邊形P1P2P3P4P5,如圖2.5.3所示。將點P0分別與Pi相連,構成向量Vi=P-P0。假設角 PiP0Pi+1=ai。如果=0,則點P0在多邊形之外,如圖2.5.3(a)所示。如果=2π,則點P0在多邊形之內,如圖2.5.3(b)所示。ai可通過下列公式計算:令Si=Vi? Vi+1, Ci=Vi·Vi+1,則tg(ai)=Si/Ci,所以ai=arctg(Si/Ci)且

ai的符號即代表角度的方向。

2_5_3.gif (5201 bytes)

圖2.5.3 夾角之和檢驗法

在多邊形邊數不太多(<44)的情況下,可以采用下列近似公式計算ai

    當 |Si|≤|Ci|

  當 |Si|>|Ci|

其中d=0.0355573為常數。當Σαi≥π

時,可判P0在多邊形內。當Σαi<π 時,可判P0在多邊形外。證明略。

(3)交點計數檢驗法

當多邊形是凹多邊形,甚至還帶孔時,可采用交點計數法判斷點是否在多邊形內。具體做法是,從判斷點作一射線至無窮遠:

求射線與多邊形邊的交點個數。若個數為奇數,則點在多邊形內,否則,點在多邊形外。

如圖2.5.4所示,射線a, c分別與多邊形交于二點和四點,為偶數,故判斷點A,C在多邊形外。而射線b, d與多邊形交三點和一點,為奇數,所以B,D在多邊形內。

當射線穿過多邊形頂點時,必須特殊對待。如圖2.5.4所示,射線f過頂點,若將交點計數為2,則會錯誤地判斷F在多邊形外。但是,若規定射線過頂點時,計數為1,則又會錯誤地判斷點E在多邊形內。正確的方法是,若共享頂點的兩邊在射線的同一側,則交點計數加2,否則加1。按這種方法,E點計為2,所以在多邊形外;F點計數為1,所以在多邊形內。讀者可以自己另取一些點來驗證。

2_5_4.gif (3218 bytes)

圖2.5.4 交點計數法

5、點與二次曲面/參數曲面的包含判定

假設點坐標為P(x0, y0, z0),二次曲面方程為Q(x, y, z)=0,則當|Q(x0, y0, z0)|<? 時,認為點在該二次曲面上,在造型系統中,通常使用裁剪的二次曲面。在這種情況下,還要判斷點是否在有效范圍內。裁剪的二次曲面通常用有理Bezier或有理B樣條的參數空間上的閉合曲線來定義曲面的有效范圍,故要把點所對應的參數空間的參數坐標計算出來,再判斷該參數坐標是否在參數空間有效區域上。

6、點與三維形體的包含判定

判斷點是否被三維形體所包含,可先用前面的方法判斷點是否在三維形體的表面上,然后判斷點是否在形體內部,其方法因形體不同而異。下面以凸多面體為例說明。

設凸多面體某個面的平面方程為ax+by+cz+d=0,調整方程系數的符號,使當ax+by+cz+d<0時,點(x,y,z)位于該平面兩側中包含該凸多面體的一側。于是要檢驗一個點是否在凸多面體內部,只要檢驗是否它對凸多面體的每一個面均滿足以上的不等式即可。

posted on 2007-12-09 20:26 李陽 閱讀(4363) 評論(0)  編輯 收藏 引用 所屬分類: 算法

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久综合中文字幕| 久久久久国产精品一区三寸| 亚洲二区免费| 久久综合狠狠综合久久激情| 黑丝一区二区| 亚洲国产精品久久久| 欧美成年人视频网站| 99精品久久| 亚洲伊人久久综合| 国产午夜精品久久久久久久| 六月婷婷久久| 欧美伦理a级免费电影| 亚洲欧美国产另类| 欧美尤物巨大精品爽| 在线观看国产一区二区| 亚洲人成小说网站色在线| 欧美日韩一区在线播放| 久久精品91久久久久久再现| 久久亚洲国产精品一区二区| 一本色道久久综合狠狠躁篇怎么玩 | 99国内精品久久| 一区二区欧美日韩| 在线观看91精品国产入口| 亚洲精品一二三区| 国产综合av| 亚洲美女av网站| 国产午夜精品久久| 亚洲激情在线播放| 国产一区二区三区日韩| 最新亚洲激情| 激情综合视频| 亚洲图片欧洲图片av| 亚洲国产黄色片| 亚洲欧美伊人| 中日韩在线视频| 久久夜色精品国产| 亚洲欧美日韩国产中文| 免费观看欧美在线视频的网站| 亚洲欧美高清| 欧美精品九九99久久| 久久久九九九九| 国产精品99免费看| 亚洲国产精品成人va在线观看| 国产日韩精品一区二区| 一级日韩一区在线观看| 伊人色综合久久天天五月婷| 亚洲影院免费观看| 这里只有精品视频在线| 免费久久久一本精品久久区| 久久精品成人| 国产精品视频一区二区高潮| 亚洲日本va午夜在线影院| 亚洲国产精品悠悠久久琪琪| 欧美一级午夜免费电影| 欧美一区二区成人| 国产精品video| 日韩一级片网址| av不卡在线看| 欧美精品色一区二区三区| 欧美高清视频一区二区| 伊人久久婷婷| 久久亚洲风情| 欧美成人精品一区二区| 亚洲高清一二三区| 女主播福利一区| 欧美国产一区二区在线观看| 亚洲大胆av| 久久久九九九九| 老司机亚洲精品| 亚洲国产成人av好男人在线观看| 久久九九全国免费精品观看| 久久久精品性| 亚洲国产精品第一区二区三区| 久久天天躁狠狠躁夜夜av| 美女爽到呻吟久久久久| 亚洲电影免费观看高清完整版在线观看| 久久高清国产| 欧美阿v一级看视频| 亚洲精品久久久久久一区二区| 欧美91精品| av成人毛片| 欧美亚洲日本国产| 狠狠色综合网| 欧美电影在线观看完整版| 亚洲激情av在线| 午夜精品福利在线| 韩国成人福利片在线播放| 久久综合伊人77777| 亚洲人体1000| 欧美亚洲午夜视频在线观看| 黑丝一区二区三区| 欧美日韩aaaaa| 午夜久久久久久| 欧美激情欧美激情在线五月| 国产精品99久久久久久久久久久久| 国产精品xxxav免费视频| 性欧美超级视频| 亚洲国产成人av好男人在线观看| 亚洲亚洲精品在线观看 | 欧美理论在线播放| 亚洲网址在线| 亚洲第一中文字幕在线观看| 亚洲一区免费| 在线欧美日韩精品| 国产精品五区| 免费一级欧美片在线播放| 亚洲午夜女主播在线直播| 久久综合九色九九| 亚洲一区二区av电影| 精品不卡视频| 国产精品免费在线| 欧美顶级艳妇交换群宴| 性色av一区二区三区在线观看| 亚洲级视频在线观看免费1级| 欧美一区二区三区视频免费播放| 亚洲国产精品综合| 国内成人在线| 国产精品免费一区二区三区在线观看 | 欧美日韩精品一区| 久久久久欧美精品| 中国成人在线视频| 亚洲国内自拍| 欧美成人免费小视频| 久久精品视频va| 亚洲亚洲精品三区日韩精品在线视频| 在线观看欧美日本| 国产日韩欧美在线观看| 欧美日韩一区二区免费在线观看| 久久综合狠狠| 久久国产一二区| 亚洲欧洲99久久| 亚洲一区亚洲| 亚洲午夜一区二区| 91久久在线| 亚洲激情网址| 亚洲电影成人| 亚洲国产精品久久久久秋霞不卡| 久久综合九色综合欧美就去吻 | 一区二区在线视频| 国产偷国产偷精品高清尤物| 国产精品青草久久| 国产精品欧美一区喷水| 国产精品久在线观看| 国产精品久久久久免费a∨| 国产精品黄色| 国产精品一区二区三区四区五区| 国产精品久久久| 国产精品网站在线播放| 国产精品一区二区女厕厕| 国产麻豆91精品| 国内精品国产成人| 一区二区三区自拍| 亚洲欧洲精品一区二区| 91久久精品美女高潮| 亚洲国产乱码最新视频| 日韩视频精品在线观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 欧美激情视频在线免费观看 欧美视频免费一 | 欧美一区91| 久久精品亚洲热| 美日韩精品免费| 欧美精品自拍| 国产精品美女黄网| 国产综合久久久久久鬼色| 在线精品观看| 日韩亚洲一区二区| 午夜精品久久久久久久99黑人| 香蕉久久国产| 免费观看成人www动漫视频| 亚洲国产第一页| 亚洲一卡久久| 久久九九久精品国产免费直播| 美女91精品| 国产精品v欧美精品v日韩| 国产精品毛片| 伊人久久av导航| 一本色道久久综合亚洲精品小说 | 影音先锋中文字幕一区| 亚洲精品久久久久久久久久久久| 亚洲深夜av| 久久九九热re6这里有精品| 欧美激情视频给我| 亚洲字幕一区二区| 欧美不卡在线| 国产日韩一级二级三级| 亚洲精品国精品久久99热一| 欧美一区二区福利在线| 亚洲第一二三四五区| 亚洲永久免费| 欧美高清视频www夜色资源网| 国产精品视频xxx| 亚洲人成毛片在线播放| 欧美一区二区黄色| 亚洲精品乱码久久久久久| 欧美中文字幕在线观看| 欧美视频网址| 亚洲人成在线播放| 久久免费黄色| 亚洲欧美清纯在线制服| 欧美激情网友自拍|