|
本文简明扼要地介绍了ug/Post后处理器的基本概念,组成及内容,目的是使广大读者从全局上对UG/Post有所了解和认识,文章深入浅出,实用性强,是一篇不可多得的普及力作。
2 q' z+ |+ t6 D2 g# S$ k一、后处理简述- y& S/ N+ X! K' C+ p. Z* K# o( f
无论是哪种CAM软件,其主要用途都是生成在机床上加工零件的刀具轨迹(简称刀轨)。一般来说,不能直接传输CAM软件内部产生的刀轨到机床上进行加工,因为各种类型的机床在物理结构和控制系统方面可能不同,由此而对NC程序中指令和格式的要求也可能不同。因此,刀轨数据必须经过处理以适应每种机床及其控制系统的特定要求。这种处理,在大多数CAM软件中叫做“后处理”。后处理的结果是使刀轨数据变成机床能够识别的刀轨数据,即NC代码。9 J- l: L& R2 V# m! B8 v3 j, [
可见,后处理必须具备两个要素:刀轨——CAM内部产生的刀轨;后处理器——是一个包含机床及其控制系统信息的处理程序。' L: _9 t) W* Z& ^- K* x: F* s' Z
UG系统提供了一般性的后处理器程序——UG/Post,它使用UG内部刀轨数据作为输入,经后处理后输出机床能够识别的NC代码。UG/Post有很强的用户化能力,它能适应从非常简单到任意复杂的机床及其控制系统的后处理。+ j6 b, J$ s8 h
二、UG/Post组成结构( e* h1 i' S" d9 O' [
提到UG/Post后处理器,不得不简单的介绍一下MOM(Manufacturing Output Manager),即加工输出管理器。MOM是UG提供的一种事件驱动工具,UG/CAM模块的输出均由它来管理,其作用是从存储在UG/CAM内的数据中提取数据来生成输出。UG/Post就是这种工具的一个具体运用。MOM是UG/post后处理器的核心,UG/post使用MOM来启动解释程序,向解释程序提供功能和数据,并加载事件处理器(Event Handler)和定义文件(Definition File)。
# u. W6 c, W+ m8 `; V. x0 c 除MOM外,UG/post主要由事件生成器、事件处理器、定义文件和输出文件等四个元素组成。一旦启动UG/POST后处理器来处理UG内部刀轨,其工作过程大至如下:事件生成器从头至尾扫描整个UG刀具轨迹数据,提取出每一个事件及其相关参数信息,并把它们传递给MOM去处理;然后,MOM传送每一事件及其相关参数给用户预先开发好的事件处理器,并由事件处理器根据本身的内容来决定对每一事件如何进行处理;接着事件处理器返回数据给MOM作为其输出,MOM读取定义文件的内容来决定输出数据如何进行格式化;最后,MOM把格式化好的输出数据写入指定的输出文件中。图1描述了这些概念及内容。
( p/ s8 Y3 _- O( O& P 2 X4 U# `# i3 Q1 B
5 S) h& w/ d- c4 n- h6 ?; p图1 UG/post的工作过程示意图 三、UG/Post的组成元素 ^: k' \5 K/ M( |/ q
下面进一步介绍组成UG/Post的四个基本元素。% U4 ?% T2 r# C5 a
1.事件生成器
$ B% r. t* X$ t4 G, D 事件生成器是UG提供的一个程序,它从UG文件(Part)中提取刀轨数据,并把它们作为事件和参数传送给MOM。每一特定事件在机床运行时将导致一些特别的机床动作,存储在与这个事件相关的参数中的信息用来进一步确定这些特别的机床动作。比如,一个“Linear-Move”事件将导致机床驱动刀具沿直线移动,而具体移动到的位置则由存储在与此事件相关的参数X、Y、Z中的数值来进一步确定。在这个例子中,事件生成器将触发“Linear-Move”事件,并且将代表终点位置的数据装入相应的参数X、Y、Z,然后这些信息传送到MOM去处理。 G2 a2 h& P. `: D" u$ J7 Z
UG/Post的事件很多,分为五大类:设置事件(Setup-event)、机床控制事件(Machine Control event)、运动事件(Move event)、固定循环事件(Cycle event)、用户定义事件(User Defined event)等。有关事件及其相关参数的详细描述,可参见UG的帮助文档。+ p( _( i* l* q% Q$ s: x7 v& Z
在进行后处理时,事件生成器生成各事件有一定的顺序,并且这个顺序是固定的,不能改变。其生成顺序大致如下:. W0 s, U; r5 s: S( ^ b- A" [
Start of Program
6 e2 j/ G5 u! W. NStart Post UDE's attached to the program
2 k. _ S! N* p! H h5 G0 CStart of Group0 g$ b4 F& [* v- f* Z# v) u
Start Post UDE's attached to the group+ ~* ?. y, I& q, @
Machine Mode! [; p5 y$ E, o9 A4 }" b# U
Start of Path
+ a6 B% o. V2 ^6 WStart Post UDE's attached to the operation
]& P9 o6 `1 t& x7 H4 R* m; K& MFirst Tool (Tool Change,No Tool Change)
8 g. B5 n9 c$ V" r% }Load Tool% C* ^9 ?/ r% J$ n8 B- p& c
MSYS
" n0 J. w0 x' r; T5 o0 o+ p: }" YInitial Move (Initial Move,First Move)
/ Y: L& s5 C, }( [& b; c2 RTool Path
$ N' J0 `$ p' w! i$ {2 gEnd Post UDE's attached to the operation
6 ?) n% F' V Y/ _ x6 T' R! tEnd of Path
% O) G2 P# x; h V" e) Z5 ?7 t9 F6 S- sEnd Post UDE's attached to the group
& Z& w* q3 I5 |; @) |End of group4 b+ m2 A/ i" e2 i5 u
End Post UDE's attached to the program. X- _ `. Y$ i2 ~3 w
End of program
6 w$ a @, ?; p- T$ a+ j5 W+ @2.事件处理器- O& F7 Z5 E0 w9 @
事件处理器是为特定机床及其控制系统开发的一套程序。每个事件的处理函数必须包含一系列指令去处理用户希望UG/Post处理的事件,这些指令将定义刀轨数据如何被处理,以及每个事件在机床上如何被执行。
) }3 M5 R7 G5 c2 F* I- r 用来定义事件处理器指令的计算机语言是TCL(Tool command language)。TCL是一种解释型的计算机语言,以其小巧、灵活、功能强大、易于扩展、易于集成而闻名。当UG/Post进行后处理时,TCL语言的解释器充当了UG/Post的转换器。8 [. J( S4 {# c! T9 j7 r( c g
对于用户希望UG/Post去处理的每个事件,必须有一个TCL过程与之对应。事件生成器触发一个事件时,MOM将调用与之对应的TCL过程去处理该事件,并把与此事件相关的参数作为全局(Global)变量传送给处理它的TCL过程。如果不希望事件处理器去处理某个特别的事件,在事件处理器中不要包含处理该事件的TCL过程或使该事件的TCL过程为空即可。另外,处理事件的TCL过程名必须与事件生成器触发的事件名统一。比如,处理Tool change(换刀)事件的TCL过程名必须是MOM_tool_change。" F: t8 c; F9 `6 G* x
3.定义文件) o1 H5 f. A0 f( r0 T( t8 W* h5 x
定义文件主要包含与特定机床相关的静态信息。因为机床的多样性,至少每类机床需要一个定义文件。大多数NC机床使用地址(Address)这一概念来描述控制机床的各个参数。比如,X地址用来存储机床移动时终点的X坐标值。NC程序中的每个命令行通过改变地址的值来达到改变机床状态的目的,而机床加工工件的过程实际上就是一系列机床状态发生改变的过程。UG/Post实现了一定的机制,使用定义文件中的信息来格式化NC指令。正如事件处理器一样,UG/Post的这种机制本质上也是由TCL语言来实现的,只不过是TCL语言核心的扩展。定义文件包含下列内容:. ~$ v! x r6 a! ~/ m
(1)一般的机床信息,如机床是铣床还是车床,是三轴还是五轴等;1 ]5 j, F* S, t2 q
(2)机床支持的地址,如X、Y、Z、A、B、C、T、M等;
]) r4 W0 ~& Z$ a& z0 @8 I (3)每个地址的属性,如格式、最大值、最小值等;
" m4 x! p6 R( y3 @ (4)模块,它们描述多个地址如何组合在一起来完成一个机床动作。比如,命令G01 X[Xval] Y[Yval] Z[Zval]完成一个直线移动。9 i0 D' S3 M5 w* ?, d6 A0 W
4.输出文件/ P, a- O2 T' T5 ?7 x' U' ~
在UG/post执行时,即后处理时,用户指定一个文件来存储后处理生成的NC指令,这个指定的文件就是输出文件。输出文件的内容由事件处理器来控制,而输出文件中NC指令的格式由定义文件来控制。8 R. R% ^: |; T9 y8 D- F
有了包含NC指令的输出文件后,这个文件就可以传送到机床上进行加工了。. t: B1 {! V d5 Y# Z% V+ @; P, D8 Z
四、UG/Post的开发方法* K0 J, |' r9 Y5 o8 ~1 G
UG/Post的开发,其核心是TCL语言的运用。如前所述,TCL是一种解释型的计算机语言,由John K. Ousterhout于加洲大学伯克利分校开发成功,目前由SUN微系统公司提供支持和维护。TCL是一款自由软件,并且它可支持Unigraphics NX当前支持的所有平台。虽然本质上都是使用TCL语言,但具体实现上却有两种途经:PostBuilder和手工编程6 p) p# x1 ~+ W. w1 m/ [
PostBuilder是UG系统为用户提供的后处理器开发工具。使用它用户只需要根据自己机床的特点,在GUI环境下进行一系列的设置即可完成后处理器的开发。值得一提是,使用PostBuilder不仅生成事件处理器文件(*.tcl)、定义文件(*.def),还生成一个特别的文件(*.pui)。这个文件是专供PostBuilder使用的,记录着关闭PostBuilder时的配置,对后处理器来说,这个文件是多余的。关于PostBuilder的更多信息可参见UG帮助文档。
; x9 A e& i8 q& ~' {$ f 手工开发后处理器,就是直接用TCL语言编写事件处理器文件(*.tcl)和定义文件(*.def)。这要求用户具有TCL语言的基本知识,同时,还要了解UG对TCL语言的扩展部分。虽然手工开发后处理器对用户技能要求较高,但手工开发灵活、方便,开发的后处理器精炼、易懂、执行效率高。
* {& [9 g1 l0 Y五、UG/Post的安装及使用6 j' u. G/ B) R6 L ^+ l: Y
一旦用户结合自己的机床特性,使用TCL开发好了后处理器,接下来就要考虑如何向UG系统安装它,以及如何在UG系统中使用它了。1 q( O* C& C" f, _7 ]! N
1.安装后处理4 L2 W. J' G% _* k" H& w
为了使一个后处理程序能够在UG中进行使用,必须在后处理配置文件中注册、安装它。UG系统默认的后处理配置文件及其在注册表中的位置为${UGII_BASE_DIR}\MACH\ resource\postprocessor\template.dat。该文件中,“#”开始的行为注释行,其他每一行为一个后处理器注册项,其格式为:- R9 a9 E# [$ ]
后处理器名,包含路径的事件处理器文件,包含路径的定义文件( }) [7 N7 p( p$ `
例如,MILL_3_AXI S,${UGII_CAM_POST_DIR}mill3ax.tcl, ${UGII_CAM_POST_DIR}mill3ax.def。1 V1 ?" [- M! t
2.使用后处理
$ T+ m1 T$ z7 B0 v y 当后处理器安装好后就可以使用了,具体的做法如下:打开已经做好加工操作(Operation)的UG文件,选取一个或多个加工操作,点击“Manufacturing Operations”工具条上“UG/POST postprocess”图标(见图2),出现如图3所示的对话框,在对话框中选取特定机床的后处理器以及输入输出文件的名称,点击Ok或Apply即可生成输出文件。
7 a b1 f. ?, D : f# N. K/ o0 K* W. A! s( f. n; g
9 a! J; x7 {$ e& q图2 Manufacturing Operations的部分工具条 " W4 z7 `8 I* l8 G) p H
1 [7 H' }) g2 K7 {6 q
图3 后处理对话框 六、结束语6 E' n& v3 m2 R- m8 M4 c1 C3 U" S; F
UG后处理是UG/CAM应用的关键技术之一,随UG系统提供的后处理器一般不能适应各企业的机床多样性,因此学习、开发和维护UG后处理器是各UG/CAM用户必须注意的环节。
. C m5 ]2 E' H' y# x E 至于UG/Post后处理器的细节请参见相关资料:有关事件生成器所生成的事件和定义文件中如何定义NC代码格式的部分请参阅UG的帮助文档;有关PostBuilder的部分请参阅PostBuilder的帮助文档;有关TCL语言的部分请参阅关于TCL语言的书籍;有关TCL语言对UG/CAM的扩展部分请参阅UG的帮助文档。 |
评分
-
查看全部评分
|