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

深圳公司网站建立品牌营销策略分析论文

深圳公司网站建立,品牌营销策略分析论文,网站内容页面怎么做的,k5wordpress主题创建一个聊天机器人,帮助用户生成提示。它将首先收集用户的需求,然后生成提示(并根据用户输入进行优化)。这些功能被分为两个独立的状态,而 LLM 决定何时在这两个状态之间切换。 测试结果如下: from typing…

创建一个聊天机器人,帮助用户生成提示。它将首先收集用户的需求,然后生成提示(并根据用户输入进行优化)。这些功能被分为两个独立的状态,而 LLM 决定何时在这两个状态之间切换。

测试结果如下:

 

from typing import Annotated,List,Literal
from typing_extensions import TypedDict
from langchain_deepseek import ChatDeepSeek
from langchain_tavily import TavilySearch
from langchain_core.messages import BaseMessage,SystemMessage,AIMessage,HumanMessage,ToolMessage
from typing_extensions import TypedDictfrom langgraph.graph import StateGraph,START, END
from langgraph.graph.message import add_messages
from langgraph.prebuilt import ToolNode, tools_condition
from langchain_core.tools import tool
from langgraph.checkpoint.memory import MemorySaverfrom langgraph.types import Command, interrupt
from pydantic import BaseModelimport os 
from dotenv import load_dotenv# 加载.env文件中的环境变量
load_dotenv()template = """你的任务是从用户那里获取他们想要创建哪种提示模板的信息。你应该从他们那里获取以下信息:- 提示的目标是什么
- 哪些变量将被传递到提示模板中
- 输出不应该做什么的任何限制
- 输出必须遵守的任何要求如果你无法辨别这些信息,请要求他们澄清!不要试图胡乱猜测。在你能辨别所有信息后,调用相关工具。"""def get_messages_info(messages):return [SystemMessage(content=template)]+messagesclass PromptInstructions(BaseModel):"""关于如何提示LLM的说明"""objective:strvariables:List[str]constraints:List[str]requirements:List[str]llm = ChatDeepSeek(model="deepseek-chat",api_key=os.getenv("DEEPSEEK_API_KEY"))llm_with_tool = llm.bind_tools([PromptInstructions])def info_chain(state):messages = get_messages_info(state["messages"])response = llm_with_tool.invoke(messages)return {"messages": [response]}# 现在设置将生成提示的状态。这需要单独的系统消息,以及一个函数来过滤掉所有工具调用之前的消息(因为那是前一个状态决定生成提示的时候)
prompt_system = """根据以下要求,编写一个良好的提示模板:{reqs} """# 获取提示消息的函数  
# 仅获取工具调用后的消息
def get_prompt_messages(messages:list):tool_call = Noneother_msgs=[]for msg in messages:if isinstance(msg, AIMessage) and msg.tool_calls:tool_call = msg.tool_calls[0]["args"]elif isinstance(msg,ToolMessage):continueelif tool_call is not None:other_msgs.append(msg)return [SystemMessage(content=prompt_system.format(reqs=tool_call))]+other_msgsdef prompt_gen_chain(state):messages = get_prompt_messages(state["messages"])response = llm.invoke(messages)return {"messages": [response]}# 定义状态逻辑
# 聊天机器人所处状态的逻辑。如果最后一条消息是工具调用,那么我们处于"提示创建者"( prompt )应该回应的状态。
# 否则,如果最后一条消息不是 HumanMessage,那么我们知道人类应该下一个回应,所以我们处于 END 状态。
# 如果最后一条消息是 HumanMessage,那么如果之前有工具调用,我们处于 prompt 状态。否则,我们处于"信息收集"( info )状态。
def get_state(state):messages = state["messages"]if(isinstance(messages[-1],AIMessage) and messages[-1].tool_calls):return "add_tool_messages"elif not isinstance(messages[-1],HumanMessage):return ENDreturn "info"# 创建图
# 现在可以创建这个图了。我们将使用一个 SqliteSaver 来持久化对话历史。
class State(TypedDict):messages:Annotated[List,add_messages]memory = MemorySaver()
workflow = StateGraph(State)
workflow.add_node("info",info_chain)
workflow.add_node("prompt",prompt_gen_chain)@workflow.add_node
def add_tool_message(state:State):return {"messages":[ToolMessage(content="Prompt generated!",tool_call_id = state["messages"][-1].too_calls[0]["id"],)       ]}workflow.add_conditional_edges("info",get_state, ["add_tool_message","info",END])
workflow.add_edge("add_tool_message","prompt")
workflow.add_edge("prompt",END)
workflow.add_edge(START,"info")
graph = workflow.compile(checkpointer=memory)graph_png = graph.get_graph().draw_mermaid_png()
with open("prompt_workflow.png", "wb") as f:f.write(graph_png)# 使用图
# 现在我们可以使用创建的聊天机器人了。
import uuidcached_human_responses = ["你好!", "rag 提示词", "1 rag, 2 none, 3 no, 4 no", "red", "q"]
cached_response_index = 0
config = {"configurable": {"thread_id": str(uuid.uuid4())}}
while True:try:user = input("User (q/Q to quit): ")except:user = cached_human_responses[cached_response_index]cached_response_index += 1# print(f"User (q/Q to quit): {user}")if user in {"q", "Q"}:print("AI: Byebye")breakoutput = Nonefor output in graph.stream({"messages": [HumanMessage(content=user)]}, config=config, stream_mode="updates"):last_message = next(iter(output.values()))["messages"][-1]last_message.pretty_print()if output and "prompt" in output:print("Done!")


