当前位置:   article > 正文

ByteBrain-大模型应用开发 #Datawhale AI 夏令营_类似 魔搭平台 免费实例

类似 魔搭平台 免费实例

ByteBrain:信息时代您的计算机科学智能知识助手


一键部署体验

魔塔社区
我的NoteBook
魔搭平台免费实例
个人云账号授权实例
PAI-DSW
启动!!!
PAI-DSW
GPU环境

1、个人云账号授权实例:可以开通阿里云PAI-DSW试用,时长三个月
2、魔塔平台免费实例:注册并绑定阿里云账号试用GPU,时长100h

#JupyterLab->Other->Terminal->Ctrl+V
git clone https://github.com/Stars-niu/ByteBrain.git
pip install streamlit==1.24.0
cd ByteBrain
streamlit run app.py --server.address 127.0.0.1 --server.port 1001
  • 1
  • 2
  • 3
  • 4
  • 5

问题注意:

  • app.py根据使用的版本自行更换
  • 重复打开应用时,可以更换监听端口的四个数字(即1001),如果出现某端口已占用的情况。补充:127.0.0.1:表示服务器只监听本地回环地址,也就是说,只有在本机上的浏览器才能访问这个应用。(如果你想让其他设备也能访问,可以设置为 0.0.0.0) 1001:这个选项指定了Streamlit服务器监听的端口。这里设置为 1001,意味着应用程序将在 http://127.0.0.1:1001 地址上运行。

Baseline

# 导入所需的库
from transformers import AutoTokenizer, AutoModelForCausalLM
import torch
import streamlit as st

# 创建一个标题和一个副标题
st.title("✨ ByteBrain")

# 源大模型下载
from modelscope import snapshot_download
model_dir = snapshot_download('IEITYuan/Yuan2-2B-Mars-hf', cache_dir='./')
# model_dir = snapshot_download('IEITYuan/Yuan2-2B-July-hf', cache_dir='./')

# 定义模型路径
path = './IEITYuan/Yuan2-2B-Mars-hf'
# path = './IEITYuan/Yuan2-2B-July-hf'

# 定义模型数据类型
torch_dtype = torch.bfloat16 # A10
# torch_dtype = torch.float16 # P100

# 定义一个函数,用于获取模型和tokenizer
@st.cache_resource
def get_model():
    print("创建tokenizer...")
    tokenizer = AutoTokenizer.from_pretrained(path, add_eos_token=False, add_bos_token=False, eos_token='<eod>')
    tokenizer.add_tokens(['<sep>', '<pad>', '<mask>', '<predict>', '<FIM_SUFFIX>', '<FIM_PREFIX>', '<FIM_MIDDLE>','<commit_before>','<commit_msg>','<commit_after>','<jupyter_start>','<jupyter_text>','<jupyter_code>','<jupyter_output>','<empty_output>'], special_tokens=True)

    print("创建模型...")
    model = AutoModelForCausalLM.from_pretrained(path, torch_dtype=torch_dtype, trust_remote_code=True).cuda()

    print("完成.")
    return tokenizer, model

# 加载model和tokenizer
tokenizer, model = get_model()

# 初次运行时,session_state中没有"messages",需要创建一个空列表
if "messages" not in st.session_state:
    st.session_state["messages"] = []

# 每次对话时,都需要遍历session_state中的所有消息,并显示在聊天界面上
for msg in st.session_state.messages:
    st.chat_message(msg["role"]).write(msg["content"])

# 如果用户在聊天输入框中输入了内容,则执行以下操作
if prompt := st.chat_input("请输入您的问题:"):
    # 将用户的输入添加到session_state中的messages列表中
    st.session_state.messages.append({"role": "user", "content": prompt})

    # 在聊天界面上显示用户的输入
    st.chat_message("user").write(prompt)

    # 调用模型
    prompt = "<n>".join(msg["content"] for msg in st.session_state.messages) + "<sep>" # 拼接对话历史
    inputs = tokenizer(prompt, return_tensors="pt")["input_ids"].cuda()
    outputs = model.generate(inputs, do_sample=False, max_length=1024) # 设置解码方式和最大生成长度
    output = tokenizer.decode(outputs[0])
    response = output.split("<sep>")[-1].replace("<eod>", '')

    # 将模型的输出添加到session_state中的messages列表中
    st.session_state.messages.append({"role": "assistant", "content": response})

    # 在聊天界面上显示模型的输出
    st.chat_message("assistant").write(response)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65

2.0版本(引入RAG方法)

RAG(Retrieval-Augmented Generation):这个名字听起来可能有点复杂,但实际上它就是一个帮助人工智能更好地理解和回答问题的技术。让我们来简单地了解一下RAG是什么以及它是怎么工作的。

RAG 是什么

RAG 就像是一个人工智能助手的超级记忆功能。通常情况下,AI在回答问题时,会依赖于它之前学习过的大量知识。但是有时候这些知识可能不够全面或者不够新。这时候RAG就派上用场了——它可以让AI在回答问题的时候去查找最新的信息,就像我们人类在回答问题前会去查阅资料一样。

RAG 怎么工作

想象一下,如果你要写一篇关于恐龙的文章,你会怎么做?你可能会先回忆自己知道的一些基本事实,然后去图书馆或者上网找一些最新的研究资料来丰富你的文章。RAG的工作原理和这个很相似:

  • 理解问题:首先,AI需要理解用户提出的问题是什么意思。
  • 搜索信息:接下来,AI会在数据库中查找与问题相关的最新信息。这就像你去图书馆或者上网查资料。
  • 整合信息:找到相关信息后,AI会把这些信息和它已有的知识结合起来,形成一个更完整的答案。
  • 生成回答:最后,AI会根据整合好的信息来生成一个回答,这样就能提供准确且最新的答案给用户了。

为什么需要 RAG

有时候,传统的AI模型可能不知道最新的数据或者事件,比如新的科学研究发现、新闻报道等。有了RAG的帮助,AI就可以实时地获取这些信息,并利用它们来生成更准确的回答。
举个例子来说,如果有人问:“谁是当前世界上最富有的人?”没有RAG的AI可能会给出一个几年前的答案,而有RAG的AI则会去查找最新的财富排行榜来给出最新的名字。
总的来说,RAG就像是给AI装上了“即时更新”的功能,让它们能够更好地适应不断变化的信息环境,从而提供更加准确和有用的答案。


# 导入所需的库
import streamlit as st
from modelscope import snapshot_download
from typing import List
import numpy as np
import torch
from transformers import AutoModel, AutoTokenizer, AutoModelForCausalLM
import os

# 设置CUDA环境变量
os.environ["CUDA_LAUNCH_BLOCKING"] = "1"

# 设置页面配置
st.set_page_config(
    page_title="ByteBrain",
    page_icon="
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小桥流水78/article/detail/1004444
推荐阅读
相关标签