RichardErkhov commited on
Commit
ea7f3d0
·
verified ·
1 Parent(s): 1859854

uploaded readme

Browse files
Files changed (1) hide show
  1. README.md +225 -0
README.md ADDED
@@ -0,0 +1,225 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Quantization made by Richard Erkhov.
2
+
3
+ [Github](https://github.com/RichardErkhov)
4
+
5
+ [Discord](https://discord.gg/pvy7H8DZMG)
6
+
7
+ [Request more models](https://github.com/RichardErkhov/quant_request)
8
+
9
+
10
+ prometheus-7b-v2.0 - GGUF
11
+ - Model creator: https://huggingface.co/prometheus-eval/
12
+ - Original model: https://huggingface.co/prometheus-eval/prometheus-7b-v2.0/
13
+
14
+
15
+ | Name | Quant method | Size |
16
+ | ---- | ---- | ---- |
17
+ | [prometheus-7b-v2.0.Q2_K.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q2_K.gguf) | Q2_K | 2.53GB |
18
+ | [prometheus-7b-v2.0.IQ3_XS.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.IQ3_XS.gguf) | IQ3_XS | 2.81GB |
19
+ | [prometheus-7b-v2.0.IQ3_S.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.IQ3_S.gguf) | IQ3_S | 2.96GB |
20
+ | [prometheus-7b-v2.0.Q3_K_S.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q3_K_S.gguf) | Q3_K_S | 2.95GB |
21
+ | [prometheus-7b-v2.0.IQ3_M.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.IQ3_M.gguf) | IQ3_M | 3.06GB |
22
+ | [prometheus-7b-v2.0.Q3_K.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q3_K.gguf) | Q3_K | 3.28GB |
23
+ | [prometheus-7b-v2.0.Q3_K_M.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q3_K_M.gguf) | Q3_K_M | 3.28GB |
24
+ | [prometheus-7b-v2.0.Q3_K_L.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q3_K_L.gguf) | Q3_K_L | 3.56GB |
25
+ | [prometheus-7b-v2.0.IQ4_XS.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.IQ4_XS.gguf) | IQ4_XS | 3.67GB |
26
+ | [prometheus-7b-v2.0.Q4_0.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q4_0.gguf) | Q4_0 | 3.83GB |
27
+ | [prometheus-7b-v2.0.IQ4_NL.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.IQ4_NL.gguf) | IQ4_NL | 3.87GB |
28
+ | [prometheus-7b-v2.0.Q4_K_S.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q4_K_S.gguf) | Q4_K_S | 3.86GB |
29
+ | [prometheus-7b-v2.0.Q4_K.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q4_K.gguf) | Q4_K | 4.07GB |
30
+ | [prometheus-7b-v2.0.Q4_K_M.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q4_K_M.gguf) | Q4_K_M | 4.07GB |
31
+ | [prometheus-7b-v2.0.Q4_1.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q4_1.gguf) | Q4_1 | 4.24GB |
32
+ | [prometheus-7b-v2.0.Q5_0.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q5_0.gguf) | Q5_0 | 4.65GB |
33
+ | [prometheus-7b-v2.0.Q5_K_S.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q5_K_S.gguf) | Q5_K_S | 4.65GB |
34
+ | [prometheus-7b-v2.0.Q5_K.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q5_K.gguf) | Q5_K | 4.78GB |
35
+ | [prometheus-7b-v2.0.Q5_K_M.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q5_K_M.gguf) | Q5_K_M | 4.78GB |
36
+ | [prometheus-7b-v2.0.Q5_1.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q5_1.gguf) | Q5_1 | 5.07GB |
37
+ | [prometheus-7b-v2.0.Q6_K.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q6_K.gguf) | Q6_K | 5.53GB |
38
+ | [prometheus-7b-v2.0.Q8_0.gguf](https://huggingface.co/RichardErkhov/prometheus-eval_-_prometheus-7b-v2.0-gguf/blob/main/prometheus-7b-v2.0.Q8_0.gguf) | Q8_0 | 7.17GB |
39
+
40
+
41
+
42
+
43
+ Original model description:
44
+ ---
45
+ tags:
46
+ - text2text-generation
47
+ datasets:
48
+ - prometheus-eval/Feedback-Collection
49
+ - prometheus-eval/Preference-Collection
50
+ license: apache-2.0
51
+ language:
52
+ - en
53
+ pipeline_tag: text2text-generation
54
+ library_name: transformers
55
+ metrics:
56
+ - pearsonr
57
+ - spearmanr
58
+ - kendall-tau
59
+ - accuracy
60
+ ---
61
+ ## Links for Reference
62
+
63
+ - **Homepage: In Progress**
64
+ - **Repository:https://github.com/prometheus-eval/prometheus-eval**
65
+ - **Paper:https://arxiv.org/abs/2405.01535**
66
+ - **Point of Contact:[email protected]**
67
+
68
+ # TL;DR
69
+ Prometheus 2 is an alternative of GPT-4 evaluation when doing fine-grained evaluation of an underlying LLM & a Reward model for Reinforcement Learning from Human Feedback (RLHF).
70
+ ![plot](./finegrained_eval.JPG)
71
+
72
+ Prometheus 2 is a language model using [Mistral-Instruct](https://huggingface.co/mistralai/Mistral-7B-Instruct-v0.2) as a base model.
73
+ It is fine-tuned on 100K feedback within the [Feedback Collection](https://huggingface.co/datasets/prometheus-eval/Feedback-Collection) and 200K feedback within the [Preference Collection](https://huggingface.co/datasets/prometheus-eval/Preference-Collection).
74
+ It is also made by weight merging to support both absolute grading (direct assessment) and relative grading (pairwise ranking).
75
+ The surprising thing is that we find weight merging also improves performance on each format.
76
+
77
+ # Model Details
78
+
79
+ ## Model Description
80
+
81
+ - **Model type:** Language model
82
+ - **Language(s) (NLP):** English
83
+ - **License:** Apache 2.0
84
+ - **Related Models:** [All Prometheus Checkpoints](https://huggingface.co/models?search=prometheus-eval/Prometheus)
85
+ - **Resources for more information:**
86
+ - [Research paper](https://arxiv.org/abs/2405.01535)
87
+ - [GitHub Repo](https://github.com/prometheus-eval/prometheus-eval)
88
+
89
+
90
+ Prometheus is trained with two different sizes (7B and 8x7B).
91
+ You could check the 8x7B sized LM on [this page](https://huggingface.co/prometheus-eval/prometheus-2-8x7b-v2.0).
92
+ Also, check out our dataset as well on [this page](https://huggingface.co/datasets/prometheus-eval/Feedback-Collection) and [this page](https://huggingface.co/datasets/prometheus-eval/Preference-Collection).
93
+
94
+ ## Prompt Format
95
+
96
+ We have made wrapper functions and classes to conveniently use Prometheus 2 at [our github repository](https://github.com/prometheus-eval/prometheus-eval).
97
+ We highly recommend you use it!
98
+
99
+ However, if you just want to use the model for your use case, please refer to the prompt format below.
100
+ Note that absolute grading and relative grading requires different prompt templates and system prompts.
101
+
102
+ ### Absolute Grading (Direct Assessment)
103
+ Prometheus requires 4 components in the input: An instruction, a response to evaluate, a score rubric, and a reference answer. You could refer to the prompt format below.
104
+ You should fill in the instruction, response, reference answer, criteria description, and score description for score in range of 1 to 5.
105
+
106
+ Fix the components with \{text\} inside.
107
+ ```
108
+ ###Task Description:
109
+ An instruction (might include an Input inside it), a response to evaluate, a reference answer that gets a score of 5, and a score rubric representing a evaluation criteria are given.
110
+ 1. Write a detailed feedback that assess the quality of the response strictly based on the given score rubric, not evaluating in general.
111
+ 2. After writing a feedback, write a score that is an integer between 1 and 5. You should refer to the score rubric.
112
+ 3. The output format should look as follows: \"Feedback: (write a feedback for criteria) [RESULT] (an integer number between 1 and 5)\"
113
+ 4. Please do not generate any other opening, closing, and explanations.
114
+
115
+ ###The instruction to evaluate:
116
+ {orig_instruction}
117
+
118
+ ###Response to evaluate:
119
+ {orig_response}
120
+
121
+ ###Reference Answer (Score 5):
122
+ {orig_reference_answer}
123
+
124
+ ###Score Rubrics:
125
+ [{orig_criteria}]
126
+ Score 1: {orig_score1_description}
127
+ Score 2: {orig_score2_description}
128
+ Score 3: {orig_score3_description}
129
+ Score 4: {orig_score4_description}
130
+ Score 5: {orig_score5_description}
131
+
132
+ ###Feedback:
133
+ ```
134
+
135
+ After this, you should apply the conversation template of Mistral (not applying it might lead to unexpected behaviors).
136
+ You can find the conversation class at this [link](https://github.com/lm-sys/FastChat/blob/main/fastchat/conversation.py).
137
+ ```
138
+ conv = get_conv_template("mistral")
139
+ conv.set_system_message("You are a fair judge assistant tasked with providing clear, objective feedback based on specific criteria, ensuring each assessment reflects the absolute standards set for performance.")
140
+ conv.append_message(conv.roles[0], dialogs['instruction'])
141
+ conv.append_message(conv.roles[1], None)
142
+ prompt = conv.get_prompt()
143
+
144
+ x = tokenizer(prompt,truncation=False)
145
+ ```
146
+
147
+ As a result, a feedback and score decision will be generated, divided by a separating phrase ```[RESULT]```
148
+
149
+ ### Relative Grading (Pairwise Ranking)
150
+ Prometheus requires 4 components in the input: An instruction, 2 responses to evaluate, a score rubric, and a reference answer. You could refer to the prompt format below.
151
+ You should fill in the instruction, 2 responses, reference answer, and criteria description.
152
+
153
+ Fix the components with \{text\} inside.
154
+ ```
155
+ ###Task Description:
156
+ An instruction (might include an Input inside it), a response to evaluate, and a score rubric representing a evaluation criteria are given.
157
+ 1. Write a detailed feedback that assess the quality of two responses strictly based on the given score rubric, not evaluating in general.
158
+ 2. After writing a feedback, choose a better response between Response A and Response B. You should refer to the score rubric.
159
+ 3. The output format should look as follows: "Feedback: (write a feedback for criteria) [RESULT] (A or B)"
160
+ 4. Please do not generate any other opening, closing, and explanations.
161
+
162
+ ###Instruction:
163
+ {orig_instruction}
164
+
165
+ ###Response A:
166
+ {orig_response_A}
167
+
168
+ ###Response B:
169
+ {orig_response_B}
170
+
171
+ ###Reference Answer:
172
+ {orig_reference_answer}
173
+
174
+ ###Score Rubric:
175
+ {orig_criteria}
176
+
177
+ ###Feedback:
178
+ ```
179
+
180
+ After this, you should apply the conversation template of Mistral (not applying it might lead to unexpected behaviors).
181
+ You can find the conversation class at this [link](https://github.com/lm-sys/FastChat/blob/main/fastchat/conversation.py).
182
+ ```
183
+ conv = get_conv_template("mistral")
184
+ conv.set_system_message("You are a fair judge assistant assigned to deliver insightful feedback that compares individual performances, highlighting how each stands relative to others within the same cohort.")
185
+ conv.append_message(conv.roles[0], dialogs['instruction'])
186
+ conv.append_message(conv.roles[1], None)
187
+ prompt = conv.get_prompt()
188
+
189
+ x = tokenizer(prompt,truncation=False)
190
+ ```
191
+
192
+ As a result, a feedback and score decision will be generated, divided by a separating phrase ```[RESULT]```
193
+
194
+ ## License
195
+ Feedback Collection, Preference Collection, and Prometheus 2 are subject to OpenAI's Terms of Use for the generated data. If you suspect any violations, please reach out to us.
196
+
197
+
198
+ # Citation
199
+
200
+
201
+ If you find the following model helpful, please consider citing our paper!
202
+
203
+ **BibTeX:**
204
+
205
+ ```bibtex
206
+ @misc{kim2023prometheus,
207
+ title={Prometheus: Inducing Fine-grained Evaluation Capability in Language Models},
208
+ author={Seungone Kim and Jamin Shin and Yejin Cho and Joel Jang and Shayne Longpre and Hwaran Lee and Sangdoo Yun and Seongjin Shin and Sungdong Kim and James Thorne and Minjoon Seo},
209
+ year={2023},
210
+ eprint={2310.08491},
211
+ archivePrefix={arXiv},
212
+ primaryClass={cs.CL}
213
+ }
214
+ ```
215
+ ```bibtex
216
+ @misc{kim2024prometheus,
217
+ title={Prometheus 2: An Open Source Language Model Specialized in Evaluating Other Language Models},
218
+ author={Seungone Kim and Juyoung Suk and Shayne Longpre and Bill Yuchen Lin and Jamin Shin and Sean Welleck and Graham Neubig and Moontae Lee and Kyungjae Lee and Minjoon Seo},
219
+ year={2024},
220
+ eprint={2405.01535},
221
+ archivePrefix={arXiv},
222
+ primaryClass={cs.CL}
223
+ }
224
+ ```
225
+