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

feat: enabled saving and evaluation for moderator (#271) #272

Merged
merged 30 commits into from
Jan 18, 2025

Conversation

XuhuiZhou
Copy link
Member

@XuhuiZhou XuhuiZhou commented Jan 7, 2025

  • feat: enable saving AgentProfile and chat history on redis

  • fix: AgentProfile can now be loaded by EpisodeLog correctly

  • feat: enable evaluation of EpisodeLog

  • [autofix.ci] apply automated fixes

  • fix: use EpisodeLog and AgentProfile from sotopia directly


Closes #231 #232

📑 Description

✅ Checks

  • My pull request adheres to the code style of this project
  • My code requires changes to the documentation
  • I have updated the documentation as required
  • All the tests have passed
  • Branch name follows type/descript (e.g. feature/add-llm-agents)
  • Ready for code review

ℹ Additional Information

XuhuiZhou and others added 24 commits December 4, 2024 20:58
* api doc

* add PUT

* add an temp example for websocket

* websocket

* update readme

* Update README.md

* update websocket live simulation api doc

* [autofix.ci] apply automated fixes

* update websocket doc

* add api server with websocket as well as a client

* fix mypy errors

* support stopping the chat

* add 404 to the status code

* fix mypy issue

* update the returned message types

* redesign websocket api

* update websocket, fix mypy error

* add example of using websocket

* clean code & change to existing functions for simulation

* fix typing mismatch

* update doc & mypy type fix

* add type check for run_async_server

* move example

---------

Co-authored-by: Hao Zhu <prokilchu@gmail.com>
Co-authored-by: Zhe Su <360307598@qq.com>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
* add customizable evaluation dimensions

* add docs

* fix mypy error & refactor examples

* add docs for evaluation dimensions

* update docs and examples

* add test cases and fix mypy issue

* fix mypy issue

* Fix test_create_custom_dimension to use CustomEvaluationDimension.get(pk) (#262)

Co-authored-by: openhands <openhands@all-hands.dev>

* Fix/custom eval dimension test (#263)

* Fix test_create_custom_dimension to use CustomEvaluationDimension.get(pk)

* Update documentation for SotopiaDimension and EvaluationDimensionBuilder

* [autofix.ci] apply automated fixes

* Add API documentation for evaluation dimensions

* Refine API documentation for evaluation_dimensions.py to match style

* [autofix.ci] apply automated fixes

---------

Co-authored-by: openhands <openhands@all-hands.dev>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>

* add doc

---------

Co-authored-by: XuhuiZhou <zhouxuhui2018@gmail.com>
Co-authored-by: openhands <openhands@all-hands.dev>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
…lationshio (#265)

* temp run

* add relationship api

* fix mypy error

* update relationship api

* simulate episode non-streaming

* modify sim episodes

* add simulation status

* task error

* add background task

* [autofix.ci] apply automated fixes

* back to arun one episode

* upload the code

* use rq to execute background tasks

* temp sol

---------

Co-authored-by: Hao Zhu <prokilchu@gmail.com>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
* initial framework

* initial conv

* fix module error

* feat: Add 3 new features to Moderator (#266)

* feat:introduce booting procedure, saving, and ending chat to moderator

* fix: moderator will now ignore none AgentAction, Observations now don't have to include all channels in the mapping

* merge changes of example into the original one

* fix: 1. save() method now accepts push_to_db config 2. booting()'s waiting time is changed to 0.1 sec

* fix: rewrite booting() so that different agent will receive different background information

* fix: moderator now inherits from Node directly, instead of from BaseAgent

---------

Co-authored-by: JXZhou <JXZhou>

* add save condition for moderator

* push to db false

* to fully stop

* stopping all agents

* fix mypy

* fix mypy error

---------

Co-authored-by: JXZhou <156194797+JXZhou0224@users.noreply.github.com>
* prototype for modal serving

* add openai secret

* fix type annotation

* add doc

* bug fix for simulation api

* add customize model, evaluator model and evaluation dimensions

* Implement modal API server with Redis integration and FastAPI setup

- Added a new script for the modal API server that initializes a Redis instance.
- Created a persistent volume for Redis data and included a function to download initial data if not present.
- Configured a Docker image with necessary dependencies including Redis Stack and FastAPI.
- Implemented a web API class that sets up and cleans up the Redis connection, ensuring readiness before serving requests.
- Integrated the SotopiaFastAPI application within the modal framework.

---------

Co-authored-by: XuhuiZhou <zhouxuhui2018@gmail.com>
* initial

* initial ui

* merge main

* add new ui

* switch to fastAPI

* websocket check

* fix render episode error

* add  page; make a simplified page and still WIP

* [autofix.ci] apply automated fixes

* fix simplified streaming version

* semi-done character page + avatar assets

* Fixed character card styling

* [autofix.ci] apply automated fixes

* unified rendering and chat display

* updated chat character icons

* add some tags

* add typing

* temp fix

* add characters avatar to simulation

* fix episode full avatar

* go to modal config

* clean up code

* add modal streamlit app

* clean codebase except websocket

* remove repeated local css

* clean websocket

* fix get name error

* fix errors

* pre render scenario

* add custom eval

* change streamlit to dynamic path

* new uv

* revert to previous install commands

* a fix for modal

* add customized dimension

* [autofix.ci] apply automated fixes

* sort scenarios in simulation

* for demo video

* update deploy instruction

* update intro page

* update intro page

* [autofix.ci] apply automated fixes

* update intro page

* add customized dimensions

* update api link and modal environment

* move folder

* fix relative import

* update modal image build

* use uv to build environment

* change folder name

* change test

* fix modal serve

* environment change

* refactor

* fix ui

---------

Co-authored-by: Zhe Su <360307598@qq.com>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
Co-authored-by: astrophie <sophie.w.feng@gmail.com>
* feat: enable saving AgentProfile and chat history on redis

* fix: AgentProfile can now be loaded by EpisodeLog correctly

* feat: enable evaluation of EpisodeLog

* [autofix.ci] apply automated fixes

* fix: use EpisodeLog and AgentProfile from sotopia directly

---------

Co-authored-by: JXZhou <JXZhou>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
@XuhuiZhou XuhuiZhou marked this pull request as draft January 7, 2025 19:46
last_turn=self.scenario,
last_turn=json.dumps(
{
"use_pk_value": self.use_pk_value,
Copy link
Member Author

Choose a reason for hiding this comment

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

What is this for?

Copy link
Collaborator

Choose a reason for hiding this comment

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

The hyperparameter that determines "whether to use AgentProfile from exisiting database" is set in the moderator. Therefore, moderator will communicate this information to all Agents before the start of conversation.

Copy link
Member Author

@XuhuiZhou XuhuiZhou Jan 8, 2025

Choose a reason for hiding this comment

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

Sounds good! It's okay if we design things that each agent initialize their own background. However, things could be tricky as the agent has no idea of other agents background and the general scenario. Unless we have a second step to make that happen.

Another easier way is to follow the original sotopia implementation:
Can you follow the reset here to write a similar version of initiating the simulation but allows more than two agents?

def reset(

Copy link
Collaborator

Choose a reason for hiding this comment

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

certainly! I will try implementing it.

epilog.save()
# print(epilog.render_for_humans())
if self.push_to_db:
epilog.save()
return epilog
Copy link
Member Author

Choose a reason for hiding this comment

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

Maybe we need to change this to evaluation queue or something

self.model_name: str = model_name
self.agent_profile_pk: str = agent_pk
self.name: str = agent_name
self.background: dict = background
Copy link
Member Author

@XuhuiZhou XuhuiZhou Jan 8, 2025

Choose a reason for hiding this comment

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

Note self.background is not used anywhere when generating the agent actions

@XuhuiZhou XuhuiZhou changed the base branch from demo to main January 8, 2025 18:38
@XuhuiZhou
Copy link
Member Author

@JXZhou0224 I have changed the base from demo to main, please git merge main to update the branch and resolve conflicts.

Please also run uv run mypy --strict . to make sure there are no mypy errors.

@XuhuiZhou XuhuiZhou marked this pull request as ready for review January 16, 2025 19:34
Copy link

codecov bot commented Jan 16, 2025

Codecov Report

Attention: Patch coverage is 60.00000% with 2 lines in your changes missing coverage. Please review.

Project coverage is 75.34%. Comparing base (3b9e842) to head (cb441c0).
Report is 31 commits behind head on main.

Files with missing lines Patch % Lines
sotopia/server.py 0.00% 2 Missing ⚠️
@@           Coverage Diff           @@
##             main     #272   +/-   ##
=======================================
  Coverage   75.34%   75.34%           
=======================================
  Files          64       64           
  Lines        3727     3727           
=======================================
  Hits         2808     2808           
  Misses        919      919           
Files with missing lines Coverage Δ
sotopia/api/fastapi_server.py 72.45% <ø> (ø)
sotopia/api/websocket_utils.py 85.91% <ø> (ø)
sotopia/cli/benchmark/benchmark.py 86.97% <ø> (ø)
sotopia/database/logs.py 94.54% <100.00%> (ø)
sotopia/envs/evaluators.py 90.41% <100.00%> (ø)
tests/api/test_fastapi.py 89.44% <ø> (ø)
tests/envs/test_evaluators.py 100.00% <100.00%> (ø)
tests/integration/test_benchmark.py 99.10% <ø> (ø)
sotopia/server.py 44.94% <0.00%> (ø)

@JXZhou0224 JXZhou0224 merged commit ea14fda into main Jan 18, 2025
9 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

aact-based BaseEngine + Orchestrator Implementation
4 participants