User Tools

Site Tools


visual3d:documentation:pipeline:event_commands:event_copy

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
visual3d:documentation:pipeline:event_commands:event_copy [2024/07/17 15:45] – created sgrangervisual3d:documentation:pipeline:event_commands:event_copy [2025/02/26 17:04] (current) wikisysop
Line 1: Line 1:
 ====== Event Copy ====== ====== Event Copy ======
  
-To make copy of an event label, you can use a pipeline command or you can select the event in the data tree using the right mouse button.+==== Overview ==== 
 +The **Event_Copy** command allows users to __create new event by copying an existing event and applying optional modifications__. Users can specify an offset for the copied event in terms of frames, time or percentage of a defined range. Additionally, users can control the sequence of copied events, exclude certain events from copying, or define specific start and end events for more refined event duplication.
  
-==== Interactive selection from the data tree: ====+This command is particularly useful for scenarios where new events need to be derived from existing ones while maintaining precise temporal relationships.
  
-{{:CopyEventMenu.jpg}}] +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 menuThe interactive selection from the data tree is shown below:
-==== From the Edit Events Dialog ====+
  
-{{:EditEventsDlg.jpg}} +{{:visual3d:documentation:pipeline:event_commands:interactive_selection_eventcopy.png?320|}}
-==== Pipeline command: ====+
  
