You are on page 1of 31

Universidad Pontificia Comillas

E.T.S.I – I.C.A.I
Departamento de Electrónica y Automática

Manual de referencia de

MATLAB & SIMULINK

Febrero 2000

Adolfo Anta Martínez


Juan Luis Zamora Macho
Ramón Rodríguez Pecharromán
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Tabla de Contenidos

1. INTRODUCCIÓN................................................................................................................... 3

2. FUNCIONES MATEMÁTICAS COMUNES .......................................................................... 4

3. CARACTERÍSTICAS DE LA VENTANA DE COMANDOS ................................................. 6

3.1. CÓMO UTILIZAR EL WORKSPACE ....................................................................................... 6


3.2. FORMATOS DE NÚMEROS ................................................................................................. 6
3.3. GESTIÓN DE DIRECTORIOS ............................................................................................... 6

4. M-FILES ................................................................................................................................ 7

5. OPERACIONES CON VECTORES ...................................................................................... 9

6. REPRESENTACIONES GRÁFICAS .................................................................................. 11

6.1 LA FUNCIÓN PLOT .............................................................................................................. 11


6.2 ESTILOS DE LÍNEA, MARCAS Y COLORES .............................................................................. 12
6.3 FIJAR REJILLAS, EJES, Y ETIQUETAS.................................................................................... 13

7. TOOLBOX DE CONTROL ................................................................................................. 16

7.1 REPRESENTACIÓN DE UN SISTEMA ...................................................................................... 16


7.2 FUNCIONES ESPECÍFICAS ................................................................................................... 17
7.3 LTIVIEW .......................................................................................................................... 20

8. AYUDA................................................................................................................................ 22

8.1. EL COMANDO HELP ........................................................................................................ 22


8.2. LA VENTANA DE AYUDA................................................................................................... 22

9. SIMULINK ........................................................................................................................... 23

9.1 INTRODUCCIÓN .................................................................................................................. 23


9.2 CONSTRUCCIÓN DEL MODELO............................................................................................. 24
9.3 SIMULACIÓN ...................................................................................................................... 27
9.4 MODELADO DE UN SISTEMA FÍSICO ...................................................................................... 28

2
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

1. Introducción
MATLAB es una aplicación destinada a cálculos matemáticos, si bien dispone de
ciertas funciones destinadas a temas más específicos, como por ejemplo la ToolBox
de control, que facilita el estudio de sistemas dinámicos y su regulación.
Además, existe un complemento de MATLAB llamado SIMULINK, que nos permite un
enfoque más gráfico de los sistemas de control.
Al ejecutar MATLAB, aparecerá una ventana en blanco, llamada ventana de
comandos. La forma de trabajar con MATLAB es como con cualquier calculadora:
» 4*2 [ pulsamos enter]
ans =
8

A su vez, podemos usar variables para realizar nuestros cálculos:

» precio = 17;
» iva =0.16;
» precio_total =17 * (1+iva)
precio_total =
19.7200

Acabamos de crear tres variables, cuyo valor se guardará en memoria. En las dos
primeras sentencias se incluye un punto y coma al final, con lo que el resultado no
aparecerá por pantalla. El nombre que elijamos para nuestras variables tiene algunas
restricciones: no pueden tener un espacio intermedio, se distinguen mayúsculas de
minúsculas, y deben empezar por una letra.
Si queremos ver las variables que tenemos definidas, teclearemos el comando who:
» who
Your variables are:
iva precio precio_total

Por supuesto, se puede sobreescribir el nombre de una variable:


» iva =0.13;
(el programa no nos avisará de que esa variable ya existe) .

Para borrar todas las variables, existe el comando clear: tecleando clear iva borraría
esta variable , pero si escribimos sólo clear, borrará todo lo que hay en memoria; por
desgracia, una vez eliminadas, las variables no se pueden recuperar.
Podemos recuperar cualquier instrucción escrita previamente pulsando la tecla del
cursor ­. Para detener la ejecución de cualquier instrucción, hay que pulsar la
combinación de teclas Ctrl+C.

3
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

2. Funciones matemáticas comunes


