Note
Go to the end to download the full example code. or to run this example in your browser via Binder
Load and explore pose tracks#
Load and explore an example dataset of pose tracks.
Imports#
from matplotlib import pyplot as plt
from movement import sample_data
from movement.io import load_poses
Define the file path#
This should be a file output by one of our supported pose estimation frameworks (e.g., DeepLabCut, SLEAP), containing predicted pose tracks. For example, the path could be something like:
# uncomment and edit the following line to point to your own local file
# file_path = "/path/to/my/data.h5"
For the sake of this example, we will use the path to one of
the sample datasets provided with movement
.
file_path = sample_data.fetch_dataset_paths(
"SLEAP_three-mice_Aeon_proofread.analysis.h5"
)["poses"]
print(file_path)
/home/runner/.movement/data/poses/SLEAP_three-mice_Aeon_proofread.analysis.h5
Load the data into movement#
ds = load_poses.from_sleap_file(file_path, fps=50)
print(ds)
<xarray.Dataset> Size: 27kB
Dimensions: (time: 601, space: 2, keypoints: 1, individuals: 3)
Coordinates:
* time (time) float64 5kB 0.0 0.02 0.04 0.06 ... 11.96 11.98 12.0
* space (space) <U1 8B 'x' 'y'
* keypoints (keypoints) <U8 32B 'centroid'
* individuals (individuals) <U10 120B 'AEON3B_NTP' 'AEON3B_TP1' 'AEON3B_TP2'
Data variables:
position (time, space, keypoints, individuals) float32 14kB 770.3 ......
confidence (time, keypoints, individuals) float32 7kB nan nan ... nan nan
Attributes:
fps: 50.0
time_unit: seconds
source_software: SLEAP
source_file: /home/runner/.movement/data/poses/SLEAP_three-mice_Aeon...
ds_type: poses
The loaded dataset contains two data variables:
position
and confidence
.
To get the position data:
Select and plot data with xarray#
You can use the sel
method to index into xarray
objects.
For example, we can get a DataArray
containing only data
for a single keypoint of the first individual:
da = position.sel(individuals="AEON3B_NTP", keypoints="centroid")
print(da)
<xarray.DataArray 'position' (time: 601, space: 2)> Size: 5kB
770.3 1.062e+03 773.3 1.062e+03 773.3 ... 618.6 194.6 618.4 194.6 616.4
Coordinates:
* time (time) float64 5kB 0.0 0.02 0.04 0.06 ... 11.96 11.98 12.0
* space (space) <U1 8B 'x' 'y'
keypoints <U8 32B 'centroid'
individuals <U10 40B 'AEON3B_NTP'
We could plot the x, y coordinates of this keypoint over time,
using xarray
’s built-in plotting methods:
da.plot.line(x="time", row="space", aspect=2, size=2.5)
data:image/s3,"s3://crabby-images/41176/41176b91d435bf64dab266c57b37062c4d2cd199" alt="space = x, space = y"
<xarray.plot.facetgrid.FacetGrid object at 0x7f62246d6c50>
Similarly we could plot the same keypoint’s x, y coordinates for all individuals:
da = position.sel(keypoints="centroid")
da.plot.line(x="time", row="individuals", aspect=2, size=2.5)
data:image/s3,"s3://crabby-images/63b3f/63b3fbc042350132a729c99ee08e2013301fdebe" alt="individuals = AEON3B_NTP, individuals = AEON3B_TP1, individuals = AEON3B_TP2"
<xarray.plot.facetgrid.FacetGrid object at 0x7f623e787dd0>
Trajectory plots#
We are not limited to xarray
’s built-in plots.
For example, we can use matplotlib
to plot trajectories
(using scatter plots):
data:image/s3,"s3://crabby-images/f2bcb/f2bcb581e4d1fe0c9b4396e5297f1dafb55a7b42" alt="Trajectory of AEON3B_TP1"
<matplotlib.colorbar.Colorbar object at 0x7f6223585c10>
Total running time of the script: (0 minutes 0.569 seconds)