{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ApATnfZgRYm-",
        "outputId": "4f7eefff-801a-4d8a-f5a7-5c5c49928a98"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/drive\n"
          ]
        }
      ],
      "source": [
        "from google.colab import drive\n",
        "drive.mount('/content/drive', force_remount=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "tTr7ETAitFga"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "\n",
        "DEVICE = \"cuda\" if torch.cuda.is_available() else \"cpu\""
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "qvVo1Prxpvj6"
      },
      "source": [
        "# Transductive & Zero-Shot Setting"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "jFATDuzmqTTU"
      },
      "source": [
        "## Data!"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "IRiLu8Yjqzah"
      },
      "source": [
        "### Which drugs are both in KG & EHR?"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5grKq0XgqVdU"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/zeroed_rows.pkl\", \"rb\") as file:\n",
        "  zeroed_rows = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "DLeqOD9GJRkH"
      },
      "outputs": [],
      "source": [
        "overlap_entity_ids = sorted(list(set(range(1710))-set(zeroed_rows)))"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "### Transductive Edges"
      ],
      "metadata": {
        "id": "GFyGpBtgfKhO"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qjq-GmO9rQvB"
      },
      "outputs": [],
      "source": [
        "test_edges = []\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id_original.txt\", \"r\") as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split(\"\\t\")\n",
        "    if len(row) == 3:\n",
        "      if int(row[0]) in zeroed_rows or int(row[1]) in zeroed_rows:\n",
        "        test_edges.append(row)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "TZBiJjVI1xcr"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/test_edges.pkl\", \"wb\") as file:\n",
        "  pickle.dump(test_edges, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "IHmi6ZRUzmnQ"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/test_edges.pkl\", \"rb\") as file:\n",
        "  test_edges = pickle.load(file)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "NNd9Su0NJxH7"
      },
      "source": [
        "### Extract the KG embeddings"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "xtRCREi8J4RN"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "\n",
        "KG_state_dict = torch.load(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models/state_0.pt\", map_location=DEVICE)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "06BElTTtmRc0"
      },
      "outputs": [],
      "source": [
        "all_embeddings = KG_state_dict['ent_embed.weight']\n",
        "# all_embeddings = model.state_dict()['ent_embed.weight']"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WU7CJdTim-0g"
      },
      "outputs": [],
      "source": [
        "Zk_overlap = []\n",
        "for i in range(len(all_embeddings)):\n",
        "  if i in overlap_entity_ids:\n",
        "    Zk_overlap.append(all_embeddings[i])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "B1VcZreGExGA"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/Zk_overlap.pkl\", \"wb\") as file:\n",
        "  pickle.dump(Zk_overlap, file)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "EN440UGUEjjY"
      },
      "source": [
        "### Fusion & General KG"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "afkaM1uyEtiY"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/Ze_overlap.pkl\", \"rb\") as file:\n",
        "  Ze_overlap = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "SZ2AX8LrE6D9"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/Zk_overlap.pkl\", \"rb\") as file:\n",
        "  Zk_overlap = pickle.load(file)"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "For Fusion"
      ],
      "metadata": {
        "id": "UGCnvf0jgMOb"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "e_F7H_GIjf_h"
      },
      "outputs": [],
      "source": [
        "import torch, numpy as np\n",
        "\n",
        "n_ent = 1710\n",
        "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
        "\n",
        "Ee_full = torch.zeros(n_ent, 64, device=device)\n",
        "ids = torch.tensor(overlap_entity_ids, dtype=torch.long, device=device)\n",
        "Ee_full[ids] = Ze_overlap.to(device)\n",
        "\n",
        "Ek_full = model.ent_embed.weight.detach().to(device)  # [n_ent, 64]\n",
        "\n",
        "ehr_mask = torch.zeros(n_ent, dtype=torch.bool, device=device)\n",
        "ehr_mask[ids] = True"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Xk4r-O1xGEgE"
      },
      "outputs": [],
      "source": [
        "ehr_mask"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "UwVTxHkHhjna",
        "outputId": "eb0c96b3-c4d3-4a10-fd06-640f8ef7bf04"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF\n"
          ]
        }
      ],
      "source": [
        "%cd \"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF\""
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Train the KG"
      ],
      "metadata": {
        "id": "1kVJ5goef8x1"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "59WV9I0VnmIn",
        "outputId": "8313b652-4234-4560-d887-3b3668605ecb"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "B=4 Iter 1\tsampled 5 candidate state for evaluate 12890\n",
            "Entity count: 1710\n",
            "Relation count: 86\n",
            "Train max head/tail/relation: tensor(1709) tensor(1708) tensor(1)\n",
            "Valid max head/tail/relation: tensor(0) tensor(0) tensor(0)\n",
            "Test  max head/tail/relation: tensor(0) tensor(0) tensor(0)\n",
            "new: 0 [3 0 2 1] 4\n",
            "Epoch 0, loss = 2285.619873046875\n",
            "Epoch 1, loss = 2212.7978515625\n",
            "Epoch 2, loss = 2194.193603515625\n",
            "Epoch 3, loss = 2148.19189453125\n",
            "Epoch 4, loss = 2087.9833984375\n",
            "Epoch 5, loss = 2067.156494140625\n",
            "Epoch 6, loss = 2108.76025390625\n",
            "Epoch 7, loss = 2134.558837890625\n",
            "Epoch 8, loss = 2118.28857421875\n",
            "Epoch 9, loss = 2073.871826171875\n",
            "Epoch 10, loss = 2040.1593017578125\n",
            "Epoch 11, loss = 2155.733154296875\n",
            "Epoch 12, loss = 2039.620361328125\n",
            "Epoch 13, loss = 2038.5054931640625\n",
            "Epoch 14, loss = 2031.1949462890625\n",
            "Epoch 15, loss = 2079.547119140625\n",
            "Epoch 16, loss = 2083.808837890625\n",
            "Epoch 17, loss = 2059.786376953125\n",
            "Epoch 18, loss = 2037.8104248046875\n",
            "Epoch 19, loss = 2140.97900390625\n",
            "Epoch 20, loss = 2037.5804443359375\n",
            "Epoch 21, loss = 2082.656494140625\n",
            "Epoch 22, loss = 2009.2725830078125\n",
            "Epoch 23, loss = 1944.94189453125\n",
            "Epoch 24, loss = 1973.65869140625\n",
            "Epoch 25, loss = 2039.83837890625\n",
            "Epoch 26, loss = 2029.842529296875\n",
            "Epoch 27, loss = 1956.342041015625\n",
            "Epoch 28, loss = 2001.067626953125\n",
            "Epoch 29, loss = 1992.933837890625\n",
            "Epoch 30, loss = 1901.974365234375\n",
            "Epoch 31, loss = 1985.0560302734375\n",
            "Epoch 32, loss = 2002.572021484375\n",
            "Epoch 33, loss = 2050.1025390625\n",
            "Epoch 34, loss = 2019.0648193359375\n",
            "Epoch 35, loss = 2074.36865234375\n",
            "Epoch 36, loss = 1999.2244873046875\n",
            "Epoch 37, loss = 2056.9951171875\n",
            "Epoch 38, loss = 1941.12548828125\n",
            "Epoch 39, loss = 1983.252685546875\n",
            "Epoch 40, loss = 1892.6717529296875\n",
            "Epoch 41, loss = 1903.4219970703125\n",
            "Epoch 42, loss = 2045.363037109375\n",
            "Epoch 43, loss = 1984.9903564453125\n",
            "Epoch 44, loss = 1983.0982666015625\n",
            "Epoch 45, loss = 1993.655029296875\n",
            "Epoch 46, loss = 1962.7198486328125\n",
            "Epoch 47, loss = 1993.3817138671875\n",
            "Epoch 48, loss = 2014.766357421875\n",
            "Epoch 49, loss = 1951.503173828125\n",
            "Epoch 50, loss = 1928.115478515625\n",
            "Epoch 51, loss = 1950.6343994140625\n",
            "Epoch 52, loss = 1900.68115234375\n",
            "Epoch 53, loss = 1996.90234375\n",
            "Epoch 54, loss = 1935.044677734375\n",
            "Epoch 55, loss = 1910.045654296875\n",
            "Epoch 56, loss = 2040.910888671875\n",
            "Epoch 57, loss = 1914.075439453125\n",
            "Epoch 58, loss = 1898.3819580078125\n",
            "Epoch 59, loss = 1963.5155029296875\n",
            "Epoch 60, loss = 1910.0157470703125\n",
            "Epoch 61, loss = 1887.678466796875\n",
            "Epoch 62, loss = 1957.6380615234375\n",
            "Epoch 63, loss = 2038.01953125\n",
            "Epoch 64, loss = 2083.76025390625\n",
            "Epoch 65, loss = 2032.740234375\n",
            "Epoch 66, loss = 2014.244384765625\n",
            "Epoch 67, loss = 1908.015625\n",
            "Epoch 68, loss = 1951.04541015625\n",
            "Epoch 69, loss = 2021.0081787109375\n",
            "Epoch 70, loss = 1899.9569091796875\n",
            "Epoch 71, loss = 1886.632568359375\n",
            "Epoch 72, loss = 1986.47998046875\n",
            "Epoch 73, loss = 1958.8218994140625\n",
            "Epoch 74, loss = 1989.0941162109375\n",
            "Epoch 75, loss = 1922.0682373046875\n",
            "Epoch 76, loss = 2088.2001953125\n",
            "Epoch 77, loss = 1974.1986083984375\n",
            "Epoch 78, loss = 2009.909912109375\n",
            "Epoch 79, loss = 1975.93896484375\n",
            "Epoch 80, loss = 1917.67822265625\n",
            "Epoch 81, loss = 1953.3446044921875\n",
            "Epoch 82, loss = 1996.617919921875\n",
            "Epoch 83, loss = 1996.9959716796875\n",
            "Epoch 84, loss = 1927.9324951171875\n",
            "Epoch 85, loss = 1942.6024169921875\n",
            "Epoch 86, loss = 1867.205322265625\n",
            "Epoch 87, loss = 1899.9931640625\n",
            "Epoch 88, loss = 1912.5135498046875\n",
            "Epoch 89, loss = 1902.0069580078125\n",
            "Epoch 90, loss = 2014.37939453125\n",
            "Epoch 91, loss = 1945.6937255859375\n",
            "Epoch 92, loss = 1938.045654296875\n",
            "Epoch 93, loss = 1911.0565185546875\n",
            "Epoch 94, loss = 1924.700927734375\n",
            "Epoch 95, loss = 1944.8038330078125\n",
            "Epoch 96, loss = 1976.6280517578125\n",
            "Epoch 97, loss = 1923.619384765625\n",
            "Epoch 98, loss = 1986.5386962890625\n",
            "Epoch 99, loss = 1910.032958984375\n",
            "Epoch 100, loss = 1957.5855712890625\n",
            "Epoch 101, loss = 1891.703857421875\n",
            "Epoch 102, loss = 1888.36767578125\n",
            "Epoch 103, loss = 1889.60791015625\n",
            "Epoch 104, loss = 1923.521484375\n",
            "Epoch 105, loss = 1986.416015625\n",
            "Epoch 106, loss = 1938.6549072265625\n",
            "Epoch 107, loss = 1885.8134765625\n",
            "Epoch 108, loss = 1951.436279296875\n",
            "Epoch 109, loss = 1925.5208740234375\n",
            "Epoch 110, loss = 1914.090087890625\n",
            "Epoch 111, loss = 1941.7060546875\n",
            "Epoch 112, loss = 1963.0413818359375\n",
            "Epoch 113, loss = 1965.476318359375\n",
            "Epoch 114, loss = 1919.22509765625\n",
            "Epoch 115, loss = 1928.9349365234375\n",
            "Epoch 116, loss = 1921.2171630859375\n",
            "Epoch 117, loss = 1921.1788330078125\n",
            "Epoch 118, loss = 1967.7703857421875\n",
            "Epoch 119, loss = 1967.414306640625\n",
            "Epoch 120, loss = 1951.6365966796875\n",
            "Epoch 121, loss = 1930.32275390625\n",
            "Epoch 122, loss = 1934.44140625\n",
            "Epoch 123, loss = 1958.042724609375\n",
            "Epoch 124, loss = 1971.53759765625\n",
            "Epoch 125, loss = 1926.2998046875\n",
            "Epoch 126, loss = 1946.3077392578125\n",
            "Epoch 127, loss = 1829.883056640625\n",
            "Epoch 128, loss = 1931.0338134765625\n",
            "Epoch 129, loss = 1933.9495849609375\n",
            "Epoch 130, loss = 1979.589111328125\n",
            "Epoch 131, loss = 1943.363525390625\n",
            "Epoch 132, loss = 1974.682373046875\n",
            "Epoch 133, loss = 1972.2034912109375\n",
            "Epoch 134, loss = 1948.037353515625\n",
            "Epoch 135, loss = 1898.4613037109375\n",
            "Epoch 136, loss = 1944.8681640625\n",
            "Epoch 137, loss = 1945.724365234375\n",
            "Epoch 138, loss = 1955.3055419921875\n",
            "Epoch 139, loss = 2044.6031494140625\n",
            "Epoch 140, loss = 1954.2672119140625\n",
            "Epoch 141, loss = 1972.747802734375\n",
            "Epoch 142, loss = 1928.938720703125\n",
            "Epoch 143, loss = 2034.604248046875\n",
            "Epoch 144, loss = 1879.9415283203125\n",
            "Epoch 145, loss = 1957.24853515625\n",
            "Epoch 146, loss = 1946.484375\n",
            "Epoch 147, loss = 1936.0152587890625\n",
            "Epoch 148, loss = 1952.3736572265625\n",
            "Epoch 149, loss = 1872.6695556640625\n",
            "structure: 0 [3 0 2 1] \twrite best mrr $valid mrr:0.0020, H@1:0.0000, H@10:0.0000\t\t$test mrr:0.0020, H@1:0.0000, H@10:0.0000\n",
            "\n",
            "✔️ Model saved to /content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models/state_0.pt\n",
            "new: 1 [2 3 0 1] 4\n",
            "Epoch 0, loss = 2309.0146484375\n",
            "Epoch 1, loss = 2177.678466796875\n",
            "Epoch 2, loss = 2230.19873046875\n",
            "Epoch 3, loss = 2203.058837890625\n",
            "Epoch 4, loss = 2110.54541015625\n",
            "Epoch 5, loss = 2115.277099609375\n",
            "Epoch 6, loss = 2191.55224609375\n",
            "Epoch 7, loss = 2101.28515625\n",
            "Epoch 8, loss = 2096.784912109375\n",
            "Epoch 9, loss = 2102.48779296875\n",
            "Epoch 10, loss = 2021.9937744140625\n",
            "Epoch 11, loss = 2067.7763671875\n",
            "Epoch 12, loss = 2106.039794921875\n",
            "Epoch 13, loss = 2077.5625\n",
            "Epoch 14, loss = 2026.67626953125\n",
            "Epoch 15, loss = 2042.36279296875\n",
            "Epoch 16, loss = 2080.54833984375\n",
            "Epoch 17, loss = 1937.8902587890625\n",
            "Epoch 18, loss = 2067.6962890625\n",
            "Epoch 19, loss = 2009.2147216796875\n",
            "Epoch 20, loss = 2162.3671875\n",
            "Epoch 21, loss = 2145.315673828125\n",
            "Epoch 22, loss = 2127.59130859375\n",
            "Epoch 23, loss = 2066.0390625\n",
            "Epoch 24, loss = 2038.8875732421875\n",
            "Epoch 25, loss = 1956.774658203125\n",
            "Epoch 26, loss = 1972.807861328125\n",
            "Epoch 27, loss = 2002.3443603515625\n",
            "Epoch 28, loss = 2053.04736328125\n",
            "Epoch 29, loss = 1975.3988037109375\n",
            "Epoch 30, loss = 1938.827880859375\n",
            "Epoch 31, loss = 1965.9166259765625\n",
            "Epoch 32, loss = 2014.4844970703125\n",
            "Epoch 33, loss = 1965.87646484375\n",
            "Process ForkServerPoolWorker-1:\n",
            "Traceback (most recent call last):\n",
            "  File \"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/train.py\", line 222, in <module>\n",
            "    pool.join()\n",
            "  File \"/usr/lib/python3.12/multiprocessing/pool.py\", line 665, in join\n",
            "    self._worker_handler.join()\n",
            "  File \"/usr/lib/python3.12/threading.py\", line 1149, in join\n",
            "    self._wait_for_tstate_lock()\n",
            "  File \"/usr/lib/python3.12/threading.py\", line 1169, in _wait_for_tstate_lock\n",
            "    if lock.acquire(block, timeout):\n",
            "       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "KeyboardInterrupt\n"
          ]
        }
      ],
      "source": [
        "!bash run.sh"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wLv-FmskS4ss",
        "outputId": "3def5629-fdb4-430e-aab6-f6ff9902b55a"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models\n"
          ]
        }
      ],
      "source": [
        "%cd \"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models\""
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "AWwEzrfSewh5",
        "outputId": "0b97dabd-72c5-4c23-9208-3eb772c8cddb"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "KGEModule(\n",
              "  (loss): Softplus(beta=1.0, threshold=20.0)\n",
              "  (ent_embed): Embedding(1710, 64)\n",
              "  (rel_embed): Embedding(86, 64)\n",
              ")"
            ]
          },
          "execution_count": 10,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model = KGEModule(1710, 86, arguments, [1,2,0,3])\n",
        "model.load_state_dict(torch.load(\"state_0.pt\", map_location=torch.device('cpu')))\n",
        "model.eval()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "YljL-ILfhGBX"
      },
      "outputs": [],
      "source": [
        "def predict(model, h, t):\n",
        "  device = next(model.parameters()).device  # detect model device\n",
        "\n",
        "  head = torch.tensor([h]).to(device)\n",
        "  tail = torch.tensor([t]).to(device)\n",
        "\n",
        "  head_embed = model.ent_embed(head)\n",
        "  tail_embed = model.ent_embed(tail)\n",
        "\n",
        "  highest_cosine_sim = 0\n",
        "  highest_cosine_sim_rela = 0\n",
        "\n",
        "  for i in range(86):\n",
        "    try:\n",
        "      rela = torch.tensor([i]).to(device)\n",
        "      rela_embed = model.rel_embed(rela)\n",
        "\n",
        "      score = model.test_trip(head_embed, rela_embed, tail_embed)\n",
        "\n",
        "      if score > highest_cosine_sim:\n",
        "        highest_cosine_sim = score\n",
        "        highest_cosine_sim_rela = i\n",
        "    except:\n",
        "      break\n",
        "\n",
        "  return highest_cosine_sim_rela"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 216
        },
        "id": "s9F8NuzlhZbO",
        "outputId": "6d90920a-a03b-4647-9844-39feccb3de2b"
      },
      "outputs": [
        {
          "ename": "NameError",
          "evalue": "name 'training_nodes_adj' is not defined",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-12-686586712.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mcount\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0maccurate_predictions\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 3\u001b[0;31m \u001b[0;32mfor\u001b[0m \u001b[0mnode\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mtraining_nodes_adj\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkeys\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      4\u001b[0m   \u001b[0;32mfor\u001b[0m \u001b[0medge\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mtraining_nodes_adj\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnode\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0mprediction\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpredict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnode\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0medge\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mNameError\u001b[0m: name 'training_nodes_adj' is not defined"
          ]
        }
      ],
      "source": [
        "count = 0\n",
        "accurate_predictions = 0\n",
        "for node in training_nodes_adj.keys():\n",
        "  for edge in training_nodes_adj[node]:\n",
        "    prediction = predict(model, node, edge[0])\n",
        "    print(prediction, edge[1])\n",
        "    if prediction == edge[1]:\n",
        "      accurate_predictions += 1\n",
        "    count += 1\n",
        "  if count >= 1000:\n",
        "    break\n",
        "print(accurate_predictions/count)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "3E75MDqiwQpY"
      },
      "source": [
        "Accuracy for combined model: $0.9008090614886731$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "WifUgR-K5rGd"
      },
      "source": [
        "Accuracy for the original model: $0.8132686084142395$"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "accurate_preds = 0\n",
        "count = 0\n",
        "\n",
        "with open(\"/content/test_file_6.txt\", 'r') as file:\n",
        "  with open(\"/content/test_file_5.txt\", 'w') as file2:\n",
        "    for line in file.readlines():\n",
        "      row = line.split(\"\\t\")\n",
        "      if len(row) == 3:\n",
        "        # global prediction\n",
        "        # exists = predict(model2, int(row[0]), int(row[2]))\n",
        "        # if exists == 1:\n",
        "        prediction = predict(model, int(row[0]), int(row[2]))\n",
        "        # else:\n",
        "        #   prediction = 0\n",
        "        file2.write(f\"{prediction}\\t{row[1]}\\n\")\n",
        "        if count % 100 == 0:\n",
        "          print(count)\n",
        "        if prediction == int(row[1]):\n",
        "          accurate_preds += 1\n",
        "      count += 1\n",
        "      if count == 50000:\n",
        "        break\n",
        "    print(accurate_preds/count)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xCB_PtQclqmn",
        "outputId": "fa772a92-f37e-4185-e9e2-7d9b0c07b80e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0\n",
            "100\n",
            "200\n",
            "300\n",
            "400\n",
            "500\n",
            "600\n",
            "700\n",
            "800\n",
            "900\n",
            "1000\n",
            "1100\n",
            "1200\n",
            "1300\n",
            "1400\n",
            "1500\n",
            "1600\n",
            "1700\n",
            "1800\n",
            "1900\n",
            "2000\n",
            "2100\n",
            "2200\n",
            "2300\n",
            "2400\n",
            "2500\n",
            "2600\n",
            "2700\n",
            "2800\n",
            "2900\n",
            "3000\n",
            "3100\n",
            "3200\n",
            "3300\n",
            "3400\n",
            "3500\n",
            "3600\n",
            "3700\n",
            "3800\n",
            "3900\n",
            "4000\n",
            "4100\n",
            "4200\n",
            "4300\n",
            "4400\n",
            "4500\n",
            "4600\n",
            "4700\n",
            "4800\n",
            "4900\n",
            "5000\n",
            "5100\n",
            "5200\n",
            "5300\n",
            "5400\n",
            "5500\n",
            "5600\n",
            "5700\n",
            "5800\n",
            "5900\n",
            "6000\n",
            "6100\n",
            "6200\n",
            "6300\n",
            "6400\n",
            "6500\n",
            "6600\n",
            "6700\n",
            "6800\n",
            "6900\n",
            "7000\n",
            "7100\n",
            "7200\n",
            "7300\n",
            "7400\n",
            "7500\n",
            "7600\n",
            "7700\n",
            "7800\n",
            "7900\n",
            "8000\n",
            "8100\n",
            "8200\n",
            "8300\n",
            "8400\n",
            "8500\n",
            "8600\n",
            "8700\n",
            "8800\n",
            "8900\n",
            "9000\n",
            "9100\n",
            "9200\n",
            "9300\n",
            "9400\n",
            "9500\n",
            "9600\n",
            "9700\n",
            "9800\n",
            "9900\n",
            "10000\n",
            "10100\n",
            "10200\n",
            "10300\n",
            "10400\n",
            "10500\n",
            "10600\n",
            "10700\n",
            "10800\n",
            "10900\n",
            "11000\n",
            "11100\n",
            "11200\n",
            "11300\n",
            "11400\n",
            "11500\n",
            "11600\n",
            "11700\n",
            "11800\n",
            "11900\n",
            "12000\n",
            "12100\n",
            "12200\n",
            "12300\n",
            "12400\n",
            "12500\n",
            "12600\n",
            "12700\n",
            "12800\n",
            "12900\n",
            "13000\n",
            "13100\n",
            "13200\n",
            "13300\n",
            "13400\n",
            "13500\n",
            "13600\n",
            "13700\n",
            "13800\n",
            "13900\n",
            "14000\n",
            "14100\n",
            "14200\n",
            "14300\n",
            "14400\n",
            "14500\n",
            "14600\n",
            "14700\n",
            "14800\n",
            "14900\n",
            "15000\n",
            "15100\n",
            "15200\n",
            "15300\n",
            "15400\n",
            "15500\n",
            "15600\n",
            "15700\n",
            "15800\n",
            "15900\n",
            "16000\n",
            "16100\n",
            "16200\n",
            "16300\n",
            "16400\n",
            "16500\n",
            "16600\n",
            "16700\n",
            "16800\n",
            "16900\n",
            "17000\n",
            "17100\n",
            "17200\n",
            "17300\n",
            "17400\n",
            "17500\n",
            "17600\n",
            "17700\n",
            "17800\n",
            "17900\n",
            "18000\n",
            "18100\n",
            "18200\n",
            "18300\n",
            "18400\n",
            "18500\n",
            "18600\n",
            "18700\n",
            "18800\n",
            "18900\n",
            "19000\n",
            "19100\n",
            "19200\n",
            "19300\n",
            "19400\n",
            "19500\n",
            "19600\n",
            "19700\n",
            "19800\n",
            "19900\n",
            "20000\n",
            "20100\n",
            "20200\n",
            "20300\n",
            "20400\n",
            "20500\n",
            "20600\n",
            "20700\n",
            "20800\n",
            "20900\n",
            "21000\n",
            "21100\n",
            "21200\n",
            "21300\n",
            "21400\n",
            "21500\n",
            "21600\n",
            "21700\n",
            "21800\n",
            "21900\n",
            "22000\n",
            "22100\n",
            "22200\n",
            "22300\n",
            "22400\n",
            "22500\n",
            "22600\n",
            "22700\n",
            "22800\n",
            "22900\n",
            "23000\n",
            "23100\n",
            "23200\n",
            "23300\n",
            "23400\n",
            "23500\n",
            "23600\n",
            "23700\n",
            "23800\n",
            "23900\n",
            "24000\n",
            "24100\n",
            "24200\n",
            "24300\n",
            "24400\n",
            "24500\n",
            "24600\n",
            "24700\n",
            "24800\n",
            "24900\n",
            "25000\n",
            "25100\n",
            "25200\n",
            "25300\n",
            "25400\n",
            "25500\n",
            "25600\n",
            "25700\n",
            "25800\n",
            "25900\n",
            "26000\n",
            "26100\n",
            "26200\n",
            "26300\n",
            "26400\n",
            "26500\n",
            "26600\n",
            "26700\n",
            "26800\n",
            "26900\n",
            "27000\n",
            "27100\n",
            "27200\n",
            "27300\n",
            "27400\n",
            "27500\n",
            "27600\n",
            "27700\n",
            "27800\n",
            "27900\n",
            "28000\n",
            "28100\n",
            "28200\n",
            "28300\n",
            "28400\n",
            "28500\n",
            "28600\n",
            "28700\n",
            "28800\n",
            "28900\n",
            "29000\n",
            "29100\n",
            "29200\n",
            "29300\n",
            "29400\n",
            "29500\n",
            "29600\n",
            "29700\n",
            "29800\n",
            "29900\n",
            "30000\n",
            "30100\n",
            "30200\n",
            "30300\n",
            "30400\n",
            "30500\n",
            "30600\n",
            "30700\n",
            "30800\n",
            "30900\n",
            "31000\n",
            "31100\n",
            "31200\n",
            "31300\n",
            "31400\n",
            "31500\n",
            "31600\n",
            "31700\n",
            "31800\n",
            "31900\n",
            "32000\n",
            "32100\n",
            "32200\n",
            "32300\n",
            "32400\n",
            "32500\n",
            "32600\n",
            "32700\n",
            "32800\n",
            "32900\n",
            "33000\n",
            "33100\n",
            "33200\n",
            "33300\n",
            "33400\n",
            "33500\n",
            "33600\n",
            "33700\n",
            "33800\n",
            "33900\n",
            "34000\n",
            "34100\n",
            "34200\n",
            "34300\n",
            "34400\n",
            "34500\n",
            "34600\n",
            "34700\n",
            "34800\n",
            "34900\n",
            "35000\n",
            "35100\n",
            "35200\n",
            "35300\n",
            "35400\n",
            "35500\n",
            "35600\n",
            "35700\n",
            "35800\n",
            "35900\n",
            "36000\n",
            "36100\n",
            "36200\n",
            "36300\n",
            "36400\n",
            "36500\n",
            "36600\n",
            "36700\n",
            "36800\n",
            "36900\n",
            "37000\n",
            "37100\n",
            "37200\n",
            "37300\n",
            "37400\n",
            "37500\n",
            "37600\n",
            "37700\n",
            "37800\n",
            "37900\n",
            "38000\n",
            "38100\n",
            "38200\n",
            "38300\n",
            "38400\n",
            "38500\n",
            "38600\n",
            "38700\n",
            "38800\n",
            "38900\n",
            "39000\n",
            "39100\n",
            "39200\n",
            "39300\n",
            "39400\n",
            "39500\n",
            "39600\n",
            "39700\n",
            "39800\n",
            "39900\n",
            "40000\n",
            "40100\n",
            "40200\n",
            "40300\n",
            "40400\n",
            "40500\n",
            "40600\n",
            "40700\n",
            "40800\n",
            "40900\n",
            "41000\n",
            "41100\n",
            "41200\n",
            "41300\n",
            "41400\n",
            "41500\n",
            "41600\n",
            "41700\n",
            "41800\n",
            "41900\n",
            "42000\n",
            "42100\n",
            "42200\n",
            "42300\n",
            "42400\n",
            "42500\n",
            "42600\n",
            "42700\n",
            "42800\n",
            "42900\n",
            "43000\n",
            "43100\n",
            "43200\n",
            "43300\n",
            "43400\n",
            "43500\n",
            "43600\n",
            "43700\n",
            "43800\n",
            "43900\n",
            "44000\n",
            "44100\n",
            "44200\n",
            "44300\n",
            "44400\n",
            "44500\n",
            "44600\n",
            "44700\n",
            "44800\n",
            "44900\n",
            "45000\n",
            "45100\n",
            "45200\n",
            "45300\n",
            "45400\n",
            "45500\n",
            "45600\n",
            "45700\n",
            "45800\n",
            "45900\n",
            "46000\n",
            "46100\n",
            "46200\n",
            "46300\n",
            "46400\n",
            "46500\n",
            "46600\n",
            "46700\n",
            "46800\n",
            "46900\n",
            "47000\n",
            "47100\n",
            "47200\n",
            "47300\n",
            "47400\n",
            "47500\n",
            "47600\n",
            "47700\n",
            "47800\n",
            "47900\n",
            "48000\n",
            "48100\n",
            "48200\n",
            "48300\n",
            "48400\n",
            "48500\n",
            "48600\n",
            "48700\n",
            "48800\n",
            "48900\n",
            "49000\n",
            "49100\n",
            "49200\n",
            "49300\n",
            "49400\n",
            "49500\n",
            "49600\n",
            "49700\n",
            "49800\n",
            "49900\n",
            "0.03776\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "7pY1E0AHSufy"
      },
      "source": [
        "### Train/Test Splits (Unseen case)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "HW8q0FldSwCu"
      },
      "outputs": [],
      "source": [
        "adj_list_for_overlapping_nodes = {}\n",
        "for i in range(len(overlap_entity_ids)):\n",
        "  adj_list_for_overlapping_nodes[overlap_entity_ids[i]] = []\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id_original.txt\") as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split(\"\\t\")\n",
        "    if len(row) == 3:\n",
        "      if int(row[0]) in overlap_entity_ids and int(row[2]) in overlap_entity_ids:\n",
        "        adj_list_for_overlapping_nodes[int(row[0])].append((int(row[2]), int(row[1])))\n",
        "        adj_list_for_overlapping_nodes[int(row[2])].append((int(row[0]), int(row[1])))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "4gW8IlB5dZ4v"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/adj_list_for_overlapping_nodes.pkl\", \"wb\") as file:\n",
        "  pickle.dump(adj_list_for_overlapping_nodes, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "eGOVgcc9MpHQ"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/adj_list_for_overlapping_nodes.pkl\", \"rb\") as file:\n",
        "  adj_list_for_overlapping_nodes = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "cLtTXMbZe_vm"
      },
      "outputs": [],
      "source": [
        "training_nodes_adj = {}\n",
        "val_nodes_adj = {}\n",
        "test_nodes_adj = {}\n",
        "train_idx = []\n",
        "val_idx = []\n",
        "test_idx = []\n",
        "count = 0\n",
        "for key, value in adj_list_for_overlapping_nodes.items():\n",
        "  if count % 10 == 0:\n",
        "    test_nodes_adj[key] = value\n",
        "    test_idx.append(count)\n",
        "  elif count % 10 == 1:\n",
        "    val_nodes_adj[key] = value\n",
        "    val_idx.append(count)\n",
        "  else:\n",
        "    training_nodes_adj[key] = value\n",
        "    train_idx.append(count)\n",
        "  count += 1"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-mb_fU5JiWJl"
      },
      "outputs": [],
      "source": [
        "for key in training_nodes_adj.keys():\n",
        "  for i in range(len(training_nodes_adj[key])-1, -1, -1):\n",
        "    if training_nodes_adj[key][i][0] not in training_nodes_adj.keys():\n",
        "      del training_nodes_adj[key][i]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "b2RYiwbKZL75"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/test_file_4.txt\", 'w') as file:\n",
        "  for key in test_nodes_adj.keys():\n",
        "    for val in test_nodes_adj[key]:\n",
        "      file.write(str(key) + \"\\t\" + str(val[1]) + \"\\t\" + str(val[0]) + \"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "z_LR8E9vZYA9",
        "outputId": "c6cd6f46-1534-454f-8c48-18796bc1afbb"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "18334 /content/test_file_4.txt\n"
          ]
        }
      ],
      "source": [
        "!wc -l \"/content/test_file_4.txt\""
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "BnnpivWgm16W"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id_zeroshotnodes.txt\", \"w\") as file:\n",
        "  file.write(str(len(training_nodes_adj)) + \"\\n\")\n",
        "  for key, value in training_nodes_adj.items():\n",
        "    for val in value:\n",
        "      file.write(str(key) + \"\\t\" + str(val[1]) + \"\\t\" + str(val[0]) + \"\\n\")\n",
        "  file.close()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "pJjonILrOMRG"
      },
      "outputs": [],
      "source": [
        "!wc -l /content/drive/MyDrive/Colab\\ Notebooks/CSIRE\\ Project\\ 2/AutoSF/KG_Data/DrugBank/train2id_zeroshotnodes.txt"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "BQ88eLFF3Kx_"
      },
      "source": [
        "## EHR Baseline & KD"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "AnV0zDo1dDCv"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "\n",
        "with open(\"/content/test_file_4.txt\", 'w') as file:\n",
        "  for i in Ze_overlap:\n",
        "    file.write(str(i/(torch.norm(i))) + \"\\n\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "vqtLp-PJ3O3c"
      },
      "source": [
        "### Normalization (Useless)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5-VvYf--SEMP"
      },
      "outputs": [],
      "source": [
        "def normalize(torch_vector):\n",
        "  return torch_vector / torch.norm(torch_vector)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Qpzx1AlX2eFC"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/test_file_3.txt\", \"w\") as file:\n",
        "  file.write(str(len(training_nodes_adj)) + \"\\n\")\n",
        "  for key, value in training_nodes_adj.items():\n",
        "    for val in value:\n",
        "      file.write(str(key) + \"\\t\" + str(val[1]) + \"\\t\" + str(val[0]) + \"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "RAFsLBdc91s9"
      },
      "outputs": [],
      "source": [
        "!wc -l /content/test_file_3.txt"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "zL0Fc3l9nxGG"
      },
      "source": [
        "### EHR MLP Baseline"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "1t1gozYstm9J"
      },
      "outputs": [],
      "source": [
        "max(overlap_entity_ids)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "aV0GZaSv0Jsn"
      },
      "outputs": [],
      "source": [
        "test_nodes_adj = {}\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id_original.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split(\" \")\n",
        "    if len(row) == 3:\n",
        "      if int(row[0]) in overlap_entity_ids and int(row[2]) in overlap_entity_ids:\n",
        "        if int(row[0]) not in test_nodes_adj.keys():\n",
        "          test_nodes_adj[int(row[0])] = []\n",
        "        test_nodes_adj[int(row[0])].append((int(row[2]), int(row[1])))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "iQBpv4Ko2atg"
      },
      "outputs": [],
      "source": [
        "training_nodes_adj = {}\n",
        "for i in edge_list:\n",
        "  if i[0] not in training_nodes_adj.keys():\n",
        "    training_nodes_adj[i[0]] = []\n",
        "  training_nodes_adj[i[0]].append((i[1], i[2]))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "IfDW0qKh5Kf5"
      },
      "outputs": [],
      "source": [
        "training_nodes_adj = {}\n",
        "\n",
        "with open(\"/content/test_file_4.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split(\"\\t\")\n",
        "    if len(row) == 3:\n",
        "      if int(row[0]) not in training_nodes_adj.keys():\n",
        "        training_nodes_adj[int(row[0])] = []\n",
        "      training_nodes_adj[int(row[0])].append((int(row[2]), int(row[1])))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "_aZ5DZNUoEak",
        "outputId": "beb58e73-a4e2-4b26-df65-224e11493d7c"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Failed\n",
            "Traceback (most recent call last):\n",
            "  File \"/tmp/ipython-input-937821953.py\", line 9, in <cell line: 0>\n",
            "    concatenated_embeddings_for_classifer.append((torch.cat((Ze_overlap[bisect.bisect(overlap_entity_ids, key)], Ze_overlap[bisect.bisect(overlap_entity_ids, val[0])])), val[1]))\n",
            "                                                             ~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "IndexError: index 1238 is out of bounds for dimension 0 with size 1238\n",
            "\n",
            "Failed\n",
            "Traceback (most recent call last):\n",
            "  File \"/tmp/ipython-input-937821953.py\", line 9, in <cell line: 0>\n",
            "    concatenated_embeddings_for_classifer.append((torch.cat((Ze_overlap[bisect.bisect(overlap_entity_ids, key)], Ze_overlap[bisect.bisect(overlap_entity_ids, val[0])])), val[1]))\n",
            "                                                             ~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "IndexError: index 1238 is out of bounds for dimension 0 with size 1238\n",
            "\n",
            "Failed\n",
            "Traceback (most recent call last):\n",
            "  File \"/tmp/ipython-input-937821953.py\", line 9, in <cell line: 0>\n",
            "    concatenated_embeddings_for_classifer.append((torch.cat((Ze_overlap[bisect.bisect(overlap_entity_ids, key)], Ze_overlap[bisect.bisect(overlap_entity_ids, val[0])])), val[1]))\n",
            "                                                             ~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "IndexError: index 1238 is out of bounds for dimension 0 with size 1238\n",
            "\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "import bisect\n",
        "import traceback\n",
        "\n",
        "concatenated_embeddings_for_classifer = []\n",
        "for key in training_nodes_adj.keys():\n",
        "  for val in training_nodes_adj[key]:\n",
        "    try:\n",
        "      concatenated_embeddings_for_classifer.append((torch.cat((Ze_overlap[bisect.bisect(overlap_entity_ids, key)], Ze_overlap[bisect.bisect(overlap_entity_ids, val[0])])), val[1]))\n",
        "      concatenated_embeddings_for_classifer.append((torch.cat((Ze_overlap[bisect.bisect(overlap_entity_ids, val[0])], Ze_overlap[bisect.bisect(overlap_entity_ids, key)])), val[1]))\n",
        "    except:\n",
        "      print(\"Failed\")\n",
        "      print(traceback.format_exc())"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 176
        },
        "id": "LnLaXMKrWu9C",
        "outputId": "cdfa0790-10fd-46ed-9b86-458856fdf167"
      },
      "outputs": [
        {
          "ename": "NameError",
          "evalue": "name 'X' is not defined",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-86379361.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/X_ehr.pkl\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"wb\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m   \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdump\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m: name 'X' is not defined"
          ]
        }
      ],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/X_ehr.pkl\", \"wb\") as file:\n",
        "  pickle.dump(X, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "PvXYeMTxW1u6"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/y_ehr.pkl\", \"wb\") as file:\n",
        "  pickle.dump(y, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "SFz_BuIzW_F9",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 180
        },
        "outputId": "cf33fa76-a84a-4810-a78a-6d7093098d38"
      },
      "outputs": [
        {
          "output_type": "error",
          "ename": "EOFError",
          "evalue": "Ran out of input",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mEOFError\u001b[0m                                  Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-483214664.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/X_ehr.pkl\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"rb\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m   \u001b[0mX\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfile\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
            "\u001b[0;31mEOFError\u001b[0m: Ran out of input"
          ]
        }
      ],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/X_ehr.pkl\", \"rb\") as file:\n",
        "  X = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "DzpjWr_RXAoS"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/y_ehr.pkl\", \"rb\") as file:\n",
        "  y = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EHOe3ib-nGwM"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "\n",
        "X = torch.stack(list(map(lambda x : x[0], concatenated_embeddings_for_classifer)))\n",
        "y = torch.from_numpy(np.array(list(map(lambda x : x[1], concatenated_embeddings_for_classifer))))"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "len(X)"
      ],
      "metadata": {
        "id": "UKw9ssY4GZVQ",
        "outputId": "c65dc9f7-519f-4cb1-ab5f-085a759b412e",
        "colab": {
          "base_uri": "https://localhost:8080/"
        }
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "224012"
            ]
          },
          "metadata": {},
          "execution_count": 12
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 153
        },
        "id": "Kom9wZ0gv-pt",
        "outputId": "96fd410a-3ca4-4a1f-9080-42b86b90a355"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.12/dist-packages/sklearn/neural_network/_multilayer_perceptron.py:691: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (15) reached and the optimization hasn't converged yet.\n",
            "  warnings.warn(\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=0)"
            ],
            "text/html": [
              "<style>#sk-container-id-2 {\n",
              "  /* Definition of color scheme common for light and dark mode */\n",
              "  --sklearn-color-text: #000;\n",
              "  --sklearn-color-text-muted: #666;\n",
              "  --sklearn-color-line: gray;\n",
              "  /* Definition of color scheme for unfitted estimators */\n",
              "  --sklearn-color-unfitted-level-0: #fff5e6;\n",
              "  --sklearn-color-unfitted-level-1: #f6e4d2;\n",
              "  --sklearn-color-unfitted-level-2: #ffe0b3;\n",
              "  --sklearn-color-unfitted-level-3: chocolate;\n",
              "  /* Definition of color scheme for fitted estimators */\n",
              "  --sklearn-color-fitted-level-0: #f0f8ff;\n",
              "  --sklearn-color-fitted-level-1: #d4ebff;\n",
              "  --sklearn-color-fitted-level-2: #b3dbfd;\n",
              "  --sklearn-color-fitted-level-3: cornflowerblue;\n",
              "\n",
              "  /* Specific color for light theme */\n",
              "  --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
              "  --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
              "  --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
              "  --sklearn-color-icon: #696969;\n",
              "\n",
              "  @media (prefers-color-scheme: dark) {\n",
              "    /* Redefinition of color scheme for dark theme */\n",
              "    --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
              "    --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
              "    --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
              "    --sklearn-color-icon: #878787;\n",
              "  }\n",
              "}\n",
              "\n",
              "#sk-container-id-2 {\n",
              "  color: var(--sklearn-color-text);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 pre {\n",
              "  padding: 0;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 input.sk-hidden--visually {\n",
              "  border: 0;\n",
              "  clip: rect(1px 1px 1px 1px);\n",
              "  clip: rect(1px, 1px, 1px, 1px);\n",
              "  height: 1px;\n",
              "  margin: -1px;\n",
              "  overflow: hidden;\n",
              "  padding: 0;\n",
              "  position: absolute;\n",
              "  width: 1px;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-dashed-wrapped {\n",
              "  border: 1px dashed var(--sklearn-color-line);\n",
              "  margin: 0 0.4em 0.5em 0.4em;\n",
              "  box-sizing: border-box;\n",
              "  padding-bottom: 0.4em;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-container {\n",
              "  /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
              "     but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
              "     so we also need the `!important` here to be able to override the\n",
              "     default hidden behavior on the sphinx rendered scikit-learn.org.\n",
              "     See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
              "  display: inline-block !important;\n",
              "  position: relative;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-text-repr-fallback {\n",
              "  display: none;\n",
              "}\n",
              "\n",
              "div.sk-parallel-item,\n",
              "div.sk-serial,\n",
              "div.sk-item {\n",
              "  /* draw centered vertical line to link estimators */\n",
              "  background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
              "  background-size: 2px 100%;\n",
              "  background-repeat: no-repeat;\n",
              "  background-position: center center;\n",
              "}\n",
              "\n",
              "/* Parallel-specific style estimator block */\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel-item::after {\n",
              "  content: \"\";\n",
              "  width: 100%;\n",
              "  border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
              "  flex-grow: 1;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel {\n",
              "  display: flex;\n",
              "  align-items: stretch;\n",
              "  justify-content: center;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  position: relative;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel-item {\n",
              "  display: flex;\n",
              "  flex-direction: column;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel-item:first-child::after {\n",
              "  align-self: flex-end;\n",
              "  width: 50%;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel-item:last-child::after {\n",
              "  align-self: flex-start;\n",
              "  width: 50%;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-parallel-item:only-child::after {\n",
              "  width: 0;\n",
              "}\n",
              "\n",
              "/* Serial-specific style estimator block */\n",
              "\n",
              "#sk-container-id-2 div.sk-serial {\n",
              "  display: flex;\n",
              "  flex-direction: column;\n",
              "  align-items: center;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  padding-right: 1em;\n",
              "  padding-left: 1em;\n",
              "}\n",
              "\n",
              "\n",
              "/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
              "clickable and can be expanded/collapsed.\n",
              "- Pipeline and ColumnTransformer use this feature and define the default style\n",
              "- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
              "*/\n",
              "\n",
              "/* Pipeline and ColumnTransformer style (default) */\n",
              "\n",
              "#sk-container-id-2 div.sk-toggleable {\n",
              "  /* Default theme specific background. It is overwritten whether we have a\n",
              "  specific estimator or a Pipeline/ColumnTransformer */\n",
              "  background-color: var(--sklearn-color-background);\n",
              "}\n",
              "\n",
              "/* Toggleable label */\n",
              "#sk-container-id-2 label.sk-toggleable__label {\n",
              "  cursor: pointer;\n",
              "  display: flex;\n",
              "  width: 100%;\n",
              "  margin-bottom: 0;\n",
              "  padding: 0.5em;\n",
              "  box-sizing: border-box;\n",
              "  text-align: center;\n",
              "  align-items: start;\n",
              "  justify-content: space-between;\n",
              "  gap: 0.5em;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 label.sk-toggleable__label .caption {\n",
              "  font-size: 0.6rem;\n",
              "  font-weight: lighter;\n",
              "  color: var(--sklearn-color-text-muted);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 label.sk-toggleable__label-arrow:before {\n",
              "  /* Arrow on the left of the label */\n",
              "  content: \"▸\";\n",
              "  float: left;\n",
              "  margin-right: 0.25em;\n",
              "  color: var(--sklearn-color-icon);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 label.sk-toggleable__label-arrow:hover:before {\n",
              "  color: var(--sklearn-color-text);\n",
              "}\n",
              "\n",
              "/* Toggleable content - dropdown */\n",
              "\n",
              "#sk-container-id-2 div.sk-toggleable__content {\n",
              "  max-height: 0;\n",
              "  max-width: 0;\n",
              "  overflow: hidden;\n",
              "  text-align: left;\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-toggleable__content.fitted {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-toggleable__content pre {\n",
              "  margin: 0.2em;\n",
              "  border-radius: 0.25em;\n",
              "  color: var(--sklearn-color-text);\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-toggleable__content.fitted pre {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
              "  /* Expand drop-down */\n",
              "  max-height: 200px;\n",
              "  max-width: 100%;\n",
              "  overflow: auto;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
              "  content: \"▾\";\n",
              "}\n",
              "\n",
              "/* Pipeline/ColumnTransformer-specific style */\n",
              "\n",
              "#sk-container-id-2 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Estimator-specific style */\n",
              "\n",
              "/* Colorize estimator box */\n",
              "#sk-container-id-2 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-label label.sk-toggleable__label,\n",
              "#sk-container-id-2 div.sk-label label {\n",
              "  /* The background is the default theme color */\n",
              "  color: var(--sklearn-color-text-on-default-background);\n",
              "}\n",
              "\n",
              "/* On hover, darken the color of the background */\n",
              "#sk-container-id-2 div.sk-label:hover label.sk-toggleable__label {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "/* Label box, darken color on hover, fitted */\n",
              "#sk-container-id-2 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Estimator label */\n",
              "\n",
              "#sk-container-id-2 div.sk-label label {\n",
              "  font-family: monospace;\n",
              "  font-weight: bold;\n",
              "  display: inline-block;\n",
              "  line-height: 1.2em;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-label-container {\n",
              "  text-align: center;\n",
              "}\n",
              "\n",
              "/* Estimator-specific */\n",
              "#sk-container-id-2 div.sk-estimator {\n",
              "  font-family: monospace;\n",
              "  border: 1px dotted var(--sklearn-color-border-box);\n",
              "  border-radius: 0.25em;\n",
              "  box-sizing: border-box;\n",
              "  margin-bottom: 0.5em;\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-estimator.fitted {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "/* on hover */\n",
              "#sk-container-id-2 div.sk-estimator:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-2 div.sk-estimator.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
              "\n",
              "/* Common style for \"i\" and \"?\" */\n",
              "\n",
              ".sk-estimator-doc-link,\n",
              "a:link.sk-estimator-doc-link,\n",
              "a:visited.sk-estimator-doc-link {\n",
              "  float: right;\n",
              "  font-size: smaller;\n",
              "  line-height: 1em;\n",
              "  font-family: monospace;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  border-radius: 1em;\n",
              "  height: 1em;\n",
              "  width: 1em;\n",
              "  text-decoration: none !important;\n",
              "  margin-left: 0.5em;\n",
              "  text-align: center;\n",
              "  /* unfitted */\n",
              "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-unfitted-level-1);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link.fitted,\n",
              "a:link.sk-estimator-doc-link.fitted,\n",
              "a:visited.sk-estimator-doc-link.fitted {\n",
              "  /* fitted */\n",
              "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-fitted-level-1);\n",
              "}\n",
              "\n",
              "/* On hover */\n",
              "div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
              ".sk-estimator-doc-link:hover,\n",
              "div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
              ".sk-estimator-doc-link:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
              ".sk-estimator-doc-link.fitted:hover,\n",
              "div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
              ".sk-estimator-doc-link.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "/* Span, style for the box shown on hovering the info icon */\n",
              ".sk-estimator-doc-link span {\n",
              "  display: none;\n",
              "  z-index: 9999;\n",
              "  position: relative;\n",
              "  font-weight: normal;\n",
              "  right: .2ex;\n",
              "  padding: .5ex;\n",
              "  margin: .5ex;\n",
              "  width: min-content;\n",
              "  min-width: 20ex;\n",
              "  max-width: 50ex;\n",
              "  color: var(--sklearn-color-text);\n",
              "  box-shadow: 2pt 2pt 4pt #999;\n",
              "  /* unfitted */\n",
              "  background: var(--sklearn-color-unfitted-level-0);\n",
              "  border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link.fitted span {\n",
              "  /* fitted */\n",
              "  background: var(--sklearn-color-fitted-level-0);\n",
              "  border: var(--sklearn-color-fitted-level-3);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link:hover span {\n",
              "  display: block;\n",
              "}\n",
              "\n",
              "/* \"?\"-specific style due to the `<a>` HTML tag */\n",
              "\n",
              "#sk-container-id-2 a.estimator_doc_link {\n",
              "  float: right;\n",
              "  font-size: 1rem;\n",
              "  line-height: 1em;\n",
              "  font-family: monospace;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  border-radius: 1rem;\n",
              "  height: 1rem;\n",
              "  width: 1rem;\n",
              "  text-decoration: none;\n",
              "  /* unfitted */\n",
              "  color: var(--sklearn-color-unfitted-level-1);\n",
              "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 a.estimator_doc_link.fitted {\n",
              "  /* fitted */\n",
              "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-fitted-level-1);\n",
              "}\n",
              "\n",
              "/* On hover */\n",
              "#sk-container-id-2 a.estimator_doc_link:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "#sk-container-id-2 a.estimator_doc_link.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-3);\n",
              "}\n",
              "</style><div id=\"sk-container-id-2\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=0)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-2\" type=\"checkbox\" checked><label for=\"sk-estimator-id-2\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow\"><div><div>MLPClassifier</div></div><div><a class=\"sk-estimator-doc-link fitted\" rel=\"noreferrer\" target=\"_blank\" href=\"https://scikit-learn.org/1.6/modules/generated/sklearn.neural_network.MLPClassifier.html\">?<span>Documentation for MLPClassifier</span></a><span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></div></label><div class=\"sk-toggleable__content fitted\"><pre>MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=0)</pre></div> </div></div></div></div>"
            ]
          },
          "metadata": {},
          "execution_count": 66
        }
      ],
      "source": [
        "from sklearn.neural_network import MLPClassifier\n",
        "import torch\n",
        "import numpy as np\n",
        "\n",
        "clf = MLPClassifier(solver='adam', alpha=0.10,\n",
        "                    hidden_layer_sizes=(32, 16, 8, 4, 2), random_state=0, max_iter=15)\n",
        "clf.fit(X, y)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "493VT5JjK7KL"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/clf_ehr_negatives.pkl\", \"wb\") as file:\n",
        "  pickle.dump(clf, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "OGLtcrEmRKKL"
      },
      "outputs": [],
      "source": [
        "relations_in_training = set()\n",
        "for key in training_nodes_adj.keys():\n",
        "  for val in training_nodes_adj[key]:\n",
        "    relations_in_training.add(val[1])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "BG6I4o3mRSCU"
      },
      "outputs": [],
      "source": [
        "relations_in_training = sorted(list(relations_in_training))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "3n4WM9GKNZ3o"
      },
      "outputs": [],
      "source": [
        "def predict_logits(clf, h, t, n_rel_expected=86):\n",
        "    # feature vector from the two drugs\n",
        "    vec = torch.cat((\n",
        "        Ze_overlap[bisect.bisect(overlap_entity_ids, h)],\n",
        "        Ze_overlap[bisect.bisect(overlap_entity_ids, t)]\n",
        "    ))\n",
        "\n",
        "    # sklearn wants (1, d) numpy\n",
        "    probs_small = clf.predict_proba([vec.numpy().ravel()])[0]  # shape (77,)\n",
        "\n",
        "    # expand into full 86-dim, default zero\n",
        "    probs_full = np.zeros(n_rel_expected, dtype=np.float32)\n",
        "    for idx, rel_id in enumerate(relations_in_training):\n",
        "        probs_full[rel_id] = probs_small[idx]\n",
        "\n",
        "    # return as torch tensor so .detach() works later\n",
        "    return torch.from_numpy(probs_full).float()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "QSbPYfLjUAm1"
      },
      "outputs": [],
      "source": [
        "import bisect\n",
        "with open(\"/content/test_file_6.txt\", 'r') as file:\n",
        "  with open(\"/content/test_file_5.txt\", 'w') as file2:\n",
        "    accurate_preds = 0\n",
        "    count = 0\n",
        "    for line in file:\n",
        "      row = line.strip().split(\"\\t\")\n",
        "      if len(row) < 3:\n",
        "        continue\n",
        "      row[0] = int(row[0]); row[1] = int(row[1]); row[2] = int(row[2])\n",
        "\n",
        "      i = bisect.bisect_left(overlap_entity_ids, row[0])\n",
        "      j = bisect.bisect_left(overlap_entity_ids, row[2])\n",
        "      # (optional safety) skip if not found\n",
        "      if i >= len(overlap_entity_ids) or i < 0:\n",
        "        continue\n",
        "      if j >= len(overlap_entity_ids) or j < 0:\n",
        "        continue\n",
        "\n",
        "      x = torch.cat((Ze_overlap[i], Ze_overlap[j]), dim=0).detach().cpu().numpy().reshape(1, -1)\n",
        "      prediction = clf.predict(x)[0]\n",
        "      if row[1] == prediction:\n",
        "        accurate_preds += 1\n",
        "      count += 1\n",
        "      file2.write(f\"{prediction}\\t{row[1]}\\n\")\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "accurate_preds/count"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "7NQQmDfivemw",
        "outputId": "d8cd5632-7905-4199-b9ed-e18010806214"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.27364459474200936"
            ]
          },
          "metadata": {},
          "execution_count": 50
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9eWXK9geCwjG"
      },
      "source": [
        "Accuracy for raw concatenation of EHR records: $0.6036871386495036$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "28GE7VWmD_-n"
      },
      "source": [
        "### Knowledge Distillation"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "i9Ia4Cf7Lw-4"
      },
      "outputs": [],
      "source": [
        "from copy import deepcopy\n",
        "\n",
        "teacher = deepcopy(model)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "oi7HORwx7b7d"
      },
      "outputs": [],
      "source": [
        "from copy import deepcopy\n",
        "\n",
        "N_train = deepcopy(overlap_entity_ids)\n",
        "E_train_teacher = []\n",
        "for node in all_known_edges:\n",
        "  for edge in all_known_edges[node]:\n",
        "    E_train_teacher.append((node, edge[0], edge[1]))\n",
        "E_train_KD = []\n",
        "for node in all_known_edges:\n",
        "  for edge in all_known_edges[node]:\n",
        "    E_train_KD.append((node, edge[0], edge[1]))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "PpsaJmoWa0W0"
      },
      "outputs": [],
      "source": [
        "id_map = {gid: idx for idx, gid in enumerate(overlap_entity_ids)}\n",
        "\n",
        "E_remap = []\n",
        "for (i, j, r) in E_train_KD:\n",
        "    if i in id_map and j in id_map:   # both nodes have overlap embeddings\n",
        "        E_remap.append((id_map[i], id_map[j], r))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "EwdBD0Ij_n-i",
        "outputId": "9bcac704-072e-4087-9ae7-bcf653382067"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Saved /content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/teacher_soft.npy  shape=(259946, 86)  dtype=float32  mode=softmax  tau=3.0\n"
          ]
        }
      ],
      "source": [
        "import numpy as np\n",
        "import torch\n",
        "import torch.nn.functional as F\n",
        "\n",
        "@torch.no_grad()\n",
        "def export_teacher_soft_from_rgcn(\n",
        "    E_train_KD,\n",
        "    encoder,\n",
        "    decoder,\n",
        "    tau: float = 0.5,\n",
        "    batch_size: int = 4096,\n",
        "    out_path: str = \"teacher_soft.npy\",\n",
        "    use_softmax: bool = True,\n",
        "    l2_normalize: bool = True\n",
        "):\n",
        "    dev = next(encoder.parameters()).device\n",
        "\n",
        "    if isinstance(E_train_KD, list):\n",
        "        E_np = np.asarray(E_train_KD, dtype=np.int64)\n",
        "    elif isinstance(E_train_KD, np.ndarray):\n",
        "        E_np = E_train_KD.astype(np.int64, copy=False)\n",
        "    else:\n",
        "        raise TypeError(\"E_train_KD must be list or numpy.ndarray.\")\n",
        "\n",
        "    assert E_np.ndim == 2 and E_np.shape[1] >= 2, \"E_train_KD must have at least two columns (i, j).\"\n",
        "    u_all = torch.from_numpy(E_np[:, 0]).long().to(dev)\n",
        "    v_all = torch.from_numpy(E_np[:, 1]).long().to(dev)\n",
        "\n",
        "    W = decoder.rel.weight.to(dev)\n",
        "    bias = getattr(decoder, \"bias\", None)\n",
        "    if bias is not None:\n",
        "        bias = bias.to(dev)\n",
        "\n",
        "\n",
        "    outs = []\n",
        "    for start in range(0, u_all.numel(), batch_size):\n",
        "        end = min(start + batch_size, u_all.numel())\n",
        "        u = u_all[start:end]\n",
        "        v = v_all[start:end]\n",
        "\n",
        "        logits = (H[u] * H[v]) @ W.t()\n",
        "        if bias is not None:\n",
        "            logits = logits + bias\n",
        "\n",
        "        logits_t = logits / float(tau)\n",
        "\n",
        "        if use_softmax:\n",
        "            soft = torch.softmax(logits_t, dim=-1)\n",
        "        else:\n",
        "            soft = torch.sigmoid(logits_t)\n",
        "\n",
        "        outs.append(soft.float().cpu().numpy())\n",
        "\n",
        "    teacher_soft = np.concatenate(outs, axis=0)\n",
        "    np.save(out_path, teacher_soft)\n",
        "    print(f\"Saved {out_path}  shape={teacher_soft.shape}  dtype={teacher_soft.dtype}  mode={'softmax' if use_softmax else 'sigmoid'}  tau={tau}\")\n",
        "\n",
        "export_teacher_soft_from_rgcn(\n",
        "    E_train_KD=E_train_KD,\n",
        "    encoder=encoder,\n",
        "    decoder=decoder,\n",
        "    tau=3.0,\n",
        "    batch_size=4096,\n",
        "    out_path=\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/teacher_soft.npy\",\n",
        "    use_softmax=True,\n",
        "    l2_normalize=True\n",
        ")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "sgtHvM2HNMe1"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "from torch.utils.data import Dataset, DataLoader"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WgkQXYoXMgst"
      },
      "outputs": [],
      "source": [
        "KD_ALPHA   = 0.25        # 1.0 = KD-only; else blend with hard labels\n",
        "LR         = 0.05\n",
        "WD         = 1e-4\n",
        "BATCH_SIZE = 1024\n",
        "EPOCHS     = 20\n",
        "DEVICE     = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "n_rel      = 86\n",
        "n_dim      = 128"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "SpL2e_5SMWyX"
      },
      "outputs": [],
      "source": [
        "class KDPairDataset(Dataset):\n",
        "    def __init__(self, edges_ijr, teacher_soft, n_rel):\n",
        "        if isinstance(edges_ijr, list):\n",
        "            edges_ijr = np.asarray(edges_ijr, dtype=np.int64)\n",
        "        else:\n",
        "            edges_ijr = edges_ijr.astype(np.int64, copy=False)\n",
        "        assert edges_ijr.ndim == 2 and edges_ijr.shape[1] >= 3, \"E_train_KD needs columns (i,j,r)\"\n",
        "        assert teacher_soft.shape[0] == edges_ijr.shape[0], \"Teacher soft rows must align with edges\"\n",
        "        self.i = torch.from_numpy(edges_ijr[:, 0]).long()\n",
        "        self.j = torch.from_numpy(edges_ijr[:, 1]).long()\n",
        "        rel = torch.from_numpy(edges_ijr[:, 2]).long()\n",
        "        self.y_hard = torch.zeros(edges_ijr.shape[0], n_rel, dtype=torch.float32)\n",
        "        self.y_hard.scatter_(1, rel.view(-1, 1), 1.0)\n",
        "        self.soft = torch.from_numpy(teacher_soft).float()\n",
        "\n",
        "    def __len__(self):\n",
        "        return self.i.size(0)\n",
        "\n",
        "    def __getitem__(self, idx):\n",
        "        return self.i[idx], self.j[idx], self.y_hard[idx], self.soft[idx]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "uok7oOFVusun"
      },
      "outputs": [],
      "source": [
        "class EHREncoder(nn.Module):\n",
        "    def __init__(self, d_in: int, d_out: int):\n",
        "        super().__init__()\n",
        "        hidden = max(2 * d_out, 64)\n",
        "        self.net = nn.Sequential(\n",
        "            nn.Linear(d_in, hidden), nn.ReLU(),\n",
        "            nn.Linear(hidden, d_out)\n",
        "        )\n",
        "    def forward(self, x):\n",
        "        return self.net(x)\n",
        "\n",
        "class StudentDDI(nn.Module):\n",
        "    \"\"\"\n",
        "    EHR-only: entity vectors come from EHR -> MLP; relation params are learned (DistMult).\n",
        "    \"\"\"\n",
        "    def __init__(self, ehr_mat_np: np.ndarray, n_rel: int, d_model: int):\n",
        "        super().__init__()\n",
        "        ehr = deepcopy(ehr_mat_np)\n",
        "        self.register_buffer(\"ehr_table\", ehr)        # [N, d_ehr]\n",
        "        d_ehr = ehr.size(1)\n",
        "        self.encoder = EHREncoder(d_ehr, d_model)\n",
        "        self.rel = nn.Parameter(torch.empty(n_rel, d_model))\n",
        "        nn.init.xavier_uniform_(self.rel)\n",
        "\n",
        "    def entity_vec(self, idx: torch.LongTensor) -> torch.Tensor:\n",
        "        # idx: [B] indices into ehr_table\n",
        "        x = self.ehr_table.index_select(0, idx)  # [B, d_ehr]\n",
        "        return self.encoder(x)                   # [B, d_model]\n",
        "\n",
        "    def pair_all_rel_logits(self, head_idx: torch.LongTensor, tail_idx: torch.LongTensor) -> torch.Tensor:\n",
        "        # DistMult: logits[b, r] = <h_b, rel[r], t_b>\n",
        "        h = self.entity_vec(head_idx)         # [B, d]\n",
        "        t = self.entity_vec(tail_idx)         # [B, d]\n",
        "        ht = h * t                            # [B, d]\n",
        "        return ht @ self.rel.t()              # [B, n_rel]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nWSwqUl4OYTe"
      },
      "outputs": [],
      "source": [
        "teacher_soft = np.load(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/teacher_soft.npy\").astype(np.float32)  # [M, n_rel]\n",
        "teacher_soft = teacher_soft[:len(E_train_KD)]\n",
        "dataset = KDPairDataset(E_train_KD, teacher_soft, n_rel)\n",
        "loader  = DataLoader(dataset, batch_size=BATCH_SIZE, shuffle=True, num_workers=2, pin_memory=True)\n",
        "\n",
        "student = StudentDDI(Ze_overlap, n_rel=n_rel, d_model=n_dim).to(DEVICE)\n",
        "opt = torch.optim.AdamW(student.parameters(), lr=LR, weight_decay=WD)\n",
        "bce = nn.BCEWithLogitsLoss().to(DEVICE)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "HPe83e6MpHC8",
        "outputId": "6413f703-e3c7-4fab-a261-9c0ed4311c41"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 01 | avg_loss: 0.090860\n",
            "Epoch 02 | avg_loss: 0.036149\n",
            "Epoch 03 | avg_loss: 0.034103\n",
            "Epoch 04 | avg_loss: 0.032827\n",
            "Epoch 05 | avg_loss: 0.031968\n",
            "Epoch 06 | avg_loss: 0.031226\n",
            "Epoch 07 | avg_loss: 0.030681\n",
            "Epoch 08 | avg_loss: 0.030313\n",
            "Epoch 09 | avg_loss: 0.029997\n",
            "Epoch 10 | avg_loss: 0.029827\n",
            "Epoch 11 | avg_loss: 0.029624\n",
            "Epoch 12 | avg_loss: 0.029504\n",
            "Epoch 13 | avg_loss: 0.029432\n",
            "Epoch 14 | avg_loss: 0.029387\n",
            "Epoch 15 | avg_loss: 0.029352\n",
            "Epoch 16 | avg_loss: 0.029409\n",
            "Epoch 17 | avg_loss: 0.029365\n",
            "Epoch 18 | avg_loss: 0.029440\n",
            "Epoch 19 | avg_loss: 0.029528\n",
            "Epoch 20 | avg_loss: 0.029591\n",
            "Saved EHR-only student to ehr_student_kd.pt\n"
          ]
        }
      ],
      "source": [
        "student.train()\n",
        "for epoch in range(1, EPOCHS + 1):\n",
        "    total_loss = 0.0\n",
        "    n_rows = 0\n",
        "    for i, j, y_hard, soft in loader:\n",
        "        i = i.to(DEVICE, non_blocking=True)\n",
        "        j = j.to(DEVICE, non_blocking=True)\n",
        "        for idx in range(len(i)):\n",
        "            i[idx] = id_map[int(i[idx])]\n",
        "            j[idx] = id_map[int(j[idx])]\n",
        "        y_hard = y_hard.to(DEVICE, non_blocking=True)\n",
        "        soft = soft.to(DEVICE, non_blocking=True)\n",
        "\n",
        "        logits = student.pair_all_rel_logits(i, j)             # [B, n_rel]\n",
        "\n",
        "        # KD loss\n",
        "        kd_loss = bce(logits, soft)\n",
        "\n",
        "        # Optional hard-label loss\n",
        "        if KD_ALPHA < 1.0:\n",
        "            sup_loss = bce(logits, y_hard)\n",
        "            loss = KD_ALPHA * kd_loss + (1.0 - KD_ALPHA) * sup_loss\n",
        "        else:\n",
        "            loss = kd_loss\n",
        "\n",
        "        opt.zero_grad(set_to_none=True)\n",
        "        loss.backward()\n",
        "        opt.step()\n",
        "\n",
        "        B = i.size(0)\n",
        "        total_loss += float(loss.detach().cpu().item()) * B\n",
        "        n_rows += B\n",
        "\n",
        "    print(f\"Epoch {epoch:02d} | avg_loss: {total_loss / max(1,n_rows):.6f}\")\n",
        "\n",
        "torch.save(student.state_dict(), \"/content/ehr_student_kd.pt\")\n",
        "print(\"Saved EHR-only student to ehr_student_kd.pt\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "22p1LcjPOKak",
        "outputId": "5d2969c3-6196-4f0b-d90f-af81ba85ed8c"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[2.0576541423797607, -1.4354774951934814, -0.16223135590553284, -0.15197069942951202, -0.30289238691329956, -0.7497437596321106, 1.1413613557815552, 1.02946138381958, 0.8776511549949646, 0.5713833570480347, -0.09250792115926743, 1.0882078409194946, -0.829036295413971, 2.032534599304199, 0.012447348795831203, 0.5493384003639221, 0.7873867750167847, -0.95005202293396, -2.5966408252716064, -1.6538047790527344, 0.14694009721279144, 0.2538515031337738, 0.7064500451087952, -0.36923128366470337, -0.19340558350086212, 0.6787843108177185, 0.4392591118812561, 0.2281537652015686, 0.6918613910675049, 1.4514269828796387, -1.8274747133255005, -0.5166667103767395, -0.02412796951830387, -1.5069714784622192, -1.9106755256652832, 1.9873260259628296, -0.6404376029968262, -0.5338441133499146, 1.5921902656555176, -1.6642537117004395, -0.2295731008052826, -0.3342975974082947, -0.9932878017425537, -0.7928875088691711, -0.9178574085235596, -0.05216920003294945, -0.2314065545797348, -0.485929399728775, -0.0523182675242424, 0.24225036799907684, 0.4072132706642151, 0.32725346088409424, -0.0646073967218399, 0.42781248688697815, -1.1444056034088135, -1.2755959033966064, 0.6564868092536926, -1.033706784248352, -0.3497146964073181, 1.4843120574951172, -0.07554914802312851, -0.1736234575510025, 1.1907057762145996, -0.29638832807540894]\n",
            "[-0.41320404410362244, 1.766709327697754, -0.6812893152236938, 0.7441837191581726, 0.044799692928791046, -1.3561187982559204, 1.128935694694519, 0.3809564411640167, -0.5538612008094788, 1.0109144449234009, 0.070091113448143, -1.1909058094024658, -0.44870635867118835, 1.0133765935897827, 1.1208908557891846, -0.6922670602798462, 1.4381376504898071, -0.43591392040252686, -0.2234751582145691, -0.8609446883201599, 0.13858841359615326, 1.2089802026748657, -1.5456207990646362, -0.5278716683387756, -0.4707312285900116, -0.5531529188156128, -0.6327173709869385, -1.8493772745132446, 0.373837411403656, -1.3955159187316895, 0.539884626865387, -0.9045486450195312, -0.04316561296582222, -0.8066638112068176, -2.1609394550323486, -1.057093858718872, 0.13574066758155823, 1.4573593139648438, 0.46034830808639526, 0.9698298573493958, 0.978848397731781, -1.2012499570846558, -0.08791068196296692, -0.34056201577186584, 0.5407024621963501, 1.0901230573654175, -1.0538396835327148, 0.604597270488739, 0.176700159907341, 2.2551510334014893, -0.338238388299942, -1.2120693922042847, 1.3749197721481323, -0.10056309401988983, 0.7647589445114136, -0.5988677740097046, -0.3036361038684845, 1.3682806491851807, 0.17164921760559082, -0.1760922223329544, 1.4463964700698853, 1.1226799488067627, 1.5929551124572754, 1.1961020231246948]\n",
            "[0.2587023079395294, 0.6883691549301147, -1.0316396951675415, 1.3894891738891602, -0.5141952037811279, 1.3764739036560059, 1.5118610858917236, 0.025476733222603798, -0.8212616443634033, 0.9260459542274475, 0.5047594308853149, 0.15467935800552368, 1.2208881378173828, 0.19154660403728485, 1.6516019105911255, 1.075520634651184, -0.5710717439651489, 2.0385689735412598, -0.2699572741985321, 0.8718052506446838, -0.21829724311828613, -0.7485836744308472, -1.1074273586273193, -0.12572696805000305, -0.06242717429995537, 0.6120973825454712, 0.8562218546867371, -0.23461279273033142, 1.3431921005249023, 2.3126494884490967, 0.9760700464248657, -2.4995169639587402, -0.9489167332649231, 1.4215632677078247, -1.9384297132492065, 0.590153694152832, 0.263381689786911, -1.1352516412734985, 0.5784465670585632, 0.6197972893714905, -1.5466326475143433, -0.6537573933601379, -1.02010977268219, -0.9945940375328064, 2.8145508766174316, -0.5104467868804932, 0.2151576578617096, 0.3612920641899109, 0.36120980978012085, -0.15179336071014404, 0.5583518147468567, -0.2503753900527954, 0.6556366086006165, 0.19108973443508148, 1.3921529054641724, 0.13974499702453613, 0.2414538711309433, -0.20762711763381958, 0.836355984210968, -0.37819281220436096, 0.23515541851520538, 0.7311631441116333, -1.0569500923156738, -0.9731191396713257]\n",
            "[-1.3421730995178223, 0.8328289985656738, 2.237138032913208, 0.31139829754829407, 0.8944219946861267, -1.788092017173767, -2.3016889095306396, -1.612817645072937, 0.18355792760849, -0.5357685089111328, 1.081368088722229, 0.744124710559845, -1.2168831825256348, 1.4312561750411987, 1.8587232828140259, 1.3752906322479248, -0.9783753752708435, -0.37395718693733215, 1.8144217729568481, 0.60445636510849, -0.739791750907898, 0.21902939677238464, -0.5728890299797058, 0.5549715757369995, 1.1770983934402466, 0.03964401036500931, 0.7277761101722717, 2.22147536277771, -0.5151239633560181, -0.5273980498313904, -0.8491045236587524, 0.8874552845954895, 0.44538384675979614, 0.29886293411254883, -1.6872988939285278, -0.35109075903892517, -1.7439078092575073, -0.6338149905204773, -0.017255619168281555, 1.881047010421753, 0.38962334394454956, -1.3846063613891602, 1.9196476936340332, -0.012322170659899712, -0.38444164395332336, 0.8521032929420471, -0.23076912760734558, -0.3546045124530792, 1.5592825412750244, -0.523393988609314, 1.5227464437484741, 0.7662736773490906, -0.13584744930267334, -0.9296306371688843, -1.2271758317947388, -0.026404118165373802, 1.2355073690414429, -0.6544882655143738, -1.674729585647583, -0.8177294731140137, -0.239593505859375, 1.9528151750564575, 1.692378282546997, -1.6925687789916992]\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tensor([[-0.8187, -0.9526, -0.2272,  ...,  1.5187, -1.2606, -0.5700],\n",
              "        [-0.6697,  0.2560,  0.6447,  ..., -0.2120,  0.1221,  1.2487],\n",
              "        [-1.7191,  0.3643, -0.4169,  ...,  0.5927, -0.4020,  0.2343],\n",
              "        ...,\n",
              "        [-0.4132,  1.7667, -0.6813,  ...,  1.1227,  1.5930,  1.1961],\n",
              "        [ 0.2587,  0.6884, -1.0316,  ...,  0.7312, -1.0570, -0.9731],\n",
              "        [-1.3422,  0.8328,  2.2371,  ...,  1.9528,  1.6924, -1.6926]])"
            ]
          },
          "metadata": {},
          "execution_count": 41
        }
      ],
      "source": [
        "import torch\n",
        "\n",
        "for embedding in ehr_embeddings_to_test:\n",
        "    print(embedding)\n",
        "    Ze_overlap = torch.cat([Ze_overlap, torch.Tensor(embedding).unsqueeze(0)], dim=0)\n",
        "Ze_overlap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ch5LKGPnyd8X",
        "outputId": "32680c05-75f3-4001-bd03-10a25d0cc304"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "StudentDDI(\n",
              "  (encoder): EHREncoder(\n",
              "    (net): Sequential(\n",
              "      (0): Linear(in_features=64, out_features=256, bias=True)\n",
              "      (1): ReLU()\n",
              "      (2): Linear(in_features=256, out_features=128, bias=True)\n",
              "    )\n",
              "  )\n",
              ")"
            ]
          },
          "metadata": {},
          "execution_count": 42
        }
      ],
      "source": [
        "from copy import deepcopy\n",
        "\n",
        "student = StudentDDI(ehr_mat_np=Ze_overlap, n_rel=n_rel, d_model=128).to(DEVICE)\n",
        "\n",
        "sd = torch.load(\"/content/ehr_student_kd.pt\", map_location=DEVICE)\n",
        "sd.pop(\"ehr_table\", None)          # remove mismatched buffer\n",
        "student.load_state_dict(sd, strict=False)\n",
        "\n",
        "with torch.no_grad():\n",
        "    student.ehr_table = student.ehr_table.to(dtype=torch.float32, device=DEVICE)\n",
        "\n",
        "student.eval()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "uaBobw2ps8zD",
        "outputId": "379296f7-18f4-402c-ca86-32860a23f2d2"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "predicted relation: 3\n"
          ]
        }
      ],
      "source": [
        "@torch.no_grad()\n",
        "def predict_relation(student1, i: int, j: int) -> int:\n",
        "    i_t = torch.tensor([i], dtype=torch.long, device=DEVICE)\n",
        "    j_t = torch.tensor([j], dtype=torch.long, device=DEVICE)\n",
        "    logits = student1.pair_all_rel_logits(i_t, j_t)      # [1, n_rel]\n",
        "    return int(torch.argmax(logits, dim=1).item())\n",
        "\n",
        "# usage:\n",
        "r_hat = predict_relation(student, i=10, j=1237)\n",
        "print(\"predicted relation:\", r_hat)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "BbWAC4X9L8L9"
      },
      "outputs": [],
      "source": [
        "from bisect import bisect\n",
        "\n",
        "count = 0\n",
        "prediction_correct_pairs = []\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id_derived.txt\", \"r\") as file:\n",
        "  with open(\"/content/test_file_5.txt\", 'w') as file2:\n",
        "    for line in file.readlines():\n",
        "      try:\n",
        "        row = line.split()\n",
        "        if len(row) == 3:\n",
        "          # print(row)\n",
        "          # existence = predict(model, int(row[0]), int(row[2]))\n",
        "          # print(bisect(overlap_entity_ids, int(row[0])), bisect(overlap_entity_ids, int(row[2])))\n",
        "          prediction = predict_relation(student, bisect(overlap_entity_ids, int(row[0]))-1, bisect(overlap_entity_ids, int(row[2]))-1)\n",
        "          # prediction = predict(model, int(row[0]), int(row[2]))\n",
        "          # if existence == 0:\n",
        "          #   prediction = 0\n",
        "          # print(prediction, int(row[1]))\n",
        "          prediction_correct_pairs.append((prediction, int(row[1])))\n",
        "          # if count == 5000:\n",
        "          #   break\n",
        "      except:\n",
        "        continue\n",
        "    for pair in prediction_correct_pairs:\n",
        "      file2.write(str(pair[0]) + \" \" + str(pair[1]) + \"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "accurate_predictions = 0\n",
        "for pair in prediction_correct_pairs:\n",
        "  if pair[0] == pair[1]:\n",
        "    accurate_predictions += 1\n",
        "print(\"Precision:\", accurate_predictions / len(prediction_correct_pairs))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tJeULWJuqsg4",
        "outputId": "ce62e593-95c5-4540-85ef-95ee82224df5"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Precision: 0.33855132540634886\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "NGBbuEuwl2Vd"
      },
      "source": [
        "## SMILES Baseline & Negative Sampling"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "bAqagWz6e3fe"
      },
      "source": [
        "### SMILES Baseline"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "yBQgISrWjDGs",
        "outputId": "b27316ed-022c-42c6-a069-9a4e7a4f7ad7"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting rdkit\n",
            "  Downloading rdkit-2025.9.1-cp312-cp312-manylinux_2_28_x86_64.whl.metadata (4.1 kB)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.12/dist-packages (from rdkit) (2.0.2)\n",
            "Requirement already satisfied: Pillow in /usr/local/lib/python3.12/dist-packages (from rdkit) (11.3.0)\n",
            "Downloading rdkit-2025.9.1-cp312-cp312-manylinux_2_28_x86_64.whl (36.2 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m36.2/36.2 MB\u001b[0m \u001b[31m75.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: rdkit\n",
            "Successfully installed rdkit-2025.9.1\n"
          ]
        }
      ],
      "source": [
        "%pip install rdkit"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "EBKnuHEUS4Lq",
        "outputId": "5e089f4d-1745-4f58-be79-b68910d7b4dd"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting Chem\n",
            "  Downloading chem-2.0.0-py3-none-any.whl.metadata (1.4 kB)\n",
            "Requirement already satisfied: pyparsing in /usr/local/lib/python3.12/dist-packages (from Chem) (3.2.5)\n",
            "Requirement already satisfied: markupsafe in /usr/local/lib/python3.12/dist-packages (from Chem) (3.0.3)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.12/dist-packages (from Chem) (2.0.2)\n",
            "Requirement already satisfied: scipy in /usr/local/lib/python3.12/dist-packages (from Chem) (1.16.2)\n",
            "Requirement already satisfied: nltk in /usr/local/lib/python3.12/dist-packages (from Chem) (3.9.1)\n",
            "Requirement already satisfied: click in /usr/local/lib/python3.12/dist-packages (from nltk->Chem) (8.3.0)\n",
            "Requirement already satisfied: joblib in /usr/local/lib/python3.12/dist-packages (from nltk->Chem) (1.5.2)\n",
            "Requirement already satisfied: regex>=2021.8.3 in /usr/local/lib/python3.12/dist-packages (from nltk->Chem) (2024.11.6)\n",
            "Requirement already satisfied: tqdm in /usr/local/lib/python3.12/dist-packages (from nltk->Chem) (4.67.1)\n",
            "Downloading chem-2.0.0-py3-none-any.whl (24 kB)\n",
            "Installing collected packages: Chem\n",
            "Successfully installed Chem-2.0.0\n"
          ]
        }
      ],
      "source": [
        "%pip install Chem"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Dtkof63_-8NH"
      },
      "outputs": [],
      "source": [
        "import json\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/LARS-research-KnowDDI-979dbfa/raw_data/Drugbank/node2id.json\") as file:\n",
        "  know_ddi_id_json = json.load(file)\n",
        "reverse_know_ddi_id_json = {}\n",
        "for key, value in know_ddi_id_json.items():\n",
        "  reverse_know_ddi_id_json[value] = key"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "er6VS1Dre4tT"
      },
      "outputs": [],
      "source": [
        "import requests\n",
        "import json\n",
        "from rdkit import Chem\n",
        "\n",
        "def drugbank_to_smiles(drugbank_code):\n",
        "  rest_information_json = json.loads(requests.get(f\"https://pubchem.ncbi.nlm.nih.gov/rest/pug/substance/sourceid/drugbank/{drugbank_code}/JSON\").text)\n",
        "  compound_information = rest_information_json['PC_Substances'][0]['compound'][0]\n",
        "  Z = compound_information['atoms']['element']\n",
        "  edges = []\n",
        "  for i in range(len(compound_information['bonds']['aid1'])):\n",
        "    edges.append((compound_information['bonds']['aid1'][i], compound_information['bonds']['aid2'][i], compound_information['bonds']['order'][i]))\n",
        "  mol = Chem.RWMol()\n",
        "  idx = [mol.AddAtom(Chem.Atom(z)) for z in Z]\n",
        "\n",
        "  order_map = {1: Chem.BondType.SINGLE, 2: Chem.BondType.DOUBLE, 3: Chem.BondType.TRIPLE}\n",
        "  for a,b,o in edges:\n",
        "      mol.AddBond(idx[a-1], idx[b-1], order_map[o])\n",
        "\n",
        "  m = mol.GetMol()\n",
        "  Chem.SanitizeMol(m)\n",
        "  return Chem.MolToSmiles(m, canonical=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "FjFJPCmHUWQk"
      },
      "outputs": [],
      "source": [
        "all_smiles_mapping = []\n",
        "for i in range(1710):\n",
        "  try:\n",
        "    all_smiles_mapping.append(drugbank_to_smiles(reverse_know_ddi_id_json[i]))\n",
        "    print(i, all_smiles_mapping[-1])\n",
        "  except:\n",
        "    continue"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EUfynEBs0zye"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/all_smiles_mapping.pkl\", \"rb\") as file:\n",
        "  all_smiles_mapping = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 652,
          "referenced_widgets": [
            "5a9c852eb707440fa4f4c171ecdf75a4",
            "0f73572d48654c4f85f799f6888d4173",
            "3a300d8b2edf4a60badec82795114e3c",
            "b7b1920c06e741748693948cf89e71bc",
            "fde000e37fea4725962209506120ce2a",
            "d5f2d0496428429697afdcea54dc29d4",
            "5862d77882c34a4b81034d29c1d92d84",
            "2d5b4a0d845c4593bad9d15a9f0ea508",
            "0ec88dd2f18547cfb899b1fcdca4d963",
            "f2f6a4b8f5584169aabe791b14151c4c",
            "55b2a3e282f34649b1557143ebcbf5e2",
            "9866ce998b1a4319abbc3e444092f780",
            "7a057441dd0e4a0f85438c9b95abe351",
            "d3bf4ab2bbca4778ab945bd0349b9d9d",
            "a830d63c369d405099ba0b83c54d5c31",
            "99502a27a22943fc8a42fb2add84d994",
            "03269e7df51349dfa65413b5d28ddfe2",
            "fa884d0cd78d4ec18cff593ebc5a3a35",
            "bbe0463caad945ea9cf6ee097e7c109b",
            "e24d16b1eef94bd296c0f5bc53904171",
            "5b7cba406d18471c903da9e73e8f5445",
            "177524600e9f40d2994e513f549229f7",
            "b8c9b78ff3d543f0a536c86652ac1495",
            "ff218e3692774565ae95b9a201e08e68",
            "a7eac9e5034e4f3aa41e9ede8fda7251",
            "5b33311bb96245db91646a26bc1028aa",
            "6f42b8de803f46ddbc62953c60cf08b9",
            "64f032bcf07d401fb65e60b1f4f635ea",
            "a2035711d968416ea6aab051924bf7c5",
            "05c3cc4af4f4419a95a61c25fe430c7b",
            "ebfa20d5fb324898ae11b216bfe55cfc",
            "83b4dfc8a94749558102c8c6246825a7",
            "e5634b9f3207494ab50d2bbd3c069114",
            "fd2e798427cc4f29ac1835dcaa0deb88",
            "81d3a7dcced04c4fb576d82949b50383",
            "4e013de02fb1491f93119dc3bf52227b",
            "e677b52ab18f4a44bd03e0ce48d66e30",
            "d69f1dbe0bff4ca99326f5cdaef950a8",
            "6676e570f5f149f693f5d249445dc8b1",
            "aecd817c908046dc9daf7dc722dd3168",
            "80023e2186fe4f168b06724580ef101c",
            "5b16435040834cccad6d38475b023faf",
            "35cd539908d143c79dd5047be34641e2",
            "9807f686d15b4a54bf6b25acb2a32b34",
            "9f3f9f25857940b698e4d931262440b7",
            "129ef7aaf22e4c388d8b29c32569d4c2",
            "6e549c60a3664348943088b3a5496963",
            "2f77d8f1401541bb803bb7dcb1da0806",
            "bc99c749328c4d7d992771870ff3ec16",
            "5efa8a4b7c4141a6a15cb25483889080",
            "1ac0e420d7aa458288aeb7d22f71fc47",
            "d330a09889b84e8aad2075b365dd7211",
            "ead518a639484f2a981401e780f97226",
            "d83286b62bb048e3a7c38789beedd414",
            "2a6b407648244da1ab30ba89bf3dcc7e"
          ]
        },
        "id": "8BbLM3pgt9p7",
        "outputId": "2f6f45c7-a811-45f1-c804-abca4db2855b"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.12/dist-packages/huggingface_hub/utils/_auth.py:94: UserWarning: \n",
            "The secret `HF_TOKEN` does not exist in your Colab secrets.\n",
            "To authenticate with the Hugging Face Hub, create a token in your settings tab (https://huggingface.co/settings/tokens), set it as secret in your Google Colab and restart your session.\n",
            "You will be able to reuse this secret in all of your notebooks.\n",
            "Please note that authentication is recommended but still optional to access public models or datasets.\n",
            "  warnings.warn(\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "tokenizer_config.json:   0%|          | 0.00/166 [00:00<?, ?B/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "5a9c852eb707440fa4f4c171ecdf75a4"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "config.json:   0%|          | 0.00/501 [00:00<?, ?B/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "9866ce998b1a4319abbc3e444092f780"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "vocab.json: 0.00B [00:00, ?B/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "b8c9b78ff3d543f0a536c86652ac1495"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "merges.txt: 0.00B [00:00, ?B/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "fd2e798427cc4f29ac1835dcaa0deb88"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "special_tokens_map.json:   0%|          | 0.00/150 [00:00<?, ?B/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "9f3f9f25857940b698e4d931262440b7"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "error",
          "ename": "KeyboardInterrupt",
          "evalue": "",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-4081853042.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0mtok\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mAutoTokenizer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfrom_pretrained\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mMODEL\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 9\u001b[0;31m \u001b[0mmdl\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mAutoModel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfrom_pretrained\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mMODEL\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     10\u001b[0m \u001b[0mmdl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meval\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     11\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/models/auto/auto_factory.py\u001b[0m in \u001b[0;36mfrom_pretrained\u001b[0;34m(cls, pretrained_model_name_or_path, *model_args, **kwargs)\u001b[0m\n\u001b[1;32m    602\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mmodel_class\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconfig_class\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mconfig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msub_configs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"text_config\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    603\u001b[0m                 \u001b[0mconfig\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mconfig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_text_config\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 604\u001b[0;31m             return model_class.from_pretrained(\n\u001b[0m\u001b[1;32m    605\u001b[0m                 \u001b[0mpretrained_model_name_or_path\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mmodel_args\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mconfig\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mconfig\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mhub_kwargs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    606\u001b[0m             )\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/modeling_utils.py\u001b[0m in \u001b[0;36m_wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    286\u001b[0m         \u001b[0mold_dtype\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_default_dtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    287\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 288\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    289\u001b[0m         \u001b[0;32mfinally\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    290\u001b[0m             \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_default_dtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mold_dtype\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/modeling_utils.py\u001b[0m in \u001b[0;36mfrom_pretrained\u001b[0;34m(cls, pretrained_model_name_or_path, config, cache_dir, ignore_mismatched_sizes, force_download, local_files_only, token, revision, use_safetensors, weights_only, *model_args, **kwargs)\u001b[0m\n\u001b[1;32m   5028\u001b[0m             )\n\u001b[1;32m   5029\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 5030\u001b[0;31m         checkpoint_files, sharded_metadata = _get_resolved_checkpoint_files(\n\u001b[0m\u001b[1;32m   5031\u001b[0m             \u001b[0mpretrained_model_name_or_path\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mpretrained_model_name_or_path\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5032\u001b[0m             \u001b[0msubfolder\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0msubfolder\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/modeling_utils.py\u001b[0m in \u001b[0;36m_get_resolved_checkpoint_files\u001b[0;34m(pretrained_model_name_or_path, subfolder, variant, gguf_file, from_tf, from_flax, use_safetensors, cache_dir, force_download, proxies, local_files_only, token, user_agent, revision, commit_hash, is_remote_code, transformers_explicit_filename)\u001b[0m\n\u001b[1;32m   1148\u001b[0m                     \u001b[0;34m\"_commit_hash\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mcommit_hash\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1149\u001b[0m                 }\n\u001b[0;32m-> 1150\u001b[0;31m                 \u001b[0mresolved_archive_file\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcached_file\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpretrained_model_name_or_path\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfilename\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mcached_file_kwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1151\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1152\u001b[0m                 \u001b[0;31m# Since we set _raise_exceptions_for_missing_entries=False, we don't get an exception but a None\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/utils/hub.py\u001b[0m in \u001b[0;36mcached_file\u001b[0;34m(path_or_repo_id, filename, **kwargs)\u001b[0m\n\u001b[1;32m    319\u001b[0m     \u001b[0;31m`\u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    320\u001b[0m     \"\"\"\n\u001b[0;32m--> 321\u001b[0;31m     \u001b[0mfile\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcached_files\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath_or_repo_id\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mpath_or_repo_id\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfilenames\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mfilename\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    322\u001b[0m     \u001b[0mfile\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mfile\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m \u001b[0;32melse\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    323\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/transformers/utils/hub.py\u001b[0m in \u001b[0;36mcached_files\u001b[0;34m(path_or_repo_id, filenames, cache_dir, force_download, resume_download, proxies, token, revision, local_files_only, subfolder, repo_type, user_agent, _raise_exceptions_for_gated_repo, _raise_exceptions_for_missing_entries, _raise_exceptions_for_connection_errors, _commit_hash, **deprecated_kwargs)\u001b[0m\n\u001b[1;32m    476\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfull_filenames\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    477\u001b[0m             \u001b[0;31m# This is slightly better for only 1 file\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 478\u001b[0;31m             hf_hub_download(\n\u001b[0m\u001b[1;32m    479\u001b[0m                 \u001b[0mpath_or_repo_id\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    480\u001b[0m                 \u001b[0mfilenames\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/utils/_validators.py\u001b[0m in \u001b[0;36m_inner_fn\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    112\u001b[0m             \u001b[0mkwargs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msmoothly_deprecate_use_auth_token\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfn_name\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhas_token\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mhas_token\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    113\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 114\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    115\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    116\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0m_inner_fn\u001b[0m  \u001b[0;31m# type: ignore\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36mhf_hub_download\u001b[0;34m(repo_id, filename, subfolder, repo_type, revision, library_name, library_version, cache_dir, local_dir, user_agent, force_download, proxies, etag_timeout, token, local_files_only, headers, endpoint, resume_download, force_filename, local_dir_use_symlinks)\u001b[0m\n\u001b[1;32m   1008\u001b[0m         )\n\u001b[1;32m   1009\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1010\u001b[0;31m         return _hf_hub_download_to_cache_dir(\n\u001b[0m\u001b[1;32m   1011\u001b[0m             \u001b[0;31m# Destination\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1012\u001b[0m             \u001b[0mcache_dir\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcache_dir\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36m_hf_hub_download_to_cache_dir\u001b[0;34m(cache_dir, repo_id, filename, repo_type, revision, endpoint, etag_timeout, headers, proxies, token, local_files_only, force_download)\u001b[0m\n\u001b[1;32m   1071\u001b[0m     \u001b[0;31m# Try to get metadata (etag, commit_hash, url, size) from the server.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1072\u001b[0m     \u001b[0;31m# If we can't, a HEAD request error is returned.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1073\u001b[0;31m     (url_to_download, etag, commit_hash, expected_size, xet_file_data, head_call_error) = _get_metadata_or_catch_error(\n\u001b[0m\u001b[1;32m   1074\u001b[0m         \u001b[0mrepo_id\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrepo_id\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1075\u001b[0m         \u001b[0mfilename\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfilename\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36m_get_metadata_or_catch_error\u001b[0;34m(repo_id, filename, repo_type, revision, endpoint, proxies, etag_timeout, headers, token, local_files_only, relative_filename, storage_folder)\u001b[0m\n\u001b[1;32m   1544\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1545\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1546\u001b[0;31m                 metadata = get_hf_file_metadata(\n\u001b[0m\u001b[1;32m   1547\u001b[0m                     \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mproxies\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mproxies\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtimeout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0metag_timeout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mheaders\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mheaders\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtoken\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtoken\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mendpoint\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mendpoint\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1548\u001b[0m                 )\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/utils/_validators.py\u001b[0m in \u001b[0;36m_inner_fn\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    112\u001b[0m             \u001b[0mkwargs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msmoothly_deprecate_use_auth_token\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfn_name\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhas_token\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mhas_token\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    113\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 114\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    115\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    116\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0m_inner_fn\u001b[0m  \u001b[0;31m# type: ignore\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36mget_hf_file_metadata\u001b[0;34m(url, token, proxies, timeout, library_name, library_version, user_agent, headers, endpoint)\u001b[0m\n\u001b[1;32m   1461\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1462\u001b[0m     \u001b[0;31m# Retrieve metadata\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1463\u001b[0;31m     r = _request_wrapper(\n\u001b[0m\u001b[1;32m   1464\u001b[0m         \u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"HEAD\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1465\u001b[0m         \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36m_request_wrapper\u001b[0;34m(method, url, follow_relative_redirects, **params)\u001b[0m\n\u001b[1;32m    284\u001b[0m     \u001b[0;31m# Recursively follow relative redirects\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    285\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mfollow_relative_redirects\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 286\u001b[0;31m         response = _request_wrapper(\n\u001b[0m\u001b[1;32m    287\u001b[0m             \u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    288\u001b[0m             \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/file_download.py\u001b[0m in \u001b[0;36m_request_wrapper\u001b[0;34m(method, url, follow_relative_redirects, **params)\u001b[0m\n\u001b[1;32m    307\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    308\u001b[0m     \u001b[0;31m# Perform request and return if status_code is not in the retry list.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 309\u001b[0;31m     \u001b[0mresponse\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhttp_backoff\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    310\u001b[0m     \u001b[0mhf_raise_for_status\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mresponse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    311\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mresponse\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/utils/_http.py\u001b[0m in \u001b[0;36mhttp_backoff\u001b[0;34m(method, url, max_retries, base_wait_time, max_wait_time, retry_on_exceptions, retry_on_status_codes, **kwargs)\u001b[0m\n\u001b[1;32m    306\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    307\u001b[0m             \u001b[0;31m# Perform request and return if status_code is not in the retry list.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 308\u001b[0;31m             \u001b[0mresponse\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msession\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrequest\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    309\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mresponse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstatus_code\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mretry_on_status_codes\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    310\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mresponse\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/requests/sessions.py\u001b[0m in \u001b[0;36mrequest\u001b[0;34m(self, method, url, params, data, headers, cookies, files, auth, timeout, allow_redirects, proxies, hooks, stream, verify, cert, json)\u001b[0m\n\u001b[1;32m    587\u001b[0m         }\n\u001b[1;32m    588\u001b[0m         \u001b[0msend_kwargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msettings\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 589\u001b[0;31m         \u001b[0mresp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mprep\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0msend_kwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    590\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    591\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mresp\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/requests/sessions.py\u001b[0m in \u001b[0;36msend\u001b[0;34m(self, request, **kwargs)\u001b[0m\n\u001b[1;32m    701\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    702\u001b[0m         \u001b[0;31m# Send the request\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 703\u001b[0;31m         \u001b[0mr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0madapter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrequest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    704\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    705\u001b[0m         \u001b[0;31m# Total elapsed time of the request (approximately)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/huggingface_hub/utils/_http.py\u001b[0m in \u001b[0;36msend\u001b[0;34m(self, request, *args, **kwargs)\u001b[0m\n\u001b[1;32m     93\u001b[0m             \u001b[0mlogger\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdebug\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Send: {_curlify(request)}\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     94\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 95\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrequest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     96\u001b[0m         \u001b[0;32mexcept\u001b[0m \u001b[0mrequests\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mRequestException\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     97\u001b[0m             \u001b[0mrequest_id\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrequest\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mheaders\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX_AMZN_TRACE_ID\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/requests/adapters.py\u001b[0m in \u001b[0;36msend\u001b[0;34m(self, request, stream, timeout, verify, cert, proxies)\u001b[0m\n\u001b[1;32m    665\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    666\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 667\u001b[0;31m             resp = conn.urlopen(\n\u001b[0m\u001b[1;32m    668\u001b[0m                 \u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrequest\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    669\u001b[0m                 \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/urllib3/connectionpool.py\u001b[0m in \u001b[0;36murlopen\u001b[0;34m(self, method, url, body, headers, retries, redirect, assert_same_host, timeout, pool_timeout, release_conn, chunked, body_pos, preload_content, decode_content, **response_kw)\u001b[0m\n\u001b[1;32m    785\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    786\u001b[0m             \u001b[0;31m# Make the request on the HTTPConnection object\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 787\u001b[0;31m             response = self._make_request(\n\u001b[0m\u001b[1;32m    788\u001b[0m                 \u001b[0mconn\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    789\u001b[0m                 \u001b[0mmethod\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/urllib3/connectionpool.py\u001b[0m in \u001b[0;36m_make_request\u001b[0;34m(self, conn, method, url, body, headers, retries, timeout, chunked, response_conn, preload_content, decode_content, enforce_content_length)\u001b[0m\n\u001b[1;32m    532\u001b[0m         \u001b[0;31m# Receive the response from the server\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    533\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 534\u001b[0;31m             \u001b[0mresponse\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mconn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgetresponse\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    535\u001b[0m         \u001b[0;32mexcept\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mBaseSSLError\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mOSError\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    536\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_raise_timeout\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0merr\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0murl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0murl\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtimeout_value\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mread_timeout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/urllib3/connection.py\u001b[0m in \u001b[0;36mgetresponse\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    563\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    564\u001b[0m         \u001b[0;31m# Get the response from http.client.HTTPConnection\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 565\u001b[0;31m         \u001b[0mhttplib_response\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgetresponse\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    566\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    567\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/http/client.py\u001b[0m in \u001b[0;36mgetresponse\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m   1428\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1429\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1430\u001b[0;31m                 \u001b[0mresponse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbegin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1431\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mConnectionError\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1432\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/http/client.py\u001b[0m in \u001b[0;36mbegin\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    329\u001b[0m         \u001b[0;31m# read until we get a non-100 response\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    330\u001b[0m         \u001b[0;32mwhile\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 331\u001b[0;31m             \u001b[0mversion\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstatus\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreason\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_read_status\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    332\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mstatus\u001b[0m \u001b[0;34m!=\u001b[0m \u001b[0mCONTINUE\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    333\u001b[0m                 \u001b[0;32mbreak\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/http/client.py\u001b[0m in \u001b[0;36m_read_status\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    290\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    291\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_read_status\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 292\u001b[0;31m         \u001b[0mline\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mstr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreadline\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_MAXLINE\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"iso-8859-1\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    293\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mline\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0m_MAXLINE\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    294\u001b[0m             \u001b[0;32mraise\u001b[0m \u001b[0mLineTooLong\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"status line\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/socket.py\u001b[0m in \u001b[0;36mreadinto\u001b[0;34m(self, b)\u001b[0m\n\u001b[1;32m    718\u001b[0m         \u001b[0;32mwhile\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    719\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 720\u001b[0;31m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_sock\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrecv_into\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mb\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    721\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mtimeout\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    722\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_timeout_occurred\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/ssl.py\u001b[0m in \u001b[0;36mrecv_into\u001b[0;34m(self, buffer, nbytes, flags)\u001b[0m\n\u001b[1;32m   1249\u001b[0m                   \u001b[0;34m\"non-zero flags not allowed in calls to recv_into() on %s\"\u001b[0m \u001b[0;34m%\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1250\u001b[0m                   self.__class__)\n\u001b[0;32m-> 1251\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mread\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnbytes\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbuffer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1252\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1253\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrecv_into\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbuffer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnbytes\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mflags\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/lib/python3.12/ssl.py\u001b[0m in \u001b[0;36mread\u001b[0;34m(self, len, buffer)\u001b[0m\n\u001b[1;32m   1101\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1102\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mbuffer\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1103\u001b[0;31m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_sslobj\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mread\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbuffer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1104\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1105\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_sslobj\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mread\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ],
      "source": [
        "from transformers import AutoTokenizer, AutoModel\n",
        "import torch\n",
        "\n",
        "MODEL = \"seyonec/ChemBERTa-zinc-base-v1\"   # RoBERTa trained on SMILES\n",
        "\n",
        "tok = AutoTokenizer.from_pretrained(MODEL)\n",
        "mdl = AutoModel.from_pretrained(MODEL)\n",
        "mdl.eval()\n",
        "\n",
        "def mean_pool(last_hidden_state, attention_mask):\n",
        "    mask = attention_mask.unsqueeze(-1).expand(last_hidden_state.size()).float()\n",
        "    summed = (last_hidden_state * mask).sum(dim=1)\n",
        "    counts = mask.sum(dim=1).clamp(min=1e-9)\n",
        "    return summed / counts  # [batch, hidden_size]\n",
        "\n",
        "@torch.no_grad()\n",
        "def smiles_to_embeddings(smiles_list):\n",
        "    batch = tok(smiles_list, return_tensors=\"pt\", padding=True, truncation=True, max_length=256)\n",
        "    out = mdl(**batch)\n",
        "    emb = mean_pool(out.last_hidden_state, batch[\"attention_mask\"])  # shape [B, 768]\n",
        "    return emb\n",
        "\n",
        "for i in range(len(all_smiles_mapping)):\n",
        "  if all_smiles_mapping[i] is None:\n",
        "    all_smiles_mapping[i] = \"\"\n",
        "\n",
        "smiles_embeddings = smiles_to_embeddings(all_smiles_mapping)  # Example\n",
        "print(smiles_embeddings.shape)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "jfcuhen08vz4"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/smiles_embeddings.pkl\", \"wb\") as file:\n",
        "  pickle.dump(smiles_embeddings, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Hg4R1zXrLkMq"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/smiles_embeddings.pkl\", \"rb\") as file:\n",
        "  smiles_embeddings = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "fdbNzG4X7d-X"
      },
      "outputs": [],
      "source": [
        "training_nodes_adj = {}\n",
        "\n",
        "with open(\"/content/test_file_4.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split()\n",
        "    if len(row) == 1:\n",
        "      continue\n",
        "    row[0] = int(row[0])\n",
        "    row[1] = int(row[1])\n",
        "    row[2] = int(row[2])\n",
        "    if row[0] not in training_nodes_adj.keys():\n",
        "      training_nodes_adj[row[0]] = []\n",
        "    training_nodes_adj[row[0]].append((row[2], row[1]))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "o5Snddfm2K-B"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import numpy as np\n",
        "\n",
        "def to_1d_tensor(x) -> torch.Tensor:\n",
        "    if isinstance(x, np.ndarray):\n",
        "        t = torch.from_numpy(x)\n",
        "    elif isinstance(x, torch.Tensor):\n",
        "        t = x.detach()\n",
        "    else:\n",
        "        t = torch.from_numpy(np.asarray(x))\n",
        "    return t.to('cpu').float().reshape(-1)\n",
        "\n",
        "concat_pair_embeddings = []\n",
        "\n",
        "for src in training_nodes_adj.keys():\n",
        "    emb1 = to_1d_tensor(smiles_embeddings[src])\n",
        "\n",
        "    for edge in training_nodes_adj[src]:\n",
        "        neighbor_id = edge[0]\n",
        "        label = edge[1]\n",
        "\n",
        "        emb2 = to_1d_tensor(smiles_embeddings[neighbor_id])\n",
        "\n",
        "        pair_vec = torch.cat([emb1, emb2], dim=0)\n",
        "        concat_pair_embeddings.append((pair_vec, label))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5wThQ8ZUbvmZ"
      },
      "outputs": [],
      "source": [
        "from sklearn.neural_network import MLPClassifier\n",
        "import torch\n",
        "import numpy as np\n",
        "\n",
        "X = torch.stack(list(zip(*concat_pair_embeddings))[0])\n",
        "y = torch.tensor([edge[1] for edge in concat_pair_embeddings])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "NKhPkADKnBuD",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 153
        },
        "outputId": "9a313b59-d182-4899-86bc-c1383fca39ff"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.12/dist-packages/sklearn/neural_network/_multilayer_perceptron.py:691: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (15) reached and the optimization hasn't converged yet.\n",
            "  warnings.warn(\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=42)"
            ],
            "text/html": [
              "<style>#sk-container-id-4 {\n",
              "  /* Definition of color scheme common for light and dark mode */\n",
              "  --sklearn-color-text: #000;\n",
              "  --sklearn-color-text-muted: #666;\n",
              "  --sklearn-color-line: gray;\n",
              "  /* Definition of color scheme for unfitted estimators */\n",
              "  --sklearn-color-unfitted-level-0: #fff5e6;\n",
              "  --sklearn-color-unfitted-level-1: #f6e4d2;\n",
              "  --sklearn-color-unfitted-level-2: #ffe0b3;\n",
              "  --sklearn-color-unfitted-level-3: chocolate;\n",
              "  /* Definition of color scheme for fitted estimators */\n",
              "  --sklearn-color-fitted-level-0: #f0f8ff;\n",
              "  --sklearn-color-fitted-level-1: #d4ebff;\n",
              "  --sklearn-color-fitted-level-2: #b3dbfd;\n",
              "  --sklearn-color-fitted-level-3: cornflowerblue;\n",
              "\n",
              "  /* Specific color for light theme */\n",
              "  --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
              "  --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
              "  --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
              "  --sklearn-color-icon: #696969;\n",
              "\n",
              "  @media (prefers-color-scheme: dark) {\n",
              "    /* Redefinition of color scheme for dark theme */\n",
              "    --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
              "    --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
              "    --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
              "    --sklearn-color-icon: #878787;\n",
              "  }\n",
              "}\n",
              "\n",
              "#sk-container-id-4 {\n",
              "  color: var(--sklearn-color-text);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 pre {\n",
              "  padding: 0;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 input.sk-hidden--visually {\n",
              "  border: 0;\n",
              "  clip: rect(1px 1px 1px 1px);\n",
              "  clip: rect(1px, 1px, 1px, 1px);\n",
              "  height: 1px;\n",
              "  margin: -1px;\n",
              "  overflow: hidden;\n",
              "  padding: 0;\n",
              "  position: absolute;\n",
              "  width: 1px;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-dashed-wrapped {\n",
              "  border: 1px dashed var(--sklearn-color-line);\n",
              "  margin: 0 0.4em 0.5em 0.4em;\n",
              "  box-sizing: border-box;\n",
              "  padding-bottom: 0.4em;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-container {\n",
              "  /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
              "     but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
              "     so we also need the `!important` here to be able to override the\n",
              "     default hidden behavior on the sphinx rendered scikit-learn.org.\n",
              "     See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
              "  display: inline-block !important;\n",
              "  position: relative;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-text-repr-fallback {\n",
              "  display: none;\n",
              "}\n",
              "\n",
              "div.sk-parallel-item,\n",
              "div.sk-serial,\n",
              "div.sk-item {\n",
              "  /* draw centered vertical line to link estimators */\n",
              "  background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
              "  background-size: 2px 100%;\n",
              "  background-repeat: no-repeat;\n",
              "  background-position: center center;\n",
              "}\n",
              "\n",
              "/* Parallel-specific style estimator block */\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel-item::after {\n",
              "  content: \"\";\n",
              "  width: 100%;\n",
              "  border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
              "  flex-grow: 1;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel {\n",
              "  display: flex;\n",
              "  align-items: stretch;\n",
              "  justify-content: center;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  position: relative;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel-item {\n",
              "  display: flex;\n",
              "  flex-direction: column;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel-item:first-child::after {\n",
              "  align-self: flex-end;\n",
              "  width: 50%;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel-item:last-child::after {\n",
              "  align-self: flex-start;\n",
              "  width: 50%;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-parallel-item:only-child::after {\n",
              "  width: 0;\n",
              "}\n",
              "\n",
              "/* Serial-specific style estimator block */\n",
              "\n",
              "#sk-container-id-4 div.sk-serial {\n",
              "  display: flex;\n",
              "  flex-direction: column;\n",
              "  align-items: center;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  padding-right: 1em;\n",
              "  padding-left: 1em;\n",
              "}\n",
              "\n",
              "\n",
              "/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
              "clickable and can be expanded/collapsed.\n",
              "- Pipeline and ColumnTransformer use this feature and define the default style\n",
              "- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
              "*/\n",
              "\n",
              "/* Pipeline and ColumnTransformer style (default) */\n",
              "\n",
              "#sk-container-id-4 div.sk-toggleable {\n",
              "  /* Default theme specific background. It is overwritten whether we have a\n",
              "  specific estimator or a Pipeline/ColumnTransformer */\n",
              "  background-color: var(--sklearn-color-background);\n",
              "}\n",
              "\n",
              "/* Toggleable label */\n",
              "#sk-container-id-4 label.sk-toggleable__label {\n",
              "  cursor: pointer;\n",
              "  display: flex;\n",
              "  width: 100%;\n",
              "  margin-bottom: 0;\n",
              "  padding: 0.5em;\n",
              "  box-sizing: border-box;\n",
              "  text-align: center;\n",
              "  align-items: start;\n",
              "  justify-content: space-between;\n",
              "  gap: 0.5em;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 label.sk-toggleable__label .caption {\n",
              "  font-size: 0.6rem;\n",
              "  font-weight: lighter;\n",
              "  color: var(--sklearn-color-text-muted);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 label.sk-toggleable__label-arrow:before {\n",
              "  /* Arrow on the left of the label */\n",
              "  content: \"▸\";\n",
              "  float: left;\n",
              "  margin-right: 0.25em;\n",
              "  color: var(--sklearn-color-icon);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 label.sk-toggleable__label-arrow:hover:before {\n",
              "  color: var(--sklearn-color-text);\n",
              "}\n",
              "\n",
              "/* Toggleable content - dropdown */\n",
              "\n",
              "#sk-container-id-4 div.sk-toggleable__content {\n",
              "  max-height: 0;\n",
              "  max-width: 0;\n",
              "  overflow: hidden;\n",
              "  text-align: left;\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-toggleable__content.fitted {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-toggleable__content pre {\n",
              "  margin: 0.2em;\n",
              "  border-radius: 0.25em;\n",
              "  color: var(--sklearn-color-text);\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-toggleable__content.fitted pre {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
              "  /* Expand drop-down */\n",
              "  max-height: 200px;\n",
              "  max-width: 100%;\n",
              "  overflow: auto;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
              "  content: \"▾\";\n",
              "}\n",
              "\n",
              "/* Pipeline/ColumnTransformer-specific style */\n",
              "\n",
              "#sk-container-id-4 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Estimator-specific style */\n",
              "\n",
              "/* Colorize estimator box */\n",
              "#sk-container-id-4 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-label label.sk-toggleable__label,\n",
              "#sk-container-id-4 div.sk-label label {\n",
              "  /* The background is the default theme color */\n",
              "  color: var(--sklearn-color-text-on-default-background);\n",
              "}\n",
              "\n",
              "/* On hover, darken the color of the background */\n",
              "#sk-container-id-4 div.sk-label:hover label.sk-toggleable__label {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "/* Label box, darken color on hover, fitted */\n",
              "#sk-container-id-4 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
              "  color: var(--sklearn-color-text);\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Estimator label */\n",
              "\n",
              "#sk-container-id-4 div.sk-label label {\n",
              "  font-family: monospace;\n",
              "  font-weight: bold;\n",
              "  display: inline-block;\n",
              "  line-height: 1.2em;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-label-container {\n",
              "  text-align: center;\n",
              "}\n",
              "\n",
              "/* Estimator-specific */\n",
              "#sk-container-id-4 div.sk-estimator {\n",
              "  font-family: monospace;\n",
              "  border: 1px dotted var(--sklearn-color-border-box);\n",
              "  border-radius: 0.25em;\n",
              "  box-sizing: border-box;\n",
              "  margin-bottom: 0.5em;\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-0);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-estimator.fitted {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-0);\n",
              "}\n",
              "\n",
              "/* on hover */\n",
              "#sk-container-id-4 div.sk-estimator:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-2);\n",
              "}\n",
              "\n",
              "#sk-container-id-4 div.sk-estimator.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-2);\n",
              "}\n",
              "\n",
              "/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
              "\n",
              "/* Common style for \"i\" and \"?\" */\n",
              "\n",
              ".sk-estimator-doc-link,\n",
              "a:link.sk-estimator-doc-link,\n",
              "a:visited.sk-estimator-doc-link {\n",
              "  float: right;\n",
              "  font-size: smaller;\n",
              "  line-height: 1em;\n",
              "  font-family: monospace;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  border-radius: 1em;\n",
              "  height: 1em;\n",
              "  width: 1em;\n",
              "  text-decoration: none !important;\n",
              "  margin-left: 0.5em;\n",
              "  text-align: center;\n",
              "  /* unfitted */\n",
              "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-unfitted-level-1);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link.fitted,\n",
              "a:link.sk-estimator-doc-link.fitted,\n",
              "a:visited.sk-estimator-doc-link.fitted {\n",
              "  /* fitted */\n",
              "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-fitted-level-1);\n",
              "}\n",
              "\n",
              "/* On hover */\n",
              "div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
              ".sk-estimator-doc-link:hover,\n",
              "div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
              ".sk-estimator-doc-link:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
              ".sk-estimator-doc-link.fitted:hover,\n",
              "div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
              ".sk-estimator-doc-link.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "/* Span, style for the box shown on hovering the info icon */\n",
              ".sk-estimator-doc-link span {\n",
              "  display: none;\n",
              "  z-index: 9999;\n",
              "  position: relative;\n",
              "  font-weight: normal;\n",
              "  right: .2ex;\n",
              "  padding: .5ex;\n",
              "  margin: .5ex;\n",
              "  width: min-content;\n",
              "  min-width: 20ex;\n",
              "  max-width: 50ex;\n",
              "  color: var(--sklearn-color-text);\n",
              "  box-shadow: 2pt 2pt 4pt #999;\n",
              "  /* unfitted */\n",
              "  background: var(--sklearn-color-unfitted-level-0);\n",
              "  border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link.fitted span {\n",
              "  /* fitted */\n",
              "  background: var(--sklearn-color-fitted-level-0);\n",
              "  border: var(--sklearn-color-fitted-level-3);\n",
              "}\n",
              "\n",
              ".sk-estimator-doc-link:hover span {\n",
              "  display: block;\n",
              "}\n",
              "\n",
              "/* \"?\"-specific style due to the `<a>` HTML tag */\n",
              "\n",
              "#sk-container-id-4 a.estimator_doc_link {\n",
              "  float: right;\n",
              "  font-size: 1rem;\n",
              "  line-height: 1em;\n",
              "  font-family: monospace;\n",
              "  background-color: var(--sklearn-color-background);\n",
              "  border-radius: 1rem;\n",
              "  height: 1rem;\n",
              "  width: 1rem;\n",
              "  text-decoration: none;\n",
              "  /* unfitted */\n",
              "  color: var(--sklearn-color-unfitted-level-1);\n",
              "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 a.estimator_doc_link.fitted {\n",
              "  /* fitted */\n",
              "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
              "  color: var(--sklearn-color-fitted-level-1);\n",
              "}\n",
              "\n",
              "/* On hover */\n",
              "#sk-container-id-4 a.estimator_doc_link:hover {\n",
              "  /* unfitted */\n",
              "  background-color: var(--sklearn-color-unfitted-level-3);\n",
              "  color: var(--sklearn-color-background);\n",
              "  text-decoration: none;\n",
              "}\n",
              "\n",
              "#sk-container-id-4 a.estimator_doc_link.fitted:hover {\n",
              "  /* fitted */\n",
              "  background-color: var(--sklearn-color-fitted-level-3);\n",
              "}\n",
              "</style><div id=\"sk-container-id-4\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=42)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-4\" type=\"checkbox\" checked><label for=\"sk-estimator-id-4\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow\"><div><div>MLPClassifier</div></div><div><a class=\"sk-estimator-doc-link fitted\" rel=\"noreferrer\" target=\"_blank\" href=\"https://scikit-learn.org/1.6/modules/generated/sklearn.neural_network.MLPClassifier.html\">?<span>Documentation for MLPClassifier</span></a><span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></div></label><div class=\"sk-toggleable__content fitted\"><pre>MLPClassifier(alpha=0.1, hidden_layer_sizes=(32, 16, 8, 4, 2), max_iter=15,\n",
              "              random_state=42)</pre></div> </div></div></div></div>"
            ]
          },
          "metadata": {},
          "execution_count": 75
        }
      ],
      "source": [
        "clf = MLPClassifier(solver='adam', alpha=0.10,\n",
        "                    hidden_layer_sizes=(32, 16, 8, 4, 2), random_state=42, max_iter=15)\n",
        "clf.fit(X, y)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "FS-Kwlp8bmTx"
      },
      "outputs": [],
      "source": [
        "test_nodes_adj = {}\n",
        "with open(\"/content/test_file_6.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    if len(line.split()) == 1:\n",
        "      continue\n",
        "    row = line.split()\n",
        "    head = int(row[0])\n",
        "    tail = int(row[2])\n",
        "    label = int(row[1])\n",
        "    if head not in test_nodes_adj.keys():\n",
        "      test_nodes_adj[head] = []\n",
        "    test_nodes_adj[head].append((tail, label))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "K3WZ0kDKpW33",
        "outputId": "ac9374a5-846b-4476-b552-5330eca0b4ed"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Accuracy: 0.14543230267221002\n"
          ]
        }
      ],
      "source": [
        "accurate_predictions = 0\n",
        "count = 0\n",
        "\n",
        "with open(\"/content/test_file_5.txt\", 'w') as file:\n",
        "  for node in test_nodes_adj.keys():\n",
        "    # try:\n",
        "      SMILES_1_embed = smiles_embeddings[node]\n",
        "      for edge in test_nodes_adj[node]:\n",
        "        # try:\n",
        "          SMILES_2_embed = smiles_embeddings[edge[0]]\n",
        "          prediction = clf.predict([torch.cat((torch.from_numpy(np.asarray(SMILES_1_embed.numpy())), torch.from_numpy(np.asarray(SMILES_2_embed.numpy()))))])\n",
        "          file.write(f\"{prediction}\\t{edge[1]}\\n\")\n",
        "          if prediction[0] == edge[1]:\n",
        "            accurate_predictions += 1\n",
        "          count += 1\n",
        "        # except:\n",
        "        #   continue\n",
        "    # except:\n",
        "    #   continue\n",
        "  print(\"Accuracy:\", accurate_predictions / count)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "xiHKnRc3uKZc"
      },
      "source": [
        "Precision of SMILES String Classification: $0.39053125340896694$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "w7wcK4qU-U1Q"
      },
      "source": [
        "### Negative Sampling Setup"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "0HrWK7D6-WZy"
      },
      "outputs": [],
      "source": [
        "all_known_edges = {}\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id.txt\", 'r') as file1:\n",
        "  with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/valid2id_original.txt\", 'r') as file2:\n",
        "    with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id_original.txt\", 'r') as file3:\n",
        "      file_list = [file1, file2, file3]\n",
        "      for i in range(3):\n",
        "        file = file_list[i]\n",
        "        for line in file:\n",
        "          parts = line.strip().split()\n",
        "          if len(parts) == 3:\n",
        "            row = (int(parts[0]), int(parts[1]), int(parts[2]))\n",
        "            # if row[0] in overlap_entity_ids and row[2] in overlap_entity_ids:\n",
        "            if row[0] not in all_known_edges.keys():\n",
        "              all_known_edges[row[0]] = []\n",
        "            if row[2] not in all_known_edges.keys():\n",
        "              all_known_edges[row[2]] = []\n",
        "            all_known_edges[row[0]].append((row[2], row[1], i))\n",
        "            all_known_edges[row[2]].append((row[0], row[1], i))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-fWq9UqaE1dc"
      },
      "outputs": [],
      "source": [
        "training_nodes_adj"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "fieHug4SEvIO"
      },
      "outputs": [],
      "source": [
        "!wc -l /content/test_file_3.txt"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Eogx5mFTHPc8"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/training_nodes_adj.pkl\", 'wb') as file:\n",
        "  pickle.dump(training_nodes_adj, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "o_WVi4_NHd45"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/test_nodes_adj.pkl\", 'wb') as file:\n",
        "  pickle.dump(test_nodes_adj, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "LGKfsfRZIwEr"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/test_nodes_adj.pkl\", 'rb') as file:\n",
        "  test_nodes_adj = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Tbm90LEn5n_0"
      },
      "outputs": [],
      "source": [
        "negative_edges_already_sampled = {}\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id.txt\", 'r') as file:\n",
        "  for line in file:\n",
        "    parts = line.strip().split()\n",
        "    if len(parts) == 3:\n",
        "      row = (int(parts[0]), int(parts[1]), int(parts[2]))\n",
        "      if row[1] == 0:\n",
        "        if row[0] not in negative_edges_already_sampled.keys():\n",
        "          negative_edges_already_sampled[row[0]] = []\n",
        "        negative_edges_already_sampled[row[0]].append(row[2])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "K0y7fWU-8Yve"
      },
      "outputs": [],
      "source": [
        "edge_list = []\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id.txt\", 'r') as file:\n",
        "  for line in file:\n",
        "    parts = line.strip().split()\n",
        "    if len(parts) == 3:\n",
        "      row = (int(parts[0]), int(parts[2]), int(parts[1]))\n",
        "      edge_list.append(row)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "_mT8vrbogpYP"
      },
      "source": [
        "### Generate Random Negatives"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "training_nodes_adj = {}\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split()\n",
        "    if len(row) == 1:\n",
        "      continue\n",
        "    row[0] = int(row[0])\n",
        "    row[1] = int(row[1])\n",
        "    row[2] = int(row[2])\n",
        "    if row[0] not in training_nodes_adj.keys():\n",
        "      training_nodes_adj[row[0]] = []\n",
        "    training_nodes_adj[row[0]].append((row[2], row[1]))"
      ],
      "metadata": {
        "id": "o290kI6vC4Qk"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Ff4fq6zJgsrt"
      },
      "outputs": [],
      "source": [
        "import random\n",
        "\n",
        "edge_list = []\n",
        "with open(\"/content/test_file_4.txt\", \"w\") as file:\n",
        "  for node in training_nodes_adj.keys():\n",
        "    for i in range(2*len(training_nodes_adj[node])):\n",
        "      random_node = random.choice(list(overlap_entity_ids))\n",
        "      while random_node in all_known_edges[node] or random_node in training_nodes_adj.keys():\n",
        "        random_node = random.choice(list(overlap_entity_ids))\n",
        "      edge_list.append((node, random_node, 0))\n",
        "    for i in training_nodes_adj[node]:\n",
        "      edge_list.append((node, i[0], i[1]))\n",
        "  random.shuffle(edge_list)\n",
        "  for edge in edge_list:\n",
        "    file.write(str(edge[0]) + \"\\t\" + str(edge[2]) + \"\\t\" + str(edge[1]) + \"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "kZsHZN8j6kt1"
      },
      "outputs": [],
      "source": [
        "import random\n",
        "\n",
        "edge_list = []\n",
        "with open(\"/content/test_file_6.txt\", \"w\") as file:\n",
        "  for node in test_nodes_adj.keys():\n",
        "    for i in range(10*len(test_nodes_adj[node])):\n",
        "      random_node = random.choice(list(overlap_entity_ids))\n",
        "      while random_node in all_known_edges[node]:\n",
        "        random_node = random.choice(list(overlap_entity_ids))\n",
        "      edge_list.append((node, random_node, 0))\n",
        "    for i in test_nodes_adj[node]:\n",
        "      edge_list.append((node, i[0], i[1]))\n",
        "  random.shuffle(edge_list)\n",
        "  for edge in edge_list:\n",
        "    file.write(str(edge[0]) + \"\\t\" + str(edge[2]) + \"\\t\" + str(edge[1]) + \"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "sMClh1ZR7If9"
      },
      "outputs": [],
      "source": [
        "!wc -l /content/test_file_4.txt"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "SXFvarSBTGRE"
      },
      "source": [
        "### Metric Testing"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "M9ihClMk1GK8"
      },
      "outputs": [],
      "source": [
        "test_triples = []\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id.txt\", 'r') as file:\n",
        "  for line in file:\n",
        "    parts = line.strip().split()\n",
        "    if len(parts) == 3:\n",
        "      test_triples.append((int(parts[0]), int(parts[1]), int(parts[2])))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "4zsTbOnzTH1m"
      },
      "outputs": [],
      "source": [
        "test_triples = []\n",
        "for node in test_nodes_adj.keys():\n",
        "  for edge in test_nodes_adj[node]:\n",
        "    test_triples.append((node, edge[1], edge[0]))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 216
        },
        "id": "xquspVGnQY8o",
        "outputId": "2420d6a5-e2a0-4e5f-b5b3-c41ef20a5798"
      },
      "outputs": [
        {
          "ename": "NameError",
          "evalue": "name 'predict' is not defined",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-967209435.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      8\u001b[0m     \u001b[0;31m# prediction = 0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m     \u001b[0;31m# if exists == 1 or exists == 0:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m     \u001b[0mprediction\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpredict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtriple\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtriple\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m     \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mprediction\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtriple\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mprediction\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mtriple\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mNameError\u001b[0m: name 'predict' is not defined"
          ]
        }
      ],
      "source": [
        "from bisect import bisect\n",
        "\n",
        "accurate_predictions = 0\n",
        "count = 0\n",
        "for triple in test_triples:\n",
        "  try:\n",
        "    # exists = predict(model, triple[0], triple[2])\n",
        "    # prediction = 0\n",
        "    # if exists == 1 or exists == 0:\n",
        "    prediction = predict(model, triple[0], triple[2])\n",
        "    print(prediction, triple[1])\n",
        "    if prediction == triple[1]:\n",
        "      accurate_predictions += 1\n",
        "    count += 1\n",
        "  except:\n",
        "    continue\n",
        "print(\"Precision:\", accurate_predictions / count)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "R8YxtXbH17u7",
        "outputId": "5830463e-f930-4d1e-a70c-318f6795244f"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\u001b[1;30;43mStreaming output truncated to the last 5000 lines.\u001b[0m\n",
            "48 15\n",
            "69 48\n",
            "48 48\n",
            "48 48\n",
            "48 15\n",
            "48 48\n",
            "8 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "37 48\n",
            "48 48\n",
            "48 48\n",
            "33 48\n",
            "48 15\n",
            "48 48\n",
            "72 48\n",
            "15 15\n",
            "48 48\n",
            "50 48\n",
            "48 48\n",
            "8 48\n",
            "48 48\n",
            "48 48\n",
            "48 15\n",
            "19 48\n",
            "31 48\n",
            "12 48\n",
            "29 48\n",
            "48 48\n",
            "19 48\n",
            "0 48\n",
            "0 48\n",
            "19 48\n",
            "48 48\n",
            "48 48\n",
            "19 48\n",
            "8 48\n",
            "48 48\n",
            "69 48\n",
            "15 15\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "19 48\n",
            "48 48\n",
            "69 48\n",
            "0 48\n",
            "0 48\n",
            "48 48\n",
            "0 48\n",
            "59 48\n",
            "19 48\n",
            "29 48\n",
            "0 48\n",
            "12 48\n",
            "48 48\n",
            "19 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "50 48\n",
            "0 48\n",
            "80 48\n",
            "48 15\n",
            "50 48\n",
            "0 48\n",
            "48 48\n",
            "48 31\n",
            "19 48\n",
            "0 48\n",
            "19 48\n",
            "29 48\n",
            "48 48\n",
            "15 48\n",
            "29 48\n",
            "0 48\n",
            "29 48\n",
            "48 48\n",
            "13 48\n",
            "0 15\n",
            "50 48\n",
            "50 48\n",
            "48 31\n",
            "48 48\n",
            "48 48\n",
            "31 48\n",
            "8 48\n",
            "0 15\n",
            "50 48\n",
            "0 48\n",
            "52 15\n",
            "15 48\n",
            "48 48\n",
            "0 48\n",
            "48 15\n",
            "48 48\n",
            "15 48\n",
            "0 48\n",
            "59 48\n",
            "0 48\n",
            "15 48\n",
            "59 48\n",
            "15 48\n",
            "48 48\n",
            "15 48\n",
            "29 48\n",
            "31 48\n",
            "19 15\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "48 48\n",
            "48 31\n",
            "19 48\n",
            "48 15\n",
            "48 48\n",
            "48 48\n",
            "29 48\n",
            "15 48\n",
            "48 48\n",
            "33 48\n",
            "69 48\n",
            "29 48\n",
            "81 48\n",
            "48 31\n",
            "19 48\n",
            "48 48\n",
            "19 15\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "8 48\n",
            "0 15\n",
            "50 48\n",
            "15 48\n",
            "0 15\n",
            "69 48\n",
            "48 48\n",
            "15 15\n",
            "19 48\n",
            "0 48\n",
            "8 48\n",
            "0 48\n",
            "48 48\n",
            "31 48\n",
            "0 48\n",
            "50 48\n",
            "80 48\n",
            "0 48\n",
            "30 48\n",
            "48 15\n",
            "48 48\n",
            "19 48\n",
            "48 48\n",
            "0 48\n",
            "50 7\n",
            "48 48\n",
            "0 48\n",
            "19 15\n",
            "29 48\n",
            "48 48\n",
            "0 15\n",
            "15 48\n",
            "8 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 7\n",
            "48 15\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "15 15\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "80 31\n",
            "15 48\n",
            "46 48\n",
            "48 48\n",
            "15 15\n",
            "74 48\n",
            "48 48\n",
            "8 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "48 48\n",
            "15 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "48 15\n",
            "81 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 59\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 15\n",
            "48 48\n",
            "37 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "59 48\n",
            "48 15\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "63 48\n",
            "48 48\n",
            "81 48\n",
            "15 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "73 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "48 15\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "80 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "72 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "15 15\n",
            "0 15\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "15 15\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "37 48\n",
            "48 48\n",
            "33 48\n",
            "48 31\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 15\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "68 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 31\n",
            "15 15\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "59 48\n",
            "46 48\n",
            "72 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "59 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 60\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "46 15\n",
            "46 7\n",
            "46 15\n",
            "1 48\n",
            "46 48\n",
            "46 48\n",
            "23 69\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "59 48\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "74 60\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "33 48\n",
            "72 48\n",
            "46 48\n",
            "50 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 15\n",
            "33 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "71 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "59 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "68 48\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 69\n",
            "46 48\n",
            "46 48\n",
            "46 32\n",
            "46 48\n",
            "80 48\n",
            "72 48\n",
            "46 48\n",
            "72 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "0 48\n",
            "1 48\n",
            "46 48\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "71 48\n",
            "0 69\n",
            "72 48\n",
            "46 48\n",
            "46 31\n",
            "59 48\n",
            "46 48\n",
            "46 48\n",
            "33 48\n",
            "72 48\n",
            "1 48\n",
            "0 48\n",
            "46 15\n",
            "46 48\n",
            "46 48\n",
            "72 48\n",
            "68 48\n",
            "80 48\n",
            "69 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "46 48\n",
            "80 48\n",
            "46 48\n",
            "80 48\n",
            "50 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 15\n",
            "33 48\n",
            "72 48\n",
            "46 48\n",
            "46 35\n",
            "0 60\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "72 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 15\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "37 48\n",
            "46 48\n",
            "73 48\n",
            "74 48\n",
            "46 48\n",
            "73 48\n",
            "48 63\n",
            "0 84\n",
            "48 48\n",
            "48 8\n",
            "48 48\n",
            "48 48\n",
            "48 84\n",
            "46 32\n",
            "48 26\n",
            "48 69\n",
            "48 48\n",
            "0 48\n",
            "0 48\n",
            "48 48\n",
            "69 63\n",
            "48 44\n",
            "48 48\n",
            "69 48\n",
            "48 48\n",
            "69 8\n",
            "46 46\n",
            "0 48\n",
            "46 48\n",
            "48 84\n",
            "48 36\n",
            "48 48\n",
            "48 48\n",
            "48 46\n",
            "48 48\n",
            "48 48\n",
            "48 46\n",
            "48 48\n",
            "48 48\n",
            "69 72\n",
            "46 48\n",
            "69 48\n",
            "48 84\n",
            "48 63\n",
            "15 48\n",
            "48 63\n",
            "48 48\n",
            "48 84\n",
            "48 48\n",
            "48 48\n",
            "48 72\n",
            "46 48\n",
            "48 48\n",
            "37 72\n",
            "48 48\n",
            "15 48\n",
            "48 63\n",
            "48 48\n",
            "69 63\n",
            "0 48\n",
            "69 63\n",
            "48 36\n",
            "46 48\n",
            "48 84\n",
            "48 48\n",
            "37 48\n",
            "48 48\n",
            "48 8\n",
            "59 48\n",
            "48 72\n",
            "48 48\n",
            "48 48\n",
            "48 65\n",
            "48 8\n",
            "48 48\n",
            "0 48\n",
            "46 48\n",
            "48 48\n",
            "48 52\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "69 48\n",
            "48 48\n",
            "48 36\n",
            "48 54\n",
            "69 48\n",
            "48 63\n",
            "48 48\n",
            "48 48\n",
            "48 84\n",
            "48 72\n",
            "48 48\n",
            "69 48\n",
            "46 8\n",
            "48 48\n",
            "48 63\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "72 8\n",
            "48 84\n",
            "0 72\n",
            "48 8\n",
            "48 48\n",
            "48 48\n",
            "59 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "48 8\n",
            "48 72\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 8\n",
            "0 72\n",
            "48 54\n",
            "48 48\n",
            "48 84\n",
            "48 63\n",
            "48 63\n",
            "69 48\n",
            "48 8\n",
            "48 72\n",
            "72 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "80 48\n",
            "48 48\n",
            "72 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "72 52\n",
            "59 46\n",
            "48 8\n",
            "48 63\n",
            "48 84\n",
            "48 48\n",
            "0 8\n",
            "0 63\n",
            "48 84\n",
            "0 48\n",
            "48 36\n",
            "59 8\n",
            "69 48\n",
            "48 48\n",
            "48 54\n",
            "48 48\n",
            "15 48\n",
            "48 48\n",
            "0 72\n",
            "48 48\n",
            "48 84\n",
            "48 48\n",
            "15 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "46 84\n",
            "69 48\n",
            "48 48\n",
            "48 8\n",
            "48 48\n",
            "48 48\n",
            "48 84\n",
            "69 48\n",
            "0 48\n",
            "36 48\n",
            "59 48\n",
            "69 48\n",
            "0 69\n",
            "15 48\n",
            "48 72\n",
            "48 48\n",
            "0 84\n",
            "48 84\n",
            "48 84\n",
            "69 84\n",
            "48 84\n",
            "69 48\n",
            "48 36\n",
            "48 48\n",
            "69 48\n",
            "46 48\n",
            "48 48\n",
            "69 52\n",
            "48 84\n",
            "48 63\n",
            "48 84\n",
            "68 63\n",
            "48 48\n",
            "48 72\n",
            "48 48\n",
            "74 48\n",
            "48 48\n",
            "48 48\n",
            "48 84\n",
            "48 8\n",
            "19 48\n",
            "48 48\n",
            "19 48\n",
            "69 48\n",
            "48 48\n",
            "48 48\n",
            "69 48\n",
            "48 48\n",
            "69 48\n",
            "15 8\n",
            "48 8\n",
            "48 63\n",
            "72 48\n",
            "48 48\n",
            "0 48\n",
            "69 8\n",
            "19 8\n",
            "48 48\n",
            "0 48\n",
            "48 84\n",
            "48 72\n",
            "48 69\n",
            "48 48\n",
            "48 48\n",
            "48 72\n",
            "48 48\n",
            "48 63\n",
            "19 48\n",
            "48 48\n",
            "48 48\n",
            "48 63\n",
            "69 48\n",
            "48 48\n",
            "69 8\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 84\n",
            "69 54\n",
            "48 54\n",
            "0 48\n",
            "72 48\n",
            "48 46\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 72\n",
            "48 84\n",
            "48 48\n",
            "69 48\n",
            "48 84\n",
            "15 48\n",
            "48 48\n",
            "48 84\n",
            "0 53\n",
            "48 13\n",
            "0 48\n",
            "48 48\n",
            "48 59\n",
            "0 53\n",
            "46 48\n",
            "48 48\n",
            "48 59\n",
            "48 36\n",
            "48 36\n",
            "48 48\n",
            "48 36\n",
            "46 36\n",
            "48 36\n",
            "74 53\n",
            "0 24\n",
            "46 13\n",
            "48 59\n",
            "48 36\n",
            "15 53\n",
            "46 59\n",
            "3 59\n",
            "48 36\n",
            "48 48\n",
            "48 53\n",
            "46 36\n",
            "0 53\n",
            "48 36\n",
            "48 13\n",
            "48 59\n",
            "48 53\n",
            "48 74\n",
            "0 24\n",
            "19 48\n",
            "15 8\n",
            "48 59\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "19 48\n",
            "36 59\n",
            "48 48\n",
            "15 24\n",
            "48 48\n",
            "48 24\n",
            "48 53\n",
            "48 59\n",
            "0 36\n",
            "48 36\n",
            "0 74\n",
            "48 53\n",
            "19 36\n",
            "48 48\n",
            "46 59\n",
            "48 59\n",
            "46 36\n",
            "48 36\n",
            "19 13\n",
            "0 53\n",
            "19 48\n",
            "0 53\n",
            "48 59\n",
            "48 48\n",
            "46 59\n",
            "48 59\n",
            "48 59\n",
            "46 36\n",
            "0 53\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 36\n",
            "48 48\n",
            "0 48\n",
            "15 53\n",
            "19 13\n",
            "48 53\n",
            "19 48\n",
            "48 36\n",
            "19 48\n",
            "48 36\n",
            "48 59\n",
            "0 48\n",
            "48 36\n",
            "48 46\n",
            "48 53\n",
            "48 36\n",
            "48 72\n",
            "46 48\n",
            "46 53\n",
            "48 48\n",
            "72 53\n",
            "19 59\n",
            "48 45\n",
            "46 72\n",
            "48 72\n",
            "48 53\n",
            "48 48\n",
            "19 36\n",
            "48 48\n",
            "0 36\n",
            "72 36\n",
            "48 36\n",
            "36 48\n",
            "48 48\n",
            "0 29\n",
            "0 36\n",
            "72 36\n",
            "48 53\n",
            "0 48\n",
            "0 74\n",
            "48 13\n",
            "48 36\n",
            "48 24\n",
            "0 48\n",
            "0 53\n",
            "19 48\n",
            "15 13\n",
            "48 36\n",
            "19 18\n",
            "48 59\n",
            "46 48\n",
            "48 59\n",
            "19 24\n",
            "0 8\n",
            "48 36\n",
            "46 48\n",
            "48 36\n",
            "48 46\n",
            "48 69\n",
            "46 48\n",
            "48 59\n",
            "46 48\n",
            "48 13\n",
            "48 48\n",
            "48 72\n",
            "48 59\n",
            "48 36\n",
            "48 48\n",
            "48 29\n",
            "46 29\n",
            "48 29\n",
            "73 59\n",
            "48 48\n",
            "0 13\n",
            "0 13\n",
            "48 53\n",
            "48 59\n",
            "19 59\n",
            "48 59\n",
            "48 59\n",
            "48 36\n",
            "48 9\n",
            "36 53\n",
            "36 48\n",
            "46 24\n",
            "46 48\n",
            "48 59\n",
            "48 59\n",
            "48 24\n",
            "0 24\n",
            "19 48\n",
            "36 59\n",
            "48 36\n",
            "48 13\n",
            "48 53\n",
            "48 36\n",
            "36 24\n",
            "48 59\n",
            "48 18\n",
            "15 59\n",
            "46 48\n",
            "48 48\n",
            "73 24\n",
            "72 46\n",
            "36 48\n",
            "48 29\n",
            "0 48\n",
            "48 59\n",
            "48 48\n",
            "48 59\n",
            "48 13\n",
            "48 59\n",
            "48 36\n",
            "48 13\n",
            "0 48\n",
            "31 59\n",
            "46 9\n",
            "73 59\n",
            "3 48\n",
            "48 48\n",
            "48 36\n",
            "3 36\n",
            "48 48\n",
            "0 48\n",
            "0 53\n",
            "46 36\n",
            "0 13\n",
            "48 53\n",
            "48 59\n",
            "48 48\n",
            "48 24\n",
            "46 24\n",
            "19 46\n",
            "0 72\n",
            "48 24\n",
            "19 53\n",
            "48 48\n",
            "48 36\n",
            "48 48\n",
            "48 8\n",
            "48 48\n",
            "72 53\n",
            "19 36\n",
            "48 36\n",
            "0 24\n",
            "0 48\n",
            "46 8\n",
            "48 13\n",
            "48 48\n",
            "0 72\n",
            "48 59\n",
            "48 8\n",
            "15 29\n",
            "48 36\n",
            "46 48\n",
            "48 13\n",
            "46 48\n",
            "3 24\n",
            "36 9\n",
            "48 36\n",
            "48 36\n",
            "48 53\n",
            "48 48\n",
            "0 36\n",
            "48 48\n",
            "46 59\n",
            "72 48\n",
            "48 48\n",
            "48 59\n",
            "46 48\n",
            "48 48\n",
            "0 36\n",
            "59 36\n",
            "48 36\n",
            "48 48\n",
            "69 59\n",
            "48 72\n",
            "48 18\n",
            "19 24\n",
            "48 29\n",
            "0 72\n",
            "48 59\n",
            "46 69\n",
            "46 48\n",
            "46 48\n",
            "80 82\n",
            "46 82\n",
            "46 82\n",
            "0 59\n",
            "46 48\n",
            "0 54\n",
            "46 9\n",
            "46 48\n",
            "0 71\n",
            "46 48\n",
            "72 48\n",
            "46 69\n",
            "46 54\n",
            "46 54\n",
            "48 59\n",
            "0 82\n",
            "46 59\n",
            "46 69\n",
            "46 48\n",
            "72 69\n",
            "46 59\n",
            "59 82\n",
            "0 59\n",
            "46 66\n",
            "59 69\n",
            "0 48\n",
            "48 48\n",
            "46 69\n",
            "48 48\n",
            "48 48\n",
            "80 82\n",
            "72 71\n",
            "48 48\n",
            "46 48\n",
            "48 50\n",
            "33 48\n",
            "50 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "50 82\n",
            "46 82\n",
            "46 82\n",
            "48 48\n",
            "46 48\n",
            "0 82\n",
            "46 54\n",
            "46 82\n",
            "46 59\n",
            "50 48\n",
            "9 54\n",
            "52 69\n",
            "46 48\n",
            "45 48\n",
            "46 82\n",
            "46 19\n",
            "46 82\n",
            "0 48\n",
            "74 82\n",
            "46 69\n",
            "50 69\n",
            "33 48\n",
            "46 82\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "14 69\n",
            "46 72\n",
            "46 48\n",
            "50 48\n",
            "0 69\n",
            "0 48\n",
            "46 29\n",
            "80 82\n",
            "46 48\n",
            "50 72\n",
            "72 48\n",
            "46 48\n",
            "46 69\n",
            "0 72\n",
            "69 72\n",
            "46 82\n",
            "33 48\n",
            "46 82\n",
            "48 82\n",
            "48 48\n",
            "46 72\n",
            "46 59\n",
            "72 59\n",
            "46 48\n",
            "0 71\n",
            "46 59\n",
            "0 48\n",
            "0 82\n",
            "37 29\n",
            "46 69\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "68 69\n",
            "46 69\n",
            "46 54\n",
            "74 69\n",
            "48 48\n",
            "46 69\n",
            "0 69\n",
            "0 48\n",
            "50 72\n",
            "0 69\n",
            "46 50\n",
            "71 69\n",
            "37 48\n",
            "48 48\n",
            "48 71\n",
            "0 50\n",
            "46 48\n",
            "46 59\n",
            "46 50\n",
            "73 71\n",
            "46 82\n",
            "46 69\n",
            "45 82\n",
            "48 59\n",
            "48 69\n",
            "46 59\n",
            "46 72\n",
            "72 69\n",
            "0 82\n",
            "50 48\n",
            "0 48\n",
            "80 82\n",
            "46 81\n",
            "46 29\n",
            "46 69\n",
            "0 54\n",
            "73 48\n",
            "46 72\n",
            "0 48\n",
            "46 69\n",
            "46 48\n",
            "46 48\n",
            "59 82\n",
            "0 59\n",
            "72 72\n",
            "46 48\n",
            "0 9\n",
            "59 69\n",
            "0 48\n",
            "58 50\n",
            "46 59\n",
            "59 48\n",
            "48 48\n",
            "48 48\n",
            "46 29\n",
            "71 82\n",
            "46 72\n",
            "80 29\n",
            "46 69\n",
            "37 69\n",
            "46 48\n",
            "0 82\n",
            "46 48\n",
            "52 48\n",
            "46 48\n",
            "48 82\n",
            "0 72\n",
            "0 59\n",
            "48 59\n",
            "74 48\n",
            "46 29\n",
            "0 54\n",
            "46 69\n",
            "46 29\n",
            "46 48\n",
            "2 48\n",
            "46 72\n",
            "48 48\n",
            "46 69\n",
            "46 48\n",
            "0 69\n",
            "46 59\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "46 72\n",
            "72 82\n",
            "48 48\n",
            "46 48\n",
            "50 59\n",
            "72 69\n",
            "46 48\n",
            "46 59\n",
            "46 48\n",
            "48 59\n",
            "46 82\n",
            "8 69\n",
            "46 48\n",
            "46 48\n",
            "46 82\n",
            "46 48\n",
            "0 48\n",
            "46 69\n",
            "0 69\n",
            "0 48\n",
            "59 48\n",
            "50 48\n",
            "46 48\n",
            "46 29\n",
            "14 48\n",
            "46 48\n",
            "46 48\n",
            "46 72\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "50 69\n",
            "72 59\n",
            "46 69\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "48 82\n",
            "46 82\n",
            "67 82\n",
            "0 59\n",
            "3 59\n",
            "72 48\n",
            "46 85\n",
            "46 9\n",
            "0 48\n",
            "46 48\n",
            "80 48\n",
            "0 48\n",
            "46 48\n",
            "46 69\n",
            "53 69\n",
            "72 48\n",
            "46 48\n",
            "46 69\n",
            "46 69\n",
            "48 54\n",
            "9 59\n",
            "37 69\n",
            "46 48\n",
            "74 71\n",
            "46 36\n",
            "46 72\n",
            "48 36\n",
            "0 48\n",
            "9 48\n",
            "59 72\n",
            "46 48\n",
            "48 48\n",
            "85 48\n",
            "59 48\n",
            "80 82\n",
            "48 59\n",
            "48 9\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "48 59\n",
            "48 69\n",
            "48 59\n",
            "48 36\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "72 69\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "37 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "48 59\n",
            "0 59\n",
            "48 59\n",
            "48 59\n",
            "0 59\n",
            "48 69\n",
            "48 69\n",
            "15 69\n",
            "48 69\n",
            "0 59\n",
            "0 59\n",
            "48 59\n",
            "48 69\n",
            "48 69\n",
            "0 69\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "0 69\n",
            "38 59\n",
            "48 59\n",
            "48 59\n",
            "29 69\n",
            "48 69\n",
            "59 59\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "13 69\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "33 69\n",
            "48 69\n",
            "48 59\n",
            "59 59\n",
            "69 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "48 69\n",
            "48 69\n",
            "48 36\n",
            "48 59\n",
            "48 59\n",
            "0 59\n",
            "48 69\n",
            "48 69\n",
            "48 59\n",
            "48 9\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "59 69\n",
            "48 59\n",
            "48 59\n",
            "48 9\n",
            "48 9\n",
            "48 59\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "33 69\n",
            "48 69\n",
            "48 69\n",
            "48 59\n",
            "48 59\n",
            "48 59\n",
            "48 69\n",
            "15 59\n",
            "48 69\n",
            "48 69\n",
            "37 69\n",
            "48 59\n",
            "0 59\n",
            "48 59\n",
            "48 59\n",
            "46 46\n",
            "48 46\n",
            "46 72\n",
            "15 46\n",
            "46 46\n",
            "0 46\n",
            "48 72\n",
            "46 74\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "15 46\n",
            "48 46\n",
            "3 72\n",
            "3 76\n",
            "15 46\n",
            "3 46\n",
            "74 46\n",
            "31 72\n",
            "14 46\n",
            "15 72\n",
            "46 46\n",
            "46 76\n",
            "46 76\n",
            "48 72\n",
            "74 72\n",
            "74 72\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "48 46\n",
            "3 46\n",
            "46 46\n",
            "74 46\n",
            "46 46\n",
            "46 48\n",
            "48 46\n",
            "74 46\n",
            "72 76\n",
            "48 46\n",
            "74 48\n",
            "46 76\n",
            "46 76\n",
            "68 46\n",
            "3 46\n",
            "48 46\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "15 46\n",
            "48 46\n",
            "46 72\n",
            "74 46\n",
            "15 46\n",
            "46 72\n",
            "15 46\n",
            "46 10\n",
            "15 46\n",
            "46 46\n",
            "46 72\n",
            "31 46\n",
            "48 46\n",
            "15 46\n",
            "46 46\n",
            "3 46\n",
            "46 10\n",
            "46 46\n",
            "46 46\n",
            "74 72\n",
            "48 72\n",
            "74 46\n",
            "74 46\n",
            "15 46\n",
            "74 46\n",
            "46 46\n",
            "3 46\n",
            "46 46\n",
            "3 46\n",
            "46 46\n",
            "3 72\n",
            "74 46\n",
            "3 72\n",
            "46 46\n",
            "75 72\n",
            "46 46\n",
            "48 46\n",
            "46 72\n",
            "46 10\n",
            "48 46\n",
            "46 46\n",
            "46 72\n",
            "48 72\n",
            "3 76\n",
            "3 46\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "3 46\n",
            "3 46\n",
            "15 46\n",
            "46 46\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "48 46\n",
            "48 72\n",
            "74 72\n",
            "48 46\n",
            "48 46\n",
            "37 46\n",
            "48 46\n",
            "48 46\n",
            "15 46\n",
            "3 46\n",
            "48 46\n",
            "48 46\n",
            "46 46\n",
            "46 74\n",
            "46 46\n",
            "46 46\n",
            "3 46\n",
            "74 46\n",
            "15 46\n",
            "46 72\n",
            "46 46\n",
            "3 46\n",
            "0 46\n",
            "46 72\n",
            "74 46\n",
            "46 46\n",
            "68 46\n",
            "46 76\n",
            "3 46\n",
            "46 46\n",
            "3 46\n",
            "46 72\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "15 10\n",
            "75 46\n",
            "31 46\n",
            "46 10\n",
            "48 46\n",
            "15 72\n",
            "48 46\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "74 46\n",
            "15 46\n",
            "46 46\n",
            "72 72\n",
            "46 72\n",
            "14 46\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "3 74\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "46 46\n",
            "3 72\n",
            "46 46\n",
            "15 46\n",
            "3 76\n",
            "3 46\n",
            "3 46\n",
            "46 46\n",
            "46 46\n",
            "74 46\n",
            "15 46\n",
            "15 46\n",
            "46 46\n",
            "74 46\n",
            "59 46\n",
            "46 72\n",
            "15 46\n",
            "15 72\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "15 10\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "15 46\n",
            "46 72\n",
            "46 10\n",
            "15 46\n",
            "46 46\n",
            "48 46\n",
            "48 72\n",
            "15 46\n",
            "48 46\n",
            "48 72\n",
            "46 46\n",
            "72 46\n",
            "46 46\n",
            "46 46\n",
            "3 10\n",
            "74 46\n",
            "46 46\n",
            "46 46\n",
            "74 72\n",
            "15 46\n",
            "37 48\n",
            "46 46\n",
            "74 46\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "15 74\n",
            "14 46\n",
            "15 46\n",
            "46 46\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "74 46\n",
            "48 46\n",
            "46 46\n",
            "3 46\n",
            "46 46\n",
            "46 46\n",
            "15 10\n",
            "14 46\n",
            "48 46\n",
            "3 72\n",
            "46 46\n",
            "46 46\n",
            "48 46\n",
            "15 46\n",
            "3 46\n",
            "46 46\n",
            "46 72\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "3 76\n",
            "15 46\n",
            "74 46\n",
            "48 46\n",
            "46 46\n",
            "3 72\n",
            "15 46\n",
            "3 46\n",
            "3 46\n",
            "74 46\n",
            "3 46\n",
            "3 46\n",
            "48 72\n",
            "46 46\n",
            "46 46\n",
            "3 46\n",
            "48 46\n",
            "3 10\n",
            "37 72\n",
            "46 72\n",
            "15 46\n",
            "46 76\n",
            "15 46\n",
            "15 46\n",
            "48 48\n",
            "15 46\n",
            "15 46\n",
            "46 46\n",
            "15 46\n",
            "46 46\n",
            "46 76\n",
            "48 46\n",
            "46 46\n",
            "48 46\n",
            "15 46\n",
            "72 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "74 72\n",
            "74 46\n",
            "46 76\n",
            "15 46\n",
            "74 46\n",
            "3 46\n",
            "46 46\n",
            "15 46\n",
            "15 46\n",
            "3 46\n",
            "46 46\n",
            "3 46\n",
            "46 46\n",
            "3 46\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "74 74\n",
            "48 46\n",
            "3 74\n",
            "46 46\n",
            "74 46\n",
            "48 46\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "74 46\n",
            "72 72\n",
            "74 46\n",
            "46 46\n",
            "46 46\n",
            "46 46\n",
            "31 46\n",
            "46 46\n",
            "48 46\n",
            "46 48\n",
            "3 46\n",
            "15 46\n",
            "46 46\n",
            "0 46\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "3 46\n",
            "48 72\n",
            "48 46\n",
            "46 46\n",
            "46 46\n",
            "48 46\n",
            "48 72\n",
            "14 46\n",
            "37 69\n",
            "48 46\n",
            "46 72\n",
            "48 48\n",
            "46 19\n",
            "0 72\n",
            "46 69\n",
            "0 46\n",
            "48 46\n",
            "0 46\n",
            "33 72\n",
            "68 46\n",
            "48 46\n",
            "48 72\n",
            "0 69\n",
            "48 46\n",
            "62 72\n",
            "48 46\n",
            "48 72\n",
            "46 72\n",
            "48 72\n",
            "0 72\n",
            "48 46\n",
            "48 46\n",
            "48 72\n",
            "62 72\n",
            "48 19\n",
            "48 72\n",
            "46 46\n",
            "48 19\n",
            "46 72\n",
            "48 72\n",
            "48 72\n",
            "0 46\n",
            "48 46\n",
            "48 46\n",
            "48 72\n",
            "46 19\n",
            "48 46\n",
            "19 72\n",
            "46 46\n",
            "48 72\n",
            "48 19\n",
            "48 76\n",
            "46 46\n",
            "48 46\n",
            "48 46\n",
            "46 72\n",
            "0 46\n",
            "15 46\n",
            "37 46\n",
            "46 46\n",
            "48 72\n",
            "48 72\n",
            "72 72\n",
            "14 72\n",
            "0 46\n",
            "0 46\n",
            "62 69\n",
            "48 72\n",
            "0 72\n",
            "48 74\n",
            "48 46\n",
            "46 46\n",
            "72 46\n",
            "48 46\n",
            "3 46\n",
            "48 72\n",
            "72 19\n",
            "48 19\n",
            "48 72\n",
            "48 19\n",
            "48 72\n",
            "0 72\n",
            "46 46\n",
            "48 46\n",
            "48 72\n",
            "48 46\n",
            "46 46\n",
            "0 46\n",
            "48 72\n",
            "46 19\n",
            "46 19\n",
            "48 46\n",
            "48 46\n",
            "19 72\n",
            "14 46\n",
            "48 46\n",
            "46 46\n",
            "14 72\n",
            "48 19\n",
            "48 46\n",
            "0 72\n",
            "46 46\n",
            "46 46\n",
            "0 46\n",
            "8 46\n",
            "3 46\n",
            "0 46\n",
            "0 46\n",
            "48 19\n",
            "0 46\n",
            "48 46\n",
            "46 69\n",
            "81 46\n",
            "48 46\n",
            "48 72\n",
            "0 46\n",
            "19 72\n",
            "81 76\n",
            "48 46\n",
            "81 19\n",
            "69 72\n",
            "73 72\n",
            "8 72\n",
            "3 76\n",
            "46 69\n",
            "46 46\n",
            "48 72\n",
            "48 46\n",
            "48 46\n",
            "0 46\n",
            "69 46\n",
            "48 46\n",
            "72 72\n",
            "0 46\n",
            "0 19\n",
            "8 46\n",
            "48 72\n",
            "48 72\n",
            "48 72\n",
            "0 72\n",
            "19 19\n",
            "3 46\n",
            "46 19\n",
            "19 19\n",
            "85 48\n",
            "48 46\n",
            "62 46\n",
            "0 46\n",
            "48 46\n",
            "48 46\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "72 69\n",
            "48 46\n",
            "62 19\n",
            "48 72\n",
            "0 46\n",
            "0 46\n",
            "46 19\n",
            "48 46\n",
            "37 46\n",
            "46 46\n",
            "48 72\n",
            "46 46\n",
            "48 72\n",
            "48 46\n",
            "48 72\n",
            "48 72\n",
            "48 46\n",
            "46 46\n",
            "0 19\n",
            "72 72\n",
            "48 46\n",
            "69 72\n",
            "48 46\n",
            "0 69\n",
            "46 46\n",
            "33 72\n",
            "48 46\n",
            "3 46\n",
            "46 72\n",
            "48 46\n",
            "48 46\n",
            "46 72\n",
            "0 46\n",
            "0 72\n",
            "48 46\n",
            "48 46\n",
            "46 46\n",
            "48 19\n",
            "0 72\n",
            "46 72\n",
            "48 72\n",
            "48 10\n",
            "19 19\n",
            "46 69\n",
            "48 46\n",
            "48 72\n",
            "0 46\n",
            "48 46\n",
            "15 72\n",
            "0 46\n",
            "19 46\n",
            "46 46\n",
            "46 72\n",
            "48 46\n",
            "46 72\n",
            "62 72\n",
            "19 46\n",
            "48 72\n",
            "48 72\n",
            "37 76\n",
            "48 72\n",
            "48 46\n",
            "48 46\n",
            "0 72\n",
            "48 46\n",
            "3 72\n",
            "46 46\n",
            "33 46\n",
            "48 46\n",
            "19 19\n",
            "0 46\n",
            "81 46\n",
            "72 46\n",
            "20 46\n",
            "0 72\n",
            "48 46\n",
            "81 19\n",
            "48 72\n",
            "48 72\n",
            "46 72\n",
            "48 46\n",
            "48 72\n",
            "46 76\n",
            "48 48\n",
            "48 19\n",
            "3 72\n",
            "3 19\n",
            "19 19\n",
            "72 46\n",
            "31 19\n",
            "48 69\n",
            "48 46\n",
            "46 46\n",
            "48 46\n",
            "0 46\n",
            "48 72\n",
            "48 46\n",
            "69 69\n",
            "33 46\n",
            "73 46\n",
            "44 69\n",
            "46 72\n",
            "48 72\n",
            "48 46\n",
            "48 46\n",
            "0 46\n",
            "81 46\n",
            "48 46\n",
            "52 46\n",
            "48 46\n",
            "33 46\n",
            "48 72\n",
            "46 46\n",
            "46 46\n",
            "19 46\n",
            "0 46\n",
            "46 72\n",
            "48 46\n",
            "48 76\n",
            "48 72\n",
            "0 76\n",
            "48 72\n",
            "48 46\n",
            "19 74\n",
            "46 69\n",
            "0 19\n",
            "48 46\n",
            "0 46\n",
            "48 72\n",
            "46 46\n",
            "62 72\n",
            "48 19\n",
            "48 19\n",
            "72 72\n",
            "19 46\n",
            "46 72\n",
            "46 72\n",
            "48 72\n",
            "46 72\n",
            "0 46\n",
            "48 69\n",
            "48 72\n",
            "48 19\n",
            "3 46\n",
            "37 46\n",
            "3 72\n",
            "15 46\n",
            "46 46\n",
            "46 46\n",
            "48 72\n",
            "0 46\n",
            "46 46\n",
            "48 46\n",
            "46 19\n",
            "15 72\n",
            "48 46\n",
            "38 72\n",
            "48 46\n",
            "48 46\n",
            "48 46\n",
            "48 46\n",
            "48 46\n",
            "19 46\n",
            "48 46\n",
            "19 19\n",
            "48 72\n",
            "14 46\n",
            "48 46\n",
            "48 46\n",
            "69 72\n",
            "44 19\n",
            "46 46\n",
            "46 69\n",
            "48 46\n",
            "19 46\n",
            "15 46\n",
            "33 72\n",
            "48 46\n",
            "8 72\n",
            "46 46\n",
            "48 72\n",
            "0 69\n",
            "46 72\n",
            "48 72\n",
            "72 72\n",
            "0 46\n",
            "0 72\n",
            "8 46\n",
            "46 46\n",
            "46 46\n",
            "36 19\n",
            "19 19\n",
            "72 72\n",
            "48 19\n",
            "46 46\n",
            "48 46\n",
            "48 72\n",
            "46 46\n",
            "46 46\n",
            "48 69\n",
            "48 69\n",
            "48 46\n",
            "0 46\n",
            "46 46\n",
            "48 19\n",
            "48 46\n",
            "48 46\n",
            "48 72\n",
            "62 46\n",
            "14 46\n",
            "46 19\n",
            "46 72\n",
            "19 69\n",
            "0 46\n",
            "0 46\n",
            "46 46\n",
            "48 19\n",
            "72 72\n",
            "8 19\n",
            "37 46\n",
            "48 69\n",
            "46 46\n",
            "72 10\n",
            "0 72\n",
            "46 48\n",
            "48 72\n",
            "46 72\n",
            "0 62\n",
            "48 76\n",
            "85 19\n",
            "72 72\n",
            "81 46\n",
            "46 46\n",
            "81 46\n",
            "46 46\n",
            "67 46\n",
            "19 19\n",
            "48 72\n",
            "48 76\n",
            "48 46\n",
            "46 72\n",
            "48 76\n",
            "48 19\n",
            "37 19\n",
            "48 46\n",
            "72 46\n",
            "48 72\n",
            "48 72\n",
            "3 46\n",
            "3 46\n",
            "3 72\n",
            "69 46\n",
            "72 46\n",
            "62 76\n",
            "48 19\n",
            "48 46\n",
            "0 46\n",
            "48 19\n",
            "48 72\n",
            "48 46\n",
            "69 72\n",
            "74 48\n",
            "0 74\n",
            "0 19\n",
            "62 19\n",
            "46 46\n",
            "33 69\n",
            "3 46\n",
            "48 46\n",
            "33 72\n",
            "48 19\n",
            "14 46\n",
            "48 46\n",
            "0 19\n",
            "62 72\n",
            "19 10\n",
            "46 46\n",
            "46 46\n",
            "19 48\n",
            "19 46\n",
            "46 46\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "19 72\n",
            "46 46\n",
            "46 72\n",
            "14 46\n",
            "19 72\n",
            "0 46\n",
            "19 72\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "0 46\n",
            "19 46\n",
            "80 72\n",
            "0 46\n",
            "48 72\n",
            "36 72\n",
            "46 48\n",
            "46 46\n",
            "0 74\n",
            "46 46\n",
            "19 46\n",
            "19 72\n",
            "19 46\n",
            "8 46\n",
            "48 72\n",
            "46 72\n",
            "0 76\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "19 72\n",
            "46 72\n",
            "19 72\n",
            "46 46\n",
            "19 46\n",
            "0 72\n",
            "19 46\n",
            "0 72\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "19 46\n",
            "19 46\n",
            "46 72\n",
            "19 46\n",
            "19 46\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "19 72\n",
            "46 46\n",
            "19 46\n",
            "72 46\n",
            "19 72\n",
            "46 46\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "30 46\n",
            "75 72\n",
            "19 72\n",
            "0 46\n",
            "46 72\n",
            "0 72\n",
            "46 46\n",
            "0 46\n",
            "68 72\n",
            "19 46\n",
            "19 48\n",
            "46 46\n",
            "19 72\n",
            "19 72\n",
            "19 46\n",
            "0 46\n",
            "3 46\n",
            "19 72\n",
            "19 72\n",
            "0 46\n",
            "0 46\n",
            "19 72\n",
            "19 74\n",
            "19 72\n",
            "0 46\n",
            "3 46\n",
            "19 46\n",
            "72 72\n",
            "19 72\n",
            "46 46\n",
            "48 72\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "19 46\n",
            "0 46\n",
            "46 72\n",
            "19 33\n",
            "80 46\n",
            "19 46\n",
            "19 72\n",
            "19 46\n",
            "46 46\n",
            "19 33\n",
            "19 46\n",
            "19 72\n",
            "19 72\n",
            "0 46\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "19 46\n",
            "46 46\n",
            "58 46\n",
            "46 46\n",
            "19 72\n",
            "0 46\n",
            "19 72\n",
            "19 74\n",
            "72 46\n",
            "58 46\n",
            "19 46\n",
            "19 46\n",
            "72 46\n",
            "68 46\n",
            "81 46\n",
            "46 46\n",
            "46 46\n",
            "46 72\n",
            "46 72\n",
            "58 46\n",
            "19 72\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "68 46\n",
            "75 46\n",
            "46 46\n",
            "75 72\n",
            "0 46\n",
            "19 72\n",
            "19 48\n",
            "19 46\n",
            "19 46\n",
            "46 72\n",
            "46 72\n",
            "46 72\n",
            "58 46\n",
            "3 46\n",
            "0 72\n",
            "0 46\n",
            "14 72\n",
            "0 72\n",
            "19 46\n",
            "46 46\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "72 46\n",
            "58 46\n",
            "46 46\n",
            "19 46\n",
            "19 72\n",
            "46 72\n",
            "19 72\n",
            "19 72\n",
            "19 46\n",
            "36 46\n",
            "19 46\n",
            "46 72\n",
            "46 46\n",
            "19 48\n",
            "35 46\n",
            "46 46\n",
            "19 46\n",
            "19 74\n",
            "0 72\n",
            "3 46\n",
            "19 46\n",
            "46 72\n",
            "3 46\n",
            "19 72\n",
            "0 46\n",
            "46 72\n",
            "46 74\n",
            "19 46\n",
            "19 72\n",
            "46 46\n",
            "46 46\n",
            "48 46\n",
            "3 46\n",
            "46 46\n",
            "19 72\n",
            "14 46\n",
            "19 72\n",
            "46 72\n",
            "46 46\n",
            "19 72\n",
            "72 72\n",
            "46 74\n",
            "72 72\n",
            "19 46\n",
            "46 46\n",
            "72 46\n",
            "30 46\n",
            "46 74\n",
            "0 46\n",
            "0 72\n",
            "19 46\n",
            "75 72\n",
            "19 46\n",
            "46 46\n",
            "46 72\n",
            "46 72\n",
            "19 46\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "46 46\n",
            "19 72\n",
            "73 72\n",
            "65 46\n",
            "46 46\n",
            "46 72\n",
            "46 74\n",
            "46 46\n",
            "19 46\n",
            "46 72\n",
            "19 74\n",
            "19 72\n",
            "46 46\n",
            "0 72\n",
            "19 72\n",
            "19 46\n",
            "46 46\n",
            "19 72\n",
            "46 46\n",
            "19 46\n",
            "48 46\n",
            "46 46\n",
            "0 72\n",
            "46 46\n",
            "19 46\n",
            "0 46\n",
            "19 46\n",
            "74 46\n",
            "46 46\n",
            "35 76\n",
            "19 46\n",
            "0 46\n",
            "0 46\n",
            "46 46\n",
            "46 48\n",
            "58 10\n",
            "46 72\n",
            "46 72\n",
            "46 72\n",
            "0 46\n",
            "19 46\n",
            "19 72\n",
            "46 46\n",
            "37 46\n",
            "19 46\n",
            "58 46\n",
            "46 72\n",
            "19 57\n",
            "58 46\n",
            "72 72\n",
            "0 72\n",
            "19 46\n",
            "46 46\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "19 46\n",
            "19 72\n",
            "37 46\n",
            "72 46\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "19 46\n",
            "19 72\n",
            "46 46\n",
            "19 46\n",
            "19 48\n",
            "30 46\n",
            "46 72\n",
            "46 76\n",
            "19 46\n",
            "3 46\n",
            "19 46\n",
            "3 46\n",
            "46 72\n",
            "19 72\n",
            "46 46\n",
            "0 46\n",
            "46 46\n",
            "46 72\n",
            "46 72\n",
            "46 46\n",
            "19 72\n",
            "19 46\n",
            "19 46\n",
            "19 46\n",
            "37 46\n",
            "0 46\n",
            "19 72\n",
            "19 46\n",
            "19 46\n",
            "46 46\n",
            "58 46\n",
            "46 46\n",
            "46 46\n",
            "19 46\n",
            "19 46\n",
            "72 72\n",
            "46 46\n",
            "72 46\n",
            "46 46\n",
            "19 46\n",
            "0 72\n",
            "19 72\n",
            "19 72\n",
            "0 72\n",
            "37 72\n",
            "46 46\n",
            "0 46\n",
            "19 72\n",
            "0 46\n",
            "46 46\n",
            "19 46\n",
            "30 46\n",
            "19 46\n",
            "46 74\n",
            "37 74\n",
            "0 72\n",
            "46 74\n",
            "0 74\n",
            "0 74\n",
            "37 74\n",
            "3 74\n",
            "33 74\n",
            "0 74\n",
            "37 74\n",
            "72 74\n",
            "37 74\n",
            "33 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "59 74\n",
            "46 74\n",
            "37 74\n",
            "46 74\n",
            "46 74\n",
            "37 74\n",
            "46 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "0 74\n",
            "0 74\n",
            "46 74\n",
            "0 74\n",
            "59 74\n",
            "37 74\n",
            "0 46\n",
            "37 74\n",
            "33 74\n",
            "59 74\n",
            "46 74\n",
            "37 74\n",
            "37 74\n",
            "0 74\n",
            "37 74\n",
            "46 74\n",
            "0 74\n",
            "37 74\n",
            "46 74\n",
            "37 74\n",
            "37 74\n",
            "72 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "59 74\n",
            "80 74\n",
            "72 74\n",
            "0 74\n",
            "0 72\n",
            "46 74\n",
            "0 74\n",
            "0 74\n",
            "0 74\n",
            "2 74\n",
            "37 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "46 74\n",
            "0 72\n",
            "37 74\n",
            "46 72\n",
            "0 74\n",
            "46 74\n",
            "0 74\n",
            "72 74\n",
            "46 74\n",
            "46 74\n",
            "0 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "37 74\n",
            "0 74\n",
            "33 74\n",
            "48 74\n",
            "36 74\n",
            "0 74\n",
            "37 74\n",
            "72 74\n",
            "19 74\n",
            "46 74\n",
            "80 74\n",
            "37 74\n",
            "46 74\n",
            "0 74\n",
            "0 74\n",
            "37 74\n",
            "59 74\n",
            "0 74\n",
            "33 74\n",
            "0 74\n",
            "46 74\n",
            "46 74\n",
            "72 74\n",
            "69 74\n",
            "2 74\n",
            "59 74\n",
            "33 74\n",
            "0 74\n",
            "0 74\n",
            "46 74\n",
            "0 74\n",
            "46 72\n",
            "46 74\n",
            "48 74\n",
            "46 74\n",
            "72 74\n",
            "0 74\n",
            "8 74\n",
            "59 74\n",
            "9 74\n",
            "46 74\n",
            "0 74\n",
            "48 72\n",
            "46 74\n",
            "59 74\n",
            "46 74\n",
            "46 74\n",
            "0 74\n",
            "37 74\n",
            "46 72\n",
            "2 74\n",
            "0 74\n",
            "37 74\n",
            "0 74\n",
            "59 74\n",
            "46 46\n",
            "72 74\n",
            "3 74\n",
            "0 72\n",
            "46 72\n",
            "67 74\n",
            "72 74\n",
            "46 74\n",
            "59 74\n",
            "72 74\n",
            "37 74\n",
            "46 74\n",
            "46 74\n",
            "8 74\n",
            "72 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "37 74\n",
            "72 74\n",
            "46 74\n",
            "72 74\n",
            "46 74\n",
            "46 74\n",
            "0 74\n",
            "37 76\n",
            "46 74\n",
            "37 74\n",
            "0 74\n",
            "81 74\n",
            "0 46\n",
            "72 74\n",
            "37 74\n",
            "0 74\n",
            "37 74\n",
            "72 46\n",
            "0 74\n",
            "0 74\n",
            "0 74\n",
            "37 74\n",
            "0 74\n",
            "0 74\n",
            "46 74\n",
            "48 74\n",
            "37 74\n",
            "72 74\n",
            "0 72\n",
            "37 74\n",
            "0 74\n",
            "59 46\n",
            "0 74\n",
            "0 74\n",
            "37 74\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "37 74\n",
            "0 74\n",
            "46 74\n",
            "0 74\n",
            "37 74\n",
            "0 72\n",
            "0 74\n",
            "46 74\n",
            "59 74\n",
            "0 74\n",
            "46 74\n",
            "37 46\n",
            "81 74\n",
            "46 74\n",
            "0 74\n",
            "0 74\n",
            "59 74\n",
            "46 74\n",
            "37 74\n",
            "37 74\n",
            "37 74\n",
            "46 74\n",
            "72 74\n",
            "0 74\n",
            "72 74\n",
            "0 74\n",
            "37 74\n",
            "72 74\n",
            "37 74\n",
            "59 74\n",
            "19 74\n",
            "72 74\n",
            "2 74\n",
            "72 74\n",
            "37 74\n",
            "46 74\n",
            "48 74\n",
            "37 74\n",
            "72 74\n",
            "72 74\n",
            "37 74\n",
            "59 74\n",
            "0 74\n",
            "46 74\n",
            "37 74\n",
            "37 10\n",
            "72 72\n",
            "0 74\n",
            "37 74\n",
            "37 74\n",
            "59 74\n",
            "2 74\n",
            "0 74\n",
            "37 74\n",
            "74 74\n",
            "69 74\n",
            "46 74\n",
            "37 74\n",
            "46 74\n",
            "72 74\n",
            "37 74\n",
            "46 74\n",
            "0 74\n",
            "24 74\n",
            "0 74\n",
            "0 74\n",
            "37 72\n",
            "37 74\n",
            "46 74\n",
            "46 74\n",
            "72 74\n",
            "59 74\n",
            "37 74\n",
            "37 74\n",
            "48 74\n",
            "72 74\n",
            "72 74\n",
            "37 74\n",
            "0 74\n",
            "36 74\n",
            "37 74\n",
            "72 74\n",
            "37 74\n",
            "81 74\n",
            "48 74\n",
            "0 74\n",
            "37 74\n",
            "46 74\n",
            "72 74\n",
            "46 74\n",
            "48 74\n",
            "37 74\n",
            "46 74\n",
            "72 74\n",
            "37 74\n",
            "37 74\n",
            "37 74\n",
            "48 74\n",
            "0 74\n",
            "14 74\n",
            "48 74\n",
            "37 74\n",
            "48 74\n",
            "80 74\n",
            "37 74\n",
            "81 74\n",
            "81 74\n",
            "37 74\n",
            "3 74\n",
            "48 74\n",
            "0 74\n",
            "59 74\n",
            "46 74\n",
            "0 74\n",
            "37 74\n",
            "48 74\n",
            "0 74\n",
            "59 74\n",
            "72 74\n",
            "72 74\n",
            "72 74\n",
            "46 74\n",
            "46 74\n",
            "0 72\n",
            "37 74\n",
            "46 74\n",
            "0 74\n",
            "0 74\n",
            "37 74\n",
            "46 74\n",
            "2 74\n",
            "46 74\n",
            "46 74\n",
            "72 74\n",
            "72 74\n",
            "46 74\n",
            "46 74\n",
            "46 74\n",
            "46 74\n",
            "37 74\n",
            "37 74\n",
            "46 74\n",
            "59 46\n",
            "37 74\n",
            "0 74\n",
            "33 74\n",
            "0 74\n",
            "37 74\n",
            "48 74\n",
            "19 74\n",
            "48 74\n",
            "48 11\n",
            "72 74\n",
            "0 74\n",
            "72 69\n",
            "46 74\n",
            "48 74\n",
            "48 10\n",
            "48 72\n",
            "48 71\n",
            "71 74\n",
            "73 74\n",
            "48 72\n",
            "48 46\n",
            "81 48\n",
            "48 48\n",
            "19 46\n",
            "48 72\n",
            "72 46\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "46 12\n",
            "19 46\n",
            "48 48\n",
            "19 72\n",
            "0 72\n",
            "46 48\n",
            "48 48\n",
            "0 48\n",
            "48 72\n",
            "46 72\n",
            "48 69\n",
            "37 48\n",
            "48 74\n",
            "19 48\n",
            "48 72\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "0 48\n",
            "52 48\n",
            "46 48\n",
            "46 48\n",
            "46 74\n",
            "3 48\n",
            "72 46\n",
            "46 48\n",
            "46 72\n",
            "46 12\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "0 72\n",
            "48 72\n",
            "68 48\n",
            "46 48\n",
            "46 46\n",
            "46 72\n",
            "0 48\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "0 66\n",
            "46 48\n",
            "72 69\n",
            "46 48\n",
            "46 48\n",
            "46 72\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "68 48\n",
            "46 66\n",
            "80 82\n",
            "48 72\n",
            "48 72\n",
            "48 13\n",
            "48 48\n",
            "48 72\n",
            "69 69\n",
            "48 48\n",
            "48 48\n",
            "72 48\n",
            "48 13\n",
            "46 48\n",
            "48 72\n",
            "48 48\n",
            "48 72\n",
            "48 82\n",
            "46 82\n",
            "48 48\n",
            "48 48\n",
            "0 13\n",
            "48 72\n",
            "33 72\n",
            "48 48\n",
            "4 72\n",
            "48 48\n",
            "72 72\n",
            "48 82\n",
            "33 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "4 13\n",
            "48 48\n",
            "0 82\n",
            "46 48\n",
            "33 48\n",
            "48 13\n",
            "48 72\n",
            "48 82\n",
            "69 82\n",
            "48 13\n",
            "69 82\n",
            "48 13\n",
            "48 84\n",
            "37 13\n",
            "46 19\n",
            "19 19\n",
            "48 19\n",
            "46 48\n",
            "48 19\n",
            "46 72\n",
            "19 19\n",
            "19 19\n",
            "48 19\n",
            "46 19\n",
            "48 19\n",
            "48 19\n",
            "46 19\n",
            "46 19\n",
            "48 72\n",
            "46 19\n",
            "48 19\n",
            "19 19\n",
            "46 19\n",
            "46 81\n",
            "48 19\n",
            "48 72\n",
            "48 72\n",
            "19 72\n",
            "19 48\n",
            "48 19\n",
            "46 81\n",
            "74 19\n",
            "48 74\n",
            "48 72\n",
            "48 19\n",
            "48 19\n",
            "19 19\n",
            "74 48\n",
            "19 19\n",
            "48 19\n",
            "46 19\n",
            "19 19\n",
            "48 19\n",
            "46 57\n",
            "46 81\n",
            "48 19\n",
            "36 81\n",
            "15 19\n",
            "48 81\n",
            "48 19\n",
            "48 72\n",
            "48 81\n",
            "48 19\n",
            "48 19\n",
            "82 19\n",
            "48 81\n",
            "48 81\n",
            "48 19\n",
            "46 19\n",
            "19 19\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "20 19\n",
            "15 19\n",
            "19 72\n",
            "48 19\n",
            "46 19\n",
            "33 72\n",
            "46 19\n",
            "4 19\n",
            "48 57\n",
            "48 19\n",
            "48 19\n",
            "74 19\n",
            "48 19\n",
            "19 48\n",
            "48 72\n",
            "48 19\n",
            "48 19\n",
            "48 81\n",
            "48 81\n",
            "46 72\n",
            "48 72\n",
            "48 19\n",
            "48 19\n",
            "4 72\n",
            "48 72\n",
            "19 48\n",
            "48 72\n",
            "48 19\n",
            "0 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "15 19\n",
            "46 19\n",
            "19 19\n",
            "19 69\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "46 19\n",
            "15 19\n",
            "19 19\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "46 19\n",
            "46 19\n",
            "72 72\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "46 48\n",
            "48 19\n",
            "48 48\n",
            "46 72\n",
            "19 19\n",
            "19 19\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "46 48\n",
            "48 19\n",
            "48 48\n",
            "48 19\n",
            "19 19\n",
            "48 72\n",
            "48 19\n",
            "19 19\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "48 72\n",
            "48 72\n",
            "19 19\n",
            "48 19\n",
            "46 19\n",
            "48 72\n",
            "46 19\n",
            "19 19\n",
            "46 19\n",
            "46 19\n",
            "72 19\n",
            "48 81\n",
            "48 48\n",
            "19 19\n",
            "46 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "46 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "48 81\n",
            "15 19\n",
            "13 19\n",
            "48 19\n",
            "46 72\n",
            "19 48\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "2 74\n",
            "72 72\n",
            "48 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "37 72\n",
            "72 72\n",
            "48 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "72 72\n",
            "72 74\n",
            "46 72\n",
            "48 74\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 72\n",
            "48 72\n",
            "72 72\n",
            "72 74\n",
            "46 72\n",
            "72 72\n",
            "48 57\n",
            "48 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "46 72\n",
            "48 72\n",
            "33 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "74 72\n",
            "46 72\n",
            "81 72\n",
            "72 72\n",
            "81 72\n",
            "48 72\n",
            "72 72\n",
            "81 72\n",
            "48 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "3 72\n",
            "72 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "73 72\n",
            "72 72\n",
            "31 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "19 74\n",
            "19 72\n",
            "48 72\n",
            "48 72\n",
            "72 74\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "81 72\n",
            "81 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "8 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "37 72\n",
            "0 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "0 74\n",
            "72 72\n",
            "20 74\n",
            "72 72\n",
            "29 72\n",
            "72 72\n",
            "72 74\n",
            "72 72\n",
            "31 74\n",
            "72 74\n",
            "72 72\n",
            "85 72\n",
            "72 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 72\n",
            "72 72\n",
            "3 72\n",
            "72 72\n",
            "48 72\n",
            "48 72\n",
            "48 72\n",
            "72 72\n",
            "72 74\n",
            "72 72\n",
            "3 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "0 74\n",
            "46 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "46 72\n",
            "4 72\n",
            "48 72\n",
            "72 72\n",
            "72 74\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "48 72\n",
            "33 72\n",
            "48 74\n",
            "72 72\n",
            "48 74\n",
            "72 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "37 72\n",
            "20 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "81 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "80 72\n",
            "72 72\n",
            "81 72\n",
            "65 72\n",
            "72 72\n",
            "72 72\n",
            "19 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "72 72\n",
            "19 72\n",
            "46 72\n",
            "14 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 72\n",
            "48 72\n",
            "72 72\n",
            "72 74\n",
            "81 72\n",
            "72 72\n",
            "19 72\n",
            "72 72\n",
            "46 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 72\n",
            "0 72\n",
            "19 72\n",
            "72 72\n",
            "48 72\n",
            "72 74\n",
            "19 72\n",
            "72 72\n",
            "48 72\n",
            "48 72\n",
            "72 72\n",
            "72 72\n",
            "0 74\n",
            "48 74\n",
            "72 72\n",
            "72 72\n",
            "0 72\n",
            "72 74\n",
            "0 74\n",
            "48 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "46 74\n",
            "72 72\n",
            "72 72\n",
            "65 74\n",
            "72 72\n",
            "72 72\n",
            "48 72\n",
            "31 74\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 74\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "46 74\n",
            "72 72\n",
            "81 74\n",
            "72 74\n",
            "72 72\n",
            "48 72\n",
            "72 72\n",
            "48 72\n",
            "37 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 74\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "48 72\n",
            "19 72\n",
            "72 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "48 74\n",
            "81 72\n",
            "48 74\n",
            "72 72\n",
            "81 72\n",
            "72 74\n",
            "72 72\n",
            "46 72\n",
            "72 74\n",
            "81 72\n",
            "72 72\n",
            "46 72\n",
            "81 72\n",
            "72 72\n",
            "72 72\n",
            "72 72\n",
            "72 74\n",
            "19 72\n",
            "72 72\n",
            "72 72\n",
            "72 33\n",
            "46 57\n",
            "0 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "0 48\n",
            "48 33\n",
            "48 72\n",
            "72 72\n",
            "0 72\n",
            "19 72\n",
            "0 72\n",
            "19 72\n",
            "48 72\n",
            "48 72\n",
            "0 74\n",
            "19 74\n",
            "37 72\n",
            "19 72\n",
            "48 72\n",
            "0 72\n",
            "37 72\n",
            "48 72\n",
            "19 48\n",
            "48 74\n",
            "0 74\n",
            "48 74\n",
            "48 57\n",
            "19 72\n",
            "0 48\n",
            "0 72\n",
            "0 72\n",
            "33 72\n",
            "59 72\n",
            "48 72\n",
            "19 72\n",
            "48 72\n",
            "48 74\n",
            "19 72\n",
            "37 74\n",
            "3 72\n",
            "48 74\n",
            "46 74\n",
            "0 72\n",
            "0 72\n",
            "59 72\n",
            "46 72\n",
            "0 72\n",
            "0 72\n",
            "19 74\n",
            "0 72\n",
            "19 74\n",
            "1 72\n",
            "0 72\n",
            "19 72\n",
            "46 72\n",
            "0 48\n",
            "48 48\n",
            "19 48\n",
            "0 48\n",
            "46 57\n",
            "48 48\n",
            "48 57\n",
            "15 46\n",
            "48 33\n",
            "48 46\n",
            "46 57\n",
            "8 57\n",
            "72 48\n",
            "73 48\n",
            "15 48\n",
            "19 74\n",
            "48 72\n",
            "48 69\n",
            "48 48\n",
            "46 23\n",
            "48 23\n",
            "48 74\n",
            "48 74\n",
            "48 48\n",
            "48 48\n",
            "19 48\n",
            "48 48\n",
            "48 48\n",
            "46 74\n",
            "48 48\n",
            "48 48\n",
            "72 74\n",
            "46 57\n",
            "48 48\n",
            "48 74\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "48 74\n",
            "48 74\n",
            "72 48\n",
            "46 48\n",
            "72 48\n",
            "48 74\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "48 23\n",
            "72 48\n",
            "19 23\n",
            "48 74\n",
            "19 48\n",
            "48 48\n",
            "46 48\n",
            "46 69\n",
            "19 48\n",
            "48 23\n",
            "46 48\n",
            "46 48\n",
            "46 74\n",
            "48 48\n",
            "48 74\n",
            "46 48\n",
            "48 74\n",
            "19 48\n",
            "19 48\n",
            "48 48\n",
            "48 23\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "72 48\n",
            "48 69\n",
            "19 48\n",
            "48 23\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "0 15\n",
            "48 15\n",
            "15 69\n",
            "48 15\n",
            "59 15\n",
            "48 15\n",
            "48 15\n",
            "33 15\n",
            "72 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "18 15\n",
            "19 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "19 15\n",
            "15 15\n",
            "59 15\n",
            "48 15\n",
            "48 15\n",
            "46 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "5 15\n",
            "0 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "59 15\n",
            "15 15\n",
            "19 15\n",
            "48 69\n",
            "48 15\n",
            "48 15\n",
            "0 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "48 48\n",
            "59 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "19 15\n",
            "48 48\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "59 15\n",
            "48 15\n",
            "48 15\n",
            "0 15\n",
            "48 15\n",
            "48 48\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "46 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "15 15\n",
            "48 15\n",
            "48 48\n",
            "19 48\n",
            "59 31\n",
            "19 15\n",
            "59 15\n",
            "15 15\n",
            "48 15\n",
            "46 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "15 15\n",
            "48 15\n",
            "19 15\n",
            "37 48\n",
            "19 15\n",
            "48 15\n",
            "15 48\n",
            "19 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "72 15\n",
            "59 15\n",
            "48 15\n",
            "59 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "19 15\n",
            "48 15\n",
            "19 74\n",
            "19 15\n",
            "0 15\n",
            "48 15\n",
            "48 15\n",
            "74 15\n",
            "48 15\n",
            "19 15\n",
            "48 72\n",
            "48 15\n",
            "48 15\n",
            "59 15\n",
            "48 15\n",
            "59 15\n",
            "59 15\n",
            "48 48\n",
            "0 15\n",
            "19 48\n",
            "48 15\n",
            "48 15\n",
            "48 15\n",
            "0 15\n",
            "19 15\n",
            "0 15\n",
            "48 15\n",
            "0 15\n",
            "69 15\n",
            "46 48\n",
            "46 28\n",
            "46 69\n",
            "46 28\n",
            "59 48\n",
            "46 82\n",
            "46 59\n",
            "48 69\n",
            "48 82\n",
            "59 48\n",
            "73 69\n",
            "2 82\n",
            "81 28\n",
            "46 28\n",
            "45 48\n",
            "46 19\n",
            "31 16\n",
            "46 48\n",
            "46 69\n",
            "46 28\n",
            "2 82\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 82\n",
            "48 48\n",
            "48 48\n",
            "46 82\n",
            "8 29\n",
            "46 48\n",
            "19 82\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "59 48\n",
            "46 59\n",
            "46 48\n",
            "9 48\n",
            "46 28\n",
            "48 28\n",
            "62 48\n",
            "48 48\n",
            "46 48\n",
            "46 28\n",
            "3 28\n",
            "59 48\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "68 48\n",
            "46 28\n",
            "46 48\n",
            "48 81\n",
            "37 48\n",
            "46 82\n",
            "46 82\n",
            "46 48\n",
            "48 28\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "35 16\n",
            "46 66\n",
            "46 28\n",
            "46 28\n",
            "48 48\n",
            "14 28\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "59 48\n",
            "46 29\n",
            "46 48\n",
            "46 48\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "26 48\n",
            "48 48\n",
            "59 28\n",
            "46 48\n",
            "48 82\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "46 82\n",
            "46 82\n",
            "31 69\n",
            "81 82\n",
            "46 48\n",
            "48 48\n",
            "46 28\n",
            "46 28\n",
            "46 82\n",
            "59 28\n",
            "46 28\n",
            "59 48\n",
            "46 82\n",
            "46 82\n",
            "46 82\n",
            "31 48\n",
            "46 48\n",
            "46 48\n",
            "62 48\n",
            "46 48\n",
            "46 59\n",
            "48 59\n",
            "46 28\n",
            "48 69\n",
            "46 28\n",
            "48 48\n",
            "46 82\n",
            "46 48\n",
            "15 82\n",
            "33 48\n",
            "46 48\n",
            "46 48\n",
            "46 82\n",
            "46 59\n",
            "46 82\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "24 48\n",
            "15 59\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "59 82\n",
            "15 28\n",
            "14 48\n",
            "46 48\n",
            "46 28\n",
            "48 48\n",
            "46 28\n",
            "46 48\n",
            "46 16\n",
            "46 48\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "46 28\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 56\n",
            "46 59\n",
            "63 28\n",
            "59 28\n",
            "46 48\n",
            "46 82\n",
            "62 59\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 82\n",
            "48 48\n",
            "48 48\n",
            "37 28\n",
            "46 28\n",
            "46 48\n",
            "59 48\n",
            "46 48\n",
            "46 82\n",
            "48 48\n",
            "46 28\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "33 28\n",
            "8 82\n",
            "46 48\n",
            "46 59\n",
            "15 82\n",
            "75 69\n",
            "46 48\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "14 28\n",
            "33 48\n",
            "48 82\n",
            "46 48\n",
            "46 69\n",
            "46 48\n",
            "46 82\n",
            "46 48\n",
            "14 69\n",
            "46 48\n",
            "48 48\n",
            "46 16\n",
            "46 69\n",
            "46 28\n",
            "46 28\n",
            "46 48\n",
            "37 48\n",
            "46 48\n",
            "81 82\n",
            "48 48\n",
            "46 82\n",
            "46 48\n",
            "62 48\n",
            "46 16\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "60 82\n",
            "0 48\n",
            "46 48\n",
            "48 82\n",
            "74 48\n",
            "46 82\n",
            "48 48\n",
            "46 82\n",
            "59 48\n",
            "59 46\n",
            "52 46\n",
            "48 46\n",
            "46 46\n",
            "12 46\n",
            "69 46\n",
            "46 72\n",
            "59 72\n",
            "81 46\n",
            "59 46\n",
            "48 17\n",
            "59 17\n",
            "69 46\n",
            "69 46\n",
            "80 46\n",
            "46 17\n",
            "46 48\n",
            "69 46\n",
            "48 48\n",
            "59 70\n",
            "69 70\n",
            "46 72\n",
            "69 17\n",
            "48 17\n",
            "48 17\n",
            "0 46\n",
            "48 17\n",
            "69 46\n",
            "0 76\n",
            "12 46\n",
            "59 17\n",
            "59 48\n",
            "46 46\n",
            "48 17\n",
            "48 17\n",
            "59 46\n",
            "52 46\n",
            "69 70\n",
            "69 48\n",
            "48 17\n",
            "69 17\n",
            "46 17\n",
            "48 46\n",
            "48 46\n",
            "48 17\n",
            "81 72\n",
            "48 46\n",
            "81 46\n",
            "69 46\n",
            "69 72\n",
            "46 46\n",
            "48 46\n",
            "59 70\n",
            "52 70\n",
            "69 46\n",
            "69 48\n",
            "46 46\n",
            "48 46\n",
            "46 46\n",
            "69 48\n",
            "59 72\n",
            "81 17\n",
            "48 46\n",
            "48 46\n",
            "59 46\n",
            "81 46\n",
            "48 17\n",
            "48 17\n",
            "69 46\n",
            "80 48\n",
            "48 48\n",
            "69 72\n",
            "69 46\n",
            "48 48\n",
            "59 48\n",
            "48 48\n",
            "69 48\n",
            "59 48\n",
            "48 63\n",
            "69 46\n",
            "48 72\n",
            "69 48\n",
            "48 46\n",
            "48 48\n",
            "69 63\n",
            "48 48\n",
            "59 48\n",
            "48 18\n",
            "48 48\n",
            "59 48\n",
            "15 46\n",
            "69 48\n",
            "48 48\n",
            "69 46\n",
            "59 48\n",
            "72 48\n",
            "72 48\n",
            "59 48\n",
            "72 46\n",
            "69 48\n",
            "69 48\n",
            "48 48\n",
            "69 48\n",
            "69 48\n",
            "15 48\n",
            "48 48\n",
            "74 48\n",
            "48 74\n",
            "48 48\n",
            "48 48\n",
            "69 48\n",
            "72 48\n",
            "48 48\n",
            "48 63\n",
            "48 48\n",
            "69 46\n",
            "48 48\n",
            "69 48\n",
            "59 48\n",
            "48 48\n",
            "69 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "69 72\n",
            "69 48\n",
            "59 48\n",
            "72 48\n",
            "69 48\n",
            "59 48\n",
            "69 46\n",
            "69 48\n",
            "69 48\n",
            "48 48\n",
            "48 63\n",
            "59 63\n",
            "59 48\n",
            "59 63\n",
            "59 48\n",
            "69 48\n",
            "59 48\n",
            "48 48\n",
            "69 46\n",
            "48 48\n",
            "69 46\n",
            "74 72\n",
            "69 48\n",
            "48 19\n",
            "73 19\n",
            "62 19\n",
            "48 19\n",
            "48 19\n",
            "0 69\n",
            "0 69\n",
            "48 19\n",
            "48 69\n",
            "48 19\n",
            "48 19\n",
            "36 19\n",
            "0 19\n",
            "48 19\n",
            "0 19\n",
            "48 19\n",
            "0 69\n",
            "48 69\n",
            "72 19\n",
            "48 19\n",
            "48 69\n",
            "74 19\n",
            "37 19\n",
            "0 19\n",
            "0 19\n",
            "48 19\n",
            "0 69\n",
            "0 19\n",
            "48 19\n",
            "46 69\n",
            "19 19\n",
            "48 19\n",
            "48 69\n",
            "46 19\n",
            "48 19\n",
            "48 19\n",
            "15 19\n",
            "74 19\n",
            "19 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "0 19\n",
            "81 19\n",
            "48 69\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "48 69\n",
            "48 69\n",
            "46 19\n",
            "48 19\n",
            "48 69\n",
            "48 19\n",
            "48 19\n",
            "20 19\n",
            "0 69\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "48 19\n",
            "48 69\n",
            "48 19\n",
            "73 19\n",
            "48 20\n",
            "33 20\n",
            "48 20\n",
            "48 20\n",
            "33 20\n",
            "48 20\n",
            "19 20\n",
            "48 56\n",
            "4 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "37 48\n",
            "46 48\n",
            "3 48\n",
            "46 48\n",
            "33 48\n",
            "0 67\n",
            "62 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "0 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 67\n",
            "46 48\n",
            "8 48\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "81 48\n",
            "46 48\n",
            "8 48\n",
            "46 59\n",
            "46 59\n",
            "46 48\n",
            "46 48\n",
            "69 48\n",
            "29 48\n",
            "46 48\n",
            "80 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "37 29\n",
            "37 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "69 48\n",
            "46 48\n",
            "46 48\n",
            "81 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 67\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "46 67\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "48 48\n",
            "46 67\n",
            "46 48\n",
            "81 48\n",
            "52 48\n",
            "46 59\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "0 59\n",
            "81 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "80 48\n",
            "48 48\n",
            "46 48\n",
            "59 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "0 29\n",
            "0 48\n",
            "33 48\n",
            "46 48\n",
            "14 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "80 48\n",
            "37 48\n",
            "37 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "59 48\n",
            "29 48\n",
            "46 48\n",
            "62 48\n",
            "46 48\n",
            "46 48\n",
            "3 48\n",
            "37 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "62 48\n",
            "46 48\n",
            "62 48\n",
            "48 48\n",
            "46 48\n",
            "0 67\n",
            "59 48\n",
            "46 48\n",
            "46 48\n",
            "46 56\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "0 48\n",
            "46 48\n",
            "46 48\n",
            "59 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "58 48\n",
            "48 48\n",
            "48 48\n",
            "46 59\n",
            "0 48\n",
            "48 48\n",
            "81 48\n",
            "46 48\n",
            "48 48\n",
            "0 59\n",
            "0 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "36 48\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "59 48\n",
            "59 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "36 48\n",
            "31 48\n",
            "59 48\n",
            "46 48\n",
            "48 48\n",
            "0 59\n",
            "29 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "46 48\n",
            "0 48\n",
            "48 48\n",
            "46 48\n",
            "0 48\n",
            "46 48\n",
            "59 48\n",
            "36 48\n",
            "48 48\n",
            "48 48\n",
            "0 48\n",
            "0 48\n",
            "46 48\n",
            "0 59\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "59 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 59\n",
            "46 59\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "0 29\n",
            "48 48\n",
            "73 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "0 48\n",
            "48 48\n",
            "5 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "46 59\n",
            "48 59\n",
            "46 48\n",
            "48 48\n",
            "48 48\n",
            "46 59\n",
            "48 48\n",
            "48 48\n",
            "33 48\n",
            "48 48\n",
            "59 48\n",
            "80 48\n",
            "0 48\n",
            "36 48\n",
            "48 48\n",
            "52 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "59 48\n",
            "48 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "46 48\n",
            "48 48\n",
            "74 44\n",
            "48 44\n",
            "48 44\n",
            "48 44\n",
            "72 44\n",
            "72 44\n",
            "48 44\n",
            "48 44\n",
            "48 44\n",
            "48 44\n",
            "48 44\n",
            "72 44\n",
            "72 44\n",
            "48 44\n",
            "0 44\n",
            "48 44\n",
            "48 44\n",
            "19 44\n",
            "48 44\n",
            "48 44\n",
            "48 44\n",
            "80 46\n",
            "46 46\n",
            "0 72\n",
            "81 46\n",
            "80 46\n",
            "69 69\n",
            "46 46\n",
            "69 46\n",
            "69 69\n",
            "59 46\n",
            "72 72\n",
            "46 69\n",
            "69 74\n",
            "46 46\n",
            "69 46\n",
            "0 46\n",
            "0 46\n",
            "81 74\n",
            "48 46\n",
            "72 46\n",
            "69 69\n",
            "81 69\n",
            "0 46\n",
            "69 46\n",
            "46 46\n",
            "48 69\n",
            "52 46\n",
            "80 46\n",
            "48 46\n",
            "46 46\n",
            "69 69\n",
            "0 46\n",
            "46 69\n",
            "46 46\n",
            "46 46\n",
            "69 69\n",
            "80 46\n",
            "0 46\n",
            "46 74\n",
            "46 46\n",
            "69 46\n",
            "46 46\n",
            "59 46\n",
            "46 46\n",
            "0 69\n",
            "69 46\n",
            "80 69\n",
            "1 46\n",
            "48 69\n",
            "46 46\n",
            "46 69\n",
            "0 46\n",
            "69 46\n",
            "80 46\n",
            "46 69\n",
            "46 46\n",
            "69 46\n",
            "46 46\n",
            "46 46\n",
            "69 46\n",
            "46 46\n",
            "69 46\n",
            "46 46\n",
            "46 46\n",
            "48 72\n",
            "46 69\n",
            "46 72\n",
            "46 46\n",
            "72 72\n",
            "37 74\n",
            "48 72\n",
            "46 46\n",
            "46 72\n",
            "46 46\n",
            "46 72\n",
            "46 72\n",
            "48 72\n",
            "46 46\n",
            "46 72\n",
            "81 74\n",
            "48 69\n",
            "37 74\n",
            "46 72\n",
            "46 72\n",
            "46 72\n",
            "14 72\n",
            "48 72\n",
            "46 72\n",
            "74 72\n",
            "46 69\n",
            "48 74\n",
            "46 72\n",
            "46 72\n",
            "46 72\n",
            "0 72\n",
            "46 72\n",
            "62 72\n",
            "14 72\n",
            "46 69\n",
            "48 74\n",
            "48 72\n",
            "3 72\n",
            "46 74\n",
            "46 72\n",
            "46 72\n",
            "46 74\n",
            "46 46\n",
            "46 72\n",
            "48 72\n",
            "48 72\n",
            "46 72\n",
            "46 72\n",
            "46 74\n",
            "48 69\n",
            "3 72\n",
            "48 74\n",
            "48 72\n",
            "59 74\n",
            "48 72\n",
            "46 46\n",
            "62 72\n",
            "46 72\n",
            "48 72\n",
            "48 72\n",
            "46 74\n",
            "46 74\n",
            "48 72\n",
            "46 46\n",
            "46 72\n",
            "48 69\n",
            "12 72\n",
            "46 74\n",
            "48 69\n",
            "48 72\n",
            "8 59\n",
            "8 72\n",
            "73 59\n",
            "31 59\n",
            "8 48\n",
            "46 59\n",
            "74 59\n",
            "8 66\n",
            "69 59\n",
            "3 72\n",
            "46 48\n",
            "8 66\n",
            "46 59\n",
            "46 66\n",
            "0 59\n",
            "3 59\n",
            "46 59\n",
            "3 48\n",
            "69 59\n",
            "69 48\n",
            "69 66\n",
            "46 72\n",
            "74 59\n",
            "8 59\n",
            "46 48\n",
            "46 48\n",
            "8 59\n",
            "59 59\n",
            "8 72\n",
            "8 66\n",
            "46 72\n",
            "8 72\n",
            "46 59\n",
            "46 59\n",
            "59 59\n",
            "8 48\n",
            "3 72\n",
            "68 72\n",
            "8 59\n",
            "69 72\n",
            "59 59\n",
            "8 72\n",
            "8 72\n",
            "46 66\n",
            "8 48\n",
            "8 66\n",
            "48 72\n",
            "46 72\n",
            "69 72\n",
            "46 59\n",
            "8 72\n",
            "46 59\n",
            "46 48\n",
            "46 59\n",
            "69 66\n",
            "59 59\n",
            "3 48\n",
            "8 59\n",
            "8 48\n",
            "8 59\n",
            "73 59\n",
            "73 59\n",
            "0 72\n",
            "69 59\n",
            "3 59\n",
            "3 59\n",
            "48 59\n",
            "48 48\n",
            "74 48\n",
            "48 74\n",
            "48 74\n",
            "48 48\n",
            "48 72\n",
            "48 71\n",
            "48 72\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "48 48\n",
            "80 69\n",
            "48 48\n",
            "52 48\n",
            "48 72\n",
            "19 71\n",
            "48 56\n",
            "72 48\n",
            "69 48\n",
            "48 48\n",
            "48 72\n",
            "37 48\n",
            "19 48\n",
            "48 69\n",
            "48 48\n",
            "48 48\n",
            "48 72\n",
            "80 69\n",
            "48 48\n",
            "48 72\n",
            "1 48\n",
            "72 74\n",
            "19 48\n",
            "0 71\n",
            "48 48\n",
            "48 72\n",
            "48 48\n",
            "82 48\n",
            "48 48\n",
            "19 48\n",
            "5 48\n",
            "54 48\n",
            "0 72\n",
            "48 48\n",
            "48 48\n",
            "19 69\n",
            "48 48\n",
            "72 72\n",
            "0 69\n",
            "80 71\n",
            "48 48\n",
            "80 48\n",
            "19 48\n",
            "48 48\n",
            "48 71\n",
            "48 48\n",
            "46 48\n",
            "46 72\n",
            "46 72\n",
            "74 48\n",
            "72 72\n",
            "46 72\n",
            "46 72\n",
            "46 72\n",
            "46 48\n",
            "46 72\n",
            "46 72\n",
            "72 72\n",
            "72 48\n",
            "46 48\n",
            "46 48\n",
            "46 48\n",
            "46 72\n",
            "46 48\n",
            "72 72\n",
            "46 79\n",
            "46 79\n",
            "19 79\n",
            "0 48\n",
            "46 79\n",
            "59 48\n",
            "69 48\n",
            "69 74\n",
            "69 72\n",
            "0 72\n",
            "0 72\n",
            "69 72\n",
            "73 72\n",
            "0 72\n",
            "69 72\n",
            "69 74\n",
            "3 72\n",
            "0 72\n",
            "15 72\n",
            "48 72\n",
            "37 72\n",
            "59 72\n",
            "59 74\n",
            "0 72\n",
            "0 72\n",
            "53 72\n",
            "0 72\n",
            "48 72\n",
            "15 74\n",
            "48 72\n",
            "8 72\n",
            "48 72\n",
            "69 72\n",
            "81 72\n",
            "69 74\n",
            "0 72\n",
            "15 72\n",
            "83 72\n",
            "73 72\n",
            "3 72\n",
            "15 72\n",
            "0 72\n",
            "0 72\n",
            "73 74\n",
            "73 72\n",
            "73 72\n",
            "73 72\n",
            "0 72\n",
            "0 72\n",
            "48 72\n",
            "0 74\n",
            "48 72\n",
            "8 72\n",
            "19 72\n",
            "0 72\n",
            "0 72\n",
            "0 72\n",
            "0 72\n",
            "59 72\n",
            "69 72\n",
            "69 57\n",
            "73 72\n",
            "69 72\n",
            "0 72\n",
            "69 72\n",
            "69 72\n",
            "69 72\n",
            "69 72\n",
            "48 72\n",
            "81 74\n",
            "69 72\n",
            "73 72\n",
            "81 72\n",
            "48 72\n",
            "15 72\n",
            "59 72\n",
            "69 72\n",
            "81 72\n",
            "69 72\n",
            "8 72\n",
            "81 72\n",
            "0 74\n",
            "15 74\n",
            "69 72\n",
            "4 74\n",
            "59 74\n",
            "0 72\n",
            "0 72\n",
            "69 72\n",
            "48 72\n",
            "59 74\n",
            "0 72\n",
            "59 72\n",
            "0 72\n",
            "69 74\n",
            "69 72\n",
            "15 72\n",
            "59 72\n",
            "0 72\n",
            "81 72\n",
            "59 72\n",
            "0 72\n",
            "29 72\n",
            "59 72\n",
            "69 74\n",
            "48 74\n",
            "0 72\n",
            "69 72\n",
            "21 72\n",
            "0 72\n",
            "73 74\n",
            "20 72\n",
            "0 72\n",
            "69 74\n",
            "59 74\n",
            "0 72\n",
            "81 72\n",
            "31 72\n",
            "69 72\n",
            "33 72\n",
            "73 72\n",
            "81 74\n",
            "0 72\n",
            "2 74\n",
            "48 72\n",
            "0 72\n",
            "8 72\n",
            "69 72\n",
            "59 72\n",
            "0 72\n",
            "69 72\n",
            "48 74\n",
            "0 72\n",
            "59 72\n",
            "8 74\n",
            "0 72\n",
            "48 72\n",
            "37 72\n",
            "0 72\n",
            "48 72\n",
            "69 72\n",
            "59 74\n",
            "15 72\n",
            "48 72\n",
            "0 72\n",
            "73 74\n",
            "0 74\n",
            "81 72\n",
            "0 72\n",
            "69 72\n",
            "0 72\n",
            "0 72\n",
            "0 72\n",
            "83 72\n",
            "8 72\n",
            "0 76\n",
            "0 72\n",
            "69 74\n",
            "48 72\n",
            "69 72\n",
            "80 72\n",
            "46 66\n",
            "48 72\n",
            "48 66\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "48 66\n",
            "48 74\n",
            "0 74\n",
            "1 69\n",
            "15 69\n",
            "15 69\n",
            "15 69\n",
            "59 69\n",
            "15 69\n",
            "0 75\n",
            "69 69\n",
            "0 75\n",
            "0 75\n",
            "48 76\n",
            "72 72\n",
            "48 75\n",
            "48 75\n",
            "74 69\n",
            "74 75\n",
            "48 72\n",
            "48 72\n",
            "48 72\n",
            "48 74\n",
            "48 74\n",
            "15 74\n",
            "8 74\n",
            "15 74\n",
            "69 74\n",
            "15 74\n",
            "46 74\n",
            "15 74\n",
            "19 74\n",
            "8 74\n",
            "46 74\n",
            "48 74\n",
            "46 74\n",
            "46 74\n",
            "48 74\n",
            "46 74\n",
            "48 74\n",
            "48 74\n",
            "48 74\n",
            "46 74\n",
            "46 74\n",
            "48 74\n",
            "48 74\n",
            "50 74\n",
            "48 74\n",
            "48 74\n",
            "75 74\n",
            "46 74\n",
            "Precision: 0.19913821315588523\n"
          ]
        }
      ],
      "source": [
        "from bisect import bisect\n",
        "\n",
        "accurate_predictions = 0\n",
        "count = 0\n",
        "for triple in test_triples:\n",
        "  try:\n",
        "    # exists = predict(model, triple[0], triple[2])\n",
        "    # prediction = 0\n",
        "    # if exists == 1 or exists == 0:\n",
        "    prediction = predict_relation(student1, bisect(overlap_entity_ids, triple[0]), bisect(overlap_entity_ids, triple[2]))\n",
        "    print(prediction, triple[1])\n",
        "    if prediction == triple[1]:\n",
        "      accurate_predictions += 1\n",
        "    count += 1\n",
        "  except:\n",
        "    continue\n",
        "print(\"Precision:\", accurate_predictions / count)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 216
        },
        "id": "jy14OOlIWA8k",
        "outputId": "f8786cb3-e16b-42a1-f211-f923379079a1"
      },
      "outputs": [
        {
          "ename": "NameError",
          "evalue": "name 'clf' is not defined",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-2154726226.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     64\u001b[0m \u001b[0;31m# test_triples = [(h1, r1, t1), (h2, r2, t2), ...]  # your locked test set\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     65\u001b[0m \u001b[0mn_rel\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m86\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 66\u001b[0;31m \u001b[0my_true\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mprobs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcollect_multiclass_scores\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mclf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_triples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mn_rel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhigher_is_better\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mT\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     67\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     68\u001b[0m \u001b[0;31m# Micro-averaged PR curve\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mNameError\u001b[0m: name 'clf' is not defined"
          ]
        }
      ],
      "source": [
        "import numpy as np\n",
        "import torch\n",
        "from sklearn.preprocessing import label_binarize\n",
        "from sklearn.metrics import precision_recall_curve, average_precision_score, auc\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "def collect_multiclass_scores(model, test_triples, n_rel, higher_is_better=True, T=None):\n",
        "    # model.eval()\n",
        "    y_true = np.array([r for (_, r, _) in test_triples], dtype=int)\n",
        "    scores = np.zeros((len(test_triples), n_rel), dtype=np.float32)\n",
        "\n",
        "    with torch.no_grad():\n",
        "        for i, (h, r, t) in enumerate(test_triples):\n",
        "            logits = predict_logits(model, h, t)\n",
        "            logits = logits if higher_is_better else -logits\n",
        "            if T is not None:\n",
        "                logits = logits / float(T)\n",
        "            scores[i, :] = logits.detach().cpu().numpy()\n",
        "\n",
        "    probs = torch.softmax(torch.from_numpy(scores), dim=1).numpy()\n",
        "    return y_true, probs\n",
        "\n",
        "def micro_pr_curve(y_true, probs, n_rel):\n",
        "    classes = np.arange(n_rel)\n",
        "    Y = label_binarize(y_true, classes=classes)  # (N, C) 0/1\n",
        "    # Micro-averaged PR curve\n",
        "    p_micro, r_micro, _ = precision_recall_curve(Y.ravel(), probs.ravel())\n",
        "    ap_micro = average_precision_score(Y, probs, average=\"micro\")\n",
        "    return r_micro, p_micro, ap_micro\n",
        "\n",
        "def per_class_pr(y_true, probs, n_rel):\n",
        "    ap_per = {}\n",
        "    curves = {}\n",
        "    for c in range(n_rel):\n",
        "        mask_pos = (y_true == c)\n",
        "        if not np.any(mask_pos):\n",
        "            ap_per[c] = np.nan\n",
        "            continue\n",
        "        y_bin = (y_true == c).astype(int)\n",
        "        y_score = probs[:, c]\n",
        "        p, r, _ = precision_recall_curve(y_bin, y_score)\n",
        "        ap = average_precision_score(y_bin, y_score)\n",
        "        ap_per[c] = ap\n",
        "        curves[c] = (r, p)\n",
        "    return ap_per, curves\n",
        "\n",
        "n_rel = 86\n",
        "y_true, probs = collect_multiclass_scores(clf, test_triples, n_rel, higher_is_better=True, T=None)\n",
        "\n",
        "r_micro, p_micro, ap_micro = micro_pr_curve(y_true, probs, n_rel)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qIKSCmtXaoZ_"
      },
      "outputs": [],
      "source": [
        "plt.figure()\n",
        "plt.plot(r_micro, p_micro, label=f\"Micro PR (AP = {ap_micro:.3f})\")\n",
        "plt.xlabel(\"Recall\"); plt.ylabel(\"Precision\")\n",
        "plt.legend(); plt.title(\"Relation classification — micro PR curve\")\n",
        "plt.grid(True, alpha=0.3)\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Zk_lxttMud11"
      },
      "source": [
        "## Case Studies"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Dapagliflozin: 426"
      ],
      "metadata": {
        "id": "_3EXema4g-iL"
      }
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "3EOJO5V0uwaX"
      },
      "source": [
        "Tamoxifen: 564"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 382
        },
        "id": "lAEaQQR1uyi2",
        "outputId": "ecdc68b6-c061-4bf7-d0e9-03cab47deb98"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "3\n",
            "48\n",
            "48\n",
            "48\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "IndexError",
          "evalue": "index out of range in self",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-2106876240.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1238\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1244\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m   \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpredict_relation\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstudent\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m426\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/torch/utils/_contextlib.py\u001b[0m in \u001b[0;36mdecorate_context\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    118\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mdecorate_context\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    119\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mctx_factory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 120\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    121\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    122\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mdecorate_context\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-3515862033.py\u001b[0m in \u001b[0;36mpredict_relation\u001b[0;34m(student1, i, j)\u001b[0m\n\u001b[1;32m      4\u001b[0m     \u001b[0mi_t\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlong\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdevice\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mDEVICE\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0mj_t\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlong\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdevice\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mDEVICE\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m     \u001b[0mlogits\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mstudent1\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpair_all_rel_logits\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mi_t\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mj_t\u001b[0m\u001b[0;34m)\u001b[0m      \u001b[0;31m# [1, n_rel]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      7\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0margmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlogits\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-654208365.py\u001b[0m in \u001b[0;36mpair_all_rel_logits\u001b[0;34m(self, head_idx, tail_idx)\u001b[0m\n\u001b[1;32m     35\u001b[0m         \u001b[0;31m# DistMult: logits[b, r] = <h_b, rel[r], t_b>\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     36\u001b[0m         \u001b[0mh\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mentity_vec\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhead_idx\u001b[0m\u001b[0;34m)\u001b[0m         \u001b[0;31m# [B, d]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 37\u001b[0;31m         \u001b[0mt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mentity_vec\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtail_idx\u001b[0m\u001b[0;34m)\u001b[0m         \u001b[0;31m# [B, d]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     38\u001b[0m         \u001b[0mht\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mh\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mt\u001b[0m                            \u001b[0;31m# [B, d]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     39\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mht\u001b[0m \u001b[0;34m@\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m              \u001b[0;31m# [B, n_rel]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-654208365.py\u001b[0m in \u001b[0;36mentity_vec\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m     29\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mentity_vec\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0midx\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mLongTensor\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m->\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mTensor\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     30\u001b[0m         \u001b[0;31m# idx: [B] indices into ehr_table\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 31\u001b[0;31m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mehr_table\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindex_select\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0midx\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# [B, d_ehr]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     32\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mencoder\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m                   \u001b[0;31m# [B, d_model]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     33\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mIndexError\u001b[0m: index out of range in self"
          ]
        }
      ],
      "source": [
        "for i in range(1238, 1244):\n",
        "  print(predict_relation(student, 426, i))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "WHs0uROIYAyu"
      },
      "source": [
        "## R-GNN/AutoSF Swap"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "qdNmSzDUdmnB",
        "outputId": "cf299603-c1a2-4e5a-ac10-2a0acc864479"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting torch_geometric\n",
            "  Downloading torch_geometric-2.7.0-py3-none-any.whl.metadata (63 kB)\n",
            "\u001b[?25l     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m0.0/63.7 kB\u001b[0m \u001b[31m?\u001b[0m eta \u001b[36m-:--:--\u001b[0m\r\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m63.7/63.7 kB\u001b[0m \u001b[31m2.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hRequirement already satisfied: aiohttp in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (3.13.0)\n",
            "Requirement already satisfied: fsspec in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (2025.3.0)\n",
            "Requirement already satisfied: jinja2 in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (3.1.6)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (2.0.2)\n",
            "Requirement already satisfied: psutil>=5.8.0 in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (5.9.5)\n",
            "Requirement already satisfied: pyparsing in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (3.2.5)\n",
            "Requirement already satisfied: requests in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (2.32.4)\n",
            "Requirement already satisfied: tqdm in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (4.67.1)\n",
            "Requirement already satisfied: xxhash in /usr/local/lib/python3.12/dist-packages (from torch_geometric) (3.6.0)\n",
            "Requirement already satisfied: aiohappyeyeballs>=2.5.0 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (2.6.1)\n",
            "Requirement already satisfied: aiosignal>=1.4.0 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (1.4.0)\n",
            "Requirement already satisfied: attrs>=17.3.0 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (25.4.0)\n",
            "Requirement already satisfied: frozenlist>=1.1.1 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (1.8.0)\n",
            "Requirement already satisfied: multidict<7.0,>=4.5 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (6.7.0)\n",
            "Requirement already satisfied: propcache>=0.2.0 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (0.4.1)\n",
            "Requirement already satisfied: yarl<2.0,>=1.17.0 in /usr/local/lib/python3.12/dist-packages (from aiohttp->torch_geometric) (1.22.0)\n",
            "Requirement already satisfied: MarkupSafe>=2.0 in /usr/local/lib/python3.12/dist-packages (from jinja2->torch_geometric) (3.0.3)\n",
            "Requirement already satisfied: charset_normalizer<4,>=2 in /usr/local/lib/python3.12/dist-packages (from requests->torch_geometric) (3.4.4)\n",
            "Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.12/dist-packages (from requests->torch_geometric) (3.11)\n",
            "Requirement already satisfied: urllib3<3,>=1.21.1 in /usr/local/lib/python3.12/dist-packages (from requests->torch_geometric) (2.5.0)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.12/dist-packages (from requests->torch_geometric) (2025.10.5)\n",
            "Requirement already satisfied: typing-extensions>=4.2 in /usr/local/lib/python3.12/dist-packages (from aiosignal>=1.4.0->aiohttp->torch_geometric) (4.15.0)\n",
            "Downloading torch_geometric-2.7.0-py3-none-any.whl (1.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m1.3/1.3 MB\u001b[0m \u001b[31m21.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: torch_geometric\n",
            "Successfully installed torch_geometric-2.7.0\n"
          ]
        }
      ],
      "source": [
        "%pip install torch_geometric"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import torch\n",
        "\n",
        "train_u = []\n",
        "train_v = []\n",
        "train_r = []\n",
        "for node in adj_list_for_overlapping_nodes.keys():\n",
        "  for edge in adj_list_for_overlapping_nodes[node]:\n",
        "    train_u.append(node)\n",
        "    train_v.append(edge[0])\n",
        "    train_r.append(edge[1])\n",
        "train_u = torch.tensor(train_u)\n",
        "train_v = torch.tensor(train_v)\n",
        "train_r = torch.tensor(train_r)"
      ],
      "metadata": {
        "id": "ocSIRNvEOvlo"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "train_u = []\n",
        "train_v = []\n",
        "train_r = []\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/train2id_negative_sampling.txt\", 'r') as file:\n",
        "  for line in file.readlines():\n",
        "    row = line.split()\n",
        "    if len(row) == 1:\n",
        "      continue\n",
        "    train_u.append(int(row[0]))\n",
        "    train_v.append(int(row[2]))\n",
        "    train_r.append(int(row[1]))\n",
        "train_u = torch.tensor(train_u)\n",
        "train_v = torch.tensor(train_v)\n",
        "train_r = torch.tensor(train_r)"
      ],
      "metadata": {
        "id": "NAZSRdqUKBKA"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-2zgo2u2-TO7"
      },
      "outputs": [],
      "source": [
        "# rgcn_linkpred_training.py\n",
        "# PyTorch Geometric ≥ 2.4, PyTorch ≥ 2.1\n",
        "\n",
        "import math, random\n",
        "from typing import Tuple\n",
        "import torch\n",
        "from torch import nn\n",
        "import torch.nn.functional as F\n",
        "\n",
        "from torch_geometric.nn import RGCNConv\n",
        "\n",
        "class RGCNEncoder(nn.Module):\n",
        "    def __init__(self, num_nodes:int, in_dim:int, hid:int, out_dim:int, num_rel:int,\n",
        "                 num_bases:int=50, use_node_feats:bool=False):\n",
        "        super().__init__()\n",
        "        self.use_node_feats = use_node_feats\n",
        "        if not use_node_feats:\n",
        "            self.emb = nn.Embedding(num_nodes, in_dim)\n",
        "            nn.init.xavier_uniform_(self.emb.weight)\n",
        "\n",
        "        self.g1 = RGCNConv(in_dim, hid, num_relations=num_rel, num_bases=num_bases)\n",
        "        self.g2 = RGCNConv(hid, out_dim, num_relations=num_rel, num_bases=num_bases)\n",
        "        self.act = nn.ReLU()\n",
        "        self.drop = nn.Dropout(0.2)\n",
        "\n",
        "    def forward(self, edge_index, edge_type, x=None):\n",
        "        x = self.emb.weight\n",
        "        h = self.drop(self.act(self.g1(x, edge_index, edge_type)))\n",
        "        h = self.g2(h, edge_index, edge_type)\n",
        "        return h  # [N, d]\n",
        "\n",
        "class RGCNEncoderWithFusion(nn.Module):\n",
        "    def __init__(self, base_encoder: RGCNEncoder, out_dim: int,\n",
        "                 Ze_overlap: torch.Tensor,\n",
        "                 overlap_entity_ids,\n",
        "                 num_nodes: int):\n",
        "        super().__init__()\n",
        "        self.base = base_encoder\n",
        "        self.register_buffer(\"ehr\", Ze_overlap.float())\n",
        "        ehr_dim = self.ehr.size(1)\n",
        "\n",
        "        node_to_ehr = torch.full((num_nodes,), -1, dtype=torch.long)\n",
        "        if isinstance(overlap_entity_ids, dict):\n",
        "            for ehr_row, drug_id in overlap_entity_ids.items():\n",
        "                if 0 <= drug_id < num_nodes:\n",
        "                    node_to_ehr[drug_id] = int(ehr_row)\n",
        "        else:\n",
        "            for ehr_row, drug_id in enumerate(overlap_entity_ids):\n",
        "                if 0 <= drug_id < num_nodes:\n",
        "                    node_to_ehr[drug_id] = int(ehr_row)\n",
        "        self.register_buffer(\"node_to_ehr\", node_to_ehr)\n",
        "\n",
        "        self.proj_ehr = nn.Linear(ehr_dim, out_dim)\n",
        "        self.gate = nn.Sequential(\n",
        "            nn.Linear(out_dim * 2, out_dim),\n",
        "            nn.ReLU(),\n",
        "            nn.Linear(out_dim, out_dim),\n",
        "            nn.Sigmoid(),\n",
        "        )\n",
        "\n",
        "    def forward(self, edge_index, edge_type, x=None):\n",
        "        H = self.base(edge_index, edge_type, x)\n",
        "        idx = self.node_to_ehr\n",
        "        mask = idx >= 0\n",
        "        if mask.any():\n",
        "            nidx = mask.nonzero(as_tuple=True)[0]\n",
        "            ehr_rows = idx[nidx]\n",
        "            z = self.ehr[ehr_rows]                          # [M, ehr_dim]\n",
        "            z_proj = self.proj_ehr(z)                       # [M, out_dim]\n",
        "            h = H[nidx]                                     # [M, out_dim]\n",
        "            g = self.gate(torch.cat([h, z_proj], dim=-1))   # [M, out_dim]\n",
        "            H = H.clone()\n",
        "            H[nidx] = g * h + (1.0 - g) * z_proj\n",
        "        return H\n",
        "\n",
        "\n",
        "class DistMultDecoder(nn.Module):\n",
        "    def __init__(self, num_rel:int, dim:int):\n",
        "        super().__init__()\n",
        "        self.rel = nn.Embedding(num_rel, dim)\n",
        "        nn.init.xavier_uniform_(self.rel.weight)\n",
        "\n",
        "    def score(self, h_u, h_v, r_id):\n",
        "        r = self.rel(r_id)                 # [B,d]\n",
        "        return (h_u * r * h_v).sum(-1)     # [B]\n",
        "\n",
        "def add_inverse_edges(edge_index, edge_type, num_rel):\n",
        "    ei_inv = edge_index.flip(0)\n",
        "    et_inv = edge_type + num_rel\n",
        "    edge_index2 = torch.cat([edge_index, ei_inv], dim=1)\n",
        "    edge_type2  = torch.cat([edge_type,  et_inv],  dim=0)\n",
        "    return edge_index2, edge_type2, num_rel * 2\n",
        "\n",
        "def batchify_edges(pos_edges:torch.Tensor, pos_types:torch.Tensor, batch_size:int, shuffle=True):\n",
        "    idx = torch.arange(pos_edges.size(1))\n",
        "    if shuffle:\n",
        "        idx = idx[torch.randperm(idx.numel())]\n",
        "    for i in range(0, idx.numel(), batch_size):\n",
        "        j = idx[i:i+batch_size]\n",
        "        yield pos_edges[:, j], pos_types[j]\n",
        "\n",
        "@torch.no_grad()\n",
        "def evaluate_rel_softmax(encoder, decoder, data, val_pairs, val_r, device, batch_size=4096):\n",
        "    encoder.eval(); decoder.eval()\n",
        "    H = encoder(data[\"edge_index\"], data[\"edge_type\"], data.get(\"x\", None))\n",
        "\n",
        "    preds = []\n",
        "    for i in range(0, val_pairs[0].numel(), batch_size):\n",
        "        sl = slice(i, i+batch_size)\n",
        "        u = val_pairs[0][sl]; v = val_pairs[1][sl]\n",
        "        logits = score_all_relations(H[u], H[v], decoder.rel.weight)   # [b,R]\n",
        "        pred_r = logits.argmax(dim=-1)\n",
        "        preds.append(pred_r)\n",
        "\n",
        "    preds = torch.cat(preds, dim=0)\n",
        "    y = val_r\n",
        "    acc = (preds == y).float().mean().item()\n",
        "\n",
        "    try:\n",
        "        from sklearn.metrics import f1_score\n",
        "        f1 = f1_score(y.cpu().numpy(), preds.cpu().numpy(), average=\"micro\")\n",
        "    except Exception:\n",
        "        f1 = float((preds == y).float().mean().item())\n",
        "\n",
        "    return {\"acc\": acc, \"f1\": f1}\n",
        "\n",
        "\n",
        "def make_negative_triples(num_nodes:int, u, v, r, k:int):\n",
        "    E = u.numel()\n",
        "    u_rep = u.repeat_interleave(k)\n",
        "    v_rep = v.repeat_interleave(k)\n",
        "    r_rep = r.repeat_interleave(k)\n",
        "    mask = torch.rand(E*k) < 0.5\n",
        "    u_rep[mask] = torch.randint(0, num_nodes, size=(int(mask.sum()),), device=u.device)\n",
        "    v_rep[~mask] = torch.randint(0, num_nodes, size=(int((~mask).sum()),), device=v.device)\n",
        "    return u_rep, v_rep, r_rep\n",
        "\n",
        "def score_all_relations(Hu, Hv, rel_weight):\n",
        "    return (Hu * Hv) @ rel_weight.t()\n",
        "\n",
        "def split_pairs(u, v, r, val_ratio=0.1, seed=42):\n",
        "    E = u.numel()\n",
        "    g = torch.Generator().manual_seed(seed)\n",
        "    idx = torch.randperm(E, generator=g)\n",
        "    n_val = int(E * val_ratio)\n",
        "    val_idx  = idx[:n_val]\n",
        "    train_idx = idx[n_val:]\n",
        "    return (u[train_idx], v[train_idx], r[train_idx]), (u[val_idx], v[val_idx], r[val_idx])\n",
        "\n",
        "(train_u, train_v, train_r), (val_u, val_v, val_r) = split_pairs(train_u, train_v, train_r, val_ratio=0.1, seed=42)\n",
        "\n",
        "\n",
        "def train_link_pred(\n",
        "    num_nodes:int,\n",
        "    edge_index:torch.Tensor,\n",
        "    edge_type:torch.Tensor,\n",
        "    train_u:torch.Tensor,\n",
        "    train_v:torch.Tensor,\n",
        "    train_r:torch.Tensor,\n",
        "    val_pos:Tuple[torch.Tensor,torch.Tensor,torch.Tensor],\n",
        "    val_neg:Tuple[torch.Tensor,torch.Tensor,torch.Tensor],\n",
        "    *,\n",
        "    in_dim=128, hid=256, out_dim=256,\n",
        "    num_rel:int=None,\n",
        "    num_bases:int=50,\n",
        "    add_inverses:bool=False,\n",
        "    k_neg:int=5,\n",
        "    batch_size:int=4096,\n",
        "    max_epochs:int=50,\n",
        "    lr:float=1e-3,\n",
        "    weight_decay:float=1e-4,\n",
        "    seed:int=1,\n",
        "    device:str=None\n",
        "):\n",
        "    torch.manual_seed(seed); random.seed(seed)\n",
        "    device = device or (\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "\n",
        "    if add_inverses:\n",
        "        edge_index, edge_type, num_rel_aug = add_inverse_edges(edge_index, edge_type, num_rel or int(edge_type.max().item()+1))\n",
        "        num_rel = num_rel_aug\n",
        "    else:\n",
        "        num_rel = num_rel or int(edge_type.max().item()+1)\n",
        "\n",
        "    data = {\n",
        "        \"edge_index\": edge_index.to(device),\n",
        "        \"edge_type\":  edge_type.to(device),\n",
        "        \"x\": None,\n",
        "    }\n",
        "\n",
        "    base_enc = RGCNEncoder(num_nodes, in_dim, hid, out_dim, num_rel,\n",
        "                       num_bases=num_bases, use_node_feats=False).to(device)\n",
        "    encoder = RGCNEncoderWithFusion(\n",
        "        base_enc, out_dim,\n",
        "        Ze_overlap if isinstance(Ze_overlap, torch.Tensor) else torch.tensor(Ze_overlap),\n",
        "        overlap_entity_ids, num_nodes\n",
        "    ).to(device)\n",
        "\n",
        "    decoder = DistMultDecoder(num_rel, out_dim).to(device)\n",
        "\n",
        "    optim = torch.optim.AdamW(list(encoder.parameters())+list(decoder.parameters()),\n",
        "                              lr=lr, weight_decay=weight_decay)\n",
        "\n",
        "    train_u = train_u.to(device); train_v = train_v.to(device); train_r = train_r.to(device)\n",
        "\n",
        "    def edge_bce_loss(pos_score, neg_score):\n",
        "        y_pos = torch.ones_like(pos_score)\n",
        "        y_neg = torch.zeros_like(neg_score)\n",
        "        logits = torch.cat([pos_score, neg_score], dim=0)\n",
        "        labels = torch.cat([y_pos, y_neg], dim=0)\n",
        "        return F.binary_cross_entropy_with_logits(logits, labels)\n",
        "\n",
        "    best = {\"epoch\": -1, \"auc\": -1, \"f1\": -1, \"state\": None}\n",
        "\n",
        "    counts = torch.bincount(train_r.cpu(), minlength=R).float()\n",
        "    freq = counts / counts.sum().clamp_min(1)\n",
        "    weights = (1.0 / freq).clamp(max=10.0)\n",
        "    weights = (weights / weights.mean()).to(device)  # normalize\n",
        "\n",
        "    for epoch in range(1, max_epochs + 1):\n",
        "        encoder.train(); decoder.train()\n",
        "        total_loss = 0.0\n",
        "\n",
        "        for pe, pr in batchify_edges(\n",
        "            pos_edges=torch.stack([train_u, train_v], dim=0),\n",
        "            pos_types=train_r,\n",
        "            batch_size=batch_size,\n",
        "            shuffle=True\n",
        "        ):\n",
        "            # fresh forward each step\n",
        "            H = encoder(data[\"edge_index\"], data[\"edge_type\"], data.get(\"x\", None))\n",
        "\n",
        "            u, v = pe[0], pe[1]\n",
        "            r = pr\n",
        "\n",
        "            logits = score_all_relations(H[u], H[v], decoder.rel.weight)  # [B,R_cls]\n",
        "            loss = F.cross_entropy(logits, r, weight=weights, label_smoothing=0.05)\n",
        "\n",
        "            optim.zero_grad()\n",
        "            loss.backward()\n",
        "            torch.nn.utils.clip_grad_norm_(list(encoder.parameters()) + list(decoder.parameters()), 1.0)\n",
        "            optim.step()\n",
        "\n",
        "            total_loss += float(loss.item())\n",
        "\n",
        "        metrics = evaluate_rel_softmax(\n",
        "            encoder, decoder, data,\n",
        "            val_pairs=(val_u, val_v),\n",
        "            val_r=val_r,\n",
        "            device=device\n",
        "        )\n",
        "        print(f\"Epoch {epoch:03d} | loss {total_loss:.3f} | val Acc {metrics['acc']:.4f} | Micro-F1 {metrics['f1']:.4f}\")\n",
        "\n",
        "        if (metrics[\"acc\"], metrics[\"f1\"]) > (best.get(\"acc\", -1), best[\"f1\"]):\n",
        "            best = {\n",
        "                \"epoch\": epoch,\n",
        "                \"acc\": metrics[\"acc\"],\n",
        "                \"f1\": metrics[\"f1\"],\n",
        "                \"state\": {\n",
        "                    \"enc\": {k: v.cpu() for k, v in encoder.state_dict().items()},\n",
        "                    \"dec\": {k: v.cpu() for k, v in decoder.state_dict().items()},\n",
        "                },\n",
        "            }\n",
        "    try:\n",
        "      print(f\"Best @ epoch {best['epoch']}: AUC={best['auc']:.4f}, F1={best['f1']:.4f}\")\n",
        "    except:\n",
        "      print(\"Errored\")\n",
        "    if best[\"state\"] is not None:\n",
        "        encoder.load_state_dict(best[\"state\"][\"enc\"])\n",
        "        decoder.load_state_dict(best[\"state\"][\"dec\"])\n",
        "    return encoder, decoder, best"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "with open(\"/content/test_file_4.txt\", 'w') as file:\n",
        "  for node in all_known_edges.keys():\n",
        "    for edge in all_known_edges[node]:\n",
        "      file.write(str(node) + \"\\t\" + str(edge[1]) + \"\\t\" + str(edge[0]) + \"\\n\")"
      ],
      "metadata": {
        "id": "dXPVqGCSS48C"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "!wc -l /content/test_file_4.txt"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Pwy-yw3GcJ75",
        "outputId": "00aec9ee-8253-4e59-cb0a-4a279901e754"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "259946 /content/test_file_4.txt\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "0Gy6EiZKcD1k",
        "outputId": "d2a4f221-0b90-4a81-ab51-0b3b925e54e2"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 001 | loss 102.842 | val Acc 0.7959 | Micro-F1 0.7959\n",
            "Epoch 002 | loss 44.343 | val Acc 0.8773 | Micro-F1 0.8773\n",
            "Epoch 003 | loss 36.584 | val Acc 0.9091 | Micro-F1 0.9091\n",
            "Epoch 004 | loss 33.617 | val Acc 0.9250 | Micro-F1 0.9250\n",
            "Epoch 005 | loss 31.761 | val Acc 0.9374 | Micro-F1 0.9374\n",
            "Epoch 006 | loss 30.573 | val Acc 0.9467 | Micro-F1 0.9467\n",
            "Epoch 007 | loss 29.687 | val Acc 0.9518 | Micro-F1 0.9518\n",
            "Epoch 008 | loss 28.992 | val Acc 0.9580 | Micro-F1 0.9580\n",
            "Epoch 009 | loss 28.416 | val Acc 0.9625 | Micro-F1 0.9625\n",
            "Epoch 010 | loss 27.888 | val Acc 0.9680 | Micro-F1 0.9680\n",
            "Errored\n"
          ]
        }
      ],
      "source": [
        "if __name__ == \"__main__\":\n",
        "    num_nodes = 1_710\n",
        "    R = 86  # or 88, etc.\n",
        "\n",
        "    E = 38419\n",
        "    torch.manual_seed(1)\n",
        "    edge_index_list = []\n",
        "    edge_type_list = []\n",
        "    for i in range(len(train_u)):\n",
        "        edge_index_list.append((train_u[i], train_v[i]))\n",
        "        edge_type_list.append(int(train_r[i]))\n",
        "    edge_index_train = torch.tensor(edge_index_list).T\n",
        "    edge_type_train  = torch.tensor(edge_type_list)\n",
        "\n",
        "    # Positives for loss (here: all training edges)\n",
        "    train_u, train_v = edge_index_train[0], edge_index_train[1]\n",
        "    train_r = edge_type_train\n",
        "\n",
        "    # Val: sample 5k positives and 5k corrupted negatives\n",
        "    idx = torch.randperm(E)\n",
        "    val_pos = (train_u[idx], train_v[idx], train_r[idx])\n",
        "    val_neg = make_negative_triples(num_nodes, val_pos[0], val_pos[1], val_pos[2], k=10)\n",
        "\n",
        "    encoder, decoder, best = train_link_pred(\n",
        "        num_nodes=num_nodes,\n",
        "        edge_index=edge_index_train,\n",
        "        edge_type=edge_type_train,\n",
        "        train_u=train_u, train_v=train_v, train_r=train_r,\n",
        "        val_pos=val_pos, val_neg=val_neg,\n",
        "        in_dim=128, hid=256, out_dim=256,\n",
        "        num_rel=R,\n",
        "        num_bases=50,\n",
        "        add_inverses=False,       # set True if you intentionally add inverse edges\n",
        "        k_neg=5,\n",
        "        batch_size=4096,\n",
        "        max_epochs=10,            # bump to 50–200 for real runs\n",
        "        lr=1e-3,\n",
        "        weight_decay=1e-4,\n",
        "        seed=1\n",
        "    )"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qjXEWSlu3nWY"
      },
      "outputs": [],
      "source": [
        "dev = next(encoder.parameters()).device\n",
        "H = encoder(edge_index_train.to(dev), edge_type_train.to(dev))"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "with open(\"/content/test_file_6.txt\", 'w') as file:\n",
        "  for node in test_nodes_adj.keys():\n",
        "    for edge in test_nodes_adj[node]:\n",
        "      file.write(str(node) + \"\\t\" + str(edge[1]) + \"\\t\" + str(edge[0]) + \"\\n\")"
      ],
      "metadata": {
        "id": "QMrt5hw6VIuj"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/KG_Data/DrugBank/test2id_original.txt\", 'r') as file:\n",
        "  with open(\"/content/test_file_5.txt\", 'w') as file2:\n",
        "    count = 0\n",
        "    accurate_predictions = 0\n",
        "    for line in file:\n",
        "      parts = line.strip().split()\n",
        "      if len(parts) == 3:\n",
        "        try:\n",
        "          head = int(parts[0])\n",
        "          relation = int(parts[1])\n",
        "          tail = int(parts[2])\n",
        "          # logits for ALL relations: [E, R_cls]\n",
        "          logits = (H[head] * H[tail]) @ decoder.rel.weight.t()\n",
        "          exists = logits.argmax(dim=-1)\n",
        "          # if exists == 1:\n",
        "          #   exists = predict_relation(student, bisect(overlap_entity_ids, head)-1, bisect(overlap_entity_ids, tail)-1)\n",
        "          # else:\n",
        "          #   exists = 0\n",
        "          print(exists, relation)\n",
        "          if int(exists) == relation:\n",
        "            accurate_predictions += 1\n",
        "          count += 1\n",
        "          file2.write(f\"{exists}\\t{relation}\\n\")\n",
        "        except:\n",
        "          continue\n",
        "print(accurate_predictions/count)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "KdYzfF8O7ql1",
        "outputId": "c3338caf-e0bf-480f-fd85-7ccdc4dbb0d4"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\u001b[1;30;43mStreaming output truncated to the last 5000 lines.\u001b[0m\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(57) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(20) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(81) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(31) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(33) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(59) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(69) 72\n",
            "tensor(69) 72\n",
            "tensor(5) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(47) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(20) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(15) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(59) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(66) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(59) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(59) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(70) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(24) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(81) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(24) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(69) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(81) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(29) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(57) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(17) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(69) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(32) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(69) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(74) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(48) 72\n",
            "tensor(19) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(69) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(56) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(32) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(29) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(69) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(48) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(3) 72\n",
            "tensor(74) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(48) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(46) 72\n",
            "tensor(72) 72\n",
            "tensor(72) 72\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(69) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(69) 73\n",
            "tensor(74) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(72) 73\n",
            "tensor(73) 73\n",
            "tensor(48) 73\n",
            "tensor(73) 73\n",
            "tensor(48) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(74) 73\n",
            "tensor(74) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(46) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(79) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(48) 73\n",
            "tensor(48) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(72) 73\n",
            "tensor(8) 73\n",
            "tensor(69) 73\n",
            "tensor(48) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(72) 73\n",
            "tensor(48) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(73) 73\n",
            "tensor(8) 73\n",
            "tensor(69) 73\n",
            "tensor(46) 73\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(48) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(5) 74\n",
            "tensor(72) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(20) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(48) 74\n",
            "tensor(69) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(57) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(66) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(48) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(46) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(19) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(48) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(59) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(82) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(46) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(63) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(69) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(3) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(48) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(46) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(15) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(32) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(63) 74\n",
            "tensor(74) 74\n",
            "tensor(32) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(80) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(10) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(63) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(76) 74\n",
            "tensor(72) 74\n",
            "tensor(3) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(75) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(57) 74\n",
            "tensor(74) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(19) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(66) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(48) 74\n",
            "tensor(72) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(32) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(75) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(71) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(46) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(3) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(48) 74\n",
            "tensor(19) 74\n",
            "tensor(69) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(57) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 74\n",
            "tensor(74) 74\n",
            "tensor(74) 74\n",
            "tensor(72) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(74) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(46) 75\n",
            "tensor(74) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(72) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(74) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(69) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(74) 75\n",
            "tensor(48) 75\n",
            "tensor(69) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(74) 75\n",
            "tensor(72) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(72) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(48) 75\n",
            "tensor(69) 75\n",
            "tensor(66) 75\n",
            "tensor(48) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(69) 75\n",
            "tensor(69) 75\n",
            "tensor(48) 75\n",
            "tensor(48) 75\n",
            "tensor(69) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(75) 75\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(1) 76\n",
            "tensor(76) 76\n",
            "tensor(72) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(48) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(48) 76\n",
            "tensor(46) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(48) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(74) 76\n",
            "tensor(76) 76\n",
            "tensor(46) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(69) 76\n",
            "tensor(76) 76\n",
            "tensor(48) 76\n",
            "tensor(3) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(76) 76\n",
            "tensor(77) 77\n",
            "tensor(72) 77\n",
            "tensor(72) 77\n",
            "tensor(77) 77\n",
            "tensor(77) 77\n",
            "tensor(48) 78\n",
            "tensor(48) 78\n",
            "tensor(48) 78\n",
            "tensor(72) 78\n",
            "tensor(48) 78\n",
            "tensor(46) 79\n",
            "tensor(79) 79\n",
            "tensor(79) 79\n",
            "tensor(72) 79\n",
            "tensor(79) 79\n",
            "tensor(79) 79\n",
            "tensor(74) 79\n",
            "tensor(46) 79\n",
            "tensor(79) 79\n",
            "tensor(72) 79\n",
            "tensor(79) 79\n",
            "tensor(79) 79\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(48) 80\n",
            "tensor(48) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(48) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(69) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(80) 80\n",
            "tensor(48) 81\n",
            "tensor(46) 81\n",
            "tensor(69) 81\n",
            "tensor(72) 81\n",
            "tensor(19) 81\n",
            "tensor(57) 81\n",
            "tensor(81) 81\n",
            "tensor(72) 81\n",
            "tensor(81) 81\n",
            "tensor(57) 81\n",
            "tensor(33) 81\n",
            "tensor(48) 81\n",
            "tensor(48) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(20) 81\n",
            "tensor(69) 81\n",
            "tensor(48) 81\n",
            "tensor(19) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(72) 81\n",
            "tensor(74) 81\n",
            "tensor(81) 81\n",
            "tensor(46) 81\n",
            "tensor(57) 81\n",
            "tensor(81) 81\n",
            "tensor(74) 81\n",
            "tensor(81) 81\n",
            "tensor(74) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(48) 81\n",
            "tensor(57) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(74) 81\n",
            "tensor(72) 81\n",
            "tensor(48) 81\n",
            "tensor(74) 81\n",
            "tensor(20) 81\n",
            "tensor(72) 81\n",
            "tensor(69) 81\n",
            "tensor(69) 81\n",
            "tensor(48) 81\n",
            "tensor(48) 81\n",
            "tensor(53) 81\n",
            "tensor(74) 81\n",
            "tensor(69) 81\n",
            "tensor(15) 81\n",
            "tensor(81) 81\n",
            "tensor(19) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(66) 81\n",
            "tensor(48) 81\n",
            "tensor(72) 81\n",
            "tensor(81) 81\n",
            "tensor(19) 81\n",
            "tensor(69) 81\n",
            "tensor(69) 81\n",
            "tensor(72) 81\n",
            "tensor(48) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(81) 81\n",
            "tensor(57) 81\n",
            "tensor(74) 81\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(74) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(72) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(72) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(19) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(19) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(28) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(72) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(19) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(19) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(74) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(28) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(72) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(72) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(72) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(74) 82\n",
            "tensor(82) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(82) 82\n",
            "tensor(28) 82\n",
            "tensor(69) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(48) 82\n",
            "tensor(48) 82\n",
            "tensor(82) 82\n",
            "tensor(83) 83\n",
            "tensor(83) 83\n",
            "tensor(48) 83\n",
            "tensor(48) 83\n",
            "tensor(83) 83\n",
            "tensor(74) 83\n",
            "tensor(72) 83\n",
            "tensor(83) 83\n",
            "tensor(83) 83\n",
            "tensor(72) 83\n",
            "tensor(74) 83\n",
            "tensor(69) 83\n",
            "tensor(83) 83\n",
            "tensor(84) 84\n",
            "tensor(46) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(69) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(19) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(69) 84\n",
            "tensor(74) 84\n",
            "tensor(74) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(72) 84\n",
            "tensor(19) 84\n",
            "tensor(48) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(19) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(75) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(84) 84\n",
            "tensor(74) 84\n",
            "tensor(84) 84\n",
            "tensor(15) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(70) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(72) 84\n",
            "tensor(48) 84\n",
            "tensor(72) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(72) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(84) 84\n",
            "tensor(48) 84\n",
            "tensor(69) 85\n",
            "tensor(85) 85\n",
            "tensor(69) 85\n",
            "tensor(85) 85\n",
            "tensor(85) 85\n",
            "0.7675108670189229\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "XxiO72QcnuMC"
      },
      "source": [
        "# GNN Classification"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "YagzfVn3hGOc"
      },
      "source": [
        "## Define the GNN model"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "8EGgghJdQhwW"
      },
      "source": [
        "### Define classes"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wxmy99ipcqz2",
        "outputId": "6119f203-f0d8-4f2a-ebcd-7a3c1af50de9"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models\n"
          ]
        }
      ],
      "source": [
        "%cd \"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/AutoSF/AutoSF_models\""
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "l7MPYzaRg2-l"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import torch.nn as nn\n",
        "\n",
        "class KGEModule(nn.Module):\n",
        "    def __init__(self, n_ent, n_rel, args, struct):\n",
        "        super(KGEModule, self).__init__()\n",
        "        self.n_ent = n_ent\n",
        "        self.n_rel = n_rel\n",
        "        self.args = args\n",
        "        self.struct = struct\n",
        "        self.lamb = args.lamb\n",
        "        self.loss = torch.nn.Softplus().cuda()\n",
        "        self.ent_embed = nn.Embedding(n_ent, args.n_dim)\n",
        "        self.rel_embed = nn.Embedding(n_rel, args.n_dim)\n",
        "        self.init_weight()\n",
        "\n",
        "    def init_weight(self):\n",
        "        for param in self.parameters():\n",
        "            nn.init.xavier_uniform_(param.data)\n",
        "\n",
        "    def forward(self, head, tail, rela, dropout=True):\n",
        "        head = head.view(-1)\n",
        "        tail = tail.view(-1)\n",
        "        rela = rela.view(-1)\n",
        "\n",
        "        head_embed = self.ent_embed(head)\n",
        "        tail_embed = self.ent_embed(tail)\n",
        "        rela_embed = self.rel_embed(rela)\n",
        "\n",
        "        # get f = h' R t\n",
        "\n",
        "        pos_trip = self.test_trip(head_embed, rela_embed, tail_embed)\n",
        "\n",
        "        neg_tail = self.test_tail(head_embed, rela_embed)\n",
        "        neg_head = self.test_head(rela_embed, tail_embed)\n",
        "\n",
        "        max_t = torch.max(neg_tail, 1, keepdim=True)[0]\n",
        "        max_h = torch.max(neg_head, 1, keepdim=True)[0]\n",
        "\n",
        "        # multi-class loss: negative loglikelihood\n",
        "        loss = - 2*pos_trip + max_t + torch.log(torch.sum(torch.exp(neg_tail - max_t), 1)) +\\\n",
        "               max_h + torch.log(torch.sum(torch.exp(neg_head - max_h), 1))\n",
        "        self.regul = torch.sum(rela_embed**2)\n",
        "\n",
        "        return torch.sum(loss)\n",
        "\n",
        "    def test_trip(self, head, rela, tail):\n",
        "        vec_hr = self.get_hr(head, rela)\n",
        "        scores = torch.sum(vec_hr * tail, 1)\n",
        "        return scores\n",
        "\n",
        "    def test_tail(self, head, rela):\n",
        "        vec_hr = self.get_hr(head, rela)\n",
        "        tail_embed = self.ent_embed.weight\n",
        "        scores = torch.mm(vec_hr, tail_embed.transpose(1,0))\n",
        "        return scores\n",
        "\n",
        "    def test_head(self, rela, tail):\n",
        "        vec_rt = self.get_rt(rela, tail)\n",
        "        head_embed = self.ent_embed.weight\n",
        "        scores = torch.mm(vec_rt, head_embed.transpose(1,0))\n",
        "        return scores\n",
        "\n",
        "    def get_hr(self, head, rela):\n",
        "        idx = tuple(self.struct)\n",
        "        length = self.args.n_dim // 4\n",
        "        h1 = head[:, :length]\n",
        "        r1 = rela[:, :length]\n",
        "\n",
        "        h2 = head[:, 1*length:2*length]\n",
        "        r2 = rela[:, 1*length:2*length]\n",
        "\n",
        "        h3 = head[:, 2*length:3*length]\n",
        "        r3 = rela[:, 2*length:3*length]\n",
        "\n",
        "        h4 = head[:, 3*length:4*length]\n",
        "        r4 = rela[:, 3*length:4*length]\n",
        "\n",
        "        hs = [h1, h2, h3, h4]\n",
        "        rs = [r1, r2, r3, r4]\n",
        "\n",
        "        vs = [0, 0, 0, 0]\n",
        "        vs[idx[0]] = h1*r1\n",
        "        vs[idx[1]] = h2*r2\n",
        "        vs[idx[2]] = h3*r3\n",
        "        vs[idx[3]] = h4*r4\n",
        "\n",
        "        res_B = (len(idx)-4)//4\n",
        "        for b_ in range(1, res_B+1):\n",
        "            base = 4*b_\n",
        "            vs[idx[base+2]] += rs[idx[base+0]] * hs[idx[base+1]] * int(idx[base+3])\n",
        "        return torch.cat(vs, 1)\n",
        "\n",
        "    def get_rt(self, rela, tail):\n",
        "        idx = tuple(self.struct)\n",
        "        length = self.args.n_dim // 4\n",
        "        t1 = tail[:, :length]\n",
        "        r1 = rela[:, :length]\n",
        "\n",
        "        t2 = tail[:, 1*length:2*length]\n",
        "        r2 = rela[:, 1*length:2*length]\n",
        "\n",
        "        t3 = tail[:, 2*length:3*length]\n",
        "        r3 = rela[:, 2*length:3*length]\n",
        "\n",
        "        t4 = tail[:, 3*length:4*length]\n",
        "        r4 = rela[:, 3*length:4*length]\n",
        "\n",
        "        ts = [t1, t2, t3, t4]\n",
        "        rs = [r1, r2, r3, r4]\n",
        "\n",
        "        vs = [r1*ts[idx[0]], r2*ts[idx[1]], r3*ts[idx[2]], r4*ts[idx[3]]]\n",
        "\n",
        "        res_B = (len(idx)-4) // 4\n",
        "        for b_ in range(1, res_B+1):\n",
        "            base = 4*b_\n",
        "            vs[idx[base+1]] += rs[idx[base+0]] * ts[idx[base+2]] * int(idx[base+3])\n",
        "        return torch.cat(vs, 1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "E1tLZsDEiT3K"
      },
      "outputs": [],
      "source": [
        "import argparse\n",
        "\n",
        "parser = argparse.ArgumentParser(description=\"Parser for AutoSF\")\n",
        "\n",
        "parser.add_argument('--task_dir', type=str, default='KG_Data/DrugBank', help='the directory to dataset')\n",
        "parser.add_argument('--optim', type=str, default='adagrad', help='optimization method')\n",
        "parser.add_argument('--lamb', type=float, default=0.2, help='set weight decay value')\n",
        "parser.add_argument('--decay_rate', type=float, default=1.0, help='set learning rate decay value')\n",
        "parser.add_argument('--n_dim', type=int, default=64, help='set embedding dimension')\n",
        "parser.add_argument('--parrel', type=int, default=4, help='set gpu #')\n",
        "parser.add_argument('--lr', type=float, default=0.5, help='set learning rate')\n",
        "parser.add_argument('--thres', type=float, default=0.0, help='threshold for early stopping')\n",
        "parser.add_argument('--n_epoch', type=int, default=150, help='number of training epochs')\n",
        "# parser.add_argument('--n_epoch', type=int, default=100, help='number of training epochs')\n",
        "parser.add_argument('--n_batch', type=int, default=4096, help='batch size')\n",
        "parser.add_argument('--epoch_per_test', type=int, default=250, help='frequency of testing')\n",
        "parser.add_argument('--test_batch_size', type=int, default=100, help='test batch size')\n",
        "parser.add_argument('--filter', type=bool, default=True, help='whether do filter in testing')\n",
        "parser.add_argument('--out_file_info', type=str, default='', help='extra string for the output file name')\n",
        "\n",
        "\n",
        "arguments = parser.parse_args([])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nA4_72atoDdF"
      },
      "outputs": [],
      "source": [
        "import random\n",
        "import numpy as np\n",
        "\n",
        "def plot_config(args):\n",
        "    out_str = \"\\noptim:{} lr:{} lamb:{}, d:{}\\n\".format(\n",
        "            args.optim, args.lr, args.lamb, args.n_dim)\n",
        "    with open(args.perf_file, 'a') as f:\n",
        "        f.write(out_str)\n",
        "\n",
        "def inplace_shuffle(*lists):\n",
        "    idx = []\n",
        "    for i in range(len(lists[0])):\n",
        "        idx.append(random.randint(0, i))\n",
        "    for ls in lists:\n",
        "        j = idx[i]\n",
        "        ls[i], ls[j] = ls[j], ls[i]\n",
        "\n",
        "def batch_by_num(n_batch, *lists, n_sample=None):\n",
        "    if n_sample is None:\n",
        "        n_sample = len(lists[0])\n",
        "\n",
        "    for i in range(n_batch):\n",
        "        start = int(n_sample * i / n_batch)\n",
        "        end = int(n_sample * (i+1) / n_batch)\n",
        "        ret = [ls[start:end] for ls in lists]\n",
        "        if len(ret) > 1:\n",
        "            yield ret\n",
        "        else:\n",
        "            yield ret[0]\n",
        "\n",
        "def batch_by_size(batch_size, *lists, n_sample=None):\n",
        "    if n_sample is None:\n",
        "        n_sample = len(lists[0])\n",
        "\n",
        "    start = 0\n",
        "    while(start < n_sample):\n",
        "        end = min(n_sample, start + batch_size)\n",
        "        ret = [ls[start:end] for ls in lists]\n",
        "        start += batch_size\n",
        "        if len(ret) > 1:\n",
        "            yield ret\n",
        "        else:\n",
        "            yield ret[0]\n",
        "\n",
        "def gen_struct(num):\n",
        "    struct = []\n",
        "    for i in range(num):\n",
        "        struct.append(random.randint(0,3))\n",
        "        struct.append(random.randint(0,3))\n",
        "        struct.append(2*random.randint(0,1)-1)\n",
        "    return struct\n",
        "\n",
        "def cal_ranks(probs, label):\n",
        "    sorted_idx = np.argsort(probs, axis=1)[:,::-1]\n",
        "    find_target = sorted_idx == np.expand_dims(label, 1)\n",
        "    ranks = np.nonzero(find_target)[1] + 1\n",
        "    return ranks\n",
        "\n",
        "def cal_performance(ranks, topk=10):\n",
        "    mrr = (1. / ranks).sum() / len(ranks)\n",
        "    m_r = sum(ranks) * 1.0 / len(ranks)\n",
        "    h_k = sum(ranks<=topk) * 1.0 / len(ranks)\n",
        "    return mrr, m_r, h_k"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "VQseGg50Qm3b"
      },
      "source": [
        "### Modify the model"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "3KJmldlzTf8t",
        "outputId": "6a6ed6d2-cfab-4755-95bf-e4331e62fab1"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "KGEModule(\n",
              "  (loss): Softplus(beta=1.0, threshold=20.0)\n",
              "  (ent_embed): Embedding(1710, 64)\n",
              "  (rel_embed): Embedding(86, 64)\n",
              ")"
            ]
          },
          "metadata": {},
          "execution_count": 50
        }
      ],
      "source": [
        "model = KGEModule(1710, 86, arguments, [3,0,2,1])\n",
        "model.load_state_dict(torch.load(\"/content/state_0 (12).pt\", map_location=torch.device('cpu')))\n",
        "model.eval()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "7U9ThFwumjib"
      },
      "source": [
        "## Prediction"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WP6auDL9HLjN"
      },
      "outputs": [],
      "source": [
        "def predict(model, h, t):\n",
        "  device = next(model.parameters()).device  # detect model device\n",
        "\n",
        "  head = torch.tensor([h]).to(device)\n",
        "  tail = torch.tensor([t]).to(device)\n",
        "\n",
        "  head_embed = model.ent_embed(head)\n",
        "  tail_embed = model.ent_embed(tail)\n",
        "\n",
        "  highest_cosine_sim = 0\n",
        "  highest_cosine_sim_rela = 0\n",
        "\n",
        "  for i in range(86):\n",
        "    rela = torch.tensor([i]).to(device)\n",
        "    rela_embed = model.rel_embed(rela)\n",
        "\n",
        "    score = model.test_trip(head_embed, rela_embed, tail_embed)\n",
        "\n",
        "    if score > highest_cosine_sim:\n",
        "      highest_cosine_sim = score\n",
        "      highest_cosine_sim_rela = i\n",
        "\n",
        "  return highest_cosine_sim_rela"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "a_gOibdyXBnJ"
      },
      "outputs": [],
      "source": [
        "def predict_logits(model, h, t):\n",
        "    model.eval()\n",
        "    device = next(model.parameters()).device\n",
        "    with torch.no_grad():\n",
        "        head = torch.tensor([h], dtype=torch.long, device=device)\n",
        "        tail = torch.tensor([t], dtype=torch.long, device=device)\n",
        "\n",
        "        head_embed = model.ent_embed(head)   # (1, d)\n",
        "        tail_embed = model.ent_embed(tail)   # (1, d)\n",
        "\n",
        "        logits = []\n",
        "        for i in range(86):\n",
        "            rela = torch.tensor([i], dtype=torch.long, device=device)\n",
        "            rela_embed = model.rel_embed(rela)          # (1, d)\n",
        "            score = model.test_trip(head_embed, rela_embed, tail_embed)\n",
        "            logits.append(score.squeeze())              # <-- squeeze the (1,) or (1,1)\n",
        "\n",
        "        return torch.stack(logits, dim=0)               # shape: (86,)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "h76fgYu1n13w"
      },
      "source": [
        "# Word2Vec Embedding"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "XFRJ9YQ6hWgn"
      },
      "source": [
        "## Plaintext Reading Route"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "BNaSc1IrhYqn"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/trinetx-drug/medication_ingredient.csv\") as file:\n",
        "  lines = file.readlines()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "IRLXg2mtjlzx"
      },
      "outputs": [],
      "source": [
        "categories = lines[0].split(\",\")\n",
        "idx_to_take = [categories.index(i) for i in ['\"patient_id\"', '\"encounter_id\"', '\"code_system\"', '\"code\"', '\"start_date\"']]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6pJOsiAckCEE",
        "outputId": "0367d1c1-0b6a-4c9b-f6f8-da2f95784b59"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "1000000\n",
            "2000000\n",
            "3000000\n",
            "4000000\n",
            "5000000\n",
            "6000000\n",
            "7000000\n",
            "8000000\n",
            "9000000\n",
            "10000000\n",
            "11000000\n",
            "12000000\n",
            "13000000\n",
            "14000000\n",
            "15000000\n",
            "16000000\n",
            "17000000\n",
            "18000000\n",
            "19000000\n",
            "20000000\n",
            "21000000\n",
            "22000000\n",
            "23000000\n",
            "24000000\n",
            "25000000\n",
            "26000000\n",
            "27000000\n",
            "28000000\n",
            "29000000\n",
            "30000000\n",
            "31000000\n",
            "32000000\n",
            "33000000\n",
            "34000000\n",
            "35000000\n",
            "36000000\n",
            "37000000\n",
            "38000000\n",
            "39000000\n",
            "40000000\n",
            "41000000\n",
            "42000000\n",
            "43000000\n",
            "44000000\n",
            "45000000\n",
            "46000000\n",
            "47000000\n",
            "48000000\n",
            "49000000\n",
            "50000000\n",
            "51000000\n",
            "52000000\n",
            "53000000\n",
            "54000000\n",
            "55000000\n",
            "56000000\n",
            "57000000\n",
            "58000000\n",
            "59000000\n",
            "60000000\n",
            "61000000\n",
            "62000000\n",
            "63000000\n",
            "64000000\n",
            "65000000\n",
            "66000000\n",
            "67000000\n",
            "68000000\n",
            "69000000\n",
            "70000000\n",
            "71000000\n",
            "72000000\n",
            "73000000\n",
            "74000000\n",
            "75000000\n",
            "76000000\n",
            "77000000\n",
            "78000000\n",
            "79000000\n",
            "80000000\n",
            "81000000\n",
            "82000000\n",
            "83000000\n",
            "84000000\n",
            "85000000\n",
            "86000000\n",
            "87000000\n",
            "88000000\n",
            "89000000\n",
            "90000000\n",
            "91000000\n",
            "92000000\n",
            "93000000\n",
            "94000000\n",
            "95000000\n",
            "96000000\n",
            "97000000\n",
            "98000000\n",
            "99000000\n",
            "100000000\n",
            "101000000\n",
            "102000000\n",
            "103000000\n",
            "104000000\n",
            "105000000\n",
            "106000000\n",
            "107000000\n",
            "108000000\n",
            "109000000\n",
            "110000000\n",
            "111000000\n",
            "112000000\n",
            "113000000\n",
            "114000000\n",
            "115000000\n",
            "116000000\n",
            "117000000\n",
            "118000000\n",
            "119000000\n",
            "120000000\n",
            "121000000\n",
            "122000000\n",
            "123000000\n",
            "124000000\n",
            "125000000\n",
            "126000000\n",
            "127000000\n",
            "128000000\n",
            "129000000\n",
            "130000000\n",
            "131000000\n",
            "132000000\n",
            "133000000\n",
            "134000000\n",
            "135000000\n",
            "136000000\n",
            "137000000\n",
            "138000000\n",
            "139000000\n",
            "140000000\n",
            "141000000\n",
            "142000000\n",
            "143000000\n",
            "144000000\n",
            "145000000\n",
            "146000000\n",
            "147000000\n",
            "148000000\n",
            "149000000\n",
            "150000000\n",
            "151000000\n",
            "152000000\n",
            "153000000\n",
            "154000000\n",
            "155000000\n",
            "156000000\n",
            "157000000\n",
            "158000000\n",
            "159000000\n",
            "160000000\n",
            "161000000\n",
            "162000000\n"
          ]
        }
      ],
      "source": [
        "events_records = []\n",
        "count = 0\n",
        "for line in lines[1:]:\n",
        "  data_row = line.split(\",\")\n",
        "  events_records.append({categories[i][1:len(categories[i])-1].strip(): data_row[i][1:len(data_row[i])-1].strip() for i in idx_to_take})\n",
        "  count += 1\n",
        "  if count % 1000000 == 0:\n",
        "    print(count)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 216
        },
        "id": "kn1NpvysULJP",
        "outputId": "583f4e9b-71f6-45a0-c536-06cdb0cbd7df"
      },
      "outputs": [
        {
          "ename": "KeyboardInterrupt",
          "evalue": "",
          "output_type": "error",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-189066742.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mdrugs_in_set\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mrecord\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mevents_records\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 3\u001b[0;31m   \u001b[0mdrugs_in_set\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0madd\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrecord\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'code_system'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;34m\"\\t\"\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0mrecord\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'code'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      4\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"/content/test_file_4.txt\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'w'\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mfile\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m   \u001b[0;32mfor\u001b[0m \u001b[0mdrug\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mdrugs_in_set\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
          ]
        }
      ],
      "source": [
        "drugs_in_set = set()\n",
        "for record in events_records:\n",
        "  drugs_in_set.add(str(record['code_system']+\"\\t\"+record['code']))\n",
        "with open(\"/content/test_file_4.txt\", 'w') as file:\n",
        "  for drug in drugs_in_set:\n",
        "     file.write(drug+\"\\n\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "riOy0vWJmKZw"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/trinetx-drug/procedure.csv\") as file:\n",
        "  lines = file.readlines()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Ictw7JQ6ojYA"
      },
      "outputs": [],
      "source": [
        "categories = lines[0].split(\",\")\n",
        "idx_to_take = [categories.index(i) for i in ['\"patient_id\"', '\"encounter_id\"', '\"code_system\"', '\"code\"', '\"date\"']]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6Wv7FiOcol-r",
        "outputId": "338c5481-655d-4c63-e813-b7d1edb1d024"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "1000000\n",
            "2000000\n",
            "3000000\n",
            "4000000\n",
            "5000000\n",
            "6000000\n",
            "7000000\n",
            "8000000\n",
            "9000000\n",
            "10000000\n",
            "11000000\n",
            "12000000\n",
            "13000000\n",
            "14000000\n",
            "15000000\n",
            "16000000\n",
            "17000000\n",
            "18000000\n",
            "19000000\n",
            "20000000\n",
            "21000000\n",
            "22000000\n",
            "23000000\n",
            "24000000\n",
            "25000000\n",
            "26000000\n",
            "27000000\n",
            "28000000\n",
            "29000000\n",
            "30000000\n",
            "31000000\n",
            "32000000\n",
            "33000000\n",
            "34000000\n",
            "35000000\n",
            "36000000\n",
            "37000000\n",
            "38000000\n",
            "39000000\n",
            "40000000\n",
            "41000000\n",
            "42000000\n",
            "43000000\n",
            "44000000\n"
          ]
        }
      ],
      "source": [
        "procedures_records = []\n",
        "count = 0\n",
        "for line in lines[1:]:\n",
        "  data_row = line.split(\",\")\n",
        "  procedures_records.append({categories[i][1:len(categories[i])-1].strip(): data_row[i][1:len(data_row[i])-1].strip() for i in idx_to_take})\n",
        "  count += 1\n",
        "  if count % 1000000 == 0:\n",
        "    print(count)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "7Y13xgqCu1A2"
      },
      "outputs": [],
      "source": [
        "for rec in procedures_records:\n",
        "    rec['start_date'] = rec.pop('date')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "bxYPSe64vNPb"
      },
      "outputs": [],
      "source": [
        "events_records.extend(procedures_records)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "qj-E10J-jQ0C"
      },
      "source": [
        "## Data processing"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FJEUG92a66Qo",
        "outputId": "4443cdbc-77f6-4c9e-cfe2-06ac168f305a"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "206834507"
            ]
          },
          "execution_count": 13,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "len(events_records)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "jwN34V28r_nq",
        "outputId": "5d29df00-af67-4bdb-e038-d51505c2968c"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Processed 100000 rows\n",
            "Processed 200000 rows\n",
            "Processed 300000 rows\n",
            "Processed 400000 rows\n",
            "Processed 500000 rows\n",
            "Processed 600000 rows\n",
            "Processed 700000 rows\n",
            "Processed 800000 rows\n",
            "Processed 900000 rows\n",
            "Processed 1000000 rows\n",
            "Processed 1100000 rows\n",
            "Processed 1200000 rows\n",
            "Processed 1300000 rows\n",
            "Processed 1400000 rows\n",
            "Processed 1500000 rows\n",
            "Processed 1600000 rows\n",
            "Processed 1700000 rows\n",
            "Processed 1800000 rows\n",
            "Processed 1900000 rows\n",
            "Processed 2000000 rows\n",
            "Processed 2100000 rows\n",
            "Processed 2200000 rows\n",
            "Processed 2300000 rows\n",
            "Processed 2400000 rows\n",
            "Processed 2500000 rows\n",
            "Processed 2600000 rows\n",
            "Processed 2700000 rows\n",
            "Processed 2800000 rows\n",
            "Processed 2900000 rows\n",
            "Processed 3000000 rows\n",
            "Processed 3100000 rows\n",
            "Processed 3200000 rows\n",
            "Processed 3300000 rows\n",
            "Processed 3400000 rows\n",
            "Processed 3500000 rows\n",
            "Processed 3600000 rows\n",
            "Processed 3700000 rows\n",
            "Processed 3800000 rows\n",
            "Processed 3900000 rows\n",
            "Processed 4000000 rows\n",
            "Processed 4100000 rows\n",
            "Processed 4200000 rows\n",
            "Processed 4300000 rows\n",
            "Processed 4400000 rows\n",
            "Processed 4500000 rows\n",
            "Processed 4600000 rows\n",
            "Processed 4700000 rows\n",
            "Processed 4800000 rows\n",
            "Processed 4900000 rows\n",
            "Processed 5000000 rows\n",
            "Processed 5100000 rows\n",
            "Processed 5200000 rows\n",
            "Processed 5300000 rows\n",
            "Processed 5400000 rows\n",
            "Processed 5500000 rows\n",
            "Processed 5600000 rows\n",
            "Processed 5700000 rows\n",
            "Processed 5800000 rows\n",
            "Processed 5900000 rows\n",
            "Processed 6000000 rows\n",
            "Processed 6100000 rows\n",
            "Processed 6200000 rows\n",
            "Processed 6300000 rows\n",
            "Processed 6400000 rows\n",
            "Processed 6500000 rows\n",
            "Processed 6600000 rows\n",
            "Processed 6700000 rows\n",
            "Processed 6800000 rows\n",
            "Processed 6900000 rows\n",
            "Processed 7000000 rows\n",
            "Processed 7100000 rows\n",
            "Processed 7200000 rows\n",
            "Processed 7300000 rows\n",
            "Processed 7400000 rows\n",
            "Processed 7500000 rows\n",
            "Processed 7600000 rows\n",
            "Processed 7700000 rows\n",
            "Processed 7800000 rows\n",
            "Processed 7900000 rows\n",
            "Processed 8000000 rows\n",
            "Processed 8100000 rows\n",
            "Processed 8200000 rows\n",
            "Processed 8300000 rows\n",
            "Processed 8400000 rows\n",
            "Processed 8500000 rows\n",
            "Processed 8600000 rows\n",
            "Processed 8700000 rows\n",
            "Processed 8800000 rows\n",
            "Processed 8900000 rows\n",
            "Processed 9000000 rows\n",
            "Processed 9100000 rows\n",
            "Processed 9200000 rows\n",
            "Processed 9300000 rows\n",
            "Processed 9400000 rows\n",
            "Processed 9500000 rows\n",
            "Processed 9600000 rows\n",
            "Processed 9700000 rows\n",
            "Processed 9800000 rows\n",
            "Processed 9900000 rows\n",
            "Processed 10000000 rows\n",
            "Processed 10100000 rows\n",
            "Processed 10200000 rows\n",
            "Processed 10300000 rows\n",
            "Processed 10400000 rows\n",
            "Processed 10500000 rows\n",
            "Processed 10600000 rows\n",
            "Processed 10700000 rows\n",
            "Processed 10800000 rows\n",
            "Processed 10900000 rows\n",
            "Processed 11000000 rows\n",
            "Processed 11100000 rows\n",
            "Processed 11200000 rows\n",
            "Processed 11300000 rows\n",
            "Processed 11400000 rows\n",
            "Processed 11500000 rows\n",
            "Processed 11600000 rows\n",
            "Processed 11700000 rows\n",
            "Processed 11800000 rows\n",
            "Processed 11900000 rows\n",
            "Processed 12000000 rows\n",
            "Processed 12100000 rows\n",
            "Processed 12200000 rows\n",
            "Processed 12300000 rows\n",
            "Processed 12400000 rows\n",
            "Processed 12500000 rows\n",
            "Processed 12600000 rows\n",
            "Processed 12700000 rows\n",
            "Processed 12800000 rows\n",
            "Processed 12900000 rows\n",
            "Processed 13000000 rows\n",
            "Processed 13100000 rows\n",
            "Processed 13200000 rows\n",
            "Processed 13300000 rows\n",
            "Processed 13400000 rows\n",
            "Processed 13500000 rows\n",
            "Processed 13600000 rows\n",
            "Processed 13700000 rows\n",
            "Processed 13800000 rows\n",
            "Processed 13900000 rows\n",
            "Processed 14000000 rows\n",
            "Processed 14100000 rows\n",
            "Processed 14200000 rows\n",
            "Processed 14300000 rows\n",
            "Processed 14400000 rows\n",
            "Processed 14500000 rows\n",
            "Processed 14600000 rows\n",
            "Processed 14700000 rows\n",
            "Processed 14800000 rows\n",
            "Processed 14900000 rows\n",
            "Processed 15000000 rows\n",
            "Processed 15100000 rows\n",
            "Processed 15200000 rows\n",
            "Processed 15300000 rows\n",
            "Processed 15400000 rows\n",
            "Processed 15500000 rows\n",
            "Processed 15600000 rows\n",
            "Processed 15700000 rows\n",
            "Processed 15800000 rows\n",
            "Processed 15900000 rows\n",
            "Processed 16000000 rows\n",
            "Processed 16100000 rows\n",
            "Processed 16200000 rows\n",
            "Processed 16300000 rows\n",
            "Processed 16400000 rows\n",
            "Processed 16500000 rows\n",
            "Processed 16600000 rows\n",
            "Processed 16700000 rows\n",
            "Processed 16800000 rows\n",
            "Processed 16900000 rows\n",
            "Processed 17000000 rows\n",
            "Processed 17100000 rows\n",
            "Processed 17200000 rows\n",
            "Processed 17300000 rows\n",
            "Processed 17400000 rows\n",
            "Processed 17500000 rows\n",
            "Processed 17600000 rows\n",
            "Processed 17700000 rows\n",
            "Processed 17800000 rows\n",
            "Processed 17900000 rows\n",
            "Processed 18000000 rows\n",
            "Processed 18100000 rows\n",
            "Processed 18200000 rows\n",
            "Processed 18300000 rows\n",
            "Processed 18400000 rows\n",
            "Processed 18500000 rows\n",
            "Processed 18600000 rows\n",
            "Processed 18700000 rows\n",
            "Processed 18800000 rows\n",
            "Processed 18900000 rows\n",
            "Processed 19000000 rows\n",
            "Processed 19100000 rows\n",
            "Processed 19200000 rows\n",
            "Processed 19300000 rows\n",
            "Processed 19400000 rows\n",
            "Processed 19500000 rows\n",
            "Processed 19600000 rows\n",
            "Processed 19700000 rows\n",
            "Processed 19800000 rows\n",
            "Processed 19900000 rows\n",
            "Processed 20000000 rows\n",
            "Processed 20100000 rows\n",
            "Processed 20200000 rows\n",
            "Processed 20300000 rows\n",
            "Processed 20400000 rows\n",
            "Processed 20500000 rows\n",
            "Processed 20600000 rows\n",
            "Processed 20700000 rows\n",
            "Processed 20800000 rows\n",
            "Processed 20900000 rows\n",
            "Processed 21000000 rows\n",
            "Processed 21100000 rows\n",
            "Processed 21200000 rows\n",
            "Processed 21300000 rows\n",
            "Processed 21400000 rows\n",
            "Processed 21500000 rows\n",
            "Processed 21600000 rows\n",
            "Processed 21700000 rows\n",
            "Processed 21800000 rows\n",
            "Processed 21900000 rows\n",
            "Processed 22000000 rows\n",
            "Processed 22100000 rows\n",
            "Processed 22200000 rows\n",
            "Processed 22300000 rows\n",
            "Processed 22400000 rows\n",
            "Processed 22500000 rows\n",
            "Processed 22600000 rows\n",
            "Processed 22700000 rows\n",
            "Processed 22800000 rows\n",
            "Processed 22900000 rows\n",
            "Processed 23000000 rows\n",
            "Processed 23100000 rows\n",
            "Processed 23200000 rows\n",
            "Processed 23300000 rows\n",
            "Processed 23400000 rows\n",
            "Processed 23500000 rows\n",
            "Processed 23600000 rows\n",
            "Processed 23700000 rows\n",
            "Processed 23800000 rows\n",
            "Processed 23900000 rows\n",
            "Processed 24000000 rows\n",
            "Processed 24100000 rows\n",
            "Processed 24200000 rows\n",
            "Processed 24300000 rows\n",
            "Processed 24400000 rows\n",
            "Processed 24500000 rows\n",
            "Processed 24600000 rows\n",
            "Processed 24700000 rows\n",
            "Processed 24800000 rows\n",
            "Processed 24900000 rows\n",
            "Processed 25000000 rows\n",
            "Processed 25100000 rows\n",
            "Processed 25200000 rows\n",
            "Processed 25300000 rows\n",
            "Processed 25400000 rows\n",
            "Processed 25500000 rows\n",
            "Processed 25600000 rows\n",
            "Processed 25700000 rows\n",
            "Processed 25800000 rows\n",
            "Processed 25900000 rows\n",
            "Processed 26000000 rows\n",
            "Processed 26100000 rows\n",
            "Processed 26200000 rows\n",
            "Processed 26300000 rows\n",
            "Processed 26400000 rows\n",
            "Processed 26500000 rows\n",
            "Processed 26600000 rows\n",
            "Processed 26700000 rows\n",
            "Processed 26800000 rows\n",
            "Processed 26900000 rows\n",
            "Processed 27000000 rows\n",
            "Processed 27100000 rows\n",
            "Processed 27200000 rows\n",
            "Processed 27300000 rows\n",
            "Processed 27400000 rows\n",
            "Processed 27500000 rows\n",
            "Processed 27600000 rows\n",
            "Processed 27700000 rows\n",
            "Processed 27800000 rows\n",
            "Processed 27900000 rows\n",
            "Processed 28000000 rows\n",
            "Processed 28100000 rows\n",
            "Processed 28200000 rows\n",
            "Processed 28300000 rows\n",
            "Processed 28400000 rows\n",
            "Processed 28500000 rows\n",
            "Processed 28600000 rows\n",
            "Processed 28700000 rows\n",
            "Processed 28800000 rows\n",
            "Processed 28900000 rows\n",
            "Processed 29000000 rows\n",
            "Processed 29100000 rows\n",
            "Processed 29200000 rows\n",
            "Processed 29300000 rows\n",
            "Processed 29400000 rows\n",
            "Processed 29500000 rows\n",
            "Processed 29600000 rows\n",
            "Processed 29700000 rows\n",
            "Processed 29800000 rows\n",
            "Processed 29900000 rows\n",
            "Processed 30000000 rows\n",
            "Processed 30100000 rows\n",
            "Processed 30200000 rows\n",
            "Processed 30300000 rows\n",
            "Processed 30400000 rows\n",
            "Processed 30500000 rows\n",
            "Processed 30600000 rows\n",
            "Processed 30700000 rows\n",
            "Processed 30800000 rows\n",
            "Processed 30900000 rows\n",
            "Processed 31000000 rows\n",
            "Processed 31100000 rows\n",
            "Processed 31200000 rows\n",
            "Processed 31300000 rows\n",
            "Processed 31400000 rows\n",
            "Processed 31500000 rows\n",
            "Processed 31600000 rows\n",
            "Processed 31700000 rows\n",
            "Processed 31800000 rows\n",
            "Processed 31900000 rows\n",
            "Processed 32000000 rows\n",
            "Processed 32100000 rows\n",
            "Processed 32200000 rows\n",
            "Processed 32300000 rows\n",
            "Processed 32400000 rows\n",
            "Processed 32500000 rows\n",
            "Processed 32600000 rows\n",
            "Processed 32700000 rows\n",
            "Processed 32800000 rows\n",
            "Processed 32900000 rows\n",
            "Processed 33000000 rows\n",
            "Processed 33100000 rows\n",
            "Processed 33200000 rows\n",
            "Processed 33300000 rows\n",
            "Processed 33400000 rows\n",
            "Processed 33500000 rows\n",
            "Processed 33600000 rows\n",
            "Processed 33700000 rows\n",
            "Processed 33800000 rows\n",
            "Processed 33900000 rows\n",
            "Processed 34000000 rows\n",
            "Processed 34100000 rows\n",
            "Processed 34200000 rows\n",
            "Processed 34300000 rows\n",
            "Processed 34400000 rows\n",
            "Processed 34500000 rows\n",
            "Processed 34600000 rows\n",
            "Processed 34700000 rows\n",
            "Processed 34800000 rows\n",
            "Processed 34900000 rows\n",
            "Processed 35000000 rows\n",
            "Processed 35100000 rows\n",
            "Processed 35200000 rows\n",
            "Processed 35300000 rows\n",
            "Processed 35400000 rows\n",
            "Processed 35500000 rows\n",
            "Processed 35600000 rows\n",
            "Processed 35700000 rows\n",
            "Processed 35800000 rows\n",
            "Processed 35900000 rows\n",
            "Processed 36000000 rows\n",
            "Processed 36100000 rows\n",
            "Processed 36200000 rows\n",
            "Processed 36300000 rows\n",
            "Processed 36400000 rows\n",
            "Processed 36500000 rows\n",
            "Processed 36600000 rows\n",
            "Processed 36700000 rows\n",
            "Processed 36800000 rows\n",
            "Processed 36900000 rows\n",
            "Processed 37000000 rows\n",
            "Processed 37100000 rows\n",
            "Processed 37200000 rows\n",
            "Processed 37300000 rows\n",
            "Processed 37400000 rows\n",
            "Processed 37500000 rows\n",
            "Processed 37600000 rows\n",
            "Processed 37700000 rows\n",
            "Processed 37800000 rows\n",
            "Processed 37900000 rows\n",
            "Processed 38000000 rows\n",
            "Processed 38100000 rows\n",
            "Processed 38200000 rows\n",
            "Processed 38300000 rows\n",
            "Processed 38400000 rows\n",
            "Processed 38500000 rows\n",
            "Processed 38600000 rows\n",
            "Processed 38700000 rows\n",
            "Processed 38800000 rows\n",
            "Processed 38900000 rows\n",
            "Processed 39000000 rows\n",
            "Processed 39100000 rows\n",
            "Processed 39200000 rows\n",
            "Processed 39300000 rows\n",
            "Processed 39400000 rows\n",
            "Processed 39500000 rows\n",
            "Processed 39600000 rows\n",
            "Processed 39700000 rows\n",
            "Processed 39800000 rows\n",
            "Processed 39900000 rows\n",
            "Processed 40000000 rows\n",
            "Processed 40100000 rows\n",
            "Processed 40200000 rows\n",
            "Processed 40300000 rows\n",
            "Processed 40400000 rows\n",
            "Processed 40500000 rows\n",
            "Processed 40600000 rows\n",
            "Processed 40700000 rows\n",
            "Processed 40800000 rows\n",
            "Processed 40900000 rows\n",
            "Processed 41000000 rows\n",
            "Processed 41100000 rows\n",
            "Processed 41200000 rows\n",
            "Processed 41300000 rows\n",
            "Processed 41400000 rows\n",
            "Processed 41500000 rows\n",
            "Processed 41600000 rows\n",
            "Processed 41700000 rows\n",
            "Processed 41800000 rows\n",
            "Processed 41900000 rows\n",
            "Processed 42000000 rows\n",
            "Processed 42100000 rows\n",
            "Processed 42200000 rows\n",
            "Processed 42300000 rows\n",
            "Processed 42400000 rows\n",
            "Processed 42500000 rows\n",
            "Processed 42600000 rows\n",
            "Processed 42700000 rows\n",
            "Processed 42800000 rows\n",
            "Processed 42900000 rows\n",
            "Processed 43000000 rows\n",
            "Processed 43100000 rows\n",
            "Processed 43200000 rows\n",
            "Processed 43300000 rows\n",
            "Processed 43400000 rows\n",
            "Processed 43500000 rows\n",
            "Processed 43600000 rows\n",
            "Processed 43700000 rows\n",
            "Processed 43800000 rows\n",
            "Processed 43900000 rows\n",
            "Processed 44000000 rows\n",
            "Processed 44100000 rows\n",
            "Processed 44200000 rows\n",
            "Processed 44300000 rows\n",
            "Processed 44400000 rows\n",
            "Processed 44500000 rows\n",
            "Processed 44600000 rows\n",
            "Processed 44700000 rows\n",
            "Processed 44800000 rows\n",
            "Processed 44900000 rows\n",
            "Processed 45000000 rows\n",
            "Processed 45100000 rows\n",
            "Processed 45200000 rows\n",
            "Processed 45300000 rows\n",
            "Processed 45400000 rows\n",
            "Processed 45500000 rows\n",
            "Processed 45600000 rows\n",
            "Processed 45700000 rows\n",
            "Processed 45800000 rows\n",
            "Processed 45900000 rows\n",
            "Processed 46000000 rows\n",
            "Processed 46100000 rows\n",
            "Processed 46200000 rows\n",
            "Processed 46300000 rows\n",
            "Processed 46400000 rows\n",
            "Processed 46500000 rows\n",
            "Processed 46600000 rows\n",
            "Processed 46700000 rows\n",
            "Processed 46800000 rows\n",
            "Processed 46900000 rows\n",
            "Processed 47000000 rows\n",
            "Processed 47100000 rows\n",
            "Processed 47200000 rows\n",
            "Processed 47300000 rows\n",
            "Processed 47400000 rows\n",
            "Processed 47500000 rows\n",
            "Processed 47600000 rows\n",
            "Processed 47700000 rows\n",
            "Processed 47800000 rows\n",
            "Processed 47900000 rows\n",
            "Processed 48000000 rows\n",
            "Processed 48100000 rows\n",
            "Processed 48200000 rows\n",
            "Processed 48300000 rows\n",
            "Processed 48400000 rows\n",
            "Processed 48500000 rows\n",
            "Processed 48600000 rows\n",
            "Processed 48700000 rows\n",
            "Processed 48800000 rows\n",
            "Processed 48900000 rows\n",
            "Processed 49000000 rows\n",
            "Processed 49100000 rows\n",
            "Processed 49200000 rows\n",
            "Processed 49300000 rows\n",
            "Processed 49400000 rows\n",
            "Processed 49500000 rows\n",
            "Processed 49600000 rows\n",
            "Processed 49700000 rows\n",
            "Processed 49800000 rows\n",
            "Processed 49900000 rows\n",
            "Processed 50000000 rows\n",
            "Processed 50100000 rows\n",
            "Processed 50200000 rows\n",
            "Processed 50300000 rows\n",
            "Processed 50400000 rows\n",
            "Processed 50500000 rows\n",
            "Processed 50600000 rows\n",
            "Processed 50700000 rows\n",
            "Processed 50800000 rows\n",
            "Processed 50900000 rows\n",
            "Processed 51000000 rows\n",
            "Processed 51100000 rows\n",
            "Processed 51200000 rows\n",
            "Processed 51300000 rows\n",
            "Processed 51400000 rows\n",
            "Processed 51500000 rows\n",
            "Processed 51600000 rows\n",
            "Processed 51700000 rows\n",
            "Processed 51800000 rows\n",
            "Processed 51900000 rows\n",
            "Processed 52000000 rows\n",
            "Processed 52100000 rows\n",
            "Processed 52200000 rows\n",
            "Processed 52300000 rows\n",
            "Processed 52400000 rows\n",
            "Processed 52500000 rows\n",
            "Processed 52600000 rows\n",
            "Processed 52700000 rows\n",
            "Processed 52800000 rows\n",
            "Processed 52900000 rows\n",
            "Processed 53000000 rows\n",
            "Processed 53100000 rows\n",
            "Processed 53200000 rows\n",
            "Processed 53300000 rows\n",
            "Processed 53400000 rows\n",
            "Processed 53500000 rows\n",
            "Processed 53600000 rows\n",
            "Processed 53700000 rows\n",
            "Processed 53800000 rows\n",
            "Processed 53900000 rows\n",
            "Processed 54000000 rows\n",
            "Processed 54100000 rows\n",
            "Processed 54200000 rows\n",
            "Processed 54300000 rows\n",
            "Processed 54400000 rows\n",
            "Processed 54500000 rows\n",
            "Processed 54600000 rows\n",
            "Processed 54700000 rows\n",
            "Processed 54800000 rows\n",
            "Processed 54900000 rows\n",
            "Processed 55000000 rows\n",
            "Processed 55100000 rows\n",
            "Processed 55200000 rows\n",
            "Processed 55300000 rows\n",
            "Processed 55400000 rows\n",
            "Processed 55500000 rows\n",
            "Processed 55600000 rows\n",
            "Processed 55700000 rows\n",
            "Processed 55800000 rows\n",
            "Processed 55900000 rows\n",
            "Processed 56000000 rows\n",
            "Processed 56100000 rows\n",
            "Processed 56200000 rows\n",
            "Processed 56300000 rows\n",
            "Processed 56400000 rows\n",
            "Processed 56500000 rows\n",
            "Processed 56600000 rows\n",
            "Processed 56700000 rows\n",
            "Processed 56800000 rows\n",
            "Processed 56900000 rows\n",
            "Processed 57000000 rows\n",
            "Processed 57100000 rows\n",
            "Processed 57200000 rows\n",
            "Processed 57300000 rows\n",
            "Processed 57400000 rows\n",
            "Processed 57500000 rows\n",
            "Processed 57600000 rows\n",
            "Processed 57700000 rows\n",
            "Processed 57800000 rows\n",
            "Processed 57900000 rows\n",
            "Processed 58000000 rows\n",
            "Processed 58100000 rows\n",
            "Processed 58200000 rows\n",
            "Processed 58300000 rows\n",
            "Processed 58400000 rows\n",
            "Processed 58500000 rows\n",
            "Processed 58600000 rows\n",
            "Processed 58700000 rows\n",
            "Processed 58800000 rows\n",
            "Processed 58900000 rows\n",
            "Processed 59000000 rows\n",
            "Processed 59100000 rows\n",
            "Processed 59200000 rows\n",
            "Processed 59300000 rows\n",
            "Processed 59400000 rows\n",
            "Processed 59500000 rows\n",
            "Processed 59600000 rows\n",
            "Processed 59700000 rows\n",
            "Processed 59800000 rows\n",
            "Processed 59900000 rows\n",
            "Processed 60000000 rows\n",
            "Processed 60100000 rows\n",
            "Processed 60200000 rows\n",
            "Processed 60300000 rows\n",
            "Processed 60400000 rows\n",
            "Processed 60500000 rows\n",
            "Processed 60600000 rows\n",
            "Processed 60700000 rows\n",
            "Processed 60800000 rows\n",
            "Processed 60900000 rows\n",
            "Processed 61000000 rows\n",
            "Processed 61100000 rows\n",
            "Processed 61200000 rows\n",
            "Processed 61300000 rows\n",
            "Processed 61400000 rows\n",
            "Processed 61500000 rows\n",
            "Processed 61600000 rows\n",
            "Processed 61700000 rows\n",
            "Processed 61800000 rows\n",
            "Processed 61900000 rows\n",
            "Processed 62000000 rows\n",
            "Processed 62100000 rows\n",
            "Processed 62200000 rows\n",
            "Processed 62300000 rows\n",
            "Processed 62400000 rows\n",
            "Processed 62500000 rows\n",
            "Processed 62600000 rows\n",
            "Processed 62700000 rows\n",
            "Processed 62800000 rows\n",
            "Processed 62900000 rows\n",
            "Processed 63000000 rows\n",
            "Processed 63100000 rows\n",
            "Processed 63200000 rows\n",
            "Processed 63300000 rows\n",
            "Processed 63400000 rows\n",
            "Processed 63500000 rows\n",
            "Processed 63600000 rows\n",
            "Processed 63700000 rows\n",
            "Processed 63800000 rows\n",
            "Processed 63900000 rows\n",
            "Processed 64000000 rows\n",
            "Processed 64100000 rows\n",
            "Processed 64200000 rows\n",
            "Processed 64300000 rows\n",
            "Processed 64400000 rows\n",
            "Processed 64500000 rows\n",
            "Processed 64600000 rows\n",
            "Processed 64700000 rows\n",
            "Processed 64800000 rows\n",
            "Processed 64900000 rows\n",
            "Processed 65000000 rows\n",
            "Processed 65100000 rows\n",
            "Processed 65200000 rows\n",
            "Processed 65300000 rows\n",
            "Processed 65400000 rows\n",
            "Processed 65500000 rows\n",
            "Processed 65600000 rows\n",
            "Processed 65700000 rows\n",
            "Processed 65800000 rows\n",
            "Processed 65900000 rows\n",
            "Processed 66000000 rows\n",
            "Processed 66100000 rows\n",
            "Processed 66200000 rows\n",
            "Processed 66300000 rows\n",
            "Processed 66400000 rows\n",
            "Processed 66500000 rows\n",
            "Processed 66600000 rows\n",
            "Processed 66700000 rows\n",
            "Processed 66800000 rows\n",
            "Processed 66900000 rows\n",
            "Processed 67000000 rows\n",
            "Processed 67100000 rows\n",
            "Processed 67200000 rows\n",
            "Processed 67300000 rows\n",
            "Processed 67400000 rows\n",
            "Processed 67500000 rows\n",
            "Processed 67600000 rows\n",
            "Processed 67700000 rows\n",
            "Processed 67800000 rows\n",
            "Processed 67900000 rows\n",
            "Processed 68000000 rows\n",
            "Processed 68100000 rows\n",
            "Processed 68200000 rows\n",
            "Processed 68300000 rows\n",
            "Processed 68400000 rows\n",
            "Processed 68500000 rows\n",
            "Processed 68600000 rows\n",
            "Processed 68700000 rows\n",
            "Processed 68800000 rows\n",
            "Processed 68900000 rows\n",
            "Processed 69000000 rows\n",
            "Processed 69100000 rows\n",
            "Processed 69200000 rows\n",
            "Processed 69300000 rows\n",
            "Processed 69400000 rows\n",
            "Processed 69500000 rows\n",
            "Processed 69600000 rows\n",
            "Processed 69700000 rows\n",
            "Processed 69800000 rows\n",
            "Processed 69900000 rows\n",
            "Processed 70000000 rows\n",
            "Processed 70100000 rows\n",
            "Processed 70200000 rows\n",
            "Processed 70300000 rows\n",
            "Processed 70400000 rows\n",
            "Processed 70500000 rows\n",
            "Processed 70600000 rows\n",
            "Processed 70700000 rows\n",
            "Processed 70800000 rows\n",
            "Processed 70900000 rows\n",
            "Processed 71000000 rows\n",
            "Processed 71100000 rows\n",
            "Processed 71200000 rows\n",
            "Processed 71300000 rows\n",
            "Processed 71400000 rows\n",
            "Processed 71500000 rows\n",
            "Processed 71600000 rows\n",
            "Processed 71700000 rows\n",
            "Processed 71800000 rows\n",
            "Processed 71900000 rows\n",
            "Processed 72000000 rows\n",
            "Processed 72100000 rows\n",
            "Processed 72200000 rows\n",
            "Processed 72300000 rows\n",
            "Processed 72400000 rows\n",
            "Processed 72500000 rows\n",
            "Processed 72600000 rows\n",
            "Processed 72700000 rows\n",
            "Processed 72800000 rows\n",
            "Processed 72900000 rows\n",
            "Processed 73000000 rows\n",
            "Processed 73100000 rows\n",
            "Processed 73200000 rows\n",
            "Processed 73300000 rows\n",
            "Processed 73400000 rows\n",
            "Processed 73500000 rows\n",
            "Processed 73600000 rows\n",
            "Processed 73700000 rows\n",
            "Processed 73800000 rows\n",
            "Processed 73900000 rows\n",
            "Processed 74000000 rows\n",
            "Processed 74100000 rows\n",
            "Processed 74200000 rows\n",
            "Processed 74300000 rows\n",
            "Processed 74400000 rows\n",
            "Processed 74500000 rows\n",
            "Processed 74600000 rows\n",
            "Processed 74700000 rows\n",
            "Processed 74800000 rows\n",
            "Processed 74900000 rows\n",
            "Processed 75000000 rows\n",
            "Processed 75100000 rows\n",
            "Processed 75200000 rows\n",
            "Processed 75300000 rows\n",
            "Processed 75400000 rows\n",
            "Processed 75500000 rows\n",
            "Processed 75600000 rows\n",
            "Processed 75700000 rows\n",
            "Processed 75800000 rows\n",
            "Processed 75900000 rows\n",
            "Processed 76000000 rows\n",
            "Processed 76100000 rows\n",
            "Processed 76200000 rows\n",
            "Processed 76300000 rows\n",
            "Processed 76400000 rows\n",
            "Processed 76500000 rows\n",
            "Processed 76600000 rows\n",
            "Processed 76700000 rows\n",
            "Processed 76800000 rows\n",
            "Processed 76900000 rows\n",
            "Processed 77000000 rows\n",
            "Processed 77100000 rows\n",
            "Processed 77200000 rows\n",
            "Processed 77300000 rows\n",
            "Processed 77400000 rows\n",
            "Processed 77500000 rows\n",
            "Processed 77600000 rows\n",
            "Processed 77700000 rows\n",
            "Processed 77800000 rows\n",
            "Processed 77900000 rows\n",
            "Processed 78000000 rows\n",
            "Processed 78100000 rows\n",
            "Processed 78200000 rows\n",
            "Processed 78300000 rows\n",
            "Processed 78400000 rows\n",
            "Processed 78500000 rows\n",
            "Processed 78600000 rows\n",
            "Processed 78700000 rows\n",
            "Processed 78800000 rows\n",
            "Processed 78900000 rows\n",
            "Processed 79000000 rows\n",
            "Processed 79100000 rows\n",
            "Processed 79200000 rows\n",
            "Processed 79300000 rows\n",
            "Processed 79400000 rows\n",
            "Processed 79500000 rows\n",
            "Processed 79600000 rows\n",
            "Processed 79700000 rows\n",
            "Processed 79800000 rows\n",
            "Processed 79900000 rows\n",
            "Processed 80000000 rows\n",
            "Processed 80100000 rows\n",
            "Processed 80200000 rows\n",
            "Processed 80300000 rows\n",
            "Processed 80400000 rows\n",
            "Processed 80500000 rows\n",
            "Processed 80600000 rows\n",
            "Processed 80700000 rows\n",
            "Processed 80800000 rows\n",
            "Processed 80900000 rows\n",
            "Processed 81000000 rows\n",
            "Processed 81100000 rows\n",
            "Processed 81200000 rows\n",
            "Processed 81300000 rows\n",
            "Processed 81400000 rows\n",
            "Processed 81500000 rows\n",
            "Processed 81600000 rows\n",
            "Processed 81700000 rows\n",
            "Processed 81800000 rows\n",
            "Processed 81900000 rows\n",
            "Processed 82000000 rows\n",
            "Processed 82100000 rows\n",
            "Processed 82200000 rows\n",
            "Processed 82300000 rows\n",
            "Processed 82400000 rows\n",
            "Processed 82500000 rows\n",
            "Processed 82600000 rows\n",
            "Processed 82700000 rows\n",
            "Processed 82800000 rows\n",
            "Processed 82900000 rows\n",
            "Processed 83000000 rows\n",
            "Processed 83100000 rows\n",
            "Processed 83200000 rows\n",
            "Processed 83300000 rows\n",
            "Processed 83400000 rows\n",
            "Processed 83500000 rows\n",
            "Processed 83600000 rows\n",
            "Processed 83700000 rows\n",
            "Processed 83800000 rows\n",
            "Processed 83900000 rows\n",
            "Processed 84000000 rows\n",
            "Processed 84100000 rows\n",
            "Processed 84200000 rows\n",
            "Processed 84300000 rows\n",
            "Processed 84400000 rows\n",
            "Processed 84500000 rows\n",
            "Processed 84600000 rows\n",
            "Processed 84700000 rows\n",
            "Processed 84800000 rows\n",
            "Processed 84900000 rows\n",
            "Processed 85000000 rows\n",
            "Processed 85100000 rows\n",
            "Processed 85200000 rows\n",
            "Processed 85300000 rows\n",
            "Processed 85400000 rows\n",
            "Processed 85500000 rows\n",
            "Processed 85600000 rows\n",
            "Processed 85700000 rows\n",
            "Processed 85800000 rows\n",
            "Processed 85900000 rows\n",
            "Processed 86000000 rows\n",
            "Processed 86100000 rows\n",
            "Processed 86200000 rows\n",
            "Processed 86300000 rows\n",
            "Processed 86400000 rows\n",
            "Processed 86500000 rows\n",
            "Processed 86600000 rows\n",
            "Processed 86700000 rows\n",
            "Processed 86800000 rows\n",
            "Processed 86900000 rows\n",
            "Processed 87000000 rows\n",
            "Processed 87100000 rows\n",
            "Processed 87200000 rows\n",
            "Processed 87300000 rows\n",
            "Processed 87400000 rows\n",
            "Processed 87500000 rows\n",
            "Processed 87600000 rows\n",
            "Processed 87700000 rows\n",
            "Processed 87800000 rows\n",
            "Processed 87900000 rows\n",
            "Processed 88000000 rows\n",
            "Processed 88100000 rows\n",
            "Processed 88200000 rows\n",
            "Processed 88300000 rows\n",
            "Processed 88400000 rows\n",
            "Processed 88500000 rows\n",
            "Processed 88600000 rows\n",
            "Processed 88700000 rows\n",
            "Processed 88800000 rows\n",
            "Processed 88900000 rows\n",
            "Processed 89000000 rows\n",
            "Processed 89100000 rows\n",
            "Processed 89200000 rows\n",
            "Processed 89300000 rows\n",
            "Processed 89400000 rows\n",
            "Processed 89500000 rows\n",
            "Processed 89600000 rows\n",
            "Processed 89700000 rows\n",
            "Processed 89800000 rows\n",
            "Processed 89900000 rows\n",
            "Processed 90000000 rows\n",
            "Processed 90100000 rows\n",
            "Processed 90200000 rows\n",
            "Processed 90300000 rows\n",
            "Processed 90400000 rows\n",
            "Processed 90500000 rows\n",
            "Processed 90600000 rows\n",
            "Processed 90700000 rows\n",
            "Processed 90800000 rows\n",
            "Processed 90900000 rows\n",
            "Processed 91000000 rows\n",
            "Processed 91100000 rows\n",
            "Processed 91200000 rows\n",
            "Processed 91300000 rows\n",
            "Processed 91400000 rows\n",
            "Processed 91500000 rows\n",
            "Processed 91600000 rows\n",
            "Processed 91700000 rows\n",
            "Processed 91800000 rows\n",
            "Processed 91900000 rows\n",
            "Processed 92000000 rows\n",
            "Processed 92100000 rows\n",
            "Processed 92200000 rows\n",
            "Processed 92300000 rows\n",
            "Processed 92400000 rows\n",
            "Processed 92500000 rows\n",
            "Processed 92600000 rows\n",
            "Processed 92700000 rows\n",
            "Processed 92800000 rows\n",
            "Processed 92900000 rows\n",
            "Processed 93000000 rows\n",
            "Processed 93100000 rows\n",
            "Processed 93200000 rows\n",
            "Processed 93300000 rows\n",
            "Processed 93400000 rows\n",
            "Processed 93500000 rows\n",
            "Processed 93600000 rows\n",
            "Processed 93700000 rows\n",
            "Processed 93800000 rows\n",
            "Processed 93900000 rows\n",
            "Processed 94000000 rows\n",
            "Processed 94100000 rows\n",
            "Processed 94200000 rows\n",
            "Processed 94300000 rows\n",
            "Processed 94400000 rows\n",
            "Processed 94500000 rows\n",
            "Processed 94600000 rows\n",
            "Processed 94700000 rows\n",
            "Processed 94800000 rows\n",
            "Processed 94900000 rows\n",
            "Processed 95000000 rows\n",
            "Processed 95100000 rows\n",
            "Processed 95200000 rows\n",
            "Processed 95300000 rows\n",
            "Processed 95400000 rows\n",
            "Processed 95500000 rows\n",
            "Processed 95600000 rows\n",
            "Processed 95700000 rows\n",
            "Processed 95800000 rows\n",
            "Processed 95900000 rows\n",
            "Processed 96000000 rows\n",
            "Processed 96100000 rows\n",
            "Processed 96200000 rows\n",
            "Processed 96300000 rows\n",
            "Processed 96400000 rows\n",
            "Processed 96500000 rows\n",
            "Processed 96600000 rows\n",
            "Processed 96700000 rows\n",
            "Processed 96800000 rows\n",
            "Processed 96900000 rows\n",
            "Processed 97000000 rows\n",
            "Processed 97100000 rows\n",
            "Processed 97200000 rows\n",
            "Processed 97300000 rows\n",
            "Processed 97400000 rows\n",
            "Processed 97500000 rows\n",
            "Processed 97600000 rows\n",
            "Processed 97700000 rows\n",
            "Processed 97800000 rows\n",
            "Processed 97900000 rows\n",
            "Processed 98000000 rows\n",
            "Processed 98100000 rows\n",
            "Processed 98200000 rows\n",
            "Processed 98300000 rows\n",
            "Processed 98400000 rows\n",
            "Processed 98500000 rows\n",
            "Processed 98600000 rows\n",
            "Processed 98700000 rows\n",
            "Processed 98800000 rows\n",
            "Processed 98900000 rows\n",
            "Processed 99000000 rows\n",
            "Processed 99100000 rows\n",
            "Processed 99200000 rows\n",
            "Processed 99300000 rows\n",
            "Processed 99400000 rows\n",
            "Processed 99500000 rows\n",
            "Processed 99600000 rows\n",
            "Processed 99700000 rows\n",
            "Processed 99800000 rows\n",
            "Processed 99900000 rows\n",
            "Processed 100000000 rows\n",
            "Processed 100100000 rows\n",
            "Processed 100200000 rows\n",
            "Processed 100300000 rows\n",
            "Processed 100400000 rows\n",
            "Processed 100500000 rows\n",
            "Processed 100600000 rows\n",
            "Processed 100700000 rows\n",
            "Processed 100800000 rows\n",
            "Processed 100900000 rows\n",
            "Processed 101000000 rows\n",
            "Processed 101100000 rows\n",
            "Processed 101200000 rows\n",
            "Processed 101300000 rows\n",
            "Processed 101400000 rows\n",
            "Processed 101500000 rows\n",
            "Processed 101600000 rows\n",
            "Processed 101700000 rows\n",
            "Processed 101800000 rows\n",
            "Processed 101900000 rows\n",
            "Processed 102000000 rows\n",
            "Processed 102100000 rows\n",
            "Processed 102200000 rows\n",
            "Processed 102300000 rows\n",
            "Processed 102400000 rows\n",
            "Processed 102500000 rows\n",
            "Processed 102600000 rows\n",
            "Processed 102700000 rows\n",
            "Processed 102800000 rows\n",
            "Processed 102900000 rows\n",
            "Processed 103000000 rows\n",
            "Processed 103100000 rows\n",
            "Processed 103200000 rows\n",
            "Processed 103300000 rows\n",
            "Processed 103400000 rows\n",
            "Processed 103500000 rows\n",
            "Processed 103600000 rows\n",
            "Processed 103700000 rows\n",
            "Processed 103800000 rows\n",
            "Processed 103900000 rows\n",
            "Processed 104000000 rows\n",
            "Processed 104100000 rows\n",
            "Processed 104200000 rows\n",
            "Processed 104300000 rows\n",
            "Processed 104400000 rows\n",
            "Processed 104500000 rows\n",
            "Processed 104600000 rows\n",
            "Processed 104700000 rows\n",
            "Processed 104800000 rows\n",
            "Processed 104900000 rows\n",
            "Processed 105000000 rows\n",
            "Processed 105100000 rows\n",
            "Processed 105200000 rows\n",
            "Processed 105300000 rows\n",
            "Processed 105400000 rows\n",
            "Processed 105500000 rows\n",
            "Processed 105600000 rows\n",
            "Processed 105700000 rows\n",
            "Processed 105800000 rows\n",
            "Processed 105900000 rows\n",
            "Processed 106000000 rows\n",
            "Processed 106100000 rows\n",
            "Processed 106200000 rows\n",
            "Processed 106300000 rows\n",
            "Processed 106400000 rows\n",
            "Processed 106500000 rows\n",
            "Processed 106600000 rows\n",
            "Processed 106700000 rows\n",
            "Processed 106800000 rows\n",
            "Processed 106900000 rows\n",
            "Processed 107000000 rows\n",
            "Processed 107100000 rows\n",
            "Processed 107200000 rows\n",
            "Processed 107300000 rows\n",
            "Processed 107400000 rows\n",
            "Processed 107500000 rows\n",
            "Processed 107600000 rows\n",
            "Processed 107700000 rows\n",
            "Processed 107800000 rows\n",
            "Processed 107900000 rows\n",
            "Processed 108000000 rows\n",
            "Processed 108100000 rows\n",
            "Processed 108200000 rows\n",
            "Processed 108300000 rows\n",
            "Processed 108400000 rows\n",
            "Processed 108500000 rows\n",
            "Processed 108600000 rows\n",
            "Processed 108700000 rows\n",
            "Processed 108800000 rows\n",
            "Processed 108900000 rows\n",
            "Processed 109000000 rows\n",
            "Processed 109100000 rows\n",
            "Processed 109200000 rows\n",
            "Processed 109300000 rows\n",
            "Processed 109400000 rows\n",
            "Processed 109500000 rows\n",
            "Processed 109600000 rows\n",
            "Processed 109700000 rows\n",
            "Processed 109800000 rows\n",
            "Processed 109900000 rows\n",
            "Processed 110000000 rows\n",
            "Processed 110100000 rows\n",
            "Processed 110200000 rows\n",
            "Processed 110300000 rows\n",
            "Processed 110400000 rows\n",
            "Processed 110500000 rows\n",
            "Processed 110600000 rows\n",
            "Processed 110700000 rows\n",
            "Processed 110800000 rows\n",
            "Processed 110900000 rows\n",
            "Processed 111000000 rows\n",
            "Processed 111100000 rows\n",
            "Processed 111200000 rows\n",
            "Processed 111300000 rows\n",
            "Processed 111400000 rows\n",
            "Processed 111500000 rows\n",
            "Processed 111600000 rows\n",
            "Processed 111700000 rows\n",
            "Processed 111800000 rows\n",
            "Processed 111900000 rows\n",
            "Processed 112000000 rows\n",
            "Processed 112100000 rows\n",
            "Processed 112200000 rows\n",
            "Processed 112300000 rows\n",
            "Processed 112400000 rows\n",
            "Processed 112500000 rows\n",
            "Processed 112600000 rows\n",
            "Processed 112700000 rows\n",
            "Processed 112800000 rows\n",
            "Processed 112900000 rows\n",
            "Processed 113000000 rows\n",
            "Processed 113100000 rows\n",
            "Processed 113200000 rows\n",
            "Processed 113300000 rows\n",
            "Processed 113400000 rows\n",
            "Processed 113500000 rows\n",
            "Processed 113600000 rows\n",
            "Processed 113700000 rows\n",
            "Processed 113800000 rows\n",
            "Processed 113900000 rows\n",
            "Processed 114000000 rows\n",
            "Processed 114100000 rows\n",
            "Processed 114200000 rows\n",
            "Processed 114300000 rows\n",
            "Processed 114400000 rows\n",
            "Processed 114500000 rows\n",
            "Processed 114600000 rows\n",
            "Processed 114700000 rows\n",
            "Processed 114800000 rows\n",
            "Processed 114900000 rows\n",
            "Processed 115000000 rows\n",
            "Processed 115100000 rows\n",
            "Processed 115200000 rows\n",
            "Processed 115300000 rows\n",
            "Processed 115400000 rows\n",
            "Processed 115500000 rows\n",
            "Processed 115600000 rows\n",
            "Processed 115700000 rows\n",
            "Processed 115800000 rows\n",
            "Processed 115900000 rows\n",
            "Processed 116000000 rows\n",
            "Processed 116100000 rows\n",
            "Processed 116200000 rows\n",
            "Processed 116300000 rows\n",
            "Processed 116400000 rows\n",
            "Processed 116500000 rows\n",
            "Processed 116600000 rows\n",
            "Processed 116700000 rows\n",
            "Processed 116800000 rows\n",
            "Processed 116900000 rows\n",
            "Processed 117000000 rows\n",
            "Processed 117100000 rows\n",
            "Processed 117200000 rows\n",
            "Processed 117300000 rows\n",
            "Processed 117400000 rows\n",
            "Processed 117500000 rows\n",
            "Processed 117600000 rows\n",
            "Processed 117700000 rows\n",
            "Processed 117800000 rows\n",
            "Processed 117900000 rows\n",
            "Processed 118000000 rows\n",
            "Processed 118100000 rows\n",
            "Processed 118200000 rows\n",
            "Processed 118300000 rows\n",
            "Processed 118400000 rows\n",
            "Processed 118500000 rows\n",
            "Processed 118600000 rows\n",
            "Processed 118700000 rows\n",
            "Processed 118800000 rows\n",
            "Processed 118900000 rows\n",
            "Processed 119000000 rows\n",
            "Processed 119100000 rows\n",
            "Processed 119200000 rows\n",
            "Processed 119300000 rows\n",
            "Processed 119400000 rows\n",
            "Processed 119500000 rows\n",
            "Processed 119600000 rows\n",
            "Processed 119700000 rows\n",
            "Processed 119800000 rows\n",
            "Processed 119900000 rows\n",
            "Processed 120000000 rows\n",
            "Processed 120100000 rows\n",
            "Processed 120200000 rows\n",
            "Processed 120300000 rows\n",
            "Processed 120400000 rows\n",
            "Processed 120500000 rows\n",
            "Processed 120600000 rows\n",
            "Processed 120700000 rows\n",
            "Processed 120800000 rows\n",
            "Processed 120900000 rows\n",
            "Processed 121000000 rows\n",
            "Processed 121100000 rows\n",
            "Processed 121200000 rows\n",
            "Processed 121300000 rows\n",
            "Processed 121400000 rows\n",
            "Processed 121500000 rows\n",
            "Processed 121600000 rows\n",
            "Processed 121700000 rows\n",
            "Processed 121800000 rows\n",
            "Processed 121900000 rows\n",
            "Processed 122000000 rows\n",
            "Processed 122100000 rows\n",
            "Processed 122200000 rows\n",
            "Processed 122300000 rows\n",
            "Processed 122400000 rows\n",
            "Processed 122500000 rows\n",
            "Processed 122600000 rows\n",
            "Processed 122700000 rows\n",
            "Processed 122800000 rows\n",
            "Processed 122900000 rows\n",
            "Processed 123000000 rows\n",
            "Processed 123100000 rows\n",
            "Processed 123200000 rows\n",
            "Processed 123300000 rows\n",
            "Processed 123400000 rows\n",
            "Processed 123500000 rows\n",
            "Processed 123600000 rows\n",
            "Processed 123700000 rows\n",
            "Processed 123800000 rows\n",
            "Processed 123900000 rows\n",
            "Processed 124000000 rows\n",
            "Processed 124100000 rows\n",
            "Processed 124200000 rows\n",
            "Processed 124300000 rows\n",
            "Processed 124400000 rows\n",
            "Processed 124500000 rows\n",
            "Processed 124600000 rows\n",
            "Processed 124700000 rows\n",
            "Processed 124800000 rows\n",
            "Processed 124900000 rows\n",
            "Processed 125000000 rows\n",
            "Processed 125100000 rows\n",
            "Processed 125200000 rows\n",
            "Processed 125300000 rows\n",
            "Processed 125400000 rows\n",
            "Processed 125500000 rows\n",
            "Processed 125600000 rows\n",
            "Processed 125700000 rows\n",
            "Processed 125800000 rows\n",
            "Processed 125900000 rows\n",
            "Processed 126000000 rows\n",
            "Processed 126100000 rows\n",
            "Processed 126200000 rows\n",
            "Processed 126300000 rows\n",
            "Processed 126400000 rows\n",
            "Processed 126500000 rows\n",
            "Processed 126600000 rows\n",
            "Processed 126700000 rows\n",
            "Processed 126800000 rows\n",
            "Processed 126900000 rows\n",
            "Processed 127000000 rows\n",
            "Processed 127100000 rows\n",
            "Processed 127200000 rows\n",
            "Processed 127300000 rows\n",
            "Processed 127400000 rows\n",
            "Processed 127500000 rows\n",
            "Processed 127600000 rows\n",
            "Processed 127700000 rows\n",
            "Processed 127800000 rows\n",
            "Processed 127900000 rows\n",
            "Processed 128000000 rows\n",
            "Processed 128100000 rows\n",
            "Processed 128200000 rows\n",
            "Processed 128300000 rows\n",
            "Processed 128400000 rows\n",
            "Processed 128500000 rows\n",
            "Processed 128600000 rows\n",
            "Processed 128700000 rows\n",
            "Processed 128800000 rows\n",
            "Processed 128900000 rows\n",
            "Processed 129000000 rows\n",
            "Processed 129100000 rows\n",
            "Processed 129200000 rows\n",
            "Processed 129300000 rows\n",
            "Processed 129400000 rows\n",
            "Processed 129500000 rows\n",
            "Processed 129600000 rows\n",
            "Processed 129700000 rows\n",
            "Processed 129800000 rows\n",
            "Processed 129900000 rows\n",
            "Processed 130000000 rows\n",
            "Processed 130100000 rows\n",
            "Processed 130200000 rows\n",
            "Processed 130300000 rows\n",
            "Processed 130400000 rows\n",
            "Processed 130500000 rows\n",
            "Processed 130600000 rows\n",
            "Processed 130700000 rows\n",
            "Processed 130800000 rows\n",
            "Processed 130900000 rows\n",
            "Processed 131000000 rows\n",
            "Processed 131100000 rows\n",
            "Processed 131200000 rows\n",
            "Processed 131300000 rows\n",
            "Processed 131400000 rows\n",
            "Processed 131500000 rows\n",
            "Processed 131600000 rows\n",
            "Processed 131700000 rows\n",
            "Processed 131800000 rows\n",
            "Processed 131900000 rows\n",
            "Processed 132000000 rows\n",
            "Processed 132100000 rows\n",
            "Processed 132200000 rows\n",
            "Processed 132300000 rows\n",
            "Processed 132400000 rows\n",
            "Processed 132500000 rows\n",
            "Processed 132600000 rows\n",
            "Processed 132700000 rows\n",
            "Processed 132800000 rows\n",
            "Processed 132900000 rows\n",
            "Processed 133000000 rows\n",
            "Processed 133100000 rows\n",
            "Processed 133200000 rows\n",
            "Processed 133300000 rows\n",
            "Processed 133400000 rows\n",
            "Processed 133500000 rows\n",
            "Processed 133600000 rows\n",
            "Processed 133700000 rows\n",
            "Processed 133800000 rows\n",
            "Processed 133900000 rows\n",
            "Processed 134000000 rows\n",
            "Processed 134100000 rows\n",
            "Processed 134200000 rows\n",
            "Processed 134300000 rows\n",
            "Processed 134400000 rows\n",
            "Processed 134500000 rows\n",
            "Processed 134600000 rows\n",
            "Processed 134700000 rows\n",
            "Processed 134800000 rows\n",
            "Processed 134900000 rows\n",
            "Processed 135000000 rows\n",
            "Processed 135100000 rows\n",
            "Processed 135200000 rows\n",
            "Processed 135300000 rows\n",
            "Processed 135400000 rows\n",
            "Processed 135500000 rows\n",
            "Processed 135600000 rows\n",
            "Processed 135700000 rows\n",
            "Processed 135800000 rows\n",
            "Processed 135900000 rows\n",
            "Processed 136000000 rows\n",
            "Processed 136100000 rows\n",
            "Processed 136200000 rows\n",
            "Processed 136300000 rows\n",
            "Processed 136400000 rows\n",
            "Processed 136500000 rows\n",
            "Processed 136600000 rows\n",
            "Processed 136700000 rows\n",
            "Processed 136800000 rows\n",
            "Processed 136900000 rows\n",
            "Processed 137000000 rows\n",
            "Processed 137100000 rows\n",
            "Processed 137200000 rows\n",
            "Processed 137300000 rows\n",
            "Processed 137400000 rows\n",
            "Processed 137500000 rows\n",
            "Processed 137600000 rows\n",
            "Processed 137700000 rows\n",
            "Processed 137800000 rows\n",
            "Processed 137900000 rows\n",
            "Processed 138000000 rows\n",
            "Processed 138100000 rows\n",
            "Processed 138200000 rows\n",
            "Processed 138300000 rows\n",
            "Processed 138400000 rows\n",
            "Processed 138500000 rows\n",
            "Processed 138600000 rows\n",
            "Processed 138700000 rows\n",
            "Processed 138800000 rows\n",
            "Processed 138900000 rows\n",
            "Processed 139000000 rows\n",
            "Processed 139100000 rows\n",
            "Processed 139200000 rows\n",
            "Processed 139300000 rows\n",
            "Processed 139400000 rows\n",
            "Processed 139500000 rows\n",
            "Processed 139600000 rows\n",
            "Processed 139700000 rows\n",
            "Processed 139800000 rows\n",
            "Processed 139900000 rows\n",
            "Processed 140000000 rows\n",
            "Processed 140100000 rows\n",
            "Processed 140200000 rows\n",
            "Processed 140300000 rows\n",
            "Processed 140400000 rows\n",
            "Processed 140500000 rows\n",
            "Processed 140600000 rows\n",
            "Processed 140700000 rows\n",
            "Processed 140800000 rows\n",
            "Processed 140900000 rows\n",
            "Processed 141000000 rows\n",
            "Processed 141100000 rows\n",
            "Processed 141200000 rows\n",
            "Processed 141300000 rows\n",
            "Processed 141400000 rows\n",
            "Processed 141500000 rows\n",
            "Processed 141600000 rows\n",
            "Processed 141700000 rows\n",
            "Processed 141800000 rows\n",
            "Processed 141900000 rows\n",
            "Processed 142000000 rows\n",
            "Processed 142100000 rows\n",
            "Processed 142200000 rows\n",
            "Processed 142300000 rows\n",
            "Processed 142400000 rows\n",
            "Processed 142500000 rows\n",
            "Processed 142600000 rows\n",
            "Processed 142700000 rows\n",
            "Processed 142800000 rows\n",
            "Processed 142900000 rows\n",
            "Processed 143000000 rows\n",
            "Processed 143100000 rows\n",
            "Processed 143200000 rows\n",
            "Processed 143300000 rows\n",
            "Processed 143400000 rows\n",
            "Processed 143500000 rows\n",
            "Processed 143600000 rows\n",
            "Processed 143700000 rows\n",
            "Processed 143800000 rows\n",
            "Processed 143900000 rows\n",
            "Processed 144000000 rows\n",
            "Processed 144100000 rows\n",
            "Processed 144200000 rows\n",
            "Processed 144300000 rows\n",
            "Processed 144400000 rows\n",
            "Processed 144500000 rows\n",
            "Processed 144600000 rows\n",
            "Processed 144700000 rows\n",
            "Processed 144800000 rows\n",
            "Processed 144900000 rows\n",
            "Processed 145000000 rows\n",
            "Processed 145100000 rows\n",
            "Processed 145200000 rows\n",
            "Processed 145300000 rows\n",
            "Processed 145400000 rows\n",
            "Processed 145500000 rows\n",
            "Processed 145600000 rows\n",
            "Processed 145700000 rows\n",
            "Processed 145800000 rows\n",
            "Processed 145900000 rows\n",
            "Processed 146000000 rows\n",
            "Processed 146100000 rows\n",
            "Processed 146200000 rows\n",
            "Processed 146300000 rows\n",
            "Processed 146400000 rows\n",
            "Processed 146500000 rows\n",
            "Processed 146600000 rows\n",
            "Processed 146700000 rows\n",
            "Processed 146800000 rows\n",
            "Processed 146900000 rows\n",
            "Processed 147000000 rows\n",
            "Processed 147100000 rows\n",
            "Processed 147200000 rows\n",
            "Processed 147300000 rows\n",
            "Processed 147400000 rows\n",
            "Processed 147500000 rows\n",
            "Processed 147600000 rows\n",
            "Processed 147700000 rows\n",
            "Processed 147800000 rows\n",
            "Processed 147900000 rows\n",
            "Processed 148000000 rows\n",
            "Processed 148100000 rows\n",
            "Processed 148200000 rows\n",
            "Processed 148300000 rows\n",
            "Processed 148400000 rows\n",
            "Processed 148500000 rows\n",
            "Processed 148600000 rows\n",
            "Processed 148700000 rows\n",
            "Processed 148800000 rows\n",
            "Processed 148900000 rows\n",
            "Processed 149000000 rows\n",
            "Processed 149100000 rows\n",
            "Processed 149200000 rows\n",
            "Processed 149300000 rows\n",
            "Processed 149400000 rows\n",
            "Processed 149500000 rows\n",
            "Processed 149600000 rows\n",
            "Processed 149700000 rows\n",
            "Processed 149800000 rows\n",
            "Processed 149900000 rows\n",
            "Processed 150000000 rows\n",
            "Processed 150100000 rows\n",
            "Processed 150200000 rows\n",
            "Processed 150300000 rows\n",
            "Processed 150400000 rows\n",
            "Processed 150500000 rows\n",
            "Processed 150600000 rows\n",
            "Processed 150700000 rows\n",
            "Processed 150800000 rows\n",
            "Processed 150900000 rows\n",
            "Processed 151000000 rows\n",
            "Processed 151100000 rows\n",
            "Processed 151200000 rows\n",
            "Processed 151300000 rows\n",
            "Processed 151400000 rows\n",
            "Processed 151500000 rows\n",
            "Processed 151600000 rows\n",
            "Processed 151700000 rows\n",
            "Processed 151800000 rows\n",
            "Processed 151900000 rows\n",
            "Processed 152000000 rows\n",
            "Processed 152100000 rows\n",
            "Processed 152200000 rows\n",
            "Processed 152300000 rows\n",
            "Processed 152400000 rows\n",
            "Processed 152500000 rows\n",
            "Processed 152600000 rows\n",
            "Processed 152700000 rows\n",
            "Processed 152800000 rows\n",
            "Processed 152900000 rows\n",
            "Processed 153000000 rows\n",
            "Processed 153100000 rows\n",
            "Processed 153200000 rows\n",
            "Processed 153300000 rows\n",
            "Processed 153400000 rows\n",
            "Processed 153500000 rows\n",
            "Processed 153600000 rows\n",
            "Processed 153700000 rows\n",
            "Processed 153800000 rows\n",
            "Processed 153900000 rows\n",
            "Processed 154000000 rows\n",
            "Processed 154100000 rows\n",
            "Processed 154200000 rows\n",
            "Processed 154300000 rows\n",
            "Processed 154400000 rows\n",
            "Processed 154500000 rows\n",
            "Processed 154600000 rows\n",
            "Processed 154700000 rows\n",
            "Processed 154800000 rows\n",
            "Processed 154900000 rows\n",
            "Processed 155000000 rows\n",
            "Processed 155100000 rows\n",
            "Processed 155200000 rows\n",
            "Processed 155300000 rows\n",
            "Processed 155400000 rows\n",
            "Processed 155500000 rows\n",
            "Processed 155600000 rows\n",
            "Processed 155700000 rows\n",
            "Processed 155800000 rows\n",
            "Processed 155900000 rows\n",
            "Processed 156000000 rows\n",
            "Processed 156100000 rows\n",
            "Processed 156200000 rows\n",
            "Processed 156300000 rows\n",
            "Processed 156400000 rows\n",
            "Processed 156500000 rows\n",
            "Processed 156600000 rows\n",
            "Processed 156700000 rows\n",
            "Processed 156800000 rows\n",
            "Processed 156900000 rows\n",
            "Processed 157000000 rows\n",
            "Processed 157100000 rows\n",
            "Processed 157200000 rows\n",
            "Processed 157300000 rows\n",
            "Processed 157400000 rows\n",
            "Processed 157500000 rows\n",
            "Processed 157600000 rows\n",
            "Processed 157700000 rows\n",
            "Processed 157800000 rows\n",
            "Processed 157900000 rows\n",
            "Processed 158000000 rows\n",
            "Processed 158100000 rows\n",
            "Processed 158200000 rows\n",
            "Processed 158300000 rows\n",
            "Processed 158400000 rows\n",
            "Processed 158500000 rows\n",
            "Processed 158600000 rows\n",
            "Processed 158700000 rows\n",
            "Processed 158800000 rows\n",
            "Processed 158900000 rows\n",
            "Processed 159000000 rows\n",
            "Processed 159100000 rows\n",
            "Processed 159200000 rows\n",
            "Processed 159300000 rows\n",
            "Processed 159400000 rows\n",
            "Processed 159500000 rows\n",
            "Processed 159600000 rows\n",
            "Processed 159700000 rows\n",
            "Processed 159800000 rows\n",
            "Processed 159900000 rows\n",
            "Processed 160000000 rows\n",
            "Processed 160100000 rows\n",
            "Processed 160200000 rows\n",
            "Processed 160300000 rows\n",
            "Processed 160400000 rows\n",
            "Processed 160500000 rows\n",
            "Processed 160600000 rows\n",
            "Processed 160700000 rows\n",
            "Processed 160800000 rows\n",
            "Processed 160900000 rows\n",
            "Processed 161000000 rows\n",
            "Processed 161100000 rows\n",
            "Processed 161200000 rows\n",
            "Processed 161300000 rows\n",
            "Processed 161400000 rows\n",
            "Processed 161500000 rows\n"
          ]
        }
      ],
      "source": [
        "from collections import defaultdict\n",
        "import pandas as pd\n",
        "\n",
        "# Step 1: group by patient_id and encounter_id\n",
        "grouped = defaultdict(lambda: {\"drugs\": [], \"procedures\": [], \"date\": None})\n",
        "\n",
        "count1 = 0\n",
        "count2 = 0\n",
        "\n",
        "for row in events_records:\n",
        "    # if count1 == 10000000 and row['modality'] == 'drug':\n",
        "    #     continue\n",
        "    # if count2 == 5000000:\n",
        "    #     break\n",
        "    key = (row['patient_id'], row['encounter_id'])\n",
        "    code = str(row['code'])\n",
        "    if row['code_system'] in ['NDC', 'RxNorm']:\n",
        "        grouped[key][\"drugs\"].append(row['code_system'] + str(code))\n",
        "        count1 += 1\n",
        "    else:\n",
        "        grouped[key][\"procedures\"].append(row['code_system'] + str(code))\n",
        "        count2 += 1\n",
        "\n",
        "    # Optional: store earliest date\n",
        "    # date = pd.to_datetime(row['start_date'], errors='coerce')\n",
        "    # if pd.notna(date):\n",
        "    #     if grouped[key][\"date\"] is None or date < grouped[key][\"date\"]:\n",
        "    #         grouped[key][\"date\"] = date\n",
        "\n",
        "    if count1 % 100000 == 0:\n",
        "       print(f\"Processed {count1} rows\")\n",
        "    if count2 % 100000 == 0 and count2 != 0:\n",
        "       print(f\"Processed {count2} rows\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "2tBOBZ8ksSKI"
      },
      "outputs": [],
      "source": [
        "samples = []\n",
        "patient_visit_count = defaultdict(int)\n",
        "\n",
        "for (patient_id, encounter_id), content in grouped.items():\n",
        "    vidx = patient_visit_count[patient_id]\n",
        "    sample = {\n",
        "        \"patient_id\": str(patient_id),\n",
        "        \"visit_id\": f\"{patient_id}_{vidx}\",\n",
        "        \"drugs\": content[\"drugs\"],\n",
        "        \"procedures\": content[\"procedures\"],\n",
        "        \"label\": 0  # Dummy label for embedding learning\n",
        "    }\n",
        "    samples.append(sample)\n",
        "    patient_visit_count[patient_id] += 1"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "zVIAZu3Nv4Yb"
      },
      "outputs": [],
      "source": [
        "%pip install pyhealth"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "p4bcmyIfZDSy"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/samples_for_retain.pkl\", \"wb\") as file:\n",
        "  pickle.dump(samples, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "f7tvHJEJZKFV"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/samples_for_retain.pkl\", \"rb\") as file:\n",
        "  samples = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "_OsNb5OCaer2"
      },
      "outputs": [],
      "source": [
        "for i in range(len(samples)-1, -1, -1):\n",
        "  if \"procedures\" not in samples[i].keys():\n",
        "    del samples[i]\n",
        "  if i % 100000 == 0:\n",
        "    print(i)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "rFj_HoxbDENt"
      },
      "outputs": [],
      "source": [
        "%pip install --force-reinstall pandas"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "AoGPJl_uxmV9"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import pandas as pd\n",
        "from collections import defaultdict\n",
        "\n",
        "from pyhealth.datasets import SampleEHRDataset, split_by_patient, get_dataloader\n",
        "from pyhealth.models import RETAIN\n",
        "from pyhealth.trainer import Trainer"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "p5hbH43-xfs9"
      },
      "outputs": [],
      "source": [
        "dataset = SampleEHRDataset(samples=samples, dataset_name=\"custom_ddi\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "4rCviZNTxwa3"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/samples_for_retain.pkl\", \"wb\") as file:\n",
        "  pickle.dump(dataset, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "zo0ihhFw_JFV"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/samples_for_retain.pkl\", \"rb\") as file:\n",
        "  dataset = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "F7zBhTx9E9g6"
      },
      "outputs": [],
      "source": [
        "dataset"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "jaZuadDzvpi8"
      },
      "outputs": [],
      "source": [
        "train_ds, val_ds, test_ds = split_by_patient(dataset, [0.8, 0.1, 0.1])\n",
        "train_loader = get_dataloader(train_ds, batch_size=64, shuffle=True)\n",
        "val_loader = get_dataloader(val_ds, batch_size=64, shuffle=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "71dcr6BqGgat"
      },
      "outputs": [],
      "source": [
        "from torch.utils.data import Subset\n",
        "\n",
        "base_train_ds = train_ds                      # start with the object you got back\n",
        "while isinstance(base_train_ds, Subset):      # peel off any nested Subsets\n",
        "    base_train_ds = base_train_ds.dataset\n",
        "\n",
        "print(type(base_train_ds))  # 👉🏻  <class 'pyhealth.datasets.sample_dataset.SampleEHRDataset'>"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "e_fcmF1NIcfg"
      },
      "outputs": [],
      "source": [
        "base_train_ds.input_info"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "vWDo9Goex95x"
      },
      "outputs": [],
      "source": [
        "from pyhealth.models import RETAIN\n",
        "\n",
        "feature_keys = [\"drugs\", \"procedures\"]   # adapt to your file\n",
        "label_key    = \"label\"                                       # binary or multi-label target\n",
        "mode         = \"multilabel\"                                      # \"multilabel\", \"multiclass\", \"regression\"\n",
        "\n",
        "model = RETAIN(\n",
        "    dataset       = base_train_ds,          # gives RETAIN access to vocab sizes etc.\n",
        "    feature_keys  = feature_keys,\n",
        "    label_key     = label_key,\n",
        "    mode          = mode,\n",
        "    embedding_dim = 64,               # tuning knobs\n",
        "    dropout       = 0.5,\n",
        ")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-GznlPabI54Q"
      },
      "outputs": [],
      "source": [
        "emb_layer = model.embeddings[\"drugs\"]        # nn.Embedding(vocab_size, embedding_dim)\n",
        "W         = emb_layer.weight                 # shape: [vocab_size, embedding_dim]\n",
        "W"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WRsUJlh-e5UT"
      },
      "outputs": [],
      "source": [
        "W.shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "naUv0c7wNDY_"
      },
      "outputs": [],
      "source": [
        "tokenizer = model.get_feature_tokenizers()['drugs']"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "msOKbHbsNIeg"
      },
      "outputs": [],
      "source": [
        "vocab_list = tokenizer.vocabulary"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "jkI7--p9NTj3"
      },
      "outputs": [],
      "source": [
        "id_drug_mapping = vocab_list.idx2token"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "dqtTl3zYfJuT"
      },
      "outputs": [],
      "source": [
        "drug_to_ehr_embeddings = {}\n",
        "for i in range(len(id_drug_mapping)):\n",
        "  drug_to_ehr_embeddings[id_drug_mapping[i]] = W[i].tolist()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "xnmcvEYXieTH"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/drug_to_ehr_embeddings.pkl\", \"wb\") as file:\n",
        "  pickle.dump(drug_to_ehr_embeddings, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "JsNTVBKEFKQU"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/drug_to_ehr_embeddings.pkl\", \"rb\") as file:\n",
        "  drug_to_ehr_embeddings = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 424
        },
        "id": "jrEOawLDVTtG",
        "outputId": "f1997c74-0b80-47b2-bfdc-7c9fce705085"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "                NDC   RxNorm  \\\n",
              "0           2000001  1367414   \n",
              "1           2000002  1367414   \n",
              "2           2001303       \\N   \n",
              "3           2001310       \\N   \n",
              "4           2001402   797697   \n",
              "...             ...      ...   \n",
              "910129  99528060612       \\N   \n",
              "910130  99528060625       \\N   \n",
              "910131  99528060645       \\N   \n",
              "910132  99528060690       \\N   \n",
              "910133  99528359003  1089766   \n",
              "\n",
              "                                                     Name  \\\n",
              "0          ergocalciferol 1.25 MG Oral Capsule [Deltalin]   \n",
              "1          ergocalciferol 1.25 MG Oral Capsule [Deltalin]   \n",
              "2                                                      \\N   \n",
              "3                                                      \\N   \n",
              "4       flurandrenolide 0.004 MG/SQCM Medicated Tape [...   \n",
              "...                                                   ...   \n",
              "910129                                                 \\N   \n",
              "910130                                                 \\N   \n",
              "910131                                                 \\N   \n",
              "910132                                                 \\N   \n",
              "910133                  menthol 35 MG/ML Topical Solution   \n",
              "\n",
              "                                                   Name 2  \n",
              "0                                                      \\N  \n",
              "1                                                      \\N  \n",
              "2           Insulin human 100 [iU]/mL injection, solution  \n",
              "3           Insulin human 100 [iU]/mL injection, solution  \n",
              "4                                                      \\N  \n",
              "...                                                   ...  \n",
              "910129  Valerian Root, Passiflora, Magnesium Carbonate...  \n",
              "910130  Valerian Root, Passiflora, Magnesium Carbonate...  \n",
              "910131  Valerian Root, Passiflora, Magnesium Carbonate...  \n",
              "910132  Valerian Root, Passiflora, Magnesium Carbonate...  \n",
              "910133                                                 \\N  \n",
              "\n",
              "[910134 rows x 4 columns]"
            ],
            "text/html": [
              "\n",
              "  <div id=\"df-bcc9cf48-b81d-4ac6-9949-a11277a0414a\" class=\"colab-df-container\">\n",
              "    <div>\n",
              "<style scoped>\n",
              "    .dataframe tbody tr th:only-of-type {\n",
              "        vertical-align: middle;\n",
              "    }\n",
              "\n",
              "    .dataframe tbody tr th {\n",
              "        vertical-align: top;\n",
              "    }\n",
              "\n",
              "    .dataframe thead th {\n",
              "        text-align: right;\n",
              "    }\n",
              "</style>\n",
              "<table border=\"1\" class=\"dataframe\">\n",
              "  <thead>\n",
              "    <tr style=\"text-align: right;\">\n",
              "      <th></th>\n",
              "      <th>NDC</th>\n",
              "      <th>RxNorm</th>\n",
              "      <th>Name</th>\n",
              "      <th>Name 2</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>2000001</td>\n",
              "      <td>1367414</td>\n",
              "      <td>ergocalciferol 1.25 MG Oral Capsule [Deltalin]</td>\n",
              "      <td>\\N</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>2000002</td>\n",
              "      <td>1367414</td>\n",
              "      <td>ergocalciferol 1.25 MG Oral Capsule [Deltalin]</td>\n",
              "      <td>\\N</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>2001303</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Insulin human 100 [iU]/mL injection, solution</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>2001310</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Insulin human 100 [iU]/mL injection, solution</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>4</th>\n",
              "      <td>2001402</td>\n",
              "      <td>797697</td>\n",
              "      <td>flurandrenolide 0.004 MG/SQCM Medicated Tape [...</td>\n",
              "      <td>\\N</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>...</th>\n",
              "      <td>...</td>\n",
              "      <td>...</td>\n",
              "      <td>...</td>\n",
              "      <td>...</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>910129</th>\n",
              "      <td>99528060612</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Valerian Root, Passiflora, Magnesium Carbonate...</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>910130</th>\n",
              "      <td>99528060625</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Valerian Root, Passiflora, Magnesium Carbonate...</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>910131</th>\n",
              "      <td>99528060645</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Valerian Root, Passiflora, Magnesium Carbonate...</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>910132</th>\n",
              "      <td>99528060690</td>\n",
              "      <td>\\N</td>\n",
              "      <td>\\N</td>\n",
              "      <td>Valerian Root, Passiflora, Magnesium Carbonate...</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>910133</th>\n",
              "      <td>99528359003</td>\n",
              "      <td>1089766</td>\n",
              "      <td>menthol 35 MG/ML Topical Solution</td>\n",
              "      <td>\\N</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "<p>910134 rows × 4 columns</p>\n",
              "</div>\n",
              "    <div class=\"colab-df-buttons\">\n",
              "\n",
              "  <div class=\"colab-df-container\">\n",
              "    <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-bcc9cf48-b81d-4ac6-9949-a11277a0414a')\"\n",
              "            title=\"Convert this dataframe to an interactive table.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
              "    <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "\n",
              "  <style>\n",
              "    .colab-df-container {\n",
              "      display:flex;\n",
              "      gap: 12px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert {\n",
              "      background-color: #E8F0FE;\n",
              "      border: none;\n",
              "      border-radius: 50%;\n",
              "      cursor: pointer;\n",
              "      display: none;\n",
              "      fill: #1967D2;\n",
              "      height: 32px;\n",
              "      padding: 0 0 0 0;\n",
              "      width: 32px;\n",
              "    }\n",
              "\n",
              "    .colab-df-convert:hover {\n",
              "      background-color: #E2EBFA;\n",
              "      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "      fill: #174EA6;\n",
              "    }\n",
              "\n",
              "    .colab-df-buttons div {\n",
              "      margin-bottom: 4px;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert {\n",
              "      background-color: #3B4455;\n",
              "      fill: #D2E3FC;\n",
              "    }\n",
              "\n",
              "    [theme=dark] .colab-df-convert:hover {\n",
              "      background-color: #434B5C;\n",
              "      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "      fill: #FFFFFF;\n",
              "    }\n",
              "  </style>\n",
              "\n",
              "    <script>\n",
              "      const buttonEl =\n",
              "        document.querySelector('#df-bcc9cf48-b81d-4ac6-9949-a11277a0414a button.colab-df-convert');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      async function convertToInteractive(key) {\n",
              "        const element = document.querySelector('#df-bcc9cf48-b81d-4ac6-9949-a11277a0414a');\n",
              "        const dataTable =\n",
              "          await google.colab.kernel.invokeFunction('convertToInteractive',\n",
              "                                                    [key], {});\n",
              "        if (!dataTable) return;\n",
              "\n",
              "        const docLinkHtml = 'Like what you see? Visit the ' +\n",
              "          '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
              "          + ' to learn more about interactive tables.';\n",
              "        element.innerHTML = '';\n",
              "        dataTable['output_type'] = 'display_data';\n",
              "        await google.colab.output.renderOutput(dataTable, element);\n",
              "        const docLink = document.createElement('div');\n",
              "        docLink.innerHTML = docLinkHtml;\n",
              "        element.appendChild(docLink);\n",
              "      }\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "\n",
              "    <div id=\"df-41ebd33f-eb13-44ef-8496-f673a680101b\">\n",
              "      <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-41ebd33f-eb13-44ef-8496-f673a680101b')\"\n",
              "                title=\"Suggest charts\"\n",
              "                style=\"display:none;\">\n",
              "\n",
              "<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "     width=\"24px\">\n",
              "    <g>\n",
              "        <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
              "    </g>\n",
              "</svg>\n",
              "      </button>\n",
              "\n",
              "<style>\n",
              "  .colab-df-quickchart {\n",
              "      --bg-color: #E8F0FE;\n",
              "      --fill-color: #1967D2;\n",
              "      --hover-bg-color: #E2EBFA;\n",
              "      --hover-fill-color: #174EA6;\n",
              "      --disabled-fill-color: #AAA;\n",
              "      --disabled-bg-color: #DDD;\n",
              "  }\n",
              "\n",
              "  [theme=dark] .colab-df-quickchart {\n",
              "      --bg-color: #3B4455;\n",
              "      --fill-color: #D2E3FC;\n",
              "      --hover-bg-color: #434B5C;\n",
              "      --hover-fill-color: #FFFFFF;\n",
              "      --disabled-bg-color: #3B4455;\n",
              "      --disabled-fill-color: #666;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart {\n",
              "    background-color: var(--bg-color);\n",
              "    border: none;\n",
              "    border-radius: 50%;\n",
              "    cursor: pointer;\n",
              "    display: none;\n",
              "    fill: var(--fill-color);\n",
              "    height: 32px;\n",
              "    padding: 0;\n",
              "    width: 32px;\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart:hover {\n",
              "    background-color: var(--hover-bg-color);\n",
              "    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "    fill: var(--button-hover-fill-color);\n",
              "  }\n",
              "\n",
              "  .colab-df-quickchart-complete:disabled,\n",
              "  .colab-df-quickchart-complete:disabled:hover {\n",
              "    background-color: var(--disabled-bg-color);\n",
              "    fill: var(--disabled-fill-color);\n",
              "    box-shadow: none;\n",
              "  }\n",
              "\n",
              "  .colab-df-spinner {\n",
              "    border: 2px solid var(--fill-color);\n",
              "    border-color: transparent;\n",
              "    border-bottom-color: var(--fill-color);\n",
              "    animation:\n",
              "      spin 1s steps(1) infinite;\n",
              "  }\n",
              "\n",
              "  @keyframes spin {\n",
              "    0% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "      border-left-color: var(--fill-color);\n",
              "    }\n",
              "    20% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    30% {\n",
              "      border-color: transparent;\n",
              "      border-left-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    40% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-top-color: var(--fill-color);\n",
              "    }\n",
              "    60% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "    }\n",
              "    80% {\n",
              "      border-color: transparent;\n",
              "      border-right-color: var(--fill-color);\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "    90% {\n",
              "      border-color: transparent;\n",
              "      border-bottom-color: var(--fill-color);\n",
              "    }\n",
              "  }\n",
              "</style>\n",
              "\n",
              "      <script>\n",
              "        async function quickchart(key) {\n",
              "          const quickchartButtonEl =\n",
              "            document.querySelector('#' + key + ' button');\n",
              "          quickchartButtonEl.disabled = true;  // To prevent multiple clicks.\n",
              "          quickchartButtonEl.classList.add('colab-df-spinner');\n",
              "          try {\n",
              "            const charts = await google.colab.kernel.invokeFunction(\n",
              "                'suggestCharts', [key], {});\n",
              "          } catch (error) {\n",
              "            console.error('Error during call to suggestCharts:', error);\n",
              "          }\n",
              "          quickchartButtonEl.classList.remove('colab-df-spinner');\n",
              "          quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
              "        }\n",
              "        (() => {\n",
              "          let quickchartButtonEl =\n",
              "            document.querySelector('#df-41ebd33f-eb13-44ef-8496-f673a680101b button');\n",
              "          quickchartButtonEl.style.display =\n",
              "            google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "        })();\n",
              "      </script>\n",
              "    </div>\n",
              "\n",
              "  <div id=\"id_7d1972d6-a76b-4a00-a165-f6415e09df9a\">\n",
              "    <style>\n",
              "      .colab-df-generate {\n",
              "        background-color: #E8F0FE;\n",
              "        border: none;\n",
              "        border-radius: 50%;\n",
              "        cursor: pointer;\n",
              "        display: none;\n",
              "        fill: #1967D2;\n",
              "        height: 32px;\n",
              "        padding: 0 0 0 0;\n",
              "        width: 32px;\n",
              "      }\n",
              "\n",
              "      .colab-df-generate:hover {\n",
              "        background-color: #E2EBFA;\n",
              "        box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
              "        fill: #174EA6;\n",
              "      }\n",
              "\n",
              "      [theme=dark] .colab-df-generate {\n",
              "        background-color: #3B4455;\n",
              "        fill: #D2E3FC;\n",
              "      }\n",
              "\n",
              "      [theme=dark] .colab-df-generate:hover {\n",
              "        background-color: #434B5C;\n",
              "        box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
              "        filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
              "        fill: #FFFFFF;\n",
              "      }\n",
              "    </style>\n",
              "    <button class=\"colab-df-generate\" onclick=\"generateWithVariable('ndc_rxnorm_conversion_df')\"\n",
              "            title=\"Generate code using this dataframe.\"\n",
              "            style=\"display:none;\">\n",
              "\n",
              "  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
              "       width=\"24px\">\n",
              "    <path d=\"M7,19H8.4L18.45,9,17,7.55,7,17.6ZM5,21V16.75L18.45,3.32a2,2,0,0,1,2.83,0l1.4,1.43a1.91,1.91,0,0,1,.58,1.4,1.91,1.91,0,0,1-.58,1.4L9.25,21ZM18.45,9,17,7.55Zm-12,3A5.31,5.31,0,0,0,4.9,8.1,5.31,5.31,0,0,0,1,6.5,5.31,5.31,0,0,0,4.9,4.9,5.31,5.31,0,0,0,6.5,1,5.31,5.31,0,0,0,8.1,4.9,5.31,5.31,0,0,0,12,6.5,5.46,5.46,0,0,0,6.5,12Z\"/>\n",
              "  </svg>\n",
              "    </button>\n",
              "    <script>\n",
              "      (() => {\n",
              "      const buttonEl =\n",
              "        document.querySelector('#id_7d1972d6-a76b-4a00-a165-f6415e09df9a button.colab-df-generate');\n",
              "      buttonEl.style.display =\n",
              "        google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
              "\n",
              "      buttonEl.onclick = () => {\n",
              "        google.colab.notebook.generateWithVariable('ndc_rxnorm_conversion_df');\n",
              "      }\n",
              "      })();\n",
              "    </script>\n",
              "  </div>\n",
              "\n",
              "    </div>\n",
              "  </div>\n"
            ],
            "application/vnd.google.colaboratory.intrinsic+json": {
              "type": "dataframe",
              "variable_name": "ndc_rxnorm_conversion_df"
            }
          },
          "metadata": {},
          "execution_count": 8
        }
      ],
      "source": [
        "import pandas as pd\n",
        "\n",
        "ndc_rxnorm_conversion_df = pd.read_csv(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/ndc.csv_0_0_0.csv\")\n",
        "ndc_rxnorm_conversion_df"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "A-B1WyZznazP"
      },
      "source": [
        "NDC to RxNorm Conversion with the CSV"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "KmASMfQGVfwZ"
      },
      "outputs": [],
      "source": [
        "ndc_to_rxnorm_conversion = {}\n",
        "for row in ndc_rxnorm_conversion_df.to_dict('records'):\n",
        "  if row['RxNorm'] != '\\\\N':\n",
        "    ndc_to_rxnorm_conversion[row['NDC']] = row['RxNorm']"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "lxiHTrkOV3XP"
      },
      "outputs": [],
      "source": [
        "rxnorm_to_ehr_embeddings = {}\n",
        "for key, value in drug_to_ehr_embeddings.items():\n",
        "  try:\n",
        "    if key[:3] == 'NDC':\n",
        "      modif_key = int(key[3:])\n",
        "      if key in ndc_to_rxnorm_conversion.keys():\n",
        "         modif_key = ndc_to_rxnorm_conversion[key]\n",
        "    else:\n",
        "      modif_key = int(key[6:])\n",
        "    rxnorm_to_ehr_embeddings[modif_key] = value\n",
        "  except:\n",
        "    continue"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "DK0baeGHYJUX"
      },
      "outputs": [],
      "source": [
        "len(rxnorm_to_ehr_embeddings)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5McfeNjZ_VeE"
      },
      "outputs": [],
      "source": [
        "from copy import deepcopy\n",
        "\n",
        "temp_dict = {}\n",
        "for key, value in rxn_to_embedding.items():\n",
        "  if key:\n",
        "    temp_dict[int(key)] = value\n",
        "\n",
        "rxn_to_embedding = deepcopy(temp_dict)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "t9vb9usFoI-g"
      },
      "outputs": [],
      "source": [
        "rxn_to_embedding.keys()-rxnorm_to_ehr_embeddings.keys()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "xTveDw-NYQoj"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "count = 0\n",
        "rxnorm_to_combined_embeddings = {}\n",
        "for key, value in rxn_to_embedding.items():\n",
        "  rxnorm_to_combined_embeddings[key] = value\n",
        "for key, value in rxnorm_to_ehr_embeddings.items():\n",
        "  if key in rxnorm_to_combined_embeddings.keys():\n",
        "    rxnorm_to_combined_embeddings[key] = torch.cat((rxnorm_to_combined_embeddings[key], torch.tensor(value)), dim=0)\n",
        "for key in rxnorm_to_combined_embeddings.keys():\n",
        "  if len(rxnorm_to_combined_embeddings[key]) != 128:\n",
        "    rxnorm_to_combined_embeddings[key] = torch.cat((rxnorm_to_combined_embeddings[key], torch.zeros(64)), dim=0)\n",
        "    count += 1"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "26G2aH4SA5HE"
      },
      "outputs": [],
      "source": [
        "sorted(rxnorm_to_ehr_embeddings.keys())"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "X3B5AZLw_8MJ"
      },
      "outputs": [],
      "source": [
        "sorted(rxn_to_embedding.keys())"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qpnOvNR2QQP3"
      },
      "outputs": [],
      "source": [
        "rxnorm_to_combined_embeddings"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "TCpfpvzWgGWp"
      },
      "outputs": [],
      "source": [
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/rxnorm_to_combined_embeddings.pkl\", \"wb\") as file:\n",
        "  pickle.dump(rxnorm_to_combined_embeddings, file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "OmEC6XVvmeHi"
      },
      "outputs": [],
      "source": [
        "import pickle\n",
        "\n",
        "with open(\"/content/drive/MyDrive/Colab Notebooks/CSIRE Project 2/CSV/rxnorm_to_combined_embeddings.pkl\", \"rb\") as file:\n",
        "  rxnorm_to_combined_embeddings = pickle.load(file)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-A2JvNLiyymK",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "f42d150f-8d17-4aca-819d-bf5e88578d58"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "6693\n"
          ]
        }
      ],
      "source": [
        "ehr_embeddings_to_test = []\n",
        "for i in [9384, 6693, 8698, 4603, 5487]:\n",
        "  try:\n",
        "    ehr_embeddings_to_test.append(rxnorm_to_ehr_embeddings[i])\n",
        "  except:\n",
        "    print(i)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "eSomLOzevLAS"
      },
      "outputs": [],
      "source": [
        "zeroed_drugs = set()\n",
        "\n",
        "for key in rxnorm_to_combined_embeddings.keys():\n",
        "  if list(rxnorm_to_combined_embeddings[key])[64:] == [0]*64:\n",
        "    zeroed_drugs.add(key)"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [
        "IRiLu8Yjqzah",
        "NNd9Su0NJxH7",
        "lqqrFZvvirVX",
        "APiIZagMqO_G",
        "vqtLp-PJ3O3c",
        "Mr_QejO8MaBe",
        "bOO75p0H5NlM",
        "bAqagWz6e3fe",
        "w7wcK4qU-U1Q",
        "SXFvarSBTGRE",
        "Zk_lxttMud11",
        "fvEXPHmuVqcZ",
        "8EGgghJdQhwW",
        "fYIXGWSvhNGD",
        "h76fgYu1n13w",
        "wn58St3lFEdC",
        "vLVIEQeAbZu-",
        "1US9EvbUVDi2",
        "xJyVPKN4UGWZ"
      ],
      "machine_shape": "hm",
      "provenance": [],
      "gpuType": "T4"
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "5a9c852eb707440fa4f4c171ecdf75a4": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_0f73572d48654c4f85f799f6888d4173",
              "IPY_MODEL_3a300d8b2edf4a60badec82795114e3c",
              "IPY_MODEL_b7b1920c06e741748693948cf89e71bc"
            ],
            "layout": "IPY_MODEL_fde000e37fea4725962209506120ce2a"
          }
        },
        "0f73572d48654c4f85f799f6888d4173": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_d5f2d0496428429697afdcea54dc29d4",
            "placeholder": "​",
            "style": "IPY_MODEL_5862d77882c34a4b81034d29c1d92d84",
            "value": "tokenizer_config.json: 100%"
          }
        },
        "3a300d8b2edf4a60badec82795114e3c": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_2d5b4a0d845c4593bad9d15a9f0ea508",
            "max": 166,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_0ec88dd2f18547cfb899b1fcdca4d963",
            "value": 166
          }
        },
        "b7b1920c06e741748693948cf89e71bc": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_f2f6a4b8f5584169aabe791b14151c4c",
            "placeholder": "​",
            "style": "IPY_MODEL_55b2a3e282f34649b1557143ebcbf5e2",
            "value": " 166/166 [00:00&lt;00:00, 13.4kB/s]"
          }
        },
        "fde000e37fea4725962209506120ce2a": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "d5f2d0496428429697afdcea54dc29d4": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "5862d77882c34a4b81034d29c1d92d84": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "2d5b4a0d845c4593bad9d15a9f0ea508": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "0ec88dd2f18547cfb899b1fcdca4d963": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "f2f6a4b8f5584169aabe791b14151c4c": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "55b2a3e282f34649b1557143ebcbf5e2": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "9866ce998b1a4319abbc3e444092f780": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_7a057441dd0e4a0f85438c9b95abe351",
              "IPY_MODEL_d3bf4ab2bbca4778ab945bd0349b9d9d",
              "IPY_MODEL_a830d63c369d405099ba0b83c54d5c31"
            ],
            "layout": "IPY_MODEL_99502a27a22943fc8a42fb2add84d994"
          }
        },
        "7a057441dd0e4a0f85438c9b95abe351": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_03269e7df51349dfa65413b5d28ddfe2",
            "placeholder": "​",
            "style": "IPY_MODEL_fa884d0cd78d4ec18cff593ebc5a3a35",
            "value": "config.json: 100%"
          }
        },
        "d3bf4ab2bbca4778ab945bd0349b9d9d": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_bbe0463caad945ea9cf6ee097e7c109b",
            "max": 501,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_e24d16b1eef94bd296c0f5bc53904171",
            "value": 501
          }
        },
        "a830d63c369d405099ba0b83c54d5c31": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_5b7cba406d18471c903da9e73e8f5445",
            "placeholder": "​",
            "style": "IPY_MODEL_177524600e9f40d2994e513f549229f7",
            "value": " 501/501 [00:00&lt;00:00, 53.1kB/s]"
          }
        },
        "99502a27a22943fc8a42fb2add84d994": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "03269e7df51349dfa65413b5d28ddfe2": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "fa884d0cd78d4ec18cff593ebc5a3a35": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "bbe0463caad945ea9cf6ee097e7c109b": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "e24d16b1eef94bd296c0f5bc53904171": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "5b7cba406d18471c903da9e73e8f5445": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "177524600e9f40d2994e513f549229f7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "b8c9b78ff3d543f0a536c86652ac1495": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_ff218e3692774565ae95b9a201e08e68",
              "IPY_MODEL_a7eac9e5034e4f3aa41e9ede8fda7251",
              "IPY_MODEL_5b33311bb96245db91646a26bc1028aa"
            ],
            "layout": "IPY_MODEL_6f42b8de803f46ddbc62953c60cf08b9"
          }
        },
        "ff218e3692774565ae95b9a201e08e68": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_64f032bcf07d401fb65e60b1f4f635ea",
            "placeholder": "​",
            "style": "IPY_MODEL_a2035711d968416ea6aab051924bf7c5",
            "value": "vocab.json: "
          }
        },
        "a7eac9e5034e4f3aa41e9ede8fda7251": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_05c3cc4af4f4419a95a61c25fe430c7b",
            "max": 1,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_ebfa20d5fb324898ae11b216bfe55cfc",
            "value": 1
          }
        },
        "5b33311bb96245db91646a26bc1028aa": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_83b4dfc8a94749558102c8c6246825a7",
            "placeholder": "​",
            "style": "IPY_MODEL_e5634b9f3207494ab50d2bbd3c069114",
            "value": " 9.43k/? [00:00&lt;00:00, 881kB/s]"
          }
        },
        "6f42b8de803f46ddbc62953c60cf08b9": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "64f032bcf07d401fb65e60b1f4f635ea": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "a2035711d968416ea6aab051924bf7c5": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "05c3cc4af4f4419a95a61c25fe430c7b": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": "20px"
          }
        },
        "ebfa20d5fb324898ae11b216bfe55cfc": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "83b4dfc8a94749558102c8c6246825a7": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "e5634b9f3207494ab50d2bbd3c069114": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "fd2e798427cc4f29ac1835dcaa0deb88": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_81d3a7dcced04c4fb576d82949b50383",
              "IPY_MODEL_4e013de02fb1491f93119dc3bf52227b",
              "IPY_MODEL_e677b52ab18f4a44bd03e0ce48d66e30"
            ],
            "layout": "IPY_MODEL_d69f1dbe0bff4ca99326f5cdaef950a8"
          }
        },
        "81d3a7dcced04c4fb576d82949b50383": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_6676e570f5f149f693f5d249445dc8b1",
            "placeholder": "​",
            "style": "IPY_MODEL_aecd817c908046dc9daf7dc722dd3168",
            "value": "merges.txt: "
          }
        },
        "4e013de02fb1491f93119dc3bf52227b": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_80023e2186fe4f168b06724580ef101c",
            "max": 1,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_5b16435040834cccad6d38475b023faf",
            "value": 1
          }
        },
        "e677b52ab18f4a44bd03e0ce48d66e30": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_35cd539908d143c79dd5047be34641e2",
            "placeholder": "​",
            "style": "IPY_MODEL_9807f686d15b4a54bf6b25acb2a32b34",
            "value": " 3.21k/? [00:00&lt;00:00, 364kB/s]"
          }
        },
        "d69f1dbe0bff4ca99326f5cdaef950a8": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "6676e570f5f149f693f5d249445dc8b1": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "aecd817c908046dc9daf7dc722dd3168": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "80023e2186fe4f168b06724580ef101c": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": "20px"
          }
        },
        "5b16435040834cccad6d38475b023faf": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "35cd539908d143c79dd5047be34641e2": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "9807f686d15b4a54bf6b25acb2a32b34": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "9f3f9f25857940b698e4d931262440b7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_129ef7aaf22e4c388d8b29c32569d4c2",
              "IPY_MODEL_6e549c60a3664348943088b3a5496963",
              "IPY_MODEL_2f77d8f1401541bb803bb7dcb1da0806"
            ],
            "layout": "IPY_MODEL_bc99c749328c4d7d992771870ff3ec16"
          }
        },
        "129ef7aaf22e4c388d8b29c32569d4c2": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_5efa8a4b7c4141a6a15cb25483889080",
            "placeholder": "​",
            "style": "IPY_MODEL_1ac0e420d7aa458288aeb7d22f71fc47",
            "value": "special_tokens_map.json: 100%"
          }
        },
        "6e549c60a3664348943088b3a5496963": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_d330a09889b84e8aad2075b365dd7211",
            "max": 150,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_ead518a639484f2a981401e780f97226",
            "value": 150
          }
        },
        "2f77d8f1401541bb803bb7dcb1da0806": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_d83286b62bb048e3a7c38789beedd414",
            "placeholder": "​",
            "style": "IPY_MODEL_2a6b407648244da1ab30ba89bf3dcc7e",
            "value": " 150/150 [00:00&lt;00:00, 15.7kB/s]"
          }
        },
        "bc99c749328c4d7d992771870ff3ec16": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "5efa8a4b7c4141a6a15cb25483889080": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "1ac0e420d7aa458288aeb7d22f71fc47": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "d330a09889b84e8aad2075b365dd7211": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "ead518a639484f2a981401e780f97226": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "d83286b62bb048e3a7c38789beedd414": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "2a6b407648244da1ab30ba89bf3dcc7e": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        }
      }
    },
    "accelerator": "GPU"
  },
  "nbformat": 4,
  "nbformat_minor": 0
}