Git Product home page Git Product logo

yulan-chat's Introduction

YuLan-Chat: An Open-Source Bilingual Chatbot

license license

YuLan-Chat models are chat-based large language models, which are developed by the researchers in GSAI, Renmin University of China (YuLan, which represents Yulan Magnolia, is the campus flower of Renmin University of China). The newest version is developed by pretraining from scratch, and supervised fine-tuning via curriculum learning with high-quality English and Chinese instructions and human preference data. The model has the following technical characteristics:

  • Owing to large-scale pre-training on high-quality Chinese-English bilingual data, the language ability of the model has been improved.
  • Owing to the curriculum learning strategy for human alignment, the helpfulness, honesty, and harmlessness of our model have been enhanced.
  • To well support Chinese longer inputs and outputs, we expand the vocabulary with Chinese words and the maximum input length. It can support 8k context now.

YuLan-Chat系列模型是**人民大学高瓴人工智能学院师生共同开发的支持聊天的大语言模型(名字"玉兰"取自**人民大学校花)。最新版本从头完成了整个预训练过程,并采用课程学习技术基于中英文双语数据进行有监督微调,包括高质量指令和人类偏好数据。该版模型具有如下技术特点:

  • 由于在大规模中英双语数据上进行了继续预训练,模型的语言能力得到提高;
  • 由于采用了课程学习方法进行人类对齐训练,模型在真实场景下的有用性、诚实性与无害性得到了增强;
  • 为了更好的支持中文和更长的输入输出,模型的词表及长度得到了扩充,目前可支持8k上下文。

News

  • [Apr. 12, 2024] We release YuLan-Chat-12B-v3, a chat-based LLM trained from scratch. It has been pre-trained on over 1.6TB English and Chinese corpus, and then supervised fine-tuned via curriculum learning with high-quality English and Chinese instructions and human preference data.
  • [Aug. 18, 2023] Our YuLan-Chat-2-13B achieves the 5th position of OpenCompass benchmark!
  • [Aug. 02, 2023] We release YuLan-LLaMA-2-13B and YuLan-Chat-2-13B. Both models have been continually pre-trained on English and Chinese corpus based on LLaMA-2, and YuLan-Chat-2-13B is the chat-based LLM based on YuLan-LLaMA-2-13B, with high-quality English and Chinese instructions.
  • [Aug. 02, 2023] We release YuLan-Chat-1-65B-v2, a chat-based LLM based on LLaMA. It has been continually pre-trained on English and Chinese corpus, and then instruction-tuned with high-quality English and Chinese instructions.
  • [Jun. 08, 2023] We release YuLan-Chat-1-13B-v1 and YuLan-Chat-1-65B-v1, and the corresponding INT-8 quantization scripts.
  • [2024年4月12日] 我们发布了YuLan-Chat-12B-v3模型,其通过完全从头开始训练得到,其通过在超过1.6TB的中英文数据上进行了大规模预训练, 然后基于高质量双语指令和人类偏好数据,使用课程学习方法进行有监督微调。
  • [2023年8月2日] 我们发布了YuLan-LLaMA-2-13BYuLan-Chat-2-13B两个模型,其都在LLaMA-2的基础上进行了双语继续预训练,YuLan-Chat-2-13B在YuLan-LLaMA-2-13B基础上进行了双语高质量对话指令微调。
  • [2023年8月2日] 我们发布了YuLan-Chat-1-65B-v2模型,其在LLaMA-65B的基础上进行了双语继续预训练, 然后用高质量双语指令进行了微调。
  • [2023年6月8日] 我们发布了YuLan-Chat-1-13B-v1YuLan-Chat-1-65B-v1两个模型,以及对应的int8量化脚本。

Model Zoo

Due to the license limitation, for models based on LLaMA, we only provide the weight difference with the original checkpoints; for models based on LLaMA-2, they can be used directly. Please check the Usage section for more details.

Limitations: Despite our efforts to reduce potential security issues during the model's usage and encourage the generation of text that aligns with ethical and legal requirements, the language model is based on probabilistic generation, which means it may still produce unexpected outputs. For instance, the generated responses may contain biases, discrimination, or other harmful content. Please do not propagate such content. We do not assume any responsibility for any consequences resulting from the dissemination of harmful information.

由于许可证的限制,基于LLaMA的模型我们仅提供与官方模型的差值,基于LLaMA-2的模型可直接使用,具体请参见使用方法章节。

