Skip to main content

Automatic matching of neurons across sessions

Project description

UnitMatchPy and DeepUnitMatch

This repository contains:

  • UnitMatchPy: automatic matching of neurons across sessions (Python package).
  • DeepUnitMatch: DeepUnitMatch pipeline and demos (see preprint below).

References

Versions

  • UnitMatchPy version: 3.3.1 (from pyproject.toml)
  • DeepUnitMatch: code lives under DeepUnitMatch/ (see DeepUnitMatch (DUM) section)

System requirements

Both UnitMatchPy and DeepUnitMatch can be ran on a standard computer, with sufficient RAM (>32GB for large datasets). This software is supported for Windows and macOS, and has been tested on Windows 11.

Installation

pip install (including pip install -e .) installs into whatever Python environment your pip points to (system Python, a conda env, or a virtualenv). pip does not create or name environments.

We recommend using Anaconda/Miniconda (conda) to create an isolated environment first:

# Create a new environment (pick any name you like; example: UMPy)
conda create -n UMPy python=3.11 pip #(press y when prompted)
conda activate UMPy

Then install using pip (options below). This step should take less than few minutes.

Option A: Install the released package (PyPI)

pip install UnitMatchPy

Optional extras (heavier dependencies used by some notebooks and integration with SpikeInterface):

pip install "UnitMatchPy[full,notebooks]"

Option B: Install a local, editable copy (for development / modified code)

First, open a terminal and navigate to this folder (the one containing pyproject.toml). The pip install -e command must be run from here:

# Windows (PowerShell) - note; you may have to give writing access to the specific CONDA environment via Windows Security → Virus & threat protection → Ransomware protection → Manage ransomware protection. For example, if the below steps result in "could not create 'UnitMatchPy.egg-info'"

Look at Controlled folder access:
cd $HOME\Documents\GitHub\UnitMatch\UnitMatchPy

# macOS / Linux
cd ~/Documents/GitHub/UnitMatch/UnitMatchPy
pip install -e .

Optional extras (e.g. if you'd like to run the notebooks or integrate with SpikeInterface):

pip install -e ".[full,notebooks]"

Demo notebooks

All demo notebooks are in Demo Notebooks/.

Run UnitMatchPy

To run UnitMatchPy, standard spike sorting data is needed (channel positions and extracted raw waveforms for each unit). Waveforms can be extracted externally (e.g. BombCell) or using the demo notebooks:

  • Demo Notebooks/extract_raw_data_demo.ipynb (compressed .cbin/.ch or raw)
  • Demo Notebooks/extract_raw_data_demo_open_ephys.ipynb (Open Ephys)
  • Demo Notebooks/UMPy_spike_interface_demo.ipynb (SpikeInterface workflow)

Example notebooks:

  • Demo Notebooks/UMPy_example.ipynb (recommended starting point)
  • Demo Notebooks/UMPy_example_detailed.ipynb (more modular / advanced)

The GUI is an optional step to curate and explore UnitMatch outputs; see Demo Notebooks/GUI_Reference_Guide.md for usage tips and shortcuts.

Run DeepUnitMatch

To try the DeepUnitMatch version, start with:

  • Demo Notebooks/DeepUnitMatch.ipynb

It should take just a few minutes to run on a standard PC.

If you want to train / fine-tune a model on your own data, see:

  • Demo Notebooks/DUM_training.ipynb

Important note: DeepUnitMatch current trained model is for Npix 2.0 4-shank only. You will need to train a new model with your own data if you have any other type of probe. (For example, Mouse2 from the figshare data is a Npix 1 dataset, you'll notice the trained model won't give good results on this mouse for that reason.)

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

unitmatchpy-3.3.1.tar.gz (185.6 kB view details)

Uploaded Source

Built Distribution

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

unitmatchpy-3.3.1-py3-none-any.whl (489.2 kB view details)

Uploaded Python 3

File details

Details for the file unitmatchpy-3.3.1.tar.gz.

File metadata

  • Download URL: unitmatchpy-3.3.1.tar.gz
  • Upload date:
  • Size: 185.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for unitmatchpy-3.3.1.tar.gz
Algorithm Hash digest
SHA256 2edfacd8bc2a0d80dcda1af5497f7a5a979a381793fdaff3171ad9ea04592b27
MD5 a1e38d907c959eb66e0b123f91d83a88
BLAKE2b-256 21d938586e3b4aa560242103bccdf779b287d34af39fc02dd681b064c9ea2ddb

See more details on using hashes here.

Provenance

The following attestation bundles were made for unitmatchpy-3.3.1.tar.gz:

Publisher: publish.yml on EnnyvanBeest/UnitMatch

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file unitmatchpy-3.3.1-py3-none-any.whl.

File metadata

  • Download URL: unitmatchpy-3.3.1-py3-none-any.whl
  • Upload date:
  • Size: 489.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for unitmatchpy-3.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2fcc2ff327819f19d6dee1213f036177b5463eb8e8cb1201745ff890fca33254
MD5 954a2dd2c64ac3deb65f9efb9e2685ff
BLAKE2b-256 d1d4077b01695a063e4283d204c51f929bd1afd0b399c1e8f3b3417a2360f471

See more details on using hashes here.

Provenance

The following attestation bundles were made for unitmatchpy-3.3.1-py3-none-any.whl:

Publisher: publish.yml on EnnyvanBeest/UnitMatch

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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