![]() |
[分享][转帖]MATLAB中曲面转入ANSYS程序(附程序)
2 个附件
前段时间因课题需要,写了个MATLAB程序,把MATLAB中计算的曲面导入ANSYS,以作进一步处理。
稍作修改,使其更有通用性。因水平有限,程序还有很多不足之处,请大家验证讨论。 例: [CODE]t=0:pi/10:2*pi; [x,y,z]=cylinder(2+cos(t)); mat2ans('cylinder.lgw',x,y,z); [/CODE] 运行ANSYS,在命令窗口输入:/input,cylinder.lgw 得到ansys中的曲面,该过程中ansys提示有几个错误,有些样条线和关键点不能删除,那是需要保留的。 |
源程序:
[CODE]function mat2ans(filename,x,y,z) % 把MATLAB计算的曲线曲面导入ANSYS % author:paradiseboy % 2004-7-13 % Henan Polytechnic University % www.dytrol.com if(ischar(filename)==0) error('Invalid filename'); end if(ndims(z)~=2) error('Variable z must be a 2-dimensional array'); end if any((size(x)~=size(z))|(size(y)~=size(z))) % size of x or y does not size of z if((length(x)==1)&(length(y)==1)) % Must be specifying dx and dy, so make vectors dx=x; dy=y; x=((1:size(z,2))-1)*dx; y=((1:size(z,1))-1)*dy; end if((length(x)==size(z,2))&(length(y)==size(z,1))) % Must be specifying vectors xvec=x; yvec=y; [x,y]=meshgrid(xvec,yvec); else error('Unable to resolve x and y variables'); end end fid=fopen(filename,'w'); if(fid==-1) error(sprintf('Unable to write to %s',filename)); end [m,n]=size(z); x=reshape(x',m*n,1); y=reshape(y',m*n,1); z=reshape(z',m*n,1); fprintf(fid,'/prep7\r\n'); % 进入前处理 % 创建关键点 for i=1:m*n fprintf(fid,'k,%4.d,%.5f,%.5f,%.5f,\r\n',i,x(i),y(i),z(i)); end % 创建样条线 for i=1:m fprintf(fid,'FLST,3,%3.d,3\r\n',n); for j=1:n fprintf(fid,'FITEM,3,%4.d,\r\n',j+(i-1)*n); end fprintf(fid,'BSPLIN, ,P51X\r\n'); end % 由蒙皮技术创建面 fprintf(fid,'FLST,2,%2.d,4\r\n',m); for i=1:m fprintf(fid,'FITEM,2,%d\r\n',i); end fprintf(fid,'ASKIN,P51X\r\n'); fprintf(fid,'ldele,all\r\n'); fprintf(fid,'kdele,all\r\n'); fprintf(fid,'aplot\r\n'); fprintf(fid,'NUMCMP,ALL\r\n'); fprintf(fid,'FINISH\r\n'); fclose(fid); [/CODE] |
2 个附件
>> z=x.*exp(-x.^2-y.^2);
>> [u,v,w]=surfnorm(x,y,z); >> surf(x,y,z); axis equal >> mat2ans('curve.lgw',x,y,z); |
2 个附件
>> [x,y]=meshgrid(-3:.5:3,-3:.1:3);
>> z=peaks(x,y); >> mat2ans('curve.lgw',x,y,z); 这个曲面特性太复杂,在ANSYS中不能由一张曲面构成。 所以导入ansys中会出错,还请高人多指点,谢谢。『[COLOR="Red"]以上内容转自振动论坛[/COLOR]』 |
哈哈,多谢版主分享……
|
共同努力!:tongue: :lol:
|
回复: [分享][转帖]MATLAB中曲面转入ANSYS程序(附程序)
好牛啊,小弟一定努力学习
|
回复: [分享][转帖]MATLAB中曲面转入ANSYS程序(附程序)
为什么我把原代码运行不出来结果?
|
所有时间均为北京时间。现在的时间是 08:02。 |
Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.