Locations Section of OpenCascade BRep

Locations Section of OpenCascade BRep

eryar@163.com

摘要Abstract:本文结合OpenCascade的BRep格式描述文档和源程序,对BRep格式进行分析,详细说明BRep的数据组织形式。本文主要通过对BRep文件中的Locations部分的读写代码进行分析,来完全理解OpenCascade中的Location部分。 

关键字Key Words:OpenCascade, BRep Format, Location, Location Set 

一、引言 Introduction

为了跟踪拓朴体的位置(Shape Location),每个形状都有一个局部坐标系。局部坐标系可以通过如下两种方式来表示: 

l 一个右手法则表示的三个互相垂直的向量,对应的类是gp_Ax2; 

l 一个相对于世界坐标系的变换(the transformation of coordinates between local and global references frames),对应的类是gp_Trsf; 

类TopLoc_Location表示了初等矩阵经过一系列变换后得到的坐标系,保存累积变换后的结果避免了矩阵变换的重新计算。 

二、<locations>部分 Section <locations>

示例: 

wps_clip_image-13782

BNF 定义: 

wps_clip_image-24805

详细说明: 

<location data 1>定义了3X4的矩阵Q,描述了三维空间的线性变换,并满足如下约定: 

wps_clip_image-7287

矩阵Q是线性变换矩阵,它可以通过矩阵乘法将一个点(x, y, z)变换成另外一点(u, v, w): 

wps_clip_image-16501

Q也可能是以下基本变换矩阵的组合: 

1) 平移变换矩阵: 

wps_clip_image-27021

2) 绕任意轴旋转的变换矩阵,轴的方向为D(Dx, Dy, Dz),旋转角度ψ: 

wps_clip_image-9085

3) 缩放变换矩阵: 

wps_clip_image-14514

4) 中心对称变换矩阵: 

wps_clip_image-18420

5) 轴对称变换矩阵: 

wps_clip_image-9661

6) 平面对称变换矩阵: 

wps_clip_image-16676

<location data 2>解释为组合变换的幂。<location data 2>是整数对li, pi的序列。这个序列将被解释为: 

wps_clip_image-2646

Lli是<location record>部分的变换矩阵。 

三、示例程序

通过分析Location数据输出和读取的程序,可以完全理解Location类的作用。Location的输出与读取都是通过类TopTools_LocationSet来实现的。调试跟踪其代码,可以理解其具体实现了。 

3.1 输出位置数据 Output Location data

将Location中的数据输出有两种方式,一种是在Debug模式下,可以输出到屏幕显示;一种是输出到文件。输出到文件还可以被读取。示例程序如下所示: 

1 /*2 *    Copyright (c) 2013 eryar All Rights Reserved.3 *4 *        File    : Main.cpp5 *        Author  : eryar@163.com6 *        Date    : 2013-11-16 20:087 *        Version : 1.0v8 *9 *    Description : Keeping track of shape location.
10 *                  The TopLoc_Location class represents a marker composed of
11 *                  references to elementary markers. The resulting cumulative
12 *                  transformation is stored in order to avoid recalculating the
13 *                  sum of the transformations for the whole list.
14 */
15 
16 #define WNT
17 #include <gp_Trsf.hxx>
18 #include <TopLoc_Location.hxx>
19 #include <TopTools_LocationSet.hxx>
20 
21 #pragma comment(lib, "TKernel.lib")
22 #pragma comment(lib, "TKMath.lib")
23 #pragma comment(lib, "TKBRep.lib")
24 
25 int main(void)
26 {
27     ofstream dumpFile("LocationTest.txt");
28 
29     TopTools_LocationSet locationSet;
30 
31     // 1. Null transformation, identity matrix.
32     gp_Trsf trsfNull;
33     TopLoc_Location locationNull(trsfNull);
34 
35     locationSet.Add(locationNull);
36     locationSet.Add(locationNull.Powered(2));
37     
38     // 2. Translate transformation.
39     gp_Trsf trsfTranslate;
40     trsfTranslate.SetTranslation(gp_Vec(100, 200, 0));
41     TopLoc_Location locationTranslate(trsfTranslate);
42 
43     locationSet.Add(locationTranslate);
44     locationSet.Add(locationTranslate.Powered(3));
45 
46     // 3. Rotate transformation.
47     gp_Trsf trsfRotate;
48     trsfRotate.SetRotation(gp::OX(), M_PI_2);
49     TopLoc_Location locationRotate(trsfRotate);
50 
51     locationSet.Add(locationRotate);
52     locationSet.Add(locationRotate.Powered(6));
53 
54     // dump the location set and write to file.
55     locationSet.Dump(std::cout);
56     locationSet.Write(dumpFile);
57 
58     return 0;
59 }

