|
Pro/ENGINEER是由美国PTC公司开发的三维CAD软件,在工业造型设计和模具设计制造行业中得到广泛应用。运用Pro/ENGINEER软件,设计人员可以在计算机上实现虚拟现实设计和制造。 在Pro/ENGINEER软件中,Program模块是自动化零件与组合件设计的一项重要工具,使用者可以经由非常简易且高级的程序语言来控制特征的出现与否、尺寸的大小、零件的出现与否、零件的个数等。当零件或组合件的Program设计完成后,往后读取此零件或组合件时,其各种变化情况即可利用问答式的方式得到不同的形状,以实现产品设计的要求。
) I: P' l- K/ y2 |6 D+ P+ a 齿轮虽然在机械行业中有广泛的使用,但Pro/ENGINEER软件不能直接生成。通过复杂的造型设计虽可以生成齿轮,但变化齿数、模数和变位系数后,又需进行复杂的设计计算和造型形状判断,工作量很大,齿轮的三维造型设计成为造型设计中望而却步的工作。本文基于渐开线齿轮的生成原理,结合Program程序,研制出变位直齿圆柱齿轮实体造型的自动化设计程序,用户只要输入齿轮的设计参数(齿数z1、z2,模数m,变位系数x1、x2,齿槽圆角半径、齿宽、轴孔直径、键槽高度和宽度)就可以快速地生成齿轮实体,使用简单方便,该设计软件可以广泛地应用于网页设计和机械产品造型设计中。
. B( `8 ^( E5 p& Z1 B2 齿轮齿槽形状的精确确定
. h' Q# W2 {1 s, L 齿形的渐开线形状可通过高级Sweep特征设计精确地设计出来,但齿轮齿槽的形状与齿轮齿数、模数、变位系数和压力角有关。具体地说,下列两种情况决定齿槽的形状:% Q" o- G) V" [" ?! n# Q
F- ~( }# x6 h3 V. [$ y. I0 u
1 E0 a' w; x- I5 \, ]( i! B/ I; I图1 第一种情况的齿槽形状 图2 第二种情况的齿槽形状 即:齿根圆的半径小于渐开线的基圆半径时和齿根圆的半径大于渐开线的基圆半径时。为了叙述方便,下文中,分别称前者为a情况,后者为b情况。因齿轮的啮合只在渐开线部分,因此对于a情况,设计时可在基圆的以下部分加与渐开线相切的直线以连接齿根圆,如图1所示。而对于b情况则无需加相切直线,仅截取渐开线的一部分即可,如图2所示。 0 p t7 {- Q. C9 l* B; B
3 程序设计时需解决的几个关键问题
* k: C1 y* E$ F# Z. g% S8 j( i 3.1 啮合角的计算! I- h, ]. ] N) ^, V
变位齿轮的齿顶圆直径和啮合角有关,因此设计时必须先由输入的齿轮设计参数经过复杂的数学计算得到啮合角值。
; ^3 Y: c; {: o) D; R; B% @ 我们知道,外齿合时的啮合角计算公式为:: V- x1 G: M+ H4 H

s. g6 h# @5 `/ b* I3 \ 可见 无法由显式直接表达出来,因此也就无法直接计算出来。虽然用C语言可以数值计算出 ,但Program自带的程序不支持C语言,幸运的是利用Program自带的解方程程序可以解出 ,具体的设计程序是:/ P$ ^9 ^% L+ q$ J1 x

0 p4 n! Q( X- o" V 上式中 必须赋初值,否则数值解会不确定,考虑到啮合角一般大于10度,所以初值设为10即可。由于Program程序中三角函数内的角度是度,因此公式右边最后的 应处理成弧度,以便和tan 同量纲。+ g8 r: p8 ?- B" B
3.2 a种情况和b种情况齿轮的调用* F! I( K8 B+ l! o3 E
对于Pro/ENGINEER软件,在零件设计模式下是无法实现两种不同零件的调用的,但在装配模式下可以实现这种调用功能,具体的方法是:在.asm下新建文件,坐标系统为mmns,把a、b两种情况的齿轮造型在基准缺省方式下直接装配在一起,这时的装配件是a和b两种情况齿轮的重叠,Program编程时,通过判断齿轮的齿根圆半径是否大于渐开线的基圆半径来决定采用a种情况还是b种情况的齿轮。若齿根圆半径小于基圆半径,则采用a种情况的齿轮 ;否则,则采用b种情况的齿轮。
! W* \4 N6 E. X" P2 Q0 f* w4 齿轮的自动化设计程序流程图
3 W" d. }4 c* d0 L Z. ~1 U3 B 4.1 a、b两种情况时的齿轮自动化设计流程图
) @# i: z( k8 m$ _9 R 图3是a种情况时齿轮的自动化设计流程图。b种情况的齿轮自动化设计流程和上图类似,只是齿槽设计时改为b种情况即可。
% e ~7 o" ]2 E' I7 G! C" N0 G( y 4.2 综合a种和b种两种情况时的齿轮自动化设计流程图+ X* n3 B2 t' H% ^2 Z% y4 j0 A0 h
综合a和b情况后的自动化设计流程图如图4所示。8 `/ R2 S0 p1 b- ^4 N. G* R8 v
图3 a种情况的齿轮自动化设计流程 图4 综合a、b两种情况后的齿轮自动化设计流程 5 源程序, O# N% N6 E2 F6 q& W% u
5.1 a种情况的齿轮自动化设计Program原程序
/ y# v+ T. A9 @. d% G- G/ l0 o! `VERSION
2 X$ L. c+ B" L1 D! rREVNUM 238336 I/ @0 H8 U0 K. X" C. U
LISTING FOR PART GEAR_A
, b5 h6 ]' c7 m/ b. pINPUT
" o- F, Z+ R& t! |Z1 NUMBER /*齿轮1齿数
" K% v% G1 M; S |1 o1 M"Enter Z1: "
( W* `' D) Z( g' l$ m. uZ2 NUMBER /*齿轮2齿数* d7 V0 I) t5 t) w, y
"Enter Z2: " h4 u5 ` ?0 B' b( z& F: a
M NUMBER /*模数
4 R: @' d. P3 y6 Q5 q! H"Enter M: "
+ {5 f6 c' @8 O7 QX1 NUMBER /*齿轮1变位系数+ Y4 X% u7 r( C# X1 m" C; F( @
"Enter x1:"
% i5 M& E& O9 }: y" I) ^% AX2 NUMBER /*齿轮2变位系数/ }( P! w( h L. I- @
"Enter x2:"
: ~; }) x1 R) e" A# nALPHA NUMBER /*压力角1 g& [ X% R" o% _" I' @ n' S
"Enter the pressure angle: "
# C+ G2 u1 r N2 CGEAR_WIDTH NUMBER /*齿轮宽度( c1 {; ]/ \! x3 H# }
"Enter the gear width: "7 y! P6 U& ?5 f1 Z9 b
RAD_FILLET NUMBER /*齿槽圆角半径
$ \. }$ b6 o# D4 X' O% R w"Enter rad_fillet:"! g1 m# J- L1 [
SHAFT_DIA NUMBER /*轴孔直径
, X& w- \, R+ H4 X0 F3 `8 _"Enter shaft_dia:"
1 T2 ?# N7 E5 G l- ?KEY_WIDTH NUMBER /*键槽宽度
9 O2 g3 u" S4 v) L"Enter key_width:"0 H9 N! X% U1 W2 V
KEY_HEIGHT NUMBER /*键槽高度
) z' f- s8 D5 X% i3 n2 o0 f"Enter key_height:"
3 c* D; i$ \$ {END INPUT. t$ B$ g- F5 o
RELATIONS
) X ^& [$ B6 ~$ T, }' g1 u0 dINVA=TAN(ALPHA)-ALPHA*PI/180 w0 u( F- {/ U* N! e4 `
/*标准压力角时的渐开线函数值
( S3 E/ w: s3 M" _; fINVAP=2*(X1+X2)*TAN(ALPHA)/(Z1+Z2)
5 D# J$ k1 L- z2 B, w/ \, \ +INVA . m" ?; r! S7 n/ r0 d
/*计算啮合角时的渐开线函数值
; M* M3 x) ~# |9 q9 i1 Z/ O1 yAP=10
' ]3 F; x/ u# v9 D' CSOLVE /*解方程程序0 q% ?) s* g. `
INVAP=TAN(AP)-AP*PI/180
% O, J5 y1 a9 BFOR AP
" b" t/ Q1 G% x# f( Y0 _HA=1 /*齿顶高系数
" P5 [ l2 f. A; mIF M<1 /*径向间隙系数的确定) W6 h$ R! E+ ] H8 M" D& }
C=0.35
7 i. t. ]" x7 B) y9 nELSE
' Q1 z1 ]' n+ S- D7 j8 @ C=0.25 X4 f6 s! E3 u4 n) b* Q
ENDIF
" }5 M# k, n1 x- H! S- O% bR1 = 0.5*M*Z1 /*齿轮1分度圆半径
3 k* ^) @' l ^8 n2 G/ v7 U' b1 f6 d2 nR2 = 0.5*M*Z2 /*齿轮1分度圆半径
- u6 @& r! u3 ~ D = R1+R2 /*标准中心距
6 H' ?4 e0 [! F7 [1 vRD = D*COS(ALPHA)/COS(AP) - k: X/ X" j- t+ m- F" ?" m( ^! P% {$ r/ S
/*实际中心距
+ i! n. c1 [2 e* YRB1 = R1*COS(ALPHA) /*基圆半径
8 ^: w5 c, t; U4 P( G: lRF1 = R1-M*(HA+C-X1) /*齿根圆半径3 c; E( X0 n4 t: V
RA1 = RD-R2+M*(HA-X2) /*齿顶圆半径. c7 l4 }& P5 K4 M% W
THICK1 = M*(0.5*PI+2*X1*TAN(ALPHA))
/ S; k1 H# I! d8 R) [# P% E /*分度圆上齿厚(弧长)3 L( v9 ~% w4 Y4 m8 z5 G1 p
TOOTH_THICK1=THICK1*COS(ALPHA)
! m% ~; u+ g' |- i2 A# o8 u +2*RB1*INVA /*基圆上齿厚(弧长)0 W" _( o* w0 m q* G4 o4 E1 ?
ANG_TOOTH_THICK1=TOOTH_THICK1/RB1*180/PI /*基圆上齿厚角(度) O% @, c; _6 J$ {4 f
D0=RA1 /*内部参数赋值* s$ S0 v& ^( k/ D6 R$ @
D1=GEAR_WIDTH
' J8 N' h# Y5 l5 dD2=360/Z1
4 k# f, T3 @& e; o) k& y# YD3=ANG_TOOTH_THICK1
. H4 b5 S3 _" I& VD4=180/Z1
" i( x6 i1 i; k' x( l# T# TD5=RB1
* }! x4 a% ~- S4 ED13=RF1
/ ?5 i1 }2 s* _7 a+ GD14=RAD_FILLET# T, I- R3 v& D5 K
D15=360/Z1# H2 `" q$ m, e. } A# v" j/ o
P16=Z18 f/ w! P. b0 {& e4 o) s+ K
D36=SHAFT_DIA
$ r9 ?5 a+ |* qD37=KEY_HEIGHT' w9 ~$ {( S1 t. A$ D$ ^
D38=KEY_WIDTH 7 J# y" c o9 f7 m4 }& t( g$ F
END RELATIONS
+ f9 p9 ]0 }( t4 M& D…………………………: r+ Y) X: N$ y0 f1 [9 O8 J
5.2 b种情况的齿轮自动化设计Program原程序 o, Y d' Y0 |! `
VERSION 9 S* _' D% N# k/ n0 K8 G. \
REVNUM 60662
$ Z9 C$ k- k4 ^: H6 XLISTING FOR PART GEAR_B
; q& V2 v# y' `! v5 t4 U; S0 BINPUT
, Y2 p' ?3 h% h$ _' A Z1 NUMBER /*齿轮1齿数6 \3 A E# k0 h/ Y6 }9 J: X
"Enter Z1: "$ R5 A9 i; E8 p d8 j
Z2 NUMBER /*齿轮2齿数! Z" c1 a2 k) u2 G2 m
"Enter Z2: "' x0 C3 d! K3 [: p2 ?! e
M NUMBER /*模数- Q. ^/ J H3 A9 f
"Enter M: "" ~! ~) F/ ^2 ?
X1 NUMBER /*齿轮1变位系数9 M( L& Z3 F" Z6 A# U
"Enter x1:"+ |6 O. U# j% q# E% |
X2 NUMBER /*齿轮2变位系数0 x q# J7 k& ]
"Enter x2:"
3 a9 ]% G" R: z5 Z0 f ALPHA NUMBER /*压力角1 S1 j- I e+ n" m; _
"Enter the pressure angle: "
+ Y, I* d* M7 V! P GEAR_WIDTH NUMBER /*齿轮宽度/ q6 I- z. t- @) t
"Enter the gear width: "
0 Q- L/ f$ {% G- q N RAD_FILLET NUMBER /*齿槽圆角半径
( t- ~/ i3 N/ |) _" X0 v0 Z" Z- g "Enter rad_fillet:"( O# g* C* ?/ _8 y7 v6 |$ H
SHAFT_DIA NUMBER /*轴孔直径
e" M/ J( Z9 t) l& W+ d" B "Enter shaft_dia:"/ u# M. h: Q6 V: X: R2 U) Q
KEY_WIDTH NUMBER /*键槽宽度
% i+ w) R, L- z& c% M f+ I+ i "Enter key_width:"
7 P! H% f! {3 C/ K# }! d8 Y KEY_HEIGHT NUMBER /*键槽高度
" z7 i" F# ?' J) H' | "Enter key_height:"3 J: Q: W2 G O; c" M) j$ i
END INPUT
* K5 ^' D4 ]) _6 b- W+ N. L( wRELATIONS
8 |6 V+ a/ k& l6 EINVA=TAN(ALPHA)-ALPHA*PI/180
/ c) I9 R6 f% `9 a /*标准压力角时的渐开线函数值
s Y% w6 U; ^ wINVAP=2*(X1+X2)*TAN(ALPHA)/(Z1+Z2): r C* R$ ]/ k6 m1 k7 a
+INVA ' L" T5 b6 C! q8 p+ P- y! k$ r' l0 m
/*计算啮合角时的渐开线函数值. Q6 I2 E" e9 r' q
AP=10) {$ h# s5 ^' V5 C) R
SOLVE /*解方程程序4 I- _ e& I# M5 k' z
INVAP=TAN(AP)-AP*PI/180( q G7 _* R4 t4 T
FOR AP $ {. o, ~5 A# x
HA=1 /*齿顶高系数% U, ?- d9 \0 e8 D- n% V
IF M<1 /*径向间隙系数的确定
6 M' J( H0 h+ v' \ C=0.35
8 l( n( h2 _' W# Z1 D+ vELSE
9 M% q4 }. P! c2 F1 D0 p( A C=0.25
+ v; v- l4 v2 c$ z. \* o/ `, xENDIF : t& ~$ j4 t7 _/ V
R1 = 0.5*M*Z1 /*齿轮1分度圆半径0 \& C; V [, e' ~% E+ A
R2 = 0.5*M*Z2 /*齿轮1分度圆半径8 ?3 H, q, w* Q% {* F
D = R1+R2 /*标准中心距
3 O3 k) ?' s3 I, E6 F+ m1 oRD = D*COS(ALPHA)/COS(AP)
8 [5 j* | D/ v# U% m /*实际中心距
, x" G3 N3 _! P( @! sRB1 = R1*COS(ALPHA) /*基圆半径' u5 I% Z& i7 x4 E/ i1 i$ @
RF1 = R1-M*(HA+C-X1) /*齿根圆半径$ `, y6 ], y. g' B
RA1 = RD-R2+M*(HA-X2) /*齿顶圆半径
; m' c! I" m7 a1 ~& c; ^0 k4 TTHICK1 = M*(0.5*PI+2*X1*TAN(ALPHA))1 [+ Z$ ~; D1 t4 K
/*分度圆上齿厚(弧长)
$ E/ _ I h$ l) s0 G: @9 l" pTOOTH_THICK1=THICK1*COS(ALPHA)
3 S2 s3 o5 N0 G" N% F* a +2*RB1*INVA /*基圆上齿厚(弧长)
9 r$ C: H9 i" P. w) \% Q$ h1 wANG_TOOTH_THICK1=TOOTH_THICK1/RB1*180/PI /*基圆上齿厚角(度)
) e( f* B% s& |7 lD0=RA1 /*内部参数赋值% l: F7 A7 t! X3 w: P5 X2 \: K1 ~
D1=GEAR_WIDTH$ I. a/ y! O: q( C9 Q9 ]- E
D2=360/Z1: S; i9 C* z' n
D3=ANG_TOOTH_THICK1
% i! M. Q5 x( d$ B7 I9 z X/ |D4=180/Z1
# v& s* Y. W0 k: t g1 I4 ?. j uD5=RB1
( Q% Y, x, p& q4 _1 {+ vD13=RF1. n8 m: d0 ]! e) y
D14=RAD_FILLET0 r4 b9 O& J, H0 A5 p
D15=360/Z1
& z7 y$ j" @* `' h W# Z4 ]8 a+ TP16=Z1( V" }% u0 e+ i& P1 y3 `3 w5 X
D116=SHAFT_DIA( ~6 q8 f3 Z/ ^, T% Z
D117=KEY_HEIGHT4 N4 ?5 j( @/ n2 \ I* r
D118=KEY_WIDTH$ ? p4 K% s7 `8 w4 [/ ], {
END RELATIONS
) d8 e. H `; L" z# T. v4 k…………………… |
|