Datorövning 2 Matlab/Simulink. Styr- och Reglerteknik för U3/EI2



Relevanta dokument
Datorövning Matlab/Simulink. Styr- och Reglerteknik för U3/EI2

Styr- och Reglerteknik för U3/EI2

Tentamen i Reglerteknik, 4p för D2/E2/T2

Tentamen i Reglerteknik, för D2/E2/T2

Styr- och Reglerteknik för U3/EI2

Tentamen i Styr- och Reglerteknik, för U3 och EI2

Tentamen i Styr- och Reglerteknik, för U3 och EI2

Styr- och Reglerteknik för U3/EI2

Liten MATLAB introduktion

Introduktion till Control System Toolbox 5.0. This version: January 13, 2015

Processidentifiering och Polplacerad Reglering

Institutionen för Tillämpad Fysik och elektronik Umeå Universitet BE. Introduktion till verktyget SIMULINK. Grunderna...2

Reglerteknik, TSIU 61

SIMULINK. En kort introduktion till. Polplacerad regulator sid 8 Appendix Symboler/block sid 10. Institutionen för Tillämpad Fysik och elektronik

Tentamen i Reglerteknik, för D2/E2/T2

Laboration: Grunderna i MATLAB

Reglerteknik AK, FRT010

TENTAMEN I TSRT19 REGLERTEKNIK

Reglerteknik för D2/E2/Mek2

Lösningar till tentamen i Industriell reglerteknik TSRT07 Tentamensdatum: Martin Enqvist

Reglerteknik AK, Period 2, 2013 Föreläsning 6. Jonas Mårtensson, kursansvarig

Försättsblad till skriftlig tentamen vid Linköpings universitet

Introduktion till verktyget SIMULINK. Grunderna...2. Tidskontinuerliga Reglersystem Övningsuppgift...13

Försättsblad till skriftlig tentamen vid Linköpings universitet

TENTAMEN I REGLERTEKNIK I

Reglerteknik AK. Tentamen 27 oktober 2015 kl 8-13

REGLERTEKNIK KTH. REGLERTEKNIK AK EL1000/EL1110/EL1120 Tentamen , kl

TENTAMEN I TSRT91 REGLERTEKNIK

Stabilitetsanalys och reglering av olinjära system

REGLERTEKNIK Laboration 5

Försättsblad till skriftlig tentamen vid Linköpings universitet

Exercises Matlab/simulink V

Försättsblad till skriftlig tentamen vid Linköpings universitet

TENTAMEN I TSRT91 REGLERTEKNIK

Reglerteknik AK. Tentamen 9 maj 2015 kl 08 13

TENTAMEN I TSRT91 REGLERTEKNIK

Lösningar till tentamen i styr- och reglerteknik (Med fet stil!)

Flervariabel reglering av tanksystem

TENTAMEN REGLERTEKNIK TSRT15

Laboration: Grunderna i Matlab

Reglerteknik 7. Kapitel 11. Köp bok och övningshäfte på kårbokhandeln. William Sandqvist

TENTAMEN I REGLERTEKNIK

Övningar i Reglerteknik

Välkomna till TSRT19 Reglerteknik Föreläsning 8. Sammanfattning av föreläsning 7 Framkoppling Den röda tråden!

Laboration i Automationsteknik FK: Del 1: Polplacering. Del 2: Markovkedjor

Laboration i tidsdiskreta system

TENTAMEN I REGLERTEKNIK Y TSRT12 för Y3 och D3. Lycka till!

Försättsblad till skriftlig tentamen vid Linköpings universitet

Introduktion till Matlab

Reglerteknik M3. Inlämningsuppgift 3. Lp II, Namn:... Personnr:... Namn:... Personnr:...

Välkomna till TSRT19 Reglerteknik Föreläsning 6. Sammanfattning av föreläsning 5 Lite mer om Bodediagram Den röda tråden!

Lunds Tekniska Högskola Avdelningen för industriell elektroteknik och automation

ERE 102 Reglerteknik D Tentamen

G(s) = 5s + 1 s(10s + 1)

TENTAMEN I DYNAMISKA SYSTEM OCH REGLERING

Lösningsförslag till tentamen i Reglerteknik Y/D (TSRT12)

TENTAMEN I TSRT22 REGLERTEKNIK

