0 前 言 QXcSDJ
ub0uxvz
目前,许多CAD系统的曲面模型(Surface Modeling)都是基于NURBS数学方法的,在这类系统中,若以创建曲面的方法来分类,一般可将曲面为分四大类:一是系统直接创建的基本曲面,如锥面、柱面、球面和圆环面;二是动迹(Motion-Based)曲面,如旋转(Revolved)曲面、拉伸(Extruded)曲面和扫掠(Swept)曲面;三是蒙(Skin)面,如直纹曲面、UV放样(Lofted)曲面;四是导出曲面(Derived),如调和(Blended)曲面、倒圆(Fillet)曲面。许多工业产品的外形都具有以下特点:(1) 横截面呈封闭形状,具有一根或两根对称轴;(2)截面形状和大小沿物体轴线是变化的。具有上述特点的工业产品比比皆是,如讲究美观漂亮的化妆品包装瓶、讲求生动活泼的儿童玩具、要求气动特性和受力特性良好且装载空间大的飞机机身、要求美观和谐且风阻系数小的现代汽车外形等等。对于构造外形具有上述特点的工业产品,用基本曲面和动迹曲面已无法完成。用UV向放样的方法可以完成,但是,用UV放样法,首先要大量的数据来生成U、V放样曲线,最后才能产生放样曲面。在新产品造型时,要设计人员给出大量U、V放样曲线的数据相当困难,致使造型效率很低。可见,用UV放样法对具有上述特点的工业产品进行造型,是方法可行而效率不行。针对目前CAD系统存在的不足,我们以AutoCAD为支撑环境,开发了下面介绍的“三维变截面造型系统”。
8(EK17rE` NlS/PWc6( 1 变截面造型基本思想及算法设计 =E?!!EIq. "5,tEP! 1.1 变截面造型基本思想
x!08FL) ~K-c-Zs#z 对于如图1所示的三维物体,从微分的角度来看,可把它切分为一个个大小和形状不同的薄片,当这些薄片趋于无穷薄时就变成了本文所称的截面;从积分的角度来看,又可把三维物体视为由一个个大小和形状不同的薄片沿一轴线叠放而成,这就是三维变截面造型的基本思想。

1.2 算法设计
N=QeeAI}}m dMnJ)R 1.2.1 横截面算法
y,D4b6 z"@yE*6 按照变截面造型的基本思想,横截面是三维物体的构成元素,其大小由宽度、高度参数确定,形状由形状因子确定。这些参数都是沿三维物体轴线变化的(参见图1)。
lj4D:>Ov >K2Md*[P3q 在“三维变截面造型系统”中,我们采用 “中国航空科技文献(HJB880658)《超椭圆及亚椭圆曲线的递推算法》”为横截面的算法,在具体实现中作了取舍和变换。超椭圆、亚椭圆及内摆线曲线族的数学表达式如下:
t)*MLg<C nCz_gYcIx f(x,y)=b
2n[(x-x
e)cosα+(y-y
e)sinα]
2n+a
2n[(y-y
e)cosα-(x-x
e)sinα]
2n-(ab)
2n=0 (1)
9{;cp?\)M d }"Dp (1)式的参数表示如下:
]H4T80wm& u&!QP4$"z (x-x
e)cosα+(y-y
e)sinα=αcos
n1t (2)
q@}eYQ=P|e 0=2D90 (y-y
e)cosα+(x-x
e)sinα=bsin
n1t
MifPZQ RvQl{aL 由(1)式,令
zdoJ+zRtK >Bj+!)96q X
i=[(x
i-x
e)]cosα+(y
i-y
e)sinα]
n 7eh<>X!TX c<`Z[EY(t Y
i=(a/b)
n[(y
i-y
e)cosα-(x
i-x
e)sinα]
n /NH9$u.g &3Q!'pJJ 可得到以下递推公式(推导过程详见参考资料[1])。

将(1)式中的指数进行变换,得 K9#=@}!3L
.%D9leiRe
f(x,y)=[(x-xe)cosα+(y-ye)sinα]2n+[an/bm]2[(y-ye)cosα-(x-xe)sinα]2m-(a)2n=0 (4) i9qn_/<c
\UdHN=A&
在上面的各表达式中,a、b为“椭圆”的半轴,xe、ye为椭圆的圆心,α为椭圆主轴与x轴的夹角,m和n为指数。 CO`%eL~
2&f]v`|M|
在三维变截面造型系统中,a、b为横截面的宽度参数和高度参数,将指数m、n变换处理后作为变截面造型系统中的M、N形状因子。形状因子是变截面造型系统的关键技术和特色技术,形状因子控制着横截面的形状, 其取值与形状的对应关系如下: VZ`L-P$AF
cZ@z]LY.g
·当M=N时
f:_\S
5w\>Whbd
0<M=N<1时:形状在矩形到椭圆之间变化。M=N=1时:形状为标准椭圆。 H>x(c|ZBp
bvf}r
,`Q7
1<M=N<2时:形状在椭圆到菱形之间变化。M=N=2时:形状为菱形。 cBl
F
PfaBzi9?f
2<M=N<40时:形状在菱形到“+”字线之间变化。 SxHj3,`#C
+wAH?q8f
·当M≠N时 'Y
ZYRFWXM
8Rgvb3u
可得到形状特异的横截面。M因子对临近X轴的形状影响大; N因子对临近Y轴的形状影响大。 P,2FH2Eyj
?Mb'l4
1.2.2 纵向控制线算法 x*G-?Xza)
.o(XnY)cgJ
纵向控制线用于描述宽度参数、高度参数及形状因子沿物体轴线变化的规律。在“三维变截面造型系统”中,形状因子的纵向算法采用线性插值,宽度参数、高度参数的纵向算法采用三次样条函数插值。介绍三次样条函数的资料很多,在此不再赘述。 /.'tfy$
jIq@@8 @o
2 系统实现 'w?*4H
$c!cO" U
根据变截面造型的基本思想和纵横向算法,以AutoCAD R13为支撑系统,AutoLISP编程语言和DCL对话控制语言为开发工具,开发了“三维变截面造型系统”。整个造型系统分为横截面设计、纵向控制线设计、造型输出控制、纵向控制线样条拟合、读取造型数据等五个主要功能模块。图2是造型系统运行时的界面。 @A_bZQ@
6^vMJ82U
2.1 横截面设计 G8w<^z>pTg
JMMT886
进行横截面设计的主要目的是寻找满足设计要求的横截面及这种横截面的形状因子值。
2.2 纵向控制线设计 gy
Jx>i
hPs7mnSW
所谓纵向控制线就是用AutoCAD的Pline命令产生的二维多义线。运行纵向控制线设计模块可建立一个纵向控制线设计区域及创建一些基本的控制线。纵向控制线设计区域是一个单位区域,即对角点坐标为(0,0)和(1,1)的矩形区域。宽度和高度控制线完全处于1×1的区域内,形状因子控制线则处于1×40的区域内。 q K sI}X~
U#I8Rd I,
纵向控制线设计模块为设计者提供了两种创建控制线的方法,一种是交互方式,另一种是读数据文件方式。数据文件的格式为每行两个数据,数据间用逗号分隔,表示一个二维坐标点。数据可以是与实物一样大小的数据,程序会自动将其变换后绘制出“单位曲线”,即曲线左端的X坐标为0,右端的X坐标为1。 nN=o/z d
vo9DmW
2.3 造型输出控制 Op&i6V}<s
t:DZow
造型输出控制模块控制的主要内容为:①控制输出的是曲面还是曲线;②控制曲面网格划分疏密或截面线间隔大小;③控制造型体的实际大小和颜色;④控制造型是封闭、完整的还是开口、部分的;⑤控制造型物体的轴线是直的还是曲的;⑥控制计算方法是线性插值还是三次样条函数插值。图3是造型输出控制模块运行时的界面。

图2
b
h%@Lo
图3
造型时,首先,在造型输出控制对话框(见图3)中输入各种造型参数和选定各种选项。其次,根据造型参数和选项,提示设计者在控制线设计区域内选取造型控制线(二维多义线),程序从AutoCAD的内部数据库中读取这些被选取的二维多义线的顶点数据,作为各种插值计算的插值结点。最后,进行造型计算,产生造型结果。 h|=<I)}z
As&=Pb9
2.4 控制线样条拟合 @a08*"lbp
PdUlwT?8C
作为造型控制线的二维多义线实际上是直线段连成的折线。用折线顶点拟合出来的三次样条曲线与折线存在着差异,有时差异会很大。为保证用折线顶点拟合出来的三次样条曲线符合预期要求,在造型之前,可进行样条拟合试算。 EJM6TI"
7QXA*.'
F
2.5 读取造型数据 Zc_%hQf2A
5'JONw'\
用数据读取模块,可读取曲面网格顶点或横截面曲线的数据,生成数据文件,便于在AutoCAD系统以外应用。 U*G8}W
u&q RK>wLa
3 应用实例及造型例子 aZ[
aZU
Lci SQ
R!
3.1 应用实例 uSeRn@
SLzxF uV
用本系统来设计飞机机身外形,当M、N形状因子在0.5~0.8之间取值时,可得到比圆或标准椭圆截面更美观、有效空间更大、抗弯抗扭能力更强的机身外形。而且机身截面曲线计算简便,纵向容易控制和修改,与传统的设计方式比较,具有简洁高效的优越性。 j.? '*?P
6qW/Td|g
3.2 造型例子 ?;s}GpEY:
K%Dksx7ow
图4右边的两个花瓶是用同一根宽度、高度控制线配以不同的形状因子控制线造型产生的,上面的花瓶用的是形状因子线1,下面的花瓶用的是形状因子线2。

4 结束语 }ze,6T*z
Ck71N3~W
大家都知道,旋转曲面的轴向大小可变,但横截面形状却只能是圆形。拉伸曲面的横截面可以是圆以外的任何形状,但其形状在拉伸方向是不可变的。本文介绍的变截面造型系统,突破了这两种曲面的局限,拓展了AutoCAD系统的造型能力,特别适合构造外形具有本文前言所述特征的工业产品,而且造型效率很高。 f`zH#{u
FtaO@5pS54
本系统的造型准备工作,在单位区域内进行,容易操作。造型输入数据是一些直观的、可视化的控制线,所以,形状容易控制和修改。控制线的点数(含端点)大于或等于2即可,因此,需输入的数据很少。