Redundance4
Redundance4 (FB)
Redundance4 (FB)FUNCTION_BLOCK Redundance4
Short description
Redundant control of 0 - 4 identical devices Influencing factors: demands, operating hours, operating and fault states Typical application: determination of leader and follower devices
Interfaces
Inputs
wActiveNumberOfDevices
WORD
0
Number of active devices ( 0 - 4 )
xFb1
BOOL
FALSE
Running - device 1 ( TRUE = running )
xFb2
BOOL
FALSE
Running - device 2 ( TRUE = running )
xFb3
BOOL
FALSE
Running - device 3 ( TRUE = running )
xFb4
BOOL
FALSE
Running - device 4 ( 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 )
xAlarm3
BOOL
TRUE
Fault - device 4 ( TRUE = fault )
uiOperatingHours1
UDINT
0
Operating hours - device 1
uiOperatingHours2
UDINT
0
Operating hours - device 2
uiOperatingHours3
UDINT
0
Operating hours - device 3
uiOperatingHours4
UDINT
0
Operating hours - device 4
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-ready 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 )
xCmd4
BOOL
FALSE
Enable - device 4 ( 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 )
wPrio4
WORD
0
Current priority of device 4 ( 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 = follower switching only allowed via input xUpdate, TRUE = follower switching automatic after operating hours
xEnFb
BOOL
TRUE
FALSE = switching based on enable ( xCmdX ), TRUE = switching based on running signal ( 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 the redundant control of 0 - 4 identical devices depending on the influencing variables Demands ( wActiveNumberOfDevices ), operating hours ( uiOperatingHours ), operating states ( xFb ) and fault states ( xAlarm ).\
Input wActiveNumberOfDevices
This input is used to set the number of devices that should currently be used. Permitted range: 0 - 4\
Input xUpdate
Each 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 string with separators. The same priority rules apply 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-ready devices.\
Output fault xErr
This output is active ( = TRUE ) if at least one of the following conditions is met.\
wActiveNumberOfDevices > wTotalMumberOfDevices\
In all other cases the output *xErr* is not active ( = FALSE ).\
Output eOperationalCondition
This output always represents the current load situation ( idle, partial load, full load ) depending on the setpoint / parameter xEnFb thereof. xEnFb = FALSE: The enable outputs xCmd of the operational-ready devices are evaluated / considered. xEnFb = TRUE: The running states xFb of the operational-ready devices are evaluated / considered. Example: xEnFb = TRUE and xFb1 = TRUE and xFb2 = TRUE: Output = PartLoad_Inputs_Fb\
Setpoint / parameter xConOperatingHours
xConOperatingHours = FALSE: Switching of the device sequence is only triggered by a rising edge on input xUpdate triggered. xConOperatingHours = TRUE: Switching of the device sequence is triggered depending on operating hours, running signals ( when xEnFb = TRUE ) and the enables ( when xEnFb = FALSE ) is triggered.\
Setpoint / parameter xEnFb
xEnFb = FALSE: The enable outputs ‘xCmd’ of the operational-ready devices are evaluated / considered. xEnFb = TRUE: The running states ‘xFb’ of the operational-ready devices are evaluated / considered.\
Setpoint / parameter wTolerance
This setpoint determines the maximum operating hours difference before switching the device sequence due to operating hours. \
Determination of the device sequence
A change of the device sequence can generally only occur 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 of at least one ready-for-operation device have changed ( low priority )\
Definition - Idle: **xEnFb** = FALSE: The enable outputs ‘xCmd’ of all ready-for-operation devices are inactive ( = FALSE ) **xEnFb** = TRUE: The status signals ‘xFb’ of all ready-for-operation devices are inactive ( = FALSE ) Definition - Full load: **xEnFb** = FALSE: The enable outputs ‘xCmd’ of all ready-for-operation devices are active ( = TRUE ) **xEnFb** = TRUE: The status signals ‘xFb’ of all ready-for-operation devices are active ( = TRUE ) Definition - Partial load: **xEnFb** = FALSE: The number of enable outputs *xCmd* of all ready-for-operation devices in the active state ( = TRUE ) is greater than/equal to 1 and less than the number of all ready-for-operation devices **xEnFb** = FALSE: The number of status signals *xFb* of all ready-for-operation devices in the active state ( = TRUE ) is greater than/equal to 1 and less than the number of all ready-for-operation devices Switching with **high** priority ( = immediate ) depending on fault states ( inputs *xAlarm* ) The fault state of each device in the range 1 - 4 is recorded cyclically and evaluated for changes. Any faulty device in the range 1 - 4 ( input *xAlarm* = TRUE ) is no longer ready for operation. Any change in the fault state of at least one device in the range 1 - 4 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 - 4. The operating hours of each ready-for-operation device in the range 1 - 4 are recorded cyclically and evaluated for changes. The operating states and enable outputs of each ready-for-operation device in the range 1 - 3 are recorded cyclically. The recalculation of the device sequence occurs as soon as one of the situations described below is given: **Situation 1** ( *xConOperationHours* = FALSE, rising edge at input *xUpdate* ) A recalculation of the device sequence is performed with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours 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 performed with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours 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 of at least one ready-for-operation device have changed. **Situation 3** ( *xConOperationHours* = TRUE, Partial load ) When first switching to partial load operation a recalculation of the device sequence is performed with an operating hours difference of 0 hours, i.e. the non-faulty device with the lowest operating hours 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 performed with an operating hours difference of **wTolerance** hours. The recalculation of the device sequence is triggered if the operating hours of at least one ready-for-operation device have changed. \
Enable outputs xCmd
The states of the outputs of the devices in the range 1 - 4 are finally determined as follows: The enable outputs of the ready-for-operation devices in the range 1 - 4 are activated if their current priority <= the number of requested devices ( input *wActiveNumberOfDevices* ). The enable outputs of the ready-for-operation devices in the range 1 - 4 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 - 4. 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 Priority = 4: The device has the fourth highest priority\
CODESYS
InOut:
Input
wActiveNumberOfDevices
WORD
0
Input
xFb1
BOOL
FALSE
Input
xFb2
BOOL
FALSE
Input
xFb3
BOOL
FALSE
Input
xFb4
BOOL
FALSE
Input
xAlarm1
BOOL
TRUE
Input
xAlarm2
BOOL
TRUE
Input
xAlarm3
BOOL
TRUE
Input
xAlarm4
BOOL
TRUE
Input
udiOperatingHours1
UDINT
0
Input
udiOperatingHours2
UDINT
0
Input
udiOperatingHours3
UDINT
0
Input
udiOperatingHours4
UDINT
0
Input
xUpdate
BOOL
Input Const
xConOperatingHours
BOOL
TRUE
Input Const
xEnFb
BOOL
FALSE
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
xCmd4
BOOL
FALSE
Output
wPrio1
WORD
0
Output
wPrio2
WORD
0
Output
wPrio3
WORD
0
Output
wPrio4
WORD
0
Output
xErr
BOOL
FALSE
Output
eOperationalCondition
eRedundance3_OperationalMode
Last updated