局限性:尽管我们尝试减少模型在使用中可能出现的安全性问题,并鼓励模型生成符合道德和法律要求的文本,但由于语言模型基于概率生成的范式,模型仍然可能会产生意外的输出。 例如,生成的响应可能包含偏见、歧视或其他有害内容。 请不要传播此类内容。 我们对因传播有害信息而造成的任何后果不承担任何责任。

Model Backbone Extended Vocab Extended Length Continue PT SFT Released Date
YuLan-Chat-12B-v3 YuLan-LLM-12B ✅ 51,190 ✅ 8,192 2024.4.12
YuLan-Chat-2-13B LLaMA2-13B ✅ 51,190 ✅ 8,192 2023.8.2
YuLan-LLaMA-2-13B LLaMA2-13B ✅ 51,190 ✅ 8,192 2023.8.2
YuLan-Chat-1-65B-v2 LLaMA-65B ✅ 51,190 ❌ 2,048 2023.8.2
YuLan-Chat-1-13B-v1 LLaMA-13B ❌ 32,000 ❌ 2,048 2023.6.8
YuLan-Chat-1-65B-v1 LLaMA-65B ❌ 32,000 ❌ 2,048 2023.6.8

Evaluation

We evaluate our YuLan-Chat model on several Chinese and English benchmarks. The evaluation results are shown as follows.

我们在中英文的一些基准测试上对YuLan-Chat进行了评价,其结果如下。

MMLU

MMLU (Massive Multitask Language Understanding) is a benchmark designed to measure knowledge acquired during pretraining by evaluating models exclusively in zero-shot and few-shot settings.

MMLU是一个评估模型知识量的常用的英文基准测试集。

Model STEM Social Science Humanities Others Avg.
YuLan-Chat-1-13B-v1 39.6 57.8 42.6 57.6 49.4
YuLan-Chat-1-65B-v1 49.2 71.7 57.7 66.7 61.3
YuLan-Chat-1-65B-v2 46.3 67.9 56.9 63.9 58.7
LLaMA-2-13B 44.6 64.2 53.9 62.2 56.2
FlagAlpha/Llama2-Chinese-13b-Chat 44.4 63.2 51.6 60.6 55.0
Linly-AI/Chinese-LLaMA-2-13B-hf 43.6 62.7 49.8 61.6 54.4
YuLan-LLaMA-2-13B 42.9 61.5 50.4 58.6 53.4
YuLan-Chat-2-13B 45.3 66.7 53.8 62.8 57.2

C-Eval

C-Eval is a comprehensive Chinese evaluation suite for foundation models.

C-Eval是一个针对基石模型综合能力的中文基准测试集。

Model STEM Social Science Humanities Others Avg. Avg. (Hard)
YuLan-Chat-1-13B-v1 30.2 37.4 31.9 30.7 32.0 25.7
YuLan-Chat-1-65B-v1 37.7 46.1 36.8 38.0 39.2 31.1
YuLan-Chat-1-65B-v2 39.9 55.9 47.7 43.7 45.4 31.4
LLaMA-2-13B 36.9 43.2 37.6 36.6 38.2 32.0
FlagAlpha/Llama2-Chinese-13b-Chat 36.8 44.5 36.3 36.5 38.1 30.9
Linly-AI/Chinese-LLaMA-2-13B-hf 33.7 44.8 36.6 36.5 37.0 27.7
YuLan-LLaMA-2-13B 35.3 46.4 41.9 37.6 39.3 28.6
YuLan-Chat-2-13B 38.9 49.7 45.0 40.8 42.6 32.2

AGI-Eval-Gaokao

AGI-Eval is a human-centric benchmark specifically designed to evaluate the general abilities of foundation models in tasks pertinent to human cognition and problem-solving. We use the sub-branch Chinese-Gaokao for evaluation.

AGI-Eval 是一个以人为中心的基准,专门设计用于评估基础模型在与人类认知和解决问题相关的任务中的一般能力。我们使用其中的"高考"分支进行评测。

Model Avg. Chinese English Geography History Biology Chemistry Physics Math-QA Math-Cloze
YuLan-Chat-1-13B-v1 29.2 32.1 63.1 34.7 25.1 26.2 29.0 25.5 26.5 0.9
YuLan-Chat-1-65B-v1 34.6 24.8 82.0 44.2 44.3 31.4 30.9 26.0 27.1 0.9
YuLan-Chat-1-65B-v2 37.9 31.4 80.4 50.8 56.6 33.3 29.0 32.0 24.4 0.8
LLaMA-2-13B 32.7 27.2 72.2 36.2 43.0 26.2 32.4 30.0 26.2 0.9
FlagAlpha/Llama2-Chinese-13b-Chat 31.6 26.4 70.6 35.2 38.7 28.1 28.0 29.5 25.6 2.5
Linly-AI/Chinese-LLaMA-2-13B-hf 31.1 22.8 74.8 42.2 37.9 24.3 28.0 23.0 26.5 0.0
YuLan-LLaMA-2-13B 34.2 25.2 70.3 43.2 48.5 30.0 29.5 31.0 28.5 1.7
YuLan-Chat-2-13B 39.5 37.0 85.3 46.7 51.9 43.8 38.2 29.0 23.1 0.9

Usage

Environment Setting

conda create -n yulan python=3.10 -y
conda activate yulan

We suggest to install the pytorch and bitsandbytes according to their official guidance for better adapting to your environment, and we provide our applied versions as reference:

我们建议根据官方手册安装pytorch和bitsandbytes,此处提供我们使用的版本作为参考。

torch==1.13
bitsandbytes==0.39.0

Then, you can install other packages by the following instruction:

然后,安装其他所需的包。

pip install -r requirements.txt

Model Weights Recovering

  1. For YuLan-Chat-1-13B-v1, YuLan-Chat-1-65B-v1, and YuLan-Chat-1-65B-v2, as they are based on LLaMA, you should download LLaMA's original weights, and then add our released delta parameters into the original parameters to compose the final model parameters.

对于基于LLaMA的模型,请先下载LLaMA官方模型,然后将我们发布的参数差值合并到原始模型参数中以获得最终的参数。

python3 apply_delta.py \
    --base-model-path ./llama-13b/ \
    --tuned-model-path ./yulan-13b/ \
    --delta-path ./yulan-13b-delta
  1. For YuLan-LLaMA-2-13B and YuLan-Chat-2-13B, you can just download our released checkpoints and load their parameters via Huggingface Transformers.

对于基于LLaMA-2的模型,可以直接下载我们发布的模型权重,并使用Huggingface Transformers进行使用。

Import from Huggingface Transformers

As our model is trained based on LLaMA, it can be loaded in the same way as original LLaMA.

由于我们的模型是基于LLaMA开发的,可以使用与LLaMA相同的方法加载。

>>> from transformers import LlamaTokenizer, LlamaForCausalLM
>>> tokenizer = LlamaTokenizer.from_pretrained("yulan-team/YuLan-Chat-2-13b")
>>> model = LlamaForCausalLM.from_pretrained("yulan-team/YuLan-Chat-2-13b").cuda()
>>> model = model.eval()
>>> input_text = "hello"
>>> prompt = "The following is a conversation between a human and an AI assistant namely YuLan, developed by GSAI, Renmin University of China. The AI assistant gives helpful, detailed, and polite answers to the user's questions.\n[|Human|]:{}\n[|AI|]:".format(input_text)
>>> inputs = tokenizer(prompt, return_tensors='pt', padding="longest", max_length=8192, truncation=True, return_attention_mask=True, add_special_tokens=True)
>>> kwargs = {'temperature': 0.8, 'top_p': 0.95, "top_k": 50, "repetition_penalty": 1.1, "no_repeat_ngram_size": 64, "max_length": 8192, "pad_token_id": tokenizer.bos_token_id, "eos_token_id": tokenizer.eos_token_id}
>>> outputs = model.generate(inputs['input_ids'].to(model.device), attention_mask=inputs['attention_mask'].to(model.device), do_sample=True, **kwargs)
>>> print(tokenizer.batch_decode(outputs, skip_special_tokens=True)[len(prompt):])
Hello! How can I assist you today?

Inference in Command Line

We provide the code for the inference of YuLan-Chat in command line.

我们提供命令行预测脚本。

python inference.py --model_path ~/pretrain-checkpoint/yulan-13b/

We also provide a quantization way for efficiently deploying YuLan-Chat. After quantization, YuLan-Chat can be loaded into a single GPU.

我们也提供了一种量化的方法以便于更轻量化地部署YuLan-Chat。经过量化后,模型可以被加载进单张GPU中。

YuLan-Chat (INT-8) GPU Consumption
13B RTX3090-24G
65B A100-80G
python inference.py --model_path ~/pretrain-checkpoint/yulan-13b/ --load_in_8bit

License

YuLan-Chat uses MIT License. All data and code in this project can only be used for academic purposes.

本项目使用MIT许可,所有的数据和代码仅供学术研究使用。

Contributors

Pre-training Fine-tuning
Yutao Zhu (Lead), Kelong Mao, Wentong Chen, Yiding Sun, Yihan Wu, Qian Cao, Lei Zhang, Feng Wang, Qiangqiang Ren Kun Zhou (Lead), Yushuo Chen, Zhipeng Chen, Lei Wang, Yupeng Hou, Xincheng Pang, Xinyu Tang, Junyi Li, Yuhan Chen, Shufang Xie

Reference

Please kindly cite our work if it helps you.

如果我们的项目对您有帮助,请引用我们,谢谢!

@misc{YuLan-Chat,
  author = {YuLan-Team},
  title = {YuLan-Chat: An Open-Source Bilingual Chatbot},
  year = {2023},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/RUC-GSAI/YuLan-Chat}},
}

YuLan-1

You can refer to our original branch for more detail about YuLan-Chat-1 and the instruction collection.

更多关于指令构造的细节,可以参考我们之前的分支。

Star History

Star History Chart

yulan-chat's People

Contributors

lancelot39 avatar daod avatar

Stargazers

冯思程 avatar Bangguo Ye avatar  avatar  avatar Zhiyuan Lu avatar  avatar  avatar 家诚 avatar  avatar  avatar zbcn avatar Fei Zhang avatar 賴祺清 avatar WestAuqa avatar  avatar Lishijie avatar xakoy avatar  avatar wangqiuyi avatar brandon avatar  avatar Liutao(Aton) avatar ZHAI Jucai avatar  avatar zzhoo8 avatar Michael_Xu avatar sshan avatar weiyudang avatar You Wan avatar  avatar  avatar will avatar JD Chen avatar alan avatar  avatar Tongxi Wu avatar New_light avatar  avatar  avatar Leo avatar Xiao Yi avatar  avatar Isaac Chao avatar  avatar PackAI avatar 蟑蛹蜂 avatar wook2014 avatar  avatar LeoLee avatar  avatar hepenghui avatar  avatar  avatar 邓六石 avatar Eason-Ni avatar  avatar  avatar AndyWo avatar  avatar  avatar volvet avatar Dralin avatar Xiaonan Cui avatar eatcosmos avatar Beibei Li avatar Tang avatar  avatar allen.hu avatar mack avatar Chen gao avatar  avatar  avatar koalacxr avatar godlaugh avatar 五档起步杰 avatar zhj@xmsme avatar cloudflash avatar liyingming avatar  avatar plattchai avatar  avatar  avatar Zhao Du avatar Qcy avatar 又几番迷离 avatar  avatar  avatar HL avatar Yongshuai Hou avatar  avatar ZhangZhengfu avatar  avatar Jason Tan avatar qy avatar Brian Yang avatar  avatar  avatar Xu Qinqin avatar  avatar guocc1982 avatar

Watchers

Yankai Lin avatar  avatar Xu Chen avatar  avatar guocc1982 avatar

yulan-chat's Issues

Inquiry regarding the prompt of ChatGPT

Dear YuLan-Chat-Team,

I hope this message finds you well. I am reaching out to kindly inquire about the following prompt of ChatGPT.

Then, we use ChatGPT to judge the degree of semantic repetition between the two, and delete highly repeated instructions and merge semantically similar instructions into a new, more complex instruction.

I test this stage in ChatGPT, but it fails to merge. Could you share this prompt to us? I genuinely appreciate any information you can provide.

Thank you for your time and consideration. I look forward to your response.

Best regards,
Run-Ze Fan

Inquiry regarding the availability of the instruction dataset

Dear YuLan-Chat-Team,

I hope this message finds you well. I am reaching out to kindly inquire about the potential release instruction date. As an interested party in the field, I am eager to explore and analyze the data to further my research and contribute to the community.

Could you please provide me with an update on when you plan to make the dataset publicly accessible? I understand that there might be certain considerations or circumstances affecting the release timeline, and I genuinely appreciate any information you can provide.

Thank you for your time and consideration. I look forward to your response and the potential opportunity to explore the dataset and contribute to its development.

Best regards,
Run-Ze Fan

微调和预训练代码

想请求博主把微调和预训练代码也同步开源下,我们也好在自己的数据集上面做微调.感谢博主大力支持!

很棒!

这个模型,拿真实场景实跑(不刷榜),目前比其他的要好。

词表大小不对应

config文件中的词表大小为52100,但是tokenizer长度为51190,手动将config中的size改为51190,训练时遇到这个问题,请问怎么解决?

RuntimeError: Error(s) in loading state_dict for LlamaForCausalLM:
	size mismatch for model.embed_tokens.weight: copying a param with shape torch.Size([51200, 5120]) from checkpoint, the shape in current model is torch.Size([51190, 5120]).
	size mismatch for lm_head.weight: copying a param with shape torch.Size([51200, 5120]) from checkpoint, the shape in current model is torch.Size([51190, 5120]).

模型量化报错

from transformers import LlamaTokenizer, LlamaForCausalLM
tokenizer = LlamaTokenizer.from_pretrained("yulan-team/YuLan-Chat-2-13b-fp16")
model = LlamaForCausalLM.from_pretrained("yulan-team/YuLan-Chat-2-13b-fp16", load_in_8bit=True).cuda()
model = model.eval()
input_text = "hello"
prompt = "The following is a conversation between a human and an AI assistant namely YuLan, developed by GSAI, Renmin University of China. The AI assistant gives helpful, detailed, and polite answers to the user's questions.\n[|Human|]:{}\n[|AI|]:".format(input_text)
inputs = tokenizer(prompt, return_tensors='pt', padding="longest", max_length=8192, truncation=True, return_attention_mask=True, add_special_tokens=True)
kwargs = {'temperature': 0.8, 'top_p': 0.95, "top_k": 50, "repetition_penalty": 1.1, "no_repeat_ngram_size": 64, "max_length": 8192, "pad_token_id": tokenizer.bos_token_id, "eos_token_id": tokenizer.eos_token_id}
outputs = model.generate(inputs['input_ids'].to(model.device), attention_mask=inputs['attention_mask'].to(model.device), do_sample=True, **kwargs)

RuntimeError Traceback (most recent call last)
in <cell line: 9>()
7 inputs = tokenizer(prompt, return_tensors='pt', padding="longest", max_length=8192, truncation=True, return_attention_mask=True, add_special_tokens=True)
8 kwargs = {'temperature': 0.8, 'top_p': 0.95, "top_k": 50, "repetition_penalty": 1.1, "no_repeat_ngram_size": 64, "max_length": 8192, "pad_token_id": tokenizer.bos_token_id, "eos_token_id": tokenizer.eos_token_id}
----> 9 outputs = model.generate(inputs['input_ids'].to(model.device), attention_mask=inputs['attention_mask'].to(model.device), do_sample=True, **kwargs)
10 print(tokenizer.batch_decode(outputs, skip_special_tokens=True)[len(prompt):])

2 frames
/usr/local/lib/python3.10/dist-packages/torch/utils/_contextlib.py in decorate_context(*args, **kwargs)
113 def decorate_context(*args, **kwargs):
114 with ctx_factory():
--> 115 return func(*args, **kwargs)
116
117 return decorate_context

/usr/local/lib/python3.10/dist-packages/transformers/generation/utils.py in generate(self, inputs, generation_config, logits_processor, stopping_criteria, prefix_allowed_tokens_fn, synced_gpus, assistant_model, streamer, **kwargs)
1586
1587 # 13. run sample
-> 1588 return self.sample(
1589 input_ids,
1590 logits_processor=logits_processor,

/usr/local/lib/python3.10/dist-packages/transformers/generation/utils.py in sample(self, input_ids, logits_processor, stopping_criteria, logits_warper, max_length, pad_token_id, eos_token_id, output_attentions, output_hidden_states, output_scores, return_dict_in_generate, synced_gpus, streamer, **model_kwargs)
2676 # sample
2677 probs = nn.functional.softmax(next_token_scores, dim=-1)
-> 2678 next_tokens = torch.multinomial(probs, num_samples=1).squeeze(1)
2679
2680 # finished sentences should have their next token be a padding token

RuntimeError: probability tensor contains either inf, nan or element < 0

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.