microsoft / autogen

A programming framework for agentic AI 🤖
https://microsoft.github.io/autogen/
Creative Commons Attribution 4.0 International
35.14k stars 5.09k forks source link

[Issue]: TransformMessages not working with GroupChatManager speaker selection prompts #2499

Open Nathan-Intergral opened 7 months ago

Nathan-Intergral commented 7 months ago

Describe the issue

When GroupChat speaker_selection_method is set to 'auto' the speaker selection prompt used to determine the next agent contains all the messages in the conversation history. Attempting to add TransformMessages to the GroupChatManager should allow you to limit the length of each speaker selection prompt but it does not.

This is due to the select_speaker function in groupchat.py uses conversable_agent.py's generate_oai_reply. Which unlike generate_reply does not call process_all_messages_before_reply so the hook for transform messages is never run.

Steps to reproduce

  1. Setup group chat and manager:
group_chat = GroupChat(
            agents=agents,
            messages=messages,
            max_round=max_round,
            speaker_selection_method="auto",
            send_introductions=introductions,
            speaker_transitions_type="allowed",
            allowed_or_disallowed_speaker_transitions=get_allowed_transitions(workers),
        )

        manager = GroupChatManager(
            groupchat=group_chat,
            llm_config=get_llm_config(),
            is_termination_msg=lambda x: "GROUPCHAT_TERMINATE" in x.get("content", ""),
        )

        transform_messages.TransformMessages(
            transforms=[
                transforms.MessageHistoryLimiter(max_messages=5),
            ]
        )
  1. initialise groupchat conversation with runtime logging enabled
logging_session_id = autogen.runtime_logging.start(config={"dbname": "logs.db"})

await overseer.a_initiate_chat(
                        manager,
                        clear_history=False,
                        message=new_request,
                    )

autogen.runtime_logging.stop()
  1. look at chat completions in logs.db, look for speaker selection prompts and note that message history provided in prompt is not limited to 5 and will continuously grow in token count as the conversation continues. Please note that this does not work for message limits or token limits.

Screenshots and logs

No response

Additional Information

No response

Nathan-Intergral commented 7 months ago

@WaelKarkoub @ekzhu Created as discussed

ekzhu commented 7 months ago

Let's start this after #2304 is merged

ekzhu commented 7 months ago

@Nathan-Intergral we are discussing a solution in this issue https://github.com/microsoft/autogen/issues/2583. Once the solution is merged we can close this issue.

WebsheetPlugin commented 6 months ago

I am sorry, but TransformMessages is not working in group chat. Was it not working all the time or is there a version it works??

WaelKarkoub commented 6 months ago

@WebsheetPlugin we are working on a solution. cc @marklysze

WebsheetPlugin commented 6 months ago

@WaelKarkoub I got it. Thanks a lot.

I am not sure if it is related but I created this report: https://github.com/microsoft/autogen/issues/2638#issue-2288327906

For me transform works in group chat, but the transform results are not chained.

marklysze commented 6 months ago

I'll have a look at this and start working on it... (adding the TransformMessages ability to the select speaker)

marklysze commented 6 months ago

Just an update that we have started this and I'm working with @WaelKarkoub on some tweaks to the TransformMessages around filtering messages so that we can allow the user to target specific messages for transforms, which is key for the select speaker messages.

marklysze commented 6 months ago

Hey @Nathan-Intergral, just a note that I've created a branch under AutoGen which will be for the addition of the speaker selection transforms functionality: https://github.com/microsoft/autogen/tree/selectspeakertransforms

At this stage it's functional, in that you can add transforms to the group chat by setting the select_speaker_auto_message_transforms property of a groupchat to a TransformMessages object.

E.g.

debate_select_speaker_compression_args = dict(model_name="microsoft/llmlingua-2-xlm-roberta-large-meetingbank", use_llmlingua2=True, device_map="cpu")

