visual3d:tutorials:emg:typical_emg_processing
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
visual3d:tutorials:emg:typical_emg_processing [2024/06/18 13:35] – sgranger | visual3d:tutorials:emg:typical_emg_processing [2024/11/15 18:04] (current) – [Open Files and Tag] wikisysop | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== | + | ====== |
- | **EMG** stands for **electromyography**, | + | **EMG** stands for **electromyography**, |
- | This tutorial will show the basic steps for processing EMG data into Visual3D. Files used in this tutorial can be found here: [[[https:// | + | ===== Overview ===== |
+ | This tutorial will show the basic steps for processing EMG data into Visual3D. Files used in this tutorial can be found here: [[https:// | ||
- | The tutorial will go through a step by step process using Visual 3D pipeline commands to process the example EMG data. It will do the following: | + | ===== Visual 3D Implementation ===== |
+ | |||
+ | Visual3D expects the EMG signals to be stored in the C3D file as ANALOG data, not unlike force platform data. One point of importance is that EMG typically has very high frequency content, which means that it must be sampled at high data sampling rates. As of Visual3D Version 5.0, EMG signals are stored as integer multiples of the motion capture sampling rate (e.g. consistent with the common use of the C3D file format). One of the nuisances caused by this requirement is that force platform data must be sampled at a very high rate in order to match the EMG sampling rate. | ||
+ | |||
+ | All of Visual3D' | ||
+ | |||
+ | ===== Processing EMG Signals with the Visual3D Pipeline ===== | ||
+ | |||
+ | The tutorial will go through a step by step process using [[visual3d: | ||
- Open Files and Tags | - Open Files and Tags | ||
Line 13: | Line 22: | ||
- Normalize based off of 4 different methods | - Normalize based off of 4 different methods | ||
- | ====== Visual 3D Implementation ====== | + | ==== Open Files and Tag ==== |
- | + | ||
- | Visual3D expects the EMG signals to be stored in the C3D file as ANALOG data, not unlike force platform data. One point of importance is that EMG typically has very high frequency content, which means that it must be sampled at high data sampling rates. | + | |
- | + | ||
- | As of Visual3D Version 5.0 EMG signals are stored as integer multiples of the Motion Capture sampling rate (e.g. consistent with the common use of the C3D file format). One of the nuisances caused by this requirement is that force platform data must be sampled at a very high rate in order to match the EMG sampling rate. | + | |
- | + | ||
- | All signal processing commands in the pipeline can be used with EMG data. | + | |
- | + | ||
- | ====== EMG Processing using Visual 3D Pipeline commands ====== | + | |
- | + | ||
- | The tutorial will go through a step by step process using Visual 3D pipeline commands to process the example EMG data. | + | |
- | + | ||
- | ===== Open Files and Tag ===== | + | |
This section will walk you through pipeline commands that will open files and automatically assign tags to motion files for **Movement** and **MVIC** trials. | This section will walk you through pipeline commands that will open files and automatically assign tags to motion files for **Movement** and **MVIC** trials. | ||
Line 62: | Line 59: | ||
! /QUERY= | ! /QUERY= | ||
/TAGS=MVC_C | /TAGS=MVC_C | ||
- | '; | + | ; |
!Assign Tags to walking files | !Assign Tags to walking files | ||
Line 72: | Line 69: | ||
</ | </ | ||
- | ===== Create Pipeline Parameter "EMG Signals" | + | ==== Create Pipeline Parameter "EMG Signals" |
Use the command **Set_Pipeline_Parameter**, | Use the command **Set_Pipeline_Parameter**, | ||
Line 83: | Line 80: | ||
</ | </ | ||
- | ===== Apply a Band Pass Filter | + | ==== Apply a Band Pass Filter ==== |
Apply a band pass filter to the EMG data with the commands **Highpass_Filter** and **Lowpass_Filter**. Surface EMG signals have a frequency content between 20 and 500 Hz. | Apply a band pass filter to the EMG data with the commands **Highpass_Filter** and **Lowpass_Filter**. Surface EMG signals have a frequency content between 20 and 500 Hz. | ||
Line 129: | Line 126: | ||
</ | </ | ||
- | ===== Compute an Envelope | + | ==== Compute an Envelope ==== |
Compute the linear envelope of the EMG signal by calculating the RMS value using the command **Moving_RMS** for short successive time periods (the time period is described as a moving window). More information on calculating the RMS can be found at the [[Visual3D: | Compute the linear envelope of the EMG signal by calculating the RMS value using the command **Moving_RMS** for short successive time periods (the time period is described as a moving window). More information on calculating the RMS can be found at the [[Visual3D: | ||
Line 149: | Line 146: | ||
</ | </ | ||
- | ===== Create Normalization Factor and Scale ===== | + | ==== Create Normalization Factor and Scale ==== |
There are four alternative normalization methods describes in this tutorial. | There are four alternative normalization methods describes in this tutorial. | ||
Line 291: | Line 288: | ||
</ | </ | ||
- | ==== Normalize EMG to MVC ==== | + | ==== Approach 1: Normalize EMG to MVC ==== |
This pipeline normalizes the EMG signal by dividing the EMG signal by the maximum value of the EMG signal from a separate trial (e.g. a trial that elicits a maximum voluntary contraction (MVC) from the muscle). | This pipeline normalizes the EMG signal by dividing the EMG signal by the maximum value of the EMG signal from a separate trial (e.g. a trial that elicits a maximum voluntary contraction (MVC) from the muscle). | ||
Line 325: | Line 322: | ||
</ | </ | ||
- | ==== Normalize EMG to Generic Global Variable ==== | + | ==== Approach 2: Normalize EMG to Generic Global Variable ==== |
Typically the scaling factors for EMG signals are the result of other data trials (such as MVIC trials). Individual files in Visual3D cannot access the data from other files, so the only way signals can be shared is through the Global Workspace. This pipeline normalizes the EMG signal to a global variable. | Typically the scaling factors for EMG signals are the result of other data trials (such as MVIC trials). Individual files in Visual3D cannot access the data from other files, so the only way signals can be shared is through the Global Workspace. This pipeline normalizes the EMG signal to a global variable. | ||
Line 359: | Line 356: | ||
</ | </ | ||
- | ==== Normalize to Maximum 30 second interval ==== | + | ==== Approach 3: Normalize to Maximum 30 second interval ==== |
This pipeline normalizes to the greatest ½ second activity during a 5 second trial. A window of twenty-five .02 second intervals of integrated EMG is moved one interval at a time across the 5 seconds of data to find the greatest EMG. The average integrated EMG during the ½ second is used to compute the normalization factor. It does the following: | This pipeline normalizes to the greatest ½ second activity during a 5 second trial. A window of twenty-five .02 second intervals of integrated EMG is moved one interval at a time across the 5 seconds of data to find the greatest EMG. The average integrated EMG during the ½ second is used to compute the normalization factor. It does the following: | ||
Line 389: | Line 386: | ||
</ | </ | ||
- | ==== Normalize to the Maximum within Each Gait Cycle ==== | + | ==== Approach 4: Normalize to the Maximum within Each Gait Cycle ==== |
For this example, the goal is as follows: | For this example, the goal is as follows: |
visual3d/tutorials/emg/typical_emg_processing.1718717716.txt.gz · Last modified: 2024/06/18 13:35 by sgranger