FB_BARSunProtectionEx

Function block for the control of glare protection with the aid of a slatted blind.

FB_BARSunProtectionEx 1:
FB_BARSunProtectionEx

The function block FB_BARSunProtectionEx enables glare protection in two ways that operate in parallel:

On the basis of the parameters entered, which are described further below, the function block calculates the necessary slat angle and blind position and transfers them to the output structure stSunblind. Of course, the output does not take place continuously since a constant blind movement would be perceived as extremely distracting. At the input uiPositioningInterval it is possible to set in seconds the interval at which new position values are to be output.
However, the shading criteria must always be fulfilled between two positioning times: no direct light may pass through the slats and the desired light incidence through the blind height must remain limited, assuming initially that the blind height is controlled via the "maximum desired light incidence" mode. Therefore, two blind and slat positions are calculated internally: the one for the current switching point and the one for the next switching point. The position in which the blind is more closed is then the valid position.

The positioning in intervals starts precisely when the following three conditions are satisfied:

If these three conditions are not satisfied, then the active bit (bActive) is set to FALSE, the blind height to 0% and the slat angle to 0% in the positioning structure.

VAR_INPUT

eDataSecurityType   : E_HVACDataSecurityType;
bEnable             : BOOL;
stTimeAct           : TIMESTRUCT;
stBlindPositionTable: ST_BARBlindPositionTable;

eDataSecurityType:if eDataSecurityType:= eDataSecurityType_Persistent, the persistent VAR_IN_OUT variables of the function block are stored in the flash of the computer if a value changes. For this to work, the function block FB_HVACPersistentDataHandling must be instanced once in the main program, which is called cyclically. Otherwise the instanced FB is not released internally.

A change of value can be initiated by the building management system, a local operating device or via a write access from TwinCAT. When the computer is restarted, the saved data are automatically read back from the flash into the RAM.

Application example: FB_BARSunProtectionEx 2:Example_PERSISTENT.zip

If eDataSecurityType:= eDataSecurityType_Idle the persistently declared variables are not saved in a fail-safe manner.

Notice

A cyclically changing variable must never be linked with the IN_OUT variable of a function block, if eDataSecurityType:= eDataSecurityType_Persistenti. It would lead to early wear of the flash memory.

bEnable: if this input is set to FALSE, the positioning is inactive, i.e. the active bit (bActive) is reset in the positioning structure stSunblind of the type ST_BARSunblind and the function block itself remains in a standstill mode. If on the other hand the function block is activated, then the active bit is TRUE and the function block outputs its control values (uiShutterHeight ,iLouvreAngle) in the positioning structure at the appropriate times.

stTimeAct: entry of the current time in GMT (Greenwich Mean Time).

stBlindPositionTable: table of 6 interpolation points, 4 of which are parameterizable, from which a blind position is then given in relation to the position of the sun by linear interpolation. Valid if ePositioningMode = ePosModeFixed (see enumerator E_BARPosMode). For a more detailed description please refer to FB_BARBlindPositionEntry.

VAR_OUTPUT

stSunblind: ST_BARSunblind;
bError    : BOOL;
udiErrorId: UDINT;

stSunblind: output structure of the blind positions, see ST_BARSunblind

bError: this output is switched to TRUE if the parameters entered are erroneous.

udiErrorId : contains the error code if the values entered should be erroneous. See error codes.

FB_BARSunProtectionEx 3:

If an error should occur, then this automatic function is deactivated and position and angle are set to 0. This means that if a priority controller is in use, another function with a lower priority (see Overview) automatically takes over control of the blind. In the case of a direct connection, conversely, the blind will drive to position/angle 0.

VAR_IN_OUT

The need for entered parameters to be preserved across a control failure makes it necessary for them to be declared as IN-OUT variables. A reference variable is then assigned to them in the program. Each change in the value of this reference variable is persistently saved in the function block and written back to the reference variable after a controller failure and restart. If the parameters were only declared as input variables, they would not be able to write a reference variable.
Application example: FB_BARSunProtectionEx 4:Example_PERSISTENT.zip.

uiPositioningInterva : UINT;
lrDegreeOfLongitude  : LREAL;
lrDegreeOfLatitude   : LREAL;
lrFacadeOrientation  : LREAL;
lrFacadeAngle        : LREAL;
uiLouvreWidth        : UINT;
uiLouvreSpacing      : UINT;
uiFixedShutterHeigh  : UINT;
uiMaxLightIncidence  : UINT;
uiWindowHeight       : UINT;
uiWindowDistanceFloor: UINT;
ePositioningMode     : E_BARPOSMODE;

uiPositioningInterval: positioning interval in seconds - time between two blind position outputs. Valid range: 1s..7200s.

lrDegreeOfLongitude: longitude in degrees. Valid range: -180°..180°.

lrDegreeOfLatitude: latitude in degrees. Valid range: -90°..90°.

lrFacadeOrientation: facade orientation in degrees:

In the northern hemisphere, the following applies for the facade orientation (looking out of the window):

Line of sight

Facade orientation

North

β=0°

East

β=90°

South

β=180°

West

β=270°

The following applies for the southern hemisphere:

Line of sight

Facade orientation

South

β=0°

East

β=90°

North

β=180°

West

β=270°

lrFacadeAngle: facade inclination in degrees. See Facade inclination.

uiLouvreWidth: width of the slats in mm, see sketch.

uiLouvreSpacing: slat spacing in mm, see sketch.

uiFixedShutterHeight: fixed (constant) shutter height [0..100%]. Valid if ePositioningMode = ePosModeFixed (see enumerator E_BARPosMode).

uiMaxLightIncidence: maximum desired incidence of light in mm measured from the outside of the wall (see Height adjustment). With the aid of the parameters uiWindowHeight and uiWindowDistanceFloor, a calculation is performed in relation to the position of the sun to determine how high the blind must be so that the incidence of light does not exceed the value uiMaxLightIncidence. Valid if ePositioningMode = ePosModeMaxIncidence (see enumerator E_BARPosMode).

uiWindowHeight: window height in mm for the calculation of the blind height if the mode "maximum desired incidence of light" is selected.

uiWindowDistanceFloor: distance between the floor and the window sill in mm for the calculation of the blind height if the mode "maximum desired incidence of light" is selected.

ePositioningMode: selection of the positioning mode, see enumerator E_BARPosMode.