Matlab2 - Funciones RLocus Bode Nyquist

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 12

Herramientas de M ATLAB - 1

Indice General
1 Introduccion

Lugar de las Races


rlocus .
2.1 Funcion
rlocfind
2.2 Funcion
sgrid . .
2.3 Funcion
2.4 Ejemplos . . . . . .

.
.
.
.

1
1
2
2
2

Respuesta en Frecuencia
bode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.1 Funcion
Nyquist . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.2 Funcion

5
5
6

Diseno
de control
rltool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.1 Funcion

7
7

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

Introduccion

En este apunte veremos algunas funciones de M ATLAB relacionadas con lugar de las races, grafico
de Bode y de Nyquist. Entre ellas nos centralizaremos en detallar las siguientes:
Comando
rlocus
rlocfind
rltool
zpmap
bode
nyquist

Breve explicacion
Calcula y grafica el lugar de las races de un sistema LTI SISO
Encuentra la ganancia del lugar de las races para polos dados
un compensador SISO usando lugar de las races
Permite disenar
Calcula y grafica polos y ceros de un sistema LTI
Respuesta en frecuencia de Bode para modelos LTI
Respuesta en frecuencia de Nyquist para modelos LTI
Tabla 1: Comandos de Matlab

Lugar de las Races

detallaremos el uso de las funciones de M ATLAB relacionadas con el grafico del


A continuacion
lugar de las races. En donde citaremos algunos ejemplos para clarificar.

2.1

rlocus
Funcion

Calcula y grafica el lugar de las races de un sistema LTI SISO. El grafico del lugar de las races se
negativa de la Figura 1 y muestra las trayectorias de
utiliza para analizar el lazo de realimentacion
los polos a lazo cerrado cuando la ganancia K vara de 0 a .
- h - sys
6

K 

G (s) =

sys(s)
1 + Ksys(s)

negativa y su funcion
de transferencia
Figura 1: Realimentacion

Herramientas de M ATLAB - 2

puede utilizarse de la siguiente forma:


La funcion
R=rlocus(sys,K)
[R,K]=rlocus(sys)
donde en el parametro R matricial devuelve el lugar complejo de la raz para la ganancia K. En el
primer caso indicamos que intervalo de valores de ganancias estamos interesados, mientras que si

no le ingresamos dicho parametro, K vara de 0 a . El sistema puede ser ingresado como funcion
transferencia, con el comando tf o zpk, o simplemente pasandole el numerador y el denominador
del sistema, es decir rlocus(num,den).

2.2

rlocfind
Funcion

nos permite hallar la ganancia del grafico del lugar de races correspondiente para un
Esta funcion
conjunto de polos dados. El comando ingresado de la siguiente forma
[K,polos]=rlocfind(sys);
se utiliza para seleccionar la ganancia del lugar de las races generado por rlocus en forma interactiva. Luego de ejecutado dicho comando, aparece una cruz sobre el grafico del lugar de las races
con el que seleccionaremos el lugar deseado para los polos a lazo cerrado. La ganancia asociada con
el punto seleccionado es la que este comando devuelve en la variable K y todos los polos a los que
le corresponde esa ganancia los devuelve en la variable polos.

2.3

sgrid
Funcion

Genera una grilla en el plano complejo s para un lugar de las races ya existente o un mapa de
polos y ceros. Se dibujan lneas de amortiguamiento () y frecuencia natural (n ) constantes. El
comando se utiliza de la siguiente forma:
sgrid(z,wn)

2.4

Ejemplos

de transferencia a lazo abierto


Ejemplo 1. Dada la siguiente funcion
G (s) H (s) =

K
,
s(s + 2)

vamos a calcular el lugar de las races. Para ello ingresamos los siguientes comandos desde el
WorkSpace de M ATLAB
sys=zpk([],[0 -2],1);
rlocus(sys);

sys=tf(1,[1 2 0]);

obteniendo la Figura 2
Si tomamos el mismo sistema pero le agregamos un polo en p = 3 y otro en p = 4, e
ingresamos nuevamente los comandos correspondientes, obtenemos los graficos de la Figura 3 respectivamente, en donde observamos como el grafico se ve forzado hacia la derecha debido a cada
polo que agregamos.
de transferencia:
Ejemplo 2. Supongamos ahora una planta con la siguiente funcion
G (s) H (s) =

K (s + 1)
,
s2 (s + )

donde = 10, 9, 8 y 3

