Skip to content

Expressions

Expressions are used throughout WinScript to perform logical analysis, triggers, and mathematical operations.

Logic

Logical analysis is performed in conjunction with the If, Else, and End If events. When an expression is used with an If event, all events located after the If event and before an Else or End If event will be executed if the expression evaluates as TRUE. If the expression evaluates as FALSE, any events located between the Else and End If events will be executed. If there is no Else event, the sequence will simply skip to the End If event.

Here's an example using just If and End If events:

Here's an example of If, Else, and End If being used together:

When adding events to a Timed sequence, expressions can be used in the Condition column of each event. If an expression is associated with a timed event, that event will only execute if the expression evaluates as TRUE.

Triggers

Expressions can also be used to trigger sequences. In this case, expressions are constantly analyzed and if they ever become TRUE, the trigger will occur.

Math

Mathematical operations are also possible thanks to expressions. Various operators and functions (listed below) can be used to make calculations to any constant or variable values you enter into the expression formula.

Variables

Up to 8 variable names can be used within an expression. Each variable is converted to a Decimal value before evaluating the expression.

Important Note: Variable names that contain operators such as '-' must be wrapped in backtick marks. For example, given the follow variables and values, choosing to not use backticks changes the meaning of the expression.

Name Value
taco 5
tuesday 2
taco-tuesday 7

With backticks "`taco-tuesday`+1" = 8

Without backticks "taco-tuesday+1" = 4

Values

explicit values can also be used in an expression. A common example is using true or false for boolean comparisons. Integers, Decimals, Percents, and Timecode values are also supported. For timecode values, the expression will use the system framerate by default, but if the expression contains a timecode variable within it, then the timecode variable's framerate will be used. Expressions support partial or full timecode values; as long as there is a colon as a timecode delimeter, the expression will interpret it as a timecode value. Timecode values are evaluated as fractiona; seconds by default, unless the toframes function is used.

Expression Operators

These are the supported operators for Boolean logic:

Operator Description
! NOT
< Less Than
<= Less Than or Equal To
> Greater Than
>= Greater Than or Equal To
== Equal To
!= NOT Equal To
&& AND
|| OR

Supported Operators:

Operator Description
+ Add
- Subtract
* Multiply
/ Divide
% Modulo
^ Power
() Parentheses
`` Backtick

Expression Functions

Supported Functions:

Function Description
cos(x) cosine of a radian angle x
cosh(x) hyperbolic cosine of x
acos(x) arc cosine of x in radians
sin(x) sine of a radian angle x
sinh(x) hyperbolic cosine of x
asin(x) arc sine of x in radians
tan(x) tangent of a radian angle x
tanh(x) hyperbolic tangent of x atan(x) arc tangent of x in radians
atan2(y,x) arc tangent in radians of y/x based on the signs of both values to determine the correct quadrant
abs(x) absolute value of x
ceil(x) rounds up x to a whole number
floor(x) rounds down x to a whole number
ln(x) natural log of x (base-e)
log(x) log of x (base-10)
ncr(n,r) number of unordered set of r items from a set of n items. (combinations)
npr(n,r) number of ordered set of r items from a total of n items (permutations)
pow(x,y) x to the y power
exp(y) e to the y power
fac(x) factorial of x
sqrt(x) square root of x
pi() Pi Constant - 3.14159...
e() Euler's Number Constant - 2.71828...
toframes(x,y) frame count of timecode x at y framerate
totime(x,y) decimal value of timecode x at y framerate