Debug模式下屏幕上输出结果为:

1 2 3 4  -------5  Dump of 6 Locations6  -------7 8     1 :9 Elementary location
10 (               1               0               0               0  )
11 (               0               1               0               0  )
12 (               0               0               1               0  )
13     2 :
14 Complex : L1^2
15 (               1               0               0               0  )
16 (               0               1               0               0  )
17 (               0               0               1               0  )
18     3 :
19 Elementary location
20 (               1               0               0             100  )
21 (               0               1               0             200  )
22 (               0               0               1               0  )
23     4 :
24 Complex : L3^3
25 (               1               0               0             300  )
26 (               0               1               0             600  )
27 (               0               0               1               0  )
28     5 :
29 Elementary location
30 (               1               0               0               0  )
31 (               0    1.11022e-016              -1               0  )
32 (               0               1    1.11022e-016               0  )
33     6 :
34 Complex : L5^6
35 (               1               0               0               0  )
36 (               0              -1   -6.66134e-016               0  )
37 (               0    6.66134e-016              -1               0  )
38 Press any key to continue . . .

输出到文件中的内容为:

 1 Locations 62 13               1               0               0               0 4               0               1               0               0 5               0               0               1               0 6 2  1 2 07 18               1               0               0             100 9               0               1               0             200 
10               0               0               1               0 
11 2  3 3 0
12 1
13               1               0               0               0 
14               0 1.11022302462516e-016              -1               0 
15               0               1 1.11022302462516e-016               0 
16 2  5 6 0

从输出结果可以看出,输出到文件中的内容与BRep文件中的内容一致。Location有两种类型,当类型为1时,即是一个初等变换矩阵(Elementary location);当类型为2时,是一个复合变换(Complex),即在初等变换矩阵的基础上做的一些变换操作。 

3.2 读取位置数据 Input Location data

读取<locations>部分的类为TopTools_LocationSet,程序代码如下所示:

1 //=======================================================================2 //function : Read3 //purpose  : 4 //=======================================================================5 6 void  TopTools_LocationSet::Read(Standard_IStream& IS)7 {8   myMap.Clear();9 
10   char buffer[255];
11   Standard_Integer l1,p;
12 
13   IS >> buffer;
14   if (strcmp(buffer,"Locations")) {
15     cout << "Not a location table "<<endl;
16     return;
17   }
18 
19   Standard_Integer i, nbLoc;
20   IS >> nbLoc;
21   
22   TopLoc_Location L;
23   gp_Trsf T;
24     
25   //OCC19559
26   Message_ProgressSentry PS(GetProgress(), "Locations", 0, nbLoc, 1);
27   for (i = 1; i <= nbLoc&& PS.More(); i++, PS.Next()) {
28     if ( !GetProgress().IsNull() ) 
29       GetProgress()->Show();
30 
31     Standard_Integer typLoc;
32     IS >> typLoc;
33     
34     if (typLoc == 1) {
35       ReadTrsf(T,IS);
36       L = T;
37     }
38 
39     else if (typLoc == 2) {
40       L = TopLoc_Location();
41       IS >> l1;
42       while (l1 != 0) { 
43     IS >> p;
44     TopLoc_Location L1 = myMap(l1);
45     L = L1.Powered(p) *L;
46     IS >> l1;
47       }
48     }
49     
50     if (!L.IsIdentity()) myMap.Add(L);
51   }
52 }

从读取Location部分的代码可以看出,分两情况来处理。一种是初等变换矩阵,类型值为1,直接读取矩阵数据;一种是复合变换,类型值为2,它是在初等变换矩阵的基础上通过Power来实现的复合变换。BRep中记录复合变换的数据为初等变换矩阵的编号及其幂次。通过编号Map得出其对应的初等变换矩阵。结合读取Location的代码,对BRep中Location部分的数据有了清晰认识。 

