【大模型】长度 32K 上下文的 ChatGLM2-6B-32K 来了,开源可商用

2023-10-31

简介

ChatGLM2-6B-32K

ChatGLM2-6B-32K在ChatGLM2-6B的基础上进一步强化了对于长文本的理解能力,能够更好的处理最多32K长度的上下文。

基于位置插值(Positional Interpolation)的方法对位置编码进行了更新,并在对话阶段使用 32K 的上下文长度训练。

在实际的使用中,如果上下文长度基本在 8K 以内,我们推荐使用ChatGLM2-6B地址;如果需要处理超过 8K 的上下文长度,推荐使用ChatGLM2-6B-32K。

ChatGLM2-6B-32K 新特性

ChatGLM2-6B-32K是开源中英双语对话模型 ChatGLM2-6B 的加长版本:

  1. 训练数据:ChatGLM2-6B-32K 使用了 GLM 的混合目标函数,经过了 1.4T 中英标识符的预训练与人类偏好对齐训练。
  2. 更长的上下文:基于 FlashAttention 技术,我们将基座模型的上下文长度(Context Length)由 ChatGLM-6B 的 2K 扩展到了 32K,并在对话阶段使用 32K 的上下文长度训练,允许更多轮次的对话。
  3. 更高效的推理:基于 Multi-Query Attention 技术,ChatGLM2-6B-32K 有更高效的推理速度和更低的显存占用:在官方的模型实现下,推理速度相比初代提升了 42%,INT4 量化下,6G 显存支持的对话长度由 1K 提升到了 8K。
  4. 更开放的协议:ChatGLM2-6B-32K 权重对学术研究完全开放,在填写问卷进行登记后亦允许免费商业使用

环境配置

环境搭建

具体搭建过程参考:
【AI实战】最强开源 6B 中文大语言模型ChatGLM2-6B,从零开始搭建
- ChatGLM2-6B 搭建

安装依赖

pip install protobuf transformers==4.30.2 cpm_kernels torch>=2.0 gradio mdtex2html sentencepiece accelerate

代码及模型权重拉取

拉取 ChatGLM2-6B

git clone https://github.com/THUDM/ChatGLM2-6B

github网站偶尔会抽风,需要耐心等待,如果失败了,再重新拉取

拉取 chatglm2-6b-32k 模型权重及代码

cd ChatGLM2-6B
git clone https://huggingface.co/THUDM/chatglm2-6b-32k

由于权重文件特别大,如果失败了,执行 rm -rf chatglm2-6b-32k,再重新拉取。

查看文件列表:

ls -l chatglm2-6b-32k

输出:

.gitattributes  1.52 kB
MODEL_LICENSE   4.13 kB
README.md   9.04 kB
config.json 1.25 kB
configuration_chatglm.py    2.31 kB
modeling_chatglm.py 51.5 kB
pytorch_model-00001-of-00007.bin    1.83 GB
pytorch_model-00002-of-00007.bin    1.97 GB
pytorch_model-00003-of-00007.bin    1.93 GB
pytorch_model-00004-of-00007.bin    1.82 GB
pytorch_model-00005-of-00007.bin    1.97 GB
pytorch_model-00006-of-00007.bin    1.93 GB
pytorch_model-00007-of-00007.bin    1.05 GB
pytorch_model.bin.index.json    20.4 kB
quantization.py 14.7 kB
tokenization_chatglm.py 10.1 kB
tokenizer.model 1.02 MB
tokenizer_config.json   

【】如果大文件下载失败,按照下面的方法下载模型文件;

wget https://huggingface.co/THUDM/chatglm2-6b-32k/resolve/main/pytorch_model-00001-of-00007.bin
wget https://huggingface.co/THUDM/chatglm2-6b-32k/resolve/main/pytorch_model-00002-of-00007.bin
其他的同上...

终端测试

进入python环境:

python3

输入代码:

from transformers import AutoTokenizer, AutoModel
tokenizer = AutoTokenizer.from_pretrained("./chatglm2-6b-32k", trust_remote_code=True)
model = AutoModel.from_pretrained("./chatglm2-6b-32k", trust_remote_code=True).half().cuda()
model = model.eval()
response, history = model.chat(tokenizer, "你好", history=[])
print(response)
response, history = model.chat(tokenizer, "晚上睡不着应该怎么办", history=history)
print(response)

输出:

晚上睡不着可能会让你感到焦虑或不舒服,但以下是一些可以帮助你入睡的方法:

1. 制定规律的睡眠时间表:保持规律的睡眠时间表可以帮助你建立健康的睡眠习惯,使你更容易入睡。尽量在每天的相同时间上床,并在同一时间起床。
2. 创造一个舒适的睡眠环境:确保睡眠环境舒适,安静,黑暗且温度适宜。可以使用舒适的床上用品,并保持房间通风。
3. 放松身心:在睡前做些放松的活动,例如泡个热水澡,听些轻柔的音乐,阅读一些有趣的书籍等,有助于缓解紧张和焦虑,使你更容易入睡。
4. 避免饮用含有咖啡因的饮料:咖啡因是一种刺激性物质,会影响你的睡眠质量。尽量避免在睡前饮用含有咖啡因的饮料,例如咖啡,茶和可乐。
5. 避免在床上做与睡眠无关的事情:在床上做些与睡眠无关的事情,例如看电影,玩游戏或工作等,可能会干扰你的睡眠。
6. 尝试呼吸技巧:深呼吸是一种放松技巧,可以帮助你缓解紧张和焦虑,使你更容易入睡。试着慢慢吸气,保持几秒钟,然后缓慢呼气。

如果这些方法无法帮助你入睡,你可以考虑咨询医生或睡眠专家,寻求进一步的建议。

网页测试

使用 gradio 搭建页面

安装 gradio

pip install gradio   -i https://pypi.tuna.tsinghua.edu.cn/simple

加载模型并启动服务

修改模型路径;

vi web_demo.py

到6,7行:

tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True)
model = AutoModel.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True).cuda()

修改为:

tokenizer = AutoTokenizer.from_pretrained("./chatglm2-6b-32k", trust_remote_code=True)
model = AutoModel.from_pretrained("./chatglm2-6b-32k", trust_remote_code=True).cuda()

开启服务:

python web_demo.py

测试地址:

http://10.192.x.x:7860/

参考

  1. https://github.com/THUDM/ChatGLM2-6B
  2. https://huggingface.co/THUDM/chatglm2-6b-32k
  3. https://huggingface.co/THUDM/chatglm2-6b
  4. https://github.com/THUDM/GLM
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【大模型】长度 32K 上下文的 ChatGLM2-6B-32K 来了,开源可商用 的相关文章

  • 【AI实战】开源可商用的中英文大语言模型baichuan-7B,从零开始搭建

    AI实战 开源可商用的中英文大语言模型baichuan 7B 从零开始搭建 baichuan 7B 简介 baichuan 7B 中文评测 baichuan 7B 搭建 参考 baichuan 7B 简介 baichuan 7B 是由百川智
  • 中文大模型评估数据集——C-Eval

    C EVAL A Multi Level Multi Discipline Chinese Evaluation Suite for Foundation Models https arxiv org pdf 2305 08322v1 pd
  • 05 神经网络语言模型(独热编码+词向量的起源)

    博客配套视频链接 https space bilibili com 383551518 spm id from 333 1007 0 0 b 站直接看 配套 github 链接 https github com nickchen121 Pr
  • ChatGLM2_6b安装

    Chatglm2 6b安装 一 安装要求 1 硬件 能否使用 或者以什么模式使用主要取决于显卡的显存 2 能否使用AMD显卡 可以 甚至可以使用CPU 但是需要降低精度 以CPU模式运行大概需要32GB 内存 二 工程与下载 官方路径 工程
  • 【AI实战】最强开源 6B 中文大语言模型ChatGLM2-6B,从零开始搭建

    AI实战 最强开源 6B 中英文大语言模型ChatGLM2 6B 从零开始搭建 ChatGLM2 6B 简介 ChatGLM2 6B 评测结果 ChatGLM2 6B 搭建 参考 ChatGLM2 6B 简介 ChatGLM2 6B 是开源
  • 为什么企业需要私有化专属大模型

    编者按 8月29日凌晨 OpenAI在官网宣布 推出企业版ChatGPT ChatGPT Enterprise 前不久 OpenAI又刚刚发布了针对企业的GPT 3 5 Turbo微调功能 因而引发了一场热烈的讨论 是否仍需要私有化的大模型
  • chatGLM-Windows环境安装

    Windows系统下环境安装 一 概要 不同安装方式 安装python 安装Nvidia驱动 安装cuda与cuddn 安装PyTorch与TensorFlow 二 安装文件 百度网盘链接 https pan baidu com s 1lb
  • LangChain 手记 Conclusion结语

    整理并翻译自DeepLearning AI LangChain的官方课程 Conclusion Conclusion 结语 本系列短课展示了大量使用LangChain构建的大语言模型应用 包括处理用户反馈 文档上的问答系统甚至使用LLM来决
  • 收入最高的十大IT职位

    过去的一年对科技行业来说非常艰难 一些公司宣布裁员 面临着迫在眉睫的经济衰退威胁 尽管经历了坎坷的一年 但市场对科技人才的需求仍然强劲 截至1月 美国的科技人才失业率下降到1 5 对于拥有适当技能和专业知识的技术人员来说 市场对人才的需求仍
  • 05 神经网络语言模型(独热编码+词向量的起源)

    博客配套视频链接 https space bilibili com 383551518 spm id from 333 1007 0 0 b 站直接看 配套 github 链接 https github com nickchen121 Pr
  • 【AI实战】开源大语言模型LLMs汇总

    AI实战 开源大语言模型LLM汇总 大语言模型 开源大语言模型 1 LLaMA 2 ChatGLM 6B 3 Alpaca 4 PandaLLM 5 GTP4ALL 6 DoctorGLM MedicalGPT zh v2 7 Medica
  • 【AI实战】llama.cpp 量化部署 llama-33B

    AI实战 llama cpp 量化部署 llama 33B llama cpp 量化介绍 环境配置 安装 llama cpp 拉取 llama cpp 仓库代码 编译llama cpp 生成量化版本模型 模型准备 将上述 pth模型权重转换
  • CodeLlama本地部署的实战方案

    大家好 我是herosunly 985院校硕士毕业 现担任算法研究员一职 热衷于机器学习算法研究与应用 曾获得阿里云天池比赛第一名 CCF比赛第二名 科大讯飞比赛第三名 拥有多项发明专利 对机器学习和深度学习拥有自己独到的见解 曾经辅导过若
  • 大语言模型介绍(一)

    什么是大语言模型 由于ChatGPT的火爆把大语言模型这个新名词推到了大众的视野里 那么 什么是大语言模型 什么是GPT WIKI百科对大语言模型是这样解释的 大语言模型 英语 large language model LLM 是一种语言模
  • RLHF 技术:如何能更有效?又有何局限性?

    编者按 自ChatGPT推出后 基于人类反馈的强化学习 RLHF 技术便成为大模型构建和应用人员关注的热点 但该方法一些情况下效果却差强人意 有些基础模型经RLHF调优后反而表现更差 RLHF技术的适用性和具体操作细节似乎成谜 这篇文章探讨
  • chatGLM介绍

    一 简述 清华大学推出的ChatGLM的第二代版本 支持中文 效果好 清华大学的ChatGLM应该是中文大语言模型中最好的 要求低 可以在消费级的显卡上运行 二 链接 工程 https github com THUDM ChatGLM2 6
  • 03 什么是预训练(Transformer 前奏)

    博客配套视频链接 https space bilibili com 383551518 spm id from 333 1007 0 0 b 站直接看 配套 github 链接 https github com nickchen121 Pr
  • chatglm2外挂知识库问答的简单实现

    一 背景 大语言模型应用未来一定是开发热点 现在一个比较成功的应用是外挂知识库 相比chatgpt这个知识库比较庞大 效果比较好的接口 外挂知识库 大模型的方式可以在不损失太多效果的条件下获得数据安全 二 原理 现在比较流行的一个方案是la
  • lmg_Model Links and Torrents

    lmg Model Links and Torrents Changelog MDY 4 bit GPU Model Requirements 4 bit CPU llama cpp RAM Requirements LLaMA 16 bi
  • 超详细!大模型面经指南(附答案)

    大模型应该算是目前当之无愧的最有影响力的AI技术 它正在革新各个行业 包括自然语言处理 机器翻译 内容创作和客户服务等 成为未来商业环境的重要组成部分 截至目前大模型已超过100个 大模型纵横的时代 不仅大模型越来越卷 就连大模型相关面试也

随机推荐

  • Qt之图形视图框架

    简述 图形视图架构 场景 视图 图元 图形视图框架中的类 图形视图坐标系 图元坐标 场景坐标 视图坐标 坐标映射 主要特点 缩放和旋转 打印 拖放 光标和tooltip 动画 OpenGL渲染 图元组 部件和布局 QGraphicsWidg
  • 通过手机号定位归属地

    工作中 很多地方 都存在只知道手机号 同时也想知道这个手机号的归属地的情况 本功能 即可实现这个要求 同时 可在此基础上做调整 实现其它功能 如制作一个属于自己的手机号段归属库等 实现思路 通过网上提供的免费查询接口 取得返回信息 并对返回
  • osg fbo(三),将颜色缓冲区图片通过shader变绿

    这个其实很简单 一 写顶点着色器和片元着色器 static const char vertexShader void main void n n gl Position ftransform n n static const char ps
  • 看完这篇文章保你面试稳操胜券——React篇

    进大厂收藏这一系列就够了 全方位搜集总结 为大家归纳出这篇面试宝典 面试途中祝你一臂之力 共分为四个系列 本 篇 为 看 完 这 篇 文 章 保 你 面 试 稳 操 胜 券 第 五 篇
  • 邮票孔相关

    1 PCB厂子把这个叫做半孔焊盘 加工起来要多收费的 首先内孔金属化的工艺要求比普通焊盘或过孔要高 负责的厂子会做切片抽检 其次是板子切割 别的板子边缘可能用冲床或者V割来加工 速度很快 这种我不知道用什么刀具 但精度控制很高 切边的时候如
  • 多开虚拟机就卡内存cpu都够_CPU过剩是真是假?告诉你造成电脑卡顿的原因

    最近一些朋友说自己的电脑经常卡顿 即使升级了CPU啥的还是无法完全解决 还有的即使用了大家推荐的固态硬盘 使用时间一长也会卡顿 原因究竟是什么呢 尽管都说如今的电脑CPU性能过剩 但也得看你是拿来干什么的 如果是日常上网聊天的话 即使是几百
  • 阿里云 k8s 专有版集群修改节点 最大pod 数

    阿里云 k8s 专有版集群修改节点 最大pod 数 默认64 在节点上编辑此文件 vi etc systemd system kubelet service d 10 kubeadm conf 修改如下这行参数中的 max pods 例如将
  • 递归算法学习——全排列

    目录 编辑 一 问题描述 1 例子 题目接口 二 问题分析和解决 1 问题分析 2 解题代码 一 问题描述 首先我们得来先看看全排列的问题描述 全排列问题的问题描述如下 给定一个不含重复数字的数组 nums 返回其 所有可能的全排列 你可以
  • 统计java类出现的次数并写出到文件

    package File方法 import java io public class FileCount int javaNum 0 int classNum 0 int rowNum 0 public void count String
  • C语言:整数的存储方式

    整数的存储方式 char类型在存储时是按照ASCII码值进行存储 存储方式与整型一致 有符号数与无符号数 char 一个字节 signed char unsigned char int 四个字节 signed int unsigned in
  • CentOS7.9安装kafka-3.2.0和window10 下安装kafka-3.2.0

    目录 1 下载软件包 2 配置环境 3 安装zookeeper 4 安装kafka 5 测试功能 6 window 10下安装 1 下载软件包 首先下载zookeeper 地址 Apache ZooKeeperhttps zookeeper
  • ubuntu下在远程登录的主机上广播信息

    要在远程登录的主机上广播信息 可以使用以下几种方法 1 使用wall命令 wall命令可以将一条消息发送给所有登录到主机上的用户 在终端中输入以下命令来广播消息 wall Your message here 将 Your message h
  • Dynamics CRM环境还原

    Dynamics CRM 组织还原 一 还原数据库 二 导入组织 一 还原数据库 备份好 bat文件 切记 如果在同一台服务器上还原一个数据库 一定要修改目标数据库的名字 默认还原的名字会和原来的备份的数据库名字一样 二 导入组织 把姓名的
  • UGUI防止点击穿透

    if IsPointerOverGameObject Input mousePosition public static bool IsPointerOverGameObject Vector2 screenPosition 实例化点击事件
  • python实现非正态分布转正态分布(BoxCox转换)

    功能 将一维非正态分布数据转化为正态分布 输入 xlsx文件含有 患者密度 人 10万人 一列 输出 将 患者密度 人 10万人 一列转换为正态分布 并输出 实现代码 import pandas as pd import numpy as
  • DeeplabV3+网络结构搭建

    整体结构图 超详细结构图 Mobilenetv2主干 主干网络搭建 import math import os import torch import torch nn as nn import torch utils model zoo
  • 测试日常工作中需要具备哪些知识和能力,在需求评审时需要考虑哪些方面,在技术方面评审时需要考虑哪些方面,从什么方面进行设计测试用例

    前几天同事分享了一波作为测试需要具备哪些能力 测试用例需要从哪些方面进行设计 我把他分享的内容拷贝了一波 作为以后在测试过程中的参考 首先需求评审 技术方案评审 测试用例评审三者的关系 一开始 我每次设计测试用例都是从需求着手 去用测试用例
  • SQL在Excel中的应用方法

    iamlaosong文 Excel中使用SQL的主要目的是连接数据库 或Excel工作表 导入数据或者对这些数据进行统计汇总 要达到这个目的 需要好好学习SQL语句的使用 本文主要说明在Excel中如何使用SQL 至于SQL语句本身就不多作
  • 简单上手element-ui,三分钟学会按需导入~

    前言 element ui是由 饿了吗 团队开发的一个基于Vue框架的组件库 它提供了很多方便的api接口 可以快速的开发通用的页面 呸 讲这些没用的东西干嘛 下面我们就简单的讲讲 怎么快速的上手使用 ps 由于现在vue3已经成为新版本趋
  • 【大模型】长度 32K 上下文的 ChatGLM2-6B-32K 来了,开源可商用

    大模型 长度 32K 上下文的 ChatGLM2 6B 32K 来了 开源可商用 简介 ChatGLM2 6B 32K ChatGLM2 6B 32K 新特性 环境配置 环境搭建 安装依赖 代码及模型权重拉取 拉取 ChatGLM2 6B