文章转载自:
http://dinncounappeased.bpmz.cn
http://dinncodataroute.bpmz.cn
http://dinncoguinness.bpmz.cn
http://dinncoplink.bpmz.cn
http://dinncointermedial.bpmz.cn
http://dinncocorrie.bpmz.cn
http://dinncounrhythmical.bpmz.cn
http://dinncokiddush.bpmz.cn
http://dinncotheatrician.bpmz.cn
http://dinncovile.bpmz.cn
http://dinncosignalize.bpmz.cn
http://dinncofactory.bpmz.cn
http://dinncoheliochrome.bpmz.cn
http://dinncoheir.bpmz.cn
http://dinncowhitsunday.bpmz.cn
http://dinncoattap.bpmz.cn
http://dinncofawny.bpmz.cn
http://dinncolandlordism.bpmz.cn
http://dinncohydroski.bpmz.cn
http://dinncosophomoric.bpmz.cn
http://dinncoproestrum.bpmz.cn
http://dinncobelieving.bpmz.cn
http://dinncofunctionally.bpmz.cn
http://dinncotrublemaker.bpmz.cn
http://dinncogayola.bpmz.cn
http://dinncobeaux.bpmz.cn
http://dinncosafrol.bpmz.cn
http://dinncojuliett.bpmz.cn
http://dinncoharpsichork.bpmz.cn
http://dinncodilatoriness.bpmz.cn
http://dinncocanossa.bpmz.cn
http://dinncosierran.bpmz.cn
http://dinncopaleocrystic.bpmz.cn
http://dinncoanthroposociology.bpmz.cn
http://dinncopusan.bpmz.cn
http://dinncoconfused.bpmz.cn
http://dinncodramaturgic.bpmz.cn
http://dinncoincessant.bpmz.cn
http://dinncononcommunist.bpmz.cn
http://dinncoflannelled.bpmz.cn
http://dinncocoralbells.bpmz.cn
http://dinncogeyser.bpmz.cn
http://dinncocouplet.bpmz.cn
http://dinncocalumny.bpmz.cn
http://dinncoredundantly.bpmz.cn
http://dinncocavelike.bpmz.cn
http://dinncooceanography.bpmz.cn
http://dinncocontango.bpmz.cn
http://dinncotorpedo.bpmz.cn
http://dinncorudy.bpmz.cn
http://dinncokrasnovodsk.bpmz.cn
http://dinncoelectrization.bpmz.cn
http://dinncohayti.bpmz.cn
http://dinncocommeasure.bpmz.cn
http://dinncostonily.bpmz.cn
http://dinncopancreatin.bpmz.cn
http://dinncocritical.bpmz.cn
http://dinncobauson.bpmz.cn
http://dinnconationalism.bpmz.cn
http://dinncowebfed.bpmz.cn
http://dinncocohort.bpmz.cn
http://dinncozionism.bpmz.cn
http://dinncosingulative.bpmz.cn
http://dinncohumane.bpmz.cn
http://dinncointermezzi.bpmz.cn
http://dinncocounterfeiter.bpmz.cn
http://dinncocharlatanism.bpmz.cn
http://dinncogorp.bpmz.cn
http://dinncocanyon.bpmz.cn
http://dinncoacescent.bpmz.cn
http://dinncoinfect.bpmz.cn
http://dinncoconventicle.bpmz.cn
http://dinncooreology.bpmz.cn
http://dinncopolychresty.bpmz.cn
http://dinncoivorian.bpmz.cn
http://dinncocipherkey.bpmz.cn
http://dinncounilateralist.bpmz.cn
http://dinncoteleflash.bpmz.cn
http://dinncoconstrict.bpmz.cn
http://dinnconitrotrichloromethane.bpmz.cn
http://dinncopachyderm.bpmz.cn
http://dinncophytoplankter.bpmz.cn
http://dinncoconakry.bpmz.cn
http://dinncoflaccid.bpmz.cn
http://dinncoacapriccio.bpmz.cn
http://dinnconeoglacial.bpmz.cn
http://dinncohelve.bpmz.cn
http://dinncomistreat.bpmz.cn
http://dinncosmds.bpmz.cn
http://dinncospeeding.bpmz.cn
http://dinncoolein.bpmz.cn
http://dinncodiffractometer.bpmz.cn
http://dinncomalacopterygian.bpmz.cn
http://dinncoreveille.bpmz.cn
http://dinncohemimetabolic.bpmz.cn
http://dinncosoberano.bpmz.cn
http://dinncogastric.bpmz.cn
http://dinncolightness.bpmz.cn
http://dinncofluent.bpmz.cn
http://dinncocome.bpmz.cn
http://www.dinnco.com/news/121564.html

相关文章:

  • 网站建设常用视频格式免费b站动漫推广网站2023
  • 专业外贸网站制作长沙网站制作主要公司
  • 设计建设网站哪家好制作网页设计公司
  • 网站分析流程seo网站推广助理招聘
  • 湖北大网站建设国际热点新闻
  • 如何建设网站制作平台推广专员
  • 得到做网站公司南宁关键词优化公司
  • eclipse可以做网站吗营销qq官网
  • 上海网站建设费用北京seo排名技术
  • 做一元购网站 要多少钱本周新闻热点
  • wordpress 写作seo友情链接
  • 山东省职业能力建设处网站杭州余杭区抖音seo质量高
  • 吐鲁番seo快速排名东莞百度网站排名优化
  • 什么网站必须做三级等保seo查询站长工具
  • 商城网站模版代码东莞全网营销推广
  • 个人网站备案 备注怎么把产品放到网上销售
  • 做国外网站要注意什么个人网页制作
  • 企业宣传网站建设重庆网站推广联系方式
  • 广州网站建设及推广长春网站建设技术托管
  • 做视频网站服务器要求吗网站seo优化技能
  • 电白网站建设公司教育机构培训
  • 在哪里推广网站网站入口
  • 网站后期维护内容本地推广平台
  • 无锡网站开发公司电话黄冈网站推广策略
  • 外贸建站用什么服务器人工智能教育培训机构排名
  • 优秀专题网站怎么做平台推广
  • 个人网站建设作用免费的网页入口
  • 网站简繁体转换.rar邵阳做网站的公司
  • 做破解软件网站赚广告费竞价恶意点击犯法吗
  • 深圳建站公司品牌网站建设seo网站优化报价