{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "6NFvoEitmh6t"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "from typing import List, Dict\n",
        "from scipy.special import softmax\n",
        "import matplotlib.pyplot as plt"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# 1. Illustration of the decoding of the embedding values"
      ],
      "metadata": {
        "id": "v74563pMs1DP"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "xs = np.linspace(0, 1, 20)\n",
        "for j in range(10):\n",
        "  plt.plot(xs, (0.25 - ((j)/10)**2) + (2*(j)/10 -1) * xs, label=str(j) )\n",
        "  plt.scatter((j)/10, (0.25 - ((j)/10)**2) + (2*(j)/10 -1) * (j)/10 )\n",
        "\n",
        "plt.legend(ncol=2)\n",
        "plt.grid()\n",
        "plt.ylim(-.2, .3)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 435
        },
        "id": "wX9XLFuWs0Uo",
        "outputId": "e6074c0a-e012-47a7-880a-a35871788f79"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# 2. Unconditional generation controlling only the first embedding"
      ],
      "metadata": {
        "id": "EqI7xVhpmsN3"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# we use the ASCII encoding for the 94 printable ASCII characters as our tokenizer\n",
        "\n",
        "N = 20 # max sequence length\n",
        "V = 94 # vocabulary size\n",
        "T = 50 # softmax (inverse) temperature\n",
        "\n",
        "def char_to_onehot_token(c: str):\n",
        "  assert len(c)==1\n",
        "  r = np.zeros(V)\n",
        "  r[ord(c[0])-32] = 1\n",
        "  return r\n",
        "\n",
        "def pred_vector_to_char(arr: np.array):\n",
        "  return chr(np.argmax(arr)+32)\n",
        "\n",
        "def build_virtual_token(s: str):\n",
        "  \"\"\" Given a string s, this builds its encoding as an embedding \"\"\"\n",
        "  assert len(s) <= N\n",
        "  r = np.zeros(N)\n",
        "  s = s.ljust(N, ' ') # padding so that all sequences are N long, this way no need for a special EOS token\n",
        "  for i, c in enumerate(s):\n",
        "    r[i] = (ord(c)-32)/V\n",
        "  return r\n",
        "\n",
        "def position_encoding(i: int):\n",
        "  r = np.zeros(N)\n",
        "  r[i] = 1\n",
        "  return r\n",
        "\n",
        "def attention_head(WQ, WK, WV, xs):\n",
        "  qs = [WQ @ x for x in xs]\n",
        "  ks = [WK @ x for x in xs]\n",
        "  vs = [WV @ x for x in xs]\n",
        "\n",
        "  A = np.zeros((len(xs), len(xs)))\n",
        "  for i in range(len(xs)):\n",
        "    for j in range(len(xs)):\n",
        "      A[i, j] = (np.dot(qs[i],ks[j])) / np.sqrt(len(xs))\n",
        "\n",
        "  A = softmax(A*T, axis=1)\n",
        "  # print(np.round(A, 3))\n",
        "\n",
        "  r = []\n",
        "  for i in range(len(xs)):\n",
        "    rr = np.zeros_like(vs[0])\n",
        "    for j in range(len(xs)):\n",
        "      rr += A[i, j] * vs[j]\n",
        "    r.append(rr)\n",
        "\n",
        "  return r\n",
        "\n",
        "def linear_layer(A, b, xs, with_relu=True):\n",
        "  rs = [np.dot(A, x) + b for x in xs]\n",
        "  if with_relu:\n",
        "    rs = [np.clip(r, 0, np.inf) for r in rs]\n",
        "  return rs"
      ],
      "metadata": {
        "id": "MA-wW-Jomnj4"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "target_string = \"I love transformers!\"\n",
        "\n",
        "E = np.zeros((N, V)) # embedding matrix, it's value doesn't matter in this case\n",
        "\n",
        "x = np.hstack([build_virtual_token(target_string), position_encoding(0)])\n",
        "\n",
        "y = []\n",
        "\n",
        "while len(y) < N:\n",
        "\n",
        "  input = [x] + [np.hstack([E @ char_to_onehot_token(y[i]), position_encoding(i+1)]) for i in range(len(y))]\n",
        "\n",
        "  K_pos = Q_pos = V_pos =  np.block([[np.zeros((N, N)), np.eye(N)]])\n",
        "  h_pos = attention_head(Q_pos, K_pos, V_pos, input)\n",
        "\n",
        "  K_first = np.zeros((1, 2*N))\n",
        "  K_first[0, N] = 1\n",
        "\n",
        "  Q_first = np.concatenate([np.zeros(N), np.ones(N)])\n",
        "\n",
        "  V_first = np.block([[np.eye(N), np.zeros((N, N))]])\n",
        "\n",
        "  h_first = attention_head(Q_first, K_first, V_first, input)\n",
        "\n",
        "  h = [p+f for p, f in zip(h_pos, h_first)]\n",
        "\n",
        "  A1 = np.eye(N)\n",
        "  b1 = np.ones(N) * -1\n",
        "  z1 = linear_layer(A1, b1, h)\n",
        "\n",
        "  A2 = np.ones(N)\n",
        "  b2 = 0\n",
        "  z2 = linear_layer(A2, b2, z1)\n",
        "\n",
        "  A3 = np.zeros(V)\n",
        "  b3 = np.zeros(V)\n",
        "  for i in range(V):\n",
        "    A3[i] = 2*i/V - 1\n",
        "    b3[i] = 0.25 - (i/V)**2\n",
        "\n",
        "  y = linear_layer(A3, b3, z2, with_relu=False)\n",
        "  y = [pred_vector_to_char(yy) for yy in y]\n",
        "\n",
        "  print(\"\".join(y))\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "oEKb3aLqp3SU",
        "outputId": "6d2babc6-52ed-4702-de47-6477d51e7808"
      },
      "execution_count": 4,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "I\n",
            "I \n",
            "I l\n",
            "I lo\n",
            "I lov\n",
            "I love\n",
            "I love \n",
            "I love t\n",
            "I love tr\n",
            "I love tra\n",
            "I love tran\n",
            "I love trans\n",
            "I love transf\n",
            "I love transfo\n",
            "I love transfor\n",
            "I love transform\n",
            "I love transforme\n",
            "I love transformer\n",
            "I love transformers\n",
            "I love transformers!\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# 3. Conditional generation of a single token given a single token"
      ],
      "metadata": {
        "id": "ri3yi7b13QM3"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "V = 94 # vocabulary size\n",
        "N = 2 # max sequence length\n",
        "T = 100 # softmax (inverse) temperature\n",
        "\n",
        "def build_virtual_token(m: Dict):\n",
        "  \"\"\" Given a map m from charcters to characters, this builds it encoding as an embedding \"\"\"\n",
        "  r = np.zeros(V)\n",
        "  for i in range(94):\n",
        "    key_char = chr(i+32)\n",
        "    if key_char in m:\n",
        "      r[i] = (ord(m[key_char]) - 32) / V\n",
        "    else:\n",
        "      r[i] = 0 / V\n",
        "  return r\n",
        "\n"
      ],
      "metadata": {
        "id": "boR0fGEZqZRH"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# flip the case of the letter\n",
        "m = {**dict(zip(\"abcdefghijklmnopqrstuvwxyz\", \"ABCDEFGHIJKLMNOPQRSTUVWXYZ\")),\n",
        "     **dict(zip(\"ABCDEFGHIJKLMNOPQRSTUVWXYZ\", \"abcdefghijklmnopqrstuvwxyz\"))}\n",
        "\n",
        "user_character = \"f\"\n",
        "\n",
        "E = np.eye(V) # embedding matrix\n",
        "\n",
        "x = [\n",
        "    np.hstack([build_virtual_token(m), position_encoding(0)]),\n",
        "    np.hstack([E @ char_to_onehot_token(user_character), position_encoding(1)]),\n",
        "]\n",
        "\n",
        "K_val = Q_val = np.block([[np.zeros((N, V)), np.eye(N)]])\n",
        "V_val = np.block([[np.eye(V), np.zeros((V,N))]])\n",
        "h_val = attention_head(Q_val, K_val, V_val, x)\n",
        "\n",
        "K_first = np.zeros((1, V+N))\n",
        "K_first[0, V] = 1\n",
        "\n",
        "Q_first = np.concatenate([np.zeros(V), np.ones(N)])\n",
        "\n",
        "V_first = np.block([[np.eye(V), np.zeros((V, N))]])\n",
        "\n",
        "h_first = attention_head(Q_first, K_first, V_first, x)\n",
        "\n",
        "h = [p+f for p, f in zip(h_val, h_first)]\n",
        "\n",
        "A1 = np.eye(V)\n",
        "b1 = np.ones(V) * -1\n",
        "z1 = linear_layer(A1, b1, h)\n",
        "\n",
        "A2 = np.ones(V)\n",
        "b2 = 0\n",
        "z2 = linear_layer(A2, b2, z1)\n",
        "\n",
        "A3 = np.zeros(V)\n",
        "b3 = np.zeros(V)\n",
        "for i in range(V):\n",
        "  A3[i] = 2*i/V - 1\n",
        "  b3[i] = 0.25 - (i/V)**2\n",
        "\n",
        "y = linear_layer(A3, b3, z2, with_relu=False)\n",
        "y = [pred_vector_to_char(yy) for yy in y]\n",
        "\n",
        "print(f\"User input: {user_character}, model response: {y[1]}\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "AJJQfxAe3zq8",
        "outputId": "dc5f3435-77dd-412d-d73c-02085aed9a58"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "User input: f, model response: F\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# 4. Conditional generation with longer responses"
      ],
      "metadata": {
        "id": "vtFKFyIeLfQa"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "V = 94 # vocabulary size\n",
        "N0 = 10 # response length\n",
        "N = 2*N0 # max sequence length\n",
        "T = 100 # softmax (inverse) temperature\n",
        "\n",
        "def build_virtual_tokens(m: Dict):\n",
        "  \"\"\" Given a map m from charcters to strings, this builds it encoding as an embedding \"\"\"\n",
        "\n",
        "  # pad m with spaces so that all targets are equally long\n",
        "  max_target_len = max([len(v) for v in m.values()])\n",
        "  if max_target_len > N0:\n",
        "    raise RuntimeError(f\"The longest target ({max_target_len}) is longer than the response length ({N0})!\")\n",
        "  padded_m = {k: v.ljust(N0, ' ') for k,v in m.items()}\n",
        "\n",
        "  vts = []\n",
        "\n",
        "  for pos in range(N0):\n",
        "    r = np.zeros(V)\n",
        "    for i in range(94):\n",
        "      key_char = chr(i+32)\n",
        "      if key_char in m:\n",
        "        r[i] = (ord(padded_m[key_char][pos]) - 32) / V\n",
        "      else:\n",
        "        r[i] = 0 / V\n",
        "    vts.append(r)\n",
        "\n",
        "  return vts\n"
      ],
      "metadata": {
        "id": "olCSEG01LeoE"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Complete capital letters with animals and small letters with food\n",
        "m = {\n",
        "  \"A\": \"lligator\",\n",
        "  \"B\": \"ear\",\n",
        "  \"C\": \"at\",\n",
        "  \"D\": \"og\",\n",
        "  \"E\": \"lephant\",\n",
        "  \"F\": \"lamingo\",\n",
        "  \"G\": \"irafe\",\n",
        "  \"H\": \"ippo\",\n",
        "  \"I\": \"guana\",\n",
        "  \"J\": \"aguar\",\n",
        "  \"K\": \"oala\",\n",
        "  \"L\": \"ion\",\n",
        "  \"M\": \"onkey\",\n",
        "  \"N\": \"ewt\",\n",
        "  \"O\": \"strich\",\n",
        "  \"P\": \"ig\",\n",
        "  \"Q\": \"uail\",\n",
        "  \"R\": \"hino\",\n",
        "  \"S\": \"heep\",\n",
        "  \"T\": \"iger\",\n",
        "  \"U\": \"rchin\",\n",
        "  \"V\": \"ulture\",\n",
        "  \"W\": \"olf\",\n",
        "  \"X\": \"ray tetra\",\n",
        "  \"Y\": \"ak\",\n",
        "  \"Z\": \"ebra\",\n",
        "  \"a\": \"sparagus\",\n",
        "  \"b\": \"lueberries\",\n",
        "  \"c\": \"auliflower\",\n",
        "  \"d\": \"aikon\",\n",
        "  \"e\": \"ndive\",\n",
        "  \"f\": \"ig\",\n",
        "  \"g\": \"inger\",\n",
        "  \"h\": \"oney\",\n",
        "  \"i\": \"ce cream\",\n",
        "  \"j\": \"am\",\n",
        "  \"k\": \"iwi\",\n",
        "  \"l\": \"emon\",\n",
        "  \"m\": \"ango\",\n",
        "  \"n\": \"ettle\",\n",
        "  \"o\": \"kra\",\n",
        "  \"p\": \"each\",\n",
        "  \"q\": \"uinoa\",\n",
        "  \"r\": \"adish\",\n",
        "  \"s\": \"pinach\",\n",
        "  \"t\": \"urnips\",\n",
        "  \"u\": \"meboshi\",\n",
        "  \"v\": \"ine leaf\",\n",
        "  \"w\": \"atermelon\",\n",
        "  \"x\": \"ylitol\",\n",
        "  \"y\": \"am\",\n",
        "  \"z\": \"ucchini\",\n",
        "}\n",
        "\n"
      ],
      "metadata": {
        "id": "oY2g0OJdLvcH"
      },
      "execution_count": 8,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "user_character = \"b\"\n",
        "\n",
        "E = np.eye(V) # embedding matrix\n",
        "\n",
        "vts = build_virtual_tokens(m)\n",
        "\n",
        "y = [user_character]\n",
        "\n",
        "while len(y) <= N0:\n",
        "\n",
        "  # print(f\"y={y}\")\n",
        "  # if len(y) > 3:\n",
        "  #   break\n",
        "\n",
        "  x = [np.hstack([vts[i], position_encoding(i)]) for i in range(N0) ] + [np.hstack([E @ char_to_onehot_token(gen_char), position_encoding(N0+i)]) for i, gen_char in enumerate(y)]\n",
        "\n",
        "  # gets the value N0 positions back\n",
        "  Q_N0back = np.block([\n",
        "      [np.zeros((N0, V)), np.zeros((N0, N0)), np.eye(N0)],\n",
        "      [np.zeros((N0, V)), np.zeros((N0, N0)), np.zeros((N0, N0))],\n",
        "    ])\n",
        "  K_N0back = np.block([np.zeros((N, V)), np.eye(N)])\n",
        "  V_N0back = np.block([[np.eye(V), np.zeros((V, N))]])\n",
        "  h_N0back = attention_head(Q_N0back, K_N0back, V_N0back, x)\n",
        "\n",
        "  # always gets the value of the user-provided token\n",
        "  Q_user = np.concatenate([np.zeros(V), np.ones(N)])\n",
        "  K_user = np.concatenate([np.zeros(V), np.zeros(N0), [1], np.zeros(N0-1)])\n",
        "  V_user = np.block([[np.eye(V), np.zeros((V,N))]])\n",
        "  h_user = attention_head(Q_user, K_user, V_user, x)\n",
        "\n",
        "  h = [p+f for p, f in zip(h_user, h_N0back)]\n",
        "\n",
        "  A1 = np.eye(V)\n",
        "  b1 = np.ones(V) * -1\n",
        "  z1 = linear_layer(A1, b1, h)\n",
        "\n",
        "  A2 = np.ones(V)\n",
        "  b2 = 0\n",
        "  z2 = linear_layer(A2, b2, z1)\n",
        "\n",
        "  A3 = np.zeros(V)\n",
        "  b3 = np.zeros(V)\n",
        "  for i in range(V):\n",
        "    A3[i] = 2*i/V - 1\n",
        "    b3[i] = 0.25 - (i/V)**2\n",
        "\n",
        "  out = linear_layer(A3, b3, z2, with_relu=False)\n",
        "  next_char = pred_vector_to_char(out[-1])\n",
        "  y.append(next_char)\n",
        "\n",
        "  print(\"\".join(y))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "3aKln3wLQokQ",
        "outputId": "1a522c19-56e4-4670-a609-e75963b7e9f6"
      },
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "bl\n",
            "blu\n",
            "blue\n",
            "blueb\n",
            "bluebe\n",
            "blueber\n",
            "blueberr\n",
            "blueberri\n",
            "blueberrie\n",
            "blueberries\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# 5. Conditional generation given 2 tokens"
      ],
      "metadata": {
        "id": "-RCiyC9EzyBY"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "V = 10 # vocabulary size (restricted only to first 10 capital letters to prevent numerical issues)\n",
        "N = 4 # max sequence length\n",
        "T = 1000 # softmax (inverse) temperature\n",
        "\n",
        "def seq_to_float(seq):\n",
        "  \"\"\"Encodes a sequence to a float in [0, 1)\"\"\"\n",
        "  assert len(seq) == V\n",
        "  powers = [V**(V-i) for i in range(V)]\n",
        "  return sum([v*p for v, p in zip(seq, powers)])/(V**V)\n",
        "\n",
        "def float_to_seq(num):\n",
        "  \"\"\"Decodes a float in [0, 1) to a sequenze\"\"\"\n",
        "  reverse = []\n",
        "  num *= V**V\n",
        "  if num == 0:\n",
        "    return [0]*V\n",
        "  while num > 0:\n",
        "    reverse.append((num%V)/V)\n",
        "    num = num//V\n",
        "  l = list(reversed(reverse))\n",
        "  return [0] * (V-len(l)) + l\n",
        "\n",
        "def build_virtual_token(m: Dict):\n",
        "  \"\"\" Given a map m from strings of length 2 to characters, this builds it encoding as an embedding \"\"\"\n",
        "  r = np.zeros(V)\n",
        "  for i in range(V):\n",
        "    key_char = chr(i+65)\n",
        "\n",
        "    # build the map for the second position\n",
        "    m2 = {s[1]: v for s, v in m.items() if s[0]==key_char}\n",
        "\n",
        "    # encode this map as a value between 0 and 1\n",
        "    r2 = np.zeros(V)\n",
        "    for j in range(V):\n",
        "      if chr(j+65) in m2:\n",
        "        r2[j] = (ord(m2[chr(j+65)]) - 65) / V\n",
        "      else:\n",
        "        r2[j] = (30+65) / V # corresponds to \"_\"\n",
        "\n",
        "    r[i] = seq_to_float(r2)\n",
        "    if key_char == \"q\":\n",
        "      print(r[i], r2)\n",
        "  return r\n",
        "\n",
        "def char_to_onehot_token(c: str):\n",
        "  assert len(c)==1\n",
        "  r = np.zeros(V)\n",
        "  r[ord(c[0])-65] = 1\n",
        "  return r\n",
        "\n",
        "def pred_vector_to_char(arr: np.array):\n",
        "  return chr(np.argmax(arr)+65)"
      ],
      "metadata": {
        "id": "OQdTVZTs-h0V"
      },
      "execution_count": 10,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# This map just returns the second character:\n",
        "# m = {chr(i+65)+chr(j+65): chr(j+65) for i in range(V) for j in range(V) }\n",
        "# This is a random map:\n",
        "np.random.seed(0)\n",
        "m = {chr(i+65)+chr(j+65): chr(np.random.randint(V)+65) for i in range(V) for j in range(V) }\n",
        "\n",
        "\n",
        "print(\"Test sequences:\")\n",
        "ts = [\"AB\", \"AA\", \"BA\", \"DE\", \"BB\", \"BG\"]\n",
        "for t in ts:\n",
        "  print(f\"'{t}' -> '{m[t]}'\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "8eRXtflW0m-J",
        "outputId": "2f551e49-44cf-4a8e-ebb3-bf7bcebab113"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Test sequences:\n",
            "'AB' -> 'A'\n",
            "'AA' -> 'F'\n",
            "'BA' -> 'H'\n",
            "'DE' -> 'D'\n",
            "'BB' -> 'G'\n",
            "'BG' -> 'H'\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def compute_completion(m, user_input):\n",
        "\n",
        "  E = np.eye(V) # embedding matrix\n",
        "  vt = build_virtual_token(m)\n",
        "  x = [\n",
        "      np.hstack([np.zeros_like(vt), position_encoding(0)]), # a dummy virtual tokens with only zeros to attend to when we don't want to attend to anything\n",
        "      np.hstack([vt, position_encoding(1)]),\n",
        "      np.hstack([E @ char_to_onehot_token(user_input[0]), position_encoding(2)]),\n",
        "      np.hstack([E @ char_to_onehot_token(user_input[1]), position_encoding(3)]),\n",
        "  ]\n",
        "\n",
        "  # extract the value of the first user-provided token but only if we are\n",
        "  # currently computing that position and put\n",
        "  # it in the first half of the residual stream\n",
        "  Q_user_token1 = np.block([np.zeros((2, V)), np.array([[1,1,0,1],[0,0,1,0]])])\n",
        "  K_user_token1 = np.block([np.zeros((2, V)), np.array([[1,0,0,0],[0,0,1,0]])])\n",
        "  # this V matrix copies only in the first half of the residual stream\n",
        "  V_user_token1 = np.block([\n",
        "      [np.eye(V), np.zeros((V, N))],\n",
        "      [np.zeros((V,V)), np.zeros((V, N))],\n",
        "  ])\n",
        "  h_user_token1 = attention_head(Q_user_token1, K_user_token1, V_user_token1, x)\n",
        "\n",
        "  # same for the second token when we are looking at the second position\n",
        "  Q_user_token2 = np.block([np.zeros((2, V)), np.array([[1,1,1,0],[0,0,0,1]])])\n",
        "  K_user_token2 = np.block([np.zeros((2, V)), np.array([[1,0,0,0],[0,0,0,1]])])\n",
        "  # this V matrix copies only in the second half of the residual stream\n",
        "  V_user_token2 = np.block([\n",
        "      [np.zeros((V,V)), np.zeros((V, N))],\n",
        "      [2*np.eye(V), np.zeros((V, N))], #2 times so that it becomes 1 when we substract 1 in the following linear layer\n",
        "  ])\n",
        "  h_user_token2 = attention_head(Q_user_token2, K_user_token2, V_user_token2, x)\n",
        "\n",
        "  # place the prefix in the first half of the residual stream as well\n",
        "  # this way the first user input token will bump the prefix value at\n",
        "  # the corresponding position to be above 1\n",
        "  Q_first = np.block([np.zeros((2, V)), np.array([[1,1,0,1],[0,0,1,0]])])\n",
        "  K_first = np.block([np.zeros((2, V)), np.array([[1,0,0,0],[0,1,0,0]])])\n",
        "  V_first = V_user_token1\n",
        "  h_first = attention_head(Q_first, K_first, V_first, x)\n",
        "\n",
        "  # combine the heads\n",
        "  h1 = [u1+u2+f for u1, u2, f in zip(h_user_token1, h_user_token2, h_first)]\n",
        "\n",
        "  # we want to now extract the value for the map from\n",
        "  # second user token to response token\n",
        "  # we do that as before: substract 1 from everything and ReLU it\n",
        "  # however, we have to be careful to\n",
        "\n",
        "  A1_1 = np.eye(V*2)\n",
        "  b1_1 = np.ones(V*2) * -1\n",
        "  z1_1 = linear_layer(A1_1, b1_1, h1)\n",
        "\n",
        "  # and now we want to unpack the one non-zero value in the first\n",
        "  # half of the residual stream to V values according to the float_to_seq function\n",
        "  # we are going to save ourselves the hassle of building an explicit MLP for that\n",
        "  # and will use Python functions instead\n",
        "\n",
        "  z1_2 = [np.hstack((float_to_seq(np.sum(z1_1[i][:V])), z1_1[i][V:])) for i in range(N)]\n",
        "\n",
        "  # and now the second attention layer combines the newly unpacked embedding in\n",
        "  # the first half of the residual stream with the second user-provided token\n",
        "  # this is almost the same as the case with conditioning on one token, with\n",
        "  # the only difference that now our residual stream is twice as wide\n",
        "\n",
        "  Q_embedding = np.block([np.zeros(V), np.ones(V)])\n",
        "  K_embedding = np.block([np.ones(V), np.zeros(V)])\n",
        "  V_embedding = np.block([\n",
        "      [np.eye(V), np.zeros((V,V))],\n",
        "      ])\n",
        "  h_embedding = attention_head(Q_embedding, K_embedding, V_embedding, z1_2)\n",
        "\n",
        "  K_user_token2_remap = np.block([np.zeros(V), np.ones(V)])\n",
        "  Q_user_token2_remap = np.block([np.zeros(V), np.ones(V)])\n",
        "  V_user_token2_remap = np.block([\n",
        "      [np.zeros((V,V)), np.eye(V)],\n",
        "      ])\n",
        "  h_user_token2_remap = attention_head(Q_user_token2_remap, K_user_token2_remap, V_user_token2_remap, z1_2)\n",
        "\n",
        "  h2 = [e+t for e, t in zip(h_embedding, h_user_token2_remap)]\n",
        "\n",
        "  # Now decode as usual: substract 1, ReLU, and map to an output token\n",
        "  A2_1 = np.eye(V)\n",
        "  b2_1 = np.ones(V) * -1\n",
        "  z2_1 = linear_layer(A2_1, b2_1, h2)\n",
        "\n",
        "  A2_2 = np.ones(V)\n",
        "  b2_2 = 0\n",
        "  z2_2 = linear_layer(A2_2, b2_2, z2_1)\n",
        "\n",
        "  A2_3 = np.zeros(V)\n",
        "  b2_3 = np.zeros(V)\n",
        "  for i in range(V):\n",
        "    A2_3[i] = 2*i/V - 1\n",
        "    b2_3[i] = 0.25 - (i/V)**2\n",
        "\n",
        "  y_ = linear_layer(A2_3, b2_3, z2_2, with_relu=False)\n",
        "  y = [pred_vector_to_char(yy) for yy in y_]\n",
        "  return y\n"
      ],
      "metadata": {
        "id": "l3BAtpO3CGGq"
      },
      "execution_count": 12,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "user_input = \"BG\"\n",
        "y = compute_completion(m, user_input)\n",
        "print(f\"User input: {user_input}, model response: {y[3]} (ground truth is {m[user_input]})\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "4Xs91L2Alwep",
        "outputId": "9d2a07cd-f56e-432c-9be5-746651eb4e23"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "User input: BG, model response: H (ground truth is H)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# test all:\n",
        "correct = []\n",
        "for k, v in m.items():\n",
        "  y = compute_completion(m, k)[3]\n",
        "  correct.append(y==v)\n",
        "  if y!=v:\n",
        "    print(f\"DIFFERENCE: For user input {k} we get completion {y} when we expected {v}!\")\n",
        "print(f\"Correctly completed sequences: {100*sum(correct)/len(correct):.2f}%\")\n",
        "# It is possible that we get a few errors because of numerical issues:\n",
        "# a change in the embedding of as little as 1e-10 (1/(V^V)) changes the map!"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "L6i1qwVumu2X",
        "outputId": "554741a3-9afd-4947-fb9b-29da2c29fec8"
      },
      "execution_count": 14,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Correctly completed sequences: 100.00%\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "u_fjd9PeoWfc"
      },
      "execution_count": 14,
      "outputs": []
    }
  ]
}