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

            Convert BSpline Curve to Arc Spline in OpenCASCADE

            Posted on 2016-11-22 23:12 eryar 閱讀(2778) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE
            Convert BSpline Curve to Arc Spline in OpenCASCADE

            eryar@163.com

            Abstract. The paper based on OpenCASCADE algorithms to approximate the NURBS curve to arc spline. The method is most useful in numerical control to drive the cutter along straight line or circular paths. Or in the shipbuilding industry to manufacture section bar for cold frame bender.

            Key Words. NURBS, Biarc approximation, arc spline,

            1.Introduction

            在數控加工CNC領域,通常需要用盡量少段數的圓弧和直線段來對曲線進行擬合。有的數控繪圖機也只有直線和圓弧插補器,即只能繪制直線和圓弧,所以也需要將自由曲線轉換成直線和圓弧來進行繪制。在船舶制造方面,如肋骨冷彎機只有兩種狀態:彎和不彎,也只能加工出直線和圓弧,所以也需要將曲面型材的彎曲信息轉換成肋骨冷彎機能加工的數據。如下圖所示為型材模型及其基線:

            wps366D.tmp

            Figure 1. 型材模型及基線

            wps367E.tmp

            Figure 2. 肋骨冷彎機

            如上圖所示,型材都是直線的,通過彎曲加工出曲線效果。所以也需要將實際的自由曲線的型材數據轉換成圓弧樣條(直線和圓?。┍阌诩庸?。國內外關于這方面的論文很多,本文基于opencascade做了一個測試,opencascade平臺相關的數據結構完善,B樣條相關算法齊全,可以基于這個開源平臺做些開發。

            2.Algorithm

            看了國內外的一些論文,對NURBS曲線進行圓弧樣條擬合的大概思路都是一個先對NURBS曲線離散的過程。一個極端情況就是生成NURBS曲線的顯示數據,即多段線來逼近。多段線對于有的機器設備(CNC)而言,加工不便,所以提出盡量使用少的圓弧和直線段來逼近NURBS曲線這種問題。

            總的思路是先將NURBS曲線離散成多段線,或將NURBS轉換成分段Bezier曲線,然后再用雙圓弧樣條曲線來進行擬合。

            3.Polygon Approximation

            將曲線離散成多段線的相關算法是個相對重要的算法,因為可以用于對NURBS曲線的顯示。生成曲線顯示數據時也有用盡量少的多段線來逼近曲線的問題。所以可以先用生成曲線顯示數據的算法來對曲線進行離散化。OpenCASCADE中取曲線上點的相關類都在包GCPnts中:

            wps367F.tmp

            如類GCPnts_TangentialDeflection可以在滿足角度偏差和曲率偏差的條件下對曲線進行離散化。根據文檔注釋可知:

            wps3680.tmp

            wps3681.tmp

            由上圖可知,曲線離散的算法滿足條件為向量P1P3和P3P2之間的夾角和P1P2與P1P3之間的夾角分別滿足角度和曲率偏差。

            如果對經過上述算法處理過的曲線上相鄰兩個點,根據切線來擬合一段圓弧,這樣處理起來程序比用雙圓弧擬合要簡單,對于尖點的處理也很方便。

            過樣條曲線上相鄰兩個節點,且在節點處都切于樣條曲線的圓弧一般是不存在的,但卻可以決定一圓弧使得在節點處兩對切線間的夾角相等,這種方法稱為平均切線法。故結合樣條曲線離散算法和平均切線法,可以將樣條曲線轉換成直線和圓弧來逼近表示的圓弧樣條曲線。直線的情況就是相鄰兩個節點處的切線之間的夾角小于一定的偏差,則認為是直線,其他情況都認為是圓弧。

            4.Arc Spline Fitting

            根據上述原理使用OpenCascade編寫程序,OpenCascade在NURBS方面的算法還是很全面的,如計算NURBS曲線曲面上的點或切線,或任意階導數等等。也有關于圓弧、線段等全面的數據結構,所以借助OpenCascade這個平臺,可以快速實現一些想法。

            wps3682.tmp

            上圖所示為當精度為0.5時B樣條曲線轉換成圓弧樣條曲線的結果。其中紅色曲線為B樣條曲線,黃色為圓弧樣條。

            wps3683.tmp

            當精度為0.1時得到的圓弧樣條。

            wps3684.tmp

            當精度為0.01時得到的圓弧樣條。由圖可知,圓弧樣條與B樣條基本重合。

            5.Conclusion

            綜上所述,當離散精度越高時,得到的圓弧樣條越逼近原始的B樣條,但是圓弧和直線段的數量也會越多。

            使用上述算法實現程序簡單,避免了雙圓弧擬合的一些復雜計算。

            OpenCascade中有完善的NURBS相關算法及常見的幾何曲線曲面的數據結構,所以借助這個平臺,可以快速驗證一些想法。

            6.References

            1.Les A. Piegl, Wayne Tiller. Biarc approximation of NURBS curves.

            2.盧建彪,雍俊海. 二次Bezier曲線的雙圓弧樣條插值二分算法.

            3.何援軍. 計算機圖形學. 機械工業出版社. 2010

            亚洲精品国产成人99久久| 伊人久久精品线影院| 一本色道久久综合| 久久人人青草97香蕉| 久久99精品国产自在现线小黄鸭 | 色偷偷88888欧美精品久久久| 99麻豆久久久国产精品免费| 精品久久久久久无码人妻热| 一本色综合久久| 国产呻吟久久久久久久92| 午夜精品久久久久久久| 国产亚洲成人久久| 72种姿势欧美久久久久大黄蕉| 伊人久久精品影院| 9191精品国产免费久久| 久久99精品久久久久久动态图| 中文字幕无码久久精品青草| 久久国产精品免费| 久久r热这里有精品视频| 精品国产乱码久久久久久人妻| 久久久久久极精品久久久| 精品精品国产自在久久高清| 久久精品aⅴ无码中文字字幕重口| 香蕉99久久国产综合精品宅男自| yellow中文字幕久久网| 精品久久久久久久久中文字幕| 777午夜精品久久av蜜臀| 一本一道久久a久久精品综合| 久久久久亚洲av成人无码电影 | 久久伊人五月天论坛| 国产精品久久久久久福利漫画| 久久久久久亚洲精品不卡| 亚洲精品无码久久久久sm| 久久久久久曰本AV免费免费| 亚洲国产成人久久笫一页 | 日韩精品久久久肉伦网站| 久久婷婷五月综合97色直播| 理论片午午伦夜理片久久 | 国内精品久久久久影院免费| 久久亚洲春色中文字幕久久久| 韩国免费A级毛片久久|