proteinglm commited on
Commit
78d71b9
·
verified ·
1 Parent(s): 4bb5efa

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +65 -3
README.md CHANGED
@@ -1,3 +1,65 @@
1
- ---
2
- license: cc-by-nc-4.0
3
- ---
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: cc-by-nc-4.0
3
+ tags:
4
+ - biology
5
+ ---
6
+
7
+ # ProteinGLM-1B-CLM
8
+
9
+ ## Model Introduction
10
+
11
+ **ProteinGLM-1B-CLM** is the open-source version of the latest generative protein language models designed to generate faithful and diverse protein sequences. The ProteinGLM family models are developed by Tsinghua University. Along with this, we have released the int4 quantization ProteinGLM weights and other small models, which include: 1B, 3B, and 10B models trained with masked language modeling for protein understanding, and 1B, 3B, and 7B causal language models aimed at protein design.
12
+
13
+ ### Out-of-Distribution Perplexity Evaluation
14
+
15
+ We evaluated the ProteinGLM-CLM (PGLM) and ProteinGLM-INT4(100B) models on two OOD test sets, one with sequence identity lower than 0.9 with the training set (<0.9 ID) and the other with sequence identity lower than 0.5 with the training set (<0.5 ID). Each OOD dataset comprises approximately 10,000 protein sequences. The perplexity results, compared against ProGen2-xlarge (6.4B), are as follows (lower is better):
16
+
17
+ | Model | ProGen2-xlarge (6.4B) | PGLM (1B) | PGLM (3B) | PGLM (7B) | PGLM-INT4 (100B) |
18
+ |:--------------------|:----------:|:----------:|:----------:|:--------------------:|:--------------------:|
19
+ | < 0.9 ID | 9.7 | 9.8 | 9.3 | 8.9 | **8.7** |
20
+ | < 0.5 ID | 14.3 | 14.0 | 13.7 | 13.5 | **13.3** |
21
+
22
+ ## How to use
23
+ ```python
24
+ from transformers import AutoModelForCausalLM, AutoTokenizer, AutoConfig
25
+ import torch
26
+
27
+ tokenizer = AutoTokenizer.from_pretrained("proteinglm/proteinglm-1b-clm", trust_remote_code=True, use_fast=True)
28
+ model = AutoModelForCausalLM.from_pretrained("proteinglm/proteinglm-1b-clm", trust_remote_code=True, torch_dtype=torch.bfloat16)
29
+ if torch.cuda.is_available():
30
+ model = model.cuda()
31
+ model.eval()
32
+
33
+ gen_kwargs = {'max_length': 256, 'top_p': 0.8, 'temperature':0.9, "num_beams": 1}
34
+ prompt=['', 'MLFVVL', 'LDL', 'VTQA']
35
+
36
+ for idx, each in enumerate(prompt):
37
+ print(f"Begin generating idx: {idx} with prompt {each}")
38
+ output = model.chat(tokenizer, each, **gen_kwargs)
39
+ print(f"\nEnd generation with length: {len(output.split())} - seqs: {output}\n")
40
+ ```
41
+
42
+ ## LICENSE
43
+
44
+ The model in this repository is open source under the [Creative Commons Attribution-NonCommercial 4.0 International License](./LICENSE).
45
+
46
+ ## Citations
47
+
48
+ If you find our work useful, please consider citing the following paper:
49
+ ```
50
+ @article{chen2024xtrimopglm,
51
+ title={xTrimoPGLM: unified 100B-scale pre-trained transformer for deciphering the language of protein},
52
+ author={Chen, Bo and Cheng, Xingyi and Li, Pan and Geng, Yangli-ao and Gong, Jing and Li, Shen and Bei, Zhilei and Tan, Xu and Wang, Boyan and Zeng, Xin and others},
53
+ journal={arXiv preprint arXiv:2401.06199},
54
+ year={2024}
55
+ }
56
+
57
+ @article{cheng2024training,
58
+ title={Training Compute-Optimal Protein Language Models},
59
+ author={Cheng, Xingyi and Chen, Bo and Li, Pan and Gong, Jing and Tang, Jie and Song, Le},
60
+ journal={bioRxiv},
61
+ pages={2024--06},
62
+ year={2024},
63
+ publisher={Cold Spring Harbor Laboratory}
64
+ }
65
+ ```