基于MATLAB的优化设计.doc
文本预览下载声明
基于MATLAB的曲柄摇杆机构优化设计
1. 问题的提出
根据机械的用途和性能要求的不同,对连杆机构设计的要求是多种多样的,但这些设计要求可归纳为以下三种问题:(1)满足预定的运动规律要求;(2)满足预定的连杆位置要求;(3)满足预定的轨迹要求。在在第一个问题里按照期望函数设计的思想,要求曲柄摇杆机构的曲柄与摇杆转角之间按照(称为期望函数)的关系实现运动,由于机构的待定参数较少,故一般不能准确实现该期望函数,设实际的函数为(称为再现函数),而再现函数一般是与期望函数不一致的,因此在设计时应使机构再现函数尽可能逼近所要求的期望函数。这时需按机械优化设计方法来设计曲柄连杆,建立优化数学模型,研究并提出其优化求解算法,并应用于优化模型的求解,求解得到更优的设计参数。
2. 曲柄摇杆机构的设计
在图 1 所示的曲柄摇杆机构中, 、、、 AB、连杆BC、CD和机架AD的长度。这里规定为摇杆在右极限位置时的曲柄起始位置角,它们由 、、和确定。
图1 曲柄摇杆机构简图
设计时,可在给定最大和最小传动角的前提下,当曲柄从转到时,要求摇杆的输出角最优地实现一个给定的运动规律。这里假设要求:
(1)
和实际输出角的平方误差之和作为目标函数,使得它的值达到最小。
2.1 设计变量的确定
决定机构尺寸的各杆长度 、、,以及当摇杆按已知运动规律开始运行时,曲柄所处的位置角应列为设计变量,即:
(2)
考虑到机构的杆长按比例变化时,不会改变其运动规律,通常设定曲柄长度=1.0,在这里可给定=5.0,其他杆长则按比例取为的倍数。若取曲柄的初始位置角为极位角,则及相应的摇杆位置角均为杆长的函数,其关系式为:
(3)
(4)
、。
2.2目标函数的建立
目标函数可根据已知的运动规律与机构实际运动规律之间的偏差最小为指标来建立,即: (5)
-期望输出角;m-输出角的等分数;-实际输出角,由图 1 可知:
(6)
式中, (7)
(8)
(9)
2.3约束条件
曲柄存在条件:
曲柄与机架共线位置时的传动角(连杆BC和摇杆CD之间的夹角):
最小传动角
最大传动角
由上面的分析可以算出:
(10)
(11)
3MATLAB工具箱优化计算结果
通过上面的分析后,将输入角分成 30 等分(m=30),经过转化为标准形式得到曲柄摇杆机构优化设计标准数学模型为:
(12)
机械优化设计中的问题,大多数属于约束优化问题,此为非线性约束优化问题,运用 MATLAB 优化工具箱的命令函数 fmincon 来处理有约束的非线性多元函数最小化优化问题。
3.1 编写程序求解
(1)首先编写目标函数 M 文件optimfun.m
function f=optimfun(x);
s=30;qb=1;jj=5;fx=0;
fa0=acos(((qb+x(1))^2-x(2)^2+jj^2)/(2*(qb+x(1))*jj));
%pu0=acos(((qb+x(1))^2-x(2)^2-jj^2)/(2*x(2)*jj)); %for i=1:s
fai=fa0+0.5*pi*i/s;
pui=pu0+2*(fai-fa0)^2?(3*pi);
ri=sqrt(qb^2+jj^2-2*qb*jj*cos(fai));
alfi=acos((ri^2+x(2)^2-x(1)^2)/(2*ri*x(2)));
bati=acos((ri^2+jj^2-qb^2)(/2*ri*jj));
if fai0 fai=pi
psi=pi-alfi-bati;
elseif faipi fai=2*pi
psi=pi-alfi+bati;
end
fx=fx+(pui-psi)^2;
end
f=fx;M 文件 confun.m
function [c,ceq]=confun(x);
qb=1;jj=5;m=45*pi/180;n=135*pi/180;
c(1)=x(1)^2+x(2)^2-(jj-qb)^2-2*x(1)*x(2)*cos(m);
%c(2)=-x(1)^2-x(2)^2+(jj+qb)^2+2*x(1)*x(2)*cos(
显示全部