This repository contains the code described in the following publication:
O'Neill P.S., Baccino-Calace M., Rupprecht P., Friedrich R.W., Müller, M., and Delvendahl, I.
(2024) Deep learning-based synaptic event detection. eLife (doi:10.7554/eLife.98485.1)
miniML is a deep-learning-based tool to detect synaptic events in 1d time-series data. It uses a CNN-LSTM network architecture that was trained using a large dataset of synaptic events (miniature excitatory postsynaptic currents) from cerebellar mossy fiber to granule cell synapses.
In this repository, we provide documentation, pre-trained models, and Python code to run model inference on recorded data. In addition, an application example (cerebellar granule cell mEPSC recording) is included.
We have updated the documentation for miniML. The latest version of the documentation is available here.
Please also see the updated preprint at bioRxiv.
To use miniML, clone the GitHub Repository and install the requirements. miniML has been tested with Python 3.9 and 3.10. The Python dependencies are: sklearn, matplotlib, h5py, pandas, numpy, scipy, tensorflow, pyabf. To install all dependencies using pip, run the following command in your Python environment:
pip install -r requirements.txt
Important
The release of TensorFlow 2.16 and Keras 3 introduced breaking changes that raise an error when loading models trained with earlier TensorFlow versions. To avoid this, it is recommended to use TensorFlow 2.14 or 2.15.
Note
miniML can be run on a GPU to speed model inference. Either CUDA or tensorflow-metal are required for GPU use. Installation instructions for these requirements may depend on the specific hardware and OS and can be found online.
To use miniML with a graphical user interface (GUI), you need to install the additional dependencies from the requirements_gui.txt file.
pip install -r requirements_gui.txt
First, a miniML MiniTrace object needs to be created containing 1d timeseries data. Currently, miniML supports direct loading from HEKA .dat files, Axon .abf files as well as HDF .h5 files. The Trace object features discrete methods for loading from these file formats (e.g., MiniTrace.from_h5_file()). Data in other file formats need to be imported as Python objects.
Next, a miniML EventDetection object is initiated. Here, one needs to specify a miniML model file to use as well as the Trace object to operate on.
miniML model inference can then be run using the detect_events() method. This method will run miniML over the given data using the specified model. Runtime will depend on data length.
Following event detection, the individual detected events are analyzed and descriptive statistics are calculated for the recording.
miniML includes several plotting methods. They can be found in the miniML_plots class in miniML_plot_functions.py
. A detection object has to be passed as data argument.
Event data and statistics can be saved in different formats (.pickle, .h5, .csv).
Tip
miniML can also be used via a GUI. To use the GUI, execute the miniml_gui.py file (located in the "core/" folder). The GUI allows easy loading of data, pre-processing (filtering, detrending etc.) and model inference. Found events can be inspected and deleted, if desired. The GUI can also be used to save results to a PICKLE, CSV or HDF5 file.
The folder "example_data/" contains an example recording from a cerebellar mossy fiber to granule cell synapse. To use miniML on this data, run the commented example Jupyter Notebook (tutorial) illustrating the use of miniML.
Detailed documentation for miniML can be found here.
The documentation includes notebooks showing how to train miniML models. You can also use the following links to Kaggle to train mminiML models on the cloud:
1 - Transfer learning
2 - Full training
3 - Training dataset
The repository contains trained models for several event detection scenarios, as outlined in the associated paper. If you have trained a model that could be useful for other researchers, please consider opening a pull request or get in touch with us in order to add it to the repository.
If you use miniML in your work, please cite:
@article{ONeill2024,
title = {A deep learning framework for automated and generalized synaptic event analysis},
url = {http://dx.doi.org/10.7554/eLife.98485.1},
DOI = {10.7554/elife.98485.1},
publisher = {eLife Sciences Publications, Ltd},
author = {O’Neill, Philipp S. and Baccino-Calace, Martín and Rupprecht, Peter and Friedrich, Rainer W. and M\"{u}ller, Martin and Delvendahl, Igor},
year = {2024},
month = jun
}
Please feel free to contact us in case of questions, either via email, or by opening an Issue here on GitHub.
philipp.oneill@physiologie.uni-freiburg.de or igor.delvendahl@physiologie.uni-freiburg.de