eryar

PipeCAD - Plant Piping Design Software.
RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
posts - 603, comments - 590, trackbacks - 0, articles - 0

Open Cascade DataExchange IGES

Posted on 2014-01-04 21:35 eryar 阅读(7323) 评论(4)  编辑 收藏 引用 所属分类: 2.OpenCASCADE

Open Cascade DataExchange IGES

eryar@163.com

摘要Abstract:本文结合OpenCascade和Initial Graphics Exchange Specification来对IGES格式进行详细说明,理解IGES格式的结构,进而方便对OpenCascade中IGES格式文件读写的实现进行理解。

关键字Key Words:IGES、Open Cascade、Data Exchange

一、引言 Introduction

目前市面上的CAD系统都有自己的数据文件,各个系统之间的数据结构和格式各不相同,这样极大影响了设计和制造部门之间或企业之间的数据传输和程序衔接的自动化,同样给CMM和CAD/CAM的数据通信带来困难。因此,迫切需要数据交换文件格式的标准化。

产品数据的正确交换可以使双方不必重建数据,提高效率。产品数据交换的通常做法是使用数据交换接口,即需要交换的每一系统与标准数据格式(中性格式)之间开发双向转换接口,两系统通过中性格式进行交换。

20世纪70年代末80年代初以来,国际上已做了大量数据交换标准的研究、制定工作。自1980年最早出现IGES1.0后,又产生了许多其他规范如XBF、SET、VDA-FS、PDDI、ESP、CAD*I、PDES等。这些规范各有不同的目的和使用范围,同时也存在着各种问题。在这些规范中,应用最成熟、最广泛的是IGES(Initial Graphics Exchange Specification)。ISO在上述规范的基础上,制定了新的数据交换标准STEP(Standard for the Exchange of Product Model data),其目的是覆盖过去已经存在的规范的功能,并解决实际应用中存在的问题。

IGES是在美国国家标准局的倡导下,由美国国家标准协会(ANSI)组织波音公司、通过公司等共同商议制订的,1980年公布第一版,以后不断完善和扩充,版本不断升级,从IGES1.0仅包含二维图形到IGES3.0支持曲面和三维线框几何,IGES4.0版支持构造实体几何(CSG)造型技术,IGES5.0支持边界表示(BRep)造型技术。目前几乎所有有影响的CAD/CAM系统都配有IGES接口,如Pro/E、CATIA、OpenCascade等。它由一系列产品的几何、绘图、结构和其他信息组成,可以处理CAD/CAM系统中的在部分信息,是用来定义产品几何形状的现代交互图形标准。

本文结合OpenCascade和Initial Graphics Exchange Specification来对IGES格式进行详细说明,理解IGES格式的结构,进而方便对OpenCascade中IGES格式文件读写实现的方式进行理解。

二、IGES规范 the Initial Graphics Exchange Specification

IGES是一种按特定的文件结构安排的数据格式,用来描述产品的设计和生产信息,可用它来交换CAD/CAM系统中以计算机可读的形式产生和存储的各种信息。标准的IGES文件包含固定长ASCII码(Fixed Format)、压缩的ASCII码(Compressed Format)和二进制(Binary Format)三种格式。

固定长ASCII码的IGES文件每行为80个字符,整个文件分为五段(Section):开始段(Start)、全局段(Global)、元素索引段(Direction Entry)、参数数据段(Parameter Data)和结束段(Terminate)。如图2.1所示:

wps_clip_image-21659

Figure 2.1 Fixed File Formats of ASCII IGES File

段标识符位于每行的第73列,74~80列指定为用于段每行的序号。序号都以1开始,且连续不间断,其值对应该段的列数。段标识符是这样规定的,字符“B”和“C”表示标记段;“S”表示开始段;“G”表示全局段;“D”表示元素索引段;“P”表示参数记录参数记录段;“T”表示结束段。固定长的ASCII格式的IGES格式的大概结构如下图2.2所示:

wps_clip_image-17890

Figure 2.2 General file structure of the Fixed Format

下面结合具体的IGES文件来对每个段进行说明,仅包含一个点的示例文件如下所示:

wps_clip_image-18936

Figure 2.3 IGES demo file Generated by OpenCascade

开始段Start Section:该段是为提供一个可读文件的序言,主要记录图形文件的最初来源及生成该IGES文件的相同名称。IGES文件至少有一个开始记录。

全局段Global Section:主要包含前处理器的描述信息及为处理该文件的后处理器所需要的信息。参数以自由的格式输入,用逗号分隔参数,用分号结束一个参数。主要参数有文件名、前处理器版本、单位、文件生成日期、作者姓名及单位、IGES的版本、绘图标准代码等。如图2.3中的2~5行。

元素索引段Directory Entry Section:该段主要为文件提供一个索引,并含有每个实体的属性信息,文件中每个实体都有一个目录条目,大小一样,由8个字符组成一个域,共20个域,每个条目占用两行。如图2.4所示:

wps_clip_image-16738

Figure 2.4 Format of the Directory Entry(DE) Section in the Fixed Format

