{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\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,
   "metadata": {},
   "outputs": [],
   "source": [
    "job_urls = {\n",
    "    \"gpt4o\": \"https://ml.azure.com/experiments/id/50bdc468-77f2-46e4-8087-361a55de71c5/runs/modest_octopus_61d8j3ttyg?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourceGroups/Singularity/providers/Microsoft.MachineLearningServices/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47\", \n",
    "    \"o1mini\": \"https://ml.azure.com/experiments/id/50bdc468-77f2-46e4-8087-361a55de71c5/runs/hungry_stick_f101zj3bks?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourceGroups/Singularity/providers/Microsoft.MachineLearningServices/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47\",\n",
    "    \"cubby_fossa\": \"https://ml.azure.com/runs/happy_moon_q3c9v79gw8?wsid=%2Fsubscriptions%2Facc09744-1ee3-4242-b375-93421c63af0c%2Fresourcegroups%2FSingularity%2Fworkspaces%2FM365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47&reloadCount=3#\",\n",
    "    \"Qwen2.5-7B\": \"https://ml.azure.com/runs/patient_pillow_jgfj2vy6my?wsid=/subscriptions/acc09744-1ee3-4242-b375-93421c63af0c/resourcegroups/Singularity/workspaces/M365Research&tid=72f988bf-86f1-41af-91ab-2d7cd011db47#\",\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "jobs = JobList.from_urls(job_urls.values())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_metrics(job: Job):\n",
    "    return job.get_node(\"confaide\").get_metrics()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics = list(map(get_metrics, jobs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Specify the metric keys to plot\n",
    "categories = [\n",
    "    'tier_1_pearsonr',\n",
    "    'tier_2a_pearsonr',\n",
    "    'tier_2b_pearsonr',\n",
    "    'tier_3_free_response_string_match_mean',\n",
    "    'tier_3_free_response_string_match_worst_case',\n",
    "    'tier_4_error_mean',\n",
    "    'tier_4_error_worst_case',\n",
    "    'tier_4_has_private_info_mean',\n",
    "    'tier_4_has_private_info_worst_case',\n",
    "    'tier_4_no_public_info_mean',\n",
    "    'tier_4_no_public_info_worst_case',\n",
    "]\n",
    "\n",
    "# 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 name, job in zip(job_urls.keys(), metrics):\n",
    "    # Get the values for the specified metrics, defaulting to 0 if a key is missing.\n",
    "    values = [job[cat] for cat in categories]\n",
    "    values += values[:1]  # complete the loop\n",
    "    ax.plot(angles, values, linewidth=1, linestyle='solid', label=name)\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()"
   ]
  }
 ],
 "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": 2
}
