'Variable' Dialog

 

The dialog is called in FBD/LD code worksheets by double-clicking on a variable, contact or coil, or by selecting 'Object Properties...' from the context menu of the object.

The 'Variable' dialog is used in FBD/LD code worksheets to

Each of these procedures is referenced in the related topics list at the end of this page.

NOTE:

The properties of already existing variables cannot be modified using the dialog. For that purpose, you have to edit the declaration directly in the variables worksheet. The dialog can, however, be used to replace a variable in a code worksheet by another already declared variable.

Dialog element

Meaning

Name

For a variable: shows the name of the variable for which the dialog was called or which is going to be inserted.

For a contact/coil: shows the variable which is assigned to the object or which is going to be assigned.

Depending on the selected 'Scope' and 'Group', the combo box contains all local or global variables which are already declared in the variables group.

For an FB instance: shows the name of the FB instance or the instance name which is going to be assigned. When declaring a new instance, a default instance name is proposed which you an accept or modify. When selecting an instance name from the combo box, note that the list only contains instances of the same data type (FB type) which are already declared in the POU.

EcoStruxure Machine Expert - Safety allows to use DIN qualifiers in IEC 61131 variable names.

Rules for using DIN qualifiers

According to the IEC 61131 standard, variable names can consist of letters, digits, and underscores. The identifier has to begin with a letter or an underscore. The use of any other character causes the compiler error "Illegal identifier".

This naming convention has been expanded in EcoStruxure Machine Expert - Safety in a way that IEC 61131 variable names may also contain DIN qualifiers:

  • The characters - + < > can be used at any position in the name and as last character. However, they cannot be used as first character of a variable name.

  • The DIN qualifiers / * # and the numbers 0 to 9 can be used at any position in the variable name.

Rules for using DIN qualifiers in IEC 61131 variable names

  • Variable names must at least contain one alphabet­ical character.

  • Variables must not have the name of an IEC 61131 data type, such as BOOL, INT, WORD, REAL, etc.

  • Variable names must not be defined as they are for literal values. Literals are used in the code by first specifying the literal data type, followed by a hash sign: <literal_prefix>#<value>. For example, SAFEINT#5 and WORD#32767 are literals. There­fore, a variable declaration such as safeint#MyVar would be invalid.

    Literal prefixes are not case-sensitive and include the following keywords:

    BOOL, REAL, LREAL, SINT, USINT, INT, UINT, DINT, UDINT, LINT, ULINT, BYTE, WORD, DWORD, LWORD, TIME, T, DATE, D, TIME_OF_DAY, TOD, DATE_AND_TIME, DT, STRING, TIMEDATE48, WEIGHT, ANALOG, UNIFRACT, BIFRACT200, FIXED, BOOLEAN2, BCD4, ENUM4, SAFEBOOL, SAFEBYTE, SAFED­WORD, SAFEINT, SAFEDINT, SAFETIME, SAFE­WORD

Data type

Specifies the data type of the variable. Data types determine what kind of value a variable can have and define the initial value, range of possible values, and the number of bits.

NOTE:

The combo box only provides data types for selec­tion which are valid in the current code context, i.e., the list depends on the formal parameter or object selected in the code worksheet.

Group

Shows the variables group within the corresponding variables worksheet (depending on the selected 'Scope') where the variable/FB instance is declared or is used to select the group when declaring a new variable/FB instance.

Modifying the group of an already declared variable, i.e., moving a variable by selecting another variables group is not possible. This must be done in the corresponding variables worksheet.

Usage

This combo box is only available for local variables. It specifies the IEC 61131 variable declaration keyword and thus the type of the variable:

  • VAR declares a local symbolic variable

  • VAR_INPUT declares an FB input variable

  • VAR_OUTPUT declares an FB output variable

Description

User-defined comment.

The comment entered here is also visible in the tooltip which appears when hovering the mouse over the respective object in the FBD/LD code.

Init

This input field is only available in case of variables. It specifies the initial value of the variable.

According to IEC 61131-3 standard, initial values can optionally be assigned to variables. The initial value is applied when processing the variable for the first time during runtime.

