visual3d:documentation:pipeline:event_commands:event_copy
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
visual3d:documentation:pipeline:event_commands:event_copy [2024/06/14 17:25] – created sgranger | visual3d:documentation:pipeline:event_commands:event_copy [2025/02/26 17:04] (current) – wikisysop | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | |**Language: | + | ====== |
- | |===== Contents | + | ==== Overview |
+ | The **Event_Copy** command | ||
- | To make a copy of an event label, you can use a pipeline | + | This command |
- | ===== Interactive | + | The functionality of this command can also be achieved by right-clicking the event label within the data tree and selecting the "Event Copy" from the context menu. The interactive |
- | [[File: | + | {{: |
- | ===== From the Edit Events Dialog ===== | + | |
- | [[File: | ||
- | ===== Pipeline command: ===== | ||
- | **Event_Copy** | + | ==== Pipeline Command ==== |
- | /Event_Name= The name of the original event | + | The command below is the command as seen in the Visual3D |
- | / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | / | + | |
- | /[[Visual3D: | + | |
- | / | + | |
- | / | + | |
- | **;** | + | |
- | ==== Copy_Event ==== | + | |
- | The name of the Legacy command. Visual3D should continue to recognize this command. | + | < |
- | ===== Event Copy Dialog | + | /EVENT_NAME= |
+ | / | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | !/ | ||
+ | </ | ||
- | As of Version 5 this dialog is complicated. Interaction with the dialog is described [[Visual3D:Documentation: | + | ==== Command Parameters ==== |
+ | The following table shows the command parameters and descriptions: | ||
- | [[File: | + | |**Parameter** |
+ | |**/ | ||
+ | |**/NEW_EVENT_NAME=** | ||
+ | |**!/EVENT_INSTANCE=0** |Defines how many event occurrences to consider.| | ||
+ | |**!/EVENT_INSTANCE_AS_LIST=FALSE**| Indicates whether the event instance is treated as a list.| | ||
+ | |**!/RANGE_INSTANCE=0**| Specifies which instance of an event range should be used.| | ||
+ | |**!/ | ||
+ | |**!/ | ||
+ | |**!/ | ||
+ | |**!/ | ||
+ | |**!/ | ||
+ | |**!/ | ||
+ | |**!/ | ||
- | ===== Frame_Offset ===== | ||
- | Frame offset | + | ==== Dialog ==== |
+ | The command | ||
- | For example, if the offset is defined by a Metric signal in the Processed folder labeled SHIFT. | + | {{: |
- | **/ | + | |
- | ===== Time_Offset ===== | + | When set to 0, copies all instances of the event. When set to n, copy the //n//th instance of the event. |
+ | If n<1, count instances from the last event; e.g. -1 = last instance. | ||
- | Time offset can be a number or an expression. | + | * **Optional - Select Event Instance**: |
+ | When set to 0, it means all occurrences of the event will be processed. When **Interpret Event Instance As List** is checked, the event is treated as a list rather than a single value. | ||
- | For example, if the offset is defined by a Metric signal | + | ==== Examples ==== |
+ | The following examples will go through | ||
- | **/ | + | === Example |
- | For example, to create an event 1 second prior to an existing event. | + | |
- | **/ | + | The stance phase of the gait cycle is the period when the foot is in contact with the ground, it is defined by the labels RON and ROFF. The following command will create an event mid way between RON and ROFF. |
- | ===== Percent_Offset ===== | + | |
- | The percent offset can be a number or an expression. | + | <code> |
- | + | Event_Copy | |
- | The percent is the percentage of the range within the Event_Sequence. | + | |
- | + | ||
- | For example, if the offset is defined by a Metric signal in the Processed folder labeled PERCENT. | + | |
- | + | ||
- | **/ | + | |
- | ===== Event Instance ===== | + | |
- | + | ||
- | Event_Instance=0 -> copy all instances of the Event | + | |
- | + | ||
- | Event_Instance=n -> copy the nth instance of the Event | + | |
- | + | ||
- | if n<1 count instances from the last Event; e.g. -1 = last instance | + | |
- | + | ||
- | ===== Range Instance ===== | + | |
- | + | ||
- | Range_Instance=0 -> use all instances of the Range | + | |
- | + | ||
- | Range_Instance=n -> use the nth instance of the Range | + | |
- | + | ||
- | if n<1 count instances from the last Range; e.g. -1 = last range | + | |
- | + | ||
- | ===== Example_Event_At_Midstance ===== | + | |
- | + | ||
- | Given that stance phase is defined by the labels RON and ROFF | + | |
- | + | ||
- | The following command will create an event mid way between RON and ROFF. | + | |
- | + | ||
- | **Event_Copy** | + | |
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
- | **;** | + | ; |
- | [[File: | + | </code> |
- | This command | + | The dialog corresponding to the example |
- | ===== Example - Copying the last event in the sequence ===== | + | {{: |
- | The event sequence used in the event_copy | + | This command |
- | In order to copy the last event, you need to select | + | === Example 2: Copying |
- | For example, given a sequence | + | The event sequence |
+ | In order to copy the last event, you need to select the first event and an offset of 100%. For example, given a sequence of events A-B-C and you want to copy Event C and name it C2. | ||
+ | |||
+ | < | ||
Event_Copy | Event_Copy | ||
/ | / | ||
/ | / | ||
!/ | !/ | ||
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
- | **;** | + | ; |
- | ===== Example - Create an Event based on a time threshold between 2 Events ===== | + | </ |
- | For example, create an event (BAD) if the time between two events (RHS to RHS) exceeds a threshold. | ||
+ | === Example 3: Create an Event based on a time threshold between 2 Events === | ||
+ | In this example, an event named BAD is created if the time between two events (RHS-> RHS) exceeds a threshold. The following is the breakdown of the command: | ||
+ | - Define a Stride: the time between two consecutive RHS. | ||
+ | - Measure Stride Time: Calculates the duration of each STRIDE. | ||
+ | - Identify Long Strides: Checks if any STRIDE duration is longer than 4 seconds, if this is the case, it is flagged. | ||
+ | - Mark as " | ||
+ | |||
+ | < | ||
! Define an Event Sequence | ! Define an Event Sequence | ||
- | **Event_Define_Event_Sequence** | + | Event_Define_Event_Sequence |
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | **;** | + | ; |
! Compute the times of the Event_Sequence | ! Compute the times of the Event_Sequence | ||
- | **Metric_Time_Between_Events** | + | Metric_Time_Between_Events |
/ | / | ||
- | ! / | + | !/ |
/ | / | ||
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
- | **;** | + | ; |
! Create a binary signal from the stride time and threshold (4 in this case) | ! Create a binary signal from the stride time and threshold (4 in this case) | ||
- | **Evaluate_Expression** | + | Evaluate_Expression |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | **;** | + | ; |
! Create a pipeline parameter from the binary signal | ! Create a pipeline parameter from the binary signal | ||
- | **Set_Pipeline_Parameter_To_Data_Value** | + | Set_Pipeline_Parameter_To_Data_Value |
/ | / | ||
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
/ | / | ||
- | **;** | + | ; |
! Create indices for a for each loop | ! Create indices for a for each loop | ||
**Get_Pipeline_Parameter_Count** | **Get_Pipeline_Parameter_Count** | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
- | **Set_Pipeline_Parameter_From_For_Loop** | + | |
+ | Set_Pipeline_Parameter_From_For_Loop | ||
/ | / | ||
/ | / | ||
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
- | **;** | + | ; |
- | **For_Each** | + | |
+ | For_Each | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
! If the binary signal is 1 execute event copy | ! If the binary signal is 1 execute event copy | ||
- | **Expression_Loop** | + | Expression_Loop |
/ | / | ||
/ | / | ||
/ | / | ||
- | **;** | + | ; |
- | **Event_Copy** | + | |
+ | Event_Copy | ||
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
/ | / | ||
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | ! / | + | !/ |
/ | / | ||
- | ! / | + | !/ |
- | ! / | + | !/ |
- | **;** | + | ; |
- | **Expression_Loop_End** | + | |
+ | Expression_Loop_End | ||
/ | / | ||
- | **;** | + | ; |
- | **End_For_Each** | + | |
+ | End_For_Each | ||
/ | / | ||
- | **;** | + | ; |
+ | </ | ||
+ | |||
+ | ==== Notes ==== | ||
+ | | ||
+ | | ||
- | Retrieved from "" | ||
visual3d/documentation/pipeline/event_commands/event_copy.1718385926.txt.gz · Last modified: 2024/06/14 17:25 by sgranger