{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f8fa762",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting Multi-Agent Simulation (3 Predators vs 1 Prey)...\n",
      "Monitor uses Mixture Martingale over grid: [0.1, 0.3, 0.5, 0.7, 0.9]\n",
      "True Eps   | Avg Tau   \n",
      "------------------------------\n",
      "0.05       | 2413.6    \n",
      "0.10       | 636.7     \n",
      "0.20       | 156.4     \n",
      "0.30       | 66.6      \n",
      "0.40       | 41.8      \n",
      "0.60       | 16.7      \n",
      "0.80       | 9.8       \n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import bundles\n",
    "\n",
    "# configuration and game settings\n",
    "grid_size = 10\n",
    "num_predators = 3 # total predators (1 suspect + N-1 honest)\n",
    "actions = [0, 1, 2, 3, 4] # stay, up, down, left, right\n",
    "action_names = [\"Stay\", \"Up\", \"Down\", \"Left\", \"Right\"]\n",
    "threshold = 20.0 # threshold for rejection\n",
    "trials_per_epsilon = 100 # number of Monte Carlo runs per epsilon\n",
    "max_steps = 5000 # safety cutoff\n",
    "\n",
    "# true epsilons (what the cheater actually uses)\n",
    "true_epsilons = [0.05, 0.1, 0.2, 0.3, 0.4, 0.6, 0.8]\n",
    "\n",
    "# monitor's hypothesis grid (the mixture)\n",
    "mixture_grid = [0.1, 0.3, 0.5, 0.7, 0.9]\n",
    "\n",
    "np.random.seed(0)\n",
    "\n",
    "# game dynamics\n",
    "\n",
    "def get_next_pos(pos, action):\n",
    "    \"\"\"calculates next position given 5x5 grid with boundaries\"\"\"\n",
    "    row, col = pos\n",
    "    if action == 0:   # stay\n",
    "        return (row, col)\n",
    "    elif action == 1: # up\n",
    "        return (max(0, row - 1), col)\n",
    "    elif action == 2: # down\n",
    "        return (min(grid_size - 1, row + 1), col)\n",
    "    elif action == 3: # left\n",
    "        return (row, max(0, col - 1))\n",
    "    elif action == 4: # right\n",
    "        return (row, min(grid_size - 1, col + 1))\n",
    "    return pos\n",
    "\n",
    "def dist_sq(pos1, pos2):\n",
    "    return (pos1[0] - pos2[0])**2 + (pos1[1] - pos2[1])**2\n",
    "\n",
    "# strategies\n",
    "\n",
    "def get_null_probs():\n",
    "    \"\"\"H0: uniform random walk (1/5 prob for each action)\"\"\"\n",
    "    return np.ones(5) / 5.0\n",
    "\n",
    "def get_optimal_probs(pred_pos, prey_pos):\n",
    "    \"\"\"\n",
    "    H1: heuristic strategy; assigns higher probability to moves that reduce distance to prey\"\"\"\n",
    "    probs = np.zeros(5)\n",
    "    current_dist = dist_sq(pred_pos, prey_pos)\n",
    "\n",
    "    # evaluate all moves\n",
    "    for act in actions:\n",
    "        next_p = get_next_pos(pred_pos, act)\n",
    "        new_d = dist_sq(next_p, prey_pos)\n",
    "        \n",
    "        if new_d < current_dist:\n",
    "            probs[act] = 10.0 # strong preference\n",
    "        elif new_d == current_dist:\n",
    "            probs[act] = 1.0  # neutral\n",
    "        else:\n",
    "            probs[act] = 0.1  # avoid moving away\n",
    "            \n",
    "    return probs / np.sum(probs)\n",
    "\n",
    "def get_mixture_probs(pred_pos, prey_pos, epsilon):\n",
    "    \"\"\"observed strategy: (1 - eps) * Null + eps * Optimal\"\"\"\n",
    "    p_null = get_null_probs()\n",
    "    p_opt = get_optimal_probs(pred_pos, prey_pos)\n",
    "    return (1 - epsilon) * p_null + epsilon * p_opt\n",
    "\n",
    "# simulation loop\n",
    "\n",
    "results_tau = []\n",
    "results_std = []\n",
    "\n",
    "print(f\"Starting Multi-Agent Simulation ({num_predators} Predators vs 1 Prey)...\")\n",
    "print(f\"Monitor uses Mixture Martingale over grid: {mixture_grid}\")\n",
    "print(f\"{'True Eps':<10} | {'Avg Tau':<10}\")\n",
    "print(\"-\" * 30)\n",
    "\n",
    "for true_epsilon in true_epsilons:\n",
    "    taus = []\n",
    "    \n",
    "    for _ in range(trials_per_epsilon):\n",
    "        # reset Game\n",
    "        predators = [(0, 0) for _ in range(num_predators)]\n",
    "        prey_pos = (grid_size-1, grid_size-1) \n",
    "        # initialize K martingales\n",
    "        candidate_martingales = np.ones(len(mixture_grid))\n",
    "        \n",
    "        t = 0\n",
    "        detected = False\n",
    "        \n",
    "        while not detected and t < max_steps:\n",
    "            t += 1\n",
    "            \n",
    "            # 1. predator moves\n",
    "            next_predators = []\n",
    "            catch_event = False\n",
    "            \n",
    "            for i in range(num_predators):\n",
    "                current_pos = predators[i]\n",
    "                \n",
    "                if i == 0: \n",
    "                    # the suspect agent plays using the TRUE epsilon\n",
    "                    p_null = get_null_probs()\n",
    "                    p_true = get_mixture_probs(current_pos, prey_pos, true_epsilon)\n",
    "                    # sample Action\n",
    "                    action = np.random.choice(actions, p=p_true)\n",
    "                    \n",
    "                    # the monitor does not know 'true_epsilon'. \n",
    "                    for k, candidate_eps in enumerate(mixture_grid):\n",
    "                        # what would the prob be if the agent was using candidate_eps?\n",
    "                        p_hyp = get_mixture_probs(current_pos, prey_pos, candidate_eps)\n",
    "                        # update component martingale\n",
    "                        lr = p_hyp[action] / p_null[action]\n",
    "                        candidate_martingales[k] *= lr\n",
    "                    \n",
    "                    # the test statistic is the average (uniform mixture)\n",
    "                    mixture_martingale_value = np.mean(candidate_martingales)\n",
    "                    \n",
    "                    if mixture_martingale_value >= threshold:\n",
    "                        detected = True\n",
    "                    \n",
    "                else:\n",
    "                    # honest agents\n",
    "                    p_null = get_null_probs()\n",
    "                    action = np.random.choice(actions, p=p_null)\n",
    "                \n",
    "                # execute move\n",
    "                new_pos = get_next_pos(current_pos, action)\n",
    "                next_predators.append(new_pos)\n",
    "                \n",
    "                if new_pos == prey_pos:\n",
    "                    catch_event = True\n",
    "            \n",
    "            predators = next_predators\n",
    "\n",
    "            # 2. prey move\n",
    "            prey_action = np.random.choice(actions) \n",
    "            prey_pos = get_next_pos(prey_pos, prey_action)\n",
    "            \n",
    "            if any(p == prey_pos for p in predators):\n",
    "                catch_event = True\n",
    "            \n",
    "            # 3. reset if caught\n",
    "            if catch_event:\n",
    "                predators = [(0, 0) for _ in range(num_predators)]\n",
    "                prey_pos = (grid_size-1, grid_size-1)\n",
    "\n",
    "        taus.append(t)\n",
    "\n",
    "    avg_tau = np.mean(taus)\n",
    "    results_tau.append(avg_tau)\n",
    "    results_std.append(np.std(taus) / np.sqrt(trials_per_epsilon)) \n",
    "    \n",
    "    print(f\"{true_epsilon:<10.2f} | {avg_tau:<10.1f}\")\n",
    "\n",
    "# plotting\n",
    "\n",
    "# style setup\n",
    "plt.rcParams.update(bundles.icml2024())\n",
    "plt.rcParams.update({\n",
    "    \"axes.labelsize\": 16,\n",
    "    \"axes.titlesize\": 16,\n",
    "    \"xtick.labelsize\": 14,\n",
    "    \"ytick.labelsize\": 14,\n",
    "    \"legend.fontsize\": 14,\n",
    "    \"lines.linewidth\": 2.5,\n",
    "})\n",
    "\n",
    "# theoretical scaling: T ~ K / epsilon^2\n",
    "# anchor to the last point (largest epsilon)\n",
    "anchor_idx = -1 \n",
    "last_eps = true_epsilons[anchor_idx]\n",
    "last_tau = results_tau[anchor_idx]\n",
    "\n",
    "# calculate constant K\n",
    "K = last_tau * (last_eps ** 2)\n",
    "\n",
    "# generate theoretical curve\n",
    "theoretical_y = [K / (e**2) for e in true_epsilons]\n",
    "\n",
    "plt.figure(figsize=(5, 3))\n",
    "\n",
    "# plot empirical data\n",
    "plt.errorbar(true_epsilons, results_tau, yerr=results_std, fmt='o-', \n",
    "             label='Empirical', \n",
    "             color='#1f77b4', ecolor='#1f77b4', capsize=5)\n",
    "\n",
    "# plot theoretical curve\n",
    "plt.plot(true_epsilons, theoretical_y, linestyle='--', \n",
    "         label='Theoretical', \n",
    "         color='#2ca02c', linewidth=2.5)\n",
    "\n",
    "plt.ylim(4,5000)\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('linear')\n",
    "\n",
    "plt.xlabel(r\"Mixture Parameter $\\varepsilon$\")\n",
    "plt.ylabel(r\"Avg Detection Time\")\n",
    "plt.grid(True, which='both', alpha=0.3)\n",
    "plt.legend()\n",
    "\n",
    "save_path = 'plots/predator-prey/scaling.pdf'\n",
    "plt.savefig(save_path, format=\"pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3fb2056e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running visual episode with Epsilon=0.6...\n",
      "Step  | Suspect Pos     | Action     | Martingale   | Probabilities (Stay, Up, Down, Left, Right)\n",
      "----------------------------------------------------------------------------------------------------------------------------------\n",
      "0     | (0, 0)          | Down       | 1.00         | [  0.11,   0.11,   0.34,   0.11,   0.34]\n",
      "1     | (1, 0)          | Right      | 1.59         | [  0.11,   0.08,   0.35,   0.11,   0.35]\n",
      "2     | (1, 1)          | Right      | 2.71         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "3     | (1, 2)          | Down       | 4.97         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "4     | (2, 2)          | Stay       | 9.48         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "5     | (2, 2)          | Right      | 4.34         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "6     | (2, 3)          | Right      | 8.04         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "7     | (2, 4)          | Right      | 15.38        | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "8     | (2, 5)          | Up         | 30.20        | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "9     | (1, 5)          | Stay       | 8.37         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "10    | (1, 5)          | Down       | 4.47         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n",
      "11    | (2, 5)          | Right      | 7.75         | [  0.11,   0.08,   0.36,   0.08,   0.36]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\etgauthi\\AppData\\Local\\Temp\\ipykernel_38448\\3473856450.py:145: UserWarning: The figure layout has changed to tight\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x1050 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import csv\n",
    "\n",
    "# colors for visualization\n",
    "color_prey = '#2ca02c'    \n",
    "color_suspect = '#d62728'   \n",
    "color_honest = '#1f77b4'    \n",
    "color_grid = '#e0e0e0'\n",
    "\n",
    "np.random.seed(0)\n",
    "\n",
    "# visualization\n",
    "\n",
    "def run_visual_episode(true_epsilon, steps_to_record=25, save_csv_name=None):\n",
    "    # setup\n",
    "    predators = [(0, 0) for _ in range(num_predators)]\n",
    "    prey_pos = (grid_size-1, grid_size-1)\n",
    "    \n",
    "    # martingale state\n",
    "    candidate_martingales = np.ones(len(mixture_grid))\n",
    "    history = []\n",
    "    csv_rows = []\n",
    "    \n",
    "    print(f\"Running visual episode with Epsilon={true_epsilon}...\")\n",
    "    print(f\"{'Step':<5} | {'Suspect Pos':<15} | {'Action':<10} | {'Martingale':<12} | {'Probabilities (Stay, Up, Down, Left, Right)'}\")\n",
    "    print(\"-\" * 130)\n",
    "    \n",
    "    for t in range(steps_to_record):\n",
    "        # 1. record State before moves\n",
    "        current_martingale = np.mean(candidate_martingales)\n",
    "        history.append({\n",
    "            'step': t,\n",
    "            'predators': predators.copy(),\n",
    "            'prey': prey_pos,\n",
    "            'martingale': current_martingale,\n",
    "            'caught': any(p == prey_pos for p in predators)\n",
    "        })\n",
    "        \n",
    "        # 2. agent moves\n",
    "        next_predators = []\n",
    "        \n",
    "        # suspect (index 0)\n",
    "        suspect_pos = predators[0]\n",
    "        p_null = get_null_probs()\n",
    "        p_true = get_mixture_probs(suspect_pos, prey_pos, true_epsilon)\n",
    "        action_s = np.random.choice(actions, p=p_true)\n",
    "        \n",
    "        # logging\n",
    "        act_name = action_names[action_s]\n",
    "        prob_str = \", \".join([f\"{v:6.2f}\" for v in p_true])\n",
    "        print(f\"{t:<5} | {str(suspect_pos):<15} | {act_name:<10} | {current_martingale:<12.2f} | [{prob_str}]\")\n",
    "        \n",
    "        # collect data for CSV\n",
    "        if save_csv_name:\n",
    "            row = [t, suspect_pos[0], suspect_pos[1], act_name, current_martingale] + list(p_true)\n",
    "            csv_rows.append(row)\n",
    "        \n",
    "        # monitor update\n",
    "        for k, candidate_eps in enumerate(mixture_grid):\n",
    "            p_hyp = get_mixture_probs(suspect_pos, prey_pos, candidate_eps)\n",
    "            lr = p_hyp[action_s] / p_null[action_s]\n",
    "            candidate_martingales[k] *= lr\n",
    "            \n",
    "        next_predators.append(get_next_pos(suspect_pos, action_s))\n",
    "        \n",
    "        # honest agents\n",
    "        for i in range(1, num_predators):\n",
    "            p_honest = get_null_probs()\n",
    "            act_h = np.random.choice(actions, p=p_honest)\n",
    "            next_predators.append(get_next_pos(predators[i], act_h))\n",
    "            \n",
    "        predators = next_predators\n",
    "        \n",
    "        # prey move\n",
    "        act_prey = np.random.choice(actions)\n",
    "        prey_pos = get_next_pos(prey_pos, act_prey)\n",
    "        \n",
    "        # reset if caught\n",
    "        if any(p == prey_pos for p in predators):\n",
    "            predators = [(0, 0) for _ in range(num_predators)]\n",
    "            prey_pos = (grid_size-1, grid_size-1)\n",
    "            \n",
    "    # save CSV\n",
    "    if save_csv_name:\n",
    "        csv_path = f'results/{save_csv_name}'\n",
    "        with open(csv_path, 'w', newline='') as f:\n",
    "            writer = csv.writer(f)\n",
    "            header = ['Step', 'Suspect_Row', 'Suspect_Col', 'Action', 'Martingale', \n",
    "                      'Prob_Stay', 'Prob_Up', 'Prob_Down', 'Prob_Left', 'Prob_Right']\n",
    "            writer.writerow(header)\n",
    "            writer.writerows(csv_rows)   \n",
    "\n",
    "    return history\n",
    "\n",
    "# plotting function\n",
    "def plot_film_strip(history, save_filename):\n",
    "    n_steps = len(history)\n",
    "    cols = 4\n",
    "    rows = (n_steps + cols - 1) // cols\n",
    "    \n",
    "    fig, axes = plt.subplots(rows, cols, figsize=(cols*3, rows*3.5))\n",
    "    axes_flat = axes.flatten()\n",
    "    \n",
    "    for i, state in enumerate(history):\n",
    "        ax = axes_flat[i]\n",
    "        \n",
    "        # grid setup\n",
    "        ax.set_xlim(-0.5, grid_size-0.5)\n",
    "        ax.set_ylim(grid_size-0.5, -0.5) # invert Y to match matrix coords\n",
    "        ax.set_xticks(np.arange(grid_size))\n",
    "        ax.set_yticks(np.arange(grid_size))\n",
    "        ax.grid(color=color_grid, linestyle='-', linewidth=1.5)\n",
    "        ax.set_xticklabels([])\n",
    "        ax.set_yticklabels([])\n",
    "        \n",
    "        # draw prey\n",
    "        py, px = state['prey']\n",
    "        ax.scatter(px, py, s=300, marker='*', c=color_prey, label='Prey', zorder=10)\n",
    "        \n",
    "        # draw honest predators\n",
    "        for idx, hp in enumerate(state['predators'][1:]):\n",
    "            hy, hx = hp\n",
    "            label = 'Honest' if idx == 0 else None\n",
    "            ax.scatter(hx, hy, s=150, marker='o', c=color_honest, alpha=0.6, label=label)\n",
    "            \n",
    "        # draw suspect predator\n",
    "        sy, sx = state['predators'][0]\n",
    "        ax.scatter(sx, sy, s=200, marker='D', c=color_suspect, edgecolors='black', label='Suspect', zorder=11)\n",
    "        \n",
    "        # info\n",
    "        m_val = state['martingale']\n",
    "        title_color = 'black'\n",
    "        if m_val > threshold: title_color = 'red'\n",
    "        \n",
    "        ax.set_title(f\"Step {state['step']}\\nMartingale: {m_val:.2f}\", \n",
    "                     fontsize=12, fontweight='bold', color=title_color)\n",
    "        \n",
    "        # add legend only to first plot\n",
    "        if i == 0:\n",
    "            ax.legend(loc='upper left', bbox_to_anchor=(-0.1, 1.3), fontsize=10, ncol=3)\n",
    "\n",
    "    # hide empty subplots\n",
    "    for j in range(n_steps, len(axes_flat)):\n",
    "        axes_flat[j].axis('off')\n",
    "        \n",
    "    plt.tight_layout()\n",
    "    plt.savefig(f'plots/{save_filename}', format='pdf', bbox_inches='tight')\n",
    "\n",
    "# execution\n",
    "\n",
    "# run a short episode with a distinct cheater (epsilon=0.6)\n",
    "history_data = run_visual_episode(true_epsilon=0.6, steps_to_record=12, save_csv_name=\"predator-prey/history.csv\")\n",
    "plot_film_strip(history_data, \"predator-prey/gameplay.pdf\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
