Skip to main content

A package for building and training quantized and binary neural networks with Pytorch

Project description

BITorch

BITorch is a library currently under development to simplify building quantized and binary neural networks with PyTorch. This is an early preview version of the library. If you wish to use it and encounter any problems, please create an issue. Our current roadmap contains:

  • Extending the model zoo with pre-trained models of state-of-the-art approaches
  • Adding examples for advanced training methods with multiple stages, knowledge distillation, etc.

All changes are tracked in the changelog.

Please refer to our wiki for a comprehensive introduction into the library or use the introduction notebook in examples/notebooks.

Installation

Similar to recent versions of torchvision, you should be using Python 3.8 or newer. Currently, the only supported installation is pip (a conda package is planned in the future).

Pip

If you wish to use a specific version of PyTorch for compatibility with certain devices or CUDA versions, we advise on installing the corresponding versions of pytorch and torchvision first (or afterwards), please consult pytorch's getting started guide.

Otherwise, simply run:

pip install bitorch

Note, that you can also request a specific PyTorch version directly, e.g. for CUDA 11.3:

pip install bitorch --extra-index-url https://download.pytorch.org/whl/cu113

If you want to run the examples install the optional dependencies as well:

pip install "bitorch[opt]"

Local and Development Install Options

The package can also be installed locally for editing and development. First, clone the repository, then run:

pip install -e .         # without optional dependencies
pip install -e ".[opt]"  # with optional dependencies

Dali Preprocessing

If you want to use the Nvidia dali preprocessing library, e.g. with CUDA 11.x, (currently only supported for imagenet) you need to install the nvidia-dali-cuda110 package by running the following command:

pip install --extra-index-url https://developer.download.nvidia.com/compute/redist --upgrade nvidia-dali-cuda110

Development

Install the package and dev requirements locally for development:

pip install -e ".[dev]"

Tests

The tests can be run with pytest:

pytest

Code formatting and typing

For conveniently checking whether your code suites the required style (more details below), run

./check-codestyle.sh

New code should be compatible with Python 3.X versions and be compliant with PEP8. To check the codebase, please run

flake8

The codebase has type annotations, please make sure to add type hints if required. We use mypy for type checking:

mypy --config-file mypy.ini

For code formatting we use black:

black . --check --verbose --diff --color  # check what changes the formatter would do
black .  # apply the formatter

In order to automatically apply the code formatting with every commit, you can also install pre-commit and use the pre-commit hook:

pre-commit install

Documentation

We use Google's Python Docstring Format to document our code.

Documentation can be generated with

sphinx-build -b html docs/source/ docs/build/ -a

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

bitorch-0.4.1.tar.gz (122.7 kB view details)

Uploaded Source

Built Distribution

bitorch-0.4.1-py2.py3-none-any.whl (159.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file bitorch-0.4.1.tar.gz.

File metadata

  • Download URL: bitorch-0.4.1.tar.gz
  • Upload date:
  • Size: 122.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.18

File hashes

Hashes for bitorch-0.4.1.tar.gz
Algorithm Hash digest
SHA256 f30223a9ffaedb5cf17464e4fb8b00c81bfac965e627c15b3eba92a276e0965e
MD5 d2a52e9640ad8facb7a40d6ff26df366
BLAKE2b-256 1cb9014b21903a99047933c75fa9c4fee1268dab049568de4e2d99f7b8a23ba6

See more details on using hashes here.

File details

Details for the file bitorch-0.4.1-py2.py3-none-any.whl.

File metadata

  • Download URL: bitorch-0.4.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 159.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.18

File hashes

Hashes for bitorch-0.4.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 592e22e8afb15f4446b3bfc9d3172333e4da5b7e830c713d6c8db4f60e08cf96
MD5 7f611b0989978bd73ab725990dcd169a
BLAKE2b-256 9c1eb17ed3d0897cfb72bc1e49768c45b05591410fb438f8d34eb6aee925c8bb

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