Reglerteknik 7. Kapitel 11. Köp bok och övningshäfte på kårbokhandeln. William Sandqvist

Försättsblad till skriftlig tentamen vid Linköpings universitet

DN1212, Numeriska metoder & grundläggande programmering. Laboration 1 del 1-3 (frivilliga delar) Del 1-3 (dvs upg ) behöver inte redovisas

Överföringsfunktioner, blockscheman och analys av reglersystem

Reglerteknik AK. Tentamen 24 oktober 2016 kl 8-13

Figur 2: Bodediagrammets amplitudkurva i uppgift 1d

REGLERTEKNIK Laboration 4

Konsolfönster i Windows Momentet ingår i kursen PDA DTR1206 Lab 1 DOS Konsolfönstret

A. Stationära felet blir 0. B. Stationära felet blir 10 %. C. Man kan inte avgöra vad stationära felet blir enbart med hjälp av polerna.

INLÄMNINGSUPPGIFT I. REGLERTEKNIK I för STS3 & X4

När man vill definiera en matris i MATLAB kan man skriva på flera olika sätt.

TENTAMEN I REGLERTEKNIK TSRT03, TSRT19

Lösningsförslag till tentamen i Reglerteknik fk M (TSRT06)

TENTAMEN I REGLERTEKNIK Y/D

TENTAMEN I TSRT07 INDUSTRIELL REGLERTEKNIK

OBS! Snabbinsatt Matlab-intro vissa fönsterhanteringsdetaljer kan vara fel men gör gärna Matlab-uppgifterna. DN1240, Numeriska metoder för OPEN1.

TSRT91 Reglerteknik: Föreläsning 4

Reglerteknik AK, FRTF05

TENTAMEN I REGLERTEKNIK

REGLERTEKNIK, KTH. REGLERTEKNIK AK EL1000, EL1110 och EL1120

Flervariabel reglering av tanksystem

Lab 1 Analog modulation

MODELLERING AV DYNAMISKA SYSTEM OCH INLUPP 2

REGLERTEKNIK Inledande laboration (obligatorisk)

EL1000/1120/1110 Reglerteknik AK

PC-BERÄKNINGAR. REGLERTEKNIK Laboration 5 och inlämningsuppgift. Inlämningsdatum:... Inlämnad av labgrupp:... Gruppdeltagare:

Reglerteknik AK, Period 2, 2013 Föreläsning 12. Jonas Mårtensson, kursansvarig

Teori Se din kursbok under avsnitt PID-reglering, Ziegler-Nichols metod och olinjära system (avsnitt 7.7 i Modern Reglerteknik av Bertil Thomas).

Nyquistkriteriet, kretsformning

Lägg märke till skillnaden, man ser det tydligare om man ritar kurvorna.

Transkript:

Högskolan i Halmstad Sektionen för Informationsvetenskap, Dator- och Elektroteknik 08/ Thomas Munther Datorövning 2 Matlab/Simulink i Styr- och Reglerteknik för U3/EI2 Laborationen förutsätter en del förberedelser som genomläsning och repetering av vissa begrepp inom kursen. Det som inte hinns med vid laborationstillfället bör gås igenom på egen hand för att dels lösa inlämningsuppgifter alternativt behövas vid ett senare tillfälle I denna laboration skall studeras olika återkopplade processer och deras stegsvar, poler och kvarstående fel. Vi ska också använda PID-reglering. Detta görs m h a Simulink och Matlab. Spara gärna m-filer och mdl-filer till exempelvis inlämningsuppgifter eller egna självstudier. Vi kommer mest använda oss av simulink Tid: ca 2timmar. OBSERVERA: alla uppgifter redovisas.

