The PIDE (Enhanced PID) is an Allen Bradley Logix5000 family (ControlLogix, CompactLogix, FlexLogix, SoftLogix) function block that improves on the standard PID found in all their controllers. First impressions of this function block are quite intimidating. If you try to dive into it head first you may just end up banging your head against a wall. Many will be quite happy to stick with the tried and true PID instruction but to compete with the more advanced process control applications the PIDE boasts the following.
Still interested? What we want to do here is basically get you off the ground with the PIDE, distill all the options to the essentials and get it working.
The PIDE is only available as a function block (sorry, no ladder). Like the PID instruction it is best to set it up in its own periodic task. The period of the task automatically becomes the sample rate (DeltaT) of the PID loop. Just make sure when adding the new routine to the task to select the Type as "Function Block Diagram."Â
The PIDE instruction can be added from the Instruction Toolbar under the Process tab.
Once you plop a function block onto a sheet it automatically creates a program tag for the instruction which stores all the settings. The parameters can be set or monitored by wiring input and output references or by clicking on the ellipsis box in the top right corner to reveal the block properties.Â
Opening the block properties for the PIDE instruction before RSLogix5000 version 15 meant you would be accosted with a long list of parameters.
Version 15 has at least organized some of the more common settings (but not all) under tabs and groups.
Â
The most essential settings are:
Name |
V15 Location |
Description |
.PV |
Must be wired in from a tag. |
The Process Variable is the reading (temperature, pressure, flow, etc.) that is to be controlled by the PID loop. |
.PVEUMax |
EUs/Limit tab in the Engineering Units Scaling group |
The Process Variable Engineering Units Maximum and Minimum. The value of PV and SP which corresponds to 100 % span of the process variable. |
.SPProg |
Should be wired in or set in the tag. |
The Set Point is the theoretical perfect value of the process variable. SPProg is the value to use when in program mode and SPOper is used when in operator mode. |
.SPHLimit |
EUs/Limit tab in the SP Limits group |
The Set Point High Limit and Set Point Low Limit clamp the maximum and minimum values of the set point. If SPHLimit > PVEUMax or SPLLimit < PVEUMin then a fault will occur. |
.PGain |
General Configuration tab in the Gains group |
Proportional gain. Enter 0 to disable. |
.IGain |
General Configuration tab in the Gains group |
Integral gain. Enter 0 to disable. |
.DGain |
General Configuration tab in the Gains group |
Derivative gain. Enter 0 to disable. |
The first thing to understand when programming a PIDE block is the different controls and modes available.Â
The Program/Operator control lets you transfer control of the PID loop between the user program and an operator interface such as an HMI. Each control has separate set points and mode controls. It's important to understand that when in Program Control the set point is determined by SPProg while in Operator Control its SPOper. The SP output indicates the set point that the function block is actually using.
Control is determined by the following inputs:
Name |
Description |
.ProgProgReq |
A program request to go to Program control. |
.ProgOperReq |
A program request to go to Operator control. |
.OperProgReq |
An operator request to go to Program control. |
.OperOperReq |
An operator request to go to Operator control. |
The ProgOper output indicates the control of the PIDE instruction. If the output is a 1 then it is in Program control and if the output is a 0 then it is in Operator control. The Program request inputs take precedence over the Operator requests so that the program can lock out any operator overrides. The ProgValueReset input clears all input requests.
The PIDE instruction supports the following modes.
Mode |
Description |
Manual |
While in Manual mode the instruction does not compute the change in CV. The value of CV is determined by the control. If in Program control, CV = CVProg and if in Operator control, CV = CVOper. Select Manual mode using either OperManualReq or ProgManualReq. The Manual output bit is set when in Manual mode. |
Auto |
While in Auto mode the instruction regulates CV to maintain PV at the SP value. If in program control, SP = SPProg and if in Operator control, SP = SPOper. Select Auto mode using either OperAutoReq or ProgAutoReq. The Auto output bit is set when in Auto mode. |
Cascade/Ratio |
While in Cascade/Ratio mode the instruction computes the change in CV. The instruction regulates CV to maintain PV at either the SPCascade value or the SPCascade value multiplied by the Ratio value. SPCascade comes from either the CVEU of a primary PID loop for cascade control or from the "uncontrolled" flow of a ratio-controlled loop. Select Cascade/Ratio mode using either OperCasRatReq or ProgCasRatReq. The CasRat output bit is set when in Cascade/Ratio mode. |
Override |
While in Override mode the instruction does not compute the change in CV. CV = CVOverride, regardless of the control mode. Override mode is typically used to set a "safe state" for the PID loop. Select Override mode using ProgOverrideReq. The Override output bit is set when in Override mode. |
Hand |
While in Hand mode the PID algorithm does not compute the change in CV. CV = HandFB, regardless of the control mode. Hand mode is typically used to indicate that control of the final control element was taken over by a field hand/auto station. Select Hand mode using ProgHandReq. The Hand output bit is set when in Hand mode. |
If a fault occurs in the PIDE settings then it is forced into Manual mode and sets a corresponding bit in the Status words. The InstructFault output is the indicator of a fault. For more detail open the block properties and look at the Status at the bottom of the dialog box. Refer to the Logix5000 Controllers Process Control and Drives Instructions (pub 1756-RM006D-EN-P) for details.
Here's an example where just the essentials are used. This is a temperature control application if you hadn't guessed all ready. I've changed the look of the function block by going into the block properties, selecting the Parameters tab and checking on (or off) the boxes in the Vis column besides the inputs and outputs that are of concern.
Here's the run down on each of the inputs.
Input | Description |
PV |
The process variable coming in from my TC card |
PVEUMax |
The span of the temperature input that equals 0 to 100%. In this case the temp goes from 0 to 1200 degC. |
SPHLimit |
We could limit the set point but in this test case just set it equal to the PVEUMax/Min. |
SPProg |
I've decided to use Program Control so the Set Point needs to come in on this input rather then SPOper. |
CVProg |
When in manual mode the CV is controlled by this input. |
DependIndepend |
I prefer the Dependent form of the PID algorithm. |
PGain |
The essential PID settings of Proportion, Integral and Derivative. |
ProgProgReq |
Set the request to use Program Control. |
ProgAutoReq |
Since we're in Program Control these inputs control the Auto and Manual modes. To run them off one switch the BNOT block is used to invert the bit. |
Now for the outputs.
Output | Description |
CVEU |
The Control Variable output in engineering units. Every PID control needs an output. In this case it goes from 0 to 100%. |
SP |
The actual set point which in this case equals SPProg. |
ProgOper |
I want to see a 1 here just to make sure we're in Program Control |
Auto |
Indicates the operating mode. |
InstructFault |
If I screw something up then this bit will come on. |
No output |
|
Output is limited at 100 |
|
Hopefully this basic introduction has gotten you off the ground. Half the battle is just getting it to work. Once that is done you can now really start to tinker with the power of the PIDE function block.