Si ejecutamos los mismos comandos que en el ejemplo anterior, es decir, ingresamos primero el
sistema y luego le calculamos el lugar de races, obtenemos los resultados que se observan en la
Figura 4 y 5

Herramientas de M ATLAB - 3

1.5

Imag Axis

0.5

0.5

1.5

2
3

2.5

1.5

0.5
Real Axis

0.5

1.5

Figura 2: Grafica del lugar de las races

Imag Axis

4
6

2
Real Axis

2
Imag Axis

Imag Axis

Figura 3: Grafica del lugar de las races

10

4
Real Axis

8
10

4
Real Axis

Figura 4: Grafica del lugar de las races para = 10 y = 9, respectivamente

Herramientas de M ATLAB - 4

4
2

Imag Axis

Imag Axis

2
2

4
3

4
4

1
Real Axis

Real Axis

Figura 5: Grafica del lugar de las races para = 8 y = 3, respectivamente

Existen casos donde queremos analizar el comportamiento de un sistema a lazo cerrado (LC),
pero donde el parametro variable no aparece como un factor multiplicativo (como lo es la ganancia
K en los ejemplos anteriores) del sistema a lazo abierto (LA). En esos casos tenemos que reescribir la
caracterstica de forma tal que el parametro variable aparezca como un factor multiplicatiecuacion
ilustran
vo de G (s) H (s) y as podremos utilizar el comando rlocus. Los ejemplos a continuacion

como
podemos proceder en distintos casos.
de transferenEjemplo 3. Grafiquemos el lugar de las races del diagrama de la Figura 6. La funcion

R(s) - h - h 66

20
(s+1)(s+4)

C (s)

1
s

k 

Figura 6: Sistema de control


cia a LA resulta
G (s) H (s) =

20
s(s + 1)(s + 4) + 20ks

caracterstica es s3 + 5s2 + 4s + 20 + 20ks = 0. Como la variable ajustable no


donde la ecuacion
caracterstica. Si
aparece como factor multiplicativo, llamemos K = 20k y reescribamos la ecuacion
ahora dividimos ambos miembros por el polinomio que no tiene terminos con K, tenemos
1+

s3

+ 5s2

Ks
+ 4s + 20

1+K

que es del tipo

num(s)
.
den(s)

Ahora podemos graficar el lugar de las races utilizando la sentencia rlocus(num,den).


transferencia G0 (s) y un controlador en realimenEjemplo 4. Consideremos una planta con funcion
con funcion
transferencia C (s), donde
tacion
G0 (s) =

1
(s + 1)(s + 2)

C (s) = 4

(s + )
.
s

de los polos a lazo cerrado para variando en R+ .


Queremos conocer como
vara la ubicacion
Veamos que los polos a lazo cerrado del sistema son los ceros de
1+4

s +
s(s2 + s 2) + 4s + 4
=
=0
s(s2 + s 2)
s(s2 + s 2)

s(s2 + s + 2) + 4 = 0

Herramientas de M ATLAB - 5

a la forma 1 + kG (s),
Si dividimos ambos miembros por s(s2 + s + 2), convertimos la ecuacion
donde
1
k = 4
y
G (s) =
s(s2 + s + 2)

Lo unico
que queda ahora es ingresar el comando rlocus para obtener la Figura 7
3

Imag Axis

3
1

0.8

0.6

0.4

0.2

0
Real Axis

0.2

0.4

0.6

0.8

de los polos a LC cuando el cero del controlador vara


Figura 7: Ubicacion

Respuesta en Frecuencia

detallaremos las funciones de M ATLAB para graficar la respuesta en frecuencia, es


En esta seccion
decir para obtener los graficos de Bode y de Nyquist, con las funciones bode y nyquist respectivamente.

3.1

bode
Funcion

nos permite obtener la respuesta en frecuencia de Bode para modelos LTI. Entre las
Esta funcion
se encuentran:
formas mas comunes de utilizar esta funcion
bode(sys): dibuja el grafico de Bode del modelo LTI sys (creado con tf o zpk). El rango de

frecuencia y el numero
de puntos que tomara para graficar los elige en forma automatica.
bode(sys,wmin,wmax): dibuja el grafico de Bode para frecuencias entre wmin y wmax (en
rad/seg).
bode(sys,w): utiliza el el vector w de frecuencias propuesto para calcular el Bode. Dado
logspace que
que el vector w debe estar en escala logartmica, existe en M ATLAB la funcion
genera un vector de frecuencias en forma logartmica.
bode(sys1,sys2,...,w): dibuja el grafico de Bode de varios modelos LTI en una sola figura. El parametro w es opcional, tambien se puede especificar color, tipo de linea y marcadores
como se los utiliza con el comando plot.
[mag,fase]=bode(sys,w) o [mag,fase,w]=bode(sys): devuelve la magnitud y la fase
en grados. Este comando no dibuja en pantalla, mag(:,:,k) y fase(:,:,k) determina la respuesta en
w(k). Para obtener magnitudes en dB, debemos calcular magdb=20*log10(mag).

