OpenCascade Law Function
OpenCascade Law Function
1.Introduction
在OpenCASCADE的TKGeomAlgo Toolkit中提供了一个Law Package,在Law包中有一个基类:Law_Function,字面上翻译为 规则函数。其类图如下所示:
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():规则函数的定义区间;
从上面的虚函数可以看出类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 中即可显示出规则函数对应的曲线,如下图所示:
Figure 2. Visualization Law Function Curves
由图可知,常量规则函数在定义区间内是一条直线;线性规则函数是一条直线;S型函数是S型的B样条曲线;插值函数是根据指定点插值得到的B样条曲线。
4.Conclusion
在OpenCASCADE中经常可以看到一些与Law相关的类,本文介绍了TKGeomAlgo中的Law包,综上所述可知,Law就是一元函数,与math_Function的概念一致。
本文显示规则曲线的方式可供借鉴,提高开发效率。只需要生成一个文本文件,就可以将结果可视化,对于其他三维的也是一样。
OpenCascade Law Function的更多相关文章
- Function Set in OPEN CASCADE
Function Set in OPEN CASCADE eryar@163.com Abstract. The common math algorithms library provides a C ...
- 通过百度echarts实现数据图表展示功能
现在我们在工作中,在开发中都会或多或少的用到图表统计数据显示给用户.通过图表可以很直观的,直接的将数据呈现出来.这里我就介绍说一下利用百度开源的echarts图表技术实现的具体功能. 1.对于不太理解 ...
- OpenCascade B-Spline Basis Function
OpenCascade B-Spline Basis Function eryar@163.com Abstract. B-splines are quite a bit more flexible ...
- OpenCASCADE Trihedron Law
OpenCASCADE Trihedron Law eryar@163.com Abstract. In differential geometry the Frenet-Serret formula ...
- OpenCASCADE Expression Interpreter by Flex & Bison
OpenCASCADE Expression Interpreter by Flex & Bison eryar@163.com Abstract. OpenCASCADE provide d ...
- 齐夫定律, Zipf's law,Zipfian distribution
齐夫定律(英语:Zipf's law,IPA英语发音:/ˈzɪf/)是由哈佛大学的语言学家乔治·金斯利·齐夫(George Kingsley Zipf)于1949年发表的实验定律. 它可以表述为: 在 ...
- OpenCASCADE Interpolation - Lagrange
OpenCASCADE Interpolation - Lagrange eryar@163.com Abstract. Power basis polynomial is the most simp ...
- OpenCASCADE BRepTools
OpenCASCADE BRepTools eryar@163.com Abstract. OpenCASCADE BRepTools provides utilities for BRep data ...
- A Simple OpenCASCADE Qt Demo-occQt
A Simple OpenCASCADE Qt Demo-occQt eryar@163.com Abstract. OpenCASCADE have provided the Qt samples ...
随机推荐
- 用eclipes写第一个HelloWorld
打开 eclipes 后,首先点击左上角新建按钮,新建一个项目,如图: 选择 Java Project 选项: 如果没有java Project这个选项的话,选择次一个的 project 也可以,在跳 ...
- 网络基础tcp/ip协议一
计算机网络: 硬件方面:通过线缆将网络设备和计算机连接起来 软件方面:操作系统,应用软件,应用程序通过通信线路互连 实现资源共享,信息传递 计算机网络的功能: 数据通信 资源共享 增加可靠性 提高系统 ...
- (1)常见O(n^2)排序算法解析
一.选择排序 1.原始数组 2.遍历数组找到最小值索引,并将最小值索引与当前遍历索引位置互换 3.确定最小位置值,进行下一次遍历 4.java代码实现 /** * author:sam * date: ...
- cips2016+学习笔记︱简述常见的语言表示模型(词嵌入、句表示、篇章表示)
在cips2016出来之前,笔者也总结过种类繁多,类似词向量的内容,自然语言处理︱简述四大类文本分析中的"词向量"(文本词特征提取)事实证明,笔者当时所写的基本跟CIPS2016一 ...
- 用vs2013+velt-0.1.4进行嵌入式开发 进行海思平台 UBOOT 开发
1.1 什么是VELT VELT的全称是Visual EmbedLinuxTools,它是一个与visual gdb类似的visual studio插件,用以辅助完成Linux开发.利用这个插件 ...
- java.text.ParseException: Unparseable date: "2015-06-09 hh:56:19"
1.错误描述 [DEBUG:]2015-06-09 16:56:19,520 [-------------------transcation start!--------------] java.te ...
- Netty的并发编程实践1:正确使用锁
很多刚接触多线程编程的开发者,虽然意识到了并发访问可变变量需要加锁,但是对于锁的范围.加锁的时机和锁的协同缺乏认识,往往会导致出现一些问题.下面笔者就结合Netty的代码来讲解下这方面的知识. 打开F ...
- Linux显示使用者将不能利用交谈式指令来对行程
Linux显示使用者将不能利用交谈式指令来对行程 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ top -s top - 19:23:34 up 52 min ...
- CF384 div2 E. Vladik and cards
题意 给你一个的排列,求一个满足条件的最长子序列 每种数字的差小于等于,并且每种数字之内是连续的 解法 首先单纯认为用肯定不行的 所以应该考虑二分答案(所求长度具有二分性) 再用dp判断是否可行,这个 ...
- TOJ 4120 Zombies VS Plants
链接:http://acm.tju.edu.cn/toj/showp4120.html 4120. Zombies VS Plants Time Limit: 1.0 Seconds Memo ...