{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Utils.checkpointUtil import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "caadc48035ea49af83ffa9d5f17df4dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:Loading model microsoft/Phi-3-mini-4k-instruct requires setting trust_remote_code=True\n",
      "WARNING:root:Loading model microsoft/Phi-3-mini-4k-instruct state dict requires setting trust_remote_code=True\n",
      "Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded pretrained model microsoft/Phi-3-mini-4k-instruct into HookedTransformer\n"
     ]
    }
   ],
   "source": [
    "MODEL_PATH = 'microsoft/Phi-3-mini-4k-instruct'\n",
    "model, tokenizer = loadTransformerLensModel(MODEL_PATH)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Moving model to device:  cuda\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "HookedTransformer(\n",
       "  (embed): Embed()\n",
       "  (hook_embed): HookPoint()\n",
       "  (blocks): ModuleList(\n",
       "    (0-31): 32 x TransformerBlock(\n",
       "      (ln1): RMSNorm(\n",
       "        (hook_scale): HookPoint()\n",
       "        (hook_normalized): HookPoint()\n",
       "      )\n",
       "      (ln2): RMSNorm(\n",
       "        (hook_scale): HookPoint()\n",
       "        (hook_normalized): HookPoint()\n",
       "      )\n",
       "      (attn): Attention(\n",
       "        (hook_k): HookPoint()\n",
       "        (hook_q): HookPoint()\n",
       "        (hook_v): HookPoint()\n",
       "        (hook_z): HookPoint()\n",
       "        (hook_attn_scores): HookPoint()\n",
       "        (hook_pattern): HookPoint()\n",
       "        (hook_result): HookPoint()\n",
       "        (hook_rot_k): HookPoint()\n",
       "        (hook_rot_q): HookPoint()\n",
       "      )\n",
       "      (mlp): GatedMLP(\n",
       "        (hook_pre): HookPoint()\n",
       "        (hook_pre_linear): HookPoint()\n",
       "        (hook_post): HookPoint()\n",
       "      )\n",
       "      (hook_attn_in): HookPoint()\n",
       "      (hook_q_input): HookPoint()\n",
       "      (hook_k_input): HookPoint()\n",
       "      (hook_v_input): HookPoint()\n",
       "      (hook_mlp_in): HookPoint()\n",
       "      (hook_attn_out): HookPoint()\n",
       "      (hook_mlp_out): HookPoint()\n",
       "      (hook_resid_pre): HookPoint()\n",
       "      (hook_resid_mid): HookPoint()\n",
       "      (hook_resid_post): HookPoint()\n",
       "    )\n",
       "  )\n",
       "  (ln_final): RMSNorm(\n",
       "    (hook_scale): HookPoint()\n",
       "    (hook_normalized): HookPoint()\n",
       "  )\n",
       "  (unembed): Unembed()\n",
       ")"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.to('cuda')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "with open('BaysianOptimization/error/phi-3/navigate/NN_kernel_layer_0_6_angle_-0.7853981633974483_0.7853981633974483_reasoning_prob_mix_v2.pkl', 'rb') as f:\n",
    "    data = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "unembed = model.unembed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "normal_cache = data[i]['normal_cache']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 49, 32, 96])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normal_cache[f'blocks.{0}.attn.hook_z'].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 49, 32, 3072])"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(normal_cache[f'blocks.{0}.attn.hook_z'].to('cuda') @ model.W_O[0,0]).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "def cosine_sim(a,b):\n",
    "    return (a @ b) / (torch.norm(a) * torch.norm(b))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [],
   "source": [
    "def getDifference(cache, true_embedding):\n",
    "    results = [[0 for _ in range(32)] for _ in range(5 * 2)]\n",
    "    for i in range(5):\n",
    "        for j in range(32):\n",
    "            first = unembed(cache[f'blocks.{i}.attn.hook_z'][:, -1, j, :].to('cuda') @ model.W_O[i,j])[0]\n",
    "            # print(first.shape)\n",
    "            second = true_embedding.detach().cpu()\n",
    "            # print(second.shape)\n",
    "            # print(f'Layer {i} head {j} cosine similarity: {cosine_sim(first.detach().cpu(), second.detach().cpu())}')\n",
    "            results[i][j] = cosine_sim(first.detach().cpu(), second.detach().cpu())\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [],
   "source": [
    "# getDifference(rotated_cache, true_embedding_weight)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 73, 32, 96])\n"
     ]
    }
   ],
   "source": [
    "normal_cache = data[3]['normal_cache']\n",
    "print(normal_cache['blocks.0.attn.hook_z'].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 280,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_average(matrix):\n",
    "    average = 0\n",
    "    for i in range(5):\n",
    "        for j in range(32):\n",
    "            average += matrix[i][j]\n",
    "    return average / 160\n",
    "\n",
    "def getStandardDeviation(matrix):\n",
    "    average = get_average(matrix)\n",
    "    std = 0\n",
    "    for i in range(5):\n",
    "        for j in range(32):\n",
    "            std += (matrix[i][j] - average) ** 2\n",
    "    return (std / 160) ** 0.5\n",
    "\n",
    "def getStandardDeviation_layer(matrix):\n",
    "    average = get_average_layer(matrix)\n",
    "    std = 0\n",
    "    for i in range(len(matrix)):\n",
    "        std += (matrix[i] - average) ** 2\n",
    "    return (std / len(matrix)) ** 0.5\n",
    "\n",
    "def get_average_layer(array):\n",
    "    average = 0\n",
    "    for i in range(len(array)):\n",
    "        average += array[i]\n",
    "    return average / len(array)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([32, 96, 3072])"
      ]
     },
     "execution_count": 162,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.W_O[i].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3072, 32064])"
      ]
     },
     "execution_count": 177,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.W_U.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 278,
   "metadata": {},
   "outputs": [],
   "source": [
    "def getTop5Tokens(rotated_cache, normal_cache, answer_token):\n",
    "    rotated_results = [[0 for _ in range(32)] for _ in range(5)]\n",
    "    normal_results = [[0 for _ in range(32)] for _ in range(5)]\n",
    "    results = [[0 for _ in range(32)] for _ in range(5)]\n",
    "    for i in range(5):\n",
    "        # sum over heads\n",
    "        # sum = (cache[f'blocks.{i}.attn.hook_z'].to('cuda') @ model.W_O[i]).sum(dim=2)\n",
    "        # print(sum.shape)\n",
    "        \n",
    "        for j in range(32):\n",
    "            prob_diff = 0\n",
    "            r_t = 0\n",
    "            n_t = 0\n",
    "            print((rotated_cache[f'blocks.{i}.attn.hook_z'][:, :, j, :].to('cuda') @ model.W_O[i,j]).shape)\n",
    "            for k in range(49):\n",
    "            # k = 0  \n",
    "                rotated_embedding = rotated_cache[f'blocks.{i}.attn.hook_z'][:, k, j, :].to('cuda') @ model.W_O[i,j]\n",
    "                normal_embedding = normal_cache[f'blocks.{i}.attn.hook_z'][:, k, j, :].to('cuda') @ model.W_O[i,j]\n",
    "                \n",
    "            \n",
    "                diff = rotated_embedding - normal_embedding\n",
    "                vocab = diff @ model.W_U\n",
    "                rotated_vocab = rotated_embedding @ model.W_U\n",
    "                normal_vocab = normal_embedding @ model.W_U\n",
    "                \n",
    "                sorted_logits, sorted_indices = torch.sort(rotated_vocab[0], descending=True)\n",
    "                rotated_rank = (sorted_indices == answer_token).nonzero(as_tuple=True)[0].item()\n",
    "                \n",
    "                _, sorted_indices = torch.sort(normal_vocab[0], descending=True)\n",
    "                normal_rank = (sorted_indices == answer_token).nonzero(as_tuple=True)[0].item()\n",
    "                # print(vocab.shape)\n",
    "                prob_rotated = torch.nn.functional.softmax(rotated_vocab[0], dim=0)[answer_token]\n",
    "                prob_normal = torch.nn.functional.softmax(normal_vocab[0], dim=0)[answer_token]\n",
    "                # print(prob_rotated.shape)\n",
    "                # top5 = torch.topk(vocab, 5)\n",
    "                top5 = torch.topk(vocab, 5)\n",
    "                # print(tokenizer.decode(top5.indices[0]))\n",
    "                prob_diff += normal_rank - rotated_rank\n",
    "                r_t += rotated_rank\n",
    "                n_t += normal_rank\n",
    "                \n",
    "            \n",
    "            results[i][j] = prob_diff / 49\n",
    "            rotated_results[i][j] = rotated_rank / 49\n",
    "            normal_results[i][j] = normal_rank / 49\n",
    "                # print(prob_rotated - prob_normal)\n",
    "            # print(top5.indices)\n",
    "            # print(tokenizer.decode(top5.indices[0]))\n",
    "            # first = (cache[f'blocks.{i}.attn.hook_z'][:, -1, j, :].to('cuda') @ model.W_O[i,j])[0] @ model.W_U\n",
    "            # print(first.shape)\n",
    "            # get top 5 tokens\n",
    "            # get probability of answer token\n",
    "            # prob = torch.nn.functional.softmax(first, dim=0)[answer_token]\n",
    "            # results[i][j] = prob.item()\n",
    "            # results[i][j] = tokenizer.decode(top5.indices)\n",
    "            \n",
    "    return results, rotated_results, normal_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 289,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'True'"
      ]
     },
     "execution_count": 289,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.decode(5852)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 279,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 49, 3072])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n",
      "torch.Size([1, 49, 3072])\n"
     ]
    }
   ],
   "source": [
    "results, rotated_results, normal_results = getTop5Tokens(data[7]['rotated_cache'], data[7]['normal_cache'], 5852)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 286,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Layer 0: 173.01721938775523\n",
      "Layer 1: 218.6077806122449\n",
      "Layer 2: 11.251913265306264\n",
      "Layer 3: 965.8258928571429\n",
      "Layer 4: -586.4904336734694\n"
     ]
    }
   ],
   "source": [
    "print(f'Layer 0: {get_average_layer(results[0])}')\n",
    "print(f'Layer 1: {get_average_layer(results[1])}')\n",
    "print(f'Layer 2: {get_average_layer(results[2])}')\n",
    "print(f'Layer 3: {get_average_layer(results[3])}')\n",
    "print(f'Layer 4: {get_average_layer(results[4])}')\n",
    "# print(f'Layer 0: {getStandardDeviation_layer(results[0])}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 282,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "389.6135204081632\n",
      "302.76721938775506\n",
      "313.33227040816325\n",
      "319.2302295918367\n",
      "385.37117346938777\n"
     ]
    }
   ],
   "source": [
    "print(get_average_layer(rotated_results[0]))\n",
    "print(get_average_layer(rotated_results[1]))\n",
    "print(get_average_layer(rotated_results[2]))\n",
    "print(get_average_layer(rotated_results[3]))\n",
    "print(get_average_layer(rotated_results[4]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 283,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "395.78125\n",
      "300.890306122449\n",
      "310.28380102040813\n",
      "333.66645408163276\n",
      "342.88201530612236\n"
     ]
    }
   ],
   "source": [
    "print(get_average_layer(normal_results[0]))\n",
    "print(get_average_layer(normal_results[1]))\n",
    "print(get_average_layer(normal_results[2]))\n",
    "print(get_average_layer(normal_results[3]))\n",
    "print(get_average_layer(normal_results[4]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 273,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "156.44247448979587"
      ]
     },
     "execution_count": 273,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_average(average)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[5852]"
      ]
     },
     "execution_count": 179,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tokenizer.encode('True', add_special_tokens=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "metadata": {},
   "outputs": [],
   "source": [
    "normal_prob = getTop5Tokens(normal_cache, 5852)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {},
   "outputs": [],
   "source": [
    "rotated_prob = getTop5Tokens(rotated_cache, 5852)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3.1188871184895105e-05, 3.1184389615646066e-05)"
      ]
     },
     "execution_count": 183,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_average(normal_prob), get_average(rotated_prob)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[['casize us !=cre',\n",
       "  '$$ident_{\\\\ O getting',\n",
       "  'usca�Exident',\n",
       "  'are� $$ coun present',\n",
       "  '� pourère nopo',\n",
       "  '$$oughcreру way',\n",
       "  '$$Asatensizeita',\n",
       "  'cheLE TheTith',\n",
       "  '$$tra ComTo        ',\n",
       "  '$$ Nowina&work',\n",
       "  'ident чces                 query',\n",
       "  'ca way projectctions Univers',\n",
       "  '$$Asples privateère',\n",
       "  'Theру project finich',\n",
       "  '$$ Monaten start idea',\n",
       "  'sizeough projectite The',\n",
       "  '$$ExAs theyough',\n",
       "  '�caareiteith',\n",
       "  '$$ited cl properchn',\n",
       "  '$$Asants Вrt',\n",
       "  'sizeAsoughcre state',\n",
       "  '$$Ascreough no',\n",
       "  '$$ fewOn forados',\n",
       "  '$$ The way Universough',\n",
       "  '$$oughsizecre read',\n",
       "  '$$Asatensizebb',\n",
       "  '�oughcaarefig',\n",
       "  '$$oughsize TheAs',\n",
       "  '$$ko Thevolore',\n",
       "  'ca us�ère no',\n",
       "  '$$As moreda Answer',\n",
       "  '$$Assize�self'],\n",
       " [\"$$eq properCh '\",\n",
       "  'typezo._\\x0b__',\n",
       "  '$$èreident name multiple',\n",
       "  '// ÉIm good$,',\n",
       "  'ough // The $$size',\n",
       "  '//aten $$eb Fran',\n",
       "  'atenEx existmapET',\n",
       "  '$$�size type came',\n",
       "  '< Ch�uthtain',\n",
       "  '$$�ряoughAs',\n",
       "  'you pl\\x7fcd Do',\n",
       "  'uscaatenshEx',\n",
       "  'The $$ère�Ex',\n",
       "  '// typeatenèreEx',\n",
       "  'The�èreframe prof',\n",
       "  \"� 'ector The false\",\n",
       "  'ough The� $$swer',\n",
       "  'casizeare noends',\n",
       "  'type $$aten��',\n",
       "  'caare typecreció',\n",
       "  'Theoseiz commandAs',\n",
       "  '$$ approightcri l',\n",
       "  \"The ' typeendssh\",\n",
       "  \"$$ident Theaten '\",\n",
       "  '$$ typeAs�aten',\n",
       "  '$$�oughaptili',\n",
       "  'typearebb�Array',\n",
       "  '$$ typeonymin pas',\n",
       "  \"$$ pourèreaten '\",\n",
       "  'backplesities Tudio',\n",
       "  'ident�Ex != type',\n",
       "  'oresfile nach Eng appro'],\n",
       " ['));string $$ags position',\n",
       "  '$$cióough The //',\n",
       "  \"caendsère 'Ex\",\n",
       "  'The $$ pourèreends',\n",
       "  '$$ident,\\\\ here two',\n",
       "  '$$ //ció Theough',\n",
       "  'enteendsíaopy an',\n",
       "  'no� îath android',\n",
       "  'The typeèreAs�',\n",
       "  '$$ció //oughident',\n",
       "  'being?ood� appro',\n",
       "  'lobatelyjectagsala',\n",
       "  '$$cióoughident).',\n",
       "  'Thely Cons��',\n",
       "  'typeareint Pr repr',\n",
       "  'upvertatal� actually',\n",
       "  '$$ong \\\\\\\\ type par',\n",
       "  'ca met // paraten',\n",
       "  'caряImска pour',\n",
       "  '$$ way betegció',\n",
       "  '$$ident),cióView',\n",
       "  'caframeère sum wur',\n",
       "  'т won Dieel John',\n",
       "  'ère type $$�ident',\n",
       "  'ough The //ssij',\n",
       "  'endsident pouresentwhere',\n",
       "  'ca Adère]fil',\n",
       "  'The pouraten $$size',\n",
       "  'mentspt�app met',\n",
       "  '// typeularcaelle',\n",
       "  'type //Exного ne',\n",
       "  'oughareèreidentAs'],\n",
       " ['$$ernstack\\x14пе',\n",
       "  'hatario simp like пере',\n",
       "  'ase Steuel keep cap',\n",
       "  'typepythoncreitch',\n",
       "  'ren qu skane get',\n",
       "  'ca.... contin strimes',\n",
       "  'value view paramzen fact',\n",
       "  'appro check vari k =>',\n",
       "  'ère The command\": from',\n",
       "  '$$atus consider things dé',\n",
       "  '$$ballfigrieRL',\n",
       "  '$$ліensechen Ind',\n",
       "  'typemlesenturlident',\n",
       "  'ca type If usender',\n",
       "  '$$atenito wherend',\n",
       "  'uroce console eff cap',\n",
       "  'selhi das child eas',\n",
       "  '_bb our topсть',\n",
       "  '$$ Theidentsizeough',\n",
       "  ': chang door test ident',\n",
       "  'contin $$)$ident�',\n",
       "  '$$ Thesize pourends',\n",
       "  'cating effect justise',\n",
       "  'culok angzoar',\n",
       "  '$$eschsizeiblició',\n",
       "  'type !=ca?\" view',\n",
       "  '$$g Flboxume',\n",
       "  '�� command8apt',\n",
       "  'As temfor�ML',\n",
       "  'typeidentca The command',\n",
       "  '$$ Thecióidentag',\n",
       "  '$$ TheAsidentsize'],\n",
       " ['$$sizeough Theends',\n",
       "  'usère\\r sk End',\n",
       "  '� class generalword}}',\n",
       "  'ogleпи�wardouth',\n",
       "  'carutesob install�',\n",
       "  'typeca //(\\\\ably',\n",
       "  '$$ired // hab sure',\n",
       "  '$$Trчиderose',\n",
       "  're $$ère beh exec',\n",
       "  'typeough Ed madesoft',\n",
       "  '$$isteis thoseente',\n",
       "  'lev programolaredure',\n",
       "  '$$ susendенop',\n",
       "  'shends pour //ca',\n",
       "  'ère $$ exist what Arch',\n",
       "  'contentég years n support',\n",
       "  '$$ comput Howeverspdex',\n",
       "  '$$ Thesize mit�',\n",
       "  'ère pouratenografND',\n",
       "  'atch Afterionesii Then',\n",
       "  'those $$ in� pat',\n",
       "  'type&ateg elão',\n",
       "  '$$èreuteediaector',\n",
       "  '$$ versionushext following',\n",
       "  '$$ odsiswell',\n",
       "  '$$size Theident lim',\n",
       "  'type Fl�areria',\n",
       "  'ildilder –}^{ reg',\n",
       "  '         riteeteмуties',\n",
       "  '$$Asció findident',\n",
       "  'caère us type command',\n",
       "  'typecacre >ized']]"
      ]
     },
     "execution_count": 169,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "getTop5Tokens(rotated_cache)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 287,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 49])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.012535177171230316 Normal cosine: 0.017302636057138443\n",
      "layer 1\n",
      "Rotated cosine : -0.0034974943846464157 Normal cosine: -0.027297891676425934\n",
      "layer 2\n",
      "Rotated cosine : -0.04435328394174576 Normal cosine: -0.034204546362161636\n",
      "layer 3\n",
      "Rotated cosine : -0.014343800023198128 Normal cosine: -0.030044499784708023\n",
      "layer 4\n",
      "Rotated cosine : -0.034805815666913986 Normal cosine: -0.007883468642830849\n",
      "0\n",
      "torch.Size([1, 49])\n",
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.013002317398786545 Normal cosine: 0.01869885064661503\n",
      "layer 1\n",
      "Rotated cosine : -0.003387682605534792 Normal cosine: -0.027249444276094437\n",
      "layer 2\n",
      "Rotated cosine : -0.043751269578933716 Normal cosine: -0.03447311371564865\n",
      "layer 3\n",
      "Rotated cosine : -0.015193796716630459 Normal cosine: -0.029361672699451447\n",
      "layer 4\n",
      "Rotated cosine : -0.03304667770862579 Normal cosine: -0.005950833670794964\n",
      "1\n",
      "torch.Size([1, 52])\n",
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.009238164871931076 Normal cosine: 0.016595086082816124\n",
      "layer 1\n",
      "Rotated cosine : -0.004855657462030649 Normal cosine: -0.02293470688164234\n",
      "layer 2\n",
      "Rotated cosine : -0.02818518877029419 Normal cosine: -0.013656416907906532\n",
      "layer 3\n",
      "Rotated cosine : -0.02020718716084957 Normal cosine: -0.03372317552566528\n",
      "layer 4\n",
      "Rotated cosine : -0.034299448132514954 Normal cosine: -0.009561607614159584\n",
      "2\n",
      "torch.Size([1, 73])\n",
      "torch.Size([1, 52])\n",
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.0135372094810009 Normal cosine: 0.01968557946383953\n",
      "layer 1\n",
      "Rotated cosine : 0.0015089265070855618 Normal cosine: -0.018345274031162262\n",
      "layer 2\n",
      "Rotated cosine : -0.03198796138167381 Normal cosine: -0.01948624849319458\n",
      "layer 3\n",
      "Rotated cosine : -0.01732734590768814 Normal cosine: -0.02828393504023552\n",
      "layer 4\n",
      "Rotated cosine : -0.03120437264442444 Normal cosine: -0.008646217174828053\n",
      "4\n",
      "torch.Size([1, 58])\n",
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.01858067512512207 Normal cosine: 0.024415278807282448\n",
      "layer 1\n",
      "Rotated cosine : 0.016728734597563744 Normal cosine: -0.007464686408638954\n",
      "layer 2\n",
      "Rotated cosine : -0.0273356381803751 Normal cosine: -0.011701036244630814\n",
      "layer 3\n",
      "Rotated cosine : -0.03655499592423439 Normal cosine: -0.0478806272149086\n",
      "layer 4\n",
      "Rotated cosine : -0.04261782765388489 Normal cosine: -0.019285231828689575\n",
      "5\n",
      "torch.Size([1, 49])\n",
      "torch.Size([1, 49])\n",
      "Rotated: True Normal: False, Label: True\n",
      "layer 0\n",
      "Rotated cosine : 0.009575875476002693 Normal cosine: 0.01383725181221962\n",
      "layer 1\n",
      "Rotated cosine : -0.004413474351167679 Normal cosine: -0.027711480855941772\n",
      "layer 2\n",
      "Rotated cosine : -0.04687418416142464 Normal cosine: -0.038056496530771255\n",
      "layer 3\n",
      "Rotated cosine : -0.01754022389650345 Normal cosine: -0.031448885798454285\n",
      "layer 4\n",
      "Rotated cosine : -0.03517971560359001 Normal cosine: -0.008250677958130836\n",
      "7\n"
     ]
    }
   ],
   "source": [
    "for i in range(len(data)):\n",
    "    \n",
    "    rotated_token = data[i]['rotated']\n",
    "    normal_token = data[i]['normal']\n",
    "    rotated_cache = data[i]['rotated_cache']\n",
    "    normal_cache = data[i]['normal_cache']\n",
    "    prompt = data[i]['prompt']\n",
    "    label = data[i]['label']\n",
    "    tokenize = tokenizer.encode(prompt, return_tensors='pt', add_special_tokens=False).to('cuda')\n",
    "    print(tokenize.shape)\n",
    "    final_logits = model(tokenizer.encode(prompt, return_tensors='pt', add_special_tokens=False).to('cuda'))\n",
    "    true_embedding_weight = final_logits[: , -1, :].squeeze()\n",
    "    if(rotated_token == label['short'] and normal_token != label['short']):\n",
    "        rotated_matrix = getDifference(rotated_cache, true_embedding_weight)\n",
    "        normal_matrix = getDifference(normal_cache, true_embedding_weight)\n",
    "        print(f'Rotated: {rotated_token} Normal: {normal_token}, Label: {label[\"short\"]}')\n",
    "        for j in range(5):\n",
    "            print(f'layer {j}')\n",
    "            print(f'Rotated cosine : {get_average_layer(rotated_matrix[j])} Normal cosine: {get_average_layer(normal_matrix[j])}')\n",
    "        print(i)\n",
    "        # break\n",
    "    # print(tokenizer.decode(torch.argmax(final_logits[:, -1, :], dim=1), skip_special_tokens=True))\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: transformer_lens in miniconda3/envs/ALTI/lib/python3.10/site-packages (2.6.0)\n",
      "Requirement already satisfied: accelerate>=0.23.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.32.1)\n",
      "Requirement already satisfied: beartype<0.15.0,>=0.14.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.14.1)\n",
      "Requirement already satisfied: better-abc<0.0.4,>=0.0.3 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.0.3)\n",
      "Requirement already satisfied: datasets>=2.7.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (2.20.0)\n",
      "Requirement already satisfied: einops>=0.6.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.8.0)\n",
      "Requirement already satisfied: fancy-einsum>=0.0.3 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.0.3)\n",
      "Requirement already satisfied: jaxtyping>=0.2.11 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.2.31)\n",
      "Requirement already satisfied: numpy>=1.24 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (1.26.4)\n",
      "Requirement already satisfied: pandas>=1.1.5 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (2.2.2)\n",
      "Requirement already satisfied: rich>=12.6.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (13.7.1)\n",
      "Requirement already satisfied: sentencepiece in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.2.0)\n",
      "Requirement already satisfied: torch>=1.10 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (2.1.0)\n",
      "Requirement already satisfied: tqdm>=4.64.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (4.66.4)\n",
      "Requirement already satisfied: transformers>=4.37.2 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (4.42.3)\n",
      "Requirement already satisfied: typing-extensions in .local/lib/python3.10/site-packages (from transformer_lens) (4.12.2)\n",
      "Requirement already satisfied: wandb>=0.13.5 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformer_lens) (0.17.4)\n",
      "Requirement already satisfied: packaging>=20.0 in .local/lib/python3.10/site-packages (from accelerate>=0.23.0->transformer_lens) (24.1)\n",
      "Requirement already satisfied: psutil in .local/lib/python3.10/site-packages (from accelerate>=0.23.0->transformer_lens) (6.0.0)\n",
      "Requirement already satisfied: pyyaml in miniconda3/envs/ALTI/lib/python3.10/site-packages (from accelerate>=0.23.0->transformer_lens) (6.0.1)\n",
      "Requirement already satisfied: huggingface-hub in miniconda3/envs/ALTI/lib/python3.10/site-packages (from accelerate>=0.23.0->transformer_lens) (0.23.4)\n",
      "Requirement already satisfied: safetensors>=0.3.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from accelerate>=0.23.0->transformer_lens) (0.4.3)\n",
      "Requirement already satisfied: filelock in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (3.15.4)\n",
      "Requirement already satisfied: pyarrow>=15.0.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (16.1.0)\n",
      "Requirement already satisfied: pyarrow-hotfix in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (0.6)\n",
      "Requirement already satisfied: dill<0.3.9,>=0.3.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (0.3.8)\n",
      "Requirement already satisfied: requests>=2.32.2 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (2.32.3)\n",
      "Requirement already satisfied: xxhash in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (3.4.1)\n",
      "Requirement already satisfied: multiprocess in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (0.70.16)\n",
      "Requirement already satisfied: fsspec<=2024.5.0,>=2023.1.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from fsspec[http]<=2024.5.0,>=2023.1.0->datasets>=2.7.1->transformer_lens) (2024.5.0)\n",
      "Requirement already satisfied: aiohttp in miniconda3/envs/ALTI/lib/python3.10/site-packages (from datasets>=2.7.1->transformer_lens) (3.9.5)\n",
      "Requirement already satisfied: typeguard==2.13.3 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from jaxtyping>=0.2.11->transformer_lens) (2.13.3)\n",
      "Requirement already satisfied: python-dateutil>=2.8.2 in .local/lib/python3.10/site-packages (from pandas>=1.1.5->transformer_lens) (2.9.0.post0)\n",
      "Requirement already satisfied: pytz>=2020.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from pandas>=1.1.5->transformer_lens) (2024.1)\n",
      "Requirement already satisfied: tzdata>=2022.7 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from pandas>=1.1.5->transformer_lens) (2024.1)\n",
      "Requirement already satisfied: markdown-it-py>=2.2.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from rich>=12.6.0->transformer_lens) (3.0.0)\n",
      "Requirement already satisfied: pygments<3.0.0,>=2.13.0 in .local/lib/python3.10/site-packages (from rich>=12.6.0->transformer_lens) (2.18.0)\n",
      "Requirement already satisfied: sympy in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (1.13.0)\n",
      "Requirement already satisfied: networkx in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (3.3)\n",
      "Requirement already satisfied: jinja2 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (3.1.4)\n",
      "Requirement already satisfied: nvidia-cuda-nvrtc-cu12==12.1.105 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.105)\n",
      "Requirement already satisfied: nvidia-cuda-runtime-cu12==12.1.105 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.105)\n",
      "Requirement already satisfied: nvidia-cuda-cupti-cu12==12.1.105 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.105)\n",
      "Requirement already satisfied: nvidia-cudnn-cu12==8.9.2.26 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (8.9.2.26)\n",
      "Requirement already satisfied: nvidia-cublas-cu12==12.1.3.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.3.1)\n",
      "Requirement already satisfied: nvidia-cufft-cu12==11.0.2.54 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (11.0.2.54)\n",
      "Requirement already satisfied: nvidia-curand-cu12==10.3.2.106 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (10.3.2.106)\n",
      "Requirement already satisfied: nvidia-cusolver-cu12==11.4.5.107 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (11.4.5.107)\n",
      "Requirement already satisfied: nvidia-cusparse-cu12==12.1.0.106 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.0.106)\n",
      "Requirement already satisfied: nvidia-nccl-cu12==2.18.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (2.18.1)\n",
      "Requirement already satisfied: nvidia-nvtx-cu12==12.1.105 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (12.1.105)\n",
      "Requirement already satisfied: triton==2.1.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from torch>=1.10->transformer_lens) (2.1.0)\n",
      "Requirement already satisfied: nvidia-nvjitlink-cu12 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from nvidia-cusolver-cu12==11.4.5.107->torch>=1.10->transformer_lens) (12.5.82)\n",
      "Requirement already satisfied: regex!=2019.12.17 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformers>=4.37.2->transformer_lens) (2024.5.15)\n",
      "Requirement already satisfied: tokenizers<0.20,>=0.19 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from transformers>=4.37.2->transformer_lens) (0.19.1)\n",
      "Requirement already satisfied: click!=8.0.0,>=7.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (8.1.7)\n",
      "Requirement already satisfied: docker-pycreds>=0.4.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (0.4.0)\n",
      "Requirement already satisfied: gitpython!=3.1.29,>=1.0.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (3.1.43)\n",
      "Requirement already satisfied: platformdirs in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (4.2.2)\n",
      "Requirement already satisfied: protobuf!=4.21.0,<6,>=3.19.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (4.25.3)\n",
      "Requirement already satisfied: sentry-sdk>=1.0.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (2.9.0)\n",
      "Requirement already satisfied: setproctitle in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (1.3.3)\n",
      "Requirement already satisfied: setuptools in miniconda3/envs/ALTI/lib/python3.10/site-packages (from wandb>=0.13.5->transformer_lens) (69.5.1)\n",
      "Requirement already satisfied: six>=1.4.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from docker-pycreds>=0.4.0->wandb>=0.13.5->transformer_lens) (1.16.0)\n",
      "Requirement already satisfied: aiosignal>=1.1.2 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (1.3.1)\n",
      "Requirement already satisfied: attrs>=17.3.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (23.2.0)\n",
      "Requirement already satisfied: frozenlist>=1.1.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (1.4.1)\n",
      "Requirement already satisfied: multidict<7.0,>=4.5 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (6.0.5)\n",
      "Requirement already satisfied: yarl<2.0,>=1.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (1.9.4)\n",
      "Requirement already satisfied: async-timeout<5.0,>=4.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from aiohttp->datasets>=2.7.1->transformer_lens) (4.0.3)\n",
      "Requirement already satisfied: gitdb<5,>=4.0.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from gitpython!=3.1.29,>=1.0.0->wandb>=0.13.5->transformer_lens) (4.0.11)\n",
      "Requirement already satisfied: mdurl~=0.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from markdown-it-py>=2.2.0->rich>=12.6.0->transformer_lens) (0.1.2)\n",
      "Requirement already satisfied: charset-normalizer<4,>=2 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from requests>=2.32.2->datasets>=2.7.1->transformer_lens) (3.3.2)\n",
      "Requirement already satisfied: idna<4,>=2.5 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from requests>=2.32.2->datasets>=2.7.1->transformer_lens) (3.7)\n",
      "Requirement already satisfied: urllib3<3,>=1.21.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from requests>=2.32.2->datasets>=2.7.1->transformer_lens) (2.2.2)\n",
      "Requirement already satisfied: certifi>=2017.4.17 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from requests>=2.32.2->datasets>=2.7.1->transformer_lens) (2024.7.4)\n",
      "Requirement already satisfied: MarkupSafe>=2.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from jinja2->torch>=1.10->transformer_lens) (2.1.5)\n",
      "Requirement already satisfied: mpmath<1.4,>=1.1.0 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from sympy->torch>=1.10->transformer_lens) (1.3.0)\n",
      "Requirement already satisfied: smmap<6,>=3.0.1 in miniconda3/envs/ALTI/lib/python3.10/site-packages (from gitdb<5,>=4.0.1->gitpython!=3.1.29,>=1.0.0->wandb>=0.13.5->transformer_lens) (5.0.1)\n"
     ]
    }
   ],
   "source": [
    "!pip install transformer_lens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "import plotly.express as px\n",
    "import transformer_lens.utils as utils\n",
    "\n",
    "def imshow(tensor, render=True, renderer=None, **kwargs):\n",
    "    fig = px.imshow(utils.to_numpy(tensor), color_continuous_midpoint=0.0, color_continuous_scale='RdBu', **kwargs)\n",
    "    if render:\n",
    "        fig.show(renderer=renderer)\n",
    "        \n",
    "    # tensor = utils.to_numpy(tensor)\n",
    "    # px.imshow(tensor).show(renderer=renderer)\n",
    "# def scatter(x,y, xaxis=\"\", yaxis=\"\", caxis=\"\", renderer=None, **kwargs):\n",
    "#     x = utils.to_numpy(x)\n",
    "#     y = utils.to_numpy(y)\n",
    "#     px.scatter(x=x, y=y, labels={xaxis: xaxis, yaxis: yaxis, caxis: caxis}, **kwargs).show(renderer=renderer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "x: %{x}<br>y: %{y}<br>color: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": [
          [
           0.17625181376934052,
           0.14857089519500732,
           -0.12036498636007309,
           0.1427510380744934,
           -0.2905092239379883,
           0.2235170602798462,
           -0.17767412960529327,
           0.22629328072071075,
           0.18945838510990143,
           -0.394915372133255,
           0.35390013456344604,
           -0.3300478160381317,
           -0.08959126472473145,
           0.33956605195999146,
           -0.07310859113931656,
           0.02167314663529396,
           -0.036937616765499115,
           0.20114581286907196,
           0.01692027784883976,
           -0.3052551746368408,
           -0.25486472249031067,
           -0.038881827145814896,
           0.40425777435302734,
           0.027930615469813347,
           0.1643448919057846,
           -0.14450900256633759,
           0.04072605073451996,
           0.2820810079574585,
           -0.16412878036499023,
           -0.2241487205028534,
           0.07138794660568237,
           -0.07941099256277084
          ],
          [
           0.08833355456590652,
           0.018415285274386406,
           0.004228564910590649,
           -0.344455748796463,
           -0.2858770191669464,
           -0.22151316702365875,
           -0.23323319852352142,
           0.033614251762628555,
           0.15246467292308807,
           0.0347759835422039,
           -0.08613528311252594,
           0.07950520515441895,
           0.4016610383987427,
           0.13098430633544922,
           0.17704543471336365,
           -0.22674228250980377,
           0.171933114528656,
           -0.31853652000427246,
           0.20508059859275818,
           0.008392960764467716,
           0.003820681245997548,
           -0.055442314594984055,
           -0.18517348170280457,
           0.39327767491340637,
           0.1446850448846817,
           -0.13445691764354706,
           0.09257328510284424,
           0.195693239569664,
           -0.37152257561683655,
           0.14385953545570374,
           0.04959415644407272,
           -0.20808130502700806
          ],
          [
           -0.06154625490307808,
           0.3163864016532898,
           -0.3185229003429413,
           -0.10454381257295609,
           0.004907090682536364,
           0.4025796949863434,
           -0.33014166355133057,
           0.05415354669094086,
           -0.00259964051656425,
           0.214878648519516,
           0.27219071984291077,
           -0.021026218309998512,
           0.18359574675559998,
           -0.5379012227058411,
           -0.1017896831035614,
           0.014266415499150753,
           0.4447062313556671,
           -0.2508990168571472,
           -0.10532736033201218,
           -0.2125600129365921,
           -0.04866648092865944,
           -0.26564711332321167,
           -0.18642175197601318,
           0.17135803401470184,
           -0.28413164615631104,
           0.11662877351045609,
           -0.23945045471191406,
           -0.2996603846549988,
           -0.05456839129328728,
           -0.057984039187431335,
           -0.052159834653139114,
           -0.16007736325263977
          ],
          [
           -0.060422372072935104,
           -0.06267596036195755,
           -0.41717880964279175,
           0.08419248461723328,
           -0.10376863926649094,
           0.08324223011732101,
           0.09291724860668182,
           0.140094593167305,
           -0.060354433953762054,
           -0.5345169305801392,
           -0.11918685585260391,
           0.004139073193073273,
           0.3059692680835724,
           0.18419359624385834,
           -0.32828018069267273,
           -0.16905048489570618,
           0.176696315407753,
           -0.14847126603126526,
           -0.012510377913713455,
           0.09979716688394547,
           -0.039980679750442505,
           -0.06989581137895584,
           0.011051846668124199,
           0.29395565390586853,
           0.1029580608010292,
           0.08873890340328217,
           0.03677315264940262,
           0.34979841113090515,
           -0.16126251220703125,
           0.10430711507797241,
           -0.2796800434589386,
           -0.15287713706493378
          ],
          [
           -0.21513596177101135,
           -0.027419298887252808,
           -0.17592883110046387,
           -0.12848292291164398,
           -0.1923394799232483,
           0.1944364458322525,
           0.16857649385929108,
           0.17950439453125,
           0.25700798630714417,
           -0.0573459193110466,
           0.2985297441482544,
           0.35830989480018616,
           -0.12413528561592102,
           -0.38295429944992065,
           -0.020564880222082138,
           0.19649165868759155,
           0.055455245077610016,
           -0.1905852109193802,
           -0.27462974190711975,
           0.04416165128350258,
           -0.3512965738773346,
           0.2005598247051239,
           -0.30348750948905945,
           -0.32853516936302185,
           -0.23824317753314972,
           0.24922184646129608,
           -0.08985481411218643,
           0.13195356726646423,
           0.056487202644348145,
           -0.19520333409309387,
           -0.32677459716796875,
           0.10647023469209671
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ]
         ]
        }
       ],
       "layout": {
        "coloraxis": {
         "cmid": 0,
         "colorscale": [
          [
           0,
           "rgb(103,0,31)"
          ],
          [
           0.1,
           "rgb(178,24,43)"
          ],
          [
           0.2,
           "rgb(214,96,77)"
          ],
          [
           0.3,
           "rgb(244,165,130)"
          ],
          [
           0.4,
           "rgb(253,219,199)"
          ],
          [
           0.5,
           "rgb(247,247,247)"
          ],
          [
           0.6,
           "rgb(209,229,240)"
          ],
          [
           0.7,
           "rgb(146,197,222)"
          ],
          [
           0.8,
           "rgb(67,147,195)"
          ],
          [
           0.9,
           "rgb(33,102,172)"
          ],
          [
           1,
           "rgb(5,48,97)"
          ]
         ]
        },
        "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
          }
         }
        },
        "title": {
         "text": "Rotated"
        },
        "xaxis": {
         "anchor": "y",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "scaleanchor": "y"
        },
        "yaxis": {
         "anchor": "x",
         "autorange": "reversed",
         "constrain": "domain",
         "domain": [
          0,
          1
         ]
        }
       }
      },
      "text/html": [
       "<div>                            <div id=\"b66c3467-6aed-4e74-b8cb-f549df6b6a1d\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"b66c3467-6aed-4e74-b8cb-f549df6b6a1d\")) {                    Plotly.newPlot(                        \"b66c3467-6aed-4e74-b8cb-f549df6b6a1d\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[0.17625181376934052,0.14857089519500732,-0.12036498636007309,0.1427510380744934,-0.2905092239379883,0.2235170602798462,-0.17767412960529327,0.22629328072071075,0.18945838510990143,-0.394915372133255,0.35390013456344604,-0.3300478160381317,-0.08959126472473145,0.33956605195999146,-0.07310859113931656,0.02167314663529396,-0.036937616765499115,0.20114581286907196,0.01692027784883976,-0.3052551746368408,-0.25486472249031067,-0.038881827145814896,0.40425777435302734,0.027930615469813347,0.1643448919057846,-0.14450900256633759,0.04072605073451996,0.2820810079574585,-0.16412878036499023,-0.2241487205028534,0.07138794660568237,-0.07941099256277084],[0.08833355456590652,0.018415285274386406,0.004228564910590649,-0.344455748796463,-0.2858770191669464,-0.22151316702365875,-0.23323319852352142,0.033614251762628555,0.15246467292308807,0.0347759835422039,-0.08613528311252594,0.07950520515441895,0.4016610383987427,0.13098430633544922,0.17704543471336365,-0.22674228250980377,0.171933114528656,-0.31853652000427246,0.20508059859275818,0.008392960764467716,0.003820681245997548,-0.055442314594984055,-0.18517348170280457,0.39327767491340637,0.1446850448846817,-0.13445691764354706,0.09257328510284424,0.195693239569664,-0.37152257561683655,0.14385953545570374,0.04959415644407272,-0.20808130502700806],[-0.06154625490307808,0.3163864016532898,-0.3185229003429413,-0.10454381257295609,0.004907090682536364,0.4025796949863434,-0.33014166355133057,0.05415354669094086,-0.00259964051656425,0.214878648519516,0.27219071984291077,-0.021026218309998512,0.18359574675559998,-0.5379012227058411,-0.1017896831035614,0.014266415499150753,0.4447062313556671,-0.2508990168571472,-0.10532736033201218,-0.2125600129365921,-0.04866648092865944,-0.26564711332321167,-0.18642175197601318,0.17135803401470184,-0.28413164615631104,0.11662877351045609,-0.23945045471191406,-0.2996603846549988,-0.05456839129328728,-0.057984039187431335,-0.052159834653139114,-0.16007736325263977],[-0.060422372072935104,-0.06267596036195755,-0.41717880964279175,0.08419248461723328,-0.10376863926649094,0.08324223011732101,0.09291724860668182,0.140094593167305,-0.060354433953762054,-0.5345169305801392,-0.11918685585260391,0.004139073193073273,0.3059692680835724,0.18419359624385834,-0.32828018069267273,-0.16905048489570618,0.176696315407753,-0.14847126603126526,-0.012510377913713455,0.09979716688394547,-0.039980679750442505,-0.06989581137895584,0.011051846668124199,0.29395565390586853,0.1029580608010292,0.08873890340328217,0.03677315264940262,0.34979841113090515,-0.16126251220703125,0.10430711507797241,-0.2796800434589386,-0.15287713706493378],[-0.21513596177101135,-0.027419298887252808,-0.17592883110046387,-0.12848292291164398,-0.1923394799232483,0.1944364458322525,0.16857649385929108,0.17950439453125,0.25700798630714417,-0.0573459193110466,0.2985297441482544,0.35830989480018616,-0.12413528561592102,-0.38295429944992065,-0.020564880222082138,0.19649165868759155,0.055455245077610016,-0.1905852109193802,-0.27462974190711975,0.04416165128350258,-0.3512965738773346,0.2005598247051239,-0.30348750948905945,-0.32853516936302185,-0.23824317753314972,0.24922184646129608,-0.08985481411218643,0.13195356726646423,0.056487202644348145,-0.19520333409309387,-0.32677459716796875,0.10647023469209671],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"x: %{x}\\u003cbr\\u003ey: %{y}\\u003cbr\\u003ecolor: %{z}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.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.0,\"#f0f921\"]],\"sequentialminus\":[[0.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.0,\"#f0f921\"]],\"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\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"scaleanchor\":\"y\",\"constrain\":\"domain\"},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"autorange\":\"reversed\",\"constrain\":\"domain\"},\"coloraxis\":{\"colorscale\":[[0.0,\"rgb(103,0,31)\"],[0.1,\"rgb(178,24,43)\"],[0.2,\"rgb(214,96,77)\"],[0.3,\"rgb(244,165,130)\"],[0.4,\"rgb(253,219,199)\"],[0.5,\"rgb(247,247,247)\"],[0.6,\"rgb(209,229,240)\"],[0.7,\"rgb(146,197,222)\"],[0.8,\"rgb(67,147,195)\"],[0.9,\"rgb(33,102,172)\"],[1.0,\"rgb(5,48,97)\"]],\"cmid\":0.0},\"title\":{\"text\":\"Rotated\"}},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('b66c3467-6aed-4e74-b8cb-f549df6b6a1d');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(rotated_matrix, title='Rotated')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "def difference(matrixA, matrixB):\n",
    "    diff = [[0 for _ in range(32)] for _ in range(5 * 2)]\n",
    "    for i in range(5):\n",
    "        for j in range(32):\n",
    "            diff[i][j] = matrixA[i][j] - matrixB[i][j]\n",
    "    return diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "x: %{x}<br>y: %{y}<br>color: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": [
          [
           -0.1036064475774765,
           -0.05291779339313507,
           -0.03743667155504227,
           0.025196276605129242,
           0.08499115705490112,
           0.00016131997108459473,
           -0.02351526916027069,
           0.10777892917394638,
           0.025295063853263855,
           -0.014131546020507812,
           0.045261532068252563,
           0.06661748886108398,
           -0.09943175315856934,
           0.045288681983947754,
           -0.09081359207630157,
           0.009980707429349422,
           0.03562306612730026,
           0.022731155157089233,
           -0.04067712277173996,
           0.04286119341850281,
           -0.02158205211162567,
           -0.016776934266090393,
           -0.03988984227180481,
           -0.018125487491488457,
           -0.030569002032279968,
           -0.002909421920776367,
           -0.09321756660938263,
           0.030422717332839966,
           -0.03813675045967102,
           -0.027538016438484192,
           0.09381581842899323,
           -0.021113891154527664
          ],
          [
           0.16585516929626465,
           0.0350901335477829,
           0.04938622564077377,
           -0.06406939029693604,
           0.04224896430969238,
           0.05222614109516144,
           -0.03447742760181427,
           0.043831612914800644,
           0.1963030993938446,
           0.020272040739655495,
           0.1947576254606247,
           0.00749969482421875,
           0.07339280843734741,
           -0.09461361169815063,
           0.08677081018686295,
           -0.20974743366241455,
           0.008538082242012024,
           -0.03297305107116699,
           -0.05054891109466553,
           -0.0700468048453331,
           -0.0973070040345192,
           0.05283365771174431,
           0.04308246076107025,
           0.08662757277488708,
           0.04932033270597458,
           0.07634837925434113,
           -0.014944061636924744,
           0.09867388755083084,
           0.01938912272453308,
           0.10017125308513641,
           -0.22757390141487122,
           0.13921883702278137
          ],
          [
           0.0706559270620346,
           0.014491140842437744,
           0.044852495193481445,
           0.17383429408073425,
           0.14221546053886414,
           0.05869477987289429,
           -0.2132866084575653,
           0.18357814848423004,
           -0.05414748936891556,
           -0.012360140681266785,
           0.17136433720588684,
           0.020636601373553276,
           -0.2205740511417389,
           -0.003949403762817383,
           -0.07001075893640518,
           -0.15207324922084808,
           0.026552170515060425,
           -0.011867538094520569,
           -0.031316615641117096,
           -0.059693723917007446,
           0.08749543130397797,
           -0.06152050197124481,
           -0.061146363615989685,
           -0.21506722271442413,
           -0.06398944556713104,
           0.030453801155090332,
           -0.05165773630142212,
           0.015527009963989258,
           -0.008720453828573227,
           0.03564246743917465,
           -0.03885018825531006,
           -0.02792857587337494
          ],
          [
           -0.15443971753120422,
           -0.09470948576927185,
           -0.06949299573898315,
           0.11688023805618286,
           0.057460956275463104,
           0.07235116511583328,
           0.10276120156049728,
           -0.020900920033454895,
           0.04714025557041168,
           0.005968034267425537,
           -0.043087445199489594,
           0.05017363652586937,
           0.24325266480445862,
           -0.031172126531600952,
           -0.20586737990379333,
           -0.08267281949520111,
           -0.1204172819852829,
           -0.06763216108083725,
           0.09288087487220764,
           -0.1835154891014099,
           -0.047215938568115234,
           0.06955494731664658,
           0.12376964092254639,
           0.16163338720798492,
           0.017789259552955627,
           0.06729622930288315,
           0.018786052241921425,
           0.02128678560256958,
           0.026099279522895813,
           0.17563524842262268,
           -0.014302551746368408,
           0.10978318750858307
          ],
          [
           -0.024326160550117493,
           0.004852224141359329,
           0.05184192955493927,
           -0.1674637496471405,
           0.0337517112493515,
           -0.011135831475257874,
           -0.05097338557243347,
           -0.10552090406417847,
           -0.052446573972702026,
           -0.03290437534451485,
           0.2162443995475769,
           0.12906084954738617,
           -0.04240242391824722,
           -0.10062393546104431,
           -0.047911278903484344,
           -0.10744374990463257,
           -0.14814957976341248,
           -0.1420651227235794,
           -0.10663466155529022,
           0.1028854250907898,
           -0.0877130925655365,
           0.05816522240638733,
           -0.07394692301750183,
           -0.1388441026210785,
           -0.024034947156906128,
           0.030798062682151794,
           -0.07133753597736359,
           0.11695074290037155,
           -0.07632242143154144,
           0.057560086250305176,
           -0.0499131977558136,
           -0.0017258450388908386
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ]
         ]
        }
       ],
       "layout": {
        "coloraxis": {
         "cmid": 0,
         "colorscale": [
          [
           0,
           "rgb(103,0,31)"
          ],
          [
           0.1,
           "rgb(178,24,43)"
          ],
          [
           0.2,
           "rgb(214,96,77)"
          ],
          [
           0.3,
           "rgb(244,165,130)"
          ],
          [
           0.4,
           "rgb(253,219,199)"
          ],
          [
           0.5,
           "rgb(247,247,247)"
          ],
          [
           0.6,
           "rgb(209,229,240)"
          ],
          [
           0.7,
           "rgb(146,197,222)"
          ],
          [
           0.8,
           "rgb(67,147,195)"
          ],
          [
           0.9,
           "rgb(33,102,172)"
          ],
          [
           1,
           "rgb(5,48,97)"
          ]
         ]
        },
        "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
          }
         }
        },
        "title": {
         "text": "Diff"
        },
        "xaxis": {
         "anchor": "y",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "scaleanchor": "y"
        },
        "yaxis": {
         "anchor": "x",
         "autorange": "reversed",
         "constrain": "domain",
         "domain": [
          0,
          1
         ]
        }
       }
      },
      "text/html": [
       "<div>                            <div id=\"693c88c3-5095-4711-80b5-315b5270e7d7\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"693c88c3-5095-4711-80b5-315b5270e7d7\")) {                    Plotly.newPlot(                        \"693c88c3-5095-4711-80b5-315b5270e7d7\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[-0.1036064475774765,-0.05291779339313507,-0.03743667155504227,0.025196276605129242,0.08499115705490112,0.00016131997108459473,-0.02351526916027069,0.10777892917394638,0.025295063853263855,-0.014131546020507812,0.045261532068252563,0.06661748886108398,-0.09943175315856934,0.045288681983947754,-0.09081359207630157,0.009980707429349422,0.03562306612730026,0.022731155157089233,-0.04067712277173996,0.04286119341850281,-0.02158205211162567,-0.016776934266090393,-0.03988984227180481,-0.018125487491488457,-0.030569002032279968,-0.002909421920776367,-0.09321756660938263,0.030422717332839966,-0.03813675045967102,-0.027538016438484192,0.09381581842899323,-0.021113891154527664],[0.16585516929626465,0.0350901335477829,0.04938622564077377,-0.06406939029693604,0.04224896430969238,0.05222614109516144,-0.03447742760181427,0.043831612914800644,0.1963030993938446,0.020272040739655495,0.1947576254606247,0.00749969482421875,0.07339280843734741,-0.09461361169815063,0.08677081018686295,-0.20974743366241455,0.008538082242012024,-0.03297305107116699,-0.05054891109466553,-0.0700468048453331,-0.0973070040345192,0.05283365771174431,0.04308246076107025,0.08662757277488708,0.04932033270597458,0.07634837925434113,-0.014944061636924744,0.09867388755083084,0.01938912272453308,0.10017125308513641,-0.22757390141487122,0.13921883702278137],[0.0706559270620346,0.014491140842437744,0.044852495193481445,0.17383429408073425,0.14221546053886414,0.05869477987289429,-0.2132866084575653,0.18357814848423004,-0.05414748936891556,-0.012360140681266785,0.17136433720588684,0.020636601373553276,-0.2205740511417389,-0.003949403762817383,-0.07001075893640518,-0.15207324922084808,0.026552170515060425,-0.011867538094520569,-0.031316615641117096,-0.059693723917007446,0.08749543130397797,-0.06152050197124481,-0.061146363615989685,-0.21506722271442413,-0.06398944556713104,0.030453801155090332,-0.05165773630142212,0.015527009963989258,-0.008720453828573227,0.03564246743917465,-0.03885018825531006,-0.02792857587337494],[-0.15443971753120422,-0.09470948576927185,-0.06949299573898315,0.11688023805618286,0.057460956275463104,0.07235116511583328,0.10276120156049728,-0.020900920033454895,0.04714025557041168,0.005968034267425537,-0.043087445199489594,0.05017363652586937,0.24325266480445862,-0.031172126531600952,-0.20586737990379333,-0.08267281949520111,-0.1204172819852829,-0.06763216108083725,0.09288087487220764,-0.1835154891014099,-0.047215938568115234,0.06955494731664658,0.12376964092254639,0.16163338720798492,0.017789259552955627,0.06729622930288315,0.018786052241921425,0.02128678560256958,0.026099279522895813,0.17563524842262268,-0.014302551746368408,0.10978318750858307],[-0.024326160550117493,0.004852224141359329,0.05184192955493927,-0.1674637496471405,0.0337517112493515,-0.011135831475257874,-0.05097338557243347,-0.10552090406417847,-0.052446573972702026,-0.03290437534451485,0.2162443995475769,0.12906084954738617,-0.04240242391824722,-0.10062393546104431,-0.047911278903484344,-0.10744374990463257,-0.14814957976341248,-0.1420651227235794,-0.10663466155529022,0.1028854250907898,-0.0877130925655365,0.05816522240638733,-0.07394692301750183,-0.1388441026210785,-0.024034947156906128,0.030798062682151794,-0.07133753597736359,0.11695074290037155,-0.07632242143154144,0.057560086250305176,-0.0499131977558136,-0.0017258450388908386],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"x: %{x}\\u003cbr\\u003ey: %{y}\\u003cbr\\u003ecolor: %{z}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.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.0,\"#f0f921\"]],\"sequentialminus\":[[0.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.0,\"#f0f921\"]],\"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\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"scaleanchor\":\"y\",\"constrain\":\"domain\"},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"autorange\":\"reversed\",\"constrain\":\"domain\"},\"coloraxis\":{\"colorscale\":[[0.0,\"rgb(103,0,31)\"],[0.1,\"rgb(178,24,43)\"],[0.2,\"rgb(214,96,77)\"],[0.3,\"rgb(244,165,130)\"],[0.4,\"rgb(253,219,199)\"],[0.5,\"rgb(247,247,247)\"],[0.6,\"rgb(209,229,240)\"],[0.7,\"rgb(146,197,222)\"],[0.8,\"rgb(67,147,195)\"],[0.9,\"rgb(33,102,172)\"],[1.0,\"rgb(5,48,97)\"]],\"cmid\":0.0},\"title\":{\"text\":\"Diff\"}},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('693c88c3-5095-4711-80b5-315b5270e7d7');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(difference(rotated_matrix, normal_matrix), title='Diff')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "average_rotated = 0\n",
    "average_normal = 0\n",
    "for i in range(5):\n",
    "    for j in range(32):\n",
    "        average_rotated += rotated_matrix[i][j]\n",
    "        average_normal += normal_matrix[i][j]\n",
    "average_rotated /= 160\n",
    "average_normal /= 160"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-0.0169) tensor(-0.0164)\n"
     ]
    }
   ],
   "source": [
    "print(average_rotated, average_normal)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "x: %{x}<br>y: %{y}<br>color: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": [
          [
           0.279858261346817,
           0.2014886885881424,
           -0.08292831480503082,
           0.11755476146936417,
           -0.3755003809928894,
           0.2233557403087616,
           -0.15415886044502258,
           0.11851435154676437,
           0.16416332125663757,
           -0.3807838261127472,
           0.3086386024951935,
           -0.3966653048992157,
           0.00984049029648304,
           0.2942773699760437,
           0.017705002799630165,
           0.011692439205944538,
           -0.07256068289279938,
           0.17841465771198273,
           0.05759740248322487,
           -0.34811636805534363,
           -0.233282670378685,
           -0.022104892879724503,
           0.44414761662483215,
           0.046056102961301804,
           0.19491389393806458,
           -0.14159958064556122,
           0.1339436173439026,
           0.25165829062461853,
           -0.1259920299053192,
           -0.1966107040643692,
           -0.022427873685956,
           -0.05829710140824318
          ],
          [
           -0.07752162218093872,
           -0.01667485013604164,
           -0.04515765979886055,
           -0.280386358499527,
           -0.3281259834766388,
           -0.2737393081188202,
           -0.19875577092170715,
           -0.010217361152172089,
           -0.04383843392133713,
           0.014503942802548409,
           -0.28089290857315063,
           0.0720055103302002,
           0.32826822996139526,
           0.22559791803359985,
           0.0902746245265007,
           -0.016994841396808624,
           0.16339503228664398,
           -0.28556346893310547,
           0.2556295096874237,
           0.07843976467847824,
           0.10112768411636353,
           -0.10827597230672836,
           -0.22825594246387482,
           0.3066501021385193,
           0.09536471217870712,
           -0.21080529689788818,
           0.10751734673976898,
           0.09701935201883316,
           -0.39091169834136963,
           0.04368828237056732,
           0.27716806530952454,
           -0.34730014204978943
          ],
          [
           -0.1322021782398224,
           0.30189526081085205,
           -0.36337539553642273,
           -0.27837809920310974,
           -0.13730837404727936,
           0.3438849151134491,
           -0.11685505509376526,
           -0.12942460179328918,
           0.05154784768819809,
           0.22723878920078278,
           0.10082637518644333,
           -0.04166281968355179,
           0.40416979789733887,
           -0.5339518189430237,
           -0.03177892416715622,
           0.1663396656513214,
           0.4181540608406067,
           -0.23903147876262665,
           -0.07401074469089508,
           -0.15286628901958466,
           -0.1361619085073471,
           -0.20412661135196686,
           -0.1252753883600235,
           0.386425256729126,
           -0.22014220058918,
           0.08617497235536575,
           -0.18779271841049194,
           -0.31518739461898804,
           -0.04584793746471405,
           -0.09362650662660599,
           -0.013309644535183907,
           -0.13214878737926483
          ],
          [
           0.09401734918355942,
           0.0320335291326046,
           -0.3476858139038086,
           -0.03268775716423988,
           -0.16122959554195404,
           0.010891064070165157,
           -0.00984395295381546,
           0.1609955132007599,
           -0.10749468952417374,
           -0.5404849648475647,
           -0.07609941065311432,
           -0.0460345633327961,
           0.06271659582853317,
           0.2153657227754593,
           -0.12241280823945999,
           -0.08637766540050507,
           0.2971135973930359,
           -0.08083910495042801,
           -0.1053912490606308,
           0.2833126485347748,
           0.0072352588176727295,
           -0.13945075869560242,
           -0.11271779239177704,
           0.1323222666978836,
           0.08516880124807358,
           0.021442675963044167,
           0.017987100407481194,
           0.32851162552833557,
           -0.18736179172992706,
           -0.07132813334465027,
           -0.2653774917125702,
           -0.26266032457351685
          ],
          [
           -0.19080980122089386,
           -0.03227152302861214,
           -0.22777076065540314,
           0.03898082301020622,
           -0.2260911911725998,
           0.20557227730751038,
           0.21954987943172455,
           0.28502529859542847,
           0.3094545602798462,
           -0.024441543966531754,
           0.08228534460067749,
           0.2292490452528,
           -0.0817328616976738,
           -0.28233036398887634,
           0.027346396818757057,
           0.3039354085922241,
           0.2036048173904419,
           -0.04852008447051048,
           -0.16799508035182953,
           -0.058723777532577515,
           -0.2635834813117981,
           0.14239460229873657,
           -0.22954058647155762,
           -0.18969106674194336,
           -0.2142082303762436,
           0.2184237837791443,
           -0.018517278134822845,
           0.015002825297415257,
           0.1328096240758896,
           -0.25276342034339905,
           -0.27686139941215515,
           0.10819607973098755
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ],
          [
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0,
           0
          ]
         ]
        }
       ],
       "layout": {
        "coloraxis": {
         "cmid": 0,
         "colorscale": [
          [
           0,
           "rgb(103,0,31)"
          ],
          [
           0.1,
           "rgb(178,24,43)"
          ],
          [
           0.2,
           "rgb(214,96,77)"
          ],
          [
           0.3,
           "rgb(244,165,130)"
          ],
          [
           0.4,
           "rgb(253,219,199)"
          ],
          [
           0.5,
           "rgb(247,247,247)"
          ],
          [
           0.6,
           "rgb(209,229,240)"
          ],
          [
           0.7,
           "rgb(146,197,222)"
          ],
          [
           0.8,
           "rgb(67,147,195)"
          ],
          [
           0.9,
           "rgb(33,102,172)"
          ],
          [
           1,
           "rgb(5,48,97)"
          ]
         ]
        },
        "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
          }
         }
        },
        "title": {
         "text": "Normal"
        },
        "xaxis": {
         "anchor": "y",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "scaleanchor": "y"
        },
        "yaxis": {
         "anchor": "x",
         "autorange": "reversed",
         "constrain": "domain",
         "domain": [
          0,
          1
         ]
        }
       }
      },
      "text/html": [
       "<div>                            <div id=\"55827f07-e587-42cd-84c8-48c444664080\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"55827f07-e587-42cd-84c8-48c444664080\")) {                    Plotly.newPlot(                        \"55827f07-e587-42cd-84c8-48c444664080\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[0.279858261346817,0.2014886885881424,-0.08292831480503082,0.11755476146936417,-0.3755003809928894,0.2233557403087616,-0.15415886044502258,0.11851435154676437,0.16416332125663757,-0.3807838261127472,0.3086386024951935,-0.3966653048992157,0.00984049029648304,0.2942773699760437,0.017705002799630165,0.011692439205944538,-0.07256068289279938,0.17841465771198273,0.05759740248322487,-0.34811636805534363,-0.233282670378685,-0.022104892879724503,0.44414761662483215,0.046056102961301804,0.19491389393806458,-0.14159958064556122,0.1339436173439026,0.25165829062461853,-0.1259920299053192,-0.1966107040643692,-0.022427873685956,-0.05829710140824318],[-0.07752162218093872,-0.01667485013604164,-0.04515765979886055,-0.280386358499527,-0.3281259834766388,-0.2737393081188202,-0.19875577092170715,-0.010217361152172089,-0.04383843392133713,0.014503942802548409,-0.28089290857315063,0.0720055103302002,0.32826822996139526,0.22559791803359985,0.0902746245265007,-0.016994841396808624,0.16339503228664398,-0.28556346893310547,0.2556295096874237,0.07843976467847824,0.10112768411636353,-0.10827597230672836,-0.22825594246387482,0.3066501021385193,0.09536471217870712,-0.21080529689788818,0.10751734673976898,0.09701935201883316,-0.39091169834136963,0.04368828237056732,0.27716806530952454,-0.34730014204978943],[-0.1322021782398224,0.30189526081085205,-0.36337539553642273,-0.27837809920310974,-0.13730837404727936,0.3438849151134491,-0.11685505509376526,-0.12942460179328918,0.05154784768819809,0.22723878920078278,0.10082637518644333,-0.04166281968355179,0.40416979789733887,-0.5339518189430237,-0.03177892416715622,0.1663396656513214,0.4181540608406067,-0.23903147876262665,-0.07401074469089508,-0.15286628901958466,-0.1361619085073471,-0.20412661135196686,-0.1252753883600235,0.386425256729126,-0.22014220058918,0.08617497235536575,-0.18779271841049194,-0.31518739461898804,-0.04584793746471405,-0.09362650662660599,-0.013309644535183907,-0.13214878737926483],[0.09401734918355942,0.0320335291326046,-0.3476858139038086,-0.03268775716423988,-0.16122959554195404,0.010891064070165157,-0.00984395295381546,0.1609955132007599,-0.10749468952417374,-0.5404849648475647,-0.07609941065311432,-0.0460345633327961,0.06271659582853317,0.2153657227754593,-0.12241280823945999,-0.08637766540050507,0.2971135973930359,-0.08083910495042801,-0.1053912490606308,0.2833126485347748,0.0072352588176727295,-0.13945075869560242,-0.11271779239177704,0.1323222666978836,0.08516880124807358,0.021442675963044167,0.017987100407481194,0.32851162552833557,-0.18736179172992706,-0.07132813334465027,-0.2653774917125702,-0.26266032457351685],[-0.19080980122089386,-0.03227152302861214,-0.22777076065540314,0.03898082301020622,-0.2260911911725998,0.20557227730751038,0.21954987943172455,0.28502529859542847,0.3094545602798462,-0.024441543966531754,0.08228534460067749,0.2292490452528,-0.0817328616976738,-0.28233036398887634,0.027346396818757057,0.3039354085922241,0.2036048173904419,-0.04852008447051048,-0.16799508035182953,-0.058723777532577515,-0.2635834813117981,0.14239460229873657,-0.22954058647155762,-0.18969106674194336,-0.2142082303762436,0.2184237837791443,-0.018517278134822845,0.015002825297415257,0.1328096240758896,-0.25276342034339905,-0.27686139941215515,0.10819607973098755],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0],[0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,0.0]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"x: %{x}\\u003cbr\\u003ey: %{y}\\u003cbr\\u003ecolor: %{z}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.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.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"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\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.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.0,\"#f0f921\"]],\"sequentialminus\":[[0.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.0,\"#f0f921\"]],\"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\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"scaleanchor\":\"y\",\"constrain\":\"domain\"},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"autorange\":\"reversed\",\"constrain\":\"domain\"},\"coloraxis\":{\"colorscale\":[[0.0,\"rgb(103,0,31)\"],[0.1,\"rgb(178,24,43)\"],[0.2,\"rgb(214,96,77)\"],[0.3,\"rgb(244,165,130)\"],[0.4,\"rgb(253,219,199)\"],[0.5,\"rgb(247,247,247)\"],[0.6,\"rgb(209,229,240)\"],[0.7,\"rgb(146,197,222)\"],[0.8,\"rgb(67,147,195)\"],[0.9,\"rgb(33,102,172)\"],[1.0,\"rgb(5,48,97)\"]],\"cmid\":0.0},\"title\":{\"text\":\"Normal\"}},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('55827f07-e587-42cd-84c8-48c444664080');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(normal_matrix, title='Normal')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ALTI",
   "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": 2
}
