Skip to main content

Web Social Simulator for WWW'25 AgentSociety Challenge

Project description

AgentSociety Challenge Logo

WWW'25 AgentSociety Challenge: WebSocietySimulator

🚀 AgentSociety Challenge

LicenseCompetition Link

Welcome to the WWW'25 AgentSociety Challenge! This repository provides the tools and framework needed to participate in a competition that focuses on building LLM Agents for user behavior simulation and recommendation systems based on open source datasets.

Participants are tasked with developing intelligent agents that interact with a simulated environment and perform specific tasks in two competition tracks:

  1. User Behavior Simulation Track: Agents simulate user behavior, including generating reviews and ratings.
  2. Recommendation Track: Agents generate recommendations based on provided contextual data.

This repository includes:

  • The core library websocietysimulator for environment simulation.
  • Scripts for dataset processing and analysis.
  • Example usage for creating and evaluating agents.

Directory Structure

1. websocietysimulator/

This is the core library containing all source code required for the competition.

  • agents/: Contains base agent classes (SimulationAgent, RecommendationAgent) and their abstractions. Participants must extend these classes for their implementations.
  • task/: Defines task structures for each track (SimulationTask, RecommendationTask).
  • llm/: Contains base LLM client classes (DeepseekLLM, OpenAILLM).
  • tools/: Includes utility tools:
    • InteractionTool: A utility for interacting with the Yelp dataset during simulations.
    • EvaluationTool: Provides comprehensive metrics for both recommendation (HR@1/3/5) and simulation tasks (RMSE, sentiment analysis).
  • simulator.py: The main simulation framework, which handles task and groundtruth setting, evaluation and agent execution.

2. example/

Contains usage examples of the websocietysimulator library. Includes sample agents and scripts to demonstrate how to load scenarios, set agents, and evaluate them.

3. data_process.py

A script to process the raw Yelp dataset into the required format for use with the websocietysimulator library. This script ensures the dataset is cleaned and structured correctly for simulations.


Quick Start

1. Install the Library

The repository is organized using Python Poetry. Follow these steps to install the library:

  1. Clone the repository:

    git clone <this_repo>
    cd websocietysimulator
    
  2. Install dependencies:

  • Option 1: Install dependencies using Poetry: (Recommended)
    poetry install  && \
    poetry shell
    
  • Option 2: Install dependencies using pip(COMING SOON):
    pip install websocietysimulator
    
  • Option 3: Install dependencies using conda:
    conda create -n websocietysimulator python=3.11 && \
    conda activate websocietysimulator && \
    pip install -r requirements.txt && \
    pip install .
    
  1. Verify the installation:
    import websocietysimulator
    

2. Data Preparation

  1. Download the raw dataset from the Yelp[1], Amazon[2] or Goodreads[3].
  2. Run the data_process.py script to process the dataset:
    python data_process.py --input <path_to_raw_dataset> --output <path_to_processed_dataset>
    
  • Check out the Data Preparation Guide for more information.
  • NOTICE: You Need at least 16GB RAM to process the dataset.

3. Organize Your Data

Ensure the dataset is organized in a directory structure similar to this:

<your_dataset_directory>/
├── item.json
├── review.json
├── user.json

You can name the dataset directory whatever you prefer (e.g., dataset/).


4. Develop Your Agent

Create a custom agent by extending either SimulationAgent or RecommendationAgent. Refer to the examples in the example/ directory. Here's a quick template:

from yelpsimulator.agents.simulation_agent import SimulationAgent

class MySimulationAgent(SimulationAgent):
    def workflow(self):
        # The simulator will automatically set the task for your agent. You can access the task by `self.task` to get task information.
        print(self.task)

        # You can also use the `interaction_tool` to get data from the dataset.
        # For example, you can get the user information by `interaction_tool.get_user(user_id="example_user_id")`.
        # You can also get the item information by `interaction_tool.get_item(item_id="example_item_id")`.
        # You can also get the reviews by `interaction_tool.get_reviews(review_id="example_review_id")`.
        user_info = interaction_tool.get_user(user_id="example_user_id")

        # Implement your logic here
        
        # Finally, you need to return the result in the format of `stars` and `review`.
        # For recommendation track, you need to return a candidate list of items, in which the first item is the most recommended item.
        stars = 4.0
        review = "Great experience!"
        return stars, review

5. Evaluation your agent with training data

Run the simulation using the provided Simulator class:

from websocietysimulator import Simulator
from my_agent import MySimulationAgent

# Initialize Simulator
simulator = Simulator(data_dir="path/to/your/dataset", device="auto", cache=False)
# The cache parameter controls whether to use cache for interaction tool.
# If you want to use cache, you can set cache=True. When using cache, the simulator will only load data into memory when it is needed, which saves a lot of memory.
# If you want to use normal interaction tool, you can set cache=False. Notice that, normal interaction tool will load all data into memory at the beginning, which needs a lot of memory (20GB+).

# Load scenarios
simulator.set_task_and_groundtruth(task_dir="path/to/task_directory", groundtruth_dir="path/to/groundtruth_directory")

# Set your custom agent
simulator.set_agent(MySimulationAgent)

# Set LLM client
simulator.set_llm(DeepseekLLM(api_key="Your API Key"))

# Run evaluation
# If you don't set the number of tasks, the simulator will run all tasks.
agent_outputs = simulator.run_simulation(number_of_tasks=None, enable_threading=True, max_workers=10)

# Evaluate the agent
evaluation_results = simulator.evaluate()
  • If you want to use your own LLMClient, you can easily implement it by inheriting the LLMBase class. Refer to the Tutorial for more information.

6. Submit your agent

  • You should register your team firstly in the competition homepage (Homepage).
  • Submit your solution through the submission button at the specific track page. (the submission button is at the top right corner of the page)
  • The content of your submission should be a .py file containing your agent (Only one {your_team}.py file without evaluation code).
  • Example submissions:

Introduction to the InteractionTool

The InteractionTool is the core utility for interacting with the dataset. It provides an interface for querying user, item, and review data.

Functions

  • Get User Information: Retrieve user data by user ID or current scenario context.

    user_info = interaction_tool.get_user(user_id="example_user_id")
    
  • Get Item Information: Retrieve item data by item ID or current scenario context.

    item_info = interaction_tool.get_item(item_id="example_item_id")
    
  • Get Reviews: Fetch reviews related to a specific item or user, filtered by time.

    reviews = interaction_tool.get_reviews(review_id="example_review_id")  # Fetch a specific review
    reviews = interaction_tool.get_reviews(item_id="example_item_id")  # Fetch all reviews for a specific item
    reviews = interaction_tool.get_reviews(user_id="example_user_id")  # Fetch all reviews for a specific user
    

License

This project is licensed under the MIT License. See the LICENSE file for details.

References

[1] Yelp Dataset: https://www.yelp.com/dataset

[2] Amazon Dataset: https://amazon-reviews-2023.github.io/

[3] Goodreads Dataset: https://sites.google.com/eng.ucsd.edu/ucsdbookgraph/home

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

websocietysimulator-1.0.0a11.tar.gz (26.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

websocietysimulator-1.0.0a11-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

Details for the file websocietysimulator-1.0.0a11.tar.gz.

File metadata

  • Download URL: websocietysimulator-1.0.0a11.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.0 CPython/3.12.8 Linux/6.5.0-1025-azure

File hashes

Hashes for websocietysimulator-1.0.0a11.tar.gz
Algorithm Hash digest
SHA256 02a8ef2b77864728f2a9a1d483b4c4740dc8847f3fdd1db150bd8f23bfbb422a
MD5 bb657eb34b6024c1a97400bcc462e6d0
BLAKE2b-256 7827c60113b59e3270d9e22bb43c36984dea7ae26f4b0b52b5ad3888c928fd1b

See more details on using hashes here.

File details

Details for the file websocietysimulator-1.0.0a11-py3-none-any.whl.

File metadata

File hashes

Hashes for websocietysimulator-1.0.0a11-py3-none-any.whl
Algorithm Hash digest
SHA256 8f925d74f911810a9282188ddced1dd5a5293222ae0842c89585351e78484ff7
MD5 b80bf825b9b3f3a6675cc247dd789214
BLAKE2b-256 d17831e3be1c030486b527c386d098c3323e18fae9a8d3ac062b3f57c3642fae

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page