Skip to content
forked from hpi-xnor/bitorch

BITorch: Open-Source Implementation of Binary Neural Networks with PyTorch

License

Notifications You must be signed in to change notification settings

jocodeone/bitorch

 
 

Repository files navigation

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.

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.

Afterwards 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

To use advanced logging capabilities with tensorboardX, 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 .

To activate advanced logging with Tensorboard and model summary, install the optional dependencies as well:

pip install -e ".[opt]"

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

Code formatting and typing

Install the dev requirements for (local) development:

pip install -e ".[dev]"

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

Finally, the tests can be run with:

pytest

About

BITorch: Open-Source Implementation of Binary Neural Networks with PyTorch

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%