princeton-nlp commited on
Commit
cb78d4b
·
verified ·
1 Parent(s): b6d53aa

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +122 -33
README.md CHANGED
@@ -10,52 +10,141 @@ model-index:
10
  results: []
11
  ---
12
 
13
- <!-- This model card has been generated automatically according to the information the Trainer had access to. You
14
- should probably proofread and complete it, then remove this comment. -->
15
 
16
- [<img src="https://raw.githubusercontent.com/wandb/assets/main/wandb-github-badge-28.svg" alt="Visualize in Weights & Biases" width="200" height="32"/>](None)
17
- # gemma2-9b-dpo-beta-0.01-lr-5e-7
18
 
19
- This model is a fine-tuned version of [/scratch/gpfs/DANQIC/ym0081/hf_cache/gemma-2-9b-it](https://huggingface.co//scratch/gpfs/DANQIC/ym0081/hf_cache/gemma-2-9b-it) on the /scratch/gpfs/DANQIC/ym0081/hf_cache/gemma2-ultrafeedback-armorm/dataset_dict/ dataset.
20
 
21
- ## Model description
22
 
23
- More information needed
24
 
25
- ## Intended uses & limitations
26
 
27
- More information needed
 
 
 
28
 
29
- ## Training and evaluation data
30
 
31
- More information needed
32
 
33
- ## Training procedure
 
34
 
35
- ### Training hyperparameters
36
 
37
- The following hyperparameters were used during training:
38
- - learning_rate: 5e-07
39
- - train_batch_size: 1
40
- - eval_batch_size: 2
41
- - seed: 42
42
- - distributed_type: multi-GPU
43
- - num_devices: 8
44
- - gradient_accumulation_steps: 16
45
- - total_train_batch_size: 128
46
- - total_eval_batch_size: 16
47
- - optimizer: Adam with betas=(0.9,0.999) and epsilon=1e-08
48
- - lr_scheduler_type: cosine
49
- - lr_scheduler_warmup_ratio: 0.1
50
- - num_epochs: 1
51
 
52
- ### Training results
53
 
 
 
 
 
 
 
 
 
 
54
 
 
55
 
56
- ### Framework versions
57
 
58
- - Transformers 4.42.4
59
- - Pytorch 2.2.2+cu121
60
- - Datasets 2.18.0
61
- - Tokenizers 0.19.1
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
10
  results: []
11
  ---
12
 
13
+ # gemma-2-9b-it-DPO Model Card
 
14
 
15
+ This model was trained under the same setup as [gemma-2-9b-it-SimPO](https://huggingface.co/princeton-nlp/gemma-2-9b-it-SimPO), with the DPO objective.
 
16
 
17
+ SimPO (Simple Preference Optimization) is an offline preference optimization algorithm designed to enhance the training of large language models (LLMs) with preference optimization datasets. SimPO aligns the reward function with the generation likelihood, eliminating the need for a reference model and incorporating a target reward margin to boost performance. Please refer to our [preprint](https://arxiv.org/pdf/2405.14734) and [github repo](https://github.com/princeton-nlp/SimPO) for more details.
18
 
19
+ ## Model Details
20
 
21
+ ### Model Description
22
 
23
+ We fine-tuned [google/gemma-2-9b-it](https://huggingface.co/google/gemma-2-9b-it) on [princeton-nlp/gemma2-ultrafeedback-armorm](https://huggingface.co/datasets/princeton-nlp/gemma2-ultrafeedback-armorm) with the DPO objective.
24
 
25
+ - **Developed by:** Yu Meng, Mengzhou Xia, Danqi Chen
26
+ - **Model type:** Causal Language Model
27
+ - **License:** gemma
28
+ - **Finetuned from model:** [google/gemma-2-9b-it](https://huggingface.co/google/gemma-2-9b-it)
29
 
30
+ ### Model Sources
31
 
32
+ <!-- Provide the basic links for the model. -->
33
 
34
+ - **Repository:** https://github.com/princeton-nlp/SimPO
35
+ - **Paper:** https://arxiv.org/pdf/2405.14734
36
 
 
37
 
38
+ ## How to Get Started with the Model
39
+ ```
40
+ import torch
41
+ from transformers import pipeline
 
 
 
 
 
 
 
 
 
 
42
 
43
+ model_id = "princeton-nlp/gemma-2-9b-it-DPO"
44
 
45
+ generator = pipeline(
46
+ "text-generation",
47
+ model=model_id,
48
+ model_kwargs={"torch_dtype": torch.bfloat16},
49
+ device="cuda",
50
+ )
51
+ outputs = generator([{"role": "user", "content": "What's the difference between llamas and alpacas?"}], do_sample=False, max_new_tokens=200)
52
+ print(outputs[0]['generated_text'])
53
+ ```
54
 
55
+ ## Training Details
56
 
57
+ ### Training Data
58
 
59
+ We use [princeton-nlp/gemma2-ultrafeedback-armorm](https://huggingface.co/datasets/princeton-nlp/gemma2-ultrafeedback-armorm) as the preference optimization dataset.
60
+
61
+ #### Training Hyperparameters
62
+
63
+ We used the following hyperparameters:
64
+ - learning rate: 5e-7
65
+ - batch size: 128
66
+ - beta: 0.01
67
+ The other hyperparameters are kept the same with our [SimPO recipe](https://github.com/princeton-nlp/SimPO/blob/main/training_configs/gemma-2-9b-it-simpo.yaml).
68
+
69
+ #### Speeds, Sizes, Times
70
+
71
+ Fine-tuning the [google/gemma-2-9b-it](https://huggingface.co/google/gemma-2-9b-it) on [princeton-nlp/gemma2-ultrafeedback-armorm](https://huggingface.co/datasets/princeton-nlp/gemma2-ultrafeedback-armorm) takes around 150 mins to finish on 8xH100 GPUs.
72
+
73
+ ## Evaluation Results
74
+
75
+
76
+ | models | AE2 LC | AE2 WR | AE2 Length | AH | AH Length | GSM | GSM Length | MMLU | MMLU Length |
77
+ |-----------------------------------|:------:|:------:|:----------:|:----:|:---------:|:----:|:----------:|:----:|:-----------:|
78
+ | [google/gemma-2-9b-it](https://huggingface.co/google/gemma-2-9b-it) | 51.1 | 38.1 | 1571 | 40.8 | 545 | 87.4 | 395 | 72.7 | 515 |
79
+ | [princeton-nlp/gemma-2-9b-it-DPO](https://huggingface.co/princeton-nlp/gemma-2-9b-it-DPO) | 67.8 | 65.4 | 2016 | 58.9 | 717 | 88.5 | 392 | 72.2 | 624 |
80
+ | [princeton-nlp/gemma-2-9b-it-SimPO](https://huggingface.co/princeton-nlp/gemma-2-9b-it-SimPO) | 72.4 | 65.9 | 1833 | 59.1 | 693 | 88.0 | 341 | 72.2 | 441 |
81
+
82
+
83
+ ## Technical Specifications
84
+
85
+ ### Model Architecture and Objective
86
+
87
+ The model architecture is based on [google/gemma-2-9b-it](https://huggingface.co/google/gemma-2-9b-it). We use the DPO training objective.
88
+
89
+ #### Hardware
90
+
91
+ We used 8xH100 GPUs for model training.
92
+
93
+ #### Software
94
+
95
+ Training was done using the [alignment-handbook](https://github.com/huggingface/alignment-handbook) library.
96
+
97
+ ## Citation
98
+
99
+ gemma model:
100
+ ```
101
+ @article{gemma_2024,
102
+ title={Gemma},
103
+ url={https://www.kaggle.com/m/3301},
104
+ DOI={10.34740/KAGGLE/M/3301},
105
+ publisher={Kaggle},
106
+ author={Gemma Team},
107
+ year={2024}
108
+ }
109
+ ```
110
+
111
+ DPO paper:
112
+ ```
113
+ @article{rafailov2024direct,
114
+ title={Direct Preference Optimization: Your language model is secretly a reward model},
115
+ author={Rafailov, Rafael and Sharma, Archit and Mitchell, Eric and Manning, Christopher D and Ermon, Stefano and Finn, Chelsea},
116
+ journal={Advances in Neural Information Processing Systems},
117
+ volume={36},
118
+ year={2024}
119
+ }
120
+ ```
121
+
122
+ SimPO paper:
123
+ ```
124
+ @article{meng2024simpo,
125
+ title={{SimPO}: Simple preference optimization with a reference-free reward},
126
+ author={Meng, Yu and Xia, Mengzhou and Chen, Danqi},
127
+ journal={arXiv preprint arXiv:2405.14734},
128
+ year={2024}
129
+ }
130
+ ```
131
+
132
+ UltraFeedback paper:
133
+ ```
134
+ @article{cui2023ultrafeedback,
135
+ title={{UltraFeedback}: Boosting language models with high-quality feedback},
136
+ author={Cui, Ganqu and Yuan, Lifan and Ding, Ning and Yao, Guanming and Zhu, Wei and Ni, Yuan and Xie, Guotong and Liu, Zhiyuan and Sun, Maosong},
137
+ journal={arXiv preprint arXiv:2310.01377},
138
+ year={2023}
139
+ }
140
+ ```
141
+
142
+ ArmoRM paper:
143
+ ```
144
+ @article{wang2024interpretable,
145
+ title={Interpretable Preferences via Multi-Objective Reward Modeling and Mixture-of-Experts},
146
+ author={Wang, Haoxiang and Xiong, Wei and Xie, Tengyang and Zhao, Han and Zhang, Tong},
147
+ journal={arXiv preprint arXiv:2406.12845},
148
+ year={2024}
149
+ }
150
+ ```