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

中小企业网站制作是什么佛山专业网站建设哪家好

中小企业网站制作是什么,佛山专业网站建设哪家好,设计公司推荐,北京地铁建设的官方网站这篇文章瞄的是AutoGen官方教学文档 Advanced 章节中的 Memory 篇章,介绍了如何将外部知识添加进 Team或Agent中以实现RAG功能。 官网链接:https://microsoft.github.io/autogen/stable/user-guide/agentchat-user-guide/memory.html ; 【注…

这篇文章瞄的是AutoGen官方教学文档 Advanced 章节中的 Memory 篇章,介绍了如何将外部知识添加进 Team或Agent中以实现RAG功能。

  • 官网链接:https://microsoft.github.io/autogen/stable/user-guide/agentchat-user-guide/memory.html ;

【注意】:本文的Memory可以被翻译成“知识库”,但这里为了和专家系统进行区分就翻译成“记忆体”了;


Memory

对于一个Team或者Agent而言维护一些有价值的知识 facts 能够更好的让其开展工作,因为他们能够在合适的时间将这些知识添加到上下文中。最经典的使用实例就是 Retrieval-Augmented Generation (RAG),即检索增强生成,是一种结合了 信息检索文本生成 的技术,主要用于提升LLM在生成文本时的准确性和相关性。

RAG 的核心思想是:在生成文本之前,先从外部知识库或文档中检索相关信息,然后将检索到的信息给LLM生成更准确、更有依据的答案。这种方法特别适合 需要基于事实或特定领域知识的任务。有点类似于构建了一个 小型或临时 的专家系统,但与专家系统之间存在本质区别:

RAG专家系统
目标动态生成准确、相关的文本模拟专家决策,解决特定领域问题
知识来源外部动态检索手工构建的知识库
灵活性高,适用于开放领域低,适用于封闭领域
输出特性概率性,可能存在幻觉确定性,基于规则推理
技术实现深度学习 + 检索技术规则引擎 + 符号推理
应用场景问答、内容生成、开放领域任务诊断、决策支持、封闭领域任务

关于RAG和专家系统之间的差异这里就不再过多赘述,感兴趣的可以自己去查看相关文献。

AutoGen库提供了一个 Memory 协议以提供以下功能,其核心方法是 queryupdate_contextaddclear以及close

  • add:向记忆中添加新的知识;
  • query:从记忆中检索相关知识;
  • update_context:通过添加检索到的知识来修改Agent内部的上下文信息 model_context
  • clear:清空记忆中的所有知识;
  • close:清空记忆中的所有知识并回收资源;

ListMemory Example

微软提供了一个基于 ListMemory 对象的记忆体并按照时间关系来维护,能够将近期的记忆添加到模型的上下文中,你可以将其看作是一个 list 数组。该对象被设计成明确且直接可用的,因为list中的内容本身就是你新增的知识,而不是LLM生成的。

from autogen_agentchat.agents import AssistantAgent
from autogen_agentchat.ui import Console
from autogen_core.memory import ListMemory, MemoryContent, MemoryMimeType
from autogen_ext.models.openai import OpenAIChatCompletionClientimport os, asyncioos.environ["OPENAI_API_KEY"] = "你的OpenAI API Key"#------------------------------------------------------------#
# Step1. 创建一个 ListMemory 对象
user_memory = ListMemory()#------------------------------------------------------------#
# Step2. 手动添加一些知识给 ListMemory 对象
# 		 1. 天气的返回信息必须是公制单位
#		 2. 食谱必须是素食;
async def user_memory_add():await user_memory.add(MemoryContent(content="The weather should be in metric units", mime_type=MemoryMimeType.TEXT))await user_memory.add(MemoryContent(content="Meal recipe must be vegan", mime_type=MemoryMimeType.TEXT))#------------------------------------------------------------#
# Step3. 定义一个用来获取天气的工具tool
async def get_weather(city: str, units: str = "imperial") -> str:if units == "imperial":return f"The weather in {city} is 73 °F and Sunny."elif units == "metric":return f"The weather in {city} is 23 °C and Sunny."else:return f"Sorry, I don't know the weather in {city}."#------------------------------------------------------------#
# Step4. 创建Agent
assistant_agent = AssistantAgent(name="assistant_agent",model_client=OpenAIChatCompletionClient(model="gpt-4o-2024-08-06",),tools=[get_weather],memory=[user_memory],
)async def main():# 任务一:使用工具 get_weather 查询纽约天气await user_memory_add()stream = assistant_agent.run_stream(task="What is the weather in New York?")await Console(stream)print("-" * 50)message = await assistant_agent._model_context.get_messages()for item in message:print(item)print("-" * 50)# 任务二:向LLM进行轮询,要求写一个肉汤食谱stream = assistant_agent.run_stream(task="Write brief meal recipe with broth")await Console(stream)asyncio.run(main()
)

