mirror of
https://github.com/FoundationAgents/MetaGPT.git
synced 2026-05-02 12:22:39 +02:00
change routing & add team info for quick question
This commit is contained in:
parent
37fcd66cbc
commit
5e5dc66cc1
5 changed files with 143 additions and 12 deletions
|
|
@ -209,18 +209,20 @@ class RoleZero(Role):
|
|||
return rsp # return output from the last action
|
||||
|
||||
async def _quick_think(self) -> Message:
|
||||
msg = self.rc.news[-1]
|
||||
rsp_msg = None
|
||||
if msg.cause_by != any_to_str(UserRequirement):
|
||||
if self.rc.news[-1].cause_by != any_to_str(UserRequirement):
|
||||
# Agents themselves won't generate quick questions, use this rule to reduce extra llm calls
|
||||
return rsp_msg
|
||||
|
||||
context = self.llm.format_msg(self.get_memories(k=4) + [UserMessage(content=QUICK_THINK_PROMPT)])
|
||||
# routing
|
||||
memory = self.get_memories(k=4)
|
||||
context = self.llm.format_msg(memory + [UserMessage(content=QUICK_THINK_PROMPT)])
|
||||
# print(context)
|
||||
rsp = await self.llm.aask(context)
|
||||
|
||||
pattern = r"#YES#,? ?"
|
||||
if re.search(pattern, rsp):
|
||||
answer = re.sub(pattern, "", rsp).strip()
|
||||
if "yes" in rsp.lower():
|
||||
# llm call with the original context
|
||||
answer = await self.llm.aask(self.llm.format_msg(memory))
|
||||
self.rc.memory.add(AIMessage(content=answer, cause_by=RunCommand))
|
||||
await self.reply_to_human(content=answer)
|
||||
rsp_msg = AIMessage(
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ from __future__ import annotations
|
|||
from metagpt.actions.di.run_command import RunCommand
|
||||
from metagpt.prompts.di.team_leader import (
|
||||
FINISH_CURRENT_TASK_CMD,
|
||||
QUICK_THINK_SYSTEM_PROMPT,
|
||||
SYSTEM_PROMPT,
|
||||
TL_INSTRUCTION,
|
||||
)
|
||||
|
|
@ -16,6 +17,7 @@ from metagpt.tools.tool_registry import register_tool
|
|||
class TeamLeader(RoleZero):
|
||||
name: str = "Tim"
|
||||
profile: str = "Team Leader"
|
||||
goal: str = "Manage a team to assist users"
|
||||
system_msg: list[str] = [SYSTEM_PROMPT]
|
||||
|
||||
# TeamLeader only reacts once each time, but may encounter errors or need to ask human, thus allowing 2 more turns
|
||||
|
|
@ -33,16 +35,26 @@ class TeamLeader(RoleZero):
|
|||
}
|
||||
)
|
||||
|
||||
def set_instruction(self):
|
||||
def _get_team_info(self) -> str:
|
||||
if not self.rc.env:
|
||||
return ""
|
||||
team_info = ""
|
||||
for role in self.rc.env.roles.values():
|
||||
# if role.profile == "Team Leader":
|
||||
# continue
|
||||
team_info += f"{role.name}: {role.profile}, {role.goal}\n"
|
||||
self.instruction = TL_INSTRUCTION.format(team_info=team_info)
|
||||
return team_info
|
||||
|
||||
async def _quick_think(self) -> Message:
|
||||
# insert team info for quick question
|
||||
self.llm.system_prompt = QUICK_THINK_SYSTEM_PROMPT.format(
|
||||
role_info=super()._get_prefix(),
|
||||
team_info=self._get_team_info(),
|
||||
)
|
||||
return await super()._quick_think()
|
||||
|
||||
async def _think(self) -> bool:
|
||||
self.set_instruction()
|
||||
self.instruction = TL_INSTRUCTION.format(team_info=self._get_team_info())
|
||||
return await super()._think()
|
||||
|
||||
def publish_message(self, msg: Message, send_to="no one"):
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue