平面连杆机构设计方案_第1页
平面连杆机构设计方案_第2页
平面连杆机构设计方案_第3页
平面连杆机构设计方案_第4页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、平面连杆机构设计方案1 平面连杆机构的运动分析1.1机构运动分析的任务、目的和方法曲柄摇杆机构是平面连杆机构中最基本的由转动副组成的四杆机构, 它可以用来实现转动和摆动之间运动形式的转换或传递动力。对四杆机构进行运动分析的意义是: 在机构尺寸参数已知的情况下, 假定主动件(曲柄)做匀速转动,撇开力的作用,仅从运动几何关系上分析从动件(连杆、摇杆)的角位移、角速度、角加速度等运动参数的变化情况。还可以根据机构闭环矢量方程计算从动件的位移偏差。 上述这些容, 无论是设计新的机械, 还是为了了解现有机械的运动性能, 都是十分必要的, 而且它还是研究机械运动性能和动力性能提供必要的依据。机构运动分析的

2、方法很多, 主要有图解法和解析法。 当需要简捷直观地了解机构的某个或某几个位置的运动特性时, 采用图解法比较方便, 而且精度也能满足实际问题的要求。而当需要精确地知道或要了解机构在整个运动循环过程中的运动特性时,采用解析法并借助计算机, 不仅可获得很高的计算精度及一系列位置的分析结果,并能绘制机构相应的运动线图, 同时还可以把机构分析和机构综合问题联系起来,以便于机构的优化设计。1.2机构的工作原理在平面四杆机构中,其具有曲柄的条件为:a. 各杆的长度应满足杆长条件,即:最短杆长度 +最长杆长度其余两杆长度之和。b. 组成该周转副的两杆中必有一杆为最短杆,且其最短杆为连架杆或机架(当最短杆为连

3、架杆时,四杆机构为曲柄摇杆机构;当最短杆为机架时,则为双曲柄机构)。在如下图 1 所示的曲柄摇杆机构中,构件 AB为曲柄,则 B 点应能通过曲柄与连杆两次共线的位置。1.3机构的数学模型的建立建立机构的闭环矢量位置方程在用矢量法建立机构的位置方程时,需将构件用矢量来表示,并作出机构的封闭矢量多边形。 如图 1 所示,先建立一直角坐标系。 设各构件的长度分别为 L1 、L2 、L3 、 L4 ,其方位角为 、 、 、 。以各杆矢量组成一个封闭矢量多边形,即 ABCDA。其个矢量之和必等于零。即:式 1式 1 为图 1 所示四杆机构的封闭矢量位置方程式。 对于一个特定的四杆机构, 其各构件的长度和

4、原动件 2 的运动规律,即 为已知,而 =0 ,故由此矢量方程可求得未知方位角 、 。角位移方程的分量形式为:式 2闭环矢量方程分量形式对时间求一阶导数(角速度方程)为:式 3其矩阵形式为:式 4联立式 3 两公式可求得:式 5式 6闭环矢量方程分量形式对时间求二阶导数(角加速度方程)矩阵形式为:式 7由式 7 可求得加速度:式 8式 9注:式 1式 9 中, Li(i=1,2,3,4)分别表示机架1、曲柄 2、连杆 3、摇杆 4 的长度; (i=1,2,3,4)是各杆与 x 轴的正向夹角,逆时针为正,顺时针为负,单位为 rad;是各杆的角速度,单位为 rad/s;为各杆的角加速度,单位为。求

5、解方法( 1)求导中应用了下列公式:式 10( 2)在角位移方程分量形式(式 2)中,由于假定机架为参考系,矢量 1 与 x 轴重合, =0 ,则有非线性超越方程组:式 11可以借助牛顿 - 辛普森数值解法或 Matlab 自带的 fsolve 函数求出连杆 3 的角位移和摇杆 4 的角位移。( 3)求解具有 n 个未知量(i=1,2, ,n )的线性方程组:式 12式中,系列矩阵是一个阶方阵:式 13的逆矩阵为 ; 常数项 b 是一个 n 维矢量:式 14因此,线性方程组解的矢量为:式 15式 11 是求解连杆 3 和摇杆 4 角速度和角加速度的依据。基于 MATLAB程序设计MATLAB是

6、 Mathworks公司推出的交互式计算分析软件,具有强大的运算分析功能,具有集科学计算、 程序设计和可视化于一体的高度集成化软件环境,是目前国际上公认的最优秀的计算分析软件之一,被广泛应用于自动控制、信号处理、 机械设计、流体力学和数理统计等工程领域。 通过运算分析, MATLAB可以从众多的设计方案中寻找最佳途径,获取最优结果,大大提高了设计水平和质量。四连杆机构的解析法同样可以用MATLAB的计算工具来求值,并结合 MATLAB的可视化手段,把各点的计算值拟合成曲线,得到四连杆机构的运动仿真轨迹。2.1程序流程图2.2M文件编写首先创建函数FoutBarPosition,函数fsolve

7、通过他确定。function t=fourbarposition(th,th2,L2,L3,L4,L1)t=L2*cos(th2)+L3*cos(th(1)-L4*cos(th(2)-L1; L2*sin(th2)+L3*sin(th(1)-L4*sin(th(2);主程序如下:disp ' * * * * * *平面四杆机构的运动分析*'L1=304.8;L2=101.6;L3=254.0;L4=177.8;%给定已知量,各杆长L1,L2,L3,L4th2=0:1/6:2*pi;%曲柄输入角度从0 至 360 度,步长为pi/6th34=zeros(length(th2),2

8、);% 建立一个N行2列的零矩阵,第一列存放options=optimset('display','off');%_3,第二列存放_3form=1:length(th2)%建立for循环,求解_3, _4th34(m,:)=fsolve('fourbarposition',11,%调用fsove函数求解关于 _3, _4options,th2(m),L2,L3,L4,L1);%的非线性超越方程,结果保存在th34中endy=L2*sin(th2)+L3*sin(th34(:,1)');%连 杆3 的D端点Y 坐标值x=L2*cos(th2

9、)+L3*cos(th34(:,1)');%连 杆3 的D端点X 坐标值xx=L2*cos(th2);%连杆 3 的 C 端点 X坐标值yy=L2*sin(th2);%连杆 3 的 C端点 Y坐标值figure(1)plot(x;xx,y;yy,'k',0 L1,0 0,%绘制连杆3的几个位置点'k-',x,y,'ko',xx,yy,'ks')title('连杆 3 的几个位置点 ')xlabel('水平方向 ')ylabel('垂直方向 ')axisequal%XY坐标均衡

10、th2=0:2/72:2*pi;%重新细分曲柄输入角度_2,步长为5 度th34=zeros(length(th2),2);options=optimset('display','off');for m=1:length(th2)th34(m,:)=fsolve('fourbarposition',1 1,options,th2(m),L2,L3,L4,L1);endfigure(2)plot(th2*180/pi,th34(:,1),th2*180/pi,th34(:,2)%绘制连杆3 的角位移关于曲柄2 的角位移图plot(th2*180/p

11、i,th34(:,1)*180/pi,th2*180/pi,th34(:,2)*180/pi)%绘制摇杆4 的角位移关于曲柄2 的角位移图axis(03600170)% 确定 XY边界值grid%图形加网格xlabel('主动件转角 theta_2(度 )')ylabel('从动件角位移 ( 度 )')title('角位移线图 ')text(120,120,'摇杆 4 角位移 ')text(150,40,'连杆 3 角位移 ')w2=250;%设定曲柄角速度for i=1:length(th2)A=-L3*si n

12、(th34(i,1) L4*sin(th34(i,2);L3*cos(th34(i,1) -L4*cos(th34(i,2);B=w2*L2*sin(th2(i); -w2*L2*cos(th2(i);w=inv(A)*B;w3(i)=w(1);w4(i)=w(2);endfigure(3)plot(th2*180/pi,w3,th2*180/pi,w4);%绘制角速度线图axis(0360-175200)text(50,160,'摇杆 4 角速度 (omega_4)')text(220,130,'连杆 3 角速度 (omega_3)')gridxlabel(&

13、#39;主动件转角 theta_2(度 )')ylabel('从动件角速度 (radcdot s-1)')title('角速度线图 ')for i=1:length(th2)C=- L3*sin(th34(i,1) L4*sin(th34(i,2);L3*cos(th34(i,1) -L4*cos(th34(i,2);D=w22*L2*cos(th2(i)+w3(i)2*L3*cos(th34(i,1)-w4(i)2*L4*cos(th34(i,2);.w22*L2*sin(th2(i)+w3(i)2*L3*sin(th34(i,1)-w4(i)2*L4

14、*sin(th34(i,2);a=inv(C)*D;a3(i)=a(1);a4(i)=a(2);endfigure(4)plot(th2*180/pi,a3,th2*180/pi,a4);%绘制角加速度线图axis(0 360 -70000 65000)text(50,50000,'摇杆 4 角加速度 (alpha_4)')text(220,12000,'连杆 3 角加速度 (alpha_3)')gridxlabel('从动件角加速度')ylabel('从动件角加速度(radcdot s-2)')title('角加速度线图

15、 ')disp '曲柄转角连杆转角- 摇杆转角- 连杆角速度- 摇杆角速度- 连杆加速度- 摇杆加速度'ydcs=th2'*180/pi,th34(:,1)*180/pi,th34(:,2)*180/pi,w3',w4',a3',a4'disp(ydcs)2.3程序运行结果输出>>*平面四杆机构的运动分析*曲柄转角连杆转角- 摇杆转角- 连杆角速度- 摇杆角速度- 连杆加速度- 摇杆加速度1.0e+004 *00.00440.0097-0.0125-0.0125-0.54784.84580.00050.00420.00

16、94-0.0126-0.01070.23005.56300.00100.00390.0092-0.0124-0.00860.89466.05200.00150.00370.0091-0.0119-0.00651.41436.29820.00200.00340.0090-0.0114-0.00431.78016.31740.00250.00320.0089-0.0107-0.00212.00276.14670.00300.00300.0089-0.01000.00002.10465.83390.00350.00280.0089-0.00930.00202.11345.42720.00400.00

17、260.0090-0.00850.00382.05664.96870.00450.00250.0091-0.00780.00541.95784.49180.00500.00230.0092-0.00720.00691.83564.01980.00550.00220.0093-0.00650.00821.70403.56800.00600.00210.0095-0.00600.00941.57253.14500.00650.00190.0097-0.00550.01041.44742.75450.00700.00180.0099-0.00500.01131.33282.39680.00750.0

18、0170.0102-0.00450.01211.23072.07020.00800.00170.0104-0.00410.01281.14251.77160.00850.00160.0107-0.00370.01341.06871.49710.00900.00150.0110-0.00340.01381.00951.24260.00950.00140.0112-0.00300.01420.96531.00350.01000.00140.0115-0.00270.01450.93640.77520.01050.00130.0118-0.00240.01480.92320.55300.01100.

19、00130.0121-0.00200.01490.92690.33190.01150.00130.0124-0.00170.01500.94850.10690.01200.00120.0127-0.00140.01500.9899-0.12760.01250.00120.0130-0.00100.01491.0530-0.37730.01300.00120.0133-0.00060.01471.1404-0.64810.01350.00120.0136-0.00020.01451.2544-0.94550.01400.00120.01390.00020.01411.3967-1.27430.0

20、1450.00120.01420.00080.01361.5677-1.63680.01500.00120.01440.00130.01291.7648-2.03140.01550.00120.01470.00200.01211.9807-2.44950.01600.00130.01490.00270.01122.2018-2.87350.01650.00130.01510.00350.01012.4071-3.27540.01700.00140.01530.00440.00892.5697-3.61860.01750.00150.01550.00530.00762.6616-3.86500.

21、01800.00160.01560.00630.00632.6609-3.98490.01850.00180.01570.00720.00492.5591-3.96740.01900.00190.01580.00800.00352.3638-3.82440.01950.00210.01590.00880.00222.0959-3.58660.02000.00230.01590.00950.00101.7823-3.29310.02050.00250.01590.0100-0.00011.4487-2.98150.02100.00270.01590.0105-0.00111.1152-2.680

22、90.02150.00290.01590.0108-0.00200.7942-2.41030.02200.00310.01580.0111-0.00280.4916-2.17940.02250.00330.01580.0112-0.00350.2086-1.99130.02300.00360.01570.0112-0.0042-0.0565-1.84500.02350.00380.01560.0111-0.0048-0.3071-1.73750.02400.00400.01550.0110-0.0054-0.5475-1.66500.02450.00420.01540.0108-0.0060-

23、0.7817-1.62330.02500.00440.01530.0104-0.0065-1.0139-1.60890.02550.00460.01510.0100-0.0071-1.2479-1.61810.02600.00480.01500.0096-0.0077-1.4868-1.64800.02650.00500.01480.0090-0.0082-1.7336-1.69550.02700.00520.01460.0084-0.0088-1.9905-1.75740.02750.00540.01450.0076-0.0095-2.2588-1.83040.02800.00550.014

24、30.0068-0.0101-2.5391-1.91000.02850.00560.01410.0058-0.0108-2.8305-1.99100.02900.00570.01380.0048-0.0115-3.1300-2.06600.02950.00580.01360.0037-0.0122-3.4326-2.12550.03000.00590.01330.0024-0.0130-3.7297-2.15720.03050.00590.01310.0011-0.0137-4.0091-2.14510.03100.00590.0128-0.0004-0.0145-4.2538-2.06960

25、.03150.00590.0125-0.0019-0.0152-4.4419-1.90790.03200.00580.0122-0.0035-0.0158-4.5473-1.63520.03250.00580.0119-0.0051-0.0163-4.5411-1.22730.03300.00560.0115-0.0066-0.0166-4.3954-0.66610.03350.00550.0112-0.0081-0.0167-4.08890.05510.03400.00530.0109-0.0095-0.0166-3.61290.92430.03450.00510.0105-0.0106-0

26、.0161-2.97811.90580.03500.00490.0102-0.0115-0.0152-2.21782.93950.03550.00470.0099-0.0122-0.0140-1.38573.94730.03600.00440.0097-0.0125-0.0125-0.54784.8458图形输出:图2连杆3的几个位置点图3 角位移线图图4角加速度线图图 5角加速度线图3 基于 MATLAB图形界面设计所谓图形用户界面 ,简称为 GU I (Graphic User Interface) ,是指包含了各种图形控制对象 , 如图形窗口、菜单、对话框以及文本等容的用户界面。 利用这

27、些用户界面 , 用户可以和计算机之间进行信息交流。 用户可以通过某种方式来选择或者激活这些图形对象 , 来运行一些特性的 M 文件。最常见的激活方式是利用鼠标或者其它设备来点击这些对象。 对于一个用户来说 , 图形用户界面就是他所面对的应用程序 , 对图形界面的操作直接影响应用程序的应用前途。 对于以往专门用于科学计算的语言 , 如 FORTRAN语言等 , 编写图形界面的功能较弱 , 因而用其开发的程序 , 其界面往往不够友好 , 用户使用起来很不方便。 而目前流行的可视化语言 , 对科学计算的功能又相对弱一些。 MATLAB提供了非常强大的编写图形用户界面的功能。 用户只和前台界面下的控件

28、发生交互, 而所有运算、 绘图等部操作都封装在部, 终端用户不需要区追究这些复杂过程的代码。 图形用户界面大大提高用户使用 MATLAB程序的易用性。 因此,学习 MATLAB图形用户界面编程,即 GUI 程序的创建,是 MATLAB编程用户应该掌握的重要一环。对于一个 MATLAB中的图形用户界面 ,它的设计过程一般可以分为两个部分:用户界面的外观设计。 在这里 , 主要是通过不同的对话框、 按钮、文本框等许多工具的使用 , 设计出一个图形用户界面。 同时也应搞清楚这个图形界面的功能是什么 , 也即在图形界面上的操作会引发什么样的结果。图形界面的完成。 在这里 ,用户将根据在外观设计阶段所确

29、定的图形界面的功能 , 针对各个不同的图形对象来编写出能够实现该功能的函数代码 , 确保这个图形界面能够完成所预定的功能。3.1界面设计首先我们新建一个GUI 文件,如下图所示:图6 新建 GUI 文件选择 Blank GUI(Default)。进入 GUI 开发环境以后添加 5 个编辑文本框, 8 个静态文本框,和 1 个下拉菜单。利用菜单编辑器,创建 Open、 Print 、Close 三个菜单。创建好 GUI 界面需要的各交互控件并调整好大概的位置后, 设置这些控件的属性。 最后的界面效果如下图示:图7 界面效果3.2代码设计(1) 打开 M文件编辑器 (M-file Edit), 点

30、击 向下的三角图标, 可以看到各个对象的回调函数( Callback ) , 某些对象的创建函数或打开函数等。通过选中相应项就可以跳动对应函数位置进行程序编辑。选中 edit_callback选项,光标跳到functionedit1_Callback(hObject,eventdata,handles) 下面空白处,添加以下代码:user_entry=str2double(get(hObject,'String');if isnan(user_entry)errordlg('请输入数值! ','Bad Input')end该语句严格限制编辑框必须

31、输入数值,否则出现错误对话框(如下图所示)。同理在其他四个编辑框的回调函数下输入相同的代码。图 8错误对话框(2) 打开 M文件编辑器 (M-file Edit), 点击 向下的三角图标, 设置下拉菜单返回函数,光标跳到 function popupmenu1_Callback(hObject, eventdata, handles) 下面空白处。 由于下拉菜单是本界面设计关键控件, 与本设计相关的程序都放在这个返回函数下。添加代码如下:L1=str2double(get(handles.edit1,'String');L2=str2double(get(handles.edi

32、t2,'String');L3=str2double(get(handles.edit3,'String');L4=str2double(get(handles.edit4,'String');w2=str2double(get(handles.edit5,'String');th2=0:2/72:2*pi;th34=zeros(length(th2),2);options=optimset('display','off');for m=1:length(th2)th34(m,:)=fsolve(&

33、#39;fourbarposition',1 1,options,th2(m),L2,L3,L4,L1);endw2=250;for i=1:length(th2)A=-L3*sin(th34(i,1) L4*sin(th34(i,2); L3*cos(th34(i,1)-L4*cos(th34(i,2);B=w2*L2*sin(th2(i); -w2*L2*cos(th2(i);w=inv(A)*B;w3(i)=w(1);w4(i)=w(2);endfor i=1:length(th2)C=-L3*sin(th34(i,1) L4*sin(th34(i,2);L3*cos(th34(

34、i,1)-L4*cos(th34(i,2);D=w22*L2*cos(th2(i)+w3(i)2*L3*cos(th34(i,1)-w4(i)2*L4*cos(th34( i,2);.w22*L2*sin(th2(i)+w3(i)2*L3*sin(th34(i,1)-w4(i)2*L4*sin(th3 4(i,2);a=inv(C)*D;a3(i)=a(1);a4(i)=a(2);endval=get(hObject,'Value');str=get(hObject,'String');switch strvalcase ' 连杆 3 的几个位置点 &#

35、39;th2=0:1/6:2*pi;th34=zeros(length(th2),2);options=optimset('display','off');for m=1:length(th2)th34(m,:)=fsolve('fourbarposition',1 1,options,th2(m),L2,L3,L4,L1);endy=L2*sin(th2)+L3*sin(th34(:,1)');x=L2*cos(th2)+L3*cos(th34(:,1)');xx=L2*cos(th2);yy=L2*sin(th2);plot(

36、x;xx,y;yy,'k',0 L1,00,'k-',x,y,'ko',xx,yy,'ks')title('连杆 3 的几个位置点 ')xlabel('水平方向 ')ylabel('垂直方向 ')axis equalgrid oncase ' 角位移线图 'plot(th2*180/pi,th34(:,1)*180/pi,th2*180/pi,th34(:,2)*180/pi)axis(0 360 0 170)gridonxlabel('主动件转角 theta

37、_2(度)')ylabel('从动件角位移 ( 度)')title('角位移线图 ')text(120,120,'摇杆 4 角位移 ')text(150,40,'连杆 3 角位移 ')case ' 角速度线图 'plot(th2*180/pi,w3,th2*180/pi,w4);axis(0 360 -175 200)text(50,160,'摇杆 4 角速度 (omega_4)')text(220,130,'连杆 3 角速度 (omega_3)')grid onxlabel

38、('主动件转角 theta_2(度)')ylabel('从动件角速度 (radcdot s-1)')title('角速度线图 ')case ' 角加速度线图 'plot(th2*180/pi,a3,th2*180/pi,a4);axis(0 360 -50000 65000)text(50,50000,'摇杆 4 角加速度 (alpha_4)')text(220,12000,'连杆 3 角加速度 (alpha_3)')grid onxlabel('主动件转角theta_2(度)')ylabel('从动件角加速度(radcdot s-2)')title('角加速度线图')endguidata(hObject,handles)%其中,guidata(hObject,handles) 命令用于更新

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论