1
0

planner.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. from hello_agents import SimpleAgent, HelloAgentsLLM
  2. from hello_agents.tools.builtin.note_tool import NoteTool
  3. class PlannerAgent(SimpleAgent):
  4. """
  5. 负责创建和更新学习路径的智能体。
  6. """
  7. def __init__(self, llm: HelloAgentsLLM, knowledge_service):
  8. """
  9. 初始化 PlannerAgent。
  10. Args:
  11. llm: 用于生成计划的大语言模型实例。
  12. """
  13. # 在 PlannerAgent.run() 中
  14. self.knowledge = knowledge_service
  15. system_prompt = """
  16. 你是一位专业的计算机科学课程规划师。
  17. 你的工作是根据用户的目标和当前水平为他们创建个性化的学习路径。
  18. 当被要求创建计划时:
  19. 1. 分析用户的目标(例如,"学习 Python 数据科学")。
  20. 2. 将其分解为逻辑模块/里程碑。
  21. 3. 对于每个模块,列出要掌握的关键概念。
  22. 4.所有阶段名称的最后必须使用 Markdown 任务列表格式:
  23. - `[ ]` 表示未完成
  24. - `[x]` 表示已完成(创建时默认未完成)
  25. 5. 当你创建学习计划时,必须遵循以下输出格式:
  26. ### 学习计划
  27. # 学习主题:<主题>
  28. ## 学习目标
  29. - ...
  30. ## 学习路径
  31. 1. 第一阶段:<阶段名称> []
  32. - 关键概念
  33. 2. 第一阶段:<阶段名称> []
  34. - 关键概念
  35. ## 学习建议
  36. - ...
  37. 请确保整个学习计划是一个完整、可直接保存的 Markdown 文档。
  38. 当被要求【更新学习计划 / 更新进度】时,你必须:
  39. 1. 假设已有一份“学习计划”文档存在。
  40. 2. 根据用户的最新学习行为(如:完成了某个知识点、提交了代码并通过评审):
  41. - 将对应的 `[ ]` 更新为 `[x]`
  42. 3. 输出【更新后的完整学习计划 Markdown 文档】(而不是只输出差异)以### 更新学习计划作为开头。
  43. """
  44. super().__init__(
  45. name="Planner",
  46. llm=llm,
  47. system_prompt=system_prompt
  48. )
  49. self.note_tool = NoteTool(workspace="notes")
  50. def run(self, input_text: str, max_tool_iterations: int = 3, **kwargs) -> str:
  51. # ===== 学习回顾 =====
  52. if any(k in input_text for k in ["之前", "回顾", "学过", "记得"]):
  53. return self.knowledge.recall(input_text)
  54. # 正常让 LLM 生成内容
  55. result = super().run(input_text)
  56. # Planner 自己判断:这是学习计划
  57. if result.strip().startswith("### 学习计划"):
  58. self._save_learning_plan(result, input_text)
  59. if result.strip().startswith("### 更新学习计划"):
  60. self._update_learning_plan(result, input_text)
  61. # 原样返回给 Tutor
  62. return result
  63. def _update_learning_plan(self, markdown: str, input_text: str):
  64. title_and_note_id_str = self.knowledge.recall(input_text)
  65. self.note_tool.run({
  66. "note_id": self.note_tool.notes_index['notes'][-1]['id'],
  67. "action": "update", # 注意是 update
  68. "title": "学习计划",
  69. "content": markdown,
  70. "tags": ["learning-plan", "progress"]
  71. })
  72. # self.knowledge.add_note(content=markdown)
  73. def _save_learning_plan(self, markdown: str, input_text: str):
  74. note_id = self.note_tool.run({
  75. "action": "create",
  76. "title": "学习计划",
  77. "content": markdown,
  78. "tags": ["learning-plan", "planner"]
  79. })
  80. content = f"title: {input_text} note_id: {note_id}"
  81. self.knowledge.add_note(content=content)