Control Digital Con Matlab2

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

UNIVERSIDAD NACIONAL DEL CALLAO

FIEE-2011B
CONTROL DIGITAL

2 FUNCIN DE TRANSFERENCIA

2.1 MUESTREO Y RETENCIN

2.1.1 MUESTREO DE UNA SEAL

Una seal continua se puede convertir a una seal discreta mediante un


muestreador que convierte la seal en un tren de impulsos a una rata o
periodo de muestreo T y magnitud de cada impulso igual al valor uestreado
de la seal continua en el instante de muestreo.

Seal continua Muestreador Seal


muestreada

El tren de impulsos unitarios se puede representar mediante la ecuacin:



T(T) = (t-kT) = x(0) (T) + x(T) (t-T) + x(2T) (t-2T) +
k=0

La seal muestreada se puede representar como la magnitud de la seal en


el instante muestreado multiplicada por el tren de impulsos de la siguiente
manera


x*(t) = x(kT) (t-kT) = x(0) (T) + x(T) (t-T) + x(2T) (t-2T) +
k=0

Sacando la Transformada de Laplace a la seal muestreada :

X*(s) = L[x*(t)] = x(0)L[(t)] + x(T)L[(t-T)] + x(2T) L[[t-2T)] +


= x(0) + x(T)e Ts + x(2T)e 2Ts +

28

X*(s) = x(kT) e kTs
k=0

Si z = e T s , esto es, s = (1/T) ln (z), entonces,



X*(s) = x(kT) z k = X(z)
k=0

Conclusin : La transformada de Laplace de una seal muestreada es la


misma transformada Z si : z = eTs

2.1.2 RETENCIN DE DATOS

Es el proceso de recuperacin de la seal continua a partir de la seal


discreta. El retenedor utiliza las muestras anteriores para extrapolar la seal
continua entre el instante de muestreo presente y el siguiente.

El retenedor ms utilizado es el retenedor de orden cero ZOH (zero order


hold). Este retenedor genera una seal continua h(t) manteniendo o
reteniendo cada valor de la muestra cada periodo de muestreo. Esto es:

h(kT+t) = x(kT), para kT t (k+1)T

29
h(t) = x(0)u(t) + [x(T)-x(0)] u(t-T) + [x(2T)-x(T)] u(t-2T) +

h(t) = x(0)[u(t)-u(t-T)] + x(T)[u(t-T)-u(t-2T)] + x(2T)[u(t-2T)-u(t-3T)] +


h(t) = x(kT) [u(t-kT) u(t-(k+1)T)], aplicando transf_Laplace,
k=0

Como, H(s) = GZOH(s) X*(s), se tiene que la Funcin de transferencia del


retenedor de orden cero es:

Existe y se aplica tambin el retenedor de orden primero FOH (First Order


Hold) cuya interpolacin entre periodos de muestreo se hace en forma
triangular. Para este retenedor,

t - kT
h(kT+t) = x(kT) +------- [ x(k+1)T- x(kT)] , para kT t (k+1)T
T

2.2 FUNCIONES DE TRANSFERENCIA


2.2.1 SISTEMA EN LAZO ABIERTO

La funcin de transferencia relaciona la salida de un sistema en los


instantes de muestreo con la correspondiente entrada muestreada.

X( z ) Y(z)

Y(z) = G(z) X(z) , entonces,

30
Demostracin :

Y(s) = G(s) X*(s), entonces,

Y*(s) = G*(s)X*(s), por tanto,

Sacando Transf_Z a la sea muestreada :

Y(z) = G(z) X(z), o sea que:

2.2.2 SISTEMAS EN CASCADA

(a) CON UN MUESTREADOR

Y(s) = G(s)H(s)X*(s), discretizando la ecuacin,

Y*(s) = [G(s)H(s)]*X*(s), si se simboliza [G(s)H(s)]* =[GH(s)]*

Y*(s) = [GH(s)]*X*(s), sacando transformada z :

Y(z) = [GH(z)]X(z), donde, GH(z) z[GH(s)] = z[G(s)H(s)]

Por tanto, la funcin de transferencia para este sistema es igual a :

31
(b) CON DOS MUESTREADORES SINCRONIZADOS

Y(s) = H(s)V*(s), y V(s) = G(s)X*(s)