四、结论

通过对OpenCascade中BRep文件中的Locations部分的数据的输出与读取,理解其实现。即对Location分为两种类型: 

1. 初等变换矩阵:存储数据为3X4变换矩阵; 

2. 复合变换:存储数据为初等变换矩阵的编号及其幂次。 

 

PDF Version: Location Section of BRep File

转载于:https://www.cnblogs.com/opencascade/p/3446718.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/300569.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

孙悟空都服输!波士顿动力最新逆天机器人视频,翻筋斗连拿大顶!

全世界只有3.14 %的人关注了青少年数学之旅刚刚&#xff0c;波士顿动力公司在YouTube发布了两段真正震撼的新视频&#xff1a;双足人形机器人Atlas展示倒立、360度翻跟头、旋转的跑酷Demo&#xff1a;More Parkour Atlas。四足机器人Spot的商业化广告宣传片&#xff1a;Spot La…

C#实例:datagridview单元格合并

这是替C#微信交流群群友做的一个小实例&#xff0c;目的就是在datagridview选择对应行以后&#xff0c;点击button后获取对应行的ip&#xff0c;并执行相应的操作&#xff0c;其实我觉得这样的话button没必要非放置到datagridview里面的&#xff01;但是为了满足群友的需求&…

NO.106 需求的状态、研发阶段及注意事项。

为什么80%的码农都做不了架构师&#xff1f;>>> 禅道项目管理软件设计的需求有两个字段来跟踪它的变化&#xff0c;一个是需求的状态字段&#xff0c;一个是需求的研发阶段字段&#xff0c;下面来看下这两个字段。 一、需求的状态 需求状态(status)字段&#xff0c…

java实例化泛型_Java让泛型实例化的方法

泛型对象可以实例化吗&#xff1f;不可以&#xff0c;T tnew T()是不可以的&#xff0c;编译器会报错。由于泛型擦除&#xff0c;编译器在编译时无法确定泛型所对应的真实类型解决方法使用反射新建实例Type superclass getClass().getGenericSuperclass();ParameterizedType p…

几种人类设计的永动机,最后一个彻底服了!| 今日最佳

全世界只有3.14 %的人关注了青少年数学之旅众所周知&#xff0c;永动机是违反当前客观科学规律的概念&#xff0c;是永远不能够被制造出来的。下面这些都是人们根据不同原理设计出来的&#xff0c;看一看有什么神奇之处&#xff0c;最后一个是亮点&#xff01;▲达芬奇设计的永…

剖析WPF依赖属性

这节来讲一下WPF中的依赖属性 (Dependency Property)。【了解属性和字段】我们知道&#xff0c;属性是面向对象语言中用来封装字段的外衣&#xff0c;它像是字段对外界的桥梁&#xff0c;我们可以通过属性来验证数据的合法性或控制对外的访问性等等。每个属性的背后都有其对应的…

你在孩子身上偷的懒,终将会变成最大的遗憾

全世界只有3.14 %的人关注了青少年数学之旅我们来看一个非常有趣的统计&#xff1a;2007年—2016年全国高考状元父母职业统计最优秀的孩子大多数出自教师家庭。很家长说&#xff0c;教师有着和孩子一样的寒暑假&#xff0c;有着教书育人的先天优势&#xff0c;我们普通人工作忙…

开发们 点广告-赚点BT币

2019独角兽企业重金招聘Python工程师标准>>> http://freebitco.in/?r14320 转载于:https://my.oschina.net/wangtao/blog/180765

Asp.net页面的生命周期

介绍Asp.net是微软.Net战略的一个组成部分。它相对以前的Asp有了很大的发展&#xff0c;引入了许多的新机制。本文就Asp.net页面的生命周期向大家做一个初步的介绍&#xff0c;以期能起到指导大家更好、更灵活地操纵Asp.net的作用。当一个获取网页的请求&#xff08;可能是通过…

太赞了!微软《dotnet中文手册》火了,完整PDF开放下载!

这是微软高级架构师基于最新的.net编写&#xff0c;循序渐进地对.net/C#进行讲解。对于零基础可以作为.net的快速入门教材&#xff0c;对于高级程序员而言&#xff0c;这也是你的进阶之路&#xff0c;今天来了&#xff0c;就是缘份&#xff0c;看到了就送给你&#xff01;资料介…

