{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2058498/2740422639.py:11: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  data = torch.load(file_path)\n"
     ]
    },
    {
     "data": {
      "image/png": "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REZGokOHDqWuY2RkhL///ltjx1RXec6hyZMnY/DgwdizZw8OHDiAWbNmISIiAocPH0bHjh2rtD65XK7xO4mOHz+Ot956C71798a6detga2sLXV1dREVFYceOHWrtU92/iy4uLgCAK1euoEePHsp2e3t72NvbA3gemF6ecwRU7pyVyWSl1sbn9dQtvHRFonj27BmA5//Dq2kcHBygUCiUIxbF0tLSkJGRAQcHB2VbRcKQg4MDHjx4gKdPn6q0X79+Xbm8ullaWsLQ0LDU23qvX78OLS0t5S+ilxVPujUxMYGXl1epL11dXVhaWsLExOS1d69UtC9v3bpV4oGIle3Lpk2bYurUqTh48CCuXLmCgoICLFu2rML7KT5+af1648aNavlZf//999DX18eBAwcwbtw4+Pj4lBqGmzZtCoVCgWvXrlVZLcWPkfjmm28qva+K9G39+vVLfUp1WaOnL/+dB4CbN2+WORmdagcGHap2hYWFOHjwIPT09NS6m6iqDRgwAMDzu6petHz5cgBQuVulXr165X7c/4ABA1BUVIQvv/xSpX3FihWQyWTw8fFRv2g1aWtro1+/fvjpp59UbqNOS0vDjh070LNnzzIvD7q6uqJp06ZYunRpqYG1+Lb24q+w2Lt3L86dO1diveL/cRc/N6Y8/TlgwACkpqZi165dyrZnz55hzZo1MDIygru7+2v38aLc3Fzk5eWptDVt2hTGxsZqPUW7c+fOsLKywoYNG1S237dvH/744w+Vc6iqaGtrQyaTqYxe3LlzB3v27FFZz9fXF1paWpg3b16J4FieUdPy6NGjB958801s3LgRP/30U6nrlPdYFenbpk2b4vr168pzEQAuXbpU6uMPgOfzlV68Rf3MmTOIj48X5e8maQ4vXVGV27dvn/J/2unp6dixYwdu3bqFzz777LVzbMTQvn17BAQEYOPGjcjIyIC7uzvOnDmDrVu3wtfXF3369FGu6+rqivXr12PBggVo1qwZrKys4OnpWep+Bw8ejD59+uDzzz/HnTt30L59exw8eBA//fQTJk+erBwhqW4LFizAoUOH0LNnT3z88cfQ0dHBV199hfz8fCxZsqTM7bS0tPD111/Dx8cHrVu3RlBQEBo2bIj79+/jyJEjMDExUc6PWrhwIQ4ePAh3d3eMHz8eLVu2REpKCmJiYnDixAmYmZmhQ4cO0NbWxuLFi5GZmQm5XA5PT89S5xqNHz8eX331FQIDA5GQkABHR0d89913OHnyJFauXFliHtTr3Lx5E3379sXw4cPRqlUr6Ojo4Mcff0RaWhreeeedinUonk+MXrx4MYKCguDu7o6RI0cqb4F2dHR85Vd6lNeLf69e1L17dzRp0gQDBw7E8uXL0b9/f4waNQrp6elYu3YtmjVrhsuXLyvXb9asGT7//HPMnz8fvXr1gp+fH+RyOc6ePQs7OzvlIw4qa/v27ejfvz98fX2Vo0v169dXPhn5999/L1egqEjfjhs3DsuXL4e3tzeCg4ORnp6ODRs2oHXr1qVOsm/WrBl69uyJjz76CPn5+Vi5ciUsLCwwffp0jfQBiUS8G75I6kq7DVZfX1/o0KGDsH79epVbVwWh7NvLHz58WOp+b9++/crjF99e/jov314uCIJQWFgozJ07V3BychJ0dXUFe3t7ISwsTMjLy1NZLzU1VRg4cKBgbGwsAHjtreZPnz4VpkyZItjZ2Qm6urqCs7OzEBkZWaIvKnp7eXnWBSCEhISUuuz8+fOCt7e3YGRkJBgaGgp9+vQRTp06pbLOy7eXF7tw4YLg5+cnWFhYCHK5XHBwcBCGDx8uxMbGqqx39+5dYezYsYKlpaUgl8uFJk2aCCEhIUJ+fr5ynU2bNglNmjQRtLW1VY5V2m3CaWlpQlBQkNCgQQNBT09PaNu2rRAVFaWyTvFtw6XdNv7i+fbo0SMhJCREcHFxEerVqyeYmpoKXbt2FXbv3l1Gb/6rtNvLi+3atUvo2LGjIJfLBXNzc2H06NEqty8LQvnP05ePV9brxT7YvHmz4OzsLMjlcsHFxUWIiooq9XwXBEHYsmWLstb69esL7u7uwqFDh5TLHRwchIEDB5bYrqxbuEvzzz//CCtXrhTc3NwEExMTQUdHR7CxsREGDRokfPPNN8KzZ8+U6xafbzExMaXuqzx9KwiCsH37dqFJkyaCnp6e0KFDB+HAgQNl3l4eGRkpLFu2TLC3txfkcrnQq1cv4dKlS+X6bFRzyQRBQ2OTRCRpsbGx8PLywvHjx0u9DZiotrpz5w6cnJwQGRmJadOmiV0OaRjn6BBRuaSkpAAAGjRoIHIlRETlxzk6RPRKOTk5+Oabb7Bq1So0atQIzZs3F7skIqJy44gOEb3Sw4cPMXHiRBgYGOD777/nN0cTUa3COTpEREQkWfyvGREREUkWgw4RERFJluQnIysUCjx48ADGxsa16ruLiIiI6jJBEPD06VPY2dlVam6g5IPOgwcPyvyuHiIiIqrZ7t27h0aNGqm9veSDTvGj4O/du1cjv26AiIiISsrKyoK9vX2Fv9LlZZIPOsWXq0xMTBh0iIiIapnKTjvhZGQiIiKSLAYdIiIikiwGHSIiIpIsyc/RKa+ioiIUFhaKXUado6urC21tbbHLICIiiarzQUcQBKSmpiIjI0PsUuosMzMz2NjY8DlHRESkcXU+6BSHHCsrKxgaGvKXbTUSBAG5ublIT08HANja2opcERERSU2dDjpFRUXKkGNhYSF2OXWSgYEBACA9PR1WVla8jEVERBpVpycjF8/JMTQ0FLmSuq24/zlHioiINK1OB51ivFwlLvY/ERFVFQYdIiIikiwGHVIKDAyEr6+v2GUQERFpTJ2ejFyW8HBpH4+IiKiu4IgOERERSRaDTi3l4eGBiRMnYvLkyahfvz6sra2xadMm5OTkICgoCMbGxmjWrBn27dsH4Pmt9MHBwXBycoKBgQFatGiBVatWvfIYCoUCERERym3at2+P7777rjo+HhERkUYw6NRiW7duRYMGDXDmzBlMnDgRH330EYYNG4bu3bvj/Pnz6NevH959913k5uZCoVCgUaNGiImJwbVr1zB79mzMmDEDu3fvLnP/ERER2LZtGzZs2ICrV69iypQpGDNmDI4dO1aNn5KIiEh9MkEQBLEOXlRUhPDwcGzfvh2pqamws7NDYGAgZs6cqbzlWBAEzJkzB5s2bUJGRgZ69OiB9evXw9nZuVzHyMrKgqmpKTIzM2FiYqKyLC8vD7dv34aTkxP09fWV7bVhjo6HhweKiopw/PhxAM/70tTUFH5+fti2bRuA5099trW1RVxcHLp161ZiHxMmTEBqaqpylCYwMBAZGRnYs2cP8vPzYW5ujt9++w1ubm7Kbd577z3k5uZix44dFS+6DGX9HIiIKu1yuPrbtqvEtlRpr/r9XRGiTkZevHgx1q9fj61bt6J169Y4d+4cgoKCYGpqikmTJgEAlixZgtWrV2Pr1q1wcnLCrFmz4O3tjWvXrtX5X4rt2rVT/llbWxsWFhZo27atss3a2hoAlF+xsHbtWmzZsgXJycn4559/UFBQgA4dOpS678TEROTm5uLNN99UaS8oKEDHjh01/EmIiIiqhqhB59SpUxgyZAgGDhwIAHB0dMS3336LM2fOAHg+mrNy5UrMnDkTQ4YMAQBs27YN1tbW2LNnD9555x3Raq8JdHV1Vd7LZDKVtuJRMYVCgZ07d2LatGlYtmwZ3NzcYGxsjMjISMTHx5e67+zsbADAL7/8goYNG6osk8vlmvwYREREVUbUoNO9e3ds3LgRN2/eRPPmzXHp0iWcOHECy5cvBwDcvn0bqamp8PLyUm5jamqKrl27Ii4urtSgk5+fj/z8fOX7rKysqv8gtcDJkyfRvXt3fPzxx8q2pKSkMtdv1aoV5HI5kpOT4e7uXh0lEhERaZyoQeezzz5DVlYWXFxcoK2tjaKiInzxxRcYPXo0gOdzTIB/L8EUs7a2Vi57WUREBObOnVu1hddCzs7O2LZtGw4cOAAnJyf897//xdmzZ+Hk5FTq+sbGxpg2bRqmTJkChUKBnj17IjMzEydPnoSJiQkCAgKq+RMQERFVnKh3Xe3evRvffPMNduzYgfPnz2Pr1q1YunQptm7dqvY+w8LCkJmZqXzdu3dPgxXXXh988AH8/PwwYsQIdO3aFY8fP1YZ3SnN/PnzMWvWLERERKBly5bo378/fvnllzLDERERUU0j6l1X9vb2+OyzzxASEqJsW7BgAbZv347r16/jzz//RNOmTXHhwgWVSbPu7u7o0KHDa58DA6h31xVVL/4ciKjKXA5Xf1vedSUqTd11JeqITm5uLrS0VEvQ1taGQqEAADg5OcHGxgaxsbHK5VlZWYiPj1e55ZmIiIioNKLO0Rk8eDC++OILNG7cGK1bt8aFCxewfPlyjBs3DsDzu4YmT56MBQsWwNnZWXl7uZ2dHb98koiIiF5L1KCzZs0azJo1Cx9//DHS09NhZ2eHDz74ALNnz1auM336dOTk5GD8+PHIyMhAz549sX//fl7iICIiotcSdY5OdeAcnZqPPwciqjKXw9XflnN0RCWJOTpEREREVYlBh4iIiCSLQYeIiIgki0GHiIiIJItBh4iIiCSLQaeWEgQB48ePh7m5OWQyGS5evChKHXfu3BH1+ERERK8i6nN0aqzL4dV7PDVuYdy/fz+io6Nx9OhRNGnSBA0aNNB8XURERLUcg04tlZSUBFtbW3Tv3l3sUoiIiGosXrqqhQIDAzFx4kQkJydDJpPB0dERCoUCERERcHJygoGBAdq3b4/vvvtOuc3Ro0chk8lw4MABdOzYEQYGBvD09ER6ejr27duHli1bwsTEBKNGjUJubq5yu/3796Nnz54wMzODhYUFBg0ahKSkpFfWd+XKFfj4+MDIyAjW1tZ499138ejRoyrrDyIiorIw6NRCq1atwrx589CoUSOkpKTg7NmziIiIwLZt27BhwwZcvXoVU6ZMwZgxY3Ds2DGVbcPDw/Hll1/i1KlTuHfvHoYPH46VK1dix44d+OWXX3Dw4EGsWbNGuX5OTg5CQ0Nx7tw5xMbGQktLC0OHDlV+8erLMjIy4OnpiY4dO+LcuXPYv38/0tLSMHz48CrtEyIiotLw0lUtZGpqCmNjY2hra8PGxgb5+flYuHAhfvvtN+W3ujdp0gQnTpzAV199BXd3d+W2CxYsQI8ePQAAwcHBCAsLQ1JSEpo0aQIAePvtt3HkyBF8+umnAAB/f3+VY2/ZsgWWlpa4du0a2rRpU6K2L7/8Eh07dsTChQtVtrG3t8fNmzfRvHlzzXYGERHRKzDoSEBiYiJyc3Px5ptvqrQXFBSgY8eOKm3t2rVT/tna2hqGhobKkFPcdubMGeX7W7duYfbs2YiPj8ejR4+UIznJycmlBp1Lly7hyJEjMDIyKrEsKSmJQYeIiKoVg44EZGdnAwB++eUXNGzYUGWZXC5Xea+rq6v8s0wmU3lf3PbiZanBgwfDwcEBmzZtgp2dHRQKBdq0aYOCgoIyaxk8eDAWL15cYpmtrW3FPhgREVElMehIQKtWrSCXy5GcnKxymaqyHj9+jBs3bmDTpk3o1asXAODEiROv3KZTp074/vvv4ejoCB0dnl5ERCQuTkaWAGNjY0ybNg1TpkzB1q1bkZSUhPPnz2PNmjXYunWr2vutX78+LCwssHHjRiQmJuLw4cMIDQ195TYhISH4+++/MXLkSJw9exZJSUk4cOAAgoKCUFRUpHYtRERE6uB/uSVi/vz5sLS0REREBP7880+YmZmhU6dOmDFjhtr71NLSws6dOzFp0iS0adMGLVq0wOrVq+Hh4VHmNnZ2djh58iQ+/fRT9OvXD/n5+XBwcED//v2hpcVcTURE1UsmCIIgdhFVKSsrC6ampsjMzISJiYnKsry8PNy+fRtOTk7Q19cXqULiz4GIqszlcPW3VeOp9aQ5r/r9XRH8LzYRERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOAInPx67x2P9ERFRV6nTQKX4q8Ivf1k3Vr7j/X35KMxERUWXV6efoaGtrw8zMDOnp6QAAQ0NDyGQykauqOwRBQG5uLtLT02FmZgZtbW2xSyIiIomp00EHAGxsbABAGXao+pmZmSl/DkRERJpU54OOTCaDra0trKysUFhYKHY5dY6uri5HcoiIqMrU+aBTTFtbm79wiYiIJKZOT0YmIiIiaWPQISIiIsli0CEiIiLJYtAhIiIiyWLQISIiIskSNeg4OjpCJpOVeIWEhAAA8vLyEBISAgsLCxgZGcHf3x9paWlilkxERES1iKhB5+zZs0hJSVG+Dh06BAAYNmwYAGDKlCnYu3cvYmJicOzYMTx48AB+fn5ilkxERES1iKjP0bG0tFR5v2jRIjRt2hTu7u7IzMzE5s2bsWPHDnh6egIAoqKi0LJlS5w+fRrdunUTo2QiIiKqRWrMHJ2CggJs374d48aNg0wmQ0JCAgoLC+Hl5aVcx8XFBY0bN0ZcXJyIlRIREVFtUWOejLxnzx5kZGQgMDAQAJCamgo9PT2YmZmprGdtbY3U1NQy95Ofn4/8/Hzl+6ysrKool4iIiGqBGjOis3nzZvj4+MDOzq5S+4mIiICpqanyZW9vr6EKiYiIqLapEUHn7t27+O233/Dee+8p22xsbFBQUICMjAyVddPS0l75TddhYWHIzMxUvu7du1dVZRMREVENVyOCTlRUFKysrDBw4EBlm6urK3R1dREbG6tsu3HjBpKTk+Hm5lbmvuRyOUxMTFReREREVDeJPkdHoVAgKioKAQEB0NH5txxTU1MEBwcjNDQU5ubmMDExwcSJE+Hm5sY7roiIiKhcRA86v/32G5KTkzFu3LgSy1asWAEtLS34+/sjPz8f3t7eWLdunQhVEhERUW0kEwRBELuIqpSVlQVTU1NkZmbyMhYRUV1zOVz9bdtVYluqNE39/q4Rc3SIiIiIqgKDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJFoMOERERSRaDDhEREUkWgw4RERFJlo7YBRCRZoSHi7MtEVFNxhEdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIs0YPO/fv3MWbMGFhYWMDAwABt27bFuXPnlMsFQcDs2bNha2sLAwMDeHl54datWyJWTERERLWFqEHnyZMn6NGjB3R1dbFv3z5cu3YNy5YtQ/369ZXrLFmyBKtXr8aGDRsQHx+PevXqwdvbG3l5eSJWTkRERLWBqF8BsXjxYtjb2yMqKkrZ5uTkpPyzIAhYuXIlZs6ciSFDhgAAtm3bBmtra+zZswfvvPNOtddMREREtYeoIzr/93//h86dO2PYsGGwsrJCx44dsWnTJuXy27dvIzU1FV5eXso2U1NTdO3aFXFxcaXuMz8/H1lZWSovIiIiqptEHdH5888/sX79eoSGhmLGjBk4e/YsJk2aBD09PQQEBCA1NRUAYG1trbKdtbW1ctnLIiIiMHfu3CqvnYiIqsnlcLEroFpM1BEdhUKBTp06YeHChejYsSPGjx+P999/Hxs2bFB7n2FhYcjMzFS+7t27p8GKiYiIqDYRNejY2tqiVatWKm0tW7ZEcnIyAMDGxgYAkJaWprJOWlqactnL5HI5TExMVF5ERERUN4kadHr06IEbN26otN28eRMODg4Ank9MtrGxQWxsrHJ5VlYW4uPj4ebmVq21EhERUe0j6hydKVOmoHv37li4cCGGDx+OM2fOYOPGjdi4cSMAQCaTYfLkyViwYAGcnZ3h5OSEWbNmwc7ODr6+vmKWTkRERLWAqEHnjTfewI8//oiwsDDMmzcPTk5OWLlyJUaPHq1cZ/r06cjJycH48eORkZGBnj17Yv/+/dDX1xexciIiIqoNZIIgCGIXUZWysrJgamqKzMxMztchSQsPF2dboip3OVyc47YT6bgEQHO/v0X/CggiIiKiqsKgQ0RERJIl6hwdIiKiGutyuPrb8rJXjcERHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLB2xCyCSmvBwcbYlohrkcrj627arxLZUAkd0iIiISLIYdIiIiEiyGHSIiIhIshh0iIiISLI4GZmIOIGaiCSLIzpEREQkWQw6REREJFkMOkRERCRZogad8PBwyGQylZeLi4tyeV5eHkJCQmBhYQEjIyP4+/sjLS1NxIqJiIioNhF9RKd169ZISUlRvk6cOKFcNmXKFOzduxcxMTE4duwYHjx4AD8/PxGrJSIiotpE9LuudHR0YGNjU6I9MzMTmzdvxo4dO+Dp6QkAiIqKQsuWLXH69Gl069atukslIiKiWkb0EZ1bt27Bzs4OTZo0wejRo5GcnAwASEhIQGFhIby8vJTruri4oHHjxoiLiytzf/n5+cjKylJ5ERERUd2kVtD5888/NXLwrl27Ijo6Gvv378f69etx+/Zt9OrVC0+fPkVqair09PRgZmamso21tTVSU1PL3GdERARMTU2VL3t7e43USkRERLWPWkGnWbNm6NOnD7Zv3468vDy1D+7j44Nhw4ahXbt28Pb2xq+//oqMjAzs3r1b7X2GhYUhMzNT+bp3757a+yIiIqLaTa2gc/78ebRr1w6hoaGwsbHBBx98gDNnzlS6GDMzMzRv3hyJiYmwsbFBQUEBMjIyVNZJS0srdU5PMblcDhMTE5UXERER1U1qBZ0OHTpg1apVePDgAbZs2YKUlBT07NkTbdq0wfLly/Hw4UO1isnOzkZSUhJsbW3h6uoKXV1dxMbGKpffuHEDycnJcHNzU2v/REREVLdUajKyjo4O/Pz8EBMTg8WLFyMxMRHTpk2Dvb09xo4di5SUlFduP23aNBw7dgx37tzBqVOnMHToUGhra2PkyJEwNTVFcHAwQkNDceTIESQkJCAoKAhubm6844qIiIjKpVJB59y5c/j4449ha2uL5cuXY9q0aUhKSsKhQ4fw4MEDDBky5JXb//XXXxg5ciRatGiB4cOHw8LCAqdPn4alpSUAYMWKFRg0aBD8/f3Ru3dv2NjY4IcffqhMyURERFSHqPUcneXLlyMqKgo3btzAgAEDsG3bNgwYMABaWs9zk5OTE6Kjo+Ho6PjK/ezcufOVy/X19bF27VqsXbtWnTKJiIiojlMr6Kxfvx7jxo1DYGAgbG1tS13HysoKmzdvrlRxRERERJWhVtC5devWa9fR09NDQECAOrsnIiIi0gi15uhERUUhJiamRHtMTAy2bt1a6aKIiIiINEGtoBMREYEGDRqUaLeyssLChQsrXRQRERGRJqgVdJKTk+Hk5FSi3cHBQfldVURERERiUyvoWFlZ4fLlyyXaL126BAsLi0oXRURERKQJak1GHjlyJCZNmgRjY2P07t0bAHDs2DF88skneOeddzRaIElDeLg42xIRUd2mVtCZP38+7ty5g759+0JH5/kuFAoFxo4dyzk6REREVGOoFXT09PSwa9cuzJ8/H5cuXYKBgQHatm0LBwcHTddHREREpDa1gk6x5s2bo3nz5pqqhYiIiEij1Ao6RUVFiI6ORmxsLNLT06FQKFSWHz58WCPFEREREVWGWkHnk08+QXR0NAYOHIg2bdpAJpNpui4iIiKiSlMr6OzcuRO7d+/GgAEDNF0PERERkcao9RwdPT09NGvWTNO1EBEREWmUWkFn6tSpWLVqFQRB0HQ9RERERBqj1qWrEydO4MiRI9i3bx9at24NXV1dleU//PCDRoojqix1HzbIhxQSEUmDWkHHzMwMQ4cO1XQtRERERBqlVtCJiorSdB1EREREGqfWHB0AePbsGX777Td89dVXePr0KQDgwYMHyM7O1lhxRERERJWh1ojO3bt30b9/fyQnJyM/Px9vvvkmjI2NsXjxYuTn52PDhg2arpOIiIiowtR+YGDnzp1x6dIlWFhYKNuHDh2K999/X2PFEdU1nARNRKRZagWd48eP49SpU9DT01Npd3R0xP379zVSGBEREVFlqTVHR6FQoKioqET7X3/9BWNj40oXRURERKQJagWdfv36YeXKlcr3MpkM2dnZmDNnDr8WgoiIiGoMtS5dLVu2DN7e3mjVqhXy8vIwatQo3Lp1Cw0aNMC3336r6RqJqh3nypRfZfqK/UxEVU2toNOoUSNcunQJO3fuxOXLl5GdnY3g4GCMHj0aBgYGmq6RiIiISC1qBR0A0NHRwZgxYzRZCxEREZFGqRV0tm3b9srlY8eOVasYIiIiIk1S+zk6LyosLERubi709PRgaGjIoCNRnE9BRES1jVp3XT158kTllZ2djRs3bqBnz56cjExEREQ1htrfdfUyZ2dnLFq0qMRoDxEREZFYNBZ0gOcTlB88eKDJXRIRERGpTa05Ov/3f/+n8l4QBKSkpODLL79Ejx49NFIYERERUWWpFXR8fX1V3stkMlhaWsLT0xPLli1Tq5BFixYhLCwMn3zyifKpy3l5eZg6dSp27tyJ/Px8eHt7Y926dbC2tlbrGEREJJLL4WJXQHWUWkFHoVBotIizZ8/iq6++Qrt27VTap0yZgl9++QUxMTEwNTXFhAkT4Ofnh5MnT2r0+ERERCRNGp2jo47s7GyMHj0amzZtQv369ZXtmZmZ2Lx5M5YvXw5PT0+4uroiKioKp06dwunTp0WsmIiIiGoLtUZ0QkNDy73u8uXLX7k8JCQEAwcOhJeXFxYsWKBsT0hIQGFhIby8vJRtLi4uaNy4MeLi4tCtW7dS95efn4/8/Hzl+6ysrHLXSkRERNKiVtC5cOECLly4gMLCQrRo0QIAcPPmTWhra6NTp07K9WQy2Sv3s3PnTpw/fx5nz54tsSw1NRV6enowMzNTabe2tkZqamqZ+4yIiMDcuXMr8Gnqltr40L/aWDMREdUMagWdwYMHw9jYGFu3blVebnry5AmCgoLQq1cvTJ069bX7uHfvHj755BMcOnQI+vr66pRRqrCwMJURp6ysLNjb22ts/0RERFR7qDVHZ9myZYiIiFCZU1O/fn0sWLCg3HddJSQkID09HZ06dYKOjg50dHRw7NgxrF69Gjo6OrC2tkZBQQEyMjJUtktLS4ONjU2Z+5XL5TAxMVF5ERERUd2k1ohOVlYWHj58WKL94cOHePr0abn20bdvX/zvf/9TaQsKCoKLiws+/fRT2NvbQ1dXF7GxsfD39wcA3LhxA8nJyXBzc1OnbCIiIqpj1Ao6Q4cORVBQEJYtW4YuXboAAOLj4/Gf//wHfn5+5dqHsbEx2rRpo9JWr149WFhYKNuDg4MRGhoKc3NzmJiYYOLEiXBzcytzIjIRERHRi9QKOhs2bMC0adMwatQoFBYWPt+Rjg6Cg4MRGRmpseJWrFgBLS0t+Pv7qzwwkIiIiKg8ZIIgCOpunJOTg6SkJABA06ZNUa9ePY0VpilZWVkwNTVFZmYm5+uAdzBRzcLzsQ65HC52BbVHu3CxK6gRNPX7u1IPDExJSUFKSgqcnZ1Rr149VCIzEREREWmcWkHn8ePH6Nu3L5o3b44BAwYgJSUFwPM5NeW5tZyIiIioOqg1R2fKlCnQ1dVFcnIyWrZsqWwfMWIEQkND1f5iTyIiqsEuh4tdAVGFqRV0Dh48iAMHDqBRo0Yq7c7Ozrh7965GCiMiIiKqLLUuXeXk5MDQ0LBE+99//w25XF7pooiIiIg0Qa2g06tXL2zbtk35XiaTQaFQYMmSJejTp4/GiiMiIiKqDLUuXS1ZsgR9+/bFuXPnUFBQgOnTp+Pq1av4+++/cfLkSU3XSERERKQWtUZ02rRpg5s3b6Jnz54YMmQIcnJy4OfnhwsXLqBp06aarpGIiIhILRUe0SksLET//v2xYcMGfP7551VRExEREZFGVHhER1dXF5cvX66KWoiIiIg0Sq1LV2PGjMHmzZs1XQsRERGRRqk1GfnZs2fYsmULfvvtN7i6upb4jqvly5drpDgiIiKiyqhQ0Pnzzz/h6OiIK1euoFOnTgCAmzdvqqwjk8k0Vx0RERFRJVQo6Dg7OyMlJQVHjhwB8PwrH1avXg1ra+sqKY6IiIioMio0R+flbyfft28fcnJyNFoQERERkaaoNUen2MvBh4iIarjL4WJXQFStKjSiI5PJSszB4ZwcIiIiqqkqNKIjCAICAwOVX9yZl5eHDz/8sMRdVz/88IPmKiQiIiJSU4WCTkBAgMr7MWPGaLQYIiIiIk2qUNCJioqqqjqIiIiINE6tJyMTERER1QYMOkRERCRZDDpEREQkWQw6REREJFkMOkRERCRZDDpEREQkWQw6REREJFkMOkRERCRZlfpSTyKiyggPF2dbIqo7OKJDREREksWgQ0RERJLFoENERESSJWrQWb9+Pdq1awcTExOYmJjAzc0N+/btUy7Py8tDSEgILCwsYGRkBH9/f6SlpYlYMREREdUmogadRo0aYdGiRUhISMC5c+fg6emJIUOG4OrVqwCAKVOmYO/evYiJicGxY8fw4MED+Pn5iVkyERER1SKi3nU1ePBglfdffPEF1q9fj9OnT6NRo0bYvHkzduzYAU9PTwBAVFQUWrZsidOnT6Nbt25ilExERES1SI2Zo1NUVISdO3ciJycHbm5uSEhIQGFhIby8vJTruLi4oHHjxoiLiytzP/n5+cjKylJ5ERERUd0ketD53//+ByMjI8jlcnz44Yf48ccf0apVK6SmpkJPTw9mZmYq61tbWyM1NbXM/UVERMDU1FT5sre3r+JPQERERDWV6EGnRYsWuHjxIuLj4/HRRx8hICAA165dU3t/YWFhyMzMVL7u3bunwWqJiIioNhH9ych6enpo1qwZAMDV1RVnz57FqlWrMGLECBQUFCAjI0NlVCctLQ02NjZl7k8ul0Mul1d12URERFQLiD6i8zKFQoH8/Hy4urpCV1cXsbGxymU3btxAcnIy3NzcRKyQiIiIagtRR3TCwsLg4+ODxo0b4+nTp9ixYweOHj2KAwcOwNTUFMHBwQgNDYW5uTlMTEwwceJEuLm58Y4rIiIiKhdRg056ejrGjh2LlJQUmJqaol27djhw4ADefPNNAMCKFSugpaUFf39/5Ofnw9vbG+vWrROzZCIiIqpFRA06mzdvfuVyfX19rF27FmvXrq2mioiIiEhKatwcHSIiIiJNYdAhIiIiyWLQISIiIsli0CEiIiLJYtAhIiIiyWLQISIiIsli0CEiIiLJYtAhIiIiyWLQISIiIsli0CEiIiLJYtAhIiIiyRL1u65IPeHhYldARERUO3BEh4iIiCSLQYeIiIgki0GHiIiIJItzdIiIapvL4WJXQFRrcESHiIiIJItBh4iIiCSLQYeIiIgki3N0iIjUdTlc/W3bVWJbIio3jugQERGRZDHoEBERkWQx6BAREZFkMegQERGRZHEyMhHVbZfDxa6AiKoQR3SIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIsvgcHSKqlcLDxdmWiGoXUUd0IiIi8MYbb8DY2BhWVlbw9fXFjRs3VNbJy8tDSEgILCwsYGRkBH9/f6SlpYlUMREREdUmogadY8eOISQkBKdPn8ahQ4dQWFiIfv36IScnR7nOlClTsHfvXsTExODYsWN48OAB/Pz8RKyaiIiIagtRL13t379f5X10dDSsrKyQkJCA3r17IzMzE5s3b8aOHTvg6ekJAIiKikLLli1x+vRpdOvWTYyyiYiIqJaoUZORMzMzAQDm5uYAgISEBBQWFsLLy0u5jouLCxo3boy4uLhS95Gfn4+srCyVFxEREdVNNWYyskKhwOTJk9GjRw+0adMGAJCamgo9PT2YmZmprGttbY3U1NRS9xMREYG5c+dWdblERERV43K4+tu2q8S2ElVjRnRCQkJw5coV7Ny5s1L7CQsLQ2ZmpvJ17949DVVIREREtU2NGNGZMGECfv75Z/z+++9o1KiRst3GxgYFBQXIyMhQGdVJS0uDjY1NqfuSy+WQy+VVXTIRERHVAqKO6AiCgAkTJuDHH3/E4cOH4eTkpLLc1dUVurq6iI2NVbbduHEDycnJcHNzq+5yiYiIqJYRdUQnJCQEO3bswE8//QRjY2PlvBtTU1MYGBjA1NQUwcHBCA0Nhbm5OUxMTDBx4kS4ubnxjisiqt0uh4tdAVGdIGrQWb9+PQDAw8NDpT0qKgqBgYEAgBUrVkBLSwv+/v7Iz8+Ht7c31q1bV82VEhERUW0katARBOG16+jr62Pt2rVYu3ZtNVREREREUlJj7roiIiIi0jQGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsHbELqKvCw8WugEg6PCzCK7bB5Sopg4hqII7oEBERkWQx6BAREZFkMegQERGRZDHoEBERkWQx6BAREZFkMegQERGRZDHoEBERkWQx6BAREZFkifrAwN9//x2RkZFISEhASkoKfvzxR/j6+iqXC4KAOXPmYNOmTcjIyECPHj2wfv16ODs7i1c0EdV6R4+pt52Hu2brIKKqJ+qITk5ODtq3b4+1a9eWunzJkiVYvXo1NmzYgPj4eNSrVw/e3t7Iy8ur5kqJiIioNhJ1RMfHxwc+Pj6lLhMEAStXrsTMmTMxZMgQAMC2bdtgbW2NPXv24J133qnOUomIiKgWqrFzdG7fvo3U1FR4eXkp20xNTdG1a1fExcWVuV1+fj6ysrJUXkRERFQ31dgv9UxNTQUAWFtbq7RbW1srl5UmIiICc+fOrdLaiKhqVPjLOYmIXqPGjuioKywsDJmZmcrXvXv3xC6JiIiIRFJjg46NjQ0AIC0tTaU9LS1Nuaw0crkcJiYmKi8iIiKqm2ps0HFycoKNjQ1iY2OVbVlZWYiPj4ebm5uIlREREVFtIeocnezsbCQmJirf3759GxcvXoS5uTkaN26MyZMnY8GCBXB2doaTkxNmzZoFOzs7lWftEBEREZVF1KBz7tw59OnTR/k+NDQUABAQEIDo6GhMnz4dOTk5GD9+PDIyMtCzZ0/s378f+vr6YpVMRK/BCcVEVJOIGnQ8PDwgCEKZy2UyGebNm4d58+ZVY1VEREQkFTV2jg4RERFRZTHoEBERkWTV2AcGEhHVNOp+GSjALwSlanI5XL3t2qm5XS3AER0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiw+MLASwsPFroCIiEgDLoerv20Nf9ggR3SIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIsvgcHSIqwcMiXOwSJOfoMfW39XDXXB1EdQ1HdIiIiEiyGHSIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIshh0iIiISLIYdIiIiEiyGHSIiIhIsvjAQCKiGo4PGyRSH0d0iIiISLIYdIiIiEiyGHSIiIhIsmrFHJ21a9ciMjISqampaN++PdasWYMuXbqIXRZRleOXaxIRVU6NH9HZtWsXQkNDMWfOHJw/fx7t27eHt7c30tPTxS6NiIiIargaH3SWL1+O999/H0FBQWjVqhU2bNgAQ0NDbNmyRezSiIiIqIar0UGnoKAACQkJ8PLyUrZpaWnBy8sLcXFxIlZGREREtUGNnqPz6NEjFBUVwdraWqXd2toa169fL3Wb/Px85OfnK99nZmYCALKysjRe3wuHIaoSOf/wJKPKycoWuwKSvCr4/fp8t8/3KwhCpfZTo4OOOiIiIjB37twS7fb29iJUQ0REJHWLqnTvT58+hampqdrb1+ig06BBA2hrayMtLU2lPS0tDTY2NqVuExYWhtDQUOV7hUKBv//+GxYWFpDJZBqtLysrC/b29rh37x5MTEw0uu/ahn2hiv3xL/aFKvbHv9gXqtgf/yrui2vXrsHOzq5S+6rRQUdPTw+urq6IjY2Fr68vgOfBJTY2FhMmTCh1G7lcDrlcrtJmZmZWpXWamJjU+ZOyGPtCFfvjX+wLVeyPf7EvVLE//tWwYUNoaVVuOnGNDjoAEBoaioCAAHTu3BldunTBypUrkZOTg6CgILFLIyIiohquxgedESNG4OHDh5g9ezZSU1PRoUMH7N+/v8QEZSIiIqKX1figAwATJkwo81KVmORyOebMmVPiUlldxL5Qxf74F/tCFfvjX+wLVeyPf2myL2RCZe/bIiIiIqqhavQDA4mIiIgqg0GHiIiIJItBh4iIiCSLQYeIiIgki0Gngu7cuYPg4GA4OTnBwMAATZs2xZw5c1BQUKCy3uXLl9GrVy/o6+vD3t4eS5YsEaniqvfFF1+ge/fuMDQ0LPPhjDKZrMRr586d1VtoNShPXyQnJ2PgwIEwNDSElZUV/vOf/+DZs2fVW6hIHB0dS5wHixZV7ePja5K1a9fC0dER+vr66Nq1K86cOSN2SaIIDw8vcR64uLiIXVa1+P333zF48GDY2dlBJpNhz549KssFQcDs2bNha2sLAwMDeHl54datW+IUWw1e1x+BgYElzpX+/ftX6BgMOhV0/fp1KBQKfPXVV7h69SpWrFiBDRs2YMaMGcp1srKy0K9fPzg4OCAhIQGRkZEIDw/Hxo0bRay86hQUFGDYsGH46KOPXrleVFQUUlJSlK/ip11Lyev6oqioCAMHDkRBQQFOnTqFrVu3Ijo6GrNnz67mSsUzb948lfNg4sSJYpdULXbt2oXQ0FDMmTMH58+fR/v27eHt7Y309HSxSxNF69atVc6DEydOiF1StcjJyUH79u2xdu3aUpcvWbIEq1evxoYNGxAfH4969erB29sbeXl51Vxp9XhdfwBA//79Vc6Vb7/9tmIHEajSlixZIjg5OSnfr1u3Tqhfv76Qn5+vbPv000+FFi1aiFFetYmKihJMTU1LXQZA+PHHH6u1HjGV1Re//vqroKWlJaSmpirb1q9fL5iYmKicL1Ll4OAgrFixQuwyRNGlSxchJCRE+b6oqEiws7MTIiIiRKxKHHPmzBHat28vdhmie/nfRYVCIdjY2AiRkZHKtoyMDEEulwvffvutCBVWr9J+TwQEBAhDhgyp1H45oqMBmZmZMDc3V76Pi4tD7969oaenp2zz9vbGjRs38OTJEzFKrBFCQkLQoEEDdOnSBVu2bIFQBx/hFBcXh7Zt26o82dvb2xtZWVm4evWqiJVVn0WLFsHCwgIdO3ZEZGRknbhsV1BQgISEBHh5eSnbtLS04OXlhbi4OBErE8+tW7dgZ2eHJk2aYPTo0UhOTha7JNHdvn0bqampKueJqakpunbtWmfPEwA4evQorKys0KJFC3z00Ud4/PhxhbavFU9GrskSExOxZs0aLF26VNmWmpoKJycnlfWKf7Glpqaifv361VpjTTBv3jx4enrC0NAQBw8exMcff4zs7GxMmjRJ7NKqVWpqaomvL3nx3JC6SZMmoVOnTjA3N8epU6cQFhaGlJQULF++XOzSqtSjR49QVFRU6s/++vXrIlUlnq5duyI6OhotWrRASkoK5s6di169euHKlSswNjYWuzzRFP8bUNp5Uhf+fShN//794efnBycnJyQlJWHGjBnw8fFBXFwctLW1y7UPjuj8f5999lmpE2ZffL38D9L9+/fRv39/DBs2DO+//75IlVcNdfrjVWbNmoUePXqgY8eO+PTTTzF9+nRERkZW4SfQHE33hdRUpH9CQ0Ph4eGBdu3a4cMPP8SyZcuwZs0a5Ofni/wpqDr5+Phg2LBhaNeuHby9vfHrr78iIyMDu3fvFrs0qmHeeecdvPXWW2jbti18fX3x888/4+zZszh69Gi598ERnf9v6tSpCAwMfOU6TZo0Uf75wYMH6NOnD7p3715ikrGNjQ3S0tJU2orf29jYaKbgKlbR/qiorl27Yv78+cjPz6/x3+uiyb6wsbEpcadNbTs3XlaZ/unatSuePXuGO3fuoEWLFlVQXc3QoEEDaGtrl/rvQm39uWuSmZkZmjdvjsTERLFLEVXxuZCWlgZbW1tle1paGjp06CBSVTVLkyZN0KBBAyQmJqJv377l2oZB5/+ztLSEpaVluda9f/8++vTpA1dXV0RFRUFLS3VgzM3NDZ9//jkKCwuhq6sLADh06BBatGhRay5bVaQ/1HHx4kXUr1+/xoccQLN94ebmhi+++ALp6emwsrIC8PzcMDExQatWrTRyjOpWmf65ePEitLS0lH0hVXp6enB1dUVsbKzybkOFQoHY2Nga+YXF1S07OxtJSUl49913xS5FVE5OTrCxsUFsbKwy2GRlZSE+Pv61d7XWFX/99RceP36sEgRfh0Gngu7fvw8PDw84ODhg6dKlePjwoXJZcRofNWoU5s6di+DgYHz66ae4cuUKVq1ahRUrVohVdpVKTk7G33//jeTkZBQVFeHixYsAgGbNmsHIyAh79+5FWloaunXrBn19fRw6dAgLFy7EtGnTxC28CryuL/r164dWrVrh3XffxZIlS5CamoqZM2ciJCSkVoS+yoiLi0N8fDz69OkDY2NjxMXFYcqUKRgzZkyt+Q9AZYSGhiIgIACdO3dGly5dsHLlSuTk5CAoKEjs0qrdtGnTMHjwYDg4OODBgweYM2cOtLW1MXLkSLFLq3LZ2dkqI1e3b9/GxYsXYW5ujsaNG2Py5MlYsGABnJ2d4eTkhFmzZsHOzk6Sj+MAXt0f5ubmmDt3Lvz9/WFjY4OkpCRMnz4dzZo1g7e3d/kPUql7tuqgqKgoAUCprxddunRJ6NmzpyCXy4WGDRsKixYtEqniqhcQEFBqfxw5ckQQBEHYt2+f0KFDB8HIyEioV6+e0L59e2HDhg1CUVGRuIVXgdf1hSAIwp07dwQfHx/BwMBAaNCggTB16lShsLBQvKKrSUJCgtC1a1fB1NRU0NfXF1q2bCksXLhQyMvLE7u0arNmzRqhcePGgp6entClSxfh9OnTYpckihEjRgi2traCnp6e0LBhQ2HEiBFCYmKi2GVViyNHjpT6b0RAQIAgCM9vMZ81a5ZgbW0tyOVyoW/fvsKNGzfELboKvao/cnNzhX79+gmWlpaCrq6u4ODgILz//vsqj+coD5kg1MF7fImIiKhO4F1XREREJFkMOkRERCRZDDpEREQkWQw6REREJFkMOkRERCRZDDpEREQkWQw6REREJFkMOkRUK3h4eGDy5Mlil0FEtQyDDhFVucGDB6N///6lLjt+/DhkMhkuX75czVURUV3AoENEVS44OBiHDh3CX3/9VWJZVFQUOnfujHbt2olQGRFJHYMOEVW5QYMGwdLSEtHR0Srt2dnZiImJga+vL0aOHImGDRvC0NAQbdu2xbfffvvKfcpkMuzZs0elzczMTOUY9+7dw/Dhw2FmZgZzc3MMGTIEd+7cUS4/evQounTpgnr16sHMzAw9evTA3bt3K/lpiagmYdAhoiqno6ODsWPHIjo6Gi9+vV5MTAyKioowZswYuLq64pdffsGVK1cwfvx4vPvuuzhz5ozaxywsLIS3tzeMjY1x/PhxnDx5EkZGRujfvz8KCgrw7Nkz+Pr6wt3dHZcvX0ZcXBzGjx8PmUymiY9MRDWEjtgFEFHdMG7cOERGRuLYsWPw8PAA8Pyylb+/PxwcHDBt2jTluhMnTsSBAwewe/dudOnSRa3j7dq1CwqFAl9//bUyvERFRcHMzAxHjx5F586dkZmZiUGDBqFp06YAgJYtW1buQxJRjcMRHSKqFi4uLujevTu2bNkCAEhMTMTx48cRHByMoqIizJ8/H23btoW5uTmMjIxw4MABJCcnq328S5cuITExEcbGxjAyMoKRkRHMzc2Rl5eHpKQkmJubIzAwEN7e3hg8eDBWrVqFlJQUTX1cIqohGHSIqNoEBwfj+++/x9OnTxEVFYWmTZvC3d0dkZGRWLVqFT799FMcOXIEFy9ehLe3NwoKCsrcl0wmU7kMBjy/XFUsOzsbrq6uuHjxosrr5s2bGDVqFIDnIzxxcXHo3r07du3ahebNm+P06dNV8+GJSBQMOkRUbYYPHw4tLS3s2LED27Ztw7hx4yCTyXDy5EkMGTIEY8aMQfv27dGkSRPcvHnzlfuytLRUGYG5desWcnNzle87deqEW7duwcrKCs2aNVN5mZqaKtfr2LEjwsLCcOrUKbRp0wY7duzQ/AcnItEw6BBRtTEyMsKIESMQFhaGlJQUBAYGAgCcnZ1x6NAhnDp1Cn/88Qc++OADpKWlvXJfnp6e+PLLL3HhwgWcO3cOH374IXR1dZXLR48ejQYNGmDIkCE4fvw4bt++jaNHj2LSpEn466+/cPv2bYSFhSEuLg53797FwYMHcevWLc7TIZIYBh0iqlbBwcF48uQJvL29YWdnBwCYOXMmOnXqBG9vb3h4eMDGxga+vr6v3M+yZctgb2+PXr16YdSoUZg2bRoMDQ2Vyw0NDfH777+jcePG8PPzQ8uWLREcHIy8vDyYmJjA0NAQ169fh7+/P5o3b47x48cjJCQEH3zwQVV+fCKqZjLh5YvcRERERBLBER0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpIsBh0iIiKSLAYdIiIikiwGHSIiIpKs/wfkPL32QELxLwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import os\n",
    "os.sys.path.append(\"../src\")\n",
    "from fair_PCA import FairPCA\n",
    "from main import *\n",
    "\n",
    "import torch\n",
    "import os\n",
    "exp_path = \"../output/exps/protect=[gender]\"\n",
    "file_path = f\"{exp_path}/extracted_features.pt\"\n",
    "data = torch.load(file_path)\n",
    "protect = list(data.keys())[0]\n",
    "hdim = 800\n",
    "fpca = FairPCA(target_dim = hdim, standardize = False, tradeoff_param = 0)\n",
    "\n",
    "if \"UserStableDiffusion3Pipeline\" not in locals():\n",
    "    pipe = UserStableDiffusion3Pipeline.from_pretrained(\"stabilityai/stable-diffusion-3-medium-diffusers\", torch_dtype=torch.float16)\n",
    "pipe.exp_dir = exp_path\n",
    "pipe.calc_projection_matrix_sg(data[protect], fpca)\n",
    "\n",
    "projections = {}\n",
    "for group in data[protect]:\n",
    "    projections[group] = fpca.nzTXT.matmul(data[protect][group].T)\n",
    "\n",
    "# plot projections with bin plot, each group is a different color. Write code woth matplotlib\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Example data in projections dict\n",
    "\n",
    "# Plot histogram for each group with different colors\n",
    "colors = ['blue', 'orange', 'green', 'red', 'purple', 'brown', 'pink', 'gray', 'olive', 'cyan']\n",
    "for i, group in enumerate(projections):\n",
    "    plt.hist(projections[group], bins=20, alpha=0.5, color=colors[i], label=group)\n",
    "\n",
    "# Labeling the plot\n",
    "plt.xlabel(\"Values\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.legend()\n",
    "plt.title(\"Bin Plot of Projections for Each Group\")\n",
    "\n",
    "# Display the plot\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting matplotlib\n",
      "  Using cached matplotlib-3.7.5-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.metadata (5.7 kB)\n",
      "Collecting contourpy>=1.0.1 (from matplotlib)\n",
      "  Using cached contourpy-1.1.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (5.9 kB)\n",
      "Collecting cycler>=0.10 (from matplotlib)\n",
      "  Using cached cycler-0.12.1-py3-none-any.whl.metadata (3.8 kB)\n",
      "Collecting fonttools>=4.22.0 (from matplotlib)\n",
      "  Downloading fonttools-4.54.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (163 kB)\n",
      "Collecting kiwisolver>=1.0.1 (from matplotlib)\n",
      "  Downloading kiwisolver-1.4.7-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.whl.metadata (6.3 kB)\n",
      "Requirement already satisfied: numpy<2,>=1.20 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from matplotlib) (1.24.4)\n",
      "Requirement already satisfied: packaging>=20.0 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from matplotlib) (24.1)\n",
      "Requirement already satisfied: pillow>=6.2.0 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from matplotlib) (9.5.0)\n",
      "Collecting pyparsing>=2.3.1 (from matplotlib)\n",
      "  Downloading pyparsing-3.1.4-py3-none-any.whl.metadata (5.1 kB)\n",
      "Requirement already satisfied: python-dateutil>=2.7 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from matplotlib) (2.9.0)\n",
      "Collecting importlib-resources>=3.2.0 (from matplotlib)\n",
      "  Downloading importlib_resources-6.4.5-py3-none-any.whl.metadata (4.0 kB)\n",
      "Requirement already satisfied: zipp>=3.1.0 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from importlib-resources>=3.2.0->matplotlib) (3.20.2)\n",
      "Requirement already satisfied: six>=1.5 in /data/zihao.fu/programs/miniconda/envs/fairimg/lib/python3.8/site-packages (from python-dateutil>=2.7->matplotlib) (1.16.0)\n",
      "Using cached matplotlib-3.7.5-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (9.2 MB)\n",
      "Using cached contourpy-1.1.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (301 kB)\n",
      "Using cached cycler-0.12.1-py3-none-any.whl (8.3 kB)\n",
      "Downloading fonttools-4.54.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.7 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m4.7/4.7 MB\u001b[0m \u001b[31m37.8 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading importlib_resources-6.4.5-py3-none-any.whl (36 kB)\n",
      "Downloading kiwisolver-1.4.7-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.whl (1.2 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m1.2/1.2 MB\u001b[0m \u001b[31m35.8 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading pyparsing-3.1.4-py3-none-any.whl (104 kB)\n",
      "Installing collected packages: pyparsing, kiwisolver, importlib-resources, fonttools, cycler, contourpy, matplotlib\n",
      "Successfully installed contourpy-1.1.1 cycler-0.12.1 fonttools-4.54.1 importlib-resources-6.4.5 kiwisolver-1.4.7 matplotlib-3.7.5 pyparsing-3.1.4\n"
     ]
    }
   ],
   "source": [
    "! pip install matplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([635, 2048])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[protect][group].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fairimg",
   "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": 2
}