discretizando las ecuacines,

Y*(s) = H*(s)V*(s), o sea que , Y(z) = H(z)V(z) (1)

V*(s) = G*(s)X*(s), o sea que , V(z) = G(z)X(z)

Reemplazando V(z) en (1), se tiene :

Y(z) = H(z) G(z)X(z)

Por tanto la funcin de transferencia del sistema es:

EJEMPLO 2-1

(a) Obtener la funcin de transferencia de (T = 1.0) :

32
Por tanto su transformada inversa de Laplace es igual a :

f(t) = L- 1 [F(s)] = (1/3) e- 2 t (1/3) e -5 t

La cual corresponde a una funcin discreta a:

f(kT) = (1/3) e- 2 kT (1/3) e -5 kT,

que tiene una transformada Z igual a :

Para un periodo de muestreo T = 1, se tiene:

(b) Obtener la funcin de transferencia de :

Entonces la funcin de transferencia del sistema para T = 1 es igual a:

33
Se comprueba que G(z)H(z) GH(z)

2.2.3 SISTEMA EN LAZO CERRADO

(a) CON UN MUESTREADOR

E(s) : es el error

E(s) = R(s) H(s)C(s) , como , C(s) = G(s) E*(s), entonces,

E(s) = R(s) G(s)H(s)E*(s), tomando seales muestreadas,

E*(s) = R*(s) [G(s)H(s)]* E*(s), despejando E*(s),

Como C*(s) = G*(s)E*(s), entonces,

Tomando transf_Z, se tiene :

34
, por tanto su funcin de transferencia es :

(b) CON DOS MUESTREADORES SINCRONIZADOS

E(s) = R(s) H(s)C(s) , como , C(s) =V*(s) y V(s) = G(s) E*(s), entonces,

C(s) = G*(s)E*(s)

E(s) = R(s) H(s)G*(s)E*(s), tomando seales muestreadas,

E*(s) = R*(s) H*(s)G*(s) E*(s), despejando E*(s),

Como C*(s) = G*(s)E*(s), entonces,

Tomando transf_Z, se tiene :

35
, por tanto su funcin de transferencia es :

EJEMPLO 2-2

Calcular la funcin de transferencia de un sistema en lazo cerrado con un


muestreador que tiene,

donde, GH(z) = z[G(s)H(s)]

Para T = 0.1 seg,

36
2.2.4 SISTEMA DE CONTROL DIGITAL

En la figura A/D es el muestreador, Gc(z) es el controlador digital, ZOH es el


(convertidor D/A) y Gp(s) es la funcin de transferencia de la planta.

e(t) es la seal de error que se muestrea, e(kT) es la seal discreta del error,
m(kT) es la salida del controlador digital que se obtiene al resolver la
ecuacin en diferencias de la funcin de transferencia del controlador, y u(t)
es la seal de control que se debe aplicar a la planta.

G(s) = Gzoh(s) Gp(s) =

Del diagrama en bloques se tiene que,

C(z) = [Gc(z)G(z)] E(z) y que E(z) = R(z) C(z), entonces,

C(z) = [Gc(z)G(z)] [R(z) C(z)] = Gc(z)G(z)R(z) Gc(z)G(z)C(z)

Luego entonces la funcin de transferencia es igual a :

Como la funcin de transferencia en lazo abierto de este sistema es :

F lazo-abierto(z) = Gc(z)G(z),

37
entonces, cuando la realimentacin es igual a 1 :

2.2.5 CONTROLADOR DIGITAL PID

Un controlador Proporcional-Integral-Derivativo continuo o analgico tiene


como respuesta de salida la siguiente ecuacin:

(1)

Donde: K = Ganancia proporcional

Ti = Tiempo integral o de ajuste

Td = tiempo derivativo o de adelanto

Discretizando la anterior ecuacin, se deben reemplazar los trminos


continuos a discretos como se indica a continuacin :

m(t) m(kT),

e(t) e(kT),

Que quedar de la siguiente forma:

(2)

Ahora se tiene que encontrar la Transf._Z M(z). De la anterior ecuacin:

La Transf._Z de la sumatoria se obtiene aplicando la propiedad de la suma


de funciones , si :

38
Reemplazando en (2) :

o sea que :

Por tanto la funcin de transferencia de un controlador PID discreto es :

