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

做网站和制作网页的区别北京朝阳区最好的小区

做网站和制作网页的区别,北京朝阳区最好的小区,企业年金辞职了就白交了吗,做视频的网站多少钱文章目录 一、概述二、获取最后的 max_tokens 令牌三、获取第一个 max_tokens 令牌四、编写自定义令牌计数器五、连成链六、使用 ChatMessageHistory 一、概述 所有模型都有 有限的 上下文窗口#xff0c;这意味着它们可以作为输入的 token 数量是有限的。如果你有很长的消息这意味着它们可以作为输入的 token 数量是有限的。如果你有很长的消息或者一个 chain 或 agent 累积了很长的 历史消息你需要管理你传递给模型的消息的长度。  trim_messages util 提供了一些基本策略用于将消息列表修剪为特定的 token 长度。 二、获取最后的 max_tokens 令牌 为了获取消息列表中的最后一个 max_tokens我们可以设置 strategy“last”。请注意对于我们的 token_counter我们可以将其传入到一个函数 (下面将详细介绍) 或一个语言模型 (因为语言模型有一个消息令牌计数方法) 中。当调整消息以适应特定模型的上下文窗口时将其传入到模型是有意义的 # pip install -U langchain-openai from langchain_core.messages import (AIMessage,HumanMessage,SystemMessage,trim_messages, ) from langchain_openai import ChatOpenAImessages [SystemMessage(youre a good assistant, you always respond with a joke.),HumanMessage(i wonder why its called langchain),AIMessage(Well, I guess they thought WordRope and SentenceString just didn\t have the same ring to it!),HumanMessage(and who is harrison chasing anyways),AIMessage(Hmmm let me think.\n\nWhy, hes probably chasing after the last cup of coffee in the office!),HumanMessage(what do you call a speechless parrot), ]trim_messages(messages,max_tokens45,strategylast,token_counterChatOpenAI(modelgpt-4o), )如果我们想始终保留初始系统消息我们可以指定 include_systemTrue  如果我们想允许拆分消息的内容我们可以指定 allow_partialTrue  如果我们需要确保我们的第一条消息 (不包括 SystemMessage) 始终是特定类型的我们可以指定 start_on trim_messages(messages,max_tokens60,strategylast,token_counterChatOpenAI(modelgpt-4o),include_systemTrue,start_onhuman, )三、获取第一个 max_tokens 令牌 我们可以通过指定 strategy“first” 来执行获取第一个 max_tokens 的翻转操作 trim_messages(messages,max_tokens45,strategyfirst,token_counterChatOpenAI(modelgpt-4o), )四、编写自定义令牌计数器 我们可以编写一个自定义令牌计数器函数该函数接收消息列表并返回一个整数。 from typing import List # pip install tiktoken import tiktoken from langchain_core.messages import BaseMessage, ToolMessagedef str_token_counter(text: str) - int:enc tiktoken.get_encoding(o200k_base)return len(enc.encode(text))def tiktoken_counter(messages: List[BaseMessage]) - int:Approximately reproduce https://github.com/openai/openai-cookbook/blob/main/examples/How_to_count_tokens_with_tiktoken.ipynbFor simplicity only supports str Message.contents.num_tokens 3 # every reply is primed with |start|assistant|message|tokens_per_message 3tokens_per_name 1for msg in messages:if isinstance(msg, HumanMessage):role userelif isinstance(msg, AIMessage):role assistantelif isinstance(msg, ToolMessage):role toolelif isinstance(msg, SystemMessage):role systemelse:raise ValueError(fUnsupported messages type {msg.__class__})num_tokens (tokens_per_message str_token_counter(role) str_token_counter(msg.content))if msg.name:num_tokens tokens_per_name str_token_counter(msg.name)return num_tokenstrim_messages(messages,max_tokens45,strategylast,token_countertiktoken_counter, )定义 str_token_counter 函数 该函数接受一个字符串 text 并返回该字符串的令牌数量。使用 tiktoken.get_encoding(“o200k_base”) 获取编码器然后使用 enc.encode(text) 将文本编码为令牌并返回令牌的长度。 定义 tiktoken_counter 函数 该函数接受一个 BaseMessage 类型的消息列表 messages 并返回总的令牌数量。由于每个回复都以 |start|assistance|message| 开头所以每个消息列表初始都默认有 3 个 token每个消息有一个基本的令牌数 tokens_per_message每个 name 属性预设的固定令牌数 tokens_per_name假设其值为 1。函数通过迭代消息列表并根据消息的角色 (如 user、assistant、tool、system) 计算令牌数量。根据消息的 tokens_per_message、role、content计算总的令牌数。如果遇到不支持的消息类型会引发 ValueError。对于每个消息如果消息对象 msg 有 name 属性 (即 msg.name 不为 None 或空)那么就要计算该 name 属性所包含的令牌数量并将其加入到总令牌数 num_tokens 中。 调用 trim_messages 函数 (假设定义在其他地方) messages要处理的消息列表。max_tokens45最大允许的令牌数。strategy“last”修剪策略 (假设修剪最后的消息)。token_countertiktoken_counter用于计算令牌数的函数。 五、连成链 trim_message可以以命令式如上所述或声明式的方式使用从而便于与链中的其他组件组合。 llm ChatOpenAI(modelgpt-4o)# Notice we dont pass in messages. This creates # a RunnableLambda that takes messages as input trimmer trim_messages(max_tokens45,strategylast,token_counterllm,include_systemTrue, )chain trimmer | llm chain.invoke(messages)查看 LangSmith 跟踪我们可以看到在消息传递到模型之前它们首先被修剪。  如果只看 trimer我们可以看到它是一个Runnable对象可以像所有Runnables一样被调用 trimmer.invoke(messages)六、使用 ChatMessageHistory 在处理聊天历史记录时修剪消息特别有用因为聊天历史记录可能会变得任意长 from langchain_core.chat_history import InMemoryChatMessageHistory from langchain_core.runnables.history import RunnableWithMessageHistorychat_history InMemoryChatMessageHistory(messagesmessages[:-1])def dummy_get_session_history(session_id):if session_id ! 1:return InMemoryChatMessageHistory()return chat_historyllm ChatOpenAI(modelgpt-4o)trimmer trim_messages(max_tokens45,strategylast,token_counterllm,include_systemTrue, )chain trimmer | llm chain_with_history RunnableWithMessageHistory(chain, dummy_get_session_history) chain_with_history.invoke([HumanMessage(what do you call a speechless parrot)],config{configurable: {session_id: 1}}, )第四行创建一个 InMemoryChatMessageHistory 对象 chat_history并初始化它的消息历史为 messages 列表 (除了最后一个消息)。第六行定义一个函数 dummy_get_session_history根据 session_id 返回相应的聊天历史记录 如果 session_id 不等于 “1”则返回一个新的空的 InMemoryChatMessageHistory 对象。如果 session_id 等于 “1”则返回之前定义的 chat_history。 倒数第五行创建一个 RunnableWithMessageHistory 对象 chain_with_history将 chain 和 dummy_get_session_history 结合在一起使其能够处理带有历史记录的消息。倒数第四行调用 chain_with_history 对象的 invoke 方法传入一个包含 HumanMessage(“what do you call a speechless parrot”) 的列表和配置 {“configurable”: {“session_id”: “1”}} 该方法将根据 session_id 为 “1” 调用 dummy_get_session_history 返回相应的历史记录。将消息传递给链 chain先修剪再由 llm 处理。 查看 LangSmith 跟踪我们可以看到我们检索了所有消息但在将消息传递给模型之前它们被修剪成只有系统消息和最后一条人类消息。
http://www.w-s-a.com/news/142044/

