AdaptLLM commited on
Commit
c8ac95c
1 Parent(s): 7d1f7c1

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +61 -11
README.md CHANGED
@@ -1,28 +1,78 @@
1
- # Adapt Large Language Models to Domains
 
 
 
 
 
 
 
 
 
 
 
 
2
 
3
- This repo contains the model for our paper [Adapting Large Language Models via Reading Comprehension](https://huggingface.co/papers/2309.09530)
 
4
 
5
- We explore **continued pre-training on domain-specific corpora** for large language models. While this approach enriches LLMs with domain knowledge, it significantly hurts their prompting ability for question answering. Inspired by human learning via reading comprehension, we propose a simple method to **transform large-scale pre-training corpora into reading comprehension texts**, consistently improving prompting performance across tasks in **biomedicine, finance, and law domains**. Our 7B model competes with much larger domain-specific models like BloombergGPT-50B. Moreover, our domain-specific reading comprehension texts enhance model performance even on general benchmarks, indicating potential for developing a general LLM across more domains.
6
 
7
- ## GitHub repo:
8
- https://github.com/microsoft/LMOps
9
 
10
- ## Domain-specific LLMs:
11
- Our models of different domains are now available in Huggingface: [Biomedicine-LLM](https://huggingface.co/AdaptLLM/medicine-LLM), [Finance-LLM](https://huggingface.co/AdaptLLM/finance-LLM) and [Law-LLM](https://huggingface.co/AdaptLLM/law-LLM), the performances of our AdaptLLM compared to other domain-specific LLMs are:
 
 
 
 
 
12
 
13
  <p align='center'>
14
- <img src="./comparison.png" width="700">
15
  </p>
16
 
17
- ## Domain-specific Tasks:
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
18
  To easily reproduce our results, we have uploaded the filled-in zero/few-shot input instructions and output completions of each domain-specific task: [biomedicine-tasks](https://huggingface.co/datasets/AdaptLLM/medicine-tasks), [finance-tasks](https://huggingface.co/datasets/AdaptLLM/finance-tasks), and [law-tasks](https://huggingface.co/datasets/AdaptLLM/law-tasks).
19
 
 
20
 
21
- ## Citation:
 
22
  ```bibtex
23
  @article{adaptllm,
24
- author = {Daixuan Cheng and Shaohan Huang and Furu Wei},
25
  title = {Adapting Large Language Models via Reading Comprehension},
 
26
  journal = {CoRR},
27
  volume = {abs/2309.09530},
28
  year = {2023}
 
1
+ ---
2
+ language:
3
+ - en
4
+ datasets:
5
+ - Open-Orca/OpenOrca
6
+ - GAIR/lima
7
+ - WizardLM/WizardLM_evol_instruct_V2_196k
8
+ - EleutherAI/pile
9
+ metrics:
10
+ - accuracy
11
+ library_name: fairseq
12
+ pipeline_tag: text-generation
13
+ ---
14
 
15
+ # Adapt (Large) Language Models to Domains
16
+ This repo contains the domain-specific base model developed from LLaMA-1-7B, using the method in our paper [Adapting Large Language Models via Reading Comprehension](https://huggingface.co/papers/2309.09530).
17
 
18
+ We explore **continued pre-training on domain-specific corpora** for large language models. While this approach enriches LLMs with domain knowledge, it significantly hurts their prompting ability for question answering. Inspired by human learning via reading comprehension, we propose a simple method to **transform large-scale pre-training corpora into reading comprehension texts**, consistently improving prompting performance across tasks in biomedicine, finance, and law domains. **Our 7B model competes with much larger domain-specific models like BloombergGPT-50B**.
19
 
20
+ ### 🤗 We are currently working hard on developing models across different domains, scales and architectures! Please stay tuned! 🤗
 
21
 
22
+ **************************** **Updates** ****************************
23
+ * 12/8: Released our [chat models](https://huggingface.co/AdaptLLM/finance-chat) developed from LLaMA-2-Chat-7B.
24
+ * 9/18: Released our [paper](https://huggingface.co/papers/2309.09530), [code](https://github.com/microsoft/LMOps), [data](https://huggingface.co/datasets/AdaptLLM/finance-tasks), and [base models](https://huggingface.co/AdaptLLM/finance-LLM) developed from LLaMA-1-7B.
25
+
26
+
27
+ ## Domain-Specific LLaMA-1
28
+ In our paper, we develop three domain-specific models from LLaMA-1-7B, which are also available in Huggingface: [Biomedicine-LLM](https://huggingface.co/AdaptLLM/medicine-LLM), [Finance-LLM](https://huggingface.co/AdaptLLM/finance-LLM) and [Law-LLM](https://huggingface.co/AdaptLLM/law-LLM), the performances of our AdaptLLM compared to other domain-specific LLMs are:
29
 
30
  <p align='center'>
31
+ <img src="https://cdn-uploads.huggingface.co/production/uploads/650801ced5578ef7e20b33d4/6efPwitFgy-pLTzvccdcP.png" width="700">
32
  </p>
33
 
34
+ ## Domain-Specific LLaMA-2-Chat
35
+ Our method is also effective for aligned models! LLaMA-2-Chat requires a [specific data format](https://huggingface.co/blog/llama2#how-to-prompt-llama-2), and our **reading comprehension can perfectly fit the data format** by transforming the reading comprehension into a multi-turn conversation. We have also open-sourced chat models in different domains: [Biomedicine-Chat](https://huggingface.co/AdaptLLM/medicine-chat), [Finance-Chat](https://huggingface.co/AdaptLLM/finance-chat) and [Law-Chat](https://huggingface.co/AdaptLLM/law-chat)
36
+
37
+ For example, to chat with the finance model:
38
+ ```python
39
+ from transformers import AutoModelForCausalLM, AutoTokenizer
40
+
41
+ model = AutoModelForCausalLM.from_pretrained("AdaptLLM/finance-chat")
42
+ tokenizer = AutoTokenizer.from_pretrained("AdaptLLM/finance-chat", use_fast=False)
43
+
44
+ # Put your input here:
45
+ user_input = '''Use this fact to answer the question: Title of each class Trading Symbol(s) Name of each exchange on which registered
46
+ Common Stock, Par Value $.01 Per Share MMM New York Stock Exchange
47
+ MMM Chicago Stock Exchange, Inc.
48
+ 1.500% Notes due 2026 MMM26 New York Stock Exchange
49
+ 1.750% Notes due 2030 MMM30 New York Stock Exchange
50
+ 1.500% Notes due 2031 MMM31 New York Stock Exchange
51
+
52
+ Which debt securities are registered to trade on a national securities exchange under 3M's name as of Q2 of 2023?'''
53
+
54
+ # We use the prompt template of LLaMA-2-Chat demo
55
+ prompt = f"<s>[INST] <<SYS>>\nYou are a helpful, respectful and honest assistant. Always answer as helpfully as possible, while being safe. Your answers should not include any harmful, unethical, racist, sexist, toxic, dangerous, or illegal content. Please ensure that your responses are socially unbiased and positive in nature.\n\nIf a question does not make any sense, or is not factually coherent, explain why instead of answering something not correct. If you don't know the answer to a question, please don't share false information.\n<</SYS>>\n\n{user_input} [/INST]"
56
+
57
+ inputs = tokenizer(prompt, return_tensors="pt", add_special_tokens=False).input_ids.to(model.device)
58
+ outputs = model.generate(input_ids=inputs, max_length=4096)[0]
59
+
60
+ answer_start = int(inputs.shape[-1])
61
+ pred = tokenizer.decode(outputs[answer_start:], skip_special_tokens=True)
62
+
63
+ print(f'### User Input:\n{user_input}\n\n### Assistant Output:\n{pred}')
64
+ ```
65
+ ## Domain-Specific Tasks
66
  To easily reproduce our results, we have uploaded the filled-in zero/few-shot input instructions and output completions of each domain-specific task: [biomedicine-tasks](https://huggingface.co/datasets/AdaptLLM/medicine-tasks), [finance-tasks](https://huggingface.co/datasets/AdaptLLM/finance-tasks), and [law-tasks](https://huggingface.co/datasets/AdaptLLM/law-tasks).
67
 
68
+ **Note:** those filled-in instructions are specifically tailored for models before alignment and do NOT fit for the specific data format required for chat models.
69
 
70
+ ## Citation
71
+ If you find our work helpful, please cite us:
72
  ```bibtex
73
  @article{adaptllm,
 
74
  title = {Adapting Large Language Models via Reading Comprehension},
75
+ author = {Daixuan Cheng and Shaohan Huang and Furu Wei},
76
  journal = {CoRR},
77
  volume = {abs/2309.09530},
78
  year = {2023}