Tengo un proceso térmico no lineal (la radiación no lineal se vuelve cada vez más presente a medida que aumenta la temperatura) al que me gustaría ajustar 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 pseudolineales (a definir), y para cada uno de estos rangos de temperatura: ajuste un modelo de primer orden usando un pequeño paso de temperatura y calcule los parámetros PID para adaptarse a este modelo. Los parámetros PID cambiarían automáticamente dependiendo de la temperatura del proceso*.
Mi problema es el siguiente: considere el punto de control de 70 ° C, por ejemplo. Los vatios P 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. [Por favor, ¿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 pone a cero el contador integral. El error puede ser de 1°C, pero la potencia requerida es mucho mayor que para alcanzar los 21°C, es seguro que el controlador demandará menos de P watt. 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 mayor sea P en comparación con dP, peor será.
Casi parece que los calentadores deberían funcionar con la suma de la salida del controlador y la potencia necesaria para permanecer en la "temperatura de referencia" actual (p. ej., 70 °C). Pero los controladores comerciales no ofrecen eso, por lo que debe haber otra forma.
¿Qué me estoy perdiendo? ¿Cuál es la forma adecuada?
*: Es efectivamente Programación de Ganancias .
¿Cómo ajustar un controlador PID a un proceso no lineal?
tu no Usted linealiza el proceso, 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 circuito 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 basada en una tabla lineal por partes. 16 o 32 segmentos suelen ser suficientes para todo menos para procesos muy no lineales.
El ejemplo del peor de los casos con el que me encontré fue controlar la corriente a través de un tubo de electrones cambiando la fuerza con la que se conducía el filamento del cátodo. 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, era demasiado difícil predecir todo este lío, así que utilicé un procedimiento de calibración durante la producción que atravesó los valores de control de la unidad 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 corriente del haz para obtener una buena respuesta en todo el rango.
Sin una función de linealización frente al proceso, debe ajustar el controlador PID para obtener estabilidad en el punto de ganancia incremental más alto del proceso. Esto luego da como resultado un comportamiento muy amortiguado en otros puntos.
Nada en su pregunta actualizada dice nada sobre 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 pasó, 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 energía real de la planta. El controlador PID analógico presumiblemente emite 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 traducción de la medida lineal al nivel de potencia real.
Normalmente haría esto con un microcontrolador que tiene un A/D incorporado. Hacer esta búsqueda de tabla e interpolación lineal entre puntos es trivial. Luego emite el resultado de una manera que eventualmente se convierte en un voltaje. Dado que la planta es lenta en comparación con un microcontrolador, esto podría ser tan fácil como filtrar y almacenar en búfer una salida PWM. O podría conducir un D/A directamente, aunque eso no parece necesario en este caso.
De acuerdo con el tema de la década de 1980 de su controlador, podría 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 en el rango de salida. Este último es una chapuza, 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 de P, I y D en varios puntos. Incluso si lo hizo, todavía tiene problemas transitorios, ya que las ganancias correctas no se aplican de inmediato a la situación. Una vez más, la "programación de ganancias" es una chapuza.
Recuerde que cuando linealiza un modelo, está suponiendo 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, aún 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.
Entonces, en su ejemplo, incluso si el error es de 0 grados (en el punto de ajuste de 70 grados), el controlador aún emitirá una potencia mayor que 0.
Un enfoque para el control no lineal con controladores PID, un enfoque que se usa ampliamente en la industria, se denomina "programación de ganancia".
El problema de control no lineal se divide en una serie de regiones lo suficientemente lineales y se utilizan los parámetros apropiados para cada región.
Eugenio Sh.
usuario42875
nick johnson
Jorge Herold
Marko Bursic
usuario42875