{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d946490",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Set Seaborn style\n",
    "sns.set_theme(style=\"whitegrid\", context=\"talk\", font_scale=1.1)\n",
    "\n",
    "# Categories and original data\n",
    "categories = [\"PMC VQA\", \"MMMU-Med\", \"MedXpertQA-MM\", \"PathVQA\", \"SLAKE\", \"VQA RAD\"]\n",
    "models_raw = {\n",
    "    # \"GPT-4o\": [58.55, 68.82, 35.95, 72.43, 76.44, 70.22],\n",
    "    # \"MedGemma 27B\": [36.75, 35.88, 12.13, 62.09, 77.40, 72.67],\n",
    "    # \"HuatuoGPT-Vision-34B\": [52.54, 57.06, 21.80, 66.72, 78.85, 74.26],\n",
    "    # \"anonymous 32B\": [54.37, 70.00, 34.60, 68.82, 73.96, 76.96],\n",
    "\n",
    "    # \"GPT-4o\": [58.55, 68.82, 35.95, 72.43, 76.44, 70.22],\n",
    "    # \"MedGemma 27B\": [36.75, 35.88, 12.13, 62.09, 77.40, 72.67],\n",
    "    # \"HuatuoGPT-Vision-34B\": [52.54, 57.06, 21.80, 66.72, 78.85, 74.26],\n",
    "    # \"anonymous 32B\": [54.37, 70.00, 34.60, 68.82, 73.96, 76.96],\n",
    "    \"GPT-4o-mini\": [ 51.90, 63.53, 28.55, 63.33, 75.24, 66.91],\n",
    "    \"HuatuoGPT-Vision-7B\": [53.39, 50.59, 22.00, 63.53, 75.00, 63.60],\n",
    "    # \"Llava Med v1.5 Mistral 7B\": [34.28, 31.37, 22.56, 56.52, 62.82, 56.74],\n",
    "    \"MedGemma 4B\": [42.73, 32.55, 8.17, 59.64, 83.49, 78.55],\n",
    "    \"anonymous 7B\": [50.67, 56.86, 24.43, 66.83, 65.79, 64.71],\n",
    "}\n",
    "\n",
    "# Normalize each dataset column-wise to [0, 100]\n",
    "dataset_max = np.array([max(vals[i] for vals in models_raw.values()) for i in range(len(categories))])\n",
    "models_norm = {\n",
    "    model: (np.array(scores) / dataset_max * 100).tolist()\n",
    "    for model, scores in models_raw.items()\n",
    "}\n",
    "\n",
    "# Radar setup\n",
    "num_vars = len(categories)\n",
    "angles = np.linspace(0, 2 * np.pi, num_vars, endpoint=False).tolist()\n",
    "angles += angles[:1]\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(9, 9), subplot_kw=dict(polar=True))\n",
    "ax.set_theta_offset(np.pi / 2)\n",
    "ax.set_theta_direction(-1)\n",
    "\n",
    "# Colors from Seaborn palette\n",
    "colors = sns.color_palette(\"pastel\", n_colors=len(models_raw))\n",
    "# Plot\n",
    "for (model_name, values), color in zip(models_norm.items(), colors):\n",
    "    values += values[:1]\n",
    "    ax.plot(angles, values, label=model_name, color=color, linewidth=2.2)\n",
    "    ax.fill(angles, values, color=color, alpha=0.15)\n",
    "\n",
    "\n",
    "# Customize axes\n",
    "ax.set_xticks(angles[:-1])\n",
    "ax.set_xticklabels(categories, fontsize=20)\n",
    "ax.tick_params(axis='x', pad=18)\n",
    "\n",
    "ax.set_rlabel_position(0)\n",
    "ax.set_yticks([20, 40, 60, 80, 100])\n",
    "ax.set_yticklabels([\"20%\", \"40%\", \"60%\", \"80%\", \"100%\"], fontsize=20)\n",
    "ax.set_ylim(0, 100)\n",
    "\n",
    "\n",
    "# Title and legend\n",
    "# plt.title(\"Normalized Medical VQA Benchmarks\", size=18, y=1.12, weight='bold')\n",
    "plt.legend(\n",
    "    loc='upper center',\n",
    "    bbox_to_anchor=(0.5, 1.3),\n",
    "    ncol=2,\n",
    "    frameon=False,\n",
    "    fontsize=18,\n",
    "    handlelength=2.5,\n",
    "    handletextpad=0.5,\n",
    "    columnspacing=1.5,\n",
    "    alignment='center'\n",
    ")\n",
    "\n",
    "ax.set_xticklabels([])\n",
    "\n",
    "# ----- place each custom label just outside the outer ring -----\n",
    "offsets = [16] * len(categories)  # Adjust offsets as needed\n",
    "offsets[0] += 1\n",
    "offsets[1] += 5\n",
    "offsets[2] += 5\n",
    "offsets[3] += -8\n",
    "offsets[4] += 2\n",
    "offsets[5] += 2\n",
    "for angle, label, offset in zip(angles[:-1], categories, offsets):\n",
    "    label_r = ax.get_ylim()[1] + offset\n",
    "    ax.text(angle, label_r, label,\n",
    "            ha='center', va='center', clip_on=False,\n",
    "            fontsize=16,\n",
    "            bbox=dict(boxstyle=\"round,pad=0.3\",\n",
    "                      facecolor=\"white\", edgecolor=\"black\", linewidth=1))\n",
    "plt.tight_layout(pad=2)\n",
    "\n",
    "plt.savefig(\"../misc/radar_plot-7b.pdf\", bbox_inches='tight', dpi=300)  # Save the figure\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c35622ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Set Seaborn style\n",
    "sns.set_theme(style=\"whitegrid\", context=\"talk\", font_scale=1.1)\n",
    "\n",
    "# Categories and original data\n",
    "categories = [\"PMC VQA\", \"MMMU-Med\", \"MedXpertQA-MM\", \"PathVQA\", \"SLAKE\", \"VQA RAD\"]\n",
    "models_raw = {\n",
    "    \"GPT-4o\": [58.55, 68.82, 35.95, 72.43, 76.44, 70.22],\n",
    "    \"HuatuoGPT-Vision-34B\": [52.54, 57.06, 21.80, 66.72, 78.85, 74.26],\n",
    "    \"MedGemma 27B\": [36.75, 35.88, 12.13, 62.09, 77.40, 72.67],\n",
    "    \"anonymous 32B\": [54.37, 70.00, 34.60, 68.82, 73.96, 76.96],\n",
    "}\n",
    "\n",
    "# Normalize each dataset column-wise to [0, 100]\n",
    "dataset_max = np.array([max(vals[i] for vals in models_raw.values()) for i in range(len(categories))])\n",
    "models_norm = {\n",
    "    model: (np.array(scores) / dataset_max * 100).tolist()\n",
    "    for model, scores in models_raw.items()\n",
    "}\n",
    "\n",
    "# Radar setup\n",
    "num_vars = len(categories)\n",
    "angles = np.linspace(0, 2 * np.pi, num_vars, endpoint=False).tolist()\n",
    "angles += angles[:1]\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(9, 9), subplot_kw=dict(polar=True))\n",
    "ax.set_theta_offset(np.pi / 2)\n",
    "ax.set_theta_direction(-1)\n",
    "\n",
    "# Colors from Seaborn palette\n",
    "colors = sns.color_palette(\"pastel\", n_colors=len(models_raw))\n",
    "# Plot\n",
    "for (model_name, values), color in zip(models_norm.items(), colors):\n",
    "    values += values[:1]\n",
    "    ax.plot(angles, values, label=model_name, color=color, linewidth=2.2)\n",
    "    ax.fill(angles, values, color=color, alpha=0.15)\n",
    "\n",
    "\n",
    "# Customize axes\n",
    "ax.set_xticks(angles[:-1])\n",
    "ax.set_xticklabels(categories, fontsize=20)\n",
    "ax.tick_params(axis='x', pad=18)\n",
    "\n",
    "ax.set_rlabel_position(0)\n",
    "ax.set_yticks([20, 40, 60, 80, 100])\n",
    "ax.set_yticklabels([\"20%\", \"40%\", \"60%\", \"80%\", \"100%\"], fontsize=20)\n",
    "ax.set_ylim(0, 100)\n",
    "\n",
    "\n",
    "# Title and legend\n",
    "# plt.title(\"Normalized Medical VQA Benchmarks\", size=18, y=1.12, weight='bold')\n",
    "plt.legend(\n",
    "    loc='upper center',\n",
    "    bbox_to_anchor=(0.5, 1.3),\n",
    "    ncol=2,\n",
    "    frameon=False,\n",
    "    fontsize=18,\n",
    "    handlelength=2.5,\n",
    "    handletextpad=0.5,\n",
    "    columnspacing=1.5,\n",
    "    alignment='center'\n",
    ")\n",
    "\n",
    "ax.set_xticklabels([])\n",
    "\n",
    "# ----- place each custom label just outside the outer ring -----\n",
    "offsets = [16] * len(categories)  # Adjust offsets as needed\n",
    "offsets[0] += 1\n",
    "offsets[1] += 5\n",
    "offsets[2] += 5\n",
    "offsets[3] += -8\n",
    "offsets[4] += 2\n",
    "offsets[5] += 2\n",
    "for angle, label, offset in zip(angles[:-1], categories, offsets):\n",
    "    label_r = ax.get_ylim()[1] + offset\n",
    "    ax.text(angle, label_r, label,\n",
    "            ha='center', va='center', clip_on=False,\n",
    "            fontsize=16,\n",
    "            bbox=dict(boxstyle=\"round,pad=0.3\",\n",
    "                      facecolor=\"white\", edgecolor=\"black\", linewidth=1))\n",
    "plt.tight_layout(pad=2)\n",
    "\n",
    "plt.savefig(\"../misc/radar_plot-32b.pdf\", bbox_inches='tight', dpi=300)  # Save the figure"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jupyter",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
