Cómo sintonizar un controlador PID a un proceso no lineal

9

Tengo un proceso térmico no lineal (la radiación no lineal se vuelve más y más presente a medida que aumenta la temperatura) al que me gustaría sintonizar un controlador PID. Me gustaría controlar la temperatura con la mayor precisión posible.

He planeado dividir el rango de temperatura en N rangos pseudo-lineales (por definir), y para cada uno de estos rangos de temperatura: ajustar un modelo de primer orden usando un pequeño paso de temperatura y calcular los parámetros PID para este modelo. Los parámetros PID se cambiarían automáticamente según la temperatura del proceso *.

Mi problema es el siguiente: considere el punto de control de 70 ° C, por ejemplo. P watt ya están fluyendo para alcanzar esta temperatura. Inyectaré dP watt para aumentar la temperatura en 1 ° C. Luego tomaré nota de la constante de tiempo, y la ganancia de estado estable será 1 / dP ° C / W. [¿Puede tomarse un momento para pensar si esto es correcto?] Finalmente, ajustaré el PID a esa planta para obtener los parámetros para ese rango de temperatura y pasaré a los otros rangos.

Ahora, suponga que el proceso alcanza los 70 ° C. Se cargan los nuevos parámetros y se restablece el contador integral. El error puede ser de 1 ° C, pero la potencia requerida es mucho más que eso para alcanzar los 21 ° C, es seguro que el controlador demandará menos de P vatios. Esto significa que la temperatura caerá mucho antes de que el término integral demande P watt, y solo entonces el dP watt adicional eventualmente llevará el proceso a 71 ° C (y ciertamente se sobrepasará). Cuanto más grande se compara P con dP, peor se pone.

Casi parece que los calentadores deberían funcionar con la suma de la salida del controlador y la potencia requerida para mantenerse en la "temperatura de referencia" actual (por ejemplo, 70 ° C). Pero los controladores estándar no ofrecen eso, por lo que debe haber otra forma.

¿Qué me estoy perdiendo? ¿Cuál es la forma correcta?

*: Efectivamente es la programación de ganancia .

user42875
fuente
1
El controlador PID generalmente está destinado a sistemas lineales. Es lo suficientemente robusto como para controlar algunos sistemas no lineales y también alrededor de algún punto operativo "casi lineal". Si no es el caso, se pueden utilizar diferentes técnicas para linealizar la planta controlada (buscar "linealización de retroalimentación" o introducir algunos bucles internos)
Eugene Sh.
Gracias por tu comentario. Eso es lo que estoy tratando de lograr: usar un controlador PID en un rango de temperaturas "casi lineal". Ya he mirado alrededor con esas palabras clave pero sin mucha suerte.
user42875
1
En lugar de entrenar varios modelos, ¿puede alimentar el valor de entrada a través de una función de 'linealización' antes de pasarlo al controlador PID y entrenarlo en función de eso?
Nick Johnson
1
Tu enfoque me suena bien. Vas a ajustar la ganancia y la constante de tiempo dependiendo de la temperatura. Tendrás que pensar en lo que sucede en los puntos de cruce. ¿Has construido algo que no funciona tan bien como te gustaría? Un bucle de control puede ocultar mucha no linealidad. Y tal vez estarás bien sin ponerte elegante.
George Herold
¿Por qué la radiación es no lineal? Si el horno pierde temperatura, entonces la pérdida de potencia es lineal Q = mc * delta_T. Si su sistema simplemente tiene fugas, entonces casi todas las constantes permanecen, como el tiempo muerto, el tiempo de aumento, excepto que la ganancia disminuye. Simplemente podría hacer que Kp variable Kp (T_actual) sea una función lineal de Kp_initial y Kp_final.
Marko Buršič

Respuestas:

11

¿Cómo sintonizar un controlador PID a un proceso no lineal?

Usted no Linealiza el proceso y luego hace que el controlador PID trabaje en los valores lineales.

Por "linealizar el proceso", no me refiero a hacer que el proceso en sí sea lineal. Eso generalmente no se puede hacer debido a la física. Sin embargo, puede colocar algo no lineal entre la salida del controlador PID y la entrada del proceso para que la salida PID controle linealmente el proceso desde el punto de vista del controlador PID.

Tal linealizador no necesita ser muy preciso ya que está dentro del ciclo de retroalimentación. Su propósito es dar la apariencia de una ganancia más o menos constante en todo el rango dinámico de control. Una forma simple y general es una función lineal basada en tablas por piezas. 16 o 32 segmentos suelen ser suficientes para cualquier cosa que no sean procesos altamente no lineales.

El peor de los casos con el que me he encontrado fue controlar la corriente a través de un tubo de electrones cambiando la fuerza con la que se impulsaba el filamento catódico. La función de la temperatura del cátodo a la corriente del haz de electrones es altamente no lineal, y el sistema que controla la corriente del filamento del cátodo también era algo no lineal. En este caso fue demasiado difícil predecir todo este desorden, por lo que utilicé un procedimiento de calibración durante la producción que pasó por los valores de control del impulsor de filamento, midió la corriente del haz para cada uno y luego calculé una tabla de búsqueda de 32 segmentos a partir de eso. Funcionó muy bien, y pudimos ajustar el controlador PID de la corriente del haz para una buena respuesta en todo el rango.

Sin una función de linealización frente al proceso, debe sintonizar el controlador PID para obtener estabilidad en el punto de ganancia incremental más alto del proceso. Esto resulta en un comportamiento muy amortiguado en otros puntos.

