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

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 閱讀(1339) 評論(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中經常可以看到一些與Law相關的類,本文介紹了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>
            国产精品高清一区二区三区| 亚洲婷婷在线| 亚洲一区二区三区乱码aⅴ| 在线观看国产日韩| 亚洲视频一区在线观看| 亚洲日本黄色| 久久国产婷婷国产香蕉| 亚洲欧美综合一区| 欧美色中文字幕| 亚洲黄色一区| 雨宫琴音一区二区在线| 欧美一区二区国产| 性刺激综合网| 国产酒店精品激情| 亚洲天堂av图片| 一本一本a久久| 欧美大胆a视频| 欧美激情无毛| 亚洲国产日韩欧美| 久久综合给合| 欧美激情无毛| 亚洲精品久久7777| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久躁日日躁aaaaxxxx| 国产丝袜一区二区三区| 亚洲综合电影| 久久国产精品电影| 狠狠色丁香久久婷婷综合_中| 欧美亚洲网站| 久久综合五月| 亚洲成色最大综合在线| 毛片av中文字幕一区二区| 麻豆精品传媒视频| 亚洲电影免费观看高清完整版在线观看 | 亚洲精品中文字幕有码专区| 久久综合影视| 亚洲欧洲日产国码二区| 野花国产精品入口| 欧美天堂亚洲电影院在线观看| 99精品99| 欧美一级片久久久久久久| 国产日韩在线亚洲字幕中文| 久久国产88| 欧美激情精品久久久久久蜜臀| 亚洲另类一区二区| 国产精品国产三级国产普通话三级| 亚洲一区二区精品| 久久精品国产免费| 最新亚洲电影| 国产精品福利av| 欧美一区视频在线| 欧美激情一区二区三区| 亚洲视频观看| 黄色成人在线免费| 欧美激情在线播放| 亚洲免费在线精品一区| 免费不卡欧美自拍视频| 一区二区91| 国产日韩在线亚洲字幕中文| 欧美成人久久| 亚洲欧美一级二级三级| 欧美福利视频| 先锋影音久久久| 亚洲国产成人在线视频| 国产精品高潮呻吟久久| 久久久亚洲欧洲日产国码αv| 亚洲免费久久| 久久人体大胆视频| 亚洲自拍偷拍网址| 亚洲国产欧美在线| 国产精品亚洲视频| 欧美激情偷拍| 欧美在线免费看| 一区二区三区日韩在线观看| 久热精品视频在线观看| 亚洲在线一区二区| 亚洲国产欧美一区二区三区同亚洲 | 欧美日韩国产综合网 | 亚洲影音先锋| 国产偷自视频区视频一区二区| 一区二区三区精品国产| 国产日韩欧美日韩大片| 亚洲二区精品| 日韩网站在线观看| 国内精品视频在线观看| 久久亚洲综合色一区二区三区| 久久一区二区视频| 亚洲人永久免费| 欧美日韩色婷婷| 亚洲一区视频在线| 久久视频一区二区| 亚洲毛片一区| 国产精品久久久久久久7电影| 亚洲婷婷免费| 欧美不卡三区| 亚洲午夜一级| 激情一区二区| 欧美日韩高清在线一区| 性久久久久久久久| 欧美成人精品一区二区| 亚洲一级黄色| 一区精品在线播放| 欧美色精品天天在线观看视频| 亚洲欧美激情视频| 欧美成人精品激情在线观看| 亚洲性图久久| 在线色欧美三级视频| 欧美视频第二页| 久久精品国产第一区二区三区最新章节 | 欧美一区2区三区4区公司二百| 红桃视频亚洲| 国产精品免费福利| 欧美国产高清| 久久久久国产一区二区三区四区| 亚洲美女中出| 欧美大片免费| 久久三级福利| 亚洲免费一级电影| 亚洲精品乱码久久久久久蜜桃91| 国产亚洲视频在线观看| 欧美日韩视频在线观看一区二区三区| 午夜欧美精品| 亚洲午夜女主播在线直播| 欧美国产精品劲爆| 久久精品中文| 欧美一区二区三区四区高清 | 亚洲午夜久久久久久久久电影院 | 欧美影片第一页| 一区二区高清在线观看| 亚洲国产网站| 一区二区在线看| 国产一区二区中文字幕免费看| 国产精品av一区二区| 欧美日韩第一区| 欧美极品欧美精品欧美视频| 久热爱精品视频线路一| 欧美中文在线免费| 亚洲欧美色婷婷| 午夜国产欧美理论在线播放| 99精品欧美| 99热免费精品| 亚洲美女精品成人在线视频| 亚洲激情在线播放| 亚洲国产欧美一区二区三区丁香婷| 久久综合激情| 欧美好骚综合网| 欧美激情精品久久久久久变态| 免费成人高清视频| 欧美成人精品三级在线观看| 欧美成人精品福利| 91久久久亚洲精品| 亚洲精品久久久久| 亚洲精品乱码久久久久| 亚洲精品视频在线观看网站 | 久久女同精品一区二区| 久久久久一本一区二区青青蜜月| 久久久久国产精品www| 蜜臀av性久久久久蜜臀aⅴ四虎 | 午夜国产精品视频| 欧美一级网站| 久久婷婷蜜乳一本欲蜜臀| 看欧美日韩国产| 亚洲观看高清完整版在线观看| 亚洲国产综合在线看不卡| 亚洲精品网站在线播放gif| 一二三区精品| 久久av在线看| 欧美激情精品久久久久久免费印度| 欧美伦理91i| 国产精品资源| 亚洲国产婷婷香蕉久久久久久99| 日韩一级免费观看| 午夜精品国产精品大乳美女| 久久这里有精品15一区二区三区| 欧美激情网站在线观看| 亚洲图色在线| 久久久综合网站| 欧美性大战久久久久久久蜜臀| 国产亚洲成人一区| 91久久国产综合久久蜜月精品 | 国产一区二区三区四区在线观看 | 国产精品久久久久秋霞鲁丝 | 在线播放视频一区| 日韩一区二区高清| 久久成人人人人精品欧| 亚洲大胆女人| 亚洲欧洲精品一区| 亚洲伊人伊色伊影伊综合网| 久久久久久网址| 亚洲美女福利视频网站| 久久国产一区二区| 国产精品国产三级国产专播精品人 | 久久亚洲综合色一区二区三区| 欧美精品久久久久久久免费观看| 国产日韩欧美电影在线观看| 亚洲毛片在线观看| 美国成人毛片| 亚洲午夜激情网页| 欧美福利小视频| 在线日韩av片|