{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eeed1846",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from matplotlib import pyplot as plt\n",
    "# pip install git+https://github.com/microsoft/responsible-ai-toolbox-privacy.git#egg=privacy_estimates[pipelines]\n",
    "from privacy_estimates.experiments.aml import JobList, Job"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40e6104f",
   "metadata": {},
   "outputs": [],
   "source": [
    "job_urls = {\n",
    "    \"qwen-base\": \"https://ml.azure.com/experiments/id/50bdc468-77f2-46e4-8087-361a55de71c5/runs/gray_gold_mhrjx2kvc8?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourceGroups/Singularity/providers/Microsoft.MachineLearningServices/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47#\",\n",
    "    \"qwen-cot\": \"https://ml.azure.com/experiments/id/50bdc468-77f2-46e4-8087-361a55de71c5/runs/funny_chayote_d1mw56sxmd?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourceGroups/Singularity/providers/Microsoft.MachineLearningServices/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47#\",\n",
    "    \"qwen-rl\": \"https://ml.azure.com/runs/zen_rocket_b7rdw20cl4?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourcegroups/Singularity/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47#\",\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a3718a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "jobs = JobList.from_urls(job_urls.values())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49e9bdb4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def postprocess(job: Job):\n",
    "    metrics = job.get_node(\"privacylens\").get_metrics()\n",
    "    return metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bb27273",
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics = [postprocess(job) for job in jobs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edbcd594",
   "metadata": {},
   "outputs": [],
   "source": [
    "categories = [\n",
    "    'info_leakage_rate',\n",
    "    'adjusted_info_leakage_rate',\n",
    "    'average_helpfulness_score',\n",
    "    'binary_helpfulness_rate',\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc74e229",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = pd.DataFrame(metrics)\n",
    "data[\"model\"] = job_urls.keys()\n",
    "data = data[[\"model\"] + categories]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ee20945",
   "metadata": {},
   "outputs": [],
   "source": [
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a2d7084",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Copy this to the results/privacylens.csv on overleaft to update results\n",
    "data.to_csv(\"privacylens.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "526b70b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Number of variables\n",
    "N = len(categories)\n",
    "\n",
    "# Compute angle for each axis in the plot (in radians)\n",
    "angles = np.linspace(0, 2 * np.pi, N, endpoint=False).tolist()\n",
    "angles += angles[:1]  # complete the loop\n",
    "\n",
    "# Create a polar subplot\n",
    "fig, ax = plt.subplots(figsize=(6, 6), subplot_kw=dict(polar=True))\n",
    "\n",
    "# Plot each experiment's metrics\n",
    "for _, row in data.iterrows():\n",
    "    # Get the values for the specified metrics, defaulting to 0 if a key is missing.\n",
    "    values = [row[cat] for cat in categories]\n",
    "    values += values[:1]  # complete the loop\n",
    "    ax.plot(angles, values, linewidth=1, linestyle='solid', label=row['model'])\n",
    "    ax.fill(angles, values, alpha=0.25)\n",
    "\n",
    "# Set the category labels\n",
    "ax.set_xticks(angles[:-1])\n",
    "ax.set_xticklabels(categories)\n",
    "\n",
    "# Add a legend\n",
    "plt.legend(loc='lower right')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a967a89",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "confaide",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
