Skip to main content

Package for implementing bayesian deep conjugate models in python.

Project description

Romus

Romus is a passion project of mine. I often have to deal with coding up simple conjugate models and gibbs samplers at work. This is useful for the variety of experimentation asks my data science team supports. I also use these models to help educate more junior data scientists about Bayesian statistics. This package is meant to serve a dual purpose as a tool for simple modeling and as an example for educational purposes.

I'm open to all questions, feedback, commentary, and suggestions as long as they are constructive and polite! Discussions should always come in the form of git issues.

Authors

James Montgomery - Initial Work - jamesmontgomery.us

License

This project is licensed under the MIT License - see the LICENSE.md file for details

About the Name

Why call the package Romus? Romulus and Remus were a famous pair of twins whose myth is tied to the founding of Rome. Conjugate distributions (or distributions closed under sampling) are pairs of distributions who have a special relationship that is sometimes useful in machine learning and statistics. Therefore I thought it would be fun to name my package after a famous pair of twins!

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Installing

For a local installation, first git clone this repository. Then follow these instructions:

pip install .

To install from pypi:

pip install -U romus

Testing

Testing is an important part of creating maintainable, production grade code. Below are instructions for running unit and style tests as well as installing the necessary testing packages. Tests have intentionally been separated from the installable pypi package for a variety of reasons.

Make sure you have the required testing packages:

pip install -r requirements_test.txt

Running the unit tests

We use the pytest framework for unit testing.

pytest -vvl -s --cov romus --disable-pytest-warnings

Running the style tests

Having neat and legible code is important. Having documentation is also important. We use pylint as our style guide framework. Many of our naming conventions follow directly from the literary sources they come from. This makes it easier to read the mathematical equations and see how they translate into the code. This sometimes forces us to break pep8 conventions for naming.

pylint romus --disable=invalid-name

Contributor's Guide

Here are some basic guidelines for contributing.

Branch Strategy

This repository doesn't use a complicated branching strategy. Simply create a feature branch off of master. When the feature is ready to be integrated with master, submit a pull request. A pull request will re quire at least one peer review and approval from the repository owner.

Style Guide

Please stick to pep8 standards when for your code. Use numpy style docstrings.

Test Requirements

Please use pytest as your testing suite. You code should have >= 80% coverage.

Updating the Docs

Updating the documentation is simple. First, let auto-docs check for updates to the package structure.

cd docs
sphinx-apidoc -o . ../romus/

Finally, rebuild the html files.

make html

Acknowledgments

A big thank you to Keegan Hines and Mack Sweeney both of who helped start me on my journey into Bayesian statistics.

TODO

This package is still in the development phase. Here I list some tasks that are still left to be completed...

  • Add ToC to README
  • Add gibbs samplers to package
  • Add mixture conjugate models to package
  • Fill out examples
  • Fill out model specification docs
  • Fill out distributions docs
  • Update docstrings
    • module docstrings
    • class docstrings
    • function docstrings
  • Type Hints
  • Proper Test
    • Units Tests
    • Smoke Tests
    • Integration Tests
  • Add docs
  • Add branch protection

Useful Resources

General

Distribution Specific

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

romus-0.0.1.tar.gz (30.9 kB view details)

Uploaded Source

Built Distribution

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

romus-0.0.1-py3-none-any.whl (20.1 kB view details)

Uploaded Python 3

File details

Details for the file romus-0.0.1.tar.gz.

File metadata

  • Download URL: romus-0.0.1.tar.gz
  • Upload date:
  • Size: 30.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/47.1.1 requests-toolbelt/0.8.0 tqdm/4.43.0 CPython/3.7.5

File hashes

Hashes for romus-0.0.1.tar.gz
Algorithm Hash digest
SHA256 bf28c85b5eedc082c622e8445b5b4f186519cdd31f5d2c984feb80eb970d628c
MD5 7da65020abdf630d4df6f2bc801789c2
BLAKE2b-256 0f68b0a04d3eb2b19d5743faebc878d2c2c886801f16262bed4f9e926a76ef1c

See more details on using hashes here.

File details

Details for the file romus-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: romus-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 20.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/47.1.1 requests-toolbelt/0.8.0 tqdm/4.43.0 CPython/3.7.5

File hashes

Hashes for romus-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bf8a88e8e913a5a7ca2940db37bb170ae52381e39b164061894e5abb247c47a8
MD5 693e32ce0bf4c9720349f713eb2b8e19
BLAKE2b-256 2ea09495f6eb3293724cd798f46e4e67e245ea87d6c66ad81dd026cf512e2367

See more details on using hashes here.

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