Kap 24 i kursboken sid 476-503 beskriver lite mer allmänt hur simulering av reglersystem med Matlab och Simulink går till. Starta matlab. Ni har nu kommit in i kommandofönstret. Här kan ni direkt ge kommandon och få direkt respons på inmatningar. Starta simulink genom att skriva simulink i kommandofönstret. Nu har ni ett antal fönster öppna. Biblioteksfönster och ett namnlöst editeringsfönster. Kopiera över de objekt som behövs. Från Simulink-> Continuous hämtas Transfer Function (överföringsfunktion). Därefter hämtas från Simulink->Math Operations blocken Add och Gain. Blocken Step och Scope hämtas från: Simulink->Sources samt Simulink-> Sinks. Step Add Gain s+ Transfer Fcn Scope Figur Förbind alla blocken det görs med höger musknapp när denna förs mot pilspetsen så kan ni dra förbindningar mellan blocken. Gör så att nedanstående Figur 2 erhålls. Step Add Gain s+ Transfer Fcn Scope Figur 2 Nu återstår några detaljer att göra. Ändra i blocket Add så att vi får en negativ återkoppling. Vi ändrar blocknamnen också. Detta görs genom att dubbelklicka med musen på befintlig text eller var ni vill i editeringsfönster. Det kan då se ut enligt nedan. 0 Börvärde reglerfel P-regulator s+ Process 0 s+ Process 30 s+ Process2 Ärvärde Sensor Figur 3 Simulera systemet och titta på stegsvaret. Förläng simuleringstiden till 50 sek. 2

Figur 4 Gå nu tillbaka till Matlabs kommando fönster (command window) och definiera: Det som står efter %-tecken är bara en kommentar. >> Gp=tf([0],[ ]) % processens delöverföringsfunktion >> Gp2=tf([],[0 ] ) % processens delöverföringsfunktion >> Gp3=tf([],[30 ] ) % processens delöverföringsfunktion >> >> Gr= % regulatorns överföringsfunktion >> Gp= Gp*Gp2*Gp3; % Multiplicerar ihop överföringsfunktionerna hos processen. Definiera kretsöverföringen och rita upp Bodediagram för avläsning av stabilitetsmarginaler >> Gk=Gr*Gp % överföringsfunktion kretsöverföring >> margin(gk) % ritar Bodediagram för kretsöverföringen och visar stabilitetsmarginaler. I figur visas amplitudmarginal ( Gain Margin- Gm) och fasmaginal (Phase Margin Pm). Normalt står även överkorsningsfrekvensen ( ω c ) självsvängningsfrekvensen ( ω π ) inom parentes. 50 Bode Diagram Gm = 3.2 db (at 0.37 rad/sec), Pm = 32.9 deg (at 0.66 rad/sec) Magnitude (db) 0-50 -00-50 0 Phase (deg) -90-80 -270 0-3 0-2 0-0 0 0 0 2 Frequency (rad/sec) Figur 5 3

Jag tror det framgår ganska väl vad som är vad i figuren. Är systemet stabilt? Det skulle vara intressant att veta var reglersystemets poler ligger i vårt fall för en P-regulator K=. För att göra detta så bildar vi först det totala systemets överföringsfunktion. >> Gtot=feedback(Gk,) % konstruerar det totala reglersystemets överföringsfunktion. % Det andra argumentet står för sensorns överföringsfunktion. % Förutsätter negativ återkoppling. Resultatet bör bli nedanstående. Transfer function: 0 ----------------------------- 300 s^3 + 340 s^2 + 4 s + Vi behöver inte rita någon modell i Simulink för att simulera stegsvar. Det kan göras direkt i Matlab också. >> step(gtot, 50) Figur 6 Om ni har gjort rätt så har ni fått samma stegsvar som i figur 4. Nu skulle vi även ta reda på var systemets poler och nollställen går med kommandot pzmap! Vi har bara poler i vårt fall ( 3 stycken). >> pzmap(gtot) 4

0.2 Pole-Zero Map 0.5 0. Imaginary Axis 0.05 0-0.05-0. -0.5-0.2 -.4 -.2 - -0.8-0.6-0.4-0.2 0 Real Axis Är systemet stabilt? Figur 7 Om vill slippa skriva om alla kommandon för varje gång vi vill göra en ändring någonstans kan vi helt helt sätta samman en m-fil. Det är ett litet program där vi samlar alla kommandon och kör alla kommandon direkt. Öppna ett editeringsfönster med: File-> New->M-file Skriv in kommandon där. Se figur 8! Skippa alla kommentarsrader om du vill spara tid. Spara m-filen som något. Jag gav m-filen namnet simulering.m. För att köra programmet kan man trycka på den gröna pilen i editorn eller gå in under Debug-> Run. Alternativt kan man skriva namnet på m-filen i matlabs kommandofönster. För att matlab skall hitta m-filen måste man välja att stå i den katalogen när man kör m-filen. >> simulering Figur 8 5

