{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pickle  \n",
    "import matplotlib.pyplot as plt\n",
    "from src.envs import gridworld\n",
    "from src.value_iteration import *\n",
    "from plot_utils.plot_simulated_data_gridworld import *\n",
    "from simulate_data_gridworld import generate_expert_trajectories\n",
    "from src.helpers import *\n",
    "import torch\n",
    "from scipy.special import logsumexp, softmax\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test: simulation env for two-agent collaborative foraging"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "grid_H, grid_W = 5, 5\n",
    "# grid_H, grid_W = 9, 9\n",
    "reward_strength = 2\n",
    "time_invariant_rewards = np.zeros((grid_H*grid_W,1))\n",
    "LOCATION_WATER = grid_H * int(grid_W/2)\n",
    "LOCATION_HOME = (grid_W-1) * grid_H + int(grid_H/2)\n",
    "time_invariant_rewards[LOCATION_WATER] = reward_strength\n",
    "time_invariant_rewards[LOCATION_HOME] = reward_strength\n",
    "r_map = np.reshape(np.array(time_invariant_rewards[:,0]), (grid_H,grid_W), order='F')\n",
    "\n",
    "gw = gridworld.GridWorld(r_map, {},)\n",
    "# gw = gridworld.GridWorld_wrapped(r_map, {},)\n",
    "action_list = [(i,j) for i in range(5) for j in range(5)]\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "reward_joint = np.zeros(((grid_H*grid_W)**2,1))\n",
    "for i in range(reward_joint.shape[0]):\n",
    "    cur = gw.idx12pos(i)\n",
    "    if cur[0] == cur[2] and cur[1] == cur[3]:\n",
    "        reward_joint[i] = r_map[cur[0], cur[1]] \n",
    "\n",
    "gamma = 0.9\n",
    "values, policy = two_agent_value_iteration(P_a.astype(int), reward_joint, gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "values_mat = np.zeros((grid_H*grid_W,grid_W*grid_H))\n",
    "for i in range(values.shape[0]):\n",
    "    idx1, idx2 = i % (grid_H*grid_W), i // (grid_H*grid_W)\n",
    "    values_mat[idx1,idx2] = values[i,0]\n",
    "\n",
    "plt.figure()\n",
    "plt.imshow(values_mat); plt.colorbar()\n",
    "plt.ylabel('Agent 1 idx'); plt.xlabel('Agent 2 idx')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 500\n",
    "rep = 200\n",
    "success = 0\n",
    "for r in range(rep):\n",
    "    # start_pos = (2, 2, np.random.randint(0,gw.height), np.random.randint(0,gw.width))\n",
    "    start_pos = (np.random.randint(0,gw.height), np.random.randint(0,gw.width), np.random.randint(0,gw.height), np.random.randint(0,gw.width))\n",
    "    gw.reset(start_pos)\n",
    "    traj = generate_expert_trajectories(gw, policy, action_list, T)\n",
    "    if np.sum(traj['rewards'])>0:\n",
    "        success += 1\n",
    "\n",
    "print(success/rep)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "traj1 = np.array([(a,b) for (a,b,c,d) in traj['states4d']])\n",
    "traj2 = np.array([(c,d) for (a,b,c,d) in traj['states4d']])\n",
    "print(traj1.shape[0])\n",
    "# plot the trajectories\n",
    "fig, ax = plt.subplots(1,2, figsize=(10,4))\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj1}, fig, ax[0])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj2}, fig, ax[1])\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test: generate policies (joint/independent/prediction)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Independent policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate independent policy\n",
    "_,policy_independent = two_agent_value_iteration_independent_control(P_a.astype(int), reward_joint, gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate trajectories for independent policy\n",
    "T = 500\n",
    "rep = 200\n",
    "success = 0\n",
    "for r in range(rep):\n",
    "    start_pos = (np.random.randint(0,gw.height), np.random.randint(0,gw.width), np.random.randint(0,gw.height), np.random.randint(0,gw.width))\n",
    "    gw.reset(start_pos)\n",
    "    traj = generate_expert_trajectories(gw, policy_independent, action_list, T)\n",
    "    if np.sum(traj['rewards'])>0:\n",
    "        success += 1\n",
    "print('Success rate: {}'.format(success / rep))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "s_plot = 30\n",
    "ax_min = np.min([policy_independent[:s_plot,:], policy[:s_plot,:]])\n",
    "ax_max = np.max([policy_independent[:s_plot,:], policy[:s_plot,:]])\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.subplot(1,2,1)\n",
    "plt.imshow(policy_independent[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Independent policy')\n",
    "plt.colorbar()\n",
    "plt.subplot(1,2,2)\n",
    "plt.imshow(policy[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Joint policy')\n",
    "plt.colorbar()\n",
    "plt.tight_layout()\n",
    "\n",
    "print(\"Percentage: {}\".format(np.sqrt(np.mean((policy-policy_independent)**2))*100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "s_idx = 5\n",
    "ax_min = np.min([np.min(policy[s_idx,:]), np.min(policy_independent[s_idx,:])])\n",
    "ax_max = np.max([np.max(policy[s_idx,:]), np.max(policy_independent[s_idx,:])])\n",
    "pos = gw.idx12pos(s_idx)\n",
    "plt.subplots(1,2, figsize=(10,4))\n",
    "plt.subplot(1,2,2)\n",
    "plt.plot(policy[s_idx,:])\n",
    "plt.ylim([ax_min,ax_max])\n",
    "plt.xticks(range(25), action_list, rotation=80)\n",
    "plt.ylabel('Probability')\n",
    "plt.title('Joint policy, s={}'.format(pos))\n",
    "plt.subplot(1,2,1)\n",
    "plt.plot(policy_independent[s_idx,:])\n",
    "plt.ylim([ax_min,ax_max])\n",
    "plt.xticks(range(25), action_list, rotation=80)\n",
    "plt.ylabel('Probability')\n",
    "plt.title('Independent policy, s={}'.format(pos))\n",
    "plt.tight_layout()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "start_pos = (np.random.randint(0,gw.height), np.random.randint(0,gw.width), np.random.randint(0,gw.height), np.random.randint(0,gw.width))\n",
    "start_pos = (0,0,0,1)\n",
    "terminal_state = [(0,2,0,2),(2,4,2,4)]\n",
    "gw = gridworld.GridWorld(r_map, terminal_state,)\n",
    "gw.reset(start_pos)\n",
    "\n",
    "traj = generate_expert_trajectories(gw, policy, action_list, T)\n",
    "traj1 = np.array([(a,b) for (a,b,c,d) in traj['states4d']])\n",
    "traj2 = np.array([(c,d) for (a,b,c,d) in traj['states4d']])\n",
    "print(traj1.shape[0])\n",
    "# plot the trajectories\n",
    "fig, ax = plt.subplots(2,2, figsize=(6,6))\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj1[:2]}, fig, ax[0,0])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj2[:2]}, fig, ax[0,1])\n",
    "\n",
    "gw.reset(start_pos)\n",
    "traj = generate_expert_trajectories(gw, policy_independent, action_list, T)\n",
    "traj1 = np.array([(a,b) for (a,b,c,d) in traj['states4d']])\n",
    "traj2 = np.array([(c,d) for (a,b,c,d) in traj['states4d']])\n",
    "print(traj1.shape[0])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj1[:2]}, fig, ax[1,0])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj2[:2]}, fig, ax[1,1])\n",
    "ax[0,0].set_title('Joint, agent 1')\n",
    "ax[0,1].set_title('Joint, agent 2')\n",
    "ax[1,0].set_title('Independent, agent 1')\n",
    "ax[1,1].set_title('Independent, agent 2')\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# calculate the mutual information between a1|s and a2|s\n",
    "MI = []\n",
    "for s_idx in range(policy.shape[0]):\n",
    "    m1 = np.repeat(p1[s_idx,:],5)\n",
    "    m2 = np.tile(p2[s_idx,:],5)\n",
    "    joint = policy[s_idx,:]\n",
    "    MI.append(np.sum(joint*np.log2(joint / (m1 * m2))))\n",
    "\n",
    "plt.imshow(np.array(MI).reshape((grid_H*grid_W,grid_H*grid_W), order='F'))\n",
    "plt.colorbar()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "indices = np.argsort(MI)\n",
    "top_MI_states = [gw.idx12pos(indices[-i]) for i in range(1,5)]\n",
    "MI_mat1 = np.zeros((grid_H,grid_W))\n",
    "MI_mat2 = np.zeros((grid_H,grid_W))\n",
    "for s in top_MI_states:\n",
    "    MI_mat1[s[0],s[1]] = 1\n",
    "    MI_mat2[s[2],s[3]] = 1\n",
    "\n",
    "print(top_MI_states)\n",
    "\n",
    "fig, ax = plt.subplots(1,2, figsize=(8,4))\n",
    "traj1 = np.array([(a,b) for (a,b,c,d) in top_MI_states])\n",
    "traj2 = np.array([(c,d) for (a,b,c,d) in top_MI_states])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj1}, fig, ax[0])\n",
    "plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj2}, fig, ax[1])\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Independent policy with uniform prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "grid_H, grid_W = 5, 5\n",
    "reward_strength = 2\n",
    "time_invariant_rewards = np.zeros((grid_H*grid_W,1))\n",
    "LOCATION_WATER = grid_H * int(grid_W/2)\n",
    "LOCATION_HOME = (grid_W-1) * grid_H + int(grid_H/2)\n",
    "time_invariant_rewards[LOCATION_WATER] = reward_strength\n",
    "time_invariant_rewards[LOCATION_HOME] = reward_strength\n",
    "r_map = np.reshape(np.array(time_invariant_rewards[:,0]), (grid_H,grid_W), order='F')\n",
    "gw = gridworld.GridWorld(r_map, {},)\n",
    "# gw_single = gridworld.GridWorld_SingleAgent(r_map,{},)\n",
    "action_list = [(i,j) for i in range(5) for j in range(5)]\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "# P_a_single = gw_single.get_permutation_mat()\n",
    "\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "reward_joint = np.zeros(((grid_H*grid_W)**2,1))\n",
    "for i in range(reward_joint.shape[0]):\n",
    "    cur = gw.idx12pos(i)\n",
    "    if cur[0] == cur[2] and cur[1] == cur[3]:\n",
    "        reward_joint[i] = r_map[cur[0], cur[1]] \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# value_single, policy_single = one_agent_value_iteration(P_a_single.astype(int), time_invariant_rewards, gamma)\n",
    "_,policy_joint = two_agent_value_iteration(P_a.astype(int), reward_joint, gamma)\n",
    "\n",
    "n1,n2 = P_a.shape\n",
    "N_STATES, N_ACTIONS = int(np.sqrt(n1)), int(np.sqrt(n2))\n",
    "if action_list is None:\n",
    "    action_list = [[a1, a2] for a1 in range(N_ACTIONS) for a2 in range(N_ACTIONS)]\n",
    "idx1 = []\n",
    "for a1 in range(5):\n",
    "    idx1.append([i for i,ele in enumerate(action_list) if ele[0] == a1])\n",
    "idx2 = []\n",
    "for a2 in range(5):\n",
    "    idx2.append([i for i,ele in enumerate(action_list) if ele[1] == a2])\n",
    "\n",
    "p1 = np.hstack([np.sum(policy_joint[:,idx1[i]],axis=1)[:,None] for i in range(N_ACTIONS)])\n",
    "p2 = np.hstack([np.sum(policy_joint[:,idx2[i]],axis=1)[:,None] for i in range(N_ACTIONS)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# two agent uniform prediction\n",
    "_, policy_uniform = two_agent_value_iteration_independent_control_uniform_prediction(P_a.astype(int), reward_joint, gamma)\n",
    "_, policy_marginal = two_agent_value_iteration_independent_control(P_a.astype(int), reward_joint, gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(np.mean((policy_uniform - policy_joint)**2))\n",
    "print(np.mean((policy_uniform - policy_marginal)**2))\n",
    "print(np.mean((policy_joint - policy_marginal)**2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "s_plot = 30\n",
    "ax_min = np.min([policy_uniform[:s_plot,:],policy_marginal[:s_plot,:], policy[:s_plot,:]])\n",
    "ax_max = np.max([policy_uniform[:s_plot,:],policy_marginal[:s_plot,:], policy[:s_plot,:]])\n",
    "plt.figure(figsize=(12,4))\n",
    "plt.subplot(1,3,1)\n",
    "plt.imshow(policy_uniform[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Uniform prediction policy')\n",
    "plt.colorbar()\n",
    "plt.subplot(1,3,2)\n",
    "plt.imshow(policy_marginal[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Independent policy')\n",
    "plt.colorbar()\n",
    "plt.subplot(1,3,3)\n",
    "plt.imshow(policy_joint[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Joint policy')\n",
    "plt.colorbar()\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Independent policy with single agent prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "grid_H, grid_W = 5, 5\n",
    "reward_strength = 2\n",
    "time_invariant_rewards = np.zeros((grid_H*grid_W,1))\n",
    "LOCATION_WATER = grid_H * int(grid_W/2)\n",
    "LOCATION_HOME = (grid_W-1) * grid_H + int(grid_H/2)\n",
    "time_invariant_rewards[LOCATION_WATER] = reward_strength\n",
    "time_invariant_rewards[LOCATION_HOME] = reward_strength\n",
    "r_map = np.reshape(np.array(time_invariant_rewards[:,0]), (grid_H,grid_W), order='F')\n",
    "gw = gridworld.GridWorld(r_map, {},)\n",
    "gw_single = gridworld.GridWorld_SingleAgent(r_map,{},)\n",
    "action_list = [(i,j) for i in range(5) for j in range(5)]\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "P_a_single = gw_single.get_permutation_mat()\n",
    "\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "reward_joint = np.zeros(((grid_H*grid_W)**2,1))\n",
    "for i in range(reward_joint.shape[0]):\n",
    "    cur = gw.idx12pos(i)\n",
    "    if cur[0] == cur[2] and cur[1] == cur[3]:\n",
    "        reward_joint[i] = r_map[cur[0], cur[1]] \n",
    "\n",
    "value_single, policy_single = one_agent_value_iteration(P_a_single.astype(int), time_invariant_rewards, gamma)\n",
    "_,policy_marginal = two_agent_value_iteration_independent_control(P_a.astype(int), reward_joint, gamma)\n",
    "_,policy_joint = two_agent_value_iteration(P_a.astype(int), reward_joint, gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from P_a to P_a_single\n",
    "P_a_single = collapse_permutation_matrix(P_a,2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, policy_with_prediction = two_agent_value_iteration_independent_control_policy_prediction(P_a,P_a_single,reward_joint, time_invariant_rewards, gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def two_agent_value_iteration_independent_control_policy_prediction(P_a, reward_joint, rewards, gamma, i, action_list=None):\n",
    "    '''\n",
    "    Calculate the oint policy for two agents using value iteration\n",
    "    Independent control\n",
    "    agent i predict the other agent's policy\n",
    "    INPUT:\n",
    "        P_a: permutation matrix (N_STATES^2, N_ACTIONS^2)\n",
    "        reward_joint: joint reward matrix (N_STATES^2, 1)\n",
    "        rewards perceived by agent i: reward matrix (N_STATES, 1)\n",
    "        i: agent index\n",
    "    OUTPUT:\n",
    "        p1: (N_STATES**2, N_ACTIONS) agent1's policy\n",
    "    '''\n",
    "    n1,n2 = P_a.shape\n",
    "    N_STATES, N_ACTIONS = int(np.sqrt(n1)), int(np.sqrt(n2))\n",
    "    assert i in [1,2], 'agent index error'\n",
    "\n",
    "    if action_list is None:\n",
    "        action_list = [[a1, a2] for a1 in range(N_ACTIONS) for a2 in range(N_ACTIONS)]\n",
    "\n",
    "    P_a_single = collapse_permutation_matrix(P_a,2-i,action_list)\n",
    "    \n",
    "    assert P_a_single.shape[0] == N_STATES and P_a_single.shape[1] == N_ACTIONS, 'P_a dimension match error'\n",
    "    assert rewards.shape[0] == N_STATES and rewards.shape[1] == 1, 'single agent reward dimension match error'\n",
    "\n",
    "    _,policy_joint = two_agent_value_iteration(P_a.astype(int), reward_joint, gamma)\n",
    "    _,policy_single = one_agent_value_iteration(P_a_single.astype(int), rewards, gamma)\n",
    "\n",
    "    idx1 = []\n",
    "    for a1 in range(5):\n",
    "        idx1.append([i for i,ele in enumerate(action_list) if ele[0] == a1])\n",
    "    idx2 = []\n",
    "    for a2 in range(5):\n",
    "        idx2.append([i for i,ele in enumerate(action_list) if ele[1] == a2])\n",
    "    p1 = np.hstack([np.sum(policy_joint[:,idx1[i]],axis=1)[:,None] for i in range(N_ACTIONS)]) # marginal\n",
    "    p2 = np.hstack([np.sum(policy_joint[:,idx2[i]],axis=1)[:,None] for i in range(N_ACTIONS)]) # marginal\n",
    "    \n",
    "    if agent == 1:\n",
    "        c1 = np.zeros((N_STATES**2, N_ACTIONS, N_ACTIONS)) # c1(s,a1,a2) = P(a1|a2,s)\n",
    "        for a_idx in range(N_ACTIONS):\n",
    "            c1[:, :, a_idx] = policy_joint[:,idx2[a_idx]] / np.hstack([p2[:,a_idx][:,None] for _ in range(N_ACTIONS)])\n",
    "        policy_single_expand2 = np.tile(policy_single,(N_STATES,1))      # P(a2|s), i.e. added s1 states, agent1's prediction of agent2 policy\n",
    "        policy1 = np.sum(c1 * policy_single_expand2[:,None,:], axis=2)\n",
    "        policy_prediction = policy1\n",
    "    elif agent == 2:\n",
    "        c2 = np.zeros((N_STATES**2, N_ACTIONS, N_ACTIONS)) # c2(s,a2,a1) = P(a2|a1,s)\n",
    "        for a_idx in range(N_ACTIONS):\n",
    "            c2[:, :, a_idx] = policy_joint[:,idx1[a_idx]] / np.hstack([p1[:,a_idx][:,None] for _ in range(N_ACTIONS)])\n",
    "        policy_single_expand1 = np.repeat(policy_single,N_STATES,axis=0) # P(a1|s), i.e. added s2 states, agent2's prediction of agent1 policy\n",
    "        policy2 = np.sum(c2 * policy_single_expand1[:,None,:], axis=2)\n",
    "        policy_prediction = policy2\n",
    "    \n",
    "    return policy_prediction\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(np.sum((policy_with_prediction - policy_joint)**2))\n",
    "print(np.sum((policy_marginal - policy_joint)**2))\n",
    "print(np.sum((policy_with_prediction - policy_marginal)**2))\n",
    "s_plot = 30\n",
    "ax_min = np.min([policy_with_prediction[:s_plot,:],policy_marginal[:s_plot,:], policy[:s_plot,:]])\n",
    "ax_max = np.max([policy_with_prediction[:s_plot,:],policy_marginal[:s_plot,:], policy[:s_plot,:]])\n",
    "plt.figure(figsize=(12,4))\n",
    "plt.subplot(1,3,1)\n",
    "plt.imshow(policy_with_prediction[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('policy prediction policy')\n",
    "plt.colorbar()\n",
    "plt.subplot(1,3,2)\n",
    "plt.imshow(policy_marginal[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Independent policy')\n",
    "plt.colorbar()\n",
    "plt.subplot(1,3,3)\n",
    "plt.imshow(policy_joint[:s_plot,:], vmin=ax_min, vmax=ax_max)\n",
    "plt.title('Joint policy')\n",
    "plt.colorbar()\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test: representation of a joint map using an interaction map"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "individual_map1 = np.ones((2,25))\n",
    "individual_map2 = np.zeros((2,25))\n",
    "diff_square = np.unique([i**2+j**2 for i in range(5) for j in range(5)])\n",
    "diff_maps = diff_square.reshape((1,diff_square.shape[0]))\n",
    "joint_maps = create_joint_maps(individual_map1, individual_map2, diff_maps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(625, 1)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid_H, grid_W = 5, 5\n",
    "N = grid_W * grid_H\n",
    "reward_strength = 2. \n",
    "rewards = np.zeros((grid_H*grid_W,1))\n",
    "rewards[22] = 1.\n",
    "rewards[10] = 1.\n",
    "r_map = np.reshape(np.array(rewards[:,0]), (grid_H,grid_W), order='F')\n",
    "gw = gridworld.GridWorld(r_map, {},)\n",
    "action_list = [(i,j) for i in range(grid_H) for j in range(grid_W)]\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "reward_joint = np.zeros((N**2,1))\n",
    "for i in range(reward_joint.shape[0]):\n",
    "    cur = gw.idx12pos(i)\n",
    "    if cur[0] == cur[2] and cur[1] == cur[3]:\n",
    "        reward_joint[i] = r_map[cur[0], cur[1]] \n",
    "\n",
    "reward_joint.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ep: 0, Loss: 62.19\n",
      "Ep: 10, Loss: 14.96\n",
      "Ep: 20, Loss: 1.58\n",
      "Ep: 30, Loss: 0.59\n",
      "Ep: 40, Loss: 0.71\n",
      "Ep: 50, Loss: 0.16\n",
      "Ep: 60, Loss: 0.02\n",
      "Ep: 70, Loss: 0.04\n",
      "Ep: 80, Loss: 0.01\n",
      "Ep: 90, Loss: 0.00\n",
      "Ep: 100, Loss: 0.00\n",
      "Ep: 110, Loss: 0.00\n",
      "Ep: 120, Loss: 0.00\n",
      "Ep: 130, Loss: 0.00\n",
      "Ep: 140, Loss: 0.00\n",
      "Ep: 150, Loss: 0.00\n",
      "Ep: 160, Loss: 0.00\n",
      "Ep: 170, Loss: 0.00\n",
      "Ep: 180, Loss: 0.00\n",
      "Ep: 190, Loss: 0.00\n"
     ]
    }
   ],
   "source": [
    "lr = 0.05\n",
    "r0 = torch.tensor(5., requires_grad=True)\n",
    "alpha = torch.ones((3,1))\n",
    "alpha[-1,0] = r0\n",
    "criterion = torch.nn.MSELoss()\n",
    "\n",
    "individual_map1 = torch.ones((1,25), requires_grad=True)\n",
    "individual_map2 = torch.ones((1,25), requires_grad=True)\n",
    "diff_square = np.unique([i**2+j**2 for i in range(5) for j in range(5)])\n",
    "diff_maps = diff_square.reshape((1,diff_square.shape[0]))\n",
    "diff_maps = 1 / (torch.from_numpy(diff_maps.astype(float)).float()+1)\n",
    "diff_maps.requires_grad = True\n",
    "\n",
    "optimizer = torch.optim.Adam([r0, individual_map1, individual_map2, diff_maps], lr=lr)\n",
    "# optimizer = torch.optim.Adam([r0], lr=lr)\n",
    "\n",
    "lambda1 = 1\n",
    "lambda2 = 1\n",
    "losses = []\n",
    "for ep in range(200):\n",
    "    priors = lambda1*torch.sum(individual_map1**2) + lambda1*torch.sum(individual_map2**2) + lambda2*torch.sum(diff_maps**2)\n",
    "    joint_maps = create_joint_maps_pytorch(individual_map1, individual_map2, diff_maps)\n",
    "    loss = criterion((alpha.T @ joint_maps), torch.from_numpy(reward_joint.T).float()) + priors\n",
    "    losses.append(loss.item())\n",
    "    loss.backward(retain_graph=True)\n",
    "    optimizer.step()\n",
    "    optimizer.zero_grad()\n",
    "    if ep % 10 == 0:\n",
    "        print('Ep: %d, Loss: %.2f' % (ep, loss.item()))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot individual maps\n",
    "fig, axs = plt.subplots(2,2,figsize=(5,5))\n",
    "axs[0,0].plot(losses)\n",
    "axs[0,0].set_title('Loss')\n",
    "axs[0,1].plot(diff_square, diff_maps[0,:].detach().numpy()*r0.item())\n",
    "axs[0,1].set_title('Diff Map')\n",
    "axs[0,1].set_xlabel('Square grid difference')\n",
    "im = axs[1,0].imshow(individual_map1[0,:].detach().numpy().reshape((5,5), order='F'))\n",
    "axs[1,0].set_title('Rec: Agent 1')\n",
    "fig.colorbar(im,ax=axs[1,0])\n",
    "im = axs[1,1].imshow(individual_map2[0,:].detach().numpy().reshape((5,5), order='F'))\n",
    "axs[1,1].set_title('Rec: Agent 2')\n",
    "fig.colorbar(im,ax=axs[1,1])\n",
    "plt.tight_layout()\n",
    "fig.savefig('figures/value_decomposition.eps')\n",
    "fig.savefig('figures/value_decomposition.png')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot interaction maps\n",
    "plt.plot(diff_maps.detach().numpy().flatten())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Collect all validation set LL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'np' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m tags \u001b[38;5;241m=\u001b[39m [\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcentralized\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mindependent_control\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mindependent_control_w_uniform_prediction\u001b[39m\u001b[38;5;124m'\u001b[39m,\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mselfish\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m      2\u001b[0m agent \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[0;32m----> 3\u001b[0m version_list \u001b[38;5;241m=\u001b[39m \u001b[43mnp\u001b[49m\u001b[38;5;241m.\u001b[39marange(\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m3\u001b[39m)\n\u001b[1;32m      4\u001b[0m tag_list \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marange(\u001b[38;5;241m3\u001b[39m)\n\u001b[1;32m      5\u001b[0m num_trajs, seed, max_iters \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m200\u001b[39m, \u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m20\u001b[39m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'np' is not defined"
     ]
    }
   ],
   "source": [
    "tags = ['centralized', 'independent_control', 'independent_control_w_uniform_prediction','selfish']\n",
    "agent = 1\n",
    "version_list = np.arange(1,3)\n",
    "tag_list = np.arange(3)\n",
    "\n",
    "ll_collect = {}\n",
    "for version in version_list:\n",
    "    ll_mat = np.zeros((len(tag_list),len(tag_list)))\n",
    "    for tag_sim, tag_train in [(i,j) for i in range(len(tag_list)) for j in range(len(tag_list))]:\n",
    "        save_dir = 'recovered_parameters/gridworld_recovered_params/fit_{}/{}{}/maps_1_1_lr_0.01_0.005_lam_5.0_1.0/'.format(tags[tag_train], tags[tag_sim], version)\n",
    "        # save_dir = 'recovered_parameters/hallway/fit_{}/{}/maps_1_1_lr_0.01_0.005_lam_2.0_1.0/'.format(tags[tag_train], version)\n",
    "        file = save_dir + 'validation_lls_{}_seed_{}_iters_{}.npy'.format(num_trajs, seed, max_iters)\n",
    "        if not os.path.exists(file):\n",
    "            continue\n",
    "        test_ll = np.load(file)\n",
    "        ll_mat[tag_sim, tag_train] = test_ll[-1]\n",
    "    ll_collect[version] = ll_mat\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "version = 1\n",
    "agent = 2\n",
    "tag_sim = 'selfish_perfect_prediction'\n",
    "ll = []\n",
    "num_trajs, seed, max_iters = 500, 1, 20\n",
    "\n",
    "for tag_train in tags[1:]:\n",
    "    save_dir = 'recovered_parameters/gridworld_recovered_params/fit_{}/{}{}/maps_1_1_lr_0.01_0.005_lam_5.0_1.0/agent_{}/'.format(tag_train, tag_sim, version, agent)\n",
    "    file = save_dir + 'validation_lls_trajs_{}_seed_{}_iters_{}.npy'.format(num_trajs, seed, max_iters)\n",
    "    if not os.path.exists(file):\n",
    "        continue\n",
    "    test_ll = np.load(file)\n",
    "    ll.append(test_ll[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['independent_control', 'independent_control_w_uniform_prediction', 'selfish']\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[-1.5736415386199951, -1.5744266510009766, -1.5515397787094116]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(tags[1:])\n",
    "ll"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ll_collect_1 = ll_collect[1]\n",
    "\n",
    "# Extract the values and labels from ll_collect_1\n",
    "values = ll_collect_1.flatten()\n",
    "\n",
    "fig,axs = plt.subplots(1,2, figsize=(8,4))\n",
    "\n",
    "im = axs[0].imshow(ll_collect[1])\n",
    "plt.colorbar(im,ax=axs[0])\n",
    "axs[0].set_xticks(range(3))\n",
    "axs[0].set_xticklabels(tags, rotation=30)\n",
    "axs[0].set_yticks(range(3))\n",
    "axs[0].set_yticklabels(tags)\n",
    "axs[0].set_xlabel('Training')\n",
    "axs[0].set_ylabel('Simulation')\n",
    "axs[0].set_title('LL per decision')\n",
    "\n",
    "\n",
    "mat = ll_collect[1]\n",
    "norm = [(mat[i,:] - np.min(mat[i,:])) / (np.max(mat[i,:])-np.min(mat[i,:])) for i in range(3)]\n",
    "\n",
    "im = axs[1].imshow(norm)\n",
    "plt.colorbar(im,ax=axs[1])\n",
    "axs[1].set_xticks(range(3))\n",
    "axs[1].set_xticklabels(tags, rotation=30)\n",
    "axs[1].set_title('Row norm')\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Finding the optimal LL (given the ground truth policy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "# GEN_DIR_NAME = 'data/simulated_gridworld_data/centralized1'\n",
    "GEN_DIR_NAME = 'data/simulated_gridworld_data/independent_control1'\n",
    "file_trajs = open(GEN_DIR_NAME +'/expert_trajectories.pickle', 'rb')\n",
    "all_expert_trajectories = pickle.load(file_trajs)\n",
    "# val_indices = np.arange(0,len(all_expert_trajectories),5)\n",
    "val_indices = np.arange(len(all_expert_trajectories))\n",
    "val_expert_trajectories = [all_expert_trajectories[i] for i in val_indices]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "len(all_expert_trajectories)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "state_action_pairs = []\n",
    "for num, traj in enumerate(val_expert_trajectories):\n",
    "    states = np.array(traj['states'])[:,np.newaxis]\n",
    "    actions = np.array(traj['actions'])[:,np.newaxis]\n",
    "    if len(states) == len(actions)+1:\n",
    "        states = np.array(traj['states'][:-1])[:,np.newaxis]\n",
    "    state_action_pairs_this_traj = np.concatenate((states, actions), axis=1)\n",
    "    state_action_pairs.append(state_action_pairs_this_traj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate policies\n",
    "grid_H, grid_W = 5, 5\n",
    "reward_strength = 2\n",
    "time_invariant_rewards = np.zeros((grid_H*grid_W,1))\n",
    "LOCATION_WATER = grid_H * int(grid_W/2)\n",
    "LOCATION_HOME = (grid_W-1) * grid_H + int(grid_H/2)\n",
    "time_invariant_rewards[LOCATION_WATER] = reward_strength\n",
    "time_invariant_rewards[LOCATION_HOME] = reward_strength\n",
    "r_map = np.reshape(np.array(time_invariant_rewards[:,0]), (grid_H,grid_W), order='F')\n",
    "\n",
    "gw = gridworld.GridWorld(r_map, {},)\n",
    "action_list = [(i,j) for i in range(5) for j in range(5)]\n",
    "P_a = gw.get_permutation_mat(action_list)\n",
    "reward_joint = np.zeros(((grid_H*grid_W)**2,1))\n",
    "for i in range(reward_joint.shape[0]):\n",
    "    cur = gw.idx12pos(i)\n",
    "    if cur[0] == cur[2] and cur[1] == cur[3]:\n",
    "        reward_joint[i] = r_map[cur[0], cur[1]] \n",
    "\n",
    "gamma = 0.9\n",
    "values, policy = two_agent_value_iteration(P_a.astype(int), reward_joint, gamma)\n",
    "values, policy_independent = two_agent_value_iteration_independent_control(P_a.astype(int), reward_joint, gamma)\n",
    "log_policy = np.log(policy)\n",
    "log_policy_independent = np.log(policy_independent)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def getLL_pairwise(state_action_pairs, log_policy):\n",
    "    num_trajectories = len(state_action_pairs)\n",
    "    log_likelihood = 0\n",
    "    N_pairs = 0\n",
    "    for i in range(num_trajectories):\n",
    "        states, actions = state_action_pairs[i][:,0].astype(int), state_action_pairs[i][:,1].astype(int)\n",
    "        for t in range(states.shape[0]):\n",
    "            log_likelihood += log_policy[states[t], actions[t]]\n",
    "            N_pairs += 1\n",
    "    return log_likelihood / N_pairs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ll = getLL_pairwise(state_action_pairs, log_policy)\n",
    "ll_independent = getLL_pairwise(state_action_pairs, log_policy_independent)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('LL for joint policy: {}'.format(ll))\n",
    "print('LL for independent policy: {}'.format(ll_independent))\n",
    "print('Probability for joint policy: {}'.format(np.exp(ll)))\n",
    "print('Probability for independent policy: {}'.format(np.exp(ll_independent)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "grid_H, grid_W = 3, 5\n",
    "gw_pre = gridworld.GridWorld_v2(grid_H, grid_W,{},{})\n",
    "# create a joint reward map, agent1: yellow; agent2: blue, state = (y1,x1,y2,x2)\n",
    "target_location = (1,4,1,0)\n",
    "reward_map = np.zeros(((grid_H*grid_W)**2, 1))\n",
    "target_idx = gw_pre.pos2idx1(target_location)\n",
    "reward_map[target_idx] = 1\n",
    "states = [(1,4,c,d) for c in range(grid_H) for d in range(grid_W)] + [(a,b,1,0) for a in range(grid_H) for b in range(grid_W)]\n",
    "terminal_states1 = list(set(states)) # remove repetitive entries\n",
    "collide_states = [(a,b,a,b) for a in range(grid_H) for b in range(grid_W)]\n",
    "terminal_states = terminal_states1 + collide_states\n",
    "gw = gridworld.GridWorld_v2(grid_H, grid_W,reward_map,terminal_states)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test: analyze simulation trajectories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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NAidOnVC3rx5s+x9EBERZQepQ7BklIODAxwcHD5DibIHrYads2fPwtvbW3k+ePBgAECXLl2wbNkyAMBvv/0GEUH79u3T7G9sbIzffvsNgYGBiI+PR7FixTBo0CDldYiIiPTJggULPukGnHHjxiEwMDDzC5RNZJsOytr0sR2ciIiIsrP0WnbevHkDLy8vAMDRo0dhamqaZr+c2rKjUx2UiYiI6N+lF1piY2OVf1euXBlmZmZZXSytyxEdlImIiIg+FcMOERER6TSGHSIiItJpDDtERESk0xh2iIiISKcx7BAREZFOY9ghIiIincawQ0RERDqNYYeIiIh0GsMOERER6TSGHSIiItJpDDtERESk0xh2iIiISKcx7BAREZFOY9ghIiIincawQ0RERDqNYYeIiIh0GsMOERER6TSGHSIiItJpDDtERESk0xh2iIiISKcx7BAREZFOY9ghIiIincawQ0RERDqNYYeIiIh0GsMOERER6TSGHSIiItJpDDtERESk0xh2iIiISKcx7BAREZFOY9ghIiIincawQ0RERDqNYYeIiIh0GsMOERER6TSGHSIiItJpDDtERESk0xh2iIiISKcx7BAREZFOY9ghIiIinabVsHP48GE0bdoUjo6OUKlU2LJli8b6rl27QqVSaTwaN26ssU1ERAQ6duwIS0tLWFtbo3v37oiJicnCd0FERETZmVbDTmxsLFxcXDBv3rz3btO4cWM8ffpUeaxZs0ZjfceOHXH16lXs3bsXO3bswOHDh9GzZ8/PXXQiIiLKIYy0+cd9fX3h6+v7wW2MjY1hb2+f7rrr169j9+7dOHPmDNzd3QEAP//8M/z8/PDDDz/A0dEx08tMREREOUu277Nz8OBB2NnZoXTp0ujTpw/Cw8OVdSdOnIC1tbUSdACgQYMGMDAwwKlTp977mvHx8YiKitJ4EBERkW7K1mGncePG+PXXX7F//35MmzYNhw4dgq+vL5KSkgAAz549g52dncY+RkZGsLGxwbNnz977ukFBQbCyslIehQsX/qzvg4iIiLRHq5ex/k27du2Uf1esWBGVKlVCiRIlcPDgQdSvX/+TXzcgIACDBw9WnkdFRTHwEBER6ahs3bLzruLFiyNfvny4ffs2AMDe3h7Pnz/X2CYxMRERERHv7ecDpPQDsrS01HgQERGRbspRYefRo0cIDw+Hg4MDAKB6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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tags_sim = ['centralized', 'independent_control', 'independent_control_w_uniform_prediction',\n",
    "                'independent_control_w_policy_prediction', 'selfish_perfect_prediction', 'selfish_selfish']\n",
    "tasks = []\n",
    "for tag in tags_sim:\n",
    "    gen_dir = 'data/simulated_gridworld_data/{}1'.format(tag)\n",
    "    file = open(gen_dir + '/expert_trajectories.pickle', 'rb')\n",
    "    all_expert_trajectories = pickle.load(file)\n",
    "    task_length = []\n",
    "    for traj in all_expert_trajectories:\n",
    "        task_length.append(len(traj['states']))\n",
    "    tasks.append(task_length)\n",
    "\n",
    "# Calculate the mean and standard deviation of task_length\n",
    "mean_task_length = [np.mean(task) for task in tasks]\n",
    "std_task_length = [np.std(task) for task in tasks]\n",
    "\n",
    "# Plot the barplot\n",
    "plt.bar(tags_sim, mean_task_length, yerr=std_task_length, capsize=5)\n",
    "plt.xlabel('Simulation Tags')\n",
    "plt.ylabel('Task Length')\n",
    "plt.xticks(rotation=45, ha='right')\n",
    "plt.title('Mean Task Length with Error Bars')\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[23.195, 17.982]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_task_length"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test: hallway task"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from process_hallway_data import hallway_action2idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "397"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "GEN_DIR_NAME = 'data/experiment_hallway/'\n",
    "df = pd.read_csv(GEN_DIR_NAME + 'trials.tsv', sep='\\t')\n",
    "df['uid'] = df['workerid'] + '_' + df['round'].astype(str)\n",
    "# rounds = df[df['exp_condition']=='f']['uid']\n",
    "rounds = df['uid']\n",
    "len(rounds.unique())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "grid_H, grid_W = 3, 5\n",
    "gw_pre = gridworld.GridWorld_v2(grid_H, grid_W,{},{})\n",
    "# create a joint reward map, agent1: yellow; agent2: blue, state = (y1,x1,y2,x2)\n",
    "target_location = (1,4,1,0)\n",
    "reward_map = np.zeros(((grid_H*grid_W)**2, 1))\n",
    "target_idx = gw_pre.pos2idx1(target_location)\n",
    "reward_map[target_idx] = 1\n",
    "states = [(1,4,c,d) for c in range(grid_H) for d in range(grid_W)] + [(a,b,1,0) for a in range(grid_H) for b in range(grid_W)]\n",
    "terminal_states1 = list(set(states)) # remove repetitive entries\n",
    "collide_states = [(a,b,a,b) for a in range(grid_H) for b in range(grid_W)]\n",
    "terminal_states = [target_location]\n",
    "\n",
    "gw = gridworld.GridWorld_v2(grid_H, grid_W,reward_map,terminal_states)\n",
    "\n",
    "action_list = [(i,j) for i in range(5) for j in range(5)]\n",
    "trajectories = []\n",
    "for id in rounds.unique():\n",
    "    df_select = df[df['uid']==id]\n",
    "    df_select_sorted = df_select.sort_values('round_step')\n",
    "    states, actions = [], []\n",
    "    for _, row in df_select_sorted.iterrows():\n",
    "        state_4d = (row['participant_y'], row['participant_x'], row['learner_y'], row['learner_x'])\n",
    "        states.append(gw.pos2idx1(state_4d))\n",
    "        action_2d = (hallway_action2idx(row['participant_action']), hallway_action2idx(row['learner_action']))\n",
    "        action_idx = action_list.index(action_2d)\n",
    "        actions.append(action_idx)\n",
    "    gw.reset(state_4d)\n",
    "    _,_,next_state,_,_ = gw.step(action_2d)\n",
    "    states.append(gw.pos2idx1(next_state))\n",
    "    trajectories.append({'states':states, 'actions':actions})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "marginal_states = [(1,4,c,d) for c in range(grid_H) for d in range(grid_W)] + [(a,b,1,0) for a in range(grid_H) for b in range(grid_W)]\n",
    "terminal_states = list(set(marginal_states)) # remove repetitive entries\n",
    "terminal_states.remove(target_location)\n",
    "terminal_state_idx = [gw.pos2idx1(pos) for pos in terminal_states]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "397\n",
      "81\n",
      "45\n",
      "278\n"
     ]
    }
   ],
   "source": [
    "success_idx = [i for i, traj in enumerate(trajectories) if traj['states'][-1]==gw.pos2idx1(target_location)]\n",
    "expert_idx = [i for i, traj in enumerate(trajectories) if traj['states'][-1]==gw.pos2idx1(target_location) and len(traj['states'])==7]\n",
    "fail_idx = [i for i, traj in enumerate(trajectories) if traj['states'][-1] in terminal_state_idx]\n",
    "print(len(trajectories))\n",
    "print(len(success_idx))\n",
    "print(len(expert_idx))\n",
    "print(len(fail_idx))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7\n",
      "14\n",
      "7\n"
     ]
    },
    {
     "data": {
      "image/png": "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4uPj1axZM91www2V3hapvFGjRslms/ksN910U6BKBILKqFGjZBgG13sDteAqnbzF3wWVI7MBAIFCZnsF7Mz3ddddp7S0NC1btkxFRUWaMmWKpk2bpoULF1a739SpU3X//fd7npef4RkAAElyG3a5/bx+zB2i1481BDIbABAoZLZXQJrv7du3a8mSJVq/fr2GDBkiSXrqqad04YUX6p///Kfatm1b5b7R0dFKTk4ORFkAgBBRl6PirhC9fqy+yGwAQCCR2V4Bab5Xr16tZs2aeUJcksaOHSu73a61a9fqsssuq3LfN954Q6+//rqSk5N10UUX6e677672SHpBQYEKCgo8z91ut44ePaoWLVrIZgvNawUAwMoMw9CJEyfUtm1b2e2hOazMSshsAEBlyOuGF5DmOz09XUlJSb4fFBamxMREpaenV7nfb3/7W3Xs2FFt27bV999/rzvvvFM7duzQe++9V+U+c+fO1X333ddgtQMAGsf+/fvVvn37Ou3rlv+Tsbjr9Emhj8wGAFSnPnktkdnl+dV833XXXXr44Yer3Wb79u11LmbatGmex/369VObNm00ZswY7dq1S127dq10n5kzZ2rGjBme51lZWerQoYP2798fUjdkB4BQkZ2drZSUFMXFxdX5Pep225KmddSezAYA1EdD5LVEZpfnV/P9l7/8RZMnT652my5duig5OVkZGRk+64uLi3X06FG/rg0bNmyYJCk1NbXKIHc6nXI6nRXWx8fHE+QAEMTqM8zYZdjl8nPyFn+3tzoyGwDQEOp7WRCZ7eVX892qVSu1atWqxu2GDx+u48ePa+PGjRo8eLAk6fPPP5fb7faEc21s3rxZktSmTRt/ygQAhDi3bHLL3yFsTeuaYjIbABAMyGyvgBxS6NWrly644AJNnTpV69at0zfffKNbbrlF11xzjWfW1IMHD6pnz55at26dJGnXrl164IEHtHHjRu3Zs0cffPCBJk6cqHPOOUf9+/cPRJkAAIsqO4ru74KKyGwAQCCR2V4Bu8/3G2+8oVtuuUVjxoyR3W7XFVdcoSeffNLzelFRkXbs2KGTJ09KkiIiIvTZZ59p3rx5ys3NVUpKiq644grNmjUrUCUCACyqbrctCc0gbwhkNgAgUMhsr4A134mJiVq4cGGVr3fq1ElGuZunp6Sk6MsvvwxUOQAAoApkNgAAgRew5hsAgEBxGza5/b1tiZ/bAwCA+iOzvWi+AQCW467DELZQvW0JAADBjMz2ovkGAFiO27DL7edkLP5uDwAA6o/M9qL5BgBYjks2ufy8DYm/2wMAgPojs71ovgEAlsNRdAAArIHM9qL5BgBYjkv+HxV3BaYUAABQDTLbKzQPKQAAAAAAEEQ48w0AsByGsAEAYA1kthfNNwDAclyGXS4/g9nf7QEAQP2R2V403wAAyzFkk9vP68eMEJ05FQCAYEZme9F8AwAsh6PoAABYA5ntRfMNALAct2GT2/DvqLi/2wMAgPojs71ovgEAluOSXS4/b9jh7/YAAKD+yGyv0PyuAAAAAAAIIpz5BgBYDkPYAACwBjLbi+YbAGA5btnl9nPwlr/bAwCA+iOzvWi+AQCW4zJscvl5VNzf7QEAQP2R2V403wAAy2EIGwAA1kBme9F8AwAsxzDscvt5D1AjRO8ZCgBAMCOzvWi+AQCW45JNLvk5hM3P7QEAQP2R2V6heUgBAAAAAIAgwplvAIDluA3/rwdzGwEqBgAAVInM9qL5BgBYjrsO14/5uz0AAKg/MtuL5hsAYDlu2eT283owf7cHAAD1R2Z7heYhhSAyf/58derUSZGRkRo2bJjWrVtndklB4ZlnnlH//v0VHx+v+Ph4DR8+XJ988onZZQWVgwcP6ne/+51atGihqKgo9evXTxs2bDC7rKBy4sQJ3X777erYsaOioqI0YsQIrV+/3uyyTLFy5UpddNFFatu2rWw2mxYvXux5raioSHfeeaf69eunmJgYtW3bVhMnTtQvv/xiXsH1VHbPUH8XoCrkddXI7JqR2dUjr32R2U03swPefPsbZu+884569uypyMhI9evXTx9//HGgSwyYt956SzNmzNDs2bO1adMmDRgwQOPGjVNGRobZpZmuffv2euihh7Rx40Zt2LBB5557ri655BJt27bN7NKCwrFjx3TmmWcqPDxcn3zyiX744Qf961//UvPmzc0uLajceOONWrZsmV577TVt2bJF559/vsaOHauDBw+aXVqjy83N1YABAzR//vwKr508eVKbNm3S3XffrU2bNum9997Tjh07dPHFF5tQacMoG8Lm74LqNdXMJq+rR2ZXj8yuGXnti8xuupltMwwjYJezv/XWW5o4caKeffZZDRs2TPPmzdM777yjHTt2KCkpqcL2q1at0jnnnKO5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YDlu2eSSze99AABA4yKzvbjVGAAAAAAAAcaZbwCA5biNksXffQAAQOMis71ovgEAluOqwxA2f7cHAAD1R2Z70XwDACyHIAcAwBrIbC+u+QZqacuWLbryyivVsWNHRUZGql27djrvvPP01FNPmV0a0OS4DVudFgAA0LjIbC/OfAO1sGrVKo0ePVodOnTQ1KlTlZycrP3792vNmjV64okndOutt5pdItCkcBQdAABrILO9aL6BWnjwwQeVkJCg9evXq1mzZj6vZWRkmFMU0IS5ZJfLz8FbrgDVAgAAqkZmezHsHKiFXbt2qU+fPhUab0lKSkqSJO3Zs0c2m00LFiyosI3NZtO9997rs+7gwYO64YYb1LZtWzmdTnXu3Fk333yzCgsLPdscP35cf/7zn9WpUyc5nU61b99eEydO1OHDhz3bFBQUaPbs2erWrZucTqdSUlL0t7/9TQUFBT6ft2zZMp111llq1qyZYmNj1aNHD/3973/32eapp55Snz59FB0drebNm2vIkCFauHChnz8tAAAAAKfizDdQCx07dtTq1au1detW9e3bt97v98svv2jo0KE6fvy4pk2bpp49e+rgwYP673//q5MnTyoiIkI5OTk6++yztX37dl1//fUaNGiQDh8+rA8++EAHDhxQy5Yt5Xa7dfHFF+vrr7/WtGnT1KtXL23ZskWPP/64fvrpJy1evFiStG3bNv36179W//79df/998vpdCo1NVXffPONp6YXXnhBt912m6688kr96U9/Un5+vr7//nutXbtWv/3tb+v9PQMNyajD9WBGiF4/BgBAMCOzvWi+gVr461//qvHjx2vgwIEaOnSozj77bI0ZM0ajR49WeHi43+83c+ZMpaena+3atRoyZIhn/f333y/DKLmx4aOPPqqtW7fqvffe02WXXebZZtasWZ5tFi5cqM8++0xffvmlzjrrLM82ffv21U033aRVq1ZpxIgRWrZsmQoLC/XJJ5+oZcuWldb00UcfqU+fPnrnnXf8/n6Axsb1YwAAWAOZ7cWwc6AWzjvvPK1evVoXX3yxvvvuOz3yyCMaN26c2rVrpw8++MCv93K73Vq8eLEuuugin8a7jM1W8svm3Xff1YABA3wa71O3eeedd9SrVy/17NlThw8f9iznnnuuJOmLL76QJM9w+ffff19ut7vSupo1a6YDBw5o/fr1fn0/gBlchr1OCwAAaFxktldofldAAJxxxhl67733dOzYMa1bt04zZ87UiRMndOWVV+qHH36o9ftkZmYqOzu7xuHru3btqnGbnTt3atu2bWrVqpXPctppp0nyTgZ39dVX68wzz9SNN96o1q1b65prrtHbb7/t04jfeeedio2N1dChQ9W9e3dNnz7dZ1g6EEzcssktu59LaB5FBwAgmJHZXgw7B/wUERGhM844Q2eccYZOO+00TZkyRe+8844mT55c6fYuV+Dma3S73erXr58ee+yxSl9PSUmRJEVFRWnlypX64osv9NFHH2nJkiV66623dO655+rTTz+Vw+FQr169tGPHDn344YdasmSJ3n33Xf373//WPffco/vuuy9g3wNQFwxhAwDAGshsL5pvoB7Kho2npaWpefPmkkpmKC9v7969Ps9btWql+Ph4bd26tdr37tq1a622+e677zRmzBjPUPSq2O12jRkzRmPGjNFjjz2mOXPm6P/9v/+nL774QmPHjpUkxcTE6Oqrr9bVV1+twsJCXX755XrwwQc1c+ZMRUZGVvv+QGOqy5A0V+lcCQAAoPGQ2V4MOwdq4YsvvvBMclbexx9/LEnq0aOH4uPj1bJlS61cudJnm3//+98+z+12uy699FL973//04YNGyq8Z9nnXHHFFfruu++0aNGiKrf5zW9+o4MHD+qFF16osE1eXp5yc3MlSUePHq3w+sCBAyXJc0uyI0eO+LweERGh3r17yzAMFRUVVdgfAAAAQO1x5huohVtvvVUnT57UZZddpp49e6qwsFCrVq3SW2+9pU6dOmnKlCmSpBtvvFEPPfSQbrzxRg0ZMkQrV67UTz/9VOH95syZo08//VQjR4703CIsLS1N77zzjr7++ms1a9ZMd9xxh/773//qqquu0vXXX6/Bgwfr6NGj+uCDD/Tss89qwIAB+v3vf6+3335bN910k7744gudeeaZcrlc+vHHH/X2229r6dKlGjJkiO6//36tXLlSEyZMUMeOHZWRkaF///vfat++vWeW9PPPP1/Jyck688wz1bp1a23fvl1PP/20JkyYoLi4uEb9eQM1Kbl+zL8haaF6/RgAAMGMzPai+QZq4Z///Kfeeecdffzxx3r++edVWFioDh066I9//KNmzZrlmU38nnvuUWZmpv773//q7bff1vjx4/XJJ58oKSnJ5/3atWun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MzR79mxt2rRJAwYM0Lhx45SRkWF2aaZr3769HnroIW3cuFEbNmzQueeeq0suuUTbtm0zu7SgcOzYMZ155pkKDw/XJ598oh9++EH/+te/1Lx5c7NLCyo33nijli1bptdee01btmzR+eefr7Fjx+rgwYNml9bocnNzNWDAAM2fP7/CaydPntSmTZt09913a9OmTXrvvfe0Y8cOXXzxxSZUCgQf8rp6ZHb1yOyakde+yOymy2YYRkAvZ58/f74effRRpaena8CAAXrqqac0dOjQKrd/5513dPfdd2vPnj3q3r27Hn74YV144YW1/rzs7GwlJCQoKytL8fHxDfEt1NmwYcN0xhln6Omnn5Ykud1upaSk6NZbb9Vdd91lam3BKDExUY8++qhuuOEGs0sx3V133aVvvvlGX331ldmlBK28vDzFxcXp/fff14QJEzzrBw8erPHjx+sf//iHidWZy2azadGiRbr00kur3Gb9+vUaOnSo9u7dqw4dOjRecarf7+myfa9Z/jtFxEb4tW9hTqHeHPN6UORDsGqqmU1e+4/M9iKzq0deVy+YM7u+v6PJ7IoCeubb3yPJq1at0rXXXqsbbrhB3377rS699FJdeuml2rp1ayDLDIjCwkJt3LhRY8eO9ayz2+0aO3asVq9ebWJlwcflcunNN99Ubm6uhg8fbnY5QeGDDz7QkCFDdNVVVykpKUmnn366XnjhBbPLCirFxcVyuVyKjIz0WR8VFaWvv/7apKqsIysrSzabTc2aNTO7lDpxyya34ecSotePNZSmmtnktX/I7IrI7OqR1/VHZoeOgDbfjz32mKZOnaopU6aod+/eevbZZxUdHa2XXnqp0u2feOIJXXDBBbrjjjvUq1cvPfDAAxo0aJDnSHRlCgoKlJ2d7bMEg8OHD8vlcql169Y+61u3bq309HSTqgouW7ZsUWxsrJxOp2666SYtWrRIvXv3NrusoPDzzz/rmWeeUffu3bV06VLdfPPNuu222/TKK6+YXVrQiIuL0/Dhw/XAAw/ol19+kcvl0uuvv67Vq1crLS3N7PKCWn5+vu68805de+21lj2abJRO3uLPYoRokDeUpprZ5HXtkNlVI7OrR17XD5kdWgLWfNflSPLq1at9tpekcePGVXvkee7cuUpISPAsKSkpDfMNIOB69OihzZs3a+3atbr55ps1adIk/fDDD2aXFRTcbrcGDRqkOXPm6PTTT9e0adM0depUPfvss2aXFlRee+01GYahdu3ayel06sknn9S1114ru53pLKpSVFSk3/zmNzIMQ88884zZ5dSZ30fQSxdUjsxGTcjsqpHZNSOv64bMDj0B+y++LkeS09PT/T7yPHPmTGVlZXmW/fv317/4BtCyZUs5HA4dOnTIZ/2hQ4eUnJxsUlXBJSIiQt26ddPgwYM1d+5cDRgwQE888YTZZQWFNm3aVDij0KtXL+3bt8+kioJT165d9eWXXyonJ0f79+/XunXrVFRUpC5duphdWlAqC/G9e/dq2bJllj2CLnnvGervgso15cwmr2uHzK4amV0z8tp/ZHZoZrblvyun0+m59UXZEgwiIiI0ePBgLV++3LPO7XZr+fLlXCNVBbfbrYKCArPLCApnnnmmduzY4bPup59+UseOHU2qKLjFxMSoTZs2OnbsmJYuXapLLrnE7JKCTlmI79y5U5999platGhhdkn1wlF0awrGzCav64bM9iKza4+8rlxRYZF2b9nrfU5mh2xmhwXqjetyJDk5OTmkjjzPmDFDkyZN0pAhQzR06FDNmzdPubm5mjJlitmlmW7mzJkaP368OnTooBMnTmjhwoVasWKFli5danZpQeHPf/6zRowYoTlz5ug3v/mN1q1bp+eff17PP/+82aUFlaVLl8owDPXo0UOpqam644471LNnzyb5bywnJ0epqame57t379bmzZuVmJioNm3a6Morr9SmTZv04YcfyuVyec5OJiYmKiLCvxlIEXqaemaT19Ujs6tHZteMvPZ1ambfM+0pNY9oqxeXz1b3nt3I7BAWsOa7/JHksqnzy44k33LLLZXuM3z4cC1fvly33367Z92yZcsse+T56quvVmZmpu655x6lp6dr4MCBWrJkSYVhek1RRkaGJk6cqLS0NCUkJKh///5aunSpzjvvPLNLCwpnnHGGFi1apJkzZ+r+++9X586dNW/ePF133XVml9aoDMNQsVGkQneRCt0FKnQXqqj0a7g9QllZWZo5c6YOHDigxMREXXHFFXrwwQcVHh5udumNbsOGDRo9erTn+YwZMyRJkyZN0r333qsPPvhAkjRw4ECf/b744guNGjWqscpsMGUTsvi7DyrX1DObvK4emV09Mrtm5LWvUzP7x6yS29TddUeennz2CTJboZvZAb3P91tv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+Ze6Xh9JOnjwoO68804tW7bM9XfLqmzO8s3Tc1A98tqNvK4emV0zMrsq8rpuZHb9zglEPr3zvXTpUk2ePFm9e/dW//79tWDBAu3bt09btmyp8ZwXXnhBl112me6991717NlTjzzyiAYNGqQ5c+b4slSfy83NlSTFxsaaXIn/+Omnn5SUlKTOnTvr+uuv1759+8wuyW8MGzZMK1eu1I8//ihJ+uqrr7R27do6f1ADNXE6nbrhhht07733qnfv3maX03g8wuZV5LUbeV09MrtmZDa8jcxWwGZ2k064Vp9AW79+vaZPn15l3+jRo2scC1FcXKzi4mLX+3l5eY0v1MucTqemTZum8847z1J3A3xp6NChWrBggbp3767MzEw99NBDuuCCC/TNN98oKirK7PJMd9999ykvL089evRQcHCwHA6HHnvsMV1//fVmlwaLevLJJxUSEqI//vGPZpfiFUze4lu+yGvJ/zObvK4emV07MhveRmYHbmY3WfNd30DLyspSu3btquxr166dsrKyqj0+PT1dDz30kFdr9bYpU6bom2++YXxUJZWvBvfr109Dhw5Vx44d9c477+jmm282sTL/8M477+itt97SwoUL1bt3b2VkZGjatGlKSkrSpEmTzC4PFrNlyxa98MIL2rp1q2w2m9nleAfLlviMr/Ja8v/MJq+rR2bXjsyGN5HZlc4JQE0223lFoC1atMirn3fGjBnKzc11bfv37/fq52+sqVOn6qOPPtL//d//qUOHDmaX47datWqls846Szt37jS7FL9w77336r777tOECRPUt29f3XDDDbr77ruVnp5udmmwoM8//1w5OTlKSUlRSEiIQkJCtHfvXt1zzz3q1KmT2eU1SMVVdE831M1XeS35d2aT1/VHZldFZsObyOzAzuwmufNdEWhr1qypM9ASEhKUnZ1dZV92dnaNk3zY7XbZ7Xav1eothmHozjvv1OLFi7Vq1SqlpqaaXZJfy8/P165du1yTcDR3p06dUlBQ1WtjwcHBcjoDdPYJ+NQNN9ygUaNGVdk3evRo3XDDDbrxxhtNqqqRGjIeLECD3Jt8mdeSf2Y2ee05MrsqMhveRGZXOicA+bT5bkigpaWlaeXKlZo2bZpr3/Lly5WWlubDSr1vypQpWrhwoT744ANFRUW5HsOLiYlRRESEydWZ709/+pPGjRunjh076tChQ5o1a5aCg4N13XXXmV2aXxg3bpwee+wxpaSkqHfv3tq2bZuee+453XTTTWaXZpr8/Pwqd1l2796tjIwMxcbGKiUlRceOHdO+fft06NAhSXItk5SQkNAsZuit6/WJi4urcnxoaKgSEhLUvXv3pi4Vfoi8Jq9rQ2bXjsyuiryuG5ndfPm0+a5PoE2cOFHt27d3PZpz1113acSIEXr22Wc1duxYLVq0SJs3b9arr77qy1K9bt68eZKkkSNHVtk/f/58TZ48uekL8jMHDhzQddddp6NHj6pt27Y6//zztWHDBrVt29bs0vzCSy+9pJkzZ+oPf/iDcnJylJSUpN///vd64IEHzC7NNJs3b9aFF17oer9ioqdJkyZpwYIF+vDDD6tcEZ4wYYIkadasWXrwwQebtFYz1PX6BBomb/Eu8pq8rg2ZXTsyuyryum5kdv3OCUQ2w/DdaPaaJgmoHGgjR45Up06dqvxFe/fdd3X//fdrz5496tatm5566ildfvnl9fqaeXl5iomJUW5urqKjoxv7LQAAvKwxP6crzj338ocVEhru0bllpUXa8MkD5EM1zMhricwGAH/W2J/RZPaZfP7YeV1WrVp1xr6rr75aV199tQ8qAgAEAq6iexd5DQDwFTLbrUnX+QYAwCuYvAUAAGsgs11ovgEAlsNVdAAArIHMdqP5BgBYj9Mo3zw9BwAANC0y2yWo7kMAAAAAAEBjcOcbAGA9jB8DAMAayGwXmm8AgOXY1IDxYz6pBAAA1IbMdqP5BgBYj2GUb56eAwAAmhaZ7ULzDQCwHGZOBQDAGshsN5pvAID1MH4MAABrILNdaL4BAJZjMwzZPHwkzdPjAQBA45HZbiw1BgAAAACAj3HnGwBgPc7Tm6fnAACApkVmu9B8AwAsh0fYAACwBjLbjeYbAGA9TN4CAIA1kNkuNN8AAOthzVAAAKyBzHah+QYAWA5rhgIAYA1kthvNNwDAeriKDgCANZDZLiw1BgAAAACAj3HnGwBgOTZn+ebpOQAAoGmR2W403wAA6+ERNgAArIHMdqH5BgBYD8uWAABgDWS2C803AMBybIYhm4dXxT09HgAANB6Z7UbzDQCwHh5hAwDAGshsF5pvAID1GJI8nYwlMHMcAAD/Rma7sNQYAAAAAAA+5tPmOz09XUOGDFFUVJTi4+M1fvx47dixo9ZzFixYIJvNVmULDw/3ZZkAAIupGD/m6YbqkdcAAF8hs9182nyvXr1aU6ZM0YYNG7R8+XKVlpbq0ksvVUFBQa3nRUdHKzMz07Xt3bvXl2UCAKzGkHsMWb03s4v2X+Q1AMBnyGwXn475Xrp0aZX3FyxYoPj4eG3ZskXDhw+v8TybzaaEhARflgYAsDImb/Eq8hoA4DNktkuTTriWm5srSYqNja31uPz8fHXs2FFOp1ODBg3S448/rt69e1d7bHFxsYqLi8/4Gnl5eV6qGgDgTRU/n43GBKtTkq0B56BefJHXEpkNAFbilbyWyOxKmqz5djqdmjZtms477zz16dOnxuO6d++uf/3rX+rXr59yc3P1zDPPaNiwYfr222/VoUOHM45PT0/XQw89dMb+5ORkr9YPAPCukydPKiYmpkHnsmao7/gqryUyGwCsqDF5LZHZldmMRl/KqJ877rhDn376qdauXVtjKFentLRUPXv21HXXXadHHnnkjI//8iq60+nUsWPHFBcXJ5vN00ss3peXl6fk5GTt379f0dHRZpfjl3iNasfrUzten9r54+tjGIZOnjyppKQkBQV5NvVIXl6eYmJidHHvexUSbPfo3DJHsVZ++7Ryc3P95rXwR77Ka4nMtjpen9rx+tSN16h2/vb6NCavJTK7Ok1y53vq1Kn66KOPtGbNGo+CXJJCQ0M1cOBA7dy5s9qP2+122e1V/2e2atWqoaX6THR0dED9xfEFXqPa8frUjtendv72+jTmCjp8x5d5LZHZgYLXp3a8PnXjNaqdP70+5LV3+XS2c8MwNHXqVC1evFifffaZUlNTPf4cDodD27dvV2Jiog8qBABYksezpjZgspdmhLwGAPgMme3i0zvfU6ZM0cKFC/XBBx8oKipKWVlZksqvoEREREiSJk6cqPbt2ys9PV2S9PDDD+vcc89V165ddeLECT399NPau3evbrnlFl+WCgCwEmZO9SryGgDgM2S2i0+b73nz5kmSRo4cWWX//PnzNXnyZEnSvn37qowhOH78uG699VZlZWWpdevWGjx4sNatW6devXr5slSfsdvtmjVr1hmP2cGN16h2vD614/WpXcC+Psyc6lXkdbmA/ffiJbw+teP1qRuvUe0C9vUhs12abMI1AAAaq2LyllFnTW/Q5C0rfnwu4CZvAQDAH5HZZ2rSdb4BAPAKHmEDAMAayGwXmm8AgPU4DcnmYTA7AzPIAQDwa2S2i09nOwcAAAAAANz5BgBYEY+wAQBgDWS2C803AMCCGrIGaGAGOQAA/o3MrsBj5z42d+5cderUSeHh4Ro6dKg2btxodkl+Y82aNRo3bpySkpJks9m0ZMkSs0vyK+np6RoyZIiioqIUHx+v8ePHa8eOHWaX5TfmzZunfv36KTo6WtHR0UpLS9Onn35qdll+64knnpDNZtO0adPMLsU7Kq6ie7oBNSCva0Ze1468rh157ZmAy2uJzK6E5tuH3n77bU2fPl2zZs3S1q1b1b9/f40ePVo5OTlml+YXCgoK1L9/f82dO9fsUvzS6tWrNWXKFG3YsEHLly9XaWmpLr30UhUUFJhdml/o0KGDnnjiCW3ZskWbN2/WRRddpCuuuELffvut2aX5nU2bNumVV15Rv379zC7Fe5xGwzagGuR17cjr2pHXtSOv6y8g81oisythnW8fGjp0qIYMGaI5c+ZIkpxOp5KTk3XnnXfqvvvuM7k6/2Kz2bR48WKNHz/e7FL81uHDhxUfH6/Vq1dr+PDhZpfjl2JjY/X000/r5ptvNrsUv5Gfn69Bgwbpb3/7mx599FENGDBAs2fPNrusBnOtGZryB4UEebhmqLNYK/b9LeDWDEXjkdf1R17XjbyuG3l9pkDLa4nMrg53vn2kpKREW7Zs0ahRo1z7goKCNGrUKK1fv97EymBVubm5ksoDC1U5HA4tWrRIBQUFSktLM7scvzJlyhSNHTu2ys+igMAjbPAS8hreRl7XjLyuWcDmtURmV8KEaz5y5MgRORwOtWvXrsr+du3a6YcffjCpKliV0+nUtGnTdN5556lPnz5ml+M3tm/frrS0NBUVFSkyMlKLFy9Wr169zC7LbyxatEhbt27Vpk2bzC4F8FvkNbyJvK4eeV078rr5oPkGLGDKlCn65ptvtHbtWrNL8Svdu3dXRkaGcnNz9Z///EeTJk3S6tWrCXRJ+/fv11133aXly5crPDzc7HK8z2nI45lQA3T8GAD/QV5Xj7yuWcDntURmV0Lz7SNt2rRRcHCwsrOzq+zPzs5WQkKCSVXBiqZOnaqPPvpIa9asUYcOHcwux6+EhYWpa9eukqTBgwdr06ZNeuGFF/TKK6+YXJn5tmzZopycHA0aNMi1z+FwaM2aNZozZ46Ki4sVHBxsYoWNxJqh8BLyGt5CXteMvK5ZwOe1RGZXwphvHwkLC9PgwYO1cuVK1z6n06mVK1cyxgX1YhiGpk6dqsWLF+uzzz5Tamqq2SX5PafTqeLiYrPL8AsXX3yxtm/froyMDNd29tln6/rrr1dGRkYABLkaMH7M7KLhj8hrNBZ57Tny2i3g81oisyvhzrcPTZ8+XZMmTdLZZ5+tc845R7Nnz1ZBQYFuvPFGs0vzC/n5+dq5c6fr/d27dysjI0OxsbFKSUkxsTL/MGXKFC1cuFAffPCBoqKilJWVJUmKiYlRRESEydWZb8aMGRozZoxSUlJ08uRJLVy4UKtWrdKyZcvMLs0vREVFnTHesGXLloqLiwuMcYhcRYcXkde1I69rR17XjryuXcDntURmV0Lz7UPXXnutDh8+rAceeEBZWVkaMGCAli5desakLs3V5s2bdeGFF7renz59uiRp0qRJWrBggUlV+Y958+ZJkkaOHFll//z58zV58uSmL8jP5OTkaOLEicrMzFRMTIz69eunZcuW6ZJLLjG7NDQFp1OSswHnAGcir2tHXteOvK4deQ0y2411vgEAluFaM7TtzQoJCvPo3DJniVYc/mfArRkKAIA/IrPPxJhvAAAAAAB8jMfOAQDWw/gxAACsgcx2ofkGAFgPa4YCAGANZLYLzTcAwHIMwynD8GwyFk+PBwAAjUdmu9F8AwCsxzA8vyoeoI+wAQDg18hsF5pvAID1GA14hC1AgxwAAL9GZrvQfAMArMfplGwePpIWoI+wAQDg18hsF5YaAwAAAADAx7jzDQCwHh5hAwDAGshsF5pvAIDlGE6nDA8fYQvUmVMBAPBnZLYbzTcAwHq4ig4AgDWQ2S403wAA63Eako0gBwDA75HZLjTfAADrMQxJns6cGphBDgCAXyOzXWi+AQCWYzgNGR5eRTcCNMgBAPBnZLYbS40BAFCDw4cP64477lBKSorsdrsSEhI0evRoffHFF5Ikm82mJUuWeOVr7dmzRzabTRkZGV75fAAANBdWyWvufAMArMdwyvNH2DyfOfXKK69USUmJXnvtNXXu3FnZ2dlauXKljh496vHnqk1JSYlXPx8AAH6jCTLbKnltMwL1nj4AIODk5eUpJiZGI22/UYgt1KNzy4xSrTIWKzc3V9HR0XUef+LECbVu3VqrVq3SiBEjzvh4p06dtHfvXtf7HTt21J49e7Rr1y5Nnz5dGzZsUEFBgXr27Kn09HSNGjWqyrk333yzfvrpJy1ZskS//e1v9dprr1X5/CNGjNCqVas8+h4BAPAXTZXZVsprHjsHAFhOmVGsMqeHm1EsqfyXgcpbcXFxtV8jMjJSkZGRWrJkSbXHbNq0SZI0f/58ZWZmut7Pz8/X5ZdfrpUrV2rbtm267LLLNG7cOO3bt6/K+c8884z69++vbdu2aebMmdq4caMkacWKFcrMzNT777/vtdcLAACz+DqzrZTX3PkGAFhGUVGRUlNTlZWV1aDzIyMjlZ+fX2XfrFmz9OCDD1Z7/Hvvvadbb71VhYWFGjRokEaMGKEJEyaoX79+ksrHkC1evFjjx4+v9ev26dNHt99+u6ZOnSqp/Er6wIEDtXjxYtcxe/bsUWpqqrZt26YBAwY06PsDAMBfNGVmWyWvGfMNALCM8PBw7d69u8FjrgzDkM1mq7LPbrfXePyVV16psWPH6vPPP9eGDRv06aef6qmnntI//vEPTZ48udpz8vPz9eCDD+rjjz9WZmamysrKVFhYeMaV9LPPPrtB3wMAAFbQlJltlbym+QYAWEp4eLjCw8Ob9OtdcskluuSSSzRz5kzdcsstmjVrVo1h/qc//UnLly/XM888o65duyoiIkJXXXXVGb98tGzZsgmqBwDAPE2Z2VbIa8Z8AwDggV69eqmgoECSFBoaKofDUeXjX3zxhSZPnqzf/OY36tu3rxISErRnz546P29YWJgknfH5AACA5/wxr2m+AQCoxtGjR3XRRRfpzTff1Ndff63du3fr3Xff1VNPPaUrrrhCUvlYsJUrVyorK0vHjx+XJHXr1k3vv/++MjIy9NVXX+l3v/udnM66l0yJj49XRESEli5dquzsbOXm5vr0+wMAIBBYKa9pvgEAqEZkZKSGDh2q559/XsOHD1efPn00c+ZM3XrrrZozZ44k6dlnn9Xy5cuVnJysgQMHSpKee+45tW7dWsOGDdO4ceM0evRoDRo0qM6vFxISohdffFGvvPKKkpKSXL8wAACAmlkpr5ntHAAAAAAAH+PONwAAAAAAPkbzDQAAAACAj9F8AwAAAADgYzTfAAAAAAD4GM03AAAAAAA+RvMNAAAAAICP0XwDAAAAAOBjNN8AAAAAAPgYzTcAAAAAAD5G8w0AAAAAgI/RfAMAAAAA4GM03wAAAAAA+BjNNwAAAAAAPkbzDQAAAACAj9F8AwAAAADgYzTfAAAAAAD4GM03AAAAAAA+RvMNAAAAAICP0XwDANBEVq1aJZvNphMnTphdCgAAqIUvMpvmGwCAakyePFk2m+2M7bLLLjO7NAAAUIlVMjvE7AIAAPBXl112mebPn19ln91uN6kaAABQEytkNs03AMBSioqKVFJS0qBzDcOQzWarss9ut9cYzna7XQkJCdV+zGaz6e9//7s+/vhjLVu2TO3bt9ezzz6rX//6165jPvnkE02bNk379+/Xueeeq0mTJjWobgAArIjMrorHzgEAllFUVKTUjpGKiYlp0NahQ4cz9qWnpze4noceekjXXHONvv76a11++eW6/vrrdezYMUnS/v379dvf/lbjxo1TRkaGbrnlFt13333eeikAAPBrZPaZuPMNALCMkpISZeU4tHdLJ0VHeXb9OO+kUx0H79H+/fsVHR3t2l/bI2kfffSRIiMjq+z761//qr/+9a+SyseYXXfddZKkxx9/XC+++KI2btyoyy67TPPmzVOXLl307LPPSpK6d++u7du368knn/SobgAArIjMPhPNNwDAciKjbIqMstV9YCVOlR8fHR1dJchrc+GFF2revHlV9sXGxrre7tevn+vtli1bKjo6Wjk5OZKk77//XkOHDq1yblpamkc1AwBgdWS2G803AMByHIZTDsPzczzVsmVLde3atcaPh4aGVnnfZrPJ6fT86wAAEKjIbDfGfAMALMcpo0FbU+rZs6c2btxYZd+GDRuatAYAAMxGZrvRfAMALMfZwP88VVxcrKysrCrbkSNH6nXu7bffrp9++kn33nuvduzYoYULF2rBggUe1wAAgJWR2W403wAAy3EYRoM2Ty1dulSJiYlVtvPPP79e56akpOi9997TkiVL1L9/f7388st6/PHHPa4BAAArI7PdbIbRgO8MAAAT5OXlKSYmRnt/SGrYzKk9Dik3N7fek7cAAICGIbPPxJ1vAAAAAAB8jNnOAQCW45Qhh4eTsTT15C0AAIDMrozmGwBgOQ2ZCTVQgxwAAH9GZrvRfAMALKchk7E0ZPIWAADQOGS2G803AMBynKc3T88BAABNi8x2o/kGAFiOowHjxzw9HgAANB6Z7UbzDQCwHIdRvnl6DgAAaFpkthtLjQEAAAAA4GPc+QYAWA7jxwAAsAYy243mGwBgOU7Z5JDN43MAAEDTIrPdaL4B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/fff1w8//KCIiAgNGzZMTz75pLp3717ree+++65mzpypPXv2qFu3bnryySd1+eWX+7JUr1u6dGmV9xcsWKD4+Hhlf5+qlMHBOlzMY+ehoSEKiYnVyRblz54HtWxpckX+Y926dbriiis0duxYSVKnTp3073//Wxs3bjS5MvOMGTNGY8aMqfHjN9xwgyRpz549TVSRf6nr9ZGkgwcP6s4779SyZctcf7esyuYs3zw9B9Ujr90q8nrLli0aPny4SVX5n5CQECUkJJhdhl8is6sir+tGZtfvnEDk0zvfDbmavG7dOl133XW6+eabtW3bNo0fP17jx4/XN99848tSfS43N1eS1CG+fMmxgrKjKig7bmZJpvvpp5/0Q/os7X/4ceW8/pYyfuAxvwrDhg3TypUr9eOPP0qSvvrqK61du7bOH9RATZxOp2644Qbde++96t27t9nlNB5X0b2KvHaryOvY2FiTK/EvP/30k5KSktS5c2ddf/312rdvn9kl+Q0yG95GZitgM9und74bcjX5hRde0GWXXaZ7771XkvTII49o+fLlmjNnjl5++eUzji8uLlZxsXuyrry8PC9+B97hdDo1bdo0nXfeeRrcb6i2HT8gSTpStFMtI4eYXJ05hg4dqgULFuhvX/2o74/u1Yml/9Xvr7xSl/74o6Kioswuz3T33Xef8vLy1KNHDwUHB8vhcOixxx7T9ddfb3ZpsKgnn3xSISEh+uMf/2h2KV7RkPFggTp+zBuaIq8l/8/synndp08fs8vxGxWZ3b17d2VmZuqhhx7SBRdcoG+++YbMFpkN7yOzAzezm3TMd32uJq9fv16jRo2qsm/06NFav359tcenp6crJibGtSUnJ3uvYC+ZMmWKvvnmGy1atEhtw90znuc040nXxowZo6uvvlpn9eilFj27q93vb1F+3km98847ZpfmF9555x299dZbWrhwobZu3arXXntNzzzzjF577TWzS4MFbdmyRS+88IIWLFggm81mdjnewbIlPuWLvJb8P7Mr5zXcKjK7X79+Gj16tD755BOdOHGCzD6NzIY3kdmBndlN1nzX92pyVlaW2rVrV2Vfu3btlJWVVe3xM2bMUG5urmvbv3+/V+turKlTp+qjjz7S//3f/6lDhw5Vmu8jLDem9q2iJUnBLSIUnZionTub7wWJyu69917dd999mjBhgvr27asb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",
      "text/plain": [
       "<Figure size 1000x1000 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "traj_list = [trajectories[expert_idx[1]],trajectories[success_idx[7]],trajectories[fail_idx[1]]]\n",
    "title_list = ['Expert', 'Success', 'Fail']\n",
    "# plot the trajectories\n",
    "fig, ax = plt.subplots(3,2, figsize=(10,10))\n",
    "for i,traj in enumerate(traj_list):\n",
    "    states4d = [gw.idx12pos(s) for s in traj['states']]\n",
    "    traj1 = np.array([(a,b) for (a,b,c,d) in states4d])\n",
    "    traj2 = np.array([(c,d) for (a,b,c,d) in states4d])\n",
    "    print(traj1.shape[0])\n",
    "    plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj1}, fig, ax[i,0])\n",
    "    plot_gridworld_trajectories(grid_H, grid_W, {'states2d':traj2}, fig, ax[i,1])\n",
    "    ax[i,0].set_title(title_list[i])\n",
    "\n",
    "plt.tight_layout()\n",
    "fig.savefig('figures/hallway_trajectories.eps')\n",
    "fig.savefig('figures/hallway_trajectories.png')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py3.8",
   "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.8.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
