import argparse
from social_dilemma_game_agent import Agent, Game
from tqdm import tqdm
import json

if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument('--game', type=str, default='eacape_room')
    parser.add_argument('--max_negotiation_round', type=int, default=3)
    parser.add_argument('--who_first', type=str, default='Bob')
    parser.add_argument('--personality', type=str, default="rational")
    parser.add_argument('--sample_num', type=int, default=10)
    parser.add_argument('--prompt_for_negotiate', type=int, default=7)
    parser.add_argument('--model', type=str, default='deepseek')
    parser.add_argument('--use_cot', type=bool, default=True)
    args = parser.parse_args()


    result_save_dir = f'result/single_round/{args.model}/{args.game}_{args.personality}_negotiation_{args.max_negotiation_round}_{args.who_first}_{args.use_cot}.json'

    args.system_prompt = f'You are a {args.personality} assistant that carefully answer the question.'
    decisions = []
    procedure = []
    thought = []
    for i in tqdm(range(args.sample_num)):
        game = Game(args)
        alice_action, bob_action = game.play()
        # 打印结果
        print(f"Alice chose: {alice_action}, Bob chose: {bob_action}")
        procedure.append(game.alice.previous_message)
        thought.append(game.alice.privious_thought)
        decisions.append({'Alice_action':alice_action, 'Bob_action':bob_action})
        with open(result_save_dir, 'w') as f:
            json.dump({'decisions':decisions, 'negotiation':procedure, 'thought':thought}, f, indent=4)