MATLAB incluye ciertas funciones que nos permiten realizar cálculos más
complejos que sumar y restar. Para usar estas funciones, se procede de igual manera
que en una calculadora programable; por ejemplo, para realizar una operación que
incluya una raíz cuadrada escribimos:

» x = 3 - sqrt (5/6) * 2
x=
1.1743

Una lista breve de las funciones de MATLAB sería:

FUNCIONES HABITUALES

abs(x) Valor absoluto de x. Si x es un número complejo, abs(x) nos da


su módulo
acos(x)1 arco coseno de x
asin (x) arco seno de x
atan (x) arco tangente de x. Devuelve un ángulo entre -90º y 90º
atan2(x,y) arco tangente de x entre y. Devuelve un ángulo entre 0º y 360º
cos (x) coseno de x
sin (x) seno de x
tan (x) tangente de x
exp (x) exponencial ex
log(x) logaritmo neperiano de x
log10 (x) logaritmo en base 10 de x
rem(x,y) resto de la división x / y
unwrap(x) sitúa el ángulo x entre pi y -pi
roots(x) halla las raíces del polinomio x
fzero('f(x)',n) encuentra la solución de la ecuación f(x)=0; n es el valor por
donde empieza a iterar para hallar la solución.
(ej.- f(x)= 'x^2+x+3' )
sqrt(x) raíz cuadrada de x
angle (x) ángulo de x
real(x) parte real de x
imag(x) parte imaginaria de x

1
MATLAB trabaja únicamente en radianes.

4
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Es recomendable trabajar con atan2 en vez de atan, pues si la parte real del número
complejo es negativa, el ángulo quedará en el segundo o tercer cuadrante. Por
ejemplo:

» 180/pi*atan(-2/3)
ans =
-33.6901
» 180/pi*atan(2/-3)
ans =
-33.6901
» 180/pi*atan2(-2,3)
ans =
-33.6901
» 180/pi*atan2(2,-3)
ans =
146.3099

Para la función atan los números complejos -2+3j y 2-3j tienen la misma fase; atan2,
sin embargo, nos da el ángulo correcto. Se ha multiplicado por 180/pi para obtener el
resultado en grados2.
Para definir un número complejo, se puede usar i o j como unidad imaginaria
indistintamente:

» c1=-1+2j
c1 =
-1.0000 + 2.0000i
» c1=-1+2i
c1 =
-1.0000 + 2.0000i

2
La constante pi viene definida por defecto en MATLAB

5
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

3. Características de la ventana de comandos

3.1. Cómo utilizar el Workspace


Todas las variables que hemos definido se guardan en el Workspace, que no es
más que el espacio de memoria que utiliza MATLAB.
Aparte de crear y borrar variables, resulta útil guardar sesiones de trabajo, es decir,
todas las instrucciones que hemos tecleado en la ventana de instrucciones. Para ello,
al inicio de la sesión tecleamos diary <nombre del fichero>. Podemos elegir el tipo de
archivo, si bien es recomendable que éste sea de texto (por ejemplo, diary
c:\regulación\resumen.txt). Para que deje de grabar la sesión teclearíamos diary off.
También podemos guardar únicamente el valor de algunas variables:
» save c:\regulación\datos x y
Aquí no es necesario añadir la extensión, y MATLAB creará el fichero con extensión
.mat. Las variables x e y han de estar previamente definidas.
Para recuperar las variables guardadas teclearemos:
» load datos

3.2. Formatos de números


Se habrá observado que por defecto todos los números nos aparecen con cuatro
decimales. Se puede cambiar el formato de salida seleccionando el menú
File\Preferences. Cabe destacar que, con el formato que aparece por defecto, algunos
números pueden aparecer por pantalla como 0.0000, aunque realmente no son 0 (sino
3.5·10-7, por ejemplo).

3.3. Gestión de directorios


Por defecto, al arrancar MATLAB empezamos en el directorio matlab\bin,
mientras que nuestros ficheros (M-files o modelos de SIMULINK) suelen estar en otras
carpetas.
Para "movernos" en MATLAB, usaremos los comandos típicos de MS-DOS: cd
para acceder a un directorio, dir para ver el contenido de un directorio, cd.. para salir
de una directorio.

