Skip to main content

Befordata: A Python package for behavioural force data

Project description

BeForData: A Python package for behavioural force data

Data structures for handling behavioural force data

This package provides core classes and utilities for loading, processing, and analysing behavioural force data, such as those collected in experimental psychology or neuroscience. It offers a structured approach to manage epochs and records of force measurements, enabling efficient data manipulation and analysis.

BeForData is based on two structured classes of force data: one for the representation of the raw time-based force measurements in the shape of a dataframe (BeForRecord) and one for epoch-based representations as matrices (BeForEpochs).

Features

  • Flexible loading and saving of force data in common formats (e.g., CSV, XDF).
  • Efficient slicing and indexing of epochs and records for batch analysis.
  • Metadata management for experimental context, including event markers and annotations.
  • Utilities for preprocessing, such as filtering and baseline correction.
  • Integration with scientific Python libraries (NumPy, pandas) for advanced analysis.

Source code: https://github.com/lindemann09/befordata

Documentation: https://lindemann09.github.io/befordata/

(c) Oliver Lindemann

GitHub license PyPI

Data Structures

  • BeForRecord

    Represents a single continuous recording of force data, including metadata such as sampling rate, channel information, and experimental annotations. BeForRecord supports data cleaning, resampling, and extraction of epochs, and provides convenient access to raw and processed force signals.

    The data structure has the following attributes:

    • dat: DataFrame containing force measurements and optionally a time column.
    • sampling_rate: Sampling rate of the force measurements (Hz).
    • sessions: List of sample indices where new recording sessions start.
    • time_column (optional): Name of the column containing time stamps (if any).
    • meta (optional): Arbitrary metadata associated with the record.
  • BeForEpochs

    A container class for managing multiple epochs of force data. Each epoch represents a segment of continuous force measurements, typically corresponding to a trial or experimental condition. BeForEpochs provides methods for slicing, indexing, and batch-processing epochs, as well as for loading and saving epoch data from various formats.

    The data structure has the following attributes:

    • dat: 2D numpy array containing the force data (epochs x samples).
    • sampling_rate: Sampling rate of the force measurements (Hz).
    • design: DataFrame containing design/metadata for each epoch.
    • zero_sample: Sample index representing the sample of the time zero within each epoch (default: 0).
    • baseline (optional): 1D numpy array containing baseline values for each epoch at zero_sample.
    • meta (optional): Arbitrary metadata associated with the epochs.

Typical Workflow

  1. Load raw force data into a BeForRecord object.
  2. Preprocess and annotate the data as needed.
  3. Segment the data into epochs using event markers, creating a BeForEpochs object.

Install via pip

pip install befordata

Citation

If you use befordata in your research, please cite it as:

Lindemann, O. (2025). BeForData: A Python package for behavioural response force
data. [Computer software]. https://pypi.org/project/befordata/

Or in BibTeX:

@software{pybefordata2025,
  author    = {Lindemann, Oliver},
  title     = {{BeForData}: A {Python} package for behavioural force data},
  year      = {2025},
  url       = {https://pypi.org/project/befordata/}
  version   = {0.4}
}

Julia

A Julia implementation of BeForData is available as a beta release.

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

befordata-0.4.6.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

befordata-0.4.6-py3-none-any.whl (21.2 kB view details)

Uploaded Python 3

File details

Details for the file befordata-0.4.6.tar.gz.

File metadata

  • Download URL: befordata-0.4.6.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for befordata-0.4.6.tar.gz
Algorithm Hash digest
SHA256 e5b564b4b858e8434c7104c9b655f4202fbae00b1d47e73ba5730f8cf3f4657d
MD5 7d0b3f91d88d3024ea7183cb0a1f0d03
BLAKE2b-256 a5b93e96122385cb76e2975f7c9903bf88c73715fac2bb3d1118148652ced51b

See more details on using hashes here.

File details

Details for the file befordata-0.4.6-py3-none-any.whl.

File metadata

  • Download URL: befordata-0.4.6-py3-none-any.whl
  • Upload date:
  • Size: 21.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for befordata-0.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e736070aa9f254b6e0fd81e5064cef6fe16082ea0c54b09cdfca85b75f65a71e
MD5 308715e4906374fbf7419bb62af32a42
BLAKE2b-256 fc4000a3ac376156b01b6ce452ef509039755ab080af69595a7ee1a77e2c912a

See more details on using hashes here.

Supported by

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