File size: 3,529 Bytes
734b49b 40fcacd f88ae64 40fcacd ddc46cf 40fcacd ddc46cf 388fc49 ddc46cf 0ddc389 ddc46cf 8524936 ddc46cf 40fcacd 6af7cff 40fcacd ce1a3f9 e927cb8 0702ff7 ce1a3f9 ddc46cf 2ff2a55 ddc46cf ce1a3f9 ddc46cf fcd083f 0702ff7 27a4584 0702ff7 ddc46cf 8524936 0702ff7 ddc46cf 02ef4b7 0702ff7 407ee02 c871a3d 53211f9 9a9544c 53211f9 0702ff7 7a67842 0702ff7 ddc46cf 7a67842 5d4ebaf 7a67842 5d4ebaf |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
---
language:
- en
pipeline_tag: tabular-classification
tags:
- Computational Neuroscience
---
To reduce the effort in manual curation, we developed a machine learning approach using Neuropixels probes,
incorporating quality metrics to identify noise clusters and isolate single-cell activity automatically.
Compatible with the Spikeinterface API, our method generalizes across various probes and species.
We generated a machine learning model trained on 11 mice in V1, SC, and ALM using Neuropixels on mice.
Each recording was labeled by at least two people and in different combinations.
The agreement amongst labelers is 80%.
There are two tutorial notebooks:
1. Model_based_curation_tutorial.ipynb
This notebook helps you apply pretrained models to new recordings. Simply load the models and use them to label your spike-sorted data.
We provide "noise_neuron_model.skops" which is used to identify noise, and "sua_mua_model.skops" which is used to isolate SUA. These models
can be used if you want to predict labels (SUA,MUA and noise) on mice data generated using Neuropixels.
Steps:
1. load your recording depending on the acquisition software you used to create the 'recording' object
2. load your sorting depending on the spike sorter you used to create the 'sorting' object
3. Then you can create a Sorting_Analyzer object and you compute quality metrics.
These steps are explained in more details in the jupyter notebook in files folder.
auto_label_units is the main in this notebook. API link to know the parameters:
(https://spikeinterface--2918.org.readthedocs.build/en/2918/api.html#spikeinterface.curation.auto_label_units)
# example use of auto-label function
from spikeinterface.curation import auto_label_units
labels = auto_label_units(
sorting_analyzer = sorting_analyzer,
model_folder = “SpikeInterface/a_folder_for_a_model”,
trusted = [‘numpy.dtype’])
2. Train_new_model.ipynb
If you have your own manually curated data (e.g., from other species), this notebook allows you to train a new model using your specific data.
Here you need to follow the three steps mentioned before but you need to provide your manually curated labels.
train_model is the main function to train your model. API link to know the parameters:
https://spikeinterface--2918.org.readthedocs.build/en/2918/api.html#spikeinterface.curation.train_model
# example use of train_model function
from spikeinterface.curation.train_manual_curation import train_model
trainer = train_model(mode = "analyzers",
labels = labels,
analyzers = [labelled_analyzer, labelled_analyzer],
output_folder = str(output_folder),
imputation_strategies = None,
scaling_techniques = None,
classifiers = None) # Default to Random Forest only. Other classifiers you can try [ "AdaBoostClassifier", "GradientBoostingClassifier",
# "LogisticRegression", "MLPClassifier", "XGBoost", "LightGBM", "CatBoost"]
Acknowledgments:
I would like to thank people who have helped a lot in this project:
* For code refactoring and helping integration in Spikeinterface: Chris Halcrow, Jake Swann, Robyn Greene
* Curators: Nilufar Lahiji, Sacha Abou Rachid, Severin Graff, Luca Koenig, Natalia Babushkina, Simon Musall
* Advisors: Alessio Buccino, Matthias Hennig and Simon Musall
Also all my amazing lab members : https://brainstatelab.wordpress.com/ |