书生·浦语大模型全链路开源体系-第2课

这篇具有很好参考价值的文章主要介绍了书生·浦语大模型全链路开源体系-第2课。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

书生·浦语大模型全链路开源体系-第2课

为了推动大模型在更多行业落地应用,让开发人员更高效地学习大模型的开发与应用,上海人工智能实验室重磅推出书生·浦语大模型实战营,为开发人员提供大模型学习和开发实践的平台。
本文是书生·浦语大模型全链路开源体系-第2课的课程实战。

相关资源

  • InternLM项目地址

https://github.com/InternLM/InternLM

  • InternLM2技术报告

https://arxiv.org/pdf/2403.17297.pdf

  • 书生·万卷 数据

https://opendatalab.org.cn/

  • 课程链接

https://www.bilibili.com/video/BV1AH4y1H78d/

实战部署InternLM2-Chat-1.8B模型

准备环境

首先,通过Intern Studio进入开发机,进入开发机后,在Terminal中输入环境配置命令,配置一个新的环境,激活虚拟环境,安装必要的依赖包。

studio-conda -o internlm-base -t demo
conda activate demo

pip install huggingface-hub==0.17.3
pip install transformers==4.34
pip install psutil==5.9.8
pip install accelerate==0.24.1
pip install streamlit==1.32.0
pip install matplotlib==3.8.3
pip install modelscope==1.9.5
pip install sentencepiece==0.1.99

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

下载模型

创建路径,用于存放案例涉及的所有材料。

mkdir -p /root/demo
cd /root/demo

创建文件download_mini.py,用于下载模型。

import os
from modelscope.hub.snapshot_download import snapshot_download

# 创建保存模型目录
os.system("mkdir /root/models")

# save_dir是模型保存到本地的目录
save_dir="/root/models"

snapshot_download("Shanghai_AI_Laboratory/internlm2-chat-1_8b", 
                  cache_dir=save_dir, 
                  revision='v1.1.0')

执行命令,下载模型。

python download_mini.py

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

运行案例

创建文件cli_demo.py,用于运行案例。

import torch
from transformers import AutoTokenizer, AutoModelForCausalLM


model_name_or_path = "/root/models/Shanghai_AI_Laboratory/internlm2-chat-1_8b"

tokenizer = AutoTokenizer.from_pretrained(model_name_or_path, trust_remote_code=True, device_map='cuda:0')
model = AutoModelForCausalLM.from_pretrained(model_name_or_path, trust_remote_code=True, torch_dtype=torch.bfloat16, device_map='cuda:0')
model = model.eval()

system_prompt = """You are an AI assistant whose name is InternLM (书生·浦语).
- InternLM (书生·浦语) is a conversational language model that is developed by Shanghai AI Laboratory (上海人工智能实验室). It is designed to be helpful, honest, and harmless.
- InternLM (书生·浦语) can understand and communicate fluently in the language chosen by the user such as English and 中文.
"""

messages = [(system_prompt, '')]

print("=============Welcome to InternLM chatbot, type 'exit' to exit.=============")

while True:
    input_text = input("\nUser  >>> ")
    input_text = input_text.replace(' ', '')
    if input_text == "exit":
        break

    length = 0
    for response, _ in model.stream_chat(tokenizer, input_text, messages):
        if response is not None:
            print(response[length:], flush=True, end="")
            length = len(response)

执行程序。

python cli_demo.py

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

实战部署InternLM2-Chat-7B模型

准备环境

首先,通过Intern Studio进入开发机,进入开发机后,在Terminal中输入环境配置命令,配置一个新的环境。

bash /root/share/install_conda_env_internlm_base.sh internlm-demo

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

环境自动配置完成后,通过命令激活新的虚拟环境。

conda activate internlm-demo

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

在虚拟环境中,安装必要的依赖包。

python -m pip install --upgrade pip
pip install modelscope==1.9.5
pip install transformers==4.35.2
pip install streamlit==1.32.0
pip install sentencepiece==0.1.99
pip install accelerate==0.24.1

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

下载模型及案例代码

在开发机中的/root/share目录下,默认已经为我们下载好了常用的模型,直接复制即可,无需重复下载。复制模型、下载案例代码。

