Control Tutorials for MATLAB and Simulink (2024)

Key MATLAB commands used in this tutorial are: tf , rlocus , sgrid , feedback , step

Related Tutorial Links

  • Intro to Root Locus
  • Lead/Lag Control
  • Root Locus Activity
  • Example Animation

Related External Links

Contents

  • Open-loop root locus
  • Lead controller
  • Selecting the gain
  • Plotting the closed-loop response

The open-loop transfer function of the plant for the ball and beam experiment is given below:

(1)Control Tutorials for MATLAB and Simulink (1)

The design criteria for this problem are:

  • Settling time less than 3 seconds
  • Overshoot less than 5%

To see the derivation of the equations for this problem refer to the page.

Control Tutorials for MATLAB and Simulink (2)

Open-loop root locus

The main idea of the root locus design is to estimate the closed-loop response from the open-loop root locus plot. By adding zeroes and/or poles to the original system (adding a compensator), the root locus and thus the closed-loop response will be modified. Let us first view the root locus for the plant in open loop. Create a new m-file with the following MATLAB code in order to model the plant and plot the root locus. Now, run the m-file and you should see the following root locus plot:

m = 0.111;R = 0.015;g = -9.8;L = 1.0;d = 0.03;J = 9.99e-6;s = tf('s');P_ball = -m*g*d/L/(J/R^2+m)/s^2;rlocus(P_ball)

Control Tutorials for MATLAB and Simulink (3)

As you can see the system has two poles at the origin which go off to infinity along the imaginary axes.

The design criteria can also be plotted onto the root locus using the sgrid command. This command generates a grid of constant damping ratio and natural frequency. The damping ratio (Control Tutorials for MATLAB and Simulink (4)) and natural frequency (Control Tutorials for MATLAB and Simulink (5)) were found using the following equations which relate them to our maximum percent overshoot (Control Tutorials for MATLAB and Simulink (6)) and settling time (Control Tutorials for MATLAB and Simulink (7)) requirements:

(2)Control Tutorials for MATLAB and Simulink (8)

(3)Control Tutorials for MATLAB and Simulink (9)

Note, that the equation with Control Tutorials for MATLAB and Simulink (10) is found by assuming the system has settled when the response remains within 2% of its final value. From these equations, the damping ratio and natural frequency were found to be 0.7 and 1.9 respectively.

sgrid(0.70, 1.9)axis([-5 5 -2 2])

Control Tutorials for MATLAB and Simulink (11)

The area between the two dotted diagonal lines represents locations where the percent overshoot is less than 5%. The area outside the curved line represents locations where the settling time is less than 3 seconds. Note that no region of the plot falls within the design criteria shown by these lines. To remedy this and bring the root locus into the left-hand plane for stability we will try adding a lead-compensator to the system.

Lead controller

A first order lead compensator tends to shift the root locus into the left-hand plane. For a more detailed description of lead compensators refer to the page. A lead compensator has the form given below:

(4)Control Tutorials for MATLAB and Simulink (12)

where, the magnitude of Control Tutorials for MATLAB and Simulink (13) is less than the magnitude of Control Tutorials for MATLAB and Simulink (14).

Now, let us add the controller to the plant and view the root locus. We will position the zero near the origin to cancel out one of the poles. The pole of our compensator will be placed to the left of the origin to pull the root locus further into the left-hand plane. Add the following lines of MATLAB code to your m-file. Run your m-file in the MATLAB command window and you should see the following:

zo = 0.01;po = 5;C=tf([1 zo],[1 po]);rlocus(C*P_ball)sgrid(0.70, 1.9)

Control Tutorials for MATLAB and Simulink (15)

Now, the branches of the root locus are within our design criteria.

Selecting the gain

Now that we have moved the root locus into the left-hand plane, we may select a gain that will satisfy our design requirements. We can use the rlocfind command to help us do this. Add the code [k,poles]=rlocfind(C*P_ball) onto the end of your m-file.

Then go to the plot and select a point near those indicated by the cross marks on the plot below.

Control Tutorials for MATLAB and Simulink (16)

After doing this, you should see the following output in the MATLAB command window.

