RichardErkhov commited on
Commit
0e31e78
1 Parent(s): 6f8ebbd

uploaded readme

Browse files
Files changed (1) hide show
  1. README.md +249 -0
README.md ADDED
@@ -0,0 +1,249 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
+ llama-3-meerkat-8b-v1.0 - GGUF
11
+ - Model creator: https://huggingface.co/dmis-lab/
12
+ - Original model: https://huggingface.co/dmis-lab/llama-3-meerkat-8b-v1.0/
13
+
14
+
15
+ | Name | Quant method | Size |
16
+ | ---- | ---- | ---- |
17
+ | [llama-3-meerkat-8b-v1.0.Q2_K.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q2_K.gguf) | Q2_K | 2.96GB |
18
+ | [llama-3-meerkat-8b-v1.0.IQ3_XS.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.IQ3_XS.gguf) | IQ3_XS | 3.28GB |
19
+ | [llama-3-meerkat-8b-v1.0.IQ3_S.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.IQ3_S.gguf) | IQ3_S | 3.43GB |
20
+ | [llama-3-meerkat-8b-v1.0.Q3_K_S.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q3_K_S.gguf) | Q3_K_S | 3.41GB |
21
+ | [llama-3-meerkat-8b-v1.0.IQ3_M.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.IQ3_M.gguf) | IQ3_M | 3.52GB |
22
+ | [llama-3-meerkat-8b-v1.0.Q3_K.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q3_K.gguf) | Q3_K | 3.74GB |
23
+ | [llama-3-meerkat-8b-v1.0.Q3_K_M.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q3_K_M.gguf) | Q3_K_M | 3.74GB |
24
+ | [llama-3-meerkat-8b-v1.0.Q3_K_L.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q3_K_L.gguf) | Q3_K_L | 4.03GB |
25
+ | [llama-3-meerkat-8b-v1.0.IQ4_XS.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.IQ4_XS.gguf) | IQ4_XS | 4.18GB |
26
+ | [llama-3-meerkat-8b-v1.0.Q4_0.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q4_0.gguf) | Q4_0 | 4.34GB |
27
+ | [llama-3-meerkat-8b-v1.0.IQ4_NL.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.IQ4_NL.gguf) | IQ4_NL | 4.38GB |
28
+ | [llama-3-meerkat-8b-v1.0.Q4_K_S.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q4_K_S.gguf) | Q4_K_S | 4.37GB |
29
+ | [llama-3-meerkat-8b-v1.0.Q4_K.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q4_K.gguf) | Q4_K | 4.58GB |
30
+ | [llama-3-meerkat-8b-v1.0.Q4_K_M.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q4_K_M.gguf) | Q4_K_M | 4.58GB |
31
+ | [llama-3-meerkat-8b-v1.0.Q4_1.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q4_1.gguf) | Q4_1 | 4.78GB |
32
+ | [llama-3-meerkat-8b-v1.0.Q5_0.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q5_0.gguf) | Q5_0 | 5.21GB |
33
+ | [llama-3-meerkat-8b-v1.0.Q5_K_S.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q5_K_S.gguf) | Q5_K_S | 5.21GB |
34
+ | [llama-3-meerkat-8b-v1.0.Q5_K.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q5_K.gguf) | Q5_K | 5.34GB |
35
+ | [llama-3-meerkat-8b-v1.0.Q5_K_M.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q5_K_M.gguf) | Q5_K_M | 5.34GB |
36
+ | [llama-3-meerkat-8b-v1.0.Q5_1.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q5_1.gguf) | Q5_1 | 5.65GB |
37
+ | [llama-3-meerkat-8b-v1.0.Q6_K.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q6_K.gguf) | Q6_K | 6.14GB |
38
+ | [llama-3-meerkat-8b-v1.0.Q8_0.gguf](https://huggingface.co/RichardErkhov/dmis-lab_-_llama-3-meerkat-8b-v1.0-gguf/blob/main/llama-3-meerkat-8b-v1.0.Q8_0.gguf) | Q8_0 | 7.95GB |
39
+
40
+
41
+
42
+
43
+ Original model description:
44
+ ---
45
+ license: cc-by-nc-4.0
46
+ pipeline_tag: text-generation
47
+ tags:
48
+ - medical
49
+ - small LM
50
+ - instruction-tuned
51
+ - usmle
52
+ - synthetic data
53
+ ---
54
+
55
+
56
+ # Meerkat-8B (Version 1.0)
57
+
58
+ 🚀 Meerkat-8B is a new instruction-tuned medical AI system of the Meerkat model family.
59
+ The model was based on the Meta's Llama-3-8B-Instruct model and fine-tuned using our new synthetic dataset consisting of high-quality chain-of-thought reasoning paths sourced from 18 medical textbooks, along with diverse instruction-following datasets.
60
+ This equips the model with high-level medical reasoning capabilities required for solving complex medical problems.
61
+ For further insights into our model, please refer to our paper!
62
+
63
+ 📄 **Paper**: [Small Language Models Learn Enhanced Reasoning Skills from Medical Textbooks](https://arxiv.org/abs/2404.00376)
64
+
65
+
66
+ ## Quick Start
67
+
68
+ ```python
69
+ from transformers import AutoTokenizer, AutoModelForCausalLM
70
+ import torch
71
+
72
+ model_id = "dmis-lab/llama-3-meerkat-8b-v1.0"
73
+
74
+ tokenizer = AutoTokenizer.from_pretrained(model_id)
75
+ model = AutoModelForCausalLM.from_pretrained(
76
+ model_id,
77
+ torch_dtype=torch.bfloat16, # You can choose to use this when there's not enough GPU memory available.
78
+ device_map="auto",
79
+ )
80
+
81
+ # Multi-turn dialogue example
82
+ messages =[
83
+ {"role": "system", "content": "You are a helpful doctor or healthcare professional. Guide the conversation to provide useful, complete, and scientifically-grounded answers to user questions. You have the option to compose a concise, single-turn conversation if the user's input is comprehensive to provide accurate answers. However, if essential details are missing, you should engage in a multi-turn dialogue, asking follow-up questions to gather a thorough medical history and records.\n\n"},
84
+ {"role": "user", "content": "Hello, doctor. I'm really concerned about my 10-year-old son. We recently discovered a painless mass in his left testicle, so we brought him to the pediatrician."},
85
+ {"role": "assistant", "content": "I understand your concern. Let's gather some more information. Has your son experienced any other symptoms along with the mass?"},
86
+ {"role": "user", "content": "Other than the mass, my son hasn't shown any symptoms. He's been his usual self, playing and eating normally."}
87
+ ]
88
+
89
+ input_ids = tokenizer.apply_chat_template(
90
+ messages,
91
+ add_generation_prompt=True,
92
+ return_tensors="pt"
93
+ ).to(model.device)
94
+
95
+ terminators = [
96
+ tokenizer.eos_token_id,
97
+ tokenizer.convert_tokens_to_ids("<|eot_id|>")
98
+ ]
99
+
100
+ outputs = model.generate(
101
+ input_ids,
102
+ max_new_tokens=1000,
103
+ eos_token_id=terminators,
104
+ do_sample=True,
105
+ temperature=0.7,
106
+ )
107
+ response = outputs[0][input_ids.shape[-1]:]
108
+ print(tokenizer.decode(response, skip_special_tokens=True))
109
+ ```
110
+
111
+ ## Prompt Details
112
+
113
+ To reproduce the results reported in our paper, it is advisable to utilize the identical system messages used during model training. Please refer to the guidelines detailed below.
114
+
115
+ ### USMLE
116
+
117
+ When solving USMLE-style questions such as [MedQA](https://arxiv.org/abs/2009.13081) and [MedBullets](https://arxiv.org/abs/2402.18060), use the following system message:
118
+ ```
119
+ messages = [
120
+ {"role": "system", "content": "The following is a multiple-choice question about medical knowledge. Solve this in a step-by-step fashion, starting by summarizing the available information. Output a single option from the given options as the final answer. You are strongly required to follow the specified output format; conclude your response with the phrase \"the answer is ([option_id]) [answer_string]\".\n\n"},
121
+ {"role": "user", "content": "Two weeks after undergoing an emergency cardiac catherization with stenting for unstable angina pectoris, a 61-year-old man has decreased urinary output and malaise. He has type 2 diabetes mellitus and osteoarthritis of the hips. Prior to admission, his medications were insulin and naproxen. He was also started on aspirin, clopidogrel, and metoprolol after the coronary intervention. His temperature is 38\u00b0C (100.4\u00b0F), pulse is 93/min, and blood pressure is 125/85 mm Hg. Examination shows mottled, reticulated purplish discoloration of the feet. Laboratory studies show:\nHemoglobin count 14 g/dL\nLeukocyte count 16,400/mm3\nSegmented neutrophils 56%\nEosinophils 11%\nLymphocytes 31%\nMonocytes 2%\nPlatelet count 260,000/mm3\nErythrocyte sedimentation rate 68 mm/h\nSerum\nUrea nitrogen 25 mg/dL\nCreatinine 4.2 mg/dL\nRenal biopsy shows intravascular spindle-shaped vacuoles. Which of the following is the most likely cause of this patient's symptoms?\" (A) Renal papillary necrosis (B) Cholesterol embolization (C) Eosinophilic granulomatosis with polyangiitis (D) Polyarteritis nodosa"},
122
+ ]
123
+ ```
124
+ The model generates reasoning paths to solve the problem and then sequentially provides the predicted answers.
125
+ Since the model ends its response with "the answer is," it is straightforward to extract the predicted answer for comparison with the actual answer.
126
+
127
+ ### Multiple-choice Exams
128
+
129
+ For other types of multiple-choice exams such as [MedMCQA](https://arxiv.org/abs/2203.14371) or [MMLU](https://arxiv.org/abs/2009.03300), use the following simple system message:
130
+ ```
131
+ messages = [
132
+ {"role": "system", "content": "Answer the multiple-choice question about medical knowledge.\n\n"},
133
+ {"role": "user", "content": "In a Robertsonian translocation fusion occurs at the: (A) telomeres. (B) centromeres. (C) histones. (D) ends of the long arms."},
134
+ ]
135
+ ```
136
+
137
+ ### Other Use Cases
138
+ Our model was trained using the [AlpaCare](https://github.com/xzhang97666/alpacare) instruction dataset comprising 52K examples, to enhance its generalization capabilities across diverse user prompts.
139
+ Feel free to design and test your prompts and to share your thoughts with us, whether the model exceeds expectations or falls short!
140
+
141
+
142
+ ## Reproducing MedQA Performance with vLLM
143
+
144
+ Here is an example code for fast model evaluation in MedQA using vLLM. To adapt this code for other datasets like MedMCQA or MMLU, simply modify the instructions and update the dataset paths as needed.
145
+ ```python
146
+ import re
147
+ from datasets import load_dataset
148
+ from vllm import LLM, SamplingParams
149
+ USMLE_INSTRUCTION = (
150
+ "The following is a multiple-choice question about medical knowledge. Solve this in"
151
+ " a step-by-step fashion, starting by summarizing the available information. Output"
152
+ " a single option from the given options as the final answer. You are strongly"
153
+ " required to follow the specified output format; conclude your response with the"
154
+ ' phrase "the answer is ([option_id]) [answer_string]".\n\n'
155
+ )
156
+ llm = LLM(
157
+ model="dmis-lab/llama-3-meerkat-8b-v1.0",
158
+ dtype="bfloat16",
159
+ gpu_memory_utilization=0.9,
160
+ max_model_len=2048,
161
+ trust_remote_code=True,
162
+ tensor_parallel_size=1
163
+ )
164
+
165
+ tokenizer = llm.get_tokenizer()
166
+
167
+ inputs, labels = [], []
168
+ for sample in load_dataset(
169
+ "GBaker/MedQA-USMLE-4-options", split="test", trust_remote_code=True
170
+ ):
171
+ options = sorted(sample["options"].items())
172
+ options = " ".join(map(lambda x: f"({x[0]}) {x[1]}", options))
173
+ content = tokenizer.apply_chat_template(
174
+ [{"role": "system", "content": USMLE_INSTRUCTION}, {"role": "user", "content": sample["question"] + " " + options}],
175
+ add_generation_prompt=True,
176
+ tokenize=False,
177
+ )
178
+ inputs.append(content)
179
+ labels.append(sample["answer_idx"])
180
+
181
+ generated = llm.generate(
182
+ inputs,
183
+ SamplingParams(
184
+ temperature=0.0,
185
+ stop_token_ids=[tokenizer.vocab["<|eot_id|>"]],
186
+ max_tokens=1024,
187
+ ),
188
+ )
189
+ def extract_answer(text: str, options: str = "ABCD") -> str:
190
+ return (re.findall(rf"he answer is \(([{options}])\)", text) or [options[0]])[-1]
191
+
192
+ correctness = []
193
+
194
+ for g, l in zip(generated, labels):
195
+ correctness.append(extract_answer(g.outputs[0].text) == l)
196
+
197
+ print(sum(correctness) / len(correctness))
198
+ ```
199
+
200
+
201
+ ## Evaluation
202
+
203
+ We tested models on seven medical benchmarks: [MedQA](https://arxiv.org/abs/2009.13081), [USMLE sample test](https://www.usmle.org/prepare-your-exam), [Medbullets-4](https://arxiv.org/abs/2402.18060), [Medbullets-5](https://arxiv.org/abs/2402.18060) , [MedMCQA](https://arxiv.org/abs/2203.14371), [MMLU-Medical](https://arxiv.org/abs/2009.03300), and [JAMA Clinical Challenge](https://arxiv.org/abs/2402.18060).
204
+
205
+ | **Model** | **Average** | **MedQA** | **USMLE** | **Medbullets-4** | **Medbullets-5** | **MedMCQA** | **MMLU-Medical** |
206
+ |:--------------------------------|:-----------:|:---------:|:---------:|:----------------:|:----------------:|:-----------:|:----------------:|
207
+ | GPT-4 | 76.6 | 81.4 | 86.6 | 68.8 | 63.3 | 72.4 | 87.1 |
208
+ | GPT-3.5 | 54.8 | 53.6 | 58.5 | 51.0 | 47.4 | 51.0 | 67.3 |
209
+ | MediTron-70B (Ensemble, 5 runs) | - | 70.2 | - | - | - | 66.0 | 78.0 |
210
+ |*Open-source (7B)*|
211
+ | MediTron-7B | 51.0 | 50.2 | 44.6 | 51.1 | 45.5 | 57.9 | 56.7 |
212
+ | BioMistral-7B | 55.4 | 54.3 | 51.4 | 52.3 | 48.7 | 61.1 | 64.6 |
213
+ | Meerkat-7B | 62.6 | 70.6 | 70.3 | 58.7 | 52.9 | 60.6 | 70.5 |
214
+ | Meerkat-8B (**New**) | **67.3** | **74.0** | **74.2** | **62.3** | **55.5** | **62.7** | **75.2** |
215
+
216
+ Please note that the scores in MMLU-Medical were calculated based on the average accuracies across six medical-related subjects in the original MMLU benchmark, and each result for a single subject is presented below.
217
+
218
+ | **Model** | **Average** | **Cliniq Knowledge** | **Medical Genetics** | **Anatomy** | **Professional Medicine** | **College Biology** | **College Medicine** |
219
+ |:--------------------------------|:-----------:|:--------------------:|:--------------------:|:-----------:|:-------------------------:|:-------------------:|:--------------------:|
220
+ | GPT-4 | 87.1 | 86.4 | 92.0 | 80.0 | 93.8 | 93.8 | 76.3 |
221
+ | GPT-3.5 | 67.3 | 68.7 | 68.0 | 60.7 | 69.9 | 72.9 | 63.6 |
222
+ | MediTron-70B (Ensemble, 5 runs) | 78.0 | 75.5 | 85.9 | 69.4 | 82.3 | 86.7 | 68.0 |
223
+ |*Open-source (7B)*|
224
+ | MediTron-7B | 56.7 | 57.7 | 63.8 | 56.9 | 56.0 | 57.1 | 48.9 |
225
+ | BioMistral-7B | 64.6 | 59.9 | 64.0 | 56.5 | 60.4 | 59.0 | 54.7 |
226
+ | Meerkat-7B | 70.5 | 71.6 | 74.8 | 63.2 | **77.3** | 70.8 | 65.2 |
227
+ | Meerkat-8B (**New**) | **75.2** | **74.3** | **76.7** | **74.8** | 75.3 | **76.1** | **74.3** |
228
+
229
+
230
+ ## Reference
231
+
232
+ Please see the information below to cite our paper.
233
+ ```bibtex
234
+ @article{kim2024small,
235
+ title={Small language models learn enhanced reasoning skills from medical textbooks},
236
+ author={Kim, Hyunjae and Hwang, Hyeon and Lee, Jiwoo and Park, Sihyeon and Kim, Dain and Lee, Taewhoo and Yoon, Chanwoong and Sohn, Jiwoong and Choi, Donghee and Kang, Jaewoo},
237
+ journal={arXiv preprint arXiv:2404.00376},
238
+ year={2024}
239
+ }
240
+ ```
241
+
242
+ ## Acknowledgement
243
+
244
+ Research supported with Cloud TPUs from Google’s TPU Research Cloud (TRC).
245
+
246
+ ## Contact
247
+
248
+ Feel free to email `[email protected]` if you have any questions.
249
+