Skip to content

CUHK-ARISE/GAMABench

Repository files navigation

💰GAMA-Bench

Leaderboard

Overall Guessing Bar Dollar Goods Diner Auction Battle Pirate
👑Gemini-1.5-Pro 69.8 95.4 37.2 93.8 100 35.9 26.9 81.3 87.9
GPT-4o-0806 66.7 94.3 70 95.2 90.9 10.7 20.8 67.3 84.4
LLaMA-3.1-70B 65.9 84 59.7 87 90.6 48.1 15.7 77.7 64
GPT-4t-0125 62.4 91.6 23 98.1 89.2 0.9 24.2 86.8 85.4
Mixtral-8x22B 62.4 83.6 39.3 79 83.7 79.9 13.2 36 84.3
LLaMA-3.1-405B 61.8 94.3 20.5 94.9 97 14.4 14.7 92.7 65.6
Qwen-2-72B 56.7 93.2 17 91.9 81.3 0 2.5 81.7 86.1
LLaMA-3.1-8B 56 85.5 75.7 56.4 19.6 59.3 37.1 35.9 78.3
Gemini-1.0-Pro 45.7 77.3 33.5 77.6 68.5 3.1 31.6 16.5 57.4
GPT-3.5-1106 45.1 68.5 64.3 70.3 43.5 1.4 7.6 35.7 69.5
GPT-3.5-0125 44.4 63.4 68.7 68.6 38.9 2.8 13 28.6 71.6
Mixtral-8x7B 43.4 91.8 66.8 1.2 27.6 76.4 3.1 12.6 67.3
GPT-3.5-0613 42.7 41.4 74.8 42.4 17.7 67 10.3 19.5 68.4

Updates

[Nov 25, 2024] Add models: GPT-4o-0806; Improve the score scheme of SBA;

[Aug 29, 2024] Add models: Gemini-1.5-Pro, LLaMA-3.1-{8, 70, 405}B, Mixtral-8x{7, 22}B, Qwen-2-72B;

[Apr 25, 2024] Update scoring scheme of Public Goods Game, Diner's Dilemma, and Sealed-Bid Auction to favor rational strategies (being self-interested); Update leaderboard;

Execution Process

Create Utils File

Customize the model api, create a utils.py in this dictionary:

openai_api_key = "<key>"    # Keep it empty string if not use
infradeep_api_key = "<key>" # Keep it empty string if not use
google_api_key = "<key>"    # Keep it empty string if not use
temperature = "<model temperature>"
delay_time = "<time break between each request>"

Specify Test Cases

In main.py, specify the server parameters:

  1. Import the following files:

    from server import *
    from global_functions import *
  2. Import the game:

    from games.guessing_game import *
  3. Create a simple game instance:

    game = GuessingGame(player_num=10, min=0, max=100, ratio=2/3, ratio_str='2/3', version='v1', models='gpt-3.5-turbo', name_exp='test')
    • player_num: An integer refers to the number of players
    • min, max, ratio, ratio_str: Game parameters, different games may have different parameters
    • version: A string refers to the prompt version (default: "v1")
    • models: A string or a list of models, the instruction of customizing models would be illustrated in the "Models Instruction" section (default: "gpt-3.5-turbo")
    • name_exp: A string that specifies the name of all output files belonging to this game instance
  4. Run a game instance for 20 rounds:

    game.run(20)

    After a round is completed, a JSON saving file will be stored in the "save" directory sharing the same name with name_exp, all model requests and responses records will be stored in the "records" directory , and the visualized game results will be store in the "figures" directory

  5. Load a game:

    game = load(filepath='save/test.json', object=GuessingGame)  # load the saved data 
    game = load(filepath='save/test.json', object=GuessingGame, newfile='test2')  # load and save as new file
    game.run(20)
    • filepath: A string refers to the path of the loading data
    • object: The game object that going to load
    • namefile: If it is None, the server will continue to update the current file, otherwise, the server will copy the file to a new file and update there
  6. Show the visualized and statistical analysis of game instance:

    game.show()

Additional Operations

Models Instruction

User can specify the models by passing a string or a list of models name when creating the game instance

  • If the parameter is a string, which implies all players within the game instance are all referring to that model

    game = GuessingGame(player_num=10, ..., models='gpt-3.5-turbo') # 10 players are all gpt-3.5-turbo
  • If the parameter is a list, which implies that players are agented by the models based on their position in the list, but the number of players must match the length of the list

    # player_0 to player_4 are gpt-3.5-turbo, player_5 to player_9 are gpt-4
    models = ["gpt-3.5-turbo" for _ in range(5)] + ["gpt-4" for _ in range(5)]
    game = GuessingGame(player_num=10, ..., models=models)
    models = ['gpt-3.5-turbo' if i%2==0 else 'gpt-4' for i in range(10)]

Supported models

  • OpenAI models family: models name start with gpt-3.5-turbo and gpt-4, user can specify the model version, such as gpt-3.5-turbo-0125
  • Gemini models family: models name start with gemini, such as gemini-pro-1.0

Special players

We also support user to specify some special players with fixed strategies

  1. specified=<response_1>/<response_2>/.../<response_n>: The player will response the specified answers repeatly

    models = ["specified=0"] + ["gpt-3.5-turbo" for _ in range(9)]  # first player always responses 0 in every round
    models = ["specified=0/100"] + ["gpt-3.5-turbo" for _ in range(9)]  # first player alternatively responses 0 and 100
  2. user: User can participant the game with models by inserting user to the list by giving the responses in the terminal

    models = ["user"] + ["gpt-3.5-turbo" for _ in range(9)]

Rephrase prompts

Games usually consist of 3 prompts "description", "report" and "request" (bar game consists of "explicit" and "implicit" versions of report), user can rephrase the prompts using GPT-4 and the provided implementation

from prompt_template.prompt_rephrase import *
game_file = 'guessing_game'
rephrase_files = ['description', 'report', 'request']
rephrase([f"prompt_template/{game_file}/{filename}_v1.txt" for filename in rephrase_files], replace_suffix="v1", suffix="v2")

Result Analysis

For GuessingGame, BarGame, DivideDollar, and DinerDilemma, we developed a tool to visualize and integrate multiple runs into a figure, as shown in our paper. analysis_main.ipynb demonstrated the sample usage of our tool.

Analyze Multiple Runs

In analysis_main.ipynb, specify the server and analysis parameters:

  1. Import the following files:

    from server import *
    from global_functions import *
    from analysis import *
  2. Import the game:

    from games.guessing_game import *
  3. Create an Analysis instance:

    plane = Analysis(GuessingGame)
  4. Add the saved run with label:

    plane.add('raw_results/guessing_game/guessing_game_v1_1.json', "T1")
  5. Plot the graph:

    plane.plot()
    • index: Figure index, for some games, we provided more than one figure for the analysis. For example, in DinerDilemma, we provide a graph demonstrating the percentage of players who choose "cheap" in each round; we also provide a graph demonstrating the averaged accumulated percentage of players who chose "cheap"; default 0.
    • title: Title of the graph; default None
    • xlabel: Label of the x axis, default "Round"
    • ylabel: Label of the y axis, default None
    • ylim: Range of y axis, default None
    • loc: Location of the legend, default "upper right"
    • format: Figure format, default "png"
    • savename: Name of the figure, default "merge"

👉 Paper and Citation

For more details, please refer to our paper here.

If you find our paper&tool interesting and useful, please feel free to give us a star and cite us through:

@article{huang2024how,
  author    = {Jen{-}tse Huang and
               Eric John Li and
               Man Ho Lam and
               Tian Liang and
               Wenxuan Wang and
               Youliang Yuan and
               Wenxiang Jiao and
               Xing Wang and
               Zhaopeng Tu and
               Michael R. Lyu},
  title     = {How Far Are We on the Decision-Making of LLMs? Evaluating LLMs' Gaming Ability in Multi-Agent Environments},
  journal   = {arXiv preprint arXiv:2403.11807},
  year      = {2024}
}

About

Benchmarking LLMs' Gaming Ability in Multi-Agent Environments

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •