{
  "batch_mode": "complete_episodes",
  "clip_param": 0.3,
  "entropy_coeff": 0.01,
  "env": "mpe_simple_push",
  "evaluation_interval": 10,
  "framework": "torch",
  "kl_coeff": 0.2,
  "lambda": 1.0,
  "lr": 0.0005,
  "model": {
    "custom_model": "Centralized_Critic_Model",
    "custom_model_config": {
      "algo_args": {
        "batch_episode": 10,
        "batch_mode": "complete_episodes",
        "clip_param": 0.3,
        "entropy_coeff": 0.01,
        "kl_coeff": 0.2,
        "lambda": 1.0,
        "lr": 0.0005,
        "num_sgd_iter": 5,
        "use_gae": true,
        "vf_clip_param": 20.0,
        "vf_loss_coeff": 1.0
      },
      "algorithm": "mappo",
      "env": "mpe",
      "env_args": {
        "continuous_actions": false,
        "map_name": "simple_push",
        "max_cycles": 25
      },
      "episode_limit": 25,
      "evaluation_interval": 10,
      "framework": "torch",
      "global_state_flag": false,
      "local_mode": false,
      "mask_flag": false,
      "model_arch_args": {
        "core_arch": "gru",
        "fc_layer": 1,
        "hidden_state_size": 256,
        "out_dim_fc_0": 128
      },
      "num_agents": 2,
      "num_cpus_per_worker": 10,
      "num_gpus": 1,
      "num_gpus_per_worker": 0,
      "num_workers": 10,
      "opp_action_in_cc": true,
      "policy_mapping_info": {
        "simple_adversary": {
          "all_agents_one_policy": false,
          "description": "one team attack, one team survive",
          "one_agent_one_policy": true,
          "team_prefix": [
            "adversary_",
            "agent_"
          ]
        },
        "simple_crypto": {
          "all_agents_one_policy": false,
          "description": "two team cooperate, one team attack",
          "one_agent_one_policy": true,
          "team_prefix": [
            "eve_",
            "bob_",
            "alice_"
          ]
        },
        "simple_push": {
          "all_agents_one_policy": false,
          "description": "one team target on landmark, one team attack",
          "one_agent_one_policy": true,
          "team_prefix": [
            "adversary_",
            "agent_"
          ]
        },
        "simple_reference": {
          "all_agents_one_policy": true,
          "description": "one team cooperate",
          "one_agent_one_policy": true,
          "team_prefix": [
            "agent_"
          ]
        },
        "simple_speaker_listener": {
          "all_agents_one_policy": true,
          "description": "two team cooperate",
          "one_agent_one_policy": true,
          "team_prefix": [
            "speaker_",
            "listener_"
          ]
        },
        "simple_spread": {
          "all_agents_one_policy": true,
          "description": "one team cooperate",
          "one_agent_one_policy": true,
          "team_prefix": [
            "agent_"
          ]
        },
        "simple_tag": {
          "all_agents_one_policy": false,
          "description": "one team attack, one team survive",
          "one_agent_one_policy": true,
          "team_prefix": [
            "adversary_",
            "agent_"
          ]
        },
        "simple_world_comm": {
          "all_agents_one_policy": false,
          "description": "two team cooperate and attack, one team survive",
          "one_agent_one_policy": true,
          "team_prefix": [
            "adversary_",
            "leaderadversary_",
            "agent_"
          ]
        }
      },
      "seed": 123,
      "share_policy": "group",
      "space_act": "Discrete(5)",
      "space_obs": "Dict(obs:Box([-100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100.\n -100. -100. -100. -100. -100. -100. -100.], [100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100.\n 100. 100. 100. 100. 100.], (19,), float32))",
      "stop_iters": 99999999,
      "stop_reward": 99999999,
      "stop_timesteps": 20000000
    }
  },
  "multiagent": {
    "policies": {
      "policy_adversary_": [
        null,
        "Dict(obs:Box([-100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100.\n -100. -100. -100. -100. -100. -100. -100.], [100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100.\n 100. 100. 100. 100. 100.], (19,), float32))",
        "Discrete(5)",
        {}
      ],
      "policy_agent_": [
        null,
        "Dict(obs:Box([-100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100. -100.\n -100. -100. -100. -100. -100. -100. -100.], [100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100. 100.\n 100. 100. 100. 100. 100.], (19,), float32))",
        "Discrete(5)",
        {}
      ]
    },
    "policy_mapping_fn": "<function run_cc.<locals>.<lambda> at 0x7f11726249d8>"
  },
  "num_gpus": 1,
  "num_gpus_per_worker": 0,
  "num_sgd_iter": 5,
  "num_workers": 10,
  "sgd_minibatch_size": 250,
  "simple_optimizer": false,
  "train_batch_size": 250,
  "use_gae": true,
  "vf_clip_param": 20.0,
  "vf_loss_coeff": 1.0
}