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

eryar

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

OpenCASCADE Conic to BSpline Curves-Circle

Posted on 2014-10-13 22:03 eryar 閱讀(2694) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

OpenCASCADE Conic to BSpline Curves-Circle

eryar@163.com

Abstract. The conic sections and circles play a fundamental role in CAD/CAM applications. Undoubtedly one of the greatest advantages of NURBS is their capability of precisely representing conic sections and circles, as well as free-form curves and surfaces. We assume a knowledge of conics and circles, the purpose of this paper is to study them in the framework of their representation as NURBS curves.

Key Words. OpenCASCADE, Conic Curves, Circle, Convert, BSpline Curve

1. Introduction

B樣條技術在自由曲線曲面的設計和表示方面顯示出了其卓越的優點,但在表示初等曲線曲面時卻遇到了麻煩。在很多應用領域,例如飛機、造船、汽車等工業中,圓弧、橢圓弧、拋物線、圓柱面、球面、圓錐面、圓環面等經常出現,這些形狀都表示精確且往往要求較高的加工精度。傳統的B樣條技術只能精確地表示拋物線、拋物面,對其他的二次曲線曲面只能近似表示。因此,在一個造型系統內無法用一種統一的形式表示曲線曲面,因而使得系統的開發復雜化。非均勻有理B樣條(NURBS)技術正是在這樣的需求背景下逐步發展成熟起來的。

NURBS曲線曲面能夠迅速接受的主要原因在于:

v NURBS技術可以精確表示規則曲線與曲面(如圓錐曲線、二次曲面、旋轉曲面等)。

v 可以把規則曲線曲面和自由曲線曲面統一起來表示。因而便于用統一的算法進行處理和使用統一的數據庫進行存儲,程序量可明顯減少;

v 由于增加了額外的自由度(權因子),若應用得當,有利于曲線曲面形狀的控制和修改。

v NURBS技術是非有理Bezier曲線的和B樣條形式的真正推廣;

本文主要介紹圓的NURBS表示方法,即如何將圓轉換為NURBS曲線。

2.The Effect of Multiple Knots (Multiplicity)

重節點的定義為在節點序列中順序r個節點相同或xi重復出現r次,稱為該節點xi具有重復度r(Multiplicity)。在OpenCASCADE中B樣條曲線類的構造就是用的節點Knots及其對應的重復度Multiplicities來實現的,如下所示:

  //!  Creates a  non-rational B_spline curve   on  the <br>
//!         basis <Knots, Multiplicities> of degree <Degree>. <br>
  Standard_EXPORT   Geom_BSplineCurve(const TColgp_Array1OfPnt& Poles,const TColStd_Array1OfReal& Knots,const TColStd_Array1OfInteger& Multiplicities,const Standard_Integer Degree,const Standard_Boolean Periodic = Standard_False);

重節點有如下重要性質:

v 重節點連續階性質。在每個節點區間(uj, uj+1)內部,Bi,p(u)為多項式函數,因此,所有導數存在。在一個節點uj處Bi,p(u)是p-mj次連續可微的,此處mj是該點的重數。所以增加次數,則增加連續性,而增加節點的重數,則降低連續性。通常為保證連續性,節點的最高重數為p;

v 重節點的插值基函數性質。當節點向量中的內節點uj的重數為p,則只有定義在wps_clip_image-31799上的基函數在uj上取值為1,其余基函數在uj取值為0。當節點向是中的端節點uj的重數為p+1,則只有定義在wps_clip_image-31097上的基函數在uj取值為1,其余基函數在uj取值為0。

如下圖所示為具有重節點的B樣條基函數:

wps_clip_image-25863

Figure 2.1 U={0, 0, 0, 1, 2, 3, 4, 4, 5, 5, 5} p = 2 B-spline Basis Function

wps_clip_image-28559

Figure 2.2 U={0, 0, 0, 0,1, 2, 3, 4, 4,4, 5, 5, 5,5} p = 3 B-spline Basis Function

由上圖可知,重節點的出現對B樣條曲線有影響,如下所述:

當節點向量內部某節點的重數與次數相同時,則B樣條基數在此節點處的值為1,即由此得到的B樣條曲線的控制頂點將與B樣條曲線上的點重合。所以利用重節點的插值性質可以在B樣條曲線內部構造尖點與尖角。

