{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3800acbf-0fde-486e-987a-217d827bba19",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-05-14T23:02:37.121058Z",
     "iopub.status.busy": "2025-05-14T23:02:37.120523Z",
     "iopub.status.idle": "2025-05-14T23:02:37.875402Z",
     "shell.execute_reply": "2025-05-14T23:02:37.874859Z",
     "shell.execute_reply.started": "2025-05-14T23:02:37.121008Z"
    }
   },
   "outputs": [],
   "source": [
    "import math\n",
    "import random\n",
    "import numpy as np\n",
    "import time\n",
    "from IPython.display import display, clear_output\n",
    "import matplotlib.image as mpimg\n",
    "from gridworld import *\n",
    "from agent import *\n",
    "from utils import *\n",
    "from magent import *\n",
    "import pandas as pd\n",
    "from matplotlib.colors import to_rgba"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3af47de5-59d0-429c-a48b-d9ed0646480d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-05-14T23:02:37.876128Z",
     "iopub.status.busy": "2025-05-14T23:02:37.875921Z",
     "iopub.status.idle": "2025-05-14T23:02:38.031913Z",
     "shell.execute_reply": "2025-05-14T23:02:38.031370Z",
     "shell.execute_reply.started": "2025-05-14T23:02:37.876098Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1000 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "stochastic = False\n",
    "useNegativeRewards = False\n",
    "random_reset = True\n",
    "env_name = 'mdps/5rooms.mdp'\n",
    "\n",
    "env = GridWorld(path = env_name, useNegativeRewards=useNegativeRewards, stochastic=stochastic, random_reset=random_reset)\n",
    "plotPolicy(env, policy=None, plot_policy=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a318b63f-69b4-4bfb-98f6-18f3efdfc771",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-05-14T23:02:38.032836Z",
     "iopub.status.busy": "2025-05-14T23:02:38.032629Z",
     "iopub.status.idle": "2025-05-14T23:02:38.035807Z",
     "shell.execute_reply": "2025-05-14T23:02:38.035150Z",
     "shell.execute_reply.started": "2025-05-14T23:02:38.032819Z"
    }
   },
   "outputs": [],
   "source": [
    "N_AGENT = 5\n",
    "GAMMA=0.99\n",
    "TOLERACNE = 1e-3\n",
    "VERBOSE = False\n",
    "N_ITER = 200"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9aafa620-e0c5-4688-b6c4-bdaf2bb9872d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-05-14T23:02:38.036816Z",
     "iopub.status.busy": "2025-05-14T23:02:38.036613Z"
    }
   },
   "outputs": [],
   "source": [
    "agent_mop = MaxEntropyPolicy(\n",
    "    env, \n",
    "    gamma=GAMMA\n",
    ")\n",
    "\n",
    "# Train the agent\n",
    "converged = agent_mop.policy_iteration(\n",
    "    n_iterations=N_ITER,\n",
    "    tolerance=TOLERACNE,\n",
    "    verbose=VERBOSE\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53229d8c-1833-4df3-8248-880589807d62",
   "metadata": {},
   "outputs": [],
   "source": [
    "plotPolicy(env, policy=agent_mop.pi, plot_policy=True, put_start=True, with_number=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4252c8a-6334-473a-9fa9-c2fdb890d7e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "N_AGENT = 5\n",
    "GAMMA=0.99\n",
    "TOLERACNE = 1e-3\n",
    "VERBOSE = False\n",
    "N_ITER = 200\n",
    "nc = 3\n",
    "ALPHA = 0.2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e1c3547-8103-481d-9b07-a8e285d2dab2",
   "metadata": {},
   "outputs": [],
   "source": [
    "agent_mp = ValueMixtureEntropyWeightedAgent(\n",
    "    env, \n",
    "    n_components=nc,\n",
    "    gamma=GAMMA,\n",
    "    alpha=ALPHA,\n",
    ")\n",
    "\n",
    "converged = agent_mp.policy_iteration(\n",
    "    n_iterations=N_ITER,\n",
    "    tolerance=TOLERACNE,\n",
    "    verbose=VERBOSE,\n",
    "    save_history = False\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a00309f5-90a7-48f3-a6db-cce390e8fff9",
   "metadata": {},
   "source": [
    "Seeing the mixture policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d8c98bc-e882-4730-8b49-d9a01721e204",
   "metadata": {},
   "outputs": [],
   "source": [
    "plotPolicy(env, policy=agent_mp.get_full_mixture_policy(), plot_policy=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5a4f41b9-75ed-46dc-93b0-4285d4fcbd16",
   "metadata": {},
   "source": [
    "# Seeing One component only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a1b8644-eccf-4654-af36-2abd3a920654",
   "metadata": {},
   "outputs": [],
   "source": [
    "plotPolicy(env, policy=agent_mp.pi_b[0], plot_policy=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d831bda-ce44-43d7-8f50-a17272d14c4a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
