0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

简单三步使用OpenVINO™搞定ChatGLM3的本地部署

英特尔物联网 来源:OpenVINO 中文社区 2024-04-03 18:18 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

工具介绍

英特尔OpenVINO 工具套件是一款开源AI推理优化部署的工具套件,可帮助开发人员和企业加速生成式人工智能 (AIGC)、大语言模型、计算机视觉和自然语言处理等 AI 工作负载,简化深度学习推理的开发和部署,便于实现从边缘到云的跨英特尔 平台的异构执行。

ChatGLM3是智谱AI和清华大学KEG实验室联合发布的对话预训练模型。ChatGLM3-6B是ChatGLM3系列中的开源模型,在保留了前两代模型对话流畅、部署门槛低等众多优秀特性的基础上,ChatGLM3-6B引入了以下新特性:

1

更强大的基础模型:

ChatGLM3-6B的基础模型ChatGLM3-6B-Base采用了更多样的训练数据、更充分的训练步数和更合理的训练策略。在语义、数学、推理、代码、知识等不同角度的数据集上测评显示,ChatGLM3-6B-Base具有在10B以下的预训练模型中领先的性能。

2

更完整的功能支持:

ChatGLM3-6B采用了全新设计的Prompt格式,除正常的多轮对话外,同时原生支持工具调用 (Function Call)、代码执行 (Code Interpreter) 和Agent任务等复杂场景。

3

更全面的开源序列:

除了对话模型ChatGLM3-6B外,还开源了基础模型ChatGLM-6B-Base、长文本对话模型ChatGLM3-6B-32K。以上所有权重对学术研究完全开放,在填写问卷进行登记后亦允许免费商业使用。

8c1a646e-f19a-11ee-a297-92fbcf53809c.png

图:基于Optimum-intel与OpenVINO部署生成式AI模型流程

英特尔为开发者提供了快速部署ChatGLM3-6B的方案支持。开发者只需要在GitHub上克隆示例仓库,进行环境配置,并将Hugging Face模型转换为OpenVINO IR模型,即可进行模型推理。由于大部分步骤都可以自动完成,因此开发者只需要简单的工作便能完成部署,目前该仓库也被收录在GhatGLM3的官方仓库和魔搭社区Model Card中,接下来让我们一起看下具体的步骤和方法:

示例仓库:

https://github.com/OpenVINO-dev-contest/chatglm3.openvino

官方仓库:

https://github.com/THUDM/ChatGLM3?tab=readme-ov-file#openvino-demo

Model Card:

https://www.modelscope.cn/models/ZhipuAI/chatglm3-6b/summary#

1

模型转换

当你按仓库中的README文档完成集成环境配置后,可以直接通过以下命令运行模型转换脚本:

python3 convert.py --model_id THUDM/chatglm3-6b –output {your_path}/chatglm3-6b-ov

该脚本首先会利用Transformers库从Hugging Face的model hub中下载并加载原始模型的PyTorch对象,如果开发者在这个过程中无法访问Hugging Face的model hub,也可以通过配置环境变量的方式,将模型下载地址更换为镜像网站,并将convert.py脚本的model_id参数配置为本地路径,具体方法如下:

$env:HF_ENDPOINT = https://hf-mirror.com
huggingface-cli download --resume-download --local-dir-use-symlinks False THUDM/chatglm3-6b --local-dir {your_path}/chatglm3-6b
python3 convert.py --model_id {your_path}/chatglm3-6b --output {your_path}/chatglm3-6b-ov

当获取PyTorch的模型对象后,该脚本会利用OpenVINO的PyTorch frontend进行模型格式的转换,执行完毕后,你将获取一个由.xml和.bin文件所构成的OpenVINO IR模型文件,该模型默认以FP16精度保存。

2

权重量化

该步骤为可选项,开发者可以通过以下脚本,将生成的OpenVINO模型通过权重量化策略,进一步地压缩为4-bits或者是8-bits的精度,以获取更低的推理延时及系统资源占用。

python3 quantize.py --model_path {your_path}/chatglm3-6b-ov --precision int4 --output {your_path}/chatglm3-6b-ov-int4

执行完毕后,你将获得经过压缩后的IR模型文件,以INT4对称量化为例,该压缩后的模型文件的整体容量大约为4GB左右。

8c3150b6-f19a-11ee-a297-92fbcf53809c.png

图:量化后的OpenVINO模型文件