Cuyo diagrama en bloques es el siguiente:

39
EJEMPLO 2-3

Encontrar la funcin de transferencia en lazo abierto y lazo cerrado del


sistema dado, si el controlador PID tiene como parmetros Kp=1, Ki = 0.2 y
Kd = 0.5. La planta tiene una funcin de transferencia igual a :

Como vimos anteriormente, la funcin de transferencia de la planta junto con


el retenedor es igual a:

G(z) =( 1-z 1 ) z

Resolviendo en fracciones parciales,

40
La funcin de transferencia de la planta discretizada G(z) es :

La funcin de transferencia del controlador PID es :

(a) Funcin de transferencia en lazo abierto :

41
(b) Funcin de transferencia en lazo cerrado :

PROGRAMA EN MATLAB

% OBTENER FUNCION DE TRANSFERENCIA

% tiempo de muestreo: T = 1 seg

T = 1;

% parmetros del controlador PID

Kp=1; Ki = 0.2; Kd = 0.5;

% Funcin de transferencia de la planta

Gps = zpk([ ], [0 -2], 1)

% Funcin de transferencia de planta + retenedor

Gz =c2d(Gps, T,'zoh')

Gz = tf (Gz)

% Funcin de transferencia del controlador PID

GPID =tf([ Kp+Ki+Kd -(Kp +2*Kd) Kd], [1 -1], T)

% FUNCION DE TRANSFERENCIA DEL SISTEMA EN LAZO ABIERTO

Flazo_abierto = GPID*Gz

% FUNCION DE TRANSFERENCIA DEL SISTEMA EN LAZO CERRADO

Flazo_cerrado =feedback(Flazo_abierto,1)

42
3. SIMULINK

3.1 INTRODUCCIN

Simulink es una extensin de Matlab utilizado en el modelamiento y


simulacin de sistemas. Para arrancar Simulink se puede hacer desde el
prompt de Matlab digitando el comando >>Simulink o utilizando el icono

. Se abre la ventana Simulink Library Browser como se indica abajo y se


puede diagramar un nuevo modelo activando el botn New Model , o sea el
icono o de File NewModel

Un modelo es un conjunto de bloques que representa un sistema y como


archivo tiene extensin *.mdl

3.2 ELEMENTOS BSICOS

Los elementos bsicos son lneas y bloques. Los bloques estn agrupados
en: Sources, Links, Discrete, Continuos, Math, etc., tal como aparecen en la
ventana anterior. Cada bloque tiene entradas y salida para realizar su
interconexin. Por ejemplo, haga clic en Discrete y luego clic en Discrete
Transfer Fcn y arrastre el bloque a la ventana en blanco. Si quiere modificar
la funcin de transferencia del bloque haga doble clic en l y digite los

43
coeficientes del numerador y denominador en la nueva ventana que aparece.
Para la funcin 1/(z2 +2z +4) con tiempo de muestreo de 1 seg, quedara:

3.3 SISTEMAS DE CONTROL

Realizar el diagrama en bloques del siguiente sistema de control:

Lo primero es arrastrar los bloques a la pgina en blanco de forma que, Step


es la funcin paso o escaln que se obtiene de Sources, Scope es el
osciloscopio que se obtiene de Sinks, Transfer Fcn se obtiene de Continuos,
Sum y Gain se obtienen de Math. Modifique los bloques dando doble clic
sobre cada uno de ellos para cambiar sus parmetros o valores e
interconctelos.

Lo segundo es cambiar los nombres a los bloques y asignar las variables o


seales haciendo doble clic en el lugar en que se van a colocar y salvar el
modelo especificndole un nombre, por ejemplo ejem1.mdl

44
Por ltimo se debe simular el sistema. Para ello se configura la seal de
entrada, en este caso la funcin paso. Dar doble clic y asignar los siguientes
parmetros: Step time=0, Inicial value=0, Final value=1, Sample time=0.
Para simular el sistema de control se escoge del men Simulation Start o el

icono .y luego se hace doble clic en Scope para ver su respuesta o salida
del sistema. Para observar adems la entrada se puede colocar otro Scope a
la salida de Step y se puede probar para varios pasos variando su amplitud,
tiempo de inicio y tiempo de iniciacin del paso. Para observar mejor la

