{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "678b0135-563e-4656-a338-103de6e6bc74",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('/workspace/XXXX-1/Finite-groups/src')\n",
    "from named_groups import *\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3b768244-abd3-464f-a513-03d19b8da5b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = gapS(5)\n",
    "#g = smallgrp(120, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dfdcddc5-7eb9-439c-a09f-6b49b8959959",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing subgroups from gap_repr\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing orders: 100%|██████████| 19/19 [00:00<00:00, 3499.09it/s]\n",
      "Computing elements: 100%|██████████| 17/17 [00:00<00:00, 10857.80it/s]\n"
     ]
    }
   ],
   "source": [
    "subgroups = g.get_subgroups_idx(conjugates=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3277a0ab-4dcc-4ac4-8fa2-399480f150e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "REAL\n",
      "REAL\n",
      "REAL\n",
      "REAL\n",
      "REAL\n",
      "REAL\n",
      "REAL\n"
     ]
    }
   ],
   "source": [
    "irreps = g.get_real_irreps(verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "0970022b-bb51-4c42-912d-e8a874ea2ab7",
   "metadata": {},
   "outputs": [],
   "source": [
    "subgroups = dict(sorted(subgroups.items(), key = lambda t: len(t[1])))\n",
    "irreps = dict(sorted(irreps.items(), key = lambda t: int(t[0].split('d')[0])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a444ecbd-d81f-4394-b3e3-b4c2f9d67a30",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = [\n",
    "    [\n",
    "        irrep[list(subgroup),:,:].mean(dim=0).norm().item()\n",
    "        for subgroup in subgroups.values()\n",
    "    ]\n",
    "    for irrep in irreps.values()\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "8d225637-9809-4f08-a368-dcd2cc6e0e11",
   "metadata": {},
   "outputs": [],
   "source": [
    "table = pd.DataFrame(data=data, index=irreps.keys(), columns=subgroups.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "2bc79e84-d424-4c2c-84e1-2816d9e2d777",
   "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>1</th>\n",
       "      <th>C2_0</th>\n",
       "      <th>C2_1</th>\n",
       "      <th>C3_0</th>\n",
       "      <th>C2xC2_0</th>\n",
       "      <th>C2xC2_1</th>\n",
       "      <th>C4_0</th>\n",
       "      <th>C5_0</th>\n",
       "      <th>C6_0</th>\n",
       "      <th>S3_0</th>\n",
       "      <th>S3_1</th>\n",
       "      <th>D8_0</th>\n",
       "      <th>D10_0</th>\n",
       "      <th>A4_0</th>\n",
       "      <th>D12_0</th>\n",
       "      <th>C5:C4_0</th>\n",
       "      <th>S4_0</th>\n",
       "      <th>A5_0</th>\n",
       "      <th>S5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1d-0</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1d-1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4d-0</th>\n",
       "      <td>2.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>3.193771e-08</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>7.001961e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>3.658463e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>3.311110e-08</td>\n",
       "      <td>6.769786e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>2.856056e-08</td>\n",
       "      <td>5.280985e-08</td>\n",
       "      <td>2.293063e-08</td>\n",
       "      <td>4.484193e-08</td>\n",
       "      <td>1.264405e-08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4d-1</th>\n",
       "      <td>2.000000</td>\n",
       "      <td>1.732051</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.414213</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>1.414214e+00</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>5.734528e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.414213e+00</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>5.373207e-08</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>3.189858e-08</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>4.031909e-08</td>\n",
       "      <td>3.800445e-08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5d-0</th>\n",
       "      <td>2.236068</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.732051</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.414214e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>7.763815e-08</td>\n",
       "      <td>6.419148e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>5.916322e-08</td>\n",
       "      <td>5.692168e-08</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>4.996458e-08</td>\n",
       "      <td>3.736697e-08</td>\n",
       "      <td>2.906290e-08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5d-1</th>\n",
       "      <td>2.236068</td>\n",
       "      <td>1.732051</td>\n",
       "      <td>1.732051</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.414214e+00</td>\n",
       "      <td>1.414213e+00</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>5.453872e-08</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>4.315552e-08</td>\n",
       "      <td>3.156437e-08</td>\n",
       "      <td>2.994376e-08</td>\n",
       "      <td>1.647666e-08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6d-0</th>\n",
       "      <td>2.449490</td>\n",
       "      <td>1.732051</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>8.985038e-08</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.414213e+00</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>9.999999e-01</td>\n",
       "      <td>7.770701e-08</td>\n",
       "      <td>6.243520e-08</td>\n",
       "      <td>5.673704e-08</td>\n",
       "      <td>6.886056e-08</td>\n",
       "      <td>5.028046e-08</td>\n",
       "      <td>2.651507e-08</td>\n",
       "      <td>5.617007e-08</td>\n",
       "      <td>2.213302e-08</td>\n",
       "      <td>2.045434e-08</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             1      C2_0      C2_1      C3_0       C2xC2_0       C2xC2_1  \\\n",
       "1d-0  1.000000  0.000000  1.000000  1.000000  1.000000e+00  0.000000e+00   \n",
       "1d-1  1.000000  1.000000  1.000000  1.000000  1.000000e+00  1.000000e+00   \n",
       "4d-0  2.000000  1.000000  1.414214  1.414214  1.000000e+00  3.193771e-08   \n",
       "4d-1  2.000000  1.732051  1.414214  1.414213  9.999999e-01  1.414214e+00   \n",
       "5d-0  2.236068  1.414214  1.732051  1.000000  1.414214e+00  1.000000e+00   \n",
       "5d-1  2.236068  1.732051  1.732051  1.000000  1.414214e+00  1.414213e+00   \n",
       "6d-0  2.449490  1.732051  1.414214  1.414214  8.985038e-08  9.999999e-01   \n",
       "\n",
       "          C4_0          C5_0          C6_0          S3_0          S3_1  \\\n",
       "1d-0  0.000000  1.000000e+00  0.000000e+00  0.000000e+00  1.000000e+00   \n",
       "1d-1  1.000000  1.000000e+00  1.000000e+00  1.000000e+00  1.000000e+00   \n",
       "4d-0  1.000000  7.001961e-08  1.000000e+00  3.658463e-08  1.000000e+00   \n",
       "4d-1  1.000000  5.734528e-08  1.000000e+00  1.414213e+00  9.999999e-01   \n",
       "5d-0  1.414214  1.000000e+00  7.763815e-08  6.419148e-08  1.000000e+00   \n",
       "5d-1  1.000000  1.000000e+00  9.999999e-01  1.000000e+00  9.999999e-01   \n",
       "6d-0  1.000000  1.414213e+00  9.999999e-01  9.999999e-01  7.770701e-08   \n",
       "\n",
       "              D8_0         D10_0          A4_0         D12_0       C5:C4_0  \\\n",
       "1d-0  0.000000e+00  1.000000e+00  1.000000e+00  0.000000e+00  0.000000e+00   \n",
       "1d-1  1.000000e+00  1.000000e+00  1.000000e+00  1.000000e+00  1.000000e+00   \n",
       "4d-0  3.311110e-08  6.769786e-08  1.000000e+00  2.856056e-08  5.280985e-08   \n",
       "4d-1  9.999999e-01  5.373207e-08  9.999999e-01  1.000000e+00  3.189858e-08   \n",
       "5d-0  1.000000e+00  1.000000e+00  5.916322e-08  5.692168e-08  1.000000e+00   \n",
       "5d-1  1.000000e+00  1.000000e+00  5.453872e-08  9.999999e-01  4.315552e-08   \n",
       "6d-0  6.243520e-08  5.673704e-08  6.886056e-08  5.028046e-08  2.651507e-08   \n",
       "\n",
       "              S4_0          A5_0            S5  \n",
       "1d-0  0.000000e+00  1.000000e+00  0.000000e+00  \n",
       "1d-1  1.000000e+00  1.000000e+00  1.000000e+00  \n",
       "4d-0  2.293063e-08  4.484193e-08  1.264405e-08  \n",
       "4d-1  9.999999e-01  4.031909e-08  3.800445e-08  \n",
       "5d-0  4.996458e-08  3.736697e-08  2.906290e-08  \n",
       "5d-1  3.156437e-08  2.994376e-08  1.647666e-08  \n",
       "6d-0  5.617007e-08  2.213302e-08  2.045434e-08  "
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "91d5e4ca-4a55-4214-acf2-713fcd980e9c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_33578/1256444297.py:5: FutureWarning: Styler.applymap has been deprecated. Use Styler.map instead.\n",
      "  table.style.format('{:.2f}').applymap(highlight_zeros)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "#T_121bf_row0_col0, #T_121bf_row0_col2, #T_121bf_row0_col3, #T_121bf_row0_col4, #T_121bf_row0_col7, #T_121bf_row0_col10, #T_121bf_row0_col12, #T_121bf_row0_col13, #T_121bf_row0_col17, #T_121bf_row1_col0, #T_121bf_row1_col1, #T_121bf_row1_col2, #T_121bf_row1_col3, #T_121bf_row1_col4, #T_121bf_row1_col5, #T_121bf_row1_col6, #T_121bf_row1_col7, #T_121bf_row1_col8, #T_121bf_row1_col9, #T_121bf_row1_col10, #T_121bf_row1_col11, #T_121bf_row1_col12, #T_121bf_row1_col13, #T_121bf_row1_col14, #T_121bf_row1_col15, #T_121bf_row1_col16, #T_121bf_row1_col17, #T_121bf_row1_col18, #T_121bf_row2_col0, #T_121bf_row2_col1, #T_121bf_row2_col2, #T_121bf_row2_col3, #T_121bf_row2_col4, #T_121bf_row2_col6, #T_121bf_row2_col8, #T_121bf_row2_col10, #T_121bf_row2_col13, #T_121bf_row3_col0, #T_121bf_row3_col1, #T_121bf_row3_col2, #T_121bf_row3_col3, #T_121bf_row3_col4, #T_121bf_row3_col5, #T_121bf_row3_col6, #T_121bf_row3_col8, #T_121bf_row3_col9, #T_121bf_row3_col10, #T_121bf_row3_col11, #T_121bf_row3_col13, #T_121bf_row3_col14, #T_121bf_row3_col16, #T_121bf_row4_col0, #T_121bf_row4_col1, #T_121bf_row4_col2, #T_121bf_row4_col3, #T_121bf_row4_col4, #T_121bf_row4_col5, #T_121bf_row4_col6, #T_121bf_row4_col7, #T_121bf_row4_col10, #T_121bf_row4_col11, #T_121bf_row4_col12, #T_121bf_row4_col15, #T_121bf_row5_col0, #T_121bf_row5_col1, #T_121bf_row5_col2, #T_121bf_row5_col3, #T_121bf_row5_col4, #T_121bf_row5_col5, #T_121bf_row5_col6, #T_121bf_row5_col7, #T_121bf_row5_col8, #T_121bf_row5_col9, #T_121bf_row5_col10, #T_121bf_row5_col11, #T_121bf_row5_col12, #T_121bf_row5_col14, #T_121bf_row6_col0, #T_121bf_row6_col1, #T_121bf_row6_col2, #T_121bf_row6_col3, #T_121bf_row6_col5, #T_121bf_row6_col6, #T_121bf_row6_col7, #T_121bf_row6_col8, #T_121bf_row6_col9 {\n",
       "  background-color: yellow;\n",
       "}\n",
       "#T_121bf_row0_col1, #T_121bf_row0_col5, #T_121bf_row0_col6, #T_121bf_row0_col8, #T_121bf_row0_col9, #T_121bf_row0_col11, #T_121bf_row0_col14, #T_121bf_row0_col15, #T_121bf_row0_col16, #T_121bf_row0_col18, #T_121bf_row2_col5, #T_121bf_row2_col7, #T_121bf_row2_col9, #T_121bf_row2_col11, #T_121bf_row2_col12, #T_121bf_row2_col14, #T_121bf_row2_col15, #T_121bf_row2_col16, #T_121bf_row2_col17, #T_121bf_row2_col18, #T_121bf_row3_col7, #T_121bf_row3_col12, #T_121bf_row3_col15, #T_121bf_row3_col17, #T_121bf_row3_col18, #T_121bf_row4_col8, #T_121bf_row4_col9, #T_121bf_row4_col13, #T_121bf_row4_col14, #T_121bf_row4_col16, #T_121bf_row4_col17, #T_121bf_row4_col18, #T_121bf_row5_col13, #T_121bf_row5_col15, #T_121bf_row5_col16, #T_121bf_row5_col17, #T_121bf_row5_col18, #T_121bf_row6_col4, #T_121bf_row6_col10, #T_121bf_row6_col11, #T_121bf_row6_col12, #T_121bf_row6_col13, #T_121bf_row6_col14, #T_121bf_row6_col15, #T_121bf_row6_col16, #T_121bf_row6_col17, #T_121bf_row6_col18 {\n",
       "  background-color: ;\n",
       "}\n",
       "</style>\n",
       "<table id=\"T_121bf\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"blank level0\" >&nbsp;</th>\n",
       "      <th id=\"T_121bf_level0_col0\" class=\"col_heading level0 col0\" >1</th>\n",
       "      <th id=\"T_121bf_level0_col1\" class=\"col_heading level0 col1\" >C2_0</th>\n",
       "      <th id=\"T_121bf_level0_col2\" class=\"col_heading level0 col2\" >C2_1</th>\n",
       "      <th id=\"T_121bf_level0_col3\" class=\"col_heading level0 col3\" >C3_0</th>\n",
       "      <th id=\"T_121bf_level0_col4\" class=\"col_heading level0 col4\" >C2xC2_0</th>\n",
       "      <th id=\"T_121bf_level0_col5\" class=\"col_heading level0 col5\" >C2xC2_1</th>\n",
       "      <th id=\"T_121bf_level0_col6\" class=\"col_heading level0 col6\" >C4_0</th>\n",
       "      <th id=\"T_121bf_level0_col7\" class=\"col_heading level0 col7\" >C5_0</th>\n",
       "      <th id=\"T_121bf_level0_col8\" class=\"col_heading level0 col8\" >C6_0</th>\n",
       "      <th id=\"T_121bf_level0_col9\" class=\"col_heading level0 col9\" >S3_0</th>\n",
       "      <th id=\"T_121bf_level0_col10\" class=\"col_heading level0 col10\" >S3_1</th>\n",
       "      <th id=\"T_121bf_level0_col11\" class=\"col_heading level0 col11\" >D8_0</th>\n",
       "      <th id=\"T_121bf_level0_col12\" class=\"col_heading level0 col12\" >D10_0</th>\n",
       "      <th id=\"T_121bf_level0_col13\" class=\"col_heading level0 col13\" >A4_0</th>\n",
       "      <th id=\"T_121bf_level0_col14\" class=\"col_heading level0 col14\" >D12_0</th>\n",
       "      <th id=\"T_121bf_level0_col15\" class=\"col_heading level0 col15\" >C5:C4_0</th>\n",
       "      <th id=\"T_121bf_level0_col16\" class=\"col_heading level0 col16\" >S4_0</th>\n",
       "      <th id=\"T_121bf_level0_col17\" class=\"col_heading level0 col17\" >A5_0</th>\n",
       "      <th id=\"T_121bf_level0_col18\" class=\"col_heading level0 col18\" >S5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row0\" class=\"row_heading level0 row0\" >1d-0</th>\n",
       "      <td id=\"T_121bf_row0_col0\" class=\"data row0 col0\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col1\" class=\"data row0 col1\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col2\" class=\"data row0 col2\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col3\" class=\"data row0 col3\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col4\" class=\"data row0 col4\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col5\" class=\"data row0 col5\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col6\" class=\"data row0 col6\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col7\" class=\"data row0 col7\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col8\" class=\"data row0 col8\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col9\" class=\"data row0 col9\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col10\" class=\"data row0 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col11\" class=\"data row0 col11\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col12\" class=\"data row0 col12\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col13\" class=\"data row0 col13\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col14\" class=\"data row0 col14\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col15\" class=\"data row0 col15\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col16\" class=\"data row0 col16\" >0.00</td>\n",
       "      <td id=\"T_121bf_row0_col17\" class=\"data row0 col17\" >1.00</td>\n",
       "      <td id=\"T_121bf_row0_col18\" class=\"data row0 col18\" >0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row1\" class=\"row_heading level0 row1\" >1d-1</th>\n",
       "      <td id=\"T_121bf_row1_col0\" class=\"data row1 col0\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col1\" class=\"data row1 col1\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col2\" class=\"data row1 col2\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col3\" class=\"data row1 col3\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col4\" class=\"data row1 col4\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col5\" class=\"data row1 col5\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col6\" class=\"data row1 col6\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col7\" class=\"data row1 col7\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col8\" class=\"data row1 col8\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col9\" class=\"data row1 col9\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col10\" class=\"data row1 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col11\" class=\"data row1 col11\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col12\" class=\"data row1 col12\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col13\" class=\"data row1 col13\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col14\" class=\"data row1 col14\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col15\" class=\"data row1 col15\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col16\" class=\"data row1 col16\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col17\" class=\"data row1 col17\" >1.00</td>\n",
       "      <td id=\"T_121bf_row1_col18\" class=\"data row1 col18\" >1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row2\" class=\"row_heading level0 row2\" >4d-0</th>\n",
       "      <td id=\"T_121bf_row2_col0\" class=\"data row2 col0\" >2.00</td>\n",
       "      <td id=\"T_121bf_row2_col1\" class=\"data row2 col1\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col2\" class=\"data row2 col2\" >1.41</td>\n",
       "      <td id=\"T_121bf_row2_col3\" class=\"data row2 col3\" >1.41</td>\n",
       "      <td id=\"T_121bf_row2_col4\" class=\"data row2 col4\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col5\" class=\"data row2 col5\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col6\" class=\"data row2 col6\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col7\" class=\"data row2 col7\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col8\" class=\"data row2 col8\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col9\" class=\"data row2 col9\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col10\" class=\"data row2 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col11\" class=\"data row2 col11\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col12\" class=\"data row2 col12\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col13\" class=\"data row2 col13\" >1.00</td>\n",
       "      <td id=\"T_121bf_row2_col14\" class=\"data row2 col14\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col15\" class=\"data row2 col15\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col16\" class=\"data row2 col16\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col17\" class=\"data row2 col17\" >0.00</td>\n",
       "      <td id=\"T_121bf_row2_col18\" class=\"data row2 col18\" >0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row3\" class=\"row_heading level0 row3\" >4d-1</th>\n",
       "      <td id=\"T_121bf_row3_col0\" class=\"data row3 col0\" >2.00</td>\n",
       "      <td id=\"T_121bf_row3_col1\" class=\"data row3 col1\" >1.73</td>\n",
       "      <td id=\"T_121bf_row3_col2\" class=\"data row3 col2\" >1.41</td>\n",
       "      <td id=\"T_121bf_row3_col3\" class=\"data row3 col3\" >1.41</td>\n",
       "      <td id=\"T_121bf_row3_col4\" class=\"data row3 col4\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col5\" class=\"data row3 col5\" >1.41</td>\n",
       "      <td id=\"T_121bf_row3_col6\" class=\"data row3 col6\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col7\" class=\"data row3 col7\" >0.00</td>\n",
       "      <td id=\"T_121bf_row3_col8\" class=\"data row3 col8\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col9\" class=\"data row3 col9\" >1.41</td>\n",
       "      <td id=\"T_121bf_row3_col10\" class=\"data row3 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col11\" class=\"data row3 col11\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col12\" class=\"data row3 col12\" >0.00</td>\n",
       "      <td id=\"T_121bf_row3_col13\" class=\"data row3 col13\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col14\" class=\"data row3 col14\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col15\" class=\"data row3 col15\" >0.00</td>\n",
       "      <td id=\"T_121bf_row3_col16\" class=\"data row3 col16\" >1.00</td>\n",
       "      <td id=\"T_121bf_row3_col17\" class=\"data row3 col17\" >0.00</td>\n",
       "      <td id=\"T_121bf_row3_col18\" class=\"data row3 col18\" >0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row4\" class=\"row_heading level0 row4\" >5d-0</th>\n",
       "      <td id=\"T_121bf_row4_col0\" class=\"data row4 col0\" >2.24</td>\n",
       "      <td id=\"T_121bf_row4_col1\" class=\"data row4 col1\" >1.41</td>\n",
       "      <td id=\"T_121bf_row4_col2\" class=\"data row4 col2\" >1.73</td>\n",
       "      <td id=\"T_121bf_row4_col3\" class=\"data row4 col3\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col4\" class=\"data row4 col4\" >1.41</td>\n",
       "      <td id=\"T_121bf_row4_col5\" class=\"data row4 col5\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col6\" class=\"data row4 col6\" >1.41</td>\n",
       "      <td id=\"T_121bf_row4_col7\" class=\"data row4 col7\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col8\" class=\"data row4 col8\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col9\" class=\"data row4 col9\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col10\" class=\"data row4 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col11\" class=\"data row4 col11\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col12\" class=\"data row4 col12\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col13\" class=\"data row4 col13\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col14\" class=\"data row4 col14\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col15\" class=\"data row4 col15\" >1.00</td>\n",
       "      <td id=\"T_121bf_row4_col16\" class=\"data row4 col16\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col17\" class=\"data row4 col17\" >0.00</td>\n",
       "      <td id=\"T_121bf_row4_col18\" class=\"data row4 col18\" >0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row5\" class=\"row_heading level0 row5\" >5d-1</th>\n",
       "      <td id=\"T_121bf_row5_col0\" class=\"data row5 col0\" >2.24</td>\n",
       "      <td id=\"T_121bf_row5_col1\" class=\"data row5 col1\" >1.73</td>\n",
       "      <td id=\"T_121bf_row5_col2\" class=\"data row5 col2\" >1.73</td>\n",
       "      <td id=\"T_121bf_row5_col3\" class=\"data row5 col3\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col4\" class=\"data row5 col4\" >1.41</td>\n",
       "      <td id=\"T_121bf_row5_col5\" class=\"data row5 col5\" >1.41</td>\n",
       "      <td id=\"T_121bf_row5_col6\" class=\"data row5 col6\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col7\" class=\"data row5 col7\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col8\" class=\"data row5 col8\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col9\" class=\"data row5 col9\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col10\" class=\"data row5 col10\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col11\" class=\"data row5 col11\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col12\" class=\"data row5 col12\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col13\" class=\"data row5 col13\" >0.00</td>\n",
       "      <td id=\"T_121bf_row5_col14\" class=\"data row5 col14\" >1.00</td>\n",
       "      <td id=\"T_121bf_row5_col15\" class=\"data row5 col15\" >0.00</td>\n",
       "      <td id=\"T_121bf_row5_col16\" class=\"data row5 col16\" >0.00</td>\n",
       "      <td id=\"T_121bf_row5_col17\" class=\"data row5 col17\" >0.00</td>\n",
       "      <td id=\"T_121bf_row5_col18\" class=\"data row5 col18\" >0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_121bf_level0_row6\" class=\"row_heading level0 row6\" >6d-0</th>\n",
       "      <td id=\"T_121bf_row6_col0\" class=\"data row6 col0\" >2.45</td>\n",
       "      <td id=\"T_121bf_row6_col1\" class=\"data row6 col1\" >1.73</td>\n",
       "      <td id=\"T_121bf_row6_col2\" class=\"data row6 col2\" >1.41</td>\n",
       "      <td id=\"T_121bf_row6_col3\" class=\"data row6 col3\" >1.41</td>\n",
       "      <td id=\"T_121bf_row6_col4\" class=\"data row6 col4\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col5\" class=\"data row6 col5\" >1.00</td>\n",
       "      <td id=\"T_121bf_row6_col6\" class=\"data row6 col6\" >1.00</td>\n",
       "      <td id=\"T_121bf_row6_col7\" class=\"data row6 col7\" >1.41</td>\n",
       "      <td id=\"T_121bf_row6_col8\" class=\"data row6 col8\" >1.00</td>\n",
       "      <td id=\"T_121bf_row6_col9\" class=\"data row6 col9\" >1.00</td>\n",
       "      <td id=\"T_121bf_row6_col10\" class=\"data row6 col10\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col11\" class=\"data row6 col11\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col12\" class=\"data row6 col12\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col13\" class=\"data row6 col13\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col14\" class=\"data row6 col14\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col15\" class=\"data row6 col15\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col16\" class=\"data row6 col16\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col17\" class=\"data row6 col17\" >0.00</td>\n",
       "      <td id=\"T_121bf_row6_col18\" class=\"data row6 col18\" >0.00</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x7fa56019aef0>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def highlight_zeros(val):\n",
    "    color = 'yellow' if not np.allclose(val, 0., atol=1e-6) else ''\n",
    "    return f'background-color: {color}'\n",
    "\n",
    "table.style.format('{:.2f}').applymap(highlight_zeros)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf369e0f-5b90-42b8-afee-570c541e9d35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bac3a79f-0d60-4517-af98-deeacf80d00f",
   "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
