{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d71fc574-5d15-475b-9d88-cf23779ece7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "from collections import defaultdict\n",
    "\n",
    "from data_loaders import ResultsLoader, ResultsBatchProcessor\n",
    "\n",
    "\n",
    "plt.rcParams.update({\n",
    "    'font.size': 12,\n",
    "    'axes.titlesize': 14,\n",
    "    'axes.labelsize': 13,\n",
    "    'xtick.labelsize': 11,\n",
    "    'ytick.labelsize': 11,\n",
    "    'legend.fontsize': 11,\n",
    "    'figure.titlesize': 14,\n",
    "    'lines.linewidth': 2,\n",
    "    'lines.markersize': 6,\n",
    "    'legend.frameon': False,\n",
    "    'text.usetex': True,\n",
    "    'font.family': 'serif',\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "50ac949b-bf7e-4a40-b0c7-da2e1a578efb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting data from: fixed_coarse/2D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/2D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/2D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/4D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/4D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/4D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/16D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/16D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/16D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/32D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/32D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/32D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/64D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/64D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/64D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/128D/results_Np_1\n",
      "Processed: N1_Pc4_Pf16_slv_direct\n",
      "Processed: N1_Pc4_Pf16_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf2_slv_direct\n",
      "Processed: N1_Pc4_Pf2_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf32_slv_direct\n",
      "Processed: N1_Pc4_Pf32_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf4_slv_direct\n",
      "Processed: N1_Pc4_Pf4_slv_iterative_block\n",
      "Processed: N1_Pc4_Pf8_slv_direct\n",
      "Processed: N1_Pc4_Pf8_slv_iterative_block\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/128D/results_Np_2\n",
      "Processed: N2_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N2_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n",
      "Collecting data from: fixed_coarse/128D/results_Np_4\n",
      "Processed: N4_Pc4_Pf16_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf2_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf32_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf4_slv_iterative_block_distributed\n",
      "Processed: N4_Pc4_Pf8_slv_iterative_block_distributed\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "pream_path = \"fixed_coarse\"\n",
    "results_dim = {}\n",
    "\n",
    "for dim in [2, 4, 16, 32, 64, 128]:\n",
    "\n",
    "    results_dim[f\"{dim}\"] = {\n",
    "            'N1': ResultsBatchProcessor(f\"{pream_path}/{dim}D/results_Np_1\").group_by_solver(),\n",
    "            'N2': ResultsBatchProcessor(f\"{pream_path}/{dim}D/results_Np_2\").group_by_solver(),\n",
    "            'N4': ResultsBatchProcessor(f\"{pream_path}/{dim}D/results_Np_4\").group_by_solver(),\n",
    "        }\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9c2eb562-88f7-4206-971d-e6e427a1478e",
   "metadata": {},
   "outputs": [],
   "source": [
    "style_map = {\n",
    "    'direct': {\n",
    "        'N1': {'color': 'tab:blue',  'marker': 'o', 'linestyle': '-',  'linewidth': 1.5},\n",
    "    },\n",
    "    'iterative_block': {\n",
    "        'N1': {'color': 'tab:green', 'marker': 'o', 'linestyle': '-',  'linewidth': 1.5},\n",
    "        'N2': {'color': 'tab:green', 'marker': 's', 'linestyle': '--', 'linewidth': 1.5},\n",
    "        'N4': {'color': 'tab:green', 'marker': '^', 'linestyle': '-.', 'linewidth': 1.5},\n",
    "    },\n",
    "    'iterative_block_distributed': {\n",
    "        'N1': {'color': 'tab:green', 'marker': 'o', 'linestyle': '-',  'linewidth': 1.5},\n",
    "        'N2': {'color': 'tab:green', 'marker': 's', 'linestyle': '--', 'linewidth': 1.5},\n",
    "        'N4': {'color': 'tab:green', 'marker': '^', 'linestyle': '-.', 'linewidth': 1.5},\n",
    "    }\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d5244a74-7466-4749-ba99-2b49938ed3e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_fine_vmap_comparison(results, style_map, save_name=None):\n",
    "    import numpy as np\n",
    "    import matplotlib.pyplot as plt\n",
    "\n",
    "    dims = sorted(results.keys())\n",
    "    num_dims = len(dims)\n",
    "\n",
    "    fig, axes = plt.subplots(num_dims, 2, figsize=(10, 4 * num_dims))\n",
    "\n",
    "    if num_dims == 1:\n",
    "        axes = axes[np.newaxis, :]  # shape (1, 2)\n",
    "\n",
    "    def get_part(loader):\n",
    "        return loader.get_total_partitions()\n",
    "\n",
    "    for dim_idx, dim in enumerate(dims):\n",
    "        batches = results[dim]\n",
    "        reference_loader_list = batches['N1']['direct']\n",
    "\n",
    "        reference_parts = np.array([get_part(l) for l in reference_loader_list])\n",
    "        reference_times = np.array([\n",
    "            l.run_times['solver_benchmark_fine']['average_time_per_run_seconds']\n",
    "            for l in reference_loader_list\n",
    "        ])\n",
    "        reference_dict = dict(zip(reference_parts, reference_times))\n",
    "\n",
    "        for vmap_idx, use_vmap in enumerate([False, True]):\n",
    "            ax = axes[dim_idx, vmap_idx]\n",
    "\n",
    "            for N_key, solver_dict in batches.items():\n",
    "                for solver_key, loaders in solver_dict.items():\n",
    "                    if use_vmap:\n",
    "                        vmap_suffix = '' if solver_key == 'direct' else '_vmap'\n",
    "                    else:\n",
    "                        vmap_suffix = ''\n",
    "\n",
    "                    key = f'solver_benchmark_fine{vmap_suffix}'\n",
    "                    try:\n",
    "                        times = np.array([\n",
    "                            loader.run_times[key]['average_time_per_run_seconds']\n",
    "                            for loader in loaders\n",
    "                        ])\n",
    "                    except KeyError:\n",
    "                        continue\n",
    "\n",
    "                    num_parts = np.array([get_part(l) for l in loaders])\n",
    "                    common_parts, idx_target, idx_ref = np.intersect1d(\n",
    "                        num_parts, reference_parts, return_indices=True\n",
    "                    )\n",
    "                    if len(common_parts) == 0:\n",
    "                        continue\n",
    "\n",
    "                    matched_times = times[idx_target]\n",
    "                    matched_refs = reference_times[idx_ref]\n",
    "                    speedups = matched_refs / matched_times\n",
    "\n",
    "                    label = f\"split({N_key[-1]})\" if \"iterative\" in solver_key else \"direct(1)\"\n",
    "                    ax.plot(\n",
    "                        num_parts[idx_target],\n",
    "                        speedups,\n",
    "                        label=label,\n",
    "                        **style_map[solver_key][N_key],\n",
    "                    )\n",
    "\n",
    "            ax.set_xlabel(r\"Total Model Partitions ($N_c \\times N_f = 4\\times N_f$)\")\n",
    "\n",
    "            if vmap_idx == 0:\n",
    "                ax.set_title(f\"Distributed Splitting Only\")\n",
    "            else:\n",
    "                ax.set_title(f\"Distributed + Intra-GPU Parallelism (vmap)\")\n",
    "            ax.grid(True)\n",
    "\n",
    "            if vmap_idx == 0:\n",
    "                ax.set_ylabel(f\"Speed-up vs direct\")\n",
    "\n",
    "            if dim_idx == 0 and vmap_idx == 0:\n",
    "                handles, labels = ax.get_legend_handles_labels()\n",
    "                lgd = fig.legend(\n",
    "                    handles,\n",
    "                    labels,\n",
    "                    title=r\"Solver ($\\#$ of GPUs)\",\n",
    "                    ncol=4,\n",
    "                    loc='upper center',\n",
    "                    bbox_to_anchor=(0.5, 1.13),\n",
    "                    frameon=True,\n",
    "                    fontsize=11,\n",
    "                    title_fontsize=12,\n",
    "                    columnspacing=1.0,\n",
    "                    handletextpad=0.5\n",
    "                )\n",
    "\n",
    "\n",
    "    ax = axes[0,0]\n",
    "\n",
    "\n",
    "    ########################################################\n",
    "    x_pos = 430\n",
    "    y_min = 0.77908543\n",
    "    y_max = 2.951596 \n",
    "    s = f\"{y_max/y_min:1.2f}\"\n",
    "    ax.annotate(\n",
    "        '', \n",
    "        xy=(x_pos, y_max), \n",
    "        xytext=(x_pos, y_min),\n",
    "        arrowprops=dict(arrowstyle='<->', color='black', linewidth=1.5, alpha=0.2),\n",
    "        annotation_clip=False,\n",
    "    )\n",
    "    ax.text(\n",
    "        x_pos + 10,                # slight x-offset to avoid overlapping line\n",
    "        (y_max + y_min) / 2,       # midpoint of line\n",
    "        f'{s}$\\\\times$', \n",
    "        va='center', \n",
    "        ha='left',\n",
    "        fontsize=12,\n",
    "        color='black',\n",
    "    )\n",
    "\n",
    "    ########################################################\n",
    "    x_pos = 310\n",
    "    y_min = 0.77908543\n",
    "    y_max = 1.53620329\n",
    "    s = f\"{y_max/y_min:1.2f}\"\n",
    "    ax.annotate(\n",
    "        '', \n",
    "        xy=(x_pos, y_max), \n",
    "        xytext=(x_pos, y_min),\n",
    "        arrowprops=dict(arrowstyle='<->', color='black', linewidth=1.5, alpha=0.2),\n",
    "        annotation_clip=False,\n",
    "    )\n",
    "    ax.text(\n",
    "        x_pos + 10,                # slight x-offset to avoid overlapping line\n",
    "        (y_max + y_min) / 2,       # midpoint of line\n",
    "        f'{s}$\\\\times$', \n",
    "        va='center', \n",
    "        ha='left',\n",
    "        fontsize=12,\n",
    "        color='black',\n",
    "    )\n",
    "\n",
    "    plt.tight_layout()\n",
    "    if save_name:\n",
    "        plt.savefig(f\"{save_name}.pdf\", bbox_extra_artists=(lgd,), bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "for dim, results_i in results_dim.items():\n",
    "    #print(dim)\n",
    "    if dim != str(64):\n",
    "        continue\n",
    "    results = {dim : results_i}\n",
    "    plot_fine_vmap_comparison(results, style_map, save_name=\"parallel_fine_results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e2d29c7-2325-4a45-96c8-194952d670aa",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "hierarchical_pous",
   "language": "python",
   "name": "hierarchical_pous"
  },
  "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
