{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Helper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "\n",
    "# to import functions from `patching_utils.py` and `plotly_utils.py`,\n",
    "# we need to add the repository directory to the system path.\n",
    "current_dir = os.path.dirname(os.getcwd())\n",
    "print(current_dir)\n",
    "if current_dir not in sys.path:\n",
    "    sys.path.append(current_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch as t\n",
    "from torch import Tensor\n",
    "import torch.nn.functional as F\n",
    "\n",
    "from transformer_lens import HookedTransformer, patching, ActivationCache, utils\n",
    "from transformer_lens.hook_points import HookPoint\n",
    "\n",
    "t.set_grad_enabled(False)\n",
    "\n",
    "from jaxtyping import Float, Int, Bool\n",
    "from typing import Literal, Callable, Dict, Tuple\n",
    "from functools import partial\n",
    "\n",
    "from IPython.display import display, HTML\n",
    "from plotly_utils import imshow, line, scatter, bar\n",
    "from patching_utils import prepare_data_for_fwd\n",
    "\n",
    "from tqdm import trange"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:You tried to specify center_unembed=True for a model using logit softcap, but this can't be done! Softcapping is not invariant upon adding a constant Setting center_unembed=False instead.\n",
      "Loading checkpoint shards: 100%|██████████| 8/8 [00:00<00:00, 137.44it/s]\n",
      "WARNING:root:You are not using LayerNorm, so the writing weights can't be centered! Skipping\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded pretrained model google/gemma-2-9b into HookedTransformer\n"
     ]
    }
   ],
   "source": [
    "device = \"cuda:9\"\n",
    "model_name = \"google/gemma-2-9b\"\n",
    "\n",
    "model = HookedTransformer.from_pretrained(model_name, device=device)\n",
    "model.set_ungroup_grouped_query_attention(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from data_utils import process_dataset, read_jsonl\n",
    "\n",
    "def load_data(offset):\n",
    "    setting, nmax, offset, n_icl_examples = \"setting1\", 9, offset, 4\n",
    "    filename = f\"../data/addition/{setting}/addition_nmax{nmax}_offset{offset}.jsonl\"\n",
    "    data = read_jsonl(filename)\n",
    "    processed_data = process_dataset(data, n_icl_examples=n_icl_examples, offset=offset)\n",
    "    return processed_data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Compute FVs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 0-9 token ids\n",
    "digit_token_ids = [235276, 235274, 235284, 235304, 235310, 235308, 235318, 235324, 235321, 235315]\n",
    "# FI heads\n",
    "heads = [(39, 12), (39, 7), (36, 7), (32, 6), (32, 1), (25, 13), (32, 4), (28, 6), (24, 9), (36, 6)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 25/25 [02:07<00:00,  5.12s/it]\n",
      "100%|██████████| 25/25 [02:10<00:00,  5.24s/it]\n",
      "100%|██████████| 25/25 [02:10<00:00,  5.21s/it]\n",
      "100%|██████████| 25/25 [02:09<00:00,  5.19s/it]\n"
     ]
    }
   ],
   "source": [
    "fv_offset = {}\n",
    "for offset in [-2, -1, 1, 2]:\n",
    "    fvs = {}\n",
    "\n",
    "    data = load_data(offset)\n",
    "    batch_size = 4\n",
    "    for st in trange(0, len(data), batch_size):\n",
    "        ed = st + batch_size\n",
    "        batch = data[st: ed]\n",
    "\n",
    "        for head_layer, head_idx in heads:\n",
    "            t.cuda.empty_cache()\n",
    "            _, _, _, _, normal_cache, contrast_cache, normal_logits, contrast_logits = prepare_data_for_fwd(model, batch)\n",
    "            \n",
    "            head_out = contrast_cache[utils.get_act_name(\"z\", head_layer)][:, -1, head_idx, :]\n",
    "\n",
    "            if (head_layer, head_idx) in fvs:\n",
    "                fvs[(head_layer, head_idx)].append(head_out)\n",
    "            else:\n",
    "                fvs[(head_layer, head_idx)] = [head_out]\n",
    "            del contrast_cache\n",
    "            del normal_cache\n",
    "    \n",
    "    for head_layer, head_idx in heads:\n",
    "        tensors = fvs[(head_layer, head_idx)]\n",
    "        fvs[(head_layer, head_idx)] = t.cat(tensors, dim=0).mean(dim=0)\n",
    "\n",
    "    fv_offset[offset] = fvs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([256])\n"
     ]
    }
   ],
   "source": [
    "print(fv_offset[1][(39,12)].shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Getting Naive Prompt Logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['9=9\\n0=', '0=0\\n1=', '1=1\\n2=', '2=2\\n3=', '3=3\\n4=', '4=4\\n5=', '5=5\\n6=', '6=6\\n7=', '7=7\\n8=', '8=8\\n9=']\n"
     ]
    }
   ],
   "source": [
    "prompts = [\"{}={}\\n{}=\".format((i-1) % 10, (i-1) % 10, i, i) for i in range(10)]\n",
    "print(prompts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "digit_logits = model.forward(prompts) # batch_size * seqlen * vocab_size\n",
    "digit_logits = digit_logits[:, -1, digit_token_ids] # batch_size, 0-9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly",
        "staticPlot": false
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "Output: %{x}<br>Input: %{y}<br>color: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": {
          "bdata": "mh/vQWS14EG2PtVBsN7RQXJ6z0HsDtFBzMHPQdbdy0HT+tFBxkXfQcrs4EE6ou5BvDjXQdgJ0EGozcxBA5vNQaZ3x0FvLsVBoYfEQZnfxUH3r9VBy0nlQVa37kFsMtlBBufZQQWG0EHW6slB2UnHQbw8yEF1X8VBL1bQQYCu2kH3ct1BOOjuQWkS2UEqStRB9cPSQVwYyUE9qsdB0bvGQYaR0EGFCNlBl5zbQdKg3EFGx+5BBO7YQVA10kEV0M5BJdHMQfzoyUHrC9JBiHLbQdZx1kFiCdhBG6vcQSby7kF+cddBQTPQQSuN0EFJbs9BJXzTQVMq3UGgVtZB7E/XQX4K2EHmOeBB+cXuQaBi10Fc8tJBXgnRQQv80EHb7NtBxuLTQRqt00GpYNNBeHvXQZ4530Euee5BVJzYQfNI00FIdNBBwMfaQRfW0kHtEdBBMhDQQdE90UGm1tVB4+HcQUj+7UGXmNdBp2jRQZn13EG4K9JBbMHQQTuOzkGvSNBBHfLSQQVx1UHoyN1BAQTuQQ==",
          "dtype": "f4",
          "shape": "10, 10"
         }
        }
       ],
       "layout": {
        "coloraxis": {
         "cmax": 30,
         "cmid": 0,
         "cmin": 25,
         "colorscale": [
          [
           0,
           "rgb(247,251,255)"
          ],
          [
           0.125,
           "rgb(222,235,247)"
          ],
          [
           0.25,
           "rgb(198,219,239)"
          ],
          [
           0.375,
           "rgb(158,202,225)"
          ],
          [
           0.5,
           "rgb(107,174,214)"
          ],
          [
           0.625,
           "rgb(66,146,198)"
          ],
          [
           0.75,
           "rgb(33,113,181)"
          ],
          [
           0.875,
           "rgb(8,81,156)"
          ],
          [
           1,
           "rgb(8,48,107)"
          ]
         ]
        },
        "height": 400,
        "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"
           }
          ],
          "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"
           }
          ],
          "scattermap": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermap"
           }
          ],
          "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": "Clean Baseline"
        },
        "width": 400,
        "xaxis": {
         "anchor": "y",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "scaleanchor": "y",
         "title": {
          "text": "Output"
         }
        },
        "yaxis": {
         "anchor": "x",
         "autorange": "reversed",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "title": {
          "text": "Input"
         }
        }
       }
      }
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(digit_logits,\n",
    "    labels={\"x\": \"Output\", \"y\": \"Input\"},\n",
    "    title=\"Clean Baseline\",\n",
    "    width=400,\n",
    "    height=400,\n",
    "    zmin=25,\n",
    "    zmax=30,\n",
    "    color_continuous_scale=\"Blues\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Apply FVs to Naive Prompts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def apply_fv_hook(\n",
    "    head_out: Float[Tensor, \"batch pos d_model\"],\n",
    "    hook: HookPoint,\n",
    "    head_idx: int,\n",
    "    fvs: Dict[Tuple[int, int], Tensor],\n",
    ") -> Float[Tensor, \"batch pos d_model\"]:\n",
    "    head_out[:, -1, head_idx, :] += fvs[(hook.layer(), head_idx)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "head_diffs_offset = {}\n",
    "for offset in [-2, -1, 1, 2]:\n",
    "    head_diffs = {}\n",
    "    for head_layer, head_idx in heads:\n",
    "        fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fv_offset[offset]))]\n",
    "        fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "        fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "\n",
    "        diff = fv_applied_logits - digit_logits\n",
    "        head_diffs[(head_layer, head_idx)] = diff\n",
    "    head_diffs_offset[offset] = head_diffs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "# aggregated effect of 9 heads\n",
    "aggregated_diff = {}\n",
    "for offset in [-2, -1, 1, 2]:\n",
    "\n",
    "    fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fv_offset[offset])) for head_layer, head_idx in heads]\n",
    "    fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "    fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "    # fv_applied_logits = reverse_logit_softcap(fv_applied_logits)\n",
    "\n",
    "    diff = fv_applied_logits - digit_logits\n",
    "    normalized_diff = diff - diff.mean(0).mean(0)\n",
    "    aggregated_diff[offset] = normalized_diff\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.rcParams['font.family'] = 'sans-serif' \n",
    "plt.rcParams['font.sans-serif'] = 'DejaVu Serif' "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Individual effect and aggregated effect"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwkAAAFjCAYAAAB2a0eZAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZ/FJREFUeJzt3Xl4U1X+P/B3krZpSxdo2aSUssgAglAoe4FWAfEriOKKIIKMgigq6oB7QRSRGRfEHQEZUIfRkc0NFARUHNkE5ccAAhYoBUpbKN2TJjm/P7DR0JR8bpqQpvf9ep48T3Pz6bnn3nNyk5N77v0YlFIKREREREREvzMGugJERERERFS7cJBAREREREQuOEggIiIiIiIXHCQQEREREZELDhKIiIiIiMgFBwlEREREROSCgwQiIiIiInLBQQIREREREbngIIGIiIiIiFxwkOAjW7duRe/evWEwGNC9e3ds2rQJALBp0yZ0794dBoMBvXv3xtatW7FixQoMGTIEgwcPRpcuXTB69GicPXvWWVZubi5GjhyJAQMGoFOnTpg1a1a16924cSNatmyJ9PR056NDhw4YPny437dZzwLV3pW++OILNG3aFIsXL3ZZnpeXh7/97W+44oor0L9/fwwYMABbt2716bZTVb7sDwCwZs0aDBgwAP3790eHDh3w97//3e16Dx8+jKZNm7q8/7t27YrOnTv7fZvJla/6gM1mw2uvveZsz27duuH999/3uP7qjgl0cQS6/V966SX06dMH/fr1Q+fOnbF27Vq/bi/phCKfyczMVADUzp07XZbv3LlTAVCZmZlKKaWGDBmivvzyS6WUUhaLRXXr1k098MADzvhBgwaphx9+WCml1OnTp1WLFi3Ue++953ad3333nZo9e7bLskmTJqklS5b4ZqOoWoFob6WUmj17tnrwwQdVs2bNqsS999576tprr1U2m00ppdRbb72lGjZsqAoKCmq2seSRr/rDli1bVNeuXVVeXp5SSql9+/ape++91+06jxw5oiZNmuSybM6cOWrmzJk+2irSwhd9IDMzUzVv3lzl5+crpZT6+eefVVhYmPr++++rXe+Fjgl08QSq/V9++WU1evRo53F/6dKl7AfkExwk+JD0ALF9+3blcDicr991113q2muvVUoplZWVpQCoPXv2OF+fOnWq6tmzp6gOFotFJSUlqeLi4pptDHkUqPY+evSoUkqppKSkKh8EmzdvVps3b3Y+LyoqUgDUN998480mkga+6A9KKXXttdeq+fPne12Pyy+/XB0+fNjr/yfv+aIP5OXlqUWLFrn8f0pKisrIyKh2vRc6JtDFE4j2t1qtKi4uTv3666++2xCi33G6UQCkpKTAYDAAADIzM/H1119j/PjxAIDs7GwAQMOGDZ3xTZs2xa5du6CU8lj2559/jiuvvBL16tXzQ83JG75u78TExGrX1bdvX/Tt29f5vKysDADQuHHjmm0E+cyF+oNSChs2bIDFYsE111yD1NRUPPjggygpKRGVvXPnTjRs2BBJSUl+qz/V3IX6QHx8PO68806X+LKyMjRp0qTa8i50TKDax5ftv2vXLhQVFWHHjh3Oaabz5s3z7waQboQEugJ10V133YWoqCjn8+LiYrdx/fv3x65duzBz5kxcf/31AP442GdnZzu/2J04cQJWqxWlpaUev/wvXboUDz74oA+2gqQC2d6erFy5EgMHDkTHjh1rVA7J1aQ/5Obmori4GG+88Qa+++471K9fHzfeeCPuvvtufPjhhx7XvXTpUowdO9Yn20Heq0kfON+vv/6K3Nxc3Hbbbf6oKvnBxWz/zMxM2O12LF++HOvWrUNeXh569+6N8PBwTJgwocbbQjoX4DMZdYr0VOOf5ebmqh49eqhnn33Wueyqq65So0aNUna7XR07dkwlJSUpAKqiouKC68/Pz1ft2rVzOY1J/hPo9vY0teDkyZOqU6dObutBvueL/lA5/ezP1xR88803ymAweJxCaLPZVJs2bVRRUVGNt4W846tjQiWbzaYGDx6sVq1aJVo/pxsFViDaf+nSpQqA+vbbb53LMjIyxFOUiS6E040CrGHDhnj44YcxZ84c5/SSZcuWoV69eujXrx/uvfde3HPPPUhISEBIyIVP/Pz73//Grbfe6jyNSbWPL9v7QkpKSjBq1CjMnz8fLVu29FHtydfO7w/169cHAJepBQkJCVBKOaemVeerr75Camqqyy+YVPu5OyZUmjJlCoYNG8a71dVhNW3/Bg0aAKh6zMjKyvJPhUlXOEgIgNmzZ7s8j4yMhMVigd1uB3DuTT9//nz88MMPWLVqFex2OwYNGuSx3Pfff59TDWohf7V3daxWK2699VZMmzYNffr0walTp3Dq1KkabQP5zoX6Q1RUFP7yl7+4tFdubi6Acx/8F7JkyRKMGzfO5/Ul3/N0TACAjIwMxMXF4YEHHoDFYsGBAwcudjXJT3zZ/l27doXBYKhyzGjevLl/Kk+6wkFCADz33HPON7zNZsPixYsxcOBA5y/HY8aMwbFjxwAAx44dw5IlS/Doo486/3/06NH46KOPXMo8ePAgQkJC0Lp164u0FSTlj/aujt1ux6hRo3D99dcjNTUVxcXFWLFiBb744gsfbxV5y1N/mDRpEv71r3+htLQUALBo0SLceuutzutTpk6dirlz57qUWVRUhF27diE9Pf2ibQd5z1MfeOWVV3D06FFMnToVxcXFOHTokEv+FC3HBKp9fNn+zZo1w/Dhw7Fw4UIAQGlpKZYtW+a8EJqoRgI516ku2bJli+rVq5cCoFJSUtTGjRuVUkpt3LhRpaSkKACqV69easuWLerFF19UPXv2VGlpaSolJUWNGTNGnTx50lnWU089pTp06KD69eun0tLS1KZNm1zW1a1bNzV37lyXZRkZGWrBggX+31BSSgW2vT/++GOVlpamzGazateunRo8eLDztfnz5ysAVR6cp+xfvuwPDodDPfbYY6pjx44qNTVVjRs3ziXPxYgRI9RDDz3ksv5Fixapp5566uJsLLnlqz6wf/9+ZTAYqryHx44d61yXlmMCXRyBbP+8vDx14403qq5du6revXur559/Xtnt9ou6/VQ3GZQS3FeTiIiIiIh0g9ONiIiIiIjIBfMkEBERERH50cyZM7Fy5UoYDAYMHDgQc+bMcXs3yquvvhrl5eUuy5YvX464uDgA565BmzhxIn777TdYrVY88sgjGD16tF/qzEECEREREZGfLF68GMuXL8eWLVtgMpmcmbHdJb9t2rQpFi9eXG1Z999/P2JiYvDjjz/i+PHj6NSpE9q3b4+UlBSf15vTjYiIiIiI/OT111/HnXfeCbPZjJCQENx99914/fXXNZdTUFCADz74AJMmTQJw7u5Ww4YNw9tvv+3rKgPgIIGIiIiIyC+sVit27dqFTp06OZd17twZBw8exOnTp6vEl5SUYMyYMejfvz+uueYabNiwwfnajh07YLfbcdlll7mUtWXLFr/UndONiIiIiEiXysvLYbVaNf+fUqrKNQVmsxlms9llWV5eHux2O+rXr+9cVvl3Tk6O81qDSq1bt8bYsWNx2WWXYevWrbjiiivw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XbugfJCsavfu3bjyyiuRlpaGfv36Yd26dc7XPv/8cwwcOBCDBg1Cv379qkz5+s9//oPOnTsjLS0Njz76qEt9HA4HpkyZgp49e2LQoEG4/vrrsW/fPrd1WL58OTp06ID69etXee21115DdHT0BQdwZWVluP/++5GamorU1FQ88MADzqmHldOgZsyYgZtuugnt2rXD9ddf71w+ffp03HLLLWjbti1mzJiBnTt34sYbb8Sll16Kd99917mO/fv349prr8XgwYORlpaGv/3tb3BUcxHvwoULXaYfLV68GMnJyc7pc5dccgkuu+wyZ/wbb7yB3r17Iz09HTfddJPLgOjbb79Ft27d0K9fP0yYMAEWi8VlXZXTxz744INq9w/5Fy9c9oG77roLUVFRzufFxcXVxv7666/Izc3Fbbfd5lzWunVrjB07Fpdddhm2bt2KK664At988w169erldZ2++eYbTJw4EQaDAcuXL6/TacMvtm3btmHgwIFuX9PSF/r3749du3Zh5syZuP76693GuOsv51uwYAGGDRvm9ixCpbZt22Lbtm24+eabq40hOV/1AcB9Gy9atAg333wzWrVqheLiYowbN67as4eZmZmw2+1Yvnw51q1bh7y8PPTu3Rvh4eGYMGGCM459wHf83f5fffUVEhIS0LFjR491SUxMxIkTJ+BwOGA0nvvd78SJEy4xISEhaNmyJbZt24YePXp4LPNiqfzBKzs7G40bNwZwru5WqxWlpaXOM+LuDBs2DCEhf3yFOf/X+KKiIgwePBivvfYabr75Zhw8eBApKSnYu3cvmjVrhuLiYixZsgQJCQmwWCzo2rUr+vbti9atW+PXX3/FqFGjsHXrViQnJ2P79u149dVXnYO7tWvX4quvvsKePXtgMBjwyiuv4Mcff0T79u2r1HPbtm1o06aN222IiorChx9+iL59+2LBggW46667qsQ88sgjyMnJwffffw8AuOmmmzBt2jTMmzcP7733HjIzM7Fp0yZ89dVXsFqteP755zFr1ixkZmZix44d+PTTT3Hq1Cnnvv7kk0+wfft2XHnllRg/fjxMJhNKSkrwyCOPID09HQBwxx134P3338cdd9xRpT5//etfkZWV5ZydEBYWhtdffx39+vXDkSNHkJyc7PyR4uOPP8YLL7yAX375BQ0aNMCzzz6LO++8E59++inOnDmD4cOH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++sb25/qOk43qgGllN/XMWbMGABAw4YNMXz4cHzwwQd+XyfJsP2JfUDf2P76xvanuo6DhBq49NJLYTAYcOzYMbevZ2VloV27djVaR3x8vPPvRo0aITs7u0blke+w/Yl9QN/Y/vrG9qe6joOEGoiPj8eQIUPw5ZdfVnntl19+walTp3DjjTciLCwMFovF+VpBQYF4Hfn5+c6/T506hYSEBABAWFgYADjL1VIm+Qbbn9gH9I3tr29sf6rrOEiooTfeeAMfffQR1q9f71yWl5eHCRMm4KWXXkLz5s3RqlUr5OXl4cSJEwCATz/91KWMmJgYlJSUAAAyMjLw448/Ol/78MMPAQC5ublYvXo1Ro8eDeDc3ROioqLw888/AwBWr15dpUwAKCkpwTvvvINPPvnEl5tNv2P7E/uAvrH99Y3tT3VaQK+IqCMOHTqkbr31VpWamqrS0tJUv3791Mcff+wSk5GRodq2bauuu+469eKLLyqz2ayGDh2qlFKqoqJCDR48WPXu3VsNGjRIlZWVOS86WrhwoRo8eLBq3769884Gld555x3Vpk0bNXToUPXWW28572RQVFSklFLqjjvuUN26dVOpqakqJyfn4uwMHWL7E/uAvrH99Y3tT3WVQamLcOUNaXb48GG0atXqolwYRbUP25/YB/SN7a9vbH+qDTjdiIiIiIiIXHCQUAvt378fI0eOBACkp6ejuLg4wDWii4ntT+wD+sb21ze2P9UWnG5EREREREQueCaBiIiIiIhccJBAREREREQuOEggIiIiIiIXHCQQEREREZELDhKIiIiIiMgFBwlEREREROSCgwQiIiIiInLBQQIREREREbn4/zsjZsITydqCAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x400 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 1\n",
    "\n",
    "heads_display_order = [(39,7), (39,12), (36,7), (32,1), (32,6), (25,13)] + [(32,4), (28,6), (24,9)]\n",
    "matrices = [head_diffs_offset[offset][(layer, idx)].cpu().numpy() for layer, idx in heads_display_order] + [aggregated_diff[offset].cpu().numpy() * 0.6]\n",
    "titles = [f\"H{l}.{h}\" for l, h in heads_display_order[:6]] + [f\"(H{l}.{h})\" for l, h in heads_display_order[6:]] + [\"9 Heads (Normalized)\"]\n",
    "\n",
    "# Create figure with 2 rows and 5 columns of subplots\n",
    "fig, axes = plt.subplots(2, 5, figsize=(10, 4), sharex=True, sharey=True)\n",
    "\n",
    "# Flatten axes array for easier iteration\n",
    "axes = axes.flatten()\n",
    "\n",
    "# Plot each matrix\n",
    "for i, (ax, matrix, title) in enumerate(zip(axes, matrices, titles)):\n",
    "    im = ax.imshow(matrix, cmap=\"RdBu\", vmin=-0.5, vmax=0.5)\n",
    "    ax.set_title(title, fontsize=9)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i % 5 == 0:\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "\n",
    "# Add colorbar\n",
    "cbar = fig.colorbar(im, ax=axes.ravel().tolist(), shrink=0.9, ticks=[-0.5, -0.25, 0, 0.25, 0.5])\n",
    "cbar.ax.tick_params(labelsize=9)  # set tick label font size to 12\n",
    "\n",
    "# plt.savefig(\"figures/fv_offset{}.pdf\".format(offset), dpi=300, bbox_inches='tight', pad_inches=0.0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 1\n",
    "heads_display_order = [(32,6), (25,13)] + [(32,4)]\n",
    "matrices = [head_diffs_offset[offset][(layer, idx)].cpu().numpy() for layer, idx in heads_display_order]\n",
    "titles = [f\"H{l}.{h}\" for l, h in heads_display_order[:2]] + [f\"(H{l}.{h})\" for l, h in heads_display_order[2:]]\n",
    "\n",
    "# Create figure with 2 rows and 5 columns of subplots\n",
    "fig, axes = plt.subplots(1, 3, figsize=(7, 3), sharex=True, sharey=True)\n",
    "\n",
    "# Flatten axes array for easier iteration\n",
    "axes = axes.flatten()\n",
    "\n",
    "# Plot each matrix\n",
    "for i, (ax, matrix, title) in enumerate(zip(axes, matrices, titles)):\n",
    "    im = ax.imshow(matrix, cmap=\"RdBu\", vmin=-0.15, vmax=0.15)\n",
    "    ax.set_title(title, fontsize=9)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i % 5 == 0:\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "\n",
    "# Add colorbar\n",
    "cbar = fig.colorbar(im, ax=axes.ravel().tolist(), shrink=0.55, ticks=[-0.15, 0, 0.15])\n",
    "cbar.ax.tick_params(labelsize=9)  # set tick label font size to 12\n",
    "\n",
    "# plt.tight_layout()\n",
    "\n",
    "plt.savefig(\"figures/fv_scale.pdf\", dpi=300, bbox_inches='tight', pad_inches=0.0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Comparing different offsets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jDp37hxUa39TpMVpY9KkScrIyFCrVq00ffr0Cm3R0dGaP3++unTpos8++0wvvviixo4d66eRAgAAAAAA1F5Yh9/KER5TZZtVmKOi75ZJKrmxWvPmzX05tFo7ceLX2fyXXXZZhQJtqdtvv12PP/649uzZo2nTpmnZsmW+HOIp4cZhOC3s3LlTixcvliTddNNNioys/PWMTp066aKLLpIkzZgxo0bT+QEAAAAAAAKFM7KunFH1qt4i65b1a968uVq2bOl1q4nY2Niy/bw8z8uRlW+rV69etWJHR/+6BFef/19//H85HA717Vtyn4KUlBQVF5tfYswuFGlxWli8eHFZ0XXAgAEe+1166aWSpL179+qLL77wydgAAAAAAABMcjhdXje7tGrVqmw/IyPDY7/ybdUtBDdq1KhsPy4uzmO/Fv9/74MTJ05UWCIh0FGkxWlhzZo1ZfvdunXz2O+8884r2//oo49sHRMAAAAAAIAdHA4vRVqHfUXapKSksnv87N6922O/0rbExMRq3TRMkrp06VK2722GbLB+M5oiLU4LW7dulVQy7d7bL3/5uyBu27bN9nEBAAAAAACY5gwPlys8osrNaeON0iMiIsq+wbxp0yaP/TZu3ChJuvLKK6sd+5xzzlGDBg0kSWlpaR777d+/X1LJMgqNGzeudnx/48ZhCHn5+fk6cOCAJO/T4f+33dsnPlXZt2+f1/b09PQaxQMQfMgDACRyAYAS5AIA/uRtWQM7lzuQpNGjR2vlypVKSUlRVlZWpclyO3bsUGpqqhwOh0aNGlXtuBERERoxYoSee+45paSkaNq0aZX6WJaltWvXSpKuuOIKOZ3BMz+VIi1C3vHjx8v2o6KivPYtvwh1+fOqo/wsXACnJ/IAAIlcAKAEuQCAPzkcTs9FWoe9hcurr75affv21dq1azV16lQ9/fTTZW2WZemBBx6QJN18883q3r17hXPfe+89jRo1SnFxcVq+fLlat25dof2RRx7RokWL9MUXX+i9997T0KFDK7S/8MILSktLU0xMjB555BF7nqBNKNIi5OXm5pbtR0REeO1bvj0nJ8e2MQEAAAAAANjF4XTK4WEWqafjJi1evFjJycmaPXu2cnNzNXLkSBUUFGju3Ll65513lJycrOeee67SefPnz1dmZqYyMzO1dOlS3XvvvRXaS4u3V155pa677jpNnjxZ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SZKuuOIKLVq0yOt4t23bpqSkJN16661q1aqVDh06pGXLlumLL77QxRdfrDfeeENxcXEezy//grGqMZ188eLFOnz4sH73u9+FzA3DSl1wwQU677zz1KVLF91999266KKLFB8fr7CwMBUVFengwYP65JNPNG/ePN12220688wzlZaWVnb+zz//7MfRAwAAAAAABIlqrklrh6uvvlp9+/bV2rVrNXXqVD399NO/PrRl6YEHHpAk3XzzzerevXuFc9977z2NGjVKcXFxWr58uVq3bl2h/c4779T8+fO1c+dOPfvss7r77rvL2goLC/Xwww9LkiZPnlztJTcDhc+LtEuXLtXUqVMrHMvMzNSNN94oSVqwYEGlIm1qampZe3kTJkyQVPJDLS3SPvPMM5owYYKWLl2qNWvWaP369Vq2bJny8/NVt25dtWrVSqNHj9b111/vdVbmNddcI6fTqZSUFG3btk1///vflZubq/j4eHXv3l1vv/22rrnmmpMuRzB79mzdddddatu2bYUXjielSx2MGTPmpH2DTevWrcv+vSZPnuy178MPP1z2i2WXgoIC5ebmql69eiG1rAQAAAAAADjN+bFIK5VMQkxOTtbs2bOVm5urkSNHqqCgQHPnztU777yj5ORkPffcc5XOmz9/vjIzM5WZmamlS5fq3nvvrdAeGRmpFStWKDk5Wffee68OHTqkIUOG6MiRI3riiSe0ceNG3XDDDXrooYdsf46m+bxIO2XKFE2ZMqVG5/Tr169as1BLtW3bVhMnTtTEiRNrOLpfxcfHa9y4cRo3blytY0jS9ddfX6Pp1WvXrj2lxwt0Nfk5VuVUi6lHjx7VtGnT9PLLL+vHH3+UZVlyuVzq1KmThg4dqvHjx9d6BvO+ffu8tqenp9cqLoDgQR4AIJELAJQgFwDwK8uSqlgOoKzNZk2aNNHGjRs1Z84cLVq0SAsXLpTL5VJSUpLmzZun22+/vcobt48ZM0aff/654uLidNVVV1UZ+8wzz9SWLVv0xBNPaMmSJXrqqacUExOjc845R4sWLdJ1111n99Ozhc+LtDi9rVq1Su3bt6/Vud99950GDx58So+/bNkypaSkaPTo0brwwgsVHR2tHTt2aP78+Zo+fbrmzZunN954o1aPc8YZZ5zS2AAEP/IAAIlcAKAEuQCAP5XeJMxTmy9ERkbq/vvv1/3331/t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t2+fnnnmmZP237t3r5599lk5HA7NmTNH0dHRFdpL13/6+eefK517+PBh/fDDD17jl341ybKssmMHDx7Um2++qbS0tEr9f/zxxyofS5JWr14tqeTiq23bttUepyRt2LChxuO0LEtvvvmmNm3a5PVcIBCRC8gFgEQuIBcAJcgF5ALgdEeRFoDPNWnSRMuXL1fDhg1133336e233/bYd+/evRo8eLBOnDih6dOn69prr63U56KLLpIkffTRR5XaZs+eLYfD4XU8pRdGhw8fLjv24YcfasSIEfrpp58q9Xc4HHr00UcrHd+0aZOWL18uSZoyZYrHcX755ZfKysqq0JaSkqItW7bUeJz79+/XiBEjyh4XCCbkAnIBIJELyAVACXIBuQA47VkA4Cc//fST1bt3b0uSNXDgQOull16yPv30U2vTpk3Wv//9b+uuu+6y6tSpYzVq1MhatGiRxzj79u2zGjRoYEmybrrpJmv16tXWf//7X+tPf/qTNWzYMKtPnz6WJGvs2LHWli1brH379lU4/6233rIkWS1atLBWrlxppaSkWJ07d7ZatmxpHT9+vKzfI488YkmyLrnkEmvQoEHWyJEjrdWrV1ubNm2ynn32Watx48aWJGvixIlVjrO4uNi64IILLElWr169rGXLllmbNm2ynnnmGeu8886z/vjHP1qSrB49elhbtmyxvvvuuwrnp6WlWZGRkZbT6bReeukla/369da1115ruVwua9OmTafwkwD8i1xALgAsi1xALgBKkAvIBcDpiiItAL9buXKlNWrUKOuss86yYmNjrYiICCshIcEaNGiQNXv2bOvYsWMnjbFt2zZr2LBhVsOGDa3IyEirY8eO1syZM62ioiKrb9++lqSy7eabb650/hNPPGGdeeaZVnh4uNWkSRNr8ODB1rfffluhT+kFWN++fa2CggJr2rRpVpcuXayYmBirbt26Vp8+fawlS5Z4Hefhw4etcePGWS1atLDCw8Otli1bWuPGjbMyMzPL4pduiYmJlc5fsWKF1bNnTysqKsqKjY21evToYS1duvSk/z5AMCAXkAsAyyIXkAuAEuQCcgFwunFYVrmFSwAAHk2ZMkVTp05V37599fHHH/t7OAD8hFwAQCIXAChBLgBgCmvSAgAAAAAAAIAfUaQFAAAAAAAAAD8K8/cAACDQ7d+/X0eOHNGhQ4ckSSdOnNDWrVsVERGhs846y8+jA+Ar5AIAErkAQAlyAQDTWJMWAE7illtu0SuvvFLpeGJionbv3u37AQHwC3IBAIlcAKAEuQCAaRRpAQAAAAAAAMCPWJMWAAAAAAAAAPyIIi0AAAAAAAAA+BFFWgAAAAAAAADwI4q0AAAAAAAAAOBHFGkBAAAAAAAAwI8o0gIAAAAAAACAH1GkBQAAAAAAAAA/okgLAAAAAAAAAH5EkRYAAAAAAAAA/IgiLQAAAAAAAAD4EUVaAAAAAAAAAPAjirQAAAAAAAAA4EcUaQEAAAAAAADAjyjSAgAAAAAAAIAfUaQFAAAAAAAAAD+iSAsAAAAAAAAAfkSRFgAAAAAAAAD8iCItAAAAAAAAAPgRRVoAAAAAAAAA8COKtAAAAAAAAADgRxRpAQAAAAAAAMCPKNICAAAAAAAAgB9RpAUAAAAAAAAAP6JICwAAAAAAAAB+RJEWAAAAAAAAAPyIIi0AAAAAAAAA+BFFWgAAAAAAAADwI4q0AAAAAAAAAOBHFGkBAAAAAAAAGJWfn6+ZM2eqW7duio2NVYMGDdS7d289//zzcrvdtYp54sQJLVy4UL/73e/Utm1bRUdHKyYmRu3atdPIkSO1bt06w8/CdxyWZVn+HgQAAAAAAACA0JCZmank5GRt2bJFY8aM0Y033qiCggI9++yzeuedd5ScnKwVK1YoKiqq2jG//PJLDRw4UIcPH1bnzp117733qmPHjrIsSx9++KFmzZqlnJwcjRs3Ts8++6wcDoeNz9A8irQAAAAAAAAAjOnfv78+/vhjjR8/XnPmzCk7blmWhg8frmXLlumWW27RggULqh1z+fLlGjp0qM4991ytX79ekZGRFdrff/99XXnllZKkWbNmaeLEiUaei69QpAV8JC8vT1u2bJEkNW3aVGFhYX4eERAaioqKlJGRIUnq2rVrjT6J9TXyAGAfcgEAiVwAoEQw5YJQtGTJEl1zzTWKiopSenq6GjRoUKE9NTVVnTp1ksPh0MaNG9W9e/dqxS0t0i5ZskRXXXVVlX369OmjTz75RC1atNC+fftO9an4FH8FAB/ZsmWLevXq5e9hACFtw4YN6tmzp7+H4RF5APANcgEAiVwAoESg54JQ9OKLL0qSkpOTKxVoJSkpKUlJSUlKTU3VSy+9VO0ibbt27fSnP/1J/fr189jnnHPO0SeffKL9+/frl19+UePGjWvzFPyCG4cBAAAAAAAAOGUFBQVKSUmRJK/F8dK2FStWVDt2UlKSnnzySTVq1MhjH5fLJUlyOp2Kjo6uduxAwExanHYyMjL0t7/9Te+++652796tyMhIdejQQSNHjtRtt92m8PBwWx63adOmZfspH69TfHy80fg3LvjSaDxJcjrtWWT7aMYJ4zHDwl3GY0ol6+XYwY4FzNO3bzYeU5LysjKMx3xxzgRjsQ4fOqjxvxssqeLvWSAqP76P1prPAw+t/N5oPElqHx9rPKYk/XQo23jMOpHBdVlzLLfQeMy9h8znV0natzPdeMylDw0yGu/QgQP6zcB+koIrF3y8znwumPrhj0bjSdIVneOMx5SkfcfyjMdsGGXPtVy0TdcamScKjMeMDrdnLs6735jPBfOuOMNovPQDB3XJZVwXSNK4xduMxpOkOpH2/B7s2n3UeMyoOvbkgogoe643Thw1nw+dLnvez2XuP2o85nMT+hiNl3nogEb9ZqCkwM8FJhUVFenAgQPV7p+enl6t5VZatmxZ7ZipqakqLCy5zm3durXHfqVte/bsUVZWlurXr1/tx/Dm++9L3hN1795dMTExRmL6SnC9mwFO0RdffKHhw4crPT1dgwYN0tixY5WTk6MFCxboj3/8o1555RUtX77cliRePunFx8erRYsWRuNH1k8zGk+yr0gbnmf+0yyKtJIzyswftf/lyM01HrNpfILxmJICfi23ynmg+hc71VGn8TGj8SSpftN6xmNKUp3i48Zjxtr0pskuxTnmi7SRBeb/XSUprI75IlLzBLN/B8s73XNB3cbmPwSxK2+fiDL/N6ZxTITxmJIUY9O1hjs733hMu8Ya3bDYeMyWLex5bUnkguiG5j9oj7Hpb23EYfNxI+vakwsio+0p/ha6zedDZ5g97+fCjprPMXHNT9/rApMOHDigM84w++GXVLP3xWlpv9YmvNVWyrft27fPSJE2MzNTq1evliTdd999pxzP106fVypOe3v27NHQoUOVkZGhe++9V0899VRZ25133qnLLrtMn332mYYPH641a9bYNqMWAAAAAAAgFB0//uukAW83bCvfduyYmckmTz31lAoKCjR8+HBdc801RmL6EkVanDYmTZqkjIwMtWrVStOnT6/QFh0drfnz56tLly767LPP9OKLL2rs2LF+GikAAAAAAEDthXX4rRzhVX/d3yrMUdF3yySV3FitefPmvhyaLT755BM9+eSTOuuss/TPf/7T38OpFYq0OC3s3LlTixcvliTddNNNioyMrNSnU6dOuuiii/Tpp59qxowZuuOOO2z5SjoAAAAAAICdnJF15YioW2Wb5fx17fLmzZvXaM3Zk4mN/fWeFnl5ntdaLt9Wr96pLbG2Y8cOXXXVVWrRooVWr16thg0bnlI8f7FnRXkgwCxevLhsDZUBAwZ47HfppZdKkvbu3asvvvjCJ2MDAAAAAAAwyeF0ed3s0qpVq7L9jAzPa2OXbzuVIvF3332n5ORk1alTRykpKbasyesrFGlxWlizZk3Zfrdu3Tz2O++888r2P/roI1vHBAAAAAAAYAeHw0uR1mFfkTYpKansHj+7d+/22K+0LTExsdY3DduyZYv69OmjmJgYrVu3Tu3atatVnEBBkRanha1bt0oqmXbv7Ze//Ccu27Zts31cAAAAAAAApjnDw+UKj6hyc9p4o/SIiIiybzBv2rTJY7+NGzdKkq688spaPc5XX32l/v37q3Hjxlq3bl2FGbxFRUXavXu31+UWAhFr0iLk5efn68CBA5KkuLg4r33Lt3v7xKcq+/bt89qenp5eo3gAgg95AIBELgBQglwAwJ+8LWtg53IHkjR69GitXLlSKSkpysrKqjRZbseOHUpNTZXD4dCoUaNqHH/9+vW6/PLLlZiYqNWrV6tp06YV2vft26c2bdpozZo16tev36k8FZ+iSIuQd/z48bL9qKgor32jo6OrPK86gnndEwBmkAcASOQCACXIBQD8yeFwei7SOuz9Yv3VV1+tvn37au3atZo6daqefvrpsjbLsvTAAw9Ikm6++WZ17969wrnvvfeeRo0apbi4OC1fvlytW7eu0L5u3ToNGTJEHTp00H/+8x81atTI1ufiSxRpEfJyc3PL9iMiIrz2Ld+ek5Nj25gAAAAAAADs4nA65XBWXYz1dNykxYsXKzk5WbNnz1Zubq5GjhypgoICzZ07V++8846Sk5P13HPPVTpv/vz5yszMVGZmppYuXap77723rG39+vUaPHiwcnJytHXr1gpLHJRXeuP4YEORFiGv/OzYgoICr33Lt8fExNTocfbu3eu1PT09Xb169apRTADBhTwAQCIXAChBLgDgT86wcDnDPExUC7NvTdpSTZo00caNGzVnzhwtWrRICxculMvlUlJSkubNm6fbb79dziqKxWPGjNHnn3+uuLg4XXXVVRXa1q9fXzahLtjWm60OirQIebGxsWX7J/slLj/rtvx51dGyZcuaDQxAyCEPAJDIBQBKkAsA+JPD4WVNWoe9a9KWioyM1P3336/777+/2ucMHTpUmZmZVbbdc889uueeewyNLvDYP78Z8LPIyEjFx8dLkg4ePOi1b/n2xMREW8cFAAAAAABgC5dLDg+bXL4p0qJmKNLitNC5c2dJJTcDy8rK8tiv/B1YS88BAAAAAAAIJiVr0ro8bJQDAxE/FZwW+vfvX7b/zTffeOz31Vdfle0nJyfbOSQAAAAAAABbeC7Qel4GAf5FkRanhWuuuaZsPyUlxWO/1atXSypZP+qCCy6wfVwAAAAAAACmuVzhcoVFVL257L9xGGqOIi1OCx06dNDVV18tSVq4cKEKCgoq9dmxY4c+/fRTSdLkyZPlcDh8OkYAAAAAAAATmEkbfCjS4rTx5JNPqnHjxtq9e7cefPDBCm25ubkaM2aMLMtS7969NWbMGD+NEgAAAAAA4NRQpA0+Yf4eAOArrVu31nvvvafhw4dr1qxZ2rJli4YOHaqcnBwtWLBA27dvV48ePfTuu+8qPJyp/wAAAAAAIDiV3jjMUxsCD0VanFZ69+6tzZs3a86cOXr33Xc1adIkRUREqGPHjnrmmWd0++23+6RAm1Po1olCt9GYr9/Wy2g8SXon9ZDxmJJUUGT2uUtSs7qRxmNKUky4PZ8wHi8oMh9zSEfjMSXpaE6h8Zib9mUZi5WVcdxYLF+K+eVH1YnINhrz0cs7GI0nSd/9kmM8piT1atnAeMwmdSKMx5SkMJuuYbMLio3HLCy2jMeUpEM2vLY2HzT7+s/MOGE0nq9kzX1YMfXqGI05ZcIco/HsdEGLWOMxo6x84zElqdAVZUvcMMv8NUGxw563eZe2bWg85sECs9eFmVaM0Xi+En14l2Iizf7NnXttV6PxJPveH5zX2vxrKz7WnvcHh3PNXxtLUp0I8+879h/NMx5TkrK6xhuP+fe1PxmNl3P4oNF4wcgRFiFneNXXx+4we66bcWoo0uK006xZM02fPl3Tp0/391AAAAAAAACMYyZt8KFICwAAAAAAAIQQb2vPsiZtYKJICwAAAAAAAIQQh8NLkdZBkTYQUaQFAAAAAAAAQogrzCmXh5srWHbddAGnhCItAAAAAAAAEEIcDsnhcHhsQ+ChSAsAAAAAAACEEIfTIafTQ5HWw3H4F0VaAAAAAAAAIIQ4HA6PxVhPM2zhXxRpAQAAAAAAgBDicHop0jKTNiBRpAUAAAAAAABCiMvllMtV9Q3C3B6Ow78o0gIAAAAAAAAhhJm0wYciLQAAAAAAABBCHA4vNw5jTdqARJEWAAAAAAAACCEOZ8nmqQ2BhyItAAAAAAAAEEJcLofHNWldLmbSBiKKtAAAAAAAAEAIYU3a4EORFgAAAAAAAAghDoeXIi1r0gYkirQAAAAAAABACHE6HHJ6KMZ6Og7/okgLAAAAAAAAhBBHmFPOsKrXpHV4OA7/okgLAAAAAAAAhBCn0yGnh+UOPB2Hf1GkBQAAAAAAAEKIw+HwuPYsa9IGJoq0AAAAAAAAQAhxOCSHh1UNqNEGJoq0gB+89OV+1dtTbDTmWc3qGo0nSb/vEmc8piQNffpT4zFf/+OFxmNK0piFX9oS1w6F+UW2xC0qcBuPGVUn3Fis/KwMY7F86UDdNnLEtjAaMzLM/NVW56YxxmNK0qOrfzAe88FLzzQeU5Je/upnW+LmFJj9OyBJjetGGI8pSV/tPmI8ZpeW9Y3Gy8o8YTSerzTs2lGNmzQwGjPy6HdG40lSRsOOxmNK0j+/Tjce8/yWDYzHlKTsgmO2xA13ml8XsFX9SOMxJenHI7nGYzaJMZu3fsktNBrPVxz5J+TIyzYaM76Z+bf713a25/3B8DmfGY8ZEW1PuSMy2tx1bHkR4S7jMdvHm3+PKElf7cw0HrOt4esCsNxBMKJICwAAAAAAAIQQh8shp8vDjcNcFGkDEUVaAAAAAAAAIIQwkzb4UKQFAAAAAAAAQojD4ZDDQzGWG4cFJoq0AAAAAAAAQAhxOR1yeSjSejoO/6JICwAAAAAAAISQ8DCnIsKqXpO22MNx+BdFWgAAAAAAACCEuBxeZtKy3EFAokgLAAAAAAAAhBCnl+UOuHFYYKJICwAAAAAAAISQMKcU5qEYy2oHgYkiLQAAAAAAABBCvK1JW0iVNiBRpAUAAAAAAABCiMvhlMtZdTHW5aBIG4go0gIAAAAAAAAhxOVlTVpPx+FfFGkBAAAAAACAEMKNw4IPRVoAAAAAAAAghDCTNvhQpAUAAAAAAABCSLjToQhX1WvPhlOkDUgUaQEAAAAAAIAQwkza4EORFgAAAAAAAAghYU6HwjwUYz0dh39RpAUAAAAAAABCCDcOCz4UaQEAAAAAAIAQEuFyKiKs6jVpPa1VC/+iSAsAAAAAAACEEGbSBh+KtAAAAAAAAEAI4cZhwYciLQAAAAAAABBCKNIGH4q0gB+8v/pHhdU9ajRmYV6u0XiS9HLnFsZjStKqSZcYj3n5k58ajylJx46Y/3eVpMHJbY3HfG/l98ZjSlKjuLrGYxbkFxmLVWgwli8t+jZd9X62jMY8nJ1vNJ4knd+mkfGYkvT44LOMx5z8wU7jMSXp0DHz/66S1LJRtPGY2/ZlGY8pSYlNYozH/OlQttF42b+cMBrPV8JbJykivqnRmEUNWxmNJ0mNiu15bY3pnmA85oc/HTUeU5I2px+zJe6aLQeMx7zvio7GY0pSu4bm89b3v+QYjZeZXWA0nq8UJHRRQcuWRmP+eNT8v0V2frHxmJL04X3m3x9c+cznxmNK0uZVn9gS93j6j8Zjpg+82nhMSWp2Rn3jMbftyDAar+DYYaPxgpHT4bkYS402MFGkBQAAAAAAAEJIRJiXG4d5OA7/okgLAAAAAAAAhBBuHBZ8KNICAAAAAAAAIcTlcMjl8LAmrYfj8C+KtAAAAAAAAEAIcToccnooxno6Dv+iSAsAAAAAAACEkDCnQ+GuqouxYSx3EJAo0gIAAAAAAAAhhOUOgg9FWgAAAAAAACCEsNxB8KFICwAAAAAAAIQQp0PysNqBWO0gMFGkBQAAAAAAAEJImMuhMJfTYxsCD0VaAAAAAAAAIIS45HkmrcunI0F1UaQFAAAAAAAAQojDy5q0DtakDUgUaQEAAAAAAIAQ4nI65PKw+Kyn4/AvirQAAAAAAABACHF6mUnr6Tj8q+oVhAEbvPrqqzp27JjXPosXL1bbtm01ceJE5eXl+WhkAAAAAAAAoSPM6VC4hy2MmbQBiSItfObWW2/Vvn37vPY544wz1LZtW/3tb3/TlClTfDMwAAAAAACAEFK63IGnDYGHIi18xrKsk/Y5//zztXr1as2dO1eLFy/2wagAAAAAAABCi1OS0+Fh8/fgUCXWpEVA6tat20ln3QIAAAAAAKAyp8MhF2vSBhWKtLBNWlpa2X7pLNr09HTVrVvX4zmWZenw4cOaPXu26tWrZ/sYAQAAAAAAQk24y6FwV9XFWE/H4V8UaWGbNm3aVDo2cODAap//+9//3uRwAAAAAAAATgslSxt4mknr48GgWijSwjZVrUFbnXVpXS6XBg4cqDlz5tgwKgAAAAAAgNDGcgfBhyItbLNr166yfcuy1K5dO/3nP/9R+/btPZ4TFhamJk2aKDIy0hdD9JsGzWIUUd/zsg+1cfywy2g8SVr/+qvGY0pScsYJ4zFT/tLPeExJ6vWn922Ju3Tpl8ZjOsMijMeUpBPHzP+pyDtRYCxW0YnjxmL5Unz9SDVsEGU0ZlaOuX/XUs/9Z6fxmJJ0OLfyty1O1fTBZxmPKUm3LtpsS9zNe44aj1k3Otx4TEn6/kC28Zim7yqceyzfaDxfKY7voOIWCUZj/phn/u+BQ/Zcm7WJKjIec0CbBsZjStLX+7NsiXtBh6bGYy78Iu3knWqhueG/W5JUP8bs6zUrIzivCw6cKJLjeKHRmEu2HjAaT5Ka1rUnF6Rnm8/hy+/sbTymJF1sw3sZSYqIbWg85o5VS4zHlKQDiV2Mx3RFms0vxTlHjMYLRk6Hw8tMWoq0gYgiLWyTmJhY4b8ty1JCQkKl4wAAAAAAADAn3OllTVrWOwhIFGnhM7t27VKLFi38PQwAAAAAAIDQ5pA8TpilRhuQnP4eAE4fiYmJCgur3ucCOTk5Wrdunc0jAgAAAAAACD1OObxuCDzMpEVA2rVrl/r376/i4mJ/DwUAAAAAACCoOLzMpGVJ2sBEkRY+k5ZW/RsY/PzzzzaOBAAAAAAAIHQ5HSWbpzYEHoq08JnWrVvLwcc1AAAAAAAAtnI5HHJ5qMF4Og7/okgLn7Isq9p9KegCAAAAAADUAjcOCzoUaeFTq1atUvv27SsdLyoqUmZmpr744gvNnz9ft956q6655ho/jBAAAAAAACC4sdxB8KFIC59KSEhQYmJilW3t2rXT+eefr9tuu02XX365zj//fI99AQAAAAAAUDWHPE+YpUYbmJx2BJ0yZYocDofH7eWXX650zscff+z1nFtuuaVC/6ysLC1YsEDXXnut2rZtq5iYGMXExKh169a69tprtWzZsmp9td7bY5bfhgwZYuhfp0RKSkrZGq1Tpkyp9nlHjx7V66+/rlGjRqlbt25q0KCBwsLC1KBBA/Xs2VMPPPCA9u7da3SspqSnp6tDhw4n7RcdHa1Jkybp0Ucf9cGoAAAAAAAAQovL4ZDL6WFjecmAZMtM2quuukpnnnmmJGnChAnKzMxUkyZNNHv2bEnShRdeWOmcpKQkLVy4UJI0f/58ffLJJ5Kk2bNnq0mTJmrXrl1Z36lTp+rJJ59Udna2GjVqpJEjR5YV/9asWaOlS5dq8eLFSk5O1uLFi9WwYUM7nmatZGdna9KkSXrhhRdqtD6rJP33v/9VcnKy8vPz5XA4NGzYMI0YMUL16tXT999/r1dffVUzZszQ3//+d73yyiu6+uqrbXoWtRMXF1ejvhs3brRxNAAAAAAAAKHJKc8zM22ZsYlTZkuR9uyzz9bZZ58tSXrwwQeVmZmpOnXqaOTIkR7PiYuLK2tfvXp1WZF22LBhat26dYW+ixYtUnZ2tnr27KmVK1eqUaNGZW3jxo3TihUr9Nvf/lYfffSRhg4dqnXr1snp9PwSnD59uoYPH+71OdWtW9dre3WkpKToD3/4g/bu3asBAwZo9erVNTr/2LFjys/Pl9Pp1IoVK3T55ZdXaP/LX/6iPn36aNu2bbr++uv17bffqmPHjqc8bn/YsGGD8vPz/T0MAAAAAACA4PP/3wz31IbAE9TF85dffrlCgbbUlVdeqdtuu02S9Nlnn+lf//qX1zjNmzdXx44dvW4tW7Y8pbGuWbNGl112mSIjI7Vu3Tr95S9/qXWsW265pVKBVpIaNWqkWbNmSZIKCgr0j3/8o9aP4Q+FhYXas2ePFixYoAceeEBJSUn+HhIAAAAAAEDQKb1xmKcNgSdoi7RnnnmmOnXq5LG9/Ff9//3vf/tiSF5lZ2drwoQJ+uabb3TRRRfVKkb9+vXVvXt3r8sY9OjRo2x/+/bttXocu7hcLq9bVFSU2rZtq9GjR+v48eO6++67/T1kAAAAAACAoONyeN98IT8/XzNnzlS3bt0UGxurBg0aqHfv3nr++efldrtPKXZWVpb+8pe/KCkpSTExMWrSpImSk5P15ptvGhq97wVlkfb555/XG2+84bVPq1atyvbT0tLsHtJJDRkyRE899ZSio6NrHaN3797atGmTrrjiCo996tSpU7Z/Ko9lB8uyqrUlJCRo7ty5uummm/w9ZAAAAAAAgKDj+P/lDjxtdsvMzFTPnj01efJk9erVSx988IGWLl2q5s2ba+zYsbrsssuUl5dXq9g//PCDunbtqscff1zDhw/XRx99pFdffVVut1sjRozQyJEjT7kI7A+2rElrt379+p20T1ZWVtl++cLlyeTk5MjtdhtZg7Y8X/wCSNKXX35Ztt+/f3+fPGZNLFiwoNIaw6UiIyMVHx/vsR0AAAAAAAAn521ZA18sd3Dttddqy5YtGj9+vObMmVN2vH///ho+fLiWLVumsWPHasGCBTWKm5+fryuvvFJ79+7V7Nmzdc8995S1XXrppbrooov0+uuvq3379nrkkUcMPRvfCMqZtNWxa9eusv1LLrnEa98ffvhBY8eOVbNmzVSnTh3FxsYqOjpaffr00bx584LmBlYFBQV68MEHJUldu3bV6NGj/Tyiynr27Km+fftWuV1wwQUUaAEAAAAAAAxweNjstmTJEn388ceKiorSlClTKo7J4dCMGTMkSa+88kqFyYbV8eyzz2rnzp1KSEjQXXfdVaEtIiJCf/3rXyVJM2fO1M8//1z7J+EHPptJ63a7lZmZWa2+Joqi7777rqSS2Zm33nqr177Tpk1T69atNX78eHXp0kVut1tffPGFnn/+eX3yySeaN2+eli1bpnbt2p3yuEzKz8/X0aNH9csvv2j9+vX629/+ps2bN+t3v/ud5s+fH3DLHXzwwQcUYQEAAAAAAGzmz5m0L774oiQpOTlZDRo0qNSelJSkpKQkpaam6qWXXlL37t1rHHvYsGFyuVyV2gcOHKjY2FgdP35cr7/+uiZNmlS7J+EHPivS7t27V02bNvXJY2VkZJQVaf/0pz8pISHBa/8rrrhCb7/9doVlEYYPH6477rhDl1xyibZt26ZBgwZp48aNatiwoZ1Dr5FFixZVKEC3atVKb7zxhq677jqfLa9QE4MGDfL3EAAAAAAAAEKeyym5PFRjXTZ+r76goEApKSmSSr5N7UnPnj2VmpqqFStWaO7cudWKvWvXLu3YscNrbJfLpW7dumndunVasWIFRdqqxMXF6bXXXqtW31mzZmnVqlW1fqxJkyYpNzdX5557rh5++GGvfXft2qWEhARFRERUamvdurXmzJmja665Rj/++KOmT5+uWbNm1Xpcpg0aNEgffvihTpw4oZ07d+q1117T9ddfrylTpuiZZ57RwIED/T1Ej7788kv9+9//1vbt23Xs2DHVq1dPnTt31m9+8xudd955/h4eAAAAAABA0PK2tIGd0/pSU1NVWFgoSV6/TV3atmfPHmVlZal+/fonjb158+ZK53uKvW7dugr9g4HPirRRUVG69NJLq9W3usXcqixatEivvPKKmjZtqqVLlyoyMtJr/5N9/X7YsGFq3LixfvnlF7300kuaOXOmnM7AWMq3efPmat68edl//+lPf9KECRP097//XYMHD9brr7+u6667zo8jrCwzM1OjRo3SihUrKrUtXbpUjz76qIYMGaJ//vOfatKkiR9GCAAAAAAAENyccsjp4VvWznJl2vT09JPGatmyZbUfNy0trWzf2zfqy7ft27evWkXamsY+cuSITpw4UeGb84HMZ0VaX/jvf/+rP/zhD4qNjdWKFSvUpk2bU47pcrl07rnnKiUlRYcPH9aOHTvUqVMnA6M1z+l0avbs2UpJSdG2bds0ZswYDRw4UI0aNfL30CRJJ06cUHJysrZt2ybLsiRJjRo1UkxMjHJycnT48GFJ0vLly5WcnKzPP/88aH6RasqyJMttNmar9uaL2kWFQ43HlKQdq5YYjzm8kT1rMG986gpb4vaZkmI85tFq/HGtjbywyt80OFXRsd4/QKuJQpkfny8cOl6g/CizN6ZMbGI+Zx5KsOfmmf/8d6rxmC6blvpZMOJsW+Leusj8J/uHs/KMx5Qkpw0LlznDzH7onVdQZDSerxy2ohRlmf0bdiyvwGg8SWoYbc/bhj3ZlvGYbRwHjceUpIkXJ9oS972dvxiP2ayeub+z5e07nGM85stvm82FRSfM/3v6wlfpx9XInWU05o6fjxmNJ0m5NlxrSNKBY+b/fjWrY8814md/rd7ks5r67fMbjMeMrGtPLSD74G7jMY/u2Wo0nlVwwmi8oOSQPF4elzveq1evk4YqreFUx/Hjx8v2o6KiPPYr33bsWPXyVW1jB0ttKTCmhBrwzTffaMiQIXK5XHr//fe9rntRU82aNSvbr84nDP7kdDp1/fXXSyp58S5evNjPI/rVzJkztXXrVnXv3l3vvPOOjh07pszMTKWlpSkzM1NZWVlasmSJzjvvPG3btk1PPPGEv4cMAAAAAAAQdByWWw53cdWb6VljMCIkZtJu3rxZl156qQoKCvT+++/r4osvNhrf7f71xVvVneMCTYcOHcr2t241+2nUqXj77bfVt29frVq1SuHh4ZXaY2NjNXz4cA0dOlSXXnqp3nzzTU2dOtXY4/fr109r1649ab86deooOzvb2OMCAAAAAAD4ksNyeyzGlj++YcOGCktpnqrY2Niy/bw8z7Pky7fVq1fP77EDQdAXabdv365LL71UOTk5WrFihfr06VPtc5999lnVq1dPN910k9d+Bw4cKNs3+cKtqQ8++EAxMTHq27ev135hYb/+WIuKAuerf3v27NFTTz1VZYG2vLCwME2cOFHXXnutj0YGAAAAAAAQQiy353UWyx1v3rx5jdacPZlWrVqV7WdkZHjsV76tuo9f09gNGzYMmqUOpCAv0n733XcaMGCAjh8/ruXLl6t///6V+kydOlXvvfeeNm3aVKntySefVFRUlNcibX5+vr7++mtJJQsPn3XWWeaeQA2NHTtWdevWPens2O+//75sv/wL2N/q1KmjFi1aVKtvixYtVLduXeNjGDZsmGbMmOG1T6DcGA4AAAAAAKBWLKtk89Rmk6SkJIWHh6uwsFC7d+/22K+0LTExsVo3DZOks8/+9V4R1Yldvn8wCNpq1A8//KDk5GQdOXJEy5Yt04ABA6rst2vXLn355Zce4+zcuVM//fSTx/Y33nijbAHj2267TY4qVl1+88031bhxY/Xq1avCrFs7pKamen0hut1uLVy4sOy/r7zySlvHUxPnnHOOtm/fXq2+qamp6tGjR4VjOTk5Wrdu3SmNoX79+urYsaPXzZ+FeAAAAAAAgFNVsv5skYet2LbHjYiIKKvRVTVhstTGjRsl1axu1aZNG3Xs2NFr7OLi4rLJloFUE6uOoCzS/vTTT+rfv79+/vlnjR8/XhEREfr444+r3E5WNLUsS7feemuFO8SV+uabbzRx4kRJUseOHXX//fdXGWPChAk6fPiwNm7cqL///e+n/gS9cLvduvHGG6t8XsXFxfrjH/+ozZtL7pB66623qmvXrraOpyZuv/12PfbYY8rK8n7X0iNHjmjatGmaNGlSheO7du2qcrY0AAAAAAAAyild7sDTZqPRo0dLklJSUqqsAe3YsUOpqalyOBwaNWpUrWK/++67Fe4hVerDDz/U8ePHFRUVpeuvv74Wo/cfW5Y72Lx5c1mh8MSJE2X//9prr0mSLrzwQrVt27bCOQcPHtSHH34oSRVmtr777rtq0qSJ2rVrp969e0uSkpOTtW/fPknSE088oSeeeKJW4zznnHO0Z88erVu3Th06dNANN9ygjh07qrCwUOvXr9eiRYtUUFCgnj17asmSJR4XGy7/orC8TBn/8MMPdfDgQUklM0VLbd68uezfRpJGjhzpdbyffvqp2rVrpxEjRqhDhw5q3Lixdu/erbfeeks7d+6UVFKgfeGFF6r/j+EDF1xwgc477zx16dJFd999ty666CLFx8crLCxMRUVFOnjwoD755BPNmzdPt912m84880ylpaWVnf/zzz/7cfQAAAAAAABBoppr0trh6quvVt++fbV27VpNnTpVTz/99K8PbVl64IEHJEk333yzunfvXuHc9957T6NGjVJcXJyWL1+u1q1bV2i/8847NX/+fO3cuVPPPvus7r777rK2wsJCPfzww5KkyZMnV3vJzUBhS5F26dKlmjp1aoVjmZmZuvHGGyVJCxYsqFSkTU1NLWsvb8KECZJKfnClRdo9e/YYGeeyZcu0bds2LV26VGvXrtUbb7yhzMxMOZ1ONW3aVEOGDNF1112nq666Si6Xy2Oc2bNn66677lLbtm0rvDj+17Rp07R27dpKx9955x298847Zf/tqUi7bNkybd26Ve+8847WrVunVatW6Y033lBhYaFiY2PVtm1b3XXXXbrpppsqLRUQCFq3bl22XMTkyZO99n344YfLfrHsUlBQoNzcXNWrV6/KZSwAAAAAAACCkh+LtJK0ePFiJScna/bs2crNzdXIkSNVUFCguXPn6p133lFycrKee+65SufNnz9fmZmZyszM1NKlS3XvvfdWaI+MjNSKFSuUnJyse++9V4cOHdKQIUN05MgRPfHEE9q4caNuuOEGPfTQQ7Y/R9NsKdJOmTJFU6ZMqdE5/fr18zoLtbzq9quOzp07q3Pnzqf0w7v++uurNYX6448/rvVjlOrSpYu6dOlyynH85VR/dqdaTD169KimTZuml19+WT/++KMsy5LL5VKnTp00dOhQjR8/Xs2aNatV7NLZ3Z6kp6fXKi6A4EEeACCRCwCUIBcA8CvLkqpYDqCszWZNmjTRxo0bNWfOHC1atEgLFy6Uy+VSUlKS5s2bp9tvv73KG7ePGTNGn3/+ueLi4nTVVVdVGfvMM8/Uli1b9MQTT2jJkiV66qmnFBMTo3POOUeLFi3SddddZ/fTs4UtRVrAk1WrVql9+/a1Ove7777T4MGDT+nxly1bppSUFI0ePVoXXnihoqOjtWPHDs2fP1/Tp0/XvHnz9MYbb9Tqcc4444xTGhuA4EceACCRCwCUIBcA8KfSm4R5avOFyMhI3X///R7v8VSVoUOHKjMz86T96tevr2nTpmnatGmnMsSAQpEWPpWQkKDExMRanZudnX3KM3Fbt26tjz76SG3atCk7NmTIEN15550aOnSoVq9ereHDh2vdunXq1avXKT0WAAAAAACAX1iW5xmzPphJi5qjSAufWbNmTYXiaE21adNGa9asqfX5b775pmJiYqq8AVxUVJReeeUVtW3bVvn5+brzzju1YcOGGsXfu3ev1/b09HQKv0CIIw8AkMgFAEqQCwD4lZ/XpEXNUaSFz/Tt27fafXNycrRp0yb16dOn7FhMTEyNYvyv+Ph4r+0JCQm6/PLLtWzZMm3cuFHffvutzjnnnGrHb9myZa3HBiA0kAcASOQCACXIBQD8yWFZcngoxjqYSRuQKq/QCwSAXbt2qX///j5/3B49epTtf/bZZz5/fAAAAAAAgFPmLvK+IeAwkxZ+kZaWpgMHDigvL6/K9p9++snHIyrRrFmzsn3utgoAAAAAAIKTl+UOxHIHgYgiLXzqH//4h6ZNm3bS9Zn8xe3+NVG5XC4/jgQAAAAAAKB2HJbby3IHFGkDEcsdwGcWLlyoO+64Q2lpabIs66SbSe+9954ee+yxk8Y9cOBA2X7z5s2NjgEAAAAAAMAn3JbkdnvYWJM2EFGkhc/MmTNH0dHRmjdvnr7//nvl5OTI7XZXuW3evNnoYy9ZskQPPfSQDh486LXf+vXry/Yvvvhio2MAAAAAAADwCcvyviHgUKSFz6SmpmrGjBm644471K5dO0VFRXns63A4jM+mlaQPPvjAY9v333+v1atXS5IuvPBCde7c2fjjAwAAAAAA2M3hLvK6IfBQpIXPREVF6YILLqhW386dO1dYH9aUP//5z9q5c2el44cPH9aIESNUXFysmJgYzZ071/hjAwAAAAAA+ITl9r4h4HDjMPhMz549lZGRUa2+xcXF2r9/v1q1amXksTt16qTw8HAdPHhQ5557rq677jr17NlTERERSk1N1auvvqqMjAzFxcXprbfe0rnnnmvkcQEAAAAAAHzOsjwXY1nuICBRpIXPPPDAA5oyZYouu+wyhYeHe+27Y8cOnX322SouLjby2Pfdd59uuukmLV26VB9++KHWrVunt956S4WFhWrYsKHOPvtsDRkyRH/4wx8UGxtr5DG9SWheTzGN6huNGR3hMhpPkn5pHGM8piQ1P3eA8ZhbU9YajylJN9SNtCXu2inm/w36//Uj4zElqSDfzO9hea4wc1/kcBuM5Uvtm8SocbO6RmPuO5ZnNJ4kdWlpNleVio0yfwny/rfpxmNKUrM6EbbEXTDibOMx//TeDuMxJelwdoHxmKb/buUU25Ov7dYg0qlGUWb/Ld7YfNhoPEm6pnOc8ZiSVGzDjUvcMQ2Nx5SkqPwsW+IOPaux8ZhPfrrHeExJio4wn7svu/RMo/Gyf4nVokVGQ/pEr5b11DyhgdGYs9/ZZjSeJA2yKRfkF5uf1Rdl0zXivmOFtsRddkcv4zH7PrrGeExJCo/qYDxmWLTZ6+LinCPK3P620ZhBxyqW3B7ey1nm3+Ph1FGkhc+0adNGgwcPVs+ePXXHHXeoR48eaty4sVyuym9Mfv75Z+OPHx8fr3HjxmncuHHGYwMAAAAAAAQKq6hIVlHVHypYRaxJG4go0sJnWrduLYfDIUn64x//6OfRAAAAAAAAhCi3l5m0no7DryjSwqesGqx7UlrQBQAAAAAAQPVZ7mJZHpaQtCjSBiSKtPCpVatWqX379ift991332nw4ME+GBEAAAAAAECIcbtLNk9tCDgUaeFTCQkJSkxMPGm/7OzsGs26BQAAAAAAQAmrqFBWUdU3f/W0Vi38iyItfGbNmjVq06ZNtfp26NBBu3btsnlEAAAAAAAAIcjyMpPWYiZtIHL6ewAITX/961+VmZlZ4Vjfvn0VHR1drfOPHDmiV155xY6hAQAAAAAAhDTL7S5Zl7bKjSJtIKJIC1tMnTpVhw4dqvX5hw4d0tSpUw2OCAAAAAAA4DThLva+IeCw3AFsYVmW0tPTVbdu3Vqd//PPPxseEQAAAAAAwGmCG4cFHYq0sM3AgQP9PQQAAAAAAIDTjlVUKKuQG4cFE4q0sI1lWad0vsPhMDQSAAAAAACA04i3ZQ1Y7iAgUaSFbaZNm6aEhIRanbtv3z49/PDDhkcEAAAAAAAQ+kpuHFb1sgbcOCwwUaSFbX7729+qU6dOtTp327ZtFGkBAAAAAABqw+32MpOWIm0gokgLW9x8881q2LBhrc9v2LChbrrpJoMjAgAAAAAAOD1YxYUe1561ilmTNhBRpIUtFixYcErnJyQknHIMAAAAAACA0xIzaYMORVoAAAAAAAD8X3t3HlxVff9//JWErBAgskPYtLIoKGoAETUICm604lqmVBz1h0XtaN2tOOC3RUTxB99RsauofMelCmrRSmuCS7WNGh3xIqhUZQkESAwJS9Z7z+f7R8r9kiY3EPice+45eT5m7syZ+znnnU9yk1dO3jn3cxAk3DjMd2jSAgAAAAAAAEHiRGQiNGn9hCYtAAAAAAAAECThsBRjTVqFw/GdCw4LTVoAAAAAAAAgQIwTkYlxxWys5+EtmrQAAAAAAABAgBjHkYlxg7BYz8NbNGkBD2zZUqm0Srs/fgMH5VitJ0kZHVOt15SknN7259ox5zTrNSXp/edecqXulQ32/3P5t/vOsV5TkibPf9t6zUjY3kmBzVrxtH7nPnWO7LFas1unNKv1JCklOcl6TUnq0TnDes3MtBTrNSXp/69a70rdkvxjrddceNFQ6zUl6WcvrbNes97yz2592FitFy9hIzVYjrHRuV3tFpTUwaUsyEpNtl6z2rgz14YUd/50yqndbb3m7eMHWK8pSSs2lFuveVz3jlbrVXSs1/NWK8ZHVW1EGTV2zw9HDuthtZ4kOS5FbU6G/b87vqussV5TksIRd74IHZKzrddcc98E6zUl6SfLP7Nec29uZ6v16qrKVP4XqyV9xzhGJhKrSevP86ago0kLAAAAAAAABIiJOLGbtDGeh7do0gIAAAAAAAAB4oTDchpavkGYw43DEhJNWgAAAAAAACBAuJLWf2jSAgAAAAAAAAFiIo6cSMtrXdOkTUw0aQEAAAAAAIAAMcaRcWJcSWto0iYimrQAAAAAAABAgDj1YTn1MdakjfE8vEWTFgAAAAAAAAgQ45jYV9I6Js6zweGgSQsAAAAAAAAEiOM4cmKsPevEaN7CWzRpAQAAAAAAgAAxESfmDcK4cVhiokkLAAAAAAAABIgJR+Q0tLz2rAlH4jwbHA6atAAAAAAAAECAcCWt/9CkBQAAAAAAAAKEJq3/0KQFAAAAAAAAAsQxTswbhDmGJm0iokkLAAAAAAAABAhX0voPTVoAAAAAAAAgQJyGsJyGhphjSDw0aQEAAAAAAIAAMU4rV9LGWAYB3qJJCwAAAAAAAARJK8sdiOUOEhJNWgAAAAAAACBAnIiRE6MZ60RMnGeDw0GTFgAAAAAAAAgQJxyOufasE2ZN2kREkxYAAAAAAAAIEBMxMjGumI31PLxFkxYAAAAAAAAIEMdxYi93wI3DEhJNWsADPftkKzOni9Wa++rsv10ho2Oa9ZqSVPV9tfWaKR2SrdeUpG4/ONWVusWvvG695lUNEes1JalgzkTrNc+672/WaoXr3fm83da/a6ZyumVZrbnJhZ+tfl0zrdeUpO/31VmvmeZSDvTr09mVuv/zt43Wa6aluPM1+P2VI63XnPncWqv1Gnx6A4xU06A0U2+15qbd9rNgYJd06zUlqS5s/3Vz6zthb507v2++i2RYr3lyVpL1mpJ01Yk9rNdc+PfNVuvtqayxWi9e+nRKVd/OqVZrbnXhvCArNcV6TUmqcuFvmWqXzo037tjrSt2PNldYrzllWE/rNSXppWvs/400ZckHVusZhytFjWNifh34+iQmmrQAAAAAAABAgJhI7BuEGX9e5xJ4NGkBAAAAAACAAHEaInJivOvQcelKcxwdmrQAAAAAAABAgDgRE/NK2ljPw1s0aQEAAAAAAIAAMRFHJsaa/bGeh7do0gIAAAAAAAAB4hgjJ8YNwhzDlbSJiCYtAAAAAAAAECBOvaNIcow1aeu5kjYR0aQFAAAAAAAAAsQ4RibG2rMmxhW28BZNWgAAAAAAACBATKSVJi03DktINGkBAAAAAACAAHEijpwYNwiL9Ty8RZMWAAAAAAAACBAn7CiSHKNJG6ZJm4ho0gIAAAAAAAAB0rjcQcvNWJY7SEw0aQEAAAAAAIAA4cZh/kOTFgAAAAAAAAgQJ2LkJLfcjHW4kjYh0aQFAAAAAAAAAsQ4jowTY7mDGM/DWzRpAQAAAAAAgACJNDiKmJabsRFuHJaQaNICAAAAAAAAQRJxZJJiNGNj3FAM3qJJCwAAAAAAAASIE5GcpFhr0sZ5MjgsNGkBAAAAAACAADGOkYlxgzDjcOOwRESTFgAAAAAAAAiQBsdRQ4zlDhq4cVhCokkLAAAAAAAABIhjpBgX0ooLaRMTTVrAA7u/36/94X1Wa4Yb7P8nzK23QKSkJFuvua+y1npNSQrX17hSNyU903rND59bbr2mJP2/zhnWa771X+daq1W6fZvOeNZaubjZXlWrfWl2v7++3L7Haj1JKq1052cgO8P+KciuPXXWa0rSvtqwK3XdyML5//2m9ZqSlHXHxdZr/vbKkVbrbd+2TaPvtVoyLsrqk9Whzu73wrYq+78Tv9vtzu/Z9A72fw6yUlOs15SkWpfuhF3nQt3/Ce2yXlOSrhnQYL3mz8f1t1pv+7Zk/bfVivHx9fe12m35vGBvhf3f4Wu+cud7q5ML5wVpHdzJgup6dxbzLHXh75m5L31uvaYkPTtrrPWar9w0zmq97du26bRHrJb0nYgxipiW/6aP9Ty8RZMWAAAAAAAACJBIK1fSxnoe3qJJCwAAAAAAAARIgzGqj/Hu2AaupE1INGkBAAAAAACAAGG5A/+hSQsAAAAAAAAECDcO8x+atAAAAAAAAECAsCat/9CkBQAAAAAAAAKE5Q78hyYtAAAAAAAAECANjlG9Ytw4jPUOEhJNWgAAAAAAACBAWO7Af2jSAgAAAAAAAAHSeOOwlruxXEibmGjSAgAAAAAAAAESUStX0sZ1JjhcyV5PAAAAAAAAAIA9YWPUEOMR9umNw+rq6rRw4UKdcsopys7OVteuXTVu3Dj95je/keM4R1x3//79Wr58ua688kode+yxyszMVFZWlo477jjNmDFD7733nsXPIjaatAAAAAAAAECARIxp9eE35eXlGj16tO655x6NGTNGb775plauXKk+ffpo9uzZOu+881RbW9vmup988okGDBigq6++WuvXr9ecOXNUWFiot956Sz/96U/1yiuvKD8/XzfddJOMy183ljsAAAAAAAAAAiRiYi9r4Mcbh11xxRUKhUK65ZZbtGTJkujz55xzjqZNm6bXXntNs2fP1rJly9pUt7S0VBUVFRo1apSKioqUnp4eHRs/frzGjBmjiy66SEuXLtXgwYN1xx132PqUmuFKWgAAAAAAACBAnFauonV8diXtihUr9M477ygjI0Pz5s1rMpaUlKQFCxZIkp555hl98sknR/Qx7r///iYN2gMuvPBCnXXWWZLUpDnsBpq0AAAAAAAAQIDUO6bVh5/84Q9/kCRNnDhRXbt2bTY+fPhwDR8+XMYYPfXUU22qfdxxx+n222/XhAkTYu5z8sknS5K2bdum77//vk3124ImLQAAAAAAABAgjvn3kgctPPzUo62vr1dhYaEkafTo0TH3OzD2xhtvtKn+8OHDtWjRIh1zzDEx90lJSZEkJScnKzMzs03124I1aQEAAAAAAIAA2WPCMW8Qtv+g1WpLS0sPWSs3N9favNpqw4YNamhokCQNGjQo5n4HxjZv3qyqqip16dLF2hw2btwoSTrttNOUlZVlre5/okkLAAAAAAAABMgK7Tis/caMGXPIfYyHa9hu2bIlut2jR4+Y+x08VlJSYq1JW15eroKC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",
      "text/plain": [
       "<Figure size 1600x700 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create figure with 2 rows and 5 columns of subplots\n",
    "fig, axes = plt.subplots(2, 4, figsize=(8, 3.5), sharex=True, sharey=True, dpi=200)\n",
    "\n",
    "# Plot each matrix\n",
    "offsets = [-2, -1, 1, 2]\n",
    "for i, (ax, offset) in enumerate(zip(axes[0], offsets)):\n",
    "    im = ax.imshow(head_diffs_offset[offset][(39, 7)].cpu().numpy(), cmap=\"RdBu\", vmin=-0.6, vmax=0.6)\n",
    "    ax.set_title(r\"$k={}$\".format(offset), fontsize=9)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i == 0:\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "\n",
    "cbar = fig.colorbar(im, ax=axes[0].ravel().tolist(), shrink=0.85, ticks=[-0.6, 0, 0.6])\n",
    "cbar.ax.tick_params(labelsize=9)  \n",
    "axes[0, 0].text(-0.5, 0.5, \"H39.7\", transform=axes[0, 0].transAxes,\n",
    "               va='center', ha='right', fontsize=10)\n",
    "\n",
    "for i, (ax, offset) in enumerate(zip(axes[1], offsets)):\n",
    "    im = ax.imshow(head_diffs_offset[offset][(25, 13)].cpu().numpy(), cmap=\"RdBu\", vmin=-0.2, vmax=0.2)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i == 0:\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "\n",
    "# Add colorbar\n",
    "cbar = fig.colorbar(im, ax=axes[1].ravel().tolist(), shrink=0.85, ticks=[-0.2, 0, 0.2])\n",
    "cbar.ax.tick_params(labelsize=9) \n",
    "# plt.tight_layout()\n",
    "axes[1, 0].text(-0.45, 0.5, \"H25.13\", transform=axes[1, 0].transAxes,\n",
    "               va='center', ha='right', fontsize=10)\n",
    "\n",
    "plt.savefig(\"figures/fv_different_offset.pdf\", dpi=300, bbox_inches='tight', pad_inches=0.0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Bonus: Effect of FVs in Standard Addition"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 25/25 [02:16<00:00,  5.47s/it]\n"
     ]
    }
   ],
   "source": [
    "offset = 1\n",
    "fvs_standard = {}\n",
    "\n",
    "data = load_data(offset)\n",
    "batch_size = 4\n",
    "for st in trange(0, len(data), batch_size):\n",
    "    ed = st + batch_size\n",
    "    batch = data[st: ed]\n",
    "\n",
    "    for head_layer, head_idx in heads:\n",
    "        t.cuda.empty_cache()\n",
    "        _, _, _, _, normal_cache, contrast_cache, normal_logits, contrast_logits = prepare_data_for_fwd(model, batch)\n",
    "        \n",
    "        head_out = normal_cache[utils.get_act_name(\"z\", head_layer)][:, -1, head_idx, :]\n",
    "\n",
    "        if (head_layer, head_idx) in fvs_standard:\n",
    "            fvs_standard[(head_layer, head_idx)].append(head_out)\n",
    "        else:\n",
    "            fvs_standard[(head_layer, head_idx)] = [head_out]\n",
    "        del contrast_cache\n",
    "        del normal_cache\n",
    "    \n",
    "for head_layer, head_idx in heads:\n",
    "    tensors = fvs_standard[(head_layer, head_idx)]\n",
    "    fvs_standard[(head_layer, head_idx)] = t.cat(tensors, dim=0).mean(dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "head_diffs_standard = {}\n",
    "for head_layer, head_idx in heads:\n",
    "    fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fvs_standard))]\n",
    "    fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "    fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "\n",
    "    diff = fv_applied_logits - digit_logits\n",
    "    head_diffs_standard[(head_layer, head_idx)] = diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# aggregated effect of 9 heads\n",
    "fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fvs_standard)) for head_layer, head_idx in heads]\n",
    "fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "\n",
    "diff = fv_applied_logits - digit_logits\n",
    "normalized_diff_standard = diff - diff.mean(0).mean(0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwkAAAFjCAYAAAB2a0eZAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZX1JREFUeJzt3Xl4E9X+P/D3JG1ToAtt2S6llEW+gCAUyl6gVUD8CSK4IohUrooo7hfcC6KI3KuIuCMgF9TL1SsIbqgg4HZlE5QvX0DAAmUrZetO2iSf3x/Y0dCUnEkT0nTer+fJ8zSTT8+cyefMJCdzZo4mIgIiIiIiIqLfWYJdASIiIiIiqlnYSSAiIiIiIjfsJBARERERkRt2EoiIiIiIyA07CURERERE5IadBCIiIiIicsNOAhERERERuWEngYiIiIiI3LCTQEREREREbthJ8JMNGzagV69e0DQN3bp1w7p16wAA69atQ7du3aBpGnr16oUNGzZg2bJlGDx4MAYNGoTOnTtj9OjRyM/P18vKy8vDyJEj0b9/f3Ts2BHTp0+vcr1r165FixYtkJGRoT/at2+PYcOGBXybzSxY+a7w2WefoUmTJli4cKHb8uPHj+Nvf/sbLr30UvTr1w/9+/fHhg0b/LrtVJk/2wMArFy5Ev3790e/fv3Qvn17/P3vf/e43n379qFJkyZu+3+XLl3QqVOngG8zufNXG3A4HHj55Zf1fHbt2hXvvPOO1/VXdUygCyPY+X/hhRfQu3dv9O3bF506dcIXX3wR0O0lkxDym+zsbAEgW7ZscVu+ZcsWASDZ2dkiIjJ48GD5/PPPRUTEbrdL165d5d5779XjBw4cKA8++KCIiJw8eVKaN28ub7/9tsd1fvvttzJjxgy3ZRMmTJBFixb5Z6OoSsHIt4jIjBkz5L777pOmTZtWinv77bflqquuEofDISIir7/+ujRo0EBOnz5dvY0lr/zVHtavXy9dunSR48ePi4jIzp075a677vK4zv3798uECRPcls2cOVOmTZvmp60iI/zRBrKzs6VZs2Zy4sQJERH5+eefJSIiQr777rsq13u+YwJdOMHK/6xZs2T06NH6cX/x4sVsB+QX7CT4keoBYtOmTeJyufTXb7vtNrnqqqtERCQnJ0cAyPbt2/XXJ02aJD169FCqg91ul+TkZCkqKqrexpBXwcr3gQMHREQkOTm50gfB999/L99//73+vLCwUADI119/7csmkgH+aA8iIldddZXMnTvX53pccsklsm/fPp//n3znjzZw/PhxWbBggdv/p6amSlZWVpXrPd8xgS6cYOS/rKxM4uPj5ddff/XfhhD9jsONgiA1NRWapgEAsrOz8dVXX2HcuHEAgEOHDgEAGjRooMc3adIEW7duhYh4LfvTTz/FZZddhnr16gWg5uQLf+c7KSmpynX16dMHffr00Z+XlpYCABo1alS9jSC/OV97EBGsWbMGdrsdV155JdLS0nDfffehuLhYqewtW7agQYMGSE5ODlj9qfrO1wYSEhJw6623usWXlpaicePGVZZ3vmMC1Tz+zP/WrVtRWFiIzZs368NM58yZE9gNINMIC3YFaqPbbrsNUVFR+vOioiKPcf369cPWrVsxbdo0DB8+HMAfB/tDhw7pX+yOHDmCsrIylJSUeP3yv3jxYtx3331+2ApSFcx8e/PRRx9hwIAB6NChQ7XKIXXVaQ95eXkoKirCq6++im+//Rb169fHtddei9tvvx3vvfee13UvXrwYY8eO9ct2kO+q0wbO9euvvyIvLw833XRTIKpKAXAh85+dnQ2n04mlS5di1apVOH78OHr16oXIyEjccccd1d4WMrkgn8moVVRPNf5ZXl6edO/eXZ5++ml92eWXXy6jRo0Sp9MpBw8elOTkZAEg5eXl513/iRMnpG3btm6nMSlwgp1vb0MLjh49Kh07dvRYD/I/f7SHiuFnf76m4OuvvxZN07wOIXQ4HNK6dWspLCys9raQb/x1TKjgcDhk0KBBsnz5cqX1c7hRcAUj/4sXLxYA8s033+jLsrKylIcoE50PhxsFWYMGDfDggw9i5syZ+vCSJUuWoF69eujbty/uuusu3HnnnUhMTERY2PlP/Pz73//GjTfeqJ/GpJrHn/k+n+LiYowaNQpz585FixYt/FR78rdz20P9+vUBwG1oQWJiIkREH5pWlS+//BJpaWluv2BSzefpmFDh/vvvx9ChQ3m3ulqsuvmPi4sDUPmYkZOTE5gKk6mwkxAEM2bMcHtet25d2O12OJ1OAGd3+rlz5+KHH37A8uXL4XQ6MXDgQK/lvvPOOxxqUAMFKt9VKSsrw4033ojJkyejd+/eOHbsGI4dO1atbSD/OV97iIqKwv/8z/+45SsvLw/A2Q/+81m0aBEyMzP9Xl/yP2/HBADIyspCfHw87r33XtjtduzevftCV5MCxJ/579KlCzRNq3TMaNasWWAqT6bCTkIQPPPMM/oO73A4sHDhQgwYMED/5XjMmDE4ePAgAODgwYNYtGgRHn74Yf3/R48ejffff9+tzD179iAsLAytWrW6QFtBqgKR76o4nU6MGjUKw4cPR1paGoqKirBs2TJ89tlnft4q8pW39jBhwgT861//QklJCQBgwYIFuPHGG/XrUyZNmoTZs2e7lVlYWIitW7ciIyPjgm0H+c5bG3jxxRdx4MABTJo0CUVFRdi7d6/b/ClGjglU8/gz/02bNsWwYcMwf/58AEBJSQmWLFmiXwhNVC3BHOtUm6xfv1569uwpACQ1NVXWrl0rIiJr166V1NRUASA9e/aU9evXy/PPPy89evSQ9PR0SU1NlTFjxsjRo0f1sp544glp37699O3bV9LT02XdunVu6+ratavMnj3bbVlWVpbMmzcv8BtKIhLcfH/wwQeSnp4uNptN2rZtK4MGDdJfmzt3rgCo9OA45cDyZ3twuVzyyCOPSIcOHSQtLU0yMzPd5rkYMWKEPPDAA27rX7BggTzxxBMXZmPJI3+1gV27dommaZX24bFjx+rrMnJMoAsjmPk/fvy4XHvttdKlSxfp1auXPPvss+J0Oi/o9lPtpIko3FeTiIiIiIhMg8ONiIiIiIjIDedJICIiIiIKoGnTpuGjjz6CpmkYMGAAZs6c6fFulFdccQXOnDnjtmzp0qWIj48HcPYatPHjx+O3335DWVkZHnroIYwePTogdWYngYiIiIgoQBYuXIilS5di/fr1sFqt+szYnia/bdKkCRYuXFhlWffccw9iYmLw448/4vDhw+jYsSPatWuH1NRUv9ebw42IiIiIiALklVdewa233gqbzYawsDDcfvvteOWVVwyXc/r0abz77ruYMGECgLN3txo6dCjeeOMNf1cZADsJREREREQBUVZWhq1bt6Jjx476sk6dOmHPnj04efJkpfji4mKMGTMG/fr1w5VXXok1a9bor23evBlOpxMXX3yxW1nr168PSN053IiIiIiITOnMmTMoKysz/H8iUumaApvNBpvN5rbs+PHjcDqdqF+/vr6s4u/c3Fz9WoMKrVq1wtixY3HxxRdjw4YNuPTSS/H111+jZ8+eyM3NRb169RAeHu5WVm5u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j23AvwKdfwDYsWMHcnJy0KVLl/OW98knn8BiseCqq64CAHTr1g2XXHIJ5s+fDwAICwtDVlYWbr/9dsN1DbSDBw9i1apV+Otf/woAiIuLw4033ojXX389yDXzn7y8PGRlZSErK8ttebNmzZCZmYlx48bh+PHjQaqdb6KiohARERHw9dx6661Yt24dfvjhh4Cvi2cSPGMnIcASEhJw6623ui0rLS1F48aN9efFxcUYM2YM+vXrhyuvvBJr1qw5b5lJSUlVvhYREYFOnTrpz+fNm4ekpCQMHDjQxy2gc/3rX//CpZde6vP/p6amQtM0AEB2dja++uorjBs3DoBaezmX0+nEU089haeeesrj60lJSWjYsCE++eQTn+tM7qrTBlRyPGzYMHz88cdwOp04deoUvv76a/Tq1ctjeVu3bkVhYSE2b96MSy+9FP369cOcOXPcYtgG/CvQ+QfO/hg0Y8YMr+UdOnQICQkJbsuaNGmCLVu26M979eqFgwcPYuPGjT7VOVAOHToEAGjQoIG+rEmTJti6dSvED5NVbdu2DZdddhnS09PRt29frFq1Sn/t008/xYABAzBw4ED07du30pCv//znP+jUqRPS09Px8MMPu9XH5XLh/vvvR48ePTBw4EAMHz4cO3fu9FiHpUuXon379qhfv36l115++WVER0eftwNXWlqKe+65B2lpaUhLS8O9996rDz2sGAY1depUXHfddWjbti2GDx+uL58yZQpuuOEGtGnTBlOnTsWWLVtw7bXX4qKLLsJbb72lr2PXrl246qqrMGjQIKSnp+Nvf/sbXFVcxDt//ny34UcLFy5ESkqKPnzuL3/5Cy6++GI9/tVXX0WvXr2QkZGB6667zq1D9M0336Br167o27cv7rjjDtjtdrd1VQwfe/fdd6t8fyiweOGyH9x2222IiorSnxcVFVUZ++uvvyIvLw833XSTvqxVq1YYO3YsLr74YmzYsAGXXnopvv76a/Ts2dPnOn399dcYP348NE3D0qVLa/W04Rfaxo0bMWDAAI+vGWkL/fr1w9atWzFt2jQMHz7cY4yn9nKuefPmYejQoR7PIlRo06YNNm7ciOuvv77KGFLnrzYAeM7xggULcP3116Nly5YoKipCZmZmlWcPs7Oz4XQ6sXTpUqxatQrHjx9Hr169EBkZiTvuuEOPYxvwn0Dn/8svv0RiYiI6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TZqEoqIi7N27V78XdElJCWbNmqUfkPbv349ly5bpFwU5nU4MGjQI3377rdK6du3ahX/84x/6rxq//fYbVq9ejSuuuML/G2ZSKSkp1TrT88wzz+hfCBwOBxYuXIgBAwbov5ydr70AwOjRo/H+++8DAL799lusW7dOPwg3adIEjzzyCNauXev2IZKdne31Limkrrpt4Hw5bteuHZo3b45//vOfAM7+Erl48WJkZGToHYc/t4GmTZti2LBh+t1sSkpKsGTJEv1i+ApsA/4TyPz/61//wvfff6/v0ykpKcjMzMTatWtxySWXAHDPv9PpxBVXXKEf89euXYtDhw65XePgcrlw4MCBGpn/MWPG4ODBgwDO3u1o0aJFePjhh6td7tChQ1FWVobVq1cDOPsejB49Gt9//z0SEhKQkJCgf64ePHgQP//8s/6/N954I3755Rf89NNPAM5+Cd6xY4f++rJly/R5Apo2bYp27dpV+Wu3altJTEzEvHnz8PXXX+vLLBYLxo0bhwULFkBEICJ4++23MW7cOL+dzQaAtm3b4vvvv4eIoKysDF999ZXy/5aUlGD06NGYPn26fg3NnXfeCeDs9Tn/+c9/9E7S/v370b9/f4gIhgwZgvLycnz00UcAgAMHDlT6gRO4cMetisnUjDxMIaiDnULY+vXrpWfPngJAUlNTZe3atSIisnbtWklNTRUA0rNnT1m/fr1omiYA3B4V4/lKS0slKytLunfvLv3795fu3bvLggUL9PWcOXNGmjVrJsuWLdOXvfzyy5Keni4ApHPnzm7jjPfv3y9//etfpUePHtK/f3/p0qWLzJkz54K8J2axZMkS6d+/v/7cSFsQEXn++eelR48ekp6eLqmpqTJmzBg5evSoiIjs2rXrvO1FRKRr164ye/ZstzqtXr1a0tPTxWazSdu2bd3axNGjRyUqKkoKCgoC9ZaYTnXagEqOt27dKgMGDJA+ffpIt27d5IYbbtDHD4tUbgPHjx+Xa6+9Vrp06SK9evWSZ599VpxOp/4624B/BTr/IiLbt2/Xx8onJyfLoEGD9Nf+nH+n0yn/7//9P7nkkkukd+/ecs0118j+/fvdytqwYYM0b95cH8dekzzxxBPSvn176du3r6Snp593Pofly5dL586dBYCkpaXJzp07ReRsPjp06CAAJD09Xd/+X375RQYMGCD9+/eXtLQ0t7H7K1eulDZt2khGRob89a9/lU6dOknbtm31OWw++OAD6dixo/Tr10/uvPNOSUtLk7Zt28qSJUtk586dMmTIELn00kuld+/ect1118np06c91vnQoUMSExOjz1104sQJPa/p6ely7Ngxt/jx48e7jcsvKSmRiRMnSu/evaV3795y9913S0lJiYiITJw4UWJjY6Vt27Zu86j8efnatWslMzNTbDabdO7cWXbu3ClXXHGF3iYPHjwoe/fulbS0NElJSZHrr79eRowYIY0bN5YZM2bI7NmzJTk5WRo3biyPP/64zJs3z+35tGnTJCwsTK655hq59tpr5dprr5Xk5GS9Lq+++qr07NlTMjIyZMCAAW5zNq1bt066dOkiffr0kVGjRsk111wjycnJbse2Dh06yOrVq6tsE9VVcU3CyW3fiWPfVuXHyW3fmeKaBE3ELJdoE/mHy+XC4MGD8dhjj1XrVqgXyj333IP27dvjrrvuCnZVag22AXMLpfyLCIYPH4477rgDQ4YMCXZ1TOnpp5+G0+n0OnM2ufvwww/x/vvv49///nfA1lFQUIDY2Fic/OVbxERHef+Hiv8rLEJ8p37Iz8+v1XeP5HAjIoMsFgvef/99LFmyxOvtDYNt1apVaNWqFb8c+hnbgLmFUv7fffdd3HjjjewgBNHjjz+OsLAw/Pjjj8GuSsg4duwY1q5dqw+jDDhek+ARzyQQERERkelUnEk4tXWN4TMJcSmX1vozCZxMjYiIiIjMy+jZAZOcSWAngYiIiIjMS8RgJ8Ecg3DYSSAiIiIi8xIn4HJ6j/tzvAnwwmUiIiIiInITsmcSXC4XDh8+jOjoaL9OKkL+JyIoLCxE06ZNYbH4p1/K/IeOQOQfYBsIFcw/8TPA3AJ1DPAncbkgVUyIV1W8GQS1k7Bs2TI8++yziIyMhMViwWuvvabP2OfN4cOHkZSUFOAakj/l5OSgWbNmfimL+Q89/sw/wDYQaph/4meAufn7GOBXLoPDjYzEhrCgdRI2bNiAsWPHYvPmzWjTpg0WLVqEwYMHY8eOHYiOjvb6/xUxu3fvVop3Kl5jEm4vVAsEgLBw9VinYoMycuGMpt4j1xylyrHOeg2U4iIO/uw9CEBBUTFaZFyjlCdVRvOvuRxK5YpFfZdwGbhuyar6Q5diPQFAc5SrV8BAuwrLP6QUV97wIqW4wsJCXPQ/bf2af+CPNrDzV7U2sPvkGaVym0ZFKNfBFYCL18oMlFmuemADcMahHnuqVK0ddm8S6TUm0PlXPgY4y5TK1crtynWQcJtyLFSPLQaO68E+XmiKX5QKC4vQqlPXgHwGLPlmK+pGeS/3//LUPtuvaddIuQ6n7epfFMMU03qyRD2nheXq64+LVP9sO3VGrQ5966sdUwsLi9AqpZffjwF+xU6CR0HrJDz33HMYMmQI2rRpAwC4+eabMXnyZCxcuBD33HOP1/+vOL0YHR2tdI9a9U6CWhwAIEz9ywScijt+oDoJ5eqpdkap3fM3IqqecpkA/HpK2Gj+a2cnQe1LDwBjnQSX2r2iyw3eG9rfQwKMtoGocrX9NTo6yJ0EAw2rzEAnIcxAJ6EsTO0LZUxMHeUyg51/9U6C2hcfAJBw750kXdA7Cf4/Xqh2EvT4AHwG1I2KRj2FTkJkiVq50QaOa44z6tsfrphWu1U9p64y9dioOuo/airv/9EGfiiF/48B/iROJ0T1x9zf480gaIPDVq9ejW7duv1REYsFqampWLVqVbCqRERERERm43IZf5hAUM4knDhxAgUFBWjcuLHb8iZNmmDjxo0e/8dut8Nu/+Nn/oKCgoDWkWoW5p/YBsyN+Tc35p8CyuUyONzIHJ2EoJxJKCk5e97PZnMfz2mz2fTXzjVjxgzExsbqD16wZC7MP7ENmBvzb27MPwWSuJyGH2YQlE5C3bp1AcDtV4GK5xWvnevRRx9Ffn6+/sjJyQl4PanmYP6JbcDcmH9zY/4poMTgUCMj14+GsKAMN0pISEBsbCxyc3Pdlh89ehStWrXy+D82m63SmQcyD+af2AbMjfk3N+afAsno2QGeSQiwyy67DJs3b9afiwh++uknDBw4MFhVIiIiIiKzqbgFqpGHCQStk/DII4/g008/xZ49ewAA7777LqxWK8aOHRusKhERERGR2fDuRh4FbZ6EHj16YOHChRg5ciTq1KkDi8WCL774omZPtkFEREREtQrnSfAsaJ0EABgxYgRGjBhRrTK0Hz+EVs/7hD5an5Fq5TkNzEpZrj6LcSAm89ICdOGMtShPKc7ZoKVanM3ALNYGlbvOPrwJV3xfjUyQZoRqsZqRiZQsRk4Eqsc6oxoqxalOOmVkBltfRO7fiEiFif1aNu+pVF65gUZggfrkQBGKM+oZmJ7LUF1jDMz92Kiu2v5y0u59/YUKMdURvm8jwhXyX96ql1J5Fnux+soNTLymBWDiPSOTqYlVfeIr1bqqlmlk3Ua1//TviI70fq1C/hWPKJXnNJAn1X0aAMItarFxddS/A0TZrMqxRsQqzs687pTa0aq4yMD3KqpRgtpJICIiIiIKKs6T4BE7CURERERkXkYvRjbJhcvsJBARERGRaYnLBTFwdsBIbChjJ4GIiIiIzItnEjxiJ4GIiIiIzEsMdhKEnQQiIiIiolqNw408YyeBiIiIiMyLdzfyiJ0EIiIiIjIvXpPgETsJRERERGRanHHZs5DvJEQ0b4uIaO+zbbryflUqz97wf5TXbWCyRVhKTinFuWzet0VnYHZeI7OIuiKj1VbvLFOKk/DAzbYYAQci4H3WUVFs6oqTYgIwNjuzxaE2M6tYDUyLa4SBU6Oaal1V26qRN9UHzqYd4Yzx3mZjT+xSKq+gQVvlddsd6o0gt1htdty4SPVZVMuc6uu3Gpigu1hlGnMAUeFGZv0ODFfjtnAp5F9VeZ045Vgjcyjn29W+VCTYDOwvYmC/NjA7dHG42r4dqfgh6IpQnxnaqPjhYxATHeU1bmh4oVJ5a/PU97+2CXWVY9/ckKMUd2tqonKZZQYaoJHZoVU/LppEeZ/pGgCKxK687qBxuYwNIeJwIyIiIiKiWo7DjTxiJ4GIiIiITEtcToiBL/5GYkMZOwlEREREZFq8BapnwR9QSkRERERENQrPJBARERGRaYlLIE4jZxKM3LYgdLGTQERERESmJU6XsU6CgdhQxk4CEREREZkWr0nwjJ0EIiIiIjItnknwjJ0EIiIiIjItdhI8YyeBiIiIiExLnE64nAbmSTAQG8pCvpMg1jCINdx7XHgdpfIij/6v8rrL/9JROTYQCp3qd7CN0dSnZLcUn1CKc9WJVYoTLXB32hVLGMTivRlbHGfUyrNGKK/bamC7XGGRSnGaBGhaeIuButqi1cutASSiDiSirtc4R2xTpfJijm1XXndpE/VjgFUxBUZumuGCenAY1I8B8ZFWpbgyZw24w4erDHCWeQ1TrWpE6SnlVTvrxinHNpQipTiX1FNfv6b+ER5m4HhV11GsFihq61c9/vpCKy2AZvX+hc2V/5tSeZes+1p53Tuvm6IcO62tWv7PRHn/PlNh4xHFPAHo1Vi93Jbh3vcnACiOiFGKK4D6uoNFxOA1CUY+q0NYyHcSiIiIiIh8xeFGnnEyNSIiIiIyrYpOgpFHIOzcuRP9+/dH//790bt3b2zZsqXK2B9++AHDhg3DwIEDkZqaivHjx6OwsFB/feHChUhJSUFGRob+eO+99wzVh2cSiIiIiMi0xCUGb4Hq/6GW5eXluOqqq/D0009j5MiR+PTTTzF06FDs3r0bdetWHlL72GOP4e6778b111+PsrIyDBo0CA899BDmzp2rx8yePRsZGRk+14lnEoiIiIjItFxOl+GHv33xxRc4deoUbrjhBgDAkCFDEBYWhmXLlnmMHzZsGK699loAQEREBK6//np88cUXfq0TOwlEREREZFo1YbjR+vXr0b59e1j+dKORSy65BOvXr/cY/+CDD7rFlpaWonHjxm4xc+fORf/+/ZGeno7p06ejvLzcUJ38NtxIRKAZuIMOEREREVGoKigocHtus9lgs9l8Kis3Nxf169d3W1a/fn3k5uYq/f/y5ctx77336s+bNGmCfv364Y477kBpaSmGDBmCw4cP49VXX1Wuk09nEh588MFKy4YMGYJJkyb5UhwRERERUVD4eiYhKSkJsbGx+mPGjBkeyx86dCg0TavysW/fvmrV/5///CeaNGmCm2++WV92xRVXYMKECbBarYiKisLjjz+ON998E2fOqN+S2KczCVu3bq207LPPPkPfvn19KY6IiIiIKCh8nSchJycHMTF/zBdR1VmEZcuWwXmeCdhsNhsaN26MHTt2uC0/ffo0WrVqdd66fPfdd3jnnXewfPny88YlJyfD6XQiJycHbdq0OW9sBUOdhHHjxgE4e4umir8rFBcXu916iYiIiIiopvN1noSYmBi3TkJVwsPDER5+/knlevbsiddff91t+P62bdswcuTIKv9ny5YteOyxx7BixQrUrVsX27ZtwyWXXAIAeOKJJ/DEE08gMvLsZK4Vw5aaNlWbWBQwONwoOTkZycnJsNls+t8Vj169euGjjz4yUhwRERERUVDVhAuXBw8ejLi4OHzwwQcAgM8//xwOhwPXXHMNAODXX39FWloaTp06Oyv8rl27cNttt2HBggUICwtDUVER7rrrLr287777Du+//z4AwOl0Ys6cObj++utRr576rO6GziRMmXJ2CvLWrVu7jXsKJledGLjqRHuPs3mPAQCJVJtmHADCc3cqx5Y3bqcW6HIolxltNdDr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",
      "text/plain": [
       "<Figure size 1000x400 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 1\n",
    "\n",
    "heads_display_order = [(39,7), (39,12), (36,7), (32,1), (32,6), (25,13)] + [(32,4), (28,6), (24,9)]\n",
    "matrices = [head_diffs_standard[(layer, idx)].cpu().numpy() for layer, idx in heads_display_order] + [normalized_diff_standard.cpu().numpy() * 0.6]\n",
    "titles = [f\"H{l}.{h}\" for l, h in heads_display_order[:6]] + [f\"(H{l}.{h})\" for l, h in heads_display_order[6:]] + [\"9 Heads (Normalized)\"]\n",
    "\n",
    "# Create figure with 2 rows and 5 columns of subplots\n",
    "fig, axes = plt.subplots(2, 5, figsize=(10, 4), sharex=True, sharey=True)\n",
    "\n",
    "# Flatten axes array for easier iteration\n",
    "axes = axes.flatten()\n",
    "\n",
    "# Plot each matrix\n",
    "for i, (ax, matrix, title) in enumerate(zip(axes, matrices, titles)):\n",
    "    im = ax.imshow(matrix, cmap=\"RdBu\", vmin=-0.5, vmax=0.5)\n",
    "    ax.set_title(title, fontsize=9)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i % 5 == 0:\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "\n",
    "# Add colorbar\n",
    "cbar = fig.colorbar(im, ax=axes.ravel().tolist(), shrink=0.9, ticks=[-0.5, -0.25, 0, 0.25, 0.5])\n",
    "cbar.ax.tick_params(labelsize=9)  # set tick label font size to 12\n",
    "\n",
    "plt.savefig(\"figures/fv_normal.pdf\", dpi=300, bbox_inches='tight', pad_inches=0.0)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fi4",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
