Redundance3

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

Name
Data type
Value range
Initial value
Function

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

Name
Data type
Value range
Initial value
Function

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

Name
Data type
Value range
Initial value
Function

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.\

  1. wActiveNumberOfDevices > 3\

  2. 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: \

  1. The fault state of at least one device has changed ( high priority )\

  2. 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:

Scope
Name
Type
Initial

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