{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Gridworld LLM Planner Experiments\n",
    "\n",
    "In this notebook, we evaluate the results of the Gridworld experiments performed in a planner-actor-reporter setup. We run the experiment across $5$ random seeds. To generate the results, please refer to the README.md file."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "from pathlib import Path\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from dotenv import load_dotenv\n",
    "\n",
    "from ced.actors.grid import GridWorldActor\n",
    "from ced.tools.utils import find_by_id, to_device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "_ = sns.set_theme(\n",
    "    style=\"white\", context=\"paper\",\n",
    "    rc={\n",
    "        \"pdf.fonttype\": 42,\n",
    "        \"ps.fonttype\": 42,\n",
    "        \"font.size\": 25,\n",
    "        \"axes.titlesize\": 25,\n",
    "        \"axes.labelsize\": 25,\n",
    "        \"xtick.labelsize\": 20,\n",
    "        \"ytick.labelsize\": 20,\n",
    "        \"legend.fontsize\": 20,\n",
    "        \"legend.title_fontsize\": 20,\n",
    "        \"figure.figsize\": (6.4, 6.4),\n",
    "    },\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt_skip_legend = False\n",
    "plt_palette = {\n",
    "    \"SSE\": \"#713580\", \"r-SSE\": \"#a15ab3\", \"TCFE\": \"#00cb77\",\n",
    "    \"total-ASE\": \"#0074a3\", \"A1-ASE\": \"black\", \"A2-ASE\": \"#0098d7\", \"Planner-ASE\": \"black\",\n",
    "    \"[0-10]\": \"black\", \"11\": \"#b51d65\", \"12\": \"#dd2d5a\", \"13\": \"#eb5e5f\", \"14\": \"#fa9072\", \"[15-20]\": \"black\", \n",
    "}\n",
    "\n",
    "plt_effects_title = \"\"\n",
    "plt_effects_x_label = \"Effect Value\"\n",
    "plt_effects_y_label = \"\"\n",
    "\n",
    "plt_contributions_title = \"\"\n",
    "plt_contributions_x_label = \"Time-Step\"\n",
    "plt_contributions_y_label = \"Contribution Ratio\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Helper Functions\n",
    "\n",
    "In this section we define some helper functions used throughout the notebook."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_actor(path: str, id: int, device: str) -> GridWorldActor:\n",
    "    policy = torch.load(path, map_location=device)[\"policy\"].eval()\n",
    "    policy = to_device(policy, device)\n",
    "    actor = GridWorldActor(id, policy)\n",
    "    return actor"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiments\n",
    "\n",
    "In the following sections, we perform analysis for different experimental phases. Make sure to update the location of the `.env` file, should it differ from the default (see also `llm_setup.ipynb`)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "env_path = Path(\"./.env\")\n",
    "results_dir = Path(\"./results/grid\")\n",
    "plots_dir = Path(\"./plots/grid\")\n",
    "seeds = [5656992596, 7989549204, 4429586919, 9986573471, 4459386742]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "_ = load_dotenv(dotenv_path=env_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cpu\"\n",
    "a1 = load_actor(results_dir / \"a1_policy.pt\", id=0, device=device)\n",
    "a2_phase4 = load_actor(results_dir / \"a2_policy.pt\", id=1, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(results_dir / \"trajectories.pkl\", \"rb\") as f:\n",
    "    trajectories = pickle.load(f)\n",
    "    p4_tcfe = pd.read_csv(results_dir / \"p4_trajectories.csv\")\n",
    "    p3_tcfe = pd.read_csv(results_dir / \"p3_trajectories.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Trajectory Analysis\n",
    "\n",
    "We commence by analysing sampled trajectories and the total counterfactual effect (TCFE) of intervening on A2's pickup action with an alternative `pickup green` action. Because A2 follows the pink corridor, we expect to see a positive TCFE for cases when it received $4$ highest penalties."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "order = list(reversed([str([-25., -25., -25., -25.]), str([-15., -25., -25., -25.]), str([-25., -15., -25., -25.]), str([-25., -25., -15., -25.]), str([-25., -25., -25., -15.])]))\n",
    "penalties = [str(t.get_corridor_penalties(agent_id=1, corridor=\"pink\")) for t in trajectories]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>traj_id</th>\n",
       "      <th>seed</th>\n",
       "      <th>tcfe</th>\n",
       "      <th>penalties (A2, pink)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>129352</td>\n",
       "      <td>23.516028</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6</td>\n",
       "      <td>295131</td>\n",
       "      <td>18.610738</td>\n",
       "      <td>[-25.0, -15.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7</td>\n",
       "      <td>684305</td>\n",
       "      <td>18.516404</td>\n",
       "      <td>[-25.0, -25.0, -15.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>248503</td>\n",
       "      <td>18.430336</td>\n",
       "      <td>[-25.0, -15.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>994998</td>\n",
       "      <td>17.946849</td>\n",
       "      <td>[-25.0, -25.0, -15.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8</td>\n",
       "      <td>739705</td>\n",
       "      <td>17.536050</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -15.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>437188</td>\n",
       "      <td>16.744911</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -15.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>330690</td>\n",
       "      <td>15.322737</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>653085</td>\n",
       "      <td>15.229219</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9</td>\n",
       "      <td>120545</td>\n",
       "      <td>14.972615</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   traj_id    seed       tcfe          penalties (A2, pink)\n",
       "1        1  129352  23.516028  [-25.0, -25.0, -25.0, -25.0]\n",
       "6        6  295131  18.610738  [-25.0, -15.0, -25.0, -25.0]\n",
       "7        7  684305  18.516404  [-25.0, -25.0, -15.0, -25.0]\n",
       "0        0  248503  18.430336  [-25.0, -15.0, -25.0, -25.0]\n",
       "4        4  994998  17.946849  [-25.0, -25.0, -15.0, -25.0]\n",
       "8        8  739705  17.536050  [-25.0, -25.0, -25.0, -15.0]\n",
       "2        2  437188  16.744911  [-25.0, -25.0, -25.0, -15.0]\n",
       "3        3  330690  15.322737  [-15.0, -25.0, -25.0, -25.0]\n",
       "5        5  653085  15.229219  [-15.0, -25.0, -25.0, -25.0]\n",
       "9        9  120545  14.972615  [-15.0, -25.0, -25.0, -25.0]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p4_tcfe[\"penalties (A2, pink)\"] = pd.Categorical(penalties, categories=order)\n",
    "p4_tcfe = p4_tcfe.sort_values(by=[\"tcfe\"], ascending=False)\n",
    "p4_tcfe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GridWorld Trajectory 1: Box 1 ('PINK', 'YELLOW'); Box 2 ('PINK', 'GREEN');\n",
      "    Step: 0; Reporter:  Position (A1, A2): [23, 47]; Inventory (A1, A2): NULL, NULL;\n",
      "             Planner: ('examine box 1', 'examine box 2'); Reward 0.0;\n",
      "    Step: 1; Actors (A1, A2): up, down; Position (A1, A2): [23, 47]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 2; Reporter:  Position (A1, A2): [11, 59]; Inventory (A1, A2): NULL, NULL;\n",
      "             Planner: ('pickup pink', 'pickup pink'); Reward 0.0;\n",
      "    Step: 3; Actors (A1, A2): pickup_pink, pickup_pink; Position (A1, A2): [11, 59]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 4; Reporter:  Position (A1, A2): [11, 59]; Inventory (A1, A2): PINK, PINK;\n",
      "             Planner: ('goto pink', 'goto pink'); Reward 0.0;\n",
      "    Step: 5; Actors (A1, A2): down, up; Position (A1, A2): [11, 59]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 6; Actors (A1, A2): left, up; Position (A1, A2): [23, 47]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 7; Actors (A1, A2): left, up; Position (A1, A2): [22, 35]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 8; Actors (A1, A2): left, left; Position (A1, A2): [21, 23]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 9; Actors (A1, A2): left, left; Position (A1, A2): [20, 22]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 10; Actors (A1, A2): left, left; Position (A1, A2): [19, 21]; Reward: -25.4 (A1: -25.2, A2: -0.2)\n",
      "    Step: 11; Actors (A1, A2): left, left; Position (A1, A2): [18, 20]; Reward: -25.4 (A1: -25.2, A2: -0.2)\n",
      "    Step: 12; Actors (A1, A2): left, left; Position (A1, A2): [17, 19]; Reward: -40.4 (A1: -15.2, A2: -25.2)\n",
      "    Step: 13; Actors (A1, A2): left, left; Position (A1, A2): [16, 18]; Reward: -30.4 (A1: -5.2, A2: -25.2)\n",
      "    Step: 14; Actors (A1, A2): up, left; Position (A1, A2): [15, 17]; Reward: -25.4 (A1: -0.2, A2: -25.2)\n",
      "    Step: 15; Actors (A1, A2): left, left; Position (A1, A2): [3, 16]; Reward: -25.4 (A1: -0.2, A2: -25.2)\n",
      "    Step: 16; Actors (A1, A2): left, left; Position (A1, A2): [2, 15]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 17; Actors (A1, A2): left, up; Position (A1, A2): [1, 14]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 18; Actors (A1, A2): None, left; Position (A1, A2): [0, 2]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 19; Actors (A1, A2): None, left; Position (A1, A2): [0, 1]; Reward: -0.4 (A1: -0.2, A2: -0.2)\n",
      "    Step: 20; Goal Reward: 360.0; Total Reward: 183.2;\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(find_by_id(trajectories, p4_tcfe.iloc[0].traj_id).render())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Next, we show the TCFE of intervening on the Planner's instruction, forcing it to direct A2 to pickup the green object. This experiment was a part of our additional results reported in the appendix."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>traj_id</th>\n",
       "      <th>seed</th>\n",
       "      <th>tcfe</th>\n",
       "      <th>penalties (A2, pink)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>267009</td>\n",
       "      <td>23.739867</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>335540</td>\n",
       "      <td>19.095595</td>\n",
       "      <td>[-25.0, -15.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6</td>\n",
       "      <td>117993</td>\n",
       "      <td>18.696265</td>\n",
       "      <td>[-25.0, -15.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7</td>\n",
       "      <td>869979</td>\n",
       "      <td>18.119716</td>\n",
       "      <td>[-25.0, -25.0, -15.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>402694</td>\n",
       "      <td>17.948205</td>\n",
       "      <td>[-25.0, -25.0, -15.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>324868</td>\n",
       "      <td>17.449614</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -15.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8</td>\n",
       "      <td>196013</td>\n",
       "      <td>17.313106</td>\n",
       "      <td>[-25.0, -25.0, -25.0, -15.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>559277</td>\n",
       "      <td>15.315216</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9</td>\n",
       "      <td>638350</td>\n",
       "      <td>14.961987</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>657700</td>\n",
       "      <td>14.388452</td>\n",
       "      <td>[-15.0, -25.0, -25.0, -25.0]</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   traj_id    seed       tcfe          penalties (A2, pink)\n",
       "1        1  267009  23.739867  [-25.0, -25.0, -25.0, -25.0]\n",
       "0        0  335540  19.095595  [-25.0, -15.0, -25.0, -25.0]\n",
       "6        6  117993  18.696265  [-25.0, -15.0, -25.0, -25.0]\n",
       "7        7  869979  18.119716  [-25.0, -25.0, -15.0, -25.0]\n",
       "4        4  402694  17.948205  [-25.0, -25.0, -15.0, -25.0]\n",
       "2        2  324868  17.449614  [-25.0, -25.0, -25.0, -15.0]\n",
       "8        8  196013  17.313106  [-25.0, -25.0, -25.0, -15.0]\n",
       "5        5  559277  15.315216  [-15.0, -25.0, -25.0, -25.0]\n",
       "9        9  638350  14.961987  [-15.0, -25.0, -25.0, -25.0]\n",
       "3        3  657700  14.388452  [-15.0, -25.0, -25.0, -25.0]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p3_tcfe[\"penalties (A2, pink)\"] = pd.Categorical(penalties, categories=order)\n",
    "p3_tcfe = p3_tcfe.sort_values(by=[\"tcfe\"], ascending=False)\n",
    "p3_tcfe"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysing counterfactual effects (intervening on A2's action): total-ASE, SSE, -r-SSE\n",
    "\n",
    "In this section, we show our analysis for several counterfactual effects, focusing on the trajectory with the highest TCFE. To beging with, we show the results for intervening on the A2's action, forcing it to pickup the green object."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AABASXQzPVkZGRmSpOvXr9u4GpQ2hOwy7sKFC1q6dKl27NihEydO6Nq1aypXrpwqV66sunXrqlmzZurQoYP8/PxUsWLFXPvZtWuXVqxYoQMHDujChQtKSkqSi4uLvLy81KBBA7Vu3VoPPfSQWrduLXt7+xzXjhgxolB1jxgxQv/617+K9J0BAABsjZBdhi1ZskQff/yxEhMTs72fmpqqmJgYxcTEaO/evVq4cKH69u2rmTNn5ujjxo0bevPNN7Vhwwar506ePKmTJ09q06ZNmjVrlr7++ms98sgjxfadAAAASgNCdhm1evVqvffee5IkZ2dnBQQE6OGHH1aNGjWUkZGhixcvKjw8XH/88YcOHz6caz8TJkzQ1q1bJUn169fXkCFD1KpVK7m7u8tisej06dMKCQnRxo0bdeXKlXzreuaZZzR06NB821WpUqWA3xQAAKDkIWSXQWlpaQoMDJQkVahQQf/73//k4+OTo123bt308ssv6/jx4zpy5EiO83/88YcRsB9++GF98cUXcnJyytamffv2CggIUFpamjZs2KCaNWvmWVvVqlXl7e1d1K8GAABQKhCyy6ADBw7o0qVLkqSnnnrKasDOqlGjRmrUqFGO94ODg43jt956K0fAzqpcuXLq1atXESsGAAAoW1jCr4SYPXu2mjZtqqZNm0qSrl27pv/+978aMGCAOnTooKZNmyooKKhAfZ0/f944rl+/fpFryrpc0Z30AwAAcK/hTnYJdOrUKY0ePVrR0dFFut7R0dE4Pn78eJHruL2fZs2aFbkvAACAewl3skugCRMm6OLFi3r22Wf13XffadmyZfrss8/UsGHDAl2fNQz/9NNP2rFjR5HqaNGihXE8efJkxcbGFqkfAACAew13skugo0eP6uuvv9bDDz9svNeyZcsCX1+3bl117dpVmzZtUnJyskaOHKlWrVrpkUce0f33369WrVrJw8Mj334GDx6sb7/9VomJiQoJCVHXrl3VpUsXdezYUa1bt5aPj0+e87StuXLliiIjI/Nt17Bhw2x30gEAAEoTQnYJNHDgwGwBuyg+/vhjjR07VmFhYZKksLAw41iSGjRooIcfflgBAQHZ7lhnVbNmTc2cOVOvvvqqLBaLkpKStH79eq1fv16S5OTkpNatW6tHjx4aMGCAKleunG9dixcv1uLFi/NtFxwcrDp16hTgmwIA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VAoAAFCyFHvIfuaZZzR06FDjtcViUXh4uObPn6/o6GiFhYXp73//u5YsWSI7O7viLgeFMHnyZP3000+SJE9PTz399NNq27atPDw8lJSUpOjoaIWGhio4OFjnzp3Lt79u3bpp4sSJ+bZzc3O709IBAABsqthDdtWqVeXt7Z3tvTZt2qh///4aMmSITp8+rYMHD2rTpk3Mvy5BIiMjtWTJEklSs2bNtGDBAlWqVClbm7Zt26pfv3569913tW3bNrm4uOTZZ6VKlXKMBQAAgLLIZg8+uru7a+zYscbrP//801alwIqNGzcqIyNDkjRx4sQcAft2fn5+at++/d0oDQAAoMSz6ROHrVu3No4LMt0gK4vFoj/++EPbtm1TeHi4zp49q6SkJFWsWFGNGzdW165d9fTTT6tChQq59tG0aVNJ0vjx4/XSSy/p4MGD+v7777V3717FxsaqSpUqevDBBzVu3Dg1atTIah9BQUF6++23JUnBwcGqVauWli5dquXLl+v48eNKSUlR3bp11bdvX40cOVLly5fP83ulpaXpl19+0bp163To0CHFx8erQoUKuu+++9SzZ08988wzud4xfvbZZ7V792517NhRCxcu1KlTp7RgwQJt3bpVMTExSkpKUnBwsOrUqZPvn2/Wfx/16tXLtz0AAAD+P5uG7KyriqSlpRXq2hdeeEG7d+/O8X5cXJz27NmjPXv26H//+5/mzZuXa0DOatGiRfr444+VmppqvHfx4kX98ssv+v333/X111/rgQceyLOPpKQkjR49Wjt27Mj2fmRkpCIjI7Vx40b98MMPcnV1tXr9uXPn9OKLLyoiIiLb+/Hx8QoJCVFISIgWL16sr776Sg0bNsyzlg0bNuiNN96QxWLJs11unJycjOMTJ07ovvvuK1I/AAAA9yKbhuzIyEjj2MvLq1DXpqamytvbW/7+/mrVqpW8vLyUkZGh6OhobdiwQWvXrtXZs2f1j3/8QytXrpSzs3OufW3dulUHDx6Ut7e3RowYIW9vbyUnJ+v333/XggULlJiYqDfffFPr16/PFj5v9+677+rAgQMaOHCg+vTpo2rVqun8+fP65ptvtH//fh08eFBffPGFXnvttRzXxsXFaejQoTp//rycnJz05JNP6oEHHlDt2rVlsVi0bds2LViwQKdPn9bzzz+v5cuXq2LFilbrOHfunN544w25uLjoxRdfVIcOHVSuXDmFhYXlGvBv17x5c+P4008/lY+PT4HugAMAAMCGITs1NVXfffed8bpjx46Fun7q1Klq0KBBjvfvv/9+9e3bV4MHD9aYMWN08uRJ/fLLLxoyZEiufYWGhqpLly6aM2dOthDdoUMHVa5cWZ9//rnOnTunzZs3q0ePHrn2s3//fn3yySd64oknjPdatGihRx55RIMGDTIeJnz55ZdzrA3+4Ycf6vz586pdu7Z++OEH1a1bN9t5X19f9e7dW8OGDdOZM2f0zTff6JVXXrFax9mzZ+Xl5aWffvpJtWrVyvZnU1C9e/fWZ599pkuXLunUqVPq1auX/Pz89OCDD6p169Zq0aJFvlNfbnf16tVsP1jlpk6dOgX+YQAAAKAkuusPPlosFu3evVujRo1SaGioJKl27drq27dvofqxFrCzeuihh4zVSoKDg/Ns6+zsrKlTp1q9S/3ss88aG6zs3bs3z3569uyZLWBncnJy0rBhwyTdmvpx7NixbOfPnj2rtWvXSpLee++9HAE7U/PmzY3lEIOCgvKs5bXXXssWsAvL1dVVc+fOVbVq1STd+qFo8+bNmjZtmoYNG6YOHTpo8ODB+u9//6uYmJgC9RkcHKz+/fvn+09YWFiR6wYAACgJij1kz5kzR02bNjX+adu2rfGAnnRrib///ve/eU7DKIjY2FidOnXKmP8cGRkpDw8PScoxx/l2Dz30kKpWrWr1nJubmxHoz5w5k2c//fv3z/VcixYtjOOzZ89mO7d582alpaWpfPnyeuSRR/L8jMx54RcvXsz1YVFHR0f16dMnz34KonXr1lqzZo1efPFF1axZM9u51NRUhYWF6T//+Y969Oihr7/++o4/DwAAoKwo1HSRmJgYJSQkWD3n7u6u6tWrF7ivOnXqqFevXhozZkyuATc/+/bt08KFC7Vjxw7Fx8fn2i4uLi7PfvJ7qM/d3V2SdOPGjSL3U7lyZeP4+vXr2c6Fh4dLkhITE7PNhc7P5cuXrd6tbtCggdU56CkpKTp58mSu/TVs2DDHtuiVK1fWxIkTNXHiRB07dkz79+9XeHi4QkJCjKkfycnJmj59uhITEzVhwoRc+x84cKACAwML+vUAAABKrUKF7JkzZ2r58uVWz+UWoLLu+GhnZydnZ2dVqVIl14f2Cmr27NmaM2dOgdomJSXleT6/ucX29rdu+Kenp+fZLq/NWLLuZnl7P1euXMmz39wkJiZafT+3Na1jYmLyvNue3/J+jRs3VuPGjY357SdPntSnn35qTMf56quvFBAQwAOSAADgnmeTHR/v1I4dO4yAXbduXY0ePVrt27dXrVq1VL58eeOhwlmzZmnu3LmmfnZxyFy+sEqVKlqwYEGBr8stzJYrV86UuvLTsGFDzZkzR8OGDVNISIhSU1O1YcMGjRw58q58PgAAQElVqJAdGBhYIn7dn7ndt7u7u5YsWWLMvb5dblNbSprMqSQ3btxQo0aNii0k16lTR0eOHDG1T3t7ew0aNEghISGSpNOnT5vaPwAAQGlks23V70Tm6hy+vr65Bmzp/891Luky52HfvHmz1NScVdY1zrNOiwEAALhXlcqQnbkrY167GR4+fFgHDhy4WyXdka5duxrh9IcffrBxNbdkZGQUuG3WHwxyW34QAADgXlIqQ3b9+vUlSSEhIVanJ8TGxurNN9+822UV2X333afevXtLktasWZNtkx5rzpw5o9WrVxdrTXPmzNEnn3yS7xrYERERmj9/vqRbU0e6du1arHUBAACUBjbdVr2oBgwYoE2bNslisWj48OEaO3assQ71/v379d133+ny5ctq27at9u/fb+NqC2bSpEkKDw/XmTNnFBgYqODgYD3xxBNq0qSJnJycFB8fr4iICP3555/auXOnevTooX79+hVbPRaLRfPnz9f333+vTp06ydfXV82aNZOHh4cyMjJ07tw5bd26VcuXL9fNmzclScOHD89zk6CC7vhYrlw5NWrUyKyvAgAAcNeVypDdu3dvBQQEKCgoSBcvXtSHH36Y7Xy5cuX09ttv6+rVq6UmZFeuXFmLFy/WxIkTtXfvXu3Zs0d79uzJtX2FChWKtR5PT0+VK1dOaWlp2rp1q7Zu3ZprW3t7e40YMUL//Oc/8+wzODg43903JalixYr57q4JAABQkpXKkC1JU6dO1YMPPqglS5bor7/+UkpKijw9PdWhQwcNHz5crVu31uzZs21dZqF4enpq0aJF+uOPP7R69WqFhobq8uXLSk1NVcWKFVW/fn21bdtW/v7+xs6PxWX06NEaMGCAtmzZoj179igiIkJnz57V9evXZW9vr0qVKqlhw4Zq3769nnjiiXw39AEAALiX2GUU5gk3oAQ7dOiQAgICNHXqVAUEBNi6HAAAUMZk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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p4_quantities = pd.concat(pd.read_csv(results_dir / str(s) / \"p4_causal_quantities.csv\") for s in seeds)\n",
    "p4_quantities\n",
    "\n",
    "order = [\"TCFE\", \"total-ASE\", \"SSE\", \"r-SSE\", \"A1-ASE\", \"A2-ASE\", \"Planner-ASE\"]\n",
    "df = p4_quantities.drop(columns=[\"reverse_sse_icc\"])\n",
    "df = df.rename(columns={\"tcfe\": \"TCFE\", \"ase_total\": \"total-ASE\", \"ase_0\": \"A1-ASE\", \"ase_1\": \"A2-ASE\", \"ase_2\": \"Planner-ASE\", \"sse\": \"SSE\", \"reverse_sse\": \"r-SSE\"})\n",
    "\n",
    "for column in order[1:]:\n",
    "    # plot the negative of the effects, for visual consistency\n",
    "    df[column] = -1 * df[column]\n",
    "\n",
    "df = pd.melt(df, id_vars=[\"seed\", \"traj_id\"])\n",
    "df[\"variable\"] = pd.Categorical(df[\"variable\"], categories=order, ordered=True)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(7, 7))\n",
    "\n",
    "ax = sns.barplot(data=df, x=\"value\", y=\"variable\", palette=plt_palette, errorbar=(\"se\", 2), errwidth=1, capsize=0.3, saturation=1.0, orient=\"h\", ax=ax) \n",
    "ax.set_title(plt_effects_title)\n",
    "ax.set_xlabel(plt_effects_x_label)\n",
    "ax.set_ylabel(plt_effects_y_label)\n",
    "ax.yaxis.set_ticklabels([\"TCFE\", \"-total ASE\", \"-SSE\", \"-r-SSE\", \"-$\\\\mathcal{A}_1$-SE\", \"-$\\\\mathcal{A}_2$-SE\", \"-Planner-SE\"])\n",
    "ax.set_box_aspect(1)\n",
    "\n",
    "if plt_skip_legend: _ = ax.get_legend().remove()\n",
    "fig.savefig(plots_dir / \"p4_tmain_quantities.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysing counterfactual effects (intervening on Planner's action): total-ASE, SSE, -r-SSE\n",
    "\n",
    "Next, we show our analysis for the case of intervening on the Planner's action, forcing it to instruct the A2 agent to pickup the green object."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Rln0Z/PEE0/o008/zbE+r1FIMjk5OWno0KFaunSpJGn16tU6e/ashg4dqiZNmshkMunIkSNatWqVrl69KhcXF3Xv3j3bNPclYWdnp1GjRunjjz+WdG+88KeeekrDhg0zn//gwYNauXKlbty4IT8/P124cKHAhzSN+l0BKjrCNgBYWEJCgrZv316kY/KahbA09OzZU1988YVef/113bp1SykpKVq/fn22mRKLysPDQ8uXL9fzzz+vc+fOSbo382BERESR23rsscc0YMAAff/995Lu/Xz37NmTbZ+sQw5aysCBAzV//vxsIbFhw4bZ7trn5bXXXtO+fft0/PhxSdLBgwd18ODBHPs5ODho1qxZhepbXRRjxozRtm3btH//fklSeHi4wsPDc+zXokULzZs3T0OGDClUu0b8rgAVHd1IAADq1q2bfv75Z40ZM0Y1atTId193d3cFBQVpyZIlat68eZ77eXp6au3atXr99dez9WP+Izs7O/n7+2fr6/1HH330kebPn6/AwEB5enrKxcXF8PG7GzVqpIceeijbugEDBhTqvC4uLlq2bJkGDRpkfrDwj3x9fbVixYp8+38Xl4ODgxYuXKinnnoq1/M7ODhoyJAhWrVqldzc3IrUthG/K0BFZpPB9zoAgCzS09MVERGh06dPKy4uTnfv3pWrq6vq1aunFi1aFCs0ZWRk6OjRozp58qRiY2OVlpamatWqqVmzZmrbtm22LiEVTXR0tPbs2aOrV6/Kzs5OHh4eatu2rZo0aVIq54+NjdWuXbt05coVValSRfXr11enTp1Uq1atErdtxO8KUNEQtgEAAACD0I0EAAAAMAhhGwAAADAIYRsAAAAwCGEbAAAAMAhhGwAAADAIYRsAAAAwCGEbAAAAMAhhGwAAADAIYRsAAAAwCGEbAAAAMAhhGwAAADAIYRsAAAAwCGEbAAAAMAhhGwAAADDI/wNZX1AKoc/CIgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p3_quantities = pd.concat(pd.read_csv(results_dir / str(s) / \"p3_causal_quantities.csv\") for s in seeds)\n",
    "p3_quantities\n",
    "\n",
    "order = [\"TCFE\", \"total-ASE\", \"SSE\", \"r-SSE\", \"A1-ASE\", \"A2-ASE\", \"Planner-ASE\"]\n",
    "df = p3_quantities.drop(columns=[\"reverse_sse_icc\"])\n",
    "df = df.rename(columns={\"tcfe\": \"TCFE\", \"ase_total\": \"total-ASE\", \"ase_0\": \"A1-ASE\", \"ase_1\": \"A2-ASE\", \"ase_2\": \"Planner-ASE\", \"sse\": \"SSE\", \"reverse_sse\": \"r-SSE\"})\n",
    "\n",
    "df = pd.melt(df, id_vars=[\"seed\", \"traj_id\"])\n",
    "df[\"variable\"] = pd.Categorical(df[\"variable\"], categories=order, ordered=True)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(7, 7))\n",
    "\n",
    "ax = sns.barplot(data=df, x=\"value\", y=\"variable\", palette=plt_palette, errorbar=(\"se\", 2), errwidth=1, capsize=0.3, saturation=1.0, orient=\"h\", ax=ax) \n",
    "ax.set_title(plt_effects_title)\n",
    "ax.set_xlabel(plt_effects_x_label)\n",
    "ax.set_ylabel(plt_effects_y_label)\n",
    "ax.yaxis.set_ticklabels([\"TCFE\", \"total ASE\", \"SSE\", \"r-SSE\", \"$\\\\mathcal{A}_1$-SE\", \"$\\\\mathcal{A}_2$-SE\", \"Planner-SE\"])\n",
    "ax.set_box_aspect(1)\n",
    "\n",
    "if plt_skip_legend: _ = ax.get_legend().remove()\n",
    "fig.savefig(plots_dir / \"p3_tmain_quantities.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysing intrinsic causal contribution results\n",
    "\n",
    "In this section, we show the results for the reverse state-specific effect intrinsic causal contribution analysis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7ty50X4CAgJw6tQprcZMS0vTu14iIiKitsKoQ+rRo0cRHByM0tJS4b3y8nIUFxcjJSUF0dHRCAsLg6urq859X758Gf7+/pDJZPX23b17F0lJSUhKSsKOHTuwZs0aPP300836WoiIiIjaE6MNqampqQgKCoJcLodUKsWCBQvg4+MDuVyOuLg47N27F5mZmQgMDERMTAxsbGx06r+0tFQIqF5eXhg7diwGDx4MBwcHFBYW4ueff0Z0dDRKS0vx9ttvo0OHDhgzZkyjfQ4ePBjr16/X+2smIiIiMhZGG1LXrl0LuVwOMzMzREREYNiwYcK+kSNHwtXVFaGhocjMzMT27duxZMkSnfo3MTHB5MmTsXjxYvTr16/e/lGjRmH06NFYvHgxqqur8dFHH2H06NHCvLGaSKVSuLu761QHERERkTEyygenkpOTcebMGQCAn59fnYCqMnfuXPTt2xcAEBkZicrKSp3G8PLywmeffaYxoKpMmDABTz31FAAgOzsbqampOo1BRERE1F4ZZUg9cuSIsO3n56exjYmJCXx9fQEAJSUlSEhIaJFafHx8hO3s7OwWGYOIiIjI2BhlSD179iyA2svngwYNarCd+uIEiYmJLVKLQqEQtk1NTVtkDCIiIiJjY5T3pKanpwMAXFxcYGbW8JfYp0+feseITX1qKdXtBQ3JyMjA9OnTce3aNVRUVKBjx44YNGgQJk6ciGeeeQbm5uYtUiMRERGRoTG6M6kVFRUoKioCAHTr1q3Rtvb29pBKpQCAvLw80Wu5fPkyjh8/DgBwd3dvMqTeuXMHycnJuHfvHhQKBfLz83H06FG8++678PX1bbEgTURERGRojO5MallZmbCtCqCNsba2hkwm0zjfaXMoFAosX74c1dXVAICgoKAG20okEowcORJjxozBgAED4ODggLKyMly8eBFRUVFIT0/H1atXMWvWLERHR6NHjx6i1kpERERkaIwupFZUVAjb2lwet7CwAADI5XJR61i9ejVSUlIAAFOnTsW4ceMabLt161bY2dnVe3/EiBF4+eWXsXLlShw4cAB37tzBunXrsHXrVlFrJSIiIjI0Rne539LSUtjWZlop1YNNVlZWotWwbds2REdHAwCGDBmC999/v9H2mgKqirm5OT766CP07t0bAPDLL78gPz9ftFqJiIiIDJHRhdQOHToI29pcwi8vLweg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vb09Hn/8cXz88ceIjY2Fi4sLJBIJlEol1q5dK0ZJRERERNSGiRJSf/jhB2F79uzZePPNN7Ve5rRfv37YuXOn8ODU9evXkZSUJEZZRERERNRGiRJSr1y5AgCwsLDA3//+d52P79atG1566aV6/RERERFR+yRKSC0uLoZEIoG7uztsbGz06mP48OHC9t27d8Uoi4iIiIjaKFFCaqdOnQAAVlZWevehfqyqPyIiIiJqn0QJqf3794dSqURmZqbefWRkZAjb/fr1E6EqIiIiImqrRAmpzz//PADgzp07OHLkiM7H19TUIDo6GgDg6uoKT09PMcoiIiIiojZKlJA6adIkeHt7Q6lU4oMPPtD5wad169YhNTUVpqamWLFihRglEREREVEbJkpINTExwWeffYahQ4eioKAAL730Er766qsmH4A6c+YMAgICsHv3blhYWGDVqlUYNWqUGCURERERURum9YpTW7dubbLN3/72N2RlZaGoqAj//Oc/sXXrVgwePBj9+/eHg4MDzM3NUVZWhpycHKSkpODWrVvC0qijR49Gfn4+tm7disWLFzfriyIiIiKitk2nkKpaUaopqtWjqqqqcP78eZw/f75eG6VSKbQFgPj4eMTHxwMAQyoRERFRO6d1SAX+FyzFPOb+/doGYSIiIiIyXlqH1KlTp7ZkHUREREREAq1D6vr161uyDiIiIiIigShP9xMRERERiYkhlYiIiIgMDkMqERERERkchlQiIiIiMjgMqURERERkcLR+uv+hhx4StiUSCVJTUzXua677+yYiIiKi9kfrkKpavlTT5PyN7SMiIiIi0pVOl/sbC6EMqEREREQkFq3PpMbHx+u1j4iIiIhIV1qHVGdnZ732ERERERHpSuuQ2lbl5uZi165dOHbsGPLy8mBhYYFevXph8uTJeOWVV2Btba133zU1NcjIyEBycjKSk5Nx4cIFpKWlobKyEgAQGRkJHx+fJvsJCAjAqVOntBozLS1N73qJiIiI2gpRQurWrVuF7enTp6Nr165idNtsR48eRXBwMEpLS4X3ysvLUVxcjJSUFERHRyMsLAyurq569f/9999j2bJlYpVLRERERP9PtJAqkUhgZ2eHRYsWidFls6WmpiIoKAhyuRxSqRQLFiyAj48P5HI54uLisHfvXmRmZiIwMBAxMTGwsbHReQz1h8XMzc3h7u6OyspK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eAC1Z0qTkpI0tktKShLOpI4fP17vM6JRUVHCdlMrXBERERG1dUYZUj09PTFixAgAtSH13Llz9dpEREQIq0zNmjWr3jRSCQkJ8PDwgIeHB5YtW6ZxnFdffRWmpqYAgDVr1tSbXkoul2PNmjUAADMzM7z66qv1+khKShKWV9VEqVRi8+bN+OOPPwAAAwYMEM4UExERERkro5snVWX58uXw9/eHXC7H3LlzsXDhQvj4+EAulyMuLk44M+nm5oY5c+boNUbv3r0xb948hIWFISUlBf7+/pg/fz569eqF69ev4+uvv0ZqaioAYN68eXBzc6vXx2+//YawsDA8/vjjeOyxx9C3b1/Y2dlBoVAgLS0NMTExOH/+PIDaRQHWrFnD+1OJiIjI6BltSB04cCA2b96M4OBglJaWYtOmTfXauLm5ISwsDDY2NnqPExQUhIKCAsTExCA1NRVBQUH12rzwwgtYunRpg30oFArEx8cjPj6+wTY9evTAhg0b4OnpqXetRERERG2F0YZUABg3bhwOHjyIyMhIHDt2DPn5+TA3N4eLiwsmTZqEmTNn1lmyVB8mJiZYt24dJk6ciKioKFy4cAFFRUXo2LEjhgwZghdffBFjxoxp8Php06bByckJSUlJSEtLQ0FBAe7evQszMzN07NgRAwcOxNixY/Hss8/WWUCAiIiIyJgZdUgFAGdnZ4SEhCAkJESn43x8fJCWlqZ1+zFjxjQaRhvi7OyMl19+GS+//LLOxxIREREZK6N8cIqIiIiI2jaGVCIiIiIyOAypRERERGRwGFKJiIiIyOAwpBIRERGRwWFIJSIiIiKDw5BKRERERAaHIZWIiIiIDA5DKhEREREZHIZUIiIiIjI4DKlEREREZHAYUomIiIjI4DCkEhEREZHBYUglIiIiIoPDkEpEREREBochlYiIiIgMDkMqERERERkchlQiIiIiMjgMqURERERkcBhSiYiIiMjgMKQSERERkcFhSCUiIiIig8OQSkREREQGhyGViIiIiAwOQyoRERERGRyGVCIiIiIyOAypRERERGRwGFKJiIiIyOAwpBIRERGRwWFIJSIiIiKDw5BKRERERAaHIZWIiIiIDA5DKhEREREZHIZUIiIiIjI4DKlEREREZHAYUomIiIjI4DCkEhEREZHBYUglIiIiIoPDkEpEREREBochlYiIiIgMDkMqERER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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = p4_quantities.copy()\n",
    "contributions = []\n",
    "\n",
    "for i in range(len(df)):\n",
    "    sse_icc = df.iloc[i][\"reverse_sse_icc\"].strip(\"[]\").split(\", \")\n",
    "    sse_icc = list(map(float, sse_icc))\n",
    "    \n",
    "    assert all([i == 0 for i in sse_icc[:11]]), \"We expect steps [0-10] to have 0 contribution.\"\n",
    "    assert all([i == 0 for i in sse_icc[15:]]), \"We expect steps [15-20] to have 0 contribution.\"\n",
    "    sse_icc = [0.0, *sse_icc[11:15], 0.0]\n",
    "    \n",
    "    sse_icc = np.array(sse_icc) / df.iloc[i][\"reverse_sse\"]\n",
    "    contributions.append(sse_icc.tolist())\n",
    "\n",
    "contributions_df = pd.DataFrame(contributions, columns=[\"[0-10]\", \"11\", \"12\", \"13\", \"14\", \"[15-20]\"])\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(7, 7))\n",
    "ax = sns.barplot(data=contributions_df, errorbar=(\"se\", 2), errwidth=1, capsize=0.3, palette=plt_palette, ax=ax)\n",
    "ax.set_xlabel(plt_contributions_x_label)\n",
    "ax.set_ylabel(plt_contributions_y_label)\n",
    "ax.set_title(plt_contributions_title)\n",
    "\n",
    "fig.savefig(plots_dir / \"p4_icc.pdf\", bbox_inches=\"tight\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mpi-ase-llm",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
