2007年5月30日

5/30- 第十一次作業

作業十一 廖婉婷 b94611040


*本週(5/24)有來上課*


Q:某凸輪開始時先在0-100°區間滯留,然後提升後在200至260°區間滯留,
其高度(衝程)為5公分,其餘l由260°至360°則為返程。
升程採用等加速度運動,返程之運動型式自定。
設刻度區間為10°,試繪出其高度、速度及加速度與凸輪迴轉角度間之關係。

本題我們先採用講義上function dwell
計算出隨角度改變之高度,速度,加速度值
再利用plot_dwell函式繪出關係圖
以下為函式內容:
function [y,yy,yyy]=dwell(ctheta,range,pattern)
%ctheta= 需要計算之凸輪角度
%range= 升程及返程之範圍
%pattern= 運動型式
% 1:等速運動uniform 2:抛物線parabolic 3:簡諧simple harmonic
%     4:擺線cycloidal 5:多項式polynomial motion
d2r=pi/180;
theta=ctheta*d2r;range=range*d2r;
dim=length(ctheta);
y=zeros(size(ctheta));yy=y;yyy=y;
for i=1:dim
if theta(i)>=range(3) %for the last motion(downward)
mode=pattern(2);betax=2*pi-range(3);
switch mode,
case 1, [y(i),yy(i),yyy(i)]=uniform(theta(i), range(3),betax,-1);
case 2, [y(i),yy(i),yyy(i)]=parabolicm(theta(i), range(3),betax,-1);
case 3, [y(i),yy(i),yyy(i)]=harmonicm(theta(i), range(3),betax,-1);
case 4, [y(i),yy(i),yyy(i)]=cycloidm(theta(i), range(3),betax,-1);
case 5, [y(i),yy(i),yyy(i)]=polynorm(theta(i), range(3),betax,-1);
end;

elseif theta(i)>=range(2) % dewell on the top
y(i)=1;
elseif theta(i)>=range(1) % for the 1st motion(upward)
mode=pattern(1);betax=range(2)-range(1);
switch mode,
case 1, [y(i), yy(i), yyy(i)]=uniform(theta(i), range(1),betax,+1);
case 2, [y(i), yy(i), yyy(i)]=parabolicm(theta(i), range(1),betax,+1);
case 3, [y(i), yy(i), yyy(i)]=harmonicm(theta(i), range(1),betax,+1);
case 4, [y(i), yy(i), yyy(i)]=cycloidm(theta(i), range(1),betax,+1);
case 5, [y(i), yy(i), yyy(i)]=polynorm(theta(i), range(1),betax,+1);
end
end
end

由題目給定開始時先在0-100°區間滯留,然後提升後在200至260°區間滯留,
其餘由260°至360°則為返程。
也就是升程為100~200°,返程為260~360°
注意ctheta表現的方式
[x y]分別表示升程與返程之運動型式
由於題目限定升程為等加速度運動
而返程運動自訂
故分別列出[2 1] [2 2] [2 3] [2 4] [2 5]各項情況之結果
function plot_dwell(ctheta,s,pattern,range)
%ctheta= 凸輪角度
%pattern= 運動型式
% 1:等速運動uniform 2:抛物線parabolic 3:簡諧simple harmonic
%     4:擺線cycloidal 5:多項式polynomial motion
%range= 升程及返程範圍
figure(1);clf;
[y,yy,yyy]=dwell(ctheta,range,pattern)
h1=plot(ctheta,y*s,'b-',ctheta,yy*s,'k-',ctheta,yyy*s,'r-')
legend('Displacement','Velocity','Acceleration',3)
xlabel('Elapsed Angle, degrees')
grid

1.升程:拋物線 返程:等速運動
axis([0 360 -180 180])
plot_dwell(0:10:360,8,[2 1],[100 200 260])
title('升程:拋物線 返程:等速運動')


2.升程:拋物線 返程:拋物線
axis([0 360 -180 180])
plot_dwell(0:10:360,8,[2 2],[100 200 260])
title('升程:拋物線 返程:拋物線')


3.升程:拋物線 返程:簡諧運動
axis([0 360 -180 180])
plot_dwell(0:10:360,8,[2 3],[100 200 260])
title('升程:拋物線 返程:簡諧運動')


4.升程:拋物線 返程:擺線運動
axis([0 360 -180 180])
plot_dwell(0:10:360,8,[2 4],[100 200 260])
title('升程:拋物線 返程:擺線運動')


5.升程:拋物線 返程:多項式
axis([0 360 -180 180])
plot_dwell(0:10:360,8,[2 5],[100 200 260])
title('升程:拋物線 返程:多項式')



Q:設凸輪之半徑為15公分,以順時針方向旋轉,其從動件為梢型,
垂直接觸,長為10公分,從動件之運動係依照第二項之運動型式。
試繪出此凸輪之工作曲線。

本題使用講義pincam函式
另角度為0~360度 每10度作間隔
半徑r0 = 15
衝程s = 5
由於為垂直接觸 偏置量e = 0
從動件長度L = 10
凸輪順時針轉動故cw = -1
運動型式在此以上題之第一情況為代表
亦即升程為加速度運動 返程為等速運動
因此pattern = [2 1]
function [x,y]=pincam(cth,r0,s,e,L,range,pattern,cw)
%cth: 凸輪角度(deg)
%r0: 凸輪基圓半徑
%e: 偏置量
%s: 從動件衝程
%L: 從動件長度
%cw: 凸輪轉動方向(反時鐘為正,順時鐘為負)
%pattern: 運動型式
% 1:等速運動uniform 2:抛物線parabolic 3:簡諧simple harmonic
%     4:擺線cycloidal 5:多項式polynomial motion
%range: 升程及返程範圍
figure(1);
clf;
th=cth*pi/180;
s0=sqrt(r0*r0-e*e);
for i=1:length(cth)
t=th(i)*cw;
A=[cos(t) -sin(t);sin(t) cos(t)];
[ym,yy,yyy]=dwell(cth(i),range,pattern);
x0=s0+ym*s;
Sx=[0 x0 x0+L;e e e];
X=A\Sx;
x(i)=X(1,2);y(i)=X(2,2);
line(X(1,1:2),X(2,1:2));
line(X(1,2:3),X(2,2:3),'linewidth',3,'color','red')
end
hold on;
plot([0 x],[0 y],'ro',x,y,'k-')
axis equal

%由題目條件執行function
>> [x y]=pincam([0:10:360],15,5,0,10,[100 200 260],[2 1],-1)
title('從動件為梢形之凸輪工作曲線')

以下為結果:


Q:你能讓此凸輪迴轉嗎?

for i = 1:10:360;
[x y]=pincam(i,15,5,0,10,[120 180 210],[2 4],-1)
axis equal;
grid on;
end;

2007年5月23日

5/23- 第十次作業

作業十 b94611040 廖婉婷




*本週(5/17)有來上課*


Q1:請思考速度與加速度的問題,當一桿以某特定點M等角速度迴轉時,其端點P之速度方向如何?
其加速度方向如何?若該特定點M復以等速水平運動,則同一端點P之速度與加速度方向會變為如何?
若M點同時也有加速度,則點P會有何變化?
若以此推理四連桿的運動,則點P與Q之速度與加速度方向會與桿一(固定桿)之兩端點之關係如何?
與我們前面的作業分析結果有無共通之處?


在分析速度,加速度的問題時
我們可以使用之前的function dyad_draw
以下是函式內容:
function dyad_draw(rho,theta,td,tdd)
% Inputs: rho: 連桿長度
% theta: 連桿水平角度(deg)
% td: 角速度(rad/s)
% tdd: 角加速度(rad/s^2)
clf;
[vec,data] = dyad(rho,theta,td,tdd);
%先由function dyad計算出速度 加速度對應值再繪出
x=[0;cumsum(real(data(:,1)))];y=[0;cumsum(imag(data(:,1)))];
for i=1:length(x)-1
linkshape([x(i) y(i)],[x(i+1) y(i+1)],1);
end
for k=1:length(rho)
x0=x(k+1);y0=y(k+1);
vx=x0+real(data(k,2));vy=y0+imag(data(k,2));
ax=x0+real(data(k,3));ay=y0+imag(data(k,3));
line([x0 vx],[y0 vy],'marker','s','linewidth',2);
line([x0 ax],[y0 ay],'marker','s','color','r','linewidth',3)
end
sdata=sum(data);
ss=[real(sdata(1)) imag(sdata(1))];
vv=[real(sdata(2)) imag(sdata(2))];
aa=[real(sdata(3)) imag(sdata(3))];
line([0 ss(1)],[0 ss(2)],'linestyle',':','linewidth',2)
line([ss(1) ss(1)+vv(1)],[ss(2) ss(2)+vv(2)],...
'marker','d','color','g','linewidth',3)
line([ss(1) ss(1)+aa(1)],[ss(2) ss(2)+aa(2)],...
'marker','d','color','m','linewidth',3)

axis equal;grid on

今設一桿以特定點M作等角速度 ω(rad/s)轉動
則另一端P點有速度v = ωr(m/s)
其方向與M至P之向量垂直,與軌跡路徑相切
用於表示p點之速度快慢
至於加速度一般可分為切線及法線加速度
由於本題作等角速度迴轉,故角加速度為零,切線加速度亦為零
因此加速度僅為法線加速度之值: rω^2 (m/s^2), 其方向為向心
今假設桿長4, 水平角度30deg, 角速度0.5rad/s
結果如下圖所示:
dyad_draw(4,30,.5,.2)


若M為等角加速度0.2rad/s^2旋轉
執行程式
dyad_draw(4,30,.5,.2)
gtext ('切線加速度')
gtext ('法線加速度')
gtext ('合加速度')
%標明加速度及其切線,法線分量之位置

應該如下圖所示:


若該特定點M復以等速水平運動,則需考慮到相對運動之觀念
設如果M點是以Vm(m/s)的速度移動
那P點的速度為Vp = Vm + w x r ,
其中w x r為w和r之外積,r為m至p之相對位置
由於M點速度不影響該桿之角加速度 故加速度值不變
Vp和Vm的關係可由下圖作圖解:

若M點同時也有加速度設為A(m/s^2) 則要考慮到相對加速度
由上式相對速度關係式再對時間t微分
可以得到:Ap = Am + (Ap/m)t + (Ap/m)n
其中(Ap/m)t和(Ap/m)n 為相對加速度之切線及法線分量
因此式子變為Ap = Am + αxr - ω^2r
其關係見下圖:



若推至四連桿運動,因為桿一為固定
因此P與Q點可分別看作一端為固定點之桿作迴轉運動,也就是我們一開始討論的情形
可發現與前面作業所討論相同
首先見下圖

我們假設以下情況皆以桿二驅動
由於桿一固定 也就是0點固定點
若r1作等角速度ω迴轉
則p點有一速度Vp = ωr1, 方向與r垂直
因r1沒有角加速度 p點僅有法線加速度(Ap)n

若r1作等角加速度α迴轉
則p點產生了切線加速度(Ap)t
因此加速度合Ap = (Ap)t + (Ap)n

若要分析Q點速度,加速度
由於是第二桿驅動 p點已具有速度/加速度
因此討論到Q點則需採用相對速度/加速度的觀念
也就是VQ = Vp + w x r ; AQ = Ap + αxr - ω^2r





Q2:設有一運動之曲柄滑塊連桿組合,
設滑塊之偏置量為零,且在水平方向移動,
試以此機構之曲桿長度及角度,
以及連結桿之長度為輸入項,
利用matlab寫出一程式計算在不同曲柄角度時,
六點瞬心之對應位置。
可順便探討六點瞬心與曲柄角間之關係。


根據機構的定義,任二連桿在相同的平面上運動,應可找到一個瞬心
今天一曲柄滑塊機構,可看作一四連桿
又由甘迺迪定理可推得此機構共有4(4-1)/2 = 6個瞬心
首先由於四連桿之旋轉結即為瞬心 我們可以很快找到四個瞬心
另兩個瞬心則是彼此相對之桿造成的

因此要找出另兩個瞬心
由課本上瞬心定位法我們發現:
點13可由12 23之連線與14 34之連線交點獲得
同理
點24則為23 34連線與12 24之連線的交點

由以上找出了六個瞬心位置
便可由function繪出機構瞬心示意圖
以下為函示內容:
function drawcenter(r2,th2,r3)
%輸入函數為
%r2 = 曲桿長度
%th2 = 曲桿水平角度
%r3 = 連結桿長度
theta2 = th2*pi / 180;
%首先須記得將th2換算為弧度
X12 = 0; Y12 = 0;
X23 = r2*cos(theta2); Y23 = r2*sin(theta2);
X34 = X23+r3*cos(Y23/r3); Y34 = 0;
X13 = X34; Y13 = X34*tan(theta2);
X24 = 0; Y24 = X34*tan(Y23/r3);

% 繪出各部份
draw_inner = [X12 Y12;X23 Y23;X34 Y34;X12 Y12];
draw_outer = [X34 Y34;X13 Y13;X23 Y23;X24 Y24;X12 Y12];
draw_block = [X34-0.5 Y34-0.5;X34-0.5 Y34+0.5;X34+0.5 Y34+0.5;X34+0.5 Y34-0.5;X34-0.5 Y34-0.5];

hold on;
plot(draw_inner(:,1),draw_inner(:,2),'k-');
plot(draw_inner(:,1),draw_inner(:,2),'bo');
plot(draw_outer(:,1),draw_outer(:,2),'r:');
plot(draw_outer(:,1),draw_outer(:,2),'bo');
plot(draw_block(:,1),draw_block(:,2),'k-');
hold off;

%標註
text(X12+0.2,Y12-0.2,'12');
text(X23+0.2,Y23-0.2,'23');
text(X34+0.2,Y34-0.2,'34');
text(X13+0.2,Y13-0.2,'13');
text(X24+0.2,Y24-0.2,'24');

今假設r2 = 60, th2 = 45, r3 = 50
執行程式
>> axis([0 100 0 100])
axis equal;
drawcenter (50,45,60)

得到以下結果:

須特別留意在曲柄滑塊組合中
點14因為滑塊的關係,與接觸面(視為另一桿)運動方向相同
其方向應與地面垂直
亦即點14存在於無窮遠的位置


若要分析瞬心位置與曲柄角間之關係
我們試著將上一題繪出瞬心之function作角度迴圈製成動畫
再製作動畫前
我們先利用之前作業之function sld_angle_limits
算出給定桿長之極限角度 方便跑動畫時之角度範圍
以下為函式內容:
function [Qstart, Qstop]=sld_angle_limits(r,theta1,linkdrive)
%r= 各桿桿長
%theta1= 第一桿水平角度
%linkdrive= 0 第二桿驅動
%linkdrive= 1 第三桿驅動
%linkdrive= 2 滑塊驅動
%例如本題給定條件r = [0 60 50 0]
%r1隨角度改變因此可設為0
%又假設為滑塊驅動情況 故linkdrive = 2
r1=r(1);r2=r(2);r3=r(3);r4=r(4);
g2d=180/pi;
switch linkdrive
case 0 %crank
if r3+r4=0 & r3>r4
Qstart=asin((r4-r3)/r2);Qstop=asin((r4+r3)/r2);
elseif r3+r4>=r2 & r4>=r3 & r3>=0
Qstart=asin((r4-r3)/r2);Qstop=pi-asin((r4-r3)/r2);
elseif r3-r4<=r2 & r4<0 & r3>=-r4
Qstart=asin((r4-r3)/r2);Qstop=asin((r4+r3)/r2);
elseif r3-r4>=r2 & r3>=0 & -r4>=r3
Qstart=-pi-asin((r4+r3)/r2);Qstop=asin((r4+r3)/r2);
else
Qstart=0;Qstop=2*pi;
end
case 1 %coupler
if r2-r4<=r3 & r4>=0 & r2>=r4
Qstart=asin((r4-r2)/r3);Qstop=pi-asin((r4-r2)/r3);
elseif r2+r4=0
Qstart=asin((r4-r2)/r3);Qstop=asin((r4+r2)/r3);
elseif r2+r4<=r3 & r4<=0 & r2+r4>=0
Qstart=-pi-asin((r4+r2)/r3);
Qstop=asin((r4+r2)/r3);
elseif r2-r4 < r3 & r4 <=0
Qstart=asin((r4-r2)/r3);Qstop=asin((r4+r2)/r3);
else %r2>=(r3+abs(r4))
Qstart=0;Qstop=2*pi;
end
case 2 %slider displacement
Qstart=0;Qstop=0;
arg2=(r2+r3)^2-r4^2;
if abs(r2-r3)>=r4
arg1=(r2-r3)^2-r4^2;
if arg1>0,Qstart=sqrt(arg1);end;
Qstop=sqrt(arg2);
else
if arg2<0, return; end
Qstart=sqrt(arg2);Qstop=-sqrt(arg2);
end
theta1=0;g2d=1;
end %case
if Qstop < Qstart,TT=Qstart;Qstart=Qstop;Qstop=TT;end
adjust=(Qstop-Qstart)*1e-8;
Qstart=theta1+(Qstart+adjust)*g2d;
Qstop=theta1+(Qstop-adjust)*g2d;
%Qstart = 驅動桿(二或三桿)之最低限角度 (deg)
%Qstop = 驅動桿(二或三桿)之最高限角度 (deg)

執行程式:
[Qstart, Qstop]=sld_angle_limits([0 60 10 0],0,2)

Qstart =

10.0000


Qstop =

110.0000

得到給定桿長之曲柄滑塊極限角度約為10~110(deg)

讓程式跑角度迴圈製成動畫之指令:
for i = 10:110,
clf;
axis([0 100 -10 90])
axis equal
%在此必須固定座標軸
%不然畫面會隨著瞬心位置遠近而改變
%很難看出與滑塊機構之關係
drawcenter(60,i,50);
pause(0.1);
end;

結果如下:

2007年5月20日

5/8討論課心得

