Metodos Identificacion Dinamica Matlab Code
Metodos Identificacion Dinamica Matlab Code
Metodos Identificacion Dinamica Matlab Code
y la constante de tiempo se calcula grficamente como se muestra o tomando el valor de t
para el cual c 63 . 0 c k + = , o sea, que la respuesta c(t) ha alcanzado el 63.2% de su
variacin total.
k
c
1
c
r
1
r
t
t
Fig. 2.1 Escaln de entrada y respuesta del sistema de primer orden.
12
2.1.2 Mtodo de Oldenbourg Sartorius
Se usa para sistemas de segundo orden no oscilatorio. La ganancia se calcula igual al caso
de primer orden: K = c / r (2.1)
Suponemos:
) 1 s T )( 1 s T (
K
) s ( F
2 1
+ +
= (2.2)
Para calcular las constantes de tiempo T
1
y T
2
se usan las relaciones entre los tiempos T
A
y
T
C
, definidos cuando se traza una tangente por el punto de inflexin de la curva que
representa la respuesta de un sistema de segundo orden a un escaln, segn muestra la Fig.
2.2
n
1
2
1 A
)
T
T
( T T = donde
2 1
2
T T
T
n
= (2.3)
2 1 C
T T T + = (2.4)
los valores de T
A
y T
C
se determinan grficamente de la representacin de la respuesta del
sistema a un escaln.
La solucin analtica de las ecuaciones resultantes al sustituir T
A
y T
C
en las expresiones
(2.3) y (2.4) es muy compleja, por lo que resulta ms conveniente aplicar un procedimiento
grfico.
Estas expresiones pueden escribirse como:
n
A 1
A 2
A
1
)
T / T
T / T
(
T
T
1= (2.5)
A
2
A
1
A
C
T
T
T
T
T
T
+ = (2.6)
13
c
c
1
T
A
T
C
t
Fig. 2.2 Respuesta de un sistema de segundo orden a un escaln
De la primera ecuacin se puede obtener la siguiente tabla:
T
1
/T
A
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
T
2
/T
A
1 0.73 0.57 0.44 0.34 0.25 0.18 0.12 0.07 0.03 0
Fig. 2.3 Curvas para la aplicacin del Mtodo de Oldenbourg- Sartorius
Representamos ambas en una grfica como se muestra en la fig. 2.3 .
T
1
/T
A
T
2
/T
A
14
Obtenindose las constantes de tiempo en las intersecciones de ambas curvas.
Es importante sealar que si T
C
/T
A
= 0.736, la recta que representa la expresin es tangente
a la curva, lo que significa que T
1
y T
2
son iguales. Si la relacin T
C
/T
A
< 0.736 no hay
interseccin entre la recta y la curva y significa que estamos en presencia de un sistema de
orden superior al segundo, caso para el cual este mtodo no es aplicable.
Uno de los ms graves problemas de estos mtodos es el trazado de la tangente. Sin
embargo esto se puede, hoy en da, simplificar usando Matlab.
En el Departamento de Informtica de la Facultad de Ingeniera Elctrica se elabor un
programa que resuelve el problema con el siguiente algoritmo:
Fig. 2.4 Algoritmo de solucin por Matlab
Se elabor el programa os que se presenta en el anexo # 1.
15
2.1.3 Mtodo de Anderson. Segundo orden
Si se tiene un sistema de segundo orden cuya funcin de transferencia es de la forma:
) 1 sT )( 1 sT (
K
) s ( R
) s ( C
2 1
+ +
=
la respuesta a un escaln de amplitud A sera:
)
T T
e T e T
1 ( AK ) t ( C
1 2
T
t
2
T
t
1
2 1
+ =
(2.7)
que puede escribirse:
2 1
T
t
2
T
t
1
e K e K AK ) t ( C
+ = (2.8)
donde K
1
y K
2
son positivos si T
2
> T
1
. La diferencia entre las respuestas a estado
estacionario y transitoria sera:
2 1
T
t
2
T
t
1 L
e K e K ) t ( C AK ) t ( C
+ = = (2.9)
t
Log C
L
(t)
K
1
K
2
0.37K
1
0.37K
2
T
1 T
2
1
T
t
1
e K
2
T
t
2
e K
16
Fig. 2.5 Representacin grfica del Mtodo de Anderson
y como T
1
y T
2
son reales, C(t) es no oscilatoria y C
L
(t) es positiva.
Como T
2
> T
1
, el primer trmino de C
L
(t) disminuye ms rpidamente que el segundo,
luego, para valores altos de t, se puede decir que:
2
T
t
e
2
K ) t (
L
C
y tomando logaritmo se tiene que:
t ) e log
T
1
( K log ) t ( C log
2
2 L
(2.10)
es decir, si se construye una grfica de C
L
(t), usando papel semilogartmico con el eje
logartmico para C
L
(t) y el eje lineal para t, se obtiene, para valores altos de t, una lnea
recta que interseca al eje logartmico (t = 0) en K
2
.
Tambin se sabe que un trmino exponencial de la forma
2
T
t
2
e K
alcanza un 36.8% de su
valor inicial cuando t = T
2
. De acuerdo con esto se puede establecer la grfica anterior y
determinar la constante de tiempo mayor.
Para la determinacin de la otra constante de tiempo, obsrvese que:
1 2
T
t
1 L
T
t
2
e K ) t ( C e K
= (2.11)
Esto significa, por un razonamiento similar, que si se traza la representacin de la
diferencia mencionada en un grfico semilogartmico, se obtiene una lnea recta que
corresponde a la representacin de
1
T
t
1
e K
, dicha lnea recta, para t = 0 tiene por
ordenada k
1
y para t = T
1
tiene por ordenada 0,368 k
1
.
En resumen, se deben de seguir los siguientes pasos:
17
Se traza la curva correspondiente a la diferencia del valor a estado estacionario y el
transitorio de la respuesta del sistema a un escaln en funcin del tiempo, en un papel
semilogartmico, situando en el eje lineal los valores del tiempo.
Se prolonga la parte recta de la curva anterior, correspondiente a los valores altos de t,
hasta intersecar el eje vertical (K
2
).
Se determina la mayor constante de tiempo como el valor del tiempo donde la recta
anterior alcanza el 0.368 de su valor inicial.
Se repite el procedimiento anterior para los valores resultantes de la diferencia entre la
curva original C
L
(t) y la recta que corresponde a valores altos de t, con lo que se
determina la menor constante de tiempo.
Aunque tericamente este mtodo se puede utilizar para sistemas de orden superior, dado
su carcter grfico, en la prctica no se pueden determinar ms de dos constantes de
tiempo.
18
2.1.4 Respuesta a escaln para sistemas oscilatorios.
Es conocido que la funcin de transferencia de un sistema oscilatorio de segundo orden
tiene la forma:
2
n n
2
2
n
s 2 s
K
) s ( G
+ +
= (2.12)
estos sistemas se pueden identificar determinando grficamente los valores del pico de
sobrepaso M
p
y del perodo de las oscilaciones amortiguadas d, de su respuesta ante una
seal escaln en su entrada, Fig. 2.6.
Fig. 2.6 Respuesta a un escaln de un sistema oscilatorio de segundo orden
El problema consiste en estimar K, y . El valor de la ganancia K se determina segn
(2.1), a partir de M
p
puede calcularse el coeficiente de amortiguamiento mediante la
expresin:
2
1
p
e M
= (2.13)
Para obtener la frecuencia natural no amortiguada
n
se emplean las expresiones:
19
2
n
1
=
d
2
= (2.14)
siendo M
p
el pico de sobrepaso y d el perodo de oscilacin amortiguada.
Inicio
Lectura de los valores de la salida (ys) y del
peso del escaln (r)
Determinacin de
r
C
K
=
) ys ( valorfinal
) ys ( valorfinal ) ys ( max
M
p
=
) M ( log
) M ( log
p
2 2
p
2
+
=
d = t
segundo mximo
- t
primer mximo
Clculo de y
n
Fin
Fig. 2.7 Algoritmo de solucin para este mtodo
20
Para este mtodo se confeccion un programa Matlab y se prob con un ejemplo en
Simulink.
Los parmetros de la simulacin fueron los siguientes:
Un escaln unitario a la entrada
Un paso fijo de 0.15 unidades de tiempo
Tiempo de simulacin 25 unidades de tiempo
Mtodo de solucin: ode5 (Dormand-Prince)
Fig. 2.8 Esquema de simulacin
21
Fig. 2.9 Resultado de la identificacin
La precisin pudo haber sido mejor si se hubiera disminuido el tiempo de muestreo, que en
nuestro caso fue de 0.15 unidades de tiempo.
El listado del programa se encuentra en el anexo # 2
22
2.1.5 Mtodo de Strejc. Modelo de orden n.
Se usa para modelos del tipo:
n
) 1 Ts (
K
) s ( G
+
= , es decir, se deben estimar K, T y n a partir de la respuesta a un
escaln.
La ganancia K se determina como hasta ahora, en base a
r
c
) 1 s T )( 1 s T (
Ke
2 1
sL
+ +
n
sL
) 1 Ts (
Ke
+
(2.15)
24
0 1 2 3 4 5 6 7
-0. 2
0
0. 2
0. 4
0. 6
0. 8
1
1. 2
A
B
C
D t
c(t)
r(t)
Fig. 2.11 Determinacin del tiempo de retardo L.
El proceso de identificacin consta de dos partes:
- Determinacin del retraso de transporte L.
- Determinacin de los restantes parmetros por los mtodos descritos.
Para determinar L es posible:
a) Tomar el tiempo para el cual se obtiene 0.05c, es decir, el 5% de c.
b) Se traza la tangente en el punto de inflexin y se levanta una perpendicular en A hasta
C, de manera que AC = 2.718 AB. Por C se traza una paralela a la tangente hasta
encontrar D. Desde 0 hasta D es el retraso de transporte.
2.1.7 Mtodo del retraso puro efectivo o tiempo muerto efectivo
25
Es frecuente en la identificacin de procesos qumicos la existencia de sistemas cuya
respuesta a un estmulo escaln tiene generalmente la forma de S. En estos casos un mtodo
bastante efectivo y simple consiste en descomponer dicha respuesta en un retraso puro y un
sistema de primer orden.
De manera que se obtiene:
1 Ts
e k
) s ( G
s
p
+
=
(2.16)
0 20 40 60 80 100 120
0
0.2
0.4
0.6
0.8
1
1.2
1.4
T
Fig. 2.12 Obtencin de la constante de tiempo T a partir de la respuesta a escaln.
Como se sabe, la ganancia del sistema se obtiene con
e
s s
p
x
) 0 ( y ) ( y
k
=
Donde:
y
s
salida del sistema
x
e
amplitud del escaln en la entrada del sistema
La constante de tiempo T se obtiene grficamente de la tangente al punto de inflexin como
se muestra en la Fig. 2.12.
c(t)
t
26
2.2 Mtodos basados en la respuesta a un pulso
La utilizacin de un pulso como seal de prueba en la identificacin de sistemas, permite
lograr tiempos de experimentacin cortos sin introducir grandes perturbaciones en el
comportamiento del sistema objeto de estudio, a expensas de mayores exigencias en la
exactitud de las mediciones a realizar.
2.2.1 Mtodo de pulso para obtener la respuesta a escaln
Si se aplica a un sistema un pulso rectangular de duracin T
p
y se registra la respuesta a
dicho pulso, desplazando ste muchas veces un tiempo igual a T
p
y sumando las respuestas
resultantes, se obtiene la respuesta del sistema a un escaln; lo cual es posible ya que si se
considera el sistema lineal se cumple el principio de superposicin.
Obsrvese que se obtiene la respuesta del sistema a un escaln sin necesidad de aplicar esta
seal a su entrada, por lo que el sistema a identificar slo sufre la perturbacin
correspondiente al pulso rectangular.
Fig. 2.13 Grfica de la respuesta a un escaln a partir de la respuesta a un pulso.
27
Aunque tericamente un escaln es igual a la suma de un nmero infinito de pulsos
rectangulares, en la prctica es suficiente un nmero finito de stos hasta que la suma de las
respuestas desplazadas muestre un valor constante, el cual corresponde al valor a estado
estacionario producto del escaln equivalente. Si n es el nmero de respuestas que cumple
con lo anterior, tiene que ocurrir que n * T
p
sea mayor que el tiempo para el cual el sistema
alcanza prcticamente el estado estacionario, o sea, n * T
p
> 5 T; donde T es la mayor
constante de tiempo del sistema analizado.
Este mtodo es de los llamados no paramtricos, pues lo que se obtiene es la respuesta a
escaln en lugar de los parmetros del modelo. En el Departamento de Informtica de la
Facultad de Ing. Elctrica de la Universidad de Oriente existe un programa para este
mtodo.
Se confeccion un programa Matlab (anexo # 3) y se prob con un ejemplo en Simulink.
Fig. 2.14 Esquema confeccionado en Simulink
Los parmetros de simulacin fueron los siguientes:
Un pulso unitario de duracin 2 unidades de tiempo.
Tiempo de simulacin: 40 unidades de tiempo.
Paso fijo de 0.01 unidades de tiempo.
Mtodo de solucin ode5 (Dormand-Prince)
28
Fig. 2.15 Resultados de la identificacin
29
3. Mtodos analticos
Los mtodos analticos son los ms comunes y existe una gran variedad en la literatura. A
continuacin se presenta una muestra de ellos.
3.1 Mtodo de pulso para obtener la respuesta frecuencial
Se trata de un mtodo no paramtrico en el cual se descomponen las mediciones de la
entrada y la salida del sistema en pulsos rectangulares de igual ancho y, de esa forma,
calcular la funcin transferencial sinusoidal. Como se sabe de sta se pueden determinar las
relaciones de amplitud y fase, o sea, cuando se sustituye s = j en la funcin de
transferencia. Sea el siguiente sistema:
Sistema
(t) f(t)
Si f(t) y (t) son transformables por Fourier:
Entonces
+
+
=
dt e ) t (
dt e ) t ( f
) j ( F
t j
t j
(3.1)
Dado el hecho de que es muy difcil calcular la integral de la entrada y la salida, usaremos
un mtodo grfico para evaluar las mismas, descomponiendo los transcursos de la entrada y
la salida en pulsos rectangulares de igual ancho. Como suponemos que t 0, se pueden
expresar los lmites de las integrales de 0 a .
30
t
t k
t ) 2 / 1 k ( +
t ) 2 / 1 k ( t
f(t
)
Fig. 3.1. Descomposicin en pulsos ancho t de la respuesta del sistema
De manera que:
=
+
=
0
0 k
t
2
1
k
t
2
1
k
t j t j
dt e ) t ( f dt e ) t ( f (3.2)
Segn la grfica anterior f(kt) es el valor de la funcin en el k-simo intervalo, por lo que
la ecuacin anterior puede escribirse como:
=
+
=
0
0 k
t
2
1
k
t
2
1
k
t j t j
dt e ) t k ( f dt e ) t ( f (3.3)
y la integral se puede calcular segn:
+
+
+
=
t
2
1
k
t
2
1
k
t )
2
1
k ( j t )
2
1
k ( j
t j
t
2
1
k
t
2
1
k
t j
j
e e
dt e j
j
1
dt e (3.4)
por tanto:
31
=
+
=
0
0 k
t )
2
1
k ( j t )
2
1
k ( j
t j
j
e e
) t k ( f dt e ) t ( f (3.5)
finalmente quedara:
=
0 k
) t k ( j
0
2
t
j
2
t
j
t j
e ) t k ( f
j
e e
dt e ) t ( f (3.6)
Procesando la seal estmulo (cualquiera que sea su forma), siguiendo el procedimiento
anterior para igual valor de t y suponiendo n intervalos, se tiene:
=
=
=
n
1 k
) t k ( j
n
1 k
) t k ( j
e ) t k (
e ) t k ( f
) j ( F (3.7)
y sabiendo que ) sen( j ) cos( e
j
=
(3.8)
se puede escribir la ecuacin anterior segn:
= =
= =
=
n
1 k
n
1 k
n
1 k
n
1 k
) t k sen( ) t k ( j ) t k cos( ) t k (
) t k sen( ) t k ( f j ) t k cos( ) t k ( f
) j ( F (3.9)
simplificando esta ecuacin:
) ( jD ) ( C
) ( jB ) ( A
) j ( F
+
+
= (3.10)
que, para el anlisis frecuencial ser:
2 2
2 2
D C
B A
RA
+
+
= y
C
D
tan
A
B
tan
1 1
= (3.11)
El trmino t no debe exceder de 57 . 1
2
=
+ =
2
T
2
T
2
T
2 rc
dt ) t t ( c ) t ( r
T
1
lim ) t ( R (3.12)
esta funcin da una medida de la dependencia de la variable c en el instante t+t
2
y el valor
de la variable r en t.
La funcin de autocorrelacin de una variable aleatoria se designa por:
+ =
2
T
2
T
2
T
2 rr
dt ) t t ( r ) t ( r
T
1
lim ) t ( R (3.13)
esta funcin da una medida de la dependencia del valor de una variable en t+t
2
con respecto
al valor de la misma variable en t.
Se sabe que si r(t) y c(t) son las variables de entrada y salida de un sistema, cuya respuesta
a un impulso o funcin pesante es g(t), se puede plantear que:
=
1 1 1
dt ) t ( g ) t t ( r ) t ( c (3.14)
de manera que c(t+t
2
) est dada por:
33
+ = +
1 1 1 2 2
dt ) t ( g ) t t t ( r ) t t ( c (3.15)
Si se sustituye c(t+t
2
) en la correspondiente a la funcin de correlacin cruzada, se tiene
que:
+ =
2
T
2
T
1 1 1 2
T
2 rc
dt ) t ( g ) t t t ( r dt ) t ( r
T
1
lim ) t ( R (3.16)
y al intercambiar el orden de integracin se obtiene:
(
(
(
(
+ =
2
T
2
T
1 2
T
1 1 2 rc
dt ) t t t ( r ) t ( r
T
1
lim dt ) t ( g ) t ( R (3.17)
Se puede observar que la funcin entre corchetes corresponde a la funcin de
autocorrelacin de r(t) en t = t
2
t
1
, o sea, que la funcin de correlacin cruzada puede
escribirse:
= =
1 1 1 2 rr 2 rc
dt ) t ( g ) t t ( R ) t ( R (3.18)
Si se tiene que la seal de entrada aplicada a un sistema tiene funcin de autocorrelacin
proporcional a una funcin impulso, entonces, ) t ( k ) t ( R
2 2 rr
= y sustituyendo en la
expresin anterior, se tiene que:
=
1 1 1 2 2 rc
dt ) t ( g ) t t ( ) t ( kg R (3.19)
En esta expresin el integrando es diferente de cero solo cuando t
2
= t
1
, luego puede
escribirse:
=
1 1 2 2 2 rc
dt ) t t ( ) t ( kg ) t ( R (3.20)
34
y finalmente, dado que : 1 dt ) t t (
1 1 2
=
, se llega a:
) t ( kg R
2 rc
= (3.21)
Esto significa que si a un sistema se le aplica como estmulo una seal aleatoria con funcin
de autocorrelacin dada por ) t ( k , el resultado de calcular la funcin de correlacin
cruzada de la variable de salida y el estmulo correspondiente es proporcional a la respuesta
a impulso. Como esta funcin caracteriza al sistema se puede decir que hemos identificado
el sistema.
En sistemas industriales es posible, a veces, usar las propias perturbaciones aleatorias que
sufren las variables de entrada o generarlas.
3.3 Mtodo de correlacin cruzada. Forma discreta
Considrese un sistema con secuencia de ponderacin g(j) sometido a ruidos aditivos a la
salida. En este caso puede escribirse:
=
+ =
0 j
) i ( ) j i ( u ) j ( g ) i ( y (3.22)
La correlacin cruzada entre la salida y la entrada se define mediante:
=
+
=
n
n i
yu
) k i ( u ) i ( y
1 n 2
1
lim
n
) k ( (3.23)
Sustituyendo (3.22) en (3.23) se obtiene:
35
=
=
(
(
+
+
=
n
n i 0 j
yu
) i ( ) j i ( u ) j ( g ) k i ( u
1 n 2
1
lim
n
) k ( (3.24)
El trmino delante del corchete se puede pasar para adentro de la sumatoria en j:
) i ( ) k i ( u
1 n 2
1
lim
) j i ( u ) k i ( u
1 n 2
1
lim
) j ( g ) k (
n
n i
n
0 j
n
n i
n
yu
+
+
+
=
=
= =
(3.25)
Haciendo el cambio de variables t = i k, se obtiene:
) i ( ) k i ( u
1 n 2
1
lim
) k j t ( u ) t ( u
1 n 2
1
lim
) j ( g ) k (
n
n i
n
0 j
n
n i
n
yu
+
+ +
+
=
=
= =
(3.26)
Y como la autocorrelacin de la entrada se define como:
=
+
=
n
n i
uu
) k i ( u ) i ( u
1 n 2
1
lim
n
) k ( (3.27)
sustituyendo sta en la anterior se obtiene:
) k ( ) k j ( ) j ( g ) k (
u uu
0 j
yu
=
+ =
(3.28)
Si la entrada y el ruido no estn correlacionados, entonces
) k j ( ) j ( g ) k (
uu
0 j
yu
=
=
(3.29)
Si la entrada es un ruido blanco, entonces para toda k j se obtiene:
36
d ) 0 ( y 0 ) k (
uu uu
= = (3.30)
de manera que : ) k ( g d ) k (
yu
= (3.31)
Siendo d una constante, concretamente el peso del impulso de la autocorrelacin de la
entrada. Por lo que se demuestra que se puede encontrar la respuesta a impulso sin ms que
determinar la correlacin cruzada entre la entrada y la salida.
Este mtodo se puede aplicar en lnea. En efecto, considrese un sistema con entrada r(k) a
la cual se le aade un ruido blanco u(k). En este caso la entrada real que se aplica al sistema
es:
) k ( u ) k ( r ) k ( u
~
+ = de manera que ) k ( y ) k ( y ) k ( y
u r
+ = , sustituyendo esto en (3.23) se
obtiene:
= =
+
+
+
=
n
n i
u
n
n i
r yu
) k i ( u ) i ( y
1 n 2
1
lim
n
) k i ( u ) i ( y
1 n 2
1
lim
n
) k ( (3.32)
Dado el hecho que r(k) y u(k) no estn correlacionadas, tampoco lo estarn y
r
(k) y u(k), por
lo que se puede despreciar el primer trmino.
Si se consideran los valores a partir de i = 0, se obtiene:
=
+
=
n
0 i
yu
) k i ( u ) i ( y
1 n
1
) k ( (3.32)
Se confeccion un programa Matlab (anexo # 4), que contiene la funcin CRA que resuelve
el problema, y se prob con un ejemplo en Simulink.
Los parmetros de simulacin fueron los siguientes:
Muestreo de 0.1 unidades de tiempo
37
Mtodo de solucin ode5
Tiempo final 100 unidades de tiempo
Un escaln a la entrada de peso 1
5
s +4s+1
2
Si stema
Esc
Ent
Sal
Fig. 3.2 Sistema simulado
Los resultados obtenidos se muestran en la grfica siguiente:
0 5 10 15 20
0
0.05
0.1
Respuesta a impulso obtenida
0 5 10 15 20 25 30 35 40 45 50
0
2
4
Respuestas a escaln del sistema y el modelo
Respuesta del sistema
Respuesta del modelo
Fig. 3.3 Resultados de la identificacin
38
3.4 Mtodo de deconvolucin
Consideremos un sistema lineal, estacionario y estable, con una entrada y una salida, como
se muestra en la Fig. 3.4.
Sistema x(t)
z(t)
) t (
Fig. 3.4 Sistema considerado
Tomando como modelo del sistema la respuesta a impulso se puede escribir:
) t ( d ) t ( x ) ( h ) t ( z
s
T
0
+ =
(3.33)
donde T
s
es el tiempo de establecimiento del sistema, h() la respuesta a impulso y ) t ( el
ruido aditivo. El problema se trata ahora de estimar la respuesta a impulso a partir de las
mediciones de entrada y salida.
Como paso previo a la solucin del problema de estimacin de h(t) realicemos la
discretizacin de la ecuacin (3.33).
=
= + =
N
1 k
M .... , 2 , 1 j para ) j ( ) k ( h ] ) k j [( x ) j ( z (3.34)
donde:
M Nmero de puntos de las mediciones de la salida
T
M
= M - tiempo de observacin de la salida
N Nmero de puntos de la respuesta a impulso
T
s
= N - Tiempo de establecimiento
Ilustremos cmo se toman los valores de z y x, alrededor de un punto de operacin, que
aparecen en Fig. 3.5.
39
x
z
t
t
2 3
- -2
(1-N)
(M-N)
2
M
Fig. 3.5 Mediciones de la entrada x(t) y la salida z(t)
Teniendo en cuenta que es constante, la ecuacin (3.34) se puede escribir en una forma
ms sencilla:
=
=
N
1 k
k k j j
h x z para j = 1, 2, ....., M donde consideramos que = * x x (3.35)
Es importante aclarar que, en general, las mediciones son en desviaciones.
En forma desarrollada tenemos el siguiente sistema de ecuaciones:
N N 1 3 2 1 1 0 1
h x h x 2 h x h x z
+ + + + = L
N N 2 3 1 2 0 1 1 2
h x h x h x h x z
+ + + + = L (3.36)
N N 3 3 0 2 1 1 2 3
h x h x h x h x z
+ + + + = L
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
N N M 3 3 M 2 2 M 1 1 M M
h x h x h x h x z
+ + + + = L
y en forma matricial se obtiene:
z = Ah (3.37)
donde :
40
(
(
(
(
(
(
N M 3 M 2 M 1 M
N 3 0 1 2
N 2 1 0 1
N 1 2 1 0
N * M
x x x x
x x x x
x x x x
x x x x
A
L
M M M M M
L
L
L
(3.38)
con
| |
T
M 3 2 1
z z z z z L =
| |
T
N 3 2 1
h h h h h L =
Este sistema de ecuaciones se puede resolver de varias formas, por supuesto se recomienda
usar mtodos de mnimos cuadrados (Matlab resuelve por esta va usando h=A\z). Sin
embargo, si suponemos que tomamos las mediciones desde t = 0, que es el caso en el cual
se excita al sistema en el instante en que se toma como referencia el tiempo y
i
el estimado
de h
i
, el sistema de ecuaciones toma la forma sencilla:
1 0 1
x z =
2 0 1 1 2
x x z + =
3 0 2 1 1 2 3
x x x z + + = (3.39)
. . . . . . . . . . . . . . . . . . . . . . . .
n 0 2 2 n 1 1 n n
x x x z + + + =
L
Si bien es cierto que se recomienda el uso de mnimos cuadrados para la solucin de este
problema por la presencia de ruido en el sistema as como por el error de discretizacin, se
puede intentar (si el ruido es pequeo) la solucin de una forma muy sencilla:
0
1
1
x
z
=
0
1 1 2
2
x
x z
= (3.40)
0
2 1 1 2 3
3
x
x x z
=
. . . . . . . . . . . . . . . . . . .
41
0
1 i
1 j
j j i i
i
x
x z
|
|
\
|
=
=
. . . . . . . . . . . . . . . . . .
0
1 n
1 j
j j n n
n
x
x z
|
|
\
|
=
=
(3.41)
Por el mtodo de los mnimos cuadrados se necesitara primero crear la matriz A y luego
resolver el sistema z = Ah. El inconveniente que tiene es que la matriz A tiene el orden
igual a la cantidad de valores de la entrada, es decir, puede ser grande.
Los algoritmos de solucin en ambos casos son sencillos y evidentes. La experiencia es que
se obtienen buenos resultados con ambos procedimientos.
Se confeccion un programa Matlab (anexo # 5) y se prob con un ejemplo en Simulink.
Los parmetros de simulacin fueron los siguientes:
Muestreo de 0.5 unidades de tiempo
Mtodo de solucin ode5
Tiempo final 20 unidades de tiempo
Una seal en la entrada compuesta por una sinusoide de amplitud 0.2 y frecuencia 0.1
sumada a un escaln unitario.
5
s +2s+1
2
Transfer Fcn
Sinusoide Sal
Esc
Ent
Fig. 3.6 Esquema de simulacin
42
Fig. 3.7 Entrada y Salida del sistema
Los resultados del programa fueron los siguientes:
Transfer function: Transfer function:
0.2343 z + 0.2188 Sampling time: 0.1 0.000263 s + 5.003
--------------------- ----------------------
z^2 - 1.81 z + 0.8188 s^2 + 1.999 s + 0.9999
Est claro que se pudo aumentar la precisin disminuyendo el tiempo de muestreo.
43
0 2 4 6 8 10 12 14 16 18 20
0
0.2
0.4
0.6
0.8
1
1.2
1.4
1.6
1.8
2
Fig. 3.8 Respuesta a impulso del sistema
44
3.5 Mtodo de integracin gradual.
Para la obtencin del modelo matemtico que describe el comportamiento de un sistema, es
necesario excitar al mismo en su entrada con seales de naturaleza conocida. Algunas
seales muy tiles para este fin son aqullas que se originan y terminan en estado
estacionario, como las que se muestran en la figura 3.9.
Figura 3.9. Seales con origen y terminacin en estado estacionario.
Suponiendo estado estacionario antes y despus de las mediciones, entonces se cumplen las
siguientes condiciones iniciales para la entrada u(t) y la salida y(t).
0 ) 0 ( u ) 0 ( u ) 0 ( u ); ( u ) 0 ( u
0 ) 0 ( y ) 0 ( y ) 0 ( y ); ( y ) 0 ( y
) m (
) n (
= = = = =
= = = = =
L & & &
L & & &
(3.42)
Supongamos el siguiente modelo:
) t ( u ) t ( y a ) t ( y a ) t ( y a ) t ( y a
0 1
) 1 n (
1 n
) n (
n
= + + + +
& L (3.43)
El problema principal consistira en determinar los parmetros a
0
, a
1
, a
2
,,a
n
. El mtodo de
integracin gradual lo resuelve mediante la integracin. As, integrando la ecuacin (3.43)
de 0 a , suponiendo que vale (3.42), se obtiene:
= =
0
0
0
0
0
0
ydt
udt
a udt ydt a (3.44)
Integrando la ecuacin (3.42) primero de t a y luego de 0 a se obtiene a
1
:
45
= +
0 t
2
0 t
2
0
0 t
2
1
udt ydt a dt y a &
(
(
0 t 0 t
2 2
0
0
1
udt ydt a
ydt
1
a (3.45)
El clculo del resto de los coeficientes es similar. Por ejemplo, a
2
se puede calcular como
(
(
+ =
0 t t 0 t t 0 t
2
1
3
0
3
0
2
ydt a ydt a udt
ydt
1
a (3.46)
En la Figura 3.10 se presenta la interpretacin grfica de la seal de salida.
Figura 3.10 Interpretacin grfica de la seal de salida
En el caso en que la seal de entrada comience y termine en estado estacionario, pero que
no se cumpla que y(0)= y( ), u(0)= u( ), como son los casos que se muestran en la
Figura 3.11, se procede de la siguiente forma:
Figura 3.11. Seales de entradas para las cuales u(0) u( ).
46
De la ecuacin (3.43) se resta la ecuacin para estado estacionario y se obtiene
| | | | ) t ( u ) ( u ) t ( y ) ( y a ) t ( y a ) t ( y a ) t ( y a
0 1 2
) n (
n
= + + + + & & & L (3.47)
Luego de integrar de 0 a se puede obtener:
| | | |
) ( y
dt ) t ( u ) ( u dt ) t ( y ) ( y a
a
0 0
0
1
=
(3.48)
y, luego de una integracin doble se obtiene la ecuacin (3.49):
| | | | | |
|
|
\
|
=
0 t 0 0 t
2
1
2
0 2
dt ) t ( u ) ( u dt ) t ( y ) ( y a dt ) t ( y ) ( y a
) ( y
1
a
(3.49)
En el caso de que la seal de entrada fuera un escaln, el clculo de estos parmetros se
simplificara, pues
| |
=
0
0 dt ) t ( u ) ( u (3.50)
y
| |
=
0 t
2
0 dt ) t ( u ) ( u (3.51)
debido a que u( ) = u(t) para t>0. a
0
se determina directamente de la relacin:
) ( y
) ( u
a
0
= (3.52)
3.5.1 Integracin gradual para un conjunto de datos de entrada-salida.
Se supone el modelo:
'
1 0 0
'
1
' '
u b u b y a y a y + = + + (3.53)
Si se poseen k datos para el tiempo, as como los respectivos valores de entrada y salida,
despus de integrar de 0 a t
i
, i=1,,k, se obtiene:
47
) t ( y udt b udtd b ydtd a ydt a
) t ( y udt b udtd b ydtd a ydt a
k
t
0
k
k
t
0 0
k
t
0 0
1 0
k
t
0
0 1
1
t
0
1
1
t
0 0
1
t
0 0
1 0
1
t
0
0 1
= +
= +
M (3.54)
es decir,
(
(
(
(
=
(
(
(
(
(
(
(
(
(
(
(
) t ( y
:
:
) t ( y
b
b
a
a
udt udtd ydtd ydt
udt udtd ydtd ydt
k
1
1
0
0
1
t
0
t
0 0
t
0 0
t
0
t
0
t
0 0
t
0 0
t
0
k k k k
1 1 1 1
M M M M (3.55)
Con estructura matricial-vectorial:
A p = y (3.56)
donde A[k,m]; p[m,l]; y[k,l]. Las columnas de la matriz A se pueden calcular con la ayuda
de la matriz de integracin J segn:
(
(
(
(
=
(
(
(
(
(
(
(
(
) t ( y
:
:
) t ( y
ydt
:
:
ydt
k
1
k
t
0
1
t
0
J (3.57)
Para simplificar la notacin supondremos ahora:
y(i) = y(t
i
).
Para la integral doble vale:
48
(
(
(
(
=
(
(
(
(
(
(
(
(
=
(
(
(
(
(
(
(
(
) k ( y
:
:
) 1 ( y
ydt
:
:
ydt
dt yd
:
:
dt yd
2
k
t
0
1
t
0
k
t
0 0
1
t
0 0
J J (3.58)
3.5.2 Matriz de Simpson.
La estructura de la matriz de integracin se obtiene de la siguiente forma. Se divide el
transcurso de las seales de entrada y salida en segmentos iguales de tiempo t = t
i+1
-t
i
(i=0,1,2,........k). Al aplicar la llamada Regla de Simpson se obtiene, por ejemplo, para la
seal de salida y:
( )
( )
( ) ) k ( y 4 .... ) 4 ( y 8 ) 3 ( y 16 ) 2 ( y 8 ) 1 ( y 16 ) 0 ( y 4
12
t
ydt
) 2 ( y 4 ) 1 ( y 16 ) 0 ( y 4
12
t
ydt
) 2 ( y ) 1 ( y 8 ) 0 ( y 5
12
t
ydt
t k
0
t 2
0
t
0
+ + + + + +
+ +
(3.59)
Sobre la base de estas relaciones y sabiendo que y(0) = 0, es posible establecer la matriz de
integracin J segn:
(
(
(
(
(
(
=
1 8 9 16 8 16
4 16 8 16
1 8 9 16
4 16
1 8
12
t
y y y y y
k 4 3 2 1
J
(3.60)
La elaboracin de las filas de la matriz de Simpson demanda un tratamiento diferenciado
para el caso de las filas pares e impares. Dado que el mtodo de Simpson asume que el
intervalo de integracin sea subdivido en un nmero par k de sub-intervalos de integracin,
en el caso de que se disponga de un nmero impar k-1 de sub-intervalos, se necesita hacer
49
uso de una frmula de integracin auxiliar que, combinada con la de Simpson, proporcione
un resultado cuya precisin est en correspondencia con la precisin dada por las frmulas
estndar de integracin de Simpson.
De acuerdo con lo expresado, para la obtencin de las filas pares de la matriz de Simpson
se emplea la siguiente frmula:
( ) ( ) | | ) ( y h
180
t t
y 4 y y y 8 y y y 16 y 4
12
h
dt ) t ( y
iv
4 0 k
k 2 k 4 2 1 k 3 1 0
k
t
0
t
+ + + + + + + =
L L
| |
k 0
t , t (3.61)
donde y(t):
expresin genrica, que admite hasta cuarta derivada, para las
ordenadas de entrada y salida del proceso que se identifica
t
0
y t
k
: instantes de tiempo inicial y final del registro de las ordenadas de las
entrada y salida del proceso que se identifica.
h =t= t
i+1
t
i:
magnitud del paso de integracin.
y
i
: ordenadas de la seal de entrada y salida del proceso en
experimentacin.
) ( y
iv
:
cuarta derivada de la expresin genrica y(t) evaluada en algn punto
del intervalo de integracin [t
0,
t
k
].
: ) ( y h
180
t t
iv
4 0 k
:
trmino de error de la frmula de Simpson.
Para los elementos de las filas impares de la matriz de Simpson se utiliza la frmula
auxiliar:
| | ) ( y
24
h
y y 8 y 5
12
h
dt ) t ( y
' ' '
4
2 k 1 k k
k
t
h
k
t
+ =
(3.62)
donde:
) ( y
24
h
' ' '
4
: trmino de error de la frmula auxiliar.
Esta frmula resulta de integrar al polinomio de interpolacin inverso de Newton de tercer
50
orden en correspondencia con lo estipulado para obtener la frmula de integracin cannica
de Simpson que es bsica para obtener la ecuacin (3.42). El clculo de la integral para el
caso de las filas impares se efecta segn la expresin:
= =
k
t
h
k
t
k
t
0
t
h
k
t
0
t
dt ) t ( y dt ) t ( y dt ) t ( y (3.63)
Sustituyendo (3.61) y (3.62) en (3.63), se obtiene:
( ) ( ) | |
k 2 k 4 k 4 2 1 k 3 k 3 1 0
h
k
t
0
t
y y 9 y .. y y 8 y 8 y .. y y 16 y 4
12
h
dt ) t ( y + + + + + + + + + + =
(3.64)
Para obtener la primera fila de la matriz de Simpson se parte de las siguientes expresiones:
| |
2 1 0
2
t
0
t
y 4 y 16 y 4
12
h
dt ) t ( y + + =
(Frmula auxiliar) (3.66)
de cuya resta se obtiene:
| |
2 1 0
h
2
t
0
t
y y 8 y 5
12
h
dt ) t ( y + =
(3.67)
Las ecuaciones (3.61), (3.64) y (3.67) permiten formar los elementos para las filas pares e
impares de la matriz de Simpson requerida por el mtodo de integracin gradual.
51
Figura 3.12. Algoritmo de clculo.
En el caso de trabajar con un modelo de la forma:
u b y a y
0 0
'
= + (3.68)
el sistema de ecuaciones quedara de la forma siguiente:
(
(
(
(
=
(
(
(
(
(
(
(
(
) t ( y
:
:
) t ( y
b
a
udt ydt
udt ydt
k
1
0
0
t
0
t
0
t
0
t
0
k k
1 1
M M (3.69)
Para el caso en que se desee trabajar con un modelo de 2do. orden de la forma:
52
'
1 0 0
'
1
' '
u b u b y a y a y + = + + (3.70)
El sistema sera:
(
(
(
(
=
(
(
(
(
(
(
(
(
(
(
(
) t ( y
:
:
) t ( y
b
b
a
a
udt udtd ydtd ydt
udt udtd ydtd ydt
k
1
1
0
0
1
t
0
t
0 0
t
0 0
t
0
t
0
t
0 0
t
0 0
t
0
k k k k
1 1 1 1
M M M M (3.71)
El programa desarrollado (Anexo # 6), una vez resuelto el sistema de ecuaciones, segn sea
el caso, y teniendo como resultado los valores de los coeficientes, visualiza en la pantalla
los grficos correspondientes a la salida medida y a la salida calculada a partir de la seal
de excitacin aplicada en la entrada al modelo obtenido. Se visualiza la desviacin estndar
del error entre los valores de la seal de salida medida y la obtenida a travs de la
identificacin. El usuario tiene la posibilidad de ajustar el modelo cambiando los
coeficientes calculados con el objetivo de que la respuesta del modelo sea lo ms cercana
posible a la salida medida.
Conjuntamente con el programa al que se hizo referencia, se cre la funcin INTGR con el
objetivo de aadirla al Toolbox de Identificacin de sistemas dinmicos que ofrece el
MATLAB. Esta funcin es compatible con el paquete de funciones ya existentes,
entregando los resultados en la estructura estndar conocida como matriz THETA. Esta
matriz contiene informacin acerca de la estructura del modelo, parmetros estimados,
precisin de la estimacin, as como la matriz de la covarianza de los parmetros
calculados.
Ejemplos de uso del programa.
A continuacin se tratan algunos ejemplos con el objetivo de comprobar la eficacia de este
mtodo.
53
Figura 3.13. Seal de excitacin.
La seal de excitacin en todos los casos analizados fue la siguiente:
>
<
=
1 t , 1
1 t 0 , t
0 t , 0
) t ( u
y su representacin grfica se muestra en la Figura 3.13.
Sistema de 1er. orden.
La funcin de transferencia empleada fue:
2 s
2
) s ( F
1
+
=
Este sistema fue excitado con la seal de entrada vista anteriormente, obtenindose 50
juegos de valores de entrada-salida cada 0,05 s.
54
Figura 3.14. Respuesta del modelo calculado y salida real del sistema de primer orden.
Luego se realiz la identificacin obteniendo la funcin de transferencia:
9932 , 1 s
9945 , 1
) s ( F
+
=
con una desviacin estndar de 2,1544e-6.
Sistema de 2do. Orden.
Se tom como ejemplo el siguiente sistema de segundo orden con races complejas
conjugadas
5 s 2 s
1 s 2
) s ( F
2
2
+ +
+
=
obtenindose como resultado la funcin de transferencia:
9888 , 4 s 0063 , 2 s
9943 , 0 s 9981 , 1
) s ( F
2
2
+ +
+
=
con una desviacin estndar de 2,7374e-4. La respuesta se muestra en la Figura 3.15.
55
Figura 3.15 Salida real y del modelo para un sistema de segundo orden.
Comentarios finales.
La aplicacin del mtodo en sistemas de 1er, 2do y 3er rdenes permite obtener
resultados satisfactorios, obtenindose errores promedio muy pequeos.
Se obtienen de forma directa los coeficientes del modelo continuo de una planta.
Es necesario una seleccin correcta del tiempo de muestreo.
En el caso que se trabaje con seales muy ruidosas se recomienda darle un tratamiento
preliminar o filtrado de la informacin que se va a procesar, de forma tal que los datos
que sern analizados reflejen de la forma ms exacta posible el comportamiento real del
sistema.
3.6 Mtodo de integracin mltiple
El sistema, motivo de estudio, es lineal, invariante, continuo y de parmetros concentrados,
de una entrada y una salida.
y(t)
Proceso
U(t) x(t)
v(t)
Fig. 3.16 Sistema considerado
56
u(t) seal de entrada
x(t) seal de salida ideal
y(t) seal de salida influida por el ruido
v(t) seal de ruido
Todas las seales son funciones continuas, reales, de variables continuas en t <0, >.
Supondremos el modelo del sistema de la siguiente forma:
n
n
2
2 1 0
n
n
2
2 1
p a ... p a p a a
p b .... p b p b 1
) p ( G
+ + + +
+ + + +
= (3.72)
Como es evidente, siempre es posible llegar a esta forma de la funcin de transferencia.
La estructura general del modelo se presenta en la figura 3.17.
X n (t)
X 1 (t)
X 1 (0)
X n-1 (t)
X n-1 (0)
X n (o)
u(t)
x(t)
b n
b n-1
b 1
- a o -a 1
-a n-1
1/a n
Fig. 3.17 Estructura general del modelo
La ecuacin diferencial que representa el comportamiento dinmico del sistema sera:
57
) t ( x a
dt
) t ( x d
a ) t ( u
dt
) t ( du
b
dt
) t ( u d
b
o
n
n
n 1
n
n
n
L L + = + + + (3.73)
La expresin para x
1
(t) para un paso de x = 0 a x = T sera:
+ + + +
=
+
+ + + =
T
0
T
0
T
0
n
0
2
2 n 1 n
T
0
T
0
T
0
n 2
2 n 1 n
T
0
1 n
n 2 1 1
) ( d ) ( x a ) ( d ) ( x a d ) ( x a
d ) ( u d ) ( u b d ) ( u b
)! 1 n (
T
) 0 ( x T ) 0 ( x ) 0 ( x ) T ( x
L L
L L
L
L
(3.74)
De manera que podramos escribir, para simplificar,
+ + + =
T
0
1 n
n 2 1 1
)! 1 n (
T
) 0 ( x T ) 0 ( x ) 0 ( x ) T ( x L L
+ + + =
T 2
0
1 n
n 2 1 1
)! 1 n (
) T 2 (
) 0 ( x T 2 ) 0 ( x ) 0 ( x ) T 2 ( x L L (3.75)
M
+ + + =
nT
0
1 n
n 2 1 1
)! 1 n (
) nT (
) 0 ( x nT ) 0 ( x ) 0 ( x ) nT ( x L L
O de forma matricial
(
(
(
(
(
(
(
(
(
(
(
(
(
+
(
(
(
(
(
(
(
(
(
(
(
(
(
(
=
(
(
(
(
(
(
(
(
nT
0
T 2
0
T
0
n
2
1
1 n
1 n
1
1
1
nT ) 0 ( x
T ) 0 ( x
) 0 ( x
n . . n 1
. . . . .
. . . . .
2 . . 2 1
1 . . 1 1
) nT ( x
) T 2 ( x
) T ( x
L
M
M
M
L
L
M
M
M
M
M
M
(3.76)
58
El problema consiste ahora en eliminar los estados x
1
, x
2
, , x
n
del sistema de ecuaciones.
La primera matriz del lado derecho es la conocida matriz cuadrada de orden n de
Vandermond, cuyos elementos se calculan segn V
i,j
= i
(j-1)
.
Supongamos ahora que p = [p
1
p
2
p
3
p
n
] es la primera fila de V
-1
, entonces
p.V = [1 0 ... 0]
y, luego de multiplicar la ecuacin matricial anterior por p tenemos:
(
(
(
(
(
(
(
(
(
(
+ =
(
(
(
(
nT
0
2T
0
T
0
1
1
1
p (0) x
(nT) x
(T) x
p
L
M
L
L
M
M
(3.77)
De la estructura del sistema podemos escribir:
x
1
(t) = a
n
x(t) - b
n
u(t)
de lo que sigue:
| | | |
(
(
(
(
(
(
(
=
(
(
(
(
(
(
nT
0
T
0
n 1 n n 1 n
p
) nT ( u
) 0 ( u
p p 1 b
) nT ( x
) 0 ( x
p p 1 a
L
M
L
M L M L (3.78)
Los elementos de p se pueden encontrar segn:
59
( )
1 C C
)! i n ( ! i
! n
C
n .... 1 i C p
0
n
n
n
i
n
i
n
1 i
1 i
= =
=
=
=
Finalmente el modelo completo o terminado sera:
{ {
+ +
+ =
= =
= =
= = =
) d ) ( u C ) 1 ( b ( ) d ) ( x C ) 1 ( a (
d ) ( u C ) 1 ( ) iT ( u C ) 1 ( b ) iT ( x C ) 1 ( a
j n
1 n
1 j
n
1 i
j n
T
0
i
n
i
j
j n
j n
iT
0
1 n
0 j
n
0 i
i
n
i
j
n
1 i
iT
0
n i
n
i i
n
n
0 i
i
n
i
n
n
0 i
i
n
L L
L
(3.79)
De este modo, hemos obtenido una ecuacin con los coeficientes del modelo dinmico
como incgnitas. Ahora bastara tomar diferentes intervalos [0, T] y obtener tantas
ecuaciones como quisiera y luego resolver por mnimos cuadrados.
60
4. Algunos elementos sobre el toolbox de Matlab
El Matlab 5.3 ofrece dos toolbox sobre identificacin: uno temporal y otro frecuencial.
Pretendemos mostrar algunos pocos elementos que puedan ser tiles acerca del primero sin
abordar la interfaz correspondiente por ser muy simple de usar.
4.1 Modelo lineal general
El modelo lineal general de un sistema puede ser descrito simblicamente segn:
y(t)
G
u(t) x(t)
e(t)
Fig. 4.1 Representacin simblica del sistema
y = Gu + He (4.1)
que dice que la salida medida y es debida a la entrada medida u y al ruido e. Donde G
denota las propiedades dinmicas del sistema, es decir, cmo la salida se forma desde la
entrada. Para sistemas lineales se llama funcin de transferencia entre la entrada y la salida.
H refiere las propiedades del ruido y se le llama tambin modelo del ruido, y describe cmo
est formada la perturbacin en la salida.
4.1.1 Representacin polinomial de la funcin de transferencia
Una forma til de representar G y H es en funciones racionales de q
-1
. El modelo
paramtrico ARX (Auto-Regressive eXogen) corresponde a:
) q ( A
) q ( B
q ) q ( G
nk
=
) q ( A
1
) q ( H = (4.2)
donde B y A son polinomios en el operador de retraso q
-1
:
61
na
na
1
1
q a ... q a 1 ) q ( A
+ + + = (4.3)
1 nb
nb
1
2 1
q b ... q b b ) q ( B
+
+ + + =
Los trminos na y nb dan cuenta de los rdenes de los polinomios A(q) y B(q)
respectivamente y nk es el nmero de retrasos de la entrada a la salida. Usualmente se
escribe el modelo de la siguiente forma:
) t ( e ) nk t ( u ) q ( B ) t ( y ) q ( A + = (4.4)
4.1.2 Modelo ARX
De manera explcita el modelo ARX se expresa segn:
) 1 nb nk t ( u b ... ) 1 nk t ( u b ) nk t ( u b ) na t ( y a ... ) 1 t ( y a ) t ( y
nb 2 1 na 1
+ + + + = + + +
(4.5)
Esto da lugar a un sistema de ecuaciones donde las incgnitas a y b sern los coeficientes
de la funcin de transferencia discreta y que se obtienen segn:
Mnimos Cuadrados: Minimiza la suma de los cuadrados de la parte derecha menos la parte
izquierda con respecto a los coeficientes a y b. Para esto se usa la funcin arx del Matlab.
Variable Instrumental: Se determinan a y b de manera tal que el error entre las partes
derecha e izquierda no correlaciona con alguna combinacin lineal de la entrada. Para esto
se usa la funcin iv4.
4.1.3 Modelo ARMAX
62
En la estructura ARMAX (AutoRegressive Moving Average eXogen) se introduce el
polinomio C(q) al modelo ARX:
) t ( e ) q ( C ) nk t ( u ) q ( B ) t ( y ) q ( A + = (4.6)
donde C se puede expresar segn:
nc
nc
1
1
q c ... q c 1 ) q ( C
+ + + = (4.7)
Esto da lugar a un sistema de ecuaciones donde las incgnitas son los coeficientes del
modelo discreto, cuyas soluciones (de este modelo y los posteriores) se obtienen por
prediccin del error con el Mtodo de Mxima Verosimilitud. Para esto se usa la funcin
armax.
4.1.4 Modelo OE
La estructura Output Error (OE) se presenta de forma siguiente:
) t ( e ) nk t ( u
) q ( F
) q ( B
) t ( y + =
(4.8)
con
nf
nf
1
1
q f ... q f 1 ) q ( F
+ + + = (4.9)
4.1.5 Modelo BJ
La llamada estructura de Box Jenkins est dada por:
) t ( e
) q ( D
) q ( C
) nk t ( u
) q ( F
) q ( B
) t ( y + = con
nd
nd
1
1
q d ... q d 1 ) q ( D
+ + + = (4.10)
63
Todos estos modelos son casos particulares de la estructura general:
) t ( e
) q ( D
) q ( C
) nk t ( u
) q ( F
) q ( B
) t ( y ) q ( A + = (4.11)
donde:
La estructura AR corresponde con nb = nf = nc = nd = 0 y adems u(t) = 0.
La estructura ARX se obtiene haciendo nd = nc = nf = 0.
La estructura ARMAX corresponde a nf = nd = 0.
La estructura Output Error (OE) con na = nc = nd = 0.
El modelo Box Jenkins corresponde a na = 0
De las funciones existentes en Matlab solo mencionaremos algunas y en sus formas ms
usadas para el clculo de la matriz THETA (se puede tener ms informacin ejecutando
help theta en Matlab) que provee toda la informacin necesaria para la identificacin).
AR
Para la estructura AR se pueden usar ambos mtodos:
% n es el orden del modelo AR
th = ar(y, n) % se calcula segn mnimos cuadrados
th = ivar(y, n) % se calcula segn variable instrumental
ARX
th = arx(z,[na nb nk]) % z es una matriz z = [y u], siendo y la salida y u la entrada
th = iv4(z,[na nb nk])% Por el mtodo de Variable Instrumental
Para sistemas realimentados se recomienda usar variable instrumental.
ARMAX
th = armax(z, [na nb nc nk])
OE
th = oe(z, [nb nf nk])
64
BJ
th = bj(z, [nb nc nd nf nk])
4.1.6 Ejemplo de sistema con una entrada una salida (SISO)
Supondremos ruido a la entrada.
Con ayuda del Simulink del Matlab realizaremos la identificacin del sistema lineal:
1 s 5 s s
1 s
) s ( G
2 3
+ + +
+
=
Fig. 4.2 Esquema Simulink
Se realiz una simulacin en Matlab/Simulink, segn se muestra en la fig 4.2
Como entrada se le aplica un escaln 2u(t-2) y se toma un intervalo de tiempo fijo (fixed
step size) de 0.1 unidades de tiempo y un tiempo de simulacin de 20 u. Se le adiciona
65
ruido a la entrada con el bloque Band-Limited White Noise (Noise Power = 0.5, seed =
23341) a travs de una funcin de transferencia:
1 s 10
5
+
La entrada u y la salida y se llevan al workspace del MATLAB.
Fig. 4.3 Entrada del sistema
Probemos con un modelo ARX con na = nb = 3 y nk = 1. Para esto se prepar el programa
arxpl (Anexo # 7).
66
Fig. 4.4 Respuesta de la identificacin
Nota: A este programa se le podran adicionar clculo de errores por diferentes mtodos.
Por otro lado se obtiene la expresin en polos y ceros con el objetivo de investigar si el
orden propuesto no es mayor que el real, pues en el caso de que sea mayor se vera la
posibilidad de cancelacin y se podra probar con un orden reducido.
La comparacin de las respuestas del modelo y el sistema se aprecia en la figura 4.4.
Ejemplo2. Supondremos ruido a la salida
Supondremos el mismo sistema adicionndole el mismo ruido a la salida, segn se muestra
en la figura 4.5, pero a travs de la funcin de transferencia:
67
1 s s
05 . 0
2
+ +
Fig. 4.5 Sistema con ruido a la salida
Probemos con el mismo programa arxpl.
Fig. 4.6 Respuestas del modelo y del sistema
68
Un anlisis del error medio nos dira que es realmente pequeo e igual a 0.0115.
Sin embargo pudiramos probar con la estructura ARMAX que tiene ms en cuenta el
ruido.
Usaremos ahora el mismo programa arxpl cambiando th = arx (z,[3 3 1]) por th = armax
(z,[3 3 3 1]).
Fig. 4.7 Identificacin usando la estructura armax
69
sta se ve mejor. El error medio es de 0.01.
Se pudiera probar el resto de las estructuras existentes en Matlab cambiando slo la lnea
th = arx (z,[3 3 1]) del programa arxpl.
4.2 Identificacin de sistemas multivariables (MIMO)
Los mtodos presentados en el epgrafe anterior tienen la posibilidad de ser utilizados en
sistemas multivariables. Es importante explicar cmo seran na, nb y nk en estos casos.
na es una matriz cuadrada cuyo orden coincide con el nmero de salidas.
nb y nk son matrices donde el nmero de filas corresponde con el nmero de salidas y el
nmero de columnas con el nmero de entradas.
Mostraremos algunos ejemplos de identificacin de sistemas multivariables con diferentes
seales de entradas.
Ejemplo 1.1. Se trata de un sistema multivariable con dos entradas y dos salidas, descrito
por las ecuaciones en el espacio de estado siguientes:
Bu Ax ' x + =
Du Cx y + =
con
(
=
4 25
1 0
A
(
=
1 0
1 1
B
(
=
1 0
0 1
C
(
=
0 0
0 0
D
Este sistema, en el dominio s, se puede representar de la forma siguiente:
G
11
(s)
G
12
(s)
G
21
(s)
G
22
(s)
u
1
u
2
y
1
y
2
+
+
+
+
70
Fig. 4.8 Diagrama de bloques del sistema
Donde:
25 s 4 s
4 s
) s ( G
2
11
+ +
+
=
25 s 4 s
5 s
) s ( G
2
12
+ +
+
=
25 s 4 s
25
) s ( G
2
21
+ +
=
25 s 4 s
25 s
) s ( G
2
22
+ +
=
Se trata, en particular, de un sistema de fase no mnima.
Se realiz la simulacin con ayuda del Simulink del Matlab segn el siguiente esquema para
obtener los datos necesarios para la identificacin:
Fig. 4.9 Esquema de simulacin
Los parmetros de simulacin fueron los siguientes:
Tiempo total 10 u
Tiempo de muestreo 0.02 u
Mtodo de solucin Ode5 (Dormand-Prince)
u
1
y u
2
Escaln unitario
71
Se realiz la identificacin con el programa mimopllsim (Anexo # 8) y se obtuvieron lo
siguientes resultados:
Fig. 4.10 Comparacin de las salidas del modelo y del sistema
El criterio de error fue el error medio absoluto, es decir, el valor medio de los valores
absolutos de las diferencias entre ambas salidas.
El error en la salida 1 fue de 0.0016231 u.
El error en la salida 2 fue de 0.0067574 u.
Se obtuvo la matriz A del modelo:
(
=
7720 . 9 9307 . 9
0693 . 16 7720 . 13
A
diferente a la del sistema, sin embargo, ambas matrices tienen iguales valores propios hasta
la cuarta cifra decimal.
72
Ejemplo 1.2. Mostraremos tambin los resultados del programa utilizando el mismo
sistema con entrada ruido blanco de banda limitada (Band-Limited White Noise).
Fig. 4.11 Esquema del mismo sistema con entrada ruido
Fig. 4.12 Seal utilizada para las entradas u
1
y u
2
Los parmetros de simulacin fueron los siguientes:
Tiempo total 10 u
Tiempo de muestreo 0.1 u
Mtodo de solucin Ode5 (Dormand-Prince)
73
Se utiliz la misma seal de ruido blanco de banda limitada para ambas entradas
simultneamente con los siguientes parmetros:
Potencia del ruido 1
Tiempo de muestreo 0.1
Semilla (seed) 23341
Se realiz la identificacin con el mismo programa mimopllsim y se obtuvieron los
siguientes resultados:
Fig. 4.13 Comparacin de las salidas del modelo y del sistema
El error en la salida 1 fue de 4.1934e-015 u.
El error en la salida 2 fue de 1.758e-014 u
Se obtuvo la matriz A del modelo:
(
=
1787 . 5 3499 . 3
6521 . 21 1786 . 9
A
pero con los mismos valores propios que la matriz del sistema hasta la cuarta cifra decimal.
74
Ejemplo 2. Se presenta otro sistema de dos entradas y dos salidas. Para la identificacin de
este sistema se elabor el programa mimopllsim22 (Anexo # 9).
Fig. 4.14 Esquema del sistema
Los parmetros de simulacin fueron los siguientes:
Tiempo total 10 u
Tiempo de muestreo 0.1 u
Mtodo de solucin Ode5 (Dormand-Prince)
Se utiliz la misma seal de ruido blanco de banda limitada para ambas entradas
simultneamente con los siguientes parmetros:
Potencia del ruido 1
Tiempo de muestreo 0.1
Semilla (seed) 23341
75
Se realiz la identificacin con el mismo programa mimopllsim, y se obtuvieron los
siguientes resultados:
Fig. 4.15 Comparacin de las salidas del modelo y el sistema
El error para la salida 1 es 0.00025017
El error para la salida 2 es 0.0002736
Las matrices del espacio de estado del modelo obtenido pueden conocerse si se teclea
A,B,C,D en la ventana de comandos, luego de haberse ejecutado el programa.
Ejemplo 3. Se presenta ahora un sistema de tres entradas y dos salidas. Se utilizar el
mismo programa que se us para el ejemplo anterior, pero modificando nb y nk, pues ahora
son matrices de orden 2x3.
76
El sistema utilizado fue el siguiente:
Fig. 4.16 Esquema en Simulink del sistema utilizado
Los parmetros de simulacin fueron los siguientes:
Tiempo total 10 u
Tiempo de muestreo 0.1 u
Mtodo de solucin Ode5 (Dormand-Prince)
Se utiliz la misma seal de ruido blanco de banda limitada para ambas entradas
simultneamente con los siguientes parmetros:
Potencia del ruido 1
Tiempo de muestreo 0.1
Semilla (seed) 23341
77
Se realiz la identificacin con el mismo programa mimopllsim, y se obtuvieron los
siguientes resultados:
Fig. 4.17 Comparacin de las salidas del modelo y el sistema
El error entre las salidas 1 del sistema y el modelo es 0.0007237
El error entre las salidas 2 del sistema y el modelo es 1.5415e-013
De igual forma las matrices del espacio de estado del modelo obtenido pueden conocerse si
se teclea A,B,C,D en la ventana de comandos, luego de haberse ejecutado el programa.
Ejemplo 4. Se presenta ahora un sistema de tres entradas y tres salidas como se muestra. Se
utilizar el mismo programa que se us para el ejemplo anterior, pero modificando nb y nk,
pues ahora son matrices de orden 3x3 y aumentando la grfica de la salida tres.
78
Fig. 4.18 Esquema Simulink del sistema de tres salidas y tres entradas
Los parmetros de simulacin fueron los siguientes:
Tiempo total 35 u
Tiempo de muestreo 0.1 u
Mtodo de solucin Ode5 (Dormand-Prince)
Se utiliz la misma seal de ruido blanco de banda limitada para ambas entradas
simultneamente con los siguientes parmetros:
Potencia del ruido 1
Tiempo de muestreo 0.1
Semilla (seed) 23341
79
Se realiz la identificacin con el mismo programa mimopllsim, y se obtuvieron los
siguientes resultados:
Fig. 4.19 Comparacin de las salidas del modelo y el sistema
El error entre la salida 1 del sistema y el modelo es 0.0021686.
El error entre la salida 2 del sistema y el modelo es 0.0061046.
El error entre la salida 3 del sistema y el modelo es 0.0032803.
De igual forma las matrices del espacio de estado del modelo obtenido pueden conocerse si
se teclea A,B,C,D en la ventana de comandos, luego de haberse ejecutado el programa.
80
5. Identificacin de Sistemas mediante Redes Neuronales Artificiales.
La utilizacin de la Red Neuronal (RN) ha venido a ser, en los ltimos aos, un campo de
gran desarrollo y rpido crecimiento en aplicaciones de la Inteligencia artificial (IA). La
RN se ha empleado principalmente para detectar los atributos de objetos y sus relaciones, y
es posible encontrar una amplia bibliografa al respecto.
En este captulo vamos a centrarnos en ver una descripcin del uso de la RN como un
mtodo de identificacin para sistemas dinmicos lineales y no lineales.
La principal ventaja est en la explotacin de su uso en sistemas no lineales que hasta ahora
no han podido ser resueltos por tener una solucin muy compleja, ya sea por la dificultad
de implementar algoritmos complicados o por ser sistemas con parmetros desconocidos.
Los procedimientos clsicos de identificacin de sistemas que utilizan los datos histricos
de la planta, estn basados en asumir como verdaderas varias hiptesis respecto al sistema.
Dentro de estas hiptesis se pueden resaltar la linealidad, ser invariantes en el tiempo,
conocer el orden del sistema (ARMAX), las constantes de tiempo del sistema en respuesta
a un escaln (FIR), etc.; condiciones asumidas localmente que luego son extrapoladas
globalmente a todas las condiciones de operacin.
Los requerimientos para una RN son menores en comparacin con los procedimientos
clsicos de identificacin. Comparando ambos procedimientos desde el punto de vista de
entrada y estructura, observamos que el usuario debe especificar los datos para el proceso
de entrada-salida idnticamente en ambos tipos de procedimientos.
En cuanto a la estructura, en los procedimientos clsicos el usuario debe especificar la
caracterstica de la estructura de la relacin entre las entradas y las salidas, a veces muy
complejas, mientras que para la identificacin usando las RN slo se debe especificar la
topologa de la red.
La RN no intenta asumir ninguna estructura de la relacin entrada-salida, la red crea la
81
relacin de las entradas a las salidas basndose en los ejemplos proporcionados durante el
entrenamiento. Lo que se le pide a la RN en este caso, es que internamente consiga un
modelo capaz de reproducir unos valores numricos que se asemejen a los valores de algn
sistema fsico.
La RN basada en el perceptron multicapa, con al menos una capa oculta y una funcin de
activacin sigmoidal puede aproximar una gran diversidad de funciones no lineales. Los
parmetros de la RN son ajustados para modelar el comportamiento de una funcin dada,
semejante a cualquier proceso iterativo de estimacin de parmetros.
La capacidad de aproximar funciones y la habilidad de aprender la relacin funcional entre
las variables, son dos de las ms importantes propiedades de la RN que son muy tiles para
la identificacin de sistemas. En la prctica, con la utilizacin de la RN se han logrado
buenos resultados y un rpido aprendizaje en aplicaciones de Reconocimiento de Patrones
(clasificacin), pero en aplicaciones de representacin de datos la RN es ms sensible y a
menudo requiere mayor cantidad de datos y tiempo para el entrenamiento.
Desafortunadamente, el problema de la identificacin de parmetros y su generalizacin es
un problema sobredimensionado, ya que un conjunto finito de ejemplos de una funcin son
consistentes o pueden coincidir con los puntos de un nmero infinito de otras funciones,
muchas de las cuales no tengan nada que ver con el problema original.
Si la red es capaz de descubrir una funcin que se comporta correctamente como el
conjunto de ejemplos, se debe comprobar, adems, si es capaz de generalizar la solucin
ante entradas no conocidas. Si la red logra una buena generalizacin del problema, es decir,
que si para esos valores de los parmetros se obtiene un error cuadrtico (entre los valores
de la red y los valores deseados) mnimo y aceptable, entonces ser una indicacin de que
ha descubierto una importante estructura subyacente que contribuir a la comprensin y
resolucin del problema.
82
5.1 Introduccin a las Redes Neuronales.
El cerebro humano hace uso de dos mtodos diferentes de procesamiento de informacin.
Uno es el procesamiento inferencial secuencial y lgico en trminos de smbolos. El otro
es el procesamiento paralelo, el cual es realizado por las dinmicas de elementos de proceso
interactuando mutuamente. Este mtodo usa una representacin de la informacin
distribuida con habilidad de aprendizaje. La Neurocomputacin es uno de los mtodos ms
importantes de procesamiento de informacin que usa las interacciones dinmicas
paralelas de estos elementos de proceso modificables.
Esta disciplina tecnolgica trata de sistemas de procesamiento de informacin paralelos,
distribuidos y adaptables, que desarrollan capacidad de proceso, en respuesta a la
exposicin a un entorno de informacin. Los sistemas ms empleados en
Neurocomputacin son las Redes Neuronales Artificiales (Artificial Neural Networks), las
cuales desarrollan transformaciones entre objetos.
Se puede definir una Red Neuronal Artificial (RNA) como una estructura de proceso de
informacin paralela y distribuida, formada por Elementos de Proceso (EP) o neuronas,
interconectados a travs de canales unidireccionales llamados conexiones y que tiene
asociadas reglas de aprendizaje. Cada EP tiene una salida nica que se distribuye sobre un
nmero de conexiones bilaterales.
El proceso de informacin interno a cada EP conocido tambin como modelo de neurona,
puede definirse de forma arbitraria, pero ha de ser totalmente local, es decir, depender
solamente de los valores de las seales que llegan al EP y de valores almacenados en su
memoria local. Grupos de EP pueden ser interconectados en una variedad de maneras para
formar RNA. A la organizacin que forman los EP en la red se le conoce como topologa
de la red. La mayora de las redes tienen sus EP distribuidos en conjuntos disjuntos
llamados capas, cuyos EP tienen la misma funcin de transferencia generalmente. Muchas
RNA incluyen una capa de entrada en la que cada EP recibe exactamente una entrada
proveniente del exterior y simplemente la distribuyen al resto de la red. Por tanto, no tienen
83
funcin de transferencia.
Una RNA est caracterizada fundamentalmente por tres aspectos.
La topologa de la red .
Las conexiones de los EP de procesos.
La estrategia para los patrones de aprendizaje o entrenamiento.
Algunas topologas bsicas.-
a) Red simple
Se utilizan n neuronas de entrada y se conectan con m neuronas de salida mediante caminos
pesados. No existe conexin entre las neuronas. Cada neurona de salida calcula una
respuesta, y la salida de la red ser un vector de n componentes. Si se combina con
unidades de asociacin resulta una arquitectura similar a la del Perceptron.
y
1
y
m
x
1
x
2
x
n
Fig 5.1 Topologa de una red simple
b) Redes multicapas
Es una de las topologas ms poderosas. En ella se ordena el conjunto de elementos de
procesamiento (neuronas) en niveles, de modo que los enlaces se establecen desde unidades
en el nivel y a unidades en el nivel j (i < j), por lo que la informacin fluye
unidireccionalmente. Esta arquitectura se conoce como dirigida adelante (Feedforward).
Tpicamente existe una capa de unidades de entrada, una o ms capas ocultas de neuronas,
y una capa de salida. Esta topologa es la base del Perceptron Multicapas.
84
Flujo de Seales
+
y
pM
y
p1
w
j,k
w
i,j
K
J
I
x
pN
x
p2
x
p1
Retropropagacin del error
-
Capa de
Entrada
Capa
Oculta
Capa de
Salida
Fig. 5.2 Topologa de una red multicapas
c) Topologa del modelo interactivo
Se tiene un conjunto de n neuronas, las cuales se conectan completa y mutuamente, es
decir, todas las unidades sirven como entrada y como salida; cada neurona se conecta a las
n-1 restantes mediante caminos pesados. Esta es la base de la red de Hopfield.
Fig 5.3 Modelo interactivo
Algunos modelos de neuronas
El modelo de la neurona define el comportamiento de la misma al recibir una entrada para
producir una respuesta; a esta respuesta se le conoce como nivel de activacin. Este se
calcula en dos etapas: Primero se obtiene la entrada total a la neurona, la cual es la suma del
producto del peso de cada enlace por el valor de la informacin que fluye por l, ms un
trmino que indica la predisposicin de la neurona a reaccionar(sesgo).
85
h
j
= w x
ij i
i
+ sesgo
j
En la segunda etapa se calcula el nivel de activacin utilizando una funcin cuyo
argumento es la entrada total a la neurona (h
j
). Entre las funciones ms utilizadas tenemos:
a) modelo lineal
La activacin de la neurona es igual a la entrada total.
b) modelo lineal con umbral
El nivel de activacin toma un valor binario en dependencia del signo de la entrada total.
Ejemplo de este modelo es la funcin signo.
c) modelo continuo
La salida est relacionada no linealmente con la entrada. Una de las funciones ms usadas
es la sigmoide.
s
i =
i
h
e
+ 1
1
Note que esta funcin transforma el valor de la entrada total a valores reales entre 0 y 1.
Otras funciones de activacin son:
tangente hiperblica: S
i
= (exp(h
j
) - exp(h
j
))/(exp(h
j
) + exp(h
j
)) , -1 <= S
i
<= 1
gausiana: S
i
= exp(-h
j
2
/-
2
)
86
5.2 Algoritmo de aprendizaje
El objetivo del aprendizaje es el proceso de clculo de los pesos de las conexiones. Cinco
rasgos caracterizan este paradigma:
el algoritmo usado
el criterio de parada
la forma en que los datos de entrenamiento se presentan a la red
el tipo de aprendizaje
la regla de aprendizaje
Varios algoritmos de aprendizaje han sido usados. Entre ellos, el gradiente descendente
(tambin llamado algoritmo de retropropagacin de errores o backpropagation). Otro
mtodo usado es el del gradiente conjugado. Hay varios mtodos basados en bsquedas
aleatorias, y finalmente se ha propuesto un algoritmo gentico.
Un criterio de mnimos cuadrados se calcula generalmente con la diferencia entre los
valores de salida de la red y los valores de salida del conjunto de entrenamiento.
Min Ep =
i
i
Ns
e
2
1 =
donde e
i
= d - y, d - valor deseado
Ns - Cantidad de neuronas de salida
Min E =
ij
i
Ns
j
Np
e
2
1 1 = =
Np - Cantidad de patrones
La convergencia se asume cuando el criterio de mnimos cuadrados o su razn de cambio
es menor que una tolerancia prefijada o cuando el tiempo de aprendizaje ha finalizado.
Durante el aprendizaje, el conjunto de datos de entrenamiento generalmente se presenta
repetidamente a la red, y los pesos son ajustados en cada iteracin hasta que se obtiene una
solucin. Este es el procedimiento usado en las redes feedforward. En otros tipos de redes
el conjunto de datos se puede presentar una sola vez.
87
Sistemas Dinmicos
Para la identificacin de una planta dinmica, donde la principal caracterstica es ser
dependiente del tiempo, se asume que el sistema fsico tiene una estructura matemtica
general expresada como una funcin lineal o no lineal F(y, u ) de los valores actuales y de
los valores pasados de sus entradas y salidas, como puede ser la descrita por la siguiente
ecuacin en diferencias:
y(t) = F[y(t-1),y(t-2),...,y(t-n),u(t),u(t-1),...,u(t-m)]
Para distinguir las arquitecturas de RN que incluyan alguna representacin del tiempo las
denominaremos Redes Neuronales Dinmicas. La principal diferencia es que las RN para la
identificacin de sistemas dinmicos utilizan un lazo de realimentacin(feedback) con las
salidas anteriores de la planta, considerndolas como otras entradas adicionales a la red,
adems de las entradas ya existentes.
La identificacin de los parmetros de la planta se basar en una RN de tres capas (entrada,
oculta y salida) y un bloque adicional con las seales de retardos que se aaden como
entradas.
El aumento de las unidades de retardo posibilita una rpida convergencia y mejorar la
precisin de los parmetros estimados por la red. Ahora bien en este punto se debe llegar a
un compromiso ya que ampliar la red implica un mayor nmero de operaciones y por tanto
se necesitar una mayor capacidad de clculo.
Los dos esquemas tradicionales de identificacin para sistemas dinmicos, llamados serie
paralelo y paralelo, son representados en las figuras 5.4 y 5.5 respectivamente.
y
m
(k+1)
y
p
(k+1)
+
e(k)
-
u(k)
Planta
RN
Fig. 5.4 Modelo Serie - Paralelo
88
Este esquema es tambin denominado teacher forcing y puede ser usado con cualquier
algoritmo de aprendizaje. Es muy til al inicio del aprendizaje para que los valores de la red
no se alejen mucho y converja ms rpido.
5.3 Identificacin con Redes Neuronales en el ambiente de Matlab.
Para la identificacin de sistemas utilizando Redes Neuronales en ambiente Matlab es
necesario disponer de un conjunto de datos que deben ser obtenidos por va experimental o
mediante algn modelo de Simulink. Aqu se utilizar esta ltima va para demostrar la
metodologa de trabajo.
Primero se utiliza el programa que genera los datos de salida de un sistema ante una entrada
de tipo seudo aleatoria. El programa se lista a continuacin:
% Programa GeneraDatos1
% permite generar los datos que luego sern empleados
% en el entrenamiento de la red.
ts = input('Tiempo de muestreo = ');
tstop = 10 % Tiempo final de simulacin
DatosEntr1
% La planta est representada por un sistema de primer orden
% y se generan la entrada, la entrada retrasada un paso, la
% salida y la salida retrasada un paso.
sim('DatosEntr1')
% Se simula el modelo Simulink DatosEntr1
Se seleccion para este ejemplo un tiempo de muestreo ts = 0.1 u
y
m
(k+1)
y
p
(k+1)
+
e(k)
-
u(k)
Planta
RN
Fig. 5.5 Modelo Paralelo
89
Fig. 5.6 Esquema Simulink para generar los datos del ejemplo 1
Se usa para generar los datos un generador de seales con una seal aleatoria de amplitud 3
y frecuencia de 1 Hz. Los retrasos de transporte utilizan el valor de ts como tiempo de
retraso (time delay).
Una vez generados los datos se puede utilizar el siguiente programa en Matlab para
entrenar la Red Neuronal.
% Programa EntrenaRed1
% Genera una red feedforward con 3 entradas, 20 neuronas en la capa
% oculta y una neurona de salida. Las neuronas ocultas trabajan con
% una funcin de activacin tansig y la de salida con purelin. El
% mtodo de entrenamiento empleado es el Levenberg - Marquart.
% ts tiempo de muestreo.
red = newff([-2 2;-2 2;-1 1],[15,1],{'tansig','purelin'},'trainlm');
% Se usa la entrada, la entrada retrasada un paso y la salida retrasada
% un paso. Se pueden obtener con GeneraDatos1
p = [u'; u1';y1'];
% Definicin de algunos parmetros de aprendizaje
red.trainParam.show = 50; % Mostrar cada 50 iteraciones
red.trainParam.goal = 0.0001; % Error de salida
red.trainParam.epochs = 100; % Total de pocas
% Entrenar la Red Neuronal.
red = train(red,p,y');
yred = sim(red,p); % Se simula la red entrenada
figure(1)
90
plot(yred)
hold
plot(y','red')
gensim(red,-1)
% Genera el bloque Simulink que representa la Red Neuronal
% entrenada y con el -1 se indica que se puede modificar ts.
Con el siguiente esquema Simulink (Fig. 5.7) se verifica el trabajo de la Red Neuronal
entrenada ante diferentes seales de entrada y se puede observar si la misma identifica
correctamente o no el sistema bajo estudio.
En este esquema es preciso indicar que en el bloque para obtener la seal escaln se toman
como parmetros el valor final igual a 0.6 y el tiempo de muestreo ts. Adems el bloque
que corresponde a la Red Neuronal es el que se obtuvo con el programa EntrenaRed1. De
igual forma es preciso sealar que los parmetros para la simulacin deben ser los
siguientes: tiempo de parada (tstop), tamao del paso (ts) y se recomienda que se utilice el
mismo mtodo de solucin, que en este caso fue Runge-Kutta 4to. Orden.
Fig. 5.7 Esquema Simulink para verificar el modelo de Red Neuronal
91
Fig. 5.8 Respuesta de la planta y la red ante un escaln
92
6. Algunas recomendaciones para la identificacin
Algunas recomendaciones tiles para una estrategia de identificacin pueden ser:
En la etapa de anlisis debe tenerse en cuenta que aunque el sistema sea no lineal,
puede ser til adoptar un modelo lineal con el objetivo de estudiar su
comportamiento ante variaciones relativamente pequeas sobre un punto de trabajo.
Pueden utilizarse hiptesis simplificadoras para describir el comportamiento de un
sistema mediante un modelo de orden reducido ms fcil de identificar y luego de
utilizar.
En sistemas lineales con mltiples entradas, es posible aplicar el principio de
superposicin, considerando cada salida como suma de salidas elementales
correspondientes a una sola entrada.
Ante la disyuntiva de identificar un modelo de una variable o multivariable, puede
influir el hecho de que el modelo sea de parmetros constantes o variables; para
identificar un modelo de parmetros constantes puede ser necesario considerar
distintas perturbaciones como entradas suplementarias.
En el anlisis debe tenerse en cuenta la determinacin del tiempo de duracin de
las experiencias, porque pueden existir parmetros que varen en funcin de
perturbaciones lentas no medibles, o aparecer no linealidades que no estn
presentes en un transitorio alrededor de un punto de trabajo.
Dependiendo de los resultados obtenidos en la etapa experimental, puede ser
necesario volver a considerar la etapa del anlisis para modificar la hiptesis de
partida.
Debe analizarse si el sistema cuyo modelo ser identificado, trabajar a lazo
cerrado o a lazo abierto, caso este que requiere mayor precisin.
93
Una alternativa de la etapa de anlisis es imponer el orden del sistema, otra es
dejarlo libre a determinar segn las medidas.
Es importante considerar el ruido presente. Ante seales muy ruidosas es
recomendable filtrar la informacin que se va a procesar, para que los datos
analizados reflejen de forma ms exacta el comportamiento real del sistema.
Al enfrentar un problema de complejidad evidente, pudiera ser conveniente trabajar
inicialmente con un modelo simplificado que aporte una idea general de la solucin
y finalmente con un modelo ms complejo que aporte resultados ms completos.
Es importante validar la concordancia entre los resultados del anlisis del modelo
matemtico obtenido, y los resultados del estudio experimental del sistema fsico.
Debe tenerse presente que un modelo lineal de parmetros concentrados, puede ser
vlido operando a baja frecuencia y no serlo a frecuencias altas, ya que las
propiedades despreciadas de los parmetros distribuidos pueden volverse un factor
importante en el comportamiento dinmico del sistema.
Si se dispone de suficientes mediciones confiables del sistema a identificar, puede
utilizarse una parte para la obtencin del modelo y el resto para la validacin del
mismo.
La caracterizacin de las seales (entrada, estado, salida) de un sistema dinmico,
tomadas directamente de datos de registro del sistema en operacin normal,
permite la adicin de informacin fenomenolgica sobre el sistema para compensar
las regiones de informacin escasa, a fin de identificar un modelo de un tipo
determinado, que acte como modelo global y robusto del sistema en todo el
espacio de estado posible.
94
Utilizar un escaln como seal de prueba para la identificacin de sistemas tiene
como ventaja la sencillez de la generacin de dicha funcin, y como desventaja que
introduce una alteracin relativamente grande en el comportamiento del sistema; en
procesos industriales esto no siempre es permisible.
La utilizacin de un pulso como seal de prueba en la identificacin de sistemas
permite tiempos de experimentacin cortos, en consecuencia, exige mayor
exactitud de las mediciones a realizar.
En el Mtodo de pulso para obtener la respuesta a escaln, los errores en la
determinacin de la respuesta a un pulso se van acumulando, lo que exige medios
de medicin precisos.
Las seales de prueba escaln y pulso slo pueden lograrse en la prctica de forma
aproximada, a los efectos de identificar un sistema, esta aproximacin es adecuada,
si la constante de tiempo de dichas seales es menor que la dcima parte de la
menor constante de tiempo que se requiere determinar en la identificacin.
Cuando se va a identificar un sistema utilizando seales sinusoidales, es necesario
determinar adecuadamente la gama de frecuencias y la amplitud de las seales, la
aplicacin de varias seales de diferentes frecuencias hace que el tiempo de
experimentacin sea mucho mayor.
Es recomendable trazar las grficas de los datos de que se dispone para la
identificacin y analizarlas cuidadosamente; es posible que se trate de una
respuesta a escaln y se podr inferir el orden y la ganancia; es posible observar no
linealidades, por ejemplo, diferentes respuestas a diferentes niveles; si se observa
que todo el intervalo de trabajo no contiene informacin, se puede escoger slo una
parte de ste; permite detectar la presencia de los llamados puntos locos para su
posterior eliminacin.
95
La aplicacin del Mtodo de integracin gradual a sistemas de 1ro., 2do. y 3er.
rdenes permite obtener resultados satisfactorios, obtenindose errores promedio
muy pequeos; si las seales disponibles son muy ruidosas se recomienda darle
tratamiento preliminar o filtrado, de modo que reflejen ms exactamente el
comportamiento real del sistema.
A partir de un modelo paramtrico es inmediato obtener las curvas de respuesta de
frecuencia, y un modelo no paramtrico puede parametrizarse empleando
coeficientes tales como mrgenes de fase y de ganancia, ancho de banda, etc.
96
Anexo # 1
%Mtodo de Oldenbourg Sartorius
%Calcula la pendiente y el punto de la tangente
%a la respuesta
%Deben tomarse del workspace la salida,
%la entrada y el tiempo
%La seal de salida debe almacenarse en ys
%El tiempo en t
%La seal de entrada en us
ys=y.signals.values;
t=y.time;
us=u.signals.values;
tm=t(2)-t(1);%Intervalo de muestreo
long=length(t);
tf1=t(long);%valor final de t
i=0;
tp=-tm;
p=1;
while p>0
tp=tp+tm;
i=i+1;
pendi(i)=ys(i+1)-ys(i);
pendi(i+1)=ys(i+3)-ys(i+2);
p=pendi(i+1)-pendi(i);
%disp(p);
end
ti=tp;%ste es el valor de t donde ocurre el punto de inflexin
disp(['El punto de inflexin ocurre en t= ',num2str(ti)]);
%pause
tc=0:tm:tp;
longtc=length(tc);
yp=ys(longtc);
pend=(ys(longtc)-ys(longtc-1))/tm;
%Determinaremos ahora Tc
Tc1=(ys(long)-yp+pend*ti)/pend;
Tc=Tc1-ti;
%Clculo de Ta
Ta0=(ys(1)-yp+pend*ti)/pend;
Ta=Tc1-Ta0;
%Creacin de la funcin T2/TA=F(T1/TA)
T1TA=0:0.1:1;
T2TA=[1 0.73 0.57 0.44 0.34 0.25 0.18 0.12 0.07 0.03 0];
f=polyfit(T1TA,T2TA,6);%Se crea un polinomio de grado 6
Tg=[];
for i=0:0.01:1,
Tg= [Tg polyval(f,i)];
end
abc=0:0.01:1;
a=0;
j=0;
t2tag=[];
hf=figure('NumberTitle','off','ToolBar','figure',...
'Name','Identificacin por el Mtodo de Olderbour Sartorius');
for i=0:0.01:1,
j=j+1;
t2tag=[t2tag Tc/Ta-i];
97
if (Tc/Ta-i)>Tg(j)
a=1;
end
end
if a==0
plot(abc,t2tag,abc,Tg);
grid;
warndlg('No hay interseccin','Advertencia ')
else
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 20.25 63.75 140.5 19.5 ], ...
'String',['El punto de inflexin ocurre en t= ',num2str(ti)], ...
'Style','text', ...
'Tag','StaticText2');
axes('Position',[ 0.06 0.35 0.40 0.57 ])
plot(abc,t2tag,'b',abc,Tg,'r');
grid;
axis([0 1 0 1]);
title('Grfica de OS')
Tg1r=Tg-t2tag;
Tg1=find(abs(Tg1r)==min(abs(Tg1r)));
T1Ta=Tg(Tg1);
T2Ta=abc(Tg1);
T1=Tg(Tg1)*Ta;
T2=abc(Tg1)*Ta;
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 20.25 53.75 100.5 19.5 ], ...
'String',['T1 = ',num2str(T1)], ...
'Style','text', ...
'Tag','StaticText2');
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 20.25 43.75 100.5 19.5 ], ...
'String',['T2 = ',num2str(T2)], ...
'Style','text', ...
'Tag','StaticText2');
num=[(max(ys)-ys(1))/us(long)];
den=[T1*T2 T1+T2 1];
sal=us(1)*step(num,den,t);
axes('Position',[ 0.53 0.35 0.4 0.57 ])
plot(t,ys,'b',t,sal,'r');
grid;
axis([0 max(t) 0 max(sal)+0.1*max(sal)]);
title('Respuestas del Sistema y el Modelo')
legend('Resp. del sistema', 'Resp. del modelo',4);
%*******************************************
98
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[271.5 70.25 120 15], ...
'String','Funcin de Transferencia', ...
'Style','text', ...
'Tag','StaticText7');
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[306 50 45 15], ...
'String',poly2str(num,'s'), ...
'Style','text', ...
'Tag','StaticText6');
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 267.75 38 132 15 ], ...
'String','_____________________________', ...
'Style','text', ...
'Tag','StaticText9');
h1 = uicontrol('Parent',hf, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[275.25 15.5 114.75 15], ...
'String',poly2str(den,'s'), ...
'Style','text', ...
'Tag','StaticText8');
%*******************************************
end
99
Anexo # 2
%Programa para la identificacin de sistemas subamortiguados con entrada escaln
ys=y.signals.values;
t=y.time;
ue=u.signals.values;
int=t(2)-t(1);
long=length(ys);
k=ys(long)/ue(1); %Ganancia del sistema
%Se calcula el sobrepaso
Mp=(max(ys)-ys(long))/ys(long);
%Se calcula el amortiguamiento
delta=sqrt(log(Mp)^2/(pi^2+log(Mp)^2));
b=find(ys==max(ys));
%Bsqueda del perodo de osc.
ysf=ys(b:long);%Tomo los puntos de ys del sobrepaso en adelante
c=find(ysf==min(ysf));%Encontramos el punto de mnimo despus del sobrepaso
longysf=length(ysf);
ysfm=ysf(c:longysf);%Es el vector desde el mnimo en adelante
d=find(ysfm==max(ysfm));%Es el otro mximo
per=(c+d)*int;
frec=(2*pi)/per;
frecnat=frec/sqrt(1-delta^2);
%La funci{on de transferencia
num=[k*frecnat^2];
den=[1 2*delta*frecnat frecnat^2];
g=tf(num,den);
%******************************************************
h0 = figure('ToolBar','figure','Position',[ 100 51 560 477 ],...
'NumberTitle','off','Name',....
'Identificacin de un sistema subamortiguado dada su respuesta a escaln');
posa = [0.07719298245614036 0.3418803418803419 0.8508771929824561 ....
0.5598290598290598];
ha=axes('position',posa);
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[151.5 86.25 120 15], ...
'String','Funcin de Transferencia', ...
'Style','text', ...
'Tag','StaticText7');
h1 = uicontrol('Parent',h0, ...
100
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[186 66 45 15], ...
'String',poly2str(num,'s'), ...
'Style','text', ...
'Tag','StaticText6');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 147.75 54 132 15 ], ...
'String','_____________________________', ...
'Style','text', ...
'Tag','StaticText9');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[135.25 31.5 140.75 15], ...
'String',poly2str(den,'s'), ...
'Style','text', ...
'Tag','StaticText8');
%*********************************************************
plot(t,ys,'r');
hold on
ysm=ue(1)*step(g,t);
plot(t,ysm,'b');
grid;
legend('Respuesta del sistema','Respuesta del modelo');
101
Anexo # 3
%Convierte respuesta a un pulso a respuesta a escaln
clf
veces=40;
ys=y.signals.values;
ue=u.signals.values;
t=y.time;
im=t(2)-t(1);
dondecero=find(ue==0);
Ancho=dondecero*im;
indcero=min(dondecero);
ystotal=[ys; zeros(veces*indcero,1)];
t=[t; (max(t+im):im:(length(ystotal)-1)*im)'];
p=1;
for i=1:veces
ystotalA=[zeros(indcero*p,1);ys;zeros((veces-p)*indcero,1)];
ystotal=ystotal+ystotalA;
plot(t,ystotal);
hold on
p=p+1;
end
%La respuesta a escaln est en ystotal
plot(t,ystotal,'r');
102
Anexo # 4
%Identificacin por el mtodo de correlacin
clf
ys=y.signals.values;
ue=u.signals.values;
t=y.time;
tm=t(2)-t(1);
ir=cra([ys ue],450,10,0);
close
Lir=length(ir);
t1=0:tm:(Lir-1)*tm;
h0 = figure('ToolBar','figure','Position',...
[ 100 51 560 477 ],'NumberTitle','off','Name',....
'Identificacin de un sistema por el mtodo de corelacin');
axes('position',...
[0.119642857142857 0.61625 0.775 0.310267857142857]);
plot(t1,ir)
title('Respuesta a impulso obtenida')
axis([0 t1(end)/2 0 1.1*max(ir)])
[n,d]=imp2sys(ir);
sysd=tf(n,d,tm);
sysc=d2c(sysd)
ym=step(sysc,t);
axes('position',...
[0.123214285714286 0.205714285714286 0.775 0.321428571428571]);
plot(t,ys,'r',t,ym,'b')
axis([0 t(end)/2 0 1.1*max(ys)])
legend('Respuesta del sistema','Respuesta del modelo')
title('Respuestas a escaln del sistema y el modelo')
%***************************************************************
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[151.5 40.25 120 15], ...
'String','Funcin de Transferencia', ...
'Style','text', ...
'Tag','StaticText7');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 114.75 17.25 192.75 24.75 ], ...
'String',poly2str(sysc.num{1},'s'), ...
'Style','text', ...
'Tag','StaticText6');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 147.75 18 132 15 ], ...
'String','_____________________________', ...
'Style','text', ...
103
'Tag','StaticText9');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[135.25 5.5 140.75 15], ...
'String',poly2str(sysc.den{1},'s'), ...
'Style','text', ...
'Tag','StaticText8');
%*******************************************************************
104
Anexo # 5
%Mtodo de deconvolucin por mnimos cuadrados
ue=u.signals.values;
ys=y.signals.values;
t=y.time;
clf
tm=t(2)-t(1);
%Hasta aqu pasamos al workspace las mediciones
%de la entrada y la salida.
int=t(2)-t(1);
n=length(ue);
a=zeros(n);
for i=1:n,
k=i;
for j=1:i,
a(i,j)=ue(k);
k=k-1;
end
end
%Hemos formado la matriz A
h=a\ys;
h=h/int;
plot(t,h);
grid
[n,d]=imp2sys(h);
sysd=tf(n,d,int)
sysc=d2c(sysd)*tm
105
Anexo # 6
%Programa principal de Integracin gradual
orden=input('Teclee el orden ');
us=u.signals.values;
ys=y.signals.values;
t=y.time;
Tsamp=t(2)-t(1);
z=[ys us];
[Ncap,nz]=size(z);
nu=nz-1;
if nz>Ncap,error('Los datos deben organizarse en un vector columna')
return,end
if nu~=1,error('Esta funcin solo trabaja con sistemas SISO')
return,end
num=[];den=[];
maxsize=50000;
if orden ==2
[a1 a0 b0 b1]=anaintg2(us,ys,Tsamp);
num=[b1 b0];
den=[1 a1 a0];
end
if orden ==1
[a0,b0]=anaintg1(us,ys,Ncap,Tsamp);
num=b0;
den=[1 a0];
end
funtrans=tf(num,den)
Ressys=lsim(funtrans,us,t);
plot(t,Ressys,'b')
hold on
plot(t,ys,'r')
grid
text(mean(t),max(ys)/2,'azul ... Resp. del sistema')
text(fix(mean(t)),max(ys)/2-max(ys)/5,'rojo ... Resp. del modelo')
function [A,B]=anaintg1(Ut,Yt,n,Delta)
Matriz_U = Ut;
Matriz_Y = Yt;
n=length(Yt);
if rem(n,2)>0,
Matriz_U=[Matriz_U;Matriz_U(length(Matriz_U))];
Matriz_Y=[Matriz_Y;Matriz_Y(length(Matriz_Y))];
n=n+1;
end,
Matriz_J=simpsom(n);
Matriz_J = (Delta/12)*Matriz_J;
Matriz_1C = Matriz_J*Matriz_Y;
Matriz_2C = Matriz_J*Matriz_U*(-1);
Matriz_P=[Matriz_1C Matriz_2C];
Matriz_Y= (-1)*Matriz_Y;
Matriz_Coef=Matriz_P\Matriz_Y;
A = Matriz_Coef(1);
B = Matriz_Coef(2);
106
function [A,B,C,D]=anaintg2(Ent,Sal,Delta)
Matriz_U=Ent;
Matriz_Y=Sal;
n=size(Sal,1);
if rem(n,2)>0,
Matriz_U=[Matriz_U;Matriz_U(length(Matriz_U))];
Matriz_Y=[Matriz_Y;Matriz_Y(length(Matriz_Y))];
n=n+1;
end,
Matriz_J=simpsom(n);
Matriz_J = (Delta/12)*Matriz_J;
Matriz_J2= Matriz_J*Matriz_J;
Matriz_1C = Matriz_J*Matriz_Y;
Matriz_2C = Matriz_J2*Matriz_Y;
Matriz_3C = (-1)*(Matriz_J2*Matriz_U);
Matriz_4C = (-1)*Matriz_J*Matriz_U;
Matriz_P = [Matriz_1C Matriz_2C Matriz_3C Matriz_4C];
Matriz_T= (-1)*Matriz_Y;
MatC = Matriz_P\Matriz_T;
A=MatC(1);
B=MatC(2);
C=MatC(3);
D=MatC(4);
function [MatJ]=simpsom(n)
matriz_J=zeros(n,n-1);
hw = processbar(0,'Identificando...');
tn=n+n;
in=n;
for i=1:n,
if rem(i,2)
for j=1:i,
if rem(j,2)
matriz_J(i,j)=16;
else
matriz_J(i,j)=8;
end
end
else
for j=1:i,
if rem(j,2)
matriz_J(i,j)=16;
else
matriz_J(i,j)=8;
end
end
end
processbar(i/tn)
end
for i=1:n,
for j=1:n,
if rem(i,2)
matriz_J(i,i+1)=-1;
matriz_J(i,i)=8;
107
if i-1
matriz_J(i,i-1)=9;
end
else
matriz_J(i,i)=4;
end
end
processbar((in+1)/tn)
in=in+1;
end
close(hw);
matriz_J(:,n)=[];
Columna1=4*ones(n,1);
Columna1(1)=5;
MatJ=[Columna1 matriz_J];
108
Anexo # 7
%Se hace la identificacin con el toolbox de Matlab
%Estructura ARX
ys=y.signals.values;
ue=u.signals.values;
t=y.time;
im=t(2)-t(1);
n=length(ys);
z=[ys ue];
th=arx(z,[3 3 1]);
th=sett(th,im);
tc=thd2thc(th);
[num,den]=th2tf(tc);
ft=tf(num,den);
zp=zpk(ft);
ym=lsim(ft,ue,t);
ema=mean(abs(ym-ys));
h0 = figure('ToolBar','figure','Position',[ 100 51 560 477 ],...
'NumberTitle','off','Name',....
'Obtencin del modelo de un sistema por el mtodo ARX');
posa = [0.0771929824561 0.341880341880 0.850877192982 0.559829059829];
ha=axes('position',posa);
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 13.5 84 135 19.5 ], ...
'String',['El error medio es ' num2str(ema)], ...
'Style','text', ...
'Tag','StaticText3');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 205.5 88.5 120 15 ], ...
'String','Funcin de Transferencia', ...
'Style','text', ...
'Tag','StaticText7');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 134.25 65.25 257.25 15.75 ], ...
'String',poly2str(num,'s'), ...
'Style','text', ...
'Tag','StaticText6');
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 147.75 48.75 234.75 20.25 ], ...
'String','__________________________________________', ...
'Style','text', ...
'Tag','StaticText9');
109
h1 = uicontrol('Parent',h0, ...
'Units','points', ...
'BackgroundColor',[0.8 0.8 0.8], ...
'ListboxTop',0, ...
'Position',[ 116.25 33.75 288.75 15 ], ...
'String',poly2str(den,'s'), ...
'Style','text', ...
'Tag','StaticText8');
plot(t,ym,'b',t,ys,'r');
legend('Respuesta del modelo','Respuesta del sistema')
grid;
110
Anexo # 8
%Identifiacin de sistemas multivariables (2 entradas y 2 salidas)
%por el mtodo arx
clf
ys=y.signals.values;
ue=u.signals.values;
t=y.time;
tm=t(2)-t(1);
z=[ys ue];
na=[2 2;2 2];
nb=[2 2;2 2];
nk=[0 0;0 0];
nn=[na nb nk];
th=arx(z,nn);
th=sett(th,tm);
tc=thd2thc(th);
[A,B,C,D,K,X0]=th2ss(tc);
sysss=ss(A,B,C,D);
[Y,T] = lsim(sysss,ue,t);
figure(1)
plot(T,Y(:,1),'b',t,ys(:,1),'r')
legend('Salida 1 del Modelo','Salida 1 del Sistema')
grid on
figure(2)
plot(T,Y(:,2),'b',t,ys(:,2),'r')
grid on
legend('Salida 2 del Modelo','Salida 2 del Sistema')
er1=mean(abs(Y(:,1)-ys(:,1)));
er2=mean(abs(Y(:,2)-ys(:,2)));
disp(['El error para la salida 1 es ',num2str(er1)]);
disp(['El error para la salida 2 es ',num2str(er2)]);
disp('Comparemos los vectores propios del sistema y el modelo')
disp('Del modelo')
eig(A)
disp('Del sistema')
eig([0 1;-25 -4])
111
Anexo # 9
clf
ys=y.signals.values;
ue=u.signals.values;
t=y.time;
tm=t(2)-t(1);
z=[ys ue];
na=[2 2;2 2];
nb=[2 2;2 2];
nk=[0 0;0 0];
nn=[na nb nk];
th=arx(z,nn);
th=sett(th,tm);
tc=thd2thc(th);
[A,B,C,D,K,X0]=th2ss(tc);
sysss=ss(A,B,C,D);
[Y,T] = lsim(sysss,ue,t);
subplot(211)
plot(T,Y(:,1),'b',t,ys(:,1),'r')
legend('Salida 1 del Modelo','Salida 1 del Sistema')
grid on
subplot(212)
plot(T,Y(:,2),'b',t,ys(:,2),'r')
grid on
legend('Salida 2 del Modelo','Salida 2 del Sistema')
er1=mean(abs(Y(:,1)-ys(:,1)));
er2=mean(abs(Y(:,2)-ys(:,2)));
disp(['El error para la salida 1 es ',num2str(er1)]);
disp(['El error para la salida 2 es ',num2str(er2)]);
disp('Vector propio del modelo')
eig(A)
112
Bibliografa
[1] Arafet, P. y col., Introduccin al Matlab, Monografa. Universidad de Oriente,
Santiago de Cuba, Enero 2001.
[2] Ogata, K., Modern Control Engineering, Ediciones del Castillo, 1998.
[3] Ollero, A., Control por Computador. Descripcin interna y diseo ptimo, Editorial
Marcombo, 1991.
[4] Trejo, V., Identificacin experimental de sistemas, Editorial ISPJAE, 1986.
[5] Len, E. Sistema para la identificacin dinmica. Tesis de Maestra Universidad de
Oriente. Santiago de Cuba, Abril, 2002.
[6] Sage y Melsa, System Identification,, Mathematics in science and engineering,
volume 80, AcademicPress, Inc.