LangChain学习文档

Chains(链)

【LangChain】不同的调用方式(Different call methods)

概述

本笔记:讲述Chain的不同调用方式。

所有从 Chain 继承的类中都提供了几种运行链逻辑的方法。最直接的方法是使用 __call__
说明:__call__这个是python版中的方法已经实现了。

内容

chat = ChatOpenAI(temperature=0)
prompt_template = "Tell me a {adjective} joke"
llm_chain = LLMChain(llm=chat, prompt=PromptTemplate.from_template(prompt_template))

llm_chain(inputs={"adjective": "corny"})

结果:

    {'adjective': 'corny',
     'text': 'Why did the tomato turn red? Because it saw the salad dressing!'}

默认情况下,__call__返回的是键值对:输入和输出。我们可以通过将return_only_outputs设置为True:仅返回输出键值对。

只有一个输出key的情况

如果我们想Chain只输出一个key(即:output_keys中只有一个元素),则可以使用run方法。
请注意:run方法输出一个字符串而不是键值对(或者叫:字典)。

# llm_chain only has one output key, so we can use run
# llm_chain 输出只有一个key的情况下,我们可以使用run方法。
llm_chain.output_keys
# 结果
    ['text']

则,使用run方法:

llm_chain.run({"adjective": "corny"})
# 结果
'Why did the tomato turn red? Because it saw the salad dressing!'

只有一个输入key的情况

在只有一个输入key的情况下,可以直接输入字符串,无需指定输入映射:

# These two are equivalent 这两个是等价的
llm_chain.run({"adjective": "corny"})
llm_chain.run("corny")

# These two are also equivalent 这两个也是等价的
llm_chain("corny")
llm_chain({"adjective": "corny"})

结果:

    {'adjective': 'corny',
     'text': 'Why did the tomato turn red? Because it saw the salad dressing!'}

我们可以通过其run方法轻松地将Chain对象作为Tool集成Agent中。请参阅此处的示例。

这里给个理解代码:

tools.append(
    Tool.from_function(
        func=llm_math_chain.run,
        name="Calculator",
        description="useful for when you need to answer questions about math",
        args_schema=CalculatorInput
        # coroutine= ... <- you can specify an async method if desired as well
    )
)
# Construct the agent. We will use the default agent type here.
# See documentation for a full list of options.
# 集成到了agent中
agent = initialize_agent(
    tools, llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True
)
agent.run(
    "Who is Leo DiCaprio's girlfriend? What is her current age raised to the 0.43 power?"
)

总结

要调用Chain的方法。

  1. 先构造llm_chain
llm_chain = LLMChain(llm=chat, prompt=PromptTemplate.from_template(prompt_template))
  1. 执行llm_chain(xxx),即可。默认情况下,输入和输出都会打印出来
llm_chain(inputs={"adjective": "corny"})
# 结果
    {'adjective': 'corny',
     'text': 'Why did the tomato turn red? Because it saw the salad dressing!'}
  1. 单个输出就使用run方法。
  2. 单个输入,可以不用写key:llm_chain("corny")
  3. 单个输入和输出的简写:llm_chain.run("corny")

参考地址:

Different call methods

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