{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "5398ebd2-48ab-423a-b560-92e9d2374a0b",
   "metadata": {},
   "source": [
    "### Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "aeaec889-8f37-480c-861d-8a434e24fe26",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys\n",
    "HOME = os.environ['HOME']  # change if necessary\n",
    "sys.path.append(f'{HOME}/Finite-groups/src')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8293bd26-5402-4955-a9c6-ed25d4b90d4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Syntax warning: Unbound global variable in /usr/share/gap/pkg/browse/PackageIn\\\n",
      "fo.g:73\n",
      "  if not IsKernelExtensionAvailable(\"Browse\", \"ncurses\") then\n",
      "         ^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "Syntax warning: Unbound global variable in /usr/share/gap/pkg/edim/PackageInfo\\\n",
      ".g:60\n",
      "  if not IsKernelExtensionAvailable(\"EDIM\",\"ediv\") then\n",
      "         ^^^^^^^^^^^^^^^^^^^^^^^^^^\n"
     ]
    }
   ],
   "source": [
    "import torch as t\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "import json\n",
    "from itertools import product\n",
    "from jaxtyping import Float\n",
    "from torch.utils.data import DataLoader\n",
    "from tqdm.notebook import tqdm\n",
    "import plotly.graph_objects as go\n",
    "import copy\n",
    "import math\n",
    "from itertools import product\n",
    "import pandas as pd\n",
    "from typing import Union\n",
    "from einops import repeat\n",
    "from huggingface_hub import snapshot_download\n",
    "from huggingface_hub.utils import disable_progress_bars\n",
    "\n",
    "\n",
    "from model import MLP3, MLP4, InstancedModule\n",
    "from utils import *\n",
    "from group_data import *\n",
    "from model_utils import *\n",
    "from group_utils import *\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "0f473f11-9236-4bbf-b401-c6e92cd35923",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Intersection size: 14400/14400 (1.00)\n",
      "Added 14400 elements from intersection\n",
      "Added 0 elements from group 0: smallgrp(120,35)\n",
      "Taking random subset: 5760/14400 (0.40)\n",
      "Train set size: 5760/14400 (0.40)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXX-1/Finite-groups/src/model_utils.py:50: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See XXXX for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model.load_state_dict(t.load(model_path, map_location=device))\n"
     ]
    }
   ],
   "source": [
    "device = t.device(\"cuda\" if t.cuda.is_available() else \"cpu\")\n",
    "# MODEL_DIR = '2024-08-16_22-53-29_SL2_5_MLP3_256'\n",
    "# MODEL_DIR = '2024-08-14_21-24-30_gapS_5_'\n",
    "# MODEL_DIR = '2024-09-18_23-59-00_gapS5_MLP2_128_wd2e-4_ubias'\n",
    "# MODEL_DIR = '2024-09-22_22-12-21_gapF11_MLP2_256_wd1e-4_ubias'\n",
    "MODEL_DIR = '2024-09-23_01-06-18_A5x2_MLP2_128_wd1e-4_ubias'\n",
    "# MODEL_DIR = '2024-09-18_03-03-59_gapS5_MLP2_64_wd2e-4_ubias_train1_0'\n",
    "# MODEL_DIR = '2024-09-18_03-21-55_gapS5_MLP2_64_wd2e-4_ubias_train1_0'\n",
    "# MODEL_DIR = '2024-09-17_21-48-39_gapS5_MLP3_128_wd2e-4_betafix'\n",
    "# MODEL_DIkR = '2024-09-17_05-20-44_gapS5_MLP3_128_wd2e-4'\n",
    "# MODEL_DIR = '2024-09-16_05-00-33_gapS5_MLP2_128_adamw_wd1'\n",
    "# MODEL_DIR = '2024-08-27_16-32-46_Dic30_MLP3_128'\n",
    "# MODEL_DIR = '2024-08-27_23-16-05_F11_MLP3_256'\n",
    "# MODEL_DIR = '2024-09-02_18-17-20_smallgrp_54_8_MLP3_256_0_6'\n",
    "# MODEL_DIR = '2024-09-05_15-22-58_smallgrp_54_8_MLP3_1024_0_6'\n",
    "# MODEL_DIR = '2024-09-05_20-47-44_smallgrp_54_8_MLP3_1024_0_6_wd1e-6'\n",
    "# MODEL_DIR = '2024-09-02_18-51-29_smallgrp_96_71_MLP3_256_0_6'\n",
    "# MODEL_DIR = '2024-09-03_17-28-20_smallgrp_192_1025_MLP3_512_0_6'\n",
    "# MODEL_DIR = '2024-09-03_21-09-07_Z_59_128'\n",
    "disable_progress_bars()\n",
    "local_dir = f'{HOME}/models/{MODEL_DIR}'\n",
    "if not os.path.exists(local_dir):\n",
    "    snapshot_download(repo_id=f'XXXX-3/{MODEL_DIR}', local_dir=local_dir)\n",
    "models, params = load_models(local_dir, sel='final')\n",
    "data = GroupData(params)\n",
    "group = data.groups[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f0f21317-778f-4e55-970c-1ec604f95930",
   "metadata": {},
   "source": [
    "`models` (returned from `load_models`) is a list of InstancedModule objects, one for each training checkpoint that we chose to save. For most runs, we only save the final checkpoints, so `len(models)==1`\n",
    "\n",
    "For efficiency during training, the InstancedModule object contains 100 different instances starting from different random initializations. \n",
    "\n",
    "Here, we look only at the one with best test accuracy."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "ccb4a6de-eabe-4535-9d3f-df78a05f3633",
   "metadata": {},
   "outputs": [],
   "source": [
    "loss_dict = test_loss(models[0].to(device), data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "bb7037fe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0156) tensor(1.) 42\n"
     ]
    }
   ],
   "source": [
    "# instance = loss_dict['G0_acc'].argmax().item()\n",
    "instance = loss_dict['G0_loss'].argmin().item()\n",
    "# instance = (loss_dict['G0_acc'] > 0.999).nonzero()[11]\n",
    "# instance = 33\n",
    "print(loss_dict[f'G0_loss'][instance], loss_dict[f'G0_acc'][instance], instance)\n",
    "model = models[-1][instance].to(device)\n",
    "# print(model.embedding_left.norm() + model.embedding_right.norm() + model.linear.norm() + model.unembedding.norm())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2e3f6194-2716-46ca-972f-a88fe0f49de4",
   "metadata": {},
   "source": [
    "`MLP3` architecture is\n",
    "$$f(z\\mid x, y) = W_u(z)\\cdot\\text{ReLU}[W_h(W_l(x)+W_r(y))]] = \\sum_i w_u^i(z) \\text{ReLU}[w_l^i(x)+w_r^i(y)]$$\n",
    "where $w_u^i, w_l^i, w_r^i\\in\\mathbb{R}^G$ are the columns of $W_u, (W_hW_l)^{\\top}, (W_hW_r)^{\\top}$ respectively."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "1b3e1c90-45f9-43dc-b2bf-6fa305d7d196",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([120, 128]), torch.Size([120, 128]), torch.Size([120, 128]))"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "COMPLEX = False\n",
    "\n",
    "# model.get_neurons() folds the linear map into the embeddings\n",
    "lneurons, rneurons, uneurons = model.get_neurons(squeeze=True)\n",
    "if COMPLEX:\n",
    "    lneurons = t.complex(lneurons, t.zeros_like(lneurons))\n",
    "    rneurons = t.complex(rneurons, t.zeros_like(rneurons))\n",
    "    uneurons = t.complex(uneurons, t.zeros_like(uneurons))\n",
    "# lneurons = t.complex(t.zeros_like(lneurons), lneurons)\n",
    "# rneurons = t.complex(t.zeros_like(rneurons), rneurons)\n",
    "# uneurons = t.complex(t.zeros_like(uneurons), uneurons)\n",
    "lneurons.shape, rneurons.shape, uneurons.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "ddbd2806",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ablate_loss(ln, rn, un):\n",
    "    ablate_model = copy.deepcopy(model)\n",
    "    if not isinstance(ablate_model, MLP4):\n",
    "        ablate_model = ablate_model.fold_linear()\n",
    "    ablate_model.embedding_left.data = ln.unsqueeze(0)\n",
    "    ablate_model.embedding_right.data = rn.unsqueeze(0)\n",
    "    ablate_model.unembedding.data = un.unsqueeze(0).mT\n",
    "    return test_loss(ablate_model.to(device), data)\n",
    "\n",
    "def ablate_idx_loss(idxs):\n",
    "    ln, rn= model.get_neurons()\n",
    "    un = model.unembedding.data.detach()\n",
    "    ln, rn, un = ln.squeeze(0).to('cpu'), rn.squeeze(0).to('cpu'), un.squeeze(0).to('cpu').T\n",
    "    ln, rn, un = ln[:, idxs], rn[:, idxs], un[:, idxs]\n",
    "    return ablate_loss(ln, rn, un)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9fa29f76-c012-4918-be8e-e761813b918d",
   "metadata": {},
   "source": [
    "### Neurons are irrep-sparse"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81da1cb7-4ee6-4e51-a1b8-872b3b594e1c",
   "metadata": {},
   "source": [
    "I.e., each neuron is a linear combination of matrix entries of some irrep.\n",
    "\n",
    "That is, for each $i$, there exists an irrep $\\rho_i\\colon G\\to\\text{GL}(\\mathbb{R}^d)$ such that, for some $A_i,B_i,C_i$,\n",
    "$$w_l^i(x) \\approx \\text{tr}(\\rho_i(x) A_i)$$\n",
    "$$w_r^i(y) \\approx \\text{tr}(\\rho_i(y) B_i)$$\n",
    "$$w_u^i(z) \\approx \\text{tr}(\\rho_i(z) C_i)$$\n",
    "\n",
    "(This was first noticed by Chughtai et al.)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9decac2b-f6c2-4a90-9ea8-99016c469344",
   "metadata": {},
   "source": [
    "**Notation**: 4d-0 is the 1st degree 4 irrep, 4d-1 is the 2nd, etc. Ordering is arbitrary but is consistent between runs (I think)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "a38ffde5-1654-45e2-8494-0c7103391bb6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['1d-0', '1d-1', '3d-0', '3d-1', '3d-2', '3d-3', '4d-0', '4d-1', '5d-0', '5d-1'])\n"
     ]
    }
   ],
   "source": [
    "if COMPLEX:\n",
    "    irreps = group.get_complex_irreps()\n",
    "else:\n",
    "    irreps = group.get_real_irreps(verbose=True)\n",
    "print(irreps.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "103c47dc-865a-4fbe-b9be-1e9d2b63a7e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1d-0 torch.Size([120, 1])\n",
      "1d-1 torch.Size([120, 1])\n",
      "3d-0 torch.Size([120, 9])\n",
      "3d-1 torch.Size([120, 9])\n",
      "3d-2 torch.Size([120, 9])\n",
      "3d-3 torch.Size([120, 9])\n",
      "4d-0 torch.Size([120, 16])\n",
      "4d-1 torch.Size([120, 16])\n",
      "5d-0 torch.Size([120, 25])\n",
      "5d-1 torch.Size([120, 25])\n"
     ]
    }
   ],
   "source": [
    "# Get orthogonal basis for each irrep\n",
    "irrep_bases = dict()\n",
    "for name, irrep in irreps.items():\n",
    "    irrep = einops.rearrange(irrep, 'N d1 d2 -> N (d1 d2)')\n",
    "    U, S, V = t.svd(irrep)\n",
    "    nonzero = S > 1e-5\n",
    "    irrep_bases[name] = U[:,nonzero]\n",
    "\n",
    "# Dimension of subspace spanned by each irrep\n",
    "for k, v in irrep_bases.items():\n",
    "    print(k, v.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "3d32e6f1-297a-4e02-9a48-0d01e2dfb32a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Proportion of variance explained by each irrep, for each neuron\n",
    "lexpl, rexpl, uexpl = dict(), dict(), dict()\n",
    "\n",
    "for name, basis in irrep_bases.items():\n",
    "    lexpl[name] = (basis.H @ lneurons).norm(dim=0)**2 / (lneurons.norm(dim=0)**2 + 1e-8)\n",
    "    rexpl[name] = (basis.H @ rneurons).norm(dim=0)**2 / (rneurons.norm(dim=0)**2 + 1e-8)\n",
    "    uexpl[name] = (basis.H @ uneurons).norm(dim=0)**2 / (uneurons.norm(dim=0)**2 + 1e-8)\n",
    "\n",
    "lexpl_max, lirrep = t.stack(list(lexpl.values()), dim=0).max(dim=0)\n",
    "rexpl_max, rirrep = t.stack(list(rexpl.values()), dim=0).max(dim=0)\n",
    "uexpl_max, uirrep = t.stack(list(uexpl.values()), dim=0).max(dim=0)\n",
    "\n",
    "to_P = lambda basis: basis @ basis.H\n",
    "\n",
    "ln_proj = t.stack([to_P(list(irrep_bases.values())[lirrep[i]]) @ lneurons[:,[i]] for i in range(lneurons.shape[1])], dim=1).squeeze(-1)\n",
    "rn_proj = t.stack([to_P(list(irrep_bases.values())[rirrep[i]]) @ rneurons[:,[i]] for i in range(rneurons.shape[1])], dim=1).squeeze(-1)\n",
    "un_proj = t.stack([to_P(list(irrep_bases.values())[uirrep[i]]) @ uneurons[:,[i]] for i in range(uneurons.shape[1])], dim=1).squeeze(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "644f5325",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "({'G0_loss': tensor([0.0156]), 'G0_acc': tensor([1.])},\n",
       " {'G0_loss': tensor([0.0156]), 'G0_acc': tensor([1.])},\n",
       " {'G0_loss': tensor([0.0195]), 'G0_acc': tensor([1.])},\n",
       " {'G0_loss': tensor([0.0194]), 'G0_acc': tensor([1.])})"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "basis = irrep_bases['4d-1']\n",
    "P = basis @ basis.T\n",
    "ablate_loss(lneurons, rneurons, uneurons), ablate_loss(ln_proj, rn_proj, uneurons), ablate_loss(lneurons, rneurons, un_proj), ablate_loss(ln_proj, rn_proj, un_proj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "3392505a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'1d-0': tensor(0.0113),\n",
       " '1d-1': tensor(0.9302),\n",
       " '3d-0': tensor(0.0101),\n",
       " '3d-1': tensor(0.0395),\n",
       " '3d-2': tensor(0.0001),\n",
       " '3d-3': tensor(0.0002),\n",
       " '4d-0': tensor(0.0017),\n",
       " '4d-1': tensor(0.0004),\n",
       " '5d-0': tensor(0.0060),\n",
       " '5d-1': tensor(0.0004)}"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# ures_expl = dict()\n",
    "ubias = model.unembed_bias.data.squeeze(0)\n",
    "ubias_expl = dict()\n",
    "for name, basis in irrep_bases.items():\n",
    "    # ures_expl[name] = (basis.H @ ures).norm(dim=0)**2 / (ures.norm(dim=0)**2 + 1e-8)\n",
    "    ubias_expl[name] = (basis.H @ ubias).norm(dim=0)**2 / (ubias.norm(dim=0)**2 + 1e-8)\n",
    "ubias_expl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "8b5e3ad3-02ca-4de7-ba65-fffdab7d4169",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA43klEQVR4nO3deVjVZf7/8dcB5YAoIC4shYpkaY5tNpq5K4lLJaaZZeaWNqU26tdMptRcqSaNMtcytaLNMmeyMvecCs3UZkrTUNFMBVfAZUTl3L8/5uL8PIIKeIgbez6u61yX5/7cn/u8P/f5cM7LzwIOY4wRAACARXxKuwAAAIALEVAAAIB1CCgAAMA6BBQAAGAdAgoAALAOAQUAAFiHgAIAAKxDQAEAANYhoAAAAOsQUMqI+fPny+FwaPfu3cVaf+nSpbrlllvk7+8vh8OhzMxMr9aH0rd79245HA7Nnz+/tEsps2rVqqU+ffoUeb3SnvvC1J1X40svvVSitTz33HNyOBw6fPhwib7OlSjt9wuFQ0D5Azhy5Ii6d++ugIAATZ8+XW+//bYCAwM1efJkLV68uLTLA4ArxufZ1adcaReAkrdhwwYdP35cEyZMUGxsrLt98uTJ6tatm+Lj40uvOHhNzZo19d///lfly5cv7VL+cJj70leUzzPer7KBIyh/AAcPHpQkhYSElG4hXuRyuXT69OnSLsMK586d05kzZ+RwOOTv7y9fX9/SLukPh7kvWwr7fp08ebLAdj5/fh8ElDLuiy++UPPmzRUYGKhKlSqpU6dO2rJli3t5q1at1Lt3b0nSn//8ZzkcDvXp00cOh0MnT57UggUL5HA43O0Xs2bNGjkcDn344YeaNGmSrr32Wvn7+6tt27basWNHvv7r169X+/btFRwcrAoVKqhly5b65ptvPPr06dNHtWrVyrdu3jns8zkcDg0ePFjJycmqX7++nE6nli5dKknavHmzOnTooKCgIFWsWFFt27bVunXrPNbPu4bnm2++0fDhw1WtWjUFBgaqS5cuOnTokEff77//XnFxcapataoCAgIUHR2tfv36efQ5cOCAtm3bprNnz150zs6ePavQ0FD17ds337Ls7Gz5+/trxIgRkqQzZ85ozJgxatiwoYKDgxUYGKjmzZtr9erVHuudfx1BUlKSYmJi5HQ6tXXr1gLPq//nP/9Rnz59VLt2bfn7+ys8PFz9+vXTkSNHCpzzHTt2qE+fPgoJCVFwcLD69u2rU6dO5av/nXfeUaNGjVShQgVVrlxZLVq00LJlyzz6XG7fvJTMzEwNHTpUUVFRcjqduu666/TCCy/I5XJJkowxat26tapVq+YO4Hnz2KBBA8XExLi/XPK2bdu2berevbuCgoJUpUoV/fWvf73sl8zRo0c1YsQINWjQQBUrVlRQUJA6dOigf//73x79Cpr7Pn36qGLFitq3b5/i4+NVsWJFVatWTSNGjFBubq7H+i6XS0lJSapfv778/f0VFhamxx57TMeOHfPoZ4zRxIkTde2116pChQpq3bp1oef0fC+//LJq1qypgIAAtWzZUj/99JN72bx58+RwOLR58+Z8602ePFm+vr7at2/fZV/j8OHDhZrvd955Rw0bNlRAQIBCQ0PVo0cP7d2716NPamqqunbtqvDwcPn7++vaa69Vjx49lJWVJUlF/jy71Pu1c+dOdezYUZUqVVLPnj3d41/s82ffvn3q16+fwsLC5HQ6Vb9+fb355pser5f3+fnBBx/ob3/7m8LDwxUYGKh7770337bi/+MUTxn29ttvq3fv3oqLi9MLL7ygU6dOaebMmWrWrJk2b96sWrVq6ZlnntENN9ygOXPmaPz48YqOjlZMTIxiY2P16KOPqlGjRho4cKAkKSYm5rKv+fzzz8vHx0cjRoxQVlaWXnzxRfXs2VPr169391m1apU6dOighg0bauzYsfLx8dG8efPUpk0b/etf/1KjRo2Ktb2rVq3Shx9+qMGDB6tq1aqqVauWtmzZoubNmysoKEgjR45U+fLlNXv2bLVq1UpfffWVGjdu7DHGkCFDVLlyZY0dO1a7d+9WUlKSBg8erA8++EDS/442tWvXTtWqVdOoUaMUEhKi3bt3a9GiRR7jJCQkaMGCBUpLSyswZElS+fLl1aVLFy1atEizZ8+Wn5+fe9nixYuVk5OjHj16SPpfYHnjjTf04IMPasCAATp+/Ljmzp2ruLg4fffdd7rllls8xp43b55Onz6tgQMHyul0KjQ01P3lfb7ly5dr165d6tu3r8LDw7VlyxbNmTNHW7Zs0bp16/IFwe7duys6OlqJiYnatGmT3njjDVWvXl0vvPCCu8+4ceP03HPP6c4779T48ePl5+en9evXa9WqVWrXrp2kwu2bF3Pq1Cm1bNlS+/bt02OPPaYaNWro22+/VUJCgg4cOKCkpCQ5HA69+eabuummm/SXv/zF/f6MHTtWW7Zs0Zo1axQYGJhv22rVqqXExEStW7dOr776qo4dO6a33nrrorXs2rVLixcv1v3336/o6GhlZGRo9uzZatmypbZu3arIyMiLritJubm5iouLU+PGjfXSSy9pxYoVmjJlimJiYvT444+7+z322GOaP3+++vbtqyeffFJpaWl67bXXtHnzZn3zzTfuUxFjxozRxIkT1bFjR3Xs2FGbNm1Su3btdObMmUvWcb633npLx48f16BBg3T69Gm98soratOmjX788UeFhYWpW7duGjRokJKTk3Xrrbd6rJucnKxWrVrpmmuuuezrFGa+J02apNGjR6t79+569NFHdejQIU2bNk0tWrTQ5s2bFRISojNnziguLk45OTkaMmSIwsPDtW/fPi1ZskSZmZkKDg7W22+/XazPswudO3dOcXFxatasmV566SVVqFDBvaygz5+MjAzdcccd7gBTrVo1ffHFF+rfv7+ys7M1dOhQj/EnTZokh8Ohp59+WgcPHlRSUpJiY2P1ww8/KCAgoMj1XvUMyoR58+YZSSYtLc0YY8zx48dNSEiIGTBggEe/9PR0Exwc7NGet+6GDRs8+gYGBprevXsX6vVXr15tJJl69eqZnJwcd/srr7xiJJkff/zRGGOMy+UyderUMXFxccblcrn7nTp1ykRHR5u77rrL3da7d29Ts2bNfK81duxYc+GuKcn4+PiYLVu2eLTHx8cbPz8/s3PnTnfb/v37TaVKlUyLFi3yzUFsbKxHXcOGDTO+vr4mMzPTGGPMJ598UuBcXah3794e78fFfPnll0aS+fTTTz3aO3bsaGrXru1+fu7cOY95NcaYY8eOmbCwMNOvXz93W1pampFkgoKCzMGDBz365y2bN2+eu+3UqVP5anrvvfeMJLN27Vp3W96cn/9axhjTpUsXU6VKFffz1NRU4+PjY7p06WJyc3M9+ubNa1H2zYJMmDDBBAYGml9++cWjfdSoUcbX19f8+uuv7rbZs2cbSeadd94x69atM76+vmbo0KEe6+Vt27333uvR/sQTTxhJ5t///re7rWbNmh4/E6dPn863nWlpacbpdJrx48d7tF0493n7yPn9jDHm1ltvNQ0bNnQ//9e//mUkmeTkZI9+S5cu9Wg/ePCg8fPzM506dfLYh//2t78ZSZf9Wc6rMSAgwPz222/u9vXr1xtJZtiwYe62Bx980ERGRnps+6ZNm/JtY0EKO9+7d+82vr6+ZtKkSR79fvzxR1OuXDl3++bNm40ks3Dhwku+blE+zy71fo0aNSpf/4t9/vTv399ERESYw4cPe7T36NHDBAcHu3/+8j4/r7nmGpOdne3u9+GHHxpJ5pVXXilU3X80nOIpo5YvX67MzEw9+OCDOnz4sPvh6+urxo0b5zs14C19+/b1OBLQvHlzSf/7n6Yk/fDDD0pNTdVDDz2kI0eOuOs6efKk2rZtq7Vr1xb4P/3CaNmypW688Ub389zcXC1btkzx8fGqXbu2uz0iIkIPPfSQvv76a2VnZ3uMMXDgQI+jBs2bN1dubq727Nkj6f9fp7NkyZJLnr6ZP3++jDGXPBIgSW3atFHVqlXdR2gk6dixY1q+fLkeeOABd5uvr697Xl0ul44ePapz587p9ttv16ZNm/KN27VrV1WrVu2Sry3J439lp0+f1uHDh3XHHXdIUoHj/uUvf/F43rx5cx05csQ9j4sXL5bL5dKYMWPk4+P58ZE3r1e6by5cuFDNmzdX5cqVPdaPjY1Vbm6u1q5d6+47cOBAxcXFaciQIerVq5diYmI0efLkAscdNGiQx/MhQ4ZIkj7//POL1uJ0Ot3bmZubqyNHjqhixYq64YYbCpy/ghQ0p3k/L3nbGxwcrLvuustjexs2bKiKFSu652vFihU6c+aMhgwZ4rEPX/i/9MuJj4/3OALSqFEjNW7c2GMeHnnkEe3fv9/jvUpOTlZAQIC6du1aqNe53HwvWrRILpdL3bt399ju8PBw1alTx/3awcHBkqQvv/yywNON3nb+ka3zXfj5Y4zRxx9/rHvuuUfGGI9tiIuLU1ZWVr595JFHHlGlSpXcz7t166aIiIhL7oN/ZJziKaNSU1Ml/e8LsCBBQUEl8ro1atTweF65cmVJcp8rz6sr77qXgmRlZbnXK4ro6GiP54cOHdKpU6d0ww035Otbr149uVwu7d27V/Xr1y90/S1btlTXrl01btw4vfzyy2rVqpXi4+P10EMPyel0FrnmcuXKqWvXrnr33XeVk5Mjp9OpRYsW6ezZsx4BRZIWLFigKVOm5Lu25cLtvlhbQY4ePapx48bp/fff97hWQ5L7/P35LjU/QUFB2rlzp3x8fDw+qC90pftmamqq/vOf/1w0gF24HXPnzlVMTIxSU1P17bffXvRQeZ06dTyex8TEyMfH55K/W8jlcumVV17RjBkzlJaW5nHtSJUqVS65HZLk7++fbzsqV67scW1JamqqsrKyVL169QLHyNvevBB94XZUq1atSD9PF64vSddff70+/PBD9/O77rpLERERSk5OVtu2beVyufTee++pc+fOHl+wRXmdC+c7NTVVxpgC65HkPq0VHR2t4cOHa+rUqUpOTlbz5s1177336uGHH3aHF28pV66crr322gKXFfT5k5mZqTlz5mjOnDkFrnPhvnrhtjocDl133XXF/v1WVzsCShmVdxTi7bffVnh4eL7l5cqVzFt7savejTEedf3973/Pd91EnooVK0pSvusf8lx4AWEeb5yjvVz9DodDH330kdatW6dPP/1UX375pfr166cpU6Zo3bp17tqLokePHpo9e7a++OILxcfH68MPP1TdunV18803u/u888476tOnj+Lj4/XUU0+pevXq8vX1VWJionbu3JlvzMLORffu3fXtt9/qqaee0i233KKKFSvK5XKpffv2BR7Jutz8FMaV7psul0t33XWXRo4cWeDy66+/3uP5mjVrlJOTI0n68ccf1aRJk0LVebH973yTJ0/W6NGj1a9fP02YMEGhoaHy8fHR0KFDC3UksDB39bhcLlWvXl3JyckFLi/MkTJv8/X11UMPPaTXX39dM2bM0DfffKP9+/fr4YcfLvaYF863y+WSw+HQF198UeA8nf+zNmXKFPXp00f/+Mc/tGzZMj355JPua1suFiiK4/wjZhe68Gcu7/1/+OGHL/ofsptuuslrtf0REVDKqLwLwKpXr+7xu02KojAf0EWVV1dQUNBl66pcuXKBv9E273+Kl1OtWjVVqFBB27dvz7ds27Zt8vHxUVRUVKHGutAdd9yhO+64Q5MmTdK7776rnj176v3339ejjz5a5LFatGihiIgIffDBB2rWrJlWrVqlZ555xqPPRx99pNq1a2vRokUe78vYsWOLVb/0v6MeK1eu1Lhx4zRmzBh3e94RjuKIiYmRy+XS1q1bLxpAr3TfjImJ0YkTJwq17oEDBzRkyBC1a9dOfn5+GjFihOLi4lSzZs18fVNTUz3+F7xjxw65XK5Lnqb76KOP1Lp1a82dO9ejPTMzU1WrVi38Rl1CTEyMVqxYoaZNm14yeOZtU2pqqscpzUOHDuW72+dSCnr/f/nll3zz8Mgjj2jKlCn69NNP9cUXX6hatWqKi4sr0utcar5jYmJkjFF0dHS+0FmQBg0aqEGDBnr22Wf17bffqmnTppo1a5YmTpwoqWQ+zy6lWrVqqlSpknJzcwu9n18498YY7dixgyBzEVyDUkbFxcUpKChIkydPLvBaiQtvnS1IYGCg13/lfcOGDRUTE6OXXnpJJ06cuGRdMTExysrK0n/+8x9324EDB/TJJ58U6rV8fX3Vrl07/eMf//A4RJqRkaF3331XzZo1K/KprmPHjuU7WpD3RZz3v/S8Oi93m3EeHx8fdevWTZ9++qnefvttnTt3Lt/pnbz/QZ7/2uvXr1dKSkqR6r/cmJKUlJRU7DHj4+Pl4+Oj8ePH5zuCkPc6V7pvdu/eXSkpKfryyy/zLcvMzNS5c+fczwcMGCCXy6W5c+dqzpw5KleunPr371/gEZ/p06d7PJ82bZokqUOHDhetxdfXN99YCxcuLNRttoXVvXt35ebmasKECfmWnTt3zv0zGhsbq/Lly2vatGkeNRX1/Vy8eLFH/d99953Wr1+fbx5uuukm3XTTTXrjjTf08ccfq0ePHkU6Mnu5+b7vvvvk6+urcePG5ZtjY4z7Vvjs7GyP91z6X1jx8fHx+Jksic+zS/H19VXXrl318ccfe9ymnaeg/TzvDqo8H330kQ4cOHDJffCPjCMoZVRQUJBmzpypXr166bbbblOPHj1UrVo1/frrr/rss8/UtGlTvfbaa5cco2HDhlqxYoWmTp2qyMhIRUdH57stt6h8fHz0xhtvqEOHDqpfv7769u2ra665Rvv27dPq1asVFBSkTz/9VNL/Tn08/fTT6tKli5588kn3rajXX399oS9AnDhxopYvX65mzZrpiSeeULly5TR79mzl5OToxRdfLHL9CxYs0IwZM9SlSxfFxMTo+PHjev311xUUFKSOHTu6+xXmNuPzPfDAA5o2bZrGjh2rBg0aqF69eh7L7777bi1atEhdunRRp06dlJaWplmzZunGG28sMOgVRlBQkFq0aKEXX3xRZ8+e1TXXXKNly5YpLS2tWONJ0nXXXadnnnlGEyZMUPPmzXXffffJ6XRqw4YNioyMVGJi4hXvm0899ZT++c9/6u6771afPn3UsGFDnTx5Uj/++KM++ugj7d69W1WrVtW8efP02Wefaf78+e7D/NOmTdPDDz+smTNn6oknnvAYNy0tTffee6/at2+vlJQUvfPOO3rooYc8TrVd6O6779b48ePVt29f3Xnnnfrxxx+VnJzscQTjSrVs2VKPPfaYEhMT9cMPP6hdu3YqX768UlNTtXDhQr3yyivq1q2b+3eoJCYm6u6771bHjh21efNmffHFF0U6mnPdddepWbNmevzxx5WTk6OkpCRVqVKlwFNqjzzyiPt39RT19M7l5jsmJkYTJ05UQkKCdu/erfj4eFWqVElpaWn65JNPNHDgQI0YMUKrVq3S4MGDdf/99+v666/XuXPn9Pbbb7sDQp6S+Dy7nOeff16rV69W48aNNWDAAN144406evSoNm3apBUrVujo0aMe/UNDQ9WsWTP17dtXGRkZSkpK0nXXXacBAwaUaJ1l1u992xCK58LbjPOsXr3axMXFmeDgYOPv729iYmJMnz59zPfff59v3Qtvnd22bZtp0aKFCQgIuOxtinm3yV14q19Bt+sZ879bA++77z5TpUoV43Q6Tc2aNU337t3NypUrPfotW7bM/OlPfzJ+fn7mhhtuMO+8885FbzMeNGhQgbVt2rTJxMXFmYoVK5oKFSqY1q1bm2+//dajz8XmIG+7Vq9e7R7rwQcfNDVq1DBOp9NUr17d3H333R7zaUzhbzPO43K5TFRUlJFkJk6cWODyyZMnm5o1axqn02luvfVWs2TJkny3YufN99///vd8YxT0Xvz222+mS5cuJiQkxAQHB5v777/f7N+/30gyY8eOdffLm/NDhw4VOG8Xbuebb75pbr31VuN0Ok3lypVNy5YtzfLlyz36FGbfvJjjx4+bhIQEc9111xk/Pz9TtWpVc+edd5qXXnrJnDlzxuzdu9cEBwebe+65J9+6Xbp0MYGBgWbXrl0e27Z161bTrVs3U6lSJVO5cmUzePBg89///tdj3YJuM/6///s/ExERYQICAkzTpk1NSkqKadmypWnZsuUl5753794mMDAwX30F7d/GGDNnzhzTsGFDExAQYCpVqmQaNGhgRo4cafbv3+/uk5uba8aNG+eup1WrVuann37KV3dBzt93pkyZYqKioozT6TTNmzf3uNX6fAcOHDC+vr7m+uuvv+TYBW1fYebbGGM+/vhj06xZMxMYGGgCAwNN3bp1zaBBg8z27duN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ykWyfn5+atiwoVauXOluc7lcWrlypZo0aVIaJQEAAIuU2ime4cOHq3fv3rr99tvVqFEjJSUl6eTJk+rbt29plQQAACxRagHlgQce0KFDhzRmzBilp6frlltu0dKlS/NdOIvLczqdGjt2bL7TYCg85vDKMYdXjjm8csyhd9gwjw5TmHt9AAAAfkf8sUAAAGAdAgoAALAOAQUAAFiHgAIAAKxDQAEAANYhoFho+vTpqlWrlvz9/dW4cWN99913F+3bqlUrORyOfI9OnTq5+/Tp0yff8vbt2/8em1KqijKPkpSUlKQbbrhBAQEBioqK0rBhw3T69OkrGrOs8/YcPvfcc/n2xbp165b0ZpSqoszh2bNnNX78eMXExMjf318333yzli5dekVjXg28PYd/tP1w7dq1uueeexQZGSmHw6HFixdfdp01a9botttuk9Pp1HXXXaf58+fn61Pi+6GBVd5//33j5+dn3nzzTbNlyxYzYMAAExISYjIyMgrsf+TIEXPgwAH346effjK+vr5m3rx57j69e/c27du39+h39OjR32mLSkdR5zE5Odk4nU6TnJxs0tLSzJdffmkiIiLMsGHDij1mWVcSczh27FhTv359j33x0KFDv9cm/e6KOocjR440kZGR5rPPPjM7d+40M2bMMP7+/mbTpk3FHrOsK4k5/KPth59//rl55plnzKJFi4wk88knn1yy/65du0yFChXM8OHDzdatW820adOMr6+vWbp0qbvP77EfElAs06hRIzNo0CD389zcXBMZGWkSExMLtf7LL79sKlWqZE6cOOFu6927t+ncubO3S7VaUedx0KBBpk2bNh5tw4cPN02bNi32mGVdSczh2LFjzc0331wi9dqoqHMYERFhXnvtNY+2++67z/Ts2bPYY5Z1JTGHf7T98HyFCSgjR4409evX92h74IEHTFxcnPv577EfcorHImfOnNHGjRsVGxvrbvPx8VFsbKxSUlIKNcbcuXPVo0cPBQYGerSvWbNG1atX1w033KDHH39cR44c8WrtNinOPN55553auHGj+xDlrl279Pnnn6tjx47FHrMsK4k5zJOamqrIyEjVrl1bPXv21K+//lpyG1KKijOHOTk58vf392gLCAjQ119/Xewxy7KSmMM8f5T9sDhSUlI85lyS4uLi3HP+e+2HBBSLHD58WLm5ufl+3X9YWJjS09Mvu/53332nn376SY8++qhHe/v27fXWW29p5cqVeuGFF/TVV1+pQ4cOys3N9Wr9tijOPD700EMaP368mjVrpvLlyysmJkatWrXS3/72t2KPWZaVxBxKUuPGjTV//nwtXbpUM2fOVFpampo3b67jx4+X6PaUhuLMYVxcnKZOnarU1FS5XC4tX75cixYt0oEDB4o9ZllWEnMo/bH2w+JIT08vcM6zs7P13//+93fbDwkoV5G5c+eqQYMGatSokUd7jx49dO+996pBgwaKj4/XkiVLtGHDBq1Zs6Z0CrXQmjVrNHnyZM2YMUObNm3SokWL9Nlnn2nChAmlXVqZUZg57NChg+6//37ddNNNiouL0+eff67MzEx9+OGHpVi5PV555RXVqVNHdevWlZ+fnwYPHqy+ffvKx4eP6sIqzByyH5YN7PUWqVq1qnx9fZWRkeHRnpGRofDw8Euue/LkSb3//vvq37//ZV+ndu3aqlq1qnbs2HFF9dqqOPM4evRo9erVS48++qgaNGigLl26aPLkyUpMTJTL5bqi96YsKok5LEhISIiuv/76q3JfLM4cVqtWTYsXL9bJkye1Z88ebdu2TRUrVlTt2rWLPWZZVhJzWJCreT8sjvDw8ALnPCgoSAEBAb/bfkhAsYifn58aNmyolStXuttcLpdWrlypJk2aXHLdhQsXKicnRw8//PBlX+e3337TkSNHFBERccU126g483jq1Kl8/0v19fWVJBljrui9KYtKYg4LcuLECe3cufOq3BevZJ/x9/fXNddco3Pnzunjjz9W586dr3jMsqgk5rAgV/N+WBxNmjTxmHNJWr58uXvOf7f90GuX28Ir3n//feN0Os38+fPN1q1bzcCBA01ISIhJT083xhjTq1cvM2rUqHzrNWvWzDzwwAP52o8fP25GjBhhUlJSTFpamlmxYoW57bbbTJ06dczp06dLfHtKS1HncezYsaZSpUrmvffeM7t27TLLli0zMTExpnv37oUe82pTEnP4f//3f2bNmjUmLS3NfPPNNyY2NtZUrVrVHDx48Hffvt9DUedw3bp15uOPPzY7d+40a9euNW3atDHR0dHm2LFjhR7zalMSc/hH2w+PHz9uNm/ebDZv3mwkmalTp5rNmzebPXv2GGOMGTVqlOnVq5e7f95txk899ZT5+eefzfTp0wu8zbik90MCioWmTZtmatSoYfz8/EyjRo3MunXr3Mtatmxpevfu7dF/27ZtRpJZtmxZvrFOnTpl2rVrZ6pVq2bKly9vatasaQYMGHDVfpidryjzePbsWfPcc8+ZmJgY4+/vb6KioswTTzzh8aF2uTGvRt6ewwceeMBEREQYPz8/c80115gHHnjA7Nix43fcot9fUeZwzZo1pl69esbpdJoqVaqYXr16mX379hVpzKuRt+fwj7Yfrl692kjK98ibt969e5uWLVvmW+eWW24xfn5+pnbt2h6/WytPSe+HDmMucuwVAACglHANCgAAsA4BBQAAWIeAAgAArENAAQAA1iGgAAAA6xBQAACAdQgoAADAOgQUAABgHQIKAACwDgEFAABYh4ACAACs8/8AjMN82peM70EAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAGzCAYAAAAFROyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA7hUlEQVR4nO3dfXzO9f////tO7NjMTgw7q2EtRaWS3uQ8rBY6mZSU5KToXaPwLVEhOZm8VYucpBOUqSi8ozclp5/KWUZvUVJG3rRJbHOSYcfz90eXHT+HDds6DntOt+vlclwujtfr+Xoez8freB3P3fc6Xi/zMcYYAQAAWMS3vAcAAABwJgIKAACwDgEFAABYh4ACAACsQ0ABAADWIaAAAADrEFAAAIB1CCgAAMA6BBQAAGAdAkoF8sILL8jHx+cvbXvgwAEPjwq227Vrl3x8fDRjxozyHkqFVbt2bfXo0aPU25X3vi/JuAvHOH78eK+OpSLMQeX9fsEdAQVFjBkzRgsWLCjvYQDAX8Z8VnERUCqQ559/Xn/88YfXX4cP9MWlVq1a+uOPP9StW7fyHsrfDvu+/JVmPuP9sgsBpQI4evSoJMnf31+BgYHlPBq7OZ1OHT9+vLyHYYVTp07pxIkT8vHxUWBgoPz8/Mp7SH877PuKpaTvV+GcfCbmH88ioFim8Hvabdu26YEHHlDVqlXVvHlzt3Wn++OPP/TEE0+oevXqCgkJ0Z133qm9e/fKx8dHL7zwQpH+c3Jy1KNHD4WHhyssLEw9e/bUsWPHXOt9fHx09OhRzZw5Uz4+PvLx8Tnnd9grV66Uj4+P5syZo9GjR+vSSy9VYGCg2rZtq59++qlI+3Xr1um2225TWFiYKleurFatWumrr75ya9OjRw/Vrl37rPvmdD4+Purbt6/S09N19dVXy+FwaMmSJZKkTZs2qV27dgoNDVWVKlXUtm1brV271m37GTNmyMfHR1999ZUGDhyoGjVqKDg4WB07dtRvv/3m1vabb75RUlKSqlevrqCgIMXHx6tXr15ubX799Vf98MMPOnny5Fn32cmTJxUREaGePXsWWZeXl6fAwEA99dRTkqQTJ05o2LBhatiwocLCwhQcHKwWLVpoxYoVbtudfh1BWlqaEhIS5HA4tG3btmK/V//vf/+rHj166LLLLlNgYKCio6PVq1cv/f7778Xu859++umcx02hWbNmqVGjRqpcubKqVq2qli1b6vPPP3drs3jxYrVo0ULBwcEKCQlRhw4dtHXr1rPur9Pl5OSof//+iouLk8Ph0OWXX66XXnpJTqdTkmSMUevWrVWjRg3t37/ftd2JEydUv359JSQkuH64FNb2ww8/qHPnzgoNDVW1atX05JNPnveHzMGDB/XUU0+pfv36qlKlikJDQ9WuXTt9++23bu2K2/c9evRQlSpVtHfvXiUnJ6tKlSqqUaOGnnrqKRUUFLht73Q6lZaWpquvvlqBgYGKiorSo48+qkOHDrm1M8Zo1KhRuvTSS1W5cmW1bt26xPv0dK+++qpq1aqloKAgtWrVSt99951r3fTp0+Xj46NNmzYV2W7MmDHy8/PT3r17z/saBw4cKNH+njVrlho2bKigoCBFRESoS5cu2rNnj1ubHTt2qFOnToqOjlZgYKAuvfRSdenSRbm5uZJKP5+d6/36+eef1b59e4WEhKhr166u/s82/+zdu1e9evVSVFSUHA6Hrr76ar3zzjtur1c4f3744Yd69tlnFR0dreDgYN15551Fav078i/vAaB49957r+rUqaMxY8bIGHPWdj169NCcOXPUrVs33XTTTVq1apU6dOhw1vadO3dWfHy8UlNTlZGRobfeekuRkZF66aWXJEnvvfeeHnnkETVq1Eh9+vSRJCUkJJx3vGPHjpWvr6+eeuop5ebmaty4ceratavWrVvnarN8+XK1a9dODRs21PDhw+Xr66vp06erTZs2+r//+z81atSopLvHzfLlyzVnzhz17dtX1atXV+3atbV161a1aNFCoaGhGjRokCpVqqQ33nhDN998s1atWqXGjRu79dGvXz9VrVpVw4cP165du5SWlqa+ffvqww8/lCTt379ft956q2rUqKHBgwcrPDxcu3bt0rx589z6GTJkiGbOnKnMzMxiQ5YkVapUSR07dtS8efP0xhtvKCAgwLVuwYIFys/PV5cuXST9GVjeeust3X///erdu7cOHz6st99+W0lJSVq/fr2uv/56t76nT5+u48ePq0+fPnI4HIqIiHD98D7d0qVLtXPnTvXs2VPR0dHaunWrpk2bpq1bt2rt2rVFguD5jhtJGjFihF544QU1bdpUL774ogICArRu3TotX75ct956q6Q/j6/u3bsrKSlJL730ko4dO6YpU6aoefPm2rRp01n3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5+fL4XBo3rx5OnnypFtAkaSZM2fq5ZdfLnJtS3HHSEmOG+nPayhGjBihDz74wO1aDUmu7+9Pd77j5ueff5avr6/bRH2mwmOgTZs2xa4/3/G3Y8cO/fe//z1rADuzjrffflsJCQnasWOHvv7667OeKq9Tp47b84SEBPn6+mrXrl1nHYvT6dRrr72myZMnKzMz0+3akWrVqp2zDkkKDAwsUkfVqlXdri3ZsWOHcnNzFRkZWWwfhfUWhugz66hRo0apPk9nbi9JV1xxhebMmeN6fssttygmJkbp6elq27atnE6n3n//fd11111uP2BL8zpn7u8dO3bIGFPseCS5vtaKj4/XwIED9corryg9PV0tWrTQnXfeqQcffNAVXjzF399fl156abHript/cnJyNG3aNE2bNq3Ybc48Vs+s1cfHR5dffvk5j8G/AwKKpbz1vePZrk4357jOxRP9Fp4d+de//lXkuolCVapUkaQi1z8UOvMCwkKe2FfnG7+Pj48++ugjrV27VgsXLtRnn32mXr166eWXX9batWtdYy+NLl266I033tDixYuVnJysOXPmqG7durruuutcbWbNmqUePXooOTlZTz/9tCIjI+Xn56fU1FT9/PPPRfos6b7o3Lmzvv76az399NO6/vrrVaVKFTmdTt12223FnsnyxHFT2O97772n6OjoIuv9/c89HTmdTt1yyy0aNGhQseuvuOIKt+crV65Ufn6+JGnLli1q0qRJicZZkv8MccyYMRo6dKh69eqlkSNHKiIiQr6+vurfv3+JzgSW5K4ep9OpyMhIpaenF7u+JGfKPM3Pz08PPPCA3nzzTU2ePFlfffWV9u3bpwcffLDMfZ65v51Op3x8fLR48eJi99Ppn7WXX35ZPXr00L///W99/vnneuKJJ1zXtpwtUJTF6WfMznTmZ67w/X/wwQfP+gvZtdde67GxXcwIKBVYrVq15HQ6lZmZ6ZbAi7t7pjTK+r/VnkvhhWmhoaFKTEw8Z9uqVasqJyenyPLC3xTPp0aNGqpcubK2b99eZN0PP/wgX19fxcXFlaivM91000266aabNHr0aM2ePVtdu3bVBx98oEceeaTUfbVs2VIxMTH68MMP1bx5cy1fvlzPPfecW5uPPvpIl112mebNm+f2vgwfPrxM45f+POuxbNkyjRgxQsOGDXMtLzzDURYJCQlyOp3atm3bWQNo4TEQGRl53mPgbNsfOXKkRNv++uuv6tevn2699VYFBAToqaeeUlJSkmrVqlWk7Y4dO9x+C/7pp5/kdDrP+TXdRx99pNatW+vtt992W56Tk6Pq1auXvKhzSEhI0BdffKFmzZqdM3gW1rRjxw63rzR/++23Inf7nEtx7/+PP/5YZD889NBDevnll7Vw4UItXrxYNWrUUFJSUqle51z7OyEhQcYYxcfHFwmdxalfv77q16+v559/Xl9//bWaNWumqVOnatSoUZK8M5+dS40aNRQSEqKCgoISH+dn7ntjjH766ae/fZDhGpQKrHBSmDx5stvyiRMn/qV+g4ODiw0If0XDhg2VkJCg8ePH68iRI0XWn35Lb0JCgnJzc/Xf//7XtezXX3/V/PnzS/Rafn5+uvXWW/Xvf//b7RRpdna2Zs+erebNm5f666xDhw4VOVtQ+IO48Lf0wnGe7zbjQr6+vrrnnnu0cOFCvffeezp16lSRr3cKf4M8/bXXrVunNWvWlGr85+tTktLS0srcZ3Jysnx9ffXiiy8WOYNQ+DpJSUkKDQ3VmDFjit0/Z97WfabOnTtrzZo1+uyzz4qsy8nJ0alTp1zPe/fuLafTqbffflvTpk2Tv7+/Hn744WLP+EyaNMnteeHnp127dmcdi5+fX5G+5s6dW6LbbEuqc+fOKigo0MiRI4usO3XqlOszmpiYqEqVKmnixIluYyrt+7lgwQK38a9fv17r1q0rsh+uvfZaXXvttXrrrbf08ccfq0uXLuc9+3W68+3vu+++W35+fhoxYkSRfWyMcd0Kn5eX5/aeS3+GFV9fX7fPpDfms3Px8/NTp06d9PHHH7vdpl2ouOO88A6qQh999JF+/fXXcx6DfwecQanAGjZsqE6dOiktLU2///676zbjH3/8UVLZf3No2LChvvjiC73yyiuKjY1VfHx8kdtyS8vX11dvvfWW2rVrp6uvvlo9e/bUJZdcor1792rFihUKDQ3VwoULJf351cczzzyjjh076oknnnDdinrFFVeU+ALEUaNGaenSpWrevLkef/xx+fv764033lB+fr7GjRtX6vHPnDlTkydPVseOHZWQkKDDhw/rzTffVGhoqNq3b+9qV5LbjE933333aeLEiRo+fLjq16+vevXqua2//fbbNW/ePHXs2FEdOnRQZmampk6dqquuuqrYoFcSoaGhatmypcaNG6eTJ0/qkksu0eeff67MzMwy9Sf9ed3Tc889p5EjR6pFixa6++675XA4tGHDBsXGxio1NVWhoaGaMmWKunXrphtuuEFdunRRjRo19Msvv+jTTz9Vs2bN9Prrr5/1NZ5++ml98sknuv3229WjRw81bNhQR48e1ZYtW/TRRx9p165dql69uqZPn65PP/1UM2bMcJ3mnzhxoh588EFNmTKlyEXlmZmZuvPOO3XbbbdpzZo1mjVrlh544AG3r9rOdPvtt+vFF19Uz5491bRpU23ZskXp6eluZzD+qlatWunRRx9VamqqNm/erFtvvVWVKlXSjh07NHfuXL322mu65557XP+HSmpqqm6//Xa1b99emzZt0uLFi0t1Nufyyy9X8+bN9dhjjyk/P19paWmqVq1asV+pPfTQQ67/q6e0X++cb38nJCRo1KhRGjJkiHbt2qXk5GSFhIQoMzNT8+fPV58+ffTUU09p+fLl6tu3r+69915dccUVOnXqlN577z1XQCjkjfnsfMaOHasVK1aocePG6t27t6666iodPHhQGRkZ+uKLL3Tw4EG39hEREWrevLl69uyp7OxspaWl6fLLL1fv3r29Ok7rXeC7hnAehbfi/fbbb2ddd7qjR4+alJQUExERYapUqWKSk5PN9u3bjSQzduzY8/ZbeJvt6bfF/vDDD6Zly5YmKCjovLcpFt4md+atfsXdrmfMn7cG3n333aZatWrG4XCYWrVqmc6dO5tly5a5tfv888/NNddcYwICAsyVV15pZs2addbbjFNSUoodW0ZGhklKSjJVqlQxlStXNq1btzZff/11sfWfeftwYV0rVqxw9XX//febmjVrGofDYSIjI83tt99uvvnmG7ftSnqbcSGn02ni4uKMJDNq1Khi148ZM8bUqlXLOBwO06BBA7No0aIit2IX7u9//etfRfoo7r343//+Zzp27GjCw8NNWFiYuffee82+ffvOent6SY4bY4x55513TIMGDYzD4TBVq1Y1rVq1MkuXLnVrs2LFCpOUlGTCwsJMYGCgSUhIMD169CiyL4tz+PBhM2TIEHP55ZebgIAAU716ddO0aVMzfvx4c+LECbNnzx4TFhZm7rjjjiLbduzY0QQHB5udO3e61bZt2zZzzz33mJCQEFO1alXTt29f88cff7htW9xtxv/v//0/ExMTY4KC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85I36rRxTjLGmP/85z/mueeeM/PmzTOSzPz588/ZfufOnaZy5cpm4MCBZtu2bWbixInGz8/PLFmyxNXmQsxL1gWURo0amZSUFNfzgoICExsba1JTU4ttn5KSYtq0aeO2bODAgaZZs2Zuyw4fPmzq1Kljli5dalq1amXFROCNWp955hnTvHlz7wz4L/BGrR06dDC9evVya3P33Xebrl27enDkpVPaOmNiYszrr7/utuzMGkrb54XijVrPtH//fiPJrFq1yjODLiNv1XoxzEslqdXGeckbddo4J52pJAFl0KBB5uqrr3Zbdt9995mkpCTX8wsxL1n1Fc+JEye0ceNGJSYmupb5+voqMTFRa9asKXabpk2bauPGja5TSzt37tR//vMftW/f3q1dSkqKOnTo4NZ3efJWrZ988oluvPFG3XvvvYqMjFSDBg305ptvereY8/BWrU2bNtWyZcv0448/SpK+/fZbffnll2rXrp0Xqzm7stSZn5+vwMBAt2VBQUH68ssvy9znheCNWouTm5srSYqIiPDAqMvGm7VeDPNSSWq1bV7yVp22zUlltWbNmiLHZFJSkmvfXKh5qdz+q/viHDhwQAUFBUX+u/uoqCj98MMPxW7zwAMP6MCBA2revLmMMTp16pT++c9/6tlnn3W1+eCDD5SRkaENGzZ4dfyl4a1ad+7cqSlTpmjgwIF69tlntWHDBj3xxBMKCAhQ9+7dvVrT2Xir1sGDBysvL09169aVn5+fCgoKNHr0aHXt2tWr9ZxNWepMSkrSK6+8opYtWyohIUHLli3TvHnzVFBQUOY+LwRv1Homp9Op/v37q1mzZrrmmms8XkNJeavWi2VeKkmtts1L3qrTtjmprLKysordN3l5efrjjz906NChCzIvWXUGpSxWrlypMWPGaPLkycrIyNC8efP06aefauTIkZKkPXv26Mknn1R6enqR9FvRnK9W6c9J/YYbbtCYMWPUoEED9enTR71799bUqVPLceSlV5Ja58yZo/T0dM2ePVsZGRmaOXOmxo8fr5kzZ5bjyEvntddeU506dVS3bl0FBASob9++6tmzp3x9K/xHs4jS1pqSkqLvvvtOH3zwwQUe6V93vlovpnmpJO/rxTAvlaTOi2FOsolVs2D16tXl5+en7Oxst+XZ2dmKjo4udpuhQ4eqW7dueuSRR1S/fn117NhRY8aMUWpqqpxOpzZu3Kj9+/frhhtukL+/v/z9/bVq1SpNmDBB/v7+Z/3tzdu8UaskxcTE6KqrrnLbrl69evrll1+8U0gJeKvWp59+WoMHD1aXLl1Uv359devWTQMGDFBqaqrXaypOWeqsUaOGFixYoKNHj2r37t364YcfVKVKFV122WVl7vNC8Eatp+vbt68WLVqkFStW6NJLL/VKDSXljVovpnmpJO+rbfOSt+q0bU4qq+jo6GL3TWhoqIKCgi7YvGRVQAkICFDDhg21bNky1zKn06lly5apSZMmxW5z7NixIr+B+fn5SZKMMWrbtq22bNmizZs3ux433nijunbtqs2bN7vaXmjeqFWSmjVrVuS2zB9//FG1atXy5PBLxVu1nq1NYYC50MpSZ6HAwEBdcsklOnXqlD7++GPdddddf7lPb/JGrdKf723fvn01f/58LV++XPHx8V6roaS8UevFNC8VOtf7atu85K06bZuTyqpJkyZu+0aSli5d6to3F2xe8tjlth7ywQcfGIfDYWbMmGG2bdtm+vTpY8LDw01WVpYxxphu3bqZwYMHu9oPHz7chISEmPfff9/s3LnTfP755yYhIcF07tz5rK9hy9Xy3qh1/fr1xt/f34wePdrs2LHDpKenm8qVK5tZs2Zd8PpO541au3fvbi655BLXLX3z5s0z1atXN4MGDbrg9RUqbZ1r1641H3/8sfn555/N6tWrTZs2bUx8fLw5dOhQifssL96o9bHHHjNhYWFm5cqV5tdff3U9jh07dqHLc+ONWs9UUeelktRq47zkjTptnJOM+fNusU2bNplNmzYZSeaVV14xmzZtMrt37zbGGDN48GDTrVs3V/vC24yffvpp8/3335tJkyYVe5uxt+cl6wKKMcZMnDjR1KxZ0wQEBJhGjRqZtWvXuta1atXKdO/e3fX85MmT5oUXXjAJCQkmMDDQxMXFmccff7xCTATGeKfWhQsXmmuuucY4HA5Tt25dM23atAtUzbl5uta8vDzz5JNPmpo1a5rAwEBz2WWXmeeee87k5+dfwKqKKk2dK1euNPXq1TMOh8NUq1bNdOvWzezdu7dUfZYnT9cqqdjH9OnTL1BFZ+eN9/V0FXVeKmmtNs5Lnq7T1jlpxYoVxX6uCuvr3r27adWqVZFtrr/+ehMQEGAuu+yyYj+D3p6XfIwp5//iDgAA4AxWXYMCAAAgEVAAAICFCCgAAMA6BBQAAGAdAgoAALAOAQUAAFiHgAIAAKxDQAEAANYhoAAAAOsQUAAAgHUIKAAAwDr/H7wEELcUQ5NDAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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LO6AWtxy77vvPlO1alVz8uRJZ1uHDh2KrCsvL89ERESYpKQkZ9srr7xiJJlp06YVWW7hh9f//M//GElm6dKlLtPXrFlTbPu5OnXqZJo3b+5SX0FBgWnTpo2pX7++S9++ffuaqlWrmp9++sk899xzRpJLCDp721544QWXbWvZsqUJCwtzvkeLCx/F7b9//etfRpLZuHGjs+18H2bn9jt8+LCx2+3m//2//+dse/LJJ021atXMTz/95LKecePGGU9PT7N//35jjDGrVq0yksyzzz7r7HP69GnTvn17t8JHXFycy3Hp2WefNZLMu+++a4z5MxTUrFnT9O7d22X+adOmGZvNZnbv3n3B9ZR0f7/++uvGw8PD/M///I/L/AsWLDCSzH/+8x9jjDHTp083ksyvv/563nV+8cUXJdoHhS40XmvWrHHpe77jT0FBgalfv75JTEx0CaInTpwwderUMTfffLOzrfD4eccdd7gse/jw4UaS+frrr0tU9+WCr13KUEJCgmJjY53PW7RooYCAAO3evVvSn9//vf322+ratauMMTpy5IjzkZiYqOzsbH355Zcuy+zfv7+qVKnifN66dWsZYzRo0CCXfq1bt9aBAwd0+vRpl/b4+HjFxcU5n9eqVUvdunXT2rVrdebMGbdqWr16tSIjI9WzZ0/n8qpWraphw4a5tZ/uv/9+l+ft27fX0aNHnacgV65cqYKCAvXq1culnoiICNWvX1/r1693a31nS05Olq+vr/P5li1bdPjwYQ0fPlw+Pj7O9i5duqhRo0b68MMPS1R/4RhLUmBgoHJzc/XJJ59csJa9e/eW6Da93r1769SpU1q5cqWz7eOPP1ZWVpbLVwNnb9epU6d09OhR1atXT4GBgUVeV5I0dOhQeXp6XnT9Zy/32LFjOnLkiNq3b68TJ05o27ZtLn39/Px07733Op97e3vruuuuc9k/b7/9tkJCQvTggw8WWVfh15krVqyQw+HQzTff7PIaiIuLk5+f3wVfA7/99pv+/e9/q1evXs56jxw5oqNHjyoxMVE7duxw+Uptzpw5cjgc6tmzpx5//HH169dP3bp1K7JcLy8v3XfffS7bdt999+nw4cNKT08v0f47efKkjhw5ouuvv16Sih2XczVp0kTt27d3Pg8NDVXDhg1d9umKFSvUvn17BQUFueyvhIQEnTlzxvlV6+rVq+Xl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/fr1atu2rc6cOaNt27bpzTffdP7exuTJk7Vx40Z16dJFMTExOnz4sObNm6eaNWuqXbt2kv487gQGBmrBggXy9/dXtWrV1Lp16xJfG1UaHh4eeumll9S5c2c1bdpUAwcOVI0aNfTLL79o/fr1CggI0Pvvv+8yz549e3THHXfo1ltvVVpampYsWaK7777b5bVaKVh6b00l9PHHH5tmzZoZb29v07BhQ7NkyZLz3mqbkpJSZP7ibgXNzMw0KSkpJjo62lSpUsVERESYTp06mUWLFjn7FN6atWLFCpd5C2/v+uKLL1zaC2s6+1aywpqWLFli6tevb+x2u7n66quLvSW2JDUZ8+etunfccYepWrWqCQkJMSNHjnTe/ljSW23Pvd2tuFvWjDHm7bffNu3atTPVqlUz1apVM40aNTIpKSlm+/btLv1eeOEFU6NGDWO3203btm3Nli1bznur7bn7s9Dy5cvN1Vdfbex2u6levbq55557zM8//+zSJzk52VSrVu2821XorbfeMrfccosJCwsz3t7eplatWua+++4zhw4dcpmvpLfaFtqxY4fz9unPPvusyPTff//dDBw40ISEhBg/Pz+TmJhotm3bVuQ1eL7X0NnTzh6L//znP+b66683vr6+JioqyowdO9asXbu2yJh36NDBNG3atMgyi7tl/cSJE+axxx4zderUcb7eevbsWeR3FRYtWmTi4uKMr6+v8ff3N82bNzdjx441Bw8evOj+2rVrl+nfv7+JiIgwVapUMTVq1DC33367eeutt4wxxrz77rtFbuc0xpicnBwTExNjrrrqKuctnYXbtmXLFhMfH298fHxMTEyMmTNnjsu8xd1q+/PPP5s777zTBAYGGofDYe666y5z8OBBI8lMnDjR2e98t2526dKlyLad+/o2xphjx46Z8ePHm3r16hlvb28TEhJi2rRpY55//nmX22KPHj1q+vXrZwICAozD4TD9+vUzX331lVu32m7YsMEMGzbMBAUFGT8/P3PPPfeYo0ePFjvPm2++6fz9jJIq6f425s/b5Z955hnTtGlTY7fbTVBQkImLizOTJk0y2dnZxhhjUlNTTbdu3UxUVJTx9vY2UVFRpm/fvkVuTX733XdNkyZNjJeX10X3hzvjdbHjz1dffWV69OhhgoODjd1uNzExMaZXr14mNTXV2afwOPPDDz+Ynj17Gn9/fxMUFGRGjBjh8jMBlYXNmEv4EwYArgA33nijjhw5UuxXk7iwd999V927d9fGjRtdbhmGe5544glNmjRJv/76q0JCQiq6nEvGNR8AgHLz4osvqm7dus6vNwCJaz4AAOVg2bJl+uabb/Thhx9q5syZlfaWUJQPwgcAoMz17dtXfn5+Gjx4sIYPH17R5eAywzUfAADAUlzzAQAALEX4AAAAlrrsrvkoKCjQwYMH5e/vzwVKAABUEsYYHTt2TFFRUUV+BPFcl134OHjwYJH/sRUAAFQOBw4cUM2aNS/Y57ILH/7+/pL+LD4gIKCCqwEAACWRk5Oj6Oho5+f4hVx24aPwq5aAgADCBwAAlUxJLpngglMAAGApwgcAALAU4QMAAFiK8AEAACxF+AAAAJYifAAAAEsRPgAAgKUIHwAAwFKEDwAAYCnCBwAAsBThAwAAWIrwAQAALEX4AAAAliJ8AAAAS3lVdAEAABSqPe7Dii7BbXundqnoEiodznwAAABLET4AAIClCB8AAMBShA8AAGApwgcAALCUW+Gjdu3astlsRR4pKSmSpJMnTyolJUXBwcHy8/NTUlKSMjMzy6VwAABQObkVPr744gsdOnTI+fjkk08kSXfddZckafTo0Xr//fe1YsUKbdiwQQcPHlSPHj3KvmoAAFBpufU7H6GhoS7Pp06dqtjYWHXo0EHZ2dl6+eWX9cYbb6hjx46SpMWLF6tx48batGmTrr/++rKrGgAAVFqlvuYjPz9fS5Ys0aBBg2Sz2ZSenq5Tp04pISHB2adRo0aqVauW0tLSzrucvLw85eTkuDwAAMBfV6nDx6pVq5SVlaUBAwZIkjIyMuTt7a3AwECXfuHh4crIyDjvcqZMmSKHw+F8REdHl7YkAABQCZQ6fLz88svq3LmzoqKiLqmA8ePHKzs72/k4cODAJS0PAABc3kr1f7vs27dP69at08qVK51tERERys/PV1ZWlsvZj8zMTEVERJx3WXa7XXa7vTRlAACASqhUZz4WL16ssLAwdenyf/+ZTlxcnKpUqaLU1FRn2/bt27V//37Fx8dfeqUAAOAvwe0zHwUFBVq8eLGSk5Pl5fV/szscDg0ePFhjxoxR9erVFRAQoAcffFDx8fHc6QIAAJzcDh/r1q3T/v37NWjQoCLTpk+fLg8PDyUlJSkvL0+JiYmaN29emRQKAAD+GmzGGFPRRZwtJydHDodD2dnZCggIqOhyAAAWqj3uw4ouwW17p3a5eKcrgDuf3/zfLgAAwFKEDwAAYCnCBwAAsBThAwAAWIrwAQAALEX4AAAAliJ8AAAASxE+AACApQgfAADAUoQPAABgKcIHAACwFOEDAABYivABAAAsRfgAAACWInwAAABLET4AAIClCB8AAMBShA8AAGApwgcAALAU4QMAAFiK8AEAACxF+AAAAJYifAAAAEsRPgAAgKUIHwAAwFKEDwAAYCnCBwAAsBThAwAAWIrwAQAALEX4AAAAliJ8AAAASxE+AACApQgfAADAUoQPAABgKcIHAACwFOEDAABYivABAAAsRfgAAACWcjt8/PLLL7r33nsVHBwsX19fNW/eXFu2bHFON8ZowoQJioyMlK+vrxISErRjx44yLRoAAFReboWP33//XW3btlWVKlX00Ucf6YcfftALL7ygoKAgZ59nn31Ws2bN0oIFC7R582ZVq1ZNiYmJOnnyZJkXDwAAKh8vdzo/88wzio6O1uLFi51tderUcf7bGKMZM2bo73//u7p16yZJeu211xQeHq5Vq1apT58+ZVQ2AACorNw68/Hee++pVatWuuuuuxQWFqarr75aL774onP6nj17lJGRoYSEBGebw+FQ69atlZaWVuwy8/LylJOT4/IAAAB/XW6Fj927d2v+/PmqX7++1q5dqwceeEAPPfSQ/vnPf0qSMjIyJEnh4eEu84WHhzunnWvKlClyOBzOR3R0dGm2AwAAVBJuhY+CggJdc801evrpp3X11Vdr2LBhGjp0qBYsWFDqAsaPH6/s7Gzn48CBA6VeFgAAuPy5FT4iIyPVpEkTl7bGjRtr//79kqSIiAhJUmZmpkufzMxM57Rz2e12BQQEuDwAAMBfl1vho23bttq+fbtL208//aSYmBhJf158GhERodTUVOf0nJwcbd68WfHx8WVQLgAAqOzcuttl9OjRatOmjZ5++mn16tVLn3/+uRYtWqRFixZJkmw2m0aNGqWnnnpK9evXV506dfT4448rKipK3bt3L4/6AQBAJeNW+Lj22mv1zjvvaPz48Zo8ebLq1KmjGTNm6J577nH2GTt2rHJzczVs2DBlZWWpXbt2WrNmjXx8fMq8eAAAUPnYjDGmoos4W05OjhwOh7Kzs7n+AwCuMLXHfVjRJbht79QuFV3CZcGdz2/+bxcAAGApwgcAALAU4QMAAFiK8AEAACxF+AAAAJYifAAAAEsRPgAAgKUIHwAAwFKEDwAAYCnCBwAAsBThAwAAWIrwAQAALEX4AAAAliJ8AAAASxE+AACApQgfAADAUoQPAABgKcIHAACwFOEDAABYivABAAAsRfgAAACWInwAAABLeVV0AQAAVGa1x31Y0SW4be/ULhW6fs58AAAASxE+AACApQgfAADAUoQPAABgKcIHAACwFOEDAABYivABAAAsRfgAAACWInwAAABLET4AAIClCB8AAMBShA8AAGApwgcAALAU4QMAAFiK8AEAACzlVvh44oknZLPZXB6NGjVyTj958qRSUlIUHBwsPz8/JSUlKTMzs8yLBgAAlZfbZz6aNm2qQ4cOOR+fffaZc9ro0aP1/vvva8WKFdqwYYMOHjyoHj16lGnBAACgcvNyewYvL0VERBRpz87O1ssvv6w33nhDHTt2lCQtXrxYjRs31qZNm3T99ddferUAAKDSc/vMx44dOxQVFaW6devqnnvu0f79+yVJ6enpOnXqlBISEpx9GzVqpFq1aiktLe28y8vLy1NOTo7LAwAA/HW5FT5at26tV199VWvWrNH8+fO1Z88etW/fXseOHVNGRoa8vb0VGBjoMk94eLgyMjLOu8wpU6bI4XA4H9HR0aXaEAAAUDm49bVL586dnf9u0aKFWrdurZiYGL355pvy9fUtVQHjx4/XmDFjnM9zcnIIIAAA/IVd0q22gYGBatCggXbu3KmIiAjl5+crKyvLpU9mZmax14gUstvtCggIcHkAAIC/rksKH8ePH9euXbsUGRmpuLg4ValSRampqc7p27dv1/79+xUfH3/JhQIAgL8Gt752efjhh9W1a1fFxMTo4MGDmjhxojw9PdW3b185HA4NHjxYY8aMUfXq1RUQEKAHH3xQ8fHx3OkCAACc3AofP//8s/r27aujR48qNDRU7dq106ZNmxQaGipJmj59ujw8PJSUlKS8vDwlJiZq3rx55VI4AAConGzGGFPRRZwtJydHDodD2dnZXP8BAFeY2uM+rOgSrgh7p3Yp82W68/nN/+0CAAAsRfgAAACWInwAAABLET4AAIClCB8AAMBShA8AAGApwgcAALAU4QMAAFiK8AEAACxF+AAAAJYifAAAAEsRPgAAgKUIHwAAwFKEDwAAYCnCBwAA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AQG82SoRxqtyYbwqF8arcimP8brYGY9CZX7Bqbe3t+Li4pSamupsKygoUGpqquLj48t6dQAAoJIpl69dxowZo+TkZLVq1UrXXXedZsyYodzcXA0cOLA8VgcAACqRcgkfvXv31q+//qoJEyYoIyNDLVu21Jo1a4pchFqZ2e12TZw4schXRrg8MV6VC+NVuTBelcvlMF42U5J7YgAAAMoI/7EcAACwFOEDAABYivABAAAsRfgAAACWInwAAABLET4uYO7cuapdu7Z8fHzUunVrff755+ft++KLL6p9+/YKCgpSUFCQEhISLtgfZc+d8TrbsmXLZLPZ1L179/ItEC7cHa+srCylpKQoMjJSdrtdDRo00OrVqy2qFu6O14wZM9SwYUP5+voqOjpao0eP1smTJy2q9sq2ceNGde3aVVFRUbLZbFq1atVF5/n00091zTXXyG63q169enr11VfLt0iDYi1btsx4e3ubV155xXz//fdm6NChJjAw0GRmZhbb/+677zZz5841X331lfnxxx/NgAEDjMPhMD///LPFlV+Z3B2vQnv27DE1atQw7du3N926dbOmWLg9Xnl5eaZVq1bmtttuM5999pnZs2eP+fTTT83WrVstrvzK5O54LV261NjtdrN06VKzZ88es3btWhMZGWlGjx5tceVXptWrV5vHHnvMrFy50kgy77zzzgX7796921StWtWMGTPG/PDDD2b27NnG09PTrFmzptxqJHycx3XXXWdSUlKcz8+cOWOioqLMlClTSjT/6dOnjb+/v/nnP/9ZXiXiLKUZr9OnT5s2bdqYl156ySQnJxM+LOTueM2fP9/UrVvX5OfnW1UizuLueKWkpJiOHTu6tI0ZM8a0bdu2XOtEUSUJH2PHjjVNmzZ1aevdu7dJTEwst7r42qUY+fn5Sk9PV0JCgrPNw8NDCQkJSktLK9EyTpw4oVOnTql69erlVSb+V2nHa/LkyQoLC9PgwYOtKBP/qzTj9d577yk+Pl4pKSkKDw9Xs2bN9PTTT+vMmTNWlX3FKs14tWnTRunp6c6vZnbv3q3Vq1frtttus6RmuCctLc1lfCUpMTGxxJ93pVEuP69e2R05ckRnzpwp8nPw4eHh2rZtW4mW8cgjjygqKqrIgKLslWa8PvvsM7388svaunWrBRXibKUZr927d+vf//637rnnHq1evVo7d+7U8OHDderUKU2cONGKsq9YpRmvu+++W0eOHFG7du1kjNHp06d1//3369FHH7WiZLgpIyOj2PHNycnRH3/8IV9f3zJfJ2c+ysHUqVO1bNkyvfPOO/Lx8anocnCOY8eOqV+/fnrxxRcVEhJS0eWgBAoKChQWFqZFixYpLi5OvXv31mOPPaYFCxZUdGkoxqeffqqnn35a8+bN05dffqmVK1fqww8/1JNPPlnRpeEywZmPYoSEhMjT01OZmZku7ZmZmYqIiLjgvM8//7ymTp2qdevWqUWLFuVZJv6Xu+O1a9cu7d27V127dnW2FRQUSJK8vLy0fft2xcbGlm/RV7DSvL8iIyNVpUoVeXp6OtsaN26sjIwM5efny9vbu1xrvpKVZrwef/xx9evXT0OGDJEkNW/eXLm5uRo2bJgee+wxeXjwd+/lJCIiotjxDQgIKJezHhJnPorl7e2tuLg4paamOtsKCgqUmpqq+Pj488737LPP6sknn9SaNWvUqlUrK0qF3B+vRo0a6dtvv9XWrVudjzvuuEM33XSTtm7dqujoaCvLv+KU5v3Vtm1b7dy50xkSJemnn35SZGQkwaOclWa8Tpw4USRgFAZHw/9letmJj493GV9J+uSTTy74eXfJyu1S1kpu2bJlxm63m1dffdX88MMPZtiwYSYwMNBkZGQYY4zp16+fGTdunLP/1KlTjbe3t3nrrbfMoUOHnI9jx45V1CZcUdwdr3Nxt4u13B2v/fv3G39/fzNixAizfft288EHH5iwsDDz1FNPVdQmXFHcHa+JEycaf39/869//cvs3r3bfPzxxyY2Ntb06tWrojbhinLs2DHz1Vdfma+++spIMtOmTTNfffWV2bdvnzHGmHHjxpl+/fo5+xfeavu3v/3N/Pjjj2bu3LncaluRZs+ebWrVqmW8vb3NddddZzZt2uSc1qFDB5OcnOx8HhMTYyQVeUycONH6wq9Q7ozXuQgf1nN3vP773/+a1q1bG7vdburWrWv+8Y9/mNOnT1tc9ZXLnfE6deqUeeKJJ0xsbKzx8fEx0dHRZvjw4eb333+3vvAr0Pr164v9PCoco+TkZNOhQ4ci87Rs2dJ4e3ubunXrmsWLF5drjTZjOAcGAACswzUfAADAUoQPAABgKcIHAACwFOEDAABYivABAAAsRfgAAACWInwAAABLET4AAIClCB8AAMBShA8AAGApwgcAALDU/wf2dPcIXqMj8AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for name, expl in [('left', lexpl_max), ('right', rexpl_max), ('unembed', uexpl_max)]:\n",
    "    plt.hist(expl.tolist())\n",
    "    plt.title(f'{name} neurons: variance explained by best irrep')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "fed5a553",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.8995, 0.9966, 0.8827, 0.8718, 0.9829, 0.8572, 0.9966, 0.9976, 0.8929,\n",
       "        0.9801, 0.8829, 0.8980, 0.8740, 0.8753, 0.9868, 0.8605, 0.8807, 0.8512,\n",
       "        0.9970, 0.1641, 0.8530, 0.9837, 0.8396, 0.8631, 0.8885, 0.8889, 0.9903,\n",
       "        0.8564, 0.9849, 0.8724, 0.8696, 0.8915, 0.8539, 0.9870, 0.8659, 0.9852,\n",
       "        0.8498, 0.9989, 0.9856, 0.9976, 0.8412, 0.8937, 0.9973, 0.9972, 0.9865,\n",
       "        0.9872, 0.9875, 0.9973, 0.8374, 0.9974, 0.8749, 0.9990, 0.9965, 0.9887,\n",
       "        0.8794, 0.9966, 0.9831, 0.8702, 0.8688, 0.9966, 0.8733, 0.9970, 0.9958,\n",
       "        0.8873, 0.8475, 0.9980, 0.9881, 0.9849, 0.9974, 0.9860, 0.8741, 0.9848,\n",
       "        0.9025, 0.8982, 0.8755, 0.9480, 0.9972, 0.8818, 0.8549, 0.8484, 0.8942,\n",
       "        0.8554, 0.9879, 0.8555, 0.8464, 0.9972, 0.8691, 0.9000, 0.8656, 0.9973,\n",
       "        0.8778, 0.8899, 0.9970, 0.9867, 0.8821, 0.8670, 0.9017, 0.9972, 0.4711,\n",
       "        0.9897, 0.8466, 0.9865, 0.8943, 0.8761, 0.8806, 0.9969, 0.8691, 0.9972,\n",
       "        0.9965, 0.8682, 0.8749, 0.9964, 0.9041, 0.9973, 0.9882, 0.8560, 0.9171,\n",
       "        0.9009, 0.8688, 0.8896, 0.8773, 0.8566, 0.8548, 0.8670, 0.8638, 0.8550,\n",
       "        0.8908, 0.9972])"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "uexpl_max"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "b260c80c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.9993, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 0.9999, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 0.7221, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 0.9993, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9993, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        0.9992, 1.0000, 1.0000, 0.9999, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9993, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9978, 1.0000, 0.7364,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 1.0000, 0.9995, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        0.9995, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000])"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lexpl_max"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "391db712-4bde-4137-be62-73ae274463ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1d-0 1\n",
      "1d-1 1\n",
      "3d-0 1\n",
      "3d-1 1\n",
      "3d-2 1\n",
      "3d-3 1\n",
      "4d-0 1\n",
      "4d-1 1\n",
      "5d-0 1\n",
      "5d-1 1\n"
     ]
    }
   ],
   "source": [
    "# Get Frobenius-Schur indicators\n",
    "# +1 means real irrep. Otherwise, complex.\n",
    "for name, irrep in irreps.items():\n",
    "    print(name, group.get_frobenius_schur(irrep))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "782267d3-ec8a-4a4b-b9b3-7fbbd2fcf0e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1d-0 0\n",
      "1d-1 3\n",
      "3d-0 0\n",
      "3d-1 73\n",
      "3d-2 0\n",
      "3d-3 0\n",
      "4d-0 50\n",
      "4d-1 0\n",
      "5d-0 0\n",
      "5d-1 0\n",
      "none 2\n"
     ]
    }
   ],
   "source": [
    "thresh = 0.95\n",
    "norm_thresh = 1\n",
    "irrep_idx_dict = {\n",
    "    name: [\n",
    "        i for i in range(lneurons.shape[-1]) \n",
    "        if lexpl[name][i].item() > thresh and lneurons[:,i].norm() > norm_thresh\n",
    "    ]\n",
    "    for name in irreps\n",
    "}\n",
    "irrep_idx_dict['none'] = [\n",
    "    i for i in range(lneurons.shape[-1])\n",
    "    if all(lexpl[name][i].item() <= thresh for name in irreps) or lneurons[:,i].norm() < norm_thresh \n",
    "]\n",
    "for k, v in irrep_idx_dict.items():\n",
    "    print(k, len(v))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "3445aca7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1d-1\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3d-1\n"
     ]
    },
    {
     "data": {
      "image/png": "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Myd+/OMfxxFHHBHjx4+P6667LhobG+Pss88u5dwAQIXqd3w8+eSTccopp/Q+bm1tjYiIWbNmxaJFi+Kaa66J7u7uuOKKK2Ljxo0xbdq0WLp0adTU1JRuagCgYlUVRVEM9BD/V1dXV9TV1cWmTZvc/wHsFSrxuxng45Tju1368/V7wL/bBQDYt4gPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACCV+AAAUokPACBVyePjhhtuiKqqqj7b0UcfXerTAAAValg53vTYY4+NP/7xj/97kmFlOQ0AUIHKUgXDhg2LhoaGcrw1AFDhynLPxwsvvBCNjY0xYcKEuPjii+O11177yGN7enqiq6urzwYADF4lj48pU6bEokWLYunSpXHHHXfEunXr4itf+Ups3rx5p8e3tbVFXV1d79bU1FTqkQCAvUhVURRFOU+wcePGOOyww2LBggVx2WWX7fB8T09P9PT09D7u6uqKpqam2LRpU9TW1pZzNIBdMm7uwwM9ApTUKz85o+Tv2dXVFXV1dbv09bvsd4KOGjUqjjzyyHjxxRd3+nx1dXVUV1eXewwAYC9R9v/Px5YtW+Kll16KsWPHlvtUAEAFKHl8fP/734/ly5fHK6+8En/961/jnHPOiaFDh8aFF15Y6lMBABWo5B+7vP7663HhhRfGO++8E2PGjIlp06bFqlWrYsyYMaU+FQBQgUoeH4sXLy71WwIAg4if7QIApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEApBIfAEAq8QEA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4d-0\n"
     ]
    },
    {
     "data": {
      "image/png": "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D3/I86S5le26v7Jx48a47LLL4tRTT83TZLuxzG5g0KBBmQkTJjRf3rZtW6aioiJTU1PzrW5/6623Zrp27ZrZsmVLvkbMi2zXPWHChMwpp5zSYl91dXXmxBNPzOucuZbtunv37p258847W+w799xzMxdffHFe58yXiMg88MADOz1m8uTJmSOOOKLFvvPPPz9TVVWVx8ny69us+78NHTo08/Of/zxv86SS7bq/cvjhh2dmzpyZ+4ESae26zznnnMwll1yS+4ESyWbd559/fmbatGmZ6dOnZwYOHJjXuXY3BT/z8fnnn8eaNWtixIgRzfs6dOgQI0aMiFWrVn2r+5g7d25ccMEFsffee+drzJxrzbp/8IMfxJo1a5pfonjrrbfikUceiTPPPDPJzLnQmnU3NjZGSUlJi31dunSJZ555Jq+zFtKqVata/IwiIqqqqr71nwnatqampti8eXN069at0KMk9dJLL8Wzzz4bQ4cOLfQoeTdv3rx46623Yvr06YUepSAK/q22H3/8cWzbtm27v/20V69e8dprr33j7Z9//vl45ZVXYu7cufkaMS9as+6LLrooPv744zjppJMik8nEF198EePHj29TL7u0Zt1VVVVxyy23xMknnxz9+/ePZcuWxeLFi2Pbtm0pRi6IDRs27PBnVF9fH//5z3+iS5cuBZqMFG6++ebYsmVL/OhHPyr0KEnsv//+8dFHH8UXX3wRM2bMiCuuuKLQI+XVG2+8EVOmTImnn346OnUq+K/hgij4mY9dNXfu3DjqqKNi0KBBhR4l75YvXx7/93//F3fddVe8+OKLsXjx4nj44YfjxhtvLPRoeXXbbbfFwQcfHAMGDIjOnTvHxIkTY9y4cdGhQ5t/+sJ2FixYEDNnzoz77rsvevbsWehxknj66afjhRdeiLvvvjtmzZoVCxcuLPRIebNt27a46KKLYubMmXHIIYcUepyCKXhy7bvvvtGxY8eoq6trsb+uri7Ky8t3etuGhoZYtGhR3HDDDfkcMS9as+7rrrsuLr300ub/KzjqqKOioaEhrrrqqvj1r3/dJn4Zt2bdPXr0iCVLlsRnn30Wn3zySVRUVMSUKVOiX79+KUYuiPLy8h3+jEpLS531aMcWLVoUV1xxRdx///3bvezWnvXt2zcivvxvWl1dXcyYMSMuvPDCAk+VH5s3b44XXnghXnrppZg4cWJEfPkyWyaTiU6dOsVjjz0Wp5xySoGnzL+C/7bq3LlzHHfccbFs2bLmfU1NTbFs2bIYMmTITm97//33R2NjY1xyySX5HjPnWrPuTz/9dLvA6NixY0REZNrIV/Tsyr/vkpKS2G+//eKLL76Iv/zlL3H22Wfne9yCGTJkSIufUUTE448//o0/I9quhQsXxrhx42LhwoVt8q8NyJWmpqZobGws9Bh5U1paGv/4xz+itra2eRs/fnwceuihUVtbG4MHDy70iEkU/MxHRER1dXWMHTs2jj/++Bg0aFDMmjUrGhoaYty4cRERcdlll8V+++0XNTU1LW43d+7cGD16dHTv3r0QY++ybNc9atSouOWWW+LYY4+NwYMHx9q1a+O6666LUaNGNUdIW5Dtup977rl477334phjjon33nsvZsyYEU1NTTF58uRCLiMrW7ZsibVr1zZfXrduXdTW1ka3bt2iT58+MXXq1HjvvffinnvuiYiI8ePHx5133hmTJ0+OH//4x/Hkk0/GfffdFw8//HChltAq2a47IqK2trb5th999FHU1tZG586d4/DDD089fqtlu+4FCxbE2LFj47bbbovBgwfHhg0bIuLLN1aXlZUVZA2tke26Z8+eHX369IkBAwZExJcfOb755pvjZz/7WUHmb61s1t2hQ4c48sgjW9y+Z8+eUVJSst3+dq3An7Zpdscdd2T69OmT6dy5c2bQoEGZ1atXN183dOjQzNixY1sc/9prr2UiIvPYY48lnjS3sln31q1bMzNmzMj0798/U1JSkqmsrMz89Kc/zfz73/9OP/guymbdy5cvzxx22GGZ4uLiTPfu3TOXXnpp5r333ivA1K331FNPZSJiu+2rdY4dOzYzdOjQ7W5zzDHHZDp37pzp169fZt68ecnn3lWtWfeOjj/ggAOSz74rsl330KFDd3p8W5Htum+//fbMEUcckdlrr70ypaWlmWOPPTZz1113ZbZt21aYBbRSa57n/21P/KhtUSbTRs7XAwDtQsHf8wEA7FnEBwCQlPgAAJISHwBAUuIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFL/D6B0euwoYSpkAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "none\n"
     ]
    },
    {
     "data": {
      "image/png": "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5sWyZcvi0ksvjfLy8ti+fXvcfffdMW/evK4oAQBOXTnHyPz582P//v2xdOnSaGpqiunTp8f69eu7XtS6a9eubldClixZEnl5ebFkyZJ4880346yzzop58+bFP//zP5+8swAAhqy8bAg8V9La2hpjxoyJlpaWKC4uPqm3XXbnupN6ewNh5wPXpp4CAMfg98p7evv722fTAABJiREAICkxAgAkJUYAgKTECACQlBgBAJISIwBAUmIEAEhKjAAASYkRACApMQIAJCVGAICkxAgAkJQYAQCSEiMAQFJiBABISowAAEmJEQAgKTECACQlRgCApMQIAJCUGAEAkhIjAEBSYgQASEqMAABJiREAICkxAgAkJUYAgKTECACQlBgBAJISIwBAUmIEAEhKjAAASYkRACApMQIAJCVGAICkxAgAkJQYAQCSEiMAQFJiBABISowAAEmJEQAgKTECACQlRgCApMQIAJCUGAEAkhIjAEBSYgQASEqMAABJiREAICkxAgAkJUYAgKTECACQlBgBAJISIwBAUmIEAEhKjAAASYkRACApMQIAJNWnGFmxYkWUlZVFUVFRlJeXx8aNG497/FtvvRW33HJLnH322VFYWBgf/vCH45lnnunThAGA4WVkrgPWrl0bNTU1sXLlyigvL4/ly5dHVVVV/PKXv4zx48cfdXx7e3v82Z/9WYwfPz6eeuqpmDRpUrz++utxxhlnnIz5AwBDXM4xsmzZsli0aFFUV1dHRMTKlStj3bp1sWbNmrjzzjuPOn7NmjVx8ODBeOGFF+K0006LiIiysrITmzUAMGzk9DRNe3t7bNq0KSorK9+7gfz8qKysjMbGxh7H/Pu//3tUVFTELbfcEiUlJXHxxRfH/fffHx0dHce8nyNHjkRra2u3DQAYnnKKkQMHDkRHR0eUlJR0219SUhJNTU09jnnttdfiqaeeio6OjnjmmWfi7rvvjoceeii++MUvHvN+6uvrY8yYMV1baWlpLtMEAIaQfn83TWdnZ4wfPz5WrVoVM2bMiPnz58fnP//5WLly5THH1NbWRktLS9e2e/fu/p4mAJBITq8ZGTduXIwYMSKam5u77W9ubo4JEyb0OObss8+O0047LUaMGNG176KLLoqmpqZob2+PgoKCo8YUFhZGYWFhLlMDAIaonK6MFBQUxIwZM6KhoaFrX2dnZzQ0NERFRUWPYz72sY/F9u3bo7Ozs2vfK6+8EmeffXaPIQIAnFpyfpqmpqYmVq9eHf/6r/8aL7/8ctx8883R1tbW9e6aBQsWRG1tbdfxN998cxw8eDBuvfXWeOWVV2LdunVx//33xy233HLyzgIAGLJyfmvv/PnzY//+/bF06dJoamqK6dOnx/r167te1Lpr167Iz3+vcUpLS+NHP/pR3H777fGRj3wkJk2aFLfeemvccccdJ+8sAIAhK+cYiYhYvHhxLF68uMevbdiw4ah9FRUV8b//+799uSsAYJjz2TQAQFJiBABISowAAEmJEQAgKTECACQlRgCApMQIAJCUGAEAkhIjAEBSYgQASEqMAABJiREAICkxAgAkJUYAgKTECACQlBgBAJISIwBAUmIEAEhKjAAASYkRACApMQIAJCVGAICkxAgAkJQYAQCSEiMAQFJiBABISowAAEmJEQAgKTECACQlRgCApMQIAJCUGAEAkhIjAEBSYgQASEqMAABJiREAICkxAgAkJUYAgKTECACQlBgBAJISIwBAUmIEAEhKjAAASYkRACApMQIAJCVGAICkxAgAkJQYAQCSEiMAQFJiBABISowAAEmJEQAgKTECACQlRgCApMQIAJCUGAEAkhIjAEBSYgQASEqMAABJ9SlGVqxYEWVlZVFUVBTl5eWxcePGXo174oknIi8vL6677rq+3C0AMAzlHCNr166NmpqaqKuri82bN8e0adOiqqoq9u3bd9xxO3fujH/8x3+MK664os+TBQCGn5xjZNmyZbFo0aKorq6OqVOnxsqVK2P06NGxZs2aY47p6OiIT37yk3HPPffEeeedd0ITBgCGl5xipL29PTZt2hSVlZXv3UB+flRWVkZjY+Mxx917770xfvz4WLhwYa/u58iRI9Ha2tptAwCGp5xi5MCBA9HR0RElJSXd9peUlERTU1OPY55//vn4zne+E6tXr+71/dTX18eYMWO6ttLS0lymCQAMIf36bppDhw7Fpz71qVi9enWMGzeu1+Nqa2ujpaWla9u9e3c/zhIASGlkLgePGzcuRowYEc3Nzd32Nzc3x4QJE446/le/+lXs3Lkz5s2b17Wvs7PznTseOTJ++ctfxvnnn3/UuMLCwigsLMxlagDAEJXTlZGCgoKYMWNGNDQ0dO3r7OyMhoaGqKioOOr4Cy+8MH7+85/H1q1bu7ZPfOIT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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k, v in irrep_idx_dict.items():\n",
    "    if not v:\n",
    "        continue\n",
    "    print(k)\n",
    "    plt.hist((lneurons[:,irrep_idx_dict[k]] + 1e-8).norm(dim=0).log10().tolist())\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "b617a2bc-2715-427d-97a9-8e9b5686aaaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "irrep_name = '3d-1'\n",
    "irrep_d = irreps[irrep_name].shape[-1]\n",
    "irrep = irreps[irrep_name]\n",
    "irrep_idxs = irrep_idx_dict[irrep_name]\n",
    "irrep_lneurons = lneurons[:, irrep_idxs]\n",
    "irrep_rneurons = rneurons[:, irrep_idxs]\n",
    "irrep_uneurons = uneurons[:, irrep_idxs]\n",
    "irrep_frobschur = np.sign(group.get_frobenius_schur(irrep)).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "4ae58edd-7e10-4c4d-996d-354758bfed8a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "A and B norm diff 4.784025804838166e-06\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(torch.Size([73, 3, 3]), torch.Size([73, 3, 3]), torch.Size([73, 3, 3]))"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flat_irrep = einops.rearrange(irrep, 'n d1 d2 -> n (d1 d2)')\n",
    "rcond = t.linalg.matrix_rank(flat_irrep)\n",
    "# Project neurons onto subspace spanned by flat_irrep\n",
    "A_flat = t.linalg.lstsq(flat_irrep, irrep_lneurons, driver='gelsd').solution\n",
    "B_flat = t.linalg.lstsq(flat_irrep, irrep_rneurons, driver='gelsd').solution\n",
    "C_flat = t.linalg.lstsq(flat_irrep, irrep_uneurons, driver='gelsd').solution\n",
    "# A_flat = (t.linalg.inv(flat_irrep.H @ flat_irrep) @ flat_irrep.H @ irrep_lneurons)\n",
    "# B_flat = (t.linalg.inv(flat_irrep.H @ flat_irrep) @ flat_irrep.H @ irrep_rneurons)\n",
    "# C_flat = (t.linalg.inv(flat_irrep.H @ flat_irrep) @ flat_irrep.H @ irrep_uneurons)\n",
    "A = einops.rearrange(A_flat, '(d1 d2) m -> m d1 d2', d1=irrep_d, d2=irrep_d).mH\n",
    "B = einops.rearrange(B_flat, '(d1 d2) m -> m d1 d2', d1=irrep_d, d2=irrep_d).mH\n",
    "C = einops.rearrange(C_flat, '(d1 d2) m -> m d1 d2', d1=irrep_d, d2=irrep_d).mH\n",
    "\n",
    "A_norm = t.linalg.matrix_norm(A)\n",
    "B_norm = t.linalg.matrix_norm(B)\n",
    "print('A and B norm diff', ((A_norm - B_norm).norm()**2 / B_norm.norm()**2).item())\n",
    "\n",
    "# Normalize A and B to have unit Frobenius norm\n",
    "A = A / A_norm.unsqueeze(1).unsqueeze(1)\n",
    "B = B / A_norm.unsqueeze(1).unsqueeze(1)\n",
    "C = C * ( (A_norm + B_norm) / 2).unsqueeze(1).unsqueeze(1)\n",
    "\n",
    "A.shape, B.shape, C.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "335055bf-39b9-4916-85a1-be957d7602f3",
   "metadata": {},
   "source": [
    "### $C_i\\approx B_iA_i$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "cdc2e8fe-d9f0-4409-9c32-6e64b7212967",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGzCAYAAADnmPfhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAwqUlEQVR4nO3de1xVdb7/8fdGZaMGiBcuGl7KEu8XSt04J22i1GFKz+mYOU1Yx5w84WSjR0emJtOm8OSYedQx7WalDqZT2lHLENNKMW9QaqVpKl7YVF5APAkG398f/dzTDlA2bKQvvJ6Px3r02N/9/a71+bAR3i3W2tthjDECAACwREBNFwAAAOALwgsAALAK4QUAAFiF8AIAAKxCeAEAAFYhvAAAAKsQXgAAgFUILwAAwCqEFwAAYBXCC4AaV1JSoi5duuipp56q6VKqZPLkyerTp09NlwHUeoQXwCIFBQWaMmWKBg0apKZNm8rhcGjRokU+7aNt27ZyOByerXHjxurdu7dee+21y67NzMxUcHCwAgIC9MYbb5Q7b/v27Ro7dqw6d+6sxo0bq3Xr1rrrrru0f//+Muf//e9/19GjRzV27NhSzx08eFAPPvigrrnmGgUFBSkkJET9+vXT7Nmz9d1331W88f9v48aNXv07HA41bdpUffv21ZIlS8pdV1xcrJYtW8rhcOidd94pc84jjzyiTz75RG+//bbPdQGouPo1XQCAivv22281bdo0tW7dWt27d9fGjRsrtZ8ePXpowoQJkqScnBy9+OKLGjlypAoLCzV69Ogy1xw5ckQJCQkKCQnR9ddfr8TEREVFRelf/uVfSs397//+b23evFnDhg1Tt27d5Ha7NXfuXPXq1Utbt25Vly5dvObPmDFDd999t0JDQ73G16xZo2HDhsnpdCoxMVFdunRRUVGRPvroI02cOFF79+7VwoULK/U1ePjhh3XjjTdKkk6ePKlly5bpt7/9rc6cOaOkpKRS8zds2KCcnBy1bdtWS5Ys0eDBg0vNiYyM1JAhQ/TXv/5Vd9xxR6XqAlABBoA1zp8/b3Jycowxxmzfvt1IMq+88opP+2jTpo1JSEjwGvv666/NVVddZTp27FjmmlOnTpmOHTuaVq1amS+//NKcPn3a3HDDDSYsLMx8/vnnpeZv3rzZFBYWeo3t37/fOJ1Oc88993iN79q1y0gy69ev9xr/6quvzFVXXWViYmLMiRMnSh3jyy+/NM8991yFev6x999/30gyy5cv9xovLCw0rVq1MnFxcWWuS0xMNL169TKzZ882jRs3NgUFBWXOW7FihXE4HObgwYM+1wagYvizEWARp9OpyMhIv++3RYsWiomJ0cGDB0s9V1hYqCFDhujs2bPatGmT2rdvryZNmigtLU3t27fXoEGD5Ha7vdbExcUpMDDQa+y6665T586d9fnnn3uNr1y5UoGBgbrpppu8xp955hkVFBTopZdeUlRUVKm62rdvr3HjxlW25VICAwMVFham+vVLn5D+7rvv9NZbb+nuu+/WXXfdpe+++06rVq0qcz/x8fGSVO7zAKqO8AJA33//vY4dO6awsDCvcWOMEhMTdfjwYW3atEnXXnut57mLASYiIkK/+tWvVFBQcMljGGOUm5ur5s2be41v2bJFXbp0UYMGDbzG//d//1fXXHON4uLiqthd2c6ePatvv/1W3377rfbv368nnnhCe/bs0ciRI0vNffvtt1VQUKC7775bkZGRGjBgQLnXx4SGhuraa6/V5s2bq6VuAFzzAtRJFy5c0LfffitJcrvdeuaZZ+R2u0td6+FwOLRs2bJy9xMaGqqPP/64QsdcsmSJjh8/rmnTpnmNf/HFF6Xu0MnPz9fx48c1ZMiQCu27Mv7jP/7D63FAQICeeuqpUuOStHjxYsXFxSk6OlqSdPfdd+uhhx7SN998oxYtWpSaf8011+izzz6rnsIBEF6Auui9994r9Uv3/vvv14wZM6rleF988YWSkpLkcrlKndk4efJkqTM++fn5kqTg4OBqqUeSHn/8cc/FxqdOndLbb7+tRx99VI0bN/b6c9TJkye1bt06zZo1yzN25513KikpSW+88UaZF/eGhYUpMzOz2moH6jrCC1AL5eXled1GHBgYqKZNm3oe9+nTR3/5y19UXFysPXv26C9/+YtOnz5d6joVf3C73UpISFBoaKhWrFihevXqlZpjjPF6HBISIumHP+1Ul65du3quT5Gku+66S3l5eZo8ebJ+85vfeMLdsmXLdOHCBfXs2VMHDhzwzO/Tp4+WLFlSZngxxsjhcFRb7UBdR3gBaqFx48bp1Vdf9Tzu37+/123VzZs39/ziHjhwoGJiYvTrX/9as2fP1vjx4/1WR15engYPHqwzZ87oww8/VMuWLUvNadasmU6fPu01FhISopYtW2rPnj1+q6UibrnlFq1evVrbtm1TQkKCJHmubenXr1+Za7766itdc801XmOnT58udW0PAP8hvAC10KRJk/Tb3/7W8/inf5b5qYSEBPXv319PP/20HnzwQTVu3LjKNZw/f16333679u/fr/Xr16tTp05lzouJidGhQ4dKjf/617/WwoULlZGRIZfLVeV6KuL777+XJM/Fx4cOHdKWLVs0duxY9e/f32tuSUmJ7r33Xi1dulSPPfaY13OHDh1S9+7dr0jNQF3E3UZALdSpUyfFx8d7ttjY2Muu+eMf/6iTJ0/qhRdeqPLxi4uLNXz4cGVkZGj58uWXDB8ul0t79uxRYWGh1/ikSZPUuHFjPfDAA8rNzS217uDBg5o9e3aVa/2x1atXS5IneFw86zJp0iT9+7//u9d21113qX///qXuOsrLy9PBgwer7S4pAJx5Aawzd+5cnTlzRidOnJD0wy3Fx44dkyT9/ve/L/UutRU1ePBgdenSRc8++6ySkpJK3brsiwkTJujtt9/W7bffrlOnTmnx4sVez//4rNCQIUP05JNPatOmTbrttts849dee62WLl2q4cOHq2PHjl7vsLtlyxYtX75c9913n2f+E088oalTp+r999/XgAEDLlvjhx9+qPPnz0v65wW7mzZt0t13362YmBhJP4SXHj16eO4y+qk77rhDv//977Vr1y716tVLkrR+/XoZY6r1TimgzqvRt8gD4LM2bdoYSWVuhw4dqtD6n77D7kWLFi2q1Lv2/lT//v3LrbGsHzvdunUzo0aNKnNf+/fvN6NHjzZt27Y1gYGBJjg42PTr18/MmTPHnD9/3jNvwoQJxuFwlPmOvz928R12f7wFBgaamJgY89RTT5mioiJjjDE7d+40ksyf//zncvd1+PBhI8n84Q9/8IwNHz7c/OIXv7hkDQCqxmHMTy7zB4Ar7PXXX1dSUpKys7PVpEmTSu2jd+/eatOmjZYvX+7f4nzgdrvVrl07paamcuYFqEaEFwA1rqSkRN26ddOIESP06KOP+rw+Pz9fLVq0UFZWljp27FgNFVbM5MmTtWHDBm3btq3GagDqAsILAACwCncbAQAAqxBeAACAVQgvAADAKoQXAABgFSvepK6kpEQnTpxQcHAwH3YGAIAljDE6e/asWrZsqYAA/50vsSK8nDhxotx3uAQA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = einops.rearrange(B @ A, 'm d1 d2 -> m (d1 d2)')\n",
    "y = einops.rearrange(C, 'm d1 d2 -> m (d1 d2)')\n",
    "coef = (x.conj() * y).sum(dim=-1) / (x.conj() * x).sum(dim=-1)\n",
    "yhat = coef.unsqueeze(1) * x\n",
    "r2 = (yhat - y).norm(dim=-1).pow(2) / y.norm(dim=-1).pow(2)\n",
    "plt.hist(r2.tolist(), bins=100)\n",
    "plt.title('1-R^2(C, BA)')\n",
    "plt.show()\n",
    "good = r2 < 0.3\n",
    "\n",
    "# Restrict to good neurons\n",
    "A, B, C, coef = A[good], B[good], C[good], coef[good]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "37c20aa6-e889-4139-b4fb-c41e3c588860",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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asiQISosLJQkLVu2TDfddJNGjhypzz77TCtXrtSZM2e0YMGCTn4oAACgO3IVI2vXrpUkZWVlhezfsmWL7r//fklSdXW1YmL+94LLp59+qoULF8rv92vAgAGaPHmy9u/fr7Fjx3ZscgAA0CO4ihHHcS57THl5ecjtoqIiFRUVuRoKAAD0HvxtGgAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGCKGAEAAKaIEQAAYIoYAQAApogRAABgihgBAACmiBEAAGDKVYwUFhbqxhtvVHx8vJKSkpSTk6MTJ05c9rxt27Zp9OjRiouL0/jx47V79+6wBwYAAD2Lqxh56623lJeXp3feeUelpaX64osvdMcdd6ixsbHVc/bv3697771X8+fPV2VlpXJycpSTk6OjR492eHgAAND99XVz8J49e0JuFxcXKykpSYcOHdKtt97a4jlPP/207rzzTj300EOSpOXLl6u0tFTPPvus1q1bF+bYAACgp+jQe0bq6+slSQMHDmz1mIqKCmVnZ4fsmz59uioqKjpyaQAA0EO4emXk/wsEAlq8eLFuvvlmjRs3rtXj/H6/kpOTQ/YlJyfL7/e3ek5TU5OampqCtxsaGsIdEwAAdHFhx0heXp6OHj2qffv2deY8kv77RtmlS5d2+v22ZPgjr16y74MVM6Ny7c709cfRHR9DT9ae56erPYctfW18nfWMX9fV1jBSwn1uIvWctud+e4qe8t+MriasH9MsWrRIu3bt0ptvvqmhQ4e2eWxKSorq6upC9tXV1SklJaXVcwoKClRfXx/campqwhkTAAB0A65ixHEcLVq0SK+88oreeOMNjRgx4rLn+Hw+lZWVhewrLS2Vz+dr9Ryv16uEhISQDQAA9EyufkyTl5enrVu3aufOnYqPjw++7yMxMVFXXHGFJCk3N1dDhgxRYWGhJOmB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AgAATBEjAADAFDECAABMESMAAMAUMQIAAEwRIwAAwBQxAgAATBEjAADAFDECAABMESMAAMAUMQIAAEyFFSNr1qzR8OHDFRcXp2nTpunAgQNtHr9t2zaNHj1acXFxGj9+vHbv3h3WsAAAoOdxHSMvvvii8vPztWTJEh0+fFgTJ07U9OnT9dFHH7V4/P79+3Xvvfdq/vz5qqysVE5OjnJycnT06NEODw8AALo/1zHy1FNPaeHChZo3b57Gjh2rdevW6corr9TmzZtbPP7pp5/WnXfeqYceekhjxozR8uXLdcMNN+jZZ5/t8PAAAKD76+vm4IsXL+rQoUMqKCgI7ouJiVF2drYqKipaPKeiokL5+fkh+6ZPn64dO3a0ep2mpiY1NTUFb9fX10uSGhoa3IzbLoGmf1+yLxLXibSvP45wH0N77qelNfu6SK1he5+vzlqPcIS7PuHM3J716Kx5uqNw1zCc+47kc/F1kXxOw5m5PTrzuQjn67mznp/26Kyv3facF8nv9Z3hq/t1HKftAx0Xzp0750hy9u/fH7L/oYcecqZOndriOf369XO2bt0asm/NmjVOUlJSq9dZsmSJI4mNjY2NjY2tB2w1NTVt9oWrV0aipaCgIOTVlEAgoH/961/6xje+IY/HE9FrNzQ0KC0tTTU1NUpISIjotboj1qdtrM/lsUZtY33axvq0rautj+M4On/+vAYPHtzmca5iZNCgQerTp4/q6upC9tfV1SklJaXFc1JSUlwdL0ler1derzdkX//+/d2M2mEJCQld4onsqliftrE+l8catY31aRvr07autD6JiYmXPcbVG1hjY2M1efJklZWVBfcFAgGVlZXJ5/O1eI7P5ws5XpJKS0tbPR4AAPQurn9Mk5+fr7lz52rKlCmaOnWqVq9ercbGRs2bN0+SlJubqyFDhqiwsFCS9MADDygzM1OrVq3SzJkzVVJSooMHD2rDhg2d+0gAAEC35DpG5syZo48//liPP/64/H6/0tPTtWfPHiUnJ0uSqqurFRPzvxdcMjIytHXrVj322GN69NFHdf3112vHjh0aN25c5z2KTuT1erVkyZJLfkyE/2J92sb6XB5r1DbWp22sT9u66/p4HOdyv28DAAAQOfxtGgAAYIoYAQAApogRAABgihgBAACmel2MrFmzRsOHD1dcXJymTZumAwcOtHrssWPH9P3v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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(coef.tolist(), bins=100)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "03a5ce16-cce0-4d24-8355-e59da2f73ea9",
   "metadata": {},
   "source": [
    "### $A_i, B_i, C_i$ are low rank"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "675c54bf",
   "metadata": {},
   "source": [
    "To be specific,\n",
    "$$\n",
    "\\text{rank}(A)=\\text{rank}(B)=\\begin{cases}1 & \\iota=1 \\\\ 2 & \\iota=0 \\\\ 4 & \\iota=-1,\\end{cases}\n",
    "$$\n",
    "where $\\iota$ is the Frobenius-Schur indicator. (+1 is real irrep, 0 is complex, and -1 is quaternionic.) "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "feb3c117-a0ce-456c-810d-64ff01175faf",
   "metadata": {},
   "source": [
    "In the real case, we can write\n",
    "$$A_i\\approx a_ib_i^\\top$$\n",
    "$$B_i\\approx c_id_i^\\top$$\n",
    "$$C_i\\approx A_iB_i\\approx \\langle b_i, c_i\\rangle a_i d_i^\\top$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "56746b1c-9f5b-47cd-b7fa-11f9e84739d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "rank = {\n",
    "    1: 1,\n",
    "    0: 2,\n",
    "    -1: 4\n",
    "}[irrep_frobschur]\n",
    "\n",
    "if irrep_frobschur == 1:\n",
    "    a, b, c, d, Ss = [], [], [], [], []\n",
    "    for i in range(A.shape[0]):\n",
    "        lU, lS, lV = t.linalg.svd(A[i])\n",
    "        rU, rS, rV = t.linalg.svd(B[i])\n",
    "        Ss.append(lS[0])\n",
    "        a.append(lU[:,0])\n",
    "        b.append(lV[0])\n",
    "        c.append(rU[:,0])\n",
    "        d.append(rV[0])\n",
    "        assert lS[0]**2 / lS.norm()**2 > 0.95, lS[0]**2 / lS.norm()**2\n",
    "        assert rS[0]**2 / rS.norm()**2 > 0.95, rS[0]**2 / rS.norm()**2\n",
    "    a, b, c, d = t.stack(a, dim=0), t.stack(b, dim=0), t.stack(c, dim=0), t.stack(d, dim=0)\n",
    "    a_sign = t.sgn(a[:,0])\n",
    "    a = t.diag(a_sign) @ a\n",
    "    b = t.diag(a_sign) @ b\n",
    "    d_sign = t.sgn(d[:,0])\n",
    "    c = t.diag(d_sign) @ c\n",
    "    d = t.diag(d_sign) @ d\n",
    "    Ss = t.stack(Ss, dim=0)\n",
    "else:\n",
    "    # Our guess is that left singular vectors of A are const across neurons\n",
    "    # and same for right singular vectors of B (up to sign, etc)\n",
    "    # So we use the first neuron to get the relevant singular vectors\n",
    "    # and share them across all neurons\n",
    "    lU0 = t.linalg.svd(A[0])[0]\n",
    "    # rV0 = t.linalg.svd(B[0])[2]\n",
    "    rV0 = lU0.T\n",
    "    lUs, lVs, rUs, rVs, Ss = [], [], [], [], []\n",
    "    for i in range(A.shape[0]):\n",
    "        lS = t.linalg.svd(A[i])[1]\n",
    "        rS = t.linalg.svd(B[i])[1]\n",
    "        assert (lS[0] - rS[0])**2 / lS[0]**2 < 1e-2\n",
    "        Ss.append(lS[0])\n",
    "        assert lS[:rank].norm()**2 / lS.norm()**2 > 1-1e-2\n",
    "        assert rS[:rank].norm()**2 / rS.norm()**2 > 1-1e-2\n",
    "        lS_inv, rS_inv = t.zeros_like(lS), t.zeros_like(rS)\n",
    "        lS_inv[:rank] = 1 / lS[:rank]\n",
    "        rS_inv[:rank] = 1 / rS[:rank]\n",
    "        lV = t.diag(lS_inv) @ lU0.T @ A[i]\n",
    "        rU = B[i] @ rV0.T @ t.diag(rS_inv)\n",
    "        # check that lV and rU are orthogonal,\n",
    "        # i.e. that lU0 and rV0 are valid left/right singular vectors\n",
    "        assert ((lV @ lV.T)[:rank,:rank] - t.eye(rank)).norm() < 1e-2\n",
    "        assert ((rU.T @ rU)[:rank,:rank] - t.eye(rank)).norm() < 1e-2\n",
    "        lUs.append(lU0)\n",
    "        rUs.append(rU)\n",
    "        lVs.append(lV)\n",
    "        rVs.append(rV0)\n",
    "\n",
    "    rUs = t.stack(rUs, dim=0)\n",
    "    rVs = t.stack(rVs, dim=0)\n",
    "    lUs = t.stack(lUs, dim=0)\n",
    "    lVs = t.stack(lVs, dim=0)\n",
    "    Ss = t.stack(Ss, dim=0)\n",
    "    a, b, c, d = lUs[:,:,0], lVs[:,0], rUs[:,:,0], rVs[:,0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67fc899f-9cce-4086-a556-ed4bf41b3714",
   "metadata": {},
   "source": [
    "### $a_i,d_i$ are approx. constant and equal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "7343ec70-fa6b-40eb-95cc-5d9ebd5f16ad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(2.0258e-08)\n",
      "tensor(0.9991)\n",
      "tensor(0.9993)\n",
      "tensor(8.1571e-08)\n"
     ]
    }
   ],
   "source": [
    "for v in [a, b, c, d]:\n",
    "    print((v - v.mean(dim=0)).norm()**2 / v.norm()**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "adf7c32b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.0804e-07)"
      ]
     },
     "execution_count": 102,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(a - d).norm()**2 / a.norm()**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "517308bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "a2 = t.concat([a, -a], dim=0)\n",
    "U, S, V = t.linalg.svd(a2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "33f351d8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7d5572649780>"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlIAAAGeCAYAAABfHe8hAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABQjklEQVR4nO3dfVhUdd4/8PcMMAOoMyMhDGxomKYh5ONC41bWygpJpnfev5TI1NtkdW0307Vk702r3S7M2ofb1s1qd6Nre7DcrUxTXBY1U0dQlJQHXTXyKQZSYgYfeJzP7w+Xs44gDMMwePD9uq5z2XzP+5zzPTNM53OdOed7NCIiICIiIqIO03Z3B4iIiIjUioUUERERkYdYSBERERF5iIUUERERkYdYSBERERF5iIUUERERkYdYSBERERF5iIUUERERkYdYSBERERF5yL+7O9CTOZ1OfPPNN+jTpw80Gk13d4eIiIjcICKoqalBZGQktNp2zjmJD/zhD3+QAQMGiF6vl/j4eMnLy2sz/+GHH8qQIUNEr9dLbGysfPbZZy7znU6nPPvss2I2myUwMFDGjx8v//rXv1wy586dk0ceeUT69OkjRqNR/ud//kdqamqU+du2bZMHH3xQzGazBAcHy/Dhw+Wdd97pcF/acurUKQHAiRMnTpw4cVLhdOrUqXaP9V1+RuqDDz7AokWLsGbNGiQkJOD3v/89kpKScOTIEYSFhbXI7969G6mpqcjMzMQDDzyA9957D1OmTMH+/fsRGxsLAFi5ciVWrVqFt99+G9HR0Xj22WeRlJSEkpISBAYGAgDS0tJQXl6OnJwcNDQ0YPbs2UhPT8d7772nbOeOO+7AM888g/DwcGzcuBGPPfYYjEYjHnjgAbf70pY+ffoAAE6dOgWDweCV95OIiIi6lsPhQFRUlHIcb5Pbp1c8FB8fLwsWLFBeNzU1SWRkpGRmZraaf/jhhyUlJcWlLSEhQX784x+LyOWzUWazWV5++WVlfnV1tej1enn//fdFRKSkpEQAyN69e5XM5s2bRaPRyJkzZ67Z14kTJ8rs2bPd7kt77Ha7ABC73e5WnoiIiLpfR47fXXqxeX19PQoKCpCYmKi0abVaJCYmwmq1trqM1Wp1yQNAUlKSki8rK4PNZnPJGI1GJCQkKBmr1QqTyYQxY8YomcTERGi1WuTl5V2zv3a7HSEhIW735Wp1dXVwOBwuExEREfVcXVpInT17Fk1NTQgPD3dpDw8Ph81ma3UZm83WZr753/YyV/9s6O/vj5CQkGtu98MPP8TevXsxe/Zst/tytczMTBiNRmWKiopqNUdEREQ9A4c/ALBt2zbMnj0bb775JoYNG+bxejIyMmC325Xp1KlTXuwlERERXW+6tJAKDQ2Fn58fKioqXNorKipgNptbXcZsNreZb/63vUxlZaXL/MbGRlRVVbXY7ueff45Jkybhd7/7HR577LEO9eVqer0eBoPBZSIiIqKeq0sLKZ1Oh9GjRyM3N1dpczqdyM3NhcViaXUZi8XikgeAnJwcJR8dHQ2z2eyScTgcyMvLUzIWiwXV1dUoKChQMlu3boXT6URCQoLStn37dqSkpOCll15Cenp6h/tCREREN7iuvvJ97dq1otfrJSsrS0pKSiQ9PV1MJpPYbDYREZkxY4YsXbpUye/atUv8/f3llVdekdLSUlm+fLkEBATIoUOHlMyKFSvEZDLJ+vXr5eDBgzJ58mSJjo6WS5cuKZnk5GQZOXKk5OXlyc6dO2Xw4MGSmpqqzN+6dasEBwdLRkaGlJeXK9O5c+c61Je28K49IiIi9enI8dsnA3K++uqr0r9/f9HpdBIfHy979uxR5o0bN05mzpzpkv/www/ltttuE51OJ8OGDbvmgJzh4eGi1+tl/PjxcuTIEZfMuXPnJDU1VXr37i0Gg0Fmz57tMiDnzJkzWx18a9y4cR3qS1tYSBEREalPR47fGhGRbjsd1sM5HA4YjUbY7XZeL0VERKQSHTl+81l7KtTkFOSXVaGyphZhfQIRHx0CPy2f5UdERORrLKRUJruoHM9vKEG5vVZpizAGYvmkGCTHRnRjz4iIiG48HEdKRbKLyjH/nf0uRRQA2Oy1mP/OfmQXlXdTz4iIiG5MLKRUoskpeH5DCVq7oK257fkNJWhy8pI3IiIiX2EhpRL5ZVUtzkRdSQCU22uRX1blu04RERHd4FhIqURlzbWLKE9yRERE1HkspFQirE+gV3NERETUeSykVCI+OgQRxkBca5ADDS7fvRcfHeLLbhEREd3QWEiphJ9Wg+WTYlq92By4fI3U8kkxHE+KiIjIh1hIEREREXmIhZRKNDkFSz861GZm6UeHOPwBERGRD7GQUok9x8+h+mJDm5nqiw3Yc/ycj3pERERELKRUwvrVWa/miIiIqPNYSKmGuxeR82JzIiIiX2EhpRLfH9DXqzkiIiLqPBZSKvGvyvNezREREVHn+Xd3B8g9p7676NUcERGRmjU5BfllVaisqUVYn8sDUnfHWIospFRiQEiwV3NERERqlV1Ujuc+LYHN8Z/ny5oNgXjuwRgkx0b4tC/8aU8lZlhugaadQlujuZwjIiLqqbKLyjHvnf0uRRQA2By1mPfOfmQXlfu0PyykVMJPq0FQgF+bmeAAPz4ihoiIeqwmp2Dxh1+2mVm87kufDk7NQkol8suqcLG+qc3Mhfom5JdV+ahHREREvrX72FlcaO9YWNeE3cd8N6YiCymVqKypbT/UgRwREZHa/H3/aa/mvIGFlEqE9Qn0ao6IiEhtTp674NWcN7CQUonRA/qivcuftJrLOSIiop6orqHtn/U6mvMGFlIqUXDiO7R37ZxTLueIiIh6ono3LyJ3N+cNLKRUgtdIERHRDc/d+sh3dRQLKbXgNVJERHSj0/m7V7a4m/MGFlIqwWukiIjoRhdhcu9kgbs5b2AhpRK8RoqIiG50CdGhXs15AwspleA1UkREdKObOda9x6XNHHuLT/oDsJBSDV4jRURENzqdvxbpd0e3mUm/O9qn10j5+2xL1CkjokxezREREalRxsQYAMCbX5S5XPKi1QBz745W5vsKCymVeGfP127n5t5za9d2hoiIqBtlTIzB4glD8Vfr1zhRdREDQoIxw3KLT89ENWMhpRJ5bj6MOK+sioUUERH1eDp/LebcPbC7u9H110itXr0at9xyCwIDA5GQkID8/Pw28+vWrcPQoUMRGBiIuLg4bNq0yWW+iGDZsmWIiIhAUFAQEhMTcfToUZdMVVUV0tLSYDAYYDKZMGfOHJw/f16ZX1tbi1mzZiEuLg7+/v6YMmVKi35s374dGo2mxWSz2Tx/MzrhUn2jV3NERETUeV1aSH3wwQdYtGgRli9fjv3792P48OFISkpCZWVlq/ndu3cjNTUVc+bMwYEDBzBlyhRMmTIFRUVFSmblypVYtWoV1qxZg7y8PPTq1QtJSUmorf3P3WppaWkoLi5GTk4ONm7ciB07diA9PV2Z39TUhKCgIPzsZz9DYmJim/tw5MgRlJeXK1NYWFgn3xXPhATrvJojIiKiztOISJcNpJ6QkIDvf//7+MMf/gAAcDqdiIqKwk9/+lMsXbq0RX7atGm4cOECNm7cqLTdeeedGDFiBNasWQMRQWRkJBYvXoyf//znAAC73Y7w8HBkZWVh+vTpKC0tRUxMDPbu3YsxY8YAALKzszFx4kScPn0akZGRLtucNWsWqqur8cknn7i0b9++Hffddx++++47mEwmj/bf4XDAaDTCbrfDYDB4tI5maW/uwa7j59rN/eDWm/Du3Ds7tS0iIqIbWUeO3112Rqq+vh4FBQUuZ3y0Wi0SExNhtVpbXcZqtbY4Q5SUlKTky8rKYLPZXDJGoxEJCQlKxmq1wmQyKUUUACQmJkKr1SIvL6/D+zFixAhERETgRz/6EXbt2tVmtq6uDg6Hw2XyliCdn1dzRERE1HldVkidPXsWTU1NCA8Pd2kPDw+/5nVGNputzXzzv+1lrv75zd/fHyEhIR26vikiIgJr1qzB3//+d/z9739HVFQU7r33Xuzfv/+ay2RmZsJoNCpTVFSU29trj9ng3vhQ7uaIiIio83jX3jUMGTIEQ4YMUV6PHTsWx48fx+9+9zv89a9/bXWZjIwMLFq0SHntcDi8VkyN7N8X7+SddCtHREREvtFlhVRoaCj8/PxQUVHh0l5RUQGz2dzqMmazuc18878VFRWIiIhwyYwYMULJXH0xe2NjI6qqqq65XXfFx8dj586d15yv1+uh1+s7tY1riTQFeTVHRESkZk1OQX5ZFSprahHWJxDx0SHw07bz/Jgu0GU/7el0OowePRq5ublKm9PpRG5uLiwWS6vLWCwWlzwA5OTkKPno6GiYzWaXjMPhQF5enpKxWCyorq5GQUGBktm6dSucTicSEhI6tU+FhYUuBZwvxUeHIMLY9s92EcbLf0hEREQ9WXZROX6wYitS39yDJ9cWIvXNPfjBiq3ILir3eV+69Ke9RYsWYebMmRgzZgzi4+Px+9//HhcuXMDs2bMBAI899hi+973vITMzEwDw5JNPYty4cfjNb36DlJQUrF27Fvv27cMbb7wBANBoNFi4cCF+/etfY/DgwYiOjsazzz6LyMhIZSyo22+/HcnJyZg7dy7WrFmDhoYGPPHEE5g+fbrLHXslJSWor69HVVUVampqUFhYCADKma3f//73iI6OxrBhw1BbW4s//elP2Lp1K/7xj3905Vt2TX5aDZZPisH8d/ajtdssNQCWT4rplmqciIjIV7KLyjHvnZbXK9sctZj3zn6seXQUkmN9d9KjSwupadOm4dtvv8WyZctgs9kwYsQIZGdnKxeLnzx5Elrtf06KjR07Fu+99x5++ctf4he/+AUGDx6MTz75BLGxsUrm6aefxoULF5Ceno7q6mrcddddyM7ORmDgf87WvPvuu3jiiScwfvx4aLVaTJ06FatWrXLp28SJE3HixAnl9ciRIwFcHvATuHzX4eLFi3HmzBkEBwfjjjvuwD//+U/cd9993n+j3JQcG4HXHh2F5zeUoNz+n3GzIoyBWD4pxqd/OERERL7W5BQs/ehQm5mMjw7hRzFmn51Y6NJxpG503hxH6krXy+/CREREvrTr2Fmk/an9oYzefTwBPxgU6vF2OnL85l17KuSn1cBy603d3Q0iIiKf2nX0rNu5zhRSHeH7xyQTEREReWD/ifaf8NGRnDewkCIiIiJVOPXdJa/mvIGFFBEREanCpQanV3PewEKKiIiIVCEwwL2yxd2cN7CQIiIiIlUYEBLs1Zw3sJAiIiIiVRjZ372nd7ib8wYWUkRERKQKPxjs3pAG7ua8gYUUERERqcKdA2+CKTigzUzf4ADcOdB3Yy2ykCIiIiJV8NNqsOKhuDYzmQ/F+fRpHyykiIiISDWSYyOw5tFRMBsCXdojjIE+f2AxwEfEEBERkcokx0bgRzHm6+K5syykiIiISHWul+fO8qc9IiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg91eSG1evVq3HLLLQgMDERCQgLy8/PbzK9btw5Dhw5FYGAg4uLisGnTJpf5IoJly5YhIiICQUFBSExMxNGjR10yVVVVSEtLg8FggMlkwpw5c3D+/Hllfm1tLWbNmoW4uDj4+/tjypQprfZl+/btGDVqFPR6PQYNGoSsrCyP3gMiIiLqmbq0kPrggw+waNEiLF++HPv378fw4cORlJSEysrKVvO7d+9Gamoq5syZgwMHDmDKlCmYMmUKioqKlMzKlSuxatUqrFmzBnl5eejVqxeSkpJQW1urZNLS0lBcXIycnBxs3LgRO3bsQHp6ujK/qakJQUFB+NnPfobExMRW+1JWVoaUlBTcd999KCwsxMKFC/H4449jy5YtXnp3iIiISPWkC8XHx8uCBQuU101NTRIZGSmZmZmt5h9++GFJSUlxaUtISJAf//jHIiLidDrFbDbLyy+/rMyvrq4WvV4v77//voiIlJSUCADZu3evktm8ebNoNBo5c+ZMi23OnDlTJk+e3KL96aeflmHDhrm0TZs2TZKSktrZ6/+w2+0CQOx2u9vLEBERUffqyPG7y85I1dfXo6CgwOWMj1arRWJiIqxWa6vLWK3WFmeIkpKSlHxZWRlsNptLxmg0IiEhQclYrVaYTCaMGTNGySQmJkKr1SIvL8/t/rfXl9bU1dXB4XC4TERERNRzdVkhdfbsWTQ1NSE8PNylPTw8HDabrdVlbDZbm/nmf9vLhIWFucz39/dHSEjINbfbkb44HA5cunSp1WUyMzNhNBqVKSoqyu3tERERkfrwrj0vysjIgN1uV6ZTp051d5eIiIioC3VZIRUaGgo/Pz9UVFS4tFdUVMBsNre6jNlsbjPf/G97masvZm9sbERVVdU1t9uRvhgMBgQFBbW6jF6vh8FgcJmIiIio5+qyQkqn02H06NHIzc1V2pxOJ3Jzc2GxWFpdxmKxuOQBICcnR8lHR0fDbDa7ZBwOB/Ly8pSMxWJBdXU1CgoKlMzWrVvhdDqRkJDgdv/b6wsRERFRl961t3btWtHr9ZKVlSUlJSWSnp4uJpNJbDabiIjMmDFDli5dquR37dol/v7+8sorr0hpaaksX75cAgIC5NChQ0pmxYoVYjKZZP369XLw4EGZPHmyREdHy6VLl5RMcnKyjBw5UvLy8mTnzp0yePBgSU1NdelbcXGxHDhwQCZNmiT33nuvHDhwQA4cOKDM/+qrryQ4OFiWLFkipaWlsnr1avHz85Ps7Gy395937REREalPR47fXVpIiYi8+uqr0r9/f9HpdBIfHy979uxR5o0bN05mzpzpkv/www/ltttuE51OJ8OGDZPPPvvMZb7T6ZRnn31WwsPDRa/Xy/jx4+XIkSMumXPnzklqaqr07t1bDAaDzJ49W2pqalwyAwYMEAAtpitt27ZNRowYITqdTgYOHChvvfVWh/adhRQREZH6dOT4rRER6bbTYT2cw+GA0WiE3W7n9VJEREQq0ZHjt7+P+kReVN/oxF+tX+NE1UUMCAnGDMst0PnzBkwiIiJfYyGlMpmbSvDmF2VwXnEe8cVNpZh7dzQyJsZ0X8eIiIhuQCykVCRzUwle31HWot0pUNpZTBEREfkOfw9SifpGJ95opYi60hs7ylDf6PRRj4iIiIiFlEpk7SpDe3cFyL9zRERE5BsspFTiHyXuPSfQ3RwRERF1HgsplXBcavBqjoiIiDqPhZRKhPbWeTVHREREncdCSiViv2fyao6IiIg6j4WUSlysb/JqjoiIiDqPhZRKNDndG9bA3RwRERF1HgsplTh7vt6rOSIiIuo8FlIq0a+P3qs5IiIi6jwWUirhp9V4NUdERESdx0JKJUZE9fVqjoiIiDqPhZRKRJqCvJojIiKizmMhpRLx0SGIMAa2mYkwBiI+OsRHPSIiIiIWUirhp9Vg+aQYXOsKKA2A5ZNieI0UERGRD7GQUpHk2Ai89uioFmemIoyBeO3RUUiOjeimnhEREd2Y/Lu7A9QxybER+FGMGfllVaisqUVYn8s/5/FMFBERke+xkFIhP60Glltv6u5uEBER3fD40x4RERGRh1hIEREREXmIhRQRERGRh1hIEREREXmIhRQRERGRh1hIEREREXmIhRQRERGRh1hIEREREXmIhRQRERGRh1hIEREREXmIhRQRERGRh1hIEREREXmIhRQRERGRh3xSSK1evRq33HILAgMDkZCQgPz8/Dbz69atw9ChQxEYGIi4uDhs2rTJZb6IYNmyZYiIiEBQUBASExNx9OhRl0xVVRXS0tJgMBhgMpkwZ84cnD9/3iVz8OBB3H333QgMDERUVBRWrlzpMj8rKwsajcZlCgwM7MQ7QURERD1JlxdSH3zwARYtWoTly5dj//79GD58OJKSklBZWdlqfvfu3UhNTcWcOXNw4MABTJkyBVOmTEFRUZGSWblyJVatWoU1a9YgLy8PvXr1QlJSEmpra5VMWloaiouLkZOTg40bN2LHjh1IT09X5jscDkyYMAEDBgxAQUEBXn75ZTz33HN44403XPpjMBhQXl6uTCdOnPDyO0RERESqJV0sPj5eFixYoLxuamqSyMhIyczMbDX/8MMPS0pKiktbQkKC/PjHPxYREafTKWazWV5++WVlfnV1tej1enn//fdFRKSkpEQAyN69e5XM5s2bRaPRyJkzZ0RE5I9//KP07dtX6urqlMwzzzwjQ4YMUV6/9dZbYjQaPdxzEbvdLgDEbrd7vA4iIiLyrY4cv7v0jFR9fT0KCgqQmJiotGm1WiQmJsJqtba6jNVqdckDQFJSkpIvKyuDzWZzyRiNRiQkJCgZq9UKk8mEMWPGKJnExERotVrk5eUpmXvuuQc6nc5lO0eOHMF3332ntJ0/fx4DBgxAVFQUJk+ejOLi4mvub11dHRwOh8tEREREPVeXFlJnz55FU1MTwsPDXdrDw8Nhs9laXcZms7WZb/63vUxYWJjLfH9/f4SEhLhkWlvHldsYMmQI/vKXv2D9+vV455134HQ6MXbsWJw+fbrVvmdmZsJoNCpTVFRUqzkiIiLqGXjXXhssFgsee+wxjBgxAuPGjcNHH32Efv364fXXX281n5GRAbvdrkynTp3ycY+JiIjIl7q0kAoNDYWfnx8qKipc2isqKmA2m1tdxmw2t5lv/re9zNUXszc2NqKqqsol09o6rtzG1QICAjBy5EgcO3as1fl6vR4Gg8FlIiIiop6rSwspnU6H0aNHIzc3V2lzOp3Izc2FxWJpdRmLxeKSB4CcnBwlHx0dDbPZ7JJxOBzIy8tTMhaLBdXV1SgoKFAyW7duhdPpREJCgpLZsWMHGhoaXLYzZMgQ9O3bt9W+NTU14dChQ4iIiOjI20BEREQ9VVdf+b527VrR6/WSlZUlJSUlkp6eLiaTSWw2m4iIzJgxQ5YuXarkd+3aJf7+/vLKK69IaWmpLF++XAICAuTQoUNKZsWKFWIymWT9+vVy8OBBmTx5skRHR8ulS5eUTHJysowcOVLy8vJk586dMnjwYElNTVXmV1dXS3h4uMyYMUOKiopk7dq1EhwcLK+//rqSef7552XLli1y/PhxKSgokOnTp0tgYKAUFxe7te+8a4+IiEh9OnL87vJCSkTk1Vdflf79+4tOp5P4+HjZs2ePMm/cuHEyc+ZMl/yHH34ot912m+h0Ohk2bJh89tlnLvOdTqc8++yzEh4eLnq9XsaPHy9HjhxxyZw7d05SU1Old+/eYjAYZPbs2VJTU+OS+fLLL+Wuu+4SvV4v3/ve92TFihUu8xcuXKj0Ozw8XCZOnCj79+93e79ZSBEREalPR47fGhGR7j0n1nM5HA4YjUbY7XZeL0VERKQSHTl+8649IiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLyEAspIiIiIg+xkCIiIiLykH93d4A6rskpyC+rQmVNLcL6BCI+OgR+Wk13d4uIiOiGw0JKZbKLyvH8hhKU22uVtghjIJZPikFyLB9dQ0REN4br5aQCCykVyS4qx/x39uPqEVRt9lrMf2c/Xnt0FIspIiLq8a6nkwq8RkolmpyC5zeUtCiiAChtz28oQZOTA9UTEVHP1XxS4coiCvjPSYXsonKf9oeFlErkl1W1+KO5kgAot9civ6zKd50iIiLyoevxpAILKZWorLl2EeVJjoiISG2ux5MKLKRUIqxPoFdzREREanM9nlRgIaUS8dEhiDAG4lr3I2hw+UK7+OgQX3aLiIjIZ67HkwospFTCT6vB8kkxANCimGp+vXxSDMeTIiKiHqv5pEJbfH1SgYWUiiTHRuC1R0fBfNUfkdkYyKEPiIiox/PTahD7PUObmdjvGXx6UoHjSKlMcmwEfhRjvi4GISMiIvKl+kYn/llS2WbmnyWVqG90Qufvm3NFLKRUyE+rgeXWm7q7G0RERD719u6yVoc+uJL8Ozf3nlt90SX+tEdERETqkPeVe8MauJvzBhZSREREpAo2xyWv5ryBhRQRERGpgr+blwO7m/MGFlJERESkCtW1jV7NeQMLKSIiIlIFzTWHpfYs5w0spIiIiEgVIk1BXs15AwspIiIiUoX0uwd6NecNLKSIiIhIFe66rV+7A23q/bW467Z+PuoRCykiIiJSCT+tBqumj2gz83/TR/j0aR8spIiIiEg1kmMjsObRUQjrrXNpD++jw5pueO4sHxGjQk1O4bP2iIjohnU9PXeWhZTKZBeVY/n6YlTU1Clt4X30eH7yMJ9X4URERN3lennuLH/aU5HsonLMe2e/SxEFABU1dZj3zn5kF5V3U8+IiIhuTCykVKLJKVj04ZdtZhZ/+CWanO09F5uIiEj9mpwC6/FzWF94Btbj57rt+Mef9lRi97GzuFjf1GbmQn0Tdh87i7t9eNsnERGRr2UXleO5T0tgc9QqbWZDIJ57MMbnl7nwjJRK/K3gtFdzREREatR8mcuVRRQA2By13XKZi08KqdWrV+OWW25BYGAgEhISkJ+f32Z+3bp1GDp0KAIDAxEXF4dNmza5zBcRLFu2DBEREQgKCkJiYiKOHj3qkqmqqkJaWhoMBgNMJhPmzJmD8+fPu2QOHjyIu+++G4GBgYiKisLKlSs73BdfOXnufPuhDuSIiIjUpskpWPrRoTYzGR8d8unPfF1eSH3wwQdYtGgRli9fjv3792P48OFISkpCZWVlq/ndu3cjNTUVc+bMwYEDBzBlyhRMmTIFRUVFSmblypVYtWoV1qxZg7y8PPTq1QtJSUmorf1PdZqWlobi4mLk5ORg48aN2LFjB9LT05X5DocDEyZMwIABA1BQUICXX34Zzz33HN54440O9cVXvrmq8u5sjoiISG32fHUO1Rcb2sx8d7EBe74656MeARoR6dKyLSEhAd///vfxhz/8AQDgdDoRFRWFn/70p1i6dGmL/LRp03DhwgVs3LhRabvzzjsxYsQIrFmzBiKCyMhILF68GD//+c8BAHa7HeHh4cjKysL06dNRWlqKmJgY7N27F2PGjAEAZGdnY+LEiTh9+jQiIyPx2muv4X//939hs9mg010e1Gvp0qX45JNPcPjwYbf60h6HwwGj0Qi73Q6DweDhO3jZXStycbq6/SLpZlMgdi4d36ltERERXY9Wbj6MP35+vN3cT8bdiqfvH+rxdjpy/O7SM1L19fUoKChAYmLifzao1SIxMRFWq7XVZaxWq0seAJKSkpR8WVkZbDabS8ZoNCIhIUHJWK1WmEwmpYgCgMTERGi1WuTl5SmZe+65Rymimrdz5MgRfPfdd2715Wp1dXVwOBwuk7fcFt7HqzkiIiK1OXi62qs5b+jSQurs2bNoampCeHi4S3t4eDhsNlury9hstjbzzf+2lwkLC3OZ7+/vj5CQEJdMa+u4chvt9eVqmZmZMBqNyhQVFdVqzhMjooxezREREalNkM7Pqzlv4F17XpSRkQG73a5Mp06d8tq6dxx17/ded3NERERqM/xm904WuJvzhi4tpEJDQ+Hn54eKigqX9oqKCpjN5laXMZvNbeab/20vc/XF7I2NjaiqqnLJtLaOK7fRXl+uptfrYTAYXCbvcfdSNg7ISUREPdP+k9VezXlDlxZSOp0Oo0ePRm5urtLmdDqRm5sLi8XS6jIWi8UlDwA5OTlKPjo6Gmaz2SXjcDiQl5enZCwWC6qrq1FQUKBktm7dCqfTiYSEBCWzY8cONDQ0uGxnyJAh6Nu3r1t98aUJMa0Xb57miIiI1OZfFTVezXlDl/+0t2jRIrz55pt4++23UVpaivnz5+PChQuYPXs2AOCxxx5DRkaGkn/yySeRnZ2N3/zmNzh8+DCee+457Nu3D0888QQAQKPRYOHChfj1r3+NTz/9FIcOHcJjjz2GyMhITJkyBQBw++23Izk5GXPnzkV+fj527dqFJ554AtOnT0dkZCQA4JFHHoFOp8OcOXNQXFyMDz74AP/3f/+HRYsWud0XX5r1g2i090xrzb9zREREPVGD0+nVnDd0+SNipk2bhm+//RbLli2DzWbDiBEjkJ2drVzEffLkSWi1/6nnxo4di/feew+//OUv8Ytf/AKDBw/GJ598gtjYWCXz9NNP48KFC0hPT0d1dTXuuusuZGdnIzAwUMm8++67eOKJJzB+/HhotVpMnToVq1atUuYbjUb84x//wIIFCzB69GiEhoZi2bJlLmNNudMXX9H5a5F+TzRe31F2zUz6PdHQ+fOyNyIi6pkiDYGocNS7lfOVLh9H6kbmzXGkmmVuKsGbX5ThykFbtRpg7t3RyJgY45VtEBERXY+efP8A1n/5Tbu5ycMj8X+pIz3eTkeO33xoscpkTIzB4glD8Vfr1zhRdREDQoIxw3ILz0QREVGP99+jb3arkPrv0Tf7oDeXsZBSIZ2/FnPuHtjd3SAiIvKpsYNCEazzw8X6pmtmeun8MHZQqM/6xNMYREREpAp+Wg1++/DwNjO/eXg4/LTt3Z7lPSykiIiISDWSYyOw5tFRCO+jd2k3G/RY8+goJMdG+LQ//GlPhZqcgvyyKlTW1CKsTyDio0N8Wn0TERF1p+TYCPwoxnxdHAtZSKlMdlE5ln1ShMrz/7n9M6y3Di9MifV5FU5ERNRd/LQaWG69qbu7wZ/21CS7qBzz3tnvUkQBQOX5esx7Zz+yi8q7qWdEREQ3JhZSKtHkFPxsbWGbmSfXFqLJyWHBiIiIfIWFlErs/Ne3qG9se8j7ukYndv7rWx/1iIiIiFhIqcQbX3zl1RwRERF1Hgsplfim+pJXc0RERNR5LKRUQuDetU/u5oiIiKjzWEiphCnQvZEq3M0RERFR57GQUolGN080uZsjIiKizmMhpRJmQ5BXc0RERNR5LKRUImFgiFdzRERE1HkspFRi5thotPcEIc2/c0RERD1dk1NgPX4O6wvPwHr8XLcNSM0rk1VC569FYkwYckoqr5lJjAmDzp+1MRER9WzZReV4fkMJyu21SluEMRDLJ8X4/LmzPOqqRJNTUHTG0Wam6IyDj4ghIqIeLbuoHPPf2e9SRAGAzV6L+d3w3FkWUiqRX1bV4o/mauX2WuSXVfmoR0RERL7V5BQ8v6Gk1RETm9ue31Di05MKLKRUorKm7SKqozkiIiK1ae+kgsD3JxVYSKlEWJ9Ar+aIiIjU5no8qcBCSiXio0MQYQy85p17Gly+0C4+msMfEBFRz3Q9nlRgIaUSfloNlk+KAYAWxVTz6+WTYuCnbW+QBCIiInW6Hk8qsJBSkeTYCLz26CiYja6VttkYiNceHeXzWz6JiIh86Xo8qaAREd4v30UcDgeMRiPsdjsMBoPX1tvkFOSXVaGyphZhfS5X3jwTRUREN4quHkeqI8dvFlJdqKsKKSIiohtdV55U6MjxmyObExERker4aTWw3HpTd3eD10gREREReYqFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHurSQqqqqQlpaGgwGA0wmE+bMmYPz58+3uUxtbS0WLFiAm266Cb1798bUqVNRUVHhkjl58iRSUlIQHByMsLAwLFmyBI2NjS6Z7du3Y9SoUdDr9Rg0aBCysrJabGv16tW45ZZbEBgYiISEBOTn57vMv/fee6HRaFymefPmefZmEBERUY/TpYVUWloaiouLkZOTg40bN2LHjh1IT09vc5mnnnoKGzZswLp16/D555/jm2++wUMPPaTMb2pqQkpKCurr67F79268/fbbyMrKwrJly5RMWVkZUlJScN9996GwsBALFy7E448/ji1btiiZDz74AIsWLcLy5cuxf/9+DB8+HElJSaisrHTpz9y5c1FeXq5MK1eu9NK7Q0RERKonXaSkpEQAyN69e5W2zZs3i0ajkTNnzrS6THV1tQQEBMi6deuUttLSUgEgVqtVREQ2bdokWq1WbDabknnttdfEYDBIXV2diIg8/fTTMmzYMJd1T5s2TZKSkpTX8fHxsmDBAuV1U1OTREZGSmZmptI2btw4efLJJz3Y+8vsdrsAELvd7vE6iIiIyLc6cvzusjNSVqsVJpMJY8aMUdoSExOh1WqRl5fX6jIFBQVoaGhAYmKi0jZ06FD0798fVqtVWW9cXBzCw8OVTFJSEhwOB4qLi5XMletozjSvo76+HgUFBS4ZrVaLxMREJdPs3XffRWhoKGJjY5GRkYGLFy968nYQERFRD9Rlj4ix2WwICwtz3Zi/P0JCQmCz2a65jE6ng8lkcmkPDw9XlrHZbC5FVPP85nltZRwOBy5duoTvvvsOTU1NrWYOHz6svH7kkUcwYMAAREZG4uDBg3jmmWdw5MgRfPTRR632v66uDnV1dcprh8PRao6IiIh6hg4XUkuXLsVLL73UZqa0tNTjDl1PrryeKy4uDhERERg/fjyOHz+OW2+9tUU+MzMTzz//vC+7SERERN2ow4XU4sWLMWvWrDYzAwcOhNlsbnHhdmNjI6qqqmA2m1tdzmw2o76+HtXV1S5npSoqKpRlzGZzi7vrmu/quzJz9Z1+FRUVMBgMCAoKgp+fH/z8/FrNXKtvAJCQkAAAOHbsWKuFVEZGBhYtWqS8djgciIqKuub6iIiISN06fI1Uv379MHTo0DYnnU4Hi8WC6upqFBQUKMtu3boVTqdTKUiuNnr0aAQEBCA3N1dpO3LkCE6ePAmLxQIAsFgsOHTokEuRlpOTA4PBgJiYGCVz5TqaM83r0Ol0GD16tEvG6XQiNzdXybSmsLAQABAREdHqfL1eD4PB4DIRERFRD9aVV70nJyfLyJEjJS8vT3bu3CmDBw+W1NRUZf7p06dlyJAhkpeXp7TNmzdP+vfvL1u3bpV9+/aJxWIRi8WizG9sbJTY2FiZMGGCFBYWSnZ2tvTr108yMjKUzFdffSXBwcGyZMkSKS0tldWrV4ufn59kZ2crmbVr14per5esrCwpKSmR9PR0MZlMyt2Ax44dkxdeeEH27dsnZWVlsn79ehk4cKDcc889bu8/79ojIiJSn44cv7u0kDp37pykpqZK7969xWAwyOzZs6WmpkaZX1ZWJgBk27ZtStulS5fkJz/5ifTt21eCg4Plv/7rv6S8vNxlvV9//bXcf//9EhQUJKGhobJ48WJpaGhwyWzbtk1GjBghOp1OBg4cKG+99VaL/r366qvSv39/0el0Eh8fL3v27FHmnTx5Uu655x4JCQkRvV4vgwYNkiVLlnSoKGIhRUREpD4dOX5rRES69ZRYD+ZwOGA0GmG32/kzHxERkUp05PjNZ+0REREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReci/uztARERE1FFNTkF+WRUqa2oR1icQ8dEh8NNqfN4PFlJERESkKtlF5Xh+QwnK7bVKW4QxEMsnxSA5NsKnfeFPe0RERKQa2UXlmP/OfpciCgDK7bWY/85+ZBeV+7Q/LKSIiIhIFZqcguc3lECuMV8APL+hBE3OayW8j4UUERERqUJ+WVWLM1FXK7fXIr+sykc9YiFFREREKvFN9SWv5ryBhRQRERGpQuGp77ya8wYWUkRERKQK7l77xGukiIiIiK7ybU2dV3PewEKKiIiIVCG0t86rOW9gIUVERESq4Kd1r2xxN+cNLKSIiIhIFYJ1fl7NeQMLKSIiIlKFojPVXs15AwspIiIiUoWz5+u9mvMGFlJERESkCoagAK/mvIGFFBEREanChBizV3PewEKKiIiIVGHWD6KhaSej+XfOV1hIERERkSro/LVIv6ftIin9nmjo/H1X3vj7bEtEREREnZQxMQYA8OYXZbjySTBaDTD37mhlvq9oRMR3D6S5wTgcDhiNRtjtdhgMhu7uDhERUY9R3+jEX61f40TVRQwICcYMyy1eOxPVkeM3z0gRERGR6uj8tZhz98Du7kbXXSNVVVWFtLQ0GAwGmEwmzJkzB+fPn29zmdraWixYsAA33XQTevfujalTp6KiosIlc/LkSaSkpCA4OBhhYWFYsmQJGhsbXTLbt2/HqFGjoNfrMWjQIGRlZbnM37FjByZNmoTIyEhoNBp88sknLfoiIli2bBkiIiIQFBSExMREHD161KP3goiIiHqmLiuk0tLSUFxcjJycHGzcuBE7duxAenp6m8s89dRT2LBhA9atW4fPP/8c33zzDR566CFlflNTE1JSUlBfX4/du3fj7bffRlZWFpYtW6ZkysrKkJKSgvvuuw+FhYVYuHAhHn/8cWzZskXJXLhwAcOHD8fq1auv2ZeVK1di1apVWLNmDfLy8tCrVy8kJSWhtra2E+8KERER9SjSBUpKSgSA7N27V2nbvHmzaDQaOXPmTKvLVFdXS0BAgKxbt05pKy0tFQBitVpFRGTTpk2i1WrFZrMpmddee00MBoPU1dWJiMjTTz8tw4YNc1n3tGnTJCkpqdXtApCPP/7Ypc3pdIrZbJaXX37ZpX96vV7ef/99N96By+x2uwAQu93u9jJERETUvTpy/O6SM1JWqxUmkwljxoxR2hITE6HVapGXl9fqMgUFBWhoaEBiYqLSNnToUPTv3x9Wq1VZb1xcHMLDw5VMUlISHA4HiouLlcyV62jONK/DHWVlZbDZbC7rMRqNSEhI6NB6iIiIqGfrkovNbTYbwsLCXDfk74+QkBDYbLZrLqPT6WAymVzaw8PDlWVsNptLEdU8v3leWxmHw4FLly4hKCjIrf5fue7W+tKauro61NXVKa8dDke72yIiIiL16tAZqaVLl0Kj0bQ5HT58uKv6et3LzMyE0WhUpqioqO7uEhEREXWhDp2RWrx4MWbNmtVmZuDAgTCbzaisrHRpb2xsRFVVFczm1p9/YzabUV9fj+rqapezUhUVFcoyZrMZ+fn5Lss139V3ZebqO/0qKipgMBjcOht15boqKioQERHhsp4RI0Zcc7mMjAwsWrRIee1wOFhMERER9WAdKqT69euHfv36tZuzWCyorq5GQUEBRo8eDQDYunUrnE4nEhISWl1m9OjRCAgIQG5uLqZOnQoAOHLkCE6ePAmLxaKs98UXX0RlZaXy02FOTg4MBgNiYmKUzKZNm1zWnZOTo6zDHdHR0TCbzcjNzVUKJ4fDgby8PMyfP/+ay+n1euj1ere3Q0RERCrXVVe8Jycny8iRIyUvL0927twpgwcPltTUVGX+6dOnZciQIZKXl6e0zZs3T/r37y9bt26Vffv2icViEYvFosxvbGyU2NhYmTBhghQWFkp2drb069dPMjIylMxXX30lwcHBsmTJEiktLZXVq1eLn5+fZGdnK5mamho5cOCAHDhwQADIb3/7Wzlw4ICcOHFCyaxYsUJMJpOsX79eDh48KJMnT5bo6Gi5dOmS2+8B79ojIiJSn44cv7uskDp37pykpqZK7969xWAwyOzZs6WmpkaZX1ZWJgBk27ZtStulS5fkJz/5ifTt21eCg4Plv/7rv6S8vNxlvV9//bXcf//9EhQUJKGhobJ48WJpaGhwyWzbtk1GjBghOp1OBg4cKG+99VaL+QBaTDNnzlQyTqdTnn32WQkPDxe9Xi/jx4+XI0eOdOg9YCFFRESkPh05fvNZe12Iz9ojIiJSn44cv7tsZHMiIiKino6FFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBEREZGHWEgREREReYiFFBER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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(a2 @ V[[0]].T, a2 @ V[[1]].T)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1fe30a8c",
   "metadata": {},
   "source": [
    "#### 3d stuff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "2277b850",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_a = einops.einsum(a, irrep, 'neuron d1, G d1 d2 -> neuron G d2').flatten(0, 1)\n",
    "full_d = einops.einsum(d, irrep, 'neuron d1, G d1 d2 -> neuron G d2').flatten(0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "1acac9f6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "XXXX"
       },
       "data": [
        {
         "hovertemplate": "x=%{x}<br>y=%{y}<br>z=%{z}<extra></extra>",
         "legendgroup": "",
         "marker": {
          "color": "#636efa",
          "symbol": "circle"
         },
         "mode": "markers",
         "name": "",
         "scene": "scene",
         "showlegend": false,
         "type": "scatter3d",
         "x": [
          0.9766421318054199,
          0.9765921831130981,
          0.9766947031021118,
          0.9766491651535034,
          0.9765921831130981,
          0.9766491055488586,
          0.9767110347747803,
          0.9765923619270325,
          0.9767080545425415,
          0.9766882658004761,
          0.9766949415206909,
          0.9766880869865417,
          0.976708173751831,
          0.9766489267349243,
          0.9766495823860168,
          0.9765927791595459,
          0.9766938090324402,
          0.976707935333252,
          0.9766884446144104,
          0.9767075181007385,
          0.9766337275505066,
          0.9766948819160461,
          0.976650059223175,
          0.9766953587532043,
          0.9765925407409668,
          0.976633608341217,
          0.9766494035720825,
          0.9766881465911865,
          0.9767422080039978,
          0.9767418503761292,
          0.9766497015953064,
          0.9766888618469238,
          0.9766890406608582,
          0.9765917062759399,
          0.9767079949378967,
          0.9767533540725708,
          0.9766891598701477,
          0.9766947031021118,
          0.9766497611999512,
          0.9767398238182068,
          0.9767080545425415,
          0.976707398891449,
          0.9766950607299805,
          0.976741373538971,
          0.9767417311668396,
          0.9767410159111023,
          0.9766425490379333,
          0.976741373538971,
          0.9767076373100281,
          0.9765928387641907,
          0.9766490459442139,
          0.9766941666603088,
          0.976621150970459,
          0.9767075181007385,
          0.9767081141471863,
          0.9765920042991638,
          0.9766888618469238,
          0.9765928387641907,
          0.9767410755157471,
          0.9765923619270325,
          0.976711630821228,
          0.9766938090324402,
          0.9767075777053833,
          0.976641058921814,
          0.9766503572463989,
          0.9766947031021118,
          0.9766945242881775,
          0.976648211479187,
          0.976649820804596,
          0.9767411351203918,
          0.9766950011253357,
          0.9767417311668396,
          0.97674161195755
         ],
         "y": [
          0.08399902284145355,
          0.0840628519654274,
          0.08349021524190903,
          0.0840664878487587,
          0.084060437977314,
          0.0840689092874527,
          0.08390961587429047,
          0.08406004309654236,
          0.08391213417053223,
          0.08378097414970398,
          0.08348879218101501,
          0.08378288149833679,
          0.08391119539737701,
          0.08406753093004227,
          0.08407151699066162,
          0.08406142890453339,
          0.08348741382360458,
          0.08391023427248001,
          0.08378161489963531,
          0.08391198515892029,
          0.08368445932865143,
          0.08348926901817322,
          0.08406732231378555,
          0.0834890604019165,
          0.08406040072441101,
          0.08369456231594086,
          0.08406523615121841,
          0.083780936896801,
          0.08376538753509521,
          0.08376770466566086,
          0.0840650424361229,
          0.0837789922952652,
          0.08378209918737411,
          0.08406203985214233,
          0.08390998095273972,
          0.08378655463457108,
          0.08378206938505173,
          0.08348789066076279,
          0.08406727761030197,
          0.08376999944448471,
          0.08391135931015015,
          0.08391125500202179,
          0.08348322659730911,
          0.08376741409301758,
          0.08376576751470566,
          0.08376684784889221,
          0.08400091528892517,
          0.08376433700323105,
          0.08390970528125763,
          0.08406014740467072,
          0.0840664952993393,
          0.08348795771598816,
          0.08414509892463684,
          0.08391320705413818,
          0.08391081541776657,
          0.08406221121549606,
          0.08378279209136963,
          0.08405867218971252,
          0.08376837521791458,
          0.08406326919794083,
          0.08390443027019501,
          0.08348798751831055,
          0.08391140401363373,
          0.0841129943728447,
          0.08406843990087509,
          0.08348782360553741,
          0.08348914235830307,
          0.08406563848257065,
          0.08406636118888855,
          0.08377011120319366,
          0.08349056541919708,
          0.08376797288656235,
          0.08376717567443848
         ],
         "z": [
          -0.19777338206768036,
          -0.1979929357767105,
          -0.19772905111312866,
          -0.1977100521326065,
          -0.19799374043941498,
          -0.19770930707454681,
          -0.19747108221054077,
          -0.19799335300922394,
          -0.19748440384864807,
          -0.19763757288455963,
          -0.1977287083864212,
          -0.19763828814029694,
          -0.1974841207265854,
          -0.19771061837673187,
          -0.19770579040050507,
          -0.19799061119556427,
          -0.197734996676445,
          -0.1974860429763794,
          -0.19763711094856262,
          -0.19748727977275848,
          -0.19794823229312897,
          -0.19772851467132568,
          -0.19770491123199463,
          -0.1977265328168869,
          -0.19799242913722992,
          -0.19794438779354095,
          -0.19770917296409607,
          -0.19763819873332977,
          -0.19737759232521057,
          -0.1973787546157837,
          -0.19770808517932892,
          -0.1976361721754074,
          -0.19763365387916565,
          -0.19799542427062988,
          -0.19748568534851074,
          -0.1973138153553009,
          -0.19763362407684326,
          -0.19773006439208984,
          -0.1977066993713379,
          -0.1973876655101776,
          -0.1974845677614212,
          -0.19748817384243011,
          -0.19773049652576447,
          -0.19738084077835083,
          -0.1973801553249359,
          -0.1973833590745926,
          -0.19777050614356995,
          -0.1973823606967926,
          -0.19748784601688385,
          -0.19799068570137024,
          -0.1977105736732483,
          -0.19773271679878235,
          -0.19781501591205597,
          -0.19748657941818237,
          -0.1974848210811615,
          -0.1979939490556717,
          -0.19763417541980743,
          -0.19799110293388367,
          -0.19738231599330902,
          -0.19799146056175232,
          -0.197470024228096,
          -0.19773465394973755,
          -0.1974870264530182,
          -0.19773021340370178,
          -0.19770313799381256,
          -0.1977301687002182,
          -0.19773074984550476,
          -0.19771507382392883,
          -0.19770675897598267,
          -0.19738122820854187,
          -0.1977275311946869,
          -0.19737915694713593,
          -0.19737985730171204
         ]
        }
       ],
       "layout": {
        "legend": {
         "tracegroupgap": 0
        },
        "margin": {
         "t": 60
        },
        "scene": {
         "domain": {
          "x": [
           0,
           1
          ],
          "y": [
           0,
           1
          ]
         },
         "xaxis": {
          "title": {
           "text": "x"
          }
         },
         "yaxis": {
          "title": {
           "text": "y"
          }
         },
         "zaxis": {
          "title": {
           "text": "z"
          }
         }
        },
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        }
       }
      }
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import plotly.express as px\n",
    "fig = px.scatter_3d(x=d[:,0].tolist(), y=d[:,1].tolist(), z=d[:,2].tolist())\n",
    "fig.show()\n",
    "# fig.write_html('/home/XXXX-1/a.html')\n",
    "\n",
    "# fig = plt.figure()\n",
    "# ax = fig.add_subplot(projection='3d')\n",
    "# ax.scatter(a[:,0].tolist(), a[:,1].tolist(), a[:,2].tolist(), c='b', alpha=1.)\n",
    "# ax.scatter(full_a[:,0].tolist(), full_a[:,1].tolist(), full_a[:,2].tolist(), c='b', alpha=0.1)\n",
    "# plt.show()\n",
    "# plt.scatter(d[:,0].tolist(), d[:,1].tolist())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "f99f8a4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "a2 = t.concat([a, -a], dim=0)\n",
    "U, S, V = t.linalg.svd(a2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "42317772",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([121, 4])"
      ]
     },
     "execution_count": 156,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "84fd349d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# num_as=1\n",
    "# ahat = t.concat(\n",
    "#     [einops.repeat(a[i], 'd -> m d', m=a.shape[0]//num_as) for i in range(num_as-1)]\n",
    "#     + [einops.repeat(a[num_as-1], 'd -> m d', m=a.shape[0]-(num_as-1) * (a.shape[0]//num_as))], \n",
    "#     dim=0\n",
    "# )\n",
    "# ahat = a[t.randperm(a.shape[0])]\n",
    "# ahat = einops.repeat(b[1] - b[0], 'd -> m d', m=a.shape[0])\n",
    "# ahat = ahat / ahat.norm(dim=-1).unsqueeze(-1)\n",
    "ahat = a\n",
    "Ahat = einops.einsum(ahat, b, 'm d1, m d2 -> m d1 d2')\n",
    "Bhat = einops.einsum(c, ahat, 'm d1, m d2 -> m d1 d2')\n",
    "ln = einops.einsum(irrep, Ahat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') * A_norm\n",
    "rn = einops.einsum(irrep, Bhat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') * B_norm\n",
    "Chat = einops.einsum(coef, Bhat @ Ahat, 'm, m d1 d2 -> m d1 d2')\n",
    "un = einops.einsum(irrep, Chat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') / (A_norm + B_norm) * 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "af855964",
   "metadata": {},
   "outputs": [],
   "source": [
    "# losses = []\n",
    "# for num_as in range(2, a.shape[0]):\n",
    "#     ahat = t.concat(\n",
    "#         [einops.repeat(a[i], 'd -> m d', m=a.shape[0]//num_as) for i in range(num_as-1)]\n",
    "#         + [einops.repeat(a[num_as-1], 'd -> m d', m=a.shape[0]-(num_as-1) * (a.shape[0]//num_as))], \n",
    "#         dim=0\n",
    "#     )\n",
    "#     Ahat = einops.einsum(ahat, b, 'm d1, m d2 -> m d1 d2')\n",
    "#     Bhat = einops.einsum(c, ahat, 'm d1, m d2 -> m d1 d2')\n",
    "#     ln = einops.einsum(irrep, Ahat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') * A_norm\n",
    "#     rn = einops.einsum(irrep, Bhat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') * B_norm\n",
    "#     Chat = einops.einsum(coef, Bhat @ Ahat, 'm, m d1 d2 -> m d1 d2')\n",
    "#     un = einops.einsum(irrep, Chat.mT, 'G d1 d2, neuron d1 d2 -> G neuron') / (A_norm + B_norm) * 2\n",
    "#     losses.append(ablate_loss(t.concat([ln, other_lneurons], dim=-1), t.concat([rn, other_rneurons], dim=-1), t.concat([un, other_uneurons], dim=-1))['G0_loss'].item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "40adaeac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(1.4664), tensor(1.4686), tensor(0.0232))"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(ln - irrep_lneurons).norm()**2 / irrep_lneurons.norm()**2, (rn - irrep_rneurons).norm()**2 / irrep_rneurons.norm()**2, (un - irrep_uneurons).norm()**2 / irrep_uneurons.norm()**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "d2b01f62",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'G0_loss': tensor([4.4469]), 'G0_acc': tensor([0.0087])} {'G0_loss': tensor([0.8187]), 'G0_acc': tensor([0.7269])}\n",
      "{'G0_loss': tensor([0.0327]), 'G0_acc': tensor([1.])}\n",
      "{'G0_loss': tensor([0.1025]), 'G0_acc': tensor([1.])}\n",
      "{'G0_loss': tensor([0.1737]), 'G0_acc': tensor([1.])}\n"
     ]
    }
   ],
   "source": [
    "other = [i for i in range(lneurons.shape[-1]) if i not in irrep_idxs]\n",
    "other_lneurons, other_rneurons, other_uneurons= lneurons[:, other], rneurons[:, other], uneurons[:, other]\n",
    "print(ablate_loss(other_lneurons, other_rneurons, other_uneurons), ablate_loss(irrep_lneurons, irrep_rneurons, irrep_uneurons))\n",
    "print(ablate_loss(t.concat([irrep_lneurons, other_lneurons], dim=-1), t.concat([irrep_rneurons, other_rneurons], dim=-1), t.concat([irrep_uneurons, other_uneurons], dim=-1)))\n",
    "print(ablate_loss(t.concat([ln, other_lneurons], dim=-1), t.concat([rn, other_rneurons], dim=-1), t.concat([un, other_uneurons], dim=-1)))\n",
    "print(ablate_loss(ln, rn, un))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4d1993d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# {'G0_loss': tensor([4.4466]), 'G0_acc': tensor([0.0083])} {'G0_loss': tensor([0.9043]), 'G0_acc': tensor([0.5908])}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "316ac7f4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([120, 7])"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "other_lneurons.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "f8ca2a6f-c31c-478f-9662-69295609de0b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.9314e-05)"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(a.mean(dim=0) - d.mean(dim=0)).norm()**2 / a.mean(dim=0).norm()**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "3a69106b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "XXXX"
       },
       "data": [
        {
         "hovertemplate": "x=%{x}<br>y=%{y}<br>z=%{z}<extra></extra>",
         "legendgroup": "",
         "marker": {
          "color": "#636efa",
          "opacity": 0.3,
          "symbol": "circle"
         },
         "mode": "markers",
         "name": "",
         "scene": "scene",
         "showlegend": false,
         "type": "scatter3d",
         "x": [
          -0.6237888932228088,
          -0.968550980091095,
          -0.4669293761253357,
          -0.47067204117774963,
          -0.6535552144050598,
          0.968582808971405,
          0.8760542273521423,
          0.23588447272777557,
          -0.23548321425914764,
          0.2785598039627075,
          0.4677960276603699,
          -0.5362061858177185,
          -0.46550142765045166,
          0.277066171169281,
          -0.651809811592102,
          0.4649641215801239,
          -0.5358715057373047,
          -0.9687347412109375,
          -0.23646827042102814,
          -0.534221887588501,
          -0.8762280941009521,
          -0.23445606231689453,
          -0.2358802855014801,
          -0.23599594831466675,
          0.27867236733436584,
          -0.8772375583648682,
          0.6531227827072144,
          0.46712908148765564,
          0.46690401434898376,
          -0.9687702655792236,
          0.2772228717803955,
          0.6537805199623108,
          -0.23473049700260162,
          0.9694823026657104,
          0.5359172821044922,
          -0.8767917156219482,
          0.2777363061904907,
          -0.27809256315231323,
          -0.4672910273075104,
          0.2769009470939636,
          0.2779220640659332,
          -0.652136504650116,
          0.6535910367965698,
          0.2335253357887268,
          -0.5360394716262817,
          -0.23416925966739655,
          0.8761471509933472,
          -0.4659024178981781,
          0.2356177568435669,
          0.535638689994812,
          0.4660661816596985,
          0.9686592221260071,
          0.6566275358200073,
          -0.6521588563919067,
          0.9688636064529419,
          -0.5353851914405823,
          -0.535969078540802,
          0.27803710103034973,
          -0.536250650882721,
          -0.23610819876194,
          0.9043413400650024,
          0.6519398093223572,
          -0.2766924798488617,
          0.06185135245323181,
          -0.5351089835166931,
          -0.6545173525810242,
          0.9690003991127014,
          -0.9687991738319397,
          -0.5358479619026184,
          0.9689632058143616,
          0.2768859267234802,
          0.27657681703567505,
          0.6517969369888306
         ],
         "y": [
          0.6986761093139648,
          0.23479025065898895,
          0.27667486667633057,
          0.2794237434864044,
          -0.6506757140159607,
          -0.2351018339395523,
          0.05996759980916977,
          -0.9681532979011536,
          0.9683899283409119,
          -0.46546944975852966,
          -0.278287798166275,
          -0.535460352897644,
          0.2782554030418396,
          -0.4667360186576843,
          -0.6528082489967346,
          -0.2768036425113678,
          -0.5370565056800842,
          0.23420819640159607,
          0.9680715799331665,
          -0.5364015102386475,
          -0.058757487684488297,
          0.9684790968894958,
          0.9683868288993835,
          0.9683449268341064,
          -0.4646173119544983,
          -0.05915147438645363,
          0.6512690186500549,
          -0.2797371745109558,
          -0.2772159278392792,
          0.2334781438112259,
          -0.46581482887268066,
          0.6510208249092102,
          0.9685637354850769,
          -0.23057124018669128,
          0.5366783142089844,
          -0.05489630252122879,
          -0.46618568897247314,
          0.4637792110443115,
          0.2771781086921692,
          -0.4660893976688385,
          -0.46539029479026794,
          -0.6523586511611938,
          0.6511526703834534,
          -0.9688947200775146,
          -0.5361843705177307,
          0.9686504006385803,
          0.05761701241135597,
          0.2770776152610779,
          -0.9683117270469666,
          0.5369986295700073,
          -0.27875247597694397,
          -0.23445503413677216,
          0.22075697779655457,
          -0.6525775790214539,
          -0.2334647923707962,
          -0.5373421311378479,
          -0.5378664135932922,
          -0.46474897861480713,
          -0.5362641215324402,
          0.9682775735855103,
          0.4017413258552551,
          0.6528722643852234,
          0.4664367437362671,
          0.8771385550498962,
          -0.53598952293396,
          -0.6509732604026794,
          -0.2325296550989151,
          0.23381058871746063,
          -0.5368320345878601,
          -0.23241104185581207,
          -0.4650036096572876,
          -0.4657449424266815,
          0.6523232460021973
         ],
         "z": [
          0.3503415584564209,
          0.08235632628202438,
          -0.8398975729942322,
          -0.8368932008743286,
          -0.3866353929042816,
          -0.08108353614807129,
          0.4784693717956543,
          0.08389057964086533,
          -0.0822710171341896,
          -0.8400849103927612,
          0.8388819098472595,
          0.6525068283081055,
          -0.8401681184768677,
          -0.8398760557174683,
          -0.38598641753196716,
          0.8409449458122253,
          0.6514692902565002,
          0.08185134083032608,
          -0.08318708091974258,
          0.6533608436584473,
          -0.47830110788345337,
          -0.08413466066122055,
          -0.08116456866264343,
          -0.08132727444171906,
          -0.8405191898345947,
          -0.47639837861061096,
          0.38636669516563416,
          0.8387715220451355,
          0.8397333025932312,
          0.083499975502491,
          -0.8403355479240417,
          0.3856719732284546,
          -0.0823764055967331,
          -0.08331311494112015,
          -0.6517431735992432,
          -0.4777265191078186,
          -0.8399603366851807,
          0.8411737680435181,
          -0.8395305275917053,
          -0.8402895927429199,
          -0.8403400182723999,
          -0.3861945569515228,
          0.385770708322525,
          0.0819091871380806,
          0.65204918384552,
          -0.08295266330242157,
          0.4785880446434021,
          -0.8403351306915283,
          0.08280452340841293,
          -0.6517082452774048,
          0.839690089225769,
          -0.08203797042369843,
          0.721184253692627,
          -0.38578659296035767,
          -0.08244705945253372,
          0.6516333818435669,
          0.6507204174995422,
          -0.8406567573547363,
          0.6518097519874573,
          -0.08180177211761475,
          -0.14411985874176025,
          0.3856584429740906,
          0.8401654362678528,
          0.4762378931045532,
          0.652972936630249,
          -0.3845007121562958,
          -0.08347596228122711,
          0.08222497254610062,
          0.6516736745834351,
          -0.08423428982496262,
          -0.8408958315849304,
          -0.8405872583389282,
          0.3868270814418793
         ]
        }
       ],
       "layout": {
        "legend": {
         "tracegroupgap": 0
        },
        "margin": {
         "t": 60
        },
        "scene": {
         "domain": {
          "x": [
           0,
           1
          ],
          "y": [
           0,
           1
          ]
         },
         "xaxis": {
          "title": {
           "text": "x"
          }
         },
         "yaxis": {
          "title": {
           "text": "y"
          }
         },
         "zaxis": {
          "title": {
           "text": "z"
          }
         }
        },
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        }
       }
      }
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import plotly.express as px\n",
    "import plotly.graph_objects as go\n",
    "# Create the figure\n",
    "fig = go.Figure()\n",
    "\n",
    "\n",
    "fig = px.scatter_3d(\n",
    "    x=b[:,0].tolist(), y=b[:,1].tolist(), z=b[:,2].tolist(), opacity=0.3, \n",
    "    # marker=dict(\n",
    "    #     size=4,\n",
    "    #     color='blue',\n",
    "    #     opacity=0.3\n",
    "    # ),\n",
    ")\n",
    "# fig = px.scatter_3d(\n",
    "#     x=full_b[:,0].tolist(), y=full_b[:,1].tolist(), z=full_b[:,2].tolist(), opacity=0.03, \n",
    "#     marker=dict(\n",
    "#         size=4,\n",
    "#         color='blue',\n",
    "#         opacity=0.3\n",
    "#     ),\n",
    "# )\n",
    "\n",
    "# Add the second scatter plot (full_b) in red\n",
    "# fig.add_trace(go.Scatter3d(\n",
    "#     x=full_b[:,0].tolist(),\n",
    "#     y=full_b[:,1].tolist(),\n",
    "#     z=full_b[:,2].tolist(),\n",
    "#     mode='markers',\n",
    "#     marker=dict(\n",
    "#         size=4,\n",
    "#         color='red',\n",
    "#         opacity=0.00,\n",
    "#     ),\n",
    "#     name='full_b'\n",
    "# ))\n",
    "\n",
    "\n",
    "# fig.add_trace(go.Scatter3d(\n",
    "#     x=a2[:,0].tolist(),\n",
    "#     y=a2[:,1].tolist(),\n",
    "#     z=a2[:,2].tolist(),\n",
    "#     mode='markers',\n",
    "#     marker=dict(\n",
    "#         size=6,\n",
    "#         color='red',\n",
    "#         opacity=.5,\n",
    "#     ),\n",
    "#     name='a'\n",
    "# ))\n",
    "\n",
    "\n",
    "# fig.add_trace(go.Scatter3d(\n",
    "#     # x=full_b[:,0].tolist(),\n",
    "#     # y=full_b[:,1].tolist(),\n",
    "#     # z=full_b[:,2].tolist(),\n",
    "#     x=bc_pair[:,0].tolist(),\n",
    "#     y=bc_pair[:,1].tolist(),\n",
    "#     z=bc_pair[:,3].tolist(),\n",
    "#     mode='markers',\n",
    "#     marker=dict(\n",
    "#         size=6,\n",
    "#         color='blue',\n",
    "#         opacity=.5,\n",
    "#     ),\n",
    "#     name='b'\n",
    "# ))\n",
    "\n",
    "\n",
    "\n",
    "fig.show()\n",
    "# fig.write_html('/home/XXXX-1/ab.html')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e1ea252",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "e5b988e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([121, 4, 4])"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "A.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "8738f05a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(-0.7605388164520264, -0.7517490386962891),\n",
       " (-0.7564507126808167, -0.747555136680603),\n",
       " (-0.7527337074279785, -0.7391642332077026),\n",
       " (-0.7501431703567505, -0.7050055265426636),\n",
       " (-0.7494484782218933, -0.7049088478088379),\n",
       " (-0.7477362751960754, -0.6938212513923645),\n",
       " (-0.7458003759384155, -0.6931061744689941),\n",
       " (-0.7449398040771484, -0.6928953528404236),\n",
       " (-0.7448825240135193, -0.6925239562988281),\n",
       " (-0.7396479845046997, -0.6924957036972046),\n",
       " (-0.7380285859107971, -0.6911870241165161),\n",
       " (-0.7106956243515015, -0.6891772747039795),\n",
       " (-0.7045552730560303, -0.6849766969680786),\n",
       " (-0.7041484117507935, -0.6834962964057922),\n",
       " (-0.6977403163909912, -0.6787872910499573),\n",
       " (-0.6936909556388855, -0.6764672994613647),\n",
       " (-0.6933076977729797, -0.6731046438217163),\n",
       " (-0.6929901838302612, -0.6723490357398987),\n",
       " (-0.6929565072059631, -0.668040931224823),\n",
       " (-0.6925817728042603, -0.6598889827728271),\n",
       " (-0.6923143267631531, -0.6504643559455872),\n",
       " (-0.6914838552474976, -0.6501554250717163),\n",
       " (-0.6910746097564697, -0.6489174962043762),\n",
       " (-0.6831184029579163, -0.6481380462646484),\n",
       " (-0.6716967821121216, -0.6480188369750977),\n",
       " (-0.6692564487457275, -0.6322489380836487),\n",
       " (-0.6664983630180359, -0.6288014650344849),\n",
       " (-0.6211503744125366, -0.6284612417221069),\n",
       " (-0.4584316611289978, -0.4588101804256439),\n",
       " (-0.4559488296508789, -0.4397428035736084),\n",
       " (-0.45476096868515015, -0.43869346380233765),\n",
       " (-0.4539618492126465, -0.4365282952785492),\n",
       " (-0.4516914188861847, -0.43651098012924194),\n",
       " (-0.4424040913581848, -0.42247283458709717),\n",
       " (-0.44169479608535767, -0.35224318504333496),\n",
       " (-0.4406638443470001, -0.34633830189704895),\n",
       " (-0.4373222589492798, -0.3455742597579956),\n",
       " (-0.4268741011619568, -0.3447605073451996),\n",
       " (-0.41804754734039307, -0.3374190628528595),\n",
       " (-0.41706669330596924, -0.32644426822662354),\n",
       " (-0.4167006313800812, -0.3149489760398865),\n",
       " (-0.4070878028869629, -0.31361865997314453),\n",
       " (-0.39188867807388306, -0.3133907914161682),\n",
       " (-0.3446615934371948, -0.31105712056159973),\n",
       " (-0.32298970222473145, -0.31041431427001953),\n",
       " (-0.3224572539329529, -0.3086512088775635),\n",
       " (-0.32033881545066833, -0.30689162015914917),\n",
       " (-0.3058731257915497, -0.30561336874961853),\n",
       " (-0.30173835158348083, -0.3004722595214844),\n",
       " (-0.2208394557237625, -0.29260629415512085),\n",
       " (-0.21803170442581177, -0.28649359941482544),\n",
       " (-0.16967403888702393, -0.27577486634254456),\n",
       " (-0.14120477437973022, -0.2710898816585541),\n",
       " (-0.14119307696819305, -0.25680112838745117),\n",
       " (-0.13990628719329834, -0.2228630781173706),\n",
       " (-0.07353734970092773, -0.21653369069099426),\n",
       " (-0.06410850584506989, -0.21634572744369507),\n",
       " (-0.05317956209182739, -0.13916024565696716),\n",
       " (-0.02462957054376602, -0.13793614506721497),\n",
       " (-0.020150095224380493, -0.13584010303020477),\n",
       " (-0.0022593140602111816, -0.12902913987636566),\n",
       " (0.005334675312042236, -0.07439124584197998),\n",
       " (0.018876656889915466, -0.0456942617893219),\n",
       " (0.03444726765155792, -0.040863037109375),\n",
       " (0.059186577796936035, -0.021041452884674072),\n",
       " (0.06550028920173645, -0.018074102699756622),\n",
       " (0.07008946686983109, -0.014308273792266846),\n",
       " (0.07627309113740921, -0.0043909549713134766),\n",
       " (0.22996893525123596, -0.0028938651084899902),\n",
       " (0.24639901518821716, -0.001294642686843872),\n",
       " (0.25732794404029846, -0.0008042752742767334),\n",
       " (0.26012516021728516, 0.018738597631454468),\n",
       " (0.299089252948761, 0.021011173725128174),\n",
       " (0.29931414127349854, 0.021128833293914795),\n",
       " (0.3023514747619629, 0.028101354837417603),\n",
       " (0.3045464754104614, 0.04175537824630737),\n",
       " (0.3049173951148987, 0.05649517476558685),\n",
       " (0.3082054853439331, 0.05967250466346741),\n",
       " (0.3146076798439026, 0.06392502784729004),\n",
       " (0.32265979051589966, 0.11406469345092773),\n",
       " (0.32380861043930054, 0.1146640032529831),\n",
       " (0.3326585590839386, 0.1215621829032898),\n",
       " (0.3330746591091156, 0.14830872416496277),\n",
       " (0.3332251310348511, 0.26289963722229004),\n",
       " (0.3346264362335205, 0.2925422787666321),\n",
       " (0.34479594230651855, 0.3010880947113037),\n",
       " (0.3465501070022583, 0.30562901496887207),\n",
       " (0.3465532064437866, 0.30801716446876526),\n",
       " (0.3803846538066864, 0.31567031145095825),\n",
       " (0.3893861174583435, 0.3274328112602234),\n",
       " (0.3930756747722626, 0.345195472240448),\n",
       " (0.4050106406211853, 0.3462394177913666),\n",
       " (0.4069657623767853, 0.3731444478034973),\n",
       " (0.41032087802886963, 0.38971585035324097),\n",
       " (0.41046082973480225, 0.42524170875549316),\n",
       " (0.4299667477607727, 0.4443719685077667),\n",
       " (0.598361611366272, 0.44855648279190063),\n",
       " (0.6067137122154236, 0.46210652589797974),\n",
       " (0.6194890141487122, 0.5065102577209473),\n",
       " (0.666831374168396, 0.6457641124725342),\n",
       " (0.6915897727012634, 0.6753920912742615),\n",
       " (0.6916677951812744, 0.6852821111679077),\n",
       " (0.6917755603790283, 0.6861052513122559),\n",
       " (0.6927329897880554, 0.6874397993087769),\n",
       " (0.6930686235427856, 0.6879092454910278),\n",
       " (0.6941561102867126, 0.6905103921890259),\n",
       " (0.6970922946929932, 0.6909317374229431),\n",
       " (0.6981993913650513, 0.6909691691398621),\n",
       " (0.7000455856323242, 0.6912083029747009),\n",
       " (0.7002428770065308, 0.691461443901062),\n",
       " (0.7004263997077942, 0.6914979815483093),\n",
       " (0.7029052972793579, 0.6925814151763916),\n",
       " (0.7046946883201599, 0.696178674697876),\n",
       " (0.7397283315658569, 0.6962716579437256),\n",
       " (0.740928053855896, 0.7003254294395447),\n",
       " (0.7459142208099365, 0.7393674254417419),\n",
       " (0.7470102310180664, 0.7405316829681396),\n",
       " (0.7511167526245117, 0.7471336722373962),\n",
       " (0.7518215775489807, 0.7488696575164795),\n",
       " (0.7524945139884949, 0.7533378005027771),\n",
       " (0.7542814016342163, 0.7600260376930237)]"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rho = irrep[10]\n",
    "\n",
    "trace_rho_A = einops.einsum(rho, A, 'd1 d2, m d2 d1 -> m')\n",
    "trace_A = einops.einsum(A, 'm d1 d1 -> m')\n",
    "list(zip(sorted(trace_rho_A.tolist()), sorted(trace_A.tolist())))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38c80f01",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "7070552f",
   "metadata": {},
   "source": [
    "### Plot $b_i$'s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "id": "438e309e",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_b = einops.einsum(b, irrep, 'neuron d2, G d1 d2 -> neuron G d1').flatten(0, 1)\n",
    "full_c = einops.einsum(c, irrep, 'neuron d2, G d1 d2 -> neuron G d1').flatten(0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "id": "531f5cef-60b3-4cc5-83e4-0d8a260e4f1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1\n"
     ]
    },
    {
     "data": {
      "image/png": "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hw4dvPZv3rxZ8fHx6tu3r+666y4dP378jHW43W65XC6vDQAAWJdfA86xY8dUX1+vhIQEr/0JCQlyOp3nPH/r1q3asWOHfvGLX3jtz8zM1OrVq5Wbm6vHH39c//znP3XDDTeovr6+0Xqys7MVHR3t2ZKTk33vFAAACHh+n4NzPl544QUNGDBAw4cP99o/YcIEz88DBgzQwIED1atXL23evFmjRo06rZ558+YpKyvL897lchFyAACwML+O4MTGxiokJERFRUVe+4uKiuRwOM56bmVlpdatW6epU6ee83N69uyp2NhY7dmzp9HjNptNdrvdawMAANbl14ATHh6uoUOHKjc317OvoaFBubm5SktLO+u5r776qtxut37+85+f83MOHTqk48ePKzEx8bzbDAAA2j+/r6LKysrSihUrtGrVKu3cuVN33XWXKisrNWXKFEnSpEmTNG/evNPOe+GFFzRu3Dh16dLFa39FRYV+9atf6aOPPtLXX3+t3Nxc3Xjjjerdu7cyMjL83R0AANAO+H0Ozvjx43X06FEtXLhQTqdTgwcPVk5Ojmfi8YEDBxQc7J2zdu/erS1btuidd945rb6QkBD9+9//1qpVq1RaWqqkpCSNHj1aixcv5l44AABAkhRkGIbR1o1obS6XS9HR0SorK2M+DgAA7URzvr95FhUAALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALAcAg4AALCc0LZuAAAAsAi3W2pokIKDJZutTZtCwAEAAOenuloqKZGOH5dqa6WwMKlLF6lzZykiok2aRMABAAC+q66W9u6ViovNn4OCpJoa6fBhKSFB6t+/TUIOAQcAAPjuyBEz4Ljd5lZRIZ04IRmGtG+fGXqGDGn1kMMkYwAA4Bu32ww3x4+bozYnTpgjOHa71KGDVFUl7dhxKui0IgIOAADwzYkTUmHhqQnFhiF17ChFRpqvERFmyCkrM+fotCICDgAA8I3bbYackBDz9fsrpyIizJGb0FCpvNws30oIOAAAwDc2mzlaU1VlLg8P/d7UXrfbDDkdOkj19WaZVkLAAQAAvomMlBITpbo6M+RUV5uXqWprzRGbmhpzJVVIiLkFt17sIOAAAADf2GxSr15miImMlEpL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F4DMzExjyJAhRn5+vrFlyxajT58+XstrDx06ZPTt29fIz883DMMwampqjN69extXX321kZ+fb+zZs8dYsmSJERQUZLz99ttt1Y0maW5fDcMwnn76acNutxuvvvqq8dVXXxnz5883IiIijD179rRFF5rFl/5+n9rBKirDaH5fy8rKjNTUVGPAgAHGnj17jMLCQs9WV1fXVt04zbp16wybzWa89NJLxhdffGFMnz7diImJMZxOp2EYhnH77bcbc+fO9ZT/17/+ZYSGhhpLliwxdu7caSxatKhdLRNvTl8fe+wxIzw83Hjttde8fn/l5eVt1YUma25fv689raJqbl8PHDhgdOzY0Zg5c6axe/du46233jLi4+ONhx9+uK260GTN7euiRYuMjh07Gn/+85+Nffv2Ge+8847Rq1cv45Zbbmn2ZxNwGnH8+HHj1ltvNS666CLDbrcbU6ZM8foLYv/+/YYk47333vPs+/LLL42f/vSnRnx8vBEVFWUMHDjwtGXjgciXvhqGYWRnZxtdu3Y1oqKijLS0NOODDz5o5Zb7xtf+fld7CTjN7et7771nSGp0279/f9t04gyeffZZ45JLLjHCw8ON4cOHGx999JHn2LXXXmvccccdXuVfeeUV49JLLzXCw8ONH/zgBwH/D4/vak5fu3Xr1ujvb9GiRa3fcB809/f6Xe0p4BhG8/v64YcfGqmpqYbNZjN69uxpPPLIIwH1D4+zaU5fa2trjQcffNDo1auXERERYSQnJxt333238e233zb7c4MMo7ljPgAAAIHtgllFBQAALhwEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDkEHAAAYDn/H15HNg2RrcQTAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 2\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjgAAAGfCAYAAABShKg9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA6oklEQVR4nO3deXhU9aH/8U8my0wCzISYZRKMshZIC8QLEoNavZJLItx75dZbQVGEB6Eq6JVgFSqLFTUuVKlKy5WKwlMsLhWvW1MwSK0agw2ligJllS0TljQzJIGs5/fH+WXoSFgSMknm5P16nvOEOed7zny/JmY++S7nhBmGYQgAAMBCbO1dAQAAgNZGwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJYTEcyLf/zxx3r66adVXFyskpISrVmzRmPHjj3rORs2bFBubq6+/vprpaamau7cuZo0aVJAmSVLlujpp5+Wx+PRkCFD9Pzzz2v48OHnXa+GhgYdOnRI3bp1U1hYWAtaBgAA2pphGDp+/LhSUlJks52jj8YIog8++MB46KGHjLfeesuQZKxZs+as5Xfv3m3ExMQYubm5xjfffGM8//zzRnh4uJGfn+8vs3r1aiMqKspYvny58fXXXxtTp041YmNjjdLS0vOu1/79+w1JbGxsbGxsbCG47d+//5yf9WGG0TYP2wwLCztnD86DDz6o999/X1u2bPHvGz9+vMrLy5Wfny9JysjI0OWXX64XXnhBktkbk5qaqnvuuUezZ88+r7p4vV7FxsZq//79cjqdLW8UAABoMz6fT6mpqSovL5fL5Tpr2aAOUTVXYWGhsrKyAvZlZ2frvvvukyTV1NSouLhYc+bM8R+32WzKyspSYWHhGa9bXV2t6upq/+vjx49LkpxOJwEHAIAQcz7TSzrUJGOPx6OkpKSAfUlJSfL5fDpx4oSOHj2q+vr6Jst4PJ4zXjcvL08ul8u/paamBqX+AACgY+hQASdY5syZI6/X69/279/f3lUCAABB1KGGqNxut0pLSwP2lZaWyul0Kjo6WuHh4QoPD2+yjNvtPuN17Xa77HZ7UOoMAAA6ng7Vg5OZmamCgoKAfevWrVNmZqYkKSoqSkOHDg0o09DQoIKCAn8ZAACAoAaciooKbd68WZs3b5Yk7dmzR5s3b9a+ffskmUNHEydO9Je/8847tXv3bj3wwAPatm2bfvWrX+n111/XzJkz/WVyc3O1bNkyrVixQlu3btVdd92lyspKTZ48OZhNAQAAISSoQ1R/+ctf9K//+q/+17m5uZKk22+/Xa+88opKSkr8YUeSevXqpffff18zZ87UL3/5S1188cX6zW9+o+zsbH+ZcePG6ciRI5o/f748Ho/S09OVn59/2sRjAADQebXZfXA6Ep/PJ5fLJa/XyzJxAABCRHM+vzvUHBwAAIDW0KFWUQFoJ9XVUkODZLNJrDgEYAEEHKAzO3lSKimRDh2SvF4pLExKSZF69pTOcRt0AOjICDhAZ1VeLhUVScXF0rffSmVlZi+O0ykNHCiNGiUNGCA5HO1dUwBoNgIO0BmdPGmGm48/NntwampO9dicOCFt3nxq2CotjZADIOQQcIDOqKRE2rpVOn5cioiQunU7FWJOnpQqKiSPR9q2TXK7zWErAAghrKICOpvqanPOzbFjUn29GXAiI08dj4iQoqLMcocPm2Gourr96gsALUDAATqbhgaptvbU6/Bwc2sUEWFONg4PN8s2DlUBQAgh4ACdjc1mDklFR5vhpb7e3BrV1ZnDVJGR5rCV3W6eAwAhhN9aQGdjt0vJydKll5ohp7LSDDSGYYabigrz306nlJBgluXeOABCDJOMgc4oLs5cCl5aKm3ZYs61sdvNoan6enNFVXKy1KePWRYAQgwBB+iMHA5z+Xd0tBQfL/3tb+aqKZtN6tFD+v73peHDpV69WCIOICQRcIDOyuEwe3F695ays807GRuGFBtrbgxLAQhhBBygs7PbpaQkcwMAi2CSMQAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsBwCDgAAsJw2CThLlixRz5495XA4lJGRoY0bN56x7LXXXquwsLDTtjFjxvjLTJo06bTjOTk5bdEUAAAQAiKC/QavvfaacnNztXTpUmVkZGjx4sXKzs7W9u3blZiYeFr5t956SzU1Nf7Xx44d05AhQ/TjH/84oFxOTo5efvll/2u73R68RgAAgJAS9B6cZ555RlOnTtXkyZOVlpampUuXKiYmRsuXL2+yfFxcnNxut39bt26dYmJiTgs4drs9oFz37t2D3RQAABAighpwampqVFxcrKysrFNvaLMpKytLhYWF53WNl156SePHj1eXLl0C9m/YsEGJiYnq37+/7rrrLh07duyM16iurpbP5wvYAACAdQU14Bw9elT19fVKSkoK2J+UlCSPx3PO8zdu3KgtW7bojjvuCNifk5OjlStXqqCgQE8++aT+9Kc/6frrr1d9fX2T18nLy5PL5fJvqampLW8UAADo8II+B+dCvPTSSxo0aJCGDx8esH/8+PH+fw8aNEiDBw9Wnz59tGHDBo0cOfK068yZM0e5ubn+1z6fj5ADAICFBbUHJz4+XuHh4SotLQ3YX1paKrfbfdZzKysrtXr1ak2ZMuWc79O7d2/Fx8dr586dTR632+1yOp0BGwAAsK6gBpyoqCgNHTpUBQUF/n0NDQ0qKChQZmbmWc994403VF1drVtvvfWc73PgwAEdO3ZMycnJF1xnAAAQ+oK+iio3N1fLli3TihUrtHXrVt11112qrKzU5MmTJUkTJ07UnDlzTjvvpZde0tixY3XRRRcF7K+oqNBPf/pTff7559q7d68KCgp0ww03qG/fvsrOzg52cwAAQAgI+hyccePG6ciRI5o/f748Ho/S09OVn5/vn3i8b98+2WyBOWv79u365JNPtHbt2tOuFx4eri+//FIrVqxQeXm5UlJSNGrUKC1cuJB74QAAAElSmGEYRntXoq35fD65XC55vV7m4wAAECKa8/nNs6gAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlEHAAAIDlRLR3BQAAbWDXLunECSk6WurTp71rAwQdAQcArGz7dmntWmnHDqm6WrLbpX79pFGjpP7927t2QNAQcADAqrZvl15+WTp2TLr4Ysnlkrxe6csvpYMHpcmTCTmwLObgAIBVrV1rhpv0dCk+XoqMNL+mp5v7165t7xoCQUPAAQAr2rXLHJa6+OKmj198sXl81662rRfQRgg4AGBFJ06Yc25crqaPu1zm8RMn2rZeQBsh4ACAFUVHmxOKvd6mj3u95vHo6LatF9BGCDgAYEV9+pirpQ4caPr4gQPmcZaMw6IIOABgVaNGSRddJG3eLB09KtXWml83bzb3jxrV3jUEgoZl4gBgVf37m0vBG++Dc+iQOSw1eDD3wYHlEXAAwMr69zc37mSMToaAAwCdAaEGnQxzcAAAgOUQcAAAgOUQcAAAgOUQcAAAgOUQcAAAgOUQcAAAgOW0ScBZsmSJevbsKYfDoYyMDG3cuPGMZV955RWFhYUFbA6HI6CMYRiaP3++kpOTFR0draysLO3YsSPYzQAAACEi6AHntddeU25urhYsWKBNmzZpyJAhys7O1uHDh894jtPpVElJiX/79ttvA44/9dRTeu6557R06VIVFRWpS5cuys7O1smTJ4PdHAAAEAKCHnCeeeYZTZ06VZMnT1ZaWpqWLl2qmJgYLV++/IznhIWFye12+7ekpCT/McMwtHjxYs2dO1c33HCDBg8erJUrV+rQoUN6++23g90cAAAQAoIacGpqalRcXKysrKxTb2izKSsrS4WFhWc8r6KiQpdeeqlSU1N1ww036Ouvv/Yf27NnjzweT8A1XS6XMjIyznjN6upq+Xy+gA0AAFhXUAPO0aNHVV9fH9ADI0lJSUnyeDxNntO/f38tX75c//d//6ff/va3amho0IgRI3TgwAFJ8p/XnGvm5eXJ5XL5t9TU1AttGgAA6MA63CqqzMxMTZw4Uenp6brmmmv01ltvKSEhQf/7v//b4mvOmTNHXq/Xv+3fv78VawwAADqaoAac+Ph4hYeHq7S0NGB/aWmp3G73eV0jMjJSl112mXbu3ClJ/vOac0273S6n0xmwAQAA6wpqwImKitLQoUNVUFDg39fQ0KCCggJlZmae1zXq6+v11VdfKTk5WZLUq1cvud3ugGv6fD4VFRWd9zUBAIC1RQT7DXJzc3X77bdr2LBhGj58uBYvXqzKykpNnjxZkjRx4kT16NFDeXl5kqRHHnlEV1xxhfr27avy8nI9/fTT+vbbb3XHHXdIMldY3XfffXr00UfVr18/9erVS/PmzVNKSorGjh0b7OYAAIAQEPSAM27cOB05ckTz58+Xx+NRenq68vPz/ZOE9+3bJ5vtVEfSP/7xD02dOlUej0fdu3fX0KFD9dlnnyktLc1f5oEHHlBlZaWmTZum8vJyXXXVVcrPzz/thoAAAKBzCjMMw2jvSrQ1n88nl8slr9fLfBwAAEJEcz6/O9wqKgAAgAtFwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJZDwAEAAJbTJgFnyZIl6tmzpxwOhzIyMrRx48Yzll22bJmuvvpqde/eXd27d1dWVtZp5SdNmqSwsLCALScnJ9jNAAAAISLoAee1115Tbm6uFixYoE2bNmnIkCHKzs7W4cOHmyy/YcMG3Xzzzfroo49UWFio1NRUjRo1SgcPHgwol5OTo5KSEv/2u9/9LthNAQAAISLMMAwjmG+QkZGhyy+/XC+88IIkqaGhQampqbrnnns0e/bsc55fX1+v7t2764UXXtDEiRMlmT045eXlevvtt1tUJ5/PJ5fLJa/XK6fT2aJrAACAttWcz++g9uDU1NSouLhYWVlZp97QZlNWVpYKCwvP6xpVVVWqra1VXFxcwP4NGzYoMTFR/fv311133aVjx46d8RrV1dXy+XwBGwAAsK6gBpyjR4+qvr5eSUlJAfuTkpLk8XjO6xoPPvigUlJSAkJSTk6OVq5cqYKCAj355JP605/+pOuvv1719fVNXiMvL08ul8u/paamtrxRAACgw4to7wqczRNPPKHVq1drw4YNcjgc/v3jx4/3/3vQoEEaPHiw+vTpow0bNmjkyJGnXWfOnDnKzc31v/b5fIQcAAAsLKg9OPHx8QoPD1dpaWnA/tLSUrnd7rOeu2jRIj3xxBNau3atBg8efNayvXv3Vnx8vHbu3NnkcbvdLqfTGbABAADrCmrAiYqK0tChQ1VQUODf19DQoIKCAmVmZp7xvKeeekoLFy5Ufn6+hg0bds73OXDggI4dO6bk5ORWqTcAAAhtQV8mnpubq2XLlmnFihXaunWr7rrrLlVWVmry5MmSpIkTJ2rOnDn+8k8++aTmzZun5cuXq2fPnvJ4PPJ4PKqoqJAkVVRU6Kc//ak+//xz7d27VwUFBbrhhhvUt29fZWdnB7s5AAAgBAR9Ds64ceN05MgRzZ8/Xx6PR+np6crPz/dPPN63b59stlM569e//rVqamr03//93wHXWbBggR5++GGFh4fryy+/1IoVK1ReXq6UlBSNGjVKCxculN1uD3ZzAABACAj6fXA6Iu6DAwBA6Okw98EBAABoDwQcAABgOQQcAABgOR36Rn8AACBIjhyRamqkqCgpIaG9a9PqCDgAAHQmHo+0ebP05ZdSVZUUEyMNHiylp0vnuAlvKCHgAADQWXg80u9+J23aZIabRl99JW3dKt18s2VCDnNwAADoLPLzpYICyeuV7HbJ6TS/er3m/vz89q5hqyHgAADQGRw5In30kVRdLcXHS926SQ6H+TU+3tz/0UdmOQsg4AAA0Bl8+6104IAUF2cGm/BwKSzM/OpwmPsPHDDLWQABBwCAzuDECam2VoqMbPp4ZKR5/MSJtq1XkBBwAADoDNxuyeWSysqaPl5WZh5nkjEAAAgZl1xiLgWvrjbn2Zw8KRmG+fXIEXN/erpZzgJYJg4AQGdgt0v//u/S0aPSoUPm14gIqa7OnIvzve+Zx+329q5pqyDgAADQWQwZIo0fLxUWSnv2nJqT06uXlJlpHrcIAg4AAJ2FwyFlZEj9+kk7dpgTiqOjzdeNq6ssgoATLNXVUkODZLNZprsPAGABDoeUkiJddJGlP6cIOK1t/37zPgInTphpODravImSxZIxACDEWTDU/DMCTmvxeKRPPjHvAllWZgabvn3N8czkZDPw9OhByAEAoA0QcFpD48PL1q83n+cRGWnOSN+3T9q5Uxo9Wurd2ww9KSntXVsAACyPgNMa1q83N59P6t5d6trVnJleUWEGnPXrpcRE6fhxc26OxbsFAQBobwScC3XkiPTpp2Zw6d7dvAukZN5bIDraDDq7dplBx+k0J3TBmn7/e+kf/zB/Dm68sb1rAwCdGgHnQpWUmFvXrubQVOOM9EaxseYQ1v790qBBgcdgDatWSUuWmPeUqKszw+0vfiFNny5NmNDetQOATomAc6EMw5xvI5kBp65Oioo6dbzxWE2N1KULw1NWs2qV9NBD5twrl8tcdllRIW3dau6XCDkA0A7oTrhQKSnmg8kqK80wY7OZYaZxKKqszPyLPjXVXEUFa3n+eTPc9Oolxcebw5Lx8eZrr9c8DgBocwScC5WQIF15pbn8+9gxqb7eDDoVFdLBg2bwGTBAuuaaU/NzYA2//705LOVymSHWZjsVciMizP179pjlAABtiiGq1nDddeY8nC++MIONZPbgREWZDy+76SbzL3pYy+HD5iTypKSmjzud5sq6w4fbtl4AAAJOq3C7zXkW/fqZIae8XAoPl/r3Nx9eNmAAN/izothY8/tcVdX097eqyjweG9vWNQOATi/MMAyjvSvR1nw+n1wul7xer5xOZ+te/MgR8343ERHmX/ZMKrau6mrpiiukvXvNcPtdO3ZIPXtKn3/OzwEAtILmfH4zB6e1JSSYdy2+5BI+1KzObpemTJFiYswwU1YmnTxpft2xw9w/ZQo/BwDQDhiiAi7EHXeYq+ZWrpQOHTq1au7SS6WJE83jAIA2xxBVaw9RofNp7LV5801z/lVsrPTf/80T5AGglTXn85seHOBCORzm/ZB+8pNTd7JmWAoA2hUBB2gthBoA6DCYZAwAACynTQLOkiVL1LNnTzkcDmVkZGjjxo1nLf/GG29owIABcjgcGjRokD744IOA44ZhaP78+UpOTlZ0dLSysrK0Y8eOYDYBAACEkKAHnNdee025ublasGCBNm3apCFDhig7O1uHz3B3188++0w333yzpkyZor/+9a8aO3asxo4dqy1btvjLPPXUU3ruuee0dOlSFRUVqUuXLsrOztbJkyeD3RwAABACgr6KKiMjQ5dffrleeOEFSVJDQ4NSU1N1zz33aPbs2aeVHzdunCorK/Xee+/5911xxRVKT0/X0qVLZRiGUlJSNGvWLN1///2SJK/Xq6SkJL3yyisaP378OevEKioAAEJPh7nRX01NjYqLi5WVlXXqDW02ZWVlqbCwsMlzCgsLA8pLUnZ2tr/8nj175PF4Asq4XC5lZGSc8ZoAAKBzCeoqqqNHj6q+vl5J33kYYVJSkrZt29bkOR6Pp8nyHo/Hf7xx35nKfFd1dbWqq6v9r30+X/MaAgAAQkqnWEWVl5cnl8vl31JTU9u7SgAAIIiCGnDi4+MVHh6u0tLSgP2lpaVyu91NnuN2u89avvFrc645Z84ceb1e/7Z///4WtQcAAISGoAacqKgoDR06VAUFBf59DQ0NKigoUGZmZpPnZGZmBpSXpHXr1vnL9+rVS263O6CMz+dTUVHRGa9pt9vldDoDNgAAYF1Bv5Nxbm6ubr/9dg0bNkzDhw/X4sWLVVlZqcmTJ0uSJk6cqB49eigvL0+S9D//8z+65ppr9Itf/EJjxozR6tWr9Ze//EUvvviiJCksLEz33XefHn30UfXr10+9evXSvHnzlJKSorFjxwa7OQAAIAQEPeCMGzdOR44c0fz58+XxeJSenq78/Hz/JOF9+/bJZjvVkTRixAi9+uqrmjt3rn72s5+pX79+evvtt/WDH/zAX+aBBx5QZWWlpk2bpvLycl111VXKz8+XgwcbAgAA8TRxhqsAAAgRHeY+OAAAAO2Bp4kDAFpfdbXU0CDZbJLd3t61QSdEwAEAtJ6TJ6WSEunoUTPgxMRIF10kxcVJzJNEGyLgAABaR3m5VFQk7dtnhhuHw9xiY6WLL5b69CHkoM0QcAAAF668XPrwQ2nLFqlLF6lrV8kwzB6do0fNr9HRUu/e7V1TdBJMMgYAXJiTJ6XNm6Xt282hqJQUM+TU1Jg9OZJUVSUdOGDOzYF1+XxSWZn5tZ3RgwMAuDAlJVJpqTn85HRKYWFSRITZi1NRcWqi8T/+IZ04waRjKyovl3bvlg4fNoOtJMXHm8OS33k4dlsh4AAAWq662vxrPTJSCg8//bjDYZYJC5Oiotq+fgi+8nJp0ybp+HHze9zQIHm90rffmr16V1wh9erV5vOvGKICALRcQ4M518bpNHtmqqoCj4eHS7W1UmWl5HKZ83BgLbt3m8NSYWHSnj3m66oqc7iyqsqcl3XwoDmU2YYIOACAlrPZzNDSrZsZYOrrzWGp2tpTk4zLy82/3nv1YnjKanw+af9+qa7OHKqUzCGpmJhTw5MVFeZE87KyNq0aQ1QAgJaz281wU1lpTi6urjb/aq+vNwPOsWPmMvEhQ8zjsJa6OnNuVUSE2VvncJg9OZGR5ub1mgE3KsocwqqubrOQS8ABAFyYuDhz8rBkTio9csQMNidOSJdcIg0f3i5zMNAG6uvN3rrISHO4MuI7sSI83AxB4eFm2cZVdW2AgAMAuDAOh9SjhzlUdfy4OR/nkkvMVVQpKebQFaypa1epe3cz0DaGmcjIU8cbfx4iI83hKlvbzYwh4AAALpzDcWqIimdQdR42m3TppebScI/H7MGJizN/Drxe8+ciNdWci5WU1KY/EwQcAEDrIdR0Lna72XtXV2f25uzYYS4Pj46WEhPNycbR0WYvTlxcm1aNgAMAAFqucQ6W02n24vl85sopwzDDzaWXmvvbeA4WAScU0OULAOioGudglZWZQ1QxMeaE4pgY827G7TQHi4DTkZ08af7AHDt2apb6RReZaZnVCACAjqIDzsEi4HRUJ0+ad4MsLTV/WBrvK/Htt+bTeHv3JuQAADqWDjTKQMDpqA4dMsNMXZ3Zi3P06KlkvGePOWM9Pb29awkAQIdEwOmIqqulAwfMSVsHD5rhJirKvMeAYUh795rHkpPb7SmtAAB0ZDyLqiM6ccK8OdKxY+azPbp0MZffNW5xcWbI+dvf2rumAAB0SAScjqqqynyAmcNhBpyICPP5Ho0z1B0Oc6jK52vvmgIA0OEQcDqi6GgzyJSVmQ+x+66qKikhwZyIXFnZ9vUDAKCDI+B0RI13hpTMoaraWnPuTW3tqZsnxcaavTht+FwPAABCBZOMO6r+/aW+fc1hqqgoc3jKMMxAk5BgLhlPSDCDDgAACMCf/x2VyyVde63Zk1NTY66gcjrNG/2FhZm9NwMHdqh7DgAA0FHQg9ORDRhg3vdm+3ZzaKqhwZyb43KZN/rr1au9awgAQIdEwOnIHA4pLU1yu80b/zU+riElhcc1AABwFgScjq7x+R4XXdRhnu8BAEBHR8AJFYQaAADOG5OMAQCA5RBwAACA5RBwAACA5RBwAACA5QQ14JSVlWnChAlyOp2KjY3VlClTVFFRcdby99xzj/r376/o6Ghdcskluvfee+X1egPKhYWFnbatXr06mE0BAAAhJKirqCZMmKCSkhKtW7dOtbW1mjx5sqZNm6ZXX321yfKHDh3SoUOHtGjRIqWlpenbb7/VnXfeqUOHDunNN98MKPvyyy8rJyfH/zqWRxYAAID/L8wwDCMYF966davS0tL0xRdfaNiwYZKk/Px8jR49WgcOHFBKSsp5XeeNN97QrbfeqsrKSkVEmHksLCxMa9as0dixY1tUN5/PJ5fLJa/XK6fT2aJrAACAttWcz++gDVEVFhYqNjbWH24kKSsrSzabTUVFRed9ncZGNIabRtOnT1d8fLyGDx+u5cuX62w5rbq6Wj6fL2ADAADWFbQhKo/Ho8TExMA3i4hQXFycPB7PeV3j6NGjWrhwoaZNmxaw/5FHHtF1112nmJgYrV27VnfffbcqKip07733NnmdvLw8/fznP29ZQwAAQMhpdg/O7Nmzm5zk+8/btm3bLrhiPp9PY8aMUVpamh5++OGAY/PmzdOVV16pyy67TA8++KAeeOABPf3002e81pw5c+T1ev3b/v37L7h+AACg42p2D86sWbM0adKks5bp3bu33G63Dh8+HLC/rq5OZWVlcrvdZz3/+PHjysnJUbdu3bRmzRpFRkaetXxGRoYWLlyo6upq2Zt4pIHdbm9yPwAAsKZmB5yEhAQlJCScs1xmZqbKy8tVXFysoUOHSpLWr1+vhoYGZWRknPE8n8+n7Oxs2e12vfPOO3KcxxOzN2/erO7duxNiAACApCDOwRk4cKBycnI0depULV26VLW1tZoxY4bGjx/vX0F18OBBjRw5UitXrtTw4cPl8/k0atQoVVVV6be//W3AhOCEhASFh4fr3XffVWlpqa644go5HA6tW7dOjz/+uO6///5gNQUAAISYoN4HZ9WqVZoxY4ZGjhwpm82mG2+8Uc8995z/eG1trbZv366qqipJ0qZNm/wrrPr27RtwrT179qhnz56KjIzUkiVLNHPmTBmGob59++qZZ57R1KlTg9kUAAAQQoJ2H5yOjPvgAAAQejrEfXAAAADaCwEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYDgEHAABYTlADTllZmSZMmCCn06nY2FhNmTJFFRUVZz3n2muvVVhYWMB25513BpTZt2+fxowZo5iYGCUmJuqnP/2p6urqgtkUAAAQQiKCefEJEyaopKRE69atU21trSZPnqxp06bp1VdfPet5U6dO1SOPPOJ/HRMT4/93fX29xowZI7fbrc8++0wlJSWaOHGiIiMj9fjjjwetLQAAIHSEGYZhBOPCW7duVVpamr744gsNGzZMkpSfn6/Ro0frwIEDSklJafK8a6+9Vunp6Vq8eHGTx//whz/o3//933Xo0CElJSVJkpYuXaoHH3xQR44cUVRU1Dnr5vP55HK55PV65XQ6W9ZAAADQpprz+R20IarCwkLFxsb6w40kZWVlyWazqaio6Kznrlq1SvHx8frBD36gOXPmqKqqKuC6gwYN8ocbScrOzpbP59PXX3/d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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 3\n"
     ]
    },
    {
     "data": {
      "image/png": "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+ZpsAACg67IsvHi9XiUlJTVpi4yMVEJCgrxeb4vHLVmyROPGjdM999zTpvPk5uYqLi6ucUtLS7uiugEAQOcWdHhZunSpHA5Hq1txcXG7itm0aZO2bdum1atXt/mYZcuWqbKysnE7fvx4u84NAADsIeg5Lw899JDmzp3b6j79+vVTSkqKSktLm7TX19ervLy8xctB27Zt06FDhxQfH9+k/d5779WECRP09ttvX3KMy+WSi5VDAQC4agQdXhITE5WYmHjZ/bKyslRRUaGioiJlZGRIMsNJIBBQZmZms8csXbpU3//+95u0DRs2TE8++aSmTp0abKkAAKALsuxuoyFDhmjy5MlasGCB1q5dq7q6Oi1evFjf/e53G+80OnnypCZOnKgXX3xRY8eOVUpKSrOjMtdee62uv/56q0oFAAA2Yuk6Ly+99JIGDx6siRMnasqUKRo/fryeeeaZxtfr6uq0f/9+VVdXW1kGAADoQhyGYRjhLqIj+Xw+xcXFqbKyUh6PJ9zlAACANgjm85tnGwEAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFshvAAAAFuxLLyUl5dr5syZ8ng8io+P1/z583X27NnLHldQUKBvfvObiomJkcfj0W233abz589bVSYAALAZy8LLzJkztXfvXm3dulWbN2/Wu+++q4ULF7Z6TEFBgSZPnqw777xTO3bs0M6dO7V48WI5nQwQAQAAk8MwDKOj33Tfvn0aOnSodu7cqdGjR0uS8vLyNGXKFJ04cUKpqanNHnfLLbfoW9/6llauXNnuc/t8PsXFxamyslIej6fd7wMAAEInmM9vS4Y0CgoKFB8f3xhcJCk7O1tOp1OFhYXNHlNaWqrCwkIlJSVp3LhxSk5O1u23367t27e3ei6/3y+fz9dkAwAAXZcl4cXr9SopKalJW2RkpBISEuT1eps95vDhw5KkRx99VAsWLFBeXp5uvvlmTZw4UZ999lmL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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 2\n"
     ]
    },
    {
     "data": {
      "image/png": "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wowxJtSV6Gper1fx8fGqqKigvxAAAD1EML6/u92oMQAAgK5CEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALZFEAIAALbVJUFo7dq1Gjx4sGJiYpSZmakdO3acseyjjz6qb3zjG+rfv7/69++v7OzsFuXnz5+vsLCwgCU3NzfYzQAAAL1M0IPQU089pby8PN1xxx165513NH78eOXk5Oj48eOtlt+2bZuuueYavfbaayoqKlJaWpqmTZumTz/9NKBcbm6ujh075l/+8Ic/BLspAACglwkzxphgvkFmZqYuueQSPfLII5KkpqYmpaWl6YYbbtDy5cvPun9jY6P69++vRx55RHPnzpVkXREqLy/X888/f0518nq9io+PV0VFhZxO5zkdAwAAdK1gfH8H9YrQ6dOnVVxcrOzs7M/fMDxc2dnZKioqatcxampqVF9fr4SEhID127Zt08CBAzVy5Ehdd911OnXq1BmP4fP55PV6AxYAAICgBqGTJ0+qsbFRycnJAeuTk5Pl8XjadYxly5YpNTU1IEzl5ubq8ccfV2Fhoe6991797W9/05VXXqnGxsZWj7F69WrFx8f7l7S0tHNvFAAA6DUiQ12Bttxzzz3avHmztm3bppiYGP/62bNn+38eO3asxo0bp2HDhmnbtm2aOnVqi+Pk5+crLy/P/9rr9RKGAABAcK8IJSYmKiIiQqWlpQHrS0tL5Xa729z3/vvv1z333KNXXnlF48aNa7Ps0KFDlZiYqP3797e63eFwyOl0BiwAAABBDULR0dGaOHGiCgsL/euamppUWFiorKysM+533333adWqVSooKNCkSZPO+j5HjhzRqVOnlJKS0in1BgAA9hD04fN5eXl69NFHtWnTJpWUlOi6665TdXW1FixYIEmaO3eu8vPz/eXvvfderVixQhs2bNDgwYPl8Xjk8XhUVVUlSaqqqtKtt96qN998U5988okKCws1Y8YMDR8+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I62yAHokPr0A0BqHQ0pNta76lJW13F5XJ9XWSikpdJYGejCCEACcSUqKNUze55M+/VSqqbF+Pnny8w7Uo0dboQlAj8TweQA4k5gY6dJLrU7RJSVWx+mwMKvzdFqaFYKGDAl1LQGcB4IQALTF5ZKmTJG++lXp6FGrb1CfPtZts4QEKywB6LEIQgBwNjEx1pWf1FRrNFl4OLfDgF6CIAQA7UX4AXodOksDAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbIggBAADbCmoQKisr05w5c+R0OuVyubRw4UJVVVWdsfwnn3yisLCwVpenn37aX6617Zs3bw5mUwAAQC8UGcyDz5kzR8eOHdPWrVtVX1+vBQsWaPHixXryySdbLZ+WlqZjx44FrPvd736nNWvW6MorrwxY/9hjjyk3N9f/2uVydXr9AQBA7xa0IFRSUqKCggK99dZbmjRpkiTp4Ycf1lVXXaX7779fqampLfaJiIiQ2+0OWPfcc8/p+9//vvr27Ruw3uVytSgLAADQEUG7NVZUVCSXy+UPQZKUnZ2t8PBwbd++vV3HKC4u1q5du7Rw4cIW266//nolJiYqIyNDGzZskDGm0+oOAADsIWhXhDwejwYOHBj4ZpGRSkhIkMfjadcx1q9fr9GjR2vy5MkB6++66y5dccUViouL0yuvvKKf/OQnqqqq0o033tjqcXw+n3w+n/+11+vtYGsAAEBv1OErQsuXLz9jh+bmZe/eveddsdraWj355JOtXg1asWKFvv71r2vChAlatmyZbrvtNq1Zs+aMx1q9erXi4+P9S1pa2nnXDwAA9HwdviK0dOlSzZ8/v80yQ4cOldvt1vHjxwPWNzQ0qKysrF19e5555hnV1NRo7ty5Zy2bmZmpVatWyefzyeFwtNien5+vvLw8/2uv10sYAgAAHQ9CSUlJSkpKOmu5rKwslZeXq7i4WBMnTpQkvfrqq2pqalJmZuZZ91+/fr2+853vtOu9du3apf79+7cagiTJ4XCccRsAALCvoPURGj16tHJzc7Vo0SKtW7dO9fX1WrJkiWbPnu0fMfbpp59q6tSpevzxx5WRkeHfd//+/Xr99de1ZcuWFsf905/+pNLSUl166aWKiYnR1q1b9atf/Uq33HJLsJoCAAB6qaDOI/TEE09oyZIlmjp1qsLDw3X11VfroYce8m+vr6/Xvn37VFNTE7Dfhg0bdMEFF2jatGktjhkVFaW1a9fq5ptvljFGw4cP1wMPPKBFixYFsykAAKAXCjM2HHfu9XoVHx+viooKOZ3OUFcHAAC0QzC+v3nWGAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsC2CEAAAsK3IUFcAAOT1Si+/LH32meR2Szk5ksMR6loBsAGCEIDQKS+X1q+XnnhCOnxYamyUoqKkIUOkRYukOXOkmJhQ1xJAL0YQAhAa5eXSgw9aQaimRnK5pNhYqapK2rdP+uUvpdOnpQULCEMAgoY+QgBC4+OPpT/9SaqrkwYNkgYMkOLipIEDpbQ063bZk09KZWWhrimAXowgBKDreb3SX/4ieTyS0ymFf+lXUVSU1K+fdPCgtGWL5POFpp4Aej2CEICu19BghaGmJut22JeDUHi4dTussdG6hdbUFJJqAuj9CEIAul5k5OdXgmprWwadpibrlllEhNV36MtBCQA6Cb9dAHQ9p1OaPt0aKt98ZeiL6uulykqr79BVVzGUHkDQEIQAhMbQodK//qt1C+zgQenUKWv02PHj1lB6p1P6wQ+khIRQ1xRAL8bweQCh4XJJN91kdYpunkfos8+sjtIjRzKPEIAuEWaMMaGuRFfzer2Kj49XRUWFnE5nqKsDgJmlAbRDML6/uSIEIPScTul73wt1LQDYEH2EAACAbRGEAACAbRGEAACAbQUtCP3yl7/U5MmTFRcXJ5fL1a59jDFauXKlUlJSFBsbq+zsbH344YcBZcrKyjRnzhw5nU65XC4tXLhQVVVVQWgBAADo7YIWhE6fPq3vfe97uu6669q9z3333aeHHnpI69at0/bt29WnTx/l5OSorq7OX2bOnDnavXu3tm7dqj//+c96/fXXtXjx4mA0AQAA9HJBHz6/ceNG3XTTTSovL2+znDFGqampWrp0qW655RZJUkVFhZKTk7Vx40bNnj1bJSUlGjNmjN566y1NmjRJklRQUKCrrrpKR44cUWpqarvqxPB5AAB6nmB8f3ebPkIHDhyQx+NRdna2f118fLwyMzNVVFQkSSoqKpLL5fKHIEnKzs5WeHi4tm/ffsZj+3w+eb3egAUAAKDbBCGPxyNJSk5ODlifnJzs3+bxeDRw4MCA7ZGRkUpISPCXac3q1asVHx/vX9LS0jq59gAAoCfqUBBavny5wsLC2lz27t0brLqes/z8fFVUVPiXw4cPh7pKAACgG+jQzNJLly7V/Pnz2ywzdOjQc6qI2+2WJJWWliolJcW/vrS0VOnp6f4yx48fD9ivoaFBZWVl/v1b43A45PjCdP3N3aK4RQYAQM/R/L3dmd2bOxSEkpKSlJSU1Glv/kVDhgyR2+1WYWGhP/h4vV5t377dP/IsKytL5eXlKi4u1sSJEyVJr776qpqampSZmdnu96qsrJQkbpEBANADVVZWKj4+vlOOFbRnjR06dEhlZWU6dOiQGhsbtWvXLknS8OHD1bdvX0nSqFGjtHr1av3bv/2bwsLCdNNNN+nuu+/WiBEjNGTIEK1YsUKpqamaOXOmJGn06NHKzc3VokWLtG7dOtXX12vJkiWaPXt2u0eMSVJqaqoOHz6sfv36KSwsTJIVutLS0nT48GHbjCSzW5vt1l6JNtPm3os227PNxhhVVlZ26Dv/bIIWhFauXKlNmzb5X0+YMEGS9Nprr+nyyy+XJO3bt08VFRX+Mrfddpuqq6u1ePFilZeX67LLLlNBQYFiYmL8ZZ544gktWbJEU6dOVXh4uK6++mo99NBDHapbeHi4Lrjggla3OZ1O2/wDa2a3NtutvRJttgvabA92b3NnXQlqFvR5hHoKO84tZLc22629Em2mzb0XbabNnaXbDJ8HAADoagSh/8/hcOiOO+4IGF3W29mtzXZrr0Sb7YI22wNtDg5ujQEAANviihAAALAtghAAALAtghAAALAtghAAALAt2wShX/7yl5o8ebLi4uLkcrnatY8xRitXrlRKSopiY2OVnZ2tDz/8MKBMWVmZ5syZI6fTKZfLpYULF6qqqioILei4jtbtk08+OePDdJ9++ml/uda2b968uSuadFbncj4uv/zyFu259tprA8ocOnRI06dPV1xcnAYOHKhbb71VDQ0NwWxKu3W0zWVlZbrhhhs0cuRIxcbG6sILL9SNN94YMLmp1L3O89q1azV48GDFxMQoMzNTO3bsaLP8008/rVGjRikmJkZjx47Vli1bAra357Mdah1p86OPPqpvfOMb6t+/v/r376/s7OwW5efPn9/ifObm5ga7Ge3WkfZu3LixRVu+OPGu1PvOcWu/p8LCwjR9+nR/me5+jl9//XX967/+q1JTUxUWFqbnn3/+rPts27ZNF198sRwOh4YPH66NGze2KNPR3w8tGJtYuXKleeCBB0xeXp6Jj49v1z733HOPiY+PN88//7x59913zXe+8x0zZMgQU1tb6y+Tm5trxo8fb958803zf//3f2b48OHmmmuuCVIrOqajdWtoaDDHjh0LWO68807Tt29fU1lZ6S8nyTz22GMB5b74dxJK53I+pkyZYhYtWhTQnoqKCv/2hoYGc9FFF5ns7Gyzc+dOs2XLFpOYmGjy8/OD3Zx26Wib33//ffPd737XvPjii2b//v2msLDQjBgxwlx99dUB5brLed68ebOJjo42GzZsMLt37zaLFi0yLpfLlJaWtlr+73//u4mIiDD33Xef2bNnj7n99ttNVFSUef/99/1l2vPZDqWOtvkHP/iBWbt2rdm5c6cpKSkx8+fPN/Hx8ebIkSP+MvPmzTO5ubkB57OsrKyrmtSmjrb3scceM06nM6AtHo8noExvO8enTp0KaO8HH3xgIiIizGOPPeYv053PsTHGbNmyxfz85z83zz77rJFknnvuuTbLf/zxxyYuLs7k5eWZPXv2mIcffthERESYgoICf5mO/j22xjZBqNljjz3WriDU1NRk3G63WbNmjX9deXm5cTgc5g9/+IMxxpg9e/YYSeatt97yl3nppZdMWFiY+fTTTzu97h3RWXVLT083//Ef/xGwrj3/gEPhXNs8ZcoU89Of/vSM27ds2WLCw8MDftH+5je/MU6n0/h8vk6p+7nqrPP8xz/+0URHR5v6+nr/uu5ynjMyMsz111/vf93Y2GhSU1PN6tWrWy3//e9/30yfPj1gXWZmpvnP//xPY0z7Ptuh1tE2f1lDQ4Pp16+f2bRpk3/dvHnzzIwZMzq7qp2io+092+9xO5zj//7v/zb9+vUzVVVV/nXd+Rx/WXt+v9x2223ma1/7WsC6WbNmmZycHP/r8/17NMYY29wa66gDBw7I4/EoOzvbvy4+Pl6ZmZkqKiqSJBUVFcnlcmnSpEn+MtnZ2QoPD9f27du7vM5f1Bl1Ky4u1q5du7Rw4cIW266//nolJiYqIyNDGzZskOkG01GdT5ufeOIJJSYm6qKLLlJ+fr5qamoCjjt27FglJyf71+Xk5Mjr9Wr37t2d35AO6Kx/g83T10dGBj5+MNTn+fTp0youLg74HIaHhys7O9v/OfyyoqKigPKSdb6ay7fnsx1K59LmL6upqVF9fb0SEhIC1m/btk0DBw7UyJEjdd111+nUqVOdWvdzca7traqq0qBBg5SWlqYZM2YEfBbtcI7Xr1+v2bNnq0+fPgHru+M5Pldn+yx3xt+jFMSHrvZ0Ho9HkgK+/JpfN2/zeDwaOHBgwPbIyEglJCT4y4RKZ9Rt/fr1Gj16tCZPnhyw/q677tIVV1yhuLg4vfLKK/rJT36iqqoq3XjjjZ1W/3Nxrm3+wQ9+oEGDBik1NVXvvfeeli1bpn379unZZ5/1H7e1fwfN20KpM87zyZMntWrVKi1evDhgfXc4zydPnlRjY2Orf/979+5tdZ8zna8vfm6b152pTCidS5u/bNmyZUpNTQ34gsjNzdV3v/tdDRkyRB999JF+9rOf6corr1RRUZEiIiI6tQ0dcS7tHTlypDZs2KBx48apoqJC999/vyZPnqzdu3frggsu6PXneMeOHfrggw+0fv36gPXd9RyfqzN9lr1er2pra/XZZ5+d92dF6uFBaPny5br33nvbLFNSUqJRo0Z1UY2Cr71tPl+1tbV68skntWLFihbbvrhuwoQJqq6u1po1a4L2BRnsNn8xAIwdO1YpKSmaOnWqPvroIw0bNuycj3s+uuo8e71eTZ8+XWPGjNEvfvGLgG1dfZ7ROe655x5t3rxZ27ZtC+hAPHv2bP/PY8eO1bhx4zRs2DBt27ZNU6dODUVVz1lWVpaysrL8rydPnqzRo0frt7/9rVatWhXCmnWN9evXa+zYscrIyAhY35vOcVfq0UFo6dKlmj9/fptlhg4dek7HdrvdkqTS0lKlpKT415eWlio9Pd1f5vjx4wH7NTQ0qKyszL9/Z2tvm8+3bs8884xqamo0d+7cs5bNzMzUqlWr5PP5gvI8mK5qc7PMzExJ0v79+zVs2DC53e4WoxBKS0slqUef58rKSuXm5qpfv3567rnnFBUV1Wb5YJ/n1iQmJioiIsL/992stLT0jO1zu91tlm/PZzuUzqXNze6//37dc889+utf/6px48a1WXbo0KFKTEzU/v37Q/oleT7tbRYVFaUJEyZo//79knr3Oa6urtbmzZt11113nfV9uss5Pldn+iw7nU7FxsYqIiLivP/tSLLPqLFmHe0sff/99/vXVVRUtNpZ+u233/aXefnll7tVZ+lzrduUKVNajCI6k7vvvtv079//nOvaWTrrfLzxxhtGknn33XeNMZ93lv7iKITf/va3xul0mrq6us5rwDk41zZXVFSYSy+91EyZMsVUV1e3671CdZ4zMjLMkiVL/K8bGxvNV77ylTY7S3/7298OWJeVldWis3Rbn+1Q62ibjTHm3nvvNU6n0xQVFbXrPQ4fPmzCwsLMCy+8cN71PV/n0t4vamhoMCNHjjQ333yzMab3nmNjrO8wh8NhTp48edb36E7n+MvUzs7SF110UcC6a665pkVn6fP5t2OMjUaNHTx40OzcudM/HHznzp1m586dAcPCR44caZ599ln/63vuuce4XC7zwgsvmPfee8/MmDGj1eHzEyZMMNu3bzdvvPGGGTFiRLcaPt9W3Y4cOWJGjhxptm/fHrDfhx9+aMLCwsxLL73U4pgvvviiefTRR837779vPvzwQ/PrX//axMXFmZUrVwa9Pe3R0Tbv37/f3HXXXebtt982Bw4cMC+88IIZOnSo+eY3v+nfp3n4/LRp08yuXbtMQUGBSUpK6lbD5zvS5oqKCpOZmWnGjh1r9u/fHzDUtqGhwRjTvc7z5s2bjcPhMBs3bjR79uwxixcvNi6Xyz+K70c/+pFZvny5v/zf//53ExkZae6//35TUlJi7rjjjlaHz5/tsx1KHW3zPffcY6Kjo80zzzwTcD6bf79VVlaaW265xRQVFZkDBw6Yv/71r+biiy82I0aMCHmYN6bj7b3zzjvNyy+/bD766CNTXFxsZs+ebWJiYszu3bv9ZXrbOW522WWXmVmzZrVY393PsTFWHZu/eyWZBx54wOzcudMcPHjQGGPM8uXLzY9+9CN/+ebh87feeqspKSkxa9eubXX4fFt/j+1hmyA0b948I6nF8tprr/nL6P/Pm9KsqanJrFixwiQnJxuHw2GmTp1q9u3bF3DcU6dOmWuuucb07dvXOJ1Os2DBgoBwFUpnq9uBAwda/B0YY0x+fr5JS0szjY2NLY750ksvmfT0dNO3b1/Tp08fM378eLNu3bpWy4ZCR9t86NAh881vftMkJCQYh8Nhhg8fbm699daAeYSMMeaTTz4xV155pYmNjTWJiYlm6dKlAUPNQ6mjbX7ttdda/SxIMgcOHDDGdL/z/PDDD5sLL7zQREdHm4yMDPPmm2/6t02ZMsXMmzcvoPwf//hH89WvftVER0ebr33ta+Yvf/lLwPb2fLZDrSNtHjRoUKvn84477jDGGFNTU2OmTZtmkpKSTFRUlBk0aJBZtGhRh74sgq0j7b3pppv8ZZOTk81VV11l3nnnnYDj9bZzbIwxe/fuNZLMK6+80uJYPeEcn+l3T3M7582bZ6ZMmdJin/T0dBMdHW2GDh0a8B3drK2/x/YIM6YbjHsGAAAIAeYRAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtkUQAgAAtvX/AHZLCOJAgB/dAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 3\n"
     ]
    },
    {
     "data": {
      "image/png": "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rl1rEhISzMKFC+1uTqM0tc2fffaZ+cEPfmDefvtts3fvXrNhwwZz6aWXmptuuimsXHs5zqtXrzZRUVHm+eefNzt27DBz5841cXFxpqCgoN7yn3zyiYmIiDC/+c1vzM6dO80DDzxgunTpYj777LNQmcZ8tttSU9t82223mRUrVpht27aZXbt2mVmzZhmfz2eOHj0aKjNz5kwzefLksONZVFTUWk06r6a2+YUXXjBerzesPfn5+WFlnHacT506Fdbezz//3ERERJgXXnghVKY9H+e1a9eaX/3qV+b11183kswbb7xxzvL79+83sbGxJisry+zcudM89dRTJiIiwqxbty5Upqm/w4Y4IujUeuGFFxoVdILBoElJSTGPP/54aF1xcbHxeDzmz3/+szHGmJ07dxpJZvPmzaEy7777rnG5XObYsWMtXvemaKm6paenm//4j/8IW9eYP9C20Nw2T5gwwdx9990Nbl+7dq1xu91h/0T/8Ic/GK/XayoqKlqk7s3VUsf5lVdeMVFRUaaqqiq0rr0c5zFjxpg777wz9Lympsakpqaa7OzsesvffPPN5vrrrw9bl5GRYe644w5jTOM+222tqW3+turqatO9e3fz0ksvhdbNnDnT3HDDDS1d1RbT1Daf7395ZzjOv/3tb0337t3N6dOnQ+va+3Gu1Zj/L//v//0/c/nll4etmzZtmpk0aVLo+YX+Dms54tRVUx04cED5+fnKzMwMrfP5fMrIyFBOTo4kKScnR3FxcRo9enSoTGZmptxutzZt2tTqdf6mlqhbXl6etm/frjlz5tTZdueddyohIUFjxozR888/L9MOLrV0IW1++eWXlZCQoKFDh2rhwoUqKysLe91hw4YpOTk5tG7SpEkKBALasWNHyzekCVrqb9Dv98vr9SoyMvzWdm19nCsrK5WXlxf2OXS73crMzAx9Dr8tJycnrLxkHa/a8o35bLel5rT528rKylRVVaX4+Piw9Rs3blRSUpIGDhyon/zkJzp16lSL1r25mtvm06dPq0+fPkpLS9MNN9wQ9nnsDMf5ueee0y233KKuXbuGrW+vx7mpzvdZbonfYS3H3dSzMfLz8yUp7Mut9nnttvz8fCUlJYVtj4yMVHx8fKhMW2mJuj333HMaPHiwxo0bF7b+kUce0TXXXKPY2Fj99a9/1U9/+lOdPn1aP/vZz1qs/s3R3Dbfdttt6tOnj1JTU/Xpp5/q/vvv1549e/T666+HXre+v4PabW2pJY5zYWGhlixZonnz5oWtbw/HubCwUDU1NfX+/nfv3l3vPg0dr29+bmvXNVSmLTWnzd92//33KzU1NewLYPLkyfrBD36gSy65RPv27dMvf/lLXXfddcrJyVFERESLtqGpmtPmgQMH6vnnn9fw4cPl9/u1bNkyjRs3Tjt27NBFF13k+OOcm5urzz//XM8991zY+vZ8nJuqoc9yIBDQmTNn9PXXX1/wZ6VWuw06CxYs0GOPPXbOMrt27dKgQYNaqUb2a2ybL9SZM2e0atUqPfjgg3W2fXPdyJEjVVpaqscff9y2L0C72/zNL/hhw4apV69emjhxovbt26f+/fs3+3UvRGsd50AgoOuvv15DhgzRQw89FLattY8zWsbSpUu1evVqbdy4MWxw7i233BL6ediwYRo+fLj69++vjRs3auLEiW1R1QsyduxYjR07NvR83LhxGjx4sP74xz9qyZIlbViz1vHcc89p2LBhGjNmTNh6px3n1tJug869996rWbNmnbNMv379mvXaKSkpkqSCggL16tUrtL6goEDp6emhMidOnAjbr7q6WkVFRaH9W1pj23yhdXvttddUVlamGTNmnLdsRkaGlixZooqKClvuR9Jaba6VkZEhSdq7d6/69++vlJSUOqP4CwoKJKlDH+eSkhJNnjxZ3bt31xtvvKEuXbqcs7zdx7k+CQkJioiICP2+axUUFDTYvpSUlHOWb8xnuy01p821li1bpqVLl+r999/X8OHDz1m2X79+SkhI0N69e9v8C/BC2lyrS5cuGjlypPbu3SvJ2ce5tLRUq1ev1iOPPHLe92lPx7mpGvose71excTEKCIi4oL/bkKaNKKnnWvqYORly5aF1vn9/noHI2/ZsiVU5r333mtXg5GbW7cJEybUmYXTkP/8z/80PXr0aHZdW0pLHY+PP/7YSDL//Oc/jTFnByN/cxT/H//4R+P1ek15eXnLNaAZmttmv99vrrzySjNhwgRTWlraqPdqq+M8ZswYM3/+/NDzmpoa07t373MORv6Xf/mXsHVjx46tMxj5XJ/tttbUNhtjzGOPPWa8Xq/Jyclp1HscOXLEuFwu89Zbb11wfVtCc9r8TdXV1WbgwIHmnnvuMcY49zgbY32PeTweU1hYeN73aG/HuZYaORh56NChYetuvfXWOoORL+TvJlSfJpVupw4dOmS2bdsWmi69bds2s23btrBp0wMHDjSvv/566PnSpUtNXFyceeutt8ynn35qbrjhhnqnl48cOdJs2rTJfPzxx+bSSy9tV9PLz1W3o0ePmoEDB5pNmzaF7ffll18al8tl3n333Tqv+fbbb5tnn33WfPbZZ+bLL780v//9701sbKxZtGiR7e1pjKa2ee/eveaRRx4xW7ZsMQcOHDBvvfWW6devn7n66qtD+9ROL7/22mvN9u3bzbp160xiYmK7ml7elDb7/X6TkZFhhg0bZvbu3Rs2DbW6utoY076O8+rVq43H4zEvvvii2blzp5k3b56Ji4sLzYK7/fbbzYIFC0LlP/nkExMZGWmWLVtmdu3aZRYvXlzv9PLzfbbbUlPbvHTpUhMVFWVee+21sONZ+/+tpKTE/OIXvzA5OTnmwIED5v333zdXXHGFufTSS9s8rNdqapsffvhh895775l9+/aZvLw8c8stt5jo6GizY8eOUBmnHeda48ePN9OmTauzvr0f55KSktB3ryTz5JNPmm3btplDhw4ZY4xZsGCBuf3220Pla6eX33fffWbXrl1mxYoV9U4vP9fvsLEcEXRmzpxpJNVZPvzww1AZ/d91Q2oFg0Hz4IMPmuTkZOPxeMzEiRPNnj17wl731KlT5tZbbzXdunUzXq/XzJ49Oyw8taXz1e3AgQN1fgfGGLNw4UKTlpZmampq6rzmu+++a9LT0023bt1M165dzYgRI8zKlSvrLdsWmtrmw4cPm6uvvtrEx8cbj8djBgwYYO67776w6+gYY8zBgwfNddddZ2JiYkxCQoK59957w6Zit6WmtvnDDz+s97MgyRw4cMAY0/6O81NPPWUuvvhiExUVZcaMGWP+8Y9/hLZNmDDBzJw5M6z8K6+8Yi677DITFRVlLr/8cvPOO++EbW/MZ7utNaXNffr0qfd4Ll682BhjTFlZmbn22mtNYmKi6dKli+nTp4+ZO3duk78M7NaUNv/85z8PlU1OTjZTpkwxW7duDXs9px1nY4zZvXu3kWT++te/1nmt9n6cG/rfU9vGmTNnmgkTJtTZJz093URFRZl+/fqFfUfXOtfvsLFcxrSDucMAAAA26JTX0QEAAJ0DQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADgWQQcAADjW/wdAcY99+77W5AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 3\n"
     ]
    },
    {
     "data": {
      "image/png": "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pA03ycl2/E5RkS3fo0e0aw0AjUbQATqyhASpb19p8GA7bdzjsWEnJsY+v/RSOyjZ75fS0qRBg5haDqBdYTAy0NElJNh1cnr2tD05Pp8dlFw3TsflsperevQg5ABodwg6ACyPxz6Sk+3zumnn3P4BQDtG0AFQP8INAAdgjA4AAHAsgg4AAHAsgg4AAHAsgg4AAHAsgg4AAHAsgg4AAHAsgg4AAHCsVgk6y5cvV69evZSQkKDs7Gxt2rTpvOVPnTqlu+++Wz169JDH49GVV16pNWvWtEZVAQCAg0R8wcDVq1crNzdXK1asUHZ2tpYtW6YJEyZo9+7d6t69+znlq6qq9M1vflPdu3fXK6+8op49e+rgwYNKrlutFQAAoJFcxhgTyTfIzs7WNddco6eeekqSFAwGlZWVpXvuuUfz588/p/yKFSv0xBNPaNeuXYqLi2vy+/n9fiUlJcnn88nr9V50/QEAQORF6vM7opeuqqqqVFhYqJycnLNv6HYrJydHBQUF9R7z5ptvasyYMbr77ruVnp6uwYMH6+c//7lqa2sjWVUAAOBAEb10deLECdXW1io9PT1se3p6unbt2lXvMfv27dP69es1bdo0rVmzRnv27NEPfvADVVdXa9GiReeUDwQCCgQCoed+v79lGwEAANqtNjfrKhgMqnv37nr66ac1cuRITZ06VT/96U+1YsWKesvn5eUpKSkp9MjKymrlGgMAgLYqokEnNTVVMTExKi4uDtteXFysjIyMeo/p0aOHrrzySsXExIS2DRw4UEVFRaqqqjqn/IIFC+Tz+UKPw4cPt2wjAABAuxXRoBMfH6+RI0dq3bp1oW3BYFDr1q3TmDFj6j3ma1/7mvbs2aNgMBja9umnn6pHjx6Kj48/p7zH45HX6w17AAAASK1w6So3N1fPPPOM/vCHP2jnzp36/ve/r9OnT2vWrFmSpOnTp2vBggWh8t///vdVWlqqe++9V59++qnefvtt/fznP9fdd98d6aoCAACHifg6OlOnTtXx48e1cOFCFRUVafjw4crPzw8NUD506JDc7rN5KysrS++8847uu+8+DR06VD179tS9996rBx98MNJVBQAADhPxdXRaG+voAADQ/rTLdXQAAACiiaADAAAci6ADAAAci6ADAAAci6ADAAAci6ADAAAci6ADAAAci6ADAAAci6ADAAAci6ADAAAc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3ita53n06NFm3rx5oee1tbWmZ8+e5x2M/K1vfSts25gxY84ZjHy+3+1oa2qbjTHm8ccfN16v1xQUFDTqPQ4fPmxcLpd54403Lrq+LaE5bf6ympoa079/f3PfffcZY9r+eW5ue59//nnj8XjMiRMnLvgebe0cf5kaORh58ODBYdtuv/32cwYjX8y/m1B9mlS6jTp48KDZunVraLr01q1bzdatW8OmTffv39+8+uqroedLliwxycnJ5o033jD/+Mc/zM0331zv9PIRI0aYjRs3mvfff99cccUVbWp6+fnqduTIEdO/f3+zcePGsOM+++wz43K5zJ/+9KdzXvPNN980zzzzjNm2bZv57LPPzG9/+1vTqVMns3Dhwoi3pzGa2uY9e/aYxx57zHz00Udm//795o033jB9+vQxN9xwQ+iYuunlN954o/n4449Nfn6+SUtLa1PTy5vSZp/PZ7Kzs82QIUPMnj17wqai1tTUGGPa1nletWqV8Xg85oUXXjA7duwwc+fONcnJyaFZcHfeeaeZP39+qPwHH3xgYmNjzdKlS83OnTvNokWL6p1efqHf7WhqapuXLFli4uPjzSuvvBJ2Puv+vpWVlZkf//jHpqCgwOzfv9+8++675uqrrzZXXHFF1MN6naa2+dFHHzXvvPOO2bt3ryksLDS33XabSUhIMNu3bw+VacvnuantrXPdddeZqVOnnrO9PZzjsrKy0GevJPPkk0+arVu3moMHDxpjjJk/f7658847Q+Xrppc/8MADZufOnWb58uX1Ti8/38+xsRwRdGbMmGEknfP4y1/+Eiqj/1s3pE4wGDQPP/ywSU9PNx6Px4wfP97s3r077HVPnjxpbr/9dtOlSxfj9XrNrFmzwsJTNF2obvv37z/nZ2CMMQsWLDBZWVmmtrb2nNf805/+ZIYPH266dOliOnfubIYNG2ZWrFhRb9loaGqbDx06ZG644QaTkpJiPB6P6devn3nggQfC1tExxpgDBw6Ym266ySQmJprU1FRz//33h03Fjqamtvkvf/lLvb8Lksz+/fuNMW3vPP/mN78xl112mYmPjzejR482H374YWjfuHHjzIwZM8LKv/TSS+bKK6808fHx5qqrrjJvv/122P7G/G5HW1PafPnll9d7PhctWmSMMaaiosLceOONJi0tzcTFxZnLL7/czJkzp8kfBpHWlDb/6Ec/CpVNT083kyZNMlu2bAl7vbZ+npv673rXrl1Gkvnzn/98zmu1h3Pc0N+eunbOmDHDjBs37pxjhg8fbuLj402fPn3CPqPrnO/n2FguY9rA3GEAAIAI6JDr6AAAgI6BoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAAByLoAMAABzr/wPaDcQvLRg+igAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i, j in list(product(range(irrep_d), repeat=2)):\n",
    "    if i >= j:\n",
    "        continue\n",
    "    print(i, j)\n",
    "    # plt.scatter(c[:,i].tolist(), c[:,j].tolist(), alpha=1., c='r')\n",
    "    # plt.scatter(full_b[:,i].tolist(), full_b[:,j].tolist(), alpha=0.01, c='b')\n",
    "    plt.scatter(b[:,i].tolist(), b[:,j].tolist(), alpha=.1, c='r')\n",
    "    # plt.scatter(full_c[:,i].tolist(), full_c[:,j].tolist(), alpha=0.01, c='r')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "id": "1b28e1f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = sum(max(0, t.dot(a[i], b[i] + c[i]).item()) * (c[i].unsqueeze(1) @ b[i].unsqueeze(1).T) for i in range(a.shape[0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 229,
   "id": "1811f4a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 1.3264,  0.3489,  0.3925, -0.9783],\n",
       "        [-0.0428,  1.3047, -0.5520,  0.2231],\n",
       "        [-0.8919,  1.5203,  0.7868, -0.3573],\n",
       "        [-0.2105, -1.2000, -0.2221,  1.1326]])"
      ]
     },
     "execution_count": 229,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "7e7857c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(X.numpy())\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd453922",
   "metadata": {},
   "outputs": [],
   "source": [
    "axis1 = t.randn((irrep_d ,1))\n",
    "axis2 = t.randn((irrep_d, 1))\n",
    "plt.scatter(full_c @ axis1, full_c @ axis2, alpha=0.5)\n",
    "plt.scatter(full_b @ axis1, full_b @ axis2, alpha=1.0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4caf4a34-481d-48a8-9a66-5489f3bbe1cd",
   "metadata": {},
   "source": [
    "### b_i and c_i are clustered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "c65a5e65",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_a = einops.einsum(a[[0]], irrep, 'neuron d1, G d1 d2 -> neuron G d2').flatten(0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "ae6c0d25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1)"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "((full_a @ a[[0]].T) > 0.95).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "23fee94d",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_b = einops.einsum(b, irrep, 'neuron d1, G d1 d2 -> neuron G d2').flatten(0, 1)\n",
    "full_c = einops.einsum(c, irrep, 'neuron d1, G d1 d2 -> neuron G d2').flatten(0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "bbe06438",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.cluster import KMeans\n",
    "\n",
    "def cluster(vecs, num_seeds=30, thresh=1, max=1000):\n",
    "    n_clusters = 1\n",
    "    losses = []\n",
    "    while not losses or losses[-1] > thresh:\n",
    "        n_clusters += 1\n",
    "        kmeans = min(\n",
    "            (KMeans(n_clusters=n_clusters, random_state=seed).fit(vecs.numpy())\n",
    "            for seed in range(num_seeds)),\n",
    "            key=lambda k: k.inertia_\n",
    "        )\n",
    "        losses.append(kmeans.inertia_)\n",
    "        if len(losses) > 1 and losses[-2] / losses[-1] > 10:\n",
    "            break\n",
    "        if n_clusters >= max:\n",
    "            break\n",
    "        print(n_clusters, losses[-1])\n",
    "    return kmeans, n_clusters, losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "236ed28d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 14560.603515625\n",
      "3 13309.58984375\n",
      "4 12160.3798828125\n",
      "5 10840.2412109375\n",
      "6 9494.88671875\n",
      "7 8185.908203125\n",
      "8 6932.17333984375\n",
      "9 5789.224609375\n",
      "10 4579.06396484375\n",
      "11 3761.78369140625\n",
      "12 3388.331298828125\n",
      "13 3089.863037109375\n",
      "14 2716.4072265625\n",
      "15 2342.953369140625\n",
      "16 2041.68798828125\n",
      "17 1668.235107421875\n",
      "18 1361.0518798828125\n",
      "19 1045.6927490234375\n",
      "20 718.589599609375\n",
      "21 373.7641296386719\n",
      "2 14560.59375\n",
      "3 13319.4609375\n",
      "4 12154.6455078125\n",
      "5 10840.23828125\n",
      "6 9494.8798828125\n",
      "7 8185.90771484375\n",
      "8 6932.17333984375\n",
      "9 5768.20166015625\n",
      "10 4579.05224609375\n",
      "11 3703.674560546875\n",
      "12 3306.61328125\n",
      "13 2933.22412109375\n",
      "14 2639.77978515625\n",
      "15 2342.935791015625\n",
      "16 1969.4830322265625\n",
      "17 1668.2117919921875\n",
      "18 1419.1082763671875\n",
      "19 1045.6507568359375\n",
      "20 718.5516967773438\n",
      "21 373.72039794921875\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(22, 22)"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b_kmeans, b_clusters, b_losses = cluster(full_b,) #max=10)\n",
    "c_kmeans, c_clusters, c_losses = cluster(full_c,) #max=10)\n",
    "b_labels, c_labels = b_kmeans.predict(b.numpy()), c_kmeans.predict(c.numpy())\n",
    "b_mean, c_mean = b_kmeans.cluster_centers_, c_kmeans.cluster_centers_\n",
    "b_clusters, c_clusters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "6114e6e9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-0.3412],\n",
       "        [ 0.7130],\n",
       "        [-0.0011],\n",
       "        [ 0.3421],\n",
       "        [-0.7128]])"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t.tensor(b_mean[b_parts[0]]) @ a[[0]].T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "39dff0df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0\n",
      "(array([ 0, 24, 57]),)\n",
      "b dot c 0.24999824166297913\n",
      "tensor([[ 0.4053,  0.5087, -0.7594, -0.0142],\n",
      "        [ 0.6521, -0.6041,  0.4516, -0.0773],\n",
      "        [ 0.5770,  0.4066, -0.7076, -0.0323]])\n",
      "\n",
      "0 3\n",
      "(array([50, 87]),)\n",
      "b dot c 0.2499980628490448\n",
      "tensor([[ 0.5512, -0.6386,  0.5324, -0.0698],\n",
      "        [ 0.6673,  0.3376, -0.6625, -0.0429]])\n",
      "\n",
      "0 7\n",
      "(array([37, 78]),)\n",
      "b dot c 0.24999822676181793\n",
      "tensor([[ 0.6634, -0.5994,  0.4411, -0.0782],\n",
      "        [ 0.4534,  0.4830, -0.7488, -0.0197]])\n",
      "\n",
      "0 8\n",
      "(array([61]),)\n",
      "b dot c 0.2499983012676239\n",
      "tensor([[ 0.3542,  0.5337, -0.7679, -0.0078]])\n",
      "\n",
      "0 9\n",
      "(array([34, 68]),)\n",
      "b dot c -0.9999929070472717\n",
      "tensor([[ 0.6558,  0.3469, -0.6692, -0.0419],\n",
      "        [ 0.8246, -0.4968,  0.2564, -0.0872]])\n",
      "\n",
      "1 1\n",
      "(array([31]),)\n",
      "b dot c 0.24999737739562988\n",
      "tensor([[ 0.9517, -0.0792, -0.2850, -0.0820]])\n",
      "\n",
      "1 2\n",
      "(array([28, 46, 60, 70]),)\n",
      "b dot c -0.9999895691871643\n",
      "tensor([[ 0.8358, -0.4862,  0.2395, -0.0878],\n",
      "        [ 0.6471,  0.3540, -0.6740, -0.0409],\n",
      "        [ 0.9539, -0.0896, -0.2741, -0.0829],\n",
      "        [ 0.4096,  0.5063, -0.7587, -0.0154]])\n",
      "\n",
      "1 4\n",
      "(array([53]),)\n",
      "b dot c 0.24999719858169556\n",
      "tensor([[ 0.9176, -0.3785,  0.0807, -0.0906]])\n",
      "\n",
      "1 5\n",
      "(array([ 62, 101]),)\n",
      "b dot c 0.24999749660491943\n",
      "tensor([[ 0.9474, -0.0630, -0.3031, -0.0816],\n",
      "        [ 0.9479, -0.0649, -0.3011, -0.0818]])\n",
      "\n",
      "1 6\n",
      "(array([48]),)\n",
      "b dot c 0.24999743700027466\n",
      "tensor([[ 0.3565,  0.5326, -0.7676, -0.0081]])\n",
      "\n",
      "2 1\n",
      "(array([ 32,  59, 104]),)\n",
      "b dot c 0.24999786913394928\n",
      "tensor([[ 0.6540,  0.3485, -0.6701, -0.0420],\n",
      "        [ 0.8390, -0.4832,  0.2343, -0.0875],\n",
      "        [ 0.4182,  0.5021, -0.7568, -0.0167]])\n",
      "\n",
      "2 2\n",
      "(array([ 36,  49, 103]),)\n",
      "b dot c 0.24999718368053436\n",
      "tensor([[ 0.8341, -0.4878,  0.2423, -0.0872],\n",
      "        [ 0.8342, -0.4878,  0.2422, -0.0872],\n",
      "        [ 0.6385,  0.3606, -0.6788, -0.0399]])\n",
      "\n",
      "2 4\n",
      "(array([ 19,  81,  82, 110]),)\n",
      "b dot c -0.9999892711639404\n",
      "tensor([[ 0.6991, -0.5824,  0.4069, -0.0802],\n",
      "        [ 0.4257,  0.4984, -0.7551, -0.0163],\n",
      "        [ 0.8314, -0.4904,  0.2461, -0.0877],\n",
      "        [ 0.9532, -0.0858, -0.2780, -0.0824]])\n",
      "\n",
      "2 5\n",
      "(array([25, 94]),)\n",
      "b dot c 0.24999722838401794\n",
      "tensor([[ 0.6489,  0.3527, -0.6729, -0.0411],\n",
      "        [ 0.8364, -0.4856,  0.2386, -0.0875]])\n",
      "\n",
      "2 6\n",
      "(array([ 7, 17, 22, 63, 79]),)\n",
      "b dot c 0.2499970644712448\n",
      "tensor([[ 0.3020,  0.5556, -0.7747, -0.0050],\n",
      "        [ 0.8597, -0.4613,  0.2009, -0.0882],\n",
      "        [ 0.8585, -0.4626,  0.2028, -0.0881],\n",
      "        [ 0.8585, -0.4626,  0.2029, -0.0881],\n",
      "        [ 0.8573, -0.4640,  0.2050, -0.0881]])\n",
      "\n",
      "3 1\n",
      "(array([39]),)\n",
      "b dot c -0.9999898672103882\n",
      "tensor([[ 0.7290,  0.2819, -0.6217, -0.0506]])\n",
      "\n",
      "3 2\n",
      "(array([  2, 111]),)\n",
      "b dot c 0.24999739229679108\n",
      "tensor([[ 0.7027, -0.5799,  0.4041, -0.0813],\n",
      "        [ 0.9489, -0.0674, -0.2972, -0.0824]])\n",
      "\n",
      "3 4\n",
      "(array([15, 18, 91]),)\n",
      "b dot c 0.2499978393316269\n",
      "tensor([[ 0.8369, -0.4848,  0.2385, -0.0883],\n",
      "        [ 0.3977,  0.5123, -0.7610, -0.0141],\n",
      "        [ 0.6457,  0.3553, -0.6747, -0.0407]])\n",
      "\n",
      "3 5\n",
      "(array([52, 54]),)\n",
      "b dot c 0.24999724328517914\n",
      "tensor([[ 0.6756, -0.5934,  0.4303, -0.0791],\n",
      "        [ 0.5680,  0.4126, -0.7114, -0.0321]])\n",
      "\n",
      "3 6\n",
      "(array([ 12,  20,  96, 105]),)\n",
      "b dot c 0.24999742209911346\n",
      "tensor([[ 0.6995, -0.5819,  0.4070, -0.0807],\n",
      "        [ 0.4034,  0.5095, -0.7599, -0.0152],\n",
      "        [ 0.6147,  0.3793, -0.6905, -0.0379],\n",
      "        [ 0.6211,  0.3745, -0.6874, -0.0386]])\n",
      "\n",
      "4 1\n",
      "(array([ 5, 35, 51, 64]),)\n",
      "b dot c 0.24999713897705078\n",
      "tensor([[ 0.4031,  0.5098, -0.7599, -0.0140],\n",
      "        [ 0.6324,  0.3659, -0.6817, -0.0385],\n",
      "        [ 0.9595, -0.1194, -0.2409, -0.0842],\n",
      "        [ 0.9600, -0.1229, -0.2370, -0.0844]])\n",
      "\n",
      "4 2\n",
      "(array([ 14, 107]),)\n",
      "b dot c 0.24999740719795227\n",
      "tensor([[ 0.8011, -0.5169,  0.2892, -0.0860],\n",
      "        [ 0.4091,  0.5072, -0.7584, -0.0150]])\n",
      "\n",
      "4 4\n",
      "(array([43]),)\n",
      "b dot c 0.24999724328517914\n",
      "tensor([[ 0.7415,  0.2697, -0.6122, -0.0514]])\n",
      "\n",
      "4 5\n",
      "(array([38, 77, 86]),)\n",
      "b dot c -0.9999895691871643\n",
      "tensor([[ 0.4486,  0.4861, -0.7497, -0.0191],\n",
      "        [ 0.8378, -0.4844,  0.2362, -0.0877],\n",
      "        [ 0.4557,  0.4822, -0.7480, -0.0198]])\n",
      "\n",
      "4 6\n",
      "(array([71, 88]),)\n",
      "b dot c 0.2499978244304657\n",
      "tensor([[ 0.9552, -0.0949, -0.2679, -0.0827],\n",
      "        [ 0.4505,  0.4852, -0.7492, -0.0191]])\n",
      "\n",
      "5 0\n",
      "(array([ 98, 100]),)\n",
      "b dot c 0.24999871850013733\n",
      "tensor([[ 0.8395, -0.4827,  0.2336, -0.0876],\n",
      "        [ 0.4371,  0.4922, -0.7526, -0.0187]])\n",
      "\n",
      "5 3\n",
      "(array([10]),)\n",
      "b dot c -0.9999927878379822\n",
      "tensor([[ 0.9558, -0.0980, -0.2646, -0.0830]])\n",
      "\n",
      "5 7\n",
      "(array([ 4,  8, 27, 30, 76]),)\n",
      "b dot c 0.24999810755252838\n",
      "tensor([[ 0.4415,  0.4897, -0.7516, -0.0188],\n",
      "        [ 0.6900, -0.5870,  0.4161, -0.0790],\n",
      "        [ 0.9508, -0.0755, -0.2892, -0.0819],\n",
      "        [ 0.6950, -0.5845,  0.4112, -0.0793],\n",
      "        [ 0.8340, -0.4879,  0.2423, -0.0873]])\n",
      "\n",
      "5 8\n",
      "(array([83]),)\n",
      "b dot c 0.24999788403511047\n",
      "tensor([[ 0.7708,  0.2386, -0.5881, -0.0555]])\n",
      "\n",
      "5 9\n",
      "(array([23, 80]),)\n",
      "b dot c 0.249998077750206\n",
      "tensor([[ 0.8274, -0.4941,  0.2524, -0.0869],\n",
      "        [ 0.6430,  0.3570, -0.6764, -0.0404]])\n",
      "\n",
      "6 1\n",
      "(array([16]),)\n",
      "b dot c 0.2499975860118866\n",
      "tensor([[ 0.9452, -0.0542, -0.3118, -0.0803]])\n",
      "\n",
      "6 2\n",
      "(array([65, 85, 92]),)\n",
      "b dot c 0.24999743700027466\n",
      "tensor([[ 0.9615, -0.1336, -0.2248, -0.0840],\n",
      "        [ 0.3006,  0.5571, -0.7741, -0.0037],\n",
      "        [ 0.8605, -0.4605,  0.1995, -0.0880]])\n",
      "\n",
      "6 4\n",
      "(array([ 6, 21, 42]),)\n",
      "b dot c 0.2499968409538269\n",
      "tensor([[ 0.4249,  0.4985, -0.7554, -0.0171],\n",
      "        [ 0.8330, -0.4888,  0.2441, -0.0870],\n",
      "        [ 0.9487, -0.0672, -0.2980, -0.0812]])\n",
      "\n",
      "6 5\n",
      "(array([13, 44]),)\n",
      "b dot c 0.2499978095293045\n",
      "tensor([[ 0.6649,  0.3400, -0.6637, -0.0418],\n",
      "        [ 0.8402, -0.4817,  0.2335, -0.0870]])\n",
      "\n",
      "6 6\n",
      "(array([73, 90]),)\n",
      "b dot c -0.9999896883964539\n",
      "tensor([[ 0.9569, -0.1029, -0.2584, -0.0835],\n",
      "        [ 0.4392,  0.4909, -0.7522, -0.0186]])\n",
      "\n",
      "7 0\n",
      "(array([26]),)\n",
      "b dot c 0.2499983310699463\n",
      "tensor([[ 0.6575, -0.6019,  0.4467, -0.0770]])\n",
      "\n",
      "7 3\n",
      "(array([ 9, 40]),)\n",
      "b dot c 0.2499978244304657\n",
      "tensor([[ 0.6683,  0.3367, -0.6619, -0.0432],\n",
      "        [ 0.8239, -0.4973,  0.2576, -0.0866]])\n",
      "\n",
      "7 7\n",
      "(array([47, 95]),)\n",
      "b dot c 0.24999867379665375\n",
      "tensor([[ 0.8400, -0.4819,  0.2337, -0.0870],\n",
      "        [ 0.4524,  0.4840, -0.7488, -0.0190]])\n",
      "\n",
      "7 8\n",
      "(array([74, 89, 99]),)\n",
      "b dot c -0.9999931454658508\n",
      "tensor([[ 0.4430,  0.4889, -0.7513, -0.0190],\n",
      "        [ 0.4404,  0.4903, -0.7519, -0.0187],\n",
      "        [ 0.7190, -0.5713,  0.3874, -0.0808]])\n",
      "\n",
      "7 9\n",
      "(array([1]),)\n",
      "b dot c 0.2499983310699463\n",
      "tensor([[ 0.7762,  0.2338, -0.5830, -0.0549]])\n",
      "\n",
      "8 0\n",
      "(array([ 84,  97, 106, 109]),)\n",
      "b dot c 0.24999801814556122\n",
      "tensor([[ 0.5971,  0.3923, -0.6988, -0.0346],\n",
      "        [ 0.5946,  0.3942, -0.6999, -0.0343],\n",
      "        [ 0.7964, -0.5205,  0.2956, -0.0859],\n",
      "        [ 0.5952,  0.3937, -0.6997, -0.0344]])\n",
      "\n",
      "8 3\n",
      "(array([58, 69]),)\n",
      "b dot c 0.24999816715717316\n",
      "tensor([[ 0.8409, -0.4812,  0.2314, -0.0879],\n",
      "        [ 0.3087,  0.5534, -0.7736, -0.0048]])\n",
      "\n",
      "8 7\n",
      "(array([ 3, 55, 56]),)\n",
      "b dot c -0.999993085861206\n",
      "tensor([[ 0.7033, -0.5804,  0.4026, -0.0802],\n",
      "        [ 0.9489, -0.0681, -0.2973, -0.0814],\n",
      "        [ 0.4477,  0.4866, -0.7499, -0.0190]])\n",
      "\n",
      "8 8\n",
      "(array([67, 75]),)\n",
      "b dot c 0.24999868869781494\n",
      "tensor([[ 0.7195, -0.5716,  0.3860, -0.0811],\n",
      "        [ 0.4491,  0.4860, -0.7495, -0.0190]])\n",
      "\n",
      "8 9\n",
      "(array([93]),)\n",
      "b dot c 0.2499983012676239\n",
      "tensor([[ 0.9536, -0.0873, -0.2761, -0.0826]])\n",
      "\n",
      "9 0\n",
      "(array([11, 33]),)\n",
      "b dot c -0.9999933838844299\n",
      "tensor([[ 0.8424, -0.4793,  0.2298, -0.0883],\n",
      "        [ 0.2854,  0.5625, -0.7759, -0.0030]])\n",
      "\n",
      "9 3\n",
      "(array([45, 66]),)\n",
      "b dot c 0.2499987930059433\n",
      "tensor([[ 0.8341, -0.4875,  0.2428, -0.0881],\n",
      "        [ 0.6434,  0.3572, -0.6759, -0.0405]])\n",
      "\n",
      "9 7\n",
      "(array([72]),)\n",
      "b dot c 0.24999800324440002\n",
      "tensor([[ 0.9624, -0.1425, -0.2145, -0.0861]])\n",
      "\n",
      "9 8\n",
      "(array([108]),)\n",
      "b dot c 0.24999842047691345\n",
      "tensor([[ 0.9566, -0.1026, -0.2593, -0.0847]])\n",
      "\n",
      "9 9\n",
      "(array([ 29,  41, 102]),)\n",
      "b dot c 0.24999822676181793\n",
      "tensor([[ 0.6460, -0.6061,  0.4575, -0.0776],\n",
      "        [ 0.4334,  0.4938, -0.7537, -0.0175],\n",
      "        [ 0.5841,  0.4014, -0.7047, -0.0337]])\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for i, j in product(range(b_clusters), range(c_clusters)):\n",
    "    ij_mask = (b_labels == i) & (c_labels == j)\n",
    "    if not ij_mask.any():\n",
    "        continue\n",
    "    print(i, j)\n",
    "    print(ij_mask.nonzero())\n",
    "    print('b dot c', np.dot(b_mean[i], c_mean[j]).item())\n",
    "    print(a[ij_mask])\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "c55bb1dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.1261, 0.0956, 0.0662, 0.0646, 0.0916, 0.0878, 0.1284, 0.1053, 0.1185,\n",
       "        0.0830, 0.1767, 0.1664, 0.1590, 0.0704, 0.1717, 0.0849, 0.1483, 0.1508,\n",
       "        0.1938, 0.1337, 0.0706, 0.1276, 0.1416, 0.1914, 0.1312, 0.1331, 0.1519,\n",
       "        0.1260, 0.1704, 0.1467, 0.1413, 0.0761, 0.1739, 0.1585, 0.1111, 0.1607,\n",
       "        0.1308, 0.1436, 0.1185, 0.0805, 0.1537, 0.1249, 0.0964, 0.1627, 0.1388,\n",
       "        0.1550, 0.1431, 0.1497, 0.1547, 0.1461, 0.1437, 0.1036, 0.1465, 0.1027,\n",
       "        0.0971, 0.0534, 0.1635, 0.0815, 0.0636, 0.1566, 0.1530, 0.1740, 0.1450,\n",
       "        0.1588, 0.1914, 0.1432, 0.1332, 0.1449, 0.0419, 0.1260, 0.1226, 0.1213,\n",
       "        0.1692, 0.1247, 0.1619, 0.0862, 0.0802, 0.1435, 0.1507, 0.0751, 0.1889,\n",
       "        0.1447, 0.1050, 0.1386, 0.1027, 0.0877, 0.1192, 0.0730, 0.1753, 0.0787,\n",
       "        0.0890, 0.0903, 0.1477, 0.1955, 0.1762, 0.1480, 0.0766, 0.1095, 0.0846,\n",
       "        0.1540, 0.0428, 0.0925, 0.1606, 0.0724, 0.1390, 0.1123, 0.1173, 0.0768,\n",
       "        0.1223, 0.1621, 0.0854, 0.1776, 0.1641])"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bc_pair = t.stack([\n",
    "    t.tensor(b_mean[i] + c_mean[j]) for i, j in product(b_parts[0], c_parts[0])\n",
    "    if np.abs(np.dot(b_mean[i], c_mean[j])) < 0.5\n",
    "], dim=0)\n",
    "bc_pair = bc_pair / bc_pair.norm(dim=1).unsqueeze(1)\n",
    "(a @ (bc_pair).T).abs().min(dim=1).values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "4c5756fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2.2361, 2.2361, 2.2361, 2.2361])"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t.svd(bc_pair)[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "174bf3cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2.5197, 2.5025, 2.4898, 2.4878])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t.svd(bc_pair)[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "4e0de51c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([121, 25])"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(a @ (bc_pair).T).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "id": "cf6987d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "b=0\n",
      "c=[]\n",
      "\n",
      "b=1\n",
      "c=[]\n",
      "\n",
      "b=2\n",
      "c=[1, 1]\n",
      "\n",
      "b=3\n",
      "c=[]\n",
      "\n",
      "b=4\n",
      "c=[]\n",
      "\n",
      "b=5\n",
      "c=[]\n",
      "\n",
      "b=6\n",
      "c=[8, 8, 8, 8]\n",
      "\n",
      "b=7\n",
      "c=[]\n",
      "\n",
      "b=8\n",
      "c=[]\n",
      "\n",
      "b=9\n",
      "c=[]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for i in range(b_clusters):\n",
    "    print(f'b={i}')\n",
    "    print(f'c={c_labels[b_labels==i].tolist()}')\n",
    "    # print(f'coef={(coef[b_labels==i]*100).round().int().tolist()}')\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "ff84fdca-0025-45de-ba42-fa38cba0e789",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "b=0, c=[0, 6, 7, 8]\n",
      "b=1, c=[1, 2, 3, 4, 5]\n",
      "b=2, c=[1, 2, 3, 4, 5]\n",
      "b=3, c=[1, 2, 3, 4, 5]\n",
      "b=4, c=[1, 2, 3, 4, 5]\n",
      "b=5, c=[1, 2, 3, 4, 5]\n",
      "b=6, c=[0, 6, 7, 9]\n",
      "b=7, c=[0, 6, 7, 8, 9]\n",
      "b=8, c=[0, 6, 7, 8]\n",
      "b=9, c=[0, 6, 7, 8, 9]\n",
      "[[0, 6, 7, 8, 9], [1, 2, 3, 4, 5]]\n",
      "[[0, 6, 7, 8, 9], [1, 2, 3, 4, 5]]\n"
     ]
    }
   ],
   "source": [
    "b_parts = []\n",
    "c_parts = []\n",
    "for i in range(b_clusters):\n",
    "    c_set = set(c_labels[b_labels == i].tolist())\n",
    "    if not c_set:\n",
    "        continue\n",
    "    done = False\n",
    "    for j in range(len(c_parts)):\n",
    "        if len(c_set & c_parts[j]) > 0:\n",
    "            c_parts[j] = c_set.union(c_parts[j])\n",
    "            b_parts[j].add(i)\n",
    "            done = True\n",
    "            break\n",
    "    if not done:\n",
    "        c_parts.append(c_set)\n",
    "        b_parts.append({i})\n",
    "    print(f'b={i}, c={sorted(c_set)}')\n",
    "\n",
    "# for b_part1, b_part2 in product(b_parts, repeat=2):\n",
    "#     assert b_part1==b_part2 or not b_part1 & b_part2\n",
    "# for c_part1, c_part2 in product(c_parts, repeat=2):\n",
    "#     assert c_part1==c_part2 or not c_part1 & c_part2\n",
    "b_parts = list(map(sorted, map(list, b_parts)))\n",
    "c_parts = list(map(sorted, map(list, c_parts)))\n",
    "print(b_parts)\n",
    "print(c_parts)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "3f3ddb92",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check that irrep is G-action on each partition of b's clusters\n",
    "for b_part in b_parts:\n",
    "    T = einops.einsum(b_mean[b_part], irrep, b_mean[b_part], 'm1 d1, G d1 d2, m2 d2 -> G m1 m2')\n",
    "    T = (T > 0.95).astype(float)\n",
    "    assert (T.sum(axis=1) == 1).all() and (T.sum(axis=2) == 1).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "4ad72b20",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check that irrep is G-action on each partition of c's clusters\n",
    "for c_part in c_parts:\n",
    "    T = einops.einsum(c_mean[c_part], irrep, c_mean[c_part], 'm1 d1, G d1 d2, m2 d2 -> G m1 m2')\n",
    "    T = (T > 0.95).astype(float)\n",
    "    assert (T.sum(axis=1) == 1).all() and (T.sum(axis=2) == 1).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "62c5a49e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check that {b_i} = {-c_i} over all points\n",
    "S = b_mean @ -c_mean.T\n",
    "S = (S > 0.95).astype(float)\n",
    "assert (S.sum(axis=0) == 1).all() and (S.sum(axis=1) == 1).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "31de1e23",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check that {b_i} = {-c_i} within each partition\n",
    "for b_part, c_part in zip(b_parts, c_parts):\n",
    "    # S = t.concat([b_mean[b_part], -b_mean[b_part]]) @ t.concat([-c_mean[c_part], c_mean[c_part]]).T\n",
    "    S = b_mean[b_part] @ -c_mean[c_part].T\n",
    "    S = (S > 0.95).astype(float)\n",
    "    assert (S.sum(axis=0) == 1).all() and (S.sum(axis=1) == 1).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "f5b90738",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check that there are two partitions, and that they are antipodal\n",
    "assert len(b_parts) == 2\n",
    "T = b_mean[b_parts[0]] @ -b_mean[b_parts[1]].T\n",
    "T = (T > 1 - 1e-2).astype(float)\n",
    "assert (T.sum(axis=0) == 1).all() and (T.sum(axis=1) == 1).all()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "cd25d113",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "size=14.581692695617676, variance=0.041072290390729904\n",
      "[2.9271507263183594, 3.0301852226257324, 2.947442054748535, 3.7306771278381348, 3.6133885383605957, 2.9927361011505127, 3.7859277725219727, 2.257120370864868, 2.655984401702881, 3.1560397148132324, 3.634443521499634, 2.2718491554260254, 2.205812692642212, 3.7508420944213867, 2.9436421394348145, 2.0772361755371094, 3.068580150604248, 2.210176467895508, 2.24330472946167, 1.8649656772613525, 3.2062294483184814, 3.5749683380126953, 2.653846025466919, 2.479753017425537, 2.113205909729004]\n",
      "size=13.402325630187988, variance=0.05738019198179245\n",
      "[2.6255760192871094, 2.7415590286254883, 1.6819978952407837, 1.9438964128494263, 2.556933641433716, 1.918022871017456, 3.153902530670166, 1.9036931991577148, 2.5628561973571777, 3.305253744125366, 3.5791714191436768, 3.5385055541992188, 1.5172001123428345, 3.618938446044922, 2.810096502304077, 2.682288646697998, 2.0427472591400146, 3.1616780757904053, 2.6220152378082275, 1.554329752922058, 2.333005666732788, 2.927609443664551, 3.239436388015747, 3.165828227996826, 1.8741176128387451]\n"
     ]
    }
   ],
   "source": [
    "# check that coefs are uniform over {b_i}x{c_i}\n",
    "for b_part, c_part in zip(b_parts, c_parts):\n",
    "    coef_sum = t.tensor([\n",
    "        coef[(b_labels == i) & (c_labels == j)].sum().item()\n",
    "        for i, j in product(b_part, c_part)\n",
    "    ])\n",
    "    print(f'size={coef_sum.norm()}, variance={(coef_sum - coef_sum.mean()).norm()**2/coef_sum.norm()**2}')\n",
    "    print(coef_sum.tolist())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "3b44779a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2.6256, 1.6820, 1.9439, 2.5569, 2.7416, 1.9180, 1.9037, 2.5629, 3.3053,\n",
       "        3.1539, 2.6823, 3.1617, 2.6220, 1.5543, 2.0427, 2.3330, 3.2394, 3.1658,\n",
       "        1.8741, 2.9276, 3.5792, 1.5172, 3.6189, 2.8101, 3.5385])"
      ]
     },
     "execution_count": 185,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "coef_sum"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c00edddf-6ece-4254-8daa-2edcda98ed63",
   "metadata": {},
   "source": [
    "### Activations are clustered"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "652e3ada-3f49-4b25-b0be-f151d3643db8",
   "metadata": {},
   "outputs": [],
   "source": [
    "embedding_left = model.embedding_left.squeeze(0)\n",
    "embedding_right = model.embedding_right.squeeze(0)\n",
    "linear = model.linear.squeeze(0)\n",
    "unembedding = model.unembedding.squeeze(0).T\n",
    "# There's a degree of freedom with embedding/unembedding norm.\n",
    "# Rescale so that each unembedding column is norm 1\n",
    "u_norm = unembedding.norm(dim=0)\n",
    "unembedding = unembedding / u_norm\n",
    "linear = linear * u_norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "983e5927-3ff9-491d-bc03-60ad4c265c9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = len(group)\n",
    "inputs = t.tensor(list(product(range(N), repeat=2)), device=device)\n",
    "l_in, r_in = inputs[..., 0], inputs[..., 1]\n",
    "l_onehot = F.one_hot(l_in, num_classes=N).float()\n",
    "r_onehot = F.one_hot(r_in, num_classes=N).float()\n",
    "l_embed = einops.einsum(l_onehot, embedding_left, 'batch group, group embed -> batch embed')\n",
    "r_embed = einops.einsum(r_onehot, embedding_right, 'batch group, group embed -> batch embed')\n",
    "l_act = einops.einsum(l_embed, linear, 'batch embed, embed hid -> batch hid')\n",
    "r_act = einops.einsum(r_embed, linear, 'batch embed, embed hid -> batch hid')\n",
    "l_act = l_act[:, irrep_idxs]\n",
    "r_act = r_act[:, irrep_idxs]\n",
    "pre_act = l_act + r_act\n",
    "act = t.maximum(t.zeros_like(l_act), l_act + r_act)\n",
    "lin_logits = einops.einsum(pre_act, unembedding[:, irrep_idxs], 'batch hid, group hid-> batch group')\n",
    "logits = einops.einsum(act, unembedding[:, irrep_idxs], 'batch hid, group hid-> batch group')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "445e30de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9876, grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 0, 24, 57 are same (i, j)\n",
    "(act[:,0] - act[:,24]).norm()**2 / act[:,0].norm()**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "e04616ea",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([14400, 74])"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "act.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "3d909e8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(5932.1118, grad_fn=<LinalgVectorNormBackward0>),\n",
       " tensor(459.0746, grad_fn=<LinalgVectorNormBackward0>))"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logits.norm(), lin_logits.norm()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "dbb533c7-f398-4029-a40d-7982277c0e5b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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7dJLL73UsZM2QCjP66X8fr/S09OVmJiopUuXXv/EgQ7w/PPPa+PGjdq6dasiIyM7ezrGOnPmjGbMmKHf/va36tevX2dPx3hcgelmFixYoCeeeOKqY+688055PJ5v3GTW0tKihoaGK741tGvXLh07dkzR0dEB6ydPnqyxY8dqz5491zHzri2U57XdmTNnNGHCBPXt21dbt25Vz549r3faxunXr5/Cw8NVV1cXsL6uru6K58/j8QQ1/mZ0Lee13cqVK/X8889r586dGj58eCinaZxgz+uxY8d04sQJPf744/a6trY2Sf//Sm11dbXuuuuu0E66O+nsm3DQOdpvNj106JC9bvv27Ve92fTUqVNWZWVlwCLJWrNmjfXZZ5/dqKl3addyXi3LshobG60xY8ZYP/7xj61z587diKl2Wffff7+VlZVlP25tbbW+973vXfUm3sceeyxgndfr5Sberwn2vFqWZf3617+2XC6XVVpaeiOmaKRgzuv58+e/8T104sSJ1sMPP2xVVlZaTU1NN3LqxiNgbmITJkywRo4caZWVlVn79++3/uZv/saaOnWqvf3zzz+3Bg0aZJWVlV1xH+JTSN8Q7HltbGy0kpKSrGHDhlmffvqpderUKXtpaWnprMPoNBs3brScTqeVn59vHT161Jo9e7YVHR1t+Xw+y7Isa8aMGdZzzz1nj3///fetiIgIa+XKldbHH39sLVmyxOrZs6dVWVnZWYfQJQV7Xp9//nnL4XBY//mf/xnwd/LMmTOddQhdUrDn9ev4FNK1I2BuYl9++aU1depUq0+fPpbL5bKefPLJgG9Ox48ftyRZu3fvvuI+CJhvCva87t6925J02eX48eOdcxCd7JVXXrEGDBhgORwO6/7777cOHDhgb/vxj39szZo1K2D85s2brXvuucdyOBzW0KFDrcLCwhs8YzMEc14TEhIu+3dyyZIlN37iXVywf18vRcBcuzDLsqwb/bYVAADA9eBTSAAAwDgEDAAAMA4BAwAAjEPAAAAA4xAwAADAOAQMAAAwDgEDAACMQ8AAAADjEDAAAMA4BAwAADAOAQMAAIzz/wCatN2a9P+FGQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjAAAAGfCAYAAABBU+jJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAApMElEQVR4nO3dfXDU5b3//1cI7ALCJgZINjmGGKQSQO6EGrZVipKTG6k3R/o9ohTQUig02MGgYjoUKJxpLKh4hzDWIu0U5GamWgsIhCCgEILkkAIBc4DGCR7Z0ILJEoRwk+v3x/nlU1ZCMCFLcsHzMXMN2c/13muv69qQvGb388mGGWOMAAAALNKquScAAADQUAQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGCd1g0pXrhwoRYuXKjPP/9cktS7d2/NmDFDGRkZkqQzZ85o6tSpWr58uaqrq5WWlqY333xTMTExzhhlZWWaNGmSPvroI3Xo0EFjx45VTk6OWrf+11Q2b96srKwsFRcXKz4+XtOnT9cTTzzRoIXV1NToyy+/VMeOHRUWFtag+wIAgOZhjNHJkycVFxenVq3qeZ3FNMAHH3xg1qxZY/7nf/7HlJSUmF/+8pemTZs2Zt++fcYYYyZOnGji4+NNXl6e2bVrlxk8eLD53ve+59z//Pnz5o477jApKSlm9+7dZu3ataZz584mOzvbqfn73/9u2rdvb7Kyssz+/fvN66+/bsLDw826desaMlVz5MgRI4lGo9FoNJqF7ciRI/X+ng8z5uo+zDEqKkrz5s3Tj370I3Xp0kXLli3Tj370I0nSZ599pp49eyo/P1+DBw/Whx9+qB/+8If68ssvnVdlFi1apGnTpukf//iHXC6Xpk2bpjVr1mjfvn3OY4wcOVIVFRVat27dt55XZWWlIiMjdeTIEXk8nqtZIgAAuEYCgYDi4+NVUVGhiIiIy9Y16C2ki124cEGrVq3SqVOn5PP5VFhYqHPnziklJcWpSUpKUteuXZ0Ak5+frz59+gS9pZSWlqZJkyapuLhYAwYMUH5+ftAYtTVTpkypdz7V1dWqrq52bp88eVKS5PF4CDAAAFjmSqd/NPgk3r1796pDhw5yu92aOHGi3nvvPfXq1Ut+v18ul0uRkZFB9TExMfL7/ZIkv98fFF5q+2v76qsJBAI6ffr0ZeeVk5OjiIgIp8XHxzd0aQAAwBINDjA9evRQUVGRCgoKNGnSJI0dO1b79+8PxdwaJDs7W5WVlU47cuRIc08JAACESIPfQnK5XOrevbskaeDAgfr000/16quv6tFHH9XZs2dVUVER9CpMeXm5vF6vJMnr9Wrnzp1B45WXlzt9tf/WHru4xuPxqF27dpedl9vtltvtbuhyAACAha7678DU1NSourpaAwcOVJs2bZSXl+f0lZSUqKysTD6fT5Lk8/m0d+9eHTt2zKnJzc2Vx+NRr169nJqLx6itqR0DAACgQa/AZGdnKyMjQ127dtXJkye1bNkybd68WevXr1dERITGjRunrKwsRUVFyePx6KmnnpLP59PgwYMlSampqerVq5dGjx6tuXPnyu/3a/r06crMzHRePZk4caLeeOMNPffcc/rJT36iTZs2aeXKlVqzZk3Trx4AAFipQQHm2LFjGjNmjI4ePaqIiAj17dtX69ev17//+79LkubPn69WrVppxIgRQX/IrlZ4eLhWr16tSZMmyefz6aabbtLYsWM1e/ZspyYxMVFr1qzR008/rVdffVW33HKL3n77baWlpTXRkgEAgO2u+u/AtFSBQEARERGqrKzkMmoAACzxbX9/81lIAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrNPizkCAtKyir8/htZauueuzkxKhLDw568qrHRbCLn8OmeN4u5jyHPG+w2a53JEkFpSeadNjDXf+f8/XjyV2bdGzIed4u1hTP4cXPW63mfv54BQYAAFiHAAMAAKxDgAEAANYhwAAAAOsQYAAAgHUIMAAAwDoEGAAAYB0CDAAAsA4BBgAAWIcAAwAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGAdAgwAALAOAQYAAFiHAAMAAKxDgAEAANYhwAAAAOsQYAAAgHUIMAAAwDoEGAAAYB0CDAAAsA4BBgAAWIcAAwAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACs06AAk5OTo+9+97vq2LGjoqOj9fDDD6ukpCSoZujQoQoLCwtqEydODKopKyvT8OHD1b59e0VHR+vZZ5/V+fPng2o2b96sO++8U263W927d9eSJUsat0IAAHDdaVCA2bJlizIzM7Vjxw7l5ubq3LlzSk1N1alTp4Lqxo8fr6NHjzpt7ty5Tt+FCxc0fPhwnT17Vtu3b9cf/vAHLVmyRDNmzHBqSktLNXz4cN17770qKirSlClT9NOf/lTr16+/yuUCAIDrQeuGFK9bty7o9pIlSxQdHa3CwkINGTLEOd6+fXt5vd46x9iwYYP279+vjRs3KiYmRv3799ecOXM0bdo0zZo1Sy6XS4sWLVJiYqJeeuklSVLPnj31ySefaP78+UpLS2voGgEAwHXmqs6BqayslCRFRUUFHV+6dKk6d+6sO+64Q9nZ2fr666+dvvz8fPXp00cxMTHOsbS0NAUCARUXFzs1KSkpQWOmpaUpPz//snOprq5WIBAIagAA4PrUoFdgLlZTU6MpU6bo+9//vu644w7n+OOPP66EhATFxcVpz549mjZtmkpKSvTnP/9ZkuT3+4PCiyTntt/vr7cmEAjo9OnTateu3SXzycnJ0a9//evGLgcAAFik0QEmMzNT+/bt0yeffBJ0fMKECc7Xffr0UWxsrIYNG6bDhw/rtttua/xMryA7O1tZWVnO7UAgoPj4+JA9HgAAaD6Negtp8uTJWr16tT766CPdcsst9dYmJydLkg4dOiRJ8nq9Ki8vD6qpvV173szlajweT52vvkiS2+2Wx+MJagAA4PrUoABjjNHkyZP13nvvadOmTUpMTLzifYqKiiRJsbGxkiSfz6e9e/fq2LFjTk1ubq48Ho969erl1OTl5QWNk5ubK5/P15DpAgCA61SDAkxmZqb+9Kc/admyZerYsaP8fr/8fr9Onz4tSTp8+LDmzJmjwsJCff755/rggw80ZswYDRkyRH379pUkpaamqlevXho9erT+9re/af369Zo+fboyMzPldrslSRMnTtTf//53Pffcc/rss8/05ptvauXKlXr66aebePkAAMBGDQowCxcuVGVlpYYOHarY2FinrVixQpLkcrm0ceNGpaamKikpSVOnTtWIESP017/+1RkjPDxcq1evVnh4uHw+n3784x9rzJgxmj17tlOTmJioNWvWKDc3V/369dNLL72kt99+m0uoAQCApAaexGuMqbc/Pj5eW7ZsueI4CQkJWrt2bb01Q4cO1e7duxsy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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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ABqLRhlgXC6X+vTpo9zcXGffmTNnlJubK5/PdwVnBgAAGoNG+yukzMxMpaen65ZbblHfvn31m9/8RhUVFc5VSY2J2+3W9OnTz/kV1tWA3ux1NfdHb3aiN3s1xv7CjLnYdUpXzosvvqi5c+fK7/erV69eev7555WUlHSlpwUAAK6wRh1gAAAAatIoz4EBAAC4EAIMAACwDgEGAABYhwADAACsQ4C5BP/xH/+hW2+9VS1btrzkv+5rjNG0adPUpk0btWjRQsnJyfr000+Dao4cOaIRI0bI4/EoMjJSo0ePVnl5eT10cH6hzuHzzz9XWFhYjduqVaucuprGV6xY0RAtBanNczxw4MBz5j5u3LigmpKSEqWlpally5aKiYnR5MmTVVVVVZ+tnCPU3o4cOaJHH31UnTp1UosWLdS2bVv9/Oc/dz74tNqVWLsFCxboBz/4gZo3b66kpCRt3779gvWrVq1S586d1bx5cyUmJmrt2rVB45fy+msoofT2+9//XrfffruuvfZaXXvttUpOTj6n/uGHHz5nfQYPHlzfbZxXKP1lZ2efM/fmzZsH1di6djV93wgLC1NaWppT01jWbsuWLbrnnnsUFxensLAwvfHGGxe9z+bNm3XzzTfL7XarY8eOys7OPqcm1NfxZbvcD178Ppg2bZp59tlnTWZmpomIiLik+zz11FMmIiLCvPHGG+bjjz829957r2nXrp05ceKEUzN48GDTs2dPs3XrVvPee++Zjh07moceeqieuqhZqHOoqqoyX331VdD25JNPmlatWpljx445dZLM0qVLg+rO7r2h1OY5HjBggBkzZkzQ3MvKypzxqqoq0717d5OcnGx27txp1q5da6Kjo01WVlZ9txMk1N52795tHnjgAfPWW2+Z/fv3m9zcXHPjjTeaoUOHBtU19NqtWLHCuFwus2TJElNYWGjGjBljIiMjTWlpaY31H3zwgQkPDzdz5swxe/fuNVOnTjXNmjUzu3fvdmou5fXXEELtbfjw4WbBggVm586dZt++febhhx82ERER5osvvnBq0tPTzeDBg4PW58iRIw3VUpBQ+1u6dKnxeDxBc/f7/UE1tq7d4cOHg/ras2ePCQ8PN0uXLnVqGsvarV271vz7v/+7ee2114ykcz44+bs+++wz07JlS5OZmWn27t1rXnjhBRMeHm7WrVvn1IT6fNUFAkwI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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjAAAAGfCAYAAABBU+jJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAmN0lEQVR4nO3df1DU953H8Reiu0J0F4myCxekJE5V4q+UJLj54WjlWAlN48Vmzsaqaa2eHmRG8Yyl56k17dHDJjYxRJtJI+mcVuNMTRPxUMQo+YGaUKmKkUtSLaS6cI2BVaKA8r0/OnybbdR0FQIf8nzMfKfu9/ve73726488u+xChGVZlgAAAAzSp7sXAAAAEC4CBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABinbzjD69at07p163Ty5ElJ0q233qrly5crMzNTknThwgUtXrxYmzdvVktLi/x+v5599ll5PB77HLW1tVqwYIFee+01DRgwQLNnz1Z+fr769v3rUvbu3avc3FxVV1crMTFRy5Yt0yOPPBLWE2tvb9epU6c0cOBARUREhHVfAADQPSzL0tmzZ5WQkKA+fa7yOosVhldeecUqLi62/vd//9eqqamxfvjDH1r9+vWzjh49almWZc2fP99KTEy0ysrKrHfeeccaP368ddddd9n3v3jxojVq1CgrPT3dOnTokLVjxw5r8ODBVl5enj3zhz/8wYqOjrZyc3OtY8eOWWvXrrUiIyOtkpKScJZq1dXVWZLY2NjY2NjYDNzq6uqu+t/5CMu6vh/mGBsbq9WrV+tb3/qWhgwZok2bNulb3/qWJOn48eMaOXKkKioqNH78eP3P//yPvvGNb+jUqVP2qzLr16/X0qVL9X//939yOBxaunSpiouLdfToUfsxpk+frsbGRpWUlPzd62pqalJMTIzq6urkcrmu5ykCAIAvSDAYVGJiohobG+V2u684F9aXkD7t0qVL2rp1q5qbm+Xz+VRZWam2tjalp6fbMyNGjNDQoUPtgKmoqNDo0aNDvqTk9/u1YMECVVdX67bbblNFRUXIOTpmFi5ceNX1tLS0qKWlxb599uxZSZLL5SJgAAAwzOe9/SPsN/EeOXJEAwYMkNPp1Pz587Vt2zalpKQoEAjI4XAoJiYmZN7j8SgQCEiSAoFASLx0HO84drWZYDCo8+fPX3Fd+fn5crvd9paYmBjuUwMAAIYIO2CGDx+uqqoqHThwQAsWLNDs2bN17NixrlhbWPLy8tTU1GRvdXV13b0kAADQRcL+EpLD4dCwYcMkSampqXr77bf11FNP6Z//+Z/V2tqqxsbGkFdh6uvr5fV6JUler1cHDx4MOV99fb19rON/O/Z9esblcikqKuqK63I6nXI6neE+HQAAYKDr/j4w7e3tamlpUWpqqvr166eysjL7WE1NjWpra+Xz+SRJPp9PR44cUUNDgz1TWloql8ullJQUe+bT5+iY6TgHAABAWK/A5OXlKTMzU0OHDtXZs2e1adMm7d27Vzt37pTb7dacOXOUm5ur2NhYuVwuPfroo/L5fBo/frwkKSMjQykpKZo5c6YKCgoUCAS0bNkyZWdn26+ezJ8/X88884wee+wxfe9739OePXv00ksvqbi4uPOfPQAAMFJYAdPQ0KBZs2bp9OnTcrvdGjNmjHbu3Kl//Md/lCStWbNGffr00bRp00K+kV2HyMhIbd++XQsWLJDP59MNN9yg2bNna9WqVfZMcnKyiouLtWjRIj311FO66aab9Pzzz8vv93fSUwYAAKa77u8D01MFg0G53W41NTXxMWoAAAzx9/73m5+FBAAAjEPAAAAA4xAwAADAOAQMAAAwDgEDAACMQ8AAAADjEDAAAMA4Yf8sJEibDtTqltqtXXLutORY6fbvdsm58Vdd+nv40OIuOS/+xjsbuu7c/B20Hdj6RJedm78rX4yu+j3s7t8/XoEBAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMbp290LAIBrceDEmS45b1pybJecF0Dn4hUYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAccIKmPz8fN1xxx0aOHCg4uLiNHXqVNXU1ITMTJw4URERESHb/PnzQ2Zqa2uVlZWl6OhoxcXFacmSJbp48WLIzN69e/W1r31NTqdTw4YNU1FR0bU9QwAA0OuEFTD79u1Tdna29u/fr9LSUrW1tSkjI0PNzc0hc3PnztXp06ftraCgwD526dIlZWVlqbW1VW+99ZZefPFFFRUVafny5fbMiRMnlJWVpUmTJqmqqkoLFy7U97//fe3cufM6ny4AAOgN+oYzXFJSEnK7qKhIcXFxqqys1IQJE+z90dHR8nq9lz3Hrl27dOzYMe3evVsej0fjxo3T448/rqVLl2rlypVyOBxav369kpOT9cQTT0iSRo4cqTfeeENr1qyR3+8P9zkCAIBe5rreA9PU1CRJio2NDdm/ceNGDR48WKNGjVJeXp4++eQT+1hFRYVGjx4tj8dj7/P7/QoGg6qurrZn0tPTQ87p9/tVUVFxxbW0tLQoGAyGbAAAoHcK6xWYT2tvb9fChQt19913a9SoUfb+hx9+WElJSUpISNDhw4e1dOlS1dTU6De/+Y0kKRAIhMSLJPt2IBC46kwwGNT58+cVFRX1mfXk5+frRz/60bU+HQAAYJBrDpjs7GwdPXpUb7zxRsj+efPm2b8ePXq04uPjNXnyZH3wwQe65ZZbrn2lnyMvL0+5ubn27WAwqMTExC57PAAA0H2u6UtIOTk52r59u1577TXddNNNV51NS0uTJL3//vuSJK/Xq/r6+pCZjtsd75u50ozL5brsqy+S5HQ65XK5QjYAANA7hRUwlmUpJydH27Zt0549e5ScnPy596mqqpIkxcfHS5J8Pp+OHDmihoYGe6a0tFQul0spKSn2TFlZWch5SktL5fP5wlkuAADopcIKmOzsbP33f/+3Nm3apIEDByoQCCgQCOj8+fOSpA8++ECPP/64KisrdfLkSb3yyiuaNWuWJkyYoDFjxkiSMjIylJKSopkzZ+r3v/+9du7cqWXLlik7O1tOp1OSNH/+fP3hD3/QY489puPHj+vZZ5/VSy+9pEWLFnXy0wcAACYKK2DWrVunpqYmTZw4UfHx8fa2ZcsWSZLD4dDu3buVkZGhESNGaPHixZo2bZpeffVV+xyRkZHavn27IiMj5fP59J3vfEezZs3SqlWr7Jnk5GQVFxertLRUY8eO1RNPPKHnn3+ej1ADAABJYb6J17Ksqx5PTEzUvn37Pvc8SUlJ2rFjx1VnJk6cqEOHDoWzPAAA8CXBz0ICAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxwgqY/Px83XHHHRo4cKDi4uI0depU1dTUhMxcuHBB2dnZuvHGGzVgwABNmzZN9fX1ITO1tbXKyspSdHS04uLitGTJEl28eDFkZu/evfra174mp9OpYcOGqaio6NqeIQAA6HXCCph9+/YpOztb+/fvV2lpqdra2pSRkaHm5mZ7ZtGiRXr11Ve1detW7du3T6dOndKDDz5oH7906ZKysrLU2tqqt956Sy+++KKKioq0fPlye+bEiRPKysrSpEmTVFVVpYULF+r73/++du7c2QlPGQAAmK5vOMMlJSUht4uKihQXF6fKykpNmDBBTU1N+uUvf6lNmzbp61//uiRpw4YNGjlypPbv36/x48dr165dOnbsmHbv3i2Px6Nx48bp8ccf19KlS7Vy5Uo5HA6tX79eycnJeuKJJyRJI0eO1BtvvKE1a9bI7/d30lMHAACmuq73wDQ1NUmSYmNjJUmVlZVqa2tTenq6PTNixAgNHTpUFRUVkqSKigqNHj1aHo/HnvH7/QoGg6qurrZnPn2OjpmOc1xOS0uLgsFgyAYAAHqnaw6Y9vZ2LVy4UHfffbdGjRolSQoEAnI4HIqJiQmZ9Xg8CgQC9syn46XjeMexq80Eg0GdP3/+suvJz8+X2+22t8TExGt9agAAoIe75oDJzs7W0aNHtXnz5s5czzXLy8tTU1OTvdXV1XX3kgAAQBcJ6z0wHXJycrR9+3aVl5frpptusvd7vV61traqsbEx5FWY+vp6eb1ee+bgwYMh5+v4lNKnZ/72k0v19fVyuVyKioq67JqcTqecTue1PB0AAGCYsF6BsSxLOTk52rZtm/bs2aPk5OSQ46mpqerXr5/KysrsfTU1NaqtrZXP55Mk+Xw+HTlyRA0NDfZMaWmpXC6XUlJS7JlPn6NjpuMcAADgyy2sV2Cys7O1adMm/fa3v9XAgQPt96y43W5FRUXJ7XZrzpw5ys3NVWxsrFwulx599FH5fD6NHz9ekpSRkaGUlBTNnDlTBQUFCgQCWrZsmbKzs+1XUObPn69nnnlGjz32mL73ve9pz549eumll1RcXNzJTx8AAJgorFdg1q1bp6amJk2cOFHx8fH2tmXLFntmzZo1+sY3vqFp06ZpwoQJ8nq9+s1vfmMfj4yM1Pbt2xUZGSmfz6fvfOc7mjVrllatWmXPJCcnq7i4WKWlpRo7dqyeeOIJPf/883yEGgAASArzFRjLsj53pn///iosLFRhYeEVZ5KSkrRjx46rnmfixIk6dOhQOMsDAABfEvwsJAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGCfsgCkvL9f999+vhIQERURE6OWXXw45/sgjjygiIiJkmzJlSsjMmTNnNGPGDLlcLsXExGjOnDk6d+5cyMzhw4d17733qn///kpMTFRBQUH4zw4AAPRKYQdMc3Ozxo4dq8LCwivOTJkyRadPn7a3X//61yHHZ8yYoerqapWWlmr79u0qLy/XvHnz7OPBYFAZGRlKSkpSZWWlVq9erZUrV+q5554Ld7kAAKAX6hvuHTIzM5WZmXnVGafTKa/Xe9lj7777rkpKSvT222/r9ttvlyStXbtW9913n372s58pISFBGzduVGtrq1544QU5HA7deuutqqqq0pNPPhkSOgAA4MupS94Ds3fvXsXFxWn48OFasGCBPvroI/tYRUWFYmJi7HiRpPT0dPXp00cHDhywZyZMmCCHw2HP+P1+1dTU6OOPP77sY7a0tCgYDIZsAACgd+r0gJkyZYp+9atfqaysTP/1X/+lffv2KTMzU5cuXZIkBQIBxcXFhdynb9++io2NVSAQsGc8Hk/ITMftjpm/lZ+fL7fbbW+JiYmd/dQAAEAPEfaXkD7P9OnT7V+PHj1aY8aM0S233KK9e/dq8uTJnf1wtry8POXm5tq3g8EgEQMAQC/V5R+jvvnmmzV48GC9//77kiSv16uGhoaQmYsXL+rMmTP2+2a8Xq/q6+tDZjpuX+m9NU6nUy6XK2QDAAC9U5cHzIcffqiPPvpI8fHxkiSfz6fGxkZVVlbaM3v27FF7e7vS0tLsmfLycrW1tdkzpaWlGj58uAYNGtTVSwYAAD1c2AFz7tw5VVVVqaqqSpJ04sQJVVVVqba2VufOndOSJUu0f/9+nTx5UmVlZXrggQc0bNgw+f1+SdLIkSM1ZcoUzZ07VwcPHtSbb76pnJwcTZ8+XQkJCZKkhx9+WA6HQ3PmzFF1dbW2bNmip556KuRLRAAA4Msr7IB55513dNttt+m2226TJOXm5uq2227T8uXLFRkZqcOHD+ub3/ymvvrVr2rOnDlKTU3V66+/LqfTaZ9j48aNGjFihCZPnqz77rtP99xzT8j3eHG73dq1a5dOnDih1NRULV68WMuXL+cj1AAAQNI1vIl34sSJsizrisd37tz5ueeIjY3Vpk2brjozZswYvf766+EuDwAAfAnws5AAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGCcsAOmvLxc999/vxISEhQREaGXX3455LhlWVq+fLni4+MVFRWl9PR0vffeeyEzZ86c0YwZM+RyuRQTE6M5c+bo3LlzITOHDx/Wvffeq/79+ysxMVEFBQXhPzsAANArhR0wzc3NGjt2rAoLCy97vKCgQE8//bTWr1+vAwcO6IYbbpDf79eFCxfsmRkzZqi6ulqlpaXavn27ysvLNW/ePPt4MBhURkaGkpKSVFlZqdWrV2vlypV67rnnruEpAgCA3qZvuHfIzMxUZmbmZY9ZlqWf//znWrZsmR544AFJ0q9+9St5PB69/PLLmj59ut59912VlJTo7bff1u233y5JWrt2re677z797Gc/U0JCgjZu3KjW1la98MILcjgcuvXWW1VVVaUnn3wyJHQAAMCXU6e+B+bEiRMKBAJKT0+397ndbqWlpamiokKSVFFRoZiYGDteJCk9PV19+vTRgQMH7JkJEybI4XDYM36/XzU1Nfr4448v+9gtLS0KBoMhGwAA6J06NWACgYAkyePxhOz3eDz2sUAgoLi4uJDjffv2VWxsbMjM5c7x6cf4W/n5+XK73faWmJh4/U8IAAD0SL3mU0h5eXlqamqyt7q6uu5eEgAA6CKdGjBer1eSVF9fH7K/vr7ePub1etXQ0BBy/OLFizpz5kzIzOXO8enH+FtOp1MulytkAwAAvVOnBkxycrK8Xq/KysrsfcFgUAcOHJDP55Mk+Xw+NTY2qrKy0p7Zs2eP2tvblZaWZs+Ul5erra3NniktLdXw4cM1aNCgzlwyAAAwUNgBc+7cOVVVVamqqkrSX964W1VVpdraWkVERGjhwoX68Y9/rFdeeUVHjhzRrFmzlJCQoKlTp0qSRo4cqSlTpmju3Lk6ePCg3nzzTeXk5Gj69OlKSEiQJD388MNyOByaM2eOqqurtWXLFj311FPKzc3ttCcOAADMFfbHqN955x1NmjTJvt0RFbNnz1ZRUZEee+wxNTc3a968eWpsbNQ999yjkpIS9e/f377Pxo0blZOTo8mTJ6tPnz6aNm2ann76afu42+3Wrl27lJ2drdTUVA0ePFjLly/nI9QAAEDSNQTMxIkTZVnWFY9HRERo1apVWrVq1RVnYmNjtWnTpqs+zpgxY/T666+HuzwAAPAl0Gs+hQQAAL48CBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABin0wNm5cqVioiICNlGjBhhH79w4YKys7N14403asCAAZo2bZrq6+tDzlFbW6usrCxFR0crLi5OS5Ys0cWLFzt7qQAAwFB9u+Kkt956q3bv3v3XB+n714dZtGiRiouLtXXrVrndbuXk5OjBBx/Um2++KUm6dOmSsrKy5PV69dZbb+n06dOaNWuW+vXrp//8z//siuUCAADDdEnA9O3bV16v9zP7m5qa9Mtf/lKbNm3S17/+dUnShg0bNHLkSO3fv1/jx4/Xrl27dOzYMe3evVsej0fjxo3T448/rqVLl2rlypVyOByXfcyWlha1tLTYt4PBYFc8NQAA0AN0yXtg3nvvPSUkJOjmm2/WjBkzVFtbK0mqrKxUW1ub0tPT7dkRI0Zo6NChqqiokCRVVFRo9OjR8ng89ozf71cwGFR1dfUVHzM/P19ut9veEhMTu+KpAQCAHqDTAyYtLU1FRUUqKSnRunXrdOLECd177706e/asAoGAHA6HYmJiQu7j8XgUCAQkSYFAICReOo53HLuSvLw8NTU12VtdXV3nPjEAANBjdPqXkDIzM+1fjxkzRmlpaUpKStJLL72kqKiozn44m9PplNPp7LLzAwCAnqPLP0YdExOjr371q3r//ffl9XrV2tqqxsbGkJn6+nr7PTNer/czn0rquH2599UAAIAvny4PmHPnzumDDz5QfHy8UlNT1a9fP5WVldnHa2pqVFtbK5/PJ0ny+Xw6cuSIGhoa7JnS0lK5XC6lpKR09XIBAIABOv1LSP/2b/+m+++/X0lJSTp16pRWrFihyMhIffvb35bb7dacOXOUm5ur2NhYuVwuPfroo/L5fBo/frwkKSMjQykpKZo5c6YKCgoUCAS0bNkyZWdn8yUiAAAgqQsC5sMPP9S3v/1tffTRRxoyZIjuuece7d+/X0OGDJEkrVmzRn369NG0adPU0tIiv9+vZ5991r5/ZGSktm/frgULFsjn8+mGG27Q7NmztWrVqs5eKgAAMFSnB8zmzZuverx///4qLCxUYWHhFWeSkpK0Y8eOzl4aAADoJfhZSAAAwDgEDAAAMA4BAwAAjEPAAAAA4xAwAADAOAQMAAAwDgEDAACMQ8AAAADjEDAAAMA4BAwAADAOAQMAAIxDwAAAAOMQMAAAwDgEDAAAMA4BAwAAjEPAAAAA4xAwAADAOAQMAAAwDgEDAACMQ8AAAADjEDAAAMA4BAwAADAOAQMAAIxDwAAAAOP07e4FAOi9Nh2o7bJz39JlZwZgAl6BAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYBwCBgAAGIeAAQAAxunRAVNYWKivfOUr6t+/v9LS0nTw4MHuXhIAAOgBemzAbNmyRbm5uVqxYoV+97vfaezYsfL7/WpoaOjupQEAgG7Wt7sXcCVPPvmk5s6dq+9+97uSpPXr16u4uFgvvPCCfvCDH3xmvqWlRS0tLfbtpqYmSVIwGOz0tX3SfFbNn1zo9PNKUvDceakL1oxQXfp7yO+f7ZPms112bv4OfjG66jpL/F35opj2b13HeS3Luvqg1QO1tLRYkZGR1rZt20L2z5o1y/rmN7952fusWLHCksTGxsbGxsbWC7a6urqrtkKPfAXmz3/+sy5duiSPxxOy3+Px6Pjx45e9T15ennJzc+3b7e3tOnPmjG688UZFRER06Xp7i2AwqMTERNXV1cnlcnX3cnoNrmvn45p2Pq5p1+C6hs+yLJ09e1YJCQlXneuRAXMtnE6nnE5nyL6YmJjuWYzhXC4Xf9G6ANe183FNOx/XtGtwXcPjdrs/d6ZHvol38ODBioyMVH19fcj++vp6eb3ebloVAADoKXpkwDgcDqWmpqqsrMze197errKyMvl8vm5cGQAA6Al67JeQcnNzNXv2bN1+++2688479fOf/1zNzc32p5LQ+ZxOp1asWPGZL8Xh+nBdOx/XtPNxTbsG17XrRFjW531Oqfs888wzWr16tQKBgMaNG6enn35aaWlp3b0sAADQzXp0wAAAAFxOj3wPDAAAwNUQMAAAwDgEDAAAMA4BAwAAjEPAQCdPntScOXOUnJysqKgo3XLLLVqxYoVaW1tD5g4fPqx7771X/fv3V2JiogoKCrppxWb4yU9+orvuukvR0dFX/K7QtbW1ysrKUnR0tOLi4rRkyRJdvHjxi12oYQoLC/WVr3xF/fv3V1pamg4ePNjdSzJKeXm57r//fiUkJCgiIkIvv/xyyHHLsrR8+XLFx8crKipK6enpeu+997pnsYbIz8/XHXfcoYEDByouLk5Tp05VTU1NyMyFCxeUnZ2tG2+8UQMGDNC0adM+881aER4CBjp+/Lja29v1i1/8QtXV1VqzZo3Wr1+vH/7wh/ZMMBhURkaGkpKSVFlZqdWrV2vlypV67rnnunHlPVtra6seeughLViw4LLHL126pKysLLW2tuqtt97Siy++qKKiIi1fvvwLXqk5tmzZotzcXK1YsUK/+93vNHbsWPn9fjU0NHT30ozR3NyssWPHqrCw8LLHCwoK9PTTT2v9+vU6cOCAbrjhBvn9fl240HU/ldp0+/btU3Z2tvbv36/S0lK1tbUpIyNDzc3N9syiRYv06quvauvWrdq3b59OnTqlBx98sBtX3Qtc/8+ORm9UUFBgJScn27efffZZa9CgQVZLS4u9b+nSpdbw4cO7Y3lG2bBhg+V2uz+zf8eOHVafPn2sQCBg71u3bp3lcrlCrjP+6s4777Sys7Pt25cuXbISEhKs/Pz8blyVuSRZ27Zts2+3t7dbXq/XWr16tb2vsbHRcjqd1q9//etuWKGZGhoaLEnWvn37LMv6yzXs16+ftXXrVnvm3XfftSRZFRUV3bVM4/EKDC6rqalJsbGx9u2KigpNmDBBDofD3uf3+1VTU6OPP/64O5ZovIqKCo0ePTrkp677/X4Fg0FVV1d348p6ptbWVlVWVio9Pd3e16dPH6Wnp6uioqIbV9Z7nDhxQoFAIOQau91upaWlcY3D0NTUJEn2v6GVlZVqa2sLua4jRozQ0KFDua7XgYDBZ7z//vtau3at/uVf/sXeFwgEQv5DK8m+HQgEvtD19RZc0/D8+c9/1qVLly57zbhenaPjOnKNr117e7sWLlyou+++W6NGjZL0l+vqcDg+8144ruv1IWB6sR/84AeKiIi46nb8+PGQ+/zpT3/SlClT9NBDD2nu3LndtPKe61quKYAvj+zsbB09elSbN2/u7qX0ej32hzni+i1evFiPPPLIVWduvvlm+9enTp3SpEmTdNddd33mzbler/cz75jvuO31ejtnwQYI95pejdfr/cwnaL6M1/TvNXjwYEVGRl72zyHXq3N0XMf6+nrFx8fb++vr6zVu3LhuWpU5cnJytH37dpWXl+umm26y93u9XrW2tqqxsTHkVRj+7F4fAqYXGzJkiIYMGfJ3zf7pT3/SpEmTlJqaqg0bNqhPn9AX53w+n/793/9dbW1t6tevnySptLRUw4cP16BBgzp97T1VONf08/h8Pv3kJz9RQ0OD4uLiJP3lmrpcLqWkpHTKY/QmDodDqampKisr09SpUyX95eX6srIy5eTkdO/ieonk5GR5vV6VlZXZwRIMBnXgwIErfpoOf/no+aOPPqpt27Zp7969Sk5ODjmempqqfv36qaysTNOmTZMk1dTUqLa2Vj6frzuW3Dt097uI0f0+/PBDa9iwYdbkyZOtDz/80Dp9+rS9dWhsbLQ8Ho81c+ZM6+jRo9bmzZut6Oho6xe/+EU3rrxn++Mf/2gdOnTI+tGPfmQNGDDAOnTokHXo0CHr7NmzlmVZ1sWLF61Ro0ZZGRkZVlVVlVVSUmINGTLEysvL6+aV91ybN2+2nE6nVVRUZB07dsyaN2+eFRMTE/JJLlzd2bNn7T+Lkqwnn3zSOnTokPXHP/7RsizL+ulPf2rFxMRYv/3tb63Dhw9bDzzwgJWcnGydP3++m1fecy1YsMByu93W3r17Q/79/OSTT+yZ+fPnW0OHDrX27NljvfPOO5bP57N8Pl83rtp8BAysDRs2WJIuu33a73//e+uee+6xnE6n9Q//8A/WT3/6025asRlmz5592Wv62muv2TMnT560MjMzraioKGvw4MHW4sWLrba2tu5btAHWrl1rDR061HI4HNadd95p7d+/v7uXZJTXXnvtsn8uZ8+ebVnWXz5K/R//8R+Wx+OxnE6nNXnyZKumpqZ7F93DXenfzw0bNtgz58+ft/71X//VGjRokBUdHW390z/9U8j/SUT4IizLsr7AF3wAAACuG59CAgAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMYhYAAAgHEIGAAAYJz/B8HbfvRPEWG8AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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KrL3NTY2qqioSD6frw1XBgAA2oN2+yOkzMxMpaWladSoUbrrrrv061//WmfPnrU/lWQqp9OpZcuWfePHXWg/uEftH/eo/eMemcHk+xRhWdf7nFLbefHFF7Vq1SoFAgGNGDFCzz//vJKTk9t6WQAAoI2164ABAAC4knb5HhgAAIBrIWAAAIBxCBgAAGAcAgYAABiHgGll//qv/6q7775b3bp1+9Z/M7BlWVq6dKl69+6trl27KiUlRR9//HHrLvQmd/r0ac2YMUMul0vR0dFKT09XXV3dNZ8zduxYRUREhGxz5869QSvu+HJycvT9739fUVFRSk5O1v79+685v3nzZg0YMEBRUVEaOnSotm3bdoNWevMK5x7l5uZ+4/slKirqBq725rN371498MADiouLU0REhF5//fXrPmf37t2688475XQ61a9fP+Xm5rb6OpuLgGllFy5c0M9//nPNmzfvWz9n5cqVev7557V27VqVlJTolltukd/v1/nzZv1WX5PMmDFD5eXlKiwsVF5envbu3as5c+Zc93mzZ8/WyZMn7W3lypU3YLUd38aNG5WZmally5bpgw8+0PDhw+X3+3Xq1Kkrzr/33nuaNm2a0tPTdfDgQU2ePFmTJ0/WkSNHbvDKbx7h3iPpL39d/eXfL5999tkNXPHN5+zZsxo+fLhycnK+1XxlZaVSU1N1//33q6ysTAsWLNAjjzyi7du3t/JKm+m7/+5ofBvr1q2z3G73decaGxstr9drrVq1yt5XU1NjOZ1O6/e//30rrvDmdfToUUuS9f7779v7/vjHP1oRERHW//7v/171effdd5/1D//wDzdghTefu+66y8rIyLAfNzQ0WHFxcVZ2dvYV5//u7/7OSk1NDdmXnJxs/f3f/32rrvNmFu49+rb/DUTrkGRt3br1mjOLFi2yBg8eHLLvF7/4heX3+1txZc3HKzDtTGVlpQKBgFJSUux9brdbycnJKi4ubsOVdVzFxcWKjo7WqFGj7H0pKSnq1KmTSkpKrvnc9evXq2fPnhoyZIiysrL01VdftfZyO7wLFy6otLQ05HugU6dOSklJuer3QHFxcci8JPn9fr5nWklz7pEk1dXVKSEhQfHx8XrwwQdVXl5+I5aLb8m076N2+6sEblaBQECS5PF4QvZ7PB77GFpWIBBQbGxsyL7OnTsrJibmmv/Op0+froSEBMXFxenQoUNavHixKioqtGXLltZecof2pz/9SQ0NDVf8Hvjoo4+u+JxAIMD3zA3UnHvUv39/vfLKKxo2bJhqa2v19NNP6+6771Z5ebluu+22G7FsXMfVvo+CwaDOnTunrl27ttHKroxXYJrhiSee+Mab0b6+Xe2bGDdOa9+nOXPmyO/3a+jQoZoxY4ZeffVVbd26VcePH2/BqwA6Bp/Pp1mzZmnEiBG67777tGXLFvXq1Uv/+Z//2dZLg6F4BaYZHn/8cT300EPXnOnbt2+zzu31eiVJ1dXV6t27t72/urpaI0aMaNY5b1bf9j55vd5vvPHw0qVLOn36tH0/vo2m39N17Ngx3X777WGvF3/Rs2dPRUZGqrq6OmR/dXX1Ve+H1+sNax7fTXPu0dd16dJFI0eO1LFjx1pjiWiGq30fuVyudvfqi0TANEuvXr3Uq1evVjl3YmKivF6vioqK7GAJBoMqKSkJ65NM+Pb3yefzqaamRqWlpUpKSpIk7dq1S42NjWH98tCysjJJCglPhM/hcCgpKUlFRUWaPHmyJKmxsVFFRUWaP3/+FZ/j8/lUVFSkBQsW2PsKCwvl8/luwIpvPs25R1/X0NCgw4cPa9KkSa24UoTD5/N9468faNffR239LuKO7rPPPrMOHjxoPfnkk1b37t2tgwcPWgcPHrTOnDljz/Tv39/asmWL/fjf//3frejoaOuNN96wDh06ZD344INWYmKide7cuba4hJvChAkTrJEjR1olJSXWO++8Y/3N3/yNNW3aNPv4559/bvXv398qKSmxLMuyjh07Zq1YscI6cOCAVVlZab3xxhtW3759rTFjxrTVJXQor732muV0Oq3c3Fzr6NGj1pw5c6zo6GgrEAhYlmVZM2fOtJ544gl7/t1337U6d+5sPf3009aHH35oLVu2zOrSpYt1+PDhtrqEDi/ce/Tkk09a27dvt44fP26VlpZaU6dOtaKioqzy8vK2uoQO78yZM/afOZKsZ5991jp48KD12WefWZZlWU888YQ1c+ZMe/6TTz6xunXrZi1cuND68MMPrZycHCsyMtIqKChoq0u4JgKmlaWlpVmSvrG99dZb9owka926dfbjxsZG65//+Z8tj8djOZ1Oa9y4cVZFRcWNX/xN5Msvv7SmTZtmde/e3XK5XNbDDz8cEpmVlZUh962qqsoaM2aMFRMTYzmdTqtfv37WwoULrdra2ja6go7nhRdesPr06WM5HA7rrrvusvbt22cfu++++6y0tLSQ+U2bNll33HGH5XA4rMGDB1v5+fk3eMU3n3Du0YIFC+xZj8djTZo0yfrggw/aYNU3j7feeuuKf/403Ze0tDTrvvvu+8ZzRowYYTkcDqtv374hfza1NxGWZVlt8tIPAABAM/EpJAAAYBwCBgAAGIeAAQAAxiFgAACAcQgYAABgHAIGAAAYh4ABAADGIWAAAIBxCBgAAGAcAgYAABiHgAEAAMb5f71ceVEUznzLAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjAAAAGfCAYAAABBU+jJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAm+ElEQVR4nO3df3RU5YH/8U9ImAGEmRggM+QYaJQVCPKroYZplULJJiD1x5ZuF0RAS6HQYA/GVcweFijubnZBpYgIp+sP6i6UH+eotYQCIQgohiBZIhAkizQ2uDDJFpoMUEgCeb5/fDd3mQJxg5MfT3i/zrlH595n7jz3mZq+z2QmE2WMMQIAALBIh9aeAAAAQFMRMAAAwDoEDAAAsA4BAwAArEPAAAAA6xAwAADAOgQMAACwDgEDAACsQ8AAAADrEDAAAMA6MU0ZvGrVKq1atUqff/65JGngwIFasGCBxo0bJ0m6dOmSnn76aa1fv141NTXKyMjQq6++Kp/P55yjvLxcs2fP1vvvv6+uXbtq2rRpysnJUUzM/05l165dysrKUklJiRITEzV//nw9/vjjTbqw+vp6nTp1St26dVNUVFST7gsAAFqHMUbnzp1TQkKCOnRo5HUW0wTvvfeeyc3NNf/5n/9pSktLzd/93d+Zjh07miNHjhhjjJk1a5ZJTEw0+fn55sCBA2bEiBHmm9/8pnP/y5cvm3vuucekpaWZgwcPmi1btpgePXqY7OxsZ8zvfvc706VLF5OVlWWOHj1qVqxYYaKjo83WrVubMlVz8uRJI4mNjY2NjY3Nwu3kyZON/v98lDFf7csc4+LitHTpUn3/+99Xz549tW7dOn3/+9+XJB07dkwDBgxQQUGBRowYod/+9rf67ne/q1OnTjmvyqxevVrz5s3Tf//3f8vlcmnevHnKzc3VkSNHnMeYOHGiqqqqtHXr1v/zvKqrqxUbG6uTJ0/K4/F8lUsEAAAtJBQKKTExUVVVVfJ6vTcc16RfIV3typUr2rRpky5cuKBAIKCioiLV1dUpLS3NGdO/f3/17t3bCZiCggINGjQo7FdKGRkZmj17tkpKSjRs2DAVFBSEnaNhzNy5cxudT01NjWpqapzb586dkyR5PB4CBgAAy3zZ2z+a/Cbew4cPq2vXrnK73Zo1a5beeecdJScnKxgMyuVyKTY2Nmy8z+dTMBiUJAWDwbB4aTjecKyxMaFQSBcvXrzhvHJycuT1ep0tMTGxqZcGAAAs0eSA6devn4qLi1VYWKjZs2dr2rRpOnr0aHPMrUmys7NVXV3tbCdPnmztKQEAgGbS5F8huVwu9e3bV5KUkpKijz/+WMuXL9ff/M3fqLa2VlVVVWGvwlRUVMjv90uS/H6/9u/fH3a+iooK51jDPxv2XT3G4/Goc+fON5yX2+2W2+1u6uUAAAALfeW/A1NfX6+amhqlpKSoY8eOys/Pd46VlpaqvLxcgUBAkhQIBHT48GFVVlY6Y/Ly8uTxeJScnOyMufocDWMazgEAANCkV2Cys7M1btw49e7dW+fOndO6deu0a9cubdu2TV6vV9OnT1dWVpbi4uLk8Xj05JNPKhAIaMSIEZKk9PR0JScna8qUKVqyZImCwaDmz5+vzMxM59WTWbNm6ZVXXtGzzz6rH/7wh9q5c6c2btyo3NzcyF89AACwUpMCprKyUlOnTtXp06fl9Xo1ePBgbdu2TX/5l38pSVq2bJk6dOigCRMmhP0huwbR0dHavHmzZs+erUAgoNtuu03Tpk3T4sWLnTFJSUnKzc3VU089peXLl+uOO+7Qa6+9poyMjAhdMgAAsN1X/jswbVUoFJLX61V1dTUfowYAwBL/1///5ruQAACAdQgYAABgHQIGAABYh4ABAADWIWAAAIB1CBgAAGAdAgYAAFinyd+FBGldYfk1++4q3xSRc6cmxYXvGP5ERM6LcFc/h5F67ho4zyHPHdqBwk0vNst5T/T+az2a2rtZzo3/ceBNSVJh2dmInvZE77+WpFZ//ngFBgAAWIeAAQAA1iFgAACAdQgYAABgHQIGAABYh4ABAADWIWAAAIB1CBgAAGAdAgYAAFiHgAEAANYhYAAAgHUIGAAAYB0CBgAAWIeAAQAA1iFgAACAdQgYAABgHQIGAABYh4ABAADWIWAAAIB1CBgAAGAdAgYAAFiHgAEAANYhYAAAgHUIGAAAYB0CBgAAWIeAAQAA1iFgAACAdQgYAABgHQIGAABYh4ABAADWIWAAAIB1CBgAAGAdAgYAAFiHgAEAANYhYAAAgHUIGAAAYB0CBgAAWIeAAQAA1iFgAACAdQgYAABgHQIGAABYh4ABAADWaVLA5OTk6Bvf+Ia6deum+Ph4PfLIIyotLQ0bM2rUKEVFRYVts2bNChtTXl6u8ePHq0uXLoqPj9czzzyjy5cvh43ZtWuXvv71r8vtdqtv375as2bNzV0hAABod5oUMLt371ZmZqb27dunvLw81dXVKT09XRcuXAgbN2PGDJ0+fdrZlixZ4hy7cuWKxo8fr9raWn300Uf65S9/qTVr1mjBggXOmLKyMo0fP16jR49WcXGx5s6dqx/96Efatm3bV7xcAADQHsQ0ZfDWrVvDbq9Zs0bx8fEqKirSyJEjnf1dunSR3++/7jm2b9+uo0ePaseOHfL5fBo6dKief/55zZs3T4sWLZLL5dLq1auVlJSkF198UZI0YMAAffjhh1q2bJkyMjKaeo0AAKCd+UrvgamurpYkxcXFhe1fu3atevTooXvuuUfZ2dn605/+5BwrKCjQoEGD5PP5nH0ZGRkKhUIqKSlxxqSlpYWdMyMjQwUFBTecS01NjUKhUNgGAADapya9AnO1+vp6zZ07V9/61rd0zz33OPsfffRR9enTRwkJCTp06JDmzZun0tJSvf3225KkYDAYFi+SnNvBYLDRMaFQSBcvXlTnzp2vmU9OTo5+9rOf3ezlAAAAi9x0wGRmZurIkSP68MMPw/bPnDnT+fdBgwapV69eGjNmjE6cOKG77rrr5mf6JbKzs5WVleXcDoVCSkxMbLbHAwAAreemfoU0Z84cbd68We+//77uuOOORsempqZKkj777DNJkt/vV0VFRdiYhtsN75u50RiPx3PdV18kye12y+PxhG0AAKB9alLAGGM0Z84cvfPOO9q5c6eSkpK+9D7FxcWSpF69ekmSAoGADh8+rMrKSmdMXl6ePB6PkpOTnTH5+flh58nLy1MgEGjKdAEAQDvVpIDJzMzUv//7v2vdunXq1q2bgsGggsGgLl68KEk6ceKEnn/+eRUVFenzzz/Xe++9p6lTp2rkyJEaPHiwJCk9PV3JycmaMmWKPvnkE23btk3z589XZmam3G63JGnWrFn63e9+p2effVbHjh3Tq6++qo0bN+qpp56K8OUDAAAbNSlgVq1aperqao0aNUq9evVytg0bNkiSXC6XduzYofT0dPXv319PP/20JkyYoN/85jfOOaKjo7V582ZFR0crEAjoscce09SpU7V48WJnTFJSknJzc5WXl6chQ4boxRdf1GuvvcZHqAEAgKQmvonXGNPo8cTERO3evftLz9OnTx9t2bKl0TGjRo3SwYMHmzI9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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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McZo7Nixeuedd7R27Vq1b98+6Hj37t3VtGlTFRQUOPvKyspUXl4un88nSfL5fCopKVFlZaUzJj8/X263W2lpac6YM89RP6b+HAAAABcrpHd+srKytHjxYr377ru69tprnXt0PB6PmjdvLo/HoxEjRig7O1vx8fFyu9168skn5fP51LNnT0lS3759lZaWpqFDh2rGjBny+/2aNGmSsrKynHduRo8erRdffFFPP/20nnjiCa1du1ZLly5VXl5emC8fAADYJqR3fhYsWKDq6mr17t1bbdq0cbYlS5Y4Y2bPnq17771XgwYNUq9eveT1evX22287x6Ojo7VixQpFR0fL5/Ppscce07BhwzRt2jRnTPv27ZWXl6f8/Hx17dpVs2bN0iuvvMLH3AEAwCUL6Z0fY8y3jmnWrJnmz5+v+fPnn3dMSkqK3n///Quep3fv3vroo49CmR4AAMC34md7AQAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsEpMQ08AAC7GtmWzInLe9H8dH5HzAmg8eOcHAABYhfgBAABWCTl+NmzYoPvuu09JSUmKiorS8uXLg44//vjjioqKCtr69esXNObw4cMaMmSI3G634uLiNGLECB09ejRozM6dO3XXXXepWbNmSk5O1owZM0K/OgAAgLOEHD/Hjh1T165dNX/+/POO6devnw4ePOhsb7zxRtDxIUOGaPfu3crPz9eKFSu0YcMGjRo1yjkeCATUt29fpaSkqKioSDNnztTUqVP18ssvhzpdAACAICHf8Ny/f3/179//gmNcLpe8Xu85j33yySdauXKlPvzwQ91+++2SpHnz5umee+7Rc889p6SkJC1atEi1tbV67bXXFBsbq06dOqm4uFjPP/98UCQBAACEKiL3/Kxbt04JCQm65ZZbNGbMGB06dMg5VlhYqLi4OCd8JCkjI0NNmjTRtm3bnDG9evVSbGysMyYzM1NlZWX6+uuvz/maNTU1CgQCQRsAAMDZwh4//fr10+uvv66CggL9/ve/1/r169W/f3+dPn1akuT3+5WQkBD0nJiYGMXHx8vv9ztjEhMTg8bUP64fc7bp06fL4/E4W3JycrgvDQAAXAXC/vf8PPLII86vO3furC5duuimm27SunXr1KdPn3C/nCMnJ0fZ2dnO40AgQAABAIBviPhH3W+88Ua1atVKe/fulSR5vV5VVlYGjTl16pQOHz7s3Cfk9XpVUVERNKb+8fnuJXK5XHK73UEbAADA2SIeP19++aUOHTqkNm3aSJJ8Pp+qqqpUVFTkjFm7dq3q6uqUnp7ujNmwYYNOnjzpjMnPz9ctt9yi6667LtJTBgAAV7GQ4+fo0aMqLi5WcXGxJGnfvn0qLi5WeXm5jh49qgkTJmjr1q364osvVFBQoIEDB6pDhw7KzMyUJKWmpqpfv34aOXKktm/frs2bN2vs2LF65JFHlJSUJEl69NFHFRsbqxEjRmj37t1asmSJ5s6dG/RtLQAAgIsRcvzs2LFDt912m2677TZJUnZ2tm677TZNnjxZ0dHR2rlzp+6//37dfPPNGjFihLp3766NGzfK5XI551i0aJE6duyoPn366J577tGdd94Z9Hf4eDwerV69Wvv27VP37t01fvx4TZ48mY+5AwCASxbyDc+9e/eWMea8x1etWvWt54iPj9fixYsvOKZLly7auHFjqNMDAAC4IH62FwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAq8Q09AQAXL0WbyvXTeXLGnoaABCEd34AAIBViB8AAGAV4gcAAFiF+AEAAFYhfgAAgFWIHwAAYBXiBwAAWIX4AQAAViF+AACAVYgfAABgFeIHAABYhfgBAABWIX4AAIBViB8AAGAV4gcAAFiF+AEAAFYhfgAAgFWIHwAAYBXiBwAAWIX4AQAAViF+AACAVYgfAABgFeIHAABYhfgBAABWIX4AAIBViB8AAGAV4gcAAFiF+AEAAFYhfgAAgFWIHwAAYBXiBwAAWIX4AQAAViF+AACAVYgfAABglZDjZ8OGDbrvvvuUlJSkqKgoLV++POi4MUaTJ09WmzZt1Lx5c2VkZOjTTz8NGnP48GENGTJEbrdbcXFxGjFihI4ePRo0ZufOnbrrrrvUrFkzJScna8aMGaFfHQAAwFlCjp9jx46pa9eumj9//jmPz5gxQy+88IIWLlyobdu26ZprrlFmZqZOnDjhjBkyZIh2796t/Px8rVixQhs2bNCoUaOc44FAQH379lVKSoqKioo0c+ZMTZ06VS+//PJFXCIAAMA/xYT6hP79+6t///7nPGaM0Zw5czRp0iQNHDhQkvT6668rMTFRy5cv1yOPPKJPPvlEK1eu1Icffqjbb79dkjRv3jzdc889eu6555SUlKRFixaptrZWr732mmJjY9WpUycVFxfr+eefD4okAACAUIX1np99+/bJ7/crIyPD2efxeJSenq7CwkJJUmFhoeLi4pzwkaSMjAw1adJE27Ztc8b06tVLsbGxzpjMzEyVlZXp66+/Pudr19TUKBAIBG0AAABnC2v8+P1+SVJiYmLQ/sTEROeY3+9XQkJC0PGYmBjFx8cHjTnXOc58jbNNnz5dHo/H2ZKTky/9ggAAwFXnqvm0V05Ojqqrq51t//79DT0lAADQCIU1frxerySpoqIiaH9FRYVzzOv1qrKyMuj4qVOndPjw4aAx5zrHma9xNpfLJbfbHbQBAACcLazx0759e3m9XhUUFDj7AoGAtm3bJp/PJ0ny+XyqqqpSUVGRM2bt2rWqq6tTenq6M2bDhg06efKkMyY/P1+33HKLrrvuunBOGQAAWCbk+Dl69KiKi4tVXFws6R83ORcXF6u8vFxRUVEaN26cfvOb3+i9995TSUmJhg0bpqSkJD3wwAOSpNTUVPXr108jR47U9u3btXnzZo0dO1aPPPKIkpKSJEmPPvqoYmNjNWLECO3evVtLlizR3LlzlZ2dHbYLBwAAdgr5o+47duzQ3Xff7TyuD5Lhw4crNzdXTz/9tI4dO6ZRo0apqqpKd955p1auXKlmzZo5z1m0aJHGjh2rPn36qEmTJho0aJBeeOEF57jH49Hq1auVlZWl7t27q1WrVpo8eTIfcwcAAJcs5Pjp3bu3jDHnPR4VFaVp06Zp2rRp5x0THx+vxYsXX/B1unTpoo0bN4Y6PQAAgAu6aj7tBQAA8F0QPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsErY42fq1KmKiooK2jp27OgcP3HihLKysnT99derZcuWGjRokCoqKoLOUV5ergEDBqhFixZKSEjQhAkTdOrUqXBPFQAAWCgmEift1KmT1qxZ888Xifnnyzz11FPKy8vTsmXL5PF4NHbsWD300EPavHmzJOn06dMaMGCAvF6vtmzZooMHD2rYsGFq2rSpfvvb30ZiugAAwCIRiZ+YmBh5vd5v7K+urtarr76qxYsX68c//rEk6Q9/+INSU1O1detW9ezZU6tXr1ZpaanWrFmjxMREdevWTc8++6wmTpyoqVOnKjY29pyvWVNTo5qaGudxIBCIxKUBAIArXETu+fn000+VlJSkG2+8UUOGDFF5ebkkqaioSCdPnlRGRoYztmPHjmrXrp0KCwslSYWFhercubMSExOdMZmZmQoEAtq9e/d5X3P69OnyeDzOlpycHIlLAwAAV7iwx096erpyc3O1cuVKLViwQPv27dNdd92lI0eOyO/3KzY2VnFxcUHPSUxMlN/vlyT5/f6g8Kk/Xn/sfHJyclRdXe1s+/fvD++FAQCAq0LYv+3Vv39/59ddunRRenq6UlJStHTpUjVv3jzcL+dwuVxyuVwROz8AALg6RPyj7nFxcbr55pu1d+9eeb1e1dbWqqqqKmhMRUWFc4+Q1+v9xqe/6h+f6z4iAACAUEQ8fo4eParPPvtMbdq0Uffu3dW0aVMVFBQ4x8vKylReXi6fzydJ8vl8KikpUWVlpTMmPz9fbrdbaWlpkZ4uAAC4yoX9217//u//rvvuu08pKSk6cOCApkyZoujoaA0ePFgej0cjRoxQdna24uPj5Xa79eSTT8rn86lnz56SpL59+yotLU1Dhw7VjBkz5Pf7NWnSJGVlZfFtLQAAcMnCHj9ffvmlBg8erEOHDql169a68847tXXrVrVu3VqSNHv2bDVp0kSDBg1STU2NMjMz9dJLLznPj46O1ooVKzRmzBj5fD5dc801Gj58uKZNmxbuqQIAAAuFPX7efPPNCx5v1qyZ5s+fr/nz5593TEpKit5///1wTw0AAICf7QUAAOxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAqxA/AADAKsQPAACwCvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKs06viZP3++vve976lZs2ZKT0/X9u3bG3pKAADgCtdo42fJkiXKzs7WlClT9Je//EVdu3ZVZmamKisrG3pqAADgChbT0BM4n+eff14jR47Uz3/+c0nSwoULlZeXp9dee03PPPPMN8bX1NSopqbGeVxdXS1JCgQCYZ/b348d0bG/nwj7eSUpcPS4FIE5I1hEfw/5/XNEcp0jhd+/YJH6/fv7sSOs9eVw9PgV99+6+vMaYyJy/vqTNzo1NTUmOjravPPOO0H7hw0bZu6///5zPmfKlClGEhsbGxsbG9tVsO3fvz9indEo3/n56quvdPr0aSUmJgbtT0xM1J49e875nJycHGVnZzuPq6qqlJKSovLycnk8nojO92oXCASUnJys/fv3y+12N/R0rlisY/iwluHBOoYPaxke9etYWlqqpKSkiL1Oo4yfi+FyueRyub6x3+Px8IUYJm63m7UMA9YxfFjL8GAdw4e1DI8bbrhBTZpE7rbkRnnDc6tWrRQdHa2Kioqg/RUVFfJ6vQ00KwAAcDVolPETGxur7t27q6CgwNlXV1engoIC+Xy+BpwZAAC40jXab3tlZ2dr+PDhuv3229WjRw/NmTNHx44dcz799W1cLpemTJlyzm+FITSsZXiwjuHDWoYH6xg+rGV4XK51jDImkp8luzQvvviiZs6cKb/fr27duumFF15Qenp6Q08LAABcwRp1/AAAAIRbo7znBwAAIFKIHwAAYBXiBwAAWIX4AQAAVrmi4+fw4cMaMmSI3G634uLiNGLECB09evSCzzlx4oSysrJ0/fXXq2XLlho0aNA3/jJFScrNzVWXLl3UrFkzJSQkKCsrK1KX0eAiuY6SdOjQIbVt21ZRUVGqqqqKwBU0HpFYy48//liDBw9WcnKymjdvrtTUVM2dOzfSl3JZzZ8/X9/73vfUrFkzpaena/v27Rccv2zZMnXs2FHNmjVT586d9f777wcdN8Zo8uTJatOmjZo3b66MjAx9+umnkbyERiOca3ny5ElNnDhRnTt31jXXXKOkpCQNGzZMBw4ciPRlNLhwf02eafTo0YqKitKcOXPCPOvGKRJr+cknn+j++++Xx+PRNddcozvuuEPl5eXffVIR+6lhl0G/fv1M165dzdatW83GjRtNhw4dzODBgy/4nNGjR5vk5GRTUFBgduzYYXr27Gl+8IMfBI2ZNWuWSUpKMosWLTJ79+41H3/8sXn33XcjeSkNKlLrWG/gwIGmf//+RpL5+uuvI3AFjUck1vLVV181v/rVr8y6devMZ599Zv77v//bNG/e3MybNy/Sl3NZvPnmmyY2Nta89tprZvfu3WbkyJEmLi7OVFRUnHP85s2bTXR0tJkxY4YpLS01kyZNMk2bNjUlJSXOmN/97nfG4/GY5cuXm48//tjcf//9pn379ub48eOX67IaRLjXsqqqymRkZJglS5aYPXv2mMLCQtOjRw/TvXv3y3lZl10kvibrvf3226Zr164mKSnJzJ49O8JX0vAisZZ79+418fHxZsKECeYvf/mL2bt3r3n33XfPe85zuWLjp7S01EgyH374obPvz3/+s4mKijJ/+9vfzvmcqqoq07RpU7Ns2TJn3yeffGIkmcLCQmOMMYcPHzbNmzc3a9asiewFNBKRWsd6L730kvnRj35kCgoKrvr4ifRanumXv/ylufvuu8M3+QbUo0cPk5WV5Tw+ffq0SUpKMtOnTz/n+IcfftgMGDAgaF96err5t3/7N2OMMXV1dcbr9ZqZM2c6x6uqqozL5TJvvPFGBK6g8Qj3Wp7L9u3bjSTz17/+NTyTboQitY5ffvmlueGGG8yuXbtMSkqKFfETibX82c9+Zh577LFLmtcV+22vwsJCxcXF6fbbb3f2ZWRkqEmTJtq2bds5n1NUVKSTJ08qIyPD2dexY0e1a9dOhYWFkqT8/HzV1dXpb3/7m1JTU9W2bVs9/PDD2r9/f2QvqIFEah0lqbS0VNOmTdPrr78e0R9Q11hEci3PVl1drfj4+PBNvoHU1taqqKgo6PqbNGmijIyM815/YWFh0HhJyszMdMbv27dPfr8/aIzH41F6evoF1/RKF4m1PJfq6mpFRUUpLi4uLPNubCK1jnV1dRo6dKgmTJigTp06RWbyjUwk1rKurk55eXm6+eablZmZqYSEBKWnp2v58uUhze2K/RPJ7/crISEhaF9MTIzi4+Pl9/vP+5zY2Nhv/EubmJjoPOfzzz9XXV2dfvvb32rOnDl66623dPjwYf3kJz9RbW1tRK6lIUVqHWtqajR48GDNnDlT7dq1i8jcG5tIreXZtmzZoiVLlmjUqFFhmXdD+uqrr3T69GklJiYG7b/Q9fv9/guOr/9nKOe8GkRiLc924sQJTZw4UYMHD75qf3J5pNbx97//vWJiYvSrX/0q/JNupCKxlpWVlTp69Kh+97vfqV+/flq9erUefPBBPfTQQ1q/fv13nluji59nnnlGUVFRF9z27NkTsdevq6vTyZMn9cILLygzM1M9e/bUG2+8oU8//VQffPBBxF433Bp6HXNycpSamqrHHnssYq9xuTT0Wp5p165dGjhwoKZMmaK+ffteltcEpH/c/Pzwww/LGKMFCxY09HSuKEVFRZo7d65yc3MVFRXV0NO5otXV1UmSBg4cqKeeekrdunXTM888o3vvvVcLFy78zudpdD/YdPz48Xr88ccvOObGG2+U1+tVZWVl0P5Tp07p8OHD8nq953ye1+tVbW2tqqqqgv5Pu6KiwnlOmzZtJElpaWnO8datW6tVq1ah3UnewBp6HdeuXauSkhK99dZbkv7x6RtJatWqlf7zP/9Tv/71ry/yyi6/hl7LeqWlperTp49GjRqlSZMmXdS1NDatWrVSdHT0Nz4peK7rr+f1ei84vv6fFRUVzr/P9Y+7desWxtk3LpFYy3r14fPXv/5Va9euvWrf9ZEis44bN25UZWVl0Lvgp0+f1vjx4zVnzhx98cUX4b2IRiISa9mqVSvFxMQE/RktSampqdq0adN3n9wl3THUgOpvLt2xY4ezb9WqVd/p5tK33nrL2bdnz56gm0vLysqMpKAbng8dOmSaNGliVq1aFaGraTiRWse9e/eakpISZ3vttdeMJLNly5aQ7si/kkRqLY0xZteuXSYhIcFMmDAhchfQQHr06GHGjh3rPD59+rS54YYbLnhD5L333hu0z+fzfeOG5+eee845Xl1dbc0Nz+FcS2OMqa2tNQ888IDp1KmTqaysjMzEG5lwr+NXX30V9N/DkpISk5SUZCZOnGj27NkTuQtpBCLxNenz+b5xw/MDDzzwrZ+sPdMVGz/G/ONjxbfddpvZtm2b2bRpk/mXf/mXoIv/8ssvzS233GK2bdvm7Bs9erRp166dWbt2rdmxY4fx+XzG5/MFnXfgwIGmU6dOZvPmzaakpMTce++9Ji0tzdTW1l62a7ucIrWOZ/rggw+u+k97GROZtSwpKTGtW7c2jz32mDl48KCzXS1/EL355pvG5XKZ3NxcU1paakaNGmXi4uKM3+83xhgzdOhQ88wzzzjjN2/ebGJiYsxzzz1nPvnkEzNlypRzftQ9Li7OvPvuu2bnzp1m4MCB1nzUPZxrWVtba+6//37Ttm1bU1xcHPT1V1NT0yDXeDlE4mvybLZ82isSa/n222+bpk2bmpdfftl8+umnZt68eSY6Otps3LjxO8/rio6fQ4cOmcGDB5uWLVsat9ttfv7zn5sjR444x/ft22ckmQ8++MDZd/z4cfPLX/7SXHfddaZFixbmwQcfNAcPHgw6b3V1tXniiSdMXFyciY+PNw8++KApLy+/XJd12UVqHc9kS/xEYi2nTJliJH1jS0lJuYxXFlnz5s0z7dq1M7GxsaZHjx5m69atzrEf/ehHZvjw4UHjly5dam6++WYTGxtrOnXqZPLy8oKO19XVmf/6r/8yiYmJxuVymT59+piysrLLcSkNLpxrWf/1eq7tzK/hq1G4vybPZkv8GBOZtXz11VdNhw4dTLNmzUzXrl3N8uXLQ5pTlDH//2YMAAAACzS6T3sBAABEEvEDAACsQvwAAACrED8AAMAqxA8AALAK8QMAAKxC/AAAAKsQPwAAwCrEDwAAsArxAwAArEL8AAAAq/w/8aLidMAPVYQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(15):\n",
    "    plt.hist(l_act[:,i].tolist(), alpha=0.4, bins=20)\n",
    "    plt.hist(r_act[:,i].tolist(), alpha=0.4, bins=20)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "50ccb435",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(coef.tolist(), l_act.max(dim=0)[0].tolist())\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dfb92c44",
   "metadata": {},
   "outputs": [],
   "source": [
    "big_neurons = (l_act.max(dim=0)[0] > 15).nonzero()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fbdc8d34",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 1, 3, 4, 9]"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b_part1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aa6d40b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[4],\n",
       "       [5],\n",
       "       [6],\n",
       "       [2],\n",
       "       [6],\n",
       "       [4],\n",
       "       [2],\n",
       "       [6],\n",
       "       [0],\n",
       "       [0],\n",
       "       [6],\n",
       "       [2],\n",
       "       [5],\n",
       "       [5],\n",
       "       [4],\n",
       "       [4],\n",
       "       [2],\n",
       "       [4],\n",
       "       [0],\n",
       "       [5],\n",
       "       [6],\n",
       "       [0],\n",
       "       [0]], dtype=int32)"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b_labels[big_neurons]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3f5be04",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ablate_loss(ln, rn, un):\n",
    "    ablate_model = copy.deepcopy(model)\n",
    "    ablate_model.linear.data = t.eye(ln.shape[1]).unsqueeze(0)\n",
    "    ablate_model.embedding_left.data = ln.unsqueeze(0)\n",
    "    ablate_model.embedding_right.data = rn.unsqueeze(0)\n",
    "    ablate_model.unembedding.data = un.unsqueeze(0).mT\n",
    "    return test_loss(ablate_model.to(device), data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e5c5b50",
   "metadata": {},
   "outputs": [],
   "source": [
    "big_mask = l_act.max(dim=0)[0] > 15\n",
    "small_mask = l_act.max(dim=0)[0] < 3\n",
    "part1_mask = t.tensor([i in b_part1 for i in b_labels], device=device)\n",
    "part2_mask = t.tensor([i in b_part2 for i in b_labels], device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ff4e03fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'G0_loss': tensor([0.8658]), 'G0_acc': tensor([0.5001])}\n",
      "{'G0_loss': tensor([1.4867]), 'G0_acc': tensor([0.3433])}\n",
      "{'G0_loss': tensor([4.2793]), 'G0_acc': tensor([0.3035])}\n",
      "{'G0_loss': tensor([3.3410]), 'G0_acc': tensor([0.1060])}\n",
      "{'G0_loss': tensor([2.6429]), 'G0_acc': tensor([0.1717])}\n",
      "{'G0_loss': tensor([3.5448]), 'G0_acc': tensor([0.0409])}\n",
      "{'G0_loss': tensor([4.5008]), 'G0_acc': tensor([0.0628])}\n",
      "{'G0_loss': tensor([3.2302]), 'G0_acc': tensor([0.0570])}\n",
      "{'G0_loss': tensor([4.5770]), 'G0_acc': tensor([0.0439])}\n"
     ]
    }
   ],
   "source": [
    "print(ablate_loss(irrep_lneurons, irrep_rneurons, irrep_uneurons))\n",
    "print(ablate_loss(irrep_lneurons[:,big_mask], irrep_rneurons[:,big_mask], irrep_uneurons[:,big_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,small_mask], irrep_rneurons[:,small_mask], irrep_uneurons[:,small_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part1_mask], irrep_rneurons[:,part1_mask], irrep_uneurons[:,part1_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part2_mask], irrep_rneurons[:,part2_mask], irrep_uneurons[:,part2_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part1_mask & big_mask], irrep_rneurons[:,part1_mask & big_mask], irrep_uneurons[:,part1_mask & big_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part1_mask & small_mask], irrep_rneurons[:,part1_mask & small_mask], irrep_uneurons[:,part1_mask & small_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part2_mask & big_mask], irrep_rneurons[:,part2_mask & big_mask], irrep_uneurons[:,part2_mask & big_mask]))\n",
    "print(ablate_loss(irrep_lneurons[:,part2_mask & small_mask], irrep_rneurons[:,part2_mask & small_mask], irrep_uneurons[:,part2_mask & small_mask]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "117958d7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'G0_loss': tensor([29.3090]), 'G0_acc': tensor([0.5001])}"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ablate_loss(10*irrep_lneurons, 10*irrep_rneurons, 10*irrep_uneurons)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9607b4c8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([120, 52])"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irrep_lneurons.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92c393d7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(23), tensor(25))"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "big_mask.sum(), small_mask.sum() "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a71abab3",
   "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
}
