1
0

tutor.py 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. from hello_agents import SimpleAgent, HelloAgentsLLM
  2. from typing import Dict, Any
  3. class TutorAgent(SimpleAgent):
  4. """
  5. 主要协调智能体,直接管理 Planner、Exercise 和 Reviewer 子智能体。
  6. 使用简单的直接调用模式,不依赖 A2A 协议。
  7. """
  8. def __init__(self, llm: HelloAgentsLLM, knowledge_service):
  9. """
  10. 初始化 TutorAgent 和所有子智能体。
  11. Args:
  12. llm: 用于所有 agents 的大语言模型实例。
  13. """
  14. # 导入放在这里避免循环导入
  15. from agents.planner import PlannerAgent
  16. from agents.exercise import ExerciseAgent
  17. from agents.reviewer import ReviewerAgent
  18. from tools.code_runner import CodeRunner
  19. from tools.agent_tool import AgentTool
  20. self.knowledge = knowledge_service
  21. # 创建子智能体实例
  22. self.planner = PlannerAgent(llm, knowledge_service)
  23. self.exercise = ExerciseAgent(llm)
  24. self.reviewer = ReviewerAgent(llm, tools=[CodeRunner()], knowledge_service=knowledge_service)
  25. # 定义系统提示词
  26. system_prompt = """
  27. 你是一位智能编程导师 (Tutor)。你负责协调个性化的学习体验。
  28. 你拥有以下专业助手(工具):
  29. - call_planner: 课程规划师,制定个性化学习计划, 回顾已经创建过的学习计划
  30. - call_exercise: 出题人,生成编程练习题
  31. - call_reviewer: 评审员,评审代码并提供反馈
  32. **关键:你必须使用工具,不能自己完成这些任务!**
  33. 工具调用格式(严格遵守此格式):
  34. [TOOL_CALL:工具名称:参数]
  35. 具体示例:
  36. 示例1 - 学习计划:
  37. 用户:"我想学习Python中的列表推导式"
  38. 你的回答:[TOOL_CALL:call_planner:query=请为学习Python列表推导式制定学习计划]
  39. 示例2 - 回顾学习计划:
  40. 用户:"我想回顾Python中的列表推导式的学习计划"
  41. 你的回答:[TOOL_CALL:call_planner:query=请回顾Python中的列表推导式的学习计划]
  42. 示例3 - 练习题:
  43. 用户:"请给我出一道编程题目"
  44. 你的回答:[TOOL_CALL:call_exercise:query=请给我出一道编程题目]
  45. 示例4 - 代码评审(最重要!):
  46. 用户:"请评审以下代码: numbers = [1, 2, 3]"
  47. 你的回答:[TOOL_CALL:call_reviewer:query=请评审以下代码: numbers = [1, 2, 3]]
  48. 工作流程(必须严格遵守):
  49. 1. 当用户表达学习目标时 → 立即调用 call_planner
  50. 2. 当用户请求编程题时 → 立即调用 call_exercise
  51. 3. 当用户提交代码或请求评审时 → 立即调用 call_reviewer
  52. **绝对禁止的行为**:
  53. - ❌ 不要自己制定学习计划
  54. - ❌ 不要自己出练习题
  55. - ❌ 不要自己评审代码(即使代码很简单)
  56. - ❌ 不要说"工具调用失败"然后自己完成任务
  57. 正确的行为:
  58. - ✅ 识别用户意图
  59. - ✅ 立即生成工具调用(格式:[TOOL_CALL:工具名:query=...])
  60. - ✅ 等待工具返回结果
  61. - ✅ 将结果友好地呈现给用户
  62. """
  63. # 初始化父类
  64. super().__init__(
  65. name="Tutor",
  66. llm=llm,
  67. system_prompt=system_prompt
  68. )
  69. # 简单的用户标识
  70. self.user_id = "default_user"
  71. self.current_problem = []
  72. # 将子智能体包装为工具并注册
  73. self.add_tool(AgentTool(
  74. self.planner,
  75. name="call_planner",
  76. description="调用课程规划师,为用户制定个性化的学习计划"
  77. ))
  78. self.add_tool(AgentTool(
  79. self.exercise,
  80. name="call_exercise",
  81. description="调用出题人,根据学习内容生成编程练习题"
  82. ))
  83. self.add_tool(AgentTool(
  84. self.reviewer,
  85. name="call_reviewer",
  86. description="调用评审员,对用户提交的代码进行评审和反馈"
  87. ))
  88. # def run(self, input_text: str, max_tool_iterations: int = 3, **kwargs) -> str:
  89. # result = super().run(input_text)
  90. # return result