visual3d:documentation:pipeline:expressions:mathematical_operators
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
visual3d:documentation:pipeline:expressions:mathematical_operators [2024/07/03 17:28] – removed sgranger | visual3d:documentation:pipeline:expressions:mathematical_operators [2024/11/04 20:30] (current) – wikisysop | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | ====== Mathematical Operators | ||
+ | |||
+ | The [[visual3d: | ||
+ | |||
+ | **Arithmetic Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | |||
+ | **Boolean Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | |||
+ | **Comparison Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | |||
+ | Note: Visual3D parses the mathematical operators before it parses the signal names. If you have a signal name that contains a mathematical operator (e.g. R-Foot1), Visual3D will probably not be able to parse the equation expression properly. | ||
+ | |||
+ | ===== Arithmetic Operators ===== | ||
+ | |||
+ | Arithmetic operations can generally be performed using syntax that is similar to that found in a variety of programming and scripting languages. | ||
+ | |||
+ | ==== Plus ==== | ||
+ | |||
+ | Addition is accomplished using the + character. An alternative syntax is **add(a, | ||
+ | |||
+ | NOTE: Pipeline command parameters use the + character as a delimiter. If the user wants to use an expression containing a + in a command parameter that allows multiple signals, then Visual3D will likely interpret this plus sign incorrectly. In this case the **add(a, | ||
+ | |||
+ | < | ||
+ | 2 + 3 = 5 | ||
+ | add(2,3) = 5 | ||
+ | </ | ||
+ | |||
+ | ==== Minus ==== | ||
+ | |||
+ | Subtraction is accomplished using the - character. | ||
+ | |||
+ | < | ||
+ | 3 - 2 = 1 | ||
+ | </ | ||
+ | |||
+ | ==== Multiply ==== | ||
+ | |||
+ | Multiplication is accomplished using the * character. | ||
+ | |||
+ | < | ||
+ | 3 * 2 = 6 | ||
+ | </ | ||
+ | |||
+ | ==== Divide ==== | ||
+ | |||
+ | Division is accomplished using the / character. | ||
+ | |||
+ | < | ||
+ | 6 / 3 = 2 | ||
+ | </ | ||
+ | |||
+ | ==== Power ==== | ||
+ | |||
+ | Exponentiation is accomplished using the ^ character. | ||
+ | |||
+ | < | ||
+ | 2^3 = 8 | ||
+ | </ | ||
+ | |||
+ | ===== Boolean Operators ===== | ||
+ | |||
+ | Boolean operators deal with boolean values, such as TRUE and FALSE. These are represented numerically as 1 (TRUE) and 0 (FALSE). | ||
+ | |||
+ | ==== Logical OR ==== | ||
+ | |||
+ | The Logical OR operator is signified by the | character. It takes two boolean values as input and returns TRUE if either of the input values is TRUE. | ||
+ | |||
+ | < | ||
+ | FALSE | FALSE = FALSE | ||
+ | FALSE | TRUE = TRUE | ||
+ | TRUE | FALSE = TRUE | ||
+ | TRUE | TRUE = FALSE | ||
+ | </ | ||
+ | |||
+ | ==== Logical AND ==== | ||
+ | |||
+ | The Logical AND operator is signified by the & character. It takes two boolean values as input and returns TRUE when both input values are TRUE. | ||
+ | |||
+ | < | ||
+ | FALSE | FALSE = FALSE | ||
+ | FALSE | TRUE = FALSE | ||
+ | TRUE | FALSE = FALSE | ||
+ | TRUE | TRUE = FALSE | ||
+ | </ | ||
+ | |||
+ | ==== The Adjective NOT ==== | ||
+ | |||
+ | The logical adjective NOT can be used with both the logical AND and logical OR operators. It takes one boolean value as input and negates that boolean value. | ||
+ | |||
+ | < | ||
+ | NOT(FALSE) = TRUE | ||
+ | NOT(TRUE) = FALSE | ||
+ | </ | ||
+ | |||
+ | ===Example=== | ||
+ | |||
+ | Given a workspace containing 3 trials (*trial1.c3d, | ||
+ | * All trials are assigned a TAG labeled WALK | ||
+ | * trial1.c3d is also assigned a TAG labeled BAD | ||
+ | |||
+ | < | ||
+ | Select_Active_File | ||
+ | / | ||
+ | /QUERY=BAD | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | This command results in *trial1.c3d being active | ||
+ | |||
+ | < | ||
+ | Select_Active_File | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | This command results in *trial2.c3d and *trial3.c3d being active. | ||
+ | |||
+ | ===== Comparison Operators ===== | ||
+ | |||
+ | Comparison operators take two inputs of the same type and return a boolean value. | ||
+ | |||
+ | ==== Equals ==== | ||
+ | |||
+ | Equality is tested using either = or ==. It returns TRUE if the two inputs have the same value and FALSE if they do not. | ||
+ | |||
+ | ===Example=== | ||
+ | |||
+ | Consider a model metric that is defined as a string and compare it to an explicitly defined string. | ||
+ | |||
+ | < | ||
+ | Set_Model_Metric | ||
+ | ! / | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | |||
+ | Evaluate_Expression** | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ! / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | The text strings are equal, so the resulting signal contains a 1 (indicating TRUE). | ||
+ | |||
+ | ==== Not Equals ==== | ||
+ | |||
+ | Non-equality is tested using either <> or ><. Its behaviour is opposite that of equality. | ||
+ | |||
+ | If (a==b) is TRUE then (a<> | ||
+ | |||
+ | ==== Less Than ==== | ||
+ | |||
+ | We can test is one value is less than another using the < character. | ||
+ | |||
+ | ===Example=== | ||
+ | |||
+ | Given two signals TARGET:: | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | The output signal will be 1 when RFT1::Z is less than LFT1::Z and 0 otherwise | ||
+ | |||
+ | ===Example - Foot Clearance=== | ||
+ | |||
+ | Heel and toe clearance are defined by two paths. It is possible to model "foot clearance" | ||
+ | {{: | ||
+ | |||
+ | Here is a simplified test of this. First, make the Global Workspace Active. Then, create 2 toy signals and calculate a third signal containing the lower value of the two toy signals. | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
+ | / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ! / | ||
+ | ; | ||
+ | |||
+ | Evaluate_Expression | ||
+ | / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ! / | ||
+ | ; | ||
+ | |||
+ | !create a new signal that is the lower value of the two signals | ||
+ | Evaluate_Expression | ||
+ | / | ||
+ | +(DERIVED:: | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ! / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | {{: | ||
+ | |||
+ | ==== Less Than Or Equals ==== | ||
+ | |||
+ | This boolean operator uses one of the following syntaxes: <= or =<. | ||
+ | |||
+ | The expression (a <= b) is equivalent logically to ((a < b) | (a == b)). | ||
+ | |||
+ | ===Example=== | ||
+ | |||
+ | Given two signals TARGET:: | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | The output signal will be 1 (indicating TRUE) when RFT1::Z is less than or equal to LFT1::Z and 0 (indicating FALSE) otherwise. | ||
+ | |||
+ | ==== Greater Than ==== | ||
+ | |||
+ | We can test is one value is less than another using the > character. | ||
+ | |||
+ | ===Example=== | ||
+ | |||
+ | Given two signals TARGET:: | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | The output signal will be 1 (indicating TRUE) when RFT1::Y is greater than LFT1::Y and 0 (indicating FALSE) otherwise. | ||
+ | |||
+ | ==== Greater Than Or Equals ==== | ||
+ | |||
+ | This boolean operator uses one of the following syntaxes: >= or =>. | ||
+ | |||
+ | The expression (a >= b) is equivalent logically to ((a > b) | (a == b)). | ||
+ | |||
+ | |||
visual3d/documentation/pipeline/expressions/mathematical_operators.1720027697.txt.gz · Last modified: 2024/07/03 17:28 by sgranger