使用Ragas自动化评测RAG知识问答系统的各项表现

Hello,大家好呀。

用纯代码手搓了一个RAG本地知识问答系统,使用过程中发现:

如果本地文档文档质量比较高的情况下,答案还是相当不错的

一旦知识库文件质量本身不好,或者知识库文件过多,相似的知识被分散在了不同的块,回答就会出现偏差。

那如何对输出的结果进行测试呢?一种方法是你本身对知识很熟悉,可以人工进行测评;还有一种方法就是,通过AI大模型,让其自己进行自动测评

本篇将介绍使用ragas框架,自动对RAG系统的回答结果进行测评。

老规矩,先看最终效果。

挑选了一篇文章中已经训练好的“信贷业务”这个知识库进行测评,测评的问题集可以自定义;

img

一、重要补充

网上介绍ragas框架的文章有很多,就不在这里赘述,只介绍几个重要的概念,以便我们能实践使用。

ragas官方介绍文档(https://docs.ragas.io/en/stable/concepts/)

\1. ragas的评估维度分为检索环节和生成环节

\2. 检索阶段的指标包括:上下文相关性(Context Relevance)、上下文召回率(Context Recall);通俗点讲,就是要“找得准”。

3.生成环节的指标包括:忠实度(Faithfulness)、答案相关性(Answer Relevance);通俗点讲,就是要“不跑题”、“不瞎编”。

二、实现过程

1、整体规划

1)引入ragas的python包

2)准备评测数据

3)构建评测参数

4)执行评测

5)输出评测报告

2、引入ragas

这一步也很重要,0.2+的版本和之前的版本,写法有很大的区别。要看清自己的版本。

3、准备测评数据

1)测评数据内容: 主要有用户问题、大模型生成的答案、检索上下文和真实答案(人工给出的答案,可以省略)。

2)测评数据获取: 文末扫取微信二维码获得

通过程序获得的核心代码如下:

eval_questions=[],可以设置多个问题;

answers = [],每个问题,大模型给出的答案,也就是问答界面给出的结果,通过rag返回的response.content获得。

contexts = [],这个是检索上下文,通过rag返回的response.source_nodes获得。

在这里插入图片描述

4、构建评估参数

ContextRelevance - 上下文相关性

LLMContextPrecisionWithoutReference - 用户不给出参考答案的情况下,评估内容精确度

Faithfulness - 忠实度

AnswerRelevancy - 答案相关性

关键代码
在这里插入图片描述

5、执行评估

准备好上述一切之后,只需要调用ragas的evaluate方法即可。

核心代码如下:

在这里插入图片描述

6、输出结果报告

可以打印出来,也可以输出markdown格式。

核心代码如下:
在这里插入图片描述

好了,今天ragas自动测评就到这里了,虽然简单、但很重要!就像任何一个系统投产之前需要进行测试一样重要!希望对你有用~

如何零基础入门 / 学习AI大模型?

大模型时代,火爆出圈的LLM大模型让程序员们开始重新评估自己的本领。 “AI会取代那些行业?”“谁的饭碗又将不保了?”等问题热议不断。

不如成为「掌握AI工具的技术人」,毕竟AI时代,谁先尝试,谁就能占得先机!

想正式转到一些新兴的 AI 行业,不仅需要系统的学习AI大模型。同时也要跟已有的技能结合,辅助编程提效,或上手实操应用,增加自己的职场竞争力。

但是LLM相关的内容很多,现在网上的老课程老教材关于LLM又太少。所以现在小白入门就只能靠自学,学习成本和门槛很高

那么我作为一名热心肠的互联网老兵,我意识到有很多经验和知识值得分享给大家,希望可以帮助到更多学习大模型的人!至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

👉 福利来袭CSDN大礼包:《2025最全AI大模型学习资源包》免费分享,安全可点 👈

全套AGI大模型学习大纲+路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!

read-normal-img

640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

👉学会后的收获:👈
基于大模型全栈工程实现(前端、后端、产品经理、设计、数据分析等),通过这门课可获得不同能力;

能够利用大模型解决相关实际项目需求: 大数据时代,越来越多的企业和机构需要处理海量数据,利用大模型技术可以更好地处理这些数据,提高数据分析和决策的准确性。因此,掌握大模型应用开发技能,可以让程序员更好地应对实际项目需求;

• 基于大模型和企业数据AI应用开发,实现大模型理论、掌握GPU算力、硬件、LangChain开发框架和项目实战技能, 学会Fine-tuning垂直训练大模型(数据准备、数据蒸馏、大模型部署)一站式掌握;

能够完成时下热门大模型垂直领域模型训练能力,提高程序员的编码能力: 大模型应用开发需要掌握机器学习算法、深度学习框架等技术,这些技术的掌握可以提高程序员的编码能力和分析能力,让程序员更加熟练地编写高质量的代码。

👉 福利来袭CSDN大礼包:《2025最全AI大模型学习资源包》免费分享,安全可点 👈

img

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量。

<think>嗯,用户想了解怎么用DeepSeek OpenWebUI和Ollama搭建私有的RAG知识库。首先,我得确认这两个工具的作用和它们之间的关系。Ollama应该是在本地运行大模型的工具,而DeepSeek OpenWebUI可能是一个用户界面,用来管理和交互。RAG需要结合检索和生成,所以可能需要向量数据库,比如Chroma或者FAISS。 接下来,得理清步骤。首先,用户需要安装Ollama,然后下载适合的模型,比如llama2或者deepseek的模型。然后安装DeepSeek OpenWebUI,可能需要进行配置,让它连接到Ollama。接着处理文档,转换成向量,存入数据库。最后整合RAG流程,测试整个系统。 可能需要注意的细节:Ollama的安装方法,是否支持Windows还是仅限Linux/macOS。DeepSeek OpenWebUI的配置可能需要修改设置文件,指向本地的Ollama服务。文档处理部分需要分词、向量化,可能需要用到Hugging Face的模型或者sentence-transformers。RAG的实现逻辑,如何结合检索结果生成回答。 用户可能遇到的问题包括环境配置错误,模型下载失败,OpenWebUI无法连接Ollama,或者向量数据库的集成问题。需要确保各服务之间的端口开放,比如Ollama默认的11434端口,OpenWebUI的端口是否冲突。 另外,要提醒用户准备足够的计算资源,尤其是运行本地模型需要较大的内存和显存。如果用户没有GPU,可能需要选择较小的模型或者使用量化版本。最后,测试部分需要验证检索是否正确,生成答案是否相关,可能需要示例代码或者命令。</think>以下为使用DeepSeek OpenWebUI和Ollama搭建私有RAG知识库的完整技术方案: --- ### 一、技术架构组成 $$ \text{RAG系统} = \text{Ollama(大模型)} + \text{DeepSeek OpenWebUI(交互层)} + \text{向量数据库} + \text{文档处理流水线} $$ 其中核心组件版本建议: - Ollama v0.1.25+ - DeepSeek OpenWebUI最新版 - Sentence-Transformers/all-MiniLM-L6-v2(嵌入模型) - Chroma DB(轻量级向量库) --- ### 二、详细搭建步骤 #### 步骤1:部署Ollama ```bash # Linux/macOS安装 curl -fsSL https://ollama.ai/install.sh | sh # 启动服务 ollama serve & # 下载模型(示例) ollama pull llama2:13b-chat # 基础大模型 ollama pull deepseek-ai/deepseek-coder-33b-instruct # 专用领域模型 ``` #### 步骤2:安装OpenWebUI ```bash # 使用Docker部署 docker run -d -p 3000:8080 \ -v openwebui:/app/backend/data \ --add-host=host.docker.internal:host-gateway \ --name openwebui \ ghcr.io/openwebui/openwebui:main # 配置模型连接 修改配置文件指向本地Ollama: API_BASE_URL=http://host.docker.internal:11434 ``` #### 步骤3:文档处理流水线 ```python from langchain.document_loaders import DirectoryLoader from langchain.text_splitter import RecursiveCharacterTextSplitter # 加载文档(支持PDF/DOCX/TXT) loader = DirectoryLoader('/知识库路径', glob="**/*.pdf") docs = loader.load() # 文档分块(数学表达) $$ \text{chunk_size}=512,\ \text{chunk_overlap}=64 $$ splitter = RecursiveCharacterTextSplitter.from_huggingface_tokenizer( tokenizer_name="BAAI/bge-small-en-v1.5", chunk_size=512, chunk_overlap=64 ) chunks = splitter.split_documents(docs) ``` #### 步骤4:向量数据库构建 ```python from langchain.vectorstores import Chroma from langchain.embeddings import HuggingFaceEmbeddings # 嵌入模型选择 embed_model = HuggingFaceEmbeddings( model_name="sentence-transformers/all-MiniLM-L6-v2" ) # 创建向量库 vector_db = Chroma.from_documents( documents=chunks, embedding=embed_model, persist_directory="./chroma_db" ) ``` #### 步骤5:RAG流程集成 ```python from langchain.chains import RetrievalQA from langchain.llms import Ollama # 初始化Ollama连接 llm = Ollama(base_url="http://localhost:11434", model="deepseek-coder-33b") # 构建检索链 qa_chain = RetrievalQA.from_chain_type( llm=llm, retriever=vector_db.as_retriever(search_kwargs={"k": 3}), chain_type="stuff" ) # 查询示例 response = qa_chain.run("如何配置Ollama的GPU加速?") ``` --- ### 三、核心参数优化建议 1. **分块策略优化**: $$ \text{信息密度阈值} = \frac{\text{关键实体数}}{\text{段落长度}} \geq 0.15 $$ 建议通过TF-IDF分析动态调整chunk_size 2. **检索增强参数**: ```yaml retriever: search_type: mmr # 最大边界相关算法 score_threshold: 0.65 fetch_k: 10 ``` 3. **推理参数配置**: ```python Ollama( temperature=0.3, top_p=0.9, num_ctx=4096 # 上下文窗口 ) ``` --- ### 四、验证测试方法 1. **检索有效性测试**: $$ \text{查全率} = \frac{\text{相关段落召回数}}{\text{总相关段落数}} $$ 建议构建测试集验证召回率 > 85% 2. **生成质量评估**: ```python # 使用RAGAS评估框架 from ragas.metrics import faithfulness, answer_relevancy score = evaluate( qa_chain, metrics=[faithfulness, answer_relevancy] ) ``` --- ### 五、常见问题解决方案 | 问题现象 | 排查方向 | 修复方案 | |---------|---------|---------| | OpenWebUI无法连接Ollama | 网络策略检查 | `docker network create ollama-net`并接入同一网络 | | 中文检索效果差 | 嵌入模型适配 | 切换为`text2vec-large-chinese`模型 | | 响应速度慢 | 量化模型 | 使用`llama2:13b-chat-q4_K_M`量化版本 | --- 该方案已在16GB内存+NVIDIA T4 GPU环境验证通过,建议生产环境使用Kubernetes进行容器编排管理。可通过调整chunk_size和检索策略适配不同领域知识库需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值