當端節點重數為p時,p次的B樣條曲線的端點將與相應的控制多邊形的端點相重,曲線在端節點處與控制多邊形相切。

當端節點重數為p+1時,p次B樣條曲線就具有與p次Bezier曲線相同的端點幾何性質。這時如果B樣條曲線的定義域僅有一個非零節點區間,則所定義的B樣條曲線就是Bezier曲線。由此可知,B樣條方法是Bezier方法的強有力的推廣。

理解重節點的作用非常重要,利用重節點技術可用來控制B樣條基以達到控制整條曲線在節點處的連續性的目的。

3.Construction of Circles

如前所述,NURBS技術是Bezier技術的推廣。實際上,有理Bezier技術就可精確地表示圓錐曲線。由有理Bezier曲線的公式得二次有理Bezier曲線弧的表示形式為:

wps_clip_image-17100

稱k為形狀不變因子,公式如下所示:

wps_clip_image-8521

一段小于180度的圓弧也可以用二次有理Bezier曲線來表示。由于對稱性,P0P1P2必須是一個等腰三角形,滿足P0P1=P1P2,計算得ω1=cos(θ)。

wps_clip_image-11050

Figure 3.1 圓心角度小于180度圓弧的二次有理Bezier表示

大于180度的圓弧可以使用多段小圓弧拼接而成。得用重節點技術,使多段圓弧拼接起來。重節點的一種方法是使用2重節點,在有i段圓弧時,其內部節點值可取為1/i,…,i-1/i,權因子的取法不變。

以180度的圓弧為例,可以使用兩段90度圓弧拼接而成。節點矢量可取為U={0,0,0,1/2,1/2,1,1,1}。權因子可以取為ω1=ω3=cos45,ω0=ω2=ω4=1。則對應的B樣條基函數及B樣條曲線如下圖所示:

由圖可知基函數在1/2處取值為1,則對應的B樣條曲線上的值與控制頂點重合。

wps_clip_image-21424

Figure 3.2 U={0,0,0,1/2,1/2,1,1,1} B Spline Basis

wps_clip_image-9492

Figure 3.3 Semi-Circle B Spline Curve

用四段圓弧組成一個整圓,節點矢量為U={0,0,0,1/4,1/4,2/4,2/4,3/4,3/4,1,1,1},權因子取{1,sqrt(2)/2,1,1,sqrt(2)/2,1,1,sqrt(2)/2,1},使用Tcl腳本在Draw Test Harness中顯示如下圖所示:

wps_clip_image-14261

Figure 3.4 A Circle represented by 4 arcs

Tcl代碼如下所示:

 

#
#    Copyright (c) 2014 eryar All Rights Reserved.
#
#        File    : colorscale.tcl
#        Author  : eryar@163.com
#        Date    : 2014-10-13 18:10
#        Version : 1.0v
#
#    Description : Demonstrate the rational 2d Bezier curve 
#                  and BSpline curve.
#


pload MODELING

# use 4 arc to composite a circle
2dbsplinecurve c2 2 \
 
5 0 3 1/4 2 2/4 2 3/4 2 1 3 \
 
10 0 1 \
 
10 10 sqrt(2.0)/2.0 \
 
0 10 1 \
 
-10 10 sqrt(2.0)/2.0 \
 
-10 0 1 \
 
-10 -10 sqrt(2.0)/2.0 \
 
0 -10 1 \
 
10 -10 sqrt(2.0)/2.0 \
 
10 0 1

# fit the 2d view
v2d
2dfit

也可用位于三角形上的控制點來表示圓,如下圖所示:

wps_clip_image-29784

Figure 3.5 A Circle represented by 3 arcs

相應的Tcl代碼如下所示:

 

pload MODELING
# a 2d periodic circle (parameter from 0 to 2*pi !!)
dset h sqrt(3)/2
2dpbsplinecurve c3 
2 \
4 0 2 pi/1.5 2 pi/0.75 2 2*pi 2 \
0 -h/3 1 \
0.5 -h/3 0.5 \
0.25 h/6 1 \
0 2*h/3 0.5 \
-0.25 h/6 1 \
-0.5 -h/3 0.5 \
0 -h/3 1
# fit the 2d view
v2d
2dfit

4.Code Analysis

OpenCASCADE中提供了將圓轉換為NURBS曲線的功能,轉換后得到的NURBS曲線的參數范圍不再是[0,1]。下面給出具體的實例:

 

