RAG系列(三):系统评估 - 构造QA测试数据集

引言

我们搭建了一个基础版的 RAG 系统,实现了文档解析和切分 -> 文档向量化存储 -> 用户输入问题 -> 根据问题检索相关知识 -> 将检索到的知识和原问题重新组合成 prompt -> 最后 LLM 根据增强后的 prompt 给出答案。

构造一个基础版的 RAG 系统是非常简单的,借助 LangChain 等框架可快速搭建出完整流程,代码也不会很多,但基础版的问答效果往往比较差,无法直接在实际业务中应用。

要做出一个问答效果更好的 RAG 系统,往往需要结合实际业务场景对这三个模块进行独立优化。

下面这张图是 OpenAI 介绍的 RAG 优化经验,这个准确率随不同的数据集会有不同,但基本上优化后的准确率比优化前有显著提升这个基本上是一致的。

RAG 系统的问答效果是好还是坏是需要经过评估的,而评估就需要高质量的 QA 测试数据集,所谓的 QA 测试数据集,就是一份包含“问题-回答”的测试数据集合。部分系统(如客服系统)是有这方面数据的,但绝大多数情况下是没有的,这时就需要首先构造一批问答数据,这是后续对每一步优化进行验证的基础。

本文将会使用多鲸教育研究院所发布的《2024少儿编程教育行业发展趋势报告》作为文档来构造 QA 测试数据集 ,后续也会围绕针对这个文档的问答效果优化展开。

本文使用通过 ollama 部署 qwen2.5:14b 模型来对《2024少儿编程教育行业发展趋势报告》这个文档进行 QA 测试数据集的构造和质检。

QA 测试数据集构造包含如下3个步骤:

  • • 文档解析与切分:这部分就是对文档进行解析和切分;
  • • 文档片段 QA 构造:这部分就是让 LLM 根据文档片段构造 QA;
  • • QA 质量打分:这部分就是让 LLM 再次对构造的 QA 进行质量评估。

QA 测试数据集已经构造好放在代码库里,大家可以直接使用:

https://github.com/laixiangran/ai-learn/blob/main/src/app/data/qa\_test.xlsx

本文的代码地址:

https://github.com/laixiangran/ai-learn/blob/main/src/app/rag/02\_qa\_extraction/route.ts

下面分步骤讲解下代码实现:

文档解析和切分

这一步做了一个巧妙的设计,就是将每个文档生成一个 uuid,这个 uuid 后续会作为元数据存到向量数据库中,也会和 QA 测试数据集绑定在一起,这样后续在验证检索效果的时候,就可以知道这个问题是否检索到正确的哪个文档。

// 文件解析
const loader = newPDFLoader(
'src/app/data/2024少儿编程教育行业发展趋势报告.pdf',
    {
splitPages: false,
    }
  );
const docs = await loader.load();

// 文件切分
const textSplitter = newRecursiveCharacterTextSplitter({
chunkSize: 500,
chunkOverlap: 50,
  });
const texts = await textSplitter.splitDocuments(docs);
  texts.forEach((text) => {
// 给每个文档生成uuid
    text.metadata.uuid = uuidv4();
  });

// 文档持久化
const baseTextPath = 'src/app/data/doc_base.xlsx';
awaitsaveToExcel(
    texts.map((text) => {
return {
doc: JSON.stringify(text),
      };
    }),
    baseTextPath
  );

LLM 进行 QA 构造

这一步通过 LLM 进行 QA 构造,然后将构造好的 QA 与原始文档和原始文档 uuid 进行绑定。

// 读取切分后的文档
const baseTextData = awaitreadFromExcel(baseTextPath);
  baseTextData.forEach((text) => {
    text.doc = JSON.parse(text.doc);
  });

// QA 数据集抽取
const allData = [];
const errorData = [];
const baseQaPath = `src/app/data/qa_base.xlsx`;
const errorTextPath = `src/app/data/doc_error.xlsx`;
// 本地资源有限,因此单个处理完再处理下一个
while (baseTextData.length > 0) {
const baseText = baseTextData[0];
try {
const { pageContent: document, metadata } = baseText.doc;
const prompt = `
      我会给你一段文本,你需要阅读这段文本,分别针对这段文本生成8个问题、用户回答这个问题的上下文,和基于上下文对问题的回答。

      说明:
      1. 问题要与这段文本相关,不要询问类似“这个问题的答案在哪一章”这样的问题;
      2. 上下文必须与原始文本的内容保持一致,不要进行缩写、扩写、改写、摘要、替换词语等;
      3. 答案请保持完整且简洁,无须重复问题。答案要能够独立回答问题,而不是引用现有的章节、页码等;
      4. 返回结果以JSON形式组织,格式为[{"question": "...", "context": ..., "answer": "..."}, ...];
      5. 如果当前文本主要是目录,或者是一些人名、地址、电子邮箱等没有办法生成有意义的问题时,可以返回[]。

      文本:
${document}

      回答:
      `;
const ollamaLLM = initOllamaLLM();
const res = await ollamaLLM.invoke(prompt);
const regex = newRegExp('\\[(.*?)\\]', 's');
const match = res.content.match(regex);
if (match) {
const data = JSON.parse(`[${match[1]}]`);
        data.forEach((item) => {
          item.doc = document; // 保留原始文档
          item.uuid = metadata.uuid; // 保留原始文档 uuid
        });
        allData.push(data);

// 保存QA数据集
awaitsaveToExcel(allData.flat(), baseQaPath);
        baseTextData.shift();
      }
    } catch (error) {
console.log('error', error);
      errorData.push({ doc: JSON.stringify(baseText.doc) });
awaitsaveToExcel(errorData, errorTextPath);
      baseTextData.shift();
    }
  }

QA 构造样例如下:

LLM 进行 QA 质检

这一步通过 LLM 进行 QA 质量检查,给每个问题和答案进行打分(1-5分),并给出打分的理由。

// QA 数据集质量检查
const checkQaPath = 'src/app/data/qa_grade.xlsx';
const baseQaData = awaitreadFromExcel(baseQaPath);
const allQas = [];
while (baseQaData.length > 0) {
const baseQa = baseQaData[0];
const prompt = `
      你是一个优秀的教师,你的任务是根据问题和参考答案来进行打分。

      说明:
      1. 你需要根据所出的问题以及参考答案进行打分,并给出打分理由,分值是一个int类型的值,取值范围为1-5;
      2. 好的问题,应该是询问事实、观点等,而不是类似于“这一段描述了什么”;
      3. 好的答案,应该能够直接回答问题,而不是给出在原文中的引用,例如“在第3页中”等;
      4. 结果请以JSON形式组织,格式为如下:{"score": ..., "reason": ...}。

      问题:
${baseQa.question}

      参考答案:
${baseQa.answer}

      请打分:
      `;
const ollamaLLM = initOllamaLLM();
const res = await ollamaLLM.invoke(prompt);
const regex = newRegExp('\\{(.*?)\\}', 's');
const match = res.content.match(regex);
if (match) {
const data = JSON.parse(`{${match[1]}}`);
// 保存QA数据集
      allQas.push({ ...baseQa, ...data });
awaitsaveToExcel(allQas, checkQaPath);
    }
    baseQaData.shift();
  }

QA 质检样例如下:

QA 测试数据集构造

这一步从大于 3 分的记录中随机挑选 100 条数据作为后续的 QA 测试数据集。

// 筛选出分数大于3的记录并分为测试数据集和训练集
const data = awaitreadFromExcel(checkQaPath);
const testData = [];
const trainData = [];
  data.forEach((item, i: number) => {
if (item.score > 3) {
if (i % 2 === 0 && testData.length < 100) {
        testData.push(item);
      } else {
        trainData.push(item);
      }
    }
  });
saveToExcel(testData, 'src/app/data/qa_test.xlsx');
saveToExcel(trainData, 'src/app/data/qa_train.xlsx');

QA 测试数据集样例如下:

至此,QA 测试数据集就构造完成,后续 RAG 系统的全链路效果以及各个模块的优化效果,都将基于这个 QA 测试数据集进行。

大模型算是目前当之无愧最火的一个方向了,算是新时代的风口!有小伙伴觉得,作为新领域、新方向人才需求必然相当大,与之相应的人才缺乏、人才竞争自然也会更少,那转行去做大模型是不是一个更好的选择呢?是不是更好就业呢?是不是就暂时能抵抗35岁中年危机呢?

答案当然是这样,大模型必然是新风口!

那如何学习大模型 ?

由于新岗位的生产效率,要优于被取代岗位的生产效率,所以实际上整个社会的生产效率是提升的。但是具体到个人,只能说是:

最先掌握AI的人,将会比较晚掌握AI的人有竞争优势。
这句话,放在计算机、互联网、移动互联网的开局时期,都是一样的道理。

但现在很多想入行大模型的人苦于现在网上的大模型老课程老教材,学也不是不学也不是,基于此我用做产品的心态来打磨这份大模型教程,深挖痛点并持续修改了近100余次后,终于把整个AI大模型的学习路线完善出来!

在这里插入图片描述

在这个版本当中:

您只需要听我讲,跟着我做即可,为了让学习的道路变得更简单,这份大模型路线+学习教程已经给大家整理并打包分享出来, 😝有需要的小伙伴,可以 扫描下方二维码领取🆓↓↓↓

👉优快云大礼包🎁:全网最全《LLM大模型学习资源包》免费分享(安全咨料,放心领取)👈

一、大模型经典书籍(免费分享)

AI大模型已经成为了当今科技领域的一大热点,那以下这些大模型书籍就是非常不错的学习资源

在这里插入图片描述

二、640套大模型报告(免费分享)

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

三、大模型系列视频教程(免费分享)

在这里插入图片描述

四、2025最新大模型学习路线(免费分享)

我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。

img

L1阶段:启航篇丨极速破界AI新时代

L1阶段:了解大模型的基础知识,以及大模型在各个行业的应用和分析,学习理解大模型的核心原理、关键技术以及大模型应用场景。

img

L2阶段:攻坚篇丨RAG开发实战工坊

L2阶段:AI大模型RAG应用开发工程,主要学习RAG检索增强生成:包括Naive RAG、Advanced-RAG以及RAG性能评估,还有GraphRAG在内的多个RAG热门项目的分析。

img

L3阶段:跃迁篇丨Agent智能体架构设计

L3阶段:大模型Agent应用架构进阶实现,主要学习LangChain、 LIamaIndex框架,也会学习到AutoGPT、 MetaGPT等多Agent系统,打造Agent智能体。

img

L4阶段:精进篇丨模型微调与私有化部署

L4阶段:大模型的微调和私有化部署,更加深入的探讨Transformer架构,学习大模型的微调技术,利用DeepSpeed、Lamam Factory等工具快速进行模型微调,并通过Ollama、vLLM等推理部署框架,实现模型的快速部署。

img

L5阶段:专题集丨特训篇 【录播课】

img

全套的AI大模型学习资源已经整理打包,有需要的小伙伴可以微信扫描下方二维码免费领取

👉优快云大礼包🎁:全网最全《LLM大模型学习资源包》免费分享(安全资料,放心领取)👈

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值