OpenDeltaMirror/README.md

115 lines
4.3 KiB
Markdown
Raw Normal View History

2022-02-14 21:19:03 +08:00
<div align="center">
<img src="https://s4.ax1x.com/2022/02/14/Hy7lAf.png" width="350px">
2022-06-05 20:13:27 +08:00
**An Open-Source Framework for Paramter-Efficient Tuning (Delta Tuning).**
2022-02-14 21:19:03 +08:00
------
<p align="center">
<a href="#Overview">Overview</a>
<a href="#installation">Installation</a>
2022-02-14 23:11:04 +08:00
<a href="https://opendelta.readthedocs.io/en/latest/notes/usage.html">Basic Usage</a>
2022-02-14 21:19:03 +08:00
<a href="https://opendelta.readthedocs.io/">Docs</a>
2022-02-14 23:13:20 +08:00
<a href="https://docs.google.com/spreadsheets/d/1BIVa8ocAPga-u7rBOXLYaTfaJSjI1dWfwohmLjmFDrY/edit?usp=sharing">Performance</a>
2022-02-14 21:19:03 +08:00
</p>
</div>
2022-02-14 23:13:20 +08:00
![version](https://img.shields.io/badge/version-0.0.1-blue)
2022-02-14 21:19:03 +08:00
2022-02-16 22:57:21 +08:00
2022-02-14 21:19:03 +08:00
## Overview
2022-08-23 01:21:55 +08:00
OpenDelta is a toolkit for parameter-efficient tuning methods (we dub it as *delta tuning*), by which users could flexibly assign (or add) a small amount parameters to update while keeping the most paramters frozen. By using OpenDelta, users could easily implement prefix-tuning, adapters, Lora, or any other types of delta tuning with preferred PTMs.
2022-02-14 21:19:03 +08:00
2022-02-15 13:51:57 +08:00
- Our repo is tested on Python 3.8 and PyTorch 1.9.0. Lower version may also be supported.
2022-02-14 23:11:04 +08:00
2022-02-15 13:51:57 +08:00
- **A demo of using Opendelta to modify the PLM (E.g., BART).**
2022-02-15 10:47:56 +08:00
![How PLM changes using Delta-tuning](docs/source/imgs/demo.gif)
2022-02-15 00:07:25 +08:00
2022-02-16 22:57:21 +08:00
## Updates
2022-03-24 15:43:29 +08:00
- 2022.03.24 We notice several bugs in Soft Prompt Tuning and Prefix Tuning, mainly due to their need to customize attention ids, token_type_ids, we are fixing it! Currently, please use the other methods since they are stabler and better in performance.
2022-07-04 00:14:01 +08:00
- 2022.03.20 Add a [colab example](https://colab.research.google.com/drive/1uAhgAdc8Qr42UKYDlgUv0f7W1-gAFwGo?usp=sharing) to illustrate efficient training and space-saving multitask-serving.
2022-03-24 15:43:29 +08:00
- 2022.03.20 A new pip version released.
- 2022.02.16 Support [regular expression](https://opendelta.readthedocs.io/en/latest/notes/namebasedaddr.html#regexexpr) in named-based addressing.
2022-02-16 22:57:21 +08:00
2022-02-14 21:19:03 +08:00
## Installation
create a virtualenv (optional)
```shell
conda create -n opendelta_env python=3.8
conda activate opendelta_env
```
### Using Pip
2022-02-14 23:11:04 +08:00
Install OpenDelta using pip as follows:
2022-02-14 21:19:03 +08:00
```shell
pip install opendelta
```
To play with the latest features, you can also install OpenDelta from the source.
### Build from Source
```shell
git clone https://github.com/thunlp/OpenDelta.git
cd OpenDelta
```
#### Option 1: If you won't modify the code, run
```shell
python setup.py install
```
2022-02-16 22:57:21 +08:00
#### Option 2: If you want to modify the code or keep the repo updated by git clone, run
2022-02-14 21:19:03 +08:00
```shell
python setup.py develop
```
2022-07-03 10:10:18 +08:00
If you encounter network error using setup.py, please firstly install the dependencies via
```shell
pip install -r requirements.txt && python setup.py develop
```
2022-02-14 23:23:01 +08:00
## Must Try
```python
from transformers import AutoModelForSeq2SeqLM
2022-07-04 00:14:01 +08:00
t5 = AutoModelForSeq2SeqLM.from_pretrained("t5-large")
2022-02-14 23:23:01 +08:00
from opendelta import AutoDeltaModel
2022-07-04 00:14:01 +08:00
delta = AutoDeltaModel.from_finetuned("thunlp/FactQA_T5-large_Adapter", backbone_model=t5)
2022-02-14 23:23:01 +08:00
delta.log()
```
2022-02-14 21:19:03 +08:00
2022-02-14 23:24:21 +08:00
## Verified Supported Models
2022-02-14 21:19:03 +08:00
2022-02-14 23:47:40 +08:00
- **You can try to use OpenDelta on *any* backbone models based on PyTorch.**
- However, with small chances thatThe interface of the submodules of the backbone model is not supported. Therefore we verified some commonly
2022-02-14 21:19:03 +08:00
used models that OpenDelta are sure to support.
2022-02-14 23:47:40 +08:00
- We will keep testing more and more emerging models.
2022-02-14 21:19:03 +08:00
2022-02-14 23:47:40 +08:00
- Pull requests are welcomed when you successfully apply OpenDelta on your own backbone model.
2022-02-14 21:19:03 +08:00
| | Lora | Bias<br>Tuning | Adapter<br>Houstbly | Adapter<br>Preffier | Adapter<br>Drop | Adapater<br> Low-Rank | Compactor |Prefix<br> Tuning | Prompt <br> Tuning |
| --------- | ---- | ---- | ---- | ---- | ---- | ---- | ---- | ----- | ----- |
| T5 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
| GPT-2 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
| BART | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
| DistilBERT | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
| RoBERTa | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
| BERT | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
| T5-3b(parallel)| ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
| Deberta-v2 | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | | |
| CTRL | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | | |
2022-03-24 15:41:25 +08:00