-**Event_Copy** 
-/Event_Name= The name of the original event 
-/New_Event_Name= The name to be given to the **new event** 
-/[[#Frame_Offset|Frame_Offset]]= The frame offset from the Event_Frame 
-/[[#Time_Offset|Time_Offset]]= The time offset from the Event Frame 
-/[[#Percent_Offset|Percent_Offset]]= An offset from the Event Frame as a percentage of the ranged defined by the Event_Sequence 
-/[[Visual3D:Documentation:C3D_Signal_Types:EVENT_LABEL_Data_Type#Event_Sequence|Event_Sequence]]= Sequence of Events that defines the ranges 
-/[[Visual3D:Documentation:C3D_Signal_Types:EVENT_LABEL_Data_Type#Exclude_Events|Exclude_Events]]= An inclusive Event that excludes the range 
-/[[Visual3D:Documentation:C3D_Signal_Types:EVENT_LABEL_Data_Type#Event_Instance|Event_Instance]]= The instance of the existing event to copy. 
-/[[Visual3D:Documentation:C3D_Signal_Types:EVENT_LABEL_Data_Type#Event_Instance|Range_Instance]]= The instance of the existing event to copy. 
-/Start_At_Event= Start of Range to Find the Event (legacy-superceded by Event_Sequence) 
-/End_At_Event= End of Range to Find the Event (legacy-superceded by Event_Sequence) 
-**;** 
-=== Copy_Event === 
  
-The name of the Legacy command. Visual3D should continue to recognize this command. +==== Pipeline Command ==== 
-==== Event Copy Dialog ====+The command below is the command as seen in the Visual3D application. 
  
-As of Version 5 this dialog is complicated. Interaction with the dialog is described [[Visual3D:Documentation:Pipeline:Event_Commands:Event_Management_Commands|here]].+<code> 
 +/EVENT_NAME= 
 +/NEW_EVENT_NAME= 
 +!/EVENT_INSTANCE=0 
 +!/EVENT_INSTANCE_AS_LIST=FALSE 
 +!/RANGE_INSTANCE=0 
 +!/EVENT_SEQUENCE= 
 +!/START_AT_EVENT= 
 +!/END_AT_EVENT= 
 +!/FRAME_OFFSET= 
 +!/TIME_OFFSET= 
 +!/PERCENT_OFFSET= 
 +</code>
  
-{{:CopyEventLabelDlgEx1.jpg}}+==== Command Parameters ==== 
 +The following table shows the command parameters and descriptions:
  
-==== Frame_Offset ====+|**Parameter**     |**Description**| 
 +|**/EVENT_NAME=**  |The name of the event to be copied.| 
 +|**/NEW_EVENT_NAME=**  |The name of the new copied event.| 
 +|**!/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.| 
 +|**!/EVENT_SEQUENCE=** |Determines whether the copied event follows a specific sequence.| 
 +|**!/EXCLUDE_EVENTS=** |Specifies events that should not be copied, allowing more refined duplication.| 
 +|**!/START_AT_EVENT=** |Specifies a starting event to define the range of copying.| 
 +|**!/END_AT_EVENT=**   |Specifies an ending event to define the range of copying.| 
 +|**!/FRAME_OFFSET=**   |The number of frames by which to offset the copied event.| 
 +|**!/TIME_OFFSET=**    |The time offset (in seconds) to apply to the copied event.| 
 +|**!/PERCENT_OFFSET=** |A percentage offset relative to a defined event range.|
  
-Frame offset can be a number or an expression. 
  
-For example, if the offset is defined by Metric signal in the Processed folder labeled SHIFT.+==== Dialog ==== 
 +The command can be edited in text editor or in a dialog form. To edit in the dialog pop up form either click on the Edit button in the pipeline workshop or double-click on the pipeline command. The dialog is shown below.
  
-**/Frame_Offset**= METRIC::PROCESSED::SHIFT +{{:visual3d:documentation:pipeline:event_commands:eventcopy_dialog.png?400|}}
-==== Time_Offset ====+
  
-Time offset can be a number or an expression.+  * **Optional- Select Range Instance**:  
 +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.
  
-For exampleif the offset is defined by a Metric signal in the Processed folder labeled SHIFT.+  * **Optional - Select Event Instance**: 
 +When set to 0it 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.
  
-**/Time_Offset**= METRIC::PROCESSED::SHIFT +==== Examples ==== 
-For example, to create an event 1 second prior to an existing event.+The following examples will go through the use of the **Event_Copy** command in the Visual3D application.
  
-**/Time_Offset**-1.0 +=== Example 1: Event_At_Midstance ===
-==== Percent_Offset ====+
  
-The percent offset can be a number or an expression.+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.
  
-The percent is the percentage of the range within the Event_Sequence. +<code
- +Event_Copy
-For example, if the offset is defined by a Metric signal in the Processed folder labeled PERCENT. +
- +
-**/Percent_Offset**= METRIC::PROCESSED::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**+
 /EVENT_NAME=RON /EVENT_NAME=RON
 /NEW_EVENT_NAME=MID_STANCE /NEW_EVENT_NAME=MID_STANCE
-! /FRAME_OFFSET= +!/FRAME_OFFSET= 
-! /TIME_OFFSET=+!/TIME_OFFSET=
 /PERCENT_OFFSET=50 /PERCENT_OFFSET=50
-! /EVENT_INSTANCE=0 +!/EVENT_INSTANCE=0 
-! /RANGE_INSTANCE=0+!/RANGE_INSTANCE=0
 /EVENT_SEQUENCE=RON+ROFF /EVENT_SEQUENCE=RON+ROFF
-! /EXCLUDE_EVENTS= +!/EXCLUDE_EVENTS= 
-! /START_AT_EVENT= +!/START_AT_EVENT= 
-! /END_AT_EVENT= +!/END_AT_EVENT= 
-**;** +
-{{:CopyEventLabelDlgEx1.jpg}}+</code>
  
-This command will use all instances of a range defined by the Event_Sequence and Exclude Event, and will use every occurrence of the Event_Name within this sequence.+The dialog corresponding to the example command is shown below:
  
-==== Example - Copying the last event in the sequence ====+{{:CopyEventLabelDlgEx1.jpg?350}}
  
-The event sequence used in the event_copy command includes the first eventbut not the last event. This idiosyncratic behavior was introduced to handle sequences that had the same event label name at each end of the sequence.+This command will use all instances of a range defined by the **Event_Sequence** and **Exclude_Event**and will use every occurrence of the **Event_Name** within this sequence.
  
-In order to copy the last event, you need to select the first event and an offset of 100%+=== Example 2: Copying the last event in the sequence ===
  
-For example, given a sequence of events A-B-C and you want to copy Event C and name it C2.+The event sequence used in the **Event_Copy** command includes the first event, but not the last event. This idiosyncratic behavior was introduced to handle sequences that had the same event label name at each end of the 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.
 +
 +<code>
 Event_Copy Event_Copy
 /EVENT_NAME=A /EVENT_NAME=A
 /NEW_EVENT_NAME=C2 /NEW_EVENT_NAME=C2
 !/FRAME_OFFSET= !/FRAME_OFFSET=
-! /TIME_OFFSET=+!/TIME_OFFSET=
 /PERCENT_OFFSET=100 /PERCENT_OFFSET=100
-! /EVENT_INSTANCE=0 +!/EVENT_INSTANCE=0 
-! /RANGE_INSTANCE=0+!/RANGE_INSTANCE=0
 /EVENT_SEQUENCE=A+B+C /EVENT_SEQUENCE=A+B+C
-! /EXCLUDE_EVENTS= +!/EXCLUDE_EVENTS= 
-! /START_AT_EVENT= +!/START_AT_EVENT= 
-! /END_AT_EVENT= +!/END_AT_EVENT= 
-**;** +
-==== Example - Create an Event based on a time threshold between 2 Events ====+</code>
  
-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 "BAD": For each stride that's longer than 4 seconds, it creates a new event called "BAD" at the time of the second RHS.
 +
 +<code>
 ! Define an Event Sequence ! Define an Event Sequence
-**Event_Define_Event_Sequence**+Event_Define_Event_Sequence
 /EVENT_SEQUENCE_NAME=STRIDE /EVENT_SEQUENCE_NAME=STRIDE
 /EVENT_SEQUENCE=RHS+RHS /EVENT_SEQUENCE=RHS+RHS
-! /EXCLUDE_EVENTS= +!/EXCLUDE_EVENTS= 
-! /INSIDE_OF_SEQUENCE= +!/INSIDE_OF_SEQUENCE= 
-! /OFFSET_FROM_START= +!/OFFSET_FROM_START= 
-! /OFFSET_FROM_END= +!/OFFSET_FROM_END= 
-! /OFFSET_BY=PERCENT+!/OFFSET_BY=PERCENT
 /EVENT_SEQUENCE_INSTANCE=0 /EVENT_SEQUENCE_INSTANCE=0
-**;**+; 
 ! Compute the times of the Event_Sequence ! Compute the times of the Event_Sequence
-**Metric_Time_Between_Events**+Metric_Time_Between_Events
 /RESULT_METRIC_NAME=STRIDE_TIME /RESULT_METRIC_NAME=STRIDE_TIME
-! /RESULT_METRIC_FOLDER=PROCESSED+!/RESULT_METRIC_FOLDER=PROCESSED
 /EVENT_SEQUENCE=STRIDE /EVENT_SEQUENCE=STRIDE
 /EXCLUDE_EVENTS= /EXCLUDE_EVENTS=
 /GENERATE_MEAN_AND_STDDEV=FALSE /GENERATE_MEAN_AND_STDDEV=FALSE
-! /APPEND_TO_EXISTING_VALUES=FALSE +!/APPEND_TO_EXISTING_VALUES=FALSE 
-**;**+; 
 ! 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
 /EXPRESSION=(METRIC::PROCESSED::STRIDE_TIME>4) /EXPRESSION=(METRIC::PROCESSED::STRIDE_TIME>4)
-! /SIGNAL_TYPES= +!/SIGNAL_TYPES= 
-! /SIGNAL_FOLDER=ORIGINAL +!/SIGNAL_FOLDER=ORIGINAL 
-! /SIGNAL_NAMES=+!/SIGNAL_NAMES=
 /RESULT_TYPES=METRIC /RESULT_TYPES=METRIC
-! /RESULT_FOLDERS=PROCESSED+!/RESULT_FOLDERS=PROCESSED
 /RESULT_NAME=STRIDE_TIME_BINARY /RESULT_NAME=STRIDE_TIME_BINARY
-! /APPLY_AS_SUFFIX_TO_SIGNAL_NAME=FALSE +!/APPLY_AS_SUFFIX_TO_SIGNAL_NAME=FALSE 
-**;**+; 
 ! 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
 /SIGNAL_TYPES=METRIC /SIGNAL_TYPES=METRIC
 /SIGNAL_FOLDER=PROCESSED /SIGNAL_FOLDER=PROCESSED
 /SIGNAL_NAMES=STRIDE_TIME_BINARY /SIGNAL_NAMES=STRIDE_TIME_BINARY
-! /SIGNAL_COMPONENTS=ALL_COMPONENTS+!/SIGNAL_COMPONENTS=ALL_COMPONENTS
 /PARAMETER_NAME=INSTANCE /PARAMETER_NAME=INSTANCE
-**;**+; 
 ! Create indices for a for each loop ! Create indices for a for each loop
 **Get_Pipeline_Parameter_Count** **Get_Pipeline_Parameter_Count**
 /PARAMETER_NAME=NUMCOUNT /PARAMETER_NAME=NUMCOUNT
 /PARAMETER_VALUE=::INSTANCE /PARAMETER_VALUE=::INSTANCE
-**;** +
-**Set_Pipeline_Parameter_From_For_Loop**+ 
 +Set_Pipeline_Parameter_From_For_Loop
 /PARAMETER_NAME=COUNT /PARAMETER_NAME=COUNT
 /PARAMETER_INDEX_START=1 /PARAMETER_INDEX_START=1
 /PARAMETER_INDEX_END=::NUMCOUNT /PARAMETER_INDEX_END=::NUMCOUNT
 /PARAMETER_INDEX_STEP=1 /PARAMETER_INDEX_STEP=1
-! /PARAMETER_INDEX_TYPE=INTEGER +!/PARAMETER_INDEX_TYPE=INTEGER 
-**;** +
-**For_Each**+ 
 +For_Each
 /ITERATION_PARAMETER_NAME=INDEX /ITERATION_PARAMETER_NAME=INDEX
 /ITEMS=::COUNT /ITEMS=::COUNT
-**;**+; 
 ! If the binary signal is 1 execute event copy ! If the binary signal is 1 execute event copy
-**Expression_Loop**+Expression_Loop
 /ITERATION_PARAMETER_NAME=TEST /ITERATION_PARAMETER_NAME=TEST
 /EXPRESSION=METRIC::PROCESSED::STRIDE_TIME_BINARY[&::INDEX&] /EXPRESSION=METRIC::PROCESSED::STRIDE_TIME_BINARY[&::INDEX&]
 /AS_INTEGER=true /AS_INTEGER=true
-**;** +
-**Event_Copy**+ 
 +Event_Copy
 /EVENT_NAME=RHS /EVENT_NAME=RHS
 /NEW_EVENT_NAME=BAD /NEW_EVENT_NAME=BAD
-! /EVENT_INSTANCE=0+!/EVENT_INSTANCE=0
 /RANGE_INSTANCE=::INDEX /RANGE_INSTANCE=::INDEX
 /EVENT_SEQUENCE=STRIDE_TIME /EVENT_SEQUENCE=STRIDE_TIME
-! /EXCLUDE_EVENTS= +!/EXCLUDE_EVENTS= 
-! /START_AT_EVENT= +!/START_AT_EVENT= 
-! /END_AT_EVENT=+!/END_AT_EVENT=
 /FRAME_OFFSET=10 /FRAME_OFFSET=10
-! /TIME_OFFSET= +!/TIME_OFFSET= 
-! /PERCENT_OFFSET= +!/PERCENT_OFFSET= 
-**;** +
-**Expression_Loop_End**+ 
 +Expression_Loop_End
 /ITERATION_PARAMETER_NAME=TEST /ITERATION_PARAMETER_NAME=TEST
-**;** +
-**End_For_Each**+ 
 +End_For_Each
 /ITERATION_PARAMETER_NAME=INDEX /ITERATION_PARAMETER_NAME=INDEX
-**;**+; 
 +</code> 
 + 
 +==== Notes ==== 
 +  The /Percent_Offset parameter is only effective when /Start_At_Event and /End_At_Event are specified. 
 +  Offset values (Frame_Offset, Time_Offset, Percent_Offset) should be used cautiously to ensure event placement aligns with analysis needs. 
  
  
visual3d/documentation/pipeline/event_commands/event_copy.1721231138.txt.gz · Last modified: 2024/07/17 15:45 by sgranger