6
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

4. M-files
Cuando realizamos cálculos simples, es habitual escribir las instrucciones en la
ventana de comandos. Sin embargo, cuando se van a realizar una serie de
operaciones más complicadas y de forma repetitiva, se utilizan los llamados M-Files;
son ficheros de texto donde tecleamos las instrucciones de MATLAB. Para crear un
nuevo archivo M, hacemos clic en File\New\M-File; nos aparecerá una ventana en
blanco para editar el archivo. Por ejemplo:

% Mi primer programa en MATLAB3


comp1=-2+3i;
comp2=-10+5i;
comp=comp1+comp2;
modulo=abs(comp)
fase=unwrap(180/pi*phase(comp))

Una vez guardado el archivo (con el nombre trabajo.m, por ejemplo), nos bastará
teclear su nombre en MATLAB, y se ejecutará directamente:

» trabajo
modulo =
14.4222
fase =
140.0267

Supongamos que queremos que este programa sirva no sólo para los complejos
comp1 y comp2. Para ello, bastará con borrar las dos primeras líneas del programa
anterior. Ahora tendremos que definir antes el valor de comp1 y comp2 (si no,
MATLAB nos dará un error diciendo que las variables comp1 y comp2 no están
definidas):

» comp1=-3+2i;
» comp2=-10+j;
» trabajo
modulo =
13.3417
fase =
160.7222

3
El símbolo % indica que esa línea es comentario.

7
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

También podíamos hacer que el programa pidiese los números complejos al usuario
(pues éste no tiene por qué saber qué es comp1 y comp2):

comp1=input('Introduzca el primer número complejo -> ');


comp2=input('Introduzca el segundo número complejo -> ');
comp=comp1+comp2;
modulo=abs(comp)
fase=unwrap(180/pi*phase(comp))

8
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

5. Operaciones con vectores


Hasta ahora, todas las variables utilizadas eran escalares. Por supuesto, también se
pueden definir vectores. Por ejemplo, queremos hallar el valor de seno (x) para
0 < x < p. Como es imposible hallar todos los valores (hay infinitos puntos), debemos
definir una serie de valores de x. Si tomamos 11 puntos, definiremos x de la forma:

» x=[0 0.1*pi 0.2*pi 0.3*pi 0.4*pi 0.5*pi 0.6*pi 0.7*pi 0.8*pi 0.9*pi pi]
x=
Columns 1 through 7
0 0.3142 0.6283 0.9425 1.2566 1.5708 1.8850
Columns 8 through 11
2.1991 2.5133 2.8274 3.1416

Tal como hemos visto, para crear un vector fila es necesario escribir entre corchetes
los elementos, separados por un espacio o una coma
Si ahora escribimos sin (x), hallaremos el seno de todos los valores de x:

» y=sin(x)
y=
Columns 1 through 7
0 0.3090 0.5878 0.8090 0.9511 1.0000 0.9511
Columns 8 through 11
0.8090 0.5878 0.3090 0.0000

Para manejar un único elemento del vector, por ejemplo seno(0.5*pi), nos referiremos
a él como el elemento 6 del vector y:

» y(6)
ans =
1

Si queremos utilizar los 5 primeros elementos, escribiremos y(1:5), y para tomar del
elemento 7 al último teclearemos y(7:end)
En caso de querer representar la función seno(x), necesitaríamos bastantes más de 11
elementos para obtener una gráfica aceptable. Escribir 1000 elementos resultaría
bastante tedioso. Como era de suponer, existe una forma “automática” de crear un
vector. La instrucción es: x= (valor_inicial:incremento:valor_final). Por ejemplo:

X=(0:0.01:pi); %Esta instrucción nos crea un vector x con valor inicial x, valor
%final pi, y la diferencia entre elementos consecutivos es 0.01*pi

9
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Es muy recomendable escribir el "; " al final de la sentencia, pues si no aparecerán


