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/06/19 12:49] – sgranger | visual3d:documentation:pipeline:expressions:mathematical_operators [2024/11/04 20:30] (current) – wikisysop | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | {{{{===== contents | + | ====== Mathematical Operators |
+ | The [[visual3d: | ||
+ | **Arithmetic Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
- | | + | **Boolean Operators** |
- | | + | * [[#Logical_Or|Logical OR]] |
- | | + | * [[#Logical_And|Logical AND]] |
- | | + | * [[#Using_the_Adjective_NOT|The Adjective NOT]] |
- | * [[#power|5 power]] | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[#equals|8 equals]] | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[# | + | |
- | * [[#less_than_or_equals|12 less_than_or_equals]] | + | |
- | * [[#greater_than|13 greater_than]] | + | |
- | * [[#greater_than_or_equals|14 greater_than_or_equals]] | + | |
+ | **Comparison Operators** | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
+ | * [[# | ||
- | ===== plus ===== | + | 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. |
- | note: pipeline command parameters use + as delimiter | + | ===== Arithmetic Operators ===== |
- | 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. | + | Arithmetic operations can generally be performed using syntax that is similar |
- | the workaround is to use a mathematical function add() to express the addition. | + | ==== Plus ==== |
- | **add(a, | + | Addition is accomplished using the + character. An alternative syntax is **add(a, |
- | ===== minus ===== | + | |
- | ===== multiply ===== | + | 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, |
- | ===== divide ===== | + | < |
+ | 2 + 3 = 5 | ||
+ | add(2, | ||
+ | </ | ||
- | ===== power ===== | + | ==== Minus ==== |
- | ===== logical_or ===== | + | Subtraction is accomplished using the - character. |
- | logical or | + | < |
- | ===== logical_and ===== | + | 3 - 2 = 1 |
+ | </ | ||
- | logical and | + | ==== Multiply |
- | ===== equals ===== | + | |
- | **= or ==** - boolean operator // | + | Multiplication is accomplished using the * character. |
- | example: comparing a model metric with a string | + | |
- | consider a model metric that is defined as a string. | + | < |
- | **set_model_metric** | + | 3 * 2 = 6 |
- | ! / | + | </code> |
- | /metric_name=test | + | |
- | / | + | |
- | **;** | + | |
- | now compare it to the text string " | + | |
- | **evaluate_expression** | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | ! / | + | |
- | **;** | + | |
- | the text strings should be equal so the resulting signal contains a 1 | + | |
- | ===== not_equals ===== | + | |
- | **<> or ><** - boolean operator "not equals" | + | ==== Divide |
- | ===== using the adjective not ===== | + | |
- | not can be used with the logical and and logical or | + | Division is accomplished using the / character. |
- | example: given a workspace containing | + | < |
+ | 6 / 3 = 2 | ||
+ | </ | ||
- | all trials are assigned a tag labeled walk | + | ==== Power ==== |
- | * trial1.c3d | + | Exponentiation |
- | [[visual3d: | + | < |
- | /file_name=walk | + | 2^3 = 8 |
- | /query=bad | + | </code> |
- | **;** | + | |
- | this command results in *trial1.c3d being active | + | |
- | [[visual3d: | + | ===== Boolean Operators ===== |
- | /file_name=walk | + | |
- | /query=not(bad) | + | |
- | **;** | + | |
- | this command results in *trial2.c3d and *trial3.c3d being active. | + | |
- | ===== less_than ===== | + | Boolean operators deal with boolean values, such as TRUE and FALSE. These are represented numerically as 1 (TRUE) and 0 (FALSE). |
- | **<** boolean operator //less than// | + | ==== Logical OR ==== |
- | **example** | + | 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. |
- | given two signals | + | < |
- | target::original::rft1 | + | FALSE | FALSE = FALSE |
- | target::original::lft1 | + | FALSE | TRUE = TRUE |
- | use the boolean | + | TRUE | FALSE = TRUE |
- | **evaluate_expression** | + | TRUE | TRUE = FALSE |
- | /expression= target::original::rft1::z < target::original::lft1::z | + | </ |
- | /result_name=rft1_greater | + | |
- | /result_type=derived | + | ==== Logical AND ==== |
- | /result_folder=processed | + | |
- | **;** | + | 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. |
- | the output signal will be 1 when rft1::z is less than lft1::z and 0 otherwise | + | |
- | **example | + | < |
+ | 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 | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | 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::ORIGINAL::RFT1 and TARGET:: | ||
+ | |||
+ | < | ||
+ | Evaluate_Expression | ||
+ | /EXPRESSION= TARGET::ORIGINAL::RFT1::Z < TARGET::ORIGINAL::LFT1::Z | ||
+ | /RESULT_NAME=RFT1_GREATER | ||
+ | /RESULT_TYPE=DERIVED | ||
+ | /RESULT_FOLDER=PROCESSED | ||
+ | ; | ||
+ | </ | ||
+ | |||
+ | The output signal will be 1 when RFT1::Z is less than LFT1::Z and 0 otherwise | ||
+ | |||
+ | ===Example | ||
+ | |||
+ | Heel and toe clearance are defined by two paths. It is possible to model "foot clearance" as the lower value of the heel and toe clearance values at each frame. | ||
+ | {{: | ||
+ | |||
+ | 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 | ||
+ | / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | ! / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ! / | ||
+ | ; | ||
- | given the following situation. heel and toe clearance are defined by two paths. | ||
- | one might consider foot clearance to be the lower value of the heel and toe clearance values at each frame. | ||
- | heel_toe_clearance.jpg | ||
- | here is a simplified test of this | ||
- | make the global workspace active. | ||
- | create 2 signals as follows | ||
- | **evaluate_expression** | ||
- | / | ||
- | ! / | ||
- | ! / | ||
- | ! / | ||
- | ! / | ||
- | / | ||
- | / | ||
- | / | ||
- | ! / | ||
- | **;** | ||
- | **evaluate_expression** | ||
- | / | ||
- | ! / | ||
- | ! / | ||
- | ! / | ||
- | ! / | ||
- | / | ||
- | / | ||
- | / | ||
- | ! / | ||
- | **;** | ||
!create a new signal that is the lower value of the two signals | !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. | ||
- | **evaluate_expression** | + | ===Example=== |
- | /expression=(derived:: | + | |
- | +(derived:: | + | |
- | ! / | + | |
- | ! / | + | |
- | ! / | + | |
- | ! / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | ! / | + | |
- | **;** | + | |
- | heel_toe_clearance2.jpg | + | |
- | ===== less_than_or_equals | + | |
- | ! style=" | + | Given two signals TARGET:: |
- | example: | + | < |
+ | Evaluate_Expression | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | / | ||
+ | ; | ||
+ | </ | ||
- | given two signals | + | The output signal will be 1 (indicating TRUE) when RFT1::Y is greater |
- | target:: | + | |
- | target:: | + | |
- | 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** | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | **;** | + | |
- | the output signal will be 1 when rft1::z is less than or equal tolft1::z and 0 otherwise | + | |
- | ===== greater_than ===== | + | |
- | **>** boolean operator //greater than// | + | ==== Greater Than Or Equals ==== |
- | example: | + | This boolean operator uses one of the following syntaxes: >= or =>. |
- | given two signals | + | The expression |
- | target:: | + | |
- | target:: | + | |
- | use the boolean operator > to identify when the y component of rft1 is greater than the y component of lft1 | + | |
- | **evaluate_expression** | + | |
- | /expression= target:: | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | **;** | + | |
- | the output signal will be 1 when rft1:: | + | |
- | ===== greater_than_or_equals ===== | + | |
- | **>=** boolean operator //greater than or equals// | ||
- | }}}} |
visual3d/documentation/pipeline/expressions/mathematical_operators.1718801397.txt.gz · Last modified: 2024/06/19 12:49 by sgranger