Skip to main content

A framework of tools to structure, configure and drive deep learning projects

Project description

serotiny

While going about the work of building deep learning projects, several simultaneous problems seemed to emerge:

  • How do we reuse as much work from previous projects as possible, and focus on building the part of the project that makes it distinct?
  • How can we automate the generation of new models that are based on existing models, but vary in a crucial yet non-trivial way?
  • When generating a multiplicity of related models, how can we keep all of the results, predictions, and analyses straight?
  • How can the results from any number of trainings and predictions be compared and integrated in an insightful yet generally applicable way?

Serotiny arose from the need to address these issues and convert the complexity of deep learning projects into something simple, reproducible, configurable, and automatable at scale.

Serotiny is still a work-in-progress, but as we go along the solutions to these problems become more clear. Maybe you've run into similar situations? We'd love to hear from you.

Overview

serotiny is a framework and set of tools to structure, configure and drive deep learning projects, developed with the intention of streamlining the lifecycle of deep learning projects at Allen Institute for Cell Science.

It achieves this goal by:

  • Standardizing the structure of DL projects
  • Relying on the modularity afforded by this standard structure to make DL projects highly configurable, using hydra as the framework for configuration
  • Making it easy to adopt best-practices and latest-developments in DL infrastructure by tightly integrating with
    • Pytorch Lightning for neural net training/testing/prediction
    • MLFlow for experiment tracking and artifact management

In doing so, DL projects become reproducible, easy to collaborate on and can benefit from general and powerful tooling.

Getting started

For more information, check our documentation, or jump straight into our getting started page, and learn how training a DL model can be as simple as:

$ serotiny train data=my_dataset model=my_model

Authors

  • Guilherme Pires @colobas
  • Ryan Spangler @prismofeverything
  • Ritvik Vasan @ritvikvasan
  • Caleb Chan @calebium
  • Theo Knijnenburg @tknijnen
  • Nick Gomez @gomeznick86

Citing

If you find serotiny useful, please cite this repository as:

Serotiny Authors (2022). Serotiny: a framework of tools to structure, configure and drive deep learning projects [Computer software]. GitHub. https://github.com/AllenCellModeling/serotiny
Free software: BSD-3-Clause

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

serotiny-0.0.6.dev202210241914.tar.gz (48.4 kB view details)

Uploaded Source

Built Distribution

serotiny-0.0.6.dev202210241914-py3-none-any.whl (73.7 kB view details)

Uploaded Python 3

File details

Details for the file serotiny-0.0.6.dev202210241914.tar.gz.

File metadata

File hashes

Hashes for serotiny-0.0.6.dev202210241914.tar.gz
Algorithm Hash digest
SHA256 2e0d39db0d11d66af690c3fae6de059fa25e9e3bc30a5db60ce4aead248135e1
MD5 554b74d63de152eb8c7ca867abbcd494
BLAKE2b-256 2f0cc8c60c3d9c9649a5a1147ced027a03c2e6aa3cb5182bfed0f833f1afba4d

See more details on using hashes here.

File details

Details for the file serotiny-0.0.6.dev202210241914-py3-none-any.whl.

File metadata

File hashes

Hashes for serotiny-0.0.6.dev202210241914-py3-none-any.whl
Algorithm Hash digest
SHA256 5ea9c2409051b7a5b6b94fdc7577355de8b9ab5e244c368fce31bda309a29f6a
MD5 a4a5fe91d0bcc3e4faf33229425a2648
BLAKE2b-256 7d7ff5a37f0723b81f611a0cd71d8e96dc00ff5a350fa31f53880654b0a11e48

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