Simulink Basics Tutorial Starting Simulink Model Files Basic Elements Running Simulations Building Systems Simulink is a graphical extension to MATLAB for modeling and simulation of systems. In Simulink, systems are drawn on screen as block diagrams. Many elements of block diagrams are available, such as transfer functions, summing junctions, etc., as well as virtual input and output devices such as function generators and oscilloscopes. Simulink is integrated with MATLAB and data can be easily transfered between the programs. Simulink is supported on Unix, Macintosh, and Windows environments; and is included in the student version of MATLAB for personal computers 1 STARTING SIMULINK Simulink is started from the MATLAB command prompt >> Simulink Alternatively, you can hit the New Simulink Model button at the top of the MATLAB command window When it starts, Simulink brings up the main Simulink window and a blank, untitled, model window. This is the window into which a new model can be drawn. 2 MODEL FILES In Simulink, a model is a collection of blocks which, in general, represents a system. In addition, to drawing a model into a blank model window, previously saved model files can be loaded either from the File menu or from the MATLAB command prompt. Example: simple.mdl The following model window should appear. 3 BASIC ELEMENTS There are two major classes of items in Simulink: blocks and lines. Blocks are used to generate, modify, combine, output, and display signals. Lines are used to transfer signals from one block to another. Blocks There are several general classes of blocks: • • • • • • Sources: Used to generate various signals Sinks: Used to output or display signals Discrete: Linear, discrete-time system elements (transfer functions, state-space models, etc.) Linear: Linear, continuous-time system elements and connections (summing junctions, gains, etc.) Nonlinear: Nonlinear operators (arbitrary functions, saturation, delay, etc.) Connections: Multiplex, Demultiplex, System Macros, etc. Lines Lines transmit signals in the direction indicated by the arrow. Lines must always transmit signals from the output terminal of one block to the input terminal of another block. One exception to this is a line can tap off of another line, splitting the signal to each of two destination blocks, as shown below 4 Lines can never inject a signal into another line; lines must be combined through the use of a block such as a summing junction. A signal can be either a scalar signal or a vector signal. Simple Example The simple model consists of three blocks: Step, Transfer Fcn, and Scope. The Step is a source block from which a step input signal originates. The Transfer Function linear block. The Transfer Function modifies its input signal and outputs a new signal. The Scope is a sink block used to display a signal much like an oscilloscope. 5 MODIFYING BLOCKS A block can be modified by double-clicking on it. This dialog box contains fields for the numerator and the denominator of the block's transfer function. By entering a vector containing the coefficients of the desired numerator or denominator polynomial, the desired transfer function can be entered. For example, to change the denominator to s2+2s+1, enter the following into the denominator field: [1 2 1] 6 The "step" block can also be double-clicked, bringing up the following dialog box. The default parameters in this dialog box generate a step function occurring at time =1 s, from an initial level of zero to a level of 1. The most complicated of these three blocks is the "Scope" block. Double clicking on this brings up a blank oscilloscope screen. 7 When a simulation is performed, the signal which feeds into the scope will be displayed in this window. Use of the autoscale button, which appears as a pair of binoculars. 8 RUNNING SIMULATIONS To run a simulation, we will work with the following model file: simple2.mdl Before running a simulation of this system, first open the scope window by double-clicking on the scope block. Then, to start the simulation, either select Start from the Simulation menu The simulation should run very quickly and the scope window will appear. 9 Note that the simulation output (shown in yellow) is at a very low level relative to the axes of the scope. To fix this, hit the autoscale button (binoculars) We can change the parameters of the simulation also. In the model window, select Parameters from the Simulation menu. You will see the following dialog box. 10 There are many simulation parameter options; we will only be concerned with the start and stop times, which tell Simulink over what time period to perform the simulation. Change Start time from 0.0 to 0.. Change Stop time from 10.0 to 2.0, which should be only shortly after the system settles. . 11 BUILDING SYSTEMS Learn how to build systems in Simulink using the building blocks in Simulink's Block Libraries. 1. Gather all the necessary blocks from the block libraries. 2. Modify the blocks so they correspond to the blocks in the desired model 3. Connect the blocks with lines to form the complete system. 4. Simulate the complete system to verify that it works. 12 Gathering Blocks Create a new model (New from the File menu or Ctrl-N). Double-click on the Sources icon in the main Simulink window. 13 Drag the the Sum, Gain, and two instances of the Transfer Fcn (drag it two times) and a Sink into your model window 14 Modifying Blocks Follow these steps to properly modify the blocks in your model. • • • • • Modify the Sum block. Modify the Gain block. Change the gain to 2.5. Modify the left-most Transfer Function block. Change the numerator to [1 2] and the denominator to [1 0]. Modify the rightmost Transfer Function block. Leave the numerator [1], but change the denominator to [1 2 4]. Change the name of the first Transfer Function to "PI Controller", and the name of the second Transfer Function block to "Plant". 15 Connecting Blocks with Lines Now that the blocks are properly laid out, connect them together. The line remaining to be drawn is the feedback signal connecting the output of the Plant to the negative input of the Sum block Finally, labels can be placed in the model to identify the signals. To place a label anywhere in your model, double click at the point you want the label to be. 16 To save the model, select Save As in the File menu and type in any desired model name. Simulation Now that the model is complete, you can simulate the model. Select Start from the Simulation menu to run the simulation. Double-click on the Scope block to view its output. 17 Taking Variables from MATLAB In some cases, parameters may be calculated in MATLAB to be used in a Simulink model. If this is the case, it is not necessary to enter the result of the MATLAB calculation directly into Simulink. For example, suppose we calculated the gain in MATLAB in the variable K >> K=2.5 This variable can now be used in the Simulink Gain block. Re-run the simulation and view the output on the Scope. The result should be the same as before. 18 Now, if any calculations are done in MATLAB to change any of the variables used in the Simulink model, the simulation will use the new values the next time it is run. >> K=5 Start the Simulink simulation again, bring up the Scope window 19 Simulink Modeling Tutorial In Simulink, it is very straightforward to represent a physical system or a model. In general, a dynamic system can be constructed from just basic physical laws. We will demonstrate through an example. Train system In this example, we will consider a toy train consisting of an engine and a car. Assuming that the train only travels in one direction, we want to apply control to the train so that it has a smooth start-up and stop, along with a constant-speed ride. The mass of the engine and the car will be represented by M1 and M2, respectively. The two are held together by a spring, which has the stiffness coefficient of k. F represents the force applied by the engine, and the Greek letter, mu (which will also be represented by the letter u), represents the coefficient of rolling friction. 20 Free body diagram and Newton's law The system can be represented by following Free Body Diagrams. From Newton's law, you know that the sum of forces acting on a mass equals the mass times its acceleration. In this case, the forces acting on M1 are the spring, the friction and the force applied by the engine. The forces acting on M2 are the spring and the friction. We will begin to construct the model simply from Sum(forces_on_M1)=M1*x1'' Sum(forces_on_M2)=M1*x2'' Constructing The Model First, we will construct two copies (one for each mass) of the expressions a=x’’=1/M*sum_F. 21 The outputs of these gain blocks are the accelerations of each of the masses. We are interested in both the velocities and the positions of the masses. Since velocity is the integral of acceleration, and position is the integral of velocity, we can generate these signals using integrator blocks. 22 Now, drag two Scopes from the Sinks library into your model and connect them to the outputs of these integrators. Label them "View_x1" and "View_x2". Now we are ready to add in the forces acting on each mass. First, you need to adjust the inputs on each Sum block to represent the proper number. 23 The first force acting on M1 is just the input force, F. The next force acting on M1 is the friction force. This force is equal to: F_friction_1=mu*g*M1*v1 and acts in the negative x1-direction. 24 The last force acting on M1 is the spring force between masses. This is equal to: F_spring = k*(x1-x2) First, we need to generate (x1-x2). Since this summation comes from right to left, we need to flip the block around. Select the bloc by single-clicking on it and select Flip from the Format menu 25 Now, we can apply forces to M2. For the first force, we will use the same spring force we just generated, except that it adds in with positive sign. The last force to add in the the friction on M2. This is done in the exact same manner as the friction on M1, tapping off v2, multiplying by a gain of mu*g*M2 26 Now the model is complete. We simply need to supply the proper input and view the proper output. The input of the system will be the force, F, provided by the engine. We already have placed the function generator at the input. The output of the system will be the velocity of the engine. Running the Model Before running the model, we need to assign numerical values to each of the variables used in the model. Create an new m-file and enter the following commands. M1=1; M2=0.5; k=1; F=1; mu=0.002; g=9.8; Execute your m-file to define these values. Simulink will recognize MATLAB variables for use in the model. Now, we need to give an appropriate input to the engine. Doubleclick on the function generator (F block). Select a square wave 27 with frequency .001Hz and amplitude -1 (positive amplitude steps negative before stepping positive). The last step before running the simulation is to select an appropriate simulation time. To view one cycle of the .001Hz square wave, we should simulate for 1000 seconds. Select Parameters from the Simulation menu Now, run the simulation and open the View_v1 scope 28 Simulink Basics Tutorial - Block Libraries Sources Sinks Discrete Linear Nonlinear Connections Simulink contains a large number of blocks from which models can be built. These blocks are arranged in Block Libraries which are accessed in the main Simulink window. Each icon in the main Simulink window can be double clicked to bring up the corresponding block library. Blocks in each library can then be dragged into a model window to build a model. 29 SOURCES Source Blocks are used to generate signals. Double-click on the Sources icon in the main Simulink window to bring up the Sources window. Notice that all of the source blocks have a single output and no inputs. While parameters in each of these blocks in the library can be modified by double-clicking the block, it is best to not modify the blocks until they have been copied into a model window. 30 Constant The Constant Source Block simply generates a constant signal. The constant output value is displayed in the middle of the block, with a default value of 1. To change the constant output value, double-click on the block in your model window to bring up the following dialog box. Change the constant value field from 1 to some other value, say, 5, and close the dialog box. Your model window will reflect the update by displaying a 5 in the middle of the constant block. 31 Signal Generator The Signal Generator Source Block is a general-purpose source which encompasses some of the other blocks' functions. It generates periodic waveforms such as sine, square, and saw-tooth waves as well as a random signal. By default, the Signal Generator generates a sine wave with an amplitude of 1 and a frequency of 1 Hz. To change this, doubleclick the Signal Generator in your model window to bring up the following dialog box. 32 The Amplitude and Frequency can be changed in this dialog box, as well as the type of waveform. To change the waveform, click on the Waveform field to bring up a list of possible waveforms. Ramp The Ramp Source Block generates a signal which is initially constant and begins to increase (or decrease) at a constant rate at a specified time. The slope, start time, and initial output can be specified. Sine Wave The Sine Wave Source Block generates a sinusoidal signal. The Amplitude and Frequency can be specified, as well as the Phase (unlike the Signal Generator). There is a fourth parameter, the Sample Time, which can be used to force the Sine Wave Source to operate in discrete-time mode (more about Discrete Time systems in Simulink later.) Step As described earlier, the Step Source Block generates a step function. The initial and final values can be specified, as well as the step time. 33 Chirp Signal The Chirp Signal Source Block generates a sinusoidal signal which scans over a range of frequencies. The initial and final frequencies as well as the scan time can be specified. The amplitude is always 1, and the chirp signal repeats itself after each frequency scan. Pulse Generator The Pulse Generator Source Block generates a pulse train of varying duty cycle. The signal switches between 0 and the specified value starting at a particular time. The Period, Duty Cycle, Amplitude, and Start Time can be specified. Repeating Sequence An arbitrary set of points (t,y) can be specified. These points are entered as a vector specifying the time values, and a vector specifying the corresponding output values at those times. The output is linearly interpolated between the specified time values. At the last time value, the output immediately starts over, possibly with a discontinuous transition. Clock The Clock Source Block generates a signal equal to the current time in the simulation. This is useful when the output of a simulation is exported to MATLAB but occurs at uneven time steps. The clock's output reflects the times at which the other signals outputs occur. Digital Clock The Digital Clock Source Block generates a strictly periodic time signal at a specified sampling interval. 34 From File The From File Source Block outputs a signal taken from a specified .mat file. A matrix saved in MATLAB as a .mat file will become a signal where the first row of the matrix specifies the time values. This is similar to the Repeating Sequence Source Block. From Workspace The From Workspace Source Block is identical to the From File Source Block except the values are taken from a variable (or expression) in the MATLAB Workspace. Random Number The Random Number Source Block generates a sequence of random numbers generated with the specified random number seed. Because of the seed, the same sequence can be applied to more than one simulation. Band-Limited White Noise The Band-Limited White Noise Source Block generates a random signal which changes at a specified sample period. The strength of the signal and a random number seed can also be specified. 35 SINKS Sink Blocks are used to display or output signals. Notice that all of the sink blocks have inputs and no outputs. Most have a single input. Scope The Scope Sink Block was described earlier. It is used to display a signal as a function of time. XY Graph The XY Graph Sink Block plots one signal against another. It is useful for phase-plane plots, etc. 36 Display The Display Sink Block is a digital readout of a signal at the current simulation time. To File The To File Sink Block saves a signal to a .mat file in the same way that the From File Source Block reads from a file. The sampling time can be specified, but is not necessary. To Workspace The To Workspace Sink Block stores a signal in a specified workspace variable. Unlike the To File Sink Block, the time is not saved in the variable, and must be stored separately. Stop Simulation This is a special control block which is triggered to stop the current simulation when its input is non-zero. 37 DISCRETE Discrete Blocks are elements of discrete time dynamic systems. Double-click on the Discrete icon in the main Simulink window to bring up the Discrete window. In order for these block to interact with continuous time blocks (sources and sinks, for example) the sample time can be specified in all of the Discrete Blocks. Unit Delay The Unit Delay's output is equal to the input delayed by one sample time. 38 Discrete-Time Integrator This is the discrete time approximation of a continuous-time integrator. The approximation method can be specified as well as the initial condition and saturation limits. Zero-Order Hold Outputs a stepwise-constant version of the input signal with a specified sampling period. First-Order Hold Outputs a piecewise-linear version of the input signal with a specified sampling period. Discrete State-Space This is a discrete-time dynamic system in state-space form. A, B, C, and D matrices can be specified, as well as initial conditions. Discrete Filter This is a discrete-time filter in rational function form. Vectors containing coefficients of the polynomials in z^-1 are specified. Discrete Transfer Fcn This is the standard form of a SISO LTI discrete time system. The transfer function polynomials are represented as coefficient vectors in terms of z. Discrete Zero-Pole A discrete-time transfer function can be represented as list of zplane poles and zeros. The gain can also be specified. 39 LINEAR Linear Blocks are elements of linear continuous-time dynamic systems Gain This is a scalar or vector gain. The specified gain multiplies the input. The output is either a scalar or vector signal following normal vector-scalar multiplication rules. Sum The Sum Block adds (or subtracts) two (or more) signals and outputs their sum (or difference). The two inputs must either all be scalars, or all be vectors of the same dimension. The output is the same dimension as the inputs. 40 By default, the Sum block adds two signals. The list of signs field represents both the number of inputs and whether to add or subtract them. To make the Sum block add two signals and subtract a third, change the list of signs to the following: ++Each element in the list corresponds to one of the signals. Close the dialog box. The Sum block in your model window should now have three inputs, one of which has a minus sign as shown below. Integrator The output of the Integrator is the integral of the input. An initial condition can be specified, as well as saturation limits. This block is very useful for modeling systems. Transfer Function Numerator and denominator polynomials can be specified to create a standard SISO LTI system transfer function. 41 State Space A, B, C, and D matrices can be specified to create a LTI state space system. Inputs and outputs may be vector signals depending on the sizes of the matrices. Zero-Pole Vector lists of zeros and poles can be specified to create a transfer function. DC gain is also specified. Derivative The output is equal to the derivative of the input. Dot Product The output is equal to the dot product of two vector signals. Matrix Gain The output is equal to the input times a specified constant matrix. The size of the input and output vector signals must match the size of the matrix. Slider Gain This multiplies the input by a scalar constant which is specified by moving a slider on the screen as shown below. The limits of the slider can be specified. 42 NONLINEAR Nonlinear Blocks are elements of nonlinear continuous-time dynamic systems. Most of these have special-purpose applications and will not be used in the tutorials. Only the most relevant Nonlinear blocks will be discussed here. Double-click on the Nonlinear icon in the main Simulink window to bring up the Nonlinear window. 43 Elementary Math The output of this block is a basic mathematical function applied to the input. Copy this block into your model window and double click on it. The resulting dialog box has one field, which when clicked on, give the following menu of functions. The desired function can be selected from the list, and the choice will be displayed in the block in your model window. Product The output is equal to the product of the inputs. The number of inputs can be specified. Fcn Arbitrary MATLAB expressions can be represented by this block. 44 CONNECTIONS Connection Blocks are used to organize and combine signals and systems. These also have special purpose applications, and only some of these will be described here. Double-click on the Connections icon in the main Simulink window to bring up the Connections window. 45 Mux, Demux The Mux (Multiplexer) block is used to combine two or more scalar signals into a single vector signal. Similarly, a Demux (Demultiplexer) block breaks a vector signal into scalar signal components. The number of vector components must be specified in each case. Subsystem, In, Out The Subsystem block is used as a system "macro", where one Subsystem block can be used to represent an entire set of blocks. When double-clicked, the subsystem block brings up a blank model window. Note that the Subsystem block has no inputs or outputs. For each input a Subsystem has, an In block is used. For each output a Subsystem has, an Out block is used. For more information on Subsystems and In and Out blocks, see the Interaction with MATLAB tutorial page. 46 Simulink Basics Tutorial - Interaction With MATLAB Defining Block Parameters Using MATLAB Variables Exchanging Signals With MATLAB Extracting Models From Simulink Into MATLAB We will examine three of the ways in which Simulink can interact with MATLAB. • • • Block parameters can be defined from MATLAB variab. Signals can be exchanged between Simulink and MATLAB. Entire systems can be extracted from Simulink into MATLAB. 47 BLOCK PARAMETERS FROM MATLAB VARIABLES Often, a controller will be designed in MATLAB and verified in a Simulink model. Normally, numerical parameters such as gains and controller transfer functions are entered into simulink manually by entering the numbers in the block dialog boxes. Rather than enter numbers directly, it is possible to use MATLAB variables in Simulink block dialog boxes. In this case, the complete controller transfer function is: s+2 2.5 ----s Suppose this transfer function were generated by some computation in MATLAB. In this case, there would most likely be three variables, the numerator polynomial, the denominator polynomial, and the gain. Enter the following commands in MATLAB to generate these variables. K=2.5 num=[1 2] den=[1 0] 48 These variables can now be used in the blocks in Simulink. Double-click on the PI Controller block. Enter num in the Numerator field and den into the Denominator field. 49 You can simulate the model with the MATLAB variable parameters. Select Start from the Simulation menu to run the simulation. Double-click on the Scope block to view its output. Hit the autoscale button (binoculars) and you should see the following. 50 51 EXCHANGING SIGNALS WITH MATLAB VARIABLES Sometimes, we would like to use the results of a Simulink simulation in the MATLAB command window for further calculations and plotting. Less often, we would like to generate signals in MATLAB which we then use as inputs in a Simulink model. These tasks are accomplished through the use of the To Workspace Sink Block and the From Workspace Source Block. We will only transfer signals from Simulink to MATLAB. Doing the reverse is a very similar process. The To Workspace Sink Block saves a signal as a vector in the MATLAB Workspace. Suppose we would like to use both the output signal and the control signal for calculations in MATLAB. We will save these two variab as well as a time signal from our Simulink model. First, you need to generate a time signal 52 Before connecting these blocks to the rest of your system, first you will name the variable to which they output. 53 The To Workspace block near the Plant block will output the control signal to the MATLAB variable u. Edit this block to output to the variable u. The last To Workspace block will output the output signal to the MATLAB variable y. 54 You can now examine the outputted variab in the MATLAB window with plot(t,u,t,y); 55 EXTRACTING MODELS FROM SIMULINK INTO MATLAB Sometimes, we may build a complicated model in simulink and would like to derive either a transfer function or a state space model of the entire system. In order to do this, you first need to define the input and output signals of the model to be extracted. These virtual signals can be any signal in a model, for example, if we can generate an input-to-output transfer function or a disturbance-to-error transfer function. These signals are defined using the In and Out Connection Blocks. Once the input/output model is defined, the Simulink model must be saved to a .mdl file. You will be extracting a closed-loop reference-to-output model. Therefore, The virtual input will be put in place of the step input to the system. First, delete the Step block and connect an In block from the Connections window to your model window in place of the Step block you just deleted. 56 The virtual output does not need to replace an existing block - the signal can be tapped off an existing line. Drag an Out block from the Connections window and place it just above the Scope block. Now, save this model under a new name. Call it mymodel.mdl. At the MATLAB prompt, LINMOD obtains linear models from systems of ord. diff. equations (ODEs). >> [A,B,C,D]=linmod('mymodel') You should see the following output. 57 A = -2 1 0 -9 0 -5 2 0 0 1 0 B = 5 0 5 C = 0 D = 0 >>step(A,B,C,D) You should see the following plot which is similar to the previous Simulink Scope output. 58