每一项内容如下:

l 元素类型号(Entity Type Number):说明元素的类型;

l 参数指针(Parameter Data):说明该元素的参数在参数数据段的开始序号;

l 图层:存放图层名和它的指针;

l 参数记录数(Parameter Line Count):数字代表该元素的参数在参数数据段的行数;

参数数据段Parameter Data Section:该段记录了每个元素的几何数据。根据每个图形元素参数数的多少,决定它将有几行。如图2.3所示,116为点,它有三个数据X,Y和Z,分别为1,2,3。

结束段Terminate Section:只占一行,在前32个字符里,分别用8个字符记录了开始段、全局段、索引段和参数数据段的段码和每段的总行数。第33~72个字符没有用到。最后8个字符为结束段的段码和行数。

三、OpenCascade中IGES读写 OpenCascade IGES Reader/Writer

OpenCascade中提供IGES的程序接口有如下功能:

l 加载IGES文件到内存;loading IGES files into memory;

l 检查IGES文件的一致性;checking IGES files consistency;

l 转换IGES文件到OCCT的形状;translating IGES files into OCCT shapes;

l 转换OCCT的形状到IGES文件;translating OCCT shapes into IGES files;

l 访问IGES文件模型;accessing the IGES model;

l 选择IGES文件模型中的实体;selecting entities from the IGES model;

l 访问IGES文件模型中的每个实体;accessing each entity in the IGES model;

实现上述功能的包是IGESControl,可处理的IGES文件格式的版本为5.3。读取IGES文件实体到OCCT形状的方法如下所示:

 

Standard_Integer ReadIGES(const Standard_CString& aFileName,
                          Handle(TopTools_HSequenceOfShape)
& aHSequenceOfShape)
{
    IGESControl_Reader Reader;

    Standard_Integer status 
= Reader.ReadFile(aFileName);

    
if (status != IFSelect_RetDone) 
    {
        
return status;
    }
        
    Reader.TransferRoots();
    
    TopoDS_Shape aShape 
= Reader.OneShape();     
    aHSequenceOfShape
->Append(aShape);

    
return status;
}

将OCCT形状转换为IGES文件方法如下所示:

Standard_Boolean SaveIGES(const Standard_CString& aFileName,
                          
const Handle(TopTools_HSequenceOfShape)& aHSequenceOfShape)
{

    IGESControl_Controller::Init();
    IGESControl_Writer ICW (Interface_Static::CVal(
"XSTEP.iges.unit"),
               Interface_Static::IVal(
"XSTEP.iges.writebrep.mode"));
    
    
for (Standard_Integer i=1;i<=aHSequenceOfShape->Length();i++)
    {
        ICW.AddShape (aHSequenceOfShape
->Value(i));
    }

    ICW.ComputeModel();
    Standard_Boolean result 
= ICW.Write(aFileName );
    
return result;
}

 

四、程序示例 Example Code

通过将OpenCascade中的形状数据导出到IGES文件,结合IGES规格书,可以方便对IGES格式的理解。如下程序所示为将简单的点、线和圆导出到IGES文件:

 

/*
*    Copyright (c) 2014 eryar All Rights Reserved.
*
*           File : Main.cpp
*         Author : eryar@163.com
*           Date : 2014-01-04 20:00
*        Version : 1.0v
*
*    Description : Export OpenCascade shape to IGES entities.
*
*      Key Words : OpenCascade, IGES, DataExchange
*                  
*/

#define WNT
#include 
<gp_Pnt.hxx>
#include 
<gp_Circ.hxx>

#include 
<TopoDS_Vertex.hxx>
#include 
<TopoDS_Edge.hxx>

#include 
<TopTools_ListIteratorOfListOfShape.hxx>

#include 
<BRepBuilderAPI_MakeVertex.hxx>
#include 
<BRepBuilderAPI_MakeEdge.hxx>

#include 
<IGESControl_Controller.hxx>
#include 
<IGESControl_Writer.hxx>


#pragma comment(lib, 
"TKernel.lib")
#pragma comment(lib, 
"TKMath.lib")
#pragma comment(lib, 
"TKBRep.lib")
#pragma comment(lib, 
"TKTopAlgo.lib")
#pragma comment(lib, 
"TKIGES.lib")


void SaveIges(const std::string& igesFile, const TopTools_ListOfShape& shapes)
{
    IGESControl_Controller::Init();
    IGESControl_Writer igesWriter;

    
for (TopTools_ListIteratorOfListOfShape si(shapes); si.More(); si.Next())
    {
        igesWriter.AddShape(si.Value());
    }

    igesWriter.ComputeModel();
    igesWriter.Write(igesFile.c_str());
}


