{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 237,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "noise_index = 0\n",
    "with open(f'/home//StepByStep/InformationFlow/result/{noise_index}/data_input_id.pickle', 'rb') as f:\n",
    "    data_input_id = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 238,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import LlamaForCausalLM, LlamaTokenizer\n",
    "MODEL_PATH = '/home/models//Llama-2-7b-hf'\n",
    "\n",
    "tokenizer = LlamaTokenizer.from_pretrained(MODEL_PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def nested_data(data, entry):\n",
    "    nested_dict = {}\n",
    "    if(entry not in data):\n",
    "        print(\"Not present\")\n",
    "        return None\n",
    "    for d in data[entry]:\n",
    "        nested_dict[d] = nested_data(data, d)\n",
    "    return nested_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 240,
   "metadata": {},
   "outputs": [],
   "source": [
    "# nested = {}\n",
    "\n",
    "# def nested_data(data, entry):\n",
    "#     nested_dict = {}\n",
    "#     new_entry = entry.split('_tokenPassed')[0]\n",
    "#     # print(new_entry)\n",
    "#     if(new_entry not in data):\n",
    "#         # print(\"Not present\")\n",
    "#         return None\n",
    "#     for d in data[new_entry]:\n",
    "#         nested_dict[d] = nested_data(data, d)\n",
    "#     return nested_dict\n",
    "\n",
    "# for entry in depth_0_entry:\n",
    "#     nested[entry] = nested_data(clean_data, entry)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 241,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def getNestedData(data):\n",
    "#     clean_data = {}\n",
    "#     for d in data:\n",
    "#         attend = []\n",
    "#         for d1 in d['attending_layer_head']:\n",
    "#             attend.append(f'layer_{d1[\"layer\"]}_head_{d1[\"head\"]}_pos_{d1[\"pos\"]}')\n",
    "#         clean_data[f'layer_{d[\"layer\"]}_head_{d[\"head\"]}_pos_{d[\"pos\"]}'] = attend\n",
    "\n",
    "\n",
    "# depth_0_entry = []\n",
    "# for d in data:\n",
    "#     if d['depth'] == 0:\n",
    "#         depth_0_entry.append(f'layer_{d[\"layer\"]}_head_{d[\"head\"]}_pos_{d[\"pos\"]}')\n",
    "# nested = {}\n",
    "\n",
    "# for entry in depth_0_entry:\n",
    "#     print(entry)\n",
    "#     nested[entry] = nested_data(clean_data, entry)\n",
    "# return nested"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 242,
   "metadata": {},
   "outputs": [],
   "source": [
    "def getNestedData(data, input_id):\n",
    "    clean_data = {}\n",
    "    for d in data:\n",
    "        attend = []\n",
    "        for d1 in d['attending_layer_head']:\n",
    "            token = tokenizer.decode(input_id[d1['pos']])\n",
    "            token_passed = tokenizer.decode(d1['input_id'])\n",
    "            attend.append(f'layer_{d1[\"layer\"]}_head_{d1[\"head\"]}_token_{token}_pos_{d1[\"pos\"]}_tokenPassed_{token_passed}')\n",
    "        token = tokenizer.decode(input_id[d['pos']])\n",
    "        clean_data[f'layer_{d[\"layer\"]}_head_{d[\"head\"]}_token_{token}_pos_{d[\"pos\"]}'] = attend\n",
    "    \n",
    "    depth_0_entry = []\n",
    "    for d in data:\n",
    "        if d['depth'] == 0:\n",
    "            depth_0_entry.append(f'layer_{d[\"layer\"]}_head_{d[\"head\"]}_token_{tokenizer.decode(input_id[d[\"pos\"]])}_pos_{d[\"pos\"]}')\n",
    "    \n",
    "\n",
    "    \n",
    "    nested = {}\n",
    "\n",
    "    def nested_data(data, entry):\n",
    "        nested_dict = {}\n",
    "        new_entry = entry.split('_tokenPassed')[0]\n",
    "        # print(new_entry)\n",
    "        if(new_entry not in data):\n",
    "            # print(\"Not present\")\n",
    "            return None\n",
    "        for d in data[new_entry]:\n",
    "            nested_dict[d] = nested_data(data, d)\n",
    "        return nested_dict\n",
    "\n",
    "    for entry in depth_0_entry:\n",
    "        nested[entry] = nested_data(clean_data, entry)\n",
    "    \n",
    "    return nested\n",
    "\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 243,
   "metadata": {},
   "outputs": [],
   "source": [
    "# depth_0_entry = []\n",
    "# for d in data:\n",
    "#     if d['depth'] == 0:\n",
    "#         depth_0_entry.append(f'layer_{d[\"layer\"]}_head_{d[\"head\"]}_token_{tokenizer.decode(input_id[d[\"pos\"]])}_pos_{d[\"pos\"]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 244,
   "metadata": {},
   "outputs": [],
   "source": [
    "# nested = {}\n",
    "\n",
    "# def nested_data(data, entry):\n",
    "#     nested_dict = {}\n",
    "#     new_entry = entry.split('_tokenPassed')[0]\n",
    "#     # print(new_entry)\n",
    "#     if(new_entry not in data):\n",
    "#         # print(\"Not present\")\n",
    "#         return None\n",
    "#     for d in data[new_entry]:\n",
    "#         nested_dict[d] = nested_data(data, d)\n",
    "#     return nested_dict\n",
    "\n",
    "# for entry in depth_0_entry:\n",
    "#     nested[entry] = nested_data(clean_data, entry)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 245,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['', '13_head_22_token_<s>_pos_0_tokenPassed_sierp']"
      ]
     },
     "execution_count": 245,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'layer_13_head_22_token_<s>_pos_0_tokenPassed_sierp'.split('layer_')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 246,
   "metadata": {},
   "outputs": [],
   "source": [
    "complete_data = []\n",
    "for example in data_input_id:\n",
    "    layer_head_context_data = []\n",
    "    data = example['data']\n",
    "    input_id = example['input_id']\n",
    "    answer = example['answer']\n",
    "    \n",
    "    # nested_data = getNestedData(data, input_id)\n",
    "    # # iterate over the dictionary\n",
    "    # for key, value in nested_data.items():\n",
    "    #     if('pos_-1' in key):\n",
    "    #         depth_keys = list(nested_data[key].keys())\n",
    "    #         for k in depth_keys:\n",
    "    #             pos = int(k.split('pos_')[1].split('_')[0])\n",
    "    #             layer = int(k.split('layer_')[1].split('_')[0])\n",
    "    #             head = int(k.split('head_')[1].split('_')[0])\n",
    "    #             if((layer, head, pos) not in layer_head_context_data):\n",
    "    #                 layer_head_context_data.append((layer, head, pos))\n",
    "    # complete_data.append(layer_head_context_data)\n",
    "                \n",
    "                # layer_head_context_data.append\n",
    "    # for key in nested_data:\n",
    "        # print(key)\n",
    "    # break\n",
    "    # count = 0\n",
    "    for d in data:\n",
    "        if(tokenizer.decode(input_id[d['pos']]) == answer):\n",
    "        # count += 1\n",
    "        # if(f'token_{answer[count]}_' in )\n",
    "            if((d['layer'], d['head'], d['pos']) not in layer_head_context_data):\n",
    "                layer_head_context_data.append((d['layer'], d['head'], d['pos']))\n",
    "            for attending in d['attending_layer_head']:\n",
    "                # print(attending)\n",
    "                if((attending['layer'], attending['head'], attending['pos']) not in layer_head_context_data):\n",
    "                    layer_head_context_data.append((attending['layer'], attending['head'], attending['pos']))\n",
    "                # max_depth = max(max_depth, d['depth'] + 1)\n",
    "    complete_data.append(layer_head_context_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 247,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "29"
      ]
     },
     "execution_count": 247,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(complete_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 248,
   "metadata": {},
   "outputs": [],
   "source": [
    "def FindPartOfSentence(input_id, pos):\n",
    "    input_id_number = []\n",
    "    input_token_pos = 0\n",
    "    dot_number = 0\n",
    "    dot_1 = 0\n",
    "    dot_2 = 0\n",
    "    dot_3 = 0\n",
    "    dot_4 = 0\n",
    "    dot_5 = 0\n",
    "\n",
    "    for i in range(len(input_id)):\n",
    "        if(tokenizer.decode(input_id[i]) == 'Input'):\n",
    "            input_token_pos = i\n",
    "    # for i in range(input_token_pos, len(input_id)):\n",
    "    #     # print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_number += 1\n",
    "    #         dot_1 = i\n",
    "    #         break\n",
    "    # # print(dot_1)\n",
    "    # for i in range(dot_1 + 1, len(input_id)):\n",
    "    #     # print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_number += 1\n",
    "    #         dot_2 = i\n",
    "    #         break\n",
    "    # # print(dot_2)\n",
    "\n",
    "    # for i in range(dot_2 + 1, len(input_id)):\n",
    "    #     # print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_number += 1\n",
    "    #         dot_3 = i\n",
    "    #         break\n",
    "    # # print(dot_3)\n",
    "\n",
    "    # for i in range(dot_3 + 1, len(input_id)):\n",
    "    #     # print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_number += 1\n",
    "    #         dot_4 = i\n",
    "    #         break\n",
    "    # for i in range(dot_4 + 1, len(input_id)):\n",
    "    #     # print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_number += 1\n",
    "    #         dot_5 = i\n",
    "    #         break\n",
    "    # print(input_token_pos, dot_1, dot_2, dot_3, dot_4, dot_5)\n",
    "    response_token_position = 0\n",
    "    for i in range(len(input_id)):\n",
    "        if(tokenizer.decode(input_id[i]) == 'Response'):\n",
    "            response_token_position = i\n",
    "    # dot_6 = 0\n",
    "    # for i in range(response_position + 1, len(input_id)):\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_6 = i\n",
    "    #         break\n",
    "    # dot_7 = 0\n",
    "    # for i in range(dot_6 + 1, len(input_id)):\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_7 = i\n",
    "    #         break\n",
    "    # dot_8 = 0\n",
    "    # for i in range(dot_7 + 1, len(input_id)):\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_8 = i\n",
    "    #         break\n",
    "    # dot_9 = 0\n",
    "    # for i in range(dot_8 + 1, len(input_id)):\n",
    "    #     if(tokenizer.decode(input_id[i]) == '.'):\n",
    "    #         dot_9 = i\n",
    "    #         break\n",
    "        \n",
    "    if(pos <= input_token_pos - 5):\n",
    "        return 'fewShot'\n",
    "    elif(pos <= response_token_position - 4):\n",
    "        return 'context'\n",
    "    \n",
    "    # if(pos <= dot_1):\n",
    "    #     return 'statement_1'\n",
    "    # if(pos <= dot_2):\n",
    "    #     return 'statement_2'\n",
    "    # if(pos <= dot_3):\n",
    "    #     return 'statement_3'\n",
    "    # if(pos <= dot_4):\n",
    "    #     return 'statement_4'\n",
    "    # if(pos <= dot_5):\n",
    "    #     return 'statement_5'\n",
    "    # if(pos <= dot_6):\n",
    "    #     return 'generated_1'\n",
    "    # if(pos <= dot_7):\n",
    "    #     return 'generated_2'\n",
    "    # if(pos <= dot_8):\n",
    "    #     return 'generated_3'\n",
    "    # if(pos <= dot_9):\n",
    "    #     return 'generated_4'\n",
    "    return 'generated'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 249,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'fewShot'"
      ]
     },
     "execution_count": 249,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "FindPartOfSentence(input_id, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 250,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Input : <0x0A> Gr imp uses are liquid . "
     ]
    }
   ],
   "source": [
    "for i in range(579, len(input_id)):\n",
    "    print(tokenizer.decode(input_id[i]), end=' ')\n",
    "    if(tokenizer.decode(input_id[i]) == '.'):\n",
    "        dot_5 = i\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 251,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<s> <s> <s> <s> <s> <s> <s> ### Input : <0x0A> G or pus is tw imp us . Alex is rom pus . Rom pus is g or pus . Gor pus is small . Rom pus is mean . True or false : Alex is small . Let us think step by step . <0x0A> ## # Response : <0x0A> Alex is rom pus . Rom pus is g or pus . Alex is g or pus . Gor pus is small . Alex is small . True <0x0A> <0x0A> ## # Input : <0x0A> G orp uses are disc ord ant . Max is zum pus . Z ump us is sh amp or . Z ump us is g or pus . Gor pus is earth y . True or false : Max is small . Let us think step by step .  <0x0A> ## # Response : <0x0A> Max is zum pus . Z ump us is g or pus . Max is g or pus . Gor p uses are disc ord ant . Max is disc ord ant . False <0x0A> <0x0A> ## # Input : <0x0A> B or pin are w ump us . W ump uses are angry . W ump us is j empor . S ally is le mp us . L emp us is w ump us . True or false : S ally is fl oral . Let us think step by step .  <0x0A> ## # Response : <0x0A> S ally is le mp us . L emp us is w ump us . S ally is w ump us . W ump uses are angry . S ally is angry . False <0x0A> <0x0A> ## # Input : <0x0A> G or pus is jel git . Y ump uses are loud . Gor pus is y ump us . Y ump us is orange . R ex is g or pus . True or false : R ex is loud . Let us think step by step . <0x0A> ## # Response : <0x0A> R ex is g or pus . Gor pus is y ump us . R ex is y ump us . Y ump uses are loud . R ex is loud . True <0x0A> <0x0A> ## # Input : <0x0A> L emp us is t ump us . Max is le mp us . T ump us is f ru ity . T ump us is bright . L emp us is drop ant . True or false : Max is bright . Let us think step by step . <0x0A> ## # Response : <0x0A> Max is le mp us . L emp us is t ump us . Max is t ump us . T ump us is bright . Max is bright . True <0x0A> <0x0A> ## # Input : <0x0A> S ter p uses are d ull . Imp us is medium . Imp uses are ster p uses . W ren is imp us . Ster pus is da ump in . True or false : W ren is mel od ic . Let us think step by step . <0x0A> ## # Response : <0x0A> W ren is imp us . Imp uses are ster p uses . W ren is ster pus . Ster p uses are d ull . W ren is d ull . False <0x0A> <0x0A> ## # Input : <0x0A> Gr imp uses are liquid . Gor pus is gr imp us . Sam is g or pus . True or false : Sam is liquid . Let us think step by step . <0x0A> ## # Response : <0x0A> "
     ]
    }
   ],
   "source": [
    "for i in range(len(input_id)):\n",
    "    print(tokenizer.decode(input_id[i]), end=' ')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 252,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<s><s><s><s><s><s><s> ### Input:\n",
      "Gorpus is twimpus. Alex is rompus. Rompus is gorpus. Gorpus is small. Rompus is mean. True or false: Alex is small. Let us think step by step.\n",
      "### Response:\n",
      "Alex is rompus. Rompus is gorpus. Alex is gorpus. Gorpus is small. Alex is small. True\n",
      "\n",
      "### Input:\n",
      "Gorpuses are discordant. Max is zumpus. Zumpus is shampor. Zumpus is gorpus. Gorpus is earthy. True or false: Max is small. Let us think step by step. \n",
      "### Response:\n",
      "Max is zumpus. Zumpus is gorpus. Max is gorpus. Gorpuses are discordant. Max is discordant. False\n",
      "\n",
      "### Input:\n",
      "Borpin are wumpus. Wumpuses are angry. Wumpus is jempor. Sally is lempus. Lempus is wumpus. True or false: Sally is floral. Let us think step by step. \n",
      "### Response:\n",
      "Sally is lempus. Lempus is wumpus. Sally is wumpus. Wumpuses are angry. Sally is angry. False\n",
      "\n",
      "### Input:\n",
      "Gorpus is jelgit. Yumpuses are loud. Gorpus is yumpus. Yumpus is orange. Rex is gorpus. True or false: Rex is loud. Let us think step by step.\n",
      "### Response:\n",
      "Rex is gorpus. Gorpus is yumpus. Rex is yumpus. Yumpuses are loud. Rex is loud. True\n",
      "\n",
      "### Input:\n",
      "Lempus is tumpus. Max is lempus. Tumpus is fruity. Tumpus is bright. Lempus is dropant. True or false: Max is bright. Let us think step by step.\n",
      "### Response:\n",
      "Max is lempus. Lempus is tumpus. Max is tumpus. Tumpus is bright. Max is bright. True\n",
      "\n",
      "### Input:\n",
      "Sterpuses are dull. Impus is medium. Impuses are sterpuses. Wren is impus. Sterpus is daumpin. True or false: Wren is melodic. Let us think step by step.\n",
      "### Response:\n",
      "Wren is impus. Impuses are sterpuses. Wren is sterpus. Sterpuses are dull. Wren is dull. False\n",
      "\n",
      "### Input:\n",
      "Grimpuses are liquid. Gorpus is grimpus. Sam is gorpus. True or false: Sam is liquid. Let us think step by step.\n",
      "### Response:\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(tokenizer.decode(input_id))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 253,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 29/29 [00:52<00:00,  1.82s/it]\n"
     ]
    }
   ],
   "source": [
    "layer_head = {}\n",
    "from tqdm import tqdm\n",
    "for i in tqdm(range(len(complete_data))):\n",
    "    input_id = data_input_id[i]['input_id']\n",
    "    # print(tokenizer.decode(input_id))\n",
    "    # print(input_id)\n",
    "    \n",
    "    data = complete_data[i]\n",
    "    for d in data:\n",
    "        if((d[0], d[1]) not in layer_head):\n",
    "            layer_head[(d[0], d[1])] = []\n",
    "        if(d[2] == -1):\n",
    "            print(\"dfdf\")\n",
    "            layer_head[(d[0], d[1])].append(FindPartOfSentence(input_id, len(input_id)-1))\n",
    "        else:\n",
    "            layer_head[(d[0], d[1])].append(FindPartOfSentence(input_id, d[2]))\n",
    "        # if(d[2] == 0):\n",
    "        #     if((d[0], d[1]) not in layer_head):\n",
    "        #         layer_head[(d[0], d[1])] = [FindPartOfSentence(input_id, d[2])]\n",
    "        #     else:\n",
    "        #         layer_head[(d[0], d[1])].append(FindPartOfSentence(input_id, d[2]))\n",
    "        #     # print('context')\n",
    "        # else:\n",
    "        #     if(d[2] in input_id):\n",
    "        #         if((d[0], d[1]) not in layer_head):\n",
    "        #             layer_head[(d[0], d[1])] = [FindPartOfSentence(input_id, d[2])]\n",
    "        #         else:\n",
    "        #             layer_head[(d[0], d[1])].append(FindPartOfSentence(input_id, d[2]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "metadata": {},
   "outputs": [],
   "source": [
    "distribution = []\n",
    "for layer in range(32):\n",
    "    temp = []\n",
    "    for head in range(32):\n",
    "        temp.append(0)\n",
    "    distribution.append(temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 255,
   "metadata": {},
   "outputs": [],
   "source": [
    "values = []\n",
    "for key in layer_head:\n",
    "    # get major entites in array\n",
    "    # print(key, layer_head[key])\n",
    "    context_count = 0\n",
    "    generated_count = 0\n",
    "    fewShot_count = 0\n",
    "    for part in layer_head[key]:\n",
    "        if(part == 'context'):\n",
    "            context_count += 1\n",
    "        elif(part == 'generated'):\n",
    "            generated_count += 1\n",
    "        else:\n",
    "            fewShot_count += 1\n",
    "    if(generated_count > context_count and generated_count > fewShot_count):\n",
    "        distribution[key[0]][key[1]] = 3\n",
    "        values.append(3)\n",
    "    elif(context_count > generated_count and context_count > fewShot_count):\n",
    "        distribution[key[0]][key[1]] = 2\n",
    "        values.append(2)\n",
    "    elif(fewShot_count > generated_count and fewShot_count > context_count):\n",
    "        distribution[key[0]][key[1]] = 1\n",
    "        values.append(1)\n",
    "    else:\n",
    "        distribution[key[0]][key[1]] = 0\n",
    "        values.append(0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 256,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 1, 2]"
      ]
     },
     "execution_count": 256,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "values = list(set(values))\n",
    "values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 263,
   "metadata": {},
   "outputs": [],
   "source": [
    "import transformer_lens.utils as utils\n",
    "import plotly.express as px\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "def imshow(tensor, renderer=None, save='head.svg', title=\"Your Plot Title\", **kwargs):\n",
    "    tensor_array = utils.to_numpy(tensor)\n",
    "\n",
    "    if(len(values) == 3):\n",
    "        cmap = plt.cm.colors.ListedColormap(['white', 'red', 'blue'])\n",
    "\n",
    "        plt.imshow(tensor_array, cmap=cmap, interpolation='nearest')\n",
    "\n",
    "        cbar = plt.colorbar(ticks=[0, 1, 2], label='Color')\n",
    "        cbar.set_ticklabels(['None', 'Few Shot', 'Context'])\n",
    "        plt.title(f'Sub Task {noise_index}')\n",
    "        plt.xlabel(f'Heads')\n",
    "        plt.ylabel('Layers')\n",
    "        plt.savefig(save + '.svg', format='svg', bbox_inches='tight')\n",
    "        plt.show()\n",
    "    \n",
    "    else:\n",
    "        cmap = plt.cm.colors.ListedColormap(['white', 'red', 'blue', 'green'])\n",
    "\n",
    "        plt.imshow(tensor_array, cmap=cmap, interpolation='nearest')\n",
    "\n",
    "        cbar = plt.colorbar(ticks=[0, 1, 2, 3], label='Color')\n",
    "        cbar.set_ticklabels(['None', 'Few Shot', 'Context', 'Generated'])\n",
    "        plt.title(f'Sub Task {noise_index}')\n",
    "        plt.xlabel(f'Heads')\n",
    "        plt.ylabel('Layers')\n",
    "        plt.savefig(save + '.svg', format='svg', bbox_inches='tight')\n",
    "        plt.show()\n",
    "\n",
    "#     colors = [\"white\", \"red\", \"blue\", \"green\"]\n",
    "#     # colors = [\"red\", \"blue\", \"green\", \"white\"]\n",
    "#     label = [\"None\", \"Few Shot\", \"Context\", \"Generated\"]\n",
    "#     # color_discrete_map = {str(i): color for i, color in zip(range(len(colors)), colors)}\n",
    "\n",
    "#     # fig = px.imshow(tensor_array, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "#     fig = px.imshow(tensor_array, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "\n",
    "# # Customize the color axis with labels\n",
    "#     fig.update_coloraxes(colorbar_title_text='', colorbar_tickvals=list(range(len(colors))), colorbar_ticktext=label)\n",
    "\n",
    "#     fig.update_layout(title_text=title)\n",
    "#     fig.update_xaxes(title_text=\"Head\")\n",
    "#     fig.update_yaxes(title_text=\"Layer\")\n",
    "\n",
    "    # Customize the color axis with labels\n",
    "    # fig.update_coloraxes(colorbar_title_text='', colorbar_tickvals=list(range(len(colors))), colorbar_ticktext=labels)\n",
    "\n",
    "    # fig = px.imshow(tensor_array, color_continuous_midpoint=0, color_continuous_scale=\"RdBu\", range_color=[0, 3], **kwargs)\n",
    "    # fig = px.imshow(utils.to_numpy(tensor), color_continuous_midpoint=0.0, color_continuous_scale=\"RdBu\", **kwargs)\n",
    "    # fig.show(renderer)\n",
    "    # fig.write_html(save + '.html')\n",
    "    # import json\n",
    "    # import re\n",
    "    # import plotly.io\n",
    "\n",
    "    # # Assuming html_file_path is the path to your HTML file\n",
    "    # with open(save + '.html') as f:\n",
    "    #     html = f.read()\n",
    "\n",
    "    # # Extracting the Plotly JSON from the HTML\n",
    "    # call_arg_str = re.findall(r'Plotly\\.newPlot\\((.*)\\)', html[-2**16:])[0]\n",
    "    # call_args = json.loads(f'[{call_arg_str}]')\n",
    "    # plotly_json = {'data': call_args[1], 'layout': call_args[2]}    \n",
    "\n",
    "    # # Creating a Plotly figure from the JSON\n",
    "    # fig = plotly.io.from_json(json.dumps(plotly_json))\n",
    "\n",
    "    # # Specify the output file path with the desired format (e.g., 'figure.pdf' or 'figure.svg')\n",
    "    # output_file_path = save + '.svg'\n",
    "\n",
    "    # # Save the figure as PDF or SVG\n",
    "    # plotly.io.write_image(fig, output_file_path)\n",
    "\n",
    "    # save svg\n",
    "    # fig.savefig(save)\n",
    "    # fig.write_html(save)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 264,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import transformer_lens.utils as utils\n",
    "# import plotly.express as px\n",
    "# def imshow(tensor, renderer=None, save='head.svg', title=\"Your Plot Title\", **kwargs):\n",
    "#     tensor_array = utils.to_numpy(tensor)\n",
    "#     colors = [\"white\", \"red\", \"blue\", \"green\"]\n",
    "#     # colors = [\"red\", \"blue\", \"green\", \"white\"]\n",
    "#     label = [\"None\", \"Few Shot\", \"Context\", \"Generated\"]\n",
    "#     # color_discrete_map = {str(i): color for i, color in zip(range(len(colors)), colors)}\n",
    "\n",
    "#     # fig = px.imshow(tensor_array, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "#     fig = px.imshow(tensor_array, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "\n",
    "# # Customize the color axis with labels\n",
    "#     fig.update_coloraxes(colorbar_title_text='', colorbar_tickvals=list(range(len(colors))), colorbar_ticktext=label)\n",
    "\n",
    "#     fig.update_layout(title_text=title)\n",
    "#     fig.update_xaxes(title_text=\"Head\")\n",
    "#     fig.update_yaxes(title_text=\"Layer\")\n",
    "\n",
    "#     # Customize the color axis with labels\n",
    "#     # fig.update_coloraxes(colorbar_title_text='', colorbar_tickvals=list(range(len(colors))), colorbar_ticktext=labels)\n",
    "\n",
    "#     # fig = px.imshow(tensor_array, color_continuous_midpoint=0, color_continuous_scale=\"RdBu\", range_color=[0, 3], **kwargs)\n",
    "#     # fig = px.imshow(utils.to_numpy(tensor), color_continuous_midpoint=0.0, color_continuous_scale=\"RdBu\", **kwargs)\n",
    "#     fig.show(renderer)\n",
    "#     fig.write_html(save + '.html')\n",
    "#     import json\n",
    "#     import re\n",
    "#     import plotly.io\n",
    "\n",
    "#     # Assuming html_file_path is the path to your HTML file\n",
    "#     with open(save + '.html') as f:\n",
    "#         html = f.read()\n",
    "\n",
    "#     # Extracting the Plotly JSON from the HTML\n",
    "#     call_arg_str = re.findall(r'Plotly\\.newPlot\\((.*)\\)', html[-2**16:])[0]\n",
    "#     call_args = json.loads(f'[{call_arg_str}]')\n",
    "#     plotly_json = {'data': call_args[1], 'layout': call_args[2]}    \n",
    "\n",
    "#     # Creating a Plotly figure from the JSON\n",
    "#     fig = plotly.io.from_json(json.dumps(plotly_json))\n",
    "\n",
    "#     # Specify the output file path with the desired format (e.g., 'figure.pdf' or 'figure.svg')\n",
    "#     output_file_path = save + '.svg'\n",
    "\n",
    "#     # Save the figure as PDF or SVG\n",
    "#     plotly.io.write_image(fig, output_file_path)\n",
    "\n",
    "#     # save svg\n",
    "#     # fig.savefig(save)\n",
    "#     # fig.write_html(save)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 266,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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qtjnP/TQQxo+fLhLhRRmwIAB9p+bN2+uiIgI1atXTwkJCerevXuh74mLi9OECRPsrzMyMgg9AAC4YOrUqVqzZk2xP/X49wwfPlwjRozQDz/8oHvuuUfStWt4Zs6c6fAd7wyXeni2bNmiF198UT4+Pg7za9eurR9//NGlQoqibt26CgoK0rFjx264jtVqVUBAgMMEAIA3KuxuZIvFctPvueK0evVq3X333bLZbPL391fTpk01bty4Yv2MhIQEWSwWXbx4scjvmTJlil566SXNnTtXnTt3VufOnfXOO+9o6tSpevHFF12qw6Uenvz8/EJPK506dUr+/v4uFVIUp06d0rlz5xQSEuK2zwAA4Hb67d3I0rVTOu62ceNGPfLII3r11VfVu3dvWSwWHTp0SJ999pnbP/v3WCwWjR8/XuPHj7dfJ3yr+cKlHp4ePXpo9uzZDoVlZmYqPj5e999/f5HbyczM1N69e+1dZcnJydq7d69OnjypzMxMTZo0Sdu3b9fx48e1ceNG9enTR/Xr11d0dLQrZQMA4HWu343866ls2bKSpLVr16pVq1YqX7686tatq2nTpumXX36RJE2cOFEPPPCAvZ3Zs2fLYrFo/fr19nn169fXggULCv3cTz75RB06dNCkSZPUsGFDNWjQQA8++KDmzZtXYN1//etfql27tmw2mwYMGGAPIdK1m4WefvppVatWTeXLl9e9996rnTt3SpKOHz+url27SpIqVaoki8WiwYMHO7V//P39i6UzxaUenjfeeEPR0dFq0qSJsrOz9dhjj+no0aMKCgrSBx98UOR2du3aZd8Rkuzn5QYNGqT58+dr//79ev/993Xx4kWFhoaqR48eeuWVV3gWDwDAq/32DmGr1er0d9eWLVv0xBNPaM6cOerYsaOSkpI0YsQISVJ8fLw6d+6sBQsWKC8vT2XLllViYqKCgoKUkJCgnj176scff1RSUpK6dOlSaPvBwcFatmyZDh48qGbNmt2wjqSkJK1Zs0br1q3ThQsX1L9/f82YMUOvvvqqJGny5Mn66KOP9P777ys8PFyvv/66oqOjdezYMYWFhemjjz5Sv379dOTIEQUEBKhChQqFfs5dd90lSxHHPtmzZ0+R1vs1pwcPve6XX37R8uXLtX//fmVmZqpVq1YaOHDgDTfEU64PCqdiGRauIMaaARwxVhOKW0kcPPS3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OFBBQUHq06ePtmzZouTkZCUkJOjpp58u9EJpMyLwAADgRV5++WX7qSjpWu/Mhx9+qOXLl6tZs2Z66aWX9PLLLzt12qtixYravHmzatWqpb59+6px48YaNmyYsrOzS02Pj+lPad2I1WpVfHx8kc6rllSlYRslttNsSsN2loZtlErPdt6K395aLl17pk5OTo7DvH79+qlfv343bKew5+ns3bvX4XVwcLDef/99V8o0BYvh7vv8AAAAPIxTWgAAwPQIPAAAwPQIPAAAwPQIPAAAwPRKZeCZN2+eateurfLly6t9+/b6+uuvPV1SsZo6daosFovD1KhRI0+Xdcs2b96sXr16KTQ0VBaLRWvWrHFYbhiGXnrpJYWEhKhChQqKiorS0aNHPVPsLfi97Rw8eHCB49uzZ0/PFOui6dOnq23btvL391e1atX04IMP2gc5vC47O1uxsbGqUqWK/Pz81K9fP6WlpXmoYtcUZTu7dOlS4HiOHDnSQxU7b/78+YqIiLA/XDAyMlL//e9/7cvNcBxhDqUu8KxYsUITJkxQfHy89uzZoxYtWig6Oto+3ohZNG3aVGfOnLFPX375padLumVZWVlq0aKF5s2bV+jy119/XXPmzNF7772nHTt2yNfXV9HR0crOzr7Nld6a39tOSerZs6fD8f3ggw9uY4W3LjExUbGxsdq+fbs+++wz5ebmqkePHsrKyrKvM378eH3yySdauXKlEhMTdfr0afXt29eDVTuvKNspScOHD3c4nq+//rqHKnZezZo1NWPGDO3evVu7du1St27d1KdPH3377beSzHEcYRJGKdOuXTsjNjbW/jovL88IDQ01pk+f7sGqild8fLzRokULT5fhVpKM1atX21/n5+cbwcHBxqxZs+zzLl68aFitVuODDz7wQIXF47fbaRiGMWjQIKNPnz4eqcddzp49a0gyEhMTDcO4duzKlStnrFy50r7O4cOHDUnGtm3bPFXmLfvtdhqGYXTu3Nl45plnPFeUG1SqVMlYsGCBaY8jSqZS1cNz9epV7d69W1FRUfZ5ZcqUUVRUlLZt2+bByorf0aNHFRoaqrp162rgwIE6efKkp0tyq+TkZKWmpjocW5vNpvbt25vu2EpSQkKCqlWrpoYNG2rUqFE6d+6cp0u6Jenp6ZKkypUrS5J2796t3Nxch+PZqFEj1apVq0Qfz99u53VL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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(distribution, save=f'PartOfInput_index_{noise_index}_new', title=f\"index {noise_index}\", labels={\"x\":\"Head\", \"y\":\"Layer\"})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import plotly.express as px\n",
    "\n",
    "# Example data: a 32x32 grid with values in the range [0, 3)\n",
    "data = np.random.randint(0, 4, size=(32, 32))\n",
    "\n",
    "# Create a custom color scale with distinct colors and corresponding labels\n",
    "colors = [\"red\", \"blue\", \"green\", \"white\"]\n",
    "labels = [\"Label A\", \"Label B\", \"Label C\", \"Label D\"]\n",
    "\n",
    "# Create a figure with specified color labels\n",
    "fig = px.imshow(data, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "\n",
    "# Remove the gradient color scale\n",
    "fig.update_coloraxes(colorbar_title_text='', showscale=False)\n",
    "\n",
    "# Manually add text labels on the right side\n",
    "fig.update_layout(annotations=[\n",
    "    dict(\n",
    "        text=label,\n",
    "        x=1.1,\n",
    "        y=(i + 0.5) / len(colors),\n",
    "        xref='paper',\n",
    "        yref='paper',\n",
    "        showarrow=False,\n",
    "        font=dict(size=12),\n",
    "        bgcolor=colors[i],\n",
    "        opacity=0.7,\n",
    "        borderpad=4,\n",
    "        bordercolor='black',\n",
    "        borderwidth=1\n",
    "    ) for i, label in enumerate(labels)\n",
    "])\n",
    "\n",
    "# Set the title\n",
    "fig.update_layout(title_text=\"Your Plot Title\")\n",
    "\n",
    "# Add colored rectangles to indicate the colors corresponding to labels\n",
    "for i, color in enumerate(colors):\n",
    "    fig.add_shape(\n",
    "        dict(\n",
    "            type='rect',\n",
    "            x0=1.15,\n",
    "            x1=1.25,\n",
    "            y0=(i + 0.3) / len(colors),\n",
    "            y1=(i + 0.7) / len(colors),\n",
    "            fillcolor=color,\n",
    "            opacity=0.7,\n",
    "            layer=\"below\",\n",
    "            line=dict(width=1, color='black')\n",
    "        )\n",
    "    )\n",
    "\n",
    "# Show the plot\n",
    "fig.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "x: %{x}<br>y: %{y}<br>Label: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": [
          [
           1,
           3,
           2,
           2,
           3,
           3,
           1,
           2,
           3,
           0,
           3,
           3,
           0,
           3,
           2,
           3,
           3,
           3,
           0,
           1,
           1,
           3,
           0,
           0,
           1,
           2,
           2,
           3,
           2,
           3,
           2,
           1
          ],
          [
           1,
           0,
           3,
           2,
           2,
           0,
           3,
           1,
           1,
           2,
           0,
           1,
           1,
           3,
           1,
           1,
           2,
           0,
           0,
           0,
           0,
           2,
           0,
           1,
           1,
           0,
           2,
           1,
           0,
           1,
           3,
           1
          ],
          [
           2,
           2,
           1,
           1,
           3,
           0,
           2,
           1,
           3,
           3,
           2,
           1,
           2,
           3,
           0,
           3,
           0,
           2,
           3,
           0,
           2,
           1,
           2,
           0,
           2,
           2,
           3,
           2,
           0,
           1,
           0,
           2
          ],
          [
           3,
           1,
           0,
           3,
           2,
           0,
           0,
           3,
           2,
           0,
           3,
           2,
           2,
           3,
           1,
           1,
           3,
           0,
           1,
           3,
           1,
           1,
           3,
           3,
           3,
           2,
           3,
           3,
           2,
           1,
           0,
           1
          ],
          [
           1,
           1,
           1,
           0,
           2,
           1,
           3,
           3,
           1,
           3,
           2,
           2,
           1,
           2,
           2,
           2,
           0,
           1,
           2,
           3,
           1,
           0,
           2,
           0,
           2,
           3,
           1,
           2,
           1,
           1,
           3,
           0
          ],
          [
           0,
           0,
           3,
           1,
           2,
           1,
           2,
           0,
           1,
           3,
           1,
           2,
           2,
           2,
           2,
           0,
           1,
           0,
           1,
           3,
           0,
           2,
           2,
           1,
           0,
           3,
           0,
           0,
           2,
           2,
           2,
           3
          ],
          [
           2,
           1,
           3,
           1,
           2,
           0,
           0,
           2,
           0,
           1,
           3,
           0,
           2,
           3,
           1,
           1,
           0,
           3,
           3,
           0,
           3,
           1,
           2,
           3,
           3,
           0,
           2,
           2,
           3,
           0,
           1,
           2
          ],
          [
           2,
           0,
           1,
           1,
           1,
           1,
           2,
           3,
           2,
           2,
           2,
           2,
           1,
           3,
           1,
           2,
           0,
           3,
           2,
           2,
           3,
           0,
           0,
           1,
           3,
           1,
           1,
           3,
           0,
           1,
           1,
           0
          ],
          [
           2,
           3,
           2,
           1,
           2,
           3,
           1,
           2,
           0,
           2,
           0,
           1,
           0,
           1,
           0,
           0,
           3,
           0,
           3,
           3,
           0,
           2,
           2,
           2,
           1,
           0,
           3,
           0,
           0,
           3,
           3,
           0
          ],
          [
           3,
           2,
           0,
           0,
           2,
           3,
           2,
           3,
           2,
           0,
           3,
           3,
           0,
           1,
           0,
           2,
           1,
           1,
           2,
           0,
           1,
           1,
           2,
           3,
           2,
           2,
           0,
           0,
           1,
           2,
           3,
           2
          ],
          [
           3,
           0,
           1,
           1,
           2,
           1,
           2,
           3,
           1,
           1,
           2,
           3,
           2,
           2,
           0,
           0,
           1,
           0,
           3,
           3,
           1,
           0,
           1,
           0,
           1,
           3,
           0,
           0,
           1,
           0,
           1,
           1
          ],
          [
           2,
           1,
           2,
           2,
           2,
           0,
           2,
           3,
           0,
           1,
           1,
           2,
           1,
           3,
           2,
           2,
           1,
           3,
           1,
           2,
           0,
           1,
           3,
           3,
           1,
           2,
           1,
           3,
           0,
           1,
           2,
           1
          ],
          [
           3,
           0,
           3,
           1,
           0,
           2,
           2,
           3,
           0,
           2,
           0,
           0,
           0,
           2,
           1,
           1,
           3,
           1,
           0,
           3,
           2,
           0,
           1,
           2,
           1,
           0,
           1,
           2,
           3,
           3,
           3,
           1
          ],
          [
           1,
           1,
           3,
           3,
           1,
           3,
           1,
           3,
           1,
           1,
           1,
           2,
           2,
           3,
           1,
           2,
           0,
           0,
           3,
           2,
           3,
           2,
           0,
           1,
           3,
           0,
           0,
           3,
           0,
           2,
           0,
           0
          ],
          [
           2,
           1,
           2,
           3,
           2,
           0,
           1,
           2,
           3,
           2,
           1,
           1,
           0,
           2,
           1,
           0,
           3,
           2,
           3,
           2,
           0,
           0,
           2,
           0,
           0,
           0,
           1,
           0,
           1,
           3,
           1,
           2
          ],
          [
           2,
           1,
           3,
           3,
           2,
           0,
           3,
           3,
           0,
           1,
           2,
           1,
           3,
           3,
           2,
           2,
           1,
           3,
           0,
           2,
           0,
           0,
           2,
           0,
           3,
           1,
           1,
           2,
           1,
           1,
           0,
           1
          ],
          [
           2,
           2,
           0,
           3,
           2,
           2,
           0,
           1,
           2,
           1,
           1,
           1,
           1,
           3,
           1,
           0,
           2,
           1,
           0,
           1,
           2,
           3,
           3,
           1,
           3,
           0,
           2,
           1,
           0,
           1,
           0,
           0
          ],
          [
           3,
           1,
           3,
           2,
           0,
           0,
           1,
           1,
           3,
           1,
           2,
           3,
           2,
           0,
           3,
           2,
           3,
           1,
           2,
           1,
           0,
           3,
           2,
           0,
           3,
           0,
           1,
           1,
           1,
           1,
           1,
           1
          ],
          [
           0,
           2,
           3,
           3,
           3,
           0,
           3,
           0,
           0,
           2,
           3,
           0,
           1,
           3,
           2,
           1,
           3,
           0,
           3,
           2,
           0,
           0,
           1,
           2,
           0,
           0,
           1,
           0,
           1,
           3,
           0,
           2
          ],
          [
           2,
           0,
           2,
           2,
           1,
           0,
           1,
           1,
           0,
           1,
           1,
           0,
           1,
           3,
           1,
           1,
           3,
           1,
           3,
           2,
           3,
           2,
           2,
           3,
           2,
           0,
           1,
           2,
           2,
           3,
           2,
           0
          ],
          [
           3,
           1,
           2,
           2,
           3,
           3,
           1,
           1,
           2,
           1,
           1,
           1,
           3,
           3,
           3,
           2,
           2,
           3,
           1,
           1,
           1,
           2,
           1,
           1,
           3,
           2,
           2,
           3,
           3,
           0,
           3,
           3
          ],
          [
           3,
           3,
           0,
           0,
           1,
           0,
           2,
           3,
           1,
           3,
           3,
           0,
           3,
           1,
           2,
           3,
           0,
           0,
           1,
           2,
           1,
           3,
           1,
           3,
           2,
           3,
           3,
           2,
           1,
           0,
           2,
           0
          ],
          [
           3,
           3,
           0,
           3,
           1,
           2,
           2,
           2,
           1,
           0,
           3,
           2,
           1,
           2,
           2,
           1,
           3,
           3,
           1,
           0,
           3,
           2,
           1,
           1,
           3,
           1,
           3,
           2,
           3,
           3,
           1,
           1
          ],
          [
           2,
           0,
           1,
           1,
           3,
           3,
           2,
           2,
           0,
           0,
           3,
           0,
           1,
           2,
           1,
           0,
           2,
           2,
           0,
           2,
           0,
           1,
           0,
           1,
           0,
           3,
           2,
           3,
           0,
           0,
           0,
           2
          ],
          [
           0,
           0,
           0,
           3,
           2,
           1,
           3,
           3,
           1,
           0,
           3,
           2,
           3,
           0,
           1,
           3,
           2,
           1,
           1,
           1,
           2,
           2,
           2,
           1,
           0,
           1,
           3,
           0,
           2,
           0,
           1,
           3
          ],
          [
           3,
           2,
           2,
           2,
           0,
           1,
           0,
           1,
           0,
           3,
           1,
           1,
           0,
           0,
           1,
           3,
           3,
           2,
           0,
           2,
           1,
           2,
           3,
           0,
           0,
           3,
           1,
           2,
           1,
           2,
           1,
           1
          ],
          [
           2,
           0,
           2,
           0,
           0,
           0,
           3,
           0,
           3,
           3,
           2,
           3,
           2,
           1,
           2,
           2,
           3,
           1,
           1,
           2,
           0,
           0,
           1,
           2,
           3,
           2,
           1,
           3,
           2,
           2,
           1,
           0
          ],
          [
           2,
           0,
           1,
           3,
           0,
           1,
           2,
           2,
           3,
           3,
           0,
           1,
           0,
           0,
           0,
           1,
           2,
           2,
           3,
           1,
           3,
           2,
           3,
           0,
           2,
           3,
           0,
           3,
           2,
           1,
           1,
           0
          ],
          [
           2,
           1,
           1,
           0,
           3,
           0,
           2,
           2,
           0,
           1,
           3,
           3,
           2,
           0,
           2,
           0,
           0,
           1,
           2,
           1,
           1,
           3,
           0,
           1,
           1,
           1,
           2,
           1,
           3,
           3,
           3,
           3
          ],
          [
           3,
           2,
           1,
           1,
           1,
           2,
           0,
           3,
           3,
           0,
           3,
           2,
           2,
           3,
           1,
           3,
           3,
           1,
           1,
           1,
           2,
           3,
           1,
           3,
           3,
           3,
           2,
           1,
           0,
           3,
           3,
           0
          ],
          [
           2,
           3,
           1,
           3,
           0,
           1,
           2,
           2,
           0,
           2,
           3,
           0,
           3,
           3,
           0,
           0,
           3,
           3,
           0,
           2,
           1,
           0,
           1,
           0,
           1,
           0,
           2,
           1,
           3,
           1,
           1,
           1
          ],
          [
           3,
           1,
           2,
           2,
           0,
           3,
           1,
           2,
           0,
           1,
           0,
           1,
           2,
           2,
           1,
           2,
           2,
           1,
           3,
           3,
           3,
           1,
           0,
           1,
           2,
           1,
           2,
           0,
           2,
           0,
           3,
           0
          ]
         ]
        }
       ],
       "layout": {
        "annotations": [
         {
          "bgcolor": "red",
          "bordercolor": "black",
          "borderpad": 4,
          "borderwidth": 1,
          "font": {
           "size": 12
          },
          "opacity": 0.7,
          "showarrow": false,
          "text": "Label A",
          "x": 1.1,
          "xref": "paper",
          "y": 0.125,
          "yref": "paper"
         },
         {
          "bgcolor": "blue",
          "bordercolor": "black",
          "borderpad": 4,
          "borderwidth": 1,
          "font": {
           "size": 12
          },
          "opacity": 0.7,
          "showarrow": false,
          "text": "Label B",
          "x": 1.1,
          "xref": "paper",
          "y": 0.375,
          "yref": "paper"
         },
         {
          "bgcolor": "green",
          "bordercolor": "black",
          "borderpad": 4,
          "borderwidth": 1,
          "font": {
           "size": 12
          },
          "opacity": 0.7,
          "showarrow": false,
          "text": "Label C",
          "x": 1.1,
          "xref": "paper",
          "y": 0.625,
          "yref": "paper"
         },
         {
          "bgcolor": "white",
          "bordercolor": "black",
          "borderpad": 4,
          "borderwidth": 1,
          "font": {
           "size": 12
          },
          "opacity": 0.7,
          "showarrow": false,
          "text": "Label D",
          "x": 1.1,
          "xref": "paper",
          "y": 0.875,
          "yref": "paper"
         }
        ],
        "coloraxis": {
         "colorbar": {
          "title": {
           "text": ""
          }
         },
         "colorscale": [
          [
           0,
           "red"
          ],
          [
           0.3333333333333333,
           "blue"
          ],
          [
           0.6666666666666666,
           "green"
          ],
          [
           1,
           "white"
          ]
         ],
         "showscale": false
        },
        "margin": {
         "t": 60
        },
        "shapes": [
         {
          "fillcolor": "red",
          "layer": "below",
          "line": {
           "color": "black",
           "width": 1
          },
          "opacity": 0.7,
          "type": "rect",
          "x0": 1.15,
          "x1": 1.25,
          "y0": 0.075,
          "y1": 0.175
         },
         {
          "fillcolor": "blue",
          "layer": "below",
          "line": {
           "color": "black",
           "width": 1
          },
          "opacity": 0.7,
          "type": "rect",
          "x0": 1.15,
          "x1": 1.25,
          "y0": 0.325,
          "y1": 0.425
         },
         {
          "fillcolor": "green",
          "layer": "below",
          "line": {
           "color": "black",
           "width": 1
          },
          "opacity": 0.7,
          "type": "rect",
          "x0": 1.15,
          "x1": 1.25,
          "y0": 0.575,
          "y1": 0.675
         },
         {
          "fillcolor": "white",
          "layer": "below",
          "line": {
           "color": "black",
           "width": 1
          },
          "opacity": 0.7,
          "type": "rect",
          "x0": 1.15,
          "x1": 1.25,
          "y0": 0.825,
          "y1": 0.925
         }
        ],
        "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": "Your Plot Title"
        },
        "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=\"9c1f0286-81d2-48d4-a568-8a5ddc711360\" 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(\"9c1f0286-81d2-48d4-a568-8a5ddc711360\")) {                    Plotly.newPlot(                        \"9c1f0286-81d2-48d4-a568-8a5ddc711360\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[1,3,2,2,3,3,1,2,3,0,3,3,0,3,2,3,3,3,0,1,1,3,0,0,1,2,2,3,2,3,2,1],[1,0,3,2,2,0,3,1,1,2,0,1,1,3,1,1,2,0,0,0,0,2,0,1,1,0,2,1,0,1,3,1],[2,2,1,1,3,0,2,1,3,3,2,1,2,3,0,3,0,2,3,0,2,1,2,0,2,2,3,2,0,1,0,2],[3,1,0,3,2,0,0,3,2,0,3,2,2,3,1,1,3,0,1,3,1,1,3,3,3,2,3,3,2,1,0,1],[1,1,1,0,2,1,3,3,1,3,2,2,1,2,2,2,0,1,2,3,1,0,2,0,2,3,1,2,1,1,3,0],[0,0,3,1,2,1,2,0,1,3,1,2,2,2,2,0,1,0,1,3,0,2,2,1,0,3,0,0,2,2,2,3],[2,1,3,1,2,0,0,2,0,1,3,0,2,3,1,1,0,3,3,0,3,1,2,3,3,0,2,2,3,0,1,2],[2,0,1,1,1,1,2,3,2,2,2,2,1,3,1,2,0,3,2,2,3,0,0,1,3,1,1,3,0,1,1,0],[2,3,2,1,2,3,1,2,0,2,0,1,0,1,0,0,3,0,3,3,0,2,2,2,1,0,3,0,0,3,3,0],[3,2,0,0,2,3,2,3,2,0,3,3,0,1,0,2,1,1,2,0,1,1,2,3,2,2,0,0,1,2,3,2],[3,0,1,1,2,1,2,3,1,1,2,3,2,2,0,0,1,0,3,3,1,0,1,0,1,3,0,0,1,0,1,1],[2,1,2,2,2,0,2,3,0,1,1,2,1,3,2,2,1,3,1,2,0,1,3,3,1,2,1,3,0,1,2,1],[3,0,3,1,0,2,2,3,0,2,0,0,0,2,1,1,3,1,0,3,2,0,1,2,1,0,1,2,3,3,3,1],[1,1,3,3,1,3,1,3,1,1,1,2,2,3,1,2,0,0,3,2,3,2,0,1,3,0,0,3,0,2,0,0],[2,1,2,3,2,0,1,2,3,2,1,1,0,2,1,0,3,2,3,2,0,0,2,0,0,0,1,0,1,3,1,2],[2,1,3,3,2,0,3,3,0,1,2,1,3,3,2,2,1,3,0,2,0,0,2,0,3,1,1,2,1,1,0,1],[2,2,0,3,2,2,0,1,2,1,1,1,1,3,1,0,2,1,0,1,2,3,3,1,3,0,2,1,0,1,0,0],[3,1,3,2,0,0,1,1,3,1,2,3,2,0,3,2,3,1,2,1,0,3,2,0,3,0,1,1,1,1,1,1],[0,2,3,3,3,0,3,0,0,2,3,0,1,3,2,1,3,0,3,2,0,0,1,2,0,0,1,0,1,3,0,2],[2,0,2,2,1,0,1,1,0,1,1,0,1,3,1,1,3,1,3,2,3,2,2,3,2,0,1,2,2,3,2,0],[3,1,2,2,3,3,1,1,2,1,1,1,3,3,3,2,2,3,1,1,1,2,1,1,3,2,2,3,3,0,3,3],[3,3,0,0,1,0,2,3,1,3,3,0,3,1,2,3,0,0,1,2,1,3,1,3,2,3,3,2,1,0,2,0],[3,3,0,3,1,2,2,2,1,0,3,2,1,2,2,1,3,3,1,0,3,2,1,1,3,1,3,2,3,3,1,1],[2,0,1,1,3,3,2,2,0,0,3,0,1,2,1,0,2,2,0,2,0,1,0,1,0,3,2,3,0,0,0,2],[0,0,0,3,2,1,3,3,1,0,3,2,3,0,1,3,2,1,1,1,2,2,2,1,0,1,3,0,2,0,1,3],[3,2,2,2,0,1,0,1,0,3,1,1,0,0,1,3,3,2,0,2,1,2,3,0,0,3,1,2,1,2,1,1],[2,0,2,0,0,0,3,0,3,3,2,3,2,1,2,2,3,1,1,2,0,0,1,2,3,2,1,3,2,2,1,0],[2,0,1,3,0,1,2,2,3,3,0,1,0,0,0,1,2,2,3,1,3,2,3,0,2,3,0,3,2,1,1,0],[2,1,1,0,3,0,2,2,0,1,3,3,2,0,2,0,0,1,2,1,1,3,0,1,1,1,2,1,3,3,3,3],[3,2,1,1,1,2,0,3,3,0,3,2,2,3,1,3,3,1,1,1,2,3,1,3,3,3,2,1,0,3,3,0],[2,3,1,3,0,1,2,2,0,2,3,0,3,3,0,0,3,3,0,2,1,0,1,0,1,0,2,1,3,1,1,1],[3,1,2,2,0,3,1,2,0,1,0,1,2,2,1,2,2,1,3,3,3,1,0,1,2,1,2,0,2,0,3,0]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"x: %{x}\\u003cbr\\u003ey: %{y}\\u003cbr\\u003eLabel: %{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\":{\"colorbar\":{\"title\":{\"text\":\"\"}},\"colorscale\":[[0.0,\"red\"],[0.3333333333333333,\"blue\"],[0.6666666666666666,\"green\"],[1.0,\"white\"]],\"showscale\":false},\"margin\":{\"t\":60},\"annotations\":[{\"bgcolor\":\"red\",\"bordercolor\":\"black\",\"borderpad\":4,\"borderwidth\":1,\"font\":{\"size\":12},\"opacity\":0.7,\"showarrow\":false,\"text\":\"Label A\",\"x\":1.1,\"xref\":\"paper\",\"y\":0.125,\"yref\":\"paper\"},{\"bgcolor\":\"blue\",\"bordercolor\":\"black\",\"borderpad\":4,\"borderwidth\":1,\"font\":{\"size\":12},\"opacity\":0.7,\"showarrow\":false,\"text\":\"Label B\",\"x\":1.1,\"xref\":\"paper\",\"y\":0.375,\"yref\":\"paper\"},{\"bgcolor\":\"green\",\"bordercolor\":\"black\",\"borderpad\":4,\"borderwidth\":1,\"font\":{\"size\":12},\"opacity\":0.7,\"showarrow\":false,\"text\":\"Label C\",\"x\":1.1,\"xref\":\"paper\",\"y\":0.625,\"yref\":\"paper\"},{\"bgcolor\":\"white\",\"bordercolor\":\"black\",\"borderpad\":4,\"borderwidth\":1,\"font\":{\"size\":12},\"opacity\":0.7,\"showarrow\":false,\"text\":\"Label D\",\"x\":1.1,\"xref\":\"paper\",\"y\":0.875,\"yref\":\"paper\"}],\"title\":{\"text\":\"Your Plot Title\"},\"shapes\":[{\"fillcolor\":\"red\",\"layer\":\"below\",\"line\":{\"color\":\"black\",\"width\":1},\"opacity\":0.7,\"type\":\"rect\",\"x0\":1.15,\"x1\":1.25,\"y0\":0.075,\"y1\":0.175},{\"fillcolor\":\"blue\",\"layer\":\"below\",\"line\":{\"color\":\"black\",\"width\":1},\"opacity\":0.7,\"type\":\"rect\",\"x0\":1.15,\"x1\":1.25,\"y0\":0.325,\"y1\":0.425},{\"fillcolor\":\"green\",\"layer\":\"below\",\"line\":{\"color\":\"black\",\"width\":1},\"opacity\":0.7,\"type\":\"rect\",\"x0\":1.15,\"x1\":1.25,\"y0\":0.575,\"y1\":0.675},{\"fillcolor\":\"white\",\"layer\":\"below\",\"line\":{\"color\":\"black\",\"width\":1},\"opacity\":0.7,\"type\":\"rect\",\"x0\":1.15,\"x1\":1.25,\"y0\":0.825,\"y1\":0.925}]},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('9c1f0286-81d2-48d4-a568-8a5ddc711360');\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": [
    "import numpy as np\n",
    "import plotly.express as px\n",
    "\n",
    "# Example data: a 32x32 grid with values in the range [0, 3)\n",
    "data = np.random.randint(0, 4, size=(32, 32))\n",
    "\n",
    "# Create a custom color scale with distinct colors and corresponding labels\n",
    "colors = [\"red\", \"blue\", \"green\", \"white\"]\n",
    "labels = [\"Label A\", \"Label B\", \"Label C\", \"Label D\"]\n",
    "\n",
    "# Create a figure with specified color labels\n",
    "fig = px.imshow(data, color_continuous_scale=colors, labels=dict(color=\"Label\"))\n",
    "\n",
    "# Remove the gradient color scale\n",
    "fig.update_coloraxes(colorbar_title_text='', showscale=False)\n",
    "\n",
    "# Manually add text labels on the right side\n",
    "fig.update_layout(annotations=[\n",
    "    dict(\n",
    "        text=label,\n",
    "        x=1.1,\n",
    "        y=(i + 0.5) / len(colors),\n",
    "        xref='paper',\n",
    "        yref='paper',\n",
    "        showarrow=False,\n",
    "        font=dict(size=12),\n",
    "        bgcolor=colors[i],\n",
    "        opacity=0.7,\n",
    "        borderpad=4,\n",
    "        bordercolor='black',\n",
    "        borderwidth=1\n",
    "    ) for i, label in enumerate(labels)\n",
    "])\n",
    "\n",
    "# Set the title\n",
    "fig.update_layout(title_text=\"Your Plot Title\")\n",
    "\n",
    "# Add colored rectangles to indicate the colors corresponding to labels\n",
    "for i, color in enumerate(colors):\n",
    "    fig.add_shape(\n",
    "        dict(\n",
    "            type='rect',\n",
    "            x0=1.15,\n",
    "            x1=1.25,\n",
    "            y0=(i + 0.3) / len(colors),\n",
    "            y1=(i + 0.7) / len(colors),\n",
    "            fillcolor=color,\n",
    "            opacity=0.7,\n",
    "            layer=\"below\",\n",
    "            line=dict(width=1, color='black')\n",
    "        )\n",
    "    )\n",
    "\n",
    "# Show the plot\n",
    "fig.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0, 1, 2, 3]\n",
      "[(0.267004, 0.004874, 0.329415, 1.0), (0.127568, 0.566949, 0.550556, 1.0), (0.993248, 0.906157, 0.143936, 1.0), (0.993248, 0.906157, 0.143936, 1.0)]\n",
      "[<matplotlib.patches.Patch object at 0x7fa845702470>, <matplotlib.patches.Patch object at 0x7fa8454ddd20>, <matplotlib.patches.Patch object at 0x7fa8454ddd80>, <matplotlib.patches.Patch object at 0x7fa8454ddde0>]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAGJCAYAAABFDXDOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA9bElEQVR4nO3de1xUdd4H8M+AMKDAACKXWQHBC3iDwDVi21LxMtLKYmTlLSEvrS5UauWldkXURHKf7GZquUq1kF0U2czQUsDLqk9SYGiiEKXFxUtyD0TmPH/4OOvI7QDDnDPO5/16zesl55z5ne85Z/DDmTPnOwpBEAQQERGRLFlIXQARERG1jkFNREQkYwxqIiIiGWNQExERyRiDmoiISMYY1ERERDLGoCYiIpIxBjUREZGMMaiJiIhkjEFN1AkxMTHo16+f1GXoJCcnQ6FQ4Mcff2x32aysLCgUCmRlZXV7XUTUdQxqMprw8HA4OTmhvLy82bzKykp4eHggJCQEWq1WgupuGj16NBQKhe7h7OyMkSNHYtu2bQara+3atdi9e3eHa2ntsXLlyhaf//bbbyM5OdkgNRORdHpIXQCZj7fffhvDhg3DokWLkJqaqjfvxRdfxJUrV5CRkQELC2n/fuzbty8SExMBAJcvX8b777+POXPm4Ny5c1i3bl2Xx1+7di2mTJmCyZMnt7ncSy+9hLlz5+p+/vrrr/HGG2/gxRdfxODBg3XTAwICMHToUEydOhVKpVI3/e2334aLiwtiYmK6XDMRSYdBTUbj4+OD+Ph4LF26FDExMZgwYQKAmwG0efNmPP/88wgMDOzWGrRaLa5fvw4bG5tWl1GpVJg5c6bu57/85S/w8/PDW2+9hdWrV8PKyqpba7xl/Pjxej/b2NjgjTfewPjx4zF69Ohmy1taWhqlLiIyLr71TUa1ePFiBAQE4K9//Svq6+vR1NSE+fPnw9vbG/Hx8Th48CAeeOAB9OrVC46OjoiMjMT333+vN0Zr14dXrlwJhUKhN02hUCAuLg4pKSkYOnQolEolMjIyOlRzz549cd9996G2thaXL19udbna2lo899xz8PT0hFKphJ+fH/7xj3/g9i+oUygUqK2txXvvvad769oQZ7x3XqPu168fTp8+jezsbN16Wgr32504cQITJ06ESqVCz549MWrUKBw9erTLtRFR1/CMmoyqR48eeOedd/CHP/wBq1evhqurK7755htkZGTgP//5D8LDw+Hr64uVK1fit99+w5tvvon7778f33zzTac/vHXw4EF8/PHHiIuLg4uLS6fG+eGHH2BpaQlHR8cW5wuCgD//+c/IzMzEnDlzcM8992Dfvn144YUX8Msvv2DDhg0AgA8++ABz587Fvffei6eeegoA0L9//05tV1tee+01PP3007Czs8NLL70EAHBzc2t1+YMHDyI8PBwjRoxAfHw8LCwssH37doSFheHw4cO49957DV4jEYkkEEkgLi5OsLKyEuzs7IRp06YJgiAI99xzj+Dq6ipcvXpVt1xeXp5gYWEhzJo1SzctOjpa8Pb2bjZmfHy8cOdLGoBgYWEhnD59WlRdo0aNEvz9/YXLly8Lly9fFr7//nvhmWeeEQAIERERrdawe/duAYCwZs0avfGmTJkiKBQKobCwUDetV69eQnR0tKh6bvfJJ58IAITMzMxm87Zv3y4AEIqLi3XThg4dKowaNarZspmZmXrjaLVaYeDAgYJGoxG0Wq1uubq6OsHHx0cYP358h2slIsPhW98kiZdffhm9e/eGhYUFNmzYgNLSUuTm5iImJgbOzs665QICAjB+/Hjs3bu30+saNWoUhgwZInr5s2fPok+fPujTpw8GDx6MN998E3/605+wbdu2Vp+zd+9eWFpa4plnntGb/txzz0EQBHzxxRedrr+75ebm4vz585g+fTquXr2KK1eu4MqVK6itrcXYsWNx6NAhST+JT2Tu+NY3ScLBwQF+fn64cuUK3NzccPz4cQCAn59fs2UHDx6Mffv2oba2Fr169erwunx8fDq0fL9+/fDuu+9CoVDAxsYGAwcOhKura5vP+emnn6BWq2Fvb9+s9lvz5er8+fMAgOjo6FaXqayshJOTk7FKIqLbMKjJ5Nz5gbFbmpqaWpxua2vbofF79eqFcePGdbguU3XrbHn9+vW45557WlzGzs7OiBUR0e0Y1CQL3t7eAICCgoJm886ePQsXFxfd2bSTkxMqKiqaLSflWau3tze++uorVFdX651Vnz17Vjf/ltb+0DA0seu59WE2BwcHs/oDhchU8Bo1yYKHhwfuuecevPfee3ohnJ+fj/379+Ohhx7STevfvz8qKytx6tQp3bTS0lKkpaUZs2Q9Dz30EJqamvDWW2/pTd+wYQMUCgXCw8N103r1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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as mpatches\n",
    "import numpy as np\n",
    "\n",
    "# create some data\n",
    "data = np.array(distribution)\n",
    "# get the unique values from data\n",
    "# i.e. a sorted list of all values in data\n",
    "values = [0, 1, 2, 3]\n",
    "print(values)\n",
    "plt.figure(figsize=(8,4))\n",
    "im = plt.imshow(data, interpolation='none')\n",
    "\n",
    "# get the colors of the values, according to the \n",
    "# colormap used by imshow\n",
    "colors = [ im.cmap(im.norm(value)) for value in values]\n",
    "print(colors)\n",
    "# create a patch (proxy artist) for every color \n",
    "patches = [ mpatches.Patch(color=colors[i], label=\"Level {l}\".format(l=values[i]) ) for i in range(len(values)) ]\n",
    "print(patches)\n",
    "# put those patched as legend-handles into the legend\n",
    "plt.legend(handles=patches, bbox_to_anchor=(1.05, 1), loc=2, borderaxespad=0. )\n",
    "\n",
    "# plt.grid(True)\n",
    "plt.title('Your Plot Title')\n",
    "plt.xlabel('Head')\n",
    "plt.ylabel('Layer')\n",
    "plt.savefig('legend.svg')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAfkAAAGJCAYAAACJlEolAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA4OUlEQVR4nO3deViVdf7/8ddhR1aVRSk2d1Tcl4wxtDTUcjQ1x0lLzMYmIXNr0vy5lCnaYo5amC1KpWWTpWWlFglumSuYhRtu5G4qCAYq5/z+8OtpGNEUgVtvno/rOtfVuc/n3O/3zTFefO5zLxabzWYTAAAwHQejGwAAAGWDkAcAwKQIeQAATIqQBwDApAh5AABMipAHAMCkCHkAAEyKkAcAwKQIeQAATIqQB4oRGxursLAwo9uwmzdvniwWi/bv3/+nY1NSUmSxWJSSklLmfQG4tRHyKDWdO3dW5cqVdezYsStey87OVvXq1dW6dWtZrVYDurukXbt2slgs9keVKlXUsmVLvffee6XW1+TJk7V48eIb7uVqjwkTJhT7/jfffFPz5s0rlZ4BmJOT0Q3APN588001bNhQw4YN04IFC4q89vzzz+vkyZNatmyZHByM/dvyzjvvVEJCgiTpxIkTev/99zVw4EDt2rVLU6ZMuen1T548Wb169VL37t2vOW7MmDF64okn7M83btyoGTNm6Pnnn1dERIR9eaNGjdSgQQP16dNHrq6u9uVvvvmm/Pz8FBsbe9M9AzAnQh6lJjw8XOPHj9dzzz2n2NhY3X///ZIuhdfs2bM1cuRINW7cuEx7sFqtOn/+vNzc3K46xsfHR/369bM/f/LJJ1W3bl3NmjVLEydOlLOzc5n2eFnHjh2LPHdzc9OMGTPUsWNHtWvX7orxjo6O5dIXAPNgdz1K1fDhw9WoUSMNHjxY+fn5Kiws1D//+U+FhoZq/Pjx+v7779W2bVt5eHjI19dX3bp1U0ZGRpF1XO378AkTJshisRRZZrFYFB8fr/nz56tBgwZydXXVsmXLbqjnSpUq6a677lJeXp5OnDhx1XF5eXkaMWKEgoOD5erqqrp16+rVV1/Vf9/I0WKxKC8vT0lJSfbd7aUx0/7f7+TDwsL0888/KzU11V6nuD8M/tuPP/6oTp06ycfHR5UqVVJ0dLTWrl17070BuHUxk0epcnJy0pw5c3T33Xdr4sSJCggI0JYtW7Rs2TKtW7dOnTt3Vo0aNTRhwgT9/vvvmjlzpqKiorRly5YSH+j2/fff65NPPlF8fLz8/PxKtJ69e/fK0dFRvr6+xb5us9n017/+VStXrtTAgQPVpEkTLV++XM8++6wOHTqk119/XZL0wQcf6IknnlCrVq00aNAgSVLNmjVLtF3XMn36dD399NPy9PTUmDFjJEmBgYFXHf/999+rc+fOat68ucaPHy8HBwfNnTtX9957r1avXq1WrVqVeo8AbgE2oAzEx8fbnJ2dbZ6enra///3vNpvNZmvSpIktICDA9ttvv9nHpaen2xwcHGyPPfaYfVn//v1toaGhV6xz/Pjxtv/9JyvJ5uDgYPv555+vq6/o6GhbvXr1bCdOnLCdOHHClpGRYRsyZIhNkq1r165X7WHx4sU2SbaXXnqpyPp69epls1gstj179tiXeXh42Pr3739d/fy3//znPzZJtpUrV17x2ty5c22SbPv27bMva9CggS06OvqKsStXriyyHqvVaqtdu7YtJibGZrVa7ePOnTtnCw8Pt3Xs2PGGewVwe2B3PcrEpEmTVLVqVTk4OOj111/XkSNHlJaWptjYWFWpUsU+rlGjRurYsaO+/vrrEteKjo5W/fr1r3v8jh075O/vL39/f0VERGjmzJl64IEH9N577131PV9//bUcHR01ZMiQIstHjBghm82mb775psT9l7W0tDTt3r1bjzzyiH777TedPHlSJ0+eVF5enu677z6tWrXK0DMeAJQddtejTHh7e6tu3bo6efKkAgMDtX79eklS3bp1rxgbERGh5cuXKy8vTx4eHjdcKzw8/IbGh4WF6e2335bFYpGbm5tq166tgICAa77nwIEDCgoKkpeX1xW9X379VrV7925JUv/+/a86Jjs7W5UrVy6vlgCUE0Iet5z/PbjussLCwmKXu7u739D6PTw81KFDhxvu63Z1eZb+yiuvqEmTJsWO8fT0LMeOAJQXQh7lIjQ0VJK0c+fOK17bsWOH/Pz87LP4ypUr68yZM1eMM3K2HBoaqu+++05nz54tMpvfsWOH/fXLrvZHSmm73jqXD/zz9vauUH/cAOAUOpST6tWrq0mTJkpKSioS4Nu3b9eKFSvUpUsX+7KaNWsqOztb27Ztsy87cuSIPv/88/JsuYguXbqosLBQs2bNKrL89ddfl8ViUefOne3L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z6jX6mk6b71YbjVdHJz0advhBP0tgt31AGBSZ87nlWvAS9J568US7Tk4evSonn76adWoUUOurq4KDg5W165dlZycXGq9tWvXzn5nuNJUVustDczkAQCG2r9/v6KiouTr66tXXnlFkZGRunDhgpYvX664uDjt2LHD6BZvW8zkAQCGGjx4sCwWizZs2KCePXuqTp06atCggYYPH67169dLkg4ePKhu3brJ09NT3t7e6t27t44dO2Zfx4QJE9SkSRN98MEHCgsLk4+Pj/r06aOzZ89KkmJjY5Wamqp///vfslgsslgs2r9/vyRp+/bt6ty5szw9PRUYGKhHH31UJ0+elCSlpKTIxcVFq1evttd6+eWXFRAQoGPHjl1zvbcCQh4AYJhTp05p2bJliouLk4eHxxWv+/r6ymq1qlu3bjp16pRSU1P17bffau/evfrb3/5WZGxmZqYWL16spUuXaunSpUpNTbXfY/7f//632rRpo3/84x86cuSIjhw5ouDgYJ05c0b33nuvmjZtqk2bNmnZsmU6duyYevfuLemPXfGPPvqosrOztXXrVo0dO1bvvPOOAgMDr7reWwW76wEAhtmzZ49sNpv9XvDFSU5O1k8//aR9+/bZA/T9999XgwYNtHHjRrVs2VKSZLVaNW/ePHl5eUmSHn30USUnJ2vSpEny8fGRi4uLKlWqpGrVqtnXPWvWLDVt2lSTJ0+2L3vvvfcUHBysXbt2qU6dOnrppZf07bffatCgQdq+fbv69++vv/71r5J01fXeKpjJAwAMY7PZ/nRMRkaGgoODi8yQ69evL19fX2VkZNiXhYWF2QNekqpXr67jx49fc93p6elauXKlPD097Y/Lf3BkZmZKklxcXDR//nwtWrRI+fn5ev31129oG43ETB4AYJjatWvLYrGUysF1zs7ORZ5bLBZZrdZrvic3N1ddu3bV1KlTr3itevXq9v9et26dpEtfL5w6darYrxZuRczkAQCGqVKlimJiYvTGG28oL+/KU+/OnDmjiIgIZWVlKSsry778l19+0ZkzZ1S/fv3rruXi4qLCwsIiy5o1a6aff/5ZYWFhqlWrVpHH5SDPzMzUsGHD9Pbbb6t169bq379/kT8eilvvrYKQBwAY6o033lBhYaFatWqlRYsWaffu3crIyNCMGTPUpk0bdejQQZGRkerbt6+2bNmiDRs26LHHHlN0dLRatGhx3XXCwsL0448/av/+/Tp58qSsVqvi4uJ06tQp/f3vf9fGjRuVmZmp5cuXa8CAASosLFRhYaH69eunmJgYDRgwQHPnztW2bdv02muvXXO9twpCHgBMytfFQy4O5futrIuDk3xdbmxXdo0aNbRlyxa1b99eI0aMUMOGDdWxY0clJycrMTFRFotFS5YsUeXKlXXPPfeoQ4cOqlGjhhYuXHhDdUaOHClHR0fVr19f/v7+OnjwoIKCgrR27VoVFhbq/vvvV2RkpIYOHSpfX185ODho0qRJOnDggN566y1Jl3bhz5kzR//v//0/paenX3W9twqL7XqOerhF5eTkyMfHR5EDJsnRxa3c62+ekFjuNS+7K62XIXUvLPY3pK7RnLufMKy2T5c9htXO/rqWIXWN3Oblh9MMqZtz1qrKdfYqOztb3t7eN/z+/Px87du3T+Hh4XJz++P3IdeuN5+rfdbF4cA7ADCxau6+hG4Fxu56AABMipn8TYgJamJc8a+NK20Uvzk/GFd8jnGljWTU1zPLD39qSF1Jaj7hKUPqFp7PlzTGkNowL2byAACYFCEPAIBJEfIAAJgUIQ8AgEkR8gAAmBRH1wOAidkKD0vW0+VX0KGyLI5B5VcP10TIA4BJ2QoPy3bifknny7Gqi+S/gqC/SWFhYRo6dKiGDh16U+thdz0AmJX1tMo34HWpXgn2HBw9elTPPPOMatWqJTc3NwUGBioqKkqJiYk6d+5cGfRZ+sLCwjR9+nSj2yiCmTwAwFB79+5VVFSUfH19NXnyZEVGRsrV1VU//fST5syZozvuuEN//etfDenNZrOpsLBQTk63Z1wykwcAGGrw4MFycnLSpk2b1Lt3b0VERKhGjRrq1q2bvvrqK3Xt2lXSpXvLP/HEE/L395e3t7fuvfde+53gJGnChAlq0qSJPvjgA4WFhcnHx0d9+vTR2bNn7WOsVqsSEhIUHh4ud3d3NW7cWJ9++scVFlNSUmSxWPTNN9+oefPmcnV11Zo1a5SZmalu3bopMDBQnp6eatmypb777jv7+9q1a6cDBw5o2LBhslgsslgs9tfWrFmjtm3byt3dXcHBwRoyZIjy8v64adDx48fVtWtXubu7Kzw8XPPnzy+1n62hIZ+QkKCWLVvKy8tLAQEB6t69u3bu3GlkSwCAcvTbb79pxYoViouLk4dH8beovRyYDz/8sI4fP65vvvlGmzdvVrNmzXTffffp1KlT9rGZmZlavHixli5dqqVLlyo1NVVTpkyxv56QkKD3339fs2fP1s8//6xhw4apX79+Sk1NLVJz1KhRmjJlijIyMtSoUSPl5uaqS5cuSk5O1tatW9WpUyd17drVflvZzz77THfeeadefPFFHTlyREeOHLH306lTJ/Xs2VPbtm3TwoULtWbNGsXHx9trxcbGKisrSytXrtSnn36qN998U8ePHy+Vn6+h+x9SU1MVFxenli1b6uLFi3r++ed1//3365dffrnqhw0AMI89e/bIZrOpbt26RZb7+fkpPz9fkhQXF6euXbtqw4YNOn78uFxdXSVJr776qhYvXqxPP/1UgwYNknRppj5v3jx5eXlJkh599FElJydr0qRJKigo0OTJk/Xdd9+pTZs2ki7dy37NmjV66623FB0dba//4osvqmPHjvbnVapUUePGje3PJ06cqM8//1xffPGF4uPjVaVKFTk6OsrLy0vVqlWzj0tISFDfvn3tB9DVrl1bM2bMUHR0tBITE3Xw4EF988032rBhg1q2bClJevfddxUREVEqP19DQ37ZsmVFns+bN08BAQHavHmz7rnnHoO6AgAYbcOGDbJarerbt68KCgqUnp6u3NxcVa1atci433//XZmZmfbnYWFh9oCXpOrVq9tnxXv27NG5c+eKhLcknT9/Xk2bNi2yrEWLFkWe5+bmasKECfrqq6905MgRXbx4Ub///rt9Jn816enp2rZtW5Fd8DabTVarVfv27dOuXbvk5OSk5s2b21+vV6+efH19r7ne63VLHUmQnZ0t6dJfTMUpKChQQUGB/XlOTk659AUAKBu1atWSxWK54qvaGjVqSJLc3d0lXQrZ6tWrKyUl5Yp1/HcgOjs7F3nNYrHIarXa1yFJX331le64444i4y7vHbjsf/cmjxw5Ut9++61effVV1apVS+7u7urVq5fOn7/22Qu5ubl68sknNWTIkCteCwkJ0a5du675/pt1y4S81WrV0KFDFRUVpYYNGxY7JiEhQS+88EI5dwYAKCtVq1ZVx44dNWvWLD399NNX/aq2WbNmOnr0qJycnBQWFlaiWvXr15erq6sOHjxYZNf89Vi7dq1iY2P10EMPSboU3vv37y8yxsXFRYWFhVf0/csvv6hWrVrFrrdevXq6ePGiNm/e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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Example data\n",
    "data = np.random.randint(0, 4, size=(10, 10))  # Sample distribution data\n",
    "\n",
    "# Values and colors mapping\n",
    "values = [0, 1, 2, 3]\n",
    "colors = ['white', 'red', 'blue', 'green']\n",
    "labels = ['None', 'Few Shot', 'Context', 'Generated']\n",
    "\n",
    "plt.figure(figsize=(8, 4))\n",
    "im = plt.imshow(data, interpolation='none')\n",
    "\n",
    "# Get the colors of the values\n",
    "colors = [im.cmap(im.norm(value)) for value in values]\n",
    "\n",
    "# Create a patch (proxy artist) for every color\n",
    "patches = [plt.Rectangle((0, 0), 1, 1, color=colors[i], label=labels[i]) for i in range(len(values))]\n",
    "\n",
    "# Add legend\n",
    "plt.legend(handles=patches, bbox_to_anchor=(1.05, 1), loc='upper left', borderaxespad=0.)\n",
    "\n",
    "plt.title('Your Plot Title')\n",
    "plt.xlabel('Head')\n",
    "plt.ylabel('Layer')\n",
    "plt.savefig('legend.svg')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAfIAAAGiCAYAAAAcH0QnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAtz0lEQVR4nO3df3DU9Z3H8deCZEFJFiPkVwmUHwoCBnsUaM6W8iMC6RwF5Q9tvTEqAwMNtJD2KrlTE7zehMqc9UdTvJmzcM4UsXRERnvCIZJw9oBKJIf4IyNc7ogHCS09diGSwJHv/cG5beSH+97sN7uf5PmY+Y7s7mc/+/7+2H373d28NuB5nicAAOCkPskuAAAAxI9GDgCAw2jkAAA4jEYOAIDDaOQAADiMRg4AgMNo5AAAOIxGDgCAw2jkAAA4jEYOAIDDaOQAAMRo/fr1KigoUEZGhjIyMlRYWKjXX389qTUFyFoHACA2r776qvr27aubb75Znufpn/7pn7Ru3TodPHhQ48ePT0pNNHIAALogMzNT69at06JFi5Ly+Ncl5VGvoaOjQ8ePH1d6eroCgUCyywEAGHmepzNnzigvL099+vj3CW5bW5vOnz/f5Xk8z7us3wSDQQWDwWve7+LFi9qyZYtaW1tVWFjY5Tri5qWYpqYmTxILCwsLi+NLU1OTb73i3LlzngYmps6BAwdedl1FRcVVH/vQoUPeDTfc4PXt29cLhULer3/9a9/WMxYpd0aenp5+6R+rJF37f4aiwuVh3+oJhWIfG/avDDtD4SHZCg/LsFEkhVabhpuE1/pXh2lun7ehn0y1r7bV7ev+MTzvLc/jeFie+6Eq4zb08fXN9Dph2T/tkn7yJ6/nPjh//rx0VqZecUXt0tmfnFVTU5MyMjKiV1/rbHzMmDGqr69XOBzWr371K5WUlKi2tlbjxo3rQiHx862RV1dXa926dWpubtbEiRP17LPPasqUKZ97v+jbG0FJ/WN7rD/d+MmUImXEwVa4eTVj3I/xMNVirMPPrZJah4qhGj+3oXXuFHrCmUpxdT3jeB53y8ejhl5xLZ9+Cz0WaWlpGj16tCRp0qRJevvtt/X000/rH/7hH7peSBx8+fDipZdeUllZmSoqKvTOO+9o4sSJmjNnjk6ePOnHwwEAkDQdHR1qb29P2uP70siffPJJLV68WA8++KDGjRun5557Ttdff71+/vOfXza2vb1dkUik0wIAQCoqLy/Xnj179J//+Z969913VV5erpqaGt13331Jqynhjfz8+fOqq6tTUVHRHx+kTx8VFRVp7969l42vqqpSKBSKLvn5+YkuCQCAhDh58qTuv/9+jRkzRrNmzdLbb7+tHTt26M4770xaTQn/jPz3v/+9Ll68qOzs7E7XZ2dn68MPP7xsfHl5ucrKyqKXI5EIzRwAkJKef/75ZJdwmaR/az2Wv9UDAABXlvC31gcPHqy+ffuqpaWl0/UtLS3KyclJ9MMBANCrJbyRp6WladKkSdq1a1f0uo6ODu3atSu5yTcAAPRAvry1XlZWppKSEn35y1/WlClT9NRTT6m1tVUPPvigHw8HAECv5Usjv+eee/S73/1Ojz32mJqbm3X77bdr+/btl30B7lrCa2MPkwjIz9ABz7eZA2sMdVfa6vAMv4XjGUMbApWm4fKM4/3iVRj3ZWXqZP1bt7mFVxH72MAa6+SGbW55PkiyHLaer68Rlx4h5pGVxqktx6HxN7ACpte31Hk+oDPfvuy2fPlyLV++3K/pAQCAfAqEAQAA3YNGDgCAw2jkAAA4jEYOAIDDaOQAADiMRg4AgMNo5AAAOIxGDgCAw2jkAAA4LOk/Y3pV4bCUEWNIq38JhpIlvtKYYGiJUbXG0AYClhU1xr8atokkU8SkLTLSxjyz5WCxpldaD0RjfKmFKSrYUdbjyrp7bNvQx2Pc+iJkqcUUEx2RFDLWgnhxRg4AgMNo5AAAOIxGDgCAw2jkAAA4jEYOAIDDaOQAADiMRg4AgMNo5AAAOIxGDgCAw2jkAAA4jEYOAIDDUjZrPZQqMb2G7GJLdrpxanM6syn52ddcaUmVsQ/1DLnsVrb8eSNr3dbVrLSMNa6nj9vcxFq3gWfd4OZN4mPtpqmNmfKGseYYd3QbzsgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh6VsRKtf/IwXtcY6WqIXA2uMc1cY5vYzLlSSV2FYUUPdkmwRusYdFKg0DDbGi1o3uSW6NmCMXLXsH+uxYtmG5hhVC2sOsZUlbtnHUqz7x1SL5bhqk7TWVgvixxk5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADkvZrPWwQsrwYV4f05zjyIqOPejYq7TNbMq4tmY/m7PZLTnh1rljH2rKfJckQy6/dRuaM8sNx4o1C9+Ub2/Mcbew58/7UcUlqfSbDLbMf9vcplqsc6PbcEYOAIDDaOQAADgs4Y28srJSgUCg0zJ27NhEPwwAAJBPn5GPHz9eb7zxxh8f5LqU/SgeAACn+dJhr7vuOuXk5MQ0tr29Xe3t7dHLkUjEj5IAAOiRfPmM/KOPPlJeXp5Gjhyp++67T8eOHbvq2KqqKoVCoeiSn5/vR0kAAPRICW/kU6dO1caNG7V9+3atX79ejY2N+trXvqYzZ85ccXx5ebnC4XB0aWpqSnRJAAD0WAl/a724uDj674KCAk2dOlXDhw/XL3/5Sy1atOiy8cFgUMFgMNFlAADQK/j+52eDBg3SLbfcoiNHjvj9UAAA9Dq+N/KzZ8/q6NGjys3N9fuhAADodRL+1voPfvADzZs3T8OHD9fx48dVUVGhvn376lvf+pZtonBYyogtpNUUp1hpzNK0xItaYjQv3SFm1hRVE2teqDGP1DK952MEqDVe1DOspzXS0zK3dX5zdKmpdFvdlthi6/MnYNif1uePNc7XHOlqYKnFWoc5EhkpKeGN/OOPP9a3vvUtnTp1SkOGDNFXv/pV7du3T0OGDEn0QwEA0OslvJFv3rw50VMCAICrIGsdAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIclPNktUUJVIal/sqvwlyVuO7DGOrsl49rGM2azW1KrzXn1ljqsUfh+ZuH7mPtundu0za1zW37bwLpNjHnofjLl2/v4WwWy1CFb3bbnZkRSyFYM4sYZOQAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOo5EDAOCwlI1o1dqwpIyYhpqiTivjqiYm5gjQNbFnL5oiICV7MRYVtuGW9bQHxhpmDhi3iSUyNIXiQq1Mh4px9/i3N2XM0DXGopqOWckS0ms9Ukyvb9Zj3DLcsk3aJK21lYL4pW4jBwDg8xhO+q7M/Vx43loHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhNHIAABxGIwcAwGE0cgAAHJayEa3hsJTRldS9BPEsGdqW7GdJqrQUYsyK9jPk2pJBbmTa3jLGbRuTv02jrRvc1/1pDf03zGys2xTjbswJDxiOQ8+4f6zrGbBsRB+fm9Yc98AaX8pAN+OMHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIelbNa6RWCNJbzYmkacGnyO8jax5jN7lYa5DWMl2XLfjTnuMhxXAeNxZd09ppx4H3PcfT0OjRn+plx+49y21xRJlbHXYsmIt85t/T0BX5+b6DackQMA4DBzI9+zZ4/mzZunvLw8BQIBvfLKK51u9zxPjz32mHJzczVgwAAVFRXpo48+SlS9AADgT5gbeWtrqyZOnKjq6uor3v7EE0/omWee0XPPPaf9+/frhhtu0Jw5c9TW1tblYgEAQGfmRl5cXKwf/ehHuuuuuy67zfM8PfXUU3rkkUc0f/58FRQU6IUXXtDx48cvO3MHAMA1VVVVmjx5stLT05WVlaUFCxaooaEhqTUl9DPyxsZGNTc3q6ioKHpdKBTS1KlTtXfv3ivep729XZFIpNMCAEAqqq2tVWlpqfbt26edO3fqwoULmj17tlpbW5NWU0K/td7c3CxJys7O7nR9dnZ29LbPqqqq0po1xq9BAwCQBNu3b+90eePGjcrKylJdXZ2mTZuWlJqS/q318vJyhcPh6NLU1JTskgAAvcxn3xlub2+P6X7hcFiSlJmZ6Wd515TQRp6TkyNJamlp6XR9S0tL9LbPCgaDysjI6LQAANCd8vPzFQqFoktVVdXn3qejo0MrV67UHXfcoQkTJnRDlVeW0LfWR4wYoZycHO3atUu33367pEv/l7N//34tW7YskQ8FAEDCNDU1dTqRDAaDn3uf0tJSHT58WG+99ZafpX0ucyM/e/asjhw5Er3c2Nio+vp6ZWZmatiwYVq5cqV+9KMf6eabb9aIESP06KOPKi8vTwsWLEhk3QAAJIz1HeHly5frtdde0549ezR06FAfK/t85kZ+4MABzZgxI3q5rKxMklRSUqKNGzfqhz/8oVpbW7VkyRKdPn1aX/3qV7V9+3b179/f9DihqpAU411MMYOmKmTKpLRGGFoiJq1zWyImLdtPkmQdb5rbv4hJVZimtrHGbpqHG+JIjfGi/oYWG+JFjRG6lrhYzxhba90mAcsONUSuSraY20DAv7k9wwaPSAqZKnGH53lasWKFtm7dqpqaGo0YMSLZJdkb+fTp06/5pAgEAnr88cf1+OOPd6kwAABSTWlpqTZt2qRt27YpPT09+hdZoVBIAwYMSEpNSf/WOgAArli/fr3C4bCmT5+u3Nzc6PLSSy8lraYe8etnAAB0B+vHNN2BM3IAABxGIwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhNHIAABxGIwcAwGEpGwgTXivFGl9vySH3jHnbluxi69yWsGhzBIElx92eQG9iygmvtM7t12DJ3xRyYx66qRRjZnmlYbCPmfKeeQcZjnFj/rw1D93X3x/w8XXCls1uGduT09ZTD2fkAAA4jEYOAIDDaOQAADiMRg4AgMNo5AAAOIxGDgCAw2jkAAA4jEYOAIDDaOQAADiMRg4AgMNSNqLVwquMfaw1jtSzZWPaWOY2xDRKcURSWhjjK/3chMbN4ht7vKiNaX/6uH8Ca0xTm7aLKcrXyvdj1sdI5MrYh/q6DZGyOCMHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYT0ia90WFm2cu8Iw1hr8bajbmqHsGer2sexL8/uYE65KHzPIfcwJ9zOb3Tq3JT/dq7CtZ6DSMLe1bss2txwniiNT3rBdLL8NIdm2ofUFzrQ/DS8UEUkhUyXoCs7IAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQDoBv/7v/+rF154QS0tLQmdl0YOAEA3uO6667R06VK1tbUldF4aOQAA3WTKlCmqr69P6Jw9I9kNAAAHfOc731FZWZmampo0adIk3XDDDZ1uLygoMM8Z8Dxr4Ka/IpGIQqGQtFpS/2RXY4tTtEUp2lijMc25q47ydZsb5rZGtFqZnqU+7ns/o2jNc/uTLhoXUy2WyGK/GWKLLfvy04jWcDisjIwMe12xPManvUJhSV15jEvV+lnrn+rT5/I3wgOBgDzPUyAQ0MWLF81zckYOAEA3aWxsTPicNHIAALrJ8OHDEz6n+ctue/bs0bx585SXl6dAIKBXXnml0+0PPPCAAoFAp2Xu3LmJqhcAAKcdPXpUK1asUFFRkYqKivTd735XR48ejXs+cyNvbW3VxIkTVV1dfdUxc+fO1YkTJ6LLiy++GHeBAAD0FDt27NC4ceP029/+VgUFBSooKND+/fs1fvx47dy5M645zW+tFxcXq7i4+JpjgsGgcnJy4ioIAICeavXq1Vq1apXWrl172fUPP/yw7rzzTvOcvvwdeU1NjbKysjRmzBgtW7ZMp06duurY9vZ2RSKRTgsAAD3RBx98oEWLFl12/UMPPaT3338/rjkT3sjnzp2rF154Qbt27dKPf/xj1dbWqri4+Kpfqa+qqlIoFIou+fn5iS4JAICUMGTIkCsGwtTX1ysrKyuuORP+rfV77703+u/bbrtNBQUFGjVqlGpqajRr1qzLxpeXl6usrCx6ORKJ0MwBAD3S4sWLtWTJEv3Hf/yH/vzP/1yS9Jvf/EY//vGPO/VCC9///GzkyJEaPHiwjhw5csVGHgwGFQwG/S4DAICke/TRR5Wenq6///u/V3l5uSQpLy9PlZWV+u53vxvXnL438o8//linTp1Sbm6u3w8FAEBKCwQCWrVqlVatWqUzZ85IktLT07s0p7mRnz17VkeOHIlebmxsVH19vTIzM5WZmak1a9Zo4cKFysnJ0dGjR/XDH/5Qo0eP1pw5c7pUKAAAPUlXG/inzFnrNTU1mjFjxmXXl5SUaP369VqwYIEOHjyo06dPKy8vT7Nnz9bf/u3fKjs7O6b5P83PtaTnWjKaLXnB1rnNKn3MXPYpQ1mKY5sY1tOSb26txbqeftUh+VxLpfEOhmPFz2PW+nsClsxy89zG1TRlylca57bUbizcUovludmdWeuJSVr3t9YvfelLCsS4b9555x3z/OYz8unTp+tavX/Hjh3mIgAA6KkWLFjg6/xkrQMA4KOKigpf56eRAwDQzerq6vTBBx9IksaPH68vfelLcc9FIwcAoJucPHlS9957r2pqajRo0CBJ0unTpzVjxgxt3rxZQ4YMMc/pS0QrAAC43IoVK3TmzBm99957+sMf/qA//OEPOnz4sCKRSOr+HTkAALhk+/bteuONN3TrrbdGrxs3bpyqq6s1e/bsuObkjBwAgG7S0dGhfv36XXZ9v3791NHREdecNHIAALrJzJkz9b3vfU/Hjx+PXvff//3fWrVq1RVjzGNBIwcAoJv89Kc/VSQS0Re/+EWNGjVKo0aN0ogRIxSJRPTss8/GNSefkQMA0E3y8/P1zjvv6I033tCHH34oSbr11ltVVFQU95yckQMA4LM333xT48aNUyQSUSAQ0J133qkVK1ZoxYoVmjx5ssaPH69//dd/jWtuc9a636L5uYbcW0u8sHVtTXP7mFmeSnWbi7Ewh1zHXouPU5vnNmeWW7LzrceKj5nlftUh2WpJqf1jfZ2ojH2s9bcK/DrIyVq/3De/+U3NmDFDq1atuuLtzzzzjHbv3q2tW7ea5+aMHAAAn/37v/+75s6de9XbZ8+erbq6urjmppEDAOCzlpaWK/7Z2aeuu+46/e53v4trbho5AAA++8IXvqDDhw9f9fZDhw4pNzc3rrlp5AAA+Owb3/iGHn30UbW1tV1227lz51RRUaG/+Iu/iGtu/vwMAACfPfLII3r55Zd1yy23aPny5RozZowk6cMPP1R1dbUuXryov/mbv4lrbho5AAA+y87O1r/9279p2bJlKi8v16d/MBYIBDRnzhxVV1crOzs7rrlp5AAAdIPhw4frn//5n/U///M/OnLkiDzP080336wbb7yxS/PSyAEA6EY33nijJk+enLD5+LIbAAAOo5EDAOCwHvHWuiny0BzVaBhrjK+0jDZHTFoYMz3NUafmje4Pc7KsYUXtScfG8YbI0MAaYykWxp1viyE2HoemSFfr9vZx/9hm9pV/2/DT4FN0B87IAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcFjKZq2HTDG9hjxnY9KxZ8hPt+UW2+a2ssRW+5rjLilQGftYzzBWsm1z89yW8db8eXM0u+EYt+ahVxprMTCvp4UhD91ah/W5bOJnjnulbWr0DJyRAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA4LeJ6vIYpmkUhEoVBIWi2pf4x38jGq0cIadWqNi7UwxaIao2L9XM+AIW7XPHelaWrbdjFvlNQ5EE3b3BAXauZjdKnfx7iftZj4ue9NIpJCCofDysjI8OcR/r9XhCV15REuVSpfa/UbZ+QAADiMRg4AgMNMjbyqqkqTJ09Wenq6srKytGDBAjU0NHQa09bWptLSUt10000aOHCgFi5cqJaWloQWDQAALjE18traWpWWlmrfvn3auXOnLly4oNmzZ6u1tTU6ZtWqVXr11Ve1ZcsW1dbW6vjx47r77rsTXjgAADD+Hvn27ds7Xd64caOysrJUV1enadOmKRwO6/nnn9emTZs0c+ZMSdKGDRt06623at++ffrKV75y2Zzt7e1qb2+PXo5EIvGsBwAAvVKXPiMPh8OSpMzMTElSXV2dLly4oKKiouiYsWPHatiwYdq7d+8V56iqqlIoFIou+fn5XSkJAIBeJe5G3tHRoZUrV+qOO+7QhAkTJEnNzc1KS0vToEGDOo3Nzs5Wc3PzFecpLy9XOByOLk1NTfGWBABAr2N6a/1PlZaW6vDhw3rrrbe6VEAwGFQwGOzSHAAA9FZxnZEvX75cr732mnbv3q2hQ4dGr8/JydH58+d1+vTpTuNbWlqUk5PTpUIBAMDlTI3c8zwtX75cW7du1ZtvvqkRI0Z0un3SpEnq16+fdu3aFb2uoaFBx44dU2FhYWIqBgAAUaa31ktLS7Vp0yZt27ZN6enp0c+9Q6GQBgwYoFAopEWLFqmsrEyZmZnKyMjQihUrVFhYeMVvrAMAgK4xZa0HrpLju2HDBj3wwAOSLgXCfP/739eLL76o9vZ2zZkzRz/72c9ifms9mp9ryL21xAtbI64Da3zMczbMbWWpxe+Y8FTZP35mefvO8nsCxgx/S962r/vHTz7ve9PzzbpNfNz3fumO/PJkZq3v2bNH69atU11dnU6cOKGtW7dqwYIFXaiia0xn5LH0/P79+6u6ulrV1dVxFwUAQKpqbW3VxIkT9dBDD6VE4Fnc31oHAKA3Ki4uVnFxcbLLiKKRAwB6vc+mirr0p9H8+hkAoNfLz8/vlDJaVVWV7JJixhk5AKDXa2pq6vRlN1fOxiUaOQAAysjI8O0b9n7jrXUAABzGGTkAAAZnz57VkSNHopcbGxtVX1+vzMxMDRs2rNvroZEDAGBw4MABzZgxI3q5rKxMklRSUqKNGzd2ez00cgAADKZPnx5TQFp3SdlGHgr5M681jlSVflRxiefj3AHD3L4fj5a4S3NcrCEa0zi5af/4mVt76Q6xDzXW4plqMc7tY1SwiTVytdI4f4VxvIWl9krb1KbXCUsEdSTi34s4LsOX3QAAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHBYymatm5iyiP3LiraGRVtyjq1127Kl/Q1bN21Da2a1jznhAcM2tOWVxyFVfqDBup4+1m2ZOrDGNrfpuSlJawzHinHugOG4tRyz1lpMv1XQZioDXcQZOQAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOo5EDAOCwlI1oDSukjFgHV8Y+rzVIM2CIXrRGgHqWOFJzdKlhaKVxbmMMpCVe1jPvIUsd/tVtjcY0s0xvrsVw3FojQA2Rrp41ztUyt23mOJ4TlkcwbkNTSrR5TWOvwxC1HIlEFFobMtaCeHFGDgBwVzh86f924l3C4WSvQZfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACHpWzWusJhKSPGtHVD5rKZJSfcGhVtynE3qrQMNmY/m+a25ZD7mVjuZ92WHGrJvu8tGfT2pHXDPazracnyNs0sawi5bepKWymWrR6wrqmPv/dg4ufrLLqEM3IAABxGIwcAwGGmRl5VVaXJkycrPT1dWVlZWrBggRoaGjqNmT59ugKBQKdl6dKlCS0aAABcYmrktbW1Ki0t1b59+7Rz505duHBBs2fPVmtra6dxixcv1okTJ6LLE088kdCiAQDAJaYvu23fvr3T5Y0bNyorK0t1dXWaNm1a9Prrr79eOTk5Mc3Z3t6u9vb26OVIJGIpCQCAXq1Ln5GH//8H2TMzMztd/4tf/EKDBw/WhAkTVF5erk8++eSqc1RVVSkUCkWX/Pz8rpQEAECvEvefn3V0dGjlypW64447NGHChOj13/72tzV8+HDl5eXp0KFDevjhh9XQ0KCXX375ivOUl5errKwsejkSidDMAQCIUdyNvLS0VIcPH9Zbb73V6folS5ZE/33bbbcpNzdXs2bN0tGjRzVq1KjL5gkGgwoGg/GWAQBArxbXW+vLly/Xa6+9pt27d2vo0KHXHDt16lRJ0pEjR+J5KAAAcA2mM3LP87RixQpt3bpVNTU1GjFixOfep76+XpKUm5sbV4EAAODqTI28tLRUmzZt0rZt25Senq7m5mZJUigU0oABA3T06FFt2rRJ3/jGN3TTTTfp0KFDWrVqlaZNm6aCggJfVgAAgN4s4HmxBxYHrpK1u2HDBj3wwANqamrSX/7lX+rw4cNqbW1Vfn6+7rrrLj3yyCPKiDE3PRKJKBQKKSwpxqR1BSpjHOg3Qy77pfH+ZXlbcpGt28/XWnzMijZn4Ruipf2cW5Kvx4qfmf+WzHLrvrducxPjDvLzNcj8fDOw7HtLHdHX8XA45td+q0Q9RnfU6jfzW+vXkp+fr9ra2i4VBAAAYkfWOgAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOi/tnTH0XDkuxxuX5FDMoGSMMZYy6NNRij/SMfaglRvPS3Mb4SkP0pnUbWqIxAwH/InQDa2xTG5KR//8BDEMrbVNbavEzztXM/KQwTG2NCq60jDUe4z6+vpme+8a60X04IwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhKZu1HqoKSf1jG2vJFzZnRVca5rbNbEpztmeQ+1i3MYbakoVvqVuSPFP+szUj3sBYtypswy3MMe6GFbXuelPOvrlu/+a2HLOSMePcz8hyH/PQbfnzEUkhv0rBZ3BGDgCAw2jkAAA4jEYOAIDDaOQAADiMRg4AgMNo5AAAOIxGDgCAw2jkAAA4jEYOAIDDaOQAADgs4Hnm8EJfRSIRhUIhSWFJGTHdxxpfamLZPJasS+Pc5ql93CaBSuMdDPGl5phOQ5SmKUZTMm108zYx8gzz+1mLpQ6/+brNrZG7qcIa0erTc/PT1/FwOKyMjNhex60S9RjdUavfOCMHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYTRyAAAcRiMHAMBhNHIAABxGIwcAwGE0cgAAHEYjBwDAYdclu4CrCSsUY9J66rBmP1vSnM2J+JbIZXPAuW24aXpjqLypcmsOtaFw8+4xlmIaXmmb29ffKvCTo3no9ueyJfPfNrll3wfWGCZuM5WBLuKMHAAAh5ka+fr161VQUKCMjAxlZGSosLBQr7/+evT2trY2lZaW6qabbtLAgQO1cOFCtbS0JLxoAABwiamRDx06VGvXrlVdXZ0OHDigmTNnav78+XrvvfckSatWrdKrr76qLVu2qLa2VsePH9fdd9/tS+EAAMD4Gfm8efM6Xf67v/s7rV+/Xvv27dPQoUP1/PPPa9OmTZo5c6YkacOGDbr11lu1b98+feUrX0lc1QAAQFIXPiO/ePGiNm/erNbWVhUWFqqurk4XLlxQUVFRdMzYsWM1bNgw7d2796rztLe3KxKJdFoAAEBszI383Xff1cCBAxUMBrV06VJt3bpV48aNU3Nzs9LS0jRo0KBO47Ozs9Xc3HzV+aqqqhQKhaJLfn6+eSUAAOitzI18zJgxqq+v1/79+7Vs2TKVlJTo/fffj7uA8vJyhcPh6NLU1BT3XAAA9DbmvyNPS0vT6NGjJUmTJk3S22+/raefflr33HOPzp8/r9OnT3c6K29paVFOTs5V5wsGgwoGg/bKAQBA1/+OvKOjQ+3t7Zo0aZL69eunXbt2RW9raGjQsWPHVFhY2NWHAQAAV2A6Iy8vL1dxcbGGDRumM2fOaNOmTaqpqdGOHTsUCoW0aNEilZWVKTMzUxkZGVqxYoUKCwv5xjoAAD4xNfKTJ0/q/vvv14kTJxQKhVRQUKAdO3bozjvvlCT95Cc/UZ8+fbRw4UK1t7drzpw5+tnPfhZXYSGFpVhDWg3Rm16lsRBLlqZ1bh9Z4mI9ayyqOWPSP6ZYXHN8paUQY8xppW24V2GoxliLNVo4VXgVhsHWbWIO3TXMbU7ENUQFm8s23GGNo1G+vYCpkT///PPXvL1///6qrq5WdXV1l4oCAACxIWsdAACH0cgBAHAYjRwAAIfRyAEAcBiNHAAAh9HIAQBwGI0cAACH0cgBADCqrq7WF7/4RfXv319Tp07Vb3/726TVQiMHAMDgpZdeUllZmSoqKvTOO+9o4sSJmjNnjk6ePJmUesy/fua3P8Z/RmK/U1vsQw2z2hnqkKRIxMdq/NwmftZtZdrmtrp9XU1Hj5VU4us28feVwjcpc8y2X/pPd8Q5d/U4+PT+n53nWr/M+eSTT2rx4sV68MEHJUnPPfecfv3rX+vnP/+5Vq9e3aV64uKlmKamJk+XAoBZWFhYWBxempqafOsV586d83JychJS58CBAy+7rqKi4oqP297e7vXt29fbunVrp+vvv/9+75vf/KZv63stKXdGnpeXp6amJqWnpyvwJ78uEIlElJ+fr6amJmVkxPhjKg5iPXuO3rCOEuvZ0yRiPT3P05kzZ5SXl5fg6v6of//+amxs1Pnz57s8l+d5nfqNpKuejf/+97/XxYsXlZ2d3en67Oxsffjhh12uJR4p18j79OmjoUOHXvX2jIyMHv0k+hTr2XP0hnWUWM+epqvrGQqFEljNlfXv31/9+/f3/XFSHV92AwAgRoMHD1bfvn3V0tLS6fqWlhbl5OQkpSYaOQAAMUpLS9OkSZO0a9eu6HUdHR3atWuXCgsLk1JTyr21fjXBYFAVFRVX/dyip2A9e47esI4S69nT9Jb17IqysjKVlJToy1/+sqZMmaKnnnpKra2t0W+xd7eA53XD3wcAANCD/PSnP9W6devU3Nys22+/Xc8884ymTp2alFpo5AAAOIzPyAEAcBiNHAAAh9HIAQBwGI0cAACHOdPIU+kn4/xQWVmpQCDQaRk7dmyyy+qSPXv2aN68ecrLy1MgENArr7zS6XbP8/TYY48pNzdXAwYMUFFRkT766KPkFNsFn7eeDzzwwGX7du7cuckpNk5VVVWaPHmy0tPTlZWVpQULFqihoaHTmLa2NpWWluqmm27SwIEDtXDhwstCM1JdLOs5ffr0y/bn0qVLk1RxfNavX6+CgoJoelthYaFef/316O09YV/2Jk408lT7yTi/jB8/XidOnIgub731VrJL6pLW1lZNnDhR1dXVV7z9iSee0DPPPKPnnntO+/fv1w033KA5c+aorc2tn+P6vPWUpLlz53baty+++GI3Vth1tbW1Ki0t1b59+7Rz505duHBBs2fPVmtra3TMqlWr9Oqrr2rLli2qra3V8ePHdffddyexartY1lOSFi9e3Gl/PvHEE0mqOD5Dhw7V2rVrVVdXpwMHDmjmzJmaP3++3nvvPUk9Y1/2Kkn5qRajKVOmeKWlpdHLFy9e9PLy8ryqqqokVpVYFRUV3sSJE5Ndhm8kdfq1oI6ODi8nJ8dbt25d9LrTp097wWDQe/HFF5NQYWJ8dj09z/NKSkq8+fPnJ6Uev5w8edKT5NXW1nqed2nf9evXz9uyZUt0zAcffOBJ8vbu3ZusMrvss+vpeZ739a9/3fve976XvKJ8cuONN3r/+I//2GP3ZU+W8mfk58+fV11dnYqKiqLX9enTR0VFRdq7d28SK0u8jz76SHl5eRo5cqTuu+8+HTt2LNkl+aaxsVHNzc2d9msoFNLUqVN73H6VpJqaGmVlZWnMmDFatmyZTp06leySuiQcDkuSMjMzJUl1dXW6cOFCp/05duxYDRs2zOn9+dn1/NQvfvELDR48WBMmTFB5ebk++eSTZJSXEBcvXtTmzZvV2tqqwsLCHrsve7KUj2hNxZ+M88PUqVO1ceNGjRkzRidOnNCaNWv0ta99TYcPH1Z6enqyy0u45uZmSbrifv30tp5i7ty5uvvuuzVixAgdPXpUf/3Xf63i4mLt3btXffv2TXZ5Zh0dHVq5cqXuuOMOTZgwQdKl/ZmWlqZBgwZ1Guvy/rzSekrSt7/9bQ0fPlx5eXk6dOiQHn74YTU0NOjll19OYrV27777rgoLC9XW1qaBAwdq69atGjdunOrr63vcvuzpUr6R9xbFxcXRfxcUFGjq1KkaPny4fvnLX2rRokVJrAxdde+990b/fdttt6mgoECjRo1STU2NZs2alcTK4lNaWqrDhw87/x2Oz3O19VyyZEn037fddptyc3M1a9YsHT16VKNGjeruMuM2ZswY1dfXKxwO61e/+pVKSkpUW1ub7LIQh5R/az0VfzKuOwwaNEi33HKLjhw5kuxSfPHpvutt+1WSRo4cqcGDBzu5b5cvX67XXntNu3fv1tChQ6PX5+Tk6Pz58zp9+nSn8a7uz6ut55V8mq/t2v5MS0vT6NGjNWnSJFVVVWnixIl6+umne9y+7A1SvpGn4k/GdYezZ8/q6NGjys3NTXYpvhgxYoRycnI67ddIJKL9+/f36P0qSR9//LFOnTrl1L71PE/Lly/X1q1b9eabb2rEiBGdbp80aZL69evXaX82NDTo2LFjTu3Pz1vPK6mvr5ckp/bnlXR0dKi9vb3H7MteJdnftovF5s2bvWAw6G3cuNF7//33vSVLlniDBg3ympubk11awnz/+9/3ampqvMbGRu83v/mNV1RU5A0ePNg7efJkskuL25kzZ7yDBw96Bw8e9CR5Tz75pHfw4EHvv/7rvzzP87y1a9d6gwYN8rZt2+YdOnTImz9/vjdixAjv3LlzSa7c5lrreebMGe8HP/iBt3fvXq+xsdF74403vD/7sz/zbr75Zq+trS3Zpcds2bJlXigU8mpqarwTJ05El08++SQ6ZunSpd6wYcO8N9980ztw4IBXWFjoFRYWJrFqu89bzyNHjniPP/64d+DAAa+xsdHbtm2bN3LkSG/atGlJrtxm9erVXm1trdfY2OgdOnTIW716tRcIBLx/+Zd/8TyvZ+zL3sSJRu55nvfss896w4YN89LS0rwpU6Z4+/btS3ZJCXXPPfd4ubm5XlpamveFL3zBu+eee7wjR44ku6wu2b17tyfpsqWkpMTzvEt/gvboo4962dnZXjAY9GbNmuU1NDQkt+g4XGs9P/nkE2/27NnekCFDvH79+nnDhw/3Fi9e7Nz/hF5p/SR5GzZsiI45d+6c953vfMe78cYbveuvv9676667vBMnTiSv6Dh83noeO3bMmzZtmpeZmekFg0Fv9OjR3l/91V954XA4uYUbPfTQQ97w4cO9tLQ0b8iQId6sWbOiTdzzesa+7E34GVMAAByW8p+RAwCAq6ORAwDgMBo5AAAOo5EDAOAwGjkAAA6jkQMA4DAaOQAADqORAwDgMBo5AAAOo5EDAOAwGjkAAA77Px3++ndP5mJ4AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Assuming your 32x32 array is stored in a variable called 'color_array'\n",
    "# You can create a NumPy array with random values for demonstration\n",
    "color_array = np.random.randint(4, size=(32, 32))\n",
    "\n",
    "# Define the color map for visualization\n",
    "cmap = plt.cm.colors.ListedColormap(['white', 'red', 'blue', 'green'])\n",
    "\n",
    "# Plot the array using imshow\n",
    "plt.imshow(color_array, cmap=cmap, interpolation='nearest')\n",
    "\n",
    "# Add color bar for reference\n",
    "plt.colorbar(ticks=[0, 1, 2, 3], label='Color')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