5/8是採老師帶領小組討論的方式
一組大約八人左右

在這次討論課中
我題出的問題是:
每次的作業老師在講義中都會提供相關程式碼
我們知道那個function input什麼,output什麼
但是如果問到函式內部的程式碼架構
也就是要深入瞭解其中程式語言 就變得不太能掌握
其實主要在想要將程式結果做成自己希望的形式時就有點吃力


不過老師的回答非常有道理:
我們這門課修的是機動學
主要要學的是一些機構的組合和運動方式
matlab在其中只是個輔助工具
我們是要知道如何利用那個程式碼 求得我們需要的數據另外作分析
並不是如何從頭去創造一個完整的程式指令
這也就是每個科目所著重的點不同
如果想要更加瞭解其中組成 或許可往matlab應用的相關課程深入

真的很感謝老師
我覺得這樣的回答 完全解開了我目前的疑惑!

2007年5月16日

5/16- 第九次作業

作業九 廖婉婷 B94611040


*本週(5/3)有來上課*

由課本上定義,滑塊之滑動方向若與水平方向有一距離e時
稱為偏置機構,而其中e稱之偏置量
而此偏置機構可視為一個四連桿結構
其中偏置量將影響滑桿機構之活動範圍
<本題著重在極限位置之分析>

首先依題目給定R=50,L=55,e=10
由課本之slider_limit函式
計算滑塊水平滑行最大距離(即衝程)和界限角度
以下為程式內容:
function [ s theta21,theta22 ] = slider_limit( R,L,e )
%R= 曲桿長
%L= 連桿長
%e= 偏置量
d2g = pi/180;
th1 = asin(e./(R+L));
th2 = asin(e./abs(R-L));
s = (R+L).*cos(th1)-abs(R-L).*cos(th2);
theta21 = th1/d2g;
theta22 = th2/d2g;

執行後得到以下結果:
 slider_limit( 50,55,10 )
abs(s)
abs(theta21)
abs(theta22)

ans =

1.0452e+002 -8.6603e+000i


ans =

104.8809


ans =

5.4650


ans =

117.4463

直接對各項取絕對值
我們得到衝程為104.88
界限角度為5.47和117.45

討論:
在這邊我先發現了個問題
由於篇置量固定
最大衝程應該出現在曲桿和連桿為一直線時
由畢氏定理計算出值應為104.52?






接著利用老師講義上所提供繪製極限位置之函式(drawsldlimits)
此程式除呼叫sld_angle_limits獲得迴轉之範圍外
呼叫drawsldlink函數繪出各桿之位置。
以下為函式內容:
function [Qstart, Qstop]=sld_angle_limits(r,theta1,linkdrive)
%輸入函數:
%r = 四連桿之長度向量
%theta1 = 第一桿之夾角,角度表示(deg)
%linkdrive = 驅動模式(=0 第二桿驅動; =1 第三桿驅動 =2 滑塊驅動)
%輸出(兩個角度)
%Qstart = 驅動桿(第二桿或第三桿)之最低限角度 (deg)
%Qstop = 驅動桿(第二桿或第三桿)之最高限角度 (deg)
r1=r(1);r2=r(2);r3=r(3);r4=r(4);
g2d=180/pi;
switch linkdrive
case 0 %crank
if r3+r4=0 & r3>r4
Qstart=asin((r4-r3)/r2);Qstop=asin((r4+r3)/r2);
elseif r3+r4>=r2 & r3>=r4 & r3>=0
Qstart=asin((r4-r3)/r2);Qstop=pi-asin((r4-r3)/r2);
elseif r3-r4<=r2 & r4<0 & r3>=-r4
Qstart=asin((r4-r3)/r2);Qstop=asin((r4+r3)/r2);
elseif r3-r4>=r2 & r3>=0 & -r4>=r3
Qstart=-pi-asin((r4+r3)/r2);Qstop=asin((r4+r3)/r2);
else
Qstart=0;Qstop=2*pi;
end
case 1 %coupler
if r2-r4<=r3 & r4>=0 & r2>=r4
Qstart=asin((r4-r2)/r3);Qstop=pi-asin((r4-r2)/r3);
elseif r2+r4=0
Qstart=asin((r4-r2)/r3);Qstop=asin((r4+r2)/r3);
elseif r2+r4<=r3 & r4<=0 & r2+r4>=0
Qstart=-pi-asin((r4+r2)/r3);
Qstop=asin((r4+r2)/r3);
elseif r2-r4 < r3 & r4 < =0
Qstart=asin((r4-r2)/r3);Qstop=asin((r4+r2)/r3);
else %r2>=(r3+abs(r4))
Qstart=0;Qstop=2*pi;
end
case 2 %slider displacement
Qstart=0;Qstop=0;
arg2=(r2+r3)^2-r4^2;
if abs(r2-r3)>=r4
arg1=(r2-r3)^2-r4^2;
if arg1>0,Qstart=sqrt(arg1);end;
Qstop=sqrt(arg2);
else
if arg2<0, return; end
Qstart=sqrt(arg2);Qstop=-sqrt(arg2);
end
theta1=0;g2d=1;
end %case
if Qstop < Qstart,TT=Qstart;Qstart=Qstop;Qstop=TT;end
adjust=(Qstop-Qstart)*1e-8;
Qstart=theta1+(Qstart+adjust)*g2d;
Qstop=theta1+(Qstop-adjust)*g2d;

function [values]=drawlinks(r,th1,th2,mode,linkdrive)
%r = 四桿之向量位置
%th1 = 第一桿水平角度
%th2 = 驅動桿水平角度
%mode = +1 or -1 組合模數,負值表閉合型;正值表分支型
%linkdriver = 0 (驅動桿為第二桿); 1 (驅動桿為第三桿)
if nargin<5,linkdrive=0;end
if nargin<4,mode=1;end
[values b]=f4bar(r,th1,th2,0,0,mode,linkdrive);
rr=values(:,1);
rr(3,1)=rr(1,1)+rr(4,1);
rx=real(rr(:,1));rx(4)=0;
ry=imag(rr(:,1));ry(4)=0;
if b==1
plot([0 rx(1)],[0 ry(1)],'k-','LineWidth',4);
hold on;
if linkdrive==0
plot([0 rx(2)],[0 ry(2)],'b-','LineWidth',1.5);
plot([rx(2) rx(3)],[ry(2) ry(3)],'r-','LineWidth',2);
else
plot([0 rx(2)],[0 ry(2)],'r-','LineWidth',2);
plot([rx(2) rx(3)],[ry(2) ry(3)],'b-','LineWidth',1.5);
end
plot([rx(1) rx(3)],[ry(1) ry(3)],'g-','LineWidth',1.5);
plot(rx,ry,'bo');
text(0,0,' O');text(rx(1),ry(1),' R');
text(rx(2),ry(2),' Q');text(rx(3),ry(3),' P');
else
fprintf('Combination of links fail at degrees %6.1f\n',th2);
end
axis equal
grid on

function drawsldlimits(r,th1,sigma,driver)
%r = 四桿之向量位置
%th1 = 第一桿水平角度
%sigma = +1 or -1 組合模數,負值表閉合型;正值表分支型
%driver = 0 (驅動桿為第二桿); 1 (驅動桿為第三桿) ;2(滑塊驅動)
g2d=180/pi;
[Qstart, Qstop]=sld_angle_limits(r,th1,driver)
if Qstart==0 & Qstop==0, return; end
switch driver
case 0 %Link 2 as driving link
[rr]=drawsldlinks(r,th1,Qstart,sigma,driver);
text(real(rr(2,1)/2),imag(rr(2,1)/2),['s1=' num2str(Qstart,'%6.1f')]);
[rr]=drawsldlinks(r,th1,Qstop,sigma,driver);
text(real(rr(2,1)/2),imag(rr(2,1)/2),['s2=' num2str(Qstop,'%6.1f')]);
case 1 %Link 3 as driving link
[rr]=drawsldlinks(r,th1,Qstart,sigma,driver);
text(real(rr(2,1)+rr(3,1)/2),imag(rr(2,1)+rr(3,1)/2),...
['s1=' num2str(Qstart,'%6.1f')]);
[rr]=drawsldlinks(r,th1,Qstop,sigma,driver);
text(real(rr(2,1)+rr(3,1)/2),imag(rr(2,1)+rr(3,1)/2),...
['s1=' num2str(Qstop,'%6.1f')]);
case 2 %Slide as driving link
if abs(r(2)-r(3)) < r(4);
angx=asin((r(2)+r(3))/r(4))*g2d;
tmax=th1+angx;
tmin=th1+180-angx;
else
tmin=th1+asin((r(2)+r(3))/r(4))*g2d;
tmax=th1+asin((r(2)-r(3))/r(4))*g2d;
end
r(1)=Qstart;offr=0.1*Qstart;
[rr]=drawsldlinks(r,th1,tmin,sigma,driver);
text(real(rr(1,1)/2),imag(rr(1,1)/2)+offr,['r1=' num2str(Qstart,'%6.1f')]);
r(1)=Qstop;
[rr]=drawsldlinks(r,th1,tmax,sigma,driver);
text(real(rr(1,1)/2),imag(rr(1,1)/2)-offr,['r1=' num2str(Qstop,'%6.1f')]);
end
axis equal
grid on


雖然題目只給定R,L,e之值 也就是相當於四連桿之r2,r3,r4
由於前面slider_limit已求得衝程為104.88 也就是相當於四連桿之r1
因此在drawsldlimits函式中
即可直接代入四桿之值

(1)曲桿驅動(以第二桿為驅動桿)
因為曲桿驅動
driver為0
>> axis([-110 110 -40 40])
drawsldlimits([104.88 50 55 10],0,-1,0)

Qstart =

3.6000e-006


Qstop =

360.0000

討論:
在這邊我發現了一個問題
照程式結果跑出來的角度可作360度旋轉
但是根據課本上所述:
"若曲柄須能完成360度的迴轉,則其相關連桿之長度須依其所能夠成三角形關係而定
而若有偏置的情形時,則連結桿與曲柄之長度差應大於偏置距離e"
與本題條件所給R-L<0條件不符,顯然有錯誤
在請教過歐陽太閒同學後
發現是sld_angle_limits程式碼中少了r3>=r4>0這種情況(也就是講義所列第二情形)
因此將原程式碼中:
   elseif r3+r4>=r2 & r4>=r3 & r3>=0
Qstart=asin((r4-r3)/r2);Qstop=pi-asin((r4-r3)/r2);

修正為:
   elseif r3+r4>=r2 & r3>=r4 & r3>=0
Qstart=asin((r4-r3)/r2);Qstop=pi-asin((r4-r3)/r2);


重新跑過一次後:
axis([-110 110 -40 40])
drawsldlimits([104.88 50 55 10],0,-1,0)
title('第二桿驅動極限位置 -b94611040')

Qstart =

-64.1581


Qstop =

244.1581


得到了正確的結果





(2)連桿驅動(以第三桿為驅動桿)
%drive為1
axis([-110 110 -40 40])
drawsldlimits([104.88 50 55 10],0,-1,1)
title('第三桿驅動極限位置 -b94611040')

Qstart =

-46.6582


Qstop =

226.6582






(3)滑塊驅動
%driver為2
>> axis([-110 110 -40 40])
drawsldlimits([104.88 50 55 10],0,-1,2)
title('滑塊驅動極限位置 -b94611040')

Qstart =

-104.5227


Qstop =

104.5227


需特別注意
由於滑塊驅動屬於直線運動
故在程式中之Qstart及Qstop值為第一桿位移之最大與最小量。

討論
做到這邊 一直在思考r1的長度問題
原本是使用slider_limit計算出之最大衝程直接當作r1
但是後來考慮到此為滑塊驅動情況
當為曲稈驅動時會有角度的限制
因此試的代入其他值至r1 發現結果一樣
後來觀察sld_angle_limits程式碼
發現限制角度運算都是使用r2,r3和r4
r1會隨運動角度不同而改變 因此設任何值似乎並不影響



接著分別就第二及第三桿驅動之運動狀態作成動畫:
(1)曲桿驅動(以第二桿為驅動桿)


for i=[-64.1581:244.1581]
title('第二桿驅動極限位置 -b94611040')
pause(0.005);
clf;
drawsldlinks([0 50 55 10],0,i,1,0)
axis([-60 120 -80 80]);
axis equal;
end;


(2)連桿驅動(以第三桿為驅動桿)


for i=[-46.6582:226.6582]
title('第三桿驅動極限位置 -b94611040')
pause(0.005);
clf;
drawsldlinks([0 50 55 10],0,i,1,1)
axis([-100 100 -100 100]);
axis equal;
end;



如果要分析各桿之位置,速度,加速度
我們使用講義中的function sldlinks作分析
以下為程式碼內容:
由前面 已知r2=50, r3=55, r4=10,
r1值隨滑塊運動作變動,在此先設為1
另設驅動桿角速度為5, 角加速度為0
function [data,form] = sldlink(r,theta1,theta2,td2,tdd2,sigma,driver)
% r= [r1 r2 r3 r4],四桿之長
% td2= 驅動桿之角速度(rad/sec)
% tdd2= 驅動桿之角加速度(rad/sec^2)
% sigma= +1 or -1. 組合模數, 負值表示閉合型,正值為分支型
% driver= 0(驅動桿為第二桿); 1 (驅動桿為第三桿) ;2(滑塊驅動)
f=@(num,ndg) round(num*10^ndg)/10^ndg;
data=zeros(4,8);
if driver==1, r(2:3)=[r(3) r(2)];end
rr=r.*r;d2g=pi/180;
theta=[theta1 theta2 0 theta1+90]*d2g;
t1=theta(1);t4=theta(4);
[td,tdd,rd,rdd]=deal(zeros(4,1));
s1=sin(t1);c1=cos(t1);
s4=sin(t4);c4=cos(t4);
switch driver
case 2 % for the sliding block as driver
rd(1)=td2;
rdd(1)=tdd2;
A=-2*r(1)*r(2)*c1-2*r(2)*r(4)*c4;
B=-2*r(1)*r(2)*s1-2*r(2)*r(4)*s4;
C=rr(1)+rr(2)+rr(4)-rr(3)+2*r(1)*r(4)*(c1*c4+s1*s4);
arg=B*B-C*C+A*A;
arg=f(arg,5);
if (arg>=0)
form=1; %assembly flag
t2=2*atan((-B+sigma*sqrt(arg))/(C-A));
s2=sin(t2); c2=cos(t2);
t3=atan2((r(1)*s1+r(4)*s4-r(2)*s2),(r(1)*c1+r(4)*c4-r(2)*c2));
theta(2)=t2; theta(3)=t3;
s3=sin(t3); c3=cos(t3);
%velocity calculation
AM=[-r(2)*s2, -r(3)*s3; r(2)*c2, r(3)*c3];
BM=[rd(1)*c1;rd(1)*s1];
CM=AM\BM;
td(2)=CM(1); td(3)=CM(2);
%acceleration calculation
BM=[r(2)*td(2)*td(2)*c2+r(3)*td(3)*td(3)*c3+rdd(1)*c1;...
r(2)*td(2)*td(2)*s2+r(3)*td(3)*td(3)*s3+rdd(1)*s1];
CM=AM\BM;
tdd(2)=CM(1); tdd(3)=CM(2);
else
form=0; return;
end
case {0,1} % for link 2 or 3 as a crank
td(2)=td2; tdd(2)=tdd2; tx=theta(2);
sx=sin(tx); cx=cos(tx);
% position calculations
A=2*r(4)*(c1*c4+s1*s4)-2*r(2)*(c1*cx+s1*sx);
B=rr(2)+rr(4)-rr(3)-2*r(2)*r(4)*(cx*c4+sx*s4);
arg=A*A-4*B;
arg=f(arg,5);
if (arg>=0)
form=1; %assembly flag
r(1)=(-A+sigma*sqrt(arg))/2;
t3=atan2((r(1)*s1+r(4)*s4-r(2)*sx),(r(1)*c1+r(4)*c4-r(2)*cx));
theta(3)=t3;
s3=sin(t3); c3=cos(t3);
%velocity calculation
AM=[c1, r(3)*s3; s1, -r(3)*c3];
BM=[-r(2)*td(2)*sx;r(2)*td(2)*cx];
CM=AM\BM;
rd(1)=CM(1); td(3)=CM(2);
%acceleration calculation
BM=[-r(2)*tdd(2)*sx-r(2)*td(2)*td(2)*cx-r(3)*td(3)*td(3)*c3;...
r(2)*tdd(2)*cx-r(2)*td(2)*td(2)*sx-r(3)*td(3)*td(3)*s3];
CM=AM\BM;
rdd(1)=CM(1); tdd(3)=CM(2);
else
form=0;
if driver==1,
r(2:3)=[r(3) r(2)];
for j=1:4, data(j,1)=r(j).*exp(i*theta(j));end % position vectors
end
return;
end
if driver==1,
r(2:3)=[r(3) r(2)];
c2=c3;c3=cx;s2=s3;s3=sx;
td(2:3)=[td(3) td(2)];
tdd(2:3)=[tdd(3) tdd(2)];
theta(2:3)=[theta(3) theta(2)];
elseif driver==0
c2=cx;s2=sx;
end
end % end of switch
for j=1:4,
data(j,1)=r(j).*exp(i*theta(j));
data(j,2:4)=[theta(j)/d2g,td(j),tdd(j)];
end
data(:,5)=[rd(1);rdd(1);data(2,1);data(2,1)+data(3,1)];
data(1,6)=i*r(2)*td(2)*exp(i*theta(2));
data(2,6)=data(1,6)+i*r(3)*td(3)*exp(i*theta(3));
data(3,6)=r(2)*(i*tdd(2)-td(2)*td(2))*exp(i*theta(2));
data(4,6)=data(3,6)+r(3)*(i*tdd(3)-td(3)*td(3))*exp(i*theta(3));
%[Vq;Vp;Aq;Ap]
data(1:4,7)=abs(data(1:4,6));data(1:4,8)=angle(data(1:4,6))/d2g;

