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

【书生·浦语大模型实战】“PDF阅读小助手”学习笔记

1 参考资料

《新版本Lmdeploy量化手册与评测》

2 项目资料

项目主页:【tcexeexe / pdf阅读小助手】

3 模型运行测试

在InternStudio平台中选择A100 (1/4)的配置,镜像选择Cuda11.7-conda,可以选择已有的开发机langchain

3.1 创建工作空间

mkdir /root/pdf_project

1.2 Clone项目

git clone https://gitee.com/tcexeexe/pdf-reading-assistant.git

1.3 ⭐创建虚拟项目空间并生成软链接

# 迭代创建虚拟项目空间和model目录
ln -sf /root/pdf_project /home/tcexeexe
# 建立分词数据目录
mkdir -p /root/pdf_project/data/pdf-reading-assistant/data_base/vector_db/pdf

1.4 激活conda环境

conda activate InternLM

1.5 安装PyPDF2库

pip install PyPDF2 pypdf tiktoken transformers_stream_generator

1.6 创建model文件夹:用来存放工具模型

mkdir -p /home/tcexeexe/data/model

1.7 建立分词程序的软链接

ln -sf /root/data/model/sentence-transformer /home/tcexeexe/data/model/sentence-transformer

Note:

  • /home/tcexeexe/data/model/sentence-transformer:此路径来自于make_knowledge_repository.py

1.8 生成PDF知识库

python /root/pdf_project/data/pdf-reading-assistant/make_knowledge_repository.py

以上脚本会生成数据库文件chroma.sqlite3,知识库中指定的文件内容就会存到其中,之前使用的PDF文件就不需要了。

在安装PyPDF2之后仍然会遇到"ModuleNotFoundError: No module named ‘PyPDF2’"的错误

我们猜测这个错误是因为PyPDF2跟pypdf的重复安装导致的,为了验证这个问题,我们可以尝试使用绝对路径运行make_knowledge_repository.py:

/root/.conda/envs/InternLM/bin/python \
/root/pdf_project/data/pdf-reading-assistant/make_knowledge_repository.py

1.9 在InternStudio中上传的PDF文件会被其意外清理

我们在InternStudio上做实验时发现:

InternStudio会不定时地删除上传的PDF文件;

我们咨询了一下队长:
在这里插入图片描述
队长回复说这是InternStudio一种已知的问题;

1.8 运行网页demo

python /root/pdf_project/data/pdf-reading-assistant/web_demo.py

1.9 生成秘钥

ssh-keygen -t rsa

1.10 使用浏览器访问应用

通过网页访问:127.0.0.1:7860

1.11 提问备忘

“提示学习”:来自于《大语言模型提示注入攻击安全风险分析报告》
提示学习是什么

在这里插入图片描述

2 模型部署

2.1 OpenXLab:“相当于浦语体系中的HuggingFace平台”

2.2 更新工具库

python -m pip install --upgrade pip
http://www.lryc.cn/news/288473.html

相关文章:

  • 用ChatGPT写申请文书写进常春藤联盟?
  • uni-app导航栏自定义“返回按钮”多种方法设置原生返回
  • 【kubernets】kubelet证书单独更新
  • 【STM32】STM32学习笔记-硬件SPI读写W25Q64(40)
  • 防御保护---安全策略
  • RustDesk私有化部署,自建远程桌面搭建教程
  • Flutter环境搭建【win10虚拟机】+夜神模拟器【主机】
  • 【数据结构和算法】种花问题
  • Vite+Electron快速构建一个VUE3桌面应用(一)
  • 第二百八十九回
  • Likeshop多商户商城源码系统,支持二开
  • Excel:将截面数据转换成面板数据
  • 209.长度最小的子数组(力扣LeetCode)
  • Docker容器部署OpenCV,打造高效可移植的计算机视觉开发环境
  • 【Linux】Linux系统编程——pwd命令
  • 暴力破解
  • VirtualBox安装Ubuntu22.04
  • 85 总结一下最近遇到的一些 jar发布 相关的知识
  • Vue组件之间的通信方式都有哪些
  • C# 只读文件删除提示失败,给文件修改属性
  • Redis 实际项目中的整合,记录各种用法
  • iOS推送通知
  • 安全产品与等级保护:匹配与选择指南
  • 网络分层和网络原理之UDP和TCP
  • 软件包管理:在CentOS 7中部署Tengine
  • 爬取A站视频,涉及m3u8格式的处理
  • 《微信小程序开发从入门到实战》学习九十四
  • 深度学习记录--Batch Norm
  • svn和git的本质区别是什么
  • Redis面试