{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2f3c915b-0cc0-4abe-b5cc-543b18e59b10",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import os\n",
    "import numpy\n",
    "import json\n",
    "import re"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5ac7f26b-40ae-4fcf-94f5-4ae027c740c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "root_dir = '/home/richard/Empire-home/code/clap/simulations/imagenet/ablation_rs'\n",
    "x_name = \"rs\"\n",
    "x = list()\n",
    "acc1,acc5 = list(),list()\n",
    "for item in os.listdir(root_dir):\n",
    "    if os.path.isdir(os.path.join(root_dir,item)) and \"run\" in item:\n",
    "        sub_dir = os.path.join(root_dir,item)\n",
    "        lc_dir = os.path.join(sub_dir,\"lc\",\"lr_0.2\")\n",
    "        with open(os.path.join(lc_dir,\"results.json\"),\"r\") as f:\n",
    "            result = json.load(f)\n",
    "        acc1.append(result[\"test_acc1\"])\n",
    "        acc5.append(result[\"test_acc5\"])\n",
    "        match = re.search(x_name + r'-([\\d.]+)', sub_dir)\n",
    "        value = float(match.group(1))\n",
    "        x.append(value)\n",
    "        \n",
    "        \n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "050a44e1-f61d-4e28-82c3-2fd2c31908e6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2rVj+PDhtGjRonTVSqVw7py5wDdoygoREananJ5Z38PDg3r16hEXF+fqmiSXyjiz/ooVMGgQXHIJHD4M3t5WVyQiIuJaZT6z/nvvvYevr6+zp0sVlrOu5KhRCmEiIlK1uWStSSk7la1HbM8eaNfOnDMsJgYaN7a6IhEREdcr17UmRYorKwv69gV/f4UwERERBTEpV1deCV9/bQ7YFxERqerKbWZ9kdy0yIKIiIiCmJST7GyYPt18SlJERERMCmJSLqKi4Omn4aqrzIlcRUREREFMysns2ebXu+8GLy9raxEREakoFMSkzMXGwpdfmtsPP2xpKSIiIhWKgpiUublzwTCgVy9o3drqakRERCoOBTEpU6mp5gLfoHUlRURELqQgJmVq2TI4fRqaNIF+/ayuRkREpGJREJMydeqUOYv+ww+byxqJiIjIeVprsoKrDGtN2u3g4QGBgVZXIiIiUj601qRUGMHBVlcgIiJSMenWpJSJkydh61bzaUkRERHJn4KYlIl58+D662HUKKsrERERqbgUxMTlMjPh7bfN7R49rK1FRESkIlMQE5f7/HM4ehTq1oWBA62uRkREpOJSEBOXy1lXctQo8Pa2thYREZGKTEFMXGrXLvj+e3POsAcesLoaERGRik1BTFxqzhzz67/+BY0aWVuLiIhIRacgJi6TnQ2bNpnbWldSRESkaJrQVVzGwwN+/RWioqBrV6urERERqfgUxMSlqlWD3r2trkJERMQ96NakuMSxY5CRYXUVIiIi7kVBTFxi1Cho0gTWrLG6EhEREfehW5NSagcOwFdfmetKNmtmdTUiIiLuQz1iUmpz55oh7KaboFUrq6sRERFxHwpiUiopKbBwobmtKStERERKRkFMSuWjj+DMGWjaFPr2tboaERER96IgJk4zjPPrSj78sDl1hYiIiBSfgpg4bedOcwJXHx+47z6rqxEREXE/empSnNa+Pfz2mxnGatWyuhoRERH3oyAmpXLlleZLRERESs7tbk0mJiYSERFBaGgoAQEBBAcH06lTJ2bOnEmGk1O7R0REYLPZinzt37+/0Pf566+/eOCBB2jatCk+Pj7UrVuXm266iRUrVjhVV0WWmWl1BSIiIu7PrXrEDh48SPfu3YmNjQXAz8+P9PR0tm/fzvbt21m6dClRUVHUrFnTqff39PSkViH32KpXL/g/19dff83t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SBWIr68v999/PwC//PILt956K7t27SI7O5vs7Gx27tzJzTffzObNmwEcD9hI+Ttz5gzx8fGOV84TyykpKXn2XzgP2FNPPUW9evVISUmhX79+jodlMjIymDt3Li+88AIAo0aNolWrVq4r2GWrVkqFdfDgQcei0B4eHsall15a6Gv69OlWlywloEW/3UtSUpLRtWtXx+/M29vbqFmzpuN7wJg4caLVZUo+UlJSjD59+uT5XXl7exve3t559t155535Lj4t5SNnke+iXsOHD7/o3O3btxu1a9d2tAkMDDQ8PT0d3/fu3dtIS0tzab16Dr4KuHD+otxjGPKjxWpFyo6/vz/r1q3j3XffZfHixezevZvExEQaNmxIWFgYjzzyCF26dLG6TMmHr68vX3/9NStWrGDJkiX8/PPP/P3339hsNho3bsy1117Lv//9b/r162d1qeKkjh07smfPHqZNm8aqVas4fPgw/v7+tGvXjuHDh3Pfffe5vKfaZhgFjBgVERERkTKlAQgiIiIiFlEQExEREbGIgpiIiIiIRRTERERERCyiICYiIiJiEQUxEREREYsoiImIiIhYREFMRERExCIKYiIiIiIWURATERERsYiCmIiIiIhFFMRERERELKIgJiIiImIRBTERkTL25JNPYrPZuOWWWzAMgw8//JCePXtSu3ZtbDYbU6dOtbpEEbFIdasLEBGp7H799VcAmjdvTp8+fYiMjKRatWoEBQVhs9no0KGDtQWKiGVshmEYVhchIlKZ1a5dm9OnTxMQEED16tV55ZVXuOuuu/D39+fUqVP4+Pjg7+9vdZkiYgEFMRGRMnTw4EFCQkIA8PHxYdu2bVx55ZXWFiUiFYbGiImIlKEdO3Y4tv/zn/8ohIlIHgpiIiJlKCeIBQcH89BDD1lcjYhUNApiIiJlKCeI9evXDy8vL4urEZGKRkFMRKQM5QSxHj16WFyJiFRECmIiImXk1KlTHDlyBICrr766yLbjx4+nbdu2+Pv7U6tWLTp16sS8efPKo1QRsYjmERMRKSM5vWFeXl60a9euwHZJSUlcd911JCYmct9999G8eXNOnz7N1q1biYmJKa9yRcQCCmIiImUkJ4hdccUVhY4P++STT9i/fz87duzgqquuKqfqRKQi0K1JEZEykhPEiroteebMGQB++umnMq9JRCoWBTERkTJS3CB255130qJFC0aNGkWzZs14/PHH2bJlS3mUKCIWUxATESkDKSkp7Nu3Dyg6iDVo0IA9e/bw2Wef8Y9//IPFixfTpUsXxowZUx6lioiFtMSRiEgFk5ycTI8ePdi5cydpaWlWlyMiZUg9YiIiFoqPj79on4+PDwANGzYs73JEpJzpqUkREQs9/vjj/Pjjj/Tv35/mzZuTmprKJ598ws8//8yyZcusLk9EypiCmIiIhcLDwzl58iRLlizh1KlT1K1bl44dO7JlyxauvfZaq8sTkTKmMWIiIiIiFtEYMRERERGLKIiJiIiIWERBTERERMQiCmIiIiIiFlEQExEREbGIgpiIiIiIRRTERERERCyiICYiIiJiEQUxEREREYsoiImIiIhYREFMRERExCL/DxeE88NbHdIPAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure()\n",
    "ax1 = fig.add_axes(111)\n",
    "ax1.plot(x,acc1,linestyle='--', marker='o', color='blue')\n",
    "ax1.set_ylabel(\"top 1 accuracy\",fontsize=18)\n",
    "ax1.set_xlabel(\"$r_s$\",fontsize=18)\n",
    "ax1.tick_params(axis='both', labelsize=18)\n",
    "plt.savefig(\"ablation_rs.png\",bbox_inches='tight',dpi=1000) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d1d906d-ce8d-46f9-9433-a30803374d83",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