cada uno de los elementos del vector por pantalla: 0, 0.01pi, 0.02pi , y así hasta pi.
Las diferentes formas de crear un vector aparecen resumidas en la siguiente tabla:

Construcciones básicas de vectores


X = [2 2*pi sqrt(2) 2-3j] Crea un vector con los elementos espeficados
X = primero : ultimo Crea un vector empezando en primero,
incrementando una unidad en cada elemento,
acabando en el elemento ultimo
X=primero:incremento:ultimo En este caso, el incremento no es 1 sino que es
fijado por nosotros
X=linspace(primero, ultimo,n) Crea un vector empezando en primero, acabando
en ultimo, con n elementos
X=logspace(primero, ultimo,n) Crea un vector logarítmico

De igual manera, se pueden crear matrices, escribiendo un "; " para indicar que es una
fila distinta:
» x= [ 2 3 ; 2 5 ]

x=
2 3
2 5

10
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

6. Representaciones gráficas

6.1 La función plot


Para representar gráficos en dos dimensiones, es habitual utilizar el comando
plot(eje x, eje y). Por ejemplo, si quisiésemos representar la función seno:

» x = (0:0.01:2*pi);
» y = sin(x);
» plot (x,y)

Debería aparecernos una ventana del tipo Figure:

Fig 1. Representacion gráfica de funciones con el comando plot

Esta gráfica se puede ampliar, reducir , cambiar su color y copiar para utilizarla en otro
documento.
Si ya teníamos abierta una ventana Figure, al usar plot, desaparecerá la gráfica
anterior sin previo aviso. Para evitarlo, añadiremos una nueva ventana tecleando
figure en MATLAB. Es posible dibujar más de una gráfica en una ventana, escribiendo
plot(eje x1, eje y1, eje x2, eje y2,...); por ejemplo:

11
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

» z = cos(x);
» plot(x,y,x,z)

También podemos dividir la ventana en varias partes con el comando subplot (m,n,i).
La ventana Figure se dividirá en una matriz de m por n pequeñas ventanas, y se
seleccionará la ventana i-ésima. Por ejemplo:

subplot(2,1,1); %La ventana Figure se dividirá en dos; selecionamos la primera


plot(x,y) %Representamos y=sin(x)
subplot(2,1,2); %Ahora selecionamos la segunda
plot(x,z) %Representamos z=cos(x)

0.5

-0.5

-1
0 1 2 3 4 5 6 7

0.5

-0.5

-1
0 1 2 3 4 5 6 7

Fig 2. Representación de varias gráficas con subplot

12
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

6.2 Estilos de línea, marcas y colores


Es posible modificar el color y estilo de las gráficas. Para ello, existen ciertos
parámetros que admite la función plot, y han de introducirse como un tercer
argumento, después de cada par de variables.

Símbolo Color Símbolo Marca Símbolo Estilo de línea


b Azul . Puntos - línea continua
g Verde O Círculos : línea punteada
r Rojo x cruces -. puntos y rayas
c Cyan + más -- discontinua
m Magenta * estrellas
y Amarillo s cuadrados
k Negro d diamantes
w Blanco p pentagramas

Por ejemplo:

» plot( x, y, 'rx', x, z, 'o--')

Fig 3. Estilos de línea y colores con la función plot

13
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

6.3 Fijar rejillas, ejes, y etiquetas


