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

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>
            国产欧美日韩综合| 国产夜色精品一区二区av| 亚洲激情婷婷| 亚洲国产成人av| 欧美理论大片| 一区二区三区色| 一区二区三区日韩欧美| 国产嫩草一区二区三区在线观看 | 久久久亚洲国产美女国产盗摄| 国产精品一区久久久久| 欧美有码在线视频| 久久视频一区二区| 亚洲视频综合| 欧美一区二区三区四区高清| 一区二区视频欧美| 亚洲青涩在线| 国产精品夜夜夜| 美女网站在线免费欧美精品| 欧美人与禽性xxxxx杂性| 午夜日韩av| 久久这里有精品视频| 亚洲午夜日本在线观看| 久久精品国产综合| 亚洲一二三四久久| 久久精品视频在线播放| 在线亚洲欧美视频| 欧美在线播放| 亚洲视频一起| 久久久久久综合| 亚洲一区二区三区免费视频 | 亚洲欧洲精品一区二区| 国产精品美女主播| 亚洲第一成人在线| 国产一区亚洲一区| 99国产一区| 一区二区三区在线看| 一本大道av伊人久久综合| 亚洲缚视频在线观看| 亚洲欧美日韩一区二区三区在线| 91久久久亚洲精品| 欧美一区二区黄| 一区二区激情视频| 免费观看成人www动漫视频| 香蕉免费一区二区三区在线观看| 欧美高清在线视频| 农村妇女精品| 国产一区二区久久| 午夜伦理片一区| 亚洲一区二区三区在线视频| 欧美.www| 欧美刺激午夜性久久久久久久| 国产日韩精品一区二区三区 | 最新国产の精品合集bt伙计| 黄色精品一区| 欧美一区二区三区在线免费观看 | 亚洲视频观看| 你懂的国产精品| 蜜桃视频一区| 一区精品在线播放| 久久久免费av| 免费不卡在线观看av| 国外成人性视频| 久久精品色图| 牛人盗摄一区二区三区视频| 韩国三级在线一区| 久久美女性网| 欧美激情第8页| 亚洲日韩成人| 欧美激情aⅴ一区二区三区| 亚洲激情av在线| 99视频一区二区| 欧美日韩国产欧| 亚洲午夜影视影院在线观看| 篠田优中文在线播放第一区| 国产精品影片在线观看| 香港久久久电影| 久久久久久久精| 亚洲第一网站| 欧美另类videos死尸| 亚洲人成在线播放| 亚洲资源av| 国产日产欧产精品推荐色 | 夜夜嗨av一区二区三区网页| 一本色道精品久久一区二区三区| 国产精品www| 香蕉成人久久| 欧美激情网站在线观看| 亚洲精品一区二区三区不| 欧美乱人伦中文字幕在线| 在线一区二区三区做爰视频网站| 欧美一区二区三区在线观看| 在线观看日韩av| 欧美三级电影网| 久久成人综合视频| 亚洲精品免费看| 久久激情视频免费观看| 91久久精品国产91久久性色tv| 欧美精选午夜久久久乱码6080| 亚洲私拍自拍| 欧美大片第1页| 亚洲欧美欧美一区二区三区| 精久久久久久久久久久| 欧美国产在线视频| 午夜亚洲性色福利视频| 亚洲国产高清自拍| 久久精品最新地址| 中文欧美在线视频| 伊人色综合久久天天| 欧美日韩一区在线观看| 久久精品在线视频| 亚洲一级电影| 91久久精品国产91性色tv| 欧美一乱一性一交一视频| 亚洲精品乱码久久久久久| 国产精品网曝门| 欧美韩国日本综合| 欧美在线日韩在线| 亚洲一区二区三区在线| 欧美国产一区视频在线观看| 久久av资源网站| 在线视频中文亚洲| 亚洲人成网站在线播| 一区二区三区亚洲| 国产无一区二区| 国产精品每日更新| 欧美三级欧美一级| 欧美韩日高清| 欧美成人a∨高清免费观看| 久久久精品一区二区三区| 亚洲香蕉伊综合在人在线视看| 亚洲人成7777| 欧美黄色aa电影| 免播放器亚洲| 久久综合网络一区二区| 久久精品二区| 久久九九热免费视频| 久久aⅴ国产欧美74aaa| 亚洲欧美不卡| 亚洲永久视频| 亚洲综合电影一区二区三区| 亚洲一区不卡| 亚洲一区二区少妇| 亚洲一区在线看| 亚洲图片在线| 亚洲欧美日韩国产综合| 亚洲一区二区三区四区五区午夜 | 亚洲国产美女久久久久 | 欧美精品七区| 欧美精品尤物在线| 欧美日韩国产bt| 欧美日韩在线高清| 欧美性色综合| 国产欧美日韩一区二区三区| 国产一区二区三区久久久| 国产在线精品二区| 亚洲国产另类久久久精品极度| 亚洲国产日本| 亚洲视频在线观看| 午夜宅男久久久| 久久久一区二区| 亚洲电影免费观看高清| 亚洲精品在线免费| 中文精品在线| 久久久久久久999| 欧美成人午夜影院| 欧美视频一区二区在线观看| 国产精品美女xx| 国产一级精品aaaaa看| 亚洲国产欧美一区| 亚洲免费视频中文字幕| 久久一区二区三区av| 亚洲电影av在线| 亚洲免费一在线| 久久色中文字幕| 欧美无乱码久久久免费午夜一区| 国产精品系列在线播放| 亚洲国产成人在线视频| 这里只有精品视频在线| 久久精品国产96久久久香蕉| 亚洲第一久久影院| 亚洲欧美另类久久久精品2019| 久久精品国产免费观看| 欧美日韩一区二区三区在线观看免| 国产日韩精品一区二区| 99pao成人国产永久免费视频| 欧美怡红院视频一区二区三区| 欧美11—12娇小xxxx| 亚洲五月六月| 欧美国产日韩二区| 国产一区二区高清视频| 一区二区三区日韩精品| 免费在线亚洲欧美| 亚洲欧美区自拍先锋| 欧美日韩国产成人精品| 一区二区三区在线免费观看| 亚洲自拍16p| 亚洲精品亚洲人成人网| 噜噜噜在线观看免费视频日韩| 国产精品普通话对白| av成人福利|