{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import pickle\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "logs = pd.read_csv(\"./log.txt\", names=(\"experiment_id\", \"d\", \"m\", \"R\", \"n\", \"eta\", \"T\", \"lda_L2\", \"lda\", \"annealing\", \"annealing_interval\", \"log_interval\", \"entropy_evaluation\", \"gpu_id\", \"seed\", \"test_acc\", \"parity\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_info_from_id_file(id):\n",
    "    file_path = f\"./log/{id}.pickle\" \n",
    "    if os.path.exists(file_path): \n",
    "        with open(file_path, 'rb') as f:\n",
    "            log = pickle.load(f)\n",
    "        return float(torch.tensor(log[\"test_acc\"][-1]).mean()) # designate the information you need\n",
    "    else: \n",
    "        return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_427364/3746239685.py:6: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  return float(torch.tensor(log[\"test_acc\"][-1]).mean())\n"
     ]
    }
   ],
   "source": [
    "infos = []\n",
    "for id in logs[\"experiment_id\"]:\n",
    "    info = get_info_from_id_file(id)\n",
    "    infos.append(info)\n",
    "\n",
    "logs[\"Info\"] = infos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8797, 17)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "logs = logs[logs[\"Info\"].notna()]\n",
    "logs = logs[~logs.duplicated(subset=['R', 'n', \"d\", \"seed\"])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "logs[\"d\"] = logs[\"d\"].astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "d_list = [i*5 for i in range(1,31)]\n",
    "n_list = [i*50 for i in range(1,41)]\n",
    "l_list = [0.1/i for i in d_list]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = torch.zeros(30,40)\n",
    "a=0\n",
    "parity=2 # specify k\n",
    "for i in range(len(d_list)):\n",
    "    for j in range(len(n_list)):\n",
    "        for s in range(5):\n",
    "            num = logs[((logs[\"d\"] == d_list[i]) & (logs[\"lda\"] > l_list[i]-0.01) & (logs[\"lda\"] < l_list[i]+0.01) & (logs[\"n\"] == n_list[j]) & (logs[\"seed\"] == s) & (logs[\"parity\"] == parity))].shape[0]\n",
    "            if num < 1:\n",
    "                a+=1\n",
    "                print(num,  d_list[i],  n_list[j],  l_list[i])\n",
    "            else:\n",
    "                X[i,j] += logs[((logs[\"d\"] == d_list[i]) & (logs[\"lda\"] > l_list[i]-0.01) & (logs[\"lda\"] < l_list[i]+0.01) & (logs[\"n\"] == n_list[j]) & (logs[\"seed\"] == s) & (logs[\"parity\"] == parity))][\"Info\"].values[0]/5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>100</th>\n",
       "      <th>200</th>\n",
       "      <th>300</th>\n",
       "      <th>400</th>\n",
       "      <th>500</th>\n",
       "      <th>600</th>\n",
       "      <th>700</th>\n",
       "      <th>800</th>\n",
       "      <th>900</th>\n",
       "      <th>1000</th>\n",
       "      <th>...</th>\n",
       "      <th>2100</th>\n",
       "      <th>2200</th>\n",
       "      <th>2300</th>\n",
       "      <th>2400</th>\n",
       "      <th>2500</th>\n",
       "      <th>2600</th>\n",
       "      <th>2700</th>\n",
       "      <th>2800</th>\n",
       "      <th>2900</th>\n",
       "      <th>3000</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.996492</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.903868</td>\n",
       "      <td>0.999968</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.741536</td>\n",
       "      <td>0.995392</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>0.659276</td>\n",
       "      <td>0.984160</td>\n",
       "      <td>0.999956</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>0.580468</td>\n",
       "      <td>0.912344</td>\n",
       "      <td>0.995448</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>0.539780</td>\n",
       "      <td>0.782836</td>\n",
       "      <td>0.980068</td>\n",
       "      <td>0.999492</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>0.516528</td>\n",
       "      <td>0.679504</td>\n",
       "      <td>0.905940</td>\n",
       "      <td>0.988544</td>\n",
       "      <td>0.999588</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>0.511712</td>\n",
       "      <td>0.630956</td>\n",
       "      <td>0.845632</td>\n",
       "      <td>0.965704</td>\n",
       "      <td>0.998304</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>0.507304</td>\n",
       "      <td>0.574972</td>\n",
       "      <td>0.750136</td>\n",
       "      <td>0.909000</td>\n",
       "      <td>0.986524</td>\n",
       "      <td>0.998804</td>\n",
       "      <td>0.999852</td>\n",
       "      <td>0.999996</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60</th>\n",
       "      <td>0.503384</td>\n",
       "      <td>0.541828</td>\n",
       "      <td>0.664432</td>\n",
       "      <td>0.820516</td>\n",
       "      <td>0.939508</td>\n",
       "      <td>0.987500</td>\n",
       "      <td>0.998616</td>\n",
       "      <td>0.999848</td>\n",
       "      <td>0.999996</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>0.502312</td>\n",
       "      <td>0.533444</td>\n",
       "      <td>0.644556</td>\n",
       "      <td>0.787552</td>\n",
       "      <td>0.917368</td>\n",
       "      <td>0.987520</td>\n",
       "      <td>0.996628</td>\n",
       "      <td>0.999532</td>\n",
       "      <td>0.999980</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>70</th>\n",
       "      <td>0.502948</td>\n",
       "      <td>0.516400</td>\n",
       "      <td>0.573288</td>\n",
       "      <td>0.689808</td>\n",
       "      <td>0.824608</td>\n",
       "      <td>0.922460</td>\n",
       "      <td>0.969064</td>\n",
       "      <td>0.991100</td>\n",
       "      <td>0.997808</td>\n",
       "      <td>0.999884</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75</th>\n",
       "      <td>0.502924</td>\n",
       "      <td>0.514580</td>\n",
       "      <td>0.560404</td>\n",
       "      <td>0.654572</td>\n",
       "      <td>0.779576</td>\n",
       "      <td>0.875068</td>\n",
       "      <td>0.944016</td>\n",
       "      <td>0.977836</td>\n",
       "      <td>0.994584</td>\n",
       "      <td>0.998832</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>80</th>\n",
       "      <td>0.501828</td>\n",
       "      <td>0.510344</td>\n",
       "      <td>0.548112</td>\n",
       "      <td>0.616612</td>\n",
       "      <td>0.728520</td>\n",
       "      <td>0.834552</td>\n",
       "      <td>0.903412</td>\n",
       "      <td>0.955252</td>\n",
       "      <td>0.979076</td>\n",
       "      <td>0.992708</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>0.501460</td>\n",
       "      <td>0.508596</td>\n",
       "      <td>0.539824</td>\n",
       "      <td>0.594104</td>\n",
       "      <td>0.682228</td>\n",
       "      <td>0.793276</td>\n",
       "      <td>0.863432</td>\n",
       "      <td>0.939472</td>\n",
       "      <td>0.975796</td>\n",
       "      <td>0.989156</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>90</th>\n",
       "      <td>0.501908</td>\n",
       "      <td>0.505980</td>\n",
       "      <td>0.526848</td>\n",
       "      <td>0.568232</td>\n",
       "      <td>0.640928</td>\n",
       "      <td>0.727524</td>\n",
       "      <td>0.829604</td>\n",
       "      <td>0.899504</td>\n",
       "      <td>0.937444</td>\n",
       "      <td>0.975876</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>0.501664</td>\n",
       "      <td>0.506264</td>\n",
       "      <td>0.517576</td>\n",
       "      <td>0.552420</td>\n",
       "      <td>0.611736</td>\n",
       "      <td>0.690720</td>\n",
       "      <td>0.782136</td>\n",
       "      <td>0.855728</td>\n",
       "      <td>0.907364</td>\n",
       "      <td>0.944480</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>0.501764</td>\n",
       "      <td>0.504544</td>\n",
       "      <td>0.513032</td>\n",
       "      <td>0.534380</td>\n",
       "      <td>0.581716</td>\n",
       "      <td>0.658964</td>\n",
       "      <td>0.727924</td>\n",
       "      <td>0.803984</td>\n",
       "      <td>0.874452</td>\n",
       "      <td>0.918404</td>\n",
       "      <td>...</td>\n",
       "      <td>0.999988</td>\n",
       "      <td>0.999996</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>105</th>\n",
       "      <td>0.499800</td>\n",
       "      <td>0.502288</td>\n",
       "      <td>0.511248</td>\n",
       "      <td>0.528128</td>\n",
       "      <td>0.566140</td>\n",
       "      <td>0.623988</td>\n",
       "      <td>0.683008</td>\n",
       "      <td>0.763656</td>\n",
       "      <td>0.844584</td>\n",
       "      <td>0.893096</td>\n",
       "      <td>...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>110</th>\n",
       "      <td>0.500296</td>\n",
       "      <td>0.502524</td>\n",
       "      <td>0.507208</td>\n",
       "      <td>0.516516</td>\n",
       "      <td>0.547432</td>\n",
       "      <td>0.588184</td>\n",
       "      <td>0.651200</td>\n",
       "      <td>0.718372</td>\n",
       "      <td>0.796716</td>\n",
       "      <td>0.866656</td>\n",
       "      <td>...</td>\n",
       "      <td>0.999984</td>\n",
       "      <td>0.999996</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>115</th>\n",
       "      <td>0.500272</td>\n",
       "      <td>0.502612</td>\n",
       "      <td>0.505472</td>\n",
       "      <td>0.513436</td>\n",
       "      <td>0.534716</td>\n",
       "      <td>0.566680</td>\n",
       "      <td>0.628620</td>\n",
       "      <td>0.684664</td>\n",
       "      <td>0.749348</td>\n",
       "      <td>0.804060</td>\n",
       "      <td>...</td>\n",
       "      <td>0.999304</td>\n",
       "      <td>0.999672</td>\n",
       "      <td>0.999844</td>\n",
       "      <td>0.999904</td>\n",
       "      <td>0.999968</td>\n",
       "      <td>0.999988</td>\n",
       "      <td>0.999984</td>\n",
       "      <td>0.999992</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>120</th>\n",
       "      <td>0.502036</td>\n",
       "      <td>0.503344</td>\n",
       "      <td>0.505984</td>\n",
       "      <td>0.513452</td>\n",
       "      <td>0.530656</td>\n",
       "      <td>0.557516</td>\n",
       "      <td>0.593848</td>\n",
       "      <td>0.644404</td>\n",
       "      <td>0.699964</td>\n",
       "      <td>0.746944</td>\n",
       "      <td>...</td>\n",
       "      <td>0.995760</td>\n",
       "      <td>0.997696</td>\n",
       "      <td>0.998584</td>\n",
       "      <td>0.999076</td>\n",
       "      <td>0.999488</td>\n",
       "      <td>0.999656</td>\n",
       "      <td>0.999820</td>\n",
       "      <td>0.999880</td>\n",
       "      <td>0.999968</td>\n",
       "      <td>0.999976</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125</th>\n",
       "      <td>0.499636</td>\n",
       "      <td>0.501356</td>\n",
       "      <td>0.503324</td>\n",
       "      <td>0.507004</td>\n",
       "      <td>0.518548</td>\n",
       "      <td>0.539200</td>\n",
       "      <td>0.573056</td>\n",
       "      <td>0.607656</td>\n",
       "      <td>0.654200</td>\n",
       "      <td>0.707840</td>\n",
       "      <td>...</td>\n",
       "      <td>0.992476</td>\n",
       "      <td>0.995932</td>\n",
       "      <td>0.997736</td>\n",
       "      <td>0.998768</td>\n",
       "      <td>0.999292</td>\n",
       "      <td>0.999592</td>\n",
       "      <td>0.999796</td>\n",
       "      <td>0.999880</td>\n",
       "      <td>0.999972</td>\n",
       "      <td>0.999972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130</th>\n",
       "      <td>0.501040</td>\n",
       "      <td>0.500876</td>\n",
       "      <td>0.503660</td>\n",
       "      <td>0.508344</td>\n",
       "      <td>0.516912</td>\n",
       "      <td>0.532296</td>\n",
       "      <td>0.557328</td>\n",
       "      <td>0.592820</td>\n",
       "      <td>0.638368</td>\n",
       "      <td>0.691228</td>\n",
       "      <td>...</td>\n",
       "      <td>0.991568</td>\n",
       "      <td>0.995040</td>\n",
       "      <td>0.996888</td>\n",
       "      <td>0.997720</td>\n",
       "      <td>0.998668</td>\n",
       "      <td>0.999200</td>\n",
       "      <td>0.999516</td>\n",
       "      <td>0.999712</td>\n",
       "      <td>0.999828</td>\n",
       "      <td>0.999868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>135</th>\n",
       "      <td>0.499656</td>\n",
       "      <td>0.500508</td>\n",
       "      <td>0.503536</td>\n",
       "      <td>0.506696</td>\n",
       "      <td>0.512448</td>\n",
       "      <td>0.525012</td>\n",
       "      <td>0.547736</td>\n",
       "      <td>0.574128</td>\n",
       "      <td>0.604892</td>\n",
       "      <td>0.638524</td>\n",
       "      <td>...</td>\n",
       "      <td>0.975228</td>\n",
       "      <td>0.985504</td>\n",
       "      <td>0.989832</td>\n",
       "      <td>0.993832</td>\n",
       "      <td>0.996192</td>\n",
       "      <td>0.997300</td>\n",
       "      <td>0.998360</td>\n",
       "      <td>0.999000</td>\n",
       "      <td>0.999324</td>\n",
       "      <td>0.999488</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>140</th>\n",
       "      <td>0.501616</td>\n",
       "      <td>0.502580</td>\n",
       "      <td>0.504588</td>\n",
       "      <td>0.504788</td>\n",
       "      <td>0.511184</td>\n",
       "      <td>0.520436</td>\n",
       "      <td>0.536192</td>\n",
       "      <td>0.556940</td>\n",
       "      <td>0.585420</td>\n",
       "      <td>0.613020</td>\n",
       "      <td>...</td>\n",
       "      <td>0.965752</td>\n",
       "      <td>0.975240</td>\n",
       "      <td>0.982124</td>\n",
       "      <td>0.988084</td>\n",
       "      <td>0.991920</td>\n",
       "      <td>0.994868</td>\n",
       "      <td>0.996408</td>\n",
       "      <td>0.997408</td>\n",
       "      <td>0.998348</td>\n",
       "      <td>0.999012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>145</th>\n",
       "      <td>0.499316</td>\n",
       "      <td>0.501044</td>\n",
       "      <td>0.501728</td>\n",
       "      <td>0.504932</td>\n",
       "      <td>0.510568</td>\n",
       "      <td>0.519208</td>\n",
       "      <td>0.533412</td>\n",
       "      <td>0.552972</td>\n",
       "      <td>0.581124</td>\n",
       "      <td>0.610760</td>\n",
       "      <td>...</td>\n",
       "      <td>0.962884</td>\n",
       "      <td>0.974456</td>\n",
       "      <td>0.980360</td>\n",
       "      <td>0.986860</td>\n",
       "      <td>0.990584</td>\n",
       "      <td>0.993840</td>\n",
       "      <td>0.996084</td>\n",
       "      <td>0.997200</td>\n",
       "      <td>0.998204</td>\n",
       "      <td>0.998812</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>150</th>\n",
       "      <td>0.500868</td>\n",
       "      <td>0.499804</td>\n",
       "      <td>0.501516</td>\n",
       "      <td>0.503848</td>\n",
       "      <td>0.508668</td>\n",
       "      <td>0.515400</td>\n",
       "      <td>0.526920</td>\n",
       "      <td>0.541828</td>\n",
       "      <td>0.565076</td>\n",
       "      <td>0.589944</td>\n",
       "      <td>...</td>\n",
       "      <td>0.942316</td>\n",
       "      <td>0.954144</td>\n",
       "      <td>0.966680</td>\n",
       "      <td>0.975316</td>\n",
       "      <td>0.981492</td>\n",
       "      <td>0.985928</td>\n",
       "      <td>0.989916</td>\n",
       "      <td>0.992928</td>\n",
       "      <td>0.994588</td>\n",
       "      <td>0.996308</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>30 rows × 30 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         100       200       300       400       500       600       700   \\\n",
       "5    1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000   \n",
       "10   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000   \n",
       "15   0.996492  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000   \n",
       "20   0.903868  0.999968  1.000000  1.000000  1.000000  1.000000  1.000000   \n",
       "25   0.741536  0.995392  1.000000  1.000000  1.000000  1.000000  1.000000   \n",
       "30   0.659276  0.984160  0.999956  1.000000  1.000000  1.000000  1.000000   \n",
       "35   0.580468  0.912344  0.995448  1.000000  1.000000  1.000000  1.000000   \n",
       "40   0.539780  0.782836  0.980068  0.999492  1.000000  1.000000  1.000000   \n",
       "45   0.516528  0.679504  0.905940  0.988544  0.999588  1.000000  1.000000   \n",
       "50   0.511712  0.630956  0.845632  0.965704  0.998304  1.000000  1.000000   \n",
       "55   0.507304  0.574972  0.750136  0.909000  0.986524  0.998804  0.999852   \n",
       "60   0.503384  0.541828  0.664432  0.820516  0.939508  0.987500  0.998616   \n",
       "65   0.502312  0.533444  0.644556  0.787552  0.917368  0.987520  0.996628   \n",
       "70   0.502948  0.516400  0.573288  0.689808  0.824608  0.922460  0.969064   \n",
       "75   0.502924  0.514580  0.560404  0.654572  0.779576  0.875068  0.944016   \n",
       "80   0.501828  0.510344  0.548112  0.616612  0.728520  0.834552  0.903412   \n",
       "85   0.501460  0.508596  0.539824  0.594104  0.682228  0.793276  0.863432   \n",
       "90   0.501908  0.505980  0.526848  0.568232  0.640928  0.727524  0.829604   \n",
       "95   0.501664  0.506264  0.517576  0.552420  0.611736  0.690720  0.782136   \n",
       "100  0.501764  0.504544  0.513032  0.534380  0.581716  0.658964  0.727924   \n",
       "105  0.499800  0.502288  0.511248  0.528128  0.566140  0.623988  0.683008   \n",
       "110  0.500296  0.502524  0.507208  0.516516  0.547432  0.588184  0.651200   \n",
       "115  0.500272  0.502612  0.505472  0.513436  0.534716  0.566680  0.628620   \n",
       "120  0.502036  0.503344  0.505984  0.513452  0.530656  0.557516  0.593848   \n",
       "125  0.499636  0.501356  0.503324  0.507004  0.518548  0.539200  0.573056   \n",
       "130  0.501040  0.500876  0.503660  0.508344  0.516912  0.532296  0.557328   \n",
       "135  0.499656  0.500508  0.503536  0.506696  0.512448  0.525012  0.547736   \n",
       "140  0.501616  0.502580  0.504588  0.504788  0.511184  0.520436  0.536192   \n",
       "145  0.499316  0.501044  0.501728  0.504932  0.510568  0.519208  0.533412   \n",
       "150  0.500868  0.499804  0.501516  0.503848  0.508668  0.515400  0.526920   \n",
       "\n",
       "         800       900       1000  ...      2100      2200      2300  \\\n",
       "5    1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "10   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "15   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "20   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "25   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "30   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "35   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "40   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "45   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "50   1.000000  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "55   0.999996  1.000000  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "60   0.999848  0.999996  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "65   0.999532  0.999980  1.000000  ...  1.000000  1.000000  1.000000   \n",
       "70   0.991100  0.997808  0.999884  ...  1.000000  1.000000  1.000000   \n",
       "75   0.977836  0.994584  0.998832  ...  1.000000  1.000000  1.000000   \n",
       "80   0.955252  0.979076  0.992708  ...  1.000000  1.000000  1.000000   \n",
       "85   0.939472  0.975796  0.989156  ...  1.000000  1.000000  1.000000   \n",
       "90   0.899504  0.937444  0.975876  ...  1.000000  1.000000  1.000000   \n",
       "95   0.855728  0.907364  0.944480  ...  1.000000  1.000000  1.000000   \n",
       "100  0.803984  0.874452  0.918404  ...  0.999988  0.999996  1.000000   \n",
       "105  0.763656  0.844584  0.893096  ...  1.000000  1.000000  1.000000   \n",
       "110  0.718372  0.796716  0.866656  ...  0.999984  0.999996  1.000000   \n",
       "115  0.684664  0.749348  0.804060  ...  0.999304  0.999672  0.999844   \n",
       "120  0.644404  0.699964  0.746944  ...  0.995760  0.997696  0.998584   \n",
       "125  0.607656  0.654200  0.707840  ...  0.992476  0.995932  0.997736   \n",
       "130  0.592820  0.638368  0.691228  ...  0.991568  0.995040  0.996888   \n",
       "135  0.574128  0.604892  0.638524  ...  0.975228  0.985504  0.989832   \n",
       "140  0.556940  0.585420  0.613020  ...  0.965752  0.975240  0.982124   \n",
       "145  0.552972  0.581124  0.610760  ...  0.962884  0.974456  0.980360   \n",
       "150  0.541828  0.565076  0.589944  ...  0.942316  0.954144  0.966680   \n",
       "\n",
       "         2400      2500      2600      2700      2800      2900      3000  \n",
       "5    1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "10   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "15   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "20   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "25   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "30   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "35   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "40   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "45   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "50   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "55   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "60   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "65   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "70   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "75   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "80   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "85   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "90   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "95   1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "100  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "105  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "110  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  1.000000  \n",
       "115  0.999904  0.999968  0.999988  0.999984  0.999992  1.000000  1.000000  \n",
       "120  0.999076  0.999488  0.999656  0.999820  0.999880  0.999968  0.999976  \n",
       "125  0.998768  0.999292  0.999592  0.999796  0.999880  0.999972  0.999972  \n",
       "130  0.997720  0.998668  0.999200  0.999516  0.999712  0.999828  0.999868  \n",
       "135  0.993832  0.996192  0.997300  0.998360  0.999000  0.999324  0.999488  \n",
       "140  0.988084  0.991920  0.994868  0.996408  0.997408  0.998348  0.999012  \n",
       "145  0.986860  0.990584  0.993840  0.996084  0.997200  0.998204  0.998812  \n",
       "150  0.975316  0.981492  0.985928  0.989916  0.992928  0.994588  0.996308  \n",
       "\n",
       "[30 rows x 30 columns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "X = pd.DataFrame(data=X, index=d_list, columns=n_list).sort_index(axis=1).sort_index(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure()\n",
    "sns.set(rc = {'figure.figsize':(80,60)})\n",
    "ax = sns.heatmap(X, vmax=1.0, vmin=0.5)\n",
    "ax.set_xticklabels(ax.get_xticklabels(),rotation = 90, fontsize = 40)\n",
    "ax.set_yticklabels(ax.get_yticklabels(), fontsize = 40)\n",
    "cbar = ax.collections[0].colorbar\n",
    "cbar.ax.tick_params(labelsize=40)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.9.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
