Former-commit-id: 6e25f51bbc
group-chat
Kye 1 year ago
parent 57ed7b8957
commit c0e8ecf207

@ -7,29 +7,29 @@ from swarms.agents.base import AbstractAgent
@dataclass @dataclass
class GroupChat: class GroupChat:
"""A group chat with multiple participants with a list of workers and a max number of rounds""" """A group chat with multiple participants with a list of agents and a max number of rounds"""
workers: List[AbstractAgent] agents: List[AbstractAgent]
messages: List[Dict] messages: List[Dict]
max_rounds: int = 10 max_rounds: int = 10
admin_name: str = "Admin" #admin worker admin_name: str = "Admin" #admin agent
@property @property
def worker_names(self) -> List[str]: def agent_names(self) -> List[str]:
"""returns the names of the workers in the group chat""" """returns the names of the agents in the group chat"""
return [worker.ai_name for worker in self.workers] return [agent.ai_name for agent in self.agents]
def reset(self): def reset(self):
self.messages.clear() self.messages.clear()
def worker_by_name(self, name: str) -> AbstractAgent: def agent_by_name(self, name: str) -> AbstractAgent:
"""Find the next speaker baed on the message""" """Find the next speaker baed on the message"""
return self.workers[self.worker_names.index(name)] return self.agents[self.agent_names.index(name)]
def next_worker(self, worker: AbstractAgent) -> AbstractAgent: def next_agent(self, agent: AbstractAgent) -> AbstractAgent:
"""Returns the next worker in the list""" """Returns the next agent in the list"""
return self.workers[ return self.agents[
(self.workers_names.index(worker.ai_name) + 1) % len(self.workers) (self.agents_names.index(agent.ai_name) + 1) % len(self.agents)
] ]
def select_speaker_msg(self): def select_speaker_msg(self):
@ -39,7 +39,7 @@ class GroupChat:
You are in a role play game the following rules are available: You are in a role play game the following rules are available:
{self.__participant_roles()}. {self.__participant_roles()}.
Read the following conversation then select the next role from {self.worker_names} Read the following conversation then select the next role from {self.agent_names}
to play and only return the role to play and only return the role
""" """
@ -55,20 +55,20 @@ class GroupChat:
self.messages + [ self.messages + [
{ {
"role": "system", "role": "system",
"context": f"Read the above conversation. Then select the next role from {self.worker_names} to play. Only return the role.", "context": f"Read the above conversation. Then select the next role from {self.agent_names} to play. Only return the role.",
} }
] ]
) )
if not final: if not final:
return self.next_worker(last_speaker) return self.next_agent(last_speaker)
try: try:
return self.worker_by_name(name) return self.agent_by_name(name)
except ValueError: except ValueError:
return self.next_worker(last_speaker) return self.next_agent(last_speaker)
def _participant_roles(self): def _participant_roles(self):
return "\n".join( return "\n".join(
[f"{worker.ai_name}: {worker.system_message}" for worker in self.workers] [f"{agent.ai_name}: {agent.system_message}" for agent in self.agents]
) )
@ -118,12 +118,12 @@ class GroupChatManager(AbstractAgent):
groupchat.messages.append(message) groupchat.messages.append(message)
#broadcast the message to all workers except the speaker #broadcast the message to all agents except the speaker
for worker in groupchat.workers: for agent in groupchat.agents:
if worker != speaker: if agent != speaker:
self.send( self.send(
message, message,
worker, agent,
request_reply=False, request_reply=False,
silent=True, silent=True,
) )
@ -138,12 +138,12 @@ class GroupChatManager(AbstractAgent):
except KeyboardInterrupt: except KeyboardInterrupt:
#let the admin speak if interrupted #let the admin speak if interrupted
if groupchat.admin_name in groupchat.worker_names: if groupchat.admin_name in groupchat.agent_names:
#admin worker is a particpant #admin agent is a particpant
speaker = groupchat.worker_by_name(groupchat.admin_name) speaker = groupchat.agent_by_name(groupchat.admin_name)
reply = speaker.generate_reply(sender=self) reply = speaker.generate_reply(sender=self)
else: else:
#admin worker is not found in particpants #admin agent is not found in particpants
raise raise
if reply is None: if reply is None:
break break
@ -157,20 +157,3 @@ class GroupChatManager(AbstractAgent):
message = self.last_message(speaker) message = self.last_message(speaker)
message = self.last_messge(speaker) message = self.last_messge(speaker)
return True, None return True, None
# model = GroupChatManager(
# groupchat=GroupChat(
# workers=[
# AbstractAgent(name="A", system_message="I am worker A"),
# AbstractAgent(name="B", system_message="I am worker B"),
# AbstractAgent(name="C", system_message="I am worker C"),
# ]
# )
# )
# model.run(
# messages=[
# 'A: Hello, I am worker A',
# 'B: Hello, I am worker B',
# ]
# )
Loading…
Cancel
Save