Through the OpenBiomechanics Project, Driveline Baseball has made elite-level motion capture data publicly available. The data can be downloaded from Driveline's GitHub repository.
Having access to large datasets is a great asset, but processing these large datasets can take time (and patience). Inspect3D is designed to streamline this process. The steps in this tutorial describe how to create CMZ files from the pitching and batting data sets, then inspect and group the data in Inspect3D.
To follow along with this tutorial, ensure that your version of Inspect3D is at least v2023.08.08. Earlier versions will not have the Build CMZ feature. After verifying that you have the correct version of Inspect3D, download the following two zip files.
Please note, these downloads contain a large amount of data. Building CMZs is a slow process, so if you want to speed it up to follow along with building CMZ portion of this tutorial cut the number of datasets under openbiomechanics-main down to 3-5 subjects.
If you want to skip the Build CMZ step of this tutorial and focus on the metadata applications, you can:
For more technical information about loading metadata, see: Metadata Documentation
In the Build CMZ dialog:
From here on it is assumed that you either have:
The zip file openbiomechanics-main has a metadata file for the hitting data set which you can view at your convenience. This metadata file has a number of categories including player age, bat weight, hitting side etc.
Let's say we want to query this data set, but we only want data from subjects that are under age 20.
We start by loading library with the hitting data set, navigating to the Query Builder dialog, and opening the Auto-Populate dialog. Ensure that “Baseball” is checked. Find the “Refine using signal” checkbox and click “Add”. Then you can enter your query refinements.
When refining queries it can be helpful to have the metadata file open, so that you can see the values it contains. Note that in this case, accessing athlete_age has been set as a global metric, and you will not be able to find the meta folder unless Global Value is checked.
The result of this procedure is that data is queried only if it meets this refinement category, and the refinement name will be applied as a suffix to the end of the signal name.
Let's say you have three subjects worth of data where each subject walks at four different speeds and has a different weight.
In this example let us say we want to include metadata on the subject's walking speed and weight. To create a .csv file for this metadata, start by creating a row of headers. The minimum requirements for a metadata file include the static file name and dynamic file name. After that, we can add the other parameters we are interested in.
In the example below, we can see that there are four headers (static_model, dynamic_file, walking_speed and subject_mass).
Here you can edit the description fields and subject specific fields. After you are satisfied with the fields, click “Apply” to build CMZs and load the library.
Once your data is loaded it can be queried. This example shows how you can use metadata to refine queries.
In this instance, we have data where three subjects walk at four different speeds. The subjects also have their weight recorded.
If you navigate from the Query Builder dialog to the Auto-Populate menu, there is an option called “Refine Using Signal”. Click to enable this checkbox, and then press “Add”. In the image below, I have loaded a pre-built auto-settings file, but also have the signal refinement dialog open.
Since I want to refine my data by walking speed in this example, I name the refinement “3.0”, choose the data under METRIC>meta>walking_speed>X and indicate that the value must be “Equal to” 3.0. I can then save my refinements as an .xml file which can be loaded at any time if I want to re-query my library.
Press save and then create and close the auto-populate window. Back in the query builder you should see queries that reflect the refinements you just made.
In this example I have imported the X, Y and Z components of the ASIS marker trajectories for the subjects walking at four different speeds.
We can now used the refined queries to visualize different relationships between speed and subject kinematics, as seen in the example below:
In this example we can see the how the trajectory for the ASIS markers changes as walking speed changes for Subject 1.
In this tutorial, we reviewed how to refine data queries using metadata from OpenBiomechanics open source dataset. We also reviewed how to generate a metadata file from scratch and use it to refine data queries.
If you want to review another example of building CMZs with OpenBiomechanics data, visit the Building CMZ Tutorial.