Herramientas de M ATLAB - 6

Ejemplo 5. Dada la siguiente transferencia, queremos obtener el grafico de Bode


G (s) =

2500
s(s + 5)(s + 50)

Para ello ejecutemos los siguientes comandos desde el workspace:


G=zpk([],[0 -5 -50],2500);
bode(G);
Bode Diagrams
From: U(1)
50

Phase (deg); Magnitude (dB)

50

100

150
50

To: Y(1)

100

150

200

250

300
1
10

10

10

10

10

Frequency (rad/sec)

Figura 8: Grafico de Bode obtenido con el comando bode(G)

3.2

Nyquist
Funcion

nos permite obtener la respuesta en frecuencia de Nyquist para modelos LTI. Entre las
Esta funcion
se encuentran:
formas mas comunes de utilizar esta funcion
nyquist(sys): dibuja el grafico de Nyquist de sys que es un modelo LTI creado con los

comandos tf o zpk. El rango de frecuencia y el numero


de puntos que utilizara para graficar
son elegidos en forma automatica.
bode, excepto
Las distintas alternativas para este comando son las misma que para la funcion

el ultimos
de los tems que se reemplaza por:
[Re,Im]=nyquist(sys,w) o [Re,Im,w]=nyquist(sys): devuelve la parte real e imaginaria de la respuesta en frecuencia, a lo largo de w. La respuesta a la frecuencia w(k) esta
dada por Re(:,:,k)*Im(:,:,k)
transferencia viene dada por
Ejemplo 6. Dado el sistema cuya funcion
G (s) =
obtener el diagrama de Nyquist.
Para ello ingresamos los siguientes comandos
G=zpk([],[-1 -1],1);
nyquist(G)
y obtuvimos la Figura 9

1
(s + 1)2

Herramientas de M ATLAB - 7

Nyquist Diagrams
From: U(1)
0.8

0.6

0.4

To: Y(1)

Imaginary Axis

0.2

0.2

0.4

0.6

0.8
1

0.8

0.6

0.4

0.2

0.2

0.4

0.6

0.8

Real Axis

Figura 9: Grafico de Nyquist obtenido con el comando nyquist(G)

de control
Diseno

interactivo llamada rltool que puede utilizarse


Presentaremos ahora una herramienta de diseno
para:
Analizar el lugar de las races para los sistemas de control LTI SISO.
polos, ceros y ganancia.
Especificar los parametros de un compensador de realimentacion:

Examinar como
cambiando los parametros del compensador, cambia el lugar de las races y
unitario, respuesta al impulso
varias respuestas a lazo cerrado, como la respuesta al escalon
unitario, diagramas de Bode y/o Nyquist entre otros.

4.1

rltool
Funcion

Para explicar mejor el uso de esta herramienta, seguiremos un ejemplo que involucra un servomecanismo electro-hidraulico, que esencialmente es un amplificador de potencia electro-hidraulico,
controlado por una valvula piloto y un actuador, Figura 10. Estos servomecanismos son muy pe y se utilizan para controlar posicion.
Un modelo a lazo cerrado para el control de posicion

quenos
puede representarse como aparece en la Figura 10 (detalles del modelado matematico del mecanis ver [2, pag. 91] o [1, pag. 43]).
mo y su linealizacion

En la Figura 10, K (s) representa el compensador que deseamos disenar.


Este compensador puede ser tanto una ganancia como un sistema LTI. La planta linealizada viene dada por
Gservo (s) =

4.107
s(s + 250)(s2 + 40s + 9.104 )

un controlador de forma tal que la respuesta al escalon


a
Para este ejemplo, queremos disenar

lazo cerrado cumpla con las siguientes especificaciones de diseno:


El tiempo de establecimiento menor a 0.05 seg.
El sobrevalor maximo menor al 5%.

Herramientas de M ATLAB - 8

u -h K (s)
6

- Gservo (s)

y
-

Figura 10: Servomecanismo electro-hidraulico y el diagrama de bloques del sistema mas el compensador, respectivamente.

Figura 11: Ventana de la herramienta rltool

Herramientas de M ATLAB - 9

Para comenzar, desde el workspace de M ATLAB, ingresemos el comando rltool, con el que
abrimos una nueva ventana, Figura 11, en la que encontramos:
entre los que encontramos, por ejemplo, una opcion
para importar/exportar
Una barra de menu,
modelos y para editarlos.
que utilizaremos; si hacemos
Un grafico de bloques que es la estructura de realimentacion
click sobre el bloque K, podemos ver o editar el compensador, y sobre P, F o H para ver las
del modelo.
caractersticas de diseno
para cambiar entre realimentacion
negativa y positiva.
Un boton
del compensador que configuraremos. Por defecto toma el valor de ganancia
Una descripcion
igual a 1 (K = 1).
Cuatro botones que utilizaremos para agregar polos o ceros del compensador, borrarlos o
moverlos.
Un cuadro de texto para editar la ganancia que modificara el lugar de los polos a LC.
Botones para editar los ejes.
Botones para modificar el zoom del grafico.
Check boxes para abrir herramientas de analisis de respuesta del sistema.

Una barra de status que provee informacion.


Una vez abierta la ventana, debemos importar el modelo del sistema para el que queremos
un compensador. Existen cuatro formas para importar un modelo LTI, y e stas son:
disenar
1. Cargar el modelo desde el workspace de M ATLAB, con el comando rltool(sys,comp), don transferencia del sistema ingresada como tal, y comp la del compensador
de sys es la funcion
(opcional).
.mat de un disco.
2. Cargar el modelo desde un archivo de extension
3. Cargar bloques LTI SISO desde un diagrama de S IMULINK.
4. Crear los modelos utilizando tf, ss o zpk.
Para este ejemplo, importemos nuestro modelo del servomecanismo desde el workspace. Para
tf o zpk y guardarla en una variable,
ello debemos previamente ingresar el modelo con la funcion
por ejemplo Gservo. Una vez cargado el modelo, lo podemos importar desde el menu Import Model
que se desplegara encontraremos
del menu File. En la ventana de importacion
que utilizaremos.
Un diagrama correspondiente a la estructura de realimentacion
que conmuta entre las dos posibles estructuras de realimentacion
que hay configu Un boton
radas.

Una lista para seleccionar desde donde


se importara el modelo.
Una lista de sistemas LTI disponibles o bloques.

Un cuadro de texto para editar el nombre del diseno.


Tres botones con flechas para transferir el modelo seleccionado de la lista al componente de
del modelo, ya sea P, F o H.
diseno

Herramientas de M ATLAB - 10

Desde este recuadro


Tres cuadros de textos para los nombres de los componentes del diseno.
podemos tambien definir funciones de transferencias para cada componente, utilizando tf,
ss o zpk.
Ya sea en cualquiera de las dos configuraciones, cada componente representa: F - prefiltro; P
modelo de la planta; H - dinamica de la planta; K - compensador a disenar.
Siguiendo con nuestro ejemplo, carguemos el modelo lineal en P, seleccionandolo desde la lista

de workspace y luego haciendo un click sobre la flecha que senala


a P, o simplemente tipeando en
de
el cuadro de texto Gservo (nombre de nuestro modelo). Luego de seleccionar OK, en la region
aparecera el grafico del lugar de las races del modelo ingresado,
grafico de la ventana de diseno,
cuadros rojos sobre e l corresponden a los polos a lazo cerrado corresponFigura 12. Los pequenos
dientes al valor de la ganancia del compensador.
Root Locus Design
600

400

Imag Axes

200

200

400

600
800

600

400

200

200

400

600

Real Axis

Figura 12: Lugar de las races que resulta cuando cargamos el modelo
Veamos hasta que valor de ganancia podemos aplicarle al compensador para que se mantenga
estable a lazo cerrado, es decir, hasta que los polos a lazo cerrado se mantengan en el semi-plado
izquierdo del plano complejo. Este lmite lo podemos calcular de la siguiente forma:
1. Mover el puntero del mouse sobre un de los cuadrados rojos, donde aparecera una mano en
lugar del puntero. Arrastrar dicho cuadrado hasta lo mas cerca del eje imaginario. Observar
que el valor de la ganancia se va modificando.
2. Como no podemos saber si los polos se encuentran exactamente sobre el eje imaginario, utilizar el zoom para acercarlos mejor. Una vez alcanzado el eje imaginario, quitar el zoom con el
de los binoculares.
boton

