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:39] – created sgranger | visual3d:documentation:pipeline:expressions:mathematical_operators [2024/11/04 20:30] (current) – wikisysop | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== | + | ====== |
- | ==== Contents ==== | + | The [[visual3d: |
+ | **Arithmetic Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | **Boolean Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
- | | + | **Comparison Operators** |
- | | + | * [[# |
- | | + | * [[# |
- | | + | * [[# |
- | * [[#Power|5 Power]] | + | * [[# |
- | * [[# | + | * [[# |
- | * [[# | + | * [[# |
- | * [[#Equals|8 Equals]] | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[# | + | |
+ | 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 ==== | ==== Plus ==== | ||
- | NOTE: Pipeline command parameters use + as delimiter | + | Addition is accomplished using the + character. An alternative syntax is **add(a, |
- | If the user wants to use an expression containing a + in a command parameter that allows multiple signals, Visual3D will likely interpret this plus sign incorrectly. | + | NOTE: Pipeline command parameters use the + character as a delimiter. |
- | The workaround is to use a mathematical function | + | < |
+ | 2 + 3 = 5 | ||
+ | add(2,3) = 5 | ||
+ | </ | ||
- | **add(a, | ||
==== Minus ==== | ==== Minus ==== | ||
+ | |||
+ | Subtraction is accomplished using the - character. | ||
+ | |||
+ | < | ||
+ | 3 - 2 = 1 | ||
+ | </ | ||
==== Multiply ==== | ==== Multiply ==== | ||
+ | |||
+ | Multiplication is accomplished using the * character. | ||
+ | |||
+ | < | ||
+ | 3 * 2 = 6 | ||
+ | </ | ||
==== Divide ==== | ==== Divide ==== | ||
+ | |||
+ | Division is accomplished using the / character. | ||
+ | |||
+ | < | ||
+ | 6 / 3 = 2 | ||
+ | </ | ||
==== Power ==== | ==== Power ==== | ||
- | ==== Logical_Or ==== | + | Exponentiation is accomplished using the ^ character. |
- | Logical Or | + | < |
- | ==== Logical_And ==== | + | 2^3 = 8 |
+ | </ | ||
- | Logical And | + | ===== Boolean Operators ===== |
- | ==== Equals | + | |
- | **= or ==** - Boolean | + | Boolean |
- | Example: Comparing a model metric | + | |
- | Consider a model metric that is defined as a string. | + | ==== Logical OR ==== |
- | **Set_Model_Metric** | + | |
- | ! / | + | |
- | / | + | |
- | / | + | |
- | **;** | + | |
- | Now compare it to the text string " | + | |
- | **Evaluate_Expression** | + | |
- | /EXPRESSION=MODEL:: | + | |
- | / | + | |
- | / | + | |
- | ! / | + | |
- | **;** | + | |
- | The text strings should be equal so the resulting signal contains a 1 | + | |
- | ==== Not_Equals | + | |
- | **<> or ><** - Boolean Operator "Not Equals" | + | 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. |
- | ==== Using the Adjective NOT ==== | + | |
- | NOT can be used with the logical AND and logical OR | + | < |
+ | FALSE | FALSE = FALSE | ||
+ | FALSE | TRUE = TRUE | ||
+ | TRUE | FALSE = TRUE | ||
+ | TRUE | TRUE = FALSE | ||
+ | </ | ||
- | Example: Given a workspace containing 3 trials (*trial1.c3d, | + | ==== Logical AND ==== |
- | All trials | + | The Logical AND operator is signified by the & character. It takes two boolean values as input and returns TRUE when both input values |
+ | < | ||
+ | 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 | * trial1.c3d is also assigned a TAG labeled BAD | ||
- | [[Visual3D: | + | < |
+ | Select_Active_File | ||
/ | / | ||
/QUERY=BAD | /QUERY=BAD | ||
- | **;** | + | ; |
+ | </ | ||
This command results in *trial1.c3d being active | This command results in *trial1.c3d being active | ||
- | [[Visual3D: | + | < |
+ | Select_Active_File | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
+ | </ | ||
This command results in *trial2.c3d and *trial3.c3d being active. | This command results in *trial2.c3d and *trial3.c3d being active. | ||
- | ==== Less_Than | + | ===== 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. | ||
- | **<** Boolean Operator //less than// | + | ===Example=== |
- | **Example** | + | Given two signals TARGET:: |
- | Given two signals | + | <code> |
- | TARGET:: | + | Evaluate_Expression |
- | TARGET:: | + | |
- | Use the Boolean operator | + | |
- | **Evaluate_Expression** | + | |
/ | / | ||
/ | / | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
+ | </ | ||
The output signal will be 1 when RFT1::Z is less than LFT1::Z and 0 otherwise | The output signal will be 1 when RFT1::Z is less than LFT1::Z and 0 otherwise | ||
- | **Example - Foot Clearance** | ||
- | Given the following situation. | + | ===Example - Foot Clearance=== |
- | One might consider Foot clearance | + | |
- | {{heel_toe_clearance.jpg}} | + | Heel and toe clearance are defined by two paths. |
- | Here is a simplified test of this | + | {{:heel_toe_clearance.jpg}} |
- | Make the Global Workspace Active. | + | |
- | Create | + | Here is a simplified test of this. First, make the Global Workspace Active. |
- | **Evaluate_Expression** | + | |
+ | < | ||
+ | Evaluate_Expression | ||
/ | / | ||
! / | ! / | ||
Line 123: | Line 203: | ||
/ | / | ||
! / | ! / | ||
- | **;** | + | ; |
- | **Evaluate_Expression** | + | |
+ | Evaluate_Expression | ||
/ | / | ||
! / | ! / | ||
Line 134: | Line 215: | ||
/ | / | ||
! / | ! / | ||
- | **;** | + | ; |
- | !create a new signal that is the lower value of the two signals | + | |
- | **Evaluate_Expression** | + | !create a new signal that is the lower value of the two signals |
+ | Evaluate_Expression | ||
/ | / | ||
+(DERIVED:: | +(DERIVED:: | ||
Line 148: | Line 229: | ||
/ | / | ||
! / | ! / | ||
- | **;** | + | ; |
- | {{heel_toe_clearance2.jpg}} | + | </ |
- | ==== Less_Than_Or_Equals ==== | + | |
- | ! style=" | + | {{:heel_toe_clearance2.jpg}} |
- | Example: | + | ==== Less Than Or Equals ==== |
- | Given two signals | + | This boolean operator uses one of the following syntaxes: <= or =<. |
- | TARGET:: | + | |
- | TARGET:: | + | The expression (a <= b) is equivalent logically to ((a < b) | (a == b)). |
- | Use the Boolean operator <= or the boolean operative =< to identify when the Z component of RFT1 is less than or equal to the Z component of LFT1 | + | |
- | **Evaluate_Expression** | + | ===Example=== |
+ | |||
+ | Given two signals TARGET:: | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
/ | / | ||
/ | / | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
- | The output signal will be 1 when RFT1::Z is less than or equal toLFT1::Z and 0 otherwise | + | </ |
- | ==== Greater_Than ==== | + | |
- | **>** Boolean Operator // | + | The output signal will be 1 (indicating TRUE) when RFT1::Z is less than or equal to LFT1::Z and 0 (indicating FALSE) otherwise. |
- | Example: | + | ==== Greater Than ==== |
- | Given two signals | + | We can test is one value is less than another using the > character. |
- | TARGET:: | + | |
- | TARGET:: | + | ===Example=== |
- | Use the Boolean operator > to identify when the Y component of RFT1 is greater than the Y component of LFT1 | + | |
- | **Evaluate_Expression** | + | Given two signals TARGET:: |
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
/ | / | ||
/ | / | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
- | The output signal will be 1 when RFT1::Y is greater than LFT1::Y and 0 otherwise | + | </ |
- | ==== Greater_Than_Or_Equals | + | |
+ | The output signal will be 1 (indicating TRUE) when RFT1::Y is greater than LFT1::Y and 0 (indicating FALSE) | ||
+ | |||
+ | ==== Greater Than Or Equals | ||
+ | |||
+ | This boolean operator uses one of the following syntaxes: >= or =>. | ||
- | **>=** Boolean Operator //greater than or equals// | + | The expression (a >= b) is equivalent logically to ((a > b) | (a == b)). |
visual3d/documentation/pipeline/expressions/mathematical_operators.1720028398.txt.gz · Last modified: 2024/07/03 17:39 by sgranger