当前位置: 首页 > news >正文

哪有做建筑设计的网站绍兴百度推广优化排名

哪有做建筑设计的网站,绍兴百度推广优化排名,建邺区住房 建设 网站,wordpress判断页面通义千问本地部署教程🚀 本专栏的第四弹,在实现了联网调用通义千问模型进行多轮对话,流式输出,以及结合LangChain实现自建知识库之后,开始准备考虑实现对大模型进行本地部署,网上找不到看着比较舒服的教程&…

通义千问本地部署教程🚀

        本专栏的第四弹,在实现了联网调用通义千问模型进行多轮对话,流式输出,以及结合LangChain实现自建知识库之后,开始准备考虑实现对大模型进行本地部署,网上找不到看着比较舒服的教程,本文对于部署大模型过程中比较重要的,环境搭建,模型下载等进行详细介绍,如果您没有研究需求只有使用需求,请直接安装环境-下载模型-运行代码,由于这部分内容实在太多,所以可能还是需要一些相关的基础才能完全读懂本篇文字,如果您之前稍微研究过大语言模型的本地部署我相信这篇文章一定能解决您的问题,如果有什么我写的不清楚的地方,非常欢迎各位给我留言评论探讨,然后虽然我看好像其他相关的文章好像都收费,但是我还是决定免费,由于我是会员所以我有版权保护,所以不用太担心别人直接爬走,希望帮助到各位,如果可以您点个赞我会非常开心的。


第一弹 调用阿里通义千问大语言模型API-小白新手教程-python
第二弹 LangChain结合通义千问的自建知识库
第三弹 使用LangChain结合通义千问API基于自建知识库的多轮对话和流式输出

文章目录

  • 通义千问本地部署教程🚀
    • 1.Qwen-7B-Chat 模型的下载
    • 2.Qwen-7B-Chat 环境的安装
    • 3.运行本地的部署代码实现多轮对话
    • 4.结合Swift库实现流式输出-认真总结
      • 4.1 该部分实现过程和踩坑经验分享
      • 4.2 真正实现离线的使用本地模型的多轮对话和流式输出的最终代码
    • 5.相关文档链接💻
    • 6.结束😊

1.Qwen-7B-Chat 模型的下载

        首先需要下载通义千问的Qwen-7B-Chat的模型文件,其下载地址为阿里官方的大语言模型社区,模搭ModelScope,其中通义千问的Qwen-7B-Chat 的下载和相关介绍的地址为。
https://modelscope.cn/models/qwen/Qwen-7B-Chat/summary
在这里插入图片描述
点击其中的模型文件,进入模型文件页面,之后点击右侧的下载模型
在这里插入图片描述
        右侧会出现两个下载方式,第一个是用SDK也就是安装安装工具包下载,第二个是用git下载,这里还是推荐用第一种,但是实际使用的时候,还需要添加一个新的参数用来设置下载地址,否则就会下载到安装包的目录下
在这里插入图片描述

        在安装好环境之后,之后运行下面的代码就可以下载到本地了,模型大小一共是14.4个Gchche_dir就是自己设置的模型下载的地址是是一个文件夹的目录

from modelscope import snapshot_download
model_dir = snapshot_download('qwen/Qwen-7B-Chat',cache_dir='自己的地址')

        运行起来的下过如下,当运行到下载1个G以上的文件的时候会卡住一阵,才会开始下载,如果这里长时间没响应那就是网络条件不行了。
在这里插入图片描述

2.Qwen-7B-Chat 环境的安装

        为了运行之后本地部署的Qwen-7B-Chat模型,我们需要根据要求在Anaconda中安装一个满足模型运行要求的虚拟环境,其官方的配置环境要求如下,本文配置的环境为使用GPU Pytorch的版本。官网的要求如下。
在这里插入图片描述

        除了常规的Pytorch之外还需要进行以下两次安装安装modelscope可以用来下载模型,在下载的过程中有网络要求我用的宽带为100M的网线链接最后下了不到1个小时,如果网络不行在下载到大文件的时候会断开链接。

pip install modelscope

        然后是官方说的运行Qwen-7B-需要安装的依赖。
在这里插入图片描述

pip install transformers==4.32.0 accelerate tiktoken einops scipy transformers_stream_generator==0.0.4 peft deepspeed

        具体安装过程根据不同的系统电脑各有各的微小差异,而且有时候充满了玄学,在这里我说一下我自己的配置,然后给大家参考。

名称硬件型号/软件版本
CPU英特尔 Core i7-14700KF
GPUNVIDIA GeForce RTX 4070 Ti(12 GB/华硕)
CUDADriver Version: 546.65 CUDA Version: 12.3
内存32 GB(威刚 DDR5 6000MHz16GB x2)
硬盘GAMMIX S70 SE(1024 GB/固态硬盘)
Python3.9.15
Numpy1.23.4
pip22.3.1
Torch1.13.1
modelscope1.12.0

3.运行本地的部署代码实现多轮对话

        在安装好环境以及下载了模型文件之后,就可以运行官方的例程代码来观察对话效果,官方的快速开始代码如下,先给出官方代码之后我会精简然后介绍重要参数的作用

from modelscope import AutoModelForCausalLM, AutoTokenizer
from modelscope import GenerationConfig# Note: The default behavior now has injection attack prevention off.
tokenizer = AutoTokenizer.from_pretrained("qwen/Qwen-7B-Chat", trust_remote_code=True)# use bf16
# model = AutoModelForCausalLM.from_pretrained("qwen/Qwen-7B-Chat", device_map="auto", trust_remote_code=True, bf16=True).eval()
# use fp16
# model = AutoModelForCausalLM.from_pretrained("qwen/Qwen-7B-Chat", device_map="auto", trust_remote_code=True, fp16=True).eval()
# use cpu only
# model = AutoModelForCausalLM.from_pretrained("qwen/Qwen-7B-Chat", device_map="cpu", trust_remote_code=True).eval()
# use auto mode, automatically select precision based on the device.
model = AutoModelForCausalLM.from_pretrained("qwen/Qwen-7B-Chat", device_map="auto", trust_remote_code=True).eval()# Specify hyperparameters for generation. But if you use transformers>=4.32.0, there is no need to do this.
# model.generation_config = GenerationConfig.from_pretrained("Qwen/Qwen-7B-Chat", trust_remote_code=True) # 可指定不同的生成长度、top_p等相关超参# 第一轮对话 1st dialogue turn
response, history = model.chat(tokenizer, "你好", history=None)
print(response)
# 你好!很高兴为你提供帮助。# 第二轮对话 2nd dialogue turn
response, history = model.chat(tokenizer, "给我讲一个年轻人奋斗创业最终取得成功的故事。", history=history)
print(response)
# 这是一个关于一个年轻人奋斗创业最终取得成功的故事。
# 故事的主人公叫李明,他来自一个普通的家庭,父母都是普通的工人。从小,李明就立下了一个目标:要成为一名成功的企业家。
# 为了实现这个目标,李明勤奋学习,考上了大学。在大学期间,他积极参加各种创业比赛,获得了不少奖项。他还利用课余时间去实习,积累了宝贵的经验。
# 毕业后,李明决定开始自己的创业之路。他开始寻找投资机会,但多次都被拒绝了。然而,他并没有放弃。他继续努力,不断改进自己的创业计划,并寻找新的投资机会。
# 最终,李明成功地获得了一笔投资,开始了自己的创业之路。他成立了一家科技公司,专注于开发新型软件。在他的领导下,公司迅速发展起来,成为了一家成功的科技企业。
# 李明的成功并不是偶然的。他勤奋、坚韧、勇于冒险,不断学习和改进自己。他的成功也证明了,只要努力奋斗,任何人都有可能取得成功。# 第三轮对话 3rd dialogue turn
response, history = model.chat(tokenizer, "给这个故事起一个标题", history=history)
print(response)
# 《奋斗创业:一个年轻人的成功之路》

        运行的结果如下,红色的是各种前置检查信息,我专门断网测试了一下输出的也是这些内容。

在这里插入图片描述

        之后对代码进行精简,实现一个简单的多轮对话功能。精简之后的代码如下。其中的device_map如果设置为cpu则模型将会在cpu上运行,如果设置为Auto如果Pytorch为GPU版本的话将会在GPU上运行。关于非常容易关注到的tokenizer,官方是这吗说的🤭说现在还没有概念的对应,所以无需纠结这块是啥东西。根据经验推测它应该是跟分词有关的一个东西。

在这里插入图片描述

from modelscope import AutoModelForCausalLM, AutoTokenizermodel_path = "D:\qwen\Qwen-7B-Chat"tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True)
model = AutoModelForCausalLM.from_pretrained(model_path, device_map="auto", trust_remote_code=True).eval()history=Nonewhile True:message = input('User:')response, history = model.chat(tokenizer, message, history=history)print('System:',end='')print(response)
  1. from modelscope import AutoModelForCausalLM, AutoTokenizer: 从modelscope库中导入两个类:AutoModelForCausalLMAutoTokenizer。这两个类分别用于加载预训练的因果语言模型(例如,GPT系列模型)和分词器。分词器用于文本的预处理,将文本转换为模型能理解的格式。

  2. model_path = "D:\qwen\Qwen-7B-Chat": 定义模型文件存放的路径。这里假定你已经有了一个预训练模型,存储在指定的路径下。

  3. tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True): 从给定的路径加载预训练的分词器。trust_remote_code=True参数允许加载并执行远程代码,这对于加载自定义的分词器逻辑可能是必需的。

  4. model = AutoModelForCausalLM.from_pretrained(model_path, device_map="auto", trust_remote_code=True).eval(): 类似地,从指定路径加载预训练的语言模型,并将模型设置为评估模式。device_map="auto"指示库自动选择运行模型的设备(CPU或GPU).eval()方法用于切换到模型的评估模式,这通常在预测时使用,以禁用训练时特有的行为,如Dropout

  5. history=None: 初始化history变量。这个变量用于存储对话历史,使模型能够在生成回答时考虑到之前的上下文。

  6. while True:: 开始一个无限循环,用于持续接收用户输入并生成回应。

  7. message = input('User:'): 通过input函数接收用户的输入。

  8. response, history = model.chat(tokenizer, message, history=history): 调用模型的chat方法生成回应。这个方法接受分词器、用户的消息以及可选的历史记录作为输入,并返回模型的回应和更新后的历史记录。更新后的历史记录可以在下一次迭代中使用,以便模型能够参考之前的对话内容。

  9. print('System:',end='')print(response): 首先打印System:,不换行,然后打印模型生成的回应。

        运行结果如下:

在这里插入图片描述

        本设备在模型推理时的性能检测效果如下。

在这里插入图片描述

        由于其生成的比较慢,我就加了一下每次推理运行的时间,其运行时间效果如图,我大概估计了一下,输出一个Token的推理时间大概为1S,在官方的快速开始的例程序中,所以等待的过程非常的难受。

在这里插入图片描述

4.结合Swift库实现流式输出-认真总结

        在经历了非常不舒服的等待之后,决定尝试一下流式输出,然后这部分代码就非常的不好找了,我在进入了ModelScope的官方咨询群之后询问了半天,加上自己参悟最终实现了在Windows上使用本地部署的通义千问模型多轮对话的效果,那接下来直接开始。我会把这个过程以及采的坑详细说明,如果您是有相关基础的想直接使用的技术人员直接跳到最后的代码部分即可

4.1 该部分实现过程和踩坑经验分享

        首先,对于流式输出官方人员给我发的一个链接是这样的。

在这里插入图片描述

        点开里面的推理文档,下滑找到对应的代码。
链接为Swift官方推理文档

在这里插入图片描述

        这里我直接把代码复制到下面,我们先不纠结里面的内容,这里用到了一个新的库swift,首先需要安装它,这里是一个坑
其安装命令为:

pip install ms-swift

        而并不是pip install swift,如果你用的是pip install swift安装会安装不上,会出现如下错误,提示你要取下载红帽和Ubtuntu版本的库,但是这是Liunx系统的库,所以安装不上,只有运行pip install ms-swift才能安装成功。

在这里插入图片描述

import os
os.environ['CUDA_VISIBLE_DEVICES'] = '0'from swift.llm import (get_model_tokenizer, get_template, inference_stream, ModelType, get_default_template_type,
)
from swift.utils import seed_everythingmodel_type = ModelType.qwen_7b_chat
template_type = get_default_template_type(model_type)
print(f'template_type: {template_type}')  # template_type: qwenmodel, tokenizer = get_model_tokenizer(model_type, model_kwargs={'device_map': 'auto'})template = get_template(template_type, tokenizer)
seed_everything(42)
query = '浙江的省会在哪里?'
gen = inference_stream(model, template, query)
print(f'query: {query}')
for response, history in gen:print(f'response: {response}')
query = '这有什么好吃的?'
gen = inference_stream(model, template, query, history)
print(f'query: {query}')
for response, history in gen:print(f'response: {response}')
print(f'history: {history}')"""Out[0]
query: 浙江的省会在哪里?
...
response: 浙江省的省会是杭州。
query: 这有什么好吃的?
...
response: 杭州市有很多著名的美食,例如西湖醋鱼、龙井虾仁、糖醋排骨、毛血旺等。此外,还有杭州特色的点心,如桂花糕、荷花酥、艾窝窝等。
history: [('浙江的省会在哪里?', '浙江省的省会是杭州。'), ('这有什么好吃的?', '杭州市有很多著名的美食,例如西湖醋鱼、龙井虾仁、糖醋排骨、毛血旺等。此外,还有杭州特色的点心,如桂花糕、荷花酥、艾窝窝等。')]
"""

        直接说这个代码的结论,首先这个代码是下载和推理一体的代码,当第一次运行的时候,会在指定路径下下载模型文件,第二次运行时检测到指定文件夹下的文件了之后,就会开始进入模型推理阶段,下面的运行输出是我的模型第二次之后运行的结果。

在这里插入图片描述

        第二次运行之后对话输出部分的效果如下,之后我要对流式输出的结果进行改进,一个一个问题解决。

在这里插入图片描述

        可是即便是第二次及之后运行,其不联网依然会报下面的错误,总之该代码不能实现无网络状态下的流方式输出,这也是一个大坑。

在这里插入图片描述

        根据对代码的分析,最后首先我实现了V1版本的代码,代码如下使用swift中的inference_streamAPI进行流式输出,且可以加载本地的自己的模型,这里再print中加入\r换行符会让每次打印的时候光标出现在行的开头,当输出的文字中没有换行的时候,输出的结果岁月静好。

from modelscope import AutoModelForCausalLM, AutoTokenizer
from swift.llm import  inference_stream,get_templatemodel_path = "D:\qwen\Qwen-7B-Chat"tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True)
model = AutoModelForCausalLM.from_pretrained(model_path, device_map="auto", trust_remote_code=True).eval()
template_type = 'qwen'
template = get_template(template_type, tokenizer)
history = Nonewhile True:query = input('User:')gen = inference_stream(model, template, query, history)for response, h in gen:print(f'\rSystem: {response}',end="")history = hprint()

在这里插入图片描述

        当输出内容过长需要换行的时候结果直接负重前行(自己创造的大坑)。

在这里插入图片描述

4.2 真正实现离线的使用本地模型的多轮对话和流式输出的最终代码

        之后改进了V2版本也是最终版本,代码如下,由于这个代码是我自己悟的可能还有不少可以改进的地方,但是已经可以实现预期的的功能,详细的解释我放在后面 首先再次给出swift安装命令。

pip install ms-swift

        代码部分:

from modelscope import AutoModelForCausalLM, AutoTokenizer
from swift.llm import  inference_stream,get_templatemodel_path = "D:\qwen\Qwen-7B-Chat"tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True)
model = AutoModelForCausalLM.from_pretrained(model_path, device_map="auto", trust_remote_code=True).eval()
template_type = 'qwen'
template = get_template(template_type, tokenizer)
history = Nonebefore_len = 0while True:query = input('User:')gen = inference_stream(model, template, query, history)print(f'System:', end="")for response, h in gen:print(response[before_len:],end="")before_len = len(response)history = hprint()

在这里插入图片描述

下面是逐行解释:

  1. from modelscope import AutoModelForCausalLM, AutoTokenizer: 从modelscope库中导入AutoModelForCausalLMAutoTokenizerAutoModelForCausalLM用于加载和使用因果语言模型(如GPT),AutoTokenizer用于文本的分词和编码。

  2. from swift.llm import inference_stream, get_template: 从swift.llm模块中导入inference_streamget_template函数。inference_stream用于生成文本流,get_template用于获取特定类型的模板,这里的模板可能是指模型的输入格式或结构。

  3. model_path = "D:\qwen\Qwen-7B-Chat": 定义模型的存储路径。

  4. tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True): 加载预训练的分词器。from_pretrained方法从指定路径加载模型,trust_remote_code=True允许加载远程代码,这通常用于加载自定义的模型或分词器。

  5. model = AutoModelForCausalLM.from_pretrained(model_path, device_map="auto", trust_remote_code=True).eval(): 加载并准备模型。from_pretrained同样用于从指定路径加载模型,device_map="auto"表示自动选择设备运行模型(如GPU或CPU),trust_remote_code=True同上。.eval()将模型设置为评估模式,通常在预测或评估时使用,以禁用特定于训练的操作如Dropout。

  6. template_type = 'qwen': 定义模板类型,这里为'qwen'

  7. template = get_template(template_type, tokenizer): 获取指定类型的模板。这里的模板可能用于定义输入的格式或者是模型预处理的一部分。

  8. history = None: 初始化历史记录变量,用于存储对话历史,以便模型可以根据之前的交流生成回应。

  9. before_len = 0: 初始化变量,用于记录上一次生成文本的长度。

  10. while True:: 开始一个无限循环,用于连续接收用户输入并生成回应。

  11. query = input('User:'): 接收用户的输入。

  12. gen = inference_stream(model, template, query, history): 调用inference_stream函数,传入模型、模板、用户查询和历史记录,开始生成模型的回应。

  13. print(f'System:', end=""): 打印“System:”,不换行,准备输出模型的回应。

  14. for response, h in gen:: 遍历生成器gen的输出,gen输出的每个元素包含回应和更新后的历史记录。

  15. print(response[before_len:],end=""): 打印新生成的回应部分(去掉之前已经打印的部分),不换行。

  16. before_len = len(response): 更新已打印文本的长度。

  17. history = h: 更新历史记录,以便在下一次迭代时使用。

5.相关文档链接💻

modelscop模型介绍下载地址
https://modelscope.cn/models/qwen/Qwen-7B-Chat/summary
swift文档地址
https://github.com/modelscope/swift/blob/main/docs/source/LLM/LLM%E6%8E%A8%E7%90%86%E6%96%87%E6%A1%A3.md

6.结束😊

        目前这是我出的第一篇大语言模型的部署的文章,之后会考虑一直更新这个系列,会不定期的完善细节,之后会越来越多的补充,如果有什么问题,欢迎留言探讨。有专业需求可以在公众号上联系我。

http://www.khdw.cn/news/23483.html

相关文章:

  • wordpress左上角logo关键词怎么优化到百度首页
  • 做建筑材料哪个网站好一点短视频seo是什么
  • 武汉做网站的德升瑞杰男生技能培训班有哪些
  • 东莞建设年审网站重庆网站制作公司哪家好
  • 做暧暖ox网站谷歌排名优化
  • 北京网站建设公司兴田德润实惠高端网站建设公司
  • 秦皇岛网站制作价格南宁网站seo排名优化
  • 长安网站定制微博营销策略
  • 专业教学资源库网站建设工作黄页88网站推广方案
  • 重庆平台宁波seo推广定制
  • wordpress建站视频长尾关键词查询工具
  • 做网站推广话术郑州免费做网站
  • 网站建设案例2022年传销最新消息
  • 淮南网站建设百度官网首页官网
  • 设计公司网站官网seo推广营销公司
  • 莲都区建设分局网站广告策划方案怎么做
  • 免费网站软件下载秦皇岛seo排名
  • 无锡百度信息流网站seo基础
  • 中企动力做网站好吗上海百度推广优化排名
  • 怎么用ps做简单网站首页兔子bt樱桃搜索磁力天堂
  • 做网站要懂哪些太原seo培训
  • 赣州网站建设案例最近国际时事热点事件
  • 建筑建设网站建设千锋教育的官网
  • 做国际网站有用吗新网
  • 基督网站讲道新年做 新 造人seo知识点
  • txt做网站如何加图片国家卫健委每日疫情报告
  • 微网站功能列表重庆seo点击工具
  • 网站建设的策划方案上海站群优化公司
  • 钱包网站建设友情链接英文
  • 武汉网站营销公司全球中文网站排名