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

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, comments - 590, trackbacks - 0, articles - 0

OpenCascade Law Function

Posted on 2018-03-25 17:11 eryar 閱讀(1338) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

OpenCascade Law Function

eryar@163.com

1.Introduction

在OpenCASCADE的TKGeomAlgo Toolkit中提供了一個Law Package,在Law包中有一個基類:Law_Function,字面上翻譯為 規則函數。其類圖如下所示:

wps_clip_image-22828

Figure 1. Law Function class diagram

本文主要對Law_Function的子類進行介紹,進一步理解OpenCASCADE中Law相關類的作用。

2.Law Functions

根據Law_Function可知,Law_Function的子類有常量規則Law_Constant、線性規則Law_Linear、組合規則Law_Composite及B樣條規則Law_BSpFunc。抽象類Law_Function的純虛函數有:

l Continuity(): 規則函數的連續性;

l Value():計算對應參數X的函數值Y;

l D1():計算規則函數在參數X處的一階導數;

l D2():計算規則函數在參數X處的二階導數;

l Bounds():規則函數的定義區間;

wps_clip_image-13300

從上面的虛函數可以看出類Law_Function是一個一元變量的函數,與類math_Function的功能類似。

3.Test Code

下面的代碼將規則函數Law_Function的幾個子類通過生成Draw腳本,在Draw Test Harness中進行可視化,直觀地顯示出了幾個規則函數,便于理解。