由預設條件代入函式執行得:
[values,form] = sldlink([0 50 55 10],0,100,5,0,-1,0)
abs(values)

ans =
% column1 column2 column3 column4
0.0472 0 0 0
0.0500 0.1000 0.0050 0
0.0550 0.1345 0.0011 0.0307
0.0100 0.0900 0 0

column5 column6 column7 column8
0.2904 0.2500 0.2500 0.1700
0.9368 0.2904 0.2904 0.1800
0.0500 1.2500 1.2500 0.0800
0.0483 0.9368 0.9368 0.1800

其中第一行為各連桿位置向量。
第二行為各桿之水平夾角,第三及第四行為各桿之角度速度及角加速度。
第五行為第一桿之軸向速度與加速度、P及Q點之位置向量。
第六至八行則為P點與Q點之速度與加速度量,第六行為向量,第七行為絕對量,第八行為夾角。

此為以第二桿為軀動桿 且為預設角度之情況
因此若要以第三桿,連桿驅動, 則可比照此作法執行
另外,在嘗試將r1代入不同值時
我們發現在此處r1的值也不影響執行結果



此外,若要作連續性的速度/加速度分析
則可利用之前講義上的draw_4paths函式
由於在此不需作桿上特定點分析,因此r6,th6之值設為0
function draw_4paths(r6,th6,nlink,r,th1,theta,td2,tdd2,sigma,npts,driver,mode)
%Inputs:
% r= 四連桿之長度,以向量表示
% th1,theta: 第一桿及驅動桿之水平角度
% td2,tdd2: 驅動桿之角速度及角加速度
% sigma: 組合模數
% driver: 0為第二桿驅動, 1為第三桿驅動
% npts: 設定分割的點數或位置
% r6,rh6,nlink: 桿上特定點之位置,包括桿長,與桿之夾角及附於何桿
% mode=0 畫簡單位置圖
% =1 畫所有圖表
% =2 畫簡單位置圖+速度圖
% =3 畫所有圖表,但用簡單位置圖
代入預設值執行程式後:
>> draw_4paths(0,0,3,[0 50 55 10],0,30,2,5,1,100,0,1)


不過由於尚無法完全掌握此函式之內容
因此在瞭解清楚之前 還不敢亂加猜測其中意義

2007年5月6日

5/7- 第八次作業

作業八 廖婉婷 B94611040



本週四 (4/26)曾來上課


Q1.設桿2角度theta2=45度時,求各點之位置、速度與加速度為何?

本題採用講義上之f4bar函式
先分析出四連趕各桿/接點之位置,速度,加速度值 再取其所需
而題目一開始給定之條件為
r=[4 3 3 5], theta1=0, td2=10rad/s, tdd2=0rad/s^2
以下為函式內容:

function [data,form] = f4bar(r,theta1,theta2,td2,tdd2,mode,linkdrive)
%輸入參數為
%r= [r1 r2 r3 r4]: 各桿之長度
%theta1= 桿一之水平角度
%theta2= 驅動桿(可為桿2或3)之水平角度
%td2= 驅動桿之角速度(rad/sec)
%tdd2= 驅動桿之角加速度(rad/sec^2)
%mode= +1 or -1 組合模數,負值表閉合型;正值表分支型
%linkdrive = 0表示驅動桿為第二桿; 1表示驅動桿為第三桿
if nargin<7,linkdrive=0;end
if nargin<6,mode=1;end
data=zeros(4,6);
% if coupler is the driver, interchange the vetor 3 & 2
if linkdrive==1,r=[r(1) r(3) r(2) r(4)];end
rr=r.*r;d2g=pi/180;
[theta,td,tdd]=deal(zeros(4,1));
theta(1:2)=[theta1 theta2]*d2g;
t1=theta(1);tx=theta(2);
s1=sin(t1);c1=cos(t1);
sx=sin(tx);cx=cos(tx);
% position calculations
A=2*r(1)*r(4)*c1-2*r(2)*r(4)*cx;
C=rr(1)+rr(2)+rr(4)-rr(3)-2*r(1)*r(2)*(c1*cx+s1*sx);
B=2*r(1)*r(4)*s1-2*r(2)*r(4)*sx;
pos=B*B-C*C+A*A;
if pos>=0,
form=1;
% Check for the denominator equal to zero
if abs(C-A)>=1e-5
t4=2*atan((-B+mode*sqrt(pos))/(C-A));
s4=sin(t4);c4=cos(t4);
t3=atan2((r(1)*s1+r(4)*s4-r(2)*sx),(r(1)*c1+r(4)*c4-r(2)*cx));
s3=sin(t3);c3=cos(t3);
else
% If the denominator is zero, compute theta(3) first
A=-2*r(1)*r(3)*c1+2*r(2)*r(3)*cx;
B=-2*r(1)*r(3)*s1+2*r(2)*r(3)*sx;
C=rr(1)+rr(2)+rr(3)-rr(4)-2*r(1)*r(2)*(c1*cx+s1*sx);
pos=B*B-C*C+A*A;
if pos>=0,
t3=2*atan((-B-mode*sqrt(pos))/(C-A));
s3=sin(t3); c3=cos(t3);
t4=atan2((-r(1)*s1+r(3)*s3+r(2)*sx),...
(-r(1)*c1+r(3)*c3+r(2)*cx));
s4=sin(t4);c4=cos(t4);
end
end
theta(3)=t3;theta(4)=t4;
%velocity calculation
td(2)=td2;
AM=[-r(3)*s3, r(4)*s4; -r(3)*c3, r(4)*c4];
BM=[r(2)*td(2)*sx;r(2)*td(2)*cx];
CM=AM\BM;
td(3)=CM(1);td(4)=CM(2);

%acceleration calculation
tdd(2)=tdd2;
BM=[r(2)*tdd(2)*sx+r(2)*td(2)*td(2)*cx+r(3)*td(3)*td(3)*c3-...
r(4)*td(4)*td(4)*c4;r(2)*tdd(2)*cx-r(2)*td(2)*td(2)*sx-...
r(3)*td(3)*td(3)*s3+r(4)*td(4)*td(4)*s4];
CM=AM\BM;
tdd(3)=CM(1);tdd(4)=CM(2);
%store results in array data
% coordinates of P and Q
if linkdrive==1,
c2=c3;c3=cx;s2=s3;s3=sx;
r(2:3)=[r(3) r(2)];theta(2:3)=[theta(3) theta(2)];
td(2:3)=[td(3) td(2)];tdd(2:3)=[tdd(3) tdd(2)];
else
c2=cx;s2=sx;
end
for j=1:4,
data(j,1:4)=[r(j)*exp(i*theta(j)) theta(j)/d2g td(j) tdd(j)] ;
end % position vectors
data(1,5)=r(2)*td(2)*exp(i*theta(2));%velocity for point Q
data(2,5)=r(4)*td(4)*exp(i*theta(4));%velocity for point P
data(3,5)=r(2)*(i*tdd(2)-td(2)*td(2))*exp(i*theta(2));%acc of Q
data(4,5)=r(4)*(i*tdd(4)-td(4)*td(4))*exp(i*theta(4));%acc of P
data(1,6)=data(2,1);%position of Q, again
data(2,6)=data(1,1)+data(4,1);% position of P

%find the accelerations
else
form=0;
if linkdrive==1,
r=[r(1) r(3) r(2) r(4)];
for j=1:4, data(j,1)=r(j).*exp(i*theta(j));end % positions
end
end




%由題目給定條件執行程式
>> [data,form]=f4bar([4 3 3 5],0,45,10,0,-1,0)

data =

1.0e+003 *

Columns 1 through 5

0.0040 0 0 0 0.0212 + 0.0212i
0.0021 + 0.0021i 0.0450 0.0100 0 0.0041 - 0.0245i
0.0011 + 0.0028i 0.0695 -0.0163 0.4914 -0.2121 - 0.2121i
-0.0008 + 0.0049i 0.0995 -0.0050 0.3836 -1.8712 - 0.4391i

Column 6

0.0021 + 0.0021i
0.0032 + 0.0049i
0
0

%column1: 各桿之位置向量(複數型式)
%column2: 各桿之水平夾角
%column3: 各桿之角速度
%column4: 各桿之角加速度
%column5-1: Q點之速度
%column5-2: P點之速度
%column5-3: Q點之加速度
%column5-4: P點之加速度
%column6-1: Q點之位置向量
%column6-2: P點之位置向量

form =

1

%form=1 表示此四連桿可構成,若為0 則表不行



由程式結果得到
O點位置: 0 + 0i
Q點位置: 0.0021 + 0.0021i
P點位置: 0.0032 + 0.0049i
R點位置: 0.0040 + 0i(同桿一)


>> abs(data(:,5))
%對column5取絕對值
ans =

1.0e+003 *

0.0300
0.0248
0.3000
1.9220


又對column5取絕對值後
Q點速度為0.03
P點速度為0.0248
R點和O點速度為0(因桿1為固定桿)
(速度單位為: 長度/時間)

同理
Q點加速度為0.3
p點加速度為1.9220
R點和O點加速度為0
(加速度為: 長度/時間^2)




Q2.繪出此四連桿之相關位置及標明各點之速度方向及大小(以程式為之)。

本題使用講義上drawlinks函式
繪出由第一題給定條件之四連桿接合情形
drawlinks函式由呼叫第一題f4bar函式,只取其column1的數值
即各桿之位置向量,就能構成基本O,P,Q,R四點,進而完成連桿接合圖
以下為函式內容:
function [values]=drawlinks(r,th1,th2,mode,linkdrive)
%r: 各桿之長度
%th1: 第一桿之水平角
%th2: 驅動桿之水平角
%mode: +1 or -1,組合模式,負值表示閉合型;正值為分支型
%linkdrive: 0是驅動桿為第二桿(crank);1是驅動桿為第三桿(coupler)
if nargin<5,linkdrive=0;end
if nargin<4,mode=1;end
[values b]=f4bar(r,th1,th2,0,0,mode,linkdrive);
rr=values(:,1);
rr(3,1)=rr(1,1)+rr(4,1);
rx=real(rr(:,1));rx(4)=0;
ry=imag(rr(:,1));ry(4)=0;
if b==1
plot([0 rx(1)],[0 ry(1)],'k-','LineWidth',4);
hold on;
if linkdrive==0
plot([0 rx(2)],[0 ry(2)],'b-','LineWidth',1.5);
plot([rx(2) rx(3)],[ry(2) ry(3)],'r-','LineWidth',2);
else
plot([0 rx(2)],[0 ry(2)],'r-','LineWidth',2);
plot([rx(2) rx(3)],[ry(2) ry(3)],'b-','LineWidth',1.5);
end
plot([rx(1) rx(3)],[ry(1) ry(3)],'g-','LineWidth',1.5);
plot(rx,ry,'bo');
text(0,0,' O');text(rx(1),ry(1),' R');
text(rx(2),ry(2),' Q');text(rx(3),ry(3),' P');
else
fprintf('Combination of links fail at degrees %6.1f\n',th2);
end
axis equal
grid on




>> axis([-1 5 -1 5]);
axis equal;
drawlinks([4 3 3 5],0,45,-1,0)
%在顯示畫面上標明三點速度方向及大小
gtext ('速度方向0.0212 + 0.0212i 大小0.03')
gtext ('速度方向0.0041 - 0.0245i 大小0.0248')
gtext ('速度方向0 + 0 大小0')
gtext ('速度方向0 + 0 大小0')


ans =

Columns 1 through 5

4.0000 0 0 0 0
2.1213 + 2.1213i 45.0000 0 0 0
1.0513 + 2.8098i 69.4856 0 0 0
-0.8274 + 4.9311i 99.5246 0 0 0

Column 6

2.1213 + 2.1213i
3.1726 + 4.9311i
0
0


%Q速度方向0.0212 + 0.0212i 大小0.03
%P速度方向0.0041 - 0.0245i 大小0.0248
%R及0速度方向0 + 0 大小0


<圖> 四連桿之相關位置及各點之速度方向及大小(點圖可放大)



Q3.當桿2迴轉時,求出此組四連桿之限制角度,並繪出其位置(以程式為之)。

此題以講義中drawlimits函式
繪出四連桿之極限位置及限制角度
以下為函式內容:

function drawlimits(r,th1,sigma,driver)
%輸入參數為
%r: 四桿之位置向量
%th1: 第一桿之水平角度
%sigma: +1 or -1 組合模數,負值表閉合型;正值表分支型
%driver: 0表示驅動桿為第二桿; 1表示驅動桿為第三桿
[Qstart, Qstop]=fb_angle_limits(r,th1,driver)
clf;
[values b]=f4bar(r,th1,Qstart,0,0,sigma,driver);
rr=values(:,1);
rr(3)=rr(1)+rr(4);
rx=real(rr);rx(4)=0;
ry=imag(rr);ry(4)=0;
if b==1
plot([0 rx(1)],[0 ry(1)],'k-','LineWidth',4);
hold on;
if driver==0
plot([0 rx(2)],[0 ry(2)],'b-','LineWidth',1.5);
plot([rx(2) rx(3)],[ry(2) ry(3)],'r-','LineWidth',2);
else
plot([0 rx(2)],[0 ry(2)],'r-','LineWidth',2);
plot([rx(2) rx(3)],[ry(2) ry(3)],'b-','LineWidth',1.5);
end
plot([rx(1) rx(3)],[ry(1) ry(3)],'-g');
plot(rx,ry,'bo');
text(0,0,' O');text(rx(1),ry(1),' R');
text(rx(2),ry(2),' P');text(rx(3),ry(3),' Q');
text(rx(2)/2,ry(2)/2,['s1=' num2str(Qstart,'%6.1f')]);
else
fprintf('Combination of links fails at degrees %6.1f\n',Qstart);
end
[values b]=f4bar(r,th1,Qstop,0,0,sigma,driver);
rr=values(:,1);
rr(3)=rr(1)+rr(4);
rx=real(rr);rx(4)=0;
ry=imag(rr);ry(4)=0;
if b==1
if driver==0
plot([0 rx(2)],[0 ry(2)],'b-','LineWidth',1);
plot([rx(2) rx(3)],[ry(2) ry(3)],'r-','LineWidth',1.5);
else
plot([0 rx(2)],[0 ry(2)],'r-','LineWidth',1.5);
plot([rx(2) rx(3)],[ry(2) ry(3)],'b-','LineWidth',1);
end
plot([rx(1) rx(3)],[ry(1) ry(3)],'g-');
plot(rx,ry,'bo');
text(rx(2),ry(2),' p');text(rx(3),ry(3),' q');
text(rx(2)/2,ry(2)/2,[' s2=' num2str(Qstop,'%6.1f')]);
else
fprintf('Combination of links fail at degrees %6.1f\n',Qstop);
end
axis equal
grid on




%同1,2題之條件執行程式
>> drawlimits([4 3 3 5],0,-1,0)

Qstart =

28.9550


Qstop =

331.0450



<圖> 四連桿之極限位置(點圖可放大)

因為r1+r2 < r3+r4
且|r1-r2| < |r3-r4|
故屬於第四類型,角度限制在右側(28.9度和331度)
又由葛拉索準則,最短及最長桿之和大於其他兩桿
故應屬雙曲柄機構





Q4.設theta2=[0:20:360],試繪出此組四連桿之重疊影像,解釋為何有些沒有值。

藉由loop讓程式繪出以20度為桿2移動間隔之四連桿組成方式
以下為程式執行結果:
>>  for i=0:20:360,drawlinks([4 3 3 5],0,i,-1,0); 
end

Combination of links fail at degrees 0.0
Combination of links fail at degrees 20.0
Combination of links fail at degrees 340.0
Combination of links fail at degrees 360.0


<圖> theta2=[0:20:360],四連桿之重疊影像(點圖可放大)

由程式結果可知theta2為0,20,340,360這四個角度之連桿組合無法顯示
結合問題三我們注意到長度4 3 3 5之連桿組合
其限制角度為28.9及331度,未達及超過該角就無法組合
故本題以20度為間隔 顯示角度只會在40~320度間





Q5.若將問題三考慮在內,只在可迴轉的範圍內迴轉,請問你能讓此組四連桿作成動畫方式迴轉嗎?


首先以講義body函式
作桿上任一點位置,速度,加速度之運算:
function [val]=body2(r6,alph,values,link)
%輸入參數為:
% r6 = length of point from link's origin,Q
%alph= angle in deg. between the base link and r
%values= vetor output from the call of f4bar.m
%link =the link that the point lays on, 1-4
%outputs:(in complex form)
%val(1):initial position,(say Q, for link 2)
%val(3):middle position,(say P, for link 2)
%val(2):final position,or position of A
%val(4):velocity of A
%val(5):acceleration of A
%
r2=values(link,1);
d2g=pi/180;
switch link
case 2 % on the crank
val(1)=0;v0=0; a0=0;
val(3)=values(2,1);
case 3 % on the coupler
val(1)=values(2,1);
val(3)=values(1,1)+values(4,1);
v0=values(1,5);
a0=values(3,5);
case 4 % on the rocker
val(1)=values(1,1);
val(3)=values(1,1)+values(4,1);
v0=0; a0=0;
case 1 % on the frame
val(1)=0; v0=0; a0=0;
val(3)=values(1,1);
end
th6=(values(link,2)+alph)*d2g;
efact=exp(j*th6);
w6=values(link,3);
a6=values(link,4);
val(2)=val(1)+r6*efact;
val(4)=v0+j*r6*w6*efact;
val(5)=a0+(j*r6*a6-r6*w6*w6)*efact;



