赞
踩
ByteBrain:信息时代您的计算机科学智能知识助手
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
# 导入所需的库 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)
RAG(Retrieval-Augmented Generation):这个名字听起来可能有点复杂,但实际上它就是一个帮助人工智能更好地理解和回答问题的技术。让我们来简单地了解一下RAG是什么以及它是怎么工作的。
RAG 就像是一个人工智能助手的超级记忆功能。通常情况下,AI在回答问题时,会依赖于它之前学习过的大量知识。但是有时候这些知识可能不够全面或者不够新。这时候RAG就派上用场了——它可以让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
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。