Kinematic analysis
Contents
Kinematic analysis¶
What libraries should I import?¶
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
Recap¶
Dummy data for the following exercises is provided here.
file = '/Users/guillermo/Downloads/pose-3d.csv'
data = pd.read_csv(file, header=0)
coords = data.loc[:, ~data.columns.str.contains(
'score|error|ncams|fnum|center|M_')]
Position in space¶
position_x = coords['nose1_x']
position_y = coords['nose1_y']
position_z = coords['nose1_z']
pos_x, = plt.plot(position_x, label='x')
pos_y, = plt.plot(position_y, label='y')
pos_z, = plt.plot(position_z, label='z')
plt.xlabel('Time [frames]')
plt.ylabel('Position [mm]')
plt.legend()
data:image/s3,"s3://crabby-images/db74a/db74a903c06196142293cff2f745547c19f56b77" alt="_images/kinematicanalysis_6_0.png"
position_x.hist()
data:image/s3,"s3://crabby-images/a5882/a5882da121fedbb287ac103742cd1a4dd7c190e1" alt="_images/kinematicanalysis_7_0.png"
x = coords['nose1_x']
y = coords['nose1_y']
z = coords['nose1_z']
# creating 3d figures
fig = plt.figure(figsize=(10, 10))
ax = fig.add_subplot(projection='3d')
# creating the path map
img = ax.scatter(x, y, z, marker='o', s=60, color='gray')
# adding title and labels
ax.set_title("3D Path")
ax.set_xlabel('X-axis')
ax.set_ylabel('Y-axis')
ax.set_zlabel('Z-axis')
# displaying plot
plt.show()
data:image/s3,"s3://crabby-images/98db7/98db7a16606cf15e0c4f252c63083b62933c2df5" alt="_images/kinematicanalysis_8_0.png"
Velocity as difference between positions¶
velocity_x = np.append([0], np.diff(position_x, n=1))
velocity_y = np.append([0], np.diff(position_y, n=1))
velocity_z = np.append([0], np.diff(position_z, n=1))
vel_x, = plt.plot(velocity_x, label='x')
vel_y, = plt.plot(velocity_y, label='y')
vel_z, = plt.plot(velocity_z, label='z')
plt.xlabel('Time [frames]')
plt.ylabel('Velocity [mm/s]')
plt.legend()
data:image/s3,"s3://crabby-images/fbcb6/fbcb6ecfbe14749a2cd16a4360227689e88c8e51" alt="_images/kinematicanalysis_10_0.png"
_ = plt.hist(velocity_x, bins='auto')
data:image/s3,"s3://crabby-images/3e9f4/3e9f47e3e539fffba6d13a0ee466bae0d8c4e62c" alt="_images/kinematicanalysis_11_0.png"
Acceleration as difference in velocity¶
# Acceleration of head movement as frame-to-frame difference in velocity
acceleration_x = np.append([0], np.diff(velocity_x, n=1))
acceleration_y = np.append([0], np.diff(velocity_y, n=1))
acceleration_z = np.append([0], np.diff(velocity_z, n=1))
acc_x, = plt.plot(acceleration_x, label='x')
acc_y, = plt.plot(acceleration_y, label='y')
acc_z, = plt.plot(acceleration_z, label='z')
plt.xlabel('Time [frames]')
plt.ylabel('Acceleration [mm/s^2]')
plt.legend()
data:image/s3,"s3://crabby-images/e4122/e4122c9d4509bdaa1b9181e918aa2b75caa7debd" alt="_images/kinematicanalysis_13_0.png"
_ = plt.hist(acceleration_x, bins='auto')
data:image/s3,"s3://crabby-images/45055/450559dd077f522643e5c5bdb40d64a91b3d2242" alt="_images/kinematicanalysis_14_0.png"
plt.figure(figsize=(6, 6))
plt.hist(acceleration_x, bins=100, alpha=0.5, label="acceleration_x")
plt.hist(acceleration_y, bins=100, alpha=0.5, label="acceleration_y")
plt.hist(acceleration_z, bins=100, alpha=0.5, label="acceleration_z")
plt.xlabel("Acceleration", size=14)
plt.ylabel("Count", size=14)
plt.title("Multiple Histograms with Matplotlib")
plt.legend(loc='upper right')
data:image/s3,"s3://crabby-images/01287/01287e2bd4537ac25e1d670d0df89e461cf43242" alt="_images/kinematicanalysis_15_0.png"
# Grouped plots
_ = plt.figure(figsize=(6, 6))
plt.violinplot(acceleration_x)
plt.violinplot(acceleration_y)
plt.violinplot(acceleration_z)
plt.xlabel("Acceleration", size=14)
plt.ylabel("Count", size=14)
plt.title("Multiple Violin Plots with Matplotlib")
data:image/s3,"s3://crabby-images/a6f64/a6f6473c8448295509add10349053a1e3b633d96" alt="_images/kinematicanalysis_16_0.png"
# Combine data
combined_acc = list([acceleration_x, acceleration_y, acceleration_z])
fig, ax = plt.subplots()
xticklabels = ['x', 'y', 'z']
ax.set_xticks([1, 2, 3])
ax.set_xticklabels(xticklabels)
ax.violinplot(combined_acc)
plt.xlabel("Coordinate", size=14)
plt.ylabel("Acceleration", size=14)
plt.title("Multiple Violin Plots with Matplotlib")
data:image/s3,"s3://crabby-images/f5697/f5697f9e0e9c6e66870447bd2f0f319df86365d2" alt="_images/kinematicanalysis_17_0.png"
In the following section we will learn to cluster our data using some very basic machine learning techniques.