Rules for initializing variables

  • The initial value is optional. If no initial value is spec­ified, the variable is initialized with the default initial value of the data type as defined by IEC 61131-3.

  • Initial values can be specified for local (symbolic) variables and global output variables.

    Global input variables (global variables which are assigned to a physical input) cannot be initialized.

  • The initial value has to match the selected data type.

  • For Boolean variables, the default initial value is 0 or FALSE.

  • For safety-related variables, initial values must be entered with preceding safety-related data type in the following format: SAFEINT#value, SAFEBYTE#value, SAFE­WORD#value, SAFEDWORD#value, or SAFE­TIME#values.

    (value represents the proper value, e.g., SAFEINT#13 or SAFETIME#1s.)

  • To initialize a safety-related Boolean variable with FALSE, you can either enter SAFEBOOL#0 or SAFEFALSE. Use accordingly SAFEBOOL#1 or SAFETRUE to preset a safety-related Boolean vari­able to TRUE.

  • Global variable acts as global constant: if a global symbolic variable has an initial value, it can be considered as a global constant with symbolic name. The initialized global symbolic variable is write-protected and the compiler treats it as a constant. As a result, it can be connected, for example, to a function block formal param­eter which expects a constant.

    Refer to the topic "Inserting Constants".

DIAG

This flag is only available for local output variables (usage VAR_OUT) of the data type WORD.

If selected, an implicit diagnostic is performed for this particular variable.

Background: Safety-related firmware function blocks as well as user-defined FBs in a safety-related project may have a diagnostic output which allows polling of FB status information. This diagnostic information can be written to a reserved output buffer area (DQ buffer) while compiling and further processed, for example, using a diagnostic tool. To add a local output variable (FB output) to this buffer, the flag 'DIAG' must be selected.

Scope

Specifies the scope of the variable to be inserted/declared. Refer to the topic "IEC 61131 Implementation - Variables" for details.

  • 'Local': a local variable can only be used in the POU where it is declared.

  • 'Global': a global variable can be used in each graph­ical POU of the project.

When declaring and inserting a new variable, the declaration is inserted into the corresponding variables worksheet depending on the activated radio button.

Only local variables and global symbolic variables can be declared using the dialog (see notes below concerning global I/O variables).

While inserting an already declared variable, the following applies: If 'Local' is activated, the combo box 'Name' contains only the local variables which are declared in the selected group of the local variables worksheet. If 'Global' is marked, all variables are displayed in the combo box 'Name' which are declared in the selected 'Group' of the global variables worksheet.

Two different types of global variables are distinguished: Global symbolic variables and global I/O variables. Global I/O variables are assigned to a process data item and cannot be created in EcoStruxure Machine Expert - Safety. Refer to the section "Declaration rules" for details.

Object Type

Only visible for a selected LD object. It is used to specify/modify the object type. You can, for example, replace an NC contact by an NO contact, or select another coil type.

Also refer to the related topics list below.

Feedback

If this flag is set, the variable is considered as feedback variable, i.e., it can be used to program an implicit feedback in the safety logic.1

The 'Feedback' flag can only be set in combination with 'Usage = VAR' and 'Scope = Local'.

Further Information

For further information, refer to topic "Implicit feed­backs in FBD".

1

When programming implicit feedbacks, the safety logic may be constantly preempted by the updating of the feedback, which may result in a complex timing of your entire application.

WARNING

UNINTENDED EQUIPMENT OPERATION

  • Verify the impact of programmed implicit feedbacks particularly with respect to their effect on the performance of your application.

  • Make certain that suitable organizational measures (according to applicable sector standards) have been taken to avoid hazardous situations if the safety logic application operates in an unintended or incorrect way.

  • Do not enter the zone of operation while the machine is operating.

  • Ensure that no other persons can access the zone of operation while the machine is operating.

  • Observe the regulations given by relevant sector standards while the machine is running in any other operating mode than "opera­tional".

  • Use appropriate safety interlocks where personnel and/or equip­ment hazards exist.

Failure to follow these instructions can result in death, serious injury, or equipment damage.

Click here for related topics