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

            Make Helix Curve in OpenCASCADE

            Posted on 2015-07-09 21:52 eryar 閱讀(5595) 評論(15)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

            Make Helix Curve in OpenCASCADE

            eryar@163.com

            Abstract. OpenCASCADE does not provide helix curve directly, but you can build a helix curve by the pcurve of a surface(curve on surface). When you understand the pcurve of a surface, you can make a helix curve easily. The paper first make a helix by Tcl in Draw Test Harness, then translate the Tcl script to OpenCASCADE C++ code.

            Key Words. OpenCASCADE, Helix Curve, PCurve, Sweep, Spring


            1. Introduction

            螺旋線是實踐中常用到的曲線,例如平頭螺絲釘的外緣曲線就是螺旋線。當我們擰緊平頭螺絲釘時,它的外緣曲線上的任一點M一方面繞螺絲釘的軸旋轉,另一方面又沿平行于軸線的方向前進,點M就走出一段螺旋線。[1]

            如果空間一點M在圓柱面x*x+y*y=a*a上以角速度ω繞z軸旋轉,同時又以線速度υ沿平等于z軸正方向上升(其中ω,υ都是常數),那未點M構成的圖形叫螺旋線。其參數方程為:

            wps_clip_image-3353

            wps_clip_image-14885

            Figure 1.1 A Helix Curve

            OpenCASCADE中并沒有直接提供構造螺旋線的類和函數,因此只有自己來構造了,其中構造的核心是要理解PCurve(曲面的參數曲線)。本文先以Tcl腳本在Draw Test Harness中快速生成一個螺旋線,再將相應的Tcl腳本轉換成C++代碼。在理解Pcurve概念的基礎上來構造螺旋線還是很簡單的,甚至還可以擴展應用。

            2.Make Helix Curve

            在OpenCASCADE提供的一個經典例子:生成一個酒瓶中,就有螺旋線的應用,即生成瓶口處的螺紋。當時看這例子的時候也是沒有完全理解,究竟怎么生成的那個螺旋線?感謝lifenli的提醒,使我又重溫了一遍例子,頓時茅塞頓開,明白了pcurve的一個應用。

            由《OpenCASCADE BRep Format》[4]中可知,圓柱面的參數方程為:

            wps_clip_image-29114

            假設當你在參數空間[u,v]中創建一條二維曲線后,可根據這個二維曲線來計算對應曲面上的三維曲線。根據二維曲線的不同定義,得到的結果如下:

            條件

            參數方程

            參數曲線

            U=0

            S(v)=P+r*cos(u)+vDz

            與Z軸平行的直線

            V=0

            S(u)=P+r*(cos(u)*Dx+sin(u)*Dy)

            與XOY面平行的圓

            U!=0 && V != 0

            S(u,v)=P+r(cos(u)*Dx+sin(u)*Dy)+vDz

            螺旋線

            對比螺旋線的參數方程可知,當參數空間中的u和v都不為0時,得到的圓柱面上的線就是螺旋線。考慮最簡單的情況,那就是u=v,即在參數空間中是一條斜率k=1的直線。在OpenCASCADE的Draw Test Harness用Tcl腳本測試,Tcl腳本如下所示:
            #
            # make helix curve in OpenCASCADE.
            # Shing Liu(eryar@163.com)
            # 2015-07-08 22:00
            #


            pload MODELING VISUALIZATION

            cylinder aCylinder 
            6

            line aLine2d 
            0 0 1 1
            trim aSegment aLine2d 
            0 2*pi

            mkedge aHelixEdge aSegment aCylinder 
            0 6*pi

            vdisplay aHelixEdge
            代碼先加載所需的造型及顯示模塊,然后創建一個圓柱面aCylinder;一條二維直線aLine2d;再將參數范圍限定在0到2PI之間;最后使用了用曲面及其上的pcurve來創建邊的算法mkedge生成了螺旋線并顯示在三維窗口中。

            wps_clip_image-9019

            Figure 2.1 Make a helix by Tcl script

            上述Tcl腳本可以很容易的轉換成C++代碼的,下面給出相應的C++實現,源碼如下所示:


            #define WNT

            #include 
            <gp_Lin2d.hxx>

            #include 
            <GCE2d_MakeSegment.hxx>

            #include 
            <Geom_CylindricalSurface.hxx>

            #include 
            <BRepBuilderAPI_MakeEdge.hxx>

            #include 
            <TopoDS_Edge.hxx>

            #include 
            <BRepTools.hxx>

            #pragma comment(lib, 
            "TKernel.lib")
            #pragma comment(lib, 
            "TKMath.lib")
            #pragma comment(lib, 
            "TKG3d.lib")
            #pragma comment(lib, 
            "TKBRep.lib")
            #pragma comment(lib, 
            "TKGeomBase.lib")
            #pragma comment(lib, 
            "TKTopAlgo.lib")


            void makeHelix(void)
            {
                Handle_Geom_CylindricalSurface aCylinder 
            = new Geom_CylindricalSurface(gp::XOY(), 6.0);

                gp_Lin2d aLine2d(gp_Pnt2d(
            0.00.0), gp_Dir2d(1.01.0));

                Handle_Geom2d_TrimmedCurve aSegment 
            = GCE2d_MakeSegment(aLine2d, 0.0, M_PI * 2.0);

                TopoDS_Edge aHelixEdge 
            = BRepBuilderAPI_MakeEdge(aSegment, aCylinder, 0.06.0 * M_PI).Edge();

                BRepTools::Dump(aHelixEdge, std::cout);

                BRepTools::Write(aHelixEdge, 
            "d:/helix.brep");
            }

            int main(int argc, char* argv[])
            {
                makeHelix();

                
            return 0;
            }

            由C++代碼可知,生成螺旋線的關鍵是在生成邊的時候,將pcurve和相應的曲面及其參數范圍一起傳給了生成邊的類,這樣就得到拓樸邊了。如果想要得到幾何的螺旋線,可以使用工具BRep_Tool::Curve()來將拓樸邊中的幾何曲線提取出來。經過測試,用pcurve生成的Edge中沒有三維幾何曲線,不過occ提供了一個靜態函數來將pcurve對應的三維曲線擬合成nurbs曲線,函數為:BRepLib::BuildCurve3d();

            參數空間中pcurve的斜率決定了螺旋線的螺距pitch,當其他參數不變,改變斜率后得到如下圖所示結果:

            wps_clip_image-2214

            Figure 2.2 Different Pitch by different K

            由圖可知,當pcurve的斜率越小時,得到的螺旋線的螺距也越小。修改pcurve的斜率只需要修改上述Tcl腳本中的aLine2d的斜率。

            如當斜率k=1時的pcurve為:

            line aLine2d 0 0 1 1

            當斜率k=1.0/5.0時的pcurve為:

            line aLine2d 0 0 5 1

            當斜率k=1.0/10.0時的pcurve為:

            line aLine2d 0 0 10 1

            可以自己嘗試修改看看沒的斜率得到的不同螺旋線的螺距變化。

            3.Spring: Sweep profile along helix

            得到螺旋線后自然就想到能不能用一個圓沿著螺旋線來放樣,從而得到一個彈簧。下面還是用Tcl腳本在Draw Test Harness中嘗試一下,相應的C++實現也是很容易找到相關的類。


            #
            # make helix curve in OpenCASCADE.
            # Shing Liu(eryar@163.com)
            # 2015-07-08 22:00
            #


            pload MODELING VISUALIZATION

            cylinder aCylinder 
            6

            line aLine2d 
            0 0 1 1
            trim aSegment aLine2d 
            0 2*pi

            mkedge aHelixEdge aSegment aCylinder 
            0 6*pi

            # there is no curve 3d in the pcurve edge.
            mkedgecurve aHelixEdge 0.001

            wire aHelixWire aHelixEdge

            circle profile 
            6 0 0 0 4 1 1
            mkedge profile profile
            wire profile profile
            mkplane profile profile

            pipe aSpring aHelixWire profile

            vdisplay aSpring
            vsetmaterial aSpring steel
            vsetgradientbg 
            180 200 255 180 180 180 2
            vsetdispmode 
            1
            vzbufftrihedron

            # set ray tracing
            if { ! [catch {vrenderparams -raytrace -shadows -reflections -fsaa -rayDepth 5}] } {
                vtextureenv on 
            1
            }

            生成效果如下圖所示:

            wps_clip_image-8846

            Figure 3.1 Spring by sweep a circle along a helix path

            當將pcruve在圓錐面上生成三維曲線時就會得到類似夏天的蚊香那樣螺旋形狀。同樣使用上述代碼,只是將圓柱面改成圓錐面得到:

            wps_clip_image-3726

            Figure 3.2 Mosquito Coil

            4.Conclusion

            綜上所述,常見的計算幾何造型書中講到曲線的參數方程都會以螺旋線為經典例子,甚至是高等數學中也是一樣,由此可見螺旋線是很常見的一種曲線。但是occ中并沒有直接提供螺旋線的幾何曲線,只有通過pcurve來構造了。所以理解pcurve后,才好理解make bottle例子中的瓶頸螺紋部分的代碼。

            通過將一個輪廓沿著螺旋線掃掠可以得出很多有意思的模型。在使用sweep的過程中發現pcurve生成的邊Edge中并沒有三維幾何曲線,所以會導致算法失敗。最終發現occ提供了一個將pcurve生成的邊中生成出一個擬合三維幾何曲線的函數BRepLib::BuildCurve3d()。對于一些在曲面上的曲線的造型可以參考這種用法,用pcurve來構造。

            5. References

            1. 同濟大學數學教研室. 高等數學(上). 高等教育出版社. 1978

            2. Helix. http://mathworld.wolfram.com/Helix.html

            3. OpenCASCADE Make Bottle Tutorial. 2015

            4. OpenCASCADE BRep Format. 2015

            5. 莫勇,常智勇. 計算機輔助幾何造型技術. 科學出版社. 2009

             

            PDF Version and Tcl Script Make Helix Curve in OpenCASCADE

            Feedback

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2015-07-10 09:32 by 谷粒OO
            沒想到螺旋線居然有公式~~~我以前是在3DS Max中反復畫,最后“根據感覺”用OpenGL畫出來了。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2015-07-10 15:16 by eryar
            @谷粒OO

            厲害啊!

            看樣子有時感覺也很重要。^_^

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-15 18:56 by 五只羊
            博主您好,您這個斜率跟螺距有具體的換算公式嗎?

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-15 19:13 by eryar
            @五只羊

            公式就在那螺旋線的參數方程中,仔細理解后就知道了

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-16 15:28 by 遠離顛倒夢想
            您好,,這個掃略功能是否掃略的平面必須垂直于所掃略的曲線端點的切向量?就是對平面的位置有沒有要求?

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-16 19:31 by eryar
            @遠離顛倒夢想
            對平面的法向量沒有要求,只要不與掃略曲線平行。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-17 20:47 by 遠離顛倒夢想
            是的,像您上面的螺旋彈簧的例子,那個掃略的平面是一個圓,,那這個圓是否應該畫在端點處的法向量相垂直的地方?不然掃略下去肯定會有一部分掃壞了。。。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-03-17 21:38 by eryar
            @遠離顛倒夢想
            掃略平面法向不一定與端點處切向量垂直,你可以嘗試看看

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-04 22:12 by liyunzhou
            請問樓主,怎么由參數方程構造曲線呢?

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-04 22:54 by eryar
            @liyunzhou

            要看下你的參數方程是什么樣子的。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-05 08:53 by liyunzhou
            @eryar
            OCC里面能對任意給定的參數方程構造曲線嗎?比如:
            x=a*(2*cos(t)-cos(2*t))
            y=a*(2*sin(t)-sin(2*t))

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-05 11:03 by eryar
            @liyunzhou
            OCC目前Geom_Curve中支持Bezier和B樣條曲線,以及二次曲線,像圓,橢圓,拋物線,雙曲線。

            對任意的參數曲線,我覺得有兩種方法:
            1.可以參考二次曲線的類實現,從Geom_Curve派生,實現相關虛函數;
            2.將你的參數曲線轉換成B樣條曲線;

            Best Regards,
            Shing Liu

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-05 12:02 by liyunzhou
            @eryar
            謝謝樓主的解答,第一種方法應該沒問題。我不太理解第二種方法具體怎么進行,是和您的《OpenCASCADE Conic to BSpline Curves-Parabola》(http://www.shnenglu.com/eryar/archive/2014/10/02/208484.html)這篇文章里介紹的方法類似嗎?針對參數方程確定B樣條的各個參數。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-05 18:26 by eryar
            @liyunzhou

            原理和這個類似,不過那幾個類只針對二次曲線到B樣條的轉換。

            # re: Make Helix Curve in OpenCASCADE  回復  更多評論   

            2016-05-05 21:20 by liyunzhou
            @eryar
            好的,謝謝樓主耐心解答。
            亚洲精品无码久久久久久| 久久影视综合亚洲| 精品午夜久久福利大片| 色综合久久综合网观看| 久久精品国产影库免费看| 一本一道久久精品综合| 伊人精品久久久久7777| 99久久久国产精品免费无卡顿| 日本精品久久久久中文字幕8| 久久激情亚洲精品无码?V| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久精品国产99国产精品澳门| 中文国产成人精品久久亚洲精品AⅤ无码精品| 久久狠狠爱亚洲综合影院| 久久久久免费精品国产| 亚洲欧美伊人久久综合一区二区 | 亚洲色大成网站www久久九| 精品午夜久久福利大片| 久久久久国产精品人妻| 国产毛片久久久久久国产毛片| 久久久久亚洲AV无码麻豆| 综合久久精品色| 久久精品一区二区三区中文字幕| 久久亚洲中文字幕精品有坂深雪| 久久久久九国产精品| 国产69精品久久久久99尤物| 伊人久久大香线蕉亚洲五月天| 久久精品成人一区二区三区| 免费观看成人久久网免费观看| 漂亮人妻被黑人久久精品| 狠狠色丁香久久婷婷综合_中| 国产亚洲色婷婷久久99精品91| 国产一级持黄大片99久久| jizzjizz国产精品久久| 97久久天天综合色天天综合色hd | 99久久99久久精品国产片果冻| 国产精品免费久久久久电影网| 久久电影网2021| 国产精品一区二区久久精品无码| 国产福利电影一区二区三区久久老子无码午夜伦不 | 精品无码人妻久久久久久|