Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Make groupchat & generation async, actually #543

Merged
merged 19 commits into from
Dec 9, 2023
Merged

Make groupchat & generation async, actually #543

merged 19 commits into from
Dec 9, 2023

Conversation

kittyandrew
Copy link

@kittyandrew kittyandrew commented Nov 4, 2023

Why are these changes needed?

Those are the changes I made when developing application using autogen and asynchronous server. The core problem it addresses is ConversableAgent.generate_oai_reply being sync, so even when calling async version of initiate chat or send, in the end the whole application gets blocked by sync call underneath. So, this PR includes async version of that via a simple executor wrapper and some other changes to make async groupchat work as expected.
Looking forward to your feedback, I'd love to get this merged and not maintain my own fork any longer than I need to.

Key parts:

Related issue number

Checks

Copy link
Contributor

@sonichi sonichi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please add a test to cover the new code. It'll be even better if the test case mimics a real use case and is documented.

autogen/agentchat/groupchat.py Outdated Show resolved Hide resolved
autogen/agentchat/conversable_agent.py Show resolved Hide resolved
@sonichi sonichi requested review from pcdeadeasy, AaronWard, ragyabraham and a team November 4, 2023 04:30
@sonichi sonichi added group chat/teams group-chat-related issues async labels Nov 4, 2023
@kittyandrew
Copy link
Author

kittyandrew commented Nov 4, 2023

Hey, @sonichi, thanks for the feedback.
I've refactored select speaker as you suggested and updated async func call handler name. Additionally, I've realized that there were some places in code that depended on index 1 to be before generation func, so I've updated those places to 2, where I saw them, since there are two generation funcs now.

What's still missing is test for async as you suggested, but I'm not sure how to proceed here to be honest. There are some tests using higher async functions already and I don't have a good idea for the clean test case. In my actual code async webserver is running at the same time, so it's a difference between being able to serve new requests in a meantime and not. Here though might replace that with a loop that has asyncio.sleep(0.5) inside it and it needs to iterate at least 10 times in the next 6 seconds or something, but this feels very hacky.

@sonichi sonichi requested a review from qingyun-wu November 4, 2023 17:16
@sonichi
Copy link
Contributor

sonichi commented Nov 4, 2023

Hey, @sonichi, thanks for the feedback. I've refactored select speaker as you suggested and updated async func call handler name. Additionally, I've realized that there were some places in code that depended on index 1 to be before generation func, so I've updated those places to 2, where I saw them, since there are two generation funcs now.

What's still missing is test for async as you suggested, but I'm not sure how to proceed here to be honest. There are some tests using higher async functions already and I don't have a good idea for the clean test case. In my actual code async webserver is running at the same time, so it's a difference between being able to serve new requests in a meantime and not. Here though might replace that with a loop that has asyncio.sleep(0.5) inside it and it needs to iterate at least 10 times in the next 6 seconds or something, but this feels very hacky.

Thanks. I'd like experts in async to chime in about the best way to write the test.

@kittyandrew
Copy link
Author

@microsoft-github-policy-service agree company="Manifold"

@sonichi
Copy link
Contributor

sonichi commented Nov 5, 2023

@aayushchhabra1999 @ragyabraham Could you please review this PR? Do you have suggestions about how to write the test?

@codecov-commenter
Copy link

codecov-commenter commented Nov 5, 2023

Codecov Report

Attention: 5 lines in your changes are missing coverage. Please review.

Comparison is base (379d7bd) 26.69% compared to head (0da3b34) 63.62%.

Files Patch % Lines
autogen/agentchat/groupchat.py 82.75% 3 Missing and 2 partials ⚠️
Additional details and impacted files
@@             Coverage Diff             @@
##             main     #543       +/-   ##
===========================================
+ Coverage   26.69%   63.62%   +36.92%     
===========================================
  Files          28       28               
  Lines        3742     3766       +24     
  Branches      849      895       +46     
===========================================
+ Hits          999     2396     +1397     
+ Misses       2670     1115     -1555     
- Partials       73      255      +182     
Flag Coverage Δ
unittests 63.43% <85.71%> (+36.79%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@sonichi sonichi requested review from yiranwu0 and ekzhu November 5, 2023 16:31
@sonichi
Copy link
Contributor

sonichi commented Nov 5, 2023

https://github.com/microsoft/autogen/actions/runs/6761699902/job/18376843408?pr=543
Please fix the code format issue.
@qingyun-wu @ekzhu could you help double check whether the change has any undesirable side effect?

@qingyun-wu qingyun-wu added this pull request to the merge queue Dec 9, 2023
Merged via the queue into microsoft:main with commit 6e23871 Dec 9, 2023
84 checks passed
rlam3 pushed a commit to rlam3/autogen that referenced this pull request Dec 19, 2023
* make groupchat & generation async actually

* factored out func call pre-select; updated indecies

* fixed code format issue

* mark prepare agents subset as internal

* func renaming

* func inputs

* return agents

* Update test/agentchat/test_async.py

Co-authored-by: Chi Wang <[email protected]>

* Update notebook/agentchat_stream.ipynb

Co-authored-by: Chi Wang <[email protected]>

---------

Co-authored-by: Chi Wang <[email protected]>
Co-authored-by: Qingyun Wu <[email protected]>
whiskyboy pushed a commit to whiskyboy/autogen that referenced this pull request Apr 17, 2024
* make groupchat & generation async actually

* factored out func call pre-select; updated indecies

* fixed code format issue

* mark prepare agents subset as internal

* func renaming

* func inputs

* return agents

* Update test/agentchat/test_async.py

Co-authored-by: Chi Wang <[email protected]>

* Update notebook/agentchat_stream.ipynb

Co-authored-by: Chi Wang <[email protected]>

---------

Co-authored-by: Chi Wang <[email protected]>
Co-authored-by: Qingyun Wu <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
group chat/teams group-chat-related issues
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants