ktrapeznikov's picture
Update README.md
e5d7840 verified
# SAFE Example Submission with Custom Environment
This is an example of a submission that includes a custom environment.
So instead of using the default environment of the submission, we first create a custom environment, package it with conda-pack and then push to the model hub in addition to the rest of the files.
Here are the steps:
1. ## Determine the environment that you want and save to the `requirements-custom.txt` file.
The best way is to start from the base competition image, create a new environment, test it with your model and use `pip freeze` to export it.
To start the container:
```bash
docker run -it --rm --gpus all -v /path/to/local:/app/custom-env huggingface/competitions:latest bash
```
to create an environment:
```bash
conda init
source ~/.bashrc
conda create -n custom python=3.10 -y
conda activate custom
```
Then you can install packages with pip, conda, etc.
2. ## Export the environment with `conda-pack` to a `.tar.gz` file.
Run `docker-compose up`. This will pull the base competition image, copy the files into the container and create a new environment save it.
Change the local place where the volume `/app/custom-env` mounts in the docker-compose file. It will run `make_custom_env.sh` inside the container.
```bash
conda init
source ~/.bashrc
conda create -n custom python=3.10 -y
conda activate custom
pip install -r requirements-custom.txt
export OUTPUT=/app/custom-env/custom.tar.gz
conda deactivate
pip install conda-pack
conda-pack -n custom -o $OUTPUT
```
3. ## Upload the enviroment. Since the environment file is large.
It's better to upload it seperately using fast HF_TRANSFER. Make sure to install `pip install huggingface_hub[hf_transfer]`.
```bash
bash upload_env_file
```
Make sure to change the path to your env file in the script. This is what the script does:
```bash
ENV_FILE=/disk1/kirill/custom-env/custom.tar.gz
HF_HUB_ENABLE_HF_TRANSFER=1 huggingface-cli upload safe-challenge/safe-example-submission-custom-env $ENV_FILE custom.tar.gz
```
5. ## During runtime, `script.py` unpacks the environment to run your model in your custom environment
Rename your actual script to `_script.py`. `script.py` just calls `bash run.sh` to do all the steps:
```bash
echo "uncompressing environment"
mkdir -p custom
tar -xzf custom.tar.gz -C custom
source custom/bin/activate
echo "unpacking"
conda-unpack
echo "running"
python _script.py
```