Calculation Tag Syntax (Also the same Syntax used in graphics animations).


The syntax of any Tag that belongs to a Calculation data source should follow the following syntax format:


  • Getting Tag value:

- Example: LINE1.FT101 or Val(LINE1.FT101)


  • Getting Tag status:

- Example: Status(LINE1.FT101)


  • Getting a tag parameter: GetTagParam(TagName,TagParameter)

Examples:

- Get Tag's description: GetTagParam(LINE1.FT101,Description)

- Get Tag's data source name: GetTagParam(LINE1.FT101,DataSource)

- Get Tag's user defined 1 parameter: GetTagParam(LINE1.FT101,Description)


Note: The easiest way to know tag's parameters names is from the exported tag's sheet.


  • Check if Tag status is Normal:

- Example: IsNormal(LINE1.FT101)


  • Check if Tag status is High High:

- Example: IsHH(LINE1.FT101)


  • Check if Tag status is High:

- Example: IsHi(LINE1.FT101)


  • Check if Tag status is Low:

- Example: IsLo(LINE1.FT101)


  • Check if Tag status is Low Low:

- Example: IsLL(LINE1.FT101)


  • Check if Tag status is Initialized:

- Example: IsInitialized(LINE1.FT101)


  • Check if Tag status is Unackknowleged:

- Example: IsUnAcked(LINE1.FT101)


  • Getting Tag time stamp of last update:

- Example: TSTMAP(LINE1.FT101)


  • Using a Tag value inside an expression: Use VAL(TagName) function.

Example: VAL(LINE1.FT101) > 2


  • Dynamic parameters should be surrounded with curly parentheses.

Example: {TAG}

Example: VAL({TAG}) > 2

Example: VAL((GROUP}.TOTAL) > 2


  • String comparison needs to be surrounded with single quotations.

Example: 'VAL(LINE1.STATUS)' = 'RUNNING'


  • 'and', 'or', and 'not': Logical operators used to evaluate conditions.

Note: These operators must be in lowercase.

Examples:

VAL(SIM.Ramp1) > 5 and VAL(SIM.Random1) > 4

VAL(SIM.Ramp1) > 5 or VAL(SIM.Random1) > 4

not (VAL(SIM.Ramp1))

VAL(SIM.Ramp1) > 5 and not (VAL(SIM.Random1) > 4)


  • if statement

Syntax: if(condition, 'value is true', 'value is false')

Example: if(VAL(GROUP.TAG1) > 0, VAL(GROUP.TAG1), 0)

This result of this formula will equal to the value of "GROUP.TAG1" unless the value is below Zero. In this case, it'll equal Zero.


  • 'Max' and 'Min': Returns the larger ('Max') or smaller ('Min') of two specified inputs.

Example: Max(VAL(SIM.Ramp1), VAL(SIM.Random1))


  • 'Round': Rounds a value to the nearest integer or to the specified number of decimal places.

Example: Round(VAL(SIM.Ramp1), 2)


  • 'Ceiling': Returns the smallest integer greater than or equal to the specified input.

Example: Ceiling(VAL(SIM.Ramp1))


  • 'Floor': Returns the largest integer less than or equal to the specified input.

Example: Floor(VAL(SIM.Ramp1))


  • 'Abs': Returns the absolute value of a specified input.

Example: Abs(VAL(SIM.Ramp1))


  • 'Sin', 'Cos', 'Tan', 'Asin', 'Acos', 'Atan': Returns the result of the specified trigonometric function applied to the input.

Example: Sin(VAL(SIM.Ramp1))


  • 'Truncate': Removes the fractional part of a specified value, returning only the integer portion.

Example: Truncate(VAL(SIM.Ramp1))


  • 'Sqrt': Returns the square root of a specified input.

Example: Sqrt(VAL(SIM.Ramp1))


  • 'Pow': Raises a specified base to the power of a specified exponent.

Example: Pow(VAL(SIM.Ramp1), 2)


  • Ln', 'Log', and 'Log10': Return the natural logarithm ('Ln'), logarithm with a specified base ('Log'), or base-10 logarithm ('Log10') of a specified input.

Example: Ln(VAL(SIM.Ramp1))


  • 'Exp': Returns e (the base of natural logarithms) raised to the specified power.

Example: Exp(VAL(SIM.Ramp1))


  • 'IEEERemainder': Returns the remainder resulting from the division of one specified number by another.

Example: IEEERemainder(VAL(SIM.Ramp1), 2)


  • 'Sign': Returns a value indicating the sign of a number: -1 for negative, 0 for zero, and 1 for positive.

Example: Sign(VAL(SIM.Ramp1))


  • Special keywords:
    • $TIME: Gets the current time
    • $DATE: Gets the current date
    • $CURRENT_WIN: Gets the current opened graphical window's name
    • $CURRENT_USER: Gets the current logged user's name
    • $CURRENT_ACCESSLEVEL: Gets the current logged user's access level
    • $SERVER_CONNECT_STATUS: Returns 1 if server is connected


  • Special functions:
    • IsServerConnected(): Returns 1 if server is connected
    • GetConnectedServerIP(): Returns IP address of the connected server
    • VAL_AND_UNIT(arg1, arg2, arg3)

arg1: Tag name

arg2: Number format (See examples below)

arg3: Unit (This can be any string).

Example: VAL_AND_UNIT(VAL(LINE1.FT101),'0.0','m3')


  • Text formatting examples:




  • You can use "Formula Tester" to test your formulas as below:



In the below example, the syntax is wrong (because 'and' is in capital letters):