Skip to main content

A tool to study 2D trajectories

Project description

trajectorytools is a library with some utils to study and plot 2D trajectories.

Installation

From PyPI

pip install trajectorytools

From Source

pip install git+https://gitlab.com/polavieja_lab/trajectorytools

Example

import numpy as np
from matplotlib.cm import ScalarMappable
from matplotlib.colors import Normalize

import trajectorytools as tt
import trajectorytools.animation as ttanimation
import trajectorytools.socialcontext as ttsocial
from trajectorytools.constants import test_raw_trajectories_path

# Loading test trajectories as a numpy array of locations
test_trajectories = np.load(test_raw_trajectories_path, allow_pickle=True)

# We will process the numpy array, interpolate nans and smooth it.
# To do this, we will use the Trajectories API
traj = tt.Trajectories.from_positions(test_trajectories, smooth_params={"sigma": 1})

# We assume a circular arena and populate center and radius keys
center, radius = traj.estimate_center_and_radius_from_locations()

# We center trajectories around the estimated center
traj.origin_to(center)

# We will normalise the location by the radius:
traj.new_length_unit(radius)

# We will change the time units to seconds. The video was recorded at 32
# fps, so we do:
traj.new_time_unit(32, "second")

# Now we can find the smoothed trajectories, velocities and accelerations
# in traj.s, traj.v and traj.a
# We can use, for instance, the positions in traj.s and find the border of
# the group:
in_border = ttsocial.in_alpha_border(traj.s, alpha=5)

# Animation showing the fish on the border
colornorm = Normalize(vmin=0, vmax=3, clip=True)
mapper = ScalarMappable(norm=colornorm, cmap="RdBu")
color = mapper.to_rgba(in_border)

anim1 = ttanimation.scatter_vectors(traj.s, velocities=traj.v, k=0.3)
anim2 = ttanimation.scatter_ellipses_color(traj.s, traj.v, color)
anim = anim1 + anim2

anim.prepare()
anim.show()

In the directory examples, you can find some more example scripts. Scripts use some example trajectories, which can be found in data. All example trajectories were obtained using idtracker.ai on videos recorded in de Polavieja Lab (Champalimaud Research, Lisbon)

NOTE

Note that, when using constructors like from_idtrackerai and from_positions, we need to calculate velocity and accelerations from positions. As a result, the traj object has 2 frames less than the original positions array. By default, the missing frames correspond to the first and last frames of the video. If you used the option “only_past”:True in smooth_params, the missing frames correspond to the first two frames of the video.

Project maintainers

Jordi Torrents (2024-) Dean Rance (2021-2021) Francisco J.H. Heras (2017-2023) Francisco Romero Ferrero (2017-2023)

Contribute

We welcome contributions. The preferred way to report problems is by creating an issue. The best way to propose changes in the code is to create a pull request. Please, check our contribution guidelines and our code of conduct.

License

This project is licensed under the terms of the GNU General Public License v3.0 (See COPYING). This means that you may copy, distribute and modify the software as long as you track changes/dates in source files. However, any modifications to GPL-licensed code must also be made available under the GPL along with build & install instructions.

If you use this work in an academic context and you want to acknowledge us, please cite some of the relevant papers:

Romero-Ferrero, F., Bergomi, M. G., Hinz, R. C., Heras, F. J., & de Polavieja, G. G. (2019). idtracker.ai: tracking all individuals in small or large collectives of unmarked animals. Nature methods, 1

Heras, F. J., Romero-Ferrero, F., Hinz, R. C., & de Polavieja, G. G. (2019). Deep attention networks reveal the rules of collective motion in zebrafish. PLoS computational biology, 15(9), e1007354.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

trajectorytools-0.4.tar.gz (871.6 kB view details)

Uploaded Source

Built Distribution

trajectorytools-0.4-py3-none-any.whl (874.9 kB view details)

Uploaded Python 3

File details

Details for the file trajectorytools-0.4.tar.gz.

File metadata

  • Download URL: trajectorytools-0.4.tar.gz
  • Upload date:
  • Size: 871.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.13

File hashes

Hashes for trajectorytools-0.4.tar.gz
Algorithm Hash digest
SHA256 fc59c081c45eb8d0ad4fb3a92eb6ca48d9d4f1446124c09a490006999cb5062a
MD5 0a95aac03216cdfdb9b4dccd9459b5e9
BLAKE2b-256 516536fd08a3f80aca0f414e3c917b5088cfd78b69acdd768457862d5de64517

See more details on using hashes here.

File details

Details for the file trajectorytools-0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for trajectorytools-0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 36906683d529b4db0011ed97f80a04a5d9de567966efcfd96b2c74b6ae10c03b
MD5 30270464439f575781de7b94a2c82d26
BLAKE2b-256 7b3c2e7b359db1a86ed8704bddba36b46984e4d96ff7db0696c20b1c650be9a8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page