Select a point in the graphics window selected_point = -2.4917 + 1.0109i k = 34.7474 poles = -2.4950 + 1.0109i -2.4950 - 1.0109i -0.0101 

Note that the values returned in your MATLAB command window may not be exactly the same, but should at least have the same order of magnitude. Now, we can plot the response with this gain.

Plotting the closed-loop response

This value of k can be put into the system and the closed-loop response to a step input of 0.25 m can be obtained. Add the following lines to your m-file to perform this analysis. Run your m-file and select a point on the root locus similar to the selected point above. The step response should look like the following.

 sys_cl=feedback(k*C*P_ball,1); t=0:0.01:5; figure step(0.25*sys_cl,t) 

Control Tutorials for MATLAB and Simulink (17)

From this plot we see that when a 0.25-m step input is given to the system both the settling time and percent overshoot design criteria are met.

Note: A design problem does not necessarily have a unique answer. Using this method (or any other) may result in many different compensators. Try running your m-file several more times selecting a different point each time and study the effect this has on the step response. For practice you may also want to go back to the original open-loop root locus and try to find other ways to add zeros and poles to get a better response.


Published with MATLAB® 9.2

Control Tutorials for MATLAB and Simulink (2024)

References

Top Articles
Bfri Forum
Units of Measurement Tutorial - MATLAB & Simulink
9192464227
Jeremy Corbell Twitter
What are Dietary Reference Intakes?
O'reilly's In Monroe Georgia
Apnetv.con
Obituary | Shawn Alexander | Russell Funeral Home, Inc.
Skylar Vox Bra Size
Walthampatch
Cpt 90677 Reimbursem*nt 2023
Alexander Funeral Home Gallatin Obituaries
Tvtv.us Duluth Mn
Willam Belli's Husband
Uktulut Pier Ritual Site
Our History
Decosmo Industrial Auctions
zom 100 mangadex - WebNovel
Orange Pill 44 291
Boscov's Bus Trips
12 Facts About John J. McCloy: The 20th Century’s Most Powerful American?
F45 Training O'fallon Il Photos
48 Oz Equals How Many Quarts
1 Filmy4Wap In
Silky Jet Water Flosser
Cb2 South Coast Plaza
Usa Massage Reviews
Dhs Clio Rd Flint Mi Phone Number
30+ useful Dutch apps for new expats in the Netherlands
Shia Prayer Times Houston
A Grade Ahead Reviews the Book vs. The Movie: Cloudy with a Chance of Meatballs - A Grade Ahead Blog
The Ultimate Guide to Obtaining Bark in Conan Exiles: Tips and Tricks for the Best Results
Pnc Bank Routing Number Cincinnati
Diana Lolalytics
Roto-Rooter Plumbing and Drain Service hiring General Manager in Cincinnati Metropolitan Area | LinkedIn
2016 Honda Accord Belt Diagram
Ishow Speed Dick Leak
Why Gas Prices Are So High (Published 2022)
The Thing About ‘Dateline’
Bella Thorne Bikini Uncensored
Crazy Balls 3D Racing . Online Games . BrightestGames.com
Jason Brewer Leaving Fox 25
Arigreyfr
Amy Zais Obituary
Devotion Showtimes Near Showplace Icon At Valley Fair
Waco.craigslist
Mcoc Black Panther
552 Bus Schedule To Atlantic City
Abigail Cordova Murder
Heat Wave and Summer Temperature Data for Oklahoma City, Oklahoma
Maurices Thanks Crossword Clue
Ihop Deliver
Latest Posts
Article information

Author: Virgilio Hermann JD

Last Updated:

Views: 6106

Rating: 4 / 5 (41 voted)

Reviews: 80% of readers found this page helpful

Author information

Name: Virgilio Hermann JD

Birthday: 1997-12-21

Address: 6946 Schoen Cove, Sipesshire, MO 55944

Phone: +3763365785260

Job: Accounting Engineer

Hobby: Web surfing, Rafting, Dowsing, Stand-up comedy, Ghost hunting, Swimming, Amateur radio

Introduction: My name is Virgilio Hermann JD, I am a fine, gifted, beautiful, encouraging, kind, talented, zealous person who loves writing and wants to share my knowledge and understanding with you.