{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Build an agent:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import minerl_training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_and_evaluate(agent: object, \n",
    "                       task: object, \n",
    "                       sum_writer: object, \n",
    "                       base_path: str, \n",
    "                       offset_episode_count: int = 0, \n",
    "                       nbr_max_observations: int = 1e7,\n",
    "                       test_obs_interval: int = 1e4,\n",
    "                       test_nbr_episode: int = 10,\n",
    "                       benchmarking_record_episode_interval: int = None):\n",
    "    return agent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "minerl_training.train_and_evaluate = train_and_evaluate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/media/kevin/TOSHIBA_EXT1/DATA/UNI/MineRL/minerl/train/Regym/regym/tests/integration/MineRL/minerl_training.py:129: YAMLLoadWarning: calling yaml.load() without Loader=... is deprecated, as the default Loader is unsafe. Please read https://msg.pyyaml.org/load for full details.\n",
      "  all_configs = yaml.load(open(config_file_path))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Path: -- MineRL_training/MineRLTreechop-v0/Seed13_venv_ppo_1actors_Sk4_St4_Obs84_NoGrayscale_NoScaling_PPOratio1m1_StdAdv_SingleRewardEpisode+P/ppo_LargeCNN_h128_b32 --\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2020-01-18 12:48:30 kevin-PRIME-Z270-P minerl.env.malmo.instance.41519e[11883] INFO Starting Minecraft process: ['/tmp/tmp57dmgsud/Minecraft/launchClient.sh', '-port', '9001', '-env', '-runDir', '/tmp/tmp57dmgsud/Minecraft/run']\n",
      "2020-01-18 12:48:30 kevin-PRIME-Z270-P minerl.env.malmo.instance.41519e[11883] INFO Starting process watcher for process 12423 @ localhost:9001\n",
      "2020-01-18 12:49:25 kevin-PRIME-Z270-P minerl.env.malmo.instance.41519e[11883] INFO Minecraft process ready\n",
      "2020-01-18 12:49:25 kevin-PRIME-Z270-P minerl.env.malmo[11883] INFO Logging output of Minecraft to ./logs/mc_1.log\n",
      "2020-01-18 12:49:28 kevin-PRIME-Z270-P minerl.env.malmo[11883] INFO Minecraft process psutil.Process(pid=12423, status='terminated') terminated with exit code 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CNN: layer output dim: 20\n",
      "CNN: layer output dim: 10\n",
      "CNN: layer output dim: 10\n",
      "ActorCriticNet(\n",
      "  (phi_body): ConvolutionalBody(\n",
      "    (convs): ModuleList(\n",
      "      (0): Conv2d(12, 32, kernel_size=(8, 8), stride=(4, 4), padding=(1, 1))\n",
      "      (1): Conv2d(32, 64, kernel_size=(4, 4), stride=(2, 2), padding=(1, 1))\n",
      "      (2): Conv2d(64, 64, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (fcs): ModuleList(\n",
      "      (0): Linear(in_features=6400, out_features=512, bias=True)\n",
      "    )\n",
      "  )\n",
      "  (actor_body): DummyBody()\n",
      "  (critic_body): DummyBody()\n",
      "  (fc_action): Linear(in_features=512, out_features=5, bias=True)\n",
      "  (fc_critic): Linear(in_features=512, out_features=1, bias=True)\n",
      ")\n",
      "phi_body.convs.0.weight torch.Size([32, 12, 8, 8])\n",
      "phi_body.convs.0.bias torch.Size([32])\n",
      "phi_body.convs.1.weight torch.Size([64, 32, 4, 4])\n",
      "phi_body.convs.1.bias torch.Size([64])\n",
      "phi_body.convs.2.weight torch.Size([64, 64, 3, 3])\n",
      "phi_body.convs.2.bias torch.Size([64])\n",
      "phi_body.fcs.0.weight torch.Size([512, 6400])\n",
      "phi_body.fcs.0.bias torch.Size([512])\n",
      "fc_action.weight torch.Size([5, 512])\n",
      "fc_action.bias torch.Size([5])\n",
      "fc_critic.weight torch.Size([1, 512])\n",
      "fc_critic.bias torch.Size([1])\n",
      "Learning rate: 0.00025\n"
     ]
    }
   ],
   "source": [
    "agents, tasks = minerl_training.main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "agent = agents[0]\n",
    "task = tasks[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Duplicate and parameterize the agents action sampling function:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "EPS = 1e-8\n",
    "VERBOSE = True \n",
    "\n",
    "def forward0(self, obs, action=None, rnn_states=None):\n",
    "    global EPS\n",
    "    global VERBOSE\n",
    "    if VERBOSE:\n",
    "        print(\"Sampling actions with function 0.\")\n",
    "    obs = tensor(obs)\n",
    "    next_rnn_states = None \n",
    "    if rnn_states is not None:\n",
    "        next_rnn_states = {k: None for k in rnn_states}\n",
    "\n",
    "    if rnn_states is not None and 'phi_arch' in rnn_states:\n",
    "        phi, next_rnn_states['phi_arch'] = self.network.phi_body( (obs, rnn_states['phi_arch']) )\n",
    "    else:\n",
    "        phi = self.network.phi_body(obs)\n",
    "\n",
    "    if rnn_states is not None and 'actor_arch' in rnn_states:\n",
    "        phi_a, next_rnn_states['actor_arch'] = self.network.actor_body( (phi, rnn_states['actor_arch']) )\n",
    "    else:\n",
    "        phi_a = self.network.actor_body(phi)\n",
    "\n",
    "    if rnn_states is not None and 'critic_arch' in rnn_states:\n",
    "        phi_v, next_rnn_states['critic_arch'] = self.network.critic_body( (phi, rnn_states['critic_arch']) )\n",
    "    else:\n",
    "        phi_v = self.network.critic_body(phi)\n",
    "\n",
    "    logits = self.network.fc_action(phi_a)\n",
    "    probs = F.softmax( logits, dim=-1 )\n",
    "    #https://github.com/pytorch/pytorch/issues/7014\n",
    "    #probs = torch.clamp(probs, -1e10, 1e10)\n",
    "\n",
    "    # batch x action_dim\n",
    "    v = self.network.fc_critic(phi_v)\n",
    "    if self.use_intrinsic_critic:\n",
    "        int_v = self.network.fc_int_critic(phi_v)\n",
    "    # batch x 1\n",
    "\n",
    "    batch_size = logits.size(0)\n",
    "\n",
    "    '''\n",
    "    # RND1\n",
    "    # probs:\n",
    "    dists = torch.distributions.categorical.Categorical(probs=probs)\n",
    "\n",
    "    if action is None:\n",
    "        action = dists.sample()#.unsqueeze(1)\n",
    "        # batch #x 1\n",
    "    log_prob = dists.log_prob(action)\n",
    "    # batch #x 1\n",
    "    entropy = dists.entropy().unsqueeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "\n",
    "    '''\n",
    "    '''\n",
    "    # NORMAL:\n",
    "    #log_probs = F.log_softmax(logits, dim=-1)\n",
    "    log_probs = torch.log(probs+EPS)\n",
    "    entropy = -torch.sum(probs*log_probs, dim=-1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        #action = (probs+EPS).multinomial(num_samples=1).squeeze(1)\n",
    "        action = torch.multinomial( probs, num_samples=1).squeeze(1)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    '''\n",
    "\n",
    "    '''\n",
    "    #RND2:\n",
    "    # probs:\n",
    "    log_probs = F.log_softmax(logits, dim=-1)\n",
    "    #entropy = dists.entropy().unsqueeze(1)\n",
    "    entropy = -(log_probs * probs).sum(1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        p = probs.detach().cpu().numpy()\n",
    "        axis = 1\n",
    "        r = np.expand_dims(np.random.rand(p.shape[1 - axis]), axis=axis)\n",
    "        action = (p.cumsum(axis=axis) > r).argmax(axis=axis)\n",
    "        action = torch.from_numpy(action).to(probs.device)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "\n",
    "    prediction = {'a': action,\n",
    "                'log_pi_a': log_probs,\n",
    "                'action_logits': logits,\n",
    "                'ent': entropy,\n",
    "                'v': v}\n",
    "\n",
    "    if self.use_intrinsic_critic:\n",
    "        prediction['int_v'] = int_v\n",
    "\n",
    "    if rnn_states is not None:\n",
    "        prediction.update({'rnn_states': rnn_states,\n",
    "                           'next_rnn_states': next_rnn_states})\n",
    "\n",
    "    return prediction\n",
    "\n",
    "\n",
    "def forward1(self, obs=None, action=None, rnn_states=None):\n",
    "    global EPS\n",
    "    global VERBOSE\n",
    "    if VERBOSE:\n",
    "        print(\"Sampling actions with function 1.\")\n",
    "    obs = tensor(obs)\n",
    "    next_rnn_states = None \n",
    "    if rnn_states is not None:\n",
    "        next_rnn_states = {k: None for k in rnn_states}\n",
    "\n",
    "    if rnn_states is not None and 'phi_arch' in rnn_states:\n",
    "        phi, next_rnn_states['phi_arch'] = self.network.phi_body( (obs, rnn_states['phi_arch']) )\n",
    "    else:\n",
    "        phi = self.network.phi_body(obs)\n",
    "\n",
    "    if rnn_states is not None and 'actor_arch' in rnn_states:\n",
    "        phi_a, next_rnn_states['actor_arch'] = self.network.actor_body( (phi, rnn_states['actor_arch']) )\n",
    "    else:\n",
    "        phi_a = self.network.actor_body(phi)\n",
    "\n",
    "    if rnn_states is not None and 'critic_arch' in rnn_states:\n",
    "        phi_v, next_rnn_states['critic_arch'] = self.network.critic_body( (phi, rnn_states['critic_arch']) )\n",
    "    else:\n",
    "        phi_v = self.network.critic_body(phi)\n",
    "\n",
    "    logits = self.network.fc_action(phi_a)\n",
    "    probs = F.softmax( logits, dim=-1 )\n",
    "    #https://github.com/pytorch/pytorch/issues/7014\n",
    "    #probs = torch.clamp(probs, -1e10, 1e10)\n",
    "\n",
    "    # batch x action_dim\n",
    "    v = self.network.fc_critic(phi_v)\n",
    "    if self.use_intrinsic_critic:\n",
    "        int_v = self.network.fc_int_critic(phi_v)\n",
    "    # batch x 1\n",
    "\n",
    "    batch_size = logits.size(0)\n",
    "\n",
    "    '''\n",
    "    '''\n",
    "    # RND1\n",
    "    # probs:\n",
    "    dists = torch.distributions.categorical.Categorical(probs=probs)\n",
    "\n",
    "    if action is None:\n",
    "        action = dists.sample()#.unsqueeze(1)\n",
    "        # batch #x 1\n",
    "    log_prob = dists.log_prob(action)\n",
    "    # batch #x 1\n",
    "    entropy = dists.entropy().unsqueeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    '''\n",
    "\n",
    "    '''\n",
    "    # NORMAL:\n",
    "    #log_probs = F.log_softmax(logits, dim=-1)\n",
    "    log_probs = torch.log(probs+EPS)\n",
    "    entropy = -torch.sum(probs*log_probs, dim=-1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        #action = (probs+EPS).multinomial(num_samples=1).squeeze(1)\n",
    "        action = torch.multinomial( probs, num_samples=1).squeeze(1)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    \n",
    "    '''\n",
    "    #RND2:\n",
    "    # probs:\n",
    "    log_probs = F.log_softmax(logits, dim=-1)\n",
    "    #entropy = dists.entropy().unsqueeze(1)\n",
    "    entropy = -(log_probs * probs).sum(1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        p = probs.detach().cpu().numpy()\n",
    "        axis = 1\n",
    "        r = np.expand_dims(np.random.rand(p.shape[1 - axis]), axis=axis)\n",
    "        action = (p.cumsum(axis=axis) > r).argmax(axis=axis)\n",
    "        action = torch.from_numpy(action).to(probs.device)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "\n",
    "    prediction = {'a': action,\n",
    "                'log_pi_a': log_probs,\n",
    "                'action_logits': logits,\n",
    "                'ent': entropy,\n",
    "                'v': v}\n",
    "\n",
    "    if self.use_intrinsic_critic:\n",
    "        prediction['int_v'] = int_v\n",
    "\n",
    "    if rnn_states is not None:\n",
    "        prediction.update({'rnn_states': rnn_states,\n",
    "                           'next_rnn_states': next_rnn_states})\n",
    "\n",
    "    return prediction\n",
    "\n",
    "\n",
    "def forward2(self, obs, action=None, rnn_states=None):\n",
    "    global EPS\n",
    "    global VERBOSE\n",
    "    if VERBOSE:\n",
    "        print(\"Sampling actions with function 2.\")\n",
    "    obs = tensor(obs)\n",
    "    next_rnn_states = None \n",
    "    if rnn_states is not None:\n",
    "        next_rnn_states = {k: None for k in rnn_states}\n",
    "\n",
    "    if rnn_states is not None and 'phi_arch' in rnn_states:\n",
    "        phi, next_rnn_states['phi_arch'] = self.network.phi_body( (obs, rnn_states['phi_arch']) )\n",
    "    else:\n",
    "        phi = self.network.phi_body(obs)\n",
    "\n",
    "    if rnn_states is not None and 'actor_arch' in rnn_states:\n",
    "        phi_a, next_rnn_states['actor_arch'] = self.network.actor_body( (phi, rnn_states['actor_arch']) )\n",
    "    else:\n",
    "        phi_a = self.network.actor_body(phi)\n",
    "\n",
    "    if rnn_states is not None and 'critic_arch' in rnn_states:\n",
    "        phi_v, next_rnn_states['critic_arch'] = self.network.critic_body( (phi, rnn_states['critic_arch']) )\n",
    "    else:\n",
    "        phi_v = self.network.critic_body(phi)\n",
    "\n",
    "    logits = self.network.fc_action(phi_a)\n",
    "    probs = F.softmax( logits, dim=-1 )\n",
    "    #https://github.com/pytorch/pytorch/issues/7014\n",
    "    #probs = torch.clamp(probs, -1e10, 1e10)\n",
    "\n",
    "    # batch x action_dim\n",
    "    v = self.network.fc_critic(phi_v)\n",
    "    if self.use_intrinsic_critic:\n",
    "        int_v = self.network.fc_int_critic(phi_v)\n",
    "    # batch x 1\n",
    "\n",
    "    batch_size = logits.size(0)\n",
    "\n",
    "    '''\n",
    "    # RND1\n",
    "    # probs:\n",
    "    dists = torch.distributions.categorical.Categorical(probs=probs)\n",
    "\n",
    "    if action is None:\n",
    "        action = dists.sample()#.unsqueeze(1)\n",
    "        # batch #x 1\n",
    "    log_prob = dists.log_prob(action)\n",
    "    # batch #x 1\n",
    "    entropy = dists.entropy().unsqueeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    \n",
    "    '''\n",
    "    # NORMAL:\n",
    "    #log_probs = F.log_softmax(logits, dim=-1)\n",
    "    log_probs = torch.log(probs+EPS)\n",
    "    entropy = -torch.sum(probs*log_probs, dim=-1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        #action = (probs+EPS).multinomial(num_samples=1).squeeze(1)\n",
    "        action = torch.multinomial( probs, num_samples=1).squeeze(1)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    \n",
    "    '''\n",
    "    '''\n",
    "    #RND2:\n",
    "    # probs:\n",
    "    log_probs = F.log_softmax(logits, dim=-1)\n",
    "    #entropy = dists.entropy().unsqueeze(1)\n",
    "    entropy = -(log_probs * probs).sum(1)#, keepdim=True)\n",
    "    # batch #x 1\n",
    "\n",
    "    if action is None:\n",
    "        p = probs.detach().cpu().numpy()\n",
    "        axis = 1\n",
    "        r = np.expand_dims(np.random.rand(p.shape[1 - axis]), axis=axis)\n",
    "        action = (p.cumsum(axis=axis) > r).argmax(axis=axis)\n",
    "        action = torch.from_numpy(action).to(probs.device)\n",
    "        # batch #x 1\n",
    "    log_probs = log_probs.gather(1, action.unsqueeze(1)).squeeze(1)\n",
    "    # batch #x 1\n",
    "    '''\n",
    "    '''\n",
    "\n",
    "    prediction = {'a': action,\n",
    "                'log_pi_a': log_probs,\n",
    "                'action_logits': logits,\n",
    "                'ent': entropy,\n",
    "                'v': v}\n",
    "\n",
    "    if self.use_intrinsic_critic:\n",
    "        prediction['int_v'] = int_v\n",
    "\n",
    "    if rnn_states is not None:\n",
    "        prediction.update({'rnn_states': rnn_states,\n",
    "                           'next_rnn_states': next_rnn_states})\n",
    "\n",
    "    return prediction\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "agents.append(agent.clone())\n",
    "agents.append(agent.clone())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "agents[1].algorithm.model.forward = forward1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "agents[2].algorithm.model.forward = forward2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Issue with nn.Module's __call__ function:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "hfn() missing 1 required positional argument: 'obs'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-28-c150166465e4>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     20\u001b[0m \u001b[0minstA\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhfn\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 22\u001b[0;31m \u001b[0;32massert\u001b[0m\u001b[0;34m(\u001b[0m \u001b[0minstA\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m<ipython-input-28-c150166465e4>\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m         \u001b[0;31m#return self.forward(*[self,*input],**kwargs)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 7\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      8\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m \u001b[0;32mclass\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mA0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mTypeError\u001b[0m: hfn() missing 1 required positional argument: 'obs'"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> \u001b[0;32m<ipython-input-28-c150166465e4>\u001b[0m(7)\u001b[0;36m__call__\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m      5 \u001b[0;31m    \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m      6 \u001b[0;31m        \u001b[0;31m#return self.forward(*[self,*input],**kwargs)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m----> 7 \u001b[0;31m        \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m      8 \u001b[0;31m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m      9 \u001b[0;31m\u001b[0;32mclass\u001b[0m \u001b[0mA\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mA0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\n",
      "ipdb> pp input\n",
      "(1,)\n",
      "ipdb> pp *input\n",
      "*** SyntaxError: invalid syntax\n",
      "ipdb> print( *input)\n",
      "1\n",
      "ipdb> exit\n"
     ]
    }
   ],
   "source": [
    "class A0(object):\n",
    "    def forward(self, *input, **kwargs):\n",
    "        raise NotImplemented\n",
    "        \n",
    "    def __call__(self, *input, **kwargs):\n",
    "        #return self.forward(*[self,*input],**kwargs)\n",
    "        return self.forward(*input,**kwargs)\n",
    "    \n",
    "class A(A0):\n",
    "    def forward(self, obs, action=None):\n",
    "        print(self, obs, action)\n",
    "        return 1\n",
    "\n",
    "instA = A()\n",
    "\n",
    "def hfn(self, obs, action=None):\n",
    "    print(self,obs, action)\n",
    "    return 0\n",
    "\n",
    "instA.forward = hfn\n",
    "\n",
    "assert( instA(1) == 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "\n",
    "def original_fn(self, *input, **kwargs):\n",
    "     for hook in self._forward_pre_hooks.values():\n",
    "         result = hook(self, input)\n",
    "         if result is not None:\n",
    "             if not isinstance(result, tuple):\n",
    "                 result = (result,)\n",
    "             input = result\n",
    "     if torch._C._get_tracing_state():\n",
    "         result = self._slow_forward(*input, **kwargs)\n",
    "     else:\n",
    "         result = self.forward(*input, **kwargs)\n",
    "     for hook in self._forward_hooks.values():\n",
    "         hook_result = hook(self, input, result)\n",
    "         if hook_result is not None:\n",
    "             result = hook_result\n",
    "     if len(self._backward_hooks) > 0:\n",
    "         var = result\n",
    "         while not isinstance(var, torch.Tensor):\n",
    "             if isinstance(var, dict):\n",
    "                 var = next((v for v in var.values() if isinstance(v, torch.Tensor)))\n",
    "             else:\n",
    "                 var = var[0]\n",
    "         grad_fn = var.grad_fn\n",
    "         if grad_fn is not None:\n",
    "             for hook in self._backward_hooks.values():\n",
    "                 wrapper = functools.partial(hook, self)\n",
    "                 functools.update_wrapper(wrapper, hook)\n",
    "                 grad_fn.register_hook(wrapper)\n",
    "     return result\n",
    "\n",
    "def hook_fn(self, *input, **kwargs):\n",
    "     for hook in self._forward_pre_hooks.values():\n",
    "         result = hook(self, input)\n",
    "         if result is not None:\n",
    "             if not isinstance(result, tuple):\n",
    "                 result = (result,)\n",
    "             input = result\n",
    "     if torch._C._get_tracing_state():\n",
    "         result = self._slow_forward(*input, **kwargs)\n",
    "     else:\n",
    "         result = self.forward(*[self,*input], **kwargs)\n",
    "     for hook in self._forward_hooks.values():\n",
    "         hook_result = hook(self, input, result)\n",
    "         if hook_result is not None:\n",
    "             result = hook_result\n",
    "     if len(self._backward_hooks) > 0:\n",
    "         var = result\n",
    "         while not isinstance(var, torch.Tensor):\n",
    "             if isinstance(var, dict):\n",
    "                 var = next((v for v in var.values() if isinstance(v, torch.Tensor)))\n",
    "             else:\n",
    "                 var = var[0]\n",
    "         grad_fn = var.grad_fn\n",
    "         if grad_fn is not None:\n",
    "             for hook in self._backward_hooks.values():\n",
    "                 wrapper = functools.partial(hook, self)\n",
    "                 functools.update_wrapper(wrapper, hook)\n",
    "                 grad_fn.register_hook(wrapper)\n",
    "     return result\n",
    "\n",
    "#nn.Module.__call__ = hook_fn\n",
    "nn.Module.__call__ = original_fn"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Testing the sampling functions:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2020-01-18 12:50:07 kevin-PRIME-Z270-P minerl.env.malmo.instance.2319da[11883] INFO Starting Minecraft process: ['/tmp/tmpsqdinwrn/Minecraft/launchClient.sh', '-port', '9002', '-env', '-runDir', '/tmp/tmpsqdinwrn/Minecraft/run']\n",
      "2020-01-18 12:50:08 kevin-PRIME-Z270-P minerl.env.malmo.instance.2319da[11883] INFO Starting process watcher for process 12898 @ localhost:9002\n",
      "2020-01-18 12:50:44 kevin-PRIME-Z270-P minerl.env.malmo.instance.2319da[11883] INFO Minecraft process ready\n",
      "2020-01-18 12:50:44 kevin-PRIME-Z270-P minerl.env.malmo[11883] INFO Logging output of Minecraft to ./logs/mc_2.log\n"
     ]
    }
   ],
   "source": [
    "observation = task.env.observation_space.sample() #task.env.reset()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(84, 84, 12) 0.0032628728 254.99591\n"
     ]
    }
   ],
   "source": [
    "print(observation.shape, observation.min(), observation.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline  \n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(84, 84, 3)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f7cc8b6dcf8>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_obs = observation[...,:3]/255.0\n",
    "print(test_obs.shape)\n",
    "plt.imshow(test_obs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "robs = task.env.reset()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "a = task.env.action_space.sample()\n",
    "obs, r, done, info = task.env.step(np.array([a]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 84, 84, 12) 8.0 207.0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f7cc8a4d358>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(robs.shape, robs.min(), robs.max())\n",
    "plt.imshow(robs[0,...,:3]/255.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f7cc8a26f60>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def lineup(obs):\n",
    "    lineupobs = np.concatenate([obs[0,...,i:i+3] for i in range(0,12,3)], axis=1)\n",
    "    return lineupobs\n",
    "plt.imshow(lineup(obs)/255.0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sampling from each agents:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Automatic pdb calling has been turned ON\n"
     ]
    }
   ],
   "source": [
    "%pdb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling actions with function 1.\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'tensor' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-26-39f958793d73>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mid\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0magent\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0magents\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m     \u001b[0;31m#try:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m     \u001b[0ma\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0magent\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtake_action\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      5\u001b[0m     \u001b[0mactions\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m     \u001b[0;31m#except Exception as e:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/media/kevin/TOSHIBA_EXT1/DATA/UNI/MineRL/minerl/train/Regym/regym/rl_algorithms/agents/ppo_agent.py\u001b[0m in \u001b[0;36mtake_action\u001b[0;34m(self, state)\u001b[0m\n\u001b[1;32m    245\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcurrent_prediction\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0malgorithm\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstate\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrnn_states\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrnn_states\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    246\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 247\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcurrent_prediction\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0malgorithm\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstate\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    248\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcurrent_prediction\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_post_process\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcurrent_prediction\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    249\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-25-93352f6bb66c>\u001b[0m in \u001b[0;36moriginal_fn\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m     12\u001b[0m          \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     13\u001b[0m      \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 14\u001b[0;31m          \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     15\u001b[0m      \u001b[0;32mfor\u001b[0m \u001b[0mhook\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     16\u001b[0m          \u001b[0mhook_result\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhook\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-7-b255727724d3>\u001b[0m in \u001b[0;36mforward1\u001b[0;34m(self, obs, action, rnn_states)\u001b[0m\n\u001b[1;32m    111\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mVERBOSE\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    112\u001b[0m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Sampling actions with function 1.\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 113\u001b[0;31m     \u001b[0mobs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    114\u001b[0m     \u001b[0mnext_rnn_states\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    115\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mrnn_states\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'tensor' is not defined"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> \u001b[0;32m<ipython-input-7-b255727724d3>\u001b[0m(113)\u001b[0;36mforward1\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m    111 \u001b[0;31m    \u001b[0;32mif\u001b[0m \u001b[0mVERBOSE\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m    112 \u001b[0;31m        \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Sampling actions with function 1.\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m--> 113 \u001b[0;31m    \u001b[0mobs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m    114 \u001b[0;31m    \u001b[0mnext_rnn_states\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m    115 \u001b[0;31m    \u001b[0;32mif\u001b[0m \u001b[0mrnn_states\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\n",
      "ipdb> pp self\n",
      "tensor([[[[0.4157, 0.3779, 0.4077,  ..., 0.4039, 0.4039, 0.4039],\n",
      "          [0.3880, 0.3501, 0.3779,  ..., 0.4039, 0.4039, 0.4039],\n",
      "          [0.2868, 0.3062, 0.3465,  ..., 0.4039, 0.4034, 0.4023],\n",
      "          ...,\n",
      "          [0.2392, 0.2797, 0.3205,  ..., 0.2372, 0.2474, 0.2601],\n",
      "          [0.2770, 0.3217, 0.3475,  ..., 0.2755, 0.2803, 0.2964],\n",
      "          [0.3451, 0.3476, 0.3490,  ..., 0.2874, 0.2812, 0.3216]],\n",
      "\n",
      "         [[0.2980, 0.2703, 0.2914,  ..., 0.5153, 0.5137, 0.5137],\n",
      "          [0.2779, 0.2501, 0.2702,  ..., 0.5143, 0.5137, 0.5137],\n",
      "          [0.2556, 0.2360, 0.2465,  ..., 0.5128, 0.5121, 0.5121],\n",
      "          ...,\n",
      "          [0.3121, 0.3657, 0.4189,  ..., 0.2512, 0.2230, 0.2358],\n",
      "          [0.3627, 0.4204, 0.4540,  ..., 0.2982, 0.2355, 0.2087],\n",
      "          [0.4510, 0.4535, 0.4565,  ..., 0.3777, 0.3020, 0.2314]],\n",
      "\n",
      "         [[0.2039, 0.1838, 0.1995,  ..., 0.7388, 0.7373, 0.7373],\n",
      "          [0.1913, 0.1711, 0.1849,  ..., 0.7363, 0.7347, 0.7347],\n",
      "          [0.1589, 0.1561, 0.1687,  ..., 0.7333, 0.7317, 0.7317],\n",
      "          ...,\n",
      "          [0.1906, 0.2231, 0.2556,  ..., 0.1584, 0.1447, 0.1524],\n",
      "          [0.2216, 0.2565, 0.2769,  ..., 0.1877, 0.1556, 0.1431],\n",
      "          [0.2745, 0.2770, 0.2784,  ..., 0.2301, 0.1910, 0.1608]],\n",
      "\n",
      "         ...,\n",
      "\n",
      "         [[0.2941, 0.3168, 0.3453,  ..., 0.4588, 0.4588, 0.4588],\n",
      "          [0.2992, 0.3008, 0.3278,  ..., 0.4588, 0.4588, 0.4588],\n",
      "          [0.3194, 0.3002, 0.3064,  ..., 0.4588, 0.4588, 0.4588],\n",
      "          ...,\n",
      "          [0.2337, 0.2497, 0.2651,  ..., 0.1722, 0.1597, 0.1502],\n",
      "          [0.2493, 0.2655, 0.2751,  ..., 0.2120, 0.1988, 0.1725],\n",
      "          [0.2745, 0.2745, 0.2761,  ..., 0.3167, 0.3112, 0.2784]],\n",
      "\n",
      "         [[0.2078, 0.2255, 0.2464,  ..., 0.5725, 0.5725, 0.5725],\n",
      "          [0.2104, 0.2134, 0.2344,  ..., 0.5725, 0.5725, 0.5725],\n",
      "          [0.2261, 0.2128, 0.2235,  ..., 0.5725, 0.5720, 0.5710],\n",
      "          ...,\n",
      "          [0.3043, 0.3248, 0.3455,  ..., 0.2239, 0.2070, 0.1966],\n",
      "          [0.3241, 0.3461, 0.3599,  ..., 0.2348, 0.1927, 0.1658],\n",
      "          [0.3569, 0.3594, 0.3624,  ..., 0.2972, 0.2213, 0.1961]],\n",
      "\n",
      "         [[0.1412, 0.1563, 0.1711,  ..., 0.8157, 0.8143, 0.8118],\n",
      "          [0.1437, 0.1459, 0.1606,  ..., 0.8132, 0.8118, 0.8092],\n",
      "          [0.1546, 0.1445, 0.1589,  ..., 0.8108, 0.8093, 0.8078],\n",
      "          ...,\n",
      "          [0.1866, 0.1982, 0.2100,  ..., 0.1370, 0.1268, 0.1204],\n",
      "          [0.1994, 0.2108, 0.2187,  ..., 0.1475, 0.1232, 0.1056],\n",
      "          [0.2196, 0.2196, 0.2212,  ..., 0.1925, 0.1510, 0.1333]]]],\n",
      "       device='cuda:0')\n",
      "ipdb> exit\n"
     ]
    }
   ],
   "source": [
    "actions = []\n",
    "for id, agent in enumerate(agents): \n",
    "    #try:\n",
    "    a = agent.take_action(obs)\n",
    "    actions.append(a)\n",
    "    #except Exception as e:\n",
    "    #    print(f'Agent {id} : {e}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[array([3]), array([0])]\n"
     ]
    }
   ],
   "source": [
    "print(actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n"
     ]
    }
   ],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