同时在量化结束后,亦会在终端上打印模型的量化比例,如下图所示。

8c587254-f19a-11ee-a297-92fbcf53809c.png

图:量化比例输出

由于OpenVINO NNCF工具的权重压缩策略只针对于大语言模型中的Embedding和Linear这两种算子,所以该表格只会统计这两类算子的量化比例。其中ratio-defining parameter是指我们提前通过接口预设的混合精度比例,也就是21%权重以INT8表示,79%以INT4表示,这也是考虑到量化对ChatGLM3模型准确度的影响,事先评估得到的配置参数,开发者亦可以通过这个示例搜索出适合其他模型的量化参数。此外鉴于第一层Embedding layer和模型最后一层操作对于输出准确度的影响,NNCF默认会将他们以INT8表示,这也是为何all parameters中显示的混合精度比例会有所不同。当然开发者也可以通过nncf.compress_weights接口中设置all_layers=True,开关闭该默认策略。

示例:

https://github.com/openvinotoolkit/nncf/tree/develop/examples/llm_compression/openvino/tiny_llama_find_hyperparams

3

模型转换

最后一步就是模型部署了,这里展示的是一个Chatbot聊天机器人的示例,这也是LLM应用中最普遍,也是最基础的pipeline,而OpenVINO可以通过Optimum-intel工具为桥梁,复用Transformers库中预置的pipeline,因此在这个脚本中我们会对ChatGLM3模型再做一次封装,以继承并改写OVModelForCausalLM类中的方法,实现对于Optimum-intel工具的集成和适配。以下为该脚本的运行方式:

python3 chat.py --model_path {your_path}/chatglm3-6b-ov-int4 --max_sequence_length 4096 --device CPU

如果开发者的设备中包含英特尔的GPU产品,例如Intel ARC系列集成显卡或是独立显卡,可以在这个命令中将device参数改为GPU,以激活更强大的模型推理能力。

在终端里运行该脚本后,会生成一个简易聊天对话界面,接下来你就可以验证它的效果和性能了。

总结

通过模型转换、量化、部署这三个步骤,我们可以轻松实现在本地PC上部署ChatGLM3-6b大语言模型,经测试该模型可以流畅运行在最新的Intel Core Ultra异构平台及至强CPU平台上,作为众多AI agent和RAG等创新应用的核心基石,大语言模型的本地部署能力将充分帮助开发者们打造更安全,更高效的AI解决方案。


审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 人工智能
    +关注

    关注

    1813

    文章

    49751

    浏览量

    261621
  • 计算机视觉
    +关注

    关注

    9

    文章

    1714

    浏览量

    47457
  • pytorch
    +关注

    关注

    2

    文章

    813

    浏览量

    14706
  • OpenVINO
    +关注

    关注

    0

    文章

    117

    浏览量

    717

原文标题:简单三步使用OpenVINO™ 搞定ChatGLM3的本地部署 | 开发者实战

