{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import norm\n",
    "from scipy.optimize import curve_fit \n",
    "from functions import *\n",
    "import time\n",
    "from itertools import product\n",
    "import seaborn as sb"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Code for identifiability and generalizability in Inverse Reinforcement Learning from Multiple Experts"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate the environments for the Strebulaev Whited experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Base parameters\n",
    "theta      = 0.55\n",
    "delta      = 0.2\n",
    "r          = 0.05\n",
    "rho        = 0.7\n",
    "sigma_eps  = 0.04\n",
    "m          = 3\n",
    "n          = 20 ### Grid only depends on the number of shocks # |S| is n^2, |A| is n\n",
    "n_step     = 100\n",
    "n_traj     = 1000\n",
    "discount   = 1/(1+r)\n",
    "n_features = 3\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Dynamics\n",
    "### Transition matrix of shocks\n",
    "policies = []\n",
    "opt_policies = []\n",
    "soft_values =  []\n",
    "Ts = []\n",
    "for rho in [0.01]: #,0.2,0.7]:\n",
    "    for theta in [0.015]:#, 0.25, 0.65]:\n",
    "        for sigma_eps in [0.02, 0.04, 0.6]:\n",
    "            Tauchen = tauchen_86(n,m,rho,sigma_eps)\n",
    "            Tz, zs = Tauchen['Tz'],np.exp(Tauchen['lzs'])\n",
    "            ### Policy \n",
    "            opt_policy_f, _ = gen_opt(theta,delta,r,sigma_eps,rho)\n",
    "            ks = opt_policy_f(zs)\n",
    "            states = states_f(ks,zs)\n",
    "            n_states = states.shape[0]\n",
    "            n_actions = len(ks)\n",
    "            T = transition_matrix_f(Tz,len(ks))\n",
    "            transition_probability = T.transpose(1,0,2)\n",
    "            ### Feature cube\n",
    "            n_states, n_actions = len(states),len(ks)\n",
    "            feat_cube = np.empty((n_states, n_actions, n_features))\n",
    "            if n_features == 3:\n",
    "              a_true = np.array([1,1,-1])\n",
    "              for i,s in enumerate(states): # s = (k,z)\n",
    "                for j,a in enumerate(ks):\n",
    "                  #feat_cube[i,j,0] =  s[1]*s[0]**theta # output \n",
    "                  #feat_cube[i,j,1] =  (1-delta)*s[0] # (1-delta)*k\n",
    "                  #feat_cube[i,j,2] =  a # k'   -0.5*a\n",
    "                  feat_cube[i,j,0] =  s[1]*s[0]**theta # output\n",
    "                  feat_cube[i,j,1] =  a-(1-delta)*s[0] # investment, a - (1-delta)*k\n",
    "                  feat_cube[i,j,2] =  a*s[0]\n",
    "\n",
    "            a_true = np.array([1,1,-1])\n",
    "            reward = feat_cube.dot(a_true)\n",
    "            soft_optimal_policy, soft_value = soft_value_iteration(n_states, n_actions, transition_probability, reward, discount,threshold=1e-5)\n",
    "\n",
    "            policies.append(soft_optimal_policy)\n",
    "            soft_values.append(soft_value)\n",
    "            opt_policies.append(opt_policy_f)\n",
    "            Ts.append(transition_probability)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Random Matrices experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "35\n",
      "1.996766001547786 -4.085554871166838\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## Test with random matrices\n",
    "for seed in range(1):\n",
    "    n_s = 18\n",
    "    n_a = 5\n",
    "    np.random.seed(seed)\n",
    "    T_1 = generate_random_transition(n_s, n_a)\n",
    "    T_2 = generate_random_transition(n_s, n_a)\n",
    "    identity = np.array([np.eye(n_s) for a in range(n_a)]).transpose(2,0,1).reshape(n_s*n_a, -1)\n",
    "    A_1 = identity - discount*T_1\n",
    "    A_2 = identity - discount*T_2\n",
    "    A = np.hstack([A_1, -A_2])\n",
    "    rank_random_A=np.linalg.matrix_rank(A)\n",
    "    print(rank_random_A)\n",
    "    rand_reward = generate_random_reward(n_s, n_a)\n",
    "    soft_optimal_policy_1, _ = soft_value_iteration(n_s, n_a, T_1.reshape(n_s,n_a,n_s), rand_reward, discount,threshold=1e-5)\n",
    "    #reward_2 = generate_random_reward(n_s, n_a)\n",
    "    soft_optimal_policy_2, _ = soft_value_iteration(n_s, n_a, T_2.reshape(n_s,n_a,n_s), rand_reward, discount,threshold=1e-5)\n",
    "    b = np.log(soft_optimal_policy_1.reshape(n_s*n_a, -1)) - np.log(soft_optimal_policy_2.reshape(n_s*n_a, -1))\n",
    "    v = np.linalg.solve(A.T@A,A.T@b)\n",
    "    v_1 = v[:n_s]\n",
    "    v_2 = v[n_s:]\n",
    "    reward_recovered_1 = np.log(soft_optimal_policy_1.reshape(n_s*n_a, -1)) - A_1@v_1\n",
    "    reward_recovered_2 = np.log(soft_optimal_policy_2.reshape(n_s*n_a, -1)) - A_2@v_2\n",
    "    limit_max= max(np.max(reward_recovered_1),np.max(reward_recovered_2),np.max(rand_reward))\n",
    "    limit_min= min(np.min(reward_recovered_1),np.min(reward_recovered_2),np.min(rand_reward))\n",
    "    print(limit_max, limit_min)\n",
    "    plot_reward(reward_recovered_1.reshape(n_s, n_a),\"Random_Matrices_recovered_1\",limit_max,limit_min)\n",
    "    plot_reward(reward_recovered_2.reshape(n_s, n_a),\"Random_Matrices_recovered_2\",limit_max,limit_min)\n",
    "    plot_reward(rand_reward.reshape(n_s, n_a),\"Random_Matrices_true\",limit_max,limit_min)\n",
    "    plot_reward(reward_recovered_1.reshape(n_s, n_a)-rand_reward.reshape(n_s, n_a),\"Random_Matrices_difference_1\",limit_max,limit_min)\n",
    "    plot_reward(reward_recovered_2.reshape(n_s, n_a)-rand_reward.reshape(n_s, n_a),\"Random_Matrices_difference_2\",limit_max,limit_min)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Strebulaev Whited experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generalizability experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "552\n",
      "952\n",
      "552\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAMYAAAEYCAYAAAAH2Im2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAN/UlEQVR4nO3db6hd2V3G8e+TO44DtlboRZTcVANNwdAKLSEzWKFDO5U782LyQpGkiLYMHQqNFKtCRBklfdUKFgrpnxRDtaDpnxdywSsRtKUgzpBbCkMTTbmk0NxYGNOOeTOMMd6fL/bJuHPu/nPOyblrrz3r+YQF95yzz9r7xX6y9tr7d/ZWRGBm9zsw9AaY5cjBMGvgYJg1cDDMGjgYZg0cDLMGDoaNnqQLkl6S9N2WzyXpM5K2Jb0o6V19fToY9nrwJWC94/MngSOT9izwub4OHQwbvYj4FvDjjkVOAH8dleeBn5H08119PtT1oSRfFn8deWhFHEB73v/Uycf42Efe2/ylX/3E3i88gPXH3hq3br8y13e+/e8/vAK8WnvrfEScn6OLg8CN2uudyXs/bPtCZzDMlu3W7VfYuvDhub6jXzn7akQc26dNauRgFGaXloOApY4L2bkJHKq9Xpu818pzDEsrgIj52oPbAH57cnbqMeB2RLQeRoFHDBvCkmeukv4WeBxYlbQD/CnwEwAR8XlgE3gK2AZeAT7U16eDYekt+acOEXGq5/MAPjpPnz6UKoh/ejM7jxiW2NLmDfvKwbD08s+Fg2GJ3TsrlTkHozDt+2TCCxn558LBsCHknwwHwyYS7qz558LBKIlEYxEhkHZn9RzDrEH+uXAwSjN4EeFIzkr5yrdZA48YlpivfJs1yz8XDkZJIqozU4MbwYjhOYZZA48Ylt4IRgwHw9IKPMew/ORRRJh/MhwMSy//XDgYpWk/K5W0WCrhuhbjYBQknyLChOtakINRmNZaqWR85dvGJGkRYaJ1PQAHwwaQfzIcDEsv/1w4GCVxrdTsHAxLL/9cOBg2gBGMGK6uNWvgEcPSGslvvh2MwuRRRJhuVYtyMCwxX/m2DOVRRJg/B6Mg+RQR5h9CB6MwwxcRMorBycGwiu9EeB8Hw9LLPxcOhg0h/2Q4GAXJp4hw6A3o52BYep5jmDXIPxcOhiUW47jy7erawtzbL+tt7CStS7omaVvSmYbP3yLpG5K+I+lFSU/19elg2IRa2vJFxFytc6ulFeAc8CRwFDgl6ejUYn8CfDUi3gmcBD7bt40OhiXXNGp1tR7Hge2IuB4Rd4CLwInpVQI/Pfn7TcB/9HXqOUZBuk/Vpjum6hsF5nQQuFF7vQM8OrXMnwH/KOl3gZ8Cnujr1CNGYQ6gPQ34//s9Tbcla1tNVwNWJW3V2rNzrvYU8KWIWAOeAr4sqXPf94hRmMGLCGOhEeNWRBxr+ewmcKj2em3yXt0zwDpARPyrpEeAVeClthV6xLBKurk3uzFf63EZOCLpsKSHqSbXG1PL/AB4H4CkXwIeAf6zq1OPGJbcMqcYEXFX0mngErACXIiIK5LOAlsRsQH8PvBFSb9HdXT2wegZthwMS6qqOl/u4VxEbAKbU+89V/v7KvDuefp0MAqSSxHhGK4pOhiWWLA7gsvtDoalNZIyFAfDktqPOcZ+cDAKk8M+mcEm9HIwbCLdrNxzDLMpI7lJiINRktdpEeG+cDAKk8WdCEfAwShMHkWEw27CLBwMqyS8Ij54OGfgYFhSnnybNer/HXcOHIyCZFNEmH8uHAxLLzzHMLtfMNOv8gbnYFhai/3mOzkHozA57JM5bEMfB8Mm0s3KPWKYTQlgd+iNmIGDUZDup7a6iLDOwbDkRpALB6M0g9cpzXAH8xw4GFZJNPf2dQyzFr7ybdZgBEdSDkZJ8ikizD8ZDoYl5TmGWQvPMcym+TfflqMcdkrPMWxEUhYRJlvVwhwMSyr8GADLTTZFhMnWtDgHw5LzHMOyM3wRoecYNiZJiwjzT4aDYcnlHwsHwwbgOYZlJZ8iwqG3oJ+DYUn5OoZZE5+VMms2huraA0NvgKUVsbflsA1drY+kdUnXJG1LOtOyzG9KuirpiqS/6evTI4ZNpJmVL/s6hqQV4BzwfmAHuCxpIyKu1pY5AvwR8O6IeFnSz/b16xGjMNLeVomWtnxLHjGOA9sRcT0i7gAXgRNTy3wYOBcRL1frj5f6OnUwCnKviHC6ASlzQcz5D1iVtFVrz9a6OwjcqL3embxX9zbgbZL+RdLzktb7ttGHUpbcAkdStyLi2AOs8iHgCPA4sAZ8S9I7IuK/ur5gBRm6iDCW/3yMm8Ch2uu1yXt1O8ALEfE/wPclfY8qKJfbOvWhlFXU0vbBbszXelwGjkg6LOlh4CSwMbXM31GNFkhapTq0ut7VqUcMS2y5966NiLuSTgOXgBXgQkRckXQW2IqIjclnvybpKvC/wB9GxI+6+nUwLLllH8xFxCawOfXec7W/A/j4pM3EwShIDkWEgatrzRr5ToRm0/zUVrNmI8iFg1GaoXfK6oJ6/slwMGwi3azccwzLTvtZKT+1tc7BKEj3nQjTbccIcuFgWFq1itmsORiFGbqIkNnqnwbnYFgl4RVxzzHMGowgFw6GpeVaKctODkWE4HvXmjXynQjNpvlOhGZ7eY5hWWrfJxM+tTXZmhbnYFhivtu5Zab7jFSanbU6lEqyqgfiYBQmjyLC/JPhYFhaPitlORq8iDCTbejjYFgl4eOMPWKYNfAcw6zBCHLhYJQklyJCzzHMpniOYdYklnu38/3iYFhyI8iFg1GaLIoIR5AMB8OSCmB36I2YgYNRkByKCMEjhmUojyLCdOtalINhafn5GJajoS+uBb4ToY1JyjsR+sq32V4jOJJyMCw1X/m2zORQROg5hlkLzzHMpo3kN98Hht4AK09MKmxnbX0krUu6Jmlb0pmO5X5dUkg61tenR4zCDF1EuOw5hqQV4BzwfmAHuCxpIyKuTi33RuBjwAuz9OsRw5Jb8ohxHNiOiOsRcQe4CJxoWO4TwCeBV2fZRgejIFJzA6qhpKntg5izAauStmrt2Vp3B4Ebtdc7k/deI+ldwKGI+PtZt9GHUoVpLSJMZbFaqVsR0TsvaCLpAPAXwAfn+Z6DYckteSC6CRyqvV6bvHfPG4G3A99UNTz+HLAh6emI2Grr1MEozPBFhEu/2/ll4Iikw1SBOAl84LX1RdwGVu+9lvRN4A+6QgGeY9g9amn7YIE5RntfEXeB08Al4N+Ar0bEFUlnJT296DZ6xLDkll0rFRGbwObUe8+1LPv4LH06GJbcGK58OxgFyaKIMPzUVrNGI8iFg2HpubrWrIFHDMtOHkWE+SfDwbDkRpALB6MkUtcN11LtreE5htkeI/kFn4NhSXmOYVlqLSJMecO1/HPhYFh6vq+UWYP8Y+FgFCWLWik8YpjtFb4ToVkjjxhmDUaQCwfD0gpf+bYcDV1ECJ5jWIbaz0r5qa11DkZBuosIE22Ea6XM9qpuiZN/MhwMS85zDMtOHkWE+SfDwbDkRpALB8PScq2UZSeHIkKA3aE3YAYOhqU143P1huZgWHIjyIWDYWl5jmHWIv9YOBjFyaOIMP9oOBiFGbqIsDqUSrKqB+JgFCSfIsL8k+FgWHIjyIWDUZqhn9qayzb0cTCskmju7TmGWSNf+TZrNIJcOBglyaeIMP9kOBiWVPg332bNxjDHODD0Blh57o0as7Y+ktYlXZO0LelMw+cfl3RV0ouS/knSL/T16WAUZpEdb9l2I+ZqXSStAOeAJ4GjwClJR6cW+w5wLCJ+Gfg68Km+bXQwbEItbbligdbjOLAdEdcj4g5wEThx3zojvhERr0xePg+s9XXqOUZhhi4ihKXPMQ4CN2qvd4BHO5Z/BviHvk4djILkU0Q497dWJW3VXp+PiPPzdiLpt4BjwHv6lnUwLLGFrnzfiohjLZ/dBA7VXq9N3ruPpCeAPwbeExH/3bdCB6MwQ19cqx5nvNQuLwNHJB2mCsRJ4AP1BSS9E/gCsB4RL83SqYNhlZR3IlxiOCPirqTTwCVgBbgQEVcknQW2ImID+HPgDcDXVE2yfhART3f162BYcss+RRwRm8Dm1HvP1f5+Yt4+HQxLbgxXvh2MguRQRBh+aqtZMz8fw6zBCI6kHAxLz3MMy87Q++Q+XMfYFw6GTaSalfs335aZ7jNSCYsIk61pcQ5GYfIoIsw/Gg6GJeU5hmVp6CJC8IhhY5K0iDB/DoYl5xHDrMEIcuFglCSfIsL8k+FgWHIjyIWDYamFq2vNmnjEsOwMvVNWF/jyT4aDYRPpZuUjyIWDUZJ8igjzT4aDUZg8iggTresBOBiWlOcYlqU8igiH3oJ+DoZVUhYRjiAZDoYll38sHAxLLOh/SlIOHIyC5FBE6LNSZi08xzBrMIJcOBiWVvXAyfyT4WAUJof/rX2XEBuRlEWE+SfDwShI91NbE+2sPitltpfnGGYtPMew7AxfROi7nduYJC0iTLeuRTkYllTgs1JmjXaH3oAZOBgFyaeI0COG2R4jyIWDYWmNZY5xYOgNsPLsztn6SFqXdE3StqQzDZ//pKSvTD5/QdIv9vXpYBQmYm9Lvw0xV+siaQU4BzwJHAVOSTo6tdgzwMsR8Vbg08An+7bRwbAJtbTlawpnV+txHNiOiOsRcQe4CJyYWuYE8FeTv78OvE/qPg3ROceIiKHPYdjrzyVgdc7vPCJpq/b6fEScn/x9ELhR+2wHeHTq+68tExF3Jd0G3gzcaluhJ9+WVESsD70Ns/ChlI3dTeBQ7fXa5L3GZSQ9BLwJ+FFXpw6Gjd1l4Iikw5IeBk4CG1PLbAC/M/n7N4B/jp5ZvQ+lbNQmc4bTVHOXFeBCRFyRdBbYiogN4C+BL0vaBn5MFZ5OGsPFFrPUfChl1sDBMGvgYJg1cDDMGjgYZg0cDLMGDoZZg/8Dc9sBxE3CRfsAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAMYAAAEYCAYAAAAH2Im2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAL8UlEQVR4nO3dX6hd6V3G8e+TTMcBWys0iJJEHWgKBltoCZliLzrQVs7MxeRCkUkRbRk6N42IVSGijBKvqqAgxD8RQ7WgY+2FHDASQVsK0hlySmEw0cghQpNYHNOOuRnGMZ6fF3tn2LPP2nuffbrz7rWc7ycsOGutd797XeThXb/1rr1WqgpJb3Zg3Qcg9ZHBkDoYDKmDwZA6GAypg8GQOhgMDV6Si0leTvJPM/Ynye8l2U7yUpIPLOrTYOj/g88BG3P2PwEcGy/PAn+wqEODocGrqq8A357T5BTwZzXyAvC9SX5gXp8PzduZxGnxt7iqyir72/jgu+vO3VeX+szX/uWbV4HXJjZdqKoLS3RxGLg5sX5rvO2bsz4wNxjSqt25+ypbFz+11GfyY+deq6oTD+iQOnkqpbeC28DRifUj420zGQy1VUDVcst3bhP4mfHVqQ8Cd6tq5mkUeCqldVhx5ZrkL4DHgUNJbgG/DrwNoKr+ELgEPAlsA68Cn1zUp8FQeyv+qUNVnV6wv4BPL9Onp1JSB0cMNbayuuGBMhhqr/+5MBhq7P5VqZ4zGGqv/7kwGFqH/ifDYKi9/ufCYGgNrDGkDv3PhcFQYwO5KuXMt9TBEUONOfMtdet/LgyG1mAAI4Y1htTBEUPtDWDEMBhqq7DGkDo5Ykgd+p8Lg6F16H8yDIba638uDIZac+Zb2s2rUtIs/U+GwVB7/c+FwdAaWGNIHfqfC4OhNRjAiOHdtVIHRwy1NZDffBsMtdf/XBgMtTaMmW9rDKmDI4baG8CIYTDUXv9zYTDUmFelpBn6nwuDoXXofzIMhtrrfy4MhtbAGkPq0P9cGAw1Vs58S00k2UhyPcl2krMd+38wyZeSfD3JS0meXNSnwVBzVbXUMk+Sg8B54AngOHA6yfGpZr8GfKGq3g88Dfz+omM0GGru/tnUXpcFTgLbVXWjql4HngdOTX8l8D3jv98J/PuiTq0x1NyiUWBJh4GbE+u3gMem2vwG8HdJfg74buCjizp1xFBTtY8FOJRka2J5dsmvPQ18rqqOAE8Cn08y9/++I4baqn2NGHeq6sSMfbeBoxPrR8bbJj0DbABU1VeTPAIcAl6e9YWOGGpup5ZbFrgCHEvyaJKHGRXXm1NtvgF8BCDJjwCPAP85r1NHDDW3yhKjqu4lOQNcBg4CF6vqapJzwFZVbQK/CPxxkl9gdHb2iVowbBkMNTW663y1E3xVdQm4NLXtuYm/rwEfWqZPg6Hm+j/vbTDUXLEzgFtCDIbaGsatUgZDbT2IGuNBMBhqrv+xMBhaA2sMacpAHhJiMNTeEGoMbwmROjhiqC0v10rddgZwXcpgqCmLb6nT4t9x94HBUHMDyIXBUHtljSG9WbGnX+WtncFQW/v7zXdzBkPNDSAXBkPtOWJIUwrYWfdB7IHBUHOOGFKHAeTCYKixPTzBvA8MhppyHkOawZlvqcMAzqQMhtqzxpCmWGNIM1hjSNP8zbfUzRpD6jCAXBgMtVW+BkDq1v9YGAytgTWGNM2rUtJuowm+/ifDYKi5/sfCYGgNrDGkDgPIhcFQW85jSF28KiV1G8Ldtb5qTM1VLbcskmQjyfUk20nOzmjzU0muJbma5M8X9emIoaZWPY+R5CBwHvgYcAu4kmSzqq5NtDkG/Arwoap6Jcn3LerXEUPNrXjEOAlsV9WNqnodeB44NdXmU8D5qnpl9P318qJODYaaqyX/AYeSbE0sz050dxi4ObF+a7xt0nuA9yT5xyQvJNlYdIyeSqm5fZxJ3amqE9/BVz4EHAMeB44AX0ny3qr6r3kfkJqp1b8f4zZwdGL9yHjbpFvAi1X1P8C/JflXRkG5MqtTT6XU3E4ttyxwBTiW5NEkDwNPA5tTbf6a0WhBkkOMTq1uzOvUEUONrfbZtVV1L8kZ4DJwELhYVVeTnAO2qmpzvO/Hk1wD/hf45ar61rx+DYaaW/X0XlVdAi5NbXtu4u8CPjNe9sRgqKnCu2ulTj6JUJrmW1ulbgPIhcFQW8Uw7q41GGrOGkPqYI0hdRhALgyG2pq4Y7bXDIba2tv9T2tnMNScNYbUYQC5MBhqy3ulpBn6HwuDoTXwSYTSNJ9EKO1mjSHN0P9YGAw159POpV1Gp1LrPorFDIaas8aQpnlVSuq2M4Dy22CoKWsMaQZrDKnDAHJhMNSeNYY0xRpD6lKrfdr5g2Iw1NwAcmEw1J4jhjSlgJ11H8QeGAw154ghdRhALgyGGvP9GNJuhU8ilDr57FqpwwDOpAyGWnPmW9rFGkOawRpDmjaQ33wfWPcB6K2nxnfY7nVZJMlGkutJtpOcndPuJ5JUkhOL+nTEUFOrrjGSHATOAx8DbgFXkmxW1bWpdu8Afh54cS/9OmKouRWPGCeB7aq6UVWvA88Dpzra/SbwWeC1vRyjwVBzteQCHEqyNbE8O9HdYeDmxPqt8bY3JPkAcLSq/mavx+iplNra371Sd6pqYV3QJckB4HeATyzzOYOh5lZ8Veo2cHRi/ch4233vAH4U+HISgO8HNpM8VVVbszo1GGqqVv+08yvAsSSPMgrE08DH3/i+qrvAofvrSb4M/NK8UIA1htZgHzXG7L6q7gFngMvAPwNfqKqrSc4leWq/x+iIoeZWfa9UVV0CLk1te25G28f30qfBUHNDmPk2GGqqyre2Sp0GkAuDofa8u1bq4IghTRndRNj/ZBgMNTeAXBgMtVbWGNIuA/kFn8FQU9YY0gwDyIXBUHs+V0rq0P9YGAw1Nno5Zf+jYTDUVvkkQqmTI4bUYQC5MBhqq5z5lrpZY0gdrDGkad4rJe02eiRO/5NhMNScNYbUwRpD6jCAXBgMteW9UtIMO+s+gD0wGGprj+/VWzeDoeYGkAuDobasMaQZ+h8Lg6E18Ckh0pTRqdS6j2Ixg6G29vfW1uYMhpobQC4MhtrbGUD5bTDUlDWG1MmZb6nTAHJhMNSeNYY0pfzNt9RtCDXGgXUfgN567o8ae10WSbKR5HqS7SRnO/Z/Jsm1JC8l+fskP7SoT4Oh5naqllrmSXIQOA88ARwHTic5PtXs68CJqnof8EXgtxYdo8FQU7WPZYGTwHZV3aiq14HngVNv+s6qL1XVq+PVF4Ajizq1xlBzK64xDgM3J9ZvAY/Naf8M8LeLOjUYamt/V6UOJdmaWL9QVReW7STJTwMngA8vamsw1Ni+Zr7vVNWJGftuA0cn1o+Mt71Jko8Cvwp8uKr+e9EXGgw1NXqd8Uq7vAIcS/Ioo0A8DXx8skGS9wN/BGxU1ct76dRgqLlVPru2qu4lOQNcBg4CF6vqapJzwFZVbQK/Dbwd+KskAN+oqqfm9Zt5w1qS/s/E6IGqqqyyv7c/8rZ639F3LfWZr27/x9fmnEo9EI4Yam4IM98GQ02Vb22Vuvl+DKnDAM6kDIbas8aQpjyAeYwHwmCoMX/zLXXqfywMhlrzSYTSbtYY0gyOGFKH/sfCYGgNHDGkDgPIhcFQW6ObCPufDIOh5gaQC4Oh1sq7a6UujhjSlNEEX/+TYTDU3AByYTDUnjWGNM33Y0i7WWNIMwwgFwZD7XmvlNSh/7EwGGqsWPyWpD4wGGrLq1JSN2sMqcMAcmEw1NbohZP9T4bBUHM+JUTqYI0hTfOqlLSbNYY0gzWGtItPO5c6DSAXBkNtFV6VkjrtrPsA9sBgqC3fjyF1G0AuDIbaGkqNcWDdB6C3np0ll0WSbCS5nmQ7ydmO/d+V5C/H+19M8sOL+jQYaq6qllrmSXIQOA88ARwHTic5PtXsGeCVqno38LvAZxcdo8FQc1XLLQucBLar6kZVvQ48D5yaanMK+NPx318EPpIk8zqdW2NU1dwPS/twGTi05GceSbI1sX6hqi6M/z4M3JzYdwt4bOrzb7SpqntJ7gLvAu7M+kKLbzVVVRvrPoa98FRKQ3cbODqxfmS8rbNNkoeAdwLfmtepwdDQXQGOJXk0ycPA08DmVJtN4GfHf/8k8A+1oKr3VEqDNq4ZzjCqXQ4CF6vqapJzwFZVbQJ/Anw+yTbwbUbhmStDmGyRWvNUSupgMKQOBkPqYDCkDgZD6mAwpA4GQ+rwfyuALG79RA/SAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ranks = []\n",
    "ranks_B = []\n",
    "ids_1 = []\n",
    "ids_2 = []\n",
    "noise_1 = 0.00\n",
    "noise_2 = 0.00\n",
    "noise_3 = 0.00\n",
    "for expert_1 in [1]:\n",
    "    for expert_2 in [2]:\n",
    "        for expert_3 in [0]:\n",
    "            Ts_1 = (1-noise_1)*Ts[expert_1] + noise_1*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            Ts_2 = (1-noise_2)*Ts[expert_2] + noise_2*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            Ts_3 = (1-noise_3)*Ts[expert_3] + noise_3*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            identity = np.array([np.eye(n_states) for a in range(n)]).transpose(1,0,2)\n",
    "            matrix_1 = (identity - discount*Ts_1).reshape(n_states*n_actions, -1) \n",
    "            matrix_2 = (identity - discount*Ts_2).reshape(n_states*n_actions, -1)\n",
    "            matrix_3 = (identity - discount*Ts_3).reshape(n_states*n_actions, -1)\n",
    "            zer = np.zeros_like(matrix_1)\n",
    "            #print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "            matrix = np.hstack([matrix_1, - matrix_2])\n",
    "            matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "            ranks.append(np.linalg.matrix_rank(matrix))\n",
    "            ranks_B.append(np.linalg.matrix_rank(matrix_B))\n",
    "            print(ranks[-1])\n",
    "            print(ranks_B[-1])\n",
    "            print(ranks_B[-1] - n_states)\n",
    "            ids_1.append(expert_1)\n",
    "            ids_2.append(expert_2)\n",
    "            soft_optimal_policy_1, _ = soft_value_iteration(n_states, n_actions, Ts_1, reward, discount,threshold=1e-5,temp=1e5)\n",
    "            #reward_2 = generate_random_reward(n_s, n_a)\n",
    "            soft_optimal_policy_2, _ = soft_value_iteration(n_states, n_actions, Ts_2, reward, discount,threshold=1e-5,temp=1e5)\n",
    "            b = 1/1e5*np.log(soft_optimal_policy_1.reshape(n_states*n_actions, -1)) - 1/1e5*np.log(soft_optimal_policy_2.reshape(n_states*n_actions, -1))\n",
    "            v = np.linalg.solve(matrix.T@matrix,matrix.T@b)\n",
    "            v_1 = v[:n_states]\n",
    "            v_2 = v[n_states:]\n",
    "            reward_recovered_1 = 1/1e5*np.log(soft_optimal_policy_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "            reward_recovered_2 = 1/1e5*np.log(soft_optimal_policy_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "            \n",
    "            limit_max= max(np.max(reward_recovered_1),np.max(reward_recovered_2),np.max(reward))\n",
    "            limit_min= min(np.min(reward_recovered_1),np.min(reward_recovered_2),np.min(reward))\n",
    "            limit_abs = max(-limit_min, limit_max)\n",
    "            plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/Strebulaev_recovered_1\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1),\"figs/Strebulaev_recovered_2\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/Strebulaev_true\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1) - np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/Strebulaev_difference_1\",2*limit_abs,-2*limit_abs,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1) - np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/Strebulaev_difference_2\",2*limit_abs,-2*limit_abs,color=\"copper\")\n",
    "            \n",
    "            #RECOVERY TEST\n",
    "            soft_optimal_policy_3, _ = soft_value_iteration(n_states, n_actions, Ts_3, reward, discount,threshold=1e-5,temp=1e5)\n",
    "            predicted_policy_3, _ = soft_value_iteration(n_states, n_actions, Ts_3, reward_recovered_2.reshape(n_states,n_actions), discount,threshold=1e-5,temp=1e5)\n",
    "            \n",
    "            \n",
    "            plot_reward(np.repeat(soft_optimal_policy_3,10,axis=1),\"figs/Strebulaev_expert\",1,0,color=\"copper\")\n",
    "            plot_reward(np.repeat(predicted_policy_3,10,axis=1),\"figs/Strebulaev_recovered_expert\",1,0,color=\"copper\")\n",
    "            plot_reward(np.repeat(soft_optimal_policy_3 - predicted_policy_3,10,axis=1),\"figs/Strebulaev_difference_expert\",1,0,color=\"copper\")\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Identifiability with linear features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "803 2|S| + d for identification\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Check rank with feature matrix\n",
    "ranks = []\n",
    "ranks_B = []\n",
    "ranks_C = []\n",
    "ids_1 = []\n",
    "ids_2 = []\n",
    "noise_1 = 0.00\n",
    "noise_2 = 0.00\n",
    "noise_3 = 0.00\n",
    "for expert_1 in [1]:\n",
    "    for expert_2 in [2]:\n",
    "        for expert_3 in [0]:\n",
    "            \n",
    "            feat_matrix = feat_cube.reshape(n_states*n_actions, -1)\n",
    "            \n",
    "            Ts_1 = (1-noise_1)*Ts[expert_1] + noise_1*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            Ts_2 = (1-noise_2)*Ts[expert_2] + noise_2*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            Ts_3 = (1-noise_3)*Ts[expert_3] + noise_3*generate_random_transition(n**2, n).reshape(n**2,n,n**2)\n",
    "            identity = np.array([np.eye(n_states) for a in range(n)]).transpose(1,0,2)\n",
    "            \n",
    "            matrix_1 = (identity - discount*Ts_1).reshape(n_states*n_actions, -1) \n",
    "            matrix_2 = (identity - discount*Ts_2).reshape(n_states*n_actions, -1)\n",
    "            matrix_3 = (identity - discount*Ts_3).reshape(n_states*n_actions, -1)\n",
    "            zer = np.zeros_like(matrix_1)\n",
    "            zer2 = np.zeros_like(feat_matrix)\n",
    "            #print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "            matrix = np.hstack([matrix_1, - matrix_2])\n",
    "            matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "            matrix_C = np.vstack([np.hstack([matrix_1, - matrix_2, zer2]), np.hstack([matrix_1, zer, feat_matrix])])\n",
    "            ranks.append(np.linalg.matrix_rank(matrix))\n",
    "            ranks_B.append(np.linalg.matrix_rank(matrix_B))\n",
    "            ranks_C.append(np.linalg.matrix_rank(matrix_C))\n",
    "            print(ranks_C[-1], \"2|S| + d for identification\")\n",
    "            ids_1.append(expert_1)\n",
    "            ids_2.append(expert_2)\n",
    "            soft_optimal_policy_1, _ = soft_value_iteration(n_states, n_actions, Ts_1, reward, discount,threshold=1e-10,temp=1e0)\n",
    "            #reward_2 = generate_random_reward(n_s, n_a)\n",
    "            soft_optimal_policy_2, _ = soft_value_iteration(n_states, n_actions, Ts_2, reward, discount,threshold=1e-10,temp=1e0)\n",
    "            b = 1/1e0*np.log(soft_optimal_policy_1.reshape(n_states*n_actions, -1)) - 1/1e0*np.log(soft_optimal_policy_2.reshape(n_states*n_actions, -1))\n",
    "            b = np.vstack([b, 1/1e0*np.log(soft_optimal_policy_1.reshape(n_states*n_actions, -1))])\n",
    "            v = np.linalg.solve(matrix_C.T@matrix_C,matrix_C.T@b)\n",
    "            v_1 = v[:n_states]\n",
    "            v_2 = v[n_states:-feat_matrix.shape[1]]\n",
    "            recovered_weights = v[-feat_matrix.shape[1]:]\n",
    "            reward_recovered_1 = 1/1e0*np.log(soft_optimal_policy_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "            reward_recovered_2 = 1/1e0*np.log(soft_optimal_policy_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "            limit_max= max(np.max(reward_recovered_1),np.max(reward_recovered_2),np.max(reward))\n",
    "            limit_min= min(np.min(reward_recovered_1),np.min(reward_recovered_2),np.min(reward))\n",
    "            limit_abs = max(-limit_min, limit_max)\n",
    "            plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/linStrebulaev_recovered_1\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1),\"figs/linStrebulaev_recovered_2\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/linStrebulaev_true\",limit_max,limit_min,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1) - np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/linStrebulaev_difference_1\",2*limit_abs,-2*limit_abs,color=\"copper\")\n",
    "            plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1) - np.repeat(reward.reshape(n_states,n_actions),10,axis=1),\"figs/linStrebulaev_difference_2\",2*limit_abs,-2*limit_abs,color=\"copper\")\n",
    "            \n",
    "            #RECOVERY TEST\n",
    "            soft_optimal_policy_3, _ = soft_value_iteration(n_states, n_actions, Ts_3, reward, discount,threshold=1e-5,temp=1e5)\n",
    "            predicted_policy_3, _ = soft_value_iteration(n_states, n_actions, Ts_3, reward_recovered_2.reshape(n_states,n_actions), discount,threshold=1e-5,temp=1e5)\n",
    "            \n",
    "            \n",
    "            plot_reward(np.repeat(soft_optimal_policy_3,10,axis=1),\"figs/linStrebulaev_expert\",1,0,color=\"copper\")\n",
    "            plot_reward(np.repeat(predicted_policy_3,10,axis=1),\"figs/linStrebulaev_recovered_expert\",1,0,color=\"copper\")\n",
    "            plot_reward(np.repeat(soft_optimal_policy_3 - predicted_policy_3,10,axis=1),\"figs/linStrebulaev_difference_expert\",1,0,color=\"copper\")\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 1.00350993],\n",
       "       [ 0.99855898],\n",
       "       [-1.00343152]])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "recovered_weights"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GridWorlds experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100\n",
      "100\n",
      "100\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import sys\n",
    "import copy\n",
    "import matplotlib.pyplot as plt\n",
    "sys.path.insert(0, 'src/')\n",
    "\n",
    "from optimizers import *\n",
    "from agent import Agent\n",
    "from environment import *\n",
    "from IRLalgorithms import IRLsolver\n",
    "from MDPsolver import MDPsolver\n",
    "np.random.seed(0)\n",
    "mode =2\n",
    "dim=10\n",
    "noise_1 = 0.4\n",
    "noise_2 = 0.2\n",
    "noise_3 = 0.3\n",
    "discount_1=0.9\n",
    "discount_2=0.9\n",
    "discount_3=0.9\n",
    "gridworld_1 = GridWorldEnvironment(mode, dim,prop=noise_1, gamma=discount_1,action_penalty=True)\n",
    "solver_1 = MDPsolver(gridworld_1)\n",
    "gridworld_2 = GridWorldEnvironment(mode, dim,prop=noise_2, gamma=discount_2,action_penalty=True)\n",
    "solver_2 = MDPsolver(gridworld_2)\n",
    "gridworld_3 = GridWorldEnvironment(mode, dim,prop=noise_3, gamma=discount_3,action_penalty=True)\n",
    "solver_3 = MDPsolver(gridworld_3)\n",
    "n_actions=4\n",
    "n_states=dim**2\n",
    "\n",
    "expert_1 = solver_1.soft_value_iteration() \n",
    "expert_2 = solver_2.soft_value_iteration() \n",
    "\n",
    "T_1, T_2, T_3 = gridworld_1.T.transpose(1,0,2), gridworld_2.T.transpose(1,0,2), gridworld_3.T.transpose(1,0,2)\n",
    "\n",
    "identity = np.array([np.eye(n_states) for a in range(n_actions)]).transpose(1,0,2)\n",
    "matrix_1 = (identity - discount_1*T_1).reshape(n_states*n_actions, -1) \n",
    "matrix_2 = (identity - discount_2*T_2).reshape(n_states*n_actions, -1)\n",
    "matrix_3 = (identity - discount_3*T_3).reshape(n_states*n_actions, -1)\n",
    "\n",
    "zer = np.zeros_like(matrix_1)\n",
    "#print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "matrix = np.hstack([matrix_1, - matrix_2])\n",
    "#matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "#rank_A = np.linalg.matrix_rank(matrix)\n",
    "#rank_B = np.linalg.matrix_rank(matrix_B)\n",
    "\n",
    "b = np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_2.reshape(n_states*n_actions, -1))\n",
    "v = np.linalg.solve(matrix.T@matrix,matrix.T@b)\n",
    "v_1 = v[:n_states]\n",
    "v_2 = v[n_states:]\n",
    "\n",
    "reward_recovered_1 = np.log(expert_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "reward_recovered_2 = np.log(expert_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "true_reward = gridworld_1.r\n",
    "\n",
    "limit_max= max(np.max(reward_recovered_1),np.max(reward_recovered_2),np.max(true_reward))\n",
    "limit_min= min(np.min(reward_recovered_1),np.min(reward_recovered_2),np.min(true_reward))\n",
    "plot_state_only_reward(reward_recovered_1.reshape(n_states,n_actions),\"Gridworld_recovered_1\",limit_max,limit_min)\n",
    "plot_state_only_reward(reward_recovered_2.reshape(n_states,n_actions),\"Gridworld_recovered_2\",limit_max,limit_min)\n",
    "plot_state_only_reward(true_reward.reshape(n_states,n_actions),\"Gridworld_true\",limit_max,limit_min)\n",
    "plot_state_only_reward(reward_recovered_1.reshape(n_states,n_actions) - true_reward.reshape(n_states,n_actions),\"Gridworld_difference_1\",limit_max,limit_min)\n",
    "plot_state_only_reward(reward_recovered_2.reshape(n_states,n_actions) - true_reward.reshape(n_states,n_actions),\"Gridworld_difference_2\",limit_max,limit_min)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAL0AAAEYCAYAAAAJcffZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAS1klEQVR4nO3df4xl5V3H8fd3ZtgFg+yGbElhIWENCxEoUqmAqEGKwELbrGg1a2wobYRYfsSfqSBRo+km2BINlorWuokYdcUfCCmLCBrT1LABSmnL8qNOixEoVjch22Vm7rn33PP1j3MuTOGcMztn7nnu3PN8XuRmZ+6dOc8zy2fPfM+55zxfc3dEYjIz6QmIhKbQS3QUeomOQi/RUeglOnO1r+7/nTCndgZDSFLI2h7O83GStOVxgCyDJKU/GLY/FrDho39m49zejgtP84OHFlf9fV96/tWH3X3HOOcybvWhl2gdPLTIk3uuW/X32UW/t6WF6YzV+gi9A+7FBy2PU/5JS+M5HmIcWZX60If6/+VeBD/EOMVAASqpN4aTdWV97OlDUxBX9sZv3+6JM/RyZLqZeYVeanR0T6/z9BId7emlQnePwhV6qdbNzCv0UkFnbyRK3cy8Qi91upl6hV6qdTPzCr3UUE0v0elm5hV6qdDhszd6R1aioz29VNA7shKjbmZeoZcaHd3Tq6aXoMxsh5m9YGbzZnbLJOag0Es199U/apjZLPAZ4ErgTODnzOzMAD/Jd1HopZw3fNQ7H5h392+6ex/YC+xsYfa1VNNLtWY1/RYze3LZ5591988WH28FXlr22svABQ1n15hCL9WaHccedPf3jHkmY6XQS42xn715BThl2ecnF88FpZpeqo2/pn8C2G5m28xsA7ALeKCNqdfRnl4qjP8dWXdPzewm4GFgFtjj7gfGOsgRUOglKHffB+yb5BwUeikXYpnFCVHopUY3U6/QS7VuZl6hlxodveBMoZdq3cy8Qi81otzTLybtz8Apek4N2v9LdiAZkPXb7zmVDp2FJKWXhuk5dWKQUbqhNvSPPPxMkEksDVIWkpSs5UZrjrOYpCz209b/fQ3deb03oBeo0drtN495gx2+Mbw29H+zfz7IJIKF3p3FfkdD38ZGu5n5+tCnWRZkElnmDIcZw5aT6A5p5qSZ4y2PNcy8eIT5Oxy/7t4YrgvOJDq1e/oZG2s/3kpmlj9aH8kxIx+n5Z9txvJHiJ+qNR3d09eG/urztgWZRJIOOdwbtF7TAywkg2A1/UJvQBLo7E0rupn5+tDvvPKcMLMYDKEX4JQlQDIgCRH6LD9luTRo//RoK2I9e8Nxx4SZRT+FDXMBztM7bJxjYxIgiJnzPdrTr0t6R1ZqdDP1Cr1U62bmFXqpEWVNL3HrZuYVeqlwBMv0TSu9IyvR0Z5eKrV9fdKkKPRSqaOZV+ilWlf39KrpJTra00upDq/1pNBLBe9ueaPQS6UAV3pPhGp6qTTmllMrMrNPmdnzZvZVM7vPzDYve+3WojnbC2Z2xVrGUeilVH45va/6sUaPAGe7+znA14FbAYpmbLuAs4AdwB8XTdsaUeil0vh7Mqwwnvu/uPvoZof95J1KIG/GttfdE3d/EZgnb9rWiGp6qeBkkz2Q/Sjwt8XHW8n/EYy8XDzXiEIv5ZrX6HXdBTGzR4F3lnzfbe5+f/E1twEp8FeNZrCC+tC/8lobY75dOiQNdmN4vthT29IsYyFJSQIt9vTuMW9vVNM3UNtd0N1/ou6bzexa4P3Apf7mBMbaoK029Hd//stNt7sqyaBYDSHAYk+L/ZTFJMVbfusl9I3hf/9b499m6OLGzHYAHwcudvfFZS89APy1mf0BcBKwHXi86Ti1oX9s/ttNt7sqyWDI671BkBXO3lzWL0zoe9O6GgJMoqa/C9gIPGL5ukT73f0X3f2Amd0LPEte9tzo7o1/haqml1KTWAHE3U+reW03sHsc4yj0UinKyxCOO3pDkEkkc0PMrPUD2QxnbsaYm7HW32LP3JmdMY6andK3Qrp7t2B96G++7Owgkxgt1T0MtFT3QoDFnjJ3DvcGwc7etCHr6HWWtaE/40e2h5lFqGX93PPV1AKtcDZIwq1PP24dXtVvhZo+1K/mYZaPFSL0szNhfi5z5mZmOGp2WpPT/hr+k6IDWanU0cwr9FKt7TfwJkWhl1JOd28iUeilnG4XlBh1NPMKvVTTnl6i4sC0NgNdiUIvlbq6p5/SC0NEmtOeXip1dEev0EuF8SzpsS4p9FJKb05JlHQZgkSno9WNQi/VVNNLVFTTS5TirOmD/noLNFaoH2naS4NYbwx/7SsvBZnE6Mbw1ldDcGepWOwpxGoIr/fC3SP7wRa2GWVN/6l9TweZxNJgyEIyCLAaAsVqCINWxwHIMudwEm41hA9+evzb7Gjm60P/8msLQSahZf3WH5/8Ut2t0YGsVOpm5BV6qRFlTX/GOzcHmUToFc7y8qbVoYLX9GMX69mb33j/uUEm0esXB7IdqumzrFjWL53O0OdvTk0m9Wb2a8AdwDvc/aDl63bfCVwFLALXuvtTTbdfG/q5M05sut1VObafcmySdm5ZP5/i0MNkanozOwW4HPjvZU9fSd6IYTtwAXB38WcjunNKKk2gpSbAH5J3I1m+sZ3APZ7bD2w2s8Z7ZB3ISqU2Gq3VMbOdwCvu/pWiE8nIVmD5O6Wj7oKvNpmgQi+l1nCevrbRWl13QeA3yUubVin0Uq6lszdV3QXN7F3ANmC0lz8ZeMrMzmfM3QVV00slb/Bf47Hcv+buJ7j7qe5+KnkJ84Pu/j/k3QWvsdyFwCF3b1TagPb0UmMdnaffR366cp78lOVH1rIxhV5KTfI8PUCxtx997MCN49q2yhuJjvb0UmkdlTdjpdBLpThvFwxwswWQdxdMQnQXJL8MoR/gkocsv7htKdAFZ0e3sM0o9/SP/dtzQSbR62Af2WFxu2Coqyxvu2G82/NYO5Hs+cLzQSbRC3TnFMBCMmAxSVv/xZ1lzusBLy2+rYVtRrkESKgrBPvpkH46DHJpcT/N6A+zILcL9tNsiq+y1AKuEqFuRl6hlwpOpDW9xC3Kml4iFuvZG4lbRzOv0Es5J9Z3ZCVqquklOqrpJTodzbxCL+XWevvfeqbQSzlXTS8RUk0v0elo5hV6KadrbyRK3Yy8Qi811H5H4hJrUwaJV7Q1/eVnnxxkEkuhO5EkATqReNGJZFrb7xBpTf+h950bZhaDIfQCLAECJMmAxaT9IKZZxkKSTnXou6q+vNnyvWFmMWqJE6D9zsZ+ysZA7Xe2THX7ne72kdVallIqr+lX/1grM7vZzJ43swNm9sllz99qZvNm9oKZXbGWMXQgK5VCH8ia2SXk/aV+wN0TMzuheP5MYBdwFnAS8KiZne7ujX6N1of+/77TZJur1w+3rF+vOJDN2h0pX+ypN6AXqLw5c9wbnMwpy48Bt7t7AuDu/1s8vxPYWzz/opnNA+cDjzUZpDb0f/H5p5tsc9WWBvnZm6z1Zf3C9ZEdFiuc9QIdyN5zy/i3mTU7f9O40RpwOvBjZrYb6AG/7u5PkDdV27/s60aN1hqpDf2/Ptu4rc+qJIGW9Qsd+oUkpTcIcNDcglFN38BaGq3NAccDFwI/BNxrZt/XaBY1VNNLpTZ2DFWN1gDM7GPAPxadRx43swzYghqtSSgTOHvzT8AlAGZ2OrABOEjeaG2XmW00s23kncMfbzqI9vRSqWFNvxZ7gD1m9gzQBz5c7PUPmNm9wLNACtzY9MwNKPRSYQ01ffMx3fvAhype2w3sHsc4Cr2Ucy3VLRHqaOYVeqmmPb1ExaH1d60nRaGXStrTS3Q6mnmFXiqoKYPExtGyfhIhLeAq0elodaPQSxW9IyuRUU0vUVJNL3GJdVm/o4+aDTUPBsOs9XtkM/Lb+LKs/TVdMneG2XTXxdM89zq1of+Fi78/yCSW+ikLSRokiIv9lKUOroYgR6429OdfEib0wZb1c39zNbW2Zc5iktLrT++N4XEeyG4IWPJnAYrI0fZD/M/MnGMyZ8YCjNWSKMsbiVs3I6/QSxVdcCYx6mjmFXop5x1eqluhl0rdjLxCLzVU00t0Opp5hV7KuauPrESoo5lX6KValJcW95/7VpBJdLITiRcXnAXqRHJlC9sMvac3s3OBPwGOJl+d+AZ3f9zMDLgTuApYBK5196eajlMb+tsffLrpdlclGQw53Gs/9AALyaAIfbvjDN1ZSMI1T77yjvFuL7/gLPie/pPA77r7Q2Z2VfH5j5P/m95ePC4A7i7+bKQ29PPfPtR0u6ui9jvr0wRqegeOKz7eBIxKjZ3APcVa9fvNbLOZnejurzYZRDW9VPCmNf1aGq39MvCwmd1B3iXnouL5rcBLy75u1GhNoZcxan6l91oarV0K/Iq7/4OZ/Szw50Blj6qmakN/yvHHjnu8Ur2ivOnanVMLyYClQDX9uLVV06/QaO0e4JeKT/8O+Fzx8VgbrdWG/uPvO7fpdlelV9wu2H5Nn4d+MUlbPxk3LG4XTKb4dsEJ1PTfAi4G/h14L/CfxfMPADeZ2V7yA9hDTet5WCH0m845pe7lsdk0uoWvY7cL+tSHPnjqrwPuNLM58ubJ1xfP7yM/XTlPfsryI2sZRDW9VAodeXf/InBeyfMO3DiucRR6KZV3F4zwHVmJmMe6GoJErat7+plJT0AkNO3ppVJHd/QKvZTz5pchrHsKvVTSgaxEp6sHsgq9lIt1fXqJlxPp7YISN9X0Eh3V9BKdjmZeoZdyuuBMotT23WWTotBLOZ/uzoh1FHqp1NHMrxD6YYBfcO75OMMszO2Co7HaljmDYcYgxFjkS4KNU7Q1/bNf/HrrE3D3fLGnAH1kRzeGLwS4R3Z0Y3ioZf1uvn7lr1mtbkZ+hdB/5tFngkyiF3qFsyRt/d3GrFjhbClQH9mbW9hmlEt1H+4NgkxCy/qtP3l5M+lZtEMHslJOLTUlRh3NfH3of3R72ZKD49dLi/Km7fXpgcUkTHmTuXO4F26p7jZkHT2UrQ399R94d5hZDIZ4kJreWewPw4R+dCCrmn7dqS9vTtwcZhb9FEtS5gKcp9/UT9mkZf2OgN6RlQh1NPMKvVSLsqaXeHmH75HVCmeybpjZz5jZATPLzOw9b3ntVjObN7MXzOyKZc/vKJ6bN7NbjmQc7eml0gQOZJ8Bfgr40+VPmtmZwC7gLOAk4FEzO714+TPAZeR9qJ4wswfc/dm6QRR6qRQ68+7+HEDeNva77AT2unsCvGhm88D5xWvz7v7N4vv2Fl+r0EszDS84W0t3wSpbgf3LPh91F4S3dx1csb+sQi+lnMaXFjfuLuju9zcbcnUUeqnURk1f112wRl13wVV3HdTZGynnb562XM2jJQ8Au8xso5ltA7YDjwNPANvNbJuZbSA/2H1gpY1pTy8Vwl+GYGZXA58G3gE8aGZPu/sV7n7AzO4lP0BNgRvdfVh8z03Aw8AssMfdD6w0jkIvpfLmyYHHdL8PuK/itd3A7pLn95G33DxiCr1U0gKuEp2uXoag0EslXVosUXH1kZUYqaaX6HS0ulkh9IcWw8xiMIRk0P7vUwf6Kb1+2vpQWeYcTsLdGH5qC9uMsqa/76GvBplEqBXOABaSQbHCWbvyG8MHLPXDhP6uXx3v9iZxnj6U2tDf/9R/BZnEUrG+ZJjVENJgoQ+5BMhdY99ipDeGh1zL0AOsh/7GNSK0/6t79Hc3zQeD0zvzejqQlXKxLus3NxPmIszhrDM7O4MFKCLnZoy5GQPednfOWJk5czPGUbPTeSFrtDX9z1+0Pcgk8vXpAyzrN6rp+2nrp+NCn71pQ5R7+ksvPzvMLPopJGmAXYtDkuIhmjJ43pRhqkM/6Qm0pL6mP2ZDmFnMzsDMTJj2O7MzWICSYy5zNpmRHDXFoY9xTy9x62jmFXopl19w1s3UT+epBZE10J5eKnV0R6/QSxWf6neT6yj0Ukl7eolK/o5sN1Ov0EuljmZeoZdqquklLh3uRKLQSynV9BKljmZeoZdqXb3gTJchSCVv8FiLqkZrZnaZmX3JzL5W/PneZa+dVzw/b2Z/ZCW9e95KoZdSjpP56h9rNGq09oW3PH8Q+IC7vwv4MPCXy167G7iOfM367cCOlQZReSPlJnD2pqrRmrt/edmnB4BjzGwjcDxwnLvvL77vHuAngYfqxlHopVLDmr6NRmvL/TTwlLsnZraVvLnayPIGbJUUeqnUcE/fWqM1MzsL+H3g8kYzKyj0Uio/MF03jdYws5PJu5Rc4+7fKJ5+hby52ogarcnaZL76RxvMbDPwIHCLu//H6Hl3fxX4jpldWJy1uQZYsS2nQi+VRqvOreaxFmZ2tZm9DPwweaO1h4uXbgJOA37bzJ4uHicUr90AfA6YB77BCgexoPJGqkzm7E1pozV3/wTwiYrveRJY1Vo1Cr2UaqumXw8UeqkU5bJ+ErNIl+qWuHU08wq9lAuxhv+k6JSlREd7eqmUTXoCLVHopVysnUgkbh3NvEIv5bp8IKvQSyXV9BId7eklOh3NPNbVf82yNmb2z8CWBt960N1XvDl7khR6iY7ekZXoKPQSHYVeoqPQS3QUeonO/wOCVACGGTXAYAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"ActionGridworld_recovered_1\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1),\"ActionGridworld_recovered_2\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"ActionGridworld_true\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1) - np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"ActionGridworld_difference_1\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1) - np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"ActionGridworld_difference_2\",limit_max,limit_min,color=\"copper\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiment with different discount factors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True\n",
      "[[   0.  -10.  -20.  -30.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]]\n",
      "100\n",
      "True\n",
      "[[   0.  -10.  -20.  -30.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]]\n",
      "100\n",
      "True\n",
      "[[   0.  -10.  -20.  -30.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [-100. -110. -120. -130.]\n",
      " [-100. -110. -120. -130.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]\n",
      " [  -1.  -11.  -21.  -31.]]\n",
      "100\n"
     ]
    }
   ],
   "source": [
    "#Different discounts\n",
    "\n",
    "import sys\n",
    "import copy\n",
    "import matplotlib.pyplot as plt\n",
    "sys.path.insert(0, 'src/')\n",
    "\n",
    "from optimizers import *\n",
    "from agent import Agent\n",
    "from environment import *\n",
    "from IRLalgorithms import IRLsolver\n",
    "from MDPsolver import MDPsolver\n",
    "np.random.seed(0)\n",
    "mode =2\n",
    "dim=10\n",
    "noise_1 = 0.4\n",
    "noise_2 = 0.4\n",
    "noise_3 = 0.4\n",
    "discount_1=0.9\n",
    "discount_2=0.8\n",
    "discount_3=0.7\n",
    "gridworld_1 = GridWorldEnvironment(mode, dim,prop=noise_1, gamma=discount_1,action_penalty=True)\n",
    "solver_1 = MDPsolver(gridworld_1)\n",
    "gridworld_2 = GridWorldEnvironment(mode, dim,prop=noise_2, gamma=discount_2,action_penalty=True)\n",
    "solver_2 = MDPsolver(gridworld_2)\n",
    "gridworld_3 = GridWorldEnvironment(mode, dim,prop=noise_3, gamma=discount_3,action_penalty=True)\n",
    "solver_3 = MDPsolver(gridworld_3)\n",
    "n_actions=4\n",
    "n_states=dim**2\n",
    "\n",
    "expert_1 = solver_1.soft_value_iteration() \n",
    "expert_2 = solver_2.soft_value_iteration() \n",
    "\n",
    "T_1, T_2, T_3 = gridworld_1.T.transpose(1,0,2), gridworld_2.T.transpose(1,0,2), gridworld_3.T.transpose(1,0,2)\n",
    "\n",
    "identity = np.array([np.eye(n_states) for a in range(n_actions)]).transpose(1,0,2)\n",
    "matrix_1 = (identity - discount_1*T_1).reshape(n_states*n_actions, -1) \n",
    "matrix_2 = (identity - discount_2*T_2).reshape(n_states*n_actions, -1)\n",
    "matrix_3 = (identity - discount_3*T_3).reshape(n_states*n_actions, -1)\n",
    "\n",
    "zer = np.zeros_like(matrix_1)\n",
    "#print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "matrix = np.hstack([matrix_1, - matrix_2])\n",
    "#matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "#rank_A = np.linalg.matrix_rank(matrix)\n",
    "#rank_B = np.linalg.matrix_rank(matrix_B)\n",
    "\n",
    "b = np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_2.reshape(n_states*n_actions, -1))\n",
    "v = np.linalg.solve(matrix.T@matrix,matrix.T@b)\n",
    "v_1 = v[:n_states]\n",
    "v_2 = v[n_states:]\n",
    "\n",
    "reward_recovered_1 = np.log(expert_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "reward_recovered_2 = np.log(expert_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "true_reward = gridworld_1.r\n",
    "\n",
    "limit_max= max(np.max(reward_recovered_1),np.max(reward_recovered_2),np.max(true_reward))\n",
    "limit_min= min(np.min(reward_recovered_1),np.min(reward_recovered_2),np.min(true_reward))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"gammaActionGridworld_recovered_1\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1),\"gammaActionGridworld_recovered_2\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"gammaActionGridworld_true\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1) - np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"gammaActionGridworld_difference_1\",limit_max,limit_min,color=\"copper\")\n",
    "plot_reward(np.repeat(reward_recovered_2.reshape(n_states,n_actions),10,axis=1) - np.repeat(true_reward.reshape(n_states,n_actions),10,axis=1),\"gammaActionGridworld_difference_2\",limit_max,limit_min,color=\"copper\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Windy Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100\n",
      "100\n",
      "100\n",
      "1.5493982402909693e-13\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Different discounts\n",
    "mode=2\n",
    "noise=0.0\n",
    "discount_1=0.2\n",
    "discount_2=0.7\n",
    "discount_3=0.9\n",
    "wind_prob = [0.7,0.1,0.1,0.1]\n",
    "dim=5\n",
    "n_states=dim**2*4\n",
    "n_actions=4\n",
    "env_1 = WindyGrid(mode, dim,prop=noise, gamma=discount_1,wind_prob=wind_prob)\n",
    "env_2 = WindyGrid(mode, dim,prop=noise, gamma=discount_2,wind_prob=wind_prob)\n",
    "env_3 = WindyGrid(mode, dim,prop=noise, gamma=discount_3,wind_prob=wind_prob)\n",
    "\n",
    "T_1 = env_1.T.transpose(1,0,2)\n",
    "T_2 = env_2.T.transpose(1,0,2)\n",
    "T_3 = env_3.T.transpose(1,0,2)\n",
    "\n",
    "\n",
    "identity = np.array([np.eye(n_states) for a in range(n_actions)]).transpose(1,0,2)\n",
    "matrix_1 = (identity - discount_1*T_1).reshape(n_states*n_actions, -1) \n",
    "matrix_2 = (identity - discount_2*T_2).reshape(n_states*n_actions, -1)\n",
    "matrix_3 = (identity - discount_3*T_3).reshape(n_states*n_actions, -1)\n",
    "\n",
    "zer = np.zeros_like(matrix_1)\n",
    "#print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "matrix = np.hstack([matrix_1, - matrix_2])\n",
    "matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "\n",
    "rank_A = np.linalg.matrix_rank(matrix)\n",
    "rank_B = np.linalg.matrix_rank(matrix_B)\n",
    "\n",
    "ranks = np.array([rank_A, rank_B])\n",
    "\n",
    "solver_1 = MDPsolver(env_1)\n",
    "solver_2 = MDPsolver(env_2)\n",
    "solver_3 = MDPsolver(env_3)\n",
    "\n",
    "\n",
    "expert_1 = solver_1.soft_value_iteration() \n",
    "expert_2 = solver_2.soft_value_iteration() \n",
    "expert_3 = solver_3.soft_value_iteration()\n",
    "\n",
    "b = np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_2.reshape(n_states*n_actions, -1))\n",
    "\n",
    "v = np.linalg.solve(matrix.T@matrix,matrix.T@b)\n",
    "v_1 = v[:n_states]\n",
    "v_2 = v[n_states:]\n",
    "reward_recovered_1 = np.log(expert_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "reward_recovered_2 = np.log(expert_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "limit_max = max(np.max(reward_recovered_1), np.max(reward_recovered_2), np.max(env_3.r))\n",
    "limit_min = min(np.min(reward_recovered_1), np.min(reward_recovered_2), np.min(env_3.r))\n",
    "plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/gammaWindyGridworld_recovered_1\"+str(seed), limit_max,limit_min)\n",
    "plot_reward(np.repeat(env_3.r - reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/gammaWindyGridworld_difference\"+str(seed),limit_max,limit_min)\n",
    "plot_reward(np.repeat(env_3.r,10,axis=1),\"figs/gammaWindyGridworld_true\"+str(seed),limit_max,limit_min)\n",
    "\n",
    "copy_env_3 = copy.deepcopy(env_3)\n",
    "copy_env_3.r = reward_recovered_2.reshape(n_states,n_actions)\n",
    "recovered_solver_3 = MDPsolver(copy_env_3)\n",
    "\n",
    "recovered_expert_3 = recovered_solver_3.soft_value_iteration()\n",
    "\n",
    "plot_reward(np.repeat(expert_3,10,axis=1),\"figs/gammaWindyGridworld_expert\"+str(seed),1,0)\n",
    "plot_reward(np.repeat(recovered_expert_3,10,axis=1),\"figs/gammaWindyGridworld_recovered_expert\"+str(seed),1,0)\n",
    "plot_reward(np.repeat(recovered_expert_3 - expert_3,10,axis=1),\"figs/gammaWindyGridworld_difference_expert\"+str(seed),1,0)\n",
    "\n",
    "print(np.linalg.norm(expert_3 - recovered_expert_3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_ranks():\n",
    "    plt.figure()\n",
    "    #plt.style.use('seaborn')\n",
    "    plt.scatter(range(2, len(ranks)+1),- ranks[:-1] + ranks[1:] - n_states, marker=\"*\",c=\"blue\", s=200)\n",
    "    #plt.plot(n_states*np.ones(4), label=\"|S|\")\n",
    "    plt.ylabel(\"Rank difference \", fontsize=20)\n",
    "    plt.xlabel(\"Number of experts\", fontsize=20)\n",
    "    plt.xticks([2,3,4,5], fontsize=20)\n",
    "    plt.yticks([0,10,20,30], fontsize=20)\n",
    "    plt.savefig(\"figs/gen_condition\"+str(seed)+\".pdf\")\n",
    "    plt.figure()\n",
    "    #plt.style.use('seaborn')\n",
    "    plt.scatter(np.arange(2, len(ranks)+2), np.arange(2*n_states, (len(ranks)+2)*n_states, n_states) - ranks, marker=\"*\",c=\"blue\", s=200)\n",
    "    #plt.plot(n_states*np.ones(4), label=\"|S|\")\n",
    "    plt.ylabel(\"Degrees of freedom\", fontsize=20)\n",
    "    plt.xlabel(\"Number of experts\", fontsize=20)\n",
    "    plt.xticks([2,3,4,5], fontsize=20)\n",
    "    plt.yticks([0,20,40,60], fontsize=20)\n",
    "    plt.savefig(\"figs/id_condition\"+str(seed)+\".pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100\n",
      "100\n",
      "100\n",
      "100\n",
      "100\n",
      "100\n",
      "1.8170302958512434e-11\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Random wind prob\n",
    "for seed in range(1):\n",
    "    np.random.seed(seed)\n",
    "    mode=2\n",
    "    noise_1=0.0\n",
    "    noise_2=0.0\n",
    "    noise_3=0.0\n",
    "    discount_1=0.7\n",
    "    discount_2=0.7\n",
    "    discount_3=0.7\n",
    "    wind_prob_1 = np.random.randn(4) #shape[0.7,0.1,0.1,0.1]\n",
    "    wind_prob_2 = np.random.randn(4) #shape[0.1,0.7,0.1,0.1]\n",
    "    wind_prob_3 = np.random.randn(4) #shape[0.1,0.1,0.7,0.1]\n",
    "    wind_prob_4 = np.random.randn(4) #shape[0.1, 0.1, 0.1, 0.7]\n",
    "    wind_prob_5 = np.random.randn(4) #shape[0.02, 0.02, 0.94, 0.02]\n",
    "    wind_prob_6 = np.random.randn(4) #shape[0.02, 0.94, 0.02, 0.02]\n",
    "    #Normalize\n",
    "    wind_prob_1 = np.abs(wind_prob_1)/np.sum(np.abs(wind_prob_1)) #shape[0.7,0.1,0.1,0.1]\n",
    "    wind_prob_2 = np.abs(wind_prob_2)/np.sum(np.abs(wind_prob_2)) #shape[0.1,0.7,0.1,0.1]\n",
    "    wind_prob_3 = np.abs(wind_prob_3)/np.sum(np.abs(wind_prob_3)) #shape[0.1,0.1,0.7,0.1]\n",
    "    wind_prob_4 = np.abs(wind_prob_4)/np.sum(np.abs(wind_prob_4)) #shape[0.1, 0.1, 0.1, 0.7]\n",
    "    wind_prob_5 = np.abs(wind_prob_5)/np.sum(np.abs(wind_prob_5)) #shape[0.02, 0.02, 0.94, 0.02]\n",
    "    wind_prob_6 = np.abs(wind_prob_6)/np.sum(np.abs(wind_prob_6)) #shape[0.02, 0.94, 0.02, 0.02]\n",
    "    dim=5\n",
    "    n_states=dim**2*4\n",
    "    n_actions=4\n",
    "    env_1 = WindyGrid(mode, dim,prop=noise_1, gamma=discount_1,wind_prob=wind_prob_1)\n",
    "    env_2 = WindyGrid(mode, dim,prop=noise_2, gamma=discount_2,wind_prob=wind_prob_2)\n",
    "    env_3 = WindyGrid(mode, dim,prop=noise_3, gamma=discount_3,wind_prob=wind_prob_3)\n",
    "    env_4 = WindyGrid(mode, dim,prop=noise_3, gamma=discount_3,wind_prob=wind_prob_4)\n",
    "    env_5 = WindyGrid(mode, dim,prop=noise_3, gamma=discount_3,wind_prob=wind_prob_5)\n",
    "    env_6 = WindyGrid(mode, dim,prop=noise_3, gamma=discount_3,wind_prob=wind_prob_6)\n",
    "    T_1 = env_1.T.transpose(1,0,2)\n",
    "    T_2 = env_2.T.transpose(1,0,2)\n",
    "    T_3 = env_3.T.transpose(1,0,2)\n",
    "    T_4 = env_4.T.transpose(1,0,2)\n",
    "    T_5 = env_5.T.transpose(1,0,2)\n",
    "    T_6 = env_6.T.transpose(1,0,2)\n",
    "\n",
    "    identity = np.array([np.eye(n_states) for a in range(n_actions)]).transpose(1,0,2)\n",
    "    matrix_1 = (identity - discount_1*T_1).reshape(n_states*n_actions, -1) \n",
    "    matrix_2 = (identity - discount_2*T_2).reshape(n_states*n_actions, -1)\n",
    "    matrix_3 = (identity - discount_3*T_3).reshape(n_states*n_actions, -1)\n",
    "    matrix_4 = (identity - discount_3*T_4).reshape(n_states*n_actions, -1)\n",
    "    matrix_5 = (identity - discount_3*T_5).reshape(n_states*n_actions, -1)\n",
    "    matrix_6 = (identity - discount_3*T_6).reshape(n_states*n_actions, -1)\n",
    "\n",
    "    zer = np.zeros_like(matrix_1)\n",
    "    #print(identity.reshape(n_states*n_actions, -1).sum(axis=1))\n",
    "    matrix = np.hstack([matrix_1, - matrix_2])\n",
    "    matrix_B = np.vstack([np.hstack([matrix_1, - matrix_2, zer]), np.hstack([matrix_1, zer, -matrix_3])])\n",
    "    matrix_C = np.vstack([np.hstack([matrix_1, - matrix_2, zer, zer]), np.hstack([matrix_1, zer, -matrix_3, zer]), np.hstack([matrix_1, zer, zer, -matrix_4])])\n",
    "    matrix_D = np.vstack([np.hstack([matrix_1, - matrix_2, zer, zer,zer]), np.hstack([matrix_1, zer, -matrix_3, zer,zer]), np.hstack([matrix_1, zer, zer, -matrix_4,zer]),  np.hstack([matrix_1, zer, zer,zer, -matrix_5])])\n",
    "    matrix_E = np.vstack([np.hstack([matrix_1, - matrix_2, zer, zer, zer, zer]), np.hstack([matrix_1, zer, -matrix_3, zer, zer, zer]), np.hstack([matrix_1, zer, zer, -matrix_4,zer,zer]), np.hstack([matrix_1, zer, zer, zer,-matrix_5,zer]), np.hstack([matrix_1, zer, zer, zer,zer,-matrix_6])])\n",
    "\n",
    "    rank_A = np.linalg.matrix_rank(matrix)\n",
    "    rank_B = np.linalg.matrix_rank(matrix_B)\n",
    "    rank_C = np.linalg.matrix_rank(matrix_C)\n",
    "    rank_D = np.linalg.matrix_rank(matrix_D)\n",
    "    rank_E = np.linalg.matrix_rank(matrix_E)\n",
    "\n",
    "    ranks = np.array([rank_A, rank_B, rank_C, rank_D, rank_E])\n",
    "    plot_ranks()\n",
    "    solver_1 = MDPsolver(env_1)\n",
    "    solver_2 = MDPsolver(env_2)\n",
    "    solver_3 = MDPsolver(env_3)\n",
    "    solver_4 = MDPsolver(env_4)\n",
    "    expert_1 = solver_1.soft_value_iteration() \n",
    "    expert_2 = solver_2.soft_value_iteration() \n",
    "    expert_3 = solver_3.soft_value_iteration() \n",
    "    expert_4 = solver_4.soft_value_iteration() \n",
    "    \n",
    "    b = np.vstack([np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_2.reshape(n_states*n_actions, -1)),\n",
    "               np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_3.reshape(n_states*n_actions, -1)),\n",
    "               np.log(expert_1.reshape(n_states*n_actions, -1)) - np.log(expert_4.reshape(n_states*n_actions, -1))])\n",
    "    v = np.linalg.solve(matrix_C.T@matrix_C,matrix_C.T@b)\n",
    "    v_1 = v[:n_states]\n",
    "    v_2 = v[n_states:2*n_states]\n",
    "    reward_recovered_1 = np.log(expert_1.reshape(n_states*n_actions, -1)) - matrix_1@v_1\n",
    "    reward_recovered_2 = np.log(expert_2.reshape(n_states*n_actions, -1)) - matrix_2@v_2\n",
    "    limit_max = max(np.max(reward_recovered_1), np.max(reward_recovered_2), np.max(env_5.r))\n",
    "    limit_min = min(np.min(reward_recovered_1), np.min(reward_recovered_2), np.min(env_5.r))\n",
    "    plot_reward(np.repeat(reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/WindyGridworld_recovered_1\"+str(seed), limit_max,limit_min)\n",
    "    plot_reward(np.repeat(env_5.r - reward_recovered_1.reshape(n_states,n_actions),10,axis=1),\"figs/WindyGridworld_difference\"+str(seed),limit_max,limit_min)\n",
    "    plot_reward(np.repeat(env_5.r,10,axis=1),\"figs/WindyGridworld_true\"+str(seed),limit_max,limit_min)\n",
    "    \n",
    "    copy_env_5 = copy.deepcopy(env_5)\n",
    "    copy_env_5.r = reward_recovered_2.reshape(n_states,n_actions)\n",
    "    recovered_solver_5 = MDPsolver(copy_env_5)\n",
    "    solver_5 = MDPsolver(env_5)\n",
    "    \n",
    "    expert_5 = solver_5.soft_value_iteration()\n",
    "    recovered_expert_5 = recovered_solver_5.soft_value_iteration()\n",
    "    \n",
    "    plot_reward(np.repeat(expert_5,10,axis=1),\"figs/WindyGridworld_expert\"+str(seed),1,0)\n",
    "    plot_reward(np.repeat(recovered_expert_5,10,axis=1),\"figs/WindyGridworld_recovered_expert\"+str(seed),1,0)\n",
    "    plot_reward(np.repeat(recovered_expert_5 - expert_5,10,axis=1),\"figs/WindyGridworld_difference_expert\"+str(seed),1,0)\n",
    "    \n",
    "    print(np.linalg.norm(expert_5 - recovered_expert_5))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
