Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/kurtamohler/pytorch-dev-multienv
- Owner: kurtamohler
- License: bsd-3-clause
- Created: 2021-02-11T17:05:35.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-04-22T21:12:23.000Z (over 1 year ago)
- Last Synced: 2024-12-27T16:40:36.674Z (9 days ago)
- Language: Shell
- Size: 27.3 KB
- Stars: 5
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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