{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bec1f172",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import sys\n",
    "import os\n",
    "\n",
    "sys.path.append(os.path.dirname(os.getcwd()))\n",
    "\n",
    "from src.models import *\n",
    "from src.loss_Erf import *\n",
    "from src.equi_test import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5dfeffe7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "from multiprocessing import Pool\n",
    "\n",
    "# make save folder\n",
    "path = os.path.dirname(os.getcwd())\n",
    "folder_name = path + '/equi_two_phase_erf/'\n",
    "try:\n",
    "    os.mkdir(folder_name)\n",
    "except:\n",
    "    pass\n",
    "\n",
    "# phase diagram params\n",
    "size = [101,101]\n",
    "loss_mat = np.zeros(size)\n",
    "ranges = [[-1.5,1.5],[-1.5,1.5]]\n",
    "which_param = 0\n",
    "which_which_param = 0\n",
    "normed = False\n",
    "\n",
    "symm_blocks = [(3,1)]\n",
    "invar_nodes = 3\n",
    "d = 5\n",
    "\n",
    "def gen_phase_diagram(seed):\n",
    "    torch.manual_seed(seed)\n",
    "    teacher = EquiTwoLayer(d, symm_blocks, invar_nodes, activation='erf')\n",
    "    V = teacher.create_W().detach()\n",
    "    for a in range(size[0]):\n",
    "        for b in range(size[1]):\n",
    "            total_nodes, equi_params, invar_params = proj_equi_params_full(teacher.create_W(), symm_blocks, invar_nodes, requires_grad = True)\n",
    "            # print(equi_params[0].shape)\n",
    "            equi_params[which_param] = equi_params[which_param].detach().clone()\n",
    "            param1 = (ranges[0][0]*(size[0]-a)+ranges[0][1]*a)/size[0]\n",
    "            param2 = (ranges[1][0]*(size[0]-b)+ranges[1][1]*b)/size[0]\n",
    "            equi_params[which_param][which_which_param,which_param] = torch.tensor(param1)\n",
    "            equi_params[which_param][which_which_param,-1] = torch.tensor(param2)\n",
    "            \n",
    "            student = EquiTwoLayer(d, symm_blocks, invar_nodes, equi_params=equi_params, invar_params=invar_params, normed=normed, activation='erf')\n",
    "\n",
    "            opt = torch.optim.SGD(student.parameters(),lr = 1e-1)\n",
    "\n",
    "            iters = 1\n",
    "            for i in range(iters):\n",
    "                loss = F(student.create_W(),V)\n",
    "                loss.backward()\n",
    "                opt.step()\n",
    "                opt.zero_grad()\n",
    "                # print(loss)\n",
    "            loss_mat[a,b] = loss.detach().clone().numpy()\n",
    "#             print(seed,a,b,'              ',end='\\r')\n",
    "    name = 'etwo_'\n",
    "    for block in symm_blocks:\n",
    "        for thing in block:\n",
    "            name += str(thing)+'_'\n",
    "    name += 'invar_'+str(invar_nodes)+'_'\n",
    "    name += 'steps_' + str(iters)\n",
    "    if normed:\n",
    "        name += '_normed'\n",
    "    np.savetxt(folder_name+name+f'_{seed}.csv',loss_mat,delimiter = ',')\n",
    "\n",
    "with Pool(10) as p:\n",
    "    p.map(gen_phase_diagram,list(range(10)))\n",
    "\n",
    "# gen_phase_diagram(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4eea7640",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7a5b561d5300>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "symm_blocks = [(3,1)]\n",
    "invar_nodes = 3\n",
    "d = 5\n",
    "\n",
    "seed = 3\n",
    "torch.manual_seed(seed)\n",
    "teacher = EquiTwoLayer(d, symm_blocks, invar_nodes)\n",
    "teacher.visualize_weights()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0155853",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n",
      "(101, 101)\n"
     ]
    },
    {
     "data": {
      "image/png": "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PffHH38EAERFReHee++1Hp87dy6ys7PRpk0bhISEWOskIrqTsGeLiNyirKwMANC6des6z7t8+TIOHToEAHjyySclZStXrsTFixeRn5+Pv/zlL+5pKBGRm7Fni4jcorq6GgDqXVT6m2++gSAIUKlUePrppyVlQ4YMcVv7iIgaC3u2iMgt2rZtCwAwGAy1nlNRUYHPPvsMABAfH4+oqKhGaRsRUWNisEVEbhEZGQkAOHnyJIxGo91zFi1ahCtXrkCj0WDBggWN2TwiokbDYIuI3GL48OEAbudu/f3vf7cp/+c//4nFixcDAN5991384Q9/aNT2ERE1FuZsEZFbjBo1Cp06dcL58+fx2muv4datW3j88cdhMBiwbt06/OMf/wAATJkyBa+99loTt5aIyH0YbBGRW+h0OqxevRojRoxASUkJ5s2bh3nz5lnL1Wo1EhMT8cEHH0ClUjVhS4mI3IvDiETkNg8//DAOHjyIiRMn4t5774VWq0WHDh0wdepUHDp0CB999BHUav4zRESejT1bRORWPXr0wPr165u6GURETYZ/UhIRERG5kUoQBKGpG0FEZM/KlSvxyy+/AAB+/fVXpKenY8CAAejSpQsA4KGHHsK0adOasolERPXiMCIRNVu//PKL9a1Fi/3792P//v3WfQZbRNTcsWeLiIiIyI2Ys0VERETkRgy2iIiIiNyIwRYRERGRGzHYIiIiInIjBltEREREbsRgi4iIiMiNGGwRERERuRGDLSIiIiI3YrBFRERE5EYMtoiIiIjciMEWERERkRv9f/yF3l7CvzEbAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "\n",
    "path = os.path.dirname(os.getcwd())\n",
    "folder_name = path + '/equi_two_phase_erf/'\n",
    "\n",
    "try:\n",
    "    os.mkdir(folder_name+'landscape_erf/')\n",
    "except:\n",
    "    pass\n",
    "\n",
    "# loss_mat = np.loadtxt(folder_name+'9.csv',delimiter = ',')\n",
    "for i in range(10):\n",
    "    loss_mat = np.loadtxt(folder_name+f'etwo_3_1_invar_3_steps_1_{i+0}.csv',delimiter = ',')\n",
    "    print(loss_mat.shape)\n",
    "    vmax = loss_mat.max()\n",
    "    # vmax = np.mean(loss_mat)*2.5\n",
    "    vmax = 0.2\n",
    "    plt.clf()\n",
    "    plt.imshow(loss_mat,cmap='RdBu', vmax = vmax, vmin=-vmax, origin=\"lower\",extent=ranges[1]+ranges[0],aspect=1)\n",
    "    plt.xlabel('$\\\\theta_1$',fontsize=20)\n",
    "    plt.ylabel('$\\\\theta_2$',fontsize=20)\n",
    "    plt.xticks(fontsize=15)\n",
    "    plt.yticks(fontsize=15)\n",
    "    # plt.colorbar(fontsize=15)\n",
    "    cbar = plt.colorbar()\n",
    "    cbar.ax.tick_params(labelsize=15)\n",
    "    plt.savefig(folder_name+f'landscape_erf/etwo_3_1_invar_3_steps_1_{i+0}',bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "c8bd71fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x77bd42fdd030>"
      ]
     },
     "execution_count": 136,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAbUAAAGgCAYAAAAtsfn1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAhj0lEQVR4nO3df3BU1f3/8dcmIUsEshEsm2xNJLV8vqCgIggGmNaWTFEZK5Xa4sQ2/hipGpSAiqQWOloxSKdKsQrVaaGdglRmxB9MxWGCRakhQAQr/gg4MpIKCVqbXUAJNHu+f1jX3SVsEnL319nnY+bOsPfe3RxOLvvmfd7n3uMyxhgBAGCBrGQ3AAAApxDUAADWIKgBAKxBUAMAWIOgBgCwBkENAGANghoAwBoENQCANQhqAABrENQAANZIWlB7/PHHNWTIEPXt21fjxo3Ttm3bktUUAIAlXMl49uNf//pX/fSnP9Xy5cs1btw4LVmyRGvXrlVTU5MGDx7c5fuDwaAOHDigAQMGyOVyJaDFAAAnGWN0+PBh+Xw+ZWU5mF+ZJBg7dqypqqoKve7o6DA+n8/U1tZ26/3Nzc1GEhsbGxtbmm/Nzc2OxpccJdjx48fV2Niompqa0L6srCyVl5ervr6+0/e0t7ervb099Nr8L7l8b89eDRgwIL4NDpNJOaGJcawn/ZCVSZ0GIKZg2BfL4cOH9f/+b6jj3+EJD2qffPKJOjo65PV6I/Z7vV699957nb6ntrZW999//0n7BwwYoPz8/Li0szOZ9P1MUAPgtGAnXyxOl5DSYvZjTU2N/H5/aGtubk7Yz3aFbZnEFbUFzVcbAKSqhGdqZ511lrKzs9Xa2hqxv7W1VYWFhZ2+x+12y+12J6J5AIA0lvBMLTc3V6NHj1ZdXV1oXzAYVF1dncrKyhLdHACARRKeqUnSnDlzVFlZqTFjxmjs2LFasmSJjh49qhtvvDEZzUE3ZIeNv0aPQMYamo0erqTGBiCekhLUfvzjH+vjjz/WggUL1NLSoosuukgbNmw4afIIAAA9kZSbr3srEAjI4/Hoo4MtcZ/9SGJxsp5katHI1IDMFT5yEwgE5CsqlN/vd/R7PC1mPwIA0B1JGX5MZSQSAJC+yNQAANYgqAEArEFQAwBYg5oaeiy67tib2ZAA4CQyNQCANQhqAABrMPyIhOKxWQDiiUwNAGANghoAwBoENQCANTK+pkZJp/ei+7AjrG6WTQcDSCAyNQCANQhqAABrENQAANbI+JoanBd+7xmP0AKQSGRqAABrENQAANZg+BGOCx9i7Igaf4ye4h/+2CwemQWgt8jUAADWIKgBAKxBUAMAWCMja2qUbhInuobGFH8A8USmBgCwBkENAGANghoAwBoZWVND8gRj3LcWfYz71gD0FJkaAMAaBDUAgDUyYviRUazUEWuKP78nAL1FpgYAsAZBDQBgDYIaAMAaGVFTQ3piij+AniJTAwBYg6AGALAGQQ0AYA0ra2qUXtJH+O+KZWkA9BaZGgDAGgQ1AIA1rBx+hJ3Cp/gzvR9AZ8jUAADWIKgBAKxBUAMAWIOaGlJGdJmsI8Yq2QDQGTI1AIA1CGoAAGsQ1AAA1rCmpka5xT6xamgsSwOgM2RqAABrENQAANawZvgR9guf4s/0fgCdIVMDAFiDoAYAsAZBDQBgjbSuqbnEVP5MEl5Hi14lmyn+ACQyNQCARQhqAABrENQAANZI65oa0l947Su6LhZL9LnctwZAIlMDAFjE8aBWW1urSy65RAMGDNDgwYM1depUNTU1RZxz7NgxVVVVadCgQerfv7+mTZum1tZWp5sCAMgwjge1zZs3q6qqSlu3btXGjRt14sQJfe9739PRo0dD58yePVsvvvii1q5dq82bN+vAgQO65pprnG4KUlCWK3KLdSzWudmuyM0ocguarzYAmcNljInrP/uPP/5YgwcP1ubNm/Wtb31Lfr9fX/va17R69Wr98Ic/lCS99957Gj58uOrr63XppZd2+ZmBQEAej0cHDrYoPz8/ns2Hw3pz/1isABV9KPzHcM8akBrC/w0HAgH5igrl9/sd/R6Pe03N7/dLkgYOHChJamxs1IkTJ1ReXh46Z9iwYSopKVF9fX2nn9He3q5AIBCxAQAQLa5BLRgMqrq6WhMmTNCIESMkSS0tLcrNzVVBQUHEuV6vVy0tLZ1+Tm1trTweT2grLi6OZ7MBAGkqrkGtqqpKu3fv1po1a3r1OTU1NfL7/aGtubnZoRYi3mLVxQDYL9H17bjdpzZz5kytX79er776qs4+++zQ/sLCQh0/flxtbW0R2Vpra6sKCws7/Sy32y232x2vpgIALOF4pmaM0cyZM7Vu3Tpt2rRJpaWlEcdHjx6tPn36qK6uLrSvqalJ+/fvV1lZmdPNAQBkEMcztaqqKq1evVrPP/+8BgwYEKqTeTwe5eXlyePx6Oabb9acOXM0cOBA5efn64477lBZWVm3Zj4CAHAqjge1ZcuWSZIuu+yyiP0rVqzQDTfcIEl69NFHlZWVpWnTpqm9vV2TJ0/WE0884XRTYJlYj9SKLteFH2ZZGiB5TvdReKcr7vepxQP3qaWPeAWQrv5xhB+ObgJBDUgOK+5TAwAgUXhKPxyXiEwo+mfwOCwgNSX63yaZGgDAGgQ1AIA1CGoAAGtQU4MVYtXYOroY02c2JGAPMjUAgDUIagAAaxDUAADWoKaGXkv1mlR2ircPgHPI1AAA1iCoAQCswfAjrBTryeCxpvin+lAqgNjI1AAA1iCoAQCsQVADAFiDmhp6LN3qTl21l1VrAHuQqQEArEFQAwBYg6AGALAGNTV0S7rV0Xoi/D626L+mzX9vwEZkagAAaxDUAADWYPgRGSfWkCLT+4H0RqYGALAGQQ0AYA2CGgDAGtTUgBiil61hij+Q2sjUAADWIKgBAKxBUAMAWIOaGjqVSbWj8L9rdA2N+9aA9EKmBgCwBkENAGANhh+BMNHDrtHDkeGvM2mIFkgXZGoAAGsQ1AAA1iCoAQCsQU0NkqgPdVcHNTUgpug6dKKRqQEArEFQAwBYg6AGALAGNTUghlh1M5alAVIPmRoAwBoENQCANRh+zGAMl/VORxdTl+lfIPHI1AAA1iCoAQCsQVADAFiDmhrQA7HqZKySDSQfmRoAwBoENQCANQhqAABrUFPLINw35azo/oy+by3IMjVAwpGpAQCsQVADAFiD4UfAIdEjjEzxBxKPTA0AYA2CGgDAGgQ1AIA1qKlZjGnkiRXd3+FT+lklG0gMMjUAgDXiHtQWLVokl8ul6urq0L5jx46pqqpKgwYNUv/+/TVt2jS1trbGuykAAMvFNaht375dv//973XBBRdE7J89e7ZefPFFrV27Vps3b9aBAwd0zTXXxLMpAIAMELegduTIEVVUVOipp57SmWeeGdrv9/v1hz/8QY888oi++93vavTo0VqxYoVef/11bd26NV7NAZKqw0RuAOIjbkGtqqpKU6ZMUXl5ecT+xsZGnThxImL/sGHDVFJSovr6+k4/q729XYFAIGIDACBaXGY/rlmzRm+88Ya2b99+0rGWlhbl5uaqoKAgYr/X61VLS0unn1dbW6v7778/Hk0FAFjE8UytublZs2bN0qpVq9S3b19HPrOmpkZ+vz+0NTc3O/K5QDxlub7asqO2oPlqs40rbIP9wq/lVLieHQ9qjY2NOnTokC6++GLl5OQoJydHmzdv1tKlS5WTkyOv16vjx4+rra0t4n2tra0qLCzs9DPdbrfy8/MjNgAAojk+/Dhp0iS99dZbEftuvPFGDRs2TPfee6+Ki4vVp08f1dXVadq0aZKkpqYm7d+/X2VlZU43BwCQQRwPagMGDNCIESMi9vXr10+DBg0K7b/55ps1Z84cDRw4UPn5+brjjjtUVlamSy+91OnmAAAySFIek/Xoo48qKytL06ZNU3t7uyZPnqwnnngiGU0BkqIjjVfF7mqJnRQoqyCDuYwxaXcNBgIBeTweHTjYQn0thnT7srRZdAE9PKj1SbOH1bFuHMKd7uSQQCAgX1Gh/H6/o9/jafbPCQCAUyOoAQCswdIzlmHIMTXF+r2kw7I0sZoU6xhDk0g0MjUAgDUIagAAazD8CCRB+BDjieCpjyVLT4YUmQ2JVEKmBgCwBkENAGANghoAwBrU1IAky44qSkWvjB19PNm6ag5T/JFMZGoAAGsQ1AAA1iCoAQCsQU0tzaXCPU3onejfYfR9a6lWUwNSGZkaAMAaBDUAgDUYfgRSTKwp/uk2FMkjtZBoZGoAAGsQ1AAA1iCoAQCsQU0NSDHRU/zDV8ZOh1Wyw1FDs1P0dZhKyNQAANYgqAEArMHwI5BGEjXq09VUfCBVkakBAKxBUAMAWIOgBgCwBjW1NJPqU7jhvPDfefRU6nhN8Y81FZ9LEKmMTA0AYA2CGgDAGgQ1AIA1qKkBaawjTjW1eN2nxmOzEG9kagAAaxDUAADWYPgRSCNdDS+GT/Hn9g9kIjI1AIA1CGoAAGsQ1AAA1qCmBlikI041NR6ThXRBpgYAsAZBDQBgDYIaAMAa1NSANBarbhavZWmQeaKvpVRGpgYAsAZBDQBgDYYfAYuEDzFGP8E/FYWPiKZBc5EGyNQAANYgqAEArEFQAwBYg5oaYKnoGfxM8UcmIFMDAFiDoAYAsAZBDQBgDWpqgKWia2ZO3bcW/TGU5pBKyNQAANYgqAEArMHwI5AhoocJw4cjs3sxhtib4UgejZWa0ump/NHI1AAA1iCoAQCsQVADAFiDmhqQIaKn+DtVN6GGhlRCpgYAsAZBDQBgjbgEtY8++kjXX3+9Bg0apLy8PI0cOVI7duwIHTfGaMGCBSoqKlJeXp7Ky8u1d+/eeDQFAJBBHA9q//nPfzRhwgT16dNHL730kt555x395je/0Zlnnhk6Z/HixVq6dKmWL1+uhoYG9evXT5MnT9axY8ecbg6AbjgRjNx6wvRgc0VtgNNcxhhHa7fz5s3TP/7xD7322mudHjfGyOfz6a677tLdd98tSfL7/fJ6vVq5cqWmT59+0nva29vV3t4eeh0IBFRcXKwDB1uUn5/vZPNTHmtgwSnhE0WinwvZJ06FiejLl4kjqSkRN18HAgH5igrl9/sd/R53/NJ94YUXNGbMGF177bUaPHiwRo0apaeeeip0fN++fWppaVF5eXlon8fj0bhx41RfX9/pZ9bW1srj8YS24uJip5sNALCA40Htgw8+0LJlyzR06FC9/PLLuu2223TnnXfqT3/6kySppaVFkuT1eiPe5/V6Q8ei1dTUyO/3h7bm5manmw1knCzXV1t21BY0kZtToocjAac5fp9aMBjUmDFj9NBDD0mSRo0apd27d2v58uWqrKw8rc90u91yu91ONhMAYCHHM7WioiKdd955EfuGDx+u/fv3S5IKCwslSa2trRHntLa2ho4BAHA6HA9qEyZMUFNTU8S+PXv26JxzzpEklZaWqrCwUHV1daHjgUBADQ0NKisrc7o5AIAM4vjw4+zZszV+/Hg99NBD+tGPfqRt27bpySef1JNPPilJcrlcqq6u1oMPPqihQ4eqtLRU8+fPl8/n09SpU51uDoDTED0bklm3SBeOB7VLLrlE69atU01NjR544AGVlpZqyZIlqqioCJ0zd+5cHT16VDNmzFBbW5smTpyoDRs2qG/fvk43BwCQQRy/Ty0RAoGAPB4P96kBDome4Zio+9aQmrhPDQCAFMDSMwC6HAEI/587owVIZWRqAABrENQAANZg+BFAlzoYfrReIiaHJAKZGgDAGgQ1AIA1CGoAAGtQU0sz0ePe1DcQD7GuK65BpDIyNQCANQhqAABrENQAANagpgagRyy5nQmWIlMDAFiDoAYAsAbDjwC6FD5tP3pKP1P8kUrI1AAA1iCoAQCsQVADAFiDmhqAXmGKf3qyZamZaGRqAABrENQAANYgqAEArEFNLc1xjxASLfoai74GTwS/+nMf/tuMBOOSAwBYg6AGALAGw4+WCR8KYigSyZDNdYckIlMDAFiDoAYAsAZBDQBgDWpqAHol1hT/8On9ElP8EX9cYgAAaxDUAADWIKgBAKxBTc1iPEILyRDrOuOaRLyRqQEArEFQAwBYg+FHAAnTwfBj0ti60nU0MjUAgDUIagAAaxDUAADWoKaWQZhOjUTr6hpjqSQ4jUwNAGANghoAwBoENQCANaipZTDqGUi2DLl1CglEpgYAsAZBDQBgDYYfIYnp/kiMWKtkRz9CK5trEKeBTA0AYA2CGgDAGgQ1AIA1qKmhU9TYAKQjMjUAgDUIagAAaxDUAADWoKaGbuGRWoiH8Gspuo57Ihj5ug//Be+x6D7NBFwmAABrENQAANZg+BE9xnR/JEKsR2pxzeFUyNQAANYgqAEArOF4UOvo6ND8+fNVWlqqvLw8nXvuufrVr34lY74aOzDGaMGCBSoqKlJeXp7Ky8u1d+9ep5sCAMgwjge1hx9+WMuWLdPvfvc7vfvuu3r44Ye1ePFiPfbYY6FzFi9erKVLl2r58uVqaGhQv379NHnyZB07dszp5iABgiZyA05Hlitycyly6zBfbcCpOD5R5PXXX9fVV1+tKVOmSJKGDBmip59+Wtu2bZP0RZa2ZMkS/eIXv9DVV18tSfrzn/8sr9er5557TtOnTz/pM9vb29Xe3h56HQgEnG42AMACjmdq48ePV11dnfbs2SNJevPNN7VlyxZdccUVkqR9+/appaVF5eXlofd4PB6NGzdO9fX1nX5mbW2tPB5PaCsuLna62QAACzieqc2bN0+BQEDDhg1Tdna2Ojo6tHDhQlVUVEiSWlpaJElerzfifV6vN3QsWk1NjebMmRN6HQgECGwAgJM4HtSeeeYZrVq1SqtXr9b555+vXbt2qbq6Wj6fT5WVlaf1mW63W2632+GWIl5i1dW4vwinKzvGI7W4rvAlx4PaPffco3nz5oVqYyNHjtSHH36o2tpaVVZWqrCwUJLU2tqqoqKi0PtaW1t10UUXOd0cAEAGcbym9tlnnykrK/Jjs7OzFQx+8XTS0tJSFRYWqq6uLnQ8EAiooaFBZWVlTjcHAJBBHM/UrrrqKi1cuFAlJSU6//zztXPnTj3yyCO66aabJEkul0vV1dV68MEHNXToUJWWlmr+/Pny+XyaOnWq081BimHYCE6IntbPdYQvOR7UHnvsMc2fP1+33367Dh06JJ/Pp5/97GdasGBB6Jy5c+fq6NGjmjFjhtra2jRx4kRt2LBBffv2dbo5AIAM4jLhj/pIE4FAQB6PRwcOtig/Pz/ZzUEv8D9snEqsCUfRmRprrXUulR+GEAgE5CsqlN/vd/R7nEsBAGANlp5BUjH9H6cSa+mZ7Khj0Zlb9PFMkcqZWaKQqQEArEFQAwBYg6AGALAGNTWkLO5pA9BTZGoAAGsQ1AAA1mD4EWmjJ9OVGarMLNG/7hPBr/7MjdmZhV83AMAaBDUAgDUIagAAa1BTg5V4/JZ9smKsfN2Tc/n9J485xZ+dRKYGALAGQQ0AYA2CGgDAGtTUkHGot9kv/NcYvSwNv2O7kakBAKxBUAMAWIPhRyBMb1YOZlgrNcVaQbuz40hvZGoAAGsQ1AAA1iCoAQCsQU0NcMjp1uOo6cRXdPfaNMW/NzVgW5GpAQCsQVADAFiDoAYAsAY1NSDJnKyL2LTkSrzqRdlR/RBeY4s+ht5LdNmPTA0AYA2CGgDAGgw/AhaJNWTH9G9kAjI1AIA1CGoAAGsQ1AAA1qCmBiCjhc/iPxGMPNaH//anHX5lAABrENQAANYgqAEArEFNDQD+J/pRYun+qLFMRKYGALAGQQ0AYA2GHwHgf2xeJTtRkv00NjI1AIA1CGoAAGsQ1AAA1qCmBgCnEGuKf7LqaywhFBuZGgDAGgQ1AIA1CGoAAGtQUwOAU4h13xr3rKUmMjUAgDUIagAAa6T18KPRV49kYSQAQLyFDzlGP0Irmy+hlECmBgCwBkENAGANghoAwBppXVMDgEQKL5tF19SiS2qZMuU/1Z7aRaYGALAGQQ0AYA2CGgDAGtbU1GKN62bI0DaABIqumUXX2DKlppZqyNQAANbocVB79dVXddVVV8nn88nlcum5556LOG6M0YIFC1RUVKS8vDyVl5dr7969Eed8+umnqqioUH5+vgoKCnTzzTfryJEjvfqLAADQ46B29OhRXXjhhXr88cc7Pb548WItXbpUy5cvV0NDg/r166fJkyfr2LFjoXMqKir09ttva+PGjVq/fr1effVVzZgx4/T/Fl0wURsA9JYrastyRW5B89WGxHEZY067y10ul9atW6epU6dK+iJL8/l8uuuuu3T33XdLkvx+v7xer1auXKnp06fr3Xff1Xnnnaft27drzJgxkqQNGzboyiuv1L/+9S/5fL6Tfk57e7va29tDrwOBgIqLi/XRwRbl5+f3vN2n8XcFgFiiv0jDv2ecrK+lWpA83eYEAgF9vahQfr//tL7HT8XRmtq+ffvU0tKi8vLy0D6Px6Nx48apvr5eklRfX6+CgoJQQJOk8vJyZWVlqaGhodPPra2tlcfjCW3FxcVONhsAYAlHZz+2tLRIkrxeb8R+r9cbOtbS0qLBgwdHNiInRwMHDgydE62mpkZz5swJvfb7/SopKdHhw4dPq51kagCcRqbWM19+f/disLBTaTGl3+12y+12h14HAgFJ0rD/G5qsJgEAHHD48GF5PB7HPs/RoFZYWChJam1tVVFRUWh/a2urLrrootA5hw4dinjff//7X3366aeh93fF5/OpublZxhiVlJSoubnZ0TFZm3xZf6SPTo0+6hp91D30U9e+7KP9+/fL5XJ1Oo+iNxwNaqWlpSosLFRdXV0oiAUCATU0NOi2226TJJWVlamtrU2NjY0aPXq0JGnTpk0KBoMaN25ct35OVlaWzj777FDGlp+fzwXUBfqoa/RR1+ij7qGfuubxeOLSRz0OakeOHNH7778fer1v3z7t2rVLAwcOVElJiaqrq/Xggw9q6NChKi0t1fz58+Xz+UIzJIcPH67LL79ct9xyi5YvX64TJ05o5syZmj59uuMRGwCQWXoc1Hbs2KHvfOc7oddfTuCorKzUypUrNXfuXB09elQzZsxQW1ubJk6cqA0bNqhv376h96xatUozZ87UpEmTlJWVpWnTpmnp0qUO/HUAAJmsx0HtsssuizlbxeVy6YEHHtADDzxwynMGDhyo1atX9/RHn8TtduuXv/xlxCQSRKKPukYfdY0+6h76qWvx7qNe3XwNAEAq4YHGAABrENQAANYgqAEArEFQAwBYg6AGALBG2ga1xx9/XEOGDFHfvn01btw4bdu2LdlNSpra2lpdcsklGjBggAYPHqypU6eqqakp4pxjx46pqqpKgwYNUv/+/TVt2jS1trYmqcXJt2jRIrlcLlVXV4f20Udf+Oijj3T99ddr0KBBysvL08iRI7Vjx47Q8e4sBGyzjo4OzZ8/X6WlpcrLy9O5556rX/3qVxG3OmVaH6XU4tEmDa1Zs8bk5uaaP/7xj+btt982t9xyiykoKDCtra3JblpSTJ482axYscLs3r3b7Nq1y1x55ZWmpKTEHDlyJHTOrbfeaoqLi01dXZ3ZsWOHufTSS8348eOT2Ork2bZtmxkyZIi54IILzKxZs0L76SNjPv30U3POOeeYG264wTQ0NJgPPvjAvPzyy+b9998PnbNo0SLj8XjMc889Z958803z/e9/35SWlprPP/88iS1PnIULF5pBgwaZ9evXm3379pm1a9ea/v37m9/+9rehczKtj/72t7+Z++67zzz77LNGklm3bl3E8e70x+WXX24uvPBCs3XrVvPaa6+Zb37zm+a6667rcVvSMqiNHTvWVFVVhV53dHQYn89namtrk9iq1HHo0CEjyWzevNkYY0xbW5vp06ePWbt2beicd99910gy9fX1yWpmUhw+fNgMHTrUbNy40Xz7298OBTX66Av33nuvmThx4imPB4NBU1hYaH7961+H9rW1tRm3222efvrpRDQx6aZMmWJuuummiH3XXHONqaioMMbQR9FBrTv98c477xhJZvv27aFzXnrpJeNyucxHH33Uo5+fdsOPx48fV2NjY8RCpFlZWSovLw8tRJrp/H6/pC+e3CJJjY2NOnHiRESfDRs2TCUlJRnXZ1VVVZoyZUpEX0j00ZdeeOEFjRkzRtdee60GDx6sUaNG6amnngod785CwLYbP3686urqtGfPHknSm2++qS1btuiKK66QRB9Fi9fi0aeSFuuphfvkk0/U0dHR6UKk7733XpJalTqCwaCqq6s1YcIEjRgxQtIXC7Pm5uaqoKAg4tzwxVszwZo1a/TGG29o+/btJx2jj77wwQcfaNmyZZozZ45+/vOfa/v27brzzjuVm5urysrKbi0EbLt58+YpEAho2LBhys7OVkdHhxYuXKiKigpJ3VssOZPEa/HoU0m7oIbYqqqqtHv3bm3ZsiXZTUkpzc3NmjVrljZu3BjxcG1ECgaDGjNmjB566CFJ0qhRo7R7924tX75clZWVSW5danjmmWe0atUqrV69Wueff7527dql6upq+Xw++igFpN3w41lnnaXs7OyTZqW1trZ2e5FRW82cOVPr16/XK6+8orPPPju0v7CwUMePH1dbW1vE+ZnUZ42NjTp06JAuvvhi5eTkKCcnR5s3b9bSpUuVk5Mjr9eb8X0kSUVFRTrvvPMi9g0fPlz79++XFLkQcLhM6qd77rlH8+bN0/Tp0zVy5Ej95Cc/0ezZs1VbWyuJPorWnf5wYvHoL6VdUMvNzdXo0aNVV1cX2hcMBlVXV6eysrIktix5jDGaOXOm1q1bp02bNqm0tDTi+OjRo9WnT5+IPmtqatL+/fszps8mTZqkt956S7t27QptY8aMUUVFRejPmd5HkjRhwoSTbgfZs2ePzjnnHEmRCwF/6cuFgDOlnz777DNlZUV+dWZnZysYDEqij6J1pz/CF4/+Uk8Xjw7p1TSXJFmzZo1xu91m5cqV5p133jEzZswwBQUFpqWlJdlNS4rbbrvNeDwe8/e//90cPHgwtH322Wehc2699VZTUlJiNm3aZHbs2GHKyspMWVlZEludfOGzH42hj4z54naHnJwcs3DhQrN3716zatUqc8YZZ5i//OUvoXMWLVpkCgoKzPPPP2/++c9/mquvvtrq6erRKisrzde//vXQlP5nn33WnHXWWWbu3LmhczKtjw4fPmx27txpdu7caSSZRx55xOzcudN8+OGHxpju9cfll19uRo0aZRoaGsyWLVvM0KFDM2dKvzHGPPbYY6akpMTk5uaasWPHmq1btya7SUkjqdNtxYoVoXM+//xzc/vtt5szzzzTnHHGGeYHP/iBOXjwYPIanQKigxp99IUXX3zRjBgxwrjdbjNs2DDz5JNPRhwPBoNm/vz5xuv1GrfbbSZNmmSampqS1NrECwQCZtasWaakpMT07dvXfOMb3zD33XefaW9vD52TaX30yiuvdPodVFlZaYzpXn/8+9//Ntddd53p37+/yc/PNzfeeKM5fPhwj9vCemoAAGukXU0NAIBTIagBAKxBUAMAWIOgBgCwBkENAGANghoAwBoENQCANQhqAABrENQAANYgqAEArEFQAwBY4/8Dv+xwY5D4udgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "vmax = loss_mat.max()\n",
    "vmin = loss_mat.min()\n",
    "plt.imshow(loss_mat,cmap='RdBu', vmax = 0.1, vmin=-0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "20ae6124",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x77bdfccc6170>"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGdCAYAAACyzRGfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAAArL0lEQVR4nO3df3SU5Z338c8kkEnAZEJCySQ1MRFZMYSiiCDEsyuarmaRarfbri5apG67algE9rRAu8hyFCPdc3zoDw6uPqt0DyBtT4Uqq3hcsFJsJPxUWSuCRs2DDKkgmfAjIZ25nj/oTEmYhJnJPT/ue96vc3JOc88d5zq3NvPJdV3f7+UyxhgBAAAkSVaqBwAAADIL4QMAACQV4QMAACQV4QMAACQV4QMAACQV4QMAACQV4QMAACQV4QMAACTVoFQPoLdgMKhPP/1U+fn5crlcqR4OAACIgjFGHR0dKisrU1ZW/3MbaRc+Pv30U5WXl6d6GAAAIA6tra269NJL+70n7cJHfn6+pHODLygoSPFoAABANPx+v8rLy8Of4/1Ju/ARWmopKCggfAAAYDPRbJlgwykAAEgqwgcAAEgqwgcAAEgqwgcAAEgqwgcAAEgqwgcAAEiqmMPHtm3bNH36dJWVlcnlcmnjxo193nv//ffL5XJpxYoVAxgiAABwkpjDx6lTpzRu3DitXLmy3/s2bNigN998U2VlZXEPDgAAOE/MTcbq6+tVX1/f7z2HDx/WP//zP+uVV17RtGnT4h4cAACwTiBo1NxyXG0dnRqRn6uJVUXKzkr+OWqWdzgNBoO655579N3vfldjxoy56P1dXV3q6uoKf+/3+60eEgAAGW/z/iNa+uK7OtLeGb5W6snVkunVurWmNKljsXzD6fLlyzVo0CDNmTMnqvsbGxvl8XjCXxwqBwCAtTbvP6IH1uzpETwkydfeqQfW7NHm/UeSOh5Lw8fu3bv1ox/9SKtXr46qt7skLVq0SO3t7eGv1tZWK4cEAEBGCwSNlr74rkyE10LXlr74rgLBSHckhqXh47e//a3a2tpUUVGhQYMGadCgQfr444/1L//yL6qsrIz4M263O3yIHIfJAQBgreaW4xfMeJzPSDrS3qnmluNJG5Olez7uuece1dXV9bh2yy236J577tGsWbOsfCsAABCFto6+g0c891kh5vBx8uRJHTp0KPx9S0uL9u3bp6KiIlVUVKi4uLjH/YMHD5bX69WVV1458NECAICYjMjPtfQ+K8QcPnbt2qWpU6eGv58/f74kaebMmVq9erVlAwMAAAM3sapIpZ5c+do7I+77cEnyes6V3SZLzOHjxhtvlDHRb0r56KOPYn0LAABgkewsl5ZMr9YDa/bIJfUIIKHSkCXTq5Pa74OzXQAAcLhba0q16u7x8np6Lq14Pbladff4pPf5sLzJGAAASL3e3Uy/XO3Vl6u9zuxwCgAAUiuduplGwrILAAAOkm7dTCMhfAAA4BDp2M00EsIHAAAOkY7dTCMhfAAA4BDp2M00EsIHAAAOkY7dTCMhfAAA4BChbqZ9Fc+6dK7qJZndTCMhfAAA4BChbqaSLgggqepmGgnhAwAABwgEjZo+OKauPwY1t+4vVFKQHt1MI6HJGAAANhepqZi3wK15daNUOXxoSruZRsLMBwAANtZXU7Gj/i6t+J+Dcg/K0uSRxWkTPCTCBwAAtmWXpmK9ET4AALApuzQV643wAQCATdmlqVhvhA8AAGzKLk3FeiN8AABgU3ZpKtYb4QMAAJuyS1Ox3ggfAADYTKih2K/3HZYnL0cr/2G8vJ70bSrWG03GAACwkUgNxUo9uVo87SoNG+pWW0dn2jUV642ZDwAAbKKvhmK+9k41rNur9jNndfvVX0y7pmK9ET4AALABuzYUi4TwAQCADdi1oVgkhA8AAGzArg3FIiF8AABgA3ZtKBYJ4QMAABuwa0OxSAgfAACkuUDQqLnluOprvDKyV0OxSOjzAQBAGovU18Plksx5RS1eT66WTK9Oy4ZikRA+AABIU6G+Hr2LZ0PVtPfVVqqu2pvWDcUiYdkFAIA01F9fD+ncUstL+322Cx4S4QMAgLTkpL4evRE+AABIQ07q69Eb4QMAgDTkpL4evRE+AABIQ07q69Eb4QMAgDSUneXSkunVkuzf16M3wgcAAGkkEDRq+uCYfr3vsDx5OVr5D+Pl9fRcWvF6crXq7vG26evRG30+AABIE5EaipV6crV42lUaNtStto5OjcjPtWV57fmY+QAAIA2EGor1Lq/1tXeqYd1etZ85q9uv/qImjyy2dfCQ4ggf27Zt0/Tp01VWViaXy6WNGzeGX+vu7taCBQs0duxYDR06VGVlZfrmN7+pTz/91MoxAwDgKP01FAtdW/riuwoE+2o5Zi8xh49Tp05p3LhxWrly5QWvnT59Wnv27NHixYu1Z88ePf/88zpw4IC+8pWvWDJYAACcyMkNxSKJec9HfX296uvrI77m8Xj06quv9rj205/+VBMnTtQnn3yiioqK+EYJAICDObmhWCQJ3/PR3t4ul8ulwsLCRL8VAAC25OSGYpEktNqls7NTCxYs0F133aWCgoKI93R1damrqyv8vd/vT+SQAABIO6GGYr72zoj7Plw6V15rx4ZikSRs5qO7u1vf+MY3ZIzRqlWr+ryvsbFRHo8n/FVeXp6oIQEAkHYCQaPmluOqr/HKyHkNxSJJyMxHKHh8/PHH2rp1a5+zHpK0aNEizZ8/P/y93+8ngAAAMkKkvh4ul2TOm/7wenK1ZHq1bRuKRWJ5+AgFj4MHD+q1115TcXFxv/e73W653W6rhwEAQFoL9fXovcwSqqa9r7ZSddVe2zcUiyTm8HHy5EkdOnQo/H1LS4v27dunoqIilZaW6u/+7u+0Z88ebdq0SYFAQD6fT5JUVFSknJwc60YOAIBN9dfXQzq31PLSfp++P805Sy3nizl87Nq1S1OnTg1/H1oymTlzpv7t3/5NL7zwgiTp6quv7vFzr732mm688cb4RwoAgEPE0tdj8sj+VxDsKObwceONN8qYvjus9fcaAADIvL4evXG2CwAASZZpfT16I3wAAJBkob4efe3mcOncabZO6evRG+EDAIAky85yacn0akmZ0dejN8IHAABJEggaNX1wTL/ed1ievByt/Ifx8np6Lq14Pbladfd4R/X16C2h7dUBAMA5kRqKlXpytXjaVRo21K22jk6NyM91ZF+P3pj5AAAgwUINxXqX1/raO9Wwbq/az5zV7Vd/UZNHFjs+eEiEDwAAEqq/hmKha0tffFeBYOa0qiB8AACQQLE0FMsUhA8AABIo0xuKRUL4AAAggTK9oVgkhA8AABIo0xuKRUL4AAAgQQJBo+aW46qv8cooMxuKRUKfDwAAEiBSXw+XSzr//FWvJ1dLplc7uqFYJIQPAAAsFurr0bt4NlRNe19tpeqqvRnRUCwSll0AALBQf309pHNLLS/t92Vs8JAIHwAAWIq+HhdH+AAAwEL09bg4wgcAABair8fFET4AALAQfT0ujvABAIAFAkGjpg+OadPbn+rO6yok0dejL5TaAgAwQJF6ehQOGSxJOnG6O3wtU/t69Eb4AABgAPrq6dF+ultG0ry6UaocPlQj8nMzurz2fIQPAADi1F9Pj1A79fU7W7V9wU2EjvOw5wMAgDjR0yM+hA8AAOJET4/4ED4AAIgTPT3iQ/gAACBO9PSID+EDAIA4BIJGzS3HVV/jDW8uPR89PfpGtQsAADGK1NfD5ZLMeWUv9PToG+EDAIAY9NXXI/inC/fVVqqu2ktPj36w7AIAQJT66+shnVtqeWm/j+BxEYQPAACiRF8PaxA+AACIEn09rEH4AAAgSvT1sAbhAwCAKNHXwxqEDwAALiIQNGr64Jg2vf2p7ryuQhJ9PQaCUlsAAPoRqadH4ZDBkqQTp7vD1+jrET3CBwAAfeirp0f76W4ZSfPqRqly+FCNyM+lvDYGhA8AACLor6dHqJ36+p2t2r7gJkJHjNjzAQBABPT0SJyYw8e2bds0ffp0lZWVyeVyaePGjT1eN8bo4YcfVmlpqfLy8lRXV6eDBw9aNV4AAJKCnh6JE3P4OHXqlMaNG6eVK1dGfP2HP/yhfvzjH+vJJ5/Ujh07NHToUN1yyy3q7ORfDgDAPujpkTgx7/mor69XfX19xNeMMVqxYoX+9V//Vbfffrsk6b/+679UUlKijRs36s477xzYaAEASJJQTw9fe2fEfR8unatwoadH7Czd89HS0iKfz6e6urrwNY/Ho0mTJqmpqSniz3R1dcnv9/f4AgAglQJBo+aW46qv8YY3l56Pnh4DY2m1i8/nkySVlJT0uF5SUhJ+rbfGxkYtXbrUymEAABC3SH09XC7JnDf9QU+PgUl5qe2iRYs0f/788Pd+v1/l5eUpHBEAIFP11dcj+KcL99VWqq7aS0+PAbJ02cXr9UqSjh492uP60aNHw6/15na7VVBQ0OMLAIBk66+vh3RuqeWl/T6ChwUsDR9VVVXyer3asmVL+Jrf79eOHTs0efJkK98KAABL0dcjeWJedjl58qQOHToU/r6lpUX79u1TUVGRKioqNHfuXD366KMaNWqUqqqqtHjxYpWVlemOO+6wctwAAFiKvh7JE3P42LVrl6ZOnRr+PrRfY+bMmVq9erW+973v6dSpU/rOd76jEydO6IYbbtDmzZuVm0sdNAAgfdHXI3lcxpi+lrdSwu/3y+PxqL29nf0fAICkCQSNbli+9aJ9PTjLJbJYPr852wUAkNECQaOmD45p09uf6s7rKiTR1yPRUl5qCwBAqkTq6VE4ZLAk6cTp7vA1+npYi/ABAMhIffX0aD/dLSNpXt0oVQ4fqhH5uZTXWozwAQDIOP319Ai1U1+/s5X9HQnCng8AQMahp0dqET4AABmHnh6pRfgAAGQcenqkFuEDAJBRAkGjYNCoMG9wn/e4JJV6zm00hfXYcAoAyBiRSmt7o6dH4hE+AAAZoa/S2t7o6ZF4hA8AgOP1V1obUpg3WCtnjNf1lxcz45Fg7PkAADjexUprJenEmW5luVwEjyQgfAAAHI/S2vRC+AAAOB6ltemF8AEAcLyJVUUq9eRecFptCKW1yUX4AAA4ViBo1PTBMW16+1PdeV2FJF0QQCitTT6qXQAAjhSpp0fhkHONxU6c7g5fo7Q2+QgfAADH6aunR/vpbhlJ8+pGqXL4UI3IP7fUwoxHchE+AACO0l9PD6Nzyyzrd7Zq+4KbCB0pwp4PAICjXKynh5F0pL1TzS3Hkzco9ED4AAA4Cj090h/hAwDgKPT0SH+EDwCAYwSCRsGgUWHe4D7voadH6rHhFADgCJFKa3ujp0d6IHwAAGyvr9La3ujpkR4IHwAAW+uvtDakMG+wVs4Yr+svL2bGIw2w5wMAYGsXK62VpBNnupXlchE80gThAwBga5TW2g/hAwBga5TW2g/hAwBgS6ETa33tZ1Q0NOeC02pDKK1NP2w4BQDYTjRltRKltemK8AEAsJVoy2olSmvTFeEDAGAb0ZTVFg0drMW3jZG34NxSCzMe6YfwAQCwjWjKao+f6pa3IFeTRxYnaVSIFRtOAQC2QVmtMxA+AAC2QVmtMxA+AAC2wIm1zsGeDwBA2uPEWmchfAAA0hon1jqP5csugUBAixcvVlVVlfLy8jRy5Eg98sgjMiaaimwAAP4s2hNr1/7jJG1fcBPBwyYsn/lYvny5Vq1apZ/97GcaM2aMdu3apVmzZsnj8WjOnDlWvx0AwME4sdaZLA8fv/vd73T77bdr2rRpkqTKyko999xzam5utvqtAAAOR2mtM1m+7DJlyhRt2bJF77//viTprbfe0vbt21VfXx/x/q6uLvn9/h5fAABIlNY6leUzHwsXLpTf79fo0aOVnZ2tQCCgZcuWacaMGRHvb2xs1NKlS60eBgDAxgJBo+aW4+ETaz8/dTbivg+Xzm00pbTWXiwPH7/4xS+0du1arVu3TmPGjNG+ffs0d+5clZWVaebMmRfcv2jRIs2fPz/8vd/vV3l5udXDAgDYBCfWOp/LWFyGUl5eroULF6qhoSF87dFHH9WaNWv03nvvXfTn/X6/PB6P2tvbVVBQYOXQAABpLpYTa0sprU0rsXx+Wz7zcfr0aWVl9dxKkp2drWAwaPVbAQAchBNrM4fl4WP69OlatmyZKioqNGbMGO3du1dPPPGEvvWtb1n9VgAAB+HE2sxhefj4yU9+osWLF+vBBx9UW1ubysrK9E//9E96+OGHrX4rAICDUFabOSwPH/n5+VqxYoVWrFhh9T8aAOBglNVmDk61BQCkHCfWZhYOlgMApBQn1mYewgcAIGU4sTYzET4AACkR7Ym1K2eM1/WXFzPj4SDs+QAApAQn1mYuwgcAICUorc1chA8AQEpQWpu5CB8AgKQKBI2aPjgWPrG2rwUVSmudiw2nAICk4cRaSIQPAECSxHJiLaW1zkb4AAAkHCfW4nyEDwBAwnFiLc7HhlMAQMJRVovzET4AAAkVCBp91tEV1b2U1WYGll0AAAkTS3WLl7LajEH4AAAkRLTVLZTVZh7CBwDActFUt4RQVpt5CB8AAMtFU90iSYunXaV7a6uY8cgwbDgFAFgu2qqV4flugkcGInwAACzHoXHoD+EDAGAZDo1DNNjzAQCwBIfGIVqEDwDAgHFoHGJB+AAADAiHxiFWhA8AwIBwaBxixYZTAMCAcGgcYkX4AADEjUPjEA+WXQAAceHQOMSL8AEAiBmHxmEgCB8AgJhwaBwGivABAIgJh8ZhoNhwCgCICYfGYaCY+QAARCUQNGpuOa6DRzuiup/qFvSF8AEAuKhoK1skqltwcYQPAEC/Yjm3heoWRIPwAQDoUyyVLRLVLYgO4QMA0KdoK1tmT71CtVcM59A4RIXwAQDoU7SVLaNKLuHQOESNUlsAQESc24JEYeYDAHABzm1BIiVk5uPw4cO6++67VVxcrLy8PI0dO1a7du1KxFsBACwWqm6JJnhIVLYgdpbPfHz++eeqra3V1KlT9fLLL+sLX/iCDh48qGHDhln9VgAAi3FuC5LB8vCxfPlylZeX69lnnw1fq6qqsvptAAAJwLktSAbLl11eeOEFTZgwQV//+tc1YsQIXXPNNXr66af7vL+rq0t+v7/HFwAgNTi3Bclgefj48MMPtWrVKo0aNUqvvPKKHnjgAc2ZM0c/+9nPIt7f2Ngoj8cT/iovL7d6SACAiwgEjZo+OMa5LUgKlzEm2sZ1UcnJydGECRP0u9/9Lnxtzpw52rlzp5qami64v6urS11dfy7l8vv9Ki8vV3t7uwoKCqwcGgAggnjObdm+4CZmPtCD3++Xx+OJ6vPb8j0fpaWlqq6u7nHtqquu0q9+9auI97vdbrndbquHAQCIAue2IBUsDx+1tbU6cOBAj2vvv/++LrvsMqvfCgAwAJzbglSxPHzMmzdPU6ZM0WOPPaZvfOMbam5u1lNPPaWnnnrK6rcCAAwA57YgVSzfcHrddddpw4YNeu6551RTU6NHHnlEK1as0IwZM6x+KwDAAMR6bgvBA1ZJSHv12267Tbfddlsi/tEAAAtwbgtSibNdACDDcG4LUo3wAQAZJNrqFipbkEiEDwDIEJzbgnRB+ACADMG5LUgXlle7AADSE+e2IF0w8wEADhcIGjW3HOfcFqQNwgcAOFg857ZQ3YJEI3wAgENxbgvSFeEDAByIc1uQzggfAOBAnNuCdEb4AACHCQSN3jj0WVT3hs5tAZKJ8AEADhLLBlOJyhakBuEDABwi1g2mVLYgVWgyBgAOEMsGUypbkGrMfACAA0S7wVSisgWpR/gAAAeItnX67KkjNe/LVzLjgZQifACAjcXaOr32ii8QPJByhA8AsClap8OuCB8AYEO0ToedET4AwGZonQ67I3wAgM3QOh12R/gAABuhdTqcgPABADZB63Q4BeEDAGyA1ulwEtqrA0Cao3U6nIaZDwBIc7ROh9MQPgAgTYW6l768/0hU99M6HXZB+ACANBTr5lKJ1umwD8IHAKSZWDaXSmwwhf2w4RQA0kis3UvZYAo7YuYDANJILJtLJTaYwp4IHwCQBmLdXPrNyZepvqaU1umwJcIHAKRYPJtL62tKaZ0O2yJ8AEAKsbkUmYgNpwCQImwuRaZi5gMAUoTNpchUhA8ASIFA0OiNQ59FdS+bS+E0hA8ASLJYN5iyuRROQ/gAgCSKZYMpm0vhVAnfcPr444/L5XJp7ty5iX4rAEhrsWwwZXMpnCyhMx87d+7Uf/zHf+hLX/pSIt8GAGwhlg2mbC6FkyVs5uPkyZOaMWOGnn76aQ0bNixRbwMAaS8QNGr64FjU3UtnTx2p7QtuInjAsRI289HQ0KBp06aprq5Ojz76aJ/3dXV1qaurK/y93+9P1JAAIOni6V5ae8UXWGqBoyUkfKxfv1579uzRzp07L3pvY2Ojli5dmohhAEBK0b0UiMzyZZfW1lY99NBDWrt2rXJzcy96/6JFi9Te3h7+am1ttXpIAJB0dC8F+mb5zMfu3bvV1tam8ePHh68FAgFt27ZNP/3pT9XV1aXs7Ozwa263W2632+phAEDKBIJGq99ooXsp0AfLw8fNN9+sd955p8e1WbNmafTo0VqwYEGP4AEAThPrHg+6lyITWR4+8vPzVVNT0+Pa0KFDVVxcfMF1AHCSWPd4SHQvRWaiwykAWCCePR5sLkWmSkr4+M1vfpOMtwGAlImlgRibS5HpmPkAgAEIBI2aW45H3UBMYnMpQPgAgDjF00Bs8bSrdG9tFTMeyGiEDwCIQ7wNxAgeQBJOtQUAp6GBGDAwzHwAQAxoIAYMHOEDAKJEAzHAGoQPAIgCDcQA6xA+AOAiaCAGWIvwAQB9CPXweOPQH2ggBliI8AEAEcTTw0NicykQDcIHAPQSz/4OiQZiQLQIHwBwnlj3d0g0EANiRZMxAPiTeHp4sMcDiB0zHwAg9ngAyUT4AJDx4tnjMXvqFaq9YjgNxIA4ED4AZLR4e3jM+/JfEDqAOBE+AGQkengAqUP4AJBx2N8BpBbhA0BGoYcHkHqEDwAZgx4eQHqgzweAjEAPDyB9MPMBwPHY4wGkF8IHAEejhweQfggfAByLHh5AeiJ8AHAcengA6Y3wAcBR2N8BpD/CBwDHoIcHYA+EDwC2FwgavfnBMS381Tv08ABsgPABwNbiXWZhjweQOoQPALYV7zKLxB4PIJUIHwBsJVTJ4ms/o0f++/cxBw96eACpR/gAYBvxLrFI9PAA0gnhA4AtDGSJhf0dQHohfABIe/GcRns+9ncA6YXwASCtxXMabUhh3mCtnDFe119ezIwHkEYIHwDS1kDLaB//2ljVXjHc+oEBGBDCB4C0RBkt4FyEDwBpYyBltEVDB2vxbWPkLciljBZIc4QPAGlhoEssj311LDMdgE1kTPgI/UXV1tGpEfn8ZQSkE5ZYgMxiefhobGzU888/r/fee095eXmaMmWKli9friuvvNLqt4papL+oSvmFBaRcvAfChXAaLWBPWVb/A19//XU1NDTozTff1Kuvvqru7m799V//tU6dOmX1W0Ul9BdV76lcX3unHlizR5v3H0nJuIBMt3n/Ed2wfKtm/OcOnTjTHdPPunTuDwiCB2BPls98bN68ucf3q1ev1ogRI7R792795V/+pdVv16/+GhOFri381TvKzx1MHwAgiehWCmS2hO/5aG9vlyQVFRVFfL2rq0tdXV3h7/1+v2Xv3dxy/KKb106c6daM/7uDZRggwQZ6IFwIezwA+0to+AgGg5o7d65qa2tVU1MT8Z7GxkYtXbo0Ie/f1hH9rvnQMsyqu8fzSw2w2EAOhJMoowWcJqHho6GhQfv379f27dv7vGfRokWaP39++Hu/36/y8nJL3n9Efm7U94b+Cvv+hnd0pjvILzlggEIzHa++69Mzb3wU1z+DMlrAmRIWPmbPnq1NmzZp27ZtuvTSS/u8z+12y+12J2QME6uKVOrJla+9M+op3uOnujXv5/skUREDxGugMx0hLLEAzmR5tYsxRrNnz9aGDRu0detWVVVVWf0WUcvOcmnJ9GpJf/4LKhZUxACx66vCLBaFeYO19h8nafuCmwgegANZHj4aGhq0Zs0arVu3Tvn5+fL5fPL5fDpz5ozVbxWVW2tKteru8fJ6ol+CCTF/+lr4q3f0xqHPFAjGu0UOcLZA0Kjpg2PasOf/6fsb9se9mdT1p6/QgXAsewLO5DLGWPqJ6nJF/mXx7LPP6t57773oz/v9fnk8HrW3t6ugoMCycYWaGTWs2xNzT4EQlmGAC1m1xCLx/zHAzmL5/LY8fAxUosJHSGhKWFLMf525/vQz8+pGqXL4UNq0I2NZsZk0hEoWwBkIHxfBX2pA/Kz6/08oYlDeDjgD4SMKvRsefX7qbNzr1JJ0X22l6qq9/OUGRxtIZ9LeCO6As8Ty+Z0xp9r2lp3l0uSRxZKkvJxsPbBmT3hZJR7/+cZH+s83PuIXKhzHqs6kIQR1ABk789EbU8nAhViiBBAtZj7icGtNqb5c7R1wRQydUmF3bCYFkGjMfEQwkIqYSPiLD3bBDCCAeLHh1AJWTjeHsNaNdBOa5Wjr6NRHn53Wiv95n8ANIC6ED4tE+sUsDXw2hF/MSAcEbABWYs+HRc6viJGkK72XWPLL2tfeqfvX7KFZGZLOyv0c5yNQA4gFMx8x6v3LeyDluefjlzcSzeqZDjaTAjgfyy5JwrQ10lmi9nOwmRRAJISPJLK6U2pIqSdXi6ddpWFD3Wrr6GRpBjFJRDAOYZYOQCTs+Ugiqzulhhxp79SD6/b2uMYvffQnUfs5QpiVA2AVZj4slsi/OEP4EMD5Syoj8nP1+amzeuS/mekAkDosu6RYojal9saHQmZKZMAN/bdKJRaAWBE+0ggfFLBCopdUQgi0AOJF+EgziWpWFgkbVe0vmUsqISzlARgoNpymmUQ1K4sk0kZVb4Fbd02sYHbEBpKxZ+h8zHQASAVmPlIkWftCIuEDJ70ka0mFZToAicSyi80k+69dPoRSJxVLKiGETgCJRPiwoVR+KEkszSRK7/0+zzV/Ip8/Of9OQ9jPASAZCB8Okeqlmd4bV6+9bJh2f/w5G1n7kOoA2RszHQCSifDhQMlemokkyyUFz/uvJZMqa3oHi4lVRZKU8lmNkEz6dwEgPRE+HCqZJbvxirR8I+mCD+50+lCMJ1gUDhksSTpxujslYw5hSQVAuqDU1qGSWbIbL5+/S//nfw6Gv4/0IR1NQIm0xJOIe+INFqkOHSypALAzZj5sLt32GcQj0od97yWeRN6T7lhSAWAHLLtkuHSosMDAsaQCwE5YdslwvZdnZt90RdrvFcGfsaQCwOkIHxnADntFMhVLKgAyEeEjA91aU6ovV3tZmkkBmrkBAOEjY/W3NNPXxtXemzfRP2Y1ACAywgckXRhGJOmWGm+/Zat2rKyxSrQlxAQNALgQ1S4YkItV1tixtDXe3iSEDQCZjFJbpIxV3UKT2eeDYAEAA0f4QFq7WEBJZodTggUAWIPwAQAAkiqWz++sJI0JAABAEuEDAAAkGeEDAAAkVcLCx8qVK1VZWanc3FxNmjRJzc3NiXorAABgIwkJHz//+c81f/58LVmyRHv27NG4ceN0yy23qK2tLRFvBwAAbCQh4eOJJ57Qt7/9bc2aNUvV1dV68sknNWTIED3zzDOJeDsAAGAjloePs2fPavfu3aqrq/vzm2Rlqa6uTk1NTRfc39XVJb/f3+MLAAA4l+Xh47PPPlMgEFBJSUmP6yUlJfL5fBfc39jYKI/HE/4qLy+3ekgAACCNpLzaZdGiRWpvbw9/tba2pnpIAAAggSw/1Xb48OHKzs7W0aNHe1w/evSovF7vBfe73W653e7w96GGqyy/AABgH6HP7Wgap1sePnJycnTttddqy5YtuuOOOyRJwWBQW7Zs0ezZsy/68x0dHZLE8gsAADbU0dEhj8fT7z2Whw9Jmj9/vmbOnKkJEyZo4sSJWrFihU6dOqVZs2Zd9GfLysrU2tqq/Px8uVzWHvbl9/tVXl6u1tZWzo1JIJ5zcvCck4PnnDw86+RI1HM2xqijo0NlZWUXvTch4ePv//7v9Yc//EEPP/ywfD6frr76am3evPmCTaiRZGVl6dJLL03EsMIKCgr4DzsJeM7JwXNODp5z8vCskyMRz/liMx4hCQkfkjR79uyollkAAEBmSXm1CwAAyCwZFT7cbreWLFnSo7oG1uM5JwfPOTl4zsnDs06OdHjOLhNNTQwAAIBFMmrmAwAApB7hAwAAJBXhAwAAJBXhAwAAJFXGhI+VK1eqsrJSubm5mjRpkpqbm1M9JFtrbGzUddddp/z8fI0YMUJ33HGHDhw40OOezs5ONTQ0qLi4WJdccom+9rWvXXDmD2Lz+OOPy+Vyae7cueFrPGfrHD58WHfffbeKi4uVl5ensWPHateuXeHXjTF6+OGHVVpaqry8PNXV1engwYMpHLH9BAIBLV68WFVVVcrLy9PIkSP1yCOP9DgPhOccu23btmn69OkqKyuTy+XSxo0be7wezTM9fvy4ZsyYoYKCAhUWFuq+++7TyZMnEzNgkwHWr19vcnJyzDPPPGP+93//13z72982hYWF5ujRo6kemm3dcsst5tlnnzX79+83+/btM3/zN39jKioqzMmTJ8P33H///aa8vNxs2bLF7Nq1y1x//fVmypQpKRy1vTU3N5vKykrzpS99yTz00EPh6zxnaxw/ftxcdtll5t577zU7duwwH374oXnllVfMoUOHwvc8/vjjxuPxmI0bN5q33nrLfOUrXzFVVVXmzJkzKRy5vSxbtswUFxebTZs2mZaWFvPLX/7SXHLJJeZHP/pR+B6ec+xeeukl84Mf/MA8//zzRpLZsGFDj9ejeaa33nqrGTdunHnzzTfNb3/7W3PFFVeYu+66KyHjzYjwMXHiRNPQ0BD+PhAImLKyMtPY2JjCUTlLW1ubkWRef/11Y4wxJ06cMIMHDza//OUvw/f8/ve/N5JMU1NTqoZpWx0dHWbUqFHm1VdfNX/1V38VDh88Z+ssWLDA3HDDDX2+HgwGjdfrNf/+7/8evnbixAnjdrvNc889l4whOsK0adPMt771rR7X/vZv/9bMmDHDGMNztkLv8BHNM3333XeNJLNz587wPS+//LJxuVzm8OHDlo/R8csuZ8+e1e7du1VXVxe+lpWVpbq6OjU1NaVwZM7S3t4uSSoqKpIk7d69W93d3T2e++jRo1VRUcFzj0NDQ4OmTZvW43lKPGcrvfDCC5owYYK+/vWva8SIEbrmmmv09NNPh19vaWmRz+fr8aw9Ho8mTZrEs47BlClTtGXLFr3//vuSpLfeekvbt29XfX29JJ5zIkTzTJuamlRYWKgJEyaE76mrq1NWVpZ27Nhh+ZgSdrZLuvjss88UCAQuONSupKRE7733XopG5SzBYFBz585VbW2tampqJEk+n085OTkqLCzscW9JSYl8Pl8KRmlf69ev1549e7Rz584LXuM5W+fDDz/UqlWrNH/+fH3/+9/Xzp07NWfOHOXk5GjmzJnh5xnpdwnPOnoLFy6U3+/X6NGjlZ2drUAgoGXLlmnGjBmSxHNOgGieqc/n04gRI3q8PmjQIBUVFSXkuTs+fCDxGhoatH//fm3fvj3VQ3Gc1tZWPfTQQ3r11VeVm5ub6uE4WjAY1IQJE/TYY49Jkq655hrt379fTz75pGbOnJni0TnHL37xC61du1br1q3TmDFjtG/fPs2dO1dlZWU85wzi+GWX4cOHKzs7+4Ld/0ePHpXX603RqJxj9uzZ2rRpk1577TVdeuml4eter1dnz57ViRMnetzPc4/N7t271dbWpvHjx2vQoEEaNGiQXn/9df34xz/WoEGDVFJSwnO2SGlpqaqrq3tcu+qqq/TJJ59IUvh58rtkYL773e9q4cKFuvPOOzV27Fjdc889mjdvnhobGyXxnBMhmmfq9XrV1tbW4/U//vGPOn78eEKeu+PDR05Ojq699lpt2bIlfC0YDGrLli2aPHlyCkdmb8YYzZ49Wxs2bNDWrVtVVVXV4/Vrr71WgwcP7vHcDxw4oE8++YTnHoObb75Z77zzjvbt2xf+mjBhgmbMmBH+3zxna9TW1l5QLv7+++/rsssukyRVVVXJ6/X2eNZ+v187duzgWcfg9OnTysrq+dGTnZ2tYDAoieecCNE808mTJ+vEiRPavXt3+J6tW7cqGAxq0qRJ1g/K8i2saWj9+vXG7Xab1atXm3fffdd85zvfMYWFhcbn86V6aLb1wAMPGI/HY37zm9+YI0eOhL9Onz4dvuf+++83FRUVZuvWrWbXrl1m8uTJZvLkySkctTOcX+1iDM/ZKs3NzWbQoEFm2bJl5uDBg2bt2rVmyJAhZs2aNeF7Hn/8cVNYWGh+/etfm7ffftvcfvvtlIDGaObMmeaLX/xiuNT2+eefN8OHDzff+973wvfwnGPX0dFh9u7da/bu3WskmSeeeMLs3bvXfPzxx8aY6J7prbfeaq655hqzY8cOs337djNq1ChKbQfqJz/5iamoqDA5OTlm4sSJ5s0330z1kGxNUsSvZ599NnzPmTNnzIMPPmiGDRtmhgwZYr761a+aI0eOpG7QDtE7fPCcrfPiiy+ampoa43a7zejRo81TTz3V4/VgMGgWL15sSkpKjNvtNjfffLM5cOBAikZrT36/3zz00EOmoqLC5Obmmssvv9z84Ac/MF1dXeF7eM6xe+211yL+Tp45c6YxJrpneuzYMXPXXXeZSy65xBQUFJhZs2aZjo6OhIzXZcx5beUAAAASzPF7PgAAQHohfAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKQifAAAgKT6/2M5R7o1ZALwAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x=list(range(101)),y=loss_mat[:,90])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcab94c7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "e3nn",
   "language": "python",
   "name": "e3nn"
  },
  "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
}