相关文章:

  • 网站策划 ppt北京装修公司排名推荐
  • 郑州网站建设公司哪家专业好如何注册一家公司
  • 证券投资网站做哪些内容滨州论坛网站建设
  • 重庆网站建设公司模板广东佛山
  • 中展建设股份有限公司网站做网站备案是什么意思
  • 石家庄网站建设接单wordpress功能小工具
  • 有没有专门做网站的网站镜像上传到域名空间
  • 网站建设中 windows买域名自己做网站
  • 设计英语宁波seo做排名
  • 奉贤网站建设上海站霸深圳几个区
  • c#做网站自已建网站
  • 成都地区网站建设网站设计类型
  • 如何做网站结构优化北京响应式网站
  • 出售源码的网站威海住房建设局网站
  • 网站建设补充报价单网站建设 技术指标
  • 做网站费用分摊入什么科目做网络网站需要三证么
  • 房屋备案查询系统官网杭州排名优化软件
  • 网站地图html网络营销的流程和方法
  • 注册好网站以后怎么做wordpress 获取插件目录下
  • 南京做网站dmooo地方网站需要什么手续
  • 网站开发合同有效期omeka wordpress对比
  • 杭州设计网站的公司广州网站改版领军企业
  • 网站备案系统苏州网站设计网站开发公司
  • 怎么样做微网站著名企业vi设计
  • 三分钟做网站网页设计心得体会100字
  • 网站建设支付宝seo建站是什么
  • 常州做网站的 武进学雷锋_做美德少年网站
  • 怎样建网站赚钱贵州seo和网络推广
  • 创建网站的工具站内seo优化
  • 网站特效 站长查询网网站