respuesta se usa el botn Autoscale (binoculares ) de la ventana del


Scope. Si quiere observar mejor la respuesta o parte de ella se pueden
cambiar los parmetros de simulacin, Simulation Simulation parameters.
Por ejemplo cambiar el Start time y el Stop time y correr nuevamente la
simulacin.

3.4 MODELANDO UN MOTOR DC

Un actuador comn en sistemas de control es el motor DC. Provee


directamente movimiento rotatorio y acoplado con poleas o correas puede
proveer movimiento transnacional.

45
3.4.1 ECUACIONES DINMICAS

El circuito elctrico de la armadura y el diagrama de cuerpo libre del rotor es


mostrado en la figura con sus ecuaciones dinmicas.

(1) Leyes de Newton

(2) Leyes de Kirchhoffs

Los parmetros fsicos tienen los siguiente valores :

Momento de inercia del rotor : J = 0.01kg.m2/sg2


Rata de amortiguamiento del sistema mecnico: b = 0.1 N.m.sg
Constante de la fuerza electromotriz: Ke = Kt = 0.01 Nm/Amp
Resistencia elctrica: R = 1 ohm
Inductancia elctrica: L =0.5H
Fuente de voltaje de entrada: V
Posicin angular:
Se asume que el rotor y el eje son rgidos

3.4.2 MODELADO DEL MOTOR EN VELOCIDAD

46
3.5 EXTRAER MODELO LINEAL

Para obtener la funcin de transferencia del motor primero se trasladan los


parmetros del motor al modelo creando un archivo en Matlab (*.m) de la
siguiente forma:

% VALORES DE LOS PARMETROS DEL MOTOR


J = 0.01;
b = 0.1;
Ke = 0.01;
Kt = 0.01;
R = 1;
L = 0.5;

Se ejecuta este archivo y se simula el modelo para una entrada de paso


unitario de valor V = 0.01, con los siguientes parmetros de simulacin: Stop
time = 3 sg. Arranque la simulacin y observe la salida (velocidad del motor).

Como segundo paso se debe obtener el modelo lineal de Matlab del motor.
Para esto, borre el bloque Scope y cmbielo por Out obtenido de la librera
de Signals&Systems. Haga lo mismo para Step cambindolo por In de esta
misma librera. Los bloques In y Out definen la entrada y salida del sistema
que le gustara extraer. Salve este modelo. El sistema quedar as:

47
Como tercero y ltimo paso, despus de desarrollado el modelo y salvarlo
por ejemplo con el nombre MotorDcVel.mdl se ejecutan los siguientes
comandos:

% OBTENER EL MODELO LINEAL DEL SISTEMA


[num, den] = linmod('MotorDcVel')
Gps = tf(num, den)
La respuesta es :

3.6 CREAR UN SUBSISTEMA

Abra una nueva ventana y arrastre de la librera Signals&Systems el bloque


SubSystem , haga doble clic en este bloque, abra el modelo MotorDcVel.mdl
(el que tiene In y Out como terminales) cpielo y pguelo en la nueva
ventana de subsistema anterior. Cierre ventanas y aparece una nueva con el
bloque con los terminales del subsistema creado. Dle el nombre
MotorDcVel. Si a este bloque de subsistema se le da doble clic aparece el
modelo completo diseado anteriormente.

48
3.6.1 IMPLEMENTAR SISTEMA EN LAZO ABIERTO

Al subsistema creado que constituye la planta de un sistema de control se le


va a adicionar un controlador y obtendremos la funcin de transferencia en
lazo abierto y lazo cerrado.

% CONTROL DE UN MOTOR DC
[num, den]=linmod('ControlMotor')
Glazo_abierto = tf(num, den)

Respuesta:

3.6.2 IMPLEMENTAR SISTEMA EN LAZO CERRADO

% CONTROL DE UN MOTOR DC
[num, den]=linmod('ControlMotor')
Glazo_cerrado= tf(num, den)

Respuesta:

49
3.7 SISTEMA DISCRETO

3.7.1 DIAGRAMA EN SIMULINK

3.7.2 PROGRAMA MATLAB

% SISTEMA DISCRETO DISCRETO


T=0.1;
[num,den]=dlinmod('MotorDigital',T)
Glazo_cerradoz=tf(num,den,T)

Respuesta:

50

También podría gustarte