2022-12-20 23:17:38 -05:00
# text-generation-webui
2022-12-21 14:49:30 -05:00
A gradio webui for running large language models locally. Supports gpt-j-6B, gpt-neox-20b, opt, galactica, and many others.
Its goal is to become the [AUTOMATIC1111/stable-diffusion-webui ](https://github.com/AUTOMATIC1111/stable-diffusion-webui ) of text generation.
2022-12-21 11:17:06 -05:00
2022-12-21 12:04:51 -05:00
![webui screenshot ](https://github.com/oobabooga/text-generation-webui/raw/main/webui.png )
2023-01-07 16:40:51 -05:00
## Features
* Switch between different models using a dropdown menu.
2023-01-09 14:19:57 -05:00
* Generate nice HTML output for GPT-4chan.
2023-01-07 17:19:55 -05:00
* Generate Markdown output for [GALACTICA ](https://github.com/paperswithcode/galai ), including LaTeX support.
2023-01-07 16:40:51 -05:00
* Notebook mode that resembles OpenAI's playground.
2023-01-07 20:52:46 -05:00
* Chat mode for conversation and role playing.
2023-01-07 16:40:51 -05:00
* Load 13b/20b models in 8-bit mode.
* Load parameter presets from text files.
2023-01-09 09:11:05 -05:00
* CPU mode.
2023-01-07 16:40:51 -05:00
2022-12-21 11:17:06 -05:00
## Installation
2023-01-05 22:05:11 -05:00
Create a conda environment:
conda create -n textgen
conda activate textgen
Install the appropriate pytorch for your GPU. For NVIDIA GPUs, this should work:
conda install pytorch torchvision torchaudio pytorch-cuda=11.7 -c pytorch -c nvidia
Install the requirements:
pip install -r requirements.txt
2022-12-21 11:17:06 -05:00
2022-12-21 12:37:50 -05:00
## Downloading models
2023-01-06 00:12:38 -05:00
Models should be placed under `models/model-name` . For instance, `models/gpt-j-6B` for [gpt-j-6B ](https://huggingface.co/EleutherAI/gpt-j-6B/tree/main ).
2022-12-21 12:37:50 -05:00
2022-12-21 13:00:16 -05:00
#### Hugging Face
2022-12-21 12:37:50 -05:00
2023-01-06 00:13:48 -05:00
Hugging Face is the main place to download models. These are some of my favorite:
2022-12-21 12:37:50 -05:00
2023-01-05 22:13:26 -05:00
* [gpt-j-6B ](https://huggingface.co/EleutherAI/gpt-j-6B/tree/main )
* [gpt-neox-20b ](https://huggingface.co/EleutherAI/gpt-neox-20b/tree/main )
2023-01-07 17:19:55 -05:00
* [OPT ](https://huggingface.co/models?search=facebook/opt )
* [GALACTICA ](https://huggingface.co/models?search=facebook/galactica )
2023-01-05 22:13:26 -05:00
* [\*-Erebus ](https://huggingface.co/models?search=erebus )
2023-01-06 00:12:38 -05:00
The files that you need to download are the json, txt, and pytorch\*.bin files. The remaining files are not necessary.
2022-12-21 12:37:50 -05:00
2023-01-06 18:06:24 -05:00
For your convenience, you can automatically download a model from HF using the script `download-model.py` . Its usage is very simple:
2023-01-06 18:00:58 -05:00
python download-model.py organization/model
For instance:
python download-model.py facebook/opt-1.3b
2023-01-09 14:19:57 -05:00
#### GPT-4chan
2022-12-21 12:37:50 -05:00
2023-01-09 14:19:57 -05:00
[GPT-4chan ](https://huggingface.co/ykilcher/gpt-4chan ) has been shut down from Hugging Face, so you need to download it elsewhere. You have two options:
2022-12-21 12:37:50 -05:00
* Torrent: [16-bit ](https://archive.org/details/gpt4chan_model_float16 ) / [32-bit ](https://archive.org/details/gpt4chan_model )
* Direct download: [16-bit ](https://theswissbay.ch/pdf/_notpdf_/gpt4chan_model_float16/ ) / [32-bit ](https://theswissbay.ch/pdf/_notpdf_/gpt4chan_model/ )
2023-01-07 21:13:43 -05:00
You also need to put GPT-J-6B's config.json file in the same folder: [config.json ](https://huggingface.co/EleutherAI/gpt-j-6B/raw/main/config.json )
2023-01-09 16:58:24 -05:00
#### Converting to pytorch (optional)
2022-12-21 14:49:30 -05:00
2023-01-05 23:41:52 -05:00
The script `convert-to-torch.py` allows you to convert models to .pt format, which is about 10x faster to load:
2022-12-21 14:49:30 -05:00
2023-01-08 12:37:43 -05:00
python convert-to-torch.py models/model-name
2022-12-21 14:49:30 -05:00
2023-01-08 12:37:43 -05:00
The output model will be saved to `torch-dumps/model-name.pt` . When you load a new model, the webui first looks for this .pt file; if it is not found, it loads the model as usual from `models/model-name` .
2022-12-21 14:49:30 -05:00
2022-12-21 11:17:06 -05:00
## Starting the webui
conda activate textgen
python server.py
2023-01-06 18:00:58 -05:00
Then browse to
`http://localhost:7860/?__theme=dark`
2023-01-06 18:07:58 -05:00
Optionally, you can use the following command-line flags:
2023-01-06 18:00:58 -05:00
2023-01-09 17:06:29 -05:00
```
-h, --help show this help message and exit
--model MODEL Name of the model to load by default.
2023-01-09 17:07:10 -05:00
--notebook Launch the webui in notebook mode, where the output is written
to the same text box as the input.
2023-01-09 17:06:29 -05:00
--chat Launch the webui in chat mode.
--cpu Use the CPU to generate text.
2023-01-09 17:07:47 -05:00
--listen Make the webui reachable from your local network.
2023-01-09 17:06:29 -05:00
```
2023-01-09 08:58:46 -05:00
2023-01-05 23:33:21 -05:00
## Presets
Inference settings presets can be created under `presets/` as text files. These files are detected automatically at startup.
2023-01-09 16:12:41 -05:00
## System requirements
2023-01-09 16:18:35 -05:00
Check the [wiki ](https://github.com/oobabooga/text-generation-webui/wiki/System-requirements ) for some examples of VRAM and RAM usage in both GPU and CPU mode.
2023-01-09 16:12:41 -05:00
2022-12-21 14:52:23 -05:00
## Contributing
2023-01-09 14:09:27 -05:00
Pull requests, suggestions and issue reports are welcome.
2023-01-09 14:15:54 -05:00
## Other projects
Make sure to also check out the great work by [KoboldAI ](https://github.com/KoboldAI/KoboldAI-Client ). I have borrowed some of the presets listed on their [wiki ](https://github.com/KoboldAI/KoboldAI-Client/wiki/Settings-Presets ) after performing a k-means clustering analysis to select the most relevant subsample.