Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kurtamohler/pytorch-dev-multienv

Manage multiple development environments for PyTorch
https://github.com/kurtamohler/pytorch-dev-multienv

Last synced: 5 days ago
JSON representation

Manage multiple development environments for PyTorch

Awesome Lists containing this project

README

        

# pytorch-dev-multienv
Manage multiple environments for PyTorch contribution development. This tool
allows you to work on multiple PyTorch repo clones simultaneously

## Prerequisites

pytorch-dev-multienv has only been tested on a Quansight qgpu machine with CUDA
and other dependencies already installed. At the moment, it is not likely to
work anywhere else. In the future, I plan to generalize the tool so more people
can use it.

This tool may or may not work with ccache, I am not sure yet.

If you want to try to use this on your own machine, try following these
instructions to install CUDA:
https://github.com/Quansight/dev-notes/blob/master/CUDA-installation-in-qgpu.md#installing-cuda-driver-and-toolkits-for-sudoers-only

## Installation

Add the following lines to your `~/.bashrc` script. Make sure to fill in your
PyTorch fork URL and absolute path to pytorch-dev-multienv, everything between
and including `[` and `]`.

```
# Configure pytorch-dev-multienv
export PYTORCH_FORK_URL="[ url to your pytorch fork on GitHub ]"
export PYTORCH_DEV_MULTIENV_PATH="[ absolute path to this repo ]"
source "$PYTORCH_DEV_MULTIENV_PATH/bashrc_pytorch-dev-multienv.sh"
```

Run `$ source .bashrc`, or open a new terminal before continuing.

## Create a new PyTorch development environment

Any time you need to create a new PyTorch development environment and clone,
run the following commands.

For simplicity, I recommend using the same name for the conda env and the
pytorch clone. I also recommend prefixing these names with `pytorch-`.

```
$ create-pytorch-conda-env [new conda env name]
$ clone-pytorch [new pytorch clone name]
```

## Building and importing PyTorch

Before building PyTorch or before attempting to import it in Python, you must
activate the associated conda environment. Note that `activate-pytorch` has
automatic tab completion, which will list all the available conda envs.

```
$ activate-pytorch [pytorch conda env name]
```

Now you can build as usual. For instance:

```
$ cd [pytorch clone]
$ python setup.py develop
```

Note: If you're using multiple different PyTorch clones, make sure to always
activate the correct conda environment before building the associated clone.
You will also have to activate the correct environment before trying to run any
Python scripts using one of your PyTorch clones.

## Other tools

### even-with-upstream

When you want to even your local and origin main branch with upstream/main,
run the following while you're in your pytorch clone. This is useful when you
need to rebase a branch.

```
$ even-with-upstream
```

### clean-pytorch

If you want to completely clean and even your clone with upstream/main, run
the following while you're in your pytorch clone. Since this removes all local
changes, you can rename the pytorch repo clone afterwards, if you wish. This is
useful if you want to repurpose a clone, instead of deleting it and rerunning
`clone-pytorch`.

```
$ clean-pytorch
```

## Credits

This tool is heavily based on this script https://github.com/Quansight/pearu-sandbox/blob/master/working-envs/activate-pytorch-dev.sh