– Para fijar una cuadrícula en la ventana Figure, basta con teclear grid on. Para
quitarla, escribimos grid off.
– Podemos escribir los nombres de los ejes y de la gráfica:
» title('Representación de las funciones seno y coseno’'), xlabel ('variable
independiente'), ylabel ('variables dependientes')
– Podemos escribir en el gráfico con la función gtext:
» gtext('cos(x)')
Al pulsar enter nos aparecerá la ventana Figure; con el ratón podemos decidir
dónde situar el texto
– Existe también el comando legend, cuya función es similar a la de gtext:
» legend (‘variable Y’, ‘variable Z’)
El cuadro de la leyenda se puede situar donde queramos, arrastrandolo con el
ratón.
– También se puede cambiar los ejes, con el comando axis:
La estructura a escribir es: axis ([xmin xmax ymin ymax])
» axis([0 2*pi -1.5 1.5])
Para volver al autoescalado, teclearemos axis auto. Otra forma de ampliar o
reducir las gráficas es usando la función zoom. Los comandos zoom y legend no
pueden estar activos a la vez, pues los dos responden al clic del ratón.
– Se puede tomar valores de una gráfica con la instrucción ginput. Una vez
tecleado ginput, nos aparecerá la ventana Figure, y con el ratón haremos clic en
el punto que queramos conocer. Después pulsaremos enter y el valor de las
coordenadas del punto aparecerán en la ventana de comandos de MATLAB.

Después de todas estas operaciones, la gráfica resultante es:

14
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Representación de las funciones seno y coseno


1.5

s 0.5 sen(x)
et cos(x)
n
ei
d
n
e
p 0
e
d
s
el
b -0.5
ai
r
a
v
-1 variable Z
variable Y

-1.5
0 1 2 3 4 5 6
variable independiente

Fig 4. Edición de figuras en MATLAB

15
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

7. Toolbox de control 4

7.1 Representación de un sistema


El primer problema que se nos plantea es la definición de un sistema. Los
sistemas se suelen expresar en forma de función de transferencia. Ésta se puede
expresar como cociente de polinomios, con la instrucción tf : escribiremos entre
corchetes los coeficientes de numerador y denominador (en sentido descendente de
las potencias de la variable s).

» planta = tf ( [ 1 1] , [3 2 5] );
1+ S
nos definiría F ( s) = 2
3× S + 2× S + 5
De esta representación, podemos quedarnos únicamente con el numerador y/o
denominador:
» [num,den] = tfdata (planta , ' v ' )5
num = 0 1 1
den =
3 2 5

u obtener los polos y ceros del sistema:

» [z,p,k] = tf2zp (num,den);


z=
-1
p=
-0.3333 + 1.2472i
-0.3333 - 1.2472i
k=
0.3333

, donde k no es la ganancia estática, sino la que se obtiene al expresar la función de


transferencia en forma de polos y ceros.
También podemos obtener la descomposición en fracciones simples:

» [r, p, k] = residue (num,den)


r=
0.1667 - 0.0891i
0.1667 + 0.0891i

4
Teclear ctrldemo para ver una demostración de las posibilidades que ofrece esta Toolbox
5
El argumento 'v' se incluye para obtener numerador y denominador en forma de vectores

16
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

p=
-0.3333 + 1.2472i
-0.3333 - 1.2472i
k=
[]

El coeficiente k representa el término independiente, que valdrá 0 siempre que el


orden del numerador sea inferior al del denominador.
Es decir, F(s) también se puede expresar como:

0.1667 - j 0.0891 0.1667 + j 0.0891


F ( s) = +
S + 0.3333 - j 1.2472 S + 0.3333 + j 1.2472

7.2 Funciones específicas


Existen diversos comandos en MATLAB para dibujar gráficos de respuesta en
frecuencia:
» bode (planta) % Diagrama de Bode
» pause
» nichols (planta) % Diagrama de Black
» pause
» nyquist (planta) % Diagrama de Nyquist desde w = -¥ hasta w = +¥

Si no incluyesemos la instrucción pause, nos aparecerá únicamente la última gráfica


(el diagrama de nyquist en nuestro ejemplo); de esta manera, nos mostrará el primer
diagrama, y no pasará al siguiente hasta pulsar cualquier tecla.
Si queremos dibujar un diagrama para unas pulsaciones determinadas, es necesario
definirse previamente el vector de pulsaciones w:

» w = logspace (-2, 3, 1001); % Creamos vector w, con valor inicial en 10-2, valor
% final = 103, con 1001 puntos
» bode (planta,w)

Podemos hallar también los márgenes de ganancia y/o fase y pulsaciones asociadas:

» [ganancia, fase] =bode (planta);


» [Mg,Mf,wu,wo]=margin (ganancia,fase,w)
Mg =
7.3343

17
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Mf =
Inf
wu =
1.8258
wo =
NaN

En este caso, no tenemos margen de fase, y por tanto no existe la pulsación de cruce
(el término NaN significa Not-A-Number).
Existen también funciones para dibujar el lugar de las raíces:

» rlocus(planta)

1.5

0.5

si
x 0
A
g
a
mI
-0.5

-1

-1.5
-4 -3 -2 -1 0 1
Real Axis

Fig 5. Lugar de las raíces de la función de transferencia "planta"

Con este gráfico, es posible diseñar para obtener unos polos determinados. Para
obtener mayor precisión, es conveniente dibujar una rejilla radial:

» zeta=0:0.1:1; % Definimos x y wn
» wn=1:10;
» sgrid(zeta,wn) % Nos muestra rectas de pendiente zeta y
% circunferencias de radio wn

» zoom

18
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Y ahora hallamos la ganancia necesaria para obtener los polos

» [gan,polos]=rlocfind(planta) % Aparece un cursor en la ventana del


% lugar de las raíces
Select a point in the graphics window
selected_point =
-1.0554 + 1.4078i
gan =
4.3339
polos =
-1.0557 + 1.4131i
-1.0557 - 1.4131i

Otras funciones útiles de esta Toolbox son:

dcgain(sistema) Halla la ganancia estática del sistema


[num,den]=pade(T, n) Devuelve el numerador y denominador de una
aproximación de Pade de e-TS, de orden n
minreal(sistema) Simplifica la función de transferencia de sistema

Para empezar a simular con nuestra función de transferencia, existen numerosas


funciones en MATLAB(step, impulse), si bien lo más sencillo es utilizar SIMULINK o
LTIVIEW.

19
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

7.3 LTIVIEW
Todo lo que hemos visto hasta ahora se puede hacer con un único comando de
forma más intuitiva. Para ello, tecleamos ltiview. Nos aparecerá la siguiente pantalla:

Funciones de Fig 6. Pantalla del LTIVIEW


transferencia Tipo de gráfica

En el recuadro Workspace nos aparecen todas las funciones de transferencia


que hemos definido. Para seleccionar una de ellas, hacemos doble clic. En Plot Type,
podemos elegir el tipo de gráfica: ante un escalón, diagrama de Bode, Nyquist, lugar
de las raíces, etc; además, al seleccionar uno de ellos, nos aparecerá en Plot Options
varias posibilidades; por ejemplo, para un escalón, nos muestra el tiempo de
establecimiento, pico ,etc.; y para cualquier diagrama de respuesta en frecuencia,
podemos ver el margen de fase y ganancia de nuestra planta.

20
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Al seleccionar una de estas opciones, nos aparecerá un punto en la gráfica; para ver
cuál es el valor en concreto, es necesario mantener pulsado el ratón en ese punto.

Fig 7. Análisis de sistemas con LTIVIEW

21
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

8. Ayuda
Existen demasiados comandos en MATLAB para poder recordarlos. Para
facilitarnos la labor, se ha creado un archivo de ayuda al cual podemos recurrir en todo
momento.

8.1. El comando help


Para recurrir a la ayuda, basta con teclear help nombre_de_función. Si escribimos help
a secas, nos aparecerá una lista de categorías de las funciones disponibles. Por
ejemplo:

» help sqrt
SQRT Square root.
SQRT(X) is the square root of the elements of X. Complex
results are produced if X is not positive.
See also SQRTM

El comando help nos muestra una pequeña descripción de la función, y también una
serie de comandos relacionados (en este caso sqrtm, que nos permite hacer raíces
cuadradas de matrices).
Aunque en la ayuda aparezca la función en mayúsculas, al usarla hemos de escribirla
en minúscula (pues SQRT daría error).
Si no conocemos en concreto el nombre de la función, podemos usar el comando
lookfor:
»lookfor complex
nos mostrará todas las funciones relacionadas con números complejos.
También es útil el comando demo , que nos mostrará una pantalla con demostraciones
de todas las posibilidades que ofrece MATLAB.

8.2. La ventana de ayuda


Existe una ventana específica para la ayuda de MATLAB. Para que aparezca,
escribimos helpwin o hacemos clic en el icono , en la barra de herramientas.
La ventana contiene un listado de todas las categorías de MATLAB. Haciendo clic en
cualquiera de ellas, pasaremos a una pantalla donde aparecen todas las funciones de
esa categoría. El botón Tips nos describe brevemente cómo usar la ayuda.

22
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

9. Simulink

9.1 Introducción
Simulink es una extensión de MATLAB para la simulación de sistemas dinámicos.
Al ser un entorno gráfico, resulta bastante sencillo de emplear. Para ejecutar Simulink,
podemos teclear simulink desde MATLAB, o bien hacer clic en el icono , en la barra
de herramientas de MATLAB.
Nos aparecerán dos ventanas: una con las librerías de Simulink, y otra en blanco
donde construiremos nuestro nuevo modelo.

Fig 8. Librerías de Simulink

En cada uno de los grupos que aparecen en la fig. 3, estarán los bloques necesarios
para simular nuestro sistema de control. Por ejemplo, haciendo doble clic en Linear
aparecerá la siguiente ventana:

23
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Fig 9. Contenido de la librería Linear

9.2. Construcción del modelo

Supongamos que se tiene el siguiente sistema de control:

ref Salida
10 S +1
_ S + 3·S + 5

Fig 10. Diagrama de bloques del sistema de control

24
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Para construirlo en Simulink, seguiremos los siguientes pasos:


En el grupo Linear, elegimos el bloque Sum, y lo arrastramos hasta nuestra ventana
vacía.
Del mismo grupo, elegimos Transfer Fcn y Gain.
Para introducir los valores que tendrán los bloques, hacemos doble clic en cada uno
de ellos. Nos aparecerá el cuadro de diálogo correspondiente:

Fig 11. Introducción de valores para cada bloque

Se hará de igual manera para la constante (Gain) y el punto de suma (Sum), en el que
pondremos +-
Cada bloque tiene en sus extremos una o varias flechas. Al situarnos con el ratón en
esas flechas, el puntero pasa a ser una cruz. Para conectar los bloques, arrastramos
hasta la flecha del siguiente bloque.
Ahora necesitamos poner la referencia. Para ello, hacemos doble clic en el grupo
Sources, y elegimos Step. Lo arrastramos hasta la ventana donde tenemos el modelo.
Para cambiar los valores del escalón, y el tiempo en que éste se produce, hacemos
doble clic en el bloque. Por defecto, el escalón es unitario y se da en t=1.
Por último, para ver la salida (o cualquier otra señal) hay varias posibilidades. Las dos
más utilizadas son los bloques Scope y To Workspace (en el grupo Sinks).
El bloque Scope nos permite ver el comportamiento de una señal mientras se simula.
Por el contrario, To Workspace guarda la señal en memoria, para poder dibujarla
después de la simulación (con el comando plot) o guardarla en un fichero de datos
.mat.

25
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

El modelo en Simulink quedará como en la figura siguiente:

Fig 12. Modelo de Simulink del sistema de control

La orientación por defecto de los bloques es "a derechas" (la entrada está en la
izquierda, la salida en la derecha). Esto se puede cambiar seleccionando el bloque y
pulsando Ctrl+R o en el menú Format/Rotate Block.

Después de construir el modelo, resulta conveniente guardarlo antes de empezar a


simular (Menú File/Save as..). Los modelos de Simulink se guardan con extensión .mdl

26
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

9.3. Simulación
Para simular el sistema ya construido, elegimos Start del menú Simulation. En
este menú también hay otras opciones; la única que usaremos es Parameters:

Fig 13. Introducción de los parámetros de la simulación

En este recuadro elegimos las características de la simulación. Las más importantes


es Start time (que suele ser 0.0) y Stop time. Ésta última se tendrá que ajustar a
nuestro sistema, pues por ejemplo un sistema mecánico es mucho más rápido que
uno térmico, y necesitará menos tiempo para llegar al régimen permanente.
Una vez empezada la simulación, ésta se puede parar o hacer una pausa (en el
mismo menú Simulation/Stop y Simulation/Pause)

Si queremos ver la salida, hacemos doble clic en el bloque Scope. Nos aparecerá la
siguiente pantalla:

27
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Fig 14. Visualización de la respuesta mediante el bloque Scope

En la barra de herramientas existen varios iconos: los tres primeros fijan el tipo de
zoom (ampliar eje x y eje y, sólo eje x o solo eje y ). El cuarto icono (con el símbolo de
los prismáticos) hará que aparezca en pantalla la gráfica completa. El quinto nos
guarda la configuración de los ejes para posteriores simulaciones, y el último nos
permite fijar los ejes, y la cantidad de datos que queremos guardar.

9.4 Modelado de un sistema físico


No siempre disponemos de una función de transferencia, sino que tenemos un
conjunto de ecuaciones que nos describe el comportamiento de un sistema real.
Esta función de transferencia se podría obtener resolviendo el sistema de ecuaciones,
pero resulta más sencillo utilizar Simulink. Para ello, nos construimos cada una de las
ecuaciones con bloques. Después hemos de definir una entrada y una salida,
mediante los bloques In y Out, que aparecen en el gupo Connections, pues la función
Y ( s) salida
de transferencia se representa como F ( s ) = = .
U ( s ) entrada
Guardamos el modelo, y después, desde MATLAB, escribimos las siguientes
instrucciones:
>> [A,B,C,D]=linmod ('mi_planta'); %Donde 'mi_planta' es el nombre del archivo

28
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

>> [num,den]=ss2tf (A,B,C,D);

Ejemplo:Intentaremos modelar el siguiente sistema térmico:

Datos:
Potencia inyectada en bloque 3
Temperatura controlada en bloque 3
C1= 2 min kW / ºC C2= 2.5 min kW / ºC C3= 3.5 min kW / ºC
R13 = 7.5 ºC / kW R23 = 10 ºC / kW R30 = 15 ºC / kW
6
Las ecuaciones que nos describen este sistema son:

1 1 1
Pg ( s ) = C3 ·T3 ( s )·s + ·(T3 ( s ) - T2 ( s )) + ·(T3 ( s ) - T1 ( s )) + ·(T3 ( s ) - T0 ( s ))
R32 R31 R30
1
·(T3 ( s ) - T1 ( s )) = C1·T1 ( s )·s
R31
1
·(T3 ( s ) - T2 ( s )) = C2 ·T2 ( s )·s
R32

Representando estas ecuaciones en un modelo de Simulink, nos queda:

6
No se ha considerado el efecto de una posible perturbación, pues hemos de definir una única entrada y salida

29
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

[T3]
1
1/15 1/60 [T1]
s
[T1]

[T3]
1
1/25 1/60 [T2]
s
[T2]

[T3]
1/7.5
[T1]

[T3]
1/10 1
Out
[T2]

1
1/3. 1/60 [T3]
[T3] 1/15 s
1
In

Fig 15. Modelo de Simulink que representa el sistema térmico

Para construir el modelo de una forma más clara, se han utilizado Tags o etiquetas
(que se encuentran en Connections)
El término 1/60 corresponde al cambio de unidades de minutos a segundos

Ahora escribimos en MATLAB:

>> [A,B,C,D]=linmod ('mi_planta');


>> [num,den]=ss2tf (A,B,C,D);
>> planta =tf(num,den)

La función de transferencia entre la potencia aportada al sistema y la temperatura a


controlar queda:

T3 ( s ) 0.004762·S 2 + 8.466·10 -6 ·S + 3.527·10-9


= 3 (en segundos)
Pg ( s ) S + 0.0032·S 2 + 2.257310 - 6 ·S + 2.352·10-10

30
UPCo MATLAB & SIMULINK
ICAI - DEA Manual de referencia

Una vez modelado el sistema, resulta conveniente crear un bloque que agrupe
nuestro sistema real. Para ello, seleccionamos todos los bloques, pulsando en una
esquina y arrastrando hasta englobar a todos los elementos (no con la opción
Edit/Select all). Después hacemos clic en Edit/Create subsystem, que debería
aparecer habilitada. Debería quedarnos una ventana así:

En este diagrama de bloques sí se ha incluido la perturbación.

31

You might also like