Expressions

Expressions have a timer option but what controls the timing.

EMs have 4 expression timers each that the expression will use based on the index chosen.  This also allows other expressions to share the timer value by referencing the same index of the same EM.

Problem:

Other objects don’t have built in timers so they can’t use timers nor reference specific timers.

Solution:

  • Use the EM timers for EMs
  • Add an Expression timer for non-EMs. These can only be used by the expression directly as a value or a periodic pulse.

Currently, the AOI has the non-EM timers but that doesn’t really work because the same AOI is used for all expressions so they would all be using the same timer.   Although they could just let the timer free run and simply track the starting/ending times in seconds as a DINT

Timers 

Expression timing is accomplished by using a global rolling timestamp which is in seconds and rolls around every 24 days.

Each expression can track only 1 timer so an expression cannot contain a timer in both of its variables.  If used in both variables unpredictable results will occur.  One of the variable timers must be wrapped in a sub-expression.

Although any expression can use a timer; only EMs and CMs can reference an expressions timer value.

When creating the expression timer you have index option which is irrelevant unless the timer is going to be referred to by another expression.

When the expression is used in an EM environment then the expression timer values are also recorded into the EM UDT according to the selected index.

When the expression is used in a CM environment the expression timer value is also recorded into the CM UDT but regardless of its index.

RLO

RLOlast

bValue1

bValue2

 

RLO = TRUE (default)

15->71

16

refValue -> myValue1

NEQ 0 OLT bValue1

bValue1 = TRUE

 

Since bValue1 = true RLO remains true

 

Var2

 

Return2

myValue1 = myExpr.Value

Push Expression

RLO = myExpr.RLO = TRUE (memory)

Get Expression to myExpr

Restore RLO = TRUE

 

Var1 = Timer

RLO = True so don’t reset

Timer -> myValue1

Set bValue1 if timer <> 0

 

Var2 = Constant

RefValue -> myValue2

Set bValue2 if myValue2<> 0

 

Evaluate myValue1 > myValue2 OTL Results

 

IF NOT Results RLO = FALSE

Otherwise leave RLO alone

 

Troubleshooting

Expressions may be monitored from the EM view.

A list of all expressions will be presented or the expression may be chosen on function such as the Complete Expression.

Once an expression is selected it will be marked to monitor for that instance.

A Value member will be added to each Variable Definition but in expressions, it will only be updated when that expression is the one being monitored or none are monitored.

 

A tree node will be used to walk the expression.  WPF will also be used so the value of the node can be expressed to the far right as TRUE/FALSE or a REAL value.  An node prefixed with a #: is an expression where # is the expression ID. Other nodes are variable definitions within the expression.  Sometimes a variable references another expression.

 

30) {This.Running) [TRUE] 2: > 30 [FALSE] [12.5] 30 [30] ” src=”” style=”margin: 0px; padding: 0px; user-select: text; -webkit-user-drag: none; -webkit-tap-highlight-color: transparent; border: none; width: 345px; height: 125px;”>

 

Expression (EXP)

ID INT  
ProcID SINT  
Oper SINT  
OperLabel STRx04  
Var1 EXP_VAR  
Var2 EXP_VAR  
Value REAL  
Monitor BOOL This expression is being monitored so update its value members
MonitorID INT ID of EM or CM to monitor; 0 = none.

 

Create a new expression reference that includes text with 32 elements

Variable (EXP_VAR)

ID INT
CtrlID SINT
Type SINT
PRID INT
Context SINT
UoM SINT
Label Strx32
Value REAL

 

Add Expression tags to EM_View to signal the HMI to display when an expression exists.

 

EM_VIEW

ID DINT
PB EM_VIEW_PB (add
Tile HasOnExpr, HasOffExpr
  OnExprID, OffExprID
   

 

HMI displays a small icon when an object has an expression.

Clicking on the icon will open the Expression Monitor and will pass in a tag template ([alias].EXPRs[id] where id comes from another tag) and the expressions parent ID which is the ID of the faceplate containing the expressions.

 

The expression monitor faceplate will write to the expressions monitor ID the parent ID which will cause that expression and all of its child expressions to update value members when processing for that instance.  If the monitor ID is 0 then it will update the value anytime it runs.

Therefore it is important for the faceplate to clear the value when exiting.

The HMI should warn if the value is not zero before overwriting that it may be taking control from someone else.

 

30) {This.Running) [TRUE] 2: > 30 [FALSE] [12.5] 30 [30] ” src=”” style=”margin: 0px; padding: 0px; user-select: text; -webkit-user-drag: none; -webkit-tap-highlight-color: transparent; border: none; width: 345px; height: 125px;”>

 

###: ssssssssssssssssssssssssssssss ssss ssssssssssssssssssssssssssssss    ######## or sssss  (value or True/False)

[…]     ssssssssssssssssssssssssssssss   (var 1 Label )                                     ########

[…]     ssssssssssssssssssssssssssssss   (var 2 Label )                                     ########

 

[…] = Button if the variable is an expression to open that expression (this will need to be a different window since it doesn’t need to pass the parent ID since the top level should have already set the monitor for all child levels.

 

 

Challenge:
How to animate where expressions exist?

 

EM Expressions:

Expression Affects Icon Location Tag
Auto Start Green checkered Flag on Start button On Start Button  
Auto Stop Black checkered flag on Start Button On Stop Button  
Abort   On Abort Button  
Complete   ?  
Stage 2-3   ?  
Stage 3-2   ?  
Process Condition 0   On Abnormal Condition Navigation Button  
Process Condition 1   On Abnormal Condition Navigation Button  
Child CM Activate CM Tile – Up to 32 At upper right EM_FTSE.Tile[n].ActvtExprID
Child CM Deactivate CM Tile – Up to 48 At lower right EM_FTSE.Tile[n].DeactvtExprID
Control Parameters Up to 19 (some are hidden) Just to left of CP value EM_FTSE.Param[n].CP.ExprID
Report Parameters Up to 15 (some are hidden) Just to right of RP Value EM_FTSE.Param[n].RP.ExprID
CP     EM_FTSE.c.Exprs[1-20]
RP     EM_FTSE.c.Exprs[21-35]
Tags Up to 8   EM_FTSE.c.Exprs[40-48]

 

An expression list icon could be presented next to the expression visibility icon if other expressions exists that cannot be represented.  This list will list out all expressions by name.

 

EM List example:

 

Stage 2-3

CP 1

CP 2

RP 1

Etc.

 

Controller Expression List

 

EM_VIEW

Exprs OPER_EXPR[10]  
     ID INT Search all expressions and provide ID
     Name STRx16 Build name based on where expression was found
     Desc STRx48 Comes from expression Var labels
ExprPg OPER_PAGE  
ExprCnt SINT  

 

Macro

!===== Macro File created  11/12/2016 ===============================

! Macros are lists of commands, with one command per line

! See Help or the manual for a list of commands and their parameters

!============================================================

! Expression Monitor Macro

! These parameters are passed into the macro

! 1 is the Expression ID Tag to Monitor

! 2 is the Paraent ID

 

SET {[Reactor_PREQC]EXPRs[$%1$].MonitorID} $%2$

Display s88b_Expr /T {[Reactor_PREQC]EXPRs[$%1$]}

Updated on December 6, 2018

Related Articles

Password Protected