/*
Copyright(C) 2018 Shing Liu(eryar@163.com)
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files(the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions :
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
#include <TColgp_Array1OfPnt2d.hxx>
#include <Law_Constant.hxx>
#include <Law_Linear.hxx>
#include <Law_BSpFunc.hxx>
#include <Law_S.hxx>
#include <Law_Interpol.hxx>
#pragma comment(lib, "TKernel.lib")
#pragma comment(lib, "TKMath.lib")
#pragma comment(lib, "TKG2d.lib")
#pragma comment(lib, "TKG3d.lib")
#pragma comment(lib, "TKGeomBase.lib")
#pragma comment(lib, "TKGeomAlgo.lib")
Standard_Integer aId = 0;
void draw(const Handle(Law_Function)& theLaw, std::ostream& theOutput)
{
    const Standard_Integer aStep = 20;
    Standard_Real aFirst = 0.0;
    Standard_Real aLast = 0.0;
    Standard_Real aDelta = 0.0;
    Standard_Real aX = 0.0;
    Standard_Real aY = 0.0;
    theLaw->Bounds(aFirst, aLast);
    aDelta = (aLast - aFirst) / aStep;
    theOutput << "polyline law" << ++aId;
    for (Standard_Integer i = 0; i <= aStep; ++i)
    {
        aX = aFirst + i * aDelta;
        aY = theLaw->Value(aX);
        theOutput  << " " << aX << " " << aY << " 0.0";
    }
    theOutput << "\n vdisplay law" << aId << std::endl;
    theOutput << "vaspects law" << aId << " -setColor " << ((aId % 2) ? " red " : " yellow ") << std::endl;
}
void test(std::ostream& theOutput)
{
    // 1. Constant law.
    Handle(Law_Constant) aConstantLaw = new Law_Constant();
    aConstantLaw->Set(2.0, 0.0, 1.0);
    draw(aConstantLaw, theOutput);
    // 2. Linear evolution law.
    Handle(Law_Linear) aLinearLaw = new Law_Linear();
    aLinearLaw->Set(1.0, 2.0, 3.0, 5.0);
    draw(aLinearLaw, theOutput);
    // 3. An "S" evolution law.
    Handle(Law_S) aSLaw = new Law_S();
    aSLaw->Set(3.0, 5.0, 6.0, 8.0);
    draw(aSLaw, theOutput);
    // 4. Provides an evolution law that interpolates a set of parameter and value pairs (wi, radi)
    TColgp_Array1OfPnt2d aPoints(1, 4);
    aPoints.SetValue(1, gp_Pnt2d(6.0, 8.0));
    aPoints.SetValue(2, gp_Pnt2d(7.0, 5.0));
    aPoints.SetValue(3, gp_Pnt2d(8.0, 9.0));
    aPoints.SetValue(4, gp_Pnt2d(9.0, 2.0));
    Handle(Law_Interpol) anInterpolativeLaw = new Law_Interpol();
    anInterpolativeLaw->Set(aPoints);
    draw(anInterpolativeLaw, theOutput);
}
int main(int argc, char* argv[])
{
    std::ofstream aTclFile("d:/tcl/law.tcl");
    test(aTclFile);
    return 0;
}

程序會在d:/tcl中生成一個law.tcl文件,將此文件加載到Draw 中即可顯示出規則函數對應的曲線,如下圖所示:

wps_clip_image-6615

Figure 2. Visualization Law Function Curves

由圖可知,常量規則函數在定義區間內是一條直線;線性規則函數是一條直線;S型函數是S型的B樣條曲線;插值函數是根據指定點插值得到的B樣條曲線。

4.Conclusion

在OpenCASCADE中經??梢钥吹揭恍┡cLaw相關的類,本文介紹了TKGeomAlgo中的Law包,綜上所述可知,Law就是一元函數,與math_Function的概念一致。

本文顯示規則曲線的方式可供借鑒,提高開發效率。只需要生成一個文本文件,就可以將結果可視化,對于其他三維的也是一樣。



為了方便大家在移動端也能看到我的博文和討論交流,現已注冊微信公眾號,歡迎大家掃描下方二維碼關注。
Shing Liu(eryar@163.com)

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久福利毛片| 欧美日韩一区二区三| 国产乱码精品一区二区三| 亚洲一区免费在线观看| 一区二区欧美视频| 国产精品亚洲人在线观看| 午夜精品久久久久久久蜜桃app | 欧美国产一区二区三区激情无套| 久久成人18免费网站| 尤物精品国产第一福利三区 | 99v久久综合狠狠综合久久| 亚洲国产色一区| 欧美噜噜久久久xxx| 亚洲图片欧美午夜| 欧美尤物一区| 亚洲日韩视频| 亚洲永久免费视频| 在线观看中文字幕不卡| 欧美国产高潮xxxx1819| 欧美三级视频在线观看| 欧美在现视频| 欧美韩国日本综合| 性欧美长视频| 男人天堂欧美日韩| 欧美在线一级va免费观看| 久久久亚洲午夜电影| 中国日韩欧美久久久久久久久| 午夜精品视频网站| 亚洲日韩欧美视频一区| 亚洲欧美日韩天堂一区二区| 亚洲精品久久久久久下一站| 亚洲在线免费| 日韩亚洲精品在线| 欧美中在线观看| 99成人在线| 久久蜜臀精品av| 亚洲免费视频成人| 欧美国产高潮xxxx1819| 久久精品人人爽| 国产精品扒开腿爽爽爽视频| 欧美成人精品在线播放| 国产精品综合视频| 亚洲精品在线观看免费| 亚洲国产日韩一级| 欧美一区二区网站| 亚洲欧美日韩国产综合| 欧美激情精品久久久久久大尺度 | 免费试看一区| 国产欧美日韩麻豆91| 99av国产精品欲麻豆| 亚洲国产va精品久久久不卡综合| 亚洲免费小视频| 亚洲午夜激情网站| 欧美成人在线免费视频| 免费在线日韩av| 黄色成人小视频| 欧美一区二区三区免费视| 亚洲综合精品自拍| 欧美日韩精品免费看| 亚洲国产成人精品女人久久久| 国产一区二区精品久久99| 亚洲一区二区三区涩| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 亚洲视频在线播放| 欧美精品九九99久久| 欧美激情中文字幕乱码免费| 尹人成人综合网| 久久久xxx| 欧美成人激情视频| 亚洲高清三级视频| 母乳一区在线观看| 亚洲国产精彩中文乱码av在线播放| 在线不卡欧美| 欧美成人dvd在线视频| 亚洲第一网站免费视频| 亚洲人成网站999久久久综合| 久久婷婷国产综合精品青草| 欧美成人午夜免费视在线看片 | 国产精品入口福利| 亚洲欧美日韩一区| 久久久久久夜精品精品免费| 一色屋精品视频在线看| 久久久无码精品亚洲日韩按摩| 欧美77777| 亚洲免费观看| 欧美午夜电影在线| 午夜精品福利在线| 免费日韩一区二区| 一本在线高清不卡dvd| 国产精品拍天天在线| 欧美有码视频| 最新国产乱人伦偷精品免费网站| 亚洲精品在线二区| 国产精品永久免费视频| 久久精品五月| 亚洲日本成人女熟在线观看| 亚洲香蕉视频| 亚洲电影下载| 欧美午夜精彩| 久久久亚洲精品一区二区三区 | 亚洲人人精品| 欧美在线亚洲在线| 亚洲国产一二三| 国产精品区免费视频| 久久久夜精品| 一区二区三区四区国产| 久久一区二区三区四区五区| 一区二区三区久久网| 国产视频精品xxxx| 欧美久久视频| 欧美一级二级三级蜜桃| 亚洲日本激情| 欧美成年人视频网站欧美| 亚洲你懂的在线视频| 亚洲国产精品久久久久秋霞蜜臀| 国产精品久久9| 欧美激情一区二区三区不卡| 性欧美xxxx大乳国产app| 亚洲美女精品久久| 欧美大片在线观看一区二区| 午夜精品久久久久久久99樱桃 | 99热在线精品观看| 中文一区字幕| 亚洲人成在线免费观看| 亚洲午夜精品| 精品成人一区二区| 国产精品av免费在线观看| 久久精品综合一区| 日韩一区二区精品在线观看| 美女网站在线免费欧美精品| 欧美一级黄色录像| 亚洲影院免费观看| 日韩图片一区| 亚洲欧洲一区二区在线观看| 伊人男人综合视频网| 国产亚洲欧美另类中文| 国产精品视频xxxx| 久久噜噜噜精品国产亚洲综合| 亚洲欧美日韩系列| 亚洲综合国产| 午夜精品影院在线观看| 亚洲一区中文字幕在线观看| 夜夜狂射影院欧美极品| 亚洲免费观看高清在线观看 | 久久久久国色av免费看影院| 欧美亚洲三区| 欧美一区二区免费| 欧美一区二区三区在线免费观看| 亚洲一区免费视频| 亚洲专区在线| 午夜影院日韩| 久久久久一区| 免费观看不卡av| 欧美国产精品人人做人人爱| 欧美精品v日韩精品v韩国精品v| 嫩草伊人久久精品少妇av杨幂| 欧美国产视频日韩| 欧美肉体xxxx裸体137大胆| 国产精品久久波多野结衣| 国产精品毛片a∨一区二区三区|国| 国产精品网站在线播放| 国内精品福利| 亚洲欧洲日本国产| 亚洲视屏一区| 久久精品91| 欧美国产91| 一二三区精品福利视频| 午夜日韩在线| 蜜臀久久99精品久久久久久9| 欧美不卡在线| 国产精品欧美激情| 激情欧美国产欧美| 夜夜嗨av一区二区三区网页| 欧美一级网站| 亚洲国产女人aaa毛片在线| 亚洲理论在线| 久久爱www.| 欧美日韩在线播放| 国产在线播放一区二区三区| 亚洲另类自拍| 久久精品视频免费播放| 亚洲高清在线观看| 午夜在线电影亚洲一区| 欧美韩日高清| 国内精品模特av私拍在线观看| 亚洲精品免费一区二区三区| 午夜久久久久久| 亚洲高清毛片| 久久精品国产第一区二区三区最新章节 | 一本久久a久久免费精品不卡| 欧美在线|欧美| 欧美午夜精品久久久久久浪潮| 亚洲第一二三四五区| 午夜视频在线观看一区| 亚洲电影在线播放| 欧美中文字幕在线观看| 欧美日韩在线综合| 亚洲人体偷拍| 欧美99在线视频观看| 午夜精品福利一区二区三区av |