你穿衣品味还不如AI,这有一款时尚着装网络模型

全世界只有3.14 %的人关注了青少年数学之旅有一件衣服的时候&#xff0c;怎样的小改动可以提升其整体的时尚性&#xff1f;近日 UT 奥斯汀、康奈尔大学、乔治亚理工和 Facebook AI 研究中心的研究者提出了一种名为 Fashon 的模型&#xff0c;用于给一件衣服进行改进&#xff0…

分割移动微小物体

思路&#xff1a;1. 前后两帧相减&#xff0c;得到差分图像2.在差分图像里求像素最大的点&#xff08;最亮的点&#xff09;这样就得到&#xff0c;移动微小物体#include "check.h"#include <iostream.h>voidmain(){ DWORD t1,t2; IplImage *frame0; …

一个非常实用的Python SSH库

前言 Python的Paramiko库&#xff0c;它是一个用于实现SSHv2协议的客户端和服务器的库。通过使用Paramiko&#xff0c;我们可以在Python程序中轻松地实现远程服务器的管理、文件传输等功能。特别做智能硬件产品的同学要熟悉它&#xff0c;因为它能为你减少很多麻烦&#xff0c…

在腾讯,我的试用期总结!

在腾讯的 3 个月&#xff0c;我经历了些什么&#xff1f;大家好&#xff0c;我是鱼皮。最近不少小伙伴顺利毕业&#xff0c;入职了新公司&#xff0c;开始了人生第一段正式工作经历。但对于很多公司&#xff0c;如果你想要成为正式员工&#xff0c;是需要先经历几个月的试用期的…

这6个动作,据说只有20%的人能做到!| 今日最佳

全世界只有3.14 %的人关注了青少年数学之旅你的手指够灵活吗&#xff1f;能做出下面这些动作在回答吧。据说就是下面这6个动作&#xff0c;据说只有20%的人能做到哦&#xff01;大家不妨试试&#xff0c;看看你是不是这20%中的一员。PS&#xff1a;反正笔者已经十指已打结了...…

打造个性化的Internet Explorer

作者&#xff1a;孙辉 在Microsoft的软件哲学中&#xff0c;框架窗口是一个十分重要的角色&#xff0c;这类窗口简直无处不在。所谓框架窗口&#xff0c;就是四个窗口边上具有停靠对象能力的窗口对象&#xff0c;从现象上看&#xff0c;框架窗口有十分特别的“边”&#xff0c;…

百度家电行业报告摘录

上图反映了关注家电信息的网民在百度频道的活跃情况。很明显&#xff0c;百度贴吧、百度图片和百度知道是网民最活跃的频道&#xff0c;特别是百度贴吧&#xff0c;有超过四分之一的检索量都来自于百度贴吧。百度有不少以家电品牌或产品为主题的贴吧&#xff0c;比如海尔吧、TC…

如何识别能把桥压塌的大车?快看!能救命!

全世界只有3.14 % 的人关注了青少年数学之旅2019年10月10日晚6:10左右&#xff0c;江苏无锡市北环路附近一高架桥出现桥面侧翻&#xff0c;经现场初步勘测&#xff0c;桥下被压小车3辆&#xff08;其中一辆系停放车辆&#xff0c;无人&#xff09;。经搜救确认&#xff0c;事故…

如何用outlook express 收发邮件

一&#xff0e;创建用户1.打开Outlook express软件&#xff0c;单击“工具”选项&#xff0c;选择“帐户”选项。2.单击“添加”按钮&#xff0c;选择“邮件”选项。3.在“连接向导”中&#xff0c;输入发件人姓名&#xff0c;在对方收到邮件后&#xff0c;发件人姓名将会显示在…

java虚拟机 山寨机_十年前的山寨机居然有系统?没错,还是纯国产的

文丨太平洋数码苍茫的天涯是我的爱&#xff0c;绵绵的青山脚下花正开&#xff0c;什么样的节奏是最呀最摇摆……你是我天边最美的云彩&#xff0c;让我用心把你留下来(留下来)……不知道大家是否还记得这段熟悉的旋律&#xff0c;总之小编我今天再次回听这首歌的时候身体依然会…