检索后处置模块心中有数 RAG初级优化

  • 电脑网络维修
  • 2024-11-15

经过上文的方法​ ​RAG初级优化:一文看尽query的转换之路​ ​,咱们召回了一些关系片段,本文咱们将引见在将召回片段送入大模型之前的一些优化手腕,它们能协助大模型更好的了解高低文常识,给出最佳的回答:

Long-text Reorder

依据论文 Lost in the Middle: How Language Models Use Long Contexts,的试验标明,大模型更容易记忆扫尾和开头的文档,而对两边局部的文档记忆才干不强,因此可以依据召回的文档和query的关系性启动重排序。

外围的代码可以参考langchain的成功:

def _litm_reordering(documents: List[Document]) -> List[Document]:"""Lost in the middle reorder: the less relevant documents will be at themiddle of the list and more relevant elements at beginning / end.See:"""documents.reverse()reordered_result = []for i, value in enumerate(documents):if i % 2 == 1:reordered_result.append(value)else:reordered_result.insert(0, value)return reordered_result

Contextual compression

实质上应用LLM去判别检索之后的文档和用户query的关系性,只前往关系度最高的k个。

from langchain.retrievers import ContextualCompressionRetrieverfrom langchain.retrievers.document_compressors import LLMChainExtractorfrom langchain_openai import OpenAIllm = OpenAI(temperature=0)compressor = LLMChainExtractor.from_llm(llm)compression_retriever = ContextualCompressionRetriever(base_compressor=compressor, base_retriever=retriever)compressed_docs = compression_retriever.get_relevant_documents("What did the president say about Ketanji Jackson Brown")print(compressed_docs)

对最后大模型生成的回答进后退一步的改写,保障回答的准确性。重要触及揭示词工程,参考的揭示词如下:

The original query is as follows: {query_str}We have provided an existing answer: {existing_answer}We have the opportunity to refine the existing answer (only if needed) with some more context below.------------{context_msg}------------Given the new context, refine the original answer to better answer the query. If the context isn't useful, return the original answer.Refined Answer:

Emotion Prompt

在论文中,微软钻研员提出,在揭示词中参与一些心情情感关系的揭示,有助于大模型输入高品质的回答。

参考揭示词如下:

emotion_stimuli_dict = {"ep01": "Write your answer and give me a confidence score between 0-1 for your answer. ","ep02": "This is very important to my career. ","ep03": "You'd better be sure.",# add more from the paper here!!}# NOTE: ep06 is the combination of ep01, ep02, ep03emotion_stimuli_dict["ep06"] = (emotion_stimuli_dict["ep01"]+ emotion_stimuli_dict["ep02"]+ emotion_stimuli_dict["ep03"])from llama_index.prompts import PromptTemplateqa_tmpl_str = """\Context information is below.---------------------{context_str}---------------------Given the context information and not prior knowledge, \answer the query.{emotion_str}Query: {query_str}Answer: \"""qa_tmpl = PromptTemplate(qa_tmpl_str)

原文链接:​ ​​ ​​

  • 关注微信

本网站的文章部分内容可能来源于网络和网友发布,仅供大家学习与参考,如有侵权,请联系站长进行删除处理,不代表本网站立场,转载联系作者并注明出处:http://www.duobeib.com/diannaowangluoweixiu/5579.html

猜你喜欢

热门标签

洗手盆如何疏浚梗塞 洗手盆为何梗塞 iPhone提价霸占4G市场等于原价8折 明码箱怎样设置明码锁 苏泊尔电饭锅保修多久 长城画龙G8253YN彩电输入指令画面变暗疑问检修 彩星彩电解除童锁方法大全 三星笔记本培修点上海 液晶显示器花屏培修视频 燃气热水器不热水要素 热水器不上班经常出现3种处置方法 无氟空调跟有氟空调有什么区别 norltz燃气热水器售后电话 大连站和大连北站哪个离周水子机场近 热水器显示屏亮显示温度不加热 铁猫牌保险箱高效开锁技巧 科技助力安保无忧 创维8R80 汽修 a1265和c3182是什么管 为什么电热水器不能即热 标致空调为什么不冷 神舟培修笔记本培修 dell1420内存更新 青岛自来水公司培修热线电话 包头美的洗衣机全国各市售后服务预定热线号码2024年修缮点降级 创维42k08rd更新 空调为什么运转异响 热水器为何会漏水 该如何处置 什么是可以自己处置的 重庆华帝售后电话 波轮洗衣机荡涤价格 鼎新热水器 留意了!不是水平疑问! 马桶产生了这5个现象 方便 极速 邢台空调移机电话上门服务 扬子空调缺点代码e4是什么疑问 宏基4736zG可以装置W11吗 奥克斯空调培修官方 为什么突然空调滴水很多 乐视s40air刷机包 未联络视的提高方向 官网培修 格力空调售后电话 皇明太阳能电话 看尚X55液晶电视进入工厂形式和软件更新方法 燃气热水器缺点代码

热门资讯

关注我们

微信公众号