logging:
  output_dir: ../output/chess_game
manager:
  args:
    max_rounds: 200
    win_conditions:
      - Checkmate
    draw_conditions:
      - Stalemate
      - ThreefoldRepetition
      - FiftyMoveRule
      - InsufficientMaterial
    max_player_attempts: 1
game:
  name: chess
  players:
    - name: chess_player
      args:
        id: llama_black_mipro
        roles:
          - Black
        optimize: false
        datasets:
          - dataset: chess_puzzle_dataset
            dataset_args:
              role: Black
              num_samples: 100
        optimizer: MIPROv2
        compilation_args:
          requires_permission_to_run: false
          num_trials: 10
          minibatch_size: 10
          max_bootstrapped_demos: 3
          max_labeled_demos: 3
        metric: chess_move_validation_metric
        lm:
          type: OpenAI
          args:
            
            model_type: chat
            base_url: XXXX
            model: meta-llama/Meta-Llama-3.1-70B-Instruct
            max_tokens: 1600
        max_tries: 0
    - name: chess_player
      args:
        id: llama_white_bsfsrs
        roles:
          - White
        optimize: true
        datasets:
          - dataset: chess_puzzle_dataset
            dataset_args:
              role: White
              num_samples: 100
        # optimizer: MIPROv2
        # optimizer_args:
        #   init_temperature: 1
        # compilation_args:
        #   requires_permission_to_run: false
        #   minibatch_size: 10
        #   num_trials: 10
        #   max_bootstrapped_demos: 3
        #   max_labeled_demos: 3
        optimizer: BootstrapFewshotWithRandomSearch
        optimizer_args:
          num_candidate_programs: 8
          max_bootstrapped_demos: 3
          max_labeled_demos: 3
        metric: chess_move_validation_metric
        lm:
          type: OpenAI
          args:
            
            model_type: chat
            base_url: XXXX
            model: meta-llama/Meta-Llama-3.1-70B-Instruct
            max_tokens: 1600
        max_tries: 0
    