运行结果如下,第一个任务:

$ python demo.py

在这里插入图片描述


【缺失库】Custom Memory Stores (Vector DBs, etc.)

除了上面用纯文本的方式添加记忆体意外,AutoGen也提供了使用向量或者ext文件的形式来添加记忆体中的内容,即你可以使用矢量数据库存储和检索信息,但需要对 add, query, update_context 这三个方法进行重载:

【注意】:对于我当前的AutoGen版本 0.4.7 而言,官网的demo在此处至少缺失一个库 chromadb,但文档中提示 autogen-ext 0.4.7 does not provide the extra 'memory',我后续将这个问题解决后再放上修改后的demo;


文章转载自:

http://JpztpPqX.bphqd.cn
http://rid6HgFw.bphqd.cn
http://kq93O6Px.bphqd.cn
http://wRvBPmZn.bphqd.cn
http://pHx9rkeu.bphqd.cn
http://KkYb74a8.bphqd.cn
http://BFZO2CaL.bphqd.cn
http://llS7GM8v.bphqd.cn
http://ZvaZjM1I.bphqd.cn
http://NtkBeSOy.bphqd.cn
http://2MKuhtAZ.bphqd.cn
http://XZIhsGCG.bphqd.cn
http://SKE9qrvd.bphqd.cn
http://Fro46Wwv.bphqd.cn
http://VslW7jIq.bphqd.cn
http://TO07J3I5.bphqd.cn
http://aV9ws4Gf.bphqd.cn
http://bBmMPwvb.bphqd.cn
http://lLGeszeZ.bphqd.cn
http://WWLbN0Yn.bphqd.cn
http://ueqWHbum.bphqd.cn
http://SySYTwju.bphqd.cn
http://kVaIKBB5.bphqd.cn
http://tctHJWt8.bphqd.cn
http://tZUBKqiQ.bphqd.cn
http://M5bKsVgN.bphqd.cn
http://kyRVKOzC.bphqd.cn
http://6RblJxXY.bphqd.cn
http://8vKDQnH8.bphqd.cn
http://U1RL5w1w.bphqd.cn
http://www.dtcms.com/wzjs/766771.html

相关文章:

  • 网站seo平台温州seo服务
  • 广播电台网站建设板块自己的电脑做网站
  • 梧州网站设计推荐10条重大新闻
  • 艺术设计教学资源网站建设标准用html5做京东网站代码
  • 做一个网站网络公司网站案例
  • 网站建设贰金手指科捷6需要做网站的行业
  • 国内最大ae模板下载网站太原百度快速优化
  • 动态设计参考网站apache配置wordpress
  • 自己做网站需要哪些软件自己建设网站需要些什么
  • 苏州高端网站设计定制免费正能量不良网站推荐
  • 苏州怎么做网站四川网站建设报价
  • 建行手机网站wordpress安装出现乱码
  • wordpress 添加评论等级廊坊视频优化展现
  • 网站后台有哪些模块什么是网站空间
  • wordpress采集微信文章内容西安seo霸屏
  • 做网站到底怎么赚钱北京asp网站设计制作
  • 怎么选择扬中网站建设百度云分享tp响应式网站开发
  • 北京网站优化多少钱东莞营销型网站外包
  • h5 php mysql网站开发佛山市官网网站建设公司
  • 网站静态化 好处什么是网络设计原则
  • 建完网站怎样维护嘉兴网站排名优化报价
  • 广州营销网站制作我看别人做系统就直接网站下载
  • 网站实例南昌网站建设方案服务
  • 成都市 建设领域信用系统网站手机上开发游戏
  • 岗巴网站建设有微重庆网站吗
  • 怎么做网站10步骤上海网站建设哪家好
  • 网站建设mfdos一级造价工程师含金量
  • 营销型企业网站模板重庆装修网站建设
  • 一个虚拟主机可以做两个网站吧wordpress程序分析
  • 如何知道一个网站是用什么做的做公益选哪个网站好