debate_select_speaker_transforms = transform_messages.TransformMessages(
    transforms=[
        transforms.MessageHistoryLimiter(max_messages=10),
        transforms.MessageTokenLimiter(max_tokens=3000, max_tokens_per_message=500, min_tokens=300),
        transforms.TextMessageCompressor(
            min_tokens=1000,
            text_compressor=transforms.LLMLingua(
                debate_select_speaker_compression_args, structured_compression=True
            ),
            cache=InMemoryCache(seed=43),
            filter_dict={"role": ["system"], "name": ["Debate_Moderator_Agent", "checking_agent"]},
            exclude_filter=True,
        ),  # Allows use of <llmlingua, compress=False></llmlingua> to stop compressing certain content
    ]
)

group_chat = autogen.GroupChat(
    agents=self.agent_list,
    messages=[],
    max_round=8,
    select_speaker_message_template="You are managing a debate and your only job is to select the next speaker, each speaker has a name. Follow the debate and decide on who should speak next. The 'Debate_Moderator_Agent' is the first speaker and they will kick off the debate with a topic to debate. Then each of the four debaters will speak and speak only once each. You should start by selecting the 'Affirmative_Constructive_Debater' to provide their opening arguments in the debate.",
    select_speaker_prompt_template="Read the above conversation and your job role, which is managing the debate and choosing the next speaker. The valid speakers can be selected from this list {agentlist}. During the debate the order of debaters are: 1st is the 'Affirmative_Constructive_Debater', 2nd is the 'Negative_Constructive_Debater', 3rd is the 'Affirmative_Rebuttal_Debater', and 4th is the 'Negative_Rebuttal_Debater'. Then 5th will be the 'Debate_Judge' and 6th is the 'Debate_Moderator_Agent'.",
    max_retries_for_selecting_speaker=1,
    role_for_select_speaker_messages="user", # Ensure select speaker messages are role='user'
    select_speaker_auto_verbose=True,
    select_speaker_auto_message_transforms=debate_select_speaker_transforms,
)

I'll create a PR based on this branch, but please note that some of the filtering functionality (shown in the sample code above) is dependent on another PR being merged, #2661.

marklysze commented 6 months ago

Okie dokie, #2719 has been created!

Nathan-Intergral commented 6 months ago

@marklysze Great thank you for that!

gvijqb commented 1 week ago

select_speaker_auto_message_transforms

I am getting this error: TypeError: GroupChat.init() got an unexpected keyword argument 'select_speaker_auto_message_transforms'

Any suggestions?

ekzhu commented 1 week ago

@gvijqb your installed package and version?

gvijqb commented 1 week ago

@gvijqb your installed package and version?

Output for:

pip list | grep autogen

autogen 0.3.2 pyautogen 0.3.2

ekzhu commented 1 week ago

Uninstall both and install: autogen-agentchat. This is fixed the latest version of our package.

See read me for further info.

gvijqb commented 1 week ago

Uninstall both and install: autogen-agentchat. This is fixed the latest version of our package.

See read me for further info.

Thanks. I am not sure if I am doing anything wrong here but it is still not working for me.

Error:

    self.groupchat = autogen.GroupChat(
                     ^^^^^^^^^^^^^^^^^^
TypeError: GroupChat.__init__() got an unexpected keyword argument 'select_speaker_auto_message_transforms'

Pip list output:

pip list | grep autogen

autogen-agentchat 0.2.38

ekzhu commented 1 week ago

I checked again, @gvijqb the argument is select_speaker_transform_messages.

gvijqb commented 1 week ago

I checked again, @gvijqb the argument is select_speaker_transform_messages.

Thanks @ekzhu. This one's correct and it worked. But now I randomly get this error:

An assistant message with 'tool_calls' must be followed by tool messages responding to each 'tool_call_id'. The following tool_call_ids did not have response messages: toolu_01FSvDUeBkQLZF3rsrBzJbTR"

That could possibly mean that the tool call sequence might be getting disrupted. How can I handle this scenario? I have tried implementing a custom handler for preserving the tool call flow but that doesn't seem to be helpful so far. It still results in the above error at times.

ekzhu commented 1 week ago

@WaelKarkoub can message transform automatically handle tool call pairs?

gvijqb commented 2 days ago

@ekzhu @WaelKarkoub is there any update on this?

ekzhu commented 2 days ago

@gvijqb Could you debug into this? I suspect it is something to do with the TransformMessage handling of tool call pairs.