接著函式draw4link
與之前drawlinks類似
繪出四連桿連接情形,主動桿使用藍色表示,搖桿為綠色,地桿為黑色
function h=draw4link(values,linkdrive)
%function draw4link(values,b,linkdrive)
%draw the positions of four-bar links
% values are data from f4bar.m
%linkdrive: 0 for crank, 1 for coupler
%clf;
if nargin<2, linkdrive=0;end
rr=values(:,1);
rr(3,1)=rr(1,1)+rr(4,1);
rx=real(rr(:,1));rx(4)=0;
ry=imag(rr(:,1));ry(4)=0;
h(1)=line([0 rx(1)],[0 ry(1)],'color','k','LineWidth',4);
h(4)=line([rx(1) rx(3)],[ry(1) ry(3)],'color','g','LineWidth',1.5);
if linkdrive==0
h(2)=line([0 rx(2)],[0 ry(2)],'color','b','LineWidth',2);
h(3)=line([rx(2) rx(3)],[ry(2) ry(3)],'color','r',...
'LineWidth',1.5,'marker','o');
else
h(2)=line([0 rx(2)],[0 ry(2)],'color','r','LineWidth',1.5);
h(3)=line([rx(2) rx(3)],[ry(2) ry(3)],'color','b',...
'LineWidth',2,'marker','o');
end
text(0,0,' O');text(rx(1),ry(1),' R');
text(rx(2),ry(2),' P');text(rx(3),ry(3),' Q');
axis equal
grid on




最後以move_4paths將四連桿運動情形繪製成動畫
做動態模擬
function move_4paths(r,r6,th6,nlink,th1,td2,tdd2,sigma,driver,ntimes,npts)
%Inputs:
% r: row vector for four links
% th1: frame angle
% th2: crank angle or couple angle
% td2,tdd2:angular velocity and acceleration of the driving link.
% sigma: assembly mode
% driver: 0 for crank, 1 for coupler
% ntimes: no. of cycles
% npts: number of points divided
% r6,rh6,nlink:additional length and angle for nlink link.
%example:
% move_4paths([4 2 3 4],2,-30,3,0,10,0,1,0,4,100)
%
%clf;
if nargin<10, ntimes=3;npts=100;end;
figure(1);
[Qstart, Qstop]=fb_angle_limits(r,th1,driver);
npoint=abs(npts);
th2=linspace(Qstart,Qstop,npoint);
val=zeros(6,npoint);
for i=1:npoint,
[vr b]=f4bar(r,th1,th2(i),td2,tdd2,sigma,driver);
[para]=body2(r6,th6,vr,nlink);
val(1:3,i)=[vr(1,1);vr(2,1);vr(1,1)+vr(4,1)];
val(4:6,i)=[para(1);para(3);para(2)];
end
x=real(val);y=imag(val);
h=drawlimits(r,th1,sigma,driver);
line(x(5,:)',y(5,:)','color','r','linestyle',':');
line(x(4,:)',y(4,:)','color','b','linestyle','-.');
line(x(6,:)',y(6,:)','color','k','linestyle',':');
range=1.2*([min(min(x)) max(max(x)) min(min(y)) max(max(y))]);
axis(range);axis equal;grid off;
for i=2:4,set(h(i),'erasemode','xor');end
h0=patch('xdata',[],'ydata',[],'erasemode','xor','facecolor','r',...
'marker','o');
i=0;s=-1;axis off;
for m=1:ntimes
s=-s;
if abs(Qstop-Qstart-360)<1,i=0;s=1;end;
while 1,
i=i+s;
if i>npoint|i==0,break;end;
set(h(2),'xdata',[0 x(2,i)], 'ydata',[0 y(2,i)]);%crank
set(h(3),'xdata',[x(2,i) x(3,i)], 'ydata',[y(2,i) y(3,i)]);%coupler
set(h(4),'xdata',[x(1,i) x(3,i)], 'ydata',[y(1,i) y(3,i)]);%Rocker
set(h0,'xdata',[x(4:6,i)], 'ydata',[y(4:6,i)]);
drawnow; %flush the draw buffer
pause(0.1);
end
end % for m loop


function h=drawlimits(r,th1,sigma,driver)
%function drawlmits(r,th1,sigma,driver)
%draw the positions of four-bar links
%call f4bar funcion
%r: row vector for four links
%th1: frame angle
%sigma: assembly mode
%driver: 0 for crank, 1 for coupler
% Example:h=f4limits([4 2 3 4],0,1,0)
[Qstart, Qstop]=fb_angle_limits(r,th1,driver)
[values b]=f4bar(r,th1,Qstart,0,0,sigma,driver);
if b==1,
h=drawlinks(values,driver);
else
fprintf('Combination of links fails at degrees %6.1f\n',Qstart);
end
[values b]=f4bar(r,th1,Qstop,0,0,sigma,driver);
if b==1,
h=drawlinks(values,driver);
else
fprintf('Combination of links fails at degrees %6.1f\n',Qstart);
end
axis equal
grid on




%執行程式
%可以看到驅動桿及搖桿之運動軌跡
%還有第三桿上任一點之路徑
move_4paths([4 3 3 5],2,-30,3,0,10,0,1,0,4,100)



另外,
若只需將連桿運動情形製成動畫模式
不需其軌跡路徑,亦可由以下指令執行:
clear;
frames = 200;
LENGTH = [4 3 3 5];
[start, stop] = fb_angle_limits(LENGTH, 0, 0);
for repeat = 1:3,
for i = 0:frames,
clf;
drawlinks(LENGTH, 0, start + (i*((stop-start)/frames)));
axis([-3.5 4.5 -5.5 4]);
pause(0.01);
end;
for i = 0:frames,
clf;
drawlinks(LENGTH, 0, stop - (i*((stop-start)/frames)));
axis([-3.5 4.5 -5.5 4]);
pause(0.008);
end;
end;

2007年4月27日

4/25-第七次作業

作業七 廖婉婷 B94611040


*本人(4/19)有上課*


7-1

本題使用之函式:
function linkshape(A,B,dd)
% 繪出連桿外形
% 輸入參數為起始點A 終點B 連桿寬度dd
if nargin==2,dd=1;end;
d=abs(dd);
AB=(B(1)+j*B(2))-(A(1)+j*A(2));
D=abs(AB);th=angle(AB);
t=linspace(pi/2,2.5*pi,20);
Cout=max(d/2,0.2)*exp(j*t');Cin=Cout/2;
if dd>0,
P=[0;Cin;Cout(1:10);D+Cout(11:20);D+Cin;D+Cout(20);Cout(1)];
else
P=[Cin;0;D;D+Cin];
end
xx=real(P);yy=imag(P);
x=xx*cos(th)-yy*sin(th)+A(1);
y=xx*sin(th)+yy*cos(th)+A(2);
line(x,y)
axis equal


function [vec,dyadata] = dyad(rho,theta,td,tdd)
%由輸入參數:長度rho,起始角度theta,角速度td,角加速度tdd
%算出之vec為位置,速度及加速度之絕對值
theta=theta(:);rho=rho(:);
n=length(rho);
if nargin<4,
tdd=zeros(size(rho));
if nargin==2,
td=ones(size(rho));
end;
end;
if length(td)==1,td=ones(size(rho))*td;end;
if length(tdd)==1,tdd=ones(size(rho))*tdd;end;
td=td(:);tdd=tdd(:);
d2g=pi/180;
tt=exp(i*theta*d2g);
pp=rho.*tt;vv=i*td.*pp;aa=-pp.*td.^2+i*pp.*tdd;
dyadata=[pp vv aa];
vec=[abs(sum(dyadata));angle(sum(dyadata))/d2g];





function dyad_draw(rho,theta,td,tdd)
%經function dyad算出速度/加速度對應值後
%以下為繪出各節速度/加速度之對應方位
clf;
[vec,data] = dyad(rho,theta,td,tdd);
x=[0;cumsum(real(data(:,1)))];y=[0;cumsum(imag(data(:,1)))];
for i=1:length(x)-1
linkshape([x(i) y(i)],[x(i+1) y(i+1)],1);
end
for k=1:length(rho)
x0=x(k+1);y0=y(k+1);
vx=x0+real(data(k,2));vy=y0+imag(data(k,2));
ax=x0+real(data(k,3));ay=y0+imag(data(k,3));
line([x0 vx],[y0 vy],'marker','s','linewidth',2);
line([x0 ax],[y0 ay],'marker','s','color','r','linewidth',3)
end
sdata=sum(data);
ss=[real(sdata(1)) imag(sdata(1))];
vv=[real(sdata(2)) imag(sdata(2))];
aa=[real(sdata(3)) imag(sdata(3))];
line([0 ss(1)],[0 ss(2)],'linestyle',':','linewidth',2)
axis equal;grid on
%繪出之圖紅色為各桿之加速度,藍色為速度,綠色為合速度



題目要求各桿之對應長度rho=[a, a+5, a-5]cm,a=(學號末一碼)+10;
對應起始角度theta=[0, 0, 0]度;
對應角速度為td=[0.2, 0.5, 0 .3]rad/s;
對應角加速度為tdd=[0, 0.1, 0.2]rad/s^2;

因此取a = 0+10 = 10
rho=[10,15,5]


以下為當t=[1 2 3 4 5]秒時,此端桿之對應方位
以迴圈跑時間t=1~5
並計算出隨時間變化之位置/速度/加速度變化量以表示其相對位置
也就是將位置,速度,加速度表示成時間函數
clear; clf;
% clean up environment before starting
a = 0+10;
LENGTH = [a, a+5, a-5];
ANGLE = [0 0 0];
VELOCITY = [0.2, 0.5, 0.3];
ACCEL = [0 0.1 0.2];

% initial state
dyad_draw(LENGTH, ANGLE, VELOCITY, ACCEL);
axis([-1 35 -1 30]);
text(3, 27, 'INITIAL STATE');
pause(1);

% start moving from 1s to 5s
for t = 1:5,
% redraw the graph each time
clf;
dyad_draw(LENGTH, ANGLE + (VELOCITY.*t) + (ACCEL.*0.5.*t^2), VELOCITY + (ACCEL.*t), ACCEL);
axis([-1 35 -1 30]);
text(3, 27, ['AFTER ' num2str(t) ' SECONDS']);
pause(1);
end;



<圖一>最初端桿之對應方位(點圖可看原圖)






<圖二>t=1s時端桿之對應方位(點圖可看原圖)






<圖三>t=2s時端桿之對應方位(點圖可看原圖)






<圖四>t=3s時端桿之對應方位(點圖可看原圖)






<圖五>t=4s時端桿之對應方位(點圖可看原圖)






<圖六>t=5s時端桿之對應方位(點圖可看原圖)





7-2

function ANS = angle_velocity(INITIAL, ACCEL, TIME)
for i = 1:length(TIME),
ANS(i,:) = INITIAL + (ACCEL .* TIME(i));
end;


clear; clf;
VELOCITY = [0.2, 0.5, 0.3];
ACCEL = [0 0.1 0.2];
for i = 1:3,
T(i,:) = 0:0.1:5;
end;

% v-t graph
VELOCITY_POINT = angle_velocity(VELOCITY, ACCEL, 0:0.1:5);
subplot(2,1,1), plot(T',VELOCITY_POINT);
axis([0 5 0 1.5]);
title('速度與時間關係');
xlabel('time');
ylabel('velocity');
legend('10cm', '15cm', '5cm', 'Location', 'Best');

% a-t graph
subplot(2,1,2), plot([0 0 0; 5 5 5], [0 0.1 0.2; 0 0.1 0.2]);
axis([0 5 -0.3 0.3]);
title('加速度與時間關係');
xlabel('time');
ylabel('acceleration');
legend('10cm', '15cm', '5cm', 'Location', 'Best');



速度/加速度與時間t之關係圖(點圖可看原圖):




7-3

4/25-第六次作業



作業六 廖婉婷 b94611040


*我有上本週(十二日)的課*

6.1-1

(點圖可看原圖)
桿--桿號可見圖上標示,共13桿,其中需留意的是:
兩個接地桿視為同一桿(桿1)
右上角與地接觸之滑塊也算一桿(桿8)
需小心槽中梢(桿13)部份,由於其兩端也與結點連接,故也算作是一桿

結--要注意圖上標示MNPQRST的部份為共結之情形,分別為:
M處與桿2 3 4連接,故為(3-1)=2結
N處與桿3 5 6連接,故為(3-1)=2結
P處與桿4 5 10連接,故為(3-1)=2結
Q處與桿6 7 9連接,故為(3-1)=2結
R處與桿10 11 12連接,故為(3-1)=2結
S處與桿9 11 13連接,故為(3-1)=2結
T處與桿1 12 13連接,故為(3-1)=2結

桿8部分有一滑塊,屬稜柱結,連結度為1
而S處槽中梢,連結度為2
故總結數J = 2(正常結) + 2*7(MNPQRST七處,每處分別為2) + 1(滑塊) = 17

由古魯伯公式--M = 3(N-J-1) + fi = 3(13-17-1) + 18 = 3
(M = 可動度,即系統自由度; N = 連桿總數; J = 運動結總數; fi = 第i運動結之連結度)



6.1-2
function [df] = gruebler(nlink,jointype)
%輸入參數為總桿數nlink及各結數量jointype
%輸出函數為計算後之可動度值
code = [1 1 2 3 2 3 1 2 1 3 5];
n = length(jointype);
dim = 3;if n > 3, dim = 6; end;
ff = 0;njoint = 0;
for i = 1 : n,
njoint = njoint + jointype(i);
ff = ff + jointype(i)*code(i);
end;
df = dim*(nlink - njoint - 1) + ff;


>> df = gruebler(13,[15 1 1 ])

df =

3
%由函式跑出的可動度數值



6.1-3
左邊M處之滑塊因未與地面接觸,因此可視為一般旋轉結,與圖中其他正常結(旋轉結)一樣連結度為1,也就是只能作旋轉
而右上角之滑塊因為與地面接觸,視為一滑塊結,連結度為2,亦即可同時作軸旋轉及滑塊移動
而其中因滑塊部份有與地面接觸,故總結數須增加1
至於S部份之槽中梢,因運動結在滑槽中可同時移動和旋轉,因此連結度為2





6.2-1

(點圖可看原圖)
由圖上可以看到總共有三個球結(N,Q,R),兩個旋轉結(M,P)及一個圓柱結(S),
每個球結之自由度為3
每個旋轉結自由度為1
每個圓柱結自由度為2
因此總自由度我們可以得到3*3 + 1*2 + 2 = 13


6.2-2
於本圖中,我們得到總桿數N = 6 (需注意左下角接地觸與桿1視為同一桿)
總結數J = 6
總自由度f = 13

在三度空間運動中,每一連桿有六個自由度
故由古魯伯公式: M = 6(6-6-1) + 13 = 7 整個機構可以動


6.2-3
>> df = gruebler(6,[2 0 0 3 1])

df =

7

%由函式跑出之可動度,值與古魯伯計算出來者相同




6.2-4
但要注意的是,由於球結存在,部份連桿會有自轉運動,因此各須減掉一個自由度(此稱惰性自由度)
此處共有兩桿會自轉(如下圖橘色箭頭標示)也就是實際之可動度需減2 =>M = 7-2 = 5
由於惰性自由度為該桿之自轉運動,對整個機構的運動行為並未有幫助
因此在計算自由度時須將其減去

(點圖可看原圖)
經過比較,我們可以發現由於各結之旋轉方位產生共線之緣故,產生了惰性自由度,
但是此考量並未納入在公式中,因此需另外用觀察法以補公式計算自由度之不足



6.3-1
在一四連桿組中,若依其桿長可設定標示如:
g=最長桿之長度, s=最短桿之長度, p.q中間長度桿之長度

當最短桿與最長桿之和小於其他兩桿之和,則至少有一桿可為旋轉桿
此稱為葛拉索第一類型(葛拉索型機構) : s+g < p+q

若最短桿與最長桿之和大於其他兩桿之和,則所有三個活動連桿必屬搖桿或稱為參搖桿機構
此稱葛拉索第二類型(非葛拉索型機構) : s+g > p+q

葛拉索型之特殊狀況(或稱第三型)--即最短桿與最長桿之和等於其他兩桿之和
s+g = p+q



6.3-2
1. 7+4 = 6+5 : 第三型

>>ans = grashof(1,[4 5 6 7])
ans = Neutral Linkage

2. 8+3.6 > 5.1+4.1 : 非葛拉索型

>>ans = grashof(1,[3.6 4.1 5.1 8])
ans = Non-Grashof Linkage

3. 6.6+3.1 <>>ans = grashof(1,[3.1 4.7 5.4 6.6])
ans = Double-Crank Linkage



6.3-3
葛拉索型:
1 若鄰近最短桿之桿為基桿時,則此四連桿屬曲柄搖桿型。
2 若最短桿為基桿時,則基桿兩端之連桿為雙曲柄型。此時輸入桿若為等轉速,
輸出雖然與輸入同方向,但其速率將會因角位移而產生變化。
3 若與最短桿相對應之桿為基桿時,可以得到雙搖桿機構。

非葛拉索型
無論哪一桿作為基桿,此四連桿系均屬於雙搖桿型,因為任何桿均無法產生完整的迴轉運動。


若要將三組連桿皆改為葛拉索型,改變他們的長度以符合葛拉索機構之要求即可。



6.3-4
function ans=grashof(ground_no,linkage)

ground=linkage(ground_no);
link=sort(linkage);% sorting the links
ig=find(linkage==link(1));
if link(1)+link(4)>link(3)+link(2),
ans='Non-Grashof Linkage';
elseif link(1)+link(4)==link(3)+link(2)
ans='Neutral Linkage';
elseif link(1)==ground,
ans='Double-Crank Linkage';
else
switch ig
case 1
im=3;
case 2
im=4;
case 3
im=1;
case 4
im=2;
end
if ground==linkage(im)
ans='Double-Rocker Linkage';
else
ans='Crank-Rocker Linkage';
end
end



6.3-5
上述三組不是葛拉索機構者為第一和第二組,可以由縮短其最長/最小桿之長度,
亦或是增長中間兩桿之長度,使最長最短桿之和小於其他兩桿之和即可,則就至少有一桿可作旋轉桿