void TestCircleConvert(void)
{
    gp_Circ2d aCircle;
    aCircle.SetRadius(
1.0);
    Convert_ParameterisationType aType 
= Convert_TgtThetaOver2;
    Convert_CircleToBSplineCurve aConvertor(aCircle, aType);

    Handle_Geom_Circle aGeomCircle 
= GC_MakeCircle(gp::XOY(), 1.0);
  Handle_Geom_BSplineCurve aBSplineCurve 
= 
    GeomConvert::CurveToBSplineCurve(aGeomCircle, aType);

    std::cout 
<< "Convert Circle to BSpline Curve: " << std::endl;
    DumpConvertorInfo(aConvertor);
}

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

    
return 0;
}

結果如下圖所示:

wps_clip_image-1544

由上述結果可知,在默認參數化的情況下是按三段圓弧來拼接成一個整圓的。也可指定不同的參數化類型,將會得到不同的NURBS曲線。次數也可能不是2次,會用高次的NURBS曲線來表示圓。

5.Conclusion

利用重節點技術及二次有理B樣條的性質,可以用NURBS來精確表示圓。選擇不同的控制頂點,得到的圓的參數化效果也有所不同。

將常用的圓錐曲線用NURBS曲線來表示,即說明可以用NURBS曲線來統一表示圓錐曲線及自由曲線。這說明在理論上,一個造型內核的曲線可以只用一個類來表示,這個類對應OpenCASCADE中的Geom_BSplineCurve。

使用Tcl可以在Draw Test Harness中方便地產生NURBS曲線,從而可以快速驗證一些算法的正確性。

6. References

1. 趙罡,穆國旺,王拉柱譯Les Piegl,Wayne Tiller The NURBS Book(Second Edition) 2010 清華大學出版社

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

3. 朱心雄等,自由曲線曲面造型技術,2000,科學出版社

4. Kelly Dempski, Focus on Curves and Surface, 2003, Premier Press

5. 王仁宏,李崇君,朱春鋼 計算幾何教程 2008 科學出版社

