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

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>
            久久综合色天天久久综合图片| 夜夜躁日日躁狠狠久久88av| 牛牛影视久久网| 国产日韩欧美高清免费| 亚洲一区二区三区午夜| 亚洲欧洲99久久| 国产精品永久免费在线| 亚洲一区二区三区乱码aⅴ| 亚洲男人的天堂在线观看| 欧美国产日产韩国视频| 久久久久久久91| 亚洲中无吗在线| 欧美激情免费在线| 91久久久亚洲精品| 亚洲日韩成人| 欧美激情乱人伦| 亚洲激情视频| 亚洲视频中文字幕| 国产精品永久免费视频| 午夜视频在线观看一区| 久久久激情视频| 亚洲激情网站| 欧美日韩视频| 亚洲欧美日韩中文视频| 久久久噜噜噜久久| 亚洲国产精品成人综合| 欧美精品免费播放| 亚洲视频在线一区观看| 久久久久久亚洲精品不卡4k岛国| 狠狠色狠狠色综合系列| 女人色偷偷aa久久天堂| 日韩性生活视频| 欧美一区二区在线免费播放| 老司机午夜精品视频在线观看| 麻豆精品在线视频| 欧美激情性爽国产精品17p| 亚洲精品社区| 国产精品久久久久一区二区三区共 | 久久激情视频久久| 欧美激情一区二区三区蜜桃视频| 夜夜嗨av一区二区三区| 国产精品日日摸夜夜摸av| 久久精品视频播放| 亚洲精品字幕| 久久视频在线视频| 一区二区三区四区蜜桃| 国产又爽又黄的激情精品视频| 免费观看成人www动漫视频| 中文在线资源观看网站视频免费不卡| 久久青青草综合| 亚洲精品影院| 国产亚洲欧美另类中文| 欧美日韩国产经典色站一区二区三区| 欧美一区二区三区的| 亚洲日韩欧美视频| 久久夜色精品国产欧美乱极品 | 国产欧美一区二区精品仙草咪| 久久在线免费观看视频| 亚洲午夜免费福利视频| 亚洲第一二三四五区| 欧美一区三区二区在线观看| 亚洲精品欧美一区二区三区| 国产欧美在线| 国产精品啊v在线| 欧美不卡视频一区发布| 久久国产99| 亚洲一区在线观看免费观看电影高清| 亚洲第一色中文字幕| 久久久91精品| 亚洲欧美日韩视频一区| 日韩一级黄色av| 在线精品一区| 国产一区二区三区久久精品| 欧美色播在线播放| 欧美成人官网二区| 久久在线免费观看| 99综合视频| 99日韩精品| 亚洲电影第三页| 狠狠色综合网站久久久久久久| 国产精品人人做人人爽| 欧美日韩一区二区精品| 欧美精品国产一区| 欧美电影资源| 蜜桃久久av| 老色批av在线精品| 久久久久九九九九| 久久电影一区| 久久国产精品久久w女人spa| 亚洲欧美日韩系列| 亚洲一区免费在线观看| 亚洲一区二区视频在线| 一区二区三区欧美成人| 99国产麻豆精品| 中文日韩在线视频| 亚洲私人影院| 亚洲无玛一区| 亚洲主播在线播放| 亚洲欧美另类国产| 亚洲欧美日韩综合| 欧美亚洲在线观看| 久久精品视频导航| 噜噜噜噜噜久久久久久91 | 亚洲欧美日产图| 亚洲欧美资源在线| 欧美一区二区网站| 久久久久天天天天| 久久午夜精品一区二区| 裸体一区二区| 欧美激情一区二区三区在线| 欧美精品在线一区二区| 欧美日韩在线电影| 国产精品成人va在线观看| 国产精品素人视频| 国产主播在线一区| 亚洲国产成人不卡| 99一区二区| 亚洲一区三区在线观看| 久久国产精品99国产精| 久久夜色精品亚洲噜噜国产mv| 免费亚洲电影在线观看| 亚洲国产91| 一区二区欧美激情| 欧美在线一二三| 欧美1区视频| 欧美日韩一二区| 国产在线视频欧美| 亚洲美女精品一区| 香蕉久久久久久久av网站| 老牛嫩草一区二区三区日本| 亚洲国产一区二区三区青草影视| 一区二区三区不卡视频在线观看| 欧美一二区视频| 欧美精品一区二区高清在线观看| 国产精品www| 亚洲第一色在线| 亚洲欧美经典视频| 欧美高清不卡| 亚洲一区二区三区乱码aⅴ| 久久亚洲欧美国产精品乐播| 欧美日韩视频专区在线播放 | 在线播放中文字幕一区| 亚洲免费观看| 久久精品视频99| 亚洲精品乱码视频| 性欧美暴力猛交另类hd| 免费av成人在线| 国产精品一区二区三区久久| 91久久国产自产拍夜夜嗨| 午夜欧美大尺度福利影院在线看 | 一区二区三区成人精品| 久久久www成人免费毛片麻豆| 久久久久国产精品一区三寸| 亚洲一区免费观看| 免费视频亚洲| 亚洲一级特黄| 欧美国产另类| 曰本成人黄色| 久久精品国产99国产精品| 亚洲精品视频免费观看| 久久久国产精品一区| 欧美午夜在线视频| 亚洲人线精品午夜| 久久久久久免费| 亚洲视频在线观看视频| 欧美激情国产日韩精品一区18| 狠狠色综合网站久久久久久久| 亚洲欧美在线一区二区| 亚洲激情成人在线| 久久久久久久精| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲日本中文字幕| 欧美xx69| 久久久久久高潮国产精品视| 国产精品一区三区| 亚洲一区二区四区| 91久久中文| 男人的天堂亚洲在线| 揄拍成人国产精品视频| 久久久777| 欧美在线观看日本一区| 国产欧美日韩视频一区二区三区| 在线亚洲欧美视频| 最新成人在线| 欧美精品色综合| 亚洲人成在线影院| 欧美激情国产日韩| 男女精品视频| 亚洲精品国久久99热| 亚洲国产高清aⅴ视频| 欧美a级大片| 亚洲另类一区二区| 亚洲日本欧美| 欧美日韩美女在线观看| 一二三四社区欧美黄| 亚洲精选在线| 欧美日韩综合网| 亚洲主播在线| 亚洲综合成人在线| 国产一区二区三区不卡在线观看|