Redundance3
Redundance3 (FB)
Redundance3 (FB)FUNCTION_BLOCK Redundance3
Short description
Redundant control of 0 - 3 identical devices Influencing factors: requests, operating hours, operating and fault states Typical application: determination of leader and follower devices
Representation

Interfaces
Inputs
wActiveNumberOfDevices
WORD
0
Number of active devices ( 0 - 3 )
xFb1
BOOL
FALSE
Operation - Device 1 ( TRUE = running )
xFb2
BOOL
FALSE
Operation - Device 2 ( TRUE = running )
xFb3
BOOL
FALSE
Operation - Device 3 ( TRUE = running )
xAlarm1
BOOL
TRUE
Fault - Device 1 ( TRUE = fault )
xAlarm2
BOOL
TRUE
Fault - Device 2 ( TRUE = fault )
xAlarm3
BOOL
TRUE
Fault - Device 3 ( TRUE = fault )
uiOperatingHours1
UDINT
0
Operating hours - device 1
uiOperatingHours2
UDINT
0
Operating hours - device 2
uiOperatingHours3
UDINT
0
Operating hours - Device 3
xUpdate
BOOL
Trigger recalculation of the sequence on every rising edge
Outputs
udiCurrentSequence
UDINT
0
Current device sequence as integer
sCurrentSequence
STRING
‘’
Current device sequence as string
wNumberOfOperationalDevices
WORD
0
Number of operational devices
xCmd1
BOOL
FALSE
Enable - Device 1 ( TRUE = enable )
xCmd2
BOOL
FALSE
Enable - Device 2 ( TRUE = enable )
xCmd3
BOOL
FALSE
Enable - Device 3 ( TRUE = enable )
wPrio1
WORD
0
Current priority of device 1 ( 0 = none, 1 - 3 )
wPrio2
WORD
0
Current priority of device 2 ( 0 = none, 1 - 3 )
wPrio3
WORD
0
Current priority of device 3 ( 0 = none, 1 - 3 )
xErr
BOOL
FALSE
output - fault
eOperationalCondition
eRedundance3_OperationalMode
Number / name of the current operating condition
Setpoints / Parameters
xConOperatingHours
BOOL
TRUE
FALSE = enable follower switching only via input xUpdate, TRUE = follower switching automatically after operating hours
xEnFb
BOOL
TRUE
FALSE = switching after enable ( xCmdX ), TRUE = switching after running report ( xFbX )
wTolerance
WORD
100
Threshold - operating hours difference for direct follower change in partial load operation
Function description
General
This function block is used for redundant control of 0 - 3 identical devices depending on the influencing variables requests ( wActiveNumberOfDevices ), operating hours ( uiOperatingHours ), running states ( xFb ) and fault states ( xAlarm ).\
Input wActiveNumberOfDevices
This input is used to specify the number of devices that should currently be used. Permissible range: 0 - 3\
Input xUpdate
Every rising edge on this input triggers a recalculation of the current device sequence. Boundary conditions: xConOperationHours = FALSE, operating hours difference = 0 hours.\
Output udiCurrentSequence
This output always shows the current device sequence as an integer. The number of the device with the highest priority is always at the beginning, then follows the number of the device with the second highest priority, etc. Example: udiCurrentSequence = 145 means: Device 1 = priority 1, Device 4 = priority 2 and Device 5 = priority 3\
Output sCurrentSequence
This output always shows the current device sequence as a delimited string. The same applies regarding priorities as for the output udiCurrentSequence. Example: sdiCurrentSequence = '1-4-5' means: Device 1 = priority 1, Device 4 = priority 2 and Device 5 = priority 3\
Output wNumberOfOperationalDevices
This output always shows the number of operational devices.\
Output fault xErr
This output is active ( = TRUE ) if at least one of the following conditions is met.\
wActiveNumberOfDevices > 3\
wActiveNumberOfDevices > wOperationalNumberofDevices\
In all other cases the output *xErr* is not active ( = FALSE ).\
Output eOperationalCondition
This output always indicates the current load situation ( idle, partial load, full load ) depending on the setpoint / parameter xEnFb rep. xEnFb = FALSE: The enable outputs xCmd of the operational devices are evaluated / taken into account. xEnFb = TRUE: The operating states xFb of the operational devices are evaluated / taken into account. Example: xEnFb = TRUE and xFb1 = TRUE and xFb2 = TRUE: Output = PartLoad_Inputs_Fb\
Setpoint / parameter xConOperatingHours
xConOperatingHours = FALSE: The switching of the device sequence is only triggered by a rising edge at the input xUpdate triggered. xConOperatingHours = TRUE: The switching of the device sequence is triggered depending on the operating hours, the running reports ( when xEnFb = TRUE ) and the enables ( when xEnFb = FALSE ) triggered.\
Setpoint / parameter xEnFb
xEnFb = FALSE: The enable outputs ‘xCmd’ of the operational devices are evaluated / taken into account. xEnFb = TRUE: The operating states ‘xFb’ of the operational devices are evaluated / taken into account.\
Setpoint / parameter wTolerance
This setpoint determines the maximum operating hours difference before a switching of the device sequence due to operating hours. \
Determination of the device sequence
A switching of the device sequence can generally only take place if at least one of the following conditions is met: \
The fault state of at least one device has changed ( high priority )\
The operating hours count of at least one operational device has changed ( low priority )\
Definition - idle: **xEnFb** = FALSE: The enable outputs ‘xCmd’ of all operational devices are inactive ( = FALSE ) **xEnFb** = TRUE: The running reports ‘xFb’ of all operational devices are inactive ( = FALSE ) Definition - full load: **xEnFb** = FALSE: The enable outputs ‘xCmd’ of all operational devices are active ( = TRUE ) **xEnFb** = TRUE: The running reports ‘xFb’ of all operational devices are active ( = TRUE ) Definition - partial load: **xEnFb** = FALSE: The number of enable outputs *xCmd* of all operational devices in active state ( = TRUE ) is greater/equal 1 and less than the number of all operational devices **xEnFb** = FALSE: The number of running reports *xFb* of all operational devices in active state ( = TRUE ) is greater/equal 1 and less than the number of all operational devices Switching with **high** priority ( = immediate ) depending on fault states ( inputs *xAlarm* ) The fault state of each device in the range 1 - 3 is cyclically recorded and evaluated for changes. Any faulty device in the range 1 - 3 ( input *xAlarm* = TRUE ) is no longer operational. Any change in the fault state of at least one device in the range 1 - 3 triggers an immediate recalculation of the device sequence. Switching with **low** priority depending on operating hours ( inputs *udiOperationHours* ), operating states ( inputs *xFb* ) and enable outputs ( outputs *xCmd* ) of devices 1 - 3. The operating hours of each operational device in the range 1 - 3 are cyclically recorded and evaluated for changes. The operating states and enable outputs of each operational device in the range 1 - 3 are cyclically recorded. The recalculation of the device sequence takes place as soon as one of the situations described below applies: **Situation 1** ( *xConOperationHours* = FALSE, rising edge at input *xUpdate* ) A recalculation of the device sequence is carried out with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours count has the highest priority ( in case of equal operating hours the device with the lower number has the higher priority ). **Situation 2** ( *xConOperationHours* = TRUE, idle or full load ) In idle or under full load a recalculation of the device sequence is carried out with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours count has the highest priority ( in case of equal operating hours the device with the lower number has the higher priority ). The recalculation of the device sequence is triggered if the operating hours count of at least one operational device has changed. **Situation 3** ( *xConOperationHours* = TRUE, partial load ) On the first transition to partial load operation a recalculation of the device sequence is carried out with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours count has the highest priority ( in case of equal operating hours the device with the lower number has the higher priority ). In regular partial load operation a recalculation of the device sequence is carried out with an operating hours difference of **wTolerance** hours. The recalculation of the device sequence is triggered if the operating hours count of at least one operational device has changed. \
Enable outputs xCmd’
The states of the outputs of the devices in the range 1 - 3 are finally determined as follows: The enable outputs of the operational devices in the range 1 - 3 are activated if their current priority <= the number of requested devices ( input *wActiveNumberOfDevices* ). The enable outputs of the operational devices in the range 1 - 3 are deactivated if their current priority > the number of requested devices ( input *wActiveNumberOfDevices* ). \
Priority outputs wPrio
The priority outputs of each device always contain the current priority in the range 0 - 3. Priority = 0: The device has no or an invalid priority Priority = 1: The device has the highest priority Priority = 2: The device has the second highest priority Priority = 3: The device has the third highest priority\
CODESYS
InOut:
Input
wActiveNumberOfDevices
WORD
0
Input
xFb1
BOOL
FALSE
Input
xFb2
BOOL
FALSE
Input
xFb3
BOOL
FALSE
Input
xAlarm1
BOOL
TRUE
Input
xAlarm2
BOOL
TRUE
Input
xAlarm3
BOOL
TRUE
Input
udiOperatingHours1
UDINT
0
Input
udiOperatingHours2
UDINT
0
Input
udiOperatingHours3
UDINT
0
Input
xUpdate
BOOL
Input Const
xConOperatingHours
BOOL
TRUE
Input Const
xEnFb
BOOL
TRUE
Input Const
wTolerance
WORD
100
Output
udiCurrentSequence
UDINT
0
Output
sCurrentSequence
STRING
‘’
Output
wNumberOfOperationalDevices
WORD
0
Output
xCmd1
BOOL
FALSE
Output
xCmd2
BOOL
FALSE
Output
xCmd3
BOOL
FALSE
Output
wPrio1
WORD
0
Output
wPrio2
WORD
0
Output
wPrio3
WORD
0
Output
xErr
BOOL
FALSE
Output
eOperationalCondition
eRedundance3_OperationalMode
Last updated