Adicional

Nada en su pregunta actualizada dice nada acerca de por qué el método anterior aún no es una buena idea y aplicable. Dices que estás usando un controlador analógico. Mi primera reacción es: "La década de 1980 ya se fue, no hagas eso". Sin embargo, el controlador PID y el linealizador de planta pueden ser independientes.

Aparentemente, la entrada de la planta es potencia y la salida es temperatura. Mida la temperatura típica de estado estable en un rango de niveles de potencia. A partir de eso, puede calcular la función que convierte la "potencia" linealizada en la entrada de potencia real de la planta. El controlador PID analógico presumiblemente está generando un voltaje proporcional a la potencia. Todo lo que tiene que hacer es insertar una caja negra en línea con ese voltaje que hace la medida lineal a la traducción del nivel de potencia real.

Normalmente lo haría con un microcontrolador que tiene un A / D incorporado. Hacer esta tabla de búsqueda y la interpolación lineal entre puntos es trivial. Luego emite el resultado de una manera que eventualmente se convierte en voltaje. Dado que la planta es lenta en comparación con un microcontrolador, esto podría ser tan fácil como filtrar y amortiguar una salida PWM. O podría conducir un D / A directamente, aunque eso no parece ser necesario en este caso.

De acuerdo con el tema de 1980 de su controlador, puede hacer esto con A / D, memoria y D / A para esa sensación retro.

En cualquier caso, el controlador PID ahora está controlando efectivamente una planta lineal hasta donde sabe, y debería ser posible ajustarla para un buen rendimiento.

Hacer una transformación lineal por partes en la entrada de la planta en un lugar es más fácil que ajustar 3 valores dentro del controlador PID sobre el rango de salida. El último es un error, mientras que el primero aborda el problema directamente. También es mucho más fácil medir los datos para la función de linealización que determinar las ganancias P, I y D en varios puntos. Incluso si hiciste eso, todavía tienes problemas transitorios, ya que las ganancias correctas no se aplican de inmediato a la situación. Nuevamente, la "programación de ganancia" es un error.

Olin Lathrop
fuente
Muy interesante, gracias por presentar el enfoque linealizador. Sin embargo, estoy usando controladores de hardware que están directamente conectados a los relés, por lo que desafortunadamente tengo que programar la ganancia. ¿Es correcto mi enfoque de identificación? Parece que no lo es.
user42875
He editado mi pregunta para aclarar mi problema, los dos últimos párrafos en particular. (todavía, +1)
usuario42875
Le pregunté al fabricante de los controladores si puedo insertar una tabla de búsqueda con interpolación lineal antes de la salida; si eso se puede hacer, definitivamente elegiré esa opción, incluso si eso significa que tendré que olvidarme del herramientas de ajuste habituales basadas en la función de transferencia y tal. Es elegante. Si no lo hacen, tendré que hacer la programación de ganancia muy tediosa, pero aparentemente no hay nada de malo en mi enfoque, que es lo que quería comprobar.
user42875
2

Recuerde que cuando linealiza un modelo, está asumiendo efectivamente que el modelo no lineal y = f (x) se reemplaza con y = A * (x-x0) + B. Observe que x0 es el punto de linealización. Cuando introduce rangos para x, termina con múltiples A, B y x0. De cualquier manera, la entrada a su controlador será el error con respecto al punto de linealización actual. Sin embargo, todavía compensa la señal de entrada (con B), por lo que incluso si el error es 0 con respecto al punto de linealización actual, seguirá transmitiendo una señal.

En su ejemplo, entonces, incluso si el error es 0 grados (en el punto de ajuste de 70 grados), el controlador aún emitirá una potencia mayor que 0.

Pål-Kristian Engstad
fuente
Gracias. Creo que estás en algo, pero realmente no entiendo. En términos generales, estoy usando controladores PID básicos (análogos), de los cuales puedo cambiar los términos P, I, D en función de la temperatura. Sé que de inmediato se estableció a 70 ° C, la potencia no será cero, incluso si el error es cero. Es la solución lo que me preocupa: básicamente estoy dejando caer el controlador a 70 ° C, y dado que es t = 0s para él, el término integral tomará un tiempo en activarse, así que tendré una caída horrible. Casi parece que mi método está mal.
usuario42875
(El controlador exigirá muy poca energía al principio, por debajo de la potencia requerida para mantenerse a 70 ° C)
user42875
He editado mi pregunta para aclarar, los dos últimos párrafos en particular.
user42875
Es difícil dar consejos sin más detalles sobre su proceso, pero parece que tiene un sistema bastante inestable de alrededor de 70 grados y que alrededor de esa temperatura se produce la mayor parte del control debido a la compensación intragral (la I en el PID).
Pål-Kristian Engstad
70 ° C es solo un ejemplo, probablemente tendré 6 rangos de temperatura diferentes para sintonizar. Muy groseramente dicho, estoy controlando la temperatura dentro de un termo calentando la superficie exterior.
user42875
2

Un enfoque para el control no lineal con controladores PID, un enfoque que se usa ampliamente en la industria, se llama 'programación de ganancia'.

El problema del control no lineal se divide en una serie de regiones suficientemente lineales y se utilizan los parámetros apropiados para cada región.

Spehro Pefhany
fuente
Eso es lo que estoy tratando de lograr, como se puede leer en mi pregunta ("Los parámetros PID se cambiarían automáticamente dependiendo de la temperatura del proceso *" "*: Efectivamente es la programación de ganancia")
user42875