Owning Palette: PID VIs
Requires: Full Development System
Implements a PID controller using a PID algorithm with advanced optional features, and applies autotuning to the controller. You can use this VI in RT applications.![]() | Note This VI incorporates the functionality of both the PID Advanced VI and the PID Online Autotuning VI. |
![]() |
![]() |
![]() |
alpha specifies the derivative filter time constant. Increasing this value increases damping of derivative action. alpha can be a value between 0 and 1 or NaN, which specifies that no derivative filter is applied. | ||||||||||||||||||||||||||||
![]() |
gamma specifies an amount by which to weight the error applied to derivative action. The default value is 0, which avoids the derivative kick, or sudden change in controller output, that can occur after a change in the setpoint value. In certain cascade control operations where derivative kick is not a concern, increasing gamma might improve the speed of the first PID controller. |
||||||||||||||||||||||||||||
![]() |
manual control specifies the value of the control output when auto? is FALSE. | ||||||||||||||||||||||||||||
![]() |
auto? specifies whether the PID controller uses automatic or manual control. This VI considers the autotune? input and the technique you specify in the autotuning parameters input when determining the Boolean value to propagate to the auto? input of the PID Advanced VI. The default is FALSE. | ||||||||||||||||||||||||||||
![]() |
output range specifies the range to which to coerce the control output. The default range is –100 to 100, which corresponds to values specified in terms of percentage of full scale. You can change this range to something that is appropriate for your control system. For example, you can relate engineering units to engineering units instead of percentage to percentage. This VI implements integrator anti-windup when the controller output is saturated at the specified minimum or maximum values.
| ||||||||||||||||||||||||||||
![]() |
setpoint specifies the setpoint value, or desired value, of the process variable being controlled. | ||||||||||||||||||||||||||||
![]() |
process variable specifies the measured value of the process variable being controlled. This value is equal to the feedback value of the feedback control loop. | ||||||||||||||||||||||||||||
![]() |
PID gains specifies the proportional gain, integral time, and derivative time parameters of the controller.
| ||||||||||||||||||||||||||||
![]() |
autotune? specifies to begin autotuning. Wire this input from a Boolean control with latched mechanical action and a default value of FALSE. The default is FALSE. | ||||||||||||||||||||||||||||
![]() |
dt (s) specifies the loop-cycle time, or interval in seconds, at which the PID Online Autotuning and PID Advanced VIs are called. If dt (s) is less than or equal to zero, the VIs calculate the time since they were last called using an internal timer with 1 ms resolution. If dt (s) must be less than 1 ms, specify the value explicitly. The default is –1. | ||||||||||||||||||||||||||||
![]() |
reinitialize? specifies whether to reinitialize the internal parameters, such as the integrated error, of the controller. Set reinitialize? to TRUE if your application must stop and restart the control loop without restarting the entire application. The default is FALSE. | ||||||||||||||||||||||||||||
![]() |
beta specifies the relative emphasis of disturbance rejection to setpoint tracking. The default value of 1 is appropriate for most applications. You can use a smaller value between 0 and 1 to specify emphasis on disturbance rejection, such as process load changes. The PID Advanced VI uses this value in the two degree-of-freedom algorithm. If Autotune? is TRUE, this VI sets beta to 1. | ||||||||||||||||||||||||||||
![]() |
autotuning parameters specifies various parameters used for the autotuning process. You can select these values manually in the Autotuning Wizard.
| ||||||||||||||||||||||||||||
![]() |
output returns the control output of the PID algorithm that is applied to the controlled process. If this VI receives an invalid input, output returns NaN. | ||||||||||||||||||||||||||||
![]() |
Tuned PID Gains retains the tuned proportional gain, integral time, and derivative time parameters of the controller.
| ||||||||||||||||||||||||||||
![]() |
tuning completed? indicates completion of the autotuning process. You can use this output to determine when to update the PID gains. |
Refer to the Autotuning PID Online VI in the labview\examples\control\PID directory for an example of using the PID Advanced Autotuning VI.
Open example
Find related examples
Submit feedback on this topic.
Visit ni.com/support for technical support.