文章出处:【微信号:英特尔物联网,微信公众号:英特尔物联网】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    迅为RK3588开发环境搭建“三步曲”,从零到一轻松上手!

    迅为RK3588开发环境搭建“三步曲”,从零到一轻松上手!
    的头像 发表于 12-01 11:51 641次阅读
    迅为RK3588开发环境搭建“<b class='flag-5'>三步</b>曲”,从零到一轻松上手!

    工业物联网平台适合私有本地部署还是云端部署

    工业物联网平台的部署方式需根据企业核心需求选择, 私有本地部署适合数据安全要求极高、需深度定制且具备技术实力的企业;云端部署则更适合追求成本效益、灵活扩展及快速上线的中小型企业或实时性
    的头像 发表于 11-12 11:42 282次阅读
    工业物联网平台适合私有<b class='flag-5'>本地</b><b class='flag-5'>部署</b>还是云端<b class='flag-5'>部署</b>?

    工程师整理:UPS电源选购“三步法”,从看懂参数到下单不出错

    将分享一套简单实用的"三步选型法",帮助技术主管和企业轻松选出最适合的UPS电源。第一:读懂关键参数,不再被专业术语迷惑核心参数解析:容量(VA/W):这是最重
    的头像 发表于 09-05 09:26 621次阅读
    工程师整理:UPS电源选购“<b class='flag-5'>三步</b>法”,从看懂参数到下单不出错

    能源监测管理平台是本地部署好还是云端部署好?

    能源监测管理平台本地部署和云端部署各有优劣,企业需根据自身需求和实际情况来选择。如果企业对数据安全要求极高、网络环境特殊且预算充足,本地部署
    的头像 发表于 07-22 15:16 331次阅读
    能源监测管理平台是<b class='flag-5'>本地</b>化<b class='flag-5'>部署</b>好还是云端<b class='flag-5'>部署</b>好?

    如何本地部署NVIDIA Cosmos Reason-1-7B模型

    行动。本文将一步步带你在本地服务器上完成该模型的部署,并搭建一个直观的 Web 交互界面,亲身体验前沿 AI 的“思考”过程。
    的头像 发表于 07-09 10:17 564次阅读

    无法将Openvino™ 2025.0与onnx运行时Openvino™ 执行提供程序 1.16.2 结合使用,怎么处理?

    使用OpenVINO™与英特尔 i5-8500 CPU 和超核处理器 630 iGPU 一起部署模型。 使用了 Microsoft.ML.OnnxRuntime.OpenVino
    发表于 06-24 06:31

    本地服务器部署怎么选?一招搞定企业IT成本、性能与安全问题!

    ,往往纠结万分。其实,企业本地服务器部署方案依然有其独特优势,只要选得对,照样能在IT成本、性能、安全方面实现全兼顾!
    的头像 发表于 05-26 13:07 504次阅读
    <b class='flag-5'>本地</b>服务器<b class='flag-5'>部署</b>怎么选?一招<b class='flag-5'>搞定</b>企业IT成本、性能与安全问题!

    Intel OpenVINO™ Day0 实现阿里通义 Qwen3 快速部署

    本文将以 Qwen3-8B 为例,介绍如何利用 OpenVINO 的 Python API 在英特尔平台(GPU, NPU)Qwen3 系列模型。
    的头像 发表于 05-11 11:36 1384次阅读
    Intel <b class='flag-5'>OpenVINO</b>™ Day0 实现阿里通义 Qwen<b class='flag-5'>3</b> 快速<b class='flag-5'>部署</b>

    工厂设备总故障?谐波治理新国标解读,3搞定省电又保生产

    工厂设备总故障?谐波治理新国标解读,3搞定省电又保生产
    的头像 发表于 04-24 17:29 643次阅读
    工厂设备总故障?谐波治理新国标解读,<b class='flag-5'>3</b><b class='flag-5'>步</b><b class='flag-5'>搞定</b>省电又保生产

    Modbus转以太网终极方案:三步实现老旧设备智能升级

    7.8万元/年(人工处理报警) 四、三步快速实施指南 步骤1:物理连接 步骤2:参数配置 步骤3:系统联调 ✅ 御控云平台:实时监测设备数据 五、高频问题解答 Q1:Modbus TCP和RTU能
    发表于 04-24 10:37

    如何部署OpenVINO™工具套件应用程序?

    编写代码并测试 OpenVINO™ 工具套件应用程序后,必须将应用程序安装或部署到生产环境中的目标设备。 OpenVINO部署管理器指南包含有关如何轻松使用
    发表于 03-06 08:23

    是否可以使用OpenVINO部署管理器在部署机器上运行Python应用程序?

    使用 OpenVINO部署管理器创建运行时软件包。 将运行时包转移到部署机器中。 无法确定是否可以在部署机器上运行 Python 应用程序,而无需安装
    发表于 03-05 08:16

    华为云发布DeepSeek本地部署方案

    华为云正式推出基于华为云Stack混合云的DeepSeek本地部署方案。
    的头像 发表于 02-18 10:05 1422次阅读

    C#集成OpenVINO™:简化AI模型部署

    在开源测控、机器视觉、数采与分析大领域中,如何快速将AI模型集成到应用程序中, 实现AI赋能和应用增值? 最容易的方式是:在C#中,使用 OpenVINO工具套件 集成AI模型。 1
    的头像 发表于 02-17 10:03 2530次阅读
    C#集成<b class='flag-5'>OpenVINO</b>™:简化AI模型<b class='flag-5'>部署</b>

    C#中使用OpenVINO™:轻松集成AI模型!

    与分析大领域中,如何快速将AI模型集成到应用程序中,实现AI赋能和应用增值?最容易的方式是:在C#中,使用OpenVINO™工具套件集成AI模型。 一,什么是OpenVINO™ 工具套件?
    的头像 发表于 02-07 14:05 1671次阅读
    C#中使用<b class='flag-5'>OpenVINO</b>™:轻松集成AI模型!