• <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>

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            OpenCASCADE Rational Bezier Curves

            Posted on 2014-09-19 19:30 eryar 閱讀(2820) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE
            OpenCASCADE Rational Bezier Curves

            eryar@163.com

            Abstract. Although polynomials offer many advantages, there exist a number of important curve and surface types which cannot be represented precisely using polynomials, e.g., circles, ellipses, hyperbolas, cylinders, cones, spheres, etc. So we introduce the concepts of rational curves and homogeneous coordinates to solve the problem. To understand rational curves in a homogenous coordinate system is more straightforward. If you define irrational Bezier curves in 4D space and then project them back into 3D space, you obtain rational curves.

            Key Words. OpenCASCADE, Rational Curves, Homogenous Coordinate, Geom_BezierCurve

            1. Introduction

            由于采用了Berstein基函數(shù),Bezier曲線具有許多良好的性質(zhì)。但是作為多項(xiàng)式曲線,在表示一些“基本”曲線時(shí)還是有所不足。例如半徑為1的圓弧曲線,其參數(shù)方程可表示為:

            wps_clip_image-13132

            圓弧曲線并不是多項(xiàng)式曲線,所以Bezier曲線不可能精確表示像圓弧這樣的簡(jiǎn)單曲線。經(jīng)過(guò)參數(shù)變換t=tan(u/2),可以把上面的圓弧表示為:

            wps_clip_image-3401

            這說(shuō)明可以用有理多項(xiàng)式來(lái)精確表示圓弧曲線。事實(shí)上,有很多重要的曲線、曲面類型,如圓、橢圓、雙曲線、圓柱面、圓錐面、球面等,都無(wú)法用Bezier來(lái)精確表示。由經(jīng)典數(shù)學(xué)可知,包括圓在內(nèi)的所有二次曲線都可以用有理函數(shù)(即兩個(gè)多項(xiàng)式相除)來(lái)表示,即如下形式的有理函數(shù)來(lái)表示:、

            wps_clip_image-9943

            本文主要從齊次坐標(biāo)的表示法上來(lái)理解有理Bezier曲線的概念,及結(jié)合OpenCASCADE中的Bezier曲線來(lái)理解權(quán)因子的幾何意義。


            2. Homogeneous Coordinates

            在《計(jì)算幾何》、《計(jì)算機(jī)圖形學(xué)》或《計(jì)算機(jī)輔助幾何造型技術(shù)》等書中,都會(huì)給出有理曲線的齊次坐標(biāo)(Homogeneous Coordinates)表示法,藉此來(lái)從幾何上直觀理解有理曲線的意義。剛開始接觸齊次坐標(biāo)的概念時(shí),很不能理解,原來(lái)這是射影幾何中的一些概念。對(duì)此概念陌生的讀者可以參考丘維聲的《解析幾何》,其中對(duì)齊次坐標(biāo)、交比等概念作了詳細(xì)解釋。

            現(xiàn)在我們來(lái)說(shuō)明齊次坐標(biāo)與仿射坐標(biāo)的關(guān)系。設(shè)點(diǎn)M是平面wps_clip_image-30986上的通常點(diǎn),(x,y)是它對(duì)于標(biāo)架[O1:e1,e2]的仿射坐標(biāo),則wps_clip_image-9613對(duì)于標(biāo)架[O2:e1,e2,e3]的坐標(biāo)就是(x,y,1),于是點(diǎn)M的齊次坐標(biāo)(x1,x2,x3)與(x,y,1)成比例:

            wps_clip_image-30625

            其中λ≠0.從而得:

            wps_clip_image-30653

            因此,通常點(diǎn)的齊次坐標(biāo)和仿射坐標(biāo)可以互相確定。有時(shí)我們把通常點(diǎn)M的仿射坐標(biāo)(x,y)稱為它的非齊次坐標(biāo)。

            從四維Euclidean空間的齊次坐標(biāo)到三維Euclidean空間的中心投影變換

            wps_clip_image-23761

            這里三維空間的點(diǎn)[X,Y,Z]稱為四維空間點(diǎn)[X,Y,Z,ω]的透視像,就是四維空間點(diǎn)[X,Y,Z,ω]在ω=1超平面上的中心投影,其投影中心就是四維空間的坐標(biāo)原點(diǎn)。因此四維空間點(diǎn)[X,Y,Z,ω]與三維空間點(diǎn)[X,Y,Z]被認(rèn)為是同一點(diǎn)。事實(shí)上,對(duì)任意X,Y,Z,ω1,ω2,其中ω1≠ω2,有:

            wps_clip_image-25607

            由上可知:一個(gè)點(diǎn)的齊次坐標(biāo)不是唯一的。

            在CAGD中描述形狀的空間曲線與曲面都要用到三維空間。但是人類思維能力的限制,我們無(wú)法用圖形或模型來(lái)表達(dá)從四維空間到三維空間的投影變換關(guān)系。為了理解這種投影變換的幾何關(guān)系,我們可以降低一維,考察從三維到二維空間的投影變換,如下圖所示為三維空間的齊次坐標(biāo)到二維空間的投影。

            wps_clip_image-14079

            Figure 2.1 A representation of Euclidean points to homogeneous form

            關(guān)于中心投影、射影平面、齊次坐標(biāo)、變比等概念,可參考丘維聲的《解析幾何》一書。


            3. Bezier Curve Perspective Map

            在理解射影變換(Perspective Map)及齊次坐標(biāo)的概念后,可以構(gòu)造有理Bezier曲線的幾何模型。現(xiàn)假設(shè)給定控制點(diǎn){Pi},權(quán)因子{ωi},我們構(gòu)造帶權(quán)控制點(diǎn):

            wps_clip_image-8316

            然后在四維空間中定義非有理(即多項(xiàng)式)Bezier曲線:

            wps_clip_image-10313

            將帶權(quán)控制點(diǎn)代入上式詳細(xì)寫出每一項(xiàng)得:

            wps_clip_image-16840

            以原點(diǎn)為中心,將四維的Bezier曲線投影到ω=1的三維超平面上,所得到的投影曲線為:

            wps_clip_image-10635

            消去λ即得到有理Beizer曲線:

            wps_clip_image-16557 

            4. The Effects of Weighting Factors

            有理Bezier曲線除了具有類似于Bezier曲線的性質(zhì)外,還增加了關(guān)于“權(quán)因子”(Weights)的調(diào)整性質(zhì)。

            4.1 可退化性

            當(dāng)權(quán)因子ωi=ω≠0時(shí)(i=0,1,...,n),有理Bezier曲線退化成Bezier曲線。因?yàn)?#969;相同,所以有理Bezier曲線公式中的ω可以消去,又根據(jù)Bernstein基函數(shù)的規(guī)范性即得。使用OpenCASCADE的Tcl腳本測(cè)試效果如下圖所示:

            wps_clip_image-3697

            Figure 4.1 Degeneracy of Rational Bezier Curve

            相應(yīng)的Tcl腳本如下所示:

             

            #
            #    Copyright (c) 2014 eryar All Rights Reserved.
            #
            #        File    : degenerate.tcl
            #        Author  : eryar@163.com
            #        Date    : 2014-09-19 18:10
            #        Version : 1.0v
            #
            #    Description : Demonstrate the degeneracy of Rational Bezier Curve.
            #


            pload ALL

            # Bezier Curve with Weighted Poles: 
            # {P(1,0), w(1)}, {P(1,1), w(1)}, {P{0,1}, w(1)}

            2dbeziercurve bc1 3 1 0 1 1 1 1 0 1 1

            v2d
            2dfit

            # Bezier Curve without weights:
            2dbeziercurve bc2 3 1 0 1 1 0 1
            mkedge e1 bc2 
            0 1

            vdisplay e1
            vtop
            vfit

            上述Tcl腳本中先把權(quán)值相同的有理Bezier曲線顯示在二維窗口中,再將不帶權(quán)的Bezier曲線(控制節(jié)點(diǎn)與帶權(quán)值相同),先生成Edge,再在三維窗口中顯示出來(lái)。由圖可知,當(dāng)有理Bezier曲線的權(quán)值相同時(shí),即退化為非有理的Bezier曲線。

            4.2 當(dāng)ω0≠0,ωn≠0時(shí),對(duì)任意u∈[0,1],

            wps_clip_image-12378

            只需證明u∈[0,1]的情況,

            wps_clip_image-6898

            這說(shuō)明只要ω0≠0,ωn≠0,有理Bezier曲線R(u)一定通過(guò)首末控制頂點(diǎn)P0和Pn。對(duì)u∈[0,1],當(dāng)ωi越大,R(u)越趨向于Pi;反之,當(dāng)ωi越小,R(u)越遠(yuǎn)離Pi。

            可以看出ωi→∞的極限狀態(tài)時(shí),R(u)即過(guò)通過(guò)Pi。使用OpenCASCADE的Tcl腳本來(lái)驗(yàn)證得到如下圖所示結(jié)果:

            wps_clip_image-21596

            Figure 4.2 Rational Bezier Curve with different Weights

            相應(yīng)的Tcl腳本如下所示:

             

            #
            #    Copyright (c) 2014 eryar All Rights Reserved.
            #
            #        File    : degenerate.tcl
            #        Author  : eryar@163.com
            #        Date    : 2014-09-19 18:10
            #        Version : 1.0v
            #
            #    Description : Demonstrate the Rational Bezier Curve with different weights.
            #


            pload ALL

            set w1 
            0.1
            set w2 
            0.5
            set w3 
            1.0
            set w4 
            2.0
            set w5 
            5.0

            set u 
            0.5

            # 4 Bezier Curve with defferent Weighted Poles: 
            # {P(1,0), w(1)}, {P(1,1), w($w)}, {P{0,1}, w(1)}

            2dbeziercurve bc1 3 1 0 1 1 1 $w1 0 1 1
            2dbeziercurve bc2 
            3 1 0 1 1 1 $w2 0 1 1
            2dbeziercurve bc3 
            3 1 0 1 1 1 $w3 0 1 1
            2dbeziercurve bc4 
            3 1 0 1 1 1 $w4 0 1 1
            2dbeziercurve bc5 
            3 1 0 1 1 1 $w5 0 1 1

            # mark weight factor.
            2dcvalue bc1 $u x1 y1
            2dcvalue bc2 
            $u x2 y2
            2dcvalue bc3 
            $u x3 y3
            2dcvalue bc4 
            $u x4 y4
            2dcvalue bc5 
            $u x5 y5

            dtext x1 y1 w1
            =$w1
            dtext x2 y2 w2
            =$w2
            dtext x3 y3 w3
            =$w3
            dtext x4 y4 w4
            =$w4
            dtext x5 y5 w5
            =$w5

            v2d
            2dfit

            上述代碼顯示了一條三個(gè)控制頂點(diǎn)2次的有理Bezier曲線當(dāng)控制頂點(diǎn)P(1,1)對(duì)應(yīng)的權(quán)因子ω變化時(shí)的不同的情況。當(dāng)ω增大時(shí),導(dǎo)致曲線被拉向控制頂點(diǎn);當(dāng)ω減小時(shí),導(dǎo)致曲線被推離控制頂點(diǎn)。當(dāng)ω趨于無(wú)窮大時(shí),此時(shí)曲線將退化為與控制頂點(diǎn)重合的一個(gè)點(diǎn)。

            5. Bezier Geometry Curve

            OpenCASCADE中的Bezier曲線Geom_BezierCurve本身就是有理Bezier曲線,且都是基于BSplCLib包實(shí)現(xiàn)的。即有理Beizer曲線也是NURBS曲線的特例。如下圖所示:

            wps_clip_image-15867

            當(dāng)構(gòu)造函數(shù)只有控制頂點(diǎn)時(shí),將會(huì)構(gòu)造一個(gè)非有理的Beizer曲線。當(dāng)構(gòu)造函數(shù)將控制頂點(diǎn)對(duì)應(yīng)的權(quán)因子也設(shè)置進(jìn)來(lái)時(shí),將會(huì)構(gòu)造一個(gè)有理Bezier曲線。當(dāng)構(gòu)造有理Beizer曲線時(shí),若控制頂點(diǎn)的所有權(quán)值都相同,則認(rèn)為是非有理Bezier曲線,即退化性質(zhì)的體現(xiàn)。

            6. Conclusion

            綜上所述,由齊次坐標(biāo)表示法來(lái)理解有理Bezier曲線的概念還是比較直觀的,進(jìn)而可以去理解NURBS曲線曲面的概念。

            有理Beizer曲線與非有理Bezier曲線的區(qū)別就是權(quán)因子。若控制點(diǎn)對(duì)應(yīng)的權(quán)因子都相同時(shí),有理Beizer曲線退化為非有理Bezier曲線。且權(quán)因子的值越大,則曲線越接近對(duì)應(yīng)的控制頂點(diǎn)。權(quán)因子對(duì)曲線還有很多重要性質(zhì),讀者可以參考其他相關(guān)書籍。

            OpenCASCADE中的Beizer曲線是基于BSplCLib包實(shí)現(xiàn)的,即是NURBS曲線的特例。所以可以表示有理有非有理的Bezier曲線。

            7. References

            1. 數(shù)學(xué)手冊(cè)編寫組. 數(shù)學(xué)手冊(cè). 高等教育出版社. 1979

            2. 丘維聲. 解析幾何. 北京大學(xué)出版社. 1996

            3. 蘇步青,劉鼎元. 計(jì)算幾何. 上海科學(xué)技術(shù)出版社. 1981

            4. 蘇步青,華宣積. 應(yīng)用幾何教程. 復(fù)旦大學(xué)出版社. 2012

            5. 莫蓉,常智勇. 計(jì)算機(jī)輔助幾何造型技術(shù). 科學(xué)出版社. 2009

            6. 王仁宏,李崇君,朱春鋼. 計(jì)算幾何教程. 科學(xué)出版社. 2008

            7. 趙罡,穆國(guó)旺,王拉柱譯. 非均勻有理B樣條. 清華大學(xué)出版社. 2010

            8. 朱心雄等. 自由曲線曲面造型技術(shù). 科學(xué)出版社. 2000

            9. 孫家廣. 計(jì)算機(jī)圖形學(xué). 清華大學(xué)出版社. 2000

            10. 孫家廣. 計(jì)算機(jī)輔助幾何造型技術(shù). 清華大學(xué)出版社. 2000

            11. 王國(guó)瑾,汪國(guó)昭,鄭建民. 計(jì)算機(jī)輔助幾何設(shè)計(jì). CHEP & Springer-Verlag. 2001

            12. Les Piegl, Wayne Tiller. The NURBS Book. Springer-Verlag. 1997

            13. Kelly Dempski. Focus on Curves and Surfaces. Premier Press. 2003

            14. OpenCASCADE. Test Harness User’s Guide 6.7.1. 2014

            15. OpenCASCADE. ModelingData User’s Guide 6.7.1. 2014

             

            PDF Version and Tcl Scripts: OpenCASCADE Rational Bezier Curves

            久久精品国产国产精品四凭 | 午夜天堂av天堂久久久| 久久综合伊人77777麻豆| 伊人久久大香线蕉成人| 免费无码国产欧美久久18| 久久99精品久久只有精品| 国内精品久久久久久中文字幕| 久久久精品人妻无码专区不卡 | 免费无码国产欧美久久18| 久久av无码专区亚洲av桃花岛| 国产成人无码精品久久久久免费| 午夜精品久久久久久久无码| 久久久国产精品亚洲一区| 久久久久一本毛久久久| .精品久久久麻豆国产精品| 亚洲精品第一综合99久久| 久久精品国内一区二区三区| 亚洲国产成人久久综合一区77 | 国産精品久久久久久久| 亚洲AV无码久久精品狠狠爱浪潮| 狠狠干狠狠久久| 亚洲va中文字幕无码久久不卡| 国产精品成人久久久久三级午夜电影 | 国产精品久久久香蕉| 久久久久久久综合日本| 国产精品99久久久久久www| 久久精品亚洲一区二区三区浴池 | 国产欧美久久久精品| 思思久久精品在热线热| 久久精品中文字幕第23页| 久久精品国产免费一区| 999久久久免费精品国产| 久久综合亚洲鲁鲁五月天| 亚洲中文字幕伊人久久无码| 久久婷婷人人澡人人| 欧美日韩精品久久久免费观看| 国内精品久久久久影院网站 | 久久婷婷午色综合夜啪| 午夜精品久久久久久影视777| 亚洲国产成人久久综合一区77| 久久人妻少妇嫩草AV无码蜜桃|