int main(void)
{
    
// vertices.
    TopTools_ListOfShape vertices;
    TopoDS_Vertex theVertex 
= BRepBuilderAPI_MakeVertex(gp_Pnt(1.02.03.0));

    vertices.Append(theVertex);

    SaveIges(
"vertex.iges", vertices);

    
// edges.
    TopTools_ListOfShape edges;
    TopoDS_Edge theLine 
= BRepBuilderAPI_MakeEdge(gp_Pnt(3.04.05.0), gp_Pnt(6.07.08.0));
    TopoDS_Edge theCircle 
= BRepBuilderAPI_MakeEdge(gp_Circ(gp::XOY(), 9.0));

    edges.Append(theLine);
    edges.Append(theCircle);

    SaveIges(
"edge.iges", edges);

    
// put them together.
    TopTools_ListOfShape shapes;
    shapes.Append(theVertex);
    shapes.Append(theLine);
    shapes.Append(theCircle);
    
    SaveIges(
"shapes.iges", shapes);

    
return 0;
}

生成的IGES文件内容如下所示:

wps_clip_image-28112

Figure 4.1 Simple Fixed Format IGES File

结合下图4.2中实体类型号与实体类型的对应表可知,上图4.1中的元素索引D段可以看总共有三个实体,一个是类型号为116的点;一个是类型号为110的直线;一个是类型号为100的圆。

从数据参数P段可以看出116对应的点的坐标为(1,2,3);110对应的直线的两个端点坐标为(3,4,5)和(6,7,8);100对应的圆的数据为圆心在(0,0)半径为9的位于XY平面上的圆。圆的参数数据项每项数据说明见图4.3。

将IGES在OpenCascade中显示如图4.4所示。

wps_clip_image-6405

Figure 4.2 Curve and Surface Entities

wps_clip_image-14168

Figure 4.3 Parameter Data of Circle Entity in IGES

wps_clip_image-22491

Figure 4.4 IGES Entities in OpenCascade

五、结论 Conclusion

结合OpenCascade生成的IGES文件和Initial Graphics Exchange Specification来对IGES格式进行学习。

虽然目前许多CAD/CAM系统主要应用是在不同系统间交换工程图纸、零件模型、运动仿真和动态实验所需要的几何数据,装配或销售产品所需要的图形文件,但是IGES标准在具体应用中经常出现以下问题:

l 交换过程中会出现错误或数据丢失现象。由于IGES所支持的实体十分庞大,在实际应用中,每一个CAD/CAM系统不可能实现IGES支持的所有实体,而只能实现它所涉及的实体的交换,即只能实现IGES实体集的一个子集,但不同系统所实现的子集不可能完全相同。系统之间只能交换所实现子集的交集部分。

l 发送系统前处理器生成的IGES文件的实体类型超出了接收系统后处理器可能接受的实体类型范围,以及发送系统与接收系统之间实体类型集虽相同,但有关属性如颜色、字体、线型等代码不同,也将使部分数据丢失。

l IGES的目的只是传输工程图形及相应信息,它无法描述CIMS环境所需要的产品数据的全部信息。而且IGES对实体的定义是模糊的,这将造成各CAX系统对IGES中定义的实体有不同的理解,如相同的3D曲线功能会因不同软件的计算方式不同而使在使用IGES来执行图形交换时出现不同的曲线或丢失该曲线。

l IGES文件本身规模太大,影响数据文件的处理速度,使数据传输效率不高。

l 在转换数据的过程中发生的错误很难确定,常要人工去处理IGES文件,如在转换数据的过程中经常发生某个或某几个小曲面丢失的情况,这是要利用原有曲面边界重新生成曲面;某些小曲面(Face)在转换过程中变成大曲面(Surface),此时要对曲面进行裁剪。

六、参考资料 References

1. 李原,张开富,余剑锋. 计算机辅助几何设计技术及应用. 西北工业大学出版社. 2007

2. US PRO. Initial Graphics Exchange Specification .1997

3. OpenCascade. Data Exchange IGES Format User’s Guide. 2013

 

Feedback

# re: Open Cascade DataExchange IGES  回复  更多评论   

2018-06-29 14:37 by birds
博主您好,
我在使用bounds函数时发现,该函数对于导入的模型边界大小范围永远是0-1之内,但是通过occ自己生成的曲面却能得到精确的边界值大小。这是为什么?

# re: Open Cascade DataExchange IGES  回复  更多评论   

2018-06-29 20:53 by eryar
@birds
这个要看你的曲面是什么类型。
occ中的曲面有平面、圆柱面等解析曲面,这类曲面的参数范围不一定是0~1;
如果是B样条曲面,参数范围一般是0~1.
建议你可以看看occ的数据结构ModelingData模块。

# re: Open Cascade DataExchange IGES  回复  更多评论   

2018-06-30 21:05 by birds
谢谢,我懂了。还有一个问题请教博主,那就是我想在一个模型表面通过(u,v)提取坐标点,但是往往导入模型occ识别时都不是单一面(也就是有很多个topods_face),这样就需要我对每个面分别处理一次得到一批点,最后导致得到的点区域化,没有规律,并且在面与面交线处有重复点,所以我想问博主的是,有没有办法可以将多个面转化为一个面进行参数化处理,一次性得到所有的点。谢谢

# re: Open Cascade DataExchange IGES  回复  更多评论   

2018-07-03 14:24 by eryar
@birds
可以用拟合算法根据这些面拟合出一个面。

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理