3. Por ultimo,
verificar que la ganancia correspondiente para que los polos a lazo cerrado sean
imaginarios puros es aproximadamente 43.5 (ganancia crtica).
El valor de la ganancia podra haberse modificado directamente desde el recuadro correspondiente a la ganancia del compensador, hasta que los polos a lazo cerrado se ubiquen sobre el eje
imaginario.
el compensador, quisieramos conocer como

Antes de disenar
se comporta el sistema a lazo cerrado para un determinado valor de ganancia. Para ello, debemos seleccionar el check box que aparece

Herramientas de M ATLAB - 11

del grafico que no interesa conocer. Para este ejemplo


en la parte inferior de la ventana la opcion
vienen dadas sobre la respuesta al escalon,
por lo que seleccionarelas especificaciones de diseno
que desplegara una ventana de LTIVIEWER. Si editamos el valor de la ganancia,
mos dicha opcion,
de la ventana LTIVIEpor ejemplo 20, y presionamos ENTER, veremos como la respuesta al escalon
Recordemos que en dicha ventana, cuando hacemos click sobre la figura con el
WER se modifico.
derecho del mouse, podemos seleccionar que nos muestre las caractersticas que necesitamos,
boton
en este caso el sobrevalor y el tiempo de establecimiento. Podemos observar que en este caso por
mas que modifiquemos la ganancia, las especificaciones nunca se alcanzan. Por lo que para que se
un compensador.
cumplan debemos disenar
el compensador, debemos conocer donde

Para disenar
queremos que se ubiquen los polos a
lazo cerrado para que las especificaciones se cumplan. Por eso vamos a elegir del menu Tools, la
Add Grid/Boundary, que realizara rectas donde se especifiquen, en este caso le indicaremos
opcion
el tiempo de establecimiento igual a 0.05 seg. y el factor de amortiguamiento igual a 0.7 (ver [1,
contratapa]) . Una vez seleccionados dichos valores, veremos que en el grafico aparecen las dos
rectas correspondientes a las caractersticas ingresadas. Ahora sabemos que para que se cumplan
los polos dominantes del sistema a lazo cerrado deberan ubicarse en
las especificaciones de diseno,
de dichas rectas. Para ello, debemos mover el lugar de las races agregando polos y
la interseccion
ceros al compensador. Para ello debemos proceder de alguna de las siguientes formas:
correspon Utilizando los botones de agregar, o quitar, polos o ceros: seleccionar el boton

diente, luego con el puntero del mouse indicar donde


se ubicara el polo y hacer un click en
dicho lugar.
Para nuestro ejemplo, ubiquemos un par de polos complejos conjugados por debajo y a la
derecha de los polos a lazo abierto. Agreguemos un par de ceros complejos conjugados cerca

de los polos a lazo abierto. Observemos como


se modifico el lugar de las races. Si todava no
de las rectas correspondientes a las caractersticas de diseno,
mover
pasa por la interseccion
los polos y/o ceros. Una vez conseguido esto, modificar la ganancia para que los polos a

lazo cerrado se ubiquen donde queremos, Figura 13. Por ultimo


nos queda verificar con la
que se cumplen las especificaciones dadas, Figura 14.
respuesta al escalon
Root Locus Design
600

400

Imag Axes

200

200

400

600
800

600

400

200

200

400

Real Axis

deseada de los polos a LC.


Figura 13: Ubicacion

600

Herramientas de M ATLAB - 12

Step Response
From: U(1)

To: Y(1)

Amplitude

0.8

0.6

0.4

0.2

0
0

0.005

0.01

0.015

0.02

0.025

0.03

0.035

0.04

0.045

0.05

Time (sec.)

del sistema a LC.


Figura 14: Respuesta al escalon

Utilizando el menu Edit compensator del menu Tools, o haciendo un click sobre el compensador del grafico de bloques de la derecha. Si ya realizamos el procedimiento anterior, sabemos
que los polos, ceros y ganancia del compensador se puede aproximar con
K = 9.7
Polos = 110 140i
Ceros = 70 270i
Una vez encontrado el compensador que lleva a nuestro sistema a que cumpla con las especifi Export podemos
caciones dadas, podemos guardar los parametros desde el menu File, con la opcion
llevarlo a un disco, o al workspace de M ATLAB.

Referencias
[1] Gene F. Franklin, J.David Powel, and Abbas Emami-Naeini. Control de Sistemas Dinamicos con
Retroalimentacion. Addison-Wesley Iberoamericana, 1991.
[2] Katsiuko Ogata. Control Moderno. Pentice Hall, 1998.

También podría gustarte