Resultatet bör bli samma tre figurfönster som vi fick förut när vi körde från kommandofönstret. Fast nu ligger de i en hög på varandra. Se om de stämmer! a) Upprepa nu och simulera reglersystemet i figur 3 med en P-regulator=2! Tag upp Bodediagrammet med stabiltetsmarginaler, stegsvaret och plotta med poler och nollställen. Notera stabiltetsmarginaler, poler, kvarstående fel samt principiella utseendet på stegsvaret! b) Upprepa nu och simulera reglersystemet i figur 3 med en P-regulator=3! Tag upp Bodediagrammet med stabiltetsmarginaler, stegsvaret och plott med poler och nollställen. Notera stabiltetsmarginaler, poler, kvarstående fel samt principiella utseendet på stegsvaret! c) Upprepa nu och simulera reglersystemet i figur 3 med en P-regulator=5! Tag upp Bodediagrammet med stabiltetsmarginaler, stegsvaret och plott med poler och nollställen. Notera stabiltetsmarginaler, poler, kvarstående fel samt principiella utseendet på stegsvaret! d) Kan ni räkna ut för vilket K-värde hos P-regulatorn som systemet blir instabilt? Prova detta genom att köra m-filen igen! Kommandot margin skall användas om vi ritar upp kretsöverföringen för det är bara om denna plottas som vi får fram stabilitetsmarginaler. Om vi bara vill rita ett Bodediagram för en allmän överföringsfunktion så använder vi kommandot bode istället. >> bode(gtot) % Bodediagram utan stabilitetsmarginaler. 6

Figur 9 I figur 9 visas det totala systemets Bodediagram. Ur denna kan man inte avläsa stabilitetsmarginaler men det finns andra saker som bandbredd, resonanstopp och statisk förstärkning som ger viss information. Vi skall kolla ännu ett program (m-fil) inne i matlab uppbyggt av någon med sinne för reglerteknik och GUI:s (Graphical User Interface grafiskt användargränssnitt). Programmet startas genom att skriva sisotool i matlabs kommandofönster. >> sisotool Nu öppnas två nya fönster. Figur 0 7

Figur Gå nu in i fönster som heter Control and Estimnation Tools Manager. Välj Compensator Editor och sätt C=3 ( P-regulator). Vidare så klickar du även på System Data. Där visas vilka överföringsfunktioner vi har i vårt reglersystem i figur. Vår process är en aning enkel. Vi skall byta ut denna mot den som vi använt under laborationen nämligen Gp. F(filter =) och H (sensor =) skall båda vara oförändrade. Figur 2 Markera G (process) och välj Browse för att välja in vår tidigare process Gp som den nya processen. Gå nu tillbaka till fönstret Siso Design for Siso Design Task. Ni kan nu se att denna har förändrats här kan man t ex se. Pol- och nollställen, Bodediagram (kretsöverföring ) och Bodediagram(totala systemet). 8

Figur 3 Ovanstående kurvor har vi sett tidigare när vi kört m-filen simulering för en P-reg=3 som vi skapade tidigare. Det roliga med detta att här vi riktig interaktivitet. Titta noga på figur 3 så ser ni i Bodediagrammet med kretsöverföringen 2 prickar och i den övre vänstra (poler och nollställen) tre kvadrater. Dessa går att ta tag i och då förändras momentant övriga figurer. Prova! Det skulle vara kul att se hur andra signaler i reglersystemet beter sig när vi ändrar i dessa figurer. T ex stegsvaret för det slutna reglersystemet eller styrsignalen. Det kan vi lätt ordna genom att gå in i menyn under Analysis-> Response To Step Command. Nu öppnas ett nytt fönster. Se figur 4! Den innehåller både stegsvaret (blå) och styrsignalen (grön). 9

Figur 4 Tar man nu höger musknapp inuti plottningsytan kan man välja och få fram Characteristics. Här kan man alltså få fram direkt data ifrån stegsvaret. Figur 5 visar hur det kan se ut. Peaktid, översväng, insvängningstid visas i figur 5 nedan! Figur 5 Om ni drar i poler, amplitud- eller faskurvan i figurfönster Siso Design for Siso Design Task så ser ni interaktivt vad som händer. 0