PDF version and Tcl script: OpenCASCADE Conic to BSpline Curves-Circle

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲午夜av在线| 国产亚洲精品高潮| 欧美日韩dvd在线观看| 红桃视频亚洲| 久久久久国产一区二区| 亚洲男女毛片无遮挡| 国产视频一区欧美| 国产精品美女久久福利网站| 亚洲美女色禁图| 亚洲精品国产精品乱码不99| 久久综合色一综合色88| 亚洲黄色在线看| 亚洲人在线视频| 国产精品国产三级国产专区53| 性xx色xx综合久久久xx| 欧美一区成人| 亚洲日本欧美在线| 亚洲一区在线免费| 在线日本成人| 亚洲图片在线| 亚洲国产高清在线观看视频| 亚洲日本黄色| 国产亚洲一区精品| 亚洲黄色性网站| 国产精品你懂的在线| 欧美 日韩 国产在线| 欧美日韩另类丝袜其他| 久久婷婷久久一区二区三区| 欧美精品久久久久久久免费观看| 欧美一区二区三区的| 欧美aⅴ一区二区三区视频| 亚洲私人影院在线观看| 久久久精品免费视频| 正在播放欧美视频| 久久久水蜜桃av免费网站| 一区二区三欧美| 久久人人超碰| 欧美一区二区三区视频在线观看| 麻豆成人综合网| 久久久国产精品一区二区三区| 欧美日韩精品一本二本三本| 蘑菇福利视频一区播放| 国产欧美日韩在线视频| 亚洲破处大片| 亚洲黄色大片| 久久久久久成人| 久久福利电影| 国产精品麻豆成人av电影艾秋| 亚洲国产国产亚洲一二三| 国产一区清纯| 午夜欧美理论片| 亚洲欧美日韩国产另类专区| 欧美精品电影| 亚洲高清视频在线观看| 亚洲高清123| 久久蜜臀精品av| 美女免费视频一区| 黄色小说综合网站| 欧美在线欧美在线| 久久电影一区| 黑丝一区二区三区| 久久九九久久九九| 美女主播一区| 亚洲国产一区二区三区在线播| 久久久www成人免费无遮挡大片 | 欧美色中文字幕| 亚洲三级电影全部在线观看高清 | 欧美日韩免费看| 亚洲日本中文字幕| 欧美.www| 中文精品99久久国产香蕉| 欧美激情在线免费观看| 亚洲精品日日夜夜| 亚洲永久精品国产| 国产精品免费久久久久久| 亚洲一区影音先锋| 久久久久久久久岛国免费| 黄色成人av网| 欧美v国产在线一区二区三区| 欧美成人三级在线| 一本色道久久综合亚洲精品小说 | 久久九九热re6这里有精品| 久久只精品国产| 亚洲片国产一区一级在线观看| 欧美高清视频一二三区| 日韩午夜激情电影| 久久激情五月激情| 亚洲国产精品福利| 欧美三日本三级三级在线播放| 亚洲午夜精品久久久久久app| 久久精品亚洲一区二区| 亚洲国产精品国自产拍av秋霞| 欧美日本免费一区二区三区| 亚洲欧美日韩天堂一区二区| 久久亚洲春色中文字幕久久久| 亚洲韩日在线| 国产精品亚洲欧美| 免费不卡亚洲欧美| 亚洲午夜免费福利视频| 美女露胸一区二区三区| 亚洲视频香蕉人妖| 伊人久久大香线蕉综合热线| 欧美日本国产| 亚洲女女女同性video| 久久一二三国产| 99re视频这里只有精品| 国产欧美精品日韩区二区麻豆天美| 久久久精品一品道一区| 99精品福利视频| 欧美伊人久久久久久久久影院| 在线免费观看视频一区| 国产精品普通话对白| 欧美福利视频在线观看| 午夜亚洲精品| 一区二区三区精品久久久| 噜噜噜噜噜久久久久久91| 亚洲欧美日韩精品久久久| 亚洲日韩欧美一区二区在线| 欧美日韩国产123区| 久久国内精品视频| 亚洲一区一卡| 亚洲免费观看高清在线观看 | 猛男gaygay欧美视频| 亚洲欧美中文字幕| 一本色道久久88综合亚洲精品ⅰ| 国产一区二区三区奇米久涩| 国产精品v日韩精品| 欧美激情中文字幕乱码免费| 久久视频这里只有精品| 午夜亚洲伦理| 欧美一级二区| 欧美亚洲视频| 欧美怡红院视频| 午夜精品理论片| 亚洲综合视频一区| 亚洲影院免费观看| 一区二区三区欧美亚洲| 亚洲狼人综合| 欧美成人蜜桃| 国产在线一区二区三区四区| 国产精品扒开腿做爽爽爽视频| 欧美日本韩国在线| 欧美午夜在线视频| 国产精品免费网站| 国产精品卡一卡二卡三| 国产精品久久久久久五月尺| 国产精品www色诱视频| 欧美性色综合| 国产日产精品一区二区三区四区的观看方式 | 亚洲激情网站免费观看| 亚洲电影av在线| 亚洲激情专区| 一本大道久久精品懂色aⅴ | 亚洲国产精品一区二区尤物区| 亚洲福利视频在线| 国产欧美韩日| 亚洲国产毛片完整版| 亚洲精品一二三区| 亚洲午夜激情免费视频| 亚洲一区二区高清视频| 久久成人在线| 欧美黄色一区| 99亚洲视频| 欧美一区二区三区啪啪 | 日韩午夜中文字幕| 亚洲欧美日韩国产一区| 久久久久国内| 欧美欧美全黄| 国产麻豆视频精品| 亚洲精品视频一区| 亚洲男同1069视频| 免费不卡亚洲欧美| 亚洲裸体视频| 久久精品网址| 欧美日韩视频第一区| 国产日韩欧美精品在线| 在线看国产一区| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲欧美日韩一区二区三区在线| 久久国产精品电影| 欧美日韩二区三区| 一区二区在线免费观看| 亚洲色图综合久久| 免费在线观看一区二区| 一区二区av在线| 看欧美日韩国产| 国产精品一区视频| 日韩视频一区| 免费久久99精品国产自| 在线中文字幕不卡| 欧美aⅴ99久久黑人专区| 国产午夜精品全部视频播放| 亚洲精品综合久久中文字幕| 性欧美超级视频| 亚洲伦伦在线| 欧美精品高清视频| 最新精品在线| 裸体丰满少妇做受久久99精品 | 卡一卡二国产精品| 亚洲综合视频网|