可定制属性

构建高效的 CrewAI 团队取决于动态调整 AI 智能体以满足任何项目独特需求的能力。本节涵盖您可以定制的基础属性。

关键可定制属性

属性描述
角色指定智能体在团队中的工作,例如“分析师”或“客户服务代表”。
目标定义智能体的目标,与它的角色和团队的总体使命保持一致。
背景故事为智能体的角色设定增加深度,增强其在团队中的动机和参与度。
工具 (可选)代表智能体用于任务的能力或方法,从简单的函数到复杂的集成。
缓存 (可选)确定智能体是否应使用缓存进行工具使用。
最大 RPM设置每分钟的最大请求数(max_rpm)。可以设置为 None 以允许对外部服务进行无限请求。
详细模式 (可选)启用详细日志记录,用于调试和优化,提供执行过程的详细信息。
允许委托 (可选)控制是否将任务委托给其他智能体,默认为 False
最大迭代次数 (可选)限制任务的最大迭代次数(max_iter)以防止无限循环,默认为 25。
最大执行时间 (可选)设置智能体完成任务允许的最大时间。
系统模板 (可选)定义智能体的系统格式。
提示模板 (可选)定义智能体的提示格式。
响应模板 (可选)定义智能体的响应格式。
使用系统提示 (可选)控制智能体在执行任务期间是否使用系统提示。
遵守上下文窗口默认启用滑动上下文窗口,保持上下文大小。
最大重试次数限制设置智能体在出错时最大重试次数(max_retry_limit)。

高级定制选项

除了基本属性外,CrewAI 允许进行更深层次的定制,以显著增强智能体的行为和能力。

语言模型定制

智能体可以使用特定的语言模型(llm)和函数调用语言模型(function_calling_llm)进行定制,从而对其处理和决策能力进行高级控制。值得注意的是,设置 function_calling_llm 允许覆盖默认团队的函数调用语言模型,提供更大程度的定制。

性能和调试设置

调整智能体的性能并监控其操作对于高效的任务执行至关重要。

详细模式和 RPM 限制

  • 详细模式:启用智能体操作的详细日志记录,对于调试和优化非常有用。具体来说,它提供了智能体执行过程的详细信息,有助于性能优化。
  • RPM 限制:设置每分钟最大请求数(max_rpm)。此属性是可选的,可以设置为 None 以无限制,如果需要,允许对外部服务进行无限查询。

任务执行的最大迭代次数

max_iter 属性允许用户定义智能体执行单个任务的最大迭代次数,防止无限循环或过长的执行。默认值设置为 25,在彻底性和效率之间取得了平衡。一旦智能体接近此数值,它将尽最大努力给出一个好的答案。

定制智能体和工具

通过在初始化时定义智能体的属性和工具来对其进行定制。工具对于智能体的功能至关重要,使其能够执行专门的任务。tools 属性应该是一个智能体可以利用的工具数组,默认初始化为空列表。在智能体初始化后可以添加或修改工具以适应新的需求。

pip install 'crewai[tools]'

示例:为智能体分配工具

代码
import os
from crewai import Agent
from crewai_tools import SerperDevTool

# Set API keys for tool initialization
os.environ["OPENAI_API_KEY"] = "Your Key"
os.environ["SERPER_API_KEY"] = "Your Key"

# Initialize a search tool
search_tool = SerperDevTool()

# Initialize the agent with advanced options
agent = Agent(
  role='Research Analyst',
  goal='Provide up-to-date market analysis',
  backstory='An expert analyst with a keen eye for market trends.',
  tools=[search_tool],
  memory=True, # Enable memory
  verbose=True,
  max_rpm=None, # No limit on requests per minute
  max_iter=25, # Default value for maximum iterations
)

委托和自主性

控制智能体委托任务或提问的能力对于调整其在 CrewAI 框架内的自主性和协作动态至关重要。默认情况下,allow_delegation 属性现在设置为 False,禁用智能体在需要时寻求帮助或委托任务。可以更改此默认行为以促进 CrewAI 生态系统中的协作解决问题和效率。如果需要,可以启用委托以适应特定的操作要求。

示例:禁用智能体的委托

代码
agent = Agent(
  role='Content Writer',
  goal='Write engaging content on market trends',
  backstory='A seasoned writer with expertise in market analysis.',
  allow_delegation=True # Enabling delegation
)

结论

通过在 CrewAI 中定制智能体的角色、目标、背景故事和工具,以及语言模型定制、记忆、性能设置和委托偏好等高级选项,可以构建一支细致入微且能力强大的 AI 团队,为应对复杂挑战做好准备。