Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Kontrol Sistemleri 2013 Güz Dönemi Kısaca elde edilmek istenen veriyi yada verileri düzenlemek ve kumanda etmek amacıyla bir araya gelmiş elemanlar topluluğuna kontrol sistemi denilir. Kontrol sistemleri günümüzde yaygın olarak birçok alanda kullanılmaktadır. İlgili olduğumuz kontrol sistemi elektriksel, mekanik, biyolojik, vb. olabilir. Sıcaklık kontrolü, geçiş kontrolü, arabada bulunan birçok sistem (şekil3`e bakınız), ve otomatik pilot kontrolü bunlara örnek verilebilir. Günümüzde elektriksel kontrol sistemlerinin merkezinde bulunan kontrolörler mikroişlemci, mikrodenetleyici, ve PLC`lerden oluşmaktadır. Girişler Çıkışlar Sistem Kontrolör Şekil1 Donanımsal olarak kontrol sisteminde bulunan elemanlar: 1. Kontrolör: mikroişlemci, mikrodenetleyici, yada PLC 2. Sensörler: takometre, ısıl çift, ışık duyarlılıklı direnç (LDR), fiber optik sensör, vb. 3. Analog devre elemanları: amplifikatör, osilatör, potansiyometre, seramik rezonatör, 4. Görüntü modülü: LCD, yedi parçalı ekran, bilgisayar 5. Çıkış elemanları: akuatör, DC motor, vb. Kontrolör'ün elemanları: 1. Analog dijital dönüştürücü: X bit ADC 2. Zamanlayıcı: gerçek zaman saati (RTC), Y bit zamanlayıcı, bekçi köpeği zamanlayıcısı, 3. Giriş çıkış portları: Genel amaçlı giriş çıkış pinleri 4. Seri ve paralel ve kablosuz iletişim modülleri: seri iletişim modülleri UART, SPI, I 2C, CAN, LIN, USB, Capture Compare PWM, JTAG, RS232, ethernet, vb.; kablosuz RF IEEE802.11a,b,g, ve n 5. Hafıza modülü: Flash, SRAM, DRAM, DMA Kontrol sistemleri giriş çıkış sinyalleri türlerine göre açık ve kapalı çevrim kontrol sistemleri olarak ikiye ayrılır. Açık çevrim kontrol sistemlerinde giriş işareti çıkıştan bağımsızdır. Buna trafik sinyalizasyon sistemi (eğer trafik yoğunluğunu dikkate almıyorsa) örnek verilebilir. Kapalı çevrim kontrol sistemlerinde ise giriş işareti, bir referans işaretin çıkış işaretiyle toplamından yada farkından oluşmaktadır (fark hatayı e(t) göstermektedir) ve bu sistemler geri beslemeli sistemler olarak adlandırılır (şekil2). Alternatif akım motor hız kontrolü buna örnek verilebilir. Şekil4'e bakıldığında, motorun hızı, triak iletim açısı kontrol edilerek P1 üzerinden ayarlanmaktadır. Bu devrede R2 P1 ve C3 üzerinden bir geri besleme mevcut olup, motor yüke bindiği zaman zıt elektromotor kuvvet (EMK Lenz Yasası) azalıp gerilim düşeceğinden R2, P1, ve C3 üzerindeki gerilim artıp triak iletim açısı artırılmaktadır ve bu nedenle motor hızı arttırılmaktadır. 1/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN r (t ) R(s) + 2013 Güz Dönemi e (t) E (s) K G(s) ± V (s) K⋅G(s ) = R( s) 1∓K⋅G (s)⋅H ( s) H(s) Şekil2 Şekil3 Şekil4 2/41. v (t) V (s) Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi En basit anlamda eğer iki olay birbirini etkiliyorsa, geri besleme mevcuttur ve bir süreç içerisinde olaylar birbirlerini neden-sonuç ilişkisi içerisinde etkilemesine geri besleme denir. Isıtma sistemi, osilatör, ve biyolojik döngüler geri beslemeye örnek verilebilir. Geri besleme negatif veya pozitif formdadır. Negatif besleme kendini dengeleyen (örneğin negatif direnç devresi OPAMP), pozitif beslemeyse kendini arttıran bir etkiye sahiptir. Bundan dolayı geribeslemeli sistemlerin kararlılığı ayrı bir öneme sahiptir (Nyquist kararlılık testi) [2]. Şekil5 deki tristörlü doğru akım motoru, negatif beslemeye bir örnek olarak verilmiştir. Matematikte başlangıç yada sınır değerleri bilinen lineer diferansiyel denklemleri çözmede Laplace dönüşümünü kullanırız. Benzer şekilde, diferansiyel denklemlerle ortaya konan kontrol sistemlerinin çözümlenmesinde Laplace dönüşümü kullanılmaktadır. Kompleks zaman domeni işlemleri, Laplace domeninde (s=G+jw) kolaylıkla yapılabilir. Bu kontrol sistemlerinin modellenmesinde transfer fonksiyonu ve durum denklemleri en yaygın yöntemlerdendir. Transfer fonksiyonu yöntemi sadece doğrusal sistemler için kullanılmaktadır (zamanla değişen yada değişmeyen), yani LTI sistemler için de geçerlidir. PID (partial integrator and derivative) kontrolör ve DC motorun modellenmesi buna örnek olarak verilebilir. Kontrol sistemlerinde, sistem cevabı göz önünde bulundurulduğunda, (tanımlamaları değişmekle beraber) bazı sınırlamalar mevcuttur; 1. Sıfır yada minimum durğan hal hatası (zero or minimum steady-state response) 2. En büyük aşım (overshoot): Birim basamak tepkisine ait çıkışın en yüksek değerinin en son değerinden çıkarıldıktan sonra elde edilir, yada en son çıkış değerine göre yüzde olarak belirtilir. 3. Maksimum yükselme zamanı (Maximum rise time): Birim basamak tepkisine ait çıkışın son değerinin %10 dan %90 a ulaşana kadar geçen süre. 4. Maksimum yerleşme zamanı (Maximum settling time): Birim basamak tepkisine ait çıkışın izin verilen tolerans aralığına ulaşması için geçen süredir. 5. Kazanç ve faz marjinleri (Gain and phase margins): Sistem kazancının 0db olduğu nokta kazanç geçiş frekansı (gain crossover frequency) ve fazın -180 olduğu nokta faz geçiş frekansı (phase crossover frequency) olarak adlandırılmaktadır. Kazanç marjini, faz geçiş frekansında sistemi kararsız olması için ne kadar kazanç değişikliği gerekli olduğunu göstermektedir. (yada kapalı çevrim sistemin kararlılığını bozmadan, açık çevrim sistemin kazancının ne kadar arttırılabileceğini göstermektedir) Benzer şekilde faz marjini, kazanç geçiş frekansında sistemin kararsız olması için ne kadar faz değişikliği gerekli olduğunu göstermektedir. (yada kapalı çevrim sistemin kararlılığını bozmadan, açık çevrim sistemin fazının ne kadar arttırılabileceğini göstermektedir) Tüm bu işlemler için bode grafikleri kullanılmaktadır. Konuyu daha iyi anlayabilmek için Matlab komut satırında margin_gui komutu yazarak kapalı çevrim bir sisteme ait kazanç ve faz marjinleri analizi yapılabilir. Bu sınırlamalar birim basamak tepkisine ait, geçiş durumu (transient) ve kalıcı durum (steady-state) 3/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN süreçlerine aittir. Dizayn esnasında tüm bu limitasyonlar dikkate alınır. Buna ek olarak kontrol sistemlerinin kararlı olması gereklidir ve bunun için Routh-Hurwitz testini uygularız (ileride bu konu işlenecekdir [2]). Şekil5 Lineer Zamanla Değişmeyen Sistemler (Linear Time Invariant Systems (LTI) ) Bir sistemin LTI olabilmesi için lineerlik ve zamanla değişmeme gibi özelliklere sahip olması gereklidir. Lineerlik ve zamanla değişmeme özelliği aşağıdaki gibidir. a1⋅x 1 ( t )→a1⋅y 1 ( t ) a2⋅x 2 (t )→a2⋅y 2 (t ) a1⋅x 1(t )+a2⋅x 2 (t )→ a1⋅y 1 (t )+a2⋅y 2 ( t );(lineerlik ) x 1(t−T )→ y 1 (t−T );(zamanla değişmeme) LTI sistemleri zaman ve frekans domeninde iki şekilde gösterebiliriz. Aşağıdaki zaman ve frekans domeni ilişkisini göstermektedir. Yukarıdaki işlemler her iki taraftaki ifadelerin Laplace transformu alınarak, frekans domenindede yapılabilir. h(t) sistemin darbe tepkisidir, H(s) sistemin transfer fonksiyonudur. x 1 (t )* h(t )= y 1(t ) y a d a X 1 ( s )⋅H ( s )=Y 1 ( s ) . * k o n v ol u syo n g ö s t e r m e k t e d i r . Örnek olarak türev operatörü, integral operatörü, ve RLC devresinin oluşturduğu lineer homojen diferansiyel denklem birer LTI sistemdir. Sürekli ve ayrık zaman LTI sistemleri benzer özelliklere sahiptir. Ayrık zamanlı sistemler için gösterim () yerine [] şeklinde yapılmaktadır. Sürekli Zaman Tek Giriş Tek Çıkış Sistemleri (Continuous Time Single Input Single Output Systems (CT-SISO)) Matlab Polinom Formu; 4/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN N ( s) G( s)= s Laplacedeğişkeni , N ( s)ve D( s) pay ve payda polinomu D( s) s G( s)= 2 G=tf ( pay , payda) sisteme ait transfer fonksiyonu s +2⋅s+1 s G( s)= 2 için G=tf ([ 1 0],[12 1]); yada s=tf (' s ') ; G=s(s ^ 2+2* s +1) ; s +2⋅s+1 Sıfır, Kutup, ve Kazanç Formu; ( s−z 1)⋅(s−z 2) …( s−z n) G( s)=k⋅ s Laplace değişkeni , k reel yada sanal değerli kazanç ( s− p1)⋅(s− p 2)…(s− pn ) z 1 … z n G(s) transfer fonksiyonuna ait reel yada sanal konjuge çifti olan sıfırlar , N (s) kökleri p1 … pn G (s) transfer fonksiyonuna ait reel yada sanal konjuge çifti olankutuplar , D( s)kökleri G= zpk ( sıfır , kutup , kazanç )sisteme ait transfer fonksiyonu sıfır kutup kazanç formunda G( s)= s için G=zpk ([0],[−1 −1],[1]); yada s=zpk (' s ' ); G=s /( s+1)2 ; 2 (s +1) Ayrık Zaman Tek Giriş Tek Çıkış Sistemi (Discreate Time Single Input Single Output System (DT-SISO)) Matlab Polinom Formu; G( z)= N ( z) z ayrık zaman değişkeni , N ( z) ve D ( z) pay ve payda polinomu D( z) G( z)= z G=tf ( pay , payda , örnekleme periyodu)sisteme ait transfer fonksiyonu z −2⋅z−6 G( z)= z için G=tf ([1 0],[1 −2 −6], 0.1); yada z=tf (' z ' ,0.1); G=z /(z ^ 2−2∗z−6); z −2⋅z−6 2 2 Sıfır, Kutup, ve Kazanç Formu örneği; z G(z)= için G=zpk ([0], [−2 3],[1], 0.1); yada z=zpk (' z ' , 0.1); G=z /(z 2−z−6); ( z +2)⋅( z −3) Bunlara benzer şekilde MIMO (Multiple Input Multiple Output) sistemlere ait transfer fonksiyonları oluşturulabilir. Detaylı bilgi için Matlab Help kısmına bakabilirisiniz. Transfer Fonksiyonlarına Gecikme Ekleme (Transfer Functions with Time Delay) Matlab'da bir transfer fonksiyonunu herbir giriş çıkış kanalı üzerinde gecikme belirleyerek gösterebilirsiniz. SISO sisteme ait saniye cinsinden gecikme: tf yada zpk objelerine ait ioDelay özelliği değiştirilir. G=tf ([1 1],[1 5 3]); G.ioDelay=2 ; MIMO sisteme ait saniye cinsinden gecikme: tf yada zpk objelerine ait ioDelay özelliği değiştirilir. s=tf (' s ') ; sys=[2/s (s+1)/(s+10) ; 10 ( s−1)/(s +5)]; tau=[0.1 0.3 ; 0 0.2]; sys.ioDelay =tau ; Sonuç Transfer Fonksiyonu... 5/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Birinci giriş için 2013 Güz Dönemi #1: exp(-0.1*s) * 2/s #2: 10 İkinci giriş için #1: exp(-0.3*s) * (s+1)/(s+10) #2: exp(-0.2*s) * (s-1)/(s+5) Kontrol Sistemlerinde Durum Eşitliklerinin Analizi Herbir kontrol sistemi transfer fonksiyonu yada durum eşitlikleri şeklinde gösterilebilir. Tekrar hatırlamak gerekirse transfer fonksiyonu yöntemi sadece lineer sistemler için geçerlidir, LTI sistemler gibi. Durum eşitlikleriyse doğrusal yada doğrusal olmayan sistemlerin tümüne uygulanabilir. Sistem bu duruma indirgendiğinde işlem MATLAB aracılığıyla kolaylıkla yapılabilir. x durum matrisi, u giriş matrisi ve y çıkış matrisidir. x˙ = A⋅x +B⋅u ; y=C⋅x +D⋅u ; Aşağıda bu matrislerin büyüklükleri gösterilmiştir. Ayrıca Simulink den aşağıda gösterilen blok seçilerek aynı işlemler yapılabilir. Transfer fonksiyonuna ait pay ve paydadan durum eşitliklerine ait bilgiler elde edilebilir, ve bunun terside Matlab da yapılabilir. [ ] [ ][ ] [ ] [ ] x˙1 x u = 5 1⋅ 1 + 1 0⋅ 1 2 3 x2 2 3 u2 x˙2 [] y=[ 2 0 ]⋅ [] x1 u +[ 0 0 ]⋅ 1 x2 u2 A=[5 1;2 3]; B=[1 0;10 1]; C=[2 0]; D=[0 0]; [num1,den1]=ss2tf(A,B,C,D,1) [num2,den2]=ss2tf(A,B,C,D,2) num1 = 0 2.0000 14.0000 den1 = 1 -8 13 num2 = 0 0 2 den2 = 1 -8 13 6/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Y ( s) Y ( s) 2⋅s+14 2 G1 (s)= = 2 G 2 (s)= = 2 U 1 (s) s −8⋅s+13 U 2 ( s) s −8⋅s+13 2013 Güz Dönemi Verilen transfer fonksiyonuna ait, basamak fonksiyonun tepkisi aşağıdaki şekilde Matlab da bulunur. Step fonksiyonu sisteme birim basamak fonksiyonunu uygulamaktadır. Zaman domeninde konvolüsyon yerine, frekans domeninde bu işlemin yapıldığını ve bulunan sonucun zaman domenine dönüştürülerek fonksiyonun bulunduğunu ve grafiğinin çizildiğini düşünebilirsiniz. Darbe tepkisi için impulse(G(s)) fonksiyonu kullanılmaktadır. 5⋅s G( s)= 2 s +2⋅s+5 clc num=[0 0 5]; den=[1 2 5]; step(num,den) grid title('Basamak Fonksiyonu Tepkisi') Şekil6 Benzer şekilde impulse(tf) fonksiyonu darbe tepkisine ait grafiği çizer, parametresi transfer fonksiyonu, tf yada ss objesidir. clc num=[0 0 5]; den=[1 2 5]; figure; grid 7/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN title('Darbe Fonksiyonu Tepkisi') impulse(num,den) 2013 Güz Dönemi Sistemin darbe tepkisi şekil7 deki gibi olur. Şekil7 Ayrıca bir MIMO sistemin state-space modeline ait bilgiler aşağıdaki şekilde elde edilebilir. Y (s) Y ( s) G1 (s)= 1 G 2 ( s)= 2 İki çıkış bir girişli sistem için verilmiş ise, U (s ) U ( s) s+1 3 s +3⋅s 2+3⋅s +2 H (s)= s 2 +3 s 2 +s +1 [ ] H = [tf([1 1],[1 3 3 2]) ; tf([1 0 3],[1 1 1])]; sys = ss(H) % Noktalı virgül olmadığına dikkat ediniz. size(sys) Çıktı aşağıdaki gibidir. Ara işlemleri görmek için noktalı virgülü kaldırmak gerektiğine dikkat ediniz. a= x1 x2 x3 x4 x1 x2 -3 -1.5 2 0 0 1 0 0 x3 -1 0 0 0 x4 x5 0 0 0 0 0 0 -1 -1 8/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN x5 0 0 0 1 0 2013 Güz Dönemi b= u1 x1 1 x2 0 x3 0 x4 2 x5 0 c= y1 y2 x1 x2 x3 x4 0 0.5 0.5 0 0 0 0 -0.5 x5 0 1 d= u1 y1 0 y2 1 Continuous-time model. State-space model with 2 outputs, 1 inputs, and 5 states. Laplace ve ters Laplace dönüşümü aşağıdaki şekilde yapılmıştır. lsimplot syms t s laplace(dirac(t - 3), t, s) laplace(heaviside(t - pi), t, s) ilaplace(1/s,s,t) >> laplace ans = exp(-3*s) ans = exp(-pi*s)/s ans = 1 Matlab LTI Objeleri Bir LTI model objesine ait özelliği değiştirmek için kullanılan fonksiyon parametresi olarak yazıldıksan sonra değeri atanır. Format aşağıdaki gibidir. 'PropertyName',PropertyValue sys = ss(a,b,c,d,'Property1',Value1,...,'PropertyN',ValueN) ss objesinin bazı özellikleri aşağıda verilmiştir. • a,b,c,d,e: Durum denklemlerine ait matrisler. e (implicit descriptor) default olarak [] dır. Daha önceden belirtildiği gibi A Nx Nx, B Nx e Nu, C Ny Nx, D Ny Nu, ve E Nx Nx ölçülerde matrislerdir. • Scaled: Nümerik doğruluğu sağlamak için sistemin ölçeklenip ölçeklenmediğini yazar, 1 yada 0 dır. 9/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN • StateName: Durumların isimleri atanır, string dizisidir. • StateUnit: Durumların birimleri atanır, string dizisidir. • InternalDelay: Sistemin iç kısımlarına ait gecikmelerin tutulduğu vektördür. Örneğin, sistemleri paralel, seri, yada kapalı döngüde bağlarken gecikme eklenmek istendiğinde kulanılır. • InputDelay: Herbir giriş kanalına ait gecikmelerin tutulduğu vektördür (Nx by 1). • OutputDelay: Herbir çıkış kanalına ait gecikmelerin tutulduğu vektördür (Ny by 1). • Ts: Ayrık zamanlı sisemler için örnekleme periyodu, nümerik bir değerdir. Sürekli zaman için sıfırdır. • TimeUnit: Zaman değişkeninin birimini göstermektedir, stringdir. 'nanoseconds', 'hours', 'weeks', 'years' vb. • InputName: Girişlere isim ataması yapılabilir, stringdir. Örnek kullanım; sys.InputName = 'controls'; • InputUnit: Girişlere birim ataması yapılabilir, stringdir. • InputGroup: MIMO sistemlerde girişler guruplandırılarak işlemler yapılabilir, struct dır. Örnek kıllanım; sys.InputGroup.controls = [1 2]; sys.InputGroup.noise = [3 5]; 1 ve 2 girişler control olarak, 3 ve 5 girişler noise olarak adlandırılmıştır. sys(:,'controls') sistemin controls girişlerinden tüm çıkışlarına ait alt sistemin çıkarılması. • OutputName: Çıkışlara isim ataması yapılabilir, string dir. • OutputUnit: Çıkışlara birim ataması yapılabilir, string dir. • OutputGroup: MIMO sistemlerde Çıkışlar guruplandırılarak işlemler yapılabilir, struct dır. Örnek kıllanım; sys.OutputGroup.temperature=[1]; sys.OutputGroup.measurement = [3 5]; sys('measurement',:) tüm girişlerden measurement çıkışlarına ait alt sistem çıkarılması • Name: Sisteme isim ataması, string dir. • Notes: Sistemle ilgili her türlü notlardır. • UserData: Sistemle alakalı Matlab veri yapısıdır. Şekil8'de dcm adlı ss objesine ait örnek verilmiştir. Yine LTI sistemleri göstermek için kullanılan tf ve zpk objesi aynı özelliklere sahipdir (den ve num haricinde). Matlab workspaceden objelere ait tüm veri yapılarına değerleriyle ulaşabilirsiniz. Ayrıca dcm(1,1) <1x1 ss> ss üzerine tıkladığınızda ss objesine ait tüm açıklama Matlab Help ekranından görülebilir. Asimptotik Bode Grafikleri Bir LTI sisteme ait transfer fonksiyonunun frekansla değişimi (frequency sweep) nasıldır sorusunun cevabını bu grafikler vermektedir. Düşey eksende genlik dB cinsinden ve faz açısını derece olarak -180 +180 (yada 0 360) arasında gösteren, ve yatay eksende frekansı temsil eden belirli bir değerden itibaren logaritmik olarak arttırılan iki grafik vardır. Daha yüksek ve düşük genliğin elde edildiği frekans bölgesinin yanında, bu grafiklerde asimptotlar ve genlik yada fazın iki katı arttığı yada yarı yarıya azaldığı kırılma frekansı olarak adlandırılan +yada-3 dB noktaları önemlidir. H ( s) , s= j⋅w →∣H ( j⋅w)∣⋅ang (H ( j⋅w)) ∣H ( j⋅w)∣dB=20⋅log 10 (∣H ( j⋅w)∣) s=jw için genlik ve faz değişimi elde edildiğinden bode grafiklerinde durağan hal tepkisi elde edilir. (Sönümleme sabiti 0 alınmıştır.) Aşağıda iki sistemin bode grafikleri aracığıyla aynı olduğu gösterilmiştir. ex'= ax+bu ve y=cx+du 10/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Şekil8 a = [2 -4; 4 2]; b = [-1; 0.5]; c = [-0.5, -2]; d = [-1]; e = [1 0; -3 0.5]; % Create a descriptor state-space model. sys1 = dss(a,b,c,d,e); % Compute an explicit realization. sys2 = ss(sys1,'explicit') bode(sys1,sys2) >> bode_plot sys2 = a= x1 x2 x1 2 -4 x2 20 -20 b= u1 x1 -1 x2 -5 c= x1 x2 y1 -0.5 -2 d= u1 y1 -1 Continuous-time state-space model. Y ( s) G( s)= =C⋅(s⋅I − A)−1⋅B+ D x( 0)=0 için X ( s) 11/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil9 Bir MIMO sistem'e, istenilen herhangi bir giriş sinyali uygulamak için lsimplot fonksiyonu kullanılır. Belirlenen zaman aralığında ve adımlarla giriş sinyali uygulanır. u matrisi, sistemin giriş sayısı x t matrisi sütun sayısı ölçülerindedir. ssobjesi herhangi bir ss objesidir. t matrisi istediğimiz zaman aralığını belirlenen adımlarla göstermektedir. lsimplot(ssobjesi, u, t); Bilindiği gibi transfer fonksiyonuna ait frekans cevabı belirli bir frekans aralığındaki, genlik (dB) ve faz (derece) olarak elde edilir. Giriş sinyaline ait Laplace dönüşümü kolaylıkla yapılabiliyorsa, ilgili frekansda transfer fonksiyonuna ve giriş sinyaline ait Laplace dönüşümleri çarpıldıktan sonra çıkışa ait genlik dB cinsinden ve faz da derece cinsinden bulunabilir. Giriş ve transfer fonksiyonuna ait dB cinsinden genlikler ve derece cinsinden fazlar mevcutsa, çıkışa ait değerleri bulmak için toplamları alınarak durağan hal tepkisine ait bilgiler elde edilir. Bir sinyal için 4 önemli parametre vardır. Sinyalin türü (kare, testere, yada üçgen dalga gibi), genliği, frekansı, ve faz farkı. Eğer giriş sinyalini Laplace dönüşümüyle ortaya koymak zor ise, bu noktada Fourier dönüşümünü hatırlamak gereklidir. Bu teoreme göre, herhangi bir sinyal değişik frekanslarda sinüs sinyallerinin toplamı olarak ifade edilebilir. Sinyali oluşturan bileşenler bilindiğinde, yani herbir bileşene ait frekans ve genlik bilgileri bilindiğinde, bode grafiğine bakarak durağan haldeki çıkış sinyalini elde edebiliriz. Aslında bir sinyali oluşturmak için bir kaç tane sinüs bileşeni kullanmak yeterlidir. Şekil10'da kare dalga için bu durum ortaya konulmuş ve 5 sinüs sinyali kullanılmıştır. sin (n⋅w c ) 4 y= π⋅∑ n MATLAB'da geçici hal ve durağan hal tepkisi arasındaki farkı kolayca görebiliriz.(şekil11 bakınız) clc; num=[1 5]; den=[1 2 3]; s=tf(num,den); t=[0:0.05:20]; u=5*cos(2*t+pi/6); y=lsim(num,den,u,t); 12/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi [mag,phase]=bode(num,den,2) yss=5*mag*cos(2*t+(30+phase)*pi/180); plot(t,u,t,y,'--',t,yss,'.'); % t>1.8 civarinda duragan hal cevabina ulasir % ayni sonuc elde edilebilir figure(); lsimplot(s,u,t); Şekil10 Şekil11 Birden fazla frekansa sahip giriş sinyali uygulandığında yukarıda anlatıldığı gibi herbir sinyal için sistem çıkışındaki sinyaller hesaplandıktan sonra net çıkış tüm sinyallerin toplamı olarak bulunur. % Alcak geciren filtre clc; num=[0.5 20]; den=[1 1]; s=tf(num,den); 13/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi bode(num,den) fıgure(); t=[0:0.05:20]; u=sin(0.1*t)+cos(0.5*t+pi/4)-sin(13*t-pi/6); y=lsim(num,den,u,t); frekans=[0.1 0.5 13]; [mag,phase]=bode(num,den,frekans) yss=mag(1,1)*sin(0.1*t+phase(1,1)*pi/180)+mag(2,1)*cos(0.5*t+pi/4+phase(2,1)*pi/ 180)-mag(3,1)*sin(13*t-pi/6+phase(3,1)*pi/180); figure(); plot(t,u,t,y,'--',t,yss,'.'); Şekil12 Ayrıca bode grafiklerinden sistemin kararlılığı hakkında fikir edinebiliriz. Konuyu daha iyi anlayabilmek için Matlab komut satırında margin_gui komutu yazarak kapalı çevrim bir sisteme ait kazanç ve faz marjinleri analizi yapılabilir. Bir sisteme ait kazanç ve faz marjinleri [Gm, Pm, Wgm, Wpm]=Margin(sys) fonksiyonuyla elde edilebilir. Sorular: 1- Şekil13'de bulunan mekanik kütle yay sisteme ait modelin (a) seçeneğini Matlab'da ve (b) seçeneğini Simulink'de simülasyonunu yapınız. a) m=1, b=0.3, k= 0.2, x(0)=0.1, x'(0)=0.05, F=0 (sönümlemede) b) m=1, b=0.7, k=1, x(0)=0, x'(0)=0, F=1 Şekil13 14/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi 2- Basit bir osilatör (wien köprü, ring yada kristal osilatör gibi) devresini teorik olarak ortaya koyup, blok diyagramını çiziniz. 3- Paralel RLC devresini teorik olarak ortaya koyup, Matlab ve Simulink'de aşağıdaki değerler için simülasyonunu yapınız. R=800 ohm, C=50 uF, L=50 mH, i(t)= 50*exp(-200*t)*sin(120*pi*t), sin(1.1*t), sin(0.9*t). 4- Şekil14'deki PID geribesleme kontrolörünü doğru akım motorunun hızını kontrol etmek amacıyla dizayn ediniz ve Matlab ve Simulink'de simülasyonunu yapınız. Şekil14 5- Herhangi bir ikinci dereceden aktif geribeslemli lowpass filtrenin devresini çiziniz, transfer fonksiyonunu bulunuz, ve simülasyonunu yapınız. Yararlanılan ve faydalı olabilecek linkler: [1] http://web.itu.edu.tr/~kents/matlab.pdf [2] http://web.sakarya.edu.tr/~afboz/control/bolum1.html [3] http://www.dcsc.tudelft.nl/~sc4070/transp/refresher.pdf [4] http://www.inf.fu-berlin.de/lehre/SS05/Robotik/motors.pdf [5] MATLAB ve SIMULINK'le Modelleme Kontrol II, Zafer Birgül ISBN; 975-511-445-9 15/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN Doğru Akım Motor Kontrolü, Modelleme ve Matlab Simülasyonu Doğrusal yada doğrusal olmayan dinamik sistemlerin tümü Matlab ve Simulink aracılığıyla modellenip simülasyonu yapılabilir. Bu ksımda bir doğru akım motoruna ait bir lineer model geliştirilip Matlab'da ve Simulink'de simülasyonu yapılacaktır. Uygulamanın sonunda transfer fonksiyonları, bunlara ait sıfır, kutup, ve kazanç değerlerinin bulunması, geçici zaman tepkisi (transient response), durağan hal tepkisi (steady-state response), kapalı çevrim ve açık çevrim sistemler, yer kök eğrileri öğrenilecektir, ve sistem üzerindeki sınırlamalar hakkında bilgi edinilecektir. Grafiklerdeki verilerin üzerine tıklayarak değerlerini okuyabilirsiniz. Ara işlemleri Matlab da Command Window kısmında görebilmek için komutların sonundaki ";" kaldırabilirsiniz. Genel Matlab çalışma ortamı şekil15'de gözükmektedir. Sağ tarafda bulunan Workspace kısmından oluşturduğunuz değişkenlere ait datalara, objelere, ve bunlara ait maksimum minimum değerlerine ve boyutlarına ulaşabilirsiniz. Sol tarafda, bulunduğunuz konumda ihtiva edilen dosyalar, ve sağ alt kısımda Command History kullandığınız komutlara ait liste bulunmaktadır. Kodlarınızı bir script dosyasına yazarak (*.m file) komut satırında tekrar yazmak zorunda kalmazsınız ve sekmeler kısmında bulunan kısa yollar aracılığıyla istediğiniz şekilde debug edebilirsiniz, ve çalıştırabilirsiniz. Şekil15 Komutlarınızı bir script dosyasına kaydetmek için NewScript icon'na tıklayın yada File -> new -> script tıkladığınızda şekil16'deki editör karşınıza çıkacaktır, burada komutları yazdıktan sonra save icon'a tıklayarak dosyayı kaydedebilirsiniz. Kodlarınızı yazdıktan sonra kırmızı kutu içinde bulunan 16/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN kısayollar aracılığıyla çalıştırabilir (run) ve satırlara durdurma noktaları koyabilirsiniz (breakpoints). Ayrıca ihtiyaç duyacağınız fonksiyonları bulabilmek için, yada fonksiyonların kullanım bilgilerine ulaşmak için (syntax) mavi kutu içindeki fx kısayoluna tıklayınız; ek olarak bu kısımdan kodu anlaşılabilir kılmak için işaretler ekleyebilirsiniz. Şekil16 T = K m⋅i V emf =K b⋅w J⋅w+K ˙ f ⋅w=T =K m⋅i ( mekanik kısma ait denklem) ; ˙ L⋅i +R⋅i=V −K b⋅w (elektriksel kısma ait denklem); L⋅i˙ +R⋅i=V −K b⋅w ; (J⋅s+K f )⋅w( s)=K m⋅I ( s )=T (s) ; (L⋅s+ R)⋅I (s)=V (s)− K b⋅w(s ); Km w (s) rad / sec G( s)= = [ ] V (s) ( J⋅s+K f )⋅( L⋅s+R)+K m⋅K b V [ ][ ] [ ] −K f K M 0 w˙ = J J ⋅w + w 1 ⋅V y =[1 0]⋅ ˙i −K b −R i i L L L Km T ( s) w( s) 1 = = V ( s)−K b⋅w( s) ( L⋅s+R) T ( s) ( J⋅s+K b) [] [] 17/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil17 Şekil18 Yukarıda bir doğru akım motoruna ait elektriksel ve mekanik denklemler, sisteme ait transfer fonksiyonu, elektriksel ve mekanik kısımlara ait transfer fonksiyonları, ve sisteme ait durum denklemleri verilmiştir. Şekil17 ve şekil18'e bakıldığında modelleme daha iyi anlaşılacaktır. Matlab kodu aşağıdadır. Simülasyon grafikleri sırasıyla verilmiştir. Veriler hakkında daha detaylı bilgi için grafikler üzerine tıklayınız. 18/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Matlab Kodu: % % % % % % % % % % % % % 2013 Güz Dönemi Tüm dosyalar ayni klasörde olmalidir. ÖNEMLi NOKTALAR: ***Tork akimla dogru ve gerilimle ters orantilidir.*** ***Açisal hiz gerilimle dogru orantilidir.*** ***Bundan dolayida tork açisal hizla ters orantilidir.*** ***Güç (akim x gerilim) tork x açisal hizla dogru orantilidir. Transfer fonksiyonlariyla ilgili ayrintili bilgi için dokumanlara bak. Matlab Help kismindan ilgili fonksiyonun nasil kullanildigina ait bilgilere erisebilirsiniz. Sisteme ait sinirlamalar: ***sifir yada minimum durgan hal hatasi*** zero or minimum steady-state response error ***En buyuk asim*** outrise ***maximum yukselme zamani*** maximum rise t. ***maximum yerlesme zamani*** maximum settling time ***kazanc ve faz marjinleri*** Gain and phase margins % Yeni bir pencere açar figure; imshow('dcdemofigures_01.png'); figure; imshow('dcdemofigures_02.png'); R = 2.0; % Direnç Ohm cinsinden L = 0.5; % Bobin Henry cinsinden Km = 0.1; Kb = 0.1; % Tork ve ters EMK sabitleri ayni degerdedir. Kf = 0.2; % Nms J = 0.02; % Eylemsizlik momenti kg.m^2/s^2 h1 = tf(Km,[L R]); % Armatür kismi transfer fonksiyonu h2 = tf(1,[J Kf]); % Yük kismi transfer fonksiyonu % size(ss(h2)) % ss(h2) % ss() fonksiyon state-space matrislerini oluuturur ve size(ss(h2)) % boyutlarini gösterir. % ss(h2) state space matrislerini ve boyutlarini görebilirisiniz. % x'=Ax+Bu y=Cx+Du; A Nx e Nx boyutlarinda, B Nx e Nu boyutlarinda, % C Ny e Nx boyutlarinda, D Ny e Nu boyutlarinda matrislerdir. % [h1 , 1] iki giris tek cikis sistem olur MIMO. Birinci giristen cikisa % transfer fonksiyonu h1, ikincisi 1 dir. [h1 , 1] yazdiginizda % gorebilirsiniz. dcm = ss(h2) * [h1 , 1]; % Td torkdaki degisimi gostermektedir. dcm (bu adimda) = w = h2*(h1*Va + % Td) Td tork degisikligi girisi eklendi, [h1 , 1] bundan dolayi dcm adli % obje 1x2 ss objesidir. dcm = feedback(dcm,Kb,1,1); % size(ss(dcm)) iki giris bir cikis iki durum elemani vardir. Kapali döngü % ters EMK, geri besleme olarak Matlab default olarak negatif geribesleme % kabul eder. eger iki 1 den sonra +1 yazilirsa pozitif geribeslemenin % isareti pozitif olur. Yukarida iki transfer fonksiyonu oldugunu % soylemistik. Bunlari Td kismindan sonra paralel olan iki blok ve sonra % cikista toplam olarak dusune bilirsiniz yada iki girisli bir sistem. % Bundan dolayi dcm 2x1 giris gerektiriir. Yani bir girisi Va olan diger % girisi Td olan cikisysa w olan bir blok diyagram olusturduk. kapali dongu % fonksiyonunda paremetre olarak index degerlerini yazdik, ilk 1 iki tane % olan giristen sadece 1 si yani Va, mesela 2 yazsaydik geribesleme Td % girisine baglanirdi; ikinci 1 cikisimizi gostermektedir zaten 1 tane onun % indexini yazdik oda w dir. bu olusturlan dcm ss objesi ileride % kullanilacaktir. figure; stepplot(dcm(1)); % sistemin birim basamak tepkisiyle (step response) açisal hizin degisimi % görülür. cikisin ilk girise olan degisimi gosterilmistir % stepplot(dcm(1,1)); ile aynidir. Td icin yani 2. girise uygulanan birim 19/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi % basamak fonksiyonunun tepkisi gorulmek isteniyorsa stepplot(dcm(1,2)); % kullanilir. stepplot(dcm(1,:)); her iki cikisida gostermektedir. % unutmayin Td torkdaki degisimi gosermektedir. Yani motor yuke % bineceginden negatif degerler almasi gereklidir. ylabel('\fontsize{16} Acisal Hiz (rad/s)'); xlabel('\fontsize{16} Zaman (s)'); title('\fontsize{16} Acisal hizin birim basamak tepkisiyle olan degisimi'); % ileri besleme dizaynina ait simülasyon figure; imshow('dcdemofigures_03.png'); % kazanç degerinin belirlenmesi icin 1/birim basamak tepkisinin sonsuzdaki % degeri alindi. bunu acik cevrim sistemin cikisinin w duragan halde 1 % olmasi icin. yaptik Kff = 1/dcgain(dcm(1)); % Kff=4.1 dcgain(dcm(1))~0.24 yani w(s)/v(s) dc gain transfer fonksiyonun % s=0 iken degeridir. eger dcgain(dcm(1,2)) bulunmak istenseydi W(s)/T(s) % s=0 iken degerini bulurduk oda 4.878 t = 0:0.1:15; % 0-15 s arasinda 0.1 adimla simülasyon icin noktalar belirledik. % Yükdeki degisiklik (tork) 5s ile 10s arasinda, -0.1 Nm tork degisikligi Td = -0.1 * (t>5 & t<10); % u giris matrisi 2x150 matrisdir. Cunku dcm 2x1 giris gerktiriyordu. Simdi % 150 tane deger icin u = [ones(size(t)) ; Td]; % w_ref=1 ve Td ne oldugunu yukarida belirttik % diag([Kff,1]) diagonal matris olusturur Kff 1x1, ve 1 2x2 elamanlaridir. cl_ff = dcm * diag([Kff,1]); % ileri beslemeli sistemin duragan halde (steady state) de degerinin 1 % olmasi icin Kff ile carpildi. Sistemin Td ile olan girisi eskisiyle ayni % ss objesine sahip, ve tum degerleri eskisiyle ayni. Fakat Va ile olan % girisi cl_ff ss objesine ait yeni ozellikler atandi, yeni obje eskisinin % Kff katidir (yani amplifikator uygulanmistir). set(cl_ff,'InputName',{'w_ref','Td'},'OutputName','w'); % burada cl_ff ss objesine ait ozellikler atanmistir. % o ile 15 saniye arasinda 5s ile 10s arasinda -0.1Nm tork degisikligi için % sistemin tepksi gösterilir. figure; h = lsimplot(cl_ff,u,t); % cl_ff ileri besleme sistemine ait transfer fonksiyonu % lsimplot u giris matrisine ait t zaman araliginda sistemin cevabidir. % wref 1 olarak atanmistir. title('\fontsize{16} Acisal hizin acik cevrim sistemde basamak tepkisiyle olan degisimi'); legend('cl\_ff'); ylabel('\fontsize{16} Acisal Hiz (rad/s)'); % Grafikte belirtilen -0.1 Nm tork degisikliginin grafikde gösterilmesi line([5,5],[.2,.3]); line([10,10],[.2,.3]); text(7.5,.25,{'tork degisikligi','T_d = -0.1Nm'},... 'vertic','middle','horiz','center','color','r'); % Geri beslemeli sistemin sifir duragan hal hatasi icin, root locus yer kok % yontemi kullanarak K kazanç degerini bulma figure; h = rlocusplot(tf(1,[1 0]) * dcm(1)); setoptions(h,'FreqUnits','rad/s'); set(gca,'Xlim',[-15 5],'Ylim',[-15 15]); % eksen limitleri % K C % % % Geri beslemeli sistemle ileri beslemeli sistemin karsilastirilmasi = 5; = tf(K,[1 0]); % K/s kismina ait transfer fonksiyonu append(C,1) 5/s, Sistemin Td ile olan girisi eskisiyle ayni ss objesine sahip, ve tum degerleri eskisiyle ayni. Fakat Va ile olan girisi cl_rloc ss objesine ait yeni ozellikler atandi, yeni obje eskisinin 5/s katidir 20/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi % (yani amplifikator uygulanmistir). Bu islemler dcm * append(C,1) sonucuda % olusmustur. cl_rloc = feedback(dcm * append(C,1),1,1,1); % sisteme geribesleme için gerekli olan kisimlar eklendi. ilk bir % geribeslemenin degerinin 1 oldugunu gosterir. Birinci giris yani wref'e % geribesleme yapilmistir, ikinci 1 bunu gosterir. ucuncu 1 geribeslemein % alindigi cikis yani w gostermektedir. default olarak Matlab'da % geribesleme katsayisi negatif kabul edildiginden sistem girisi wref-w dir figure; h = lsimplot(cl_ff,cl_rloc,u,t); set(cl_rloc,'InputName',{'w_ref','Td'},'OutputName','w'); title('Ileri besleme ve geri beslemeli sistemlerin acisal hizinin tork degisimine olan tepkisi') legend('Ileribesleme','Geribesleme (rlocus)','Location','NorthWest') % daha iyi geribesleme performansi elde etmek için Lineer Quadratic % Regulator Modeli (LQR) Va = K1 * w + K2 * w/s + K3 * i kullanildi. Bu % modelde Va girisine uygulanacak sinyal w cikis ve i akim dan elde edilir. % bunlarin sisteme ait durum vektorunun elemanlari olduguna dikkat edin. % x=(w,i) boylece sistemdeki degisim hakkinda daha fazla veri elde edilmis % olunur. i(s)=w(s)/s dir. figure; imshow('dcdemofigures_05.png'); % [1 ; tf(1,[1 0])] birinci transfer fonksiyonu 1 ikinci transfer % fonksiyonu 1/s dir. dc_aug = [1 ; tf(1,[1 0])] * dcm(1); % size(ss(dc_aug)) dc_aug iki cikisli bir girisli uc durum elemani olan bir % ss objesidir. w/s olan bir cikis daha modele, birinci girise uygulanacak % sekilde DC motor modeline eklendi. daha once bahsettigimiz gibi % i(s)=w(s)/s cikisni kullanacagimizdan bu cikisa ihtiyac duyduk. lqry % lineer quadratik durum geribesleme regülatörü dizayn eder. kullanim % [K,S,e] = lqry(ss,Q,R,N) seklindedir. Daha iyi tork degisikligini yok % etmek icin (disturbance rejection) cost fonksiyonu su sekilde % hesaplanmistir. cost J= integral 0->sonsuz % (20i^2(t)+w^2(t)+0.01Va^2(t))dt K_lqr = lqry(dc_aug,[1 0;0 20],0.01); % K_lqr geribeslemeye ait K, S, ve e (F geribesleme ve W bizim % notasyonumuzda) degerlerini verir. e burada kapali cevrim eigenvalue % lardir e=eign(A-B*K). K yeni bloklardaki katsayilara sahip. P = augstate(dcm); % durum vektörünü çikis vektörüne ekler x'=Ax+Bu y=Cx+Du; % | y |=|C|x+|D|u tek bir esitlik haline gelir. % | x |=|I| +|0| % sistem 3 cikisli 2 durumlu 2 girisli oldu % girisler:Va,Td çikislar:w,x(w,i); x burada i ve w gostermektedir C = K_lqr * append(tf(1,[1 0]),1,1); % 44.72, 36.97, 15.18 K_lqr katsayilarla 1/s 1 1 carpildi C = 44.72/s, % 36.97, 15.18 oldu. OL = P * append(C,1); % Açik çevrim dizayn Va=44.72*w/s+36.97*w+15.18*i su anda geribesleme % eklenmedi OL 3 cikis 4 giris 3 durumlu bir objedir. 3 giris Va icin % yukaridaki denklemde verilmistir. diger giris Td icindir CL = feedback(OL,eye(3),1:3,1:3); % kapali çevrim dizayn. eye(3) 3x3 birim matrisdir. ilk 1:3 1 den 3 kadar % tum girisler ve ikinci 1:3 1 den 3 kadar tum cikislari temsil eder. % bunlar sirasiyla birbirine baglanir. default olarak negatif geribesleme % var. cl_lqr = CL(1,[1 4]); % Elimizde sistem 4 giris 3 cikisli, bizim ihtiyacimiz olan LQR sisteme % ait sistem (w_ref,Td)->w iki giris 1 cikisli olmali 1 cikis w ve 1 ve 4 % giris wref ve Td secildi. figure; h=bodeplot(cl_ff,cl_rloc,cl_lqr); 21/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi % Grafikle ilgili eksenleri isimlendirmede problem oldugu icin yeniden % isimlendirme yaptik. Frekans birimini Hz degistirdik, karisiklik % olmamasi acisindan. Bu LTI objeleri anlamak acisindan iyi bir uygulamadir P=getoptions(h); P.FreqUnits = 'Hz'; P.Title.String='Transfer Fonksiyonlarina Ait Bode Grafigi'; P.XLabel.String='Frekans (acisal frekans degil)'; P.YLabel.String={'Faz Farki (derece)','Genlik (dB)'}; setoptions(h,P); legend('Ileribesleme','Geribesleme (rlocus)','Geribesleme (LQR)','Location','NorthEastOutside') % üç sisteme ait asimptotik bode grafigi burada frekansa (not açisal % frekans degil) göre üç sistemin degisimi gozlenmektedir. Bundan dolayi x % ekseninin birimini Hz olarak kullanacagiz ust satir genligi alt satir faz % farkini göstermektedir. Sol tarafdaki grafiklerde I/O wref to w, sag % tarafdaki grafiklerde I/O Td to w transfer fonksiyonlari bunlara gore % ayarlandi. figure; h = lsimplot(cl_ff,cl_rloc,cl_lqr,u,t); title('Ileri besleme ve geri beslemeli sistemlerin acisal hizinin tork degisimine olan tepkisi') legend('Ileribesleme','Geribesleme (rlocus)','Geribesleme (LQR)','Location','NorthWest') Şekil19 22/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Şekil20 Şekil21 23/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Şekil22 Şekil23 24/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Şekil24 Şekil25 25/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil26 Yer Kök Eğrileri R ( s) K H(s) V ( s) B(s) Şekil27 V (s) K⋅H ( s) = B (s)=1 için R(s ) 1+K⋅H (s) Kapalı çevrim sistemin kutupları 1+KH(s)=0 özyapısal denkleminden elde edilir. b ( s) a(s ) H (s)= a ( s)+ K⋅b (s)=0 +b(s)=0 a ( s) K n a(s) polinomunun en büyük derecesi ve m b(s) polinomunun en büyük derecesidir. K sıfıra doğru yaklaştıkca a(s)=0'dır kapalı çevrim sistemin kutupları H(s)'in kutuplarıdır, benzer şekilde K sonsuza doğru yaklaştıkca b(s)=0'dır kapalı çevrim sistemin kutupları H(s)'in sıfırlarıdır. Kapalı çevrim sistem n kutba sahiptir. Bundan dolayı köklerin yer eğrisi yada yer kök eğrisi n kola sahiptir. Her kol üzerinde kazanç 0'dan büyükdür, kollar dışında kazanç 0'dan küçükdür (bu kısımla ilgilenmeyiz). Her kol, gerçel eksene göre bir açıyla (çıkış açısı), H(s)'in kutuplarıyla başlar ve, gerçel eksene göre bir açıyla (varış açısı), H(s) sıfırlarına doğru gider. Eğer H(s)'in kutup sayısı sıfır sayısından fazla ise H(s) sonsuzda n-m sıfıra sahipdir, bundan dolayı H(s)'in limiti sıfırdır. Bu durumda yer kök eğrisinin asimptotlarının (sonsuza giden kol) sayısı kutup sayısından sıfır sayısı 26/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN çıkarılarak bulunur. Rlocus() fonksiyonuyla yer kök eğrisi MATLAB'da çizilebilir. Parametre olarak transfer fonksonuna ait pay ve payda katsayıları yada durum eşitliklerine ait A,B,C,D matrisleri girilebilir. Yer kök eğrisi gerçel eksene göre simetrikdir. Yer kök yer eğrilerinin gerçel eksene göre simetrik olmalarından dolayı varış ve çıkış noktaları ya gerçel eksen üzerinde yada sanal çift halinde s (konjuge) düzlemi üzerinde bulunurlar. Eğer kök yer eğrisi gerçel eksen üzerinde yer alan iki kutup arasında yer alıyorsa bu iki kutup arasında en azından 1 çıkış noktası vardır. Benzer şekilde kök yer eğrisi gerçel eksen üzerinde yer alan iki sıfır arasında yer alıyorsa bu iki kutup arasında en azından 1 varış noktası vardır. Sanal eksene yakın olan kutuplar (yada kollar) kapalı çevrim dinamik sistemin kararlılığı ve dinamik davranışı üzerinde, en büyük aşım artacağından ve sönümleme azalacağından dolayı, daha büyük etkiye sahipdir ve baskın kol olarak adlandırılırlar. Bundan dolayı kutupların konumuna göre sistem 1. veya 2. dereceden sistem gibi davranabilir. Bu noktada n. dereceden sistemlere ait tepkileri hatırlamak gereklidir. Birinci dereceden sistemin basamak tepkisinde birinci terim zorlanmış tepki (kararlı halde) ve ikinci terim doğal tepki (geçici halde) olarak iki kısımdan oluşmaktadır. Sistem sınırlamaları c(t) üzerinde belirtilir. K C (s) K −t / τ τ G( s)= = R ( s)=u (t) için C ( s)= → c (t )= K⋅(1−e )⋅u( t) R( s) 1+ τ⋅s s⋅( s+1/ τ) İkinci dereceden sistemin transfer fonksiyonu doğal frekans ve sönümleme parametrelerini içermektedir. Sistem üzerinde olan tasarım ölçütleri dikkate alındığında aşağıdaki denklemler elde edilir. Şekil28'de verilen S düzlemi en büyük aşım, yerleşme ve yükselme zamanı sınırlamalarını karşılamaktadır. 2 C ( s) w n = 2 s=−ζ⋅w n± j⋅wn⋅√1−ζ 2 kutuplar R( s) s +2⋅ζ⋅w n⋅s+w 2n ζ>1, aşırı sönümleme , iki reel ayrık kutup ζ<1, sönümlenmemiş durum , konjuge kutuplar ζ=1, kritik sönümleme , aynı yerde iki kutup 1 Basamak tepkisi R( s)= ve 0 başlangıç koşulları s ζ ( s+ζ⋅w n)+ ⋅wn⋅√ 1−ζ 2 2 2 wn 1 √1−ζ C ( s)= C (s )= + 2 2 s s⋅( s +2⋅ζ⋅w n⋅s+w n ) ( s+ζ⋅wn )2+w 2n⋅(1−ζ 2) 1 L−1 → c (t)=1− ⋅e−ζ⋅w ⋅t⋅cos (w n⋅√ 1−ζ 2⋅t−α) , α=arctan (ζ / √ 1−ζ 2)=arccos( ζ) 2 √ 1−ζ 2 wn wn 2 ˙ s⋅C (s)= L−1 → c˙ (t)= ⋅e−ζ⋅w ⋅t sin(w n⋅√ 1−ζ ⋅t) 2 2 2 2 ( s+ζ⋅w n ) +w n⋅(1−ζ ) √1−ζ π T p= en büyük aşım zamanı ,c (t )' nin zamana göre türevi sıfıra eşitlenerek bulunur w n⋅√ 1−ζ2 G( s)= n n M p =1+e−ζ⋅π /√ 1−ζ =1+e−π/ tan (α) M p en büyük aşım α=arctan (ζ / √1−ζ 2)=arccos(ζ ) en büyük aşım zamanı , c (t)' de yerine koyulduğunda bulunur. yani c(T p ) −ln(0.02⋅√1−ζ 2) k −ζ⋅π/ √1−ζ %±2 hata için yerleşme zamanı 1.02=1+e T s= T s= k =4 ζ⋅w n ζ⋅w n 1−0.4167⋅ζ+2.917⋅ζ 2 Yükselme zamanı T r = 0<ζ<1 wn c (t) ' nin son değerinin 10 değerinden 90 değerine ulaşdığı zamandır 2 2 27/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil28 Örneğin verilen sistem için %5 den az aşım ve 1 s yükselme zamanı, kutuplar taralı bölgede olacak şekilde K orantısal kazanç değerini değiştirerek elde edilebilir. Zeta sönümleme oranı ve wn doğal frekansdır. clc; num=[1 5]; denum=[1 40 500 1500 0]; [z,p,k]=tf2zpk(num,denum) rlocus(num,denum); axis('equal'); axis([-22 3 -18 18]) zeta=0.7; wn=1.8; sgrid(zeta,wn) [kd,poles]=rlocfind(num,denum) title('Kok Yer Egrisi') [num2, den2]=cloop((kd)*num,denum) figure(); step(num2,den2) >> z= 0 0 -5 p= -17.8260 + 5.2171i -17.8260 - 5.2171i -4.3480 + 0.0000i k= 1 Select a point in the graphics window selected_point = -3.2500 + 0.9503i 28/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN kd = 593.5379 poles = -19.3048 + 0.0000i -14.4944 + 0.0000i -3.1004 + 0.9967i -3.1004 - 0.9967i Şekil29 Şekil30 (1 dereceden sisteme benzer cevap) 29/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil31 (2 dereceden sisteme benzer cevap) W n⩾ 1.8 Tr ζ⩾ √ ln(M p ) 2 π2 ln(M p ) 2 1+ π2 T r yükselme zamanı , M p % olarak en büyük aşım Yukarıdaki denklemden, %5 den az aşım ve 1 s yükselme zamanı için, sönümleme oranının 0.7'den daha büyük olması ve doğal frekansın 1.8 den büyük olması gereklidir. Şekil29'daki 45 derecelik zeta=0.7 karşılık gelen kesikli iki çizginin arasında zeta>0.7 ve kesikli yarım çember wn=1.8 dışında wn>1.8. Bu iki bölgenin kesişimi dizaynla ilgili sınırlamaları karşılayan kutup değerlerini vermektedir ve MATLAB'da sgrid(zeta,wn) şeklinde bulunmaktadır. Bu bölgeden istediğiniz değeri tıklayarak seçebilirsiniz. Şekil30'da birim basamak tepkisine olan cevabın sınırlamaları karşıladığı gösterilmiştir. Verilen yer kök eğrisi için -17.8260 + 5.2171i, -17.8260 – 5.2171i, 0 ve -4.3480 açık çevrim kutuplarından başlayan 4 adet kol vardır. Kollardan biri -5'de olan açık çevrim sıfırında son bulur. Diğer üç kol K sonsuza giderken (3 adet sıfır burada bulunmaktadır) sonsuza gider. K=0 iken Açık çevrim kutuplarının toplamı -40 dır. Kutup sayısı sıfır sayısından daha fazla olduğundan K değişirken kutupların toplamı sabit kalır. (rlocfind() ile seçilen noktaya göre tüm kutupların toplamının -40 olarak sabit kaldığı görülmektedir). Yine aynı şekilde kutıpların sağ yarı düzleme geçdiği değerler rlocfind() komutu ile istenilen noktanın üzerine tıklanarak MATLAB'da bulunabilir. Kolların yönleri ∑ z i =∑ r i z i açık çevrim kutupları r i öz yapısal denklemin kökleri kutupların toplamının sabit kalmasını sağlayacak şekildedir. Gerçek eksen üzerindeki kolları bulmak için açık çevrim kutup ve sıfırlarına bakılır. Gerçel eksen 30/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN üzerindeki en solda yer alan sıfır yada kutup'un sağında yer alan kutup ve sıfır sayısı tek ise o bölgeden yer kök eğrisi geçmektedir, eğer çiftse o bölgeden yer kök eğrisi geçmemektedir. Bu işlem en sağdaki sıfır yada kutup'a kadar devam eder ve bu işleme sanal kutup yada sıfırlar dahil edilmez. Örneğe baktığımızda -5 deki sıfırın sağında 3 tane kutup bulunmaktadır, bundan dolayı gerçel eksen üzerindeki -5'in solundaki bu bölgeden yer kök eğrisi geçmektedir. Diğer durumlar benzer şekilde bulunabilir. 180⋅(2⋅k +1) α= yer kök eğrisine ait asimptot açıları k =0,1,2 ,… , n−m−1 n−m ∑ kutupi −∑ sıfır i asimptotların gerçel eksenden geçdiği noktalar σ= n−m G=[(-17.8260-17.8260-4.3480-0)-(-5)]/(4-1)=-35/3=-11.7 noktasında yer kök eğrisine ait asimptotlar kesişirler. Asimptot açıları 60(2k+1)=60,180,300(-60) derecedir. Yer kök eğrisinin gerçel eksenden ayrılma noktası 1+KH(s)=0 özyapısal denklem eşitliğinden K elde edildikten sonra, türevi sıfıra eşitlenerek s değerleri bulunur. ∂ K (σ) ∂ H (σ)/∂ σ ∂ H (σ) −1 1+K⋅H (s)=0 K (σ)=( ) = =0 → =0 σ ' lar bulunur 2 ∂σ ∂σ H (σ) H (σ) [(s+5)/(s^4+40*s^3+500*s^2+1500*s)]'=0 -6.67+2.36i → -2.93, -17.1, -6.67-2.36i, Gerçel ekseni ayrılma noktaları -2.93 ve -17.1 dir. Kutupların yada sıfırların (varış) çıkış açıları, yer kök eğrisi üzerinde bulunan herhangi bir s noktasına açı koşulu uygulanarak bulunabilir. Test edilen nokta için sıfırların açılarından kutupların ang (s+5)−ang ( s+17.82−5.21i)−ang ( s+17.82+5.21i)−ang (s)−ang (s+4.34)=180, k =0 s=0 yakınındaki bir nokta test edildiğinde θ0=180 yada−180 s=−4.34 yakınındaki bir nokta test edildiğinde θ−4.34=180−180=0 s=−5 yakınındaki bir nokta test edildiğinde θ−5=180−360=−180 yada 180 s=−17.82+5.21i yakınındaki bir nokta test edildiğinde θ−17.82+5.21i =−74.69 s=−17.82−5.21i yakınındaki bir nokta test edildiğinde θ−17.82−5.21i =74.69 açıları çıkarılarak istenilen kutup'a yada sıfıra ait ayrılama açısı bulunabilir. Eşlenik kutupların açıları ters işaretlidir. ∑ θ z −∑ θ p =(2⋅k+1)⋅180 i i 0 kutup'undan sol tarafa doğru K değeri artmaktadır ve çıkış açısı gerçel eksene göre 180 derecedir. -4.34 kutup'undan sağ tarafa doğru K değeri artmaktadır ve çıkış açısı gerçel eksene göre 0 derecedir. -5 sıfır'ından sol tarafa doğru K değeri artmaktadır ve çıkış açısı gerçel eksene göre 180 derecedir. -17.82+5.21i kutup'undan güneydoğu yönünde K değeri artmaktadır ve çıkış açısı gerçel eksene göre -74.69 derecedir. -17.82-5.21i kutup'undan kuzeydoğu yönünde K değeri artmaktadır ve çıkış açısı gerçel eksene göre -74.69 derecedir. Gene bu durumları MATLAB'da yer kök eğrisi üzerine tıklayarak ve ilgili renkli yer kök eğrisini takip ederek teyid edebilirsiniz. Kök yer eğrisinin sanal ekseni kesdiği noktaları bulmak için Routh-Hourwitz kararlılık koşulu uygulanır. 1+KH(s)=0 den kararlılık sınırındaki k değeri ve buradan s'in sanal ekseni kesdiği noktalar bulunur. 4 3 2 s +40⋅s +500⋅s +(1500+k )⋅s+5⋅K =0 s4 s3 s2 s 1 1 500 5⋅k 40 (1500+K ) 0 18500−K 5⋅K 0 40 8000⋅K −(1500+K ) 0 0 18500−K 5⋅K 0 0 31/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi 8000⋅K 2 −(1500+ K ))⋅s=0 0=−K +9000⋅K +27750000 → K=11428,−2428 K>0 olmalı 18500−K Örneğin tabloya ait üçüncü satır (40x500-(1500+K)x1)/40 şeklinde yazılır. ( 18500−K 2 2 )⋅s +5⋅K =0 K =11428için 0=7072⋅s +2285600 → s=17.9775i ,−17.9775i 40 s satırına ait denklem çözüldüğünde, yer kök eğrisi sanal ekseni K=11428 iken keser, ve s^2 satırına ait denklem çözüldüğünde, yer kök eğrisi sanal ekseni +17.98i, -17.98i noktalarında keser. Farklı sayıda gerçel yada sanal kutup ve sıfır olması durumunda, benzer şekilde yer kök eğrisi bulunabilir. Sisteme bir kutup ilavesi baskın kutup'u sağ yarı düzleme doğru ve sıfır ilavesi baskın kutup'u sol yarı düzleme doğru hareket ettirir. Grafiklerden de anlaşılacağı gibi yer kök eğrileri geçici ve durağan hal tepkilerine ait bilgileri ortaya koyar. Diğer tarafda bode grafikleri sadece durağan tepkisiyle ilgilenmektedir. Bundan dolayı yer kök eğrileri daha iyi analiz imkanı sağladığını söyleyebiliriz. ( Routh Hourwitz Kararlılık Testi Bu test karakteristik denkleme ait köklerin sağ yarı düzlemde yer alıp almadığını belirler ve sanal eksen üzerinde bulunan ve sağ yarı düzlemde bulunan köklerin sayısını verir. H(s) polinomuna ait köklerin sol yarı düzlemde bulunabilmesi için polinomdaki tüm katsayılar aynı işaretli olmalıdır ve hiçbir katsayı sıfır olmamalıdır. Bu yeterli koşul değildir ve kararlılık testi için Routh-Hourwitz testi uygulanmaktadır. 4 3 2 H (s)=a 4⋅s +a 3⋅s +a 2⋅s +a 1⋅s+a 0 s4 s3 s2 s 1 a4 a3 a ⋅a −a ⋅a A= 3 2 4 1 a3 A⋅a1 −a 3⋅B C= A C⋅B−a 4⋅0 D= =B C a2 a0 a1 0 a ⋅a −a ⋅0 B= 3 0 4 =a 0 0 a3 0 0 0 0 Eğer ilk sütundaki elemanların tümü aynı işaretiyse köklerin tümü sol yarı düzlemdedir. Eğer ilk sütundaki elemanların işaretleri değişiyorsa, işaret değişimi kadar sağ yarı düzlemde kök vardır. Herhangi bir satırın ilk elemanı 0 olması durumunda diğer elemanların sonsuz olaması durumu ortaya çıkmaktadır. Bu sorunu aşmak için 0 yerine e gibi sembolik bir sayı yazılır ve diğer işlemlere devam edilir. Tüm satır sıfır ise sanal eksen üzerinde kök vardır. Bu durumda teste devam edebilmek için ilgili satırın bir üst satırındaki katsayılarla yardımcı denklem oluşturulur A(s) ve A'(s)=0 işlemlerinden sonra katsayılar ilgili satıra yazılarak işleme devam edilir. P ( s)=s 5+4⋅s 4+8⋅s 3+8⋅s 2+7⋅s+4 İşaret değişimi yok, sistem kararlı ve sanal eksen üzerinde iki katlı kök var. 4⋅s2 +4=0 s=± j 32/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN s5 4 s 3 s s2 s1 s0 1 4 6 4 0 4 2013 Güz Dönemi 8 7 8 4 6 0 4 → 4⋅s 2+4 0 0 4 4 Nyquist Kararlılık Testi ve Grafikleri Nyquist grafiği, pozitif yada negatif herhangi bir frekansa karşılık G(jw) değeri gerçel ve sanal olarak x-y düzleminde gösterilerek oluşturulur (polar grafik olarakda düşünülebilir). Bu grafikde w 0 ve sonsuz iken G(jw) değeri ve grafiğin gerçel (Im(G(jw))=0, Re(G(jw))) ve sanal (Re(G(jw))=0, Im(G(jw))) eksenle kesişimleri önemlidir. clc; tau1=1; tau2=1/10; num=[1]; denum=conv([tau1*1 1],[tau2*1 1]); tf(num,denum) nyquist(num,denum) Şekil32 Matlab'da sağ tıklayarak grafiğin (-1,0) noktasına zoom yapabilirsiniz yada grid opsiyonunu aktif hale getirebilirsiniz. Nyquist kararlılık testi, kapalı çevrim bir sistemin kararlılığını grafiksel olarak gerçel ve sanal eksen üzerinde, w 0 dan sonsuza artarken (yada -sonsuza) açık çevrim transfer fonksiyonunu G(jw)H(jw) (-1,0) noktasına karşı inceleyerek ortaya koymaktadır, şekil33 sağdaki grafik bu durumu 33/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN özetlemektedir. (Benzer şekilde açık çevrim transfer fonksiyonunun kararlılığını, G(jw)H(jw) (0,0) noktasına karşı inceleyerek ortaya koymaktadır, şekil33 soldaki grafik durumu özetlemektedir). Kararlılık testinde oluşturulan grafiklerde Nyquist kapalı çevresi sağ yarı s düzlemi G(jw)H(jw) kutuplarının üzerinden geçmeden çevresini dolaşacak şekilde kapsar. Şekil33 Basitleştirilmiş Nyquist kararlılık testi ω 0’dan ∞’a giderken, açık-döngü frekans tepkisi G(jω)H(jω) yer eğrisi, -1 noktasını kapasamayan kapalı-döngü sistemler, kararlıdır, -1 noktasını kapsayan sistemler kararsızdır ve -1 noktasından geçen sistemler marjinal kararlıdır.(Şekil34) Noktayı kapsamak, noktanın soluna geçmek olarak alınabilir. Bu durum açık döngüsü kararlı sistemler için geçerlidir. (s düzleminin sağ tarafında kutup'u olmayan açık döngü sistemler için geçerlidir) Şekil34 34/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN Açık çevrim G(s)⋅H ( s )için kararlılık N 0 =Z 0− P0 P 0=0 ile N 0 ; G(s )⋅H ( s) Nyquist grafiğinin(0,0) etrafındaki çevrim sayısı , saat yönünün tersiise pozitif Z 0 ; Nyquist çevrimiyle çevrelenen G(s )⋅H ( s) sıfırlarının sayısı P 0 ; Nyquist çevrimiyle çevrelenen G (s)⋅H ( s) kutuplarının sayısı Kapalı çevrim G ( s)/1+G(s )⋅H ( s)için kararlılık N −1=Z −1−P −1 Z −1=0 ile N −1 ; G(s)⋅H ( s) Nyquist grafiğinin (−1,0) etrafındaki çevrim sayısı , saat yönünün tersiise pozitif Z −1 ; Nyquist çevrimiyle çevrelenen 1+G(s )⋅H ( s) sıfırların sayısı P−1 ; Nyquist çevrimiyle çevrelenen 1+G ( s)⋅H ( s) kutupların sayısı Açık ve kapalı çevrim kutupları aynıdır P−1= P0 Açık çevrim sistemin G(s)H(s) kararlı olması için, G(s)H(s) Nyquist grafiğinin (0,0) noktasını çevrim sayısı ile sağ yarı düzlemdeki G(s)H(s) sıfırların sayısına eşit olmalıdır. N 0=Z 0 olmalıdır. Kapalı çevrim sistemin G(s)H(s) kararlı olması için, G(s)H(s) Nyquist grafiğinin (-1,0) noktasını saat yönünde çevrim sayısı ile sağ yarı düzlemdeki kapsanan G(s)H(s) kutuplarının sayısına eşit olmalıdır. N −1=−P−1 =−P 0 Kazanç geçiş frekansı |G(jWgm)H(jWgm)|=1 koşulundaki Wgm frekansıdır, ve faz geçiş frekansı ang(G(jWpm)H(jWpm))=180 dereceye eşit olduğu durumdaki Wpm frekansıdır. Kazanç marjini Gm=20log(1/|G(jWgm)H(jWgm)|) dB, faz marjini Pm=180+ang(G(jWpm)H(jWpm)). clc; num=[1]; denum=conv(conv([1 1],[1 1]),[1 1]); isstable(tf(num,denum)) nyquist(num,denum) [Gm,Pm,Wgm,Wpm]=margin(num,denum) Şekil35 35/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN Doğrusal İkinci Dereceden Düzenleyici Kontrolör (Linear Quadratic Regulator (LQR)) LQR bir dinamik sistemin optimum kontrolü konusunda karşımıza çıkan bir problemdir. Bir sistemin optimum kontrol için ikinci dereceden bir maliyet fonksiyonuyla tanımlanması ve lineer diferansiyel denklemlerle ortaya konması, LQ problem olarak adlandırılmıştır. Kontrol teorisinde temel problemlerden biri olan LQ, geribeslemeli bir sistemi durum değişkenlerini kullanarak ve sistem sınırlamalarını göz önünde bulundurarak en efektif şekilde ortaya koyan düzenleyici bir kontrol sistemidir. Maliyet fonksiyonu, durum değişkenleriyle oluşturulan fonksiyonlardan ve bunların toplamlardan oluşur. İşlem karmaşıklığını önlemek için dizaynı yapan kişi maliyeti azaltan algoritmaya ihtiyaç duyulan verileri, yani ağırlık katsayılarını atayarak sistemi oluşturmaya çalışmaktadır. Bu maliyet fonksiyonu sistemde istenilen değerlerin değişimini en aza indirmektedir (bizim örneğimizde açısal hız). Bunun yanında, dizaynı yapan kişiye düşen ağırlık katsayılarını değiştirip, bir kaç iterasyon yaparak, sisteme ait tüm sınırlamalar açısından en efektif çözümü bulmakdır. Bulduğumuz F (geribesleme) için, J maliyet fonksiyonunun minimum olması istenir. Q ve R ağırlık katsayılarını göstermektedir. Q nxn simetrik pozitif yarıtanımlı (symmetric positive semidefinite), R mxm simetrik pozitif tanımlı (symmetric positive definite) birer matrisdir. x˙ = A⋅x+B⋅u ; u=F⋅x ; F geribesleme ; J =∫ [ x T (t)⋅Q⋅x (t)+uT (t)⋅R⋅u( t)]⋅dt ve Q=M T⋅M. 0 Q yukarıda belirtildiği gibi yazılabilir. M pxn p<=n matisdir. Doğal olarak LQR kontrolörün kararlı (Stabilizable) olması istenir, bunun için (A,B) çiftinin kararlı olması gereklidir. (A,M) çifti de tespit edilebilir (detectable) olmalıdır. ARE (Algebric Ricatti Equation) çözümü W simetrik pozitif yarıtanımlı (symmetric positive definite) bir matrisdir. W bulunduğunda F de bulunmuş olur. (Daha fazla ayrıntılı matmatiksel bilgi ve altyapı için başka kaynaklara bakınız.) −1 T T −1 T F =−R ⋅B ⋅W ; W⋅A+ A ⋅W +Q−W⋅B⋅R ⋅R ⋅W =0( ARE ) ; DC motor kontrolünde kullanılan maliyet fonksiyonunu incelemek burada yararlı olacakdır. Bu fonksiyon uygulanan torka karşı açısal hızdaki değişimi (disturbance rejection)minimuma indirmektedir (integral hatası olarak da düşünülebilir). Dikkat edileceği üzere akım i(t) ve açısal hız w(t) katsayıları Va(t) ait olanlardan dan daha büyükdür. Daha büyük katsayılar daha iyi sonuç verecekdir. Lqry() fonksiyonu bize optimum geribesleme kazanç değerlerini vermektedir. Sizde değişik maliyet fonksiyonlarıyla sistemler elde etmek için değişik katsayı matrisleri uygulayınız. w( t) 2 2 2 J =∫ [20⋅i (t)+w (t)+0.01⋅V A (t)]⋅dt V A (t )=K 1⋅w( t)+K 2⋅ +K 3⋅i( t) s 0 [ ] [] Q= 1 0 ; R=[ 0.01 ] x= w ; u=[ V A ] ; 0 20 i Simulink Aracılığıyla Doğru Akım Motor Modelleme ve Simülasyon Doğru akım motorunu ait Matlab'da yapılan modelleme ve simülasyon aynı şekilde Simulink aracılığıyla da yapılabilir. Simulink Library Browser'ı açmak için Şekil15'de görünen Matlab ekranında, Simulink Library kısayoluna tıklayınız. Aynı şekilde, Matlab Command Line kısmında >>simulink komutunu yazılınca Simulink açılır. Açılan pencerede File -> New seçerek kendi modelinizi oluşturmak için boş bir çalışma sayfası açabilirsiniz. Şekil36'de görünen Simulink Library Browser aracılığıyla istediğiniz model bloğunu seçerek çalışma sayfanıza sürükleyiniz. Daha sonra seçilen modellere ait giriş çıkış pinleri birbirine bağlayınız ve bloklara ait parametreleri atayınız. Bağlantıları yaparken dikkat edilmesi gereken bir husus modellerin bazıları giriş , bazıları çıkış, ve diğer kısmıda hem giriş hem çıkış özelliğine sahip olmasıdır. Bundan sonra oluşturduğunuz çalışmanın simülasyonunu yapabilirsiniz. Oluşturduğunuz modelin üzerine 36/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN tıklayarak alt modelleri görebilirsiniz. 2013 Güz Dönemi Şekil36'da bir doğru akım motoruna ait oluşturulan dizayn ve Library browser gösterilmiştir. Simülasyonu çalıştırmak için modellere atanan değişkenlere ait değerler View-> Model Explorer -> Base Workspace den ayarlanabilir, şekil37'de değişkenlere atanan değerler gösterilmiştir. Simulation-> Configuration Parameters kısmından uzun süre beklememek için simülasyon süresi stop time 0.2s ve solver ode15 ayarlanabilir (şekil38). Simulink modeline ait denklemler aşağıda verilmiştir. Simülasyonu yapmadan önce blok diyagramın girişine step, çıkışına scope, şekil39'daki gibi bağlanır ve step için step time 0, initial value 0 ve final value 1'e ayarlanır. Run tuşuna basılarak simülasyon çalıştırılır ve scope üzerinde tıklanarak sistemin tepkisi görülebilir, daha net görüntü için autoscale tuşuna basınız. Şekil40'da sistemin tepkisi görülmektedir, bununla birlikte Simulink Profile Summary Report'da gözükmektedir. Ayrıca bağlantıların üzerine çift tıklayarak çalışmanızı anlaşılabilir kılmak açısından isimlendirme yapabilirsiniz. Şekil36 37/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN Şekil37 Şekil38 38/41. 2013 Güz Dönemi Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN 2013 Güz Dönemi Şekil39 Şekil40 Tüm bunlara ek olarak Matlab'da kodladığınız bir fonksiyonu Simulink'e aktarıp bir model halinde ihtiyaç duyduğunuz yerlerde kullanabilirsiniz. Bunun için yazdığınız kodu embedded function olarak Matlab'da compile etmeniz gerekmektedir (#eml başlangıcında olmalıdır). Bu kodu Simulink ortamında kullanabilmek için Embedded Matlab Function modelini çalışmanıza eklemeniz 39/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri Hazırlayan: Kazım EVECAN gerekmektedir. 2013 Güz Dönemi Sorular 1- Matlab'da simülasyonu yapılan doğru akım motoruna ait modellemeleri ve simülasyonu, transfer fonksiyonunu ve toplayıcıyı kullanarak Simulink'de yapınız. 2- İki eksenli hareket edebilen bir robot kola ait kontrol sistemini teorik olarak ortaya koyunuz, blok diyagramında gösteriniz ve Simulink'de simülasyonunu yapınız. 3- Girişi 0-5V arasında 8 bit analogdan dijitale çeviren dönüştürücü olan ve çıkışında istenilen periyotta ve görev saykılıyla PWM (Pulse Width Modulation) sinyali üreten sistemi modelleyiniz ve Simulink'de rampa ve testere fonksiyonları için simülasyonunu yapınız. 4- Tek fazlı asenkron motora ait açısal hız ve giriş gerilimi arasındaki transfer fonksiyonunu bulunuz. Doğru akım motoru için yapılan modellemenin ve simülasyonun benzerini tek fazlı bir asenkron motor için yapınız. Modelin Bode grafiğini oluşturup, bu grafiği yorumlayarak motor hız kontrolüne ait alternatif yöntemler öneriniz. Filtre Devreleri ve Özel Kontrolörler Aktif eleman Opamp ile ve pasif elemanlarla P, I, PD, PI, PID, faz ilerlemeli, faz gerilemeli kontrolör tasarlayınız. Pasif elemanlarla ve aktif eleman Opamp ile alçak geçiren, yüksek geçiren, band geçiren, ve çentik filtreleri tasarlayınız. Devre şekli, birinci veya ikinci dereceden denklemler ve niçin kullanıldıkları bu kontrolörleri ortaya koyabilmek açısından yeterlidir. (güncellenecekdir) Ek Okuma Çalışmaları Genel olarak konuların daha iyi anlaşılabilmesi açısından, aşağıda verilen akademik yayınlardan birini yada benzerini okuyunuz. 1- SERVO SİSTEMLERİN MATLAB ÜZERİNDEN GÖMÜLÜ SİSTEMLER ile PID KONTROLÜ. Aydın GÜLLÜ*, Mustafa ARDA*, Hilmi KUŞÇU***Trakya Üniversitesi, İpsala MYO, Elektronik ve Otomasyon Bölümü, Edirne**Trakya Üniversitesi, Mühendislik-Mimarlık Fakültesi, Makina Mühendisliği Bölümü, Edirne 2- Güneş Pili Modülünün Matlab/Simulink ile Modellenmesi ve Simülasyonu Modeling and Simulation of Solar Cell Module in Matlab/Simulink.Mustafa Ergin Şahin, Halil İbrahim Okumuş Fizik Bölümü, Fen Edebiyat Fakültesi RTE Üniversitesi, RİZE mustafaerginsahin@yahoo.com Elektrik Elektronik Mühendisliği Bölümü, KTÜ Mühendislik Mimarlık Fakültesi, TRABZON MATLAB'a alternatif olarak free-share Octave ve Scilab programları kullanılabilir. Yararlanılan ve faydalı olabilecek linkler: [1] http://www.mathworks.com/help/control/examples/dc-motor-control.html [2] http://ctms.engin.umich.edu/CTMS/index.php? example=MotorSpeed§ion=SimulinkModeling 40/41. Dumlupınar Üniversitesi Kontrol Sistemlerinin Temelleri 2013 Güz Dönemi Hazırlayan: Kazım EVECAN [3] http://home.hit.no/~hansha/documents/matlab/training/Introduction%20to %20Simulink/Introduction%20to%20Simulink.pdf [4] http://www.inf.fu-berlin.de/lehre/SS05/Robotik/motors.pdf [5] http://www.yildiz.edu.tr/~omurlu/CF/OKI/6.pdf [6] http://www.emo.org.tr/ekler/a8f19b3900fcc6c_ek.pdf 41/41.
© Copyright 2025 Paperzz