Skip to main content

DeepFinder is an original deep learning approach to localize macromolecules in cryo electron tomography images. The method is based on image segmentation using a 3D convolutional neural network.

Project description

Deep Finder

The code in this repository is described in this pre-print. This paper has now been published in Nature Methods.

News: (27/11/23) DeepFinder exists now as a Napari plugin

Contents

  • [System requirements](##System requirements)
  • [Installation guide](##Installation guide)
  • [Instructions for use](##Instructions for use)
  • Documentation
  • Google group

System requirements

Deep Finder has been implemented using Python 3 and is based on the Tensorflow package. It has been tested on Linux (Debian 10), and should also work on Mac OSX as well as Windows.

The algorithm needs an Nvidia GPU and CUDA to run at reasonable speed (in particular for training). The present code has been tested on Tesla K80 and M40 GPUs. For running on other GPUs, some parameter values (e.g. patch and batch sizes) may need to be changed to adapt to available memory.

Package dependencies

Deep Finder depends on following packages. The package versions for which our software has been tested are displayed in brackets:

tensorflow   (2.11.1)
lxml         (4.9.3)
mrcfile      (1.4.3)
scikit-learn (1.3.2)
scikit-image (0.22.0)
matplotlib   (3.8.1)
PyQt5        (5.15.10)
pyqtgraph    (0.13.3)
openpyxl     (3.1.2)
pycm         (4.0)

Installation guide

Before installation, you need a python environment on your machine. If this is not the case, we advise installing Miniconda.

(Optional) Before installation, we recommend first creating a virtual environment that will contain your DeepFinder installation:

conda create --name dfinder python=3.9
conda activate dfinder

Now, you can install DeepFinder with pip:

pip install cryoet-deepfinder

Also, in order for Keras to work with your Nvidia GPU, you need to install CUDA. Once these steps have been achieved, the user should be able to run DeepFinder.

Instructions for use

Using the scripts

Instructions for using Deep Finder are contained in folder examples/. The scripts contain comments on how the toolbox should be used. To run a script, first place yourself in its folder. For example, to run the target generation script:

cd examples/training/
python step1_generate_target.py

Using the GUI

The GUI (Graphical User Interface) should be more intuitive for those who are not used to work with script. Currently, 5 GUIs are available (tomogram annotation, target generation, training, segmentation, clustering) and allow the same functionalities as the scripts in example/. To run a GUI, first open a terminal. For example, to run the segmentation GUI:

segment

Training GUI

==Important information:== Except for the training, the using of the GUI is depreciated. We advise using the Napari plugin instead.

For more informations about how to use DeepFinder, please refer to the documentation.

Notes:

  • working examples are contained in examples/analyze/, where Deep Finder processes the test tomogram from the SHREC'19 challenge.
  • The script in examples/training/ will fail because the training data is not included in this Gitlab.
  • The evaluation script (examples/analyze/step3_launch_evaluation.py) is the one used in SHREC'19, which needs additional packages (pathlib and pycm, can be installed with pip). The performance of Deep Finder has been evaluated by an independent group, and the result of this evaluation has been published in Gubins & al., "SHREC'19 track: Classification in cryo-electron tomograms".

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

cryoet_deepfinder-0.2.1.tar.gz (43.8 kB view details)

Uploaded Source

Built Distribution

cryoet_deepfinder-0.2.1-py3-none-any.whl (45.6 kB view details)

Uploaded Python 3

File details

Details for the file cryoet_deepfinder-0.2.1.tar.gz.

File metadata

  • Download URL: cryoet_deepfinder-0.2.1.tar.gz
  • Upload date:
  • Size: 43.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.0

File hashes

Hashes for cryoet_deepfinder-0.2.1.tar.gz
Algorithm Hash digest
SHA256 e23ed6a3f9cc2be183b9723b6b9a916ae89d92f635901929ff9ea4cc410bfaf0
MD5 2a768c897bc4ef34f9039547a1ddf0f8
BLAKE2b-256 c6f9eb80edc69d76964299886c117ad6198525a0744f9b8dd4243233c52ad648

See more details on using hashes here.

File details

Details for the file cryoet_deepfinder-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for cryoet_deepfinder-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 df425a68e835e232ec539bde675b4a2b68c4ee5c5492fc61c119d0c4919bcf47
MD5 d7dbeb8d004379f40bf97a3e67f36f66
BLAKE2b-256 c02f6bbc7fbe9d40a0dabbd7dc36f054e0bfb1974d12724fb212ff2cdd2f0316

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