mkdir -p /root/model/InternLM
cp -r /root/share/temp/model_repos/internlm-chat-7b /root/model/InternLM/
mkdir -p /root/code
cd /root/code
git clone https://gitee.com/internlm/InternLM.git
cd InternLM
git checkout 3028f07cb79e5b1d7342f4ad8d11efad3fd13d17

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

运行cli案例代码

创建文件cli_demo.py,用于运行案例,将代码中的模型路径指定到新复制的模型目录。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

运行web案例代码

除了在控制台运行案例代码,还可以直接运行web_demo.py,运行之前将代码中的模型路径指定到新复制的模型目录。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

切换到VSCode界面,并通过命令行运行命令启动程序。

streamlit run web_demo.py --server.address 127.0.0.1 --server.port 6006

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

配置SSH公钥信息

由于开发机没有提供独立的公网IP地址,并且程序启动地址是127.0.0.1,因此无法通过本地浏览器直接访问开发机中启动的程序,需要通过隧道方式进行访问。首先,配置SSH公钥。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

将新生成的公钥信息添加到Intern Studio中。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

配置SHH隧道连接

公钥信息添加成功后,可以通过SSH信息查看开发机对应的端口信息。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

通过以下命令,建立本地客户端与云端开发机之间的隧道连接。

ssh -CNg -L 6006:127.0.0.1:6006 root@ssh.intern-ai.org.cn -p 40314

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

最后,通过浏览器访问案例。

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

熟悉 Huggingface 下载功能

使用 huggingface_hub Python 包,下载 InternLM2-Chat-7B 的 config.json 文件到本地。

通过代码下载指定文件

创建文件download_model.py,通过以下代码,下载模型中的指定文件。

import os
from huggingface_hub import hf_hub_download

# 创建保存模型目录
os.system("mkdir /root/models")

# save_dir是模型保存到本地的目录
save_dir="/root/models"

hf_hub_download(repo_id="internlm/internlm2-chat-7b", cache_dir=save_dir, filename="config.json")

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

使用命令下载全部文件

export HF_ENDPOINT=https://hf-mirror.com
huggingface-cli download --resume-download --local-dir-use-symlinks False internlm/internlm2-chat-7b --local-dir /root/cache/huggingface/hub/internlm/internlm2-chat-7b

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

Lagent 工具调用

cd /root/code
git clone https://gitee.com/internlm/lagent.git
cd lagent
git checkout 581d9fb8987a5d9b72bb9ebd37a95efd47d479ac
pip install -e .

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

streamlit run examples/internlm2_agent_web_demo_hf.py --server.address 127.0.0.1 --server.port 6006

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

浦语·灵笔2 的 图文创作 及 视觉问答 部署

图文创作

pip install timm==0.4.12 sentencepiece==0.1.99 markdown2==2.4.10 xlsxwriter==3.1.2 gradio==4.13.0 modelscope==1.9.5

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

git clone https://gitee.com/internlm/InternLM-XComposer.git
cd /root/code/InternLM-XComposer
git checkout f31220eddca2cf6246ee2ddf8e375a40457ff626
mkdir -p /root/models
ln -s /root/share/new_models/Shanghai_AI_Laboratory/internlm-xcomposer2-7b /root/models/internlm-xcomposer2-7b
ln -s /root/share/new_models/Shanghai_AI_Laboratory/internlm-xcomposer2-vl-7b /root/models/internlm-xcomposer2-vl-7b

python examples/gradio_demo_composition.py \
--code_path /root/models/internlm-xcomposer2-7b \
--private \
--num_gpus 1 \
--port 6006

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能

视觉问答图片理解实战

cd /root/code/InternLM-XComposer
python examples/gradio_demo_chat.py  \
--code_path /root/models/internlm-xcomposer2-vl-7b \
--private \
--num_gpus 1 \
--port 6006

书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能
书生·浦语大模型全链路开源体系-第2课,人工智能,开源,大模型,人工智能文章来源地址https://www.toymoban.com/news/detail-850108.html

到了这里,关于书生·浦语大模型全链路开源体系-第2课的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 书生·浦语大模型全链路开源体系【大模型第2课-笔记】

    1.1 什么是大模型?   大模型通常指的是机器学习或人工智能领域中参数数量巨大、拥有庞大计算能力和参数规模的模型。这些模型利用大量数据进行训练,并且拥有数十亿甚至数千亿个参数。大模型的出现和发展得益于增长的数据量、计算能力的提升以及算法优化等因素

    2024年01月19日
    浏览(93)
  • 【 书生·浦语大模型实战营】学习笔记(一):全链路开源体系介绍

    🎉 AI学习星球推荐: GoAI的学习社区 知识星球是一个致力于提供《机器学习 | 深度学习 | CV | NLP | 大模型 | 多模态 | AIGC 》各个最新AI方向综述、论文等成体系的学习资料,配有全面而有深度的专栏内容,包括不限于 前沿论文解读、资料共享、行业最新动态以、实践教程、求

    2024年04月23日
    浏览(40)
  • 【AI大模型开发者指南】书生·浦语大模型全链路开源体系

    https://intern-ai.org.cn/home https://github.com/InternLM 书生·浦语 - 语言大模型来自上海ailab、商汤科技,是国内领先的AI相关开源社区 其中许多开发者都来自OpenMMLab,相信接触过cv领域的朋友或多或少都使用过旗下的产品,例如mmpretrain、mmdet、mmseg等一系列开箱即用的cv炼丹框架。 可以

    2024年04月09日
    浏览(83)
  • 《书生·浦语大模型全链路开源开放体系》第五课作业 LMDeploy 的量化和部署

    使用 LMDeploy 以本地对话、网页Gradio、API服务中的一种方式部署 InternLM-Chat-7B 模型,生成 300 字的小故事(需截图) 这一部分主要涉及本地推理和部署。我们先看一张图。 我们把从架构上把整个服务流程分成下面几个模块。 模型推理/服务。主要提供模型本身的推理,一般来说

    2024年03月09日
    浏览(57)
  • 《书生·浦语大模型全链路开源开放体系》笔记第五课 LMDeploy 的量化和部署

    首先我们可以使用  vgpu-smi  查看显卡资源使用情况。 可以点击终端(TERMINAL)窗口右侧的「+」号创建新的终端窗口。大家可以新开一个窗口,执行下面的命令实时观察 GPU 资源的使用情况。 结果如下图所示,该窗口会实时检测 GPU 卡的使用情况。 接下来我们切换到刚刚的终

    2024年01月21日
    浏览(52)
  • 书生浦语大模型--开源体系

    一、大模型的发展   大模型与通用人工智能(AGI),大模型通常被视为发展通用人工智能的重要途径。AI研究从专用模型向通用模型转变,在过去的一二十年中,研究重点在于针对特定任务的专用模型。 专用模型的已经再多个领域取得显著成就,包裹大规模语音识别、图像识

    2024年01月20日
    浏览(51)
  • 书生·浦语大模型开源体系(二)笔记

    💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互

    2024年04月09日
    浏览(88)
  • 书生·浦语大模型开源体系(四)笔记

    💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互

    2024年04月28日
    浏览(30)
  • 书生·浦语:大模型全链路开源体系(二)——InternLM、Lagent、浦语·灵笔Demo调用

    pip、conda换源: pip临时换源: 设置pip默认源,避免每次下载依赖包都要加上一长串的国内源 conda换源: 镜像站提供了 Anaconda 仓库与第三方源(conda-forge、msys2、pytorch 等),各系统都可以通过修改用户目录下的  .condarc  文件来使用镜像站。 不同系统下的  .condarc  目录如下

    2024年02月02日
    浏览(41)
  • 书生.浦语大模型实战一

    从专用模型到通用大模型 书生.万卷1.0 文本 图像-文本 视频数据 OpenDataLab开放平台 图像:ImageNet tokens语料:WikiQA 音频 视频:MovieNet 3D模型 增量续训 使用场景:让基座模型学习到一些新知识,如某个垂类领域知识 训练数据:文章、书籍、代码等 有监督微调 使用场景:让模型

    2024年01月16日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包