{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-01T22:03:57.044082Z",
     "start_time": "2023-05-01T22:03:56.079501Z"
    }
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import logging\n",
    "import torch\n",
    "import transformers\n",
    "import datasets\n",
    "\n",
    "module_path = os.path.abspath(os.path.join('..'))\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(os.path.join(module_path, 'src'))\n",
    "\n",
    "logging.basicConfig(level=logging.INFO)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "BERT = 'BERT'\n",
    "GPT = 'GPT2'\n",
    "BERT_CONTEXT_SIZE=512\n",
    "GPT_CONTEXT_SIZE=1024\n",
    "device='cuda'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:datasets.builder:Found cached dataset wikipedia (/bigdata/cache/huggingface/wikipedia/20220301.en/2.0.0/aa542ed919df55cc5d3347f42dd4521d05ca68751f50dbc32bae2a7f1e167559)\n",
      "WARNING:datasets.arrow_dataset:Loading cached processed dataset at /bigdata/cache/huggingface/wikipedia/20220301.en/2.0.0/aa542ed919df55cc5d3347f42dd4521d05ca68751f50dbc32bae2a7f1e167559/cache-81755723a3757b4b.arrow\n"
     ]
    }
   ],
   "source": [
    "wiki = datasets.load_dataset('wikipedia', '20220301.en', split='train')\n",
    "wiki = wiki.filter(lambda x: len(x['text']) > 2000) # Only long articles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "class WikiDataset(torch.utils.data.Dataset):\n",
    "    def __init__(self, model_type, dataset_size, context_size, wiki_dataset, seed=42):\n",
    "        super().__init__()\n",
    "        self.dataset_size = dataset_size\n",
    "        self.model_type = model_type\n",
    "        self.context_size = context_size\n",
    "        self.rng = np.random.RandomState(seed)\n",
    "        \n",
    "        self.wiki = wiki_dataset\n",
    "        if model_type == GPT:\n",
    "            self.tokenizer = transformers.AutoTokenizer.from_pretrained(\"gpt2-large\")\n",
    "        else:\n",
    "            self.tokenizer = transformers.BertTokenizer.from_pretrained('bert-large-uncased')\n",
    "        self.X = torch.tensor(self._construct_dataset())\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx]\n",
    "\n",
    "    def __len__(self):\n",
    "        return self.dataset_size\n",
    "\n",
    "    def _construct_dataset(self):\n",
    "        X = []\n",
    "        for i in range(self.dataset_size):\n",
    "            if self.model_type == BERT:\n",
    "                random_sentence1 = self._random_sentence(self.context_size-2)\n",
    "                random_sentence2 = self._random_sentence(self.context_size-2)\n",
    "                len1 = self.rng.randint(5, self.context_size-2-5)\n",
    "                len2 = self.context_size - 2 - len1\n",
    "                if self.rng.uniform() < 0.5:\n",
    "                    random_sentence1 = random_sentence1[:len1]\n",
    "                    random_sentence2 = random_sentence2[:len2]\n",
    "                else:\n",
    "                    random_sentence1, random_sentence2 = random_sentence1[:len1], random_sentence1[len1:]\n",
    "                \n",
    "                tokenized = [self.tokenizer.cls_token_id] + random_sentence1 + [self.tokenizer.sep_token_id] + random_sentence2\n",
    "                assert len(tokenized) == self.context_size, len(tokenized)\n",
    "            else:\n",
    "                tokenized = self._random_sentence(self.context_size)\n",
    "            X.append(tokenized)\n",
    "        return X\n",
    "    def _random_sentence(self, sz):\n",
    "        while True:\n",
    "            doc_id = self.rng.randint(0, len(self.wiki))\n",
    "            doc_content = self.wiki[doc_id]['text']\n",
    "            doc_tokenized = self.tokenizer(doc_content, add_special_tokens=False).input_ids\n",
    "            if len(doc_tokenized) >= 1.5 * self.context_size: # Long enough articles\n",
    "                break\n",
    "        start_idx = self.rng.randint(0, len(doc_tokenized) - sz)\n",
    "        tokenized = doc_tokenized[start_idx:start_idx + sz]\n",
    "        return tokenized"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Token indices sequence length is longer than the specified maximum sequence length for this model (1810 > 1024). Running this sequence through the model will result in indexing errors\n",
      "Token indices sequence length is longer than the specified maximum sequence length for this model (578 > 512). Running this sequence through the model will result in indexing errors\n"
     ]
    }
   ],
   "source": [
    "gpt_dataset = WikiDataset(model_type=GPT, dataset_size=2000, context_size=GPT_CONTEXT_SIZE, wiki_dataset=wiki)\n",
    "bert_dataset = WikiDataset(model_type=BERT, dataset_size=2000, context_size=BERT_CONTEXT_SIZE, wiki_dataset=wiki)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of the model checkpoint at bert-large-uncased were not used when initializing BertModel: ['cls.predictions.transform.LayerNorm.weight', 'cls.predictions.bias', 'cls.predictions.transform.dense.bias', 'cls.predictions.transform.dense.weight', 'cls.predictions.transform.LayerNorm.bias', 'cls.seq_relationship.bias', 'cls.seq_relationship.weight', 'cls.predictions.decoder.weight']\n",
      "- This IS expected if you are initializing BertModel from the checkpoint of a model trained on another task or with another architecture (e.g. initializing a BertForSequenceClassification model from a BertForPreTraining model).\n",
      "- This IS NOT expected if you are initializing BertModel from the checkpoint of a model that you expect to be exactly identical (initializing a BertForSequenceClassification model from a BertForSequenceClassification model).\n"
     ]
    }
   ],
   "source": [
    "trained_bert = transformers.BertModel.from_pretrained('bert-large-uncased')\n",
    "trained_gpt2_model = transformers.GPT2Model.from_pretrained('gpt2-large')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "untrained_bert = transformers.BertModel(trained_bert.config, add_pooling_layer=trained_bert is not None)\n",
    "untrained_gpt = transformers.GPT2Model(trained_gpt2_model.config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "GPT2Model(\n",
       "  (wte): Embedding(50257, 1280)\n",
       "  (wpe): Embedding(1024, 1280)\n",
       "  (drop): Dropout(p=0.1, inplace=False)\n",
       "  (h): ModuleList(\n",
       "    (0): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (1): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (2): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (3): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (4): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (5): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (6): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (7): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (8): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (9): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (10): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (11): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (12): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (13): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (14): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (15): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (16): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (17): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (18): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (19): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (20): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (21): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (22): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (23): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (24): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (25): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (26): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (27): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (28): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (29): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (30): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (31): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (32): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (33): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (34): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "    (35): GPT2Block(\n",
       "      (ln_1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (attn): GPT2Attention(\n",
       "        (c_attn): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (attn_dropout): Dropout(p=0.1, inplace=False)\n",
       "        (resid_dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "      (ln_2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       "      (mlp): GPT2MLP(\n",
       "        (c_fc): Conv1D()\n",
       "        (c_proj): Conv1D()\n",
       "        (act): NewGELUActivation()\n",
       "        (dropout): Dropout(p=0.1, inplace=False)\n",
       "      )\n",
       "    )\n",
       "  )\n",
       "  (ln_f): LayerNorm((1280,), eps=1e-05, elementwise_affine=True)\n",
       ")"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trained_bert.eval()\n",
    "trained_gpt2_model.eval()\n",
    "untrained_bert.eval()\n",
    "untrained_gpt.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-01T22:04:03.195671Z",
     "start_time": "2023-05-01T22:04:02.021637Z"
    }
   },
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "def get_model_outs(model, dataset):\n",
    "    model = model.to(device)\n",
    "    data_loader = torch.utils.data.DataLoader(dataset, shuffle=False, batch_size=2)\n",
    "    result = {\n",
    "        'embedded': [],\n",
    "        'encoded': [],\n",
    "    }\n",
    "    for X in tqdm(data_loader):\n",
    "        with torch.no_grad():\n",
    "            X = X.to(device)\n",
    "            model_out = model(\n",
    "                input_ids=X,\n",
    "                output_hidden_states=True,\n",
    "                output_attentions=True,\n",
    "                use_cache=False,\n",
    "            )\n",
    "            result['embedded'].append(model_out.hidden_states[0].detach().clone().cpu())\n",
    "            result['encoded'].append(model_out.hidden_states[1].detach().clone().cpu()) \n",
    "    for k in result.keys():\n",
    "        if result[k]:\n",
    "            result[k] = torch.concat(result[k], dim=0)\n",
    "    model = model.to('cpu')\n",
    "    return result\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Warning: The following lines are memory intensive, it is better to run them one by one, and then proceed by loading from the disk."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-01T22:04:03.487471Z",
     "start_time": "2023-05-01T22:04:03.423149Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:55<00:00, 18.13it/s]\n"
     ]
    }
   ],
   "source": [
    "# outputs = {\n",
    "#     'trained_gpt2': get_model_outs(trained_gpt2_model, gpt_dataset),\n",
    "#     'untrained_gpt': get_model_outs(untrained_gpt, gpt_dataset),\n",
    "#     'trained_bert': get_model_outs(trained_bert, bert_dataset),\n",
    "#     'untrained_bert': get_model_outs(untrained_bert, bert_dataset),\n",
    "# }\n",
    "# torch.save(outputs, 'trained_gpt2_outputs.ckpt')\n",
    "# torch.save(outputs, 'untrained_gpt_outputs.ckpt')\n",
    "# torch.save(outputs, 'trained_bert_outputs.ckpt')\n",
    "# torch.save(outputs, 'untrained_bert_outputs.ckpt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "ename": "Exception",
     "evalue": "No Further",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mException\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn [10], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mException\u001b[39;00m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mNo Further\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[0;31mException\u001b[0m: No Further"
     ]
    }
   ],
   "source": [
    "raise Exception(\"No Further\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Since it takes to much RAM, from here, we load the computed ones from the disk"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "outputs = {}\n",
    "for file_name in ['trained_gpt2_outputs', 'untrained_gpt_outputs', 'trained_bert_outputs', 'untrained_bert_outputs']:\n",
    "    outputs.update(torch.load(f'{file_name}.ckpt'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPMAAADcCAYAAAClDJfcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAgFklEQVR4nO3df1hTdf8/8Oc22AbKNlF+rRAQAvmhYpi4FC0lh5JGWYZ6+ytu6QfURzFNL0shu+RWCy010btSM+tC74r7DrtRwh+kIiYFKqm3GoiKAxPYBGwoe3//6LuTxwEKDoeH1+O6dune53XOee/sPNn5sbMjYowxEEIeeGJbd4AQYh0UZkIEgsJMiEBQmAkRCAozIQJBYSZEICjMhAgEhZkQgaAwEyIQFOY28vb2xowZM2wy7xkzZsDb27tN4zzxxBMICQnpmA4R7Nu3DyKRCPv27bPaNJOTkyESido8nuDCfOjQISQnJ6O2ttbWXelyGhoakJycbNUVm9w9O1t3wNoOHTqElJQUzJgxAyqVyurTP336NMRiwf0NtIqGhgakpKQA+HOLgNxfggtzW5hMJjQ2NkIul9/1ODKZrAN79GAyL0diWzb/iGlpP/D2/QaRSITExERkZmYiJCQEMpkMwcHByM7O5o0zb948AICPjw9EIhFEIhHKysp409i2bRuCg4Mhk8m48d9//308/vjj6NmzJxwcHBAWFoZ//etfFv26fZ958+bNEIlEOHjwIJKSkuDi4oJu3brh2WefxZUrVyzG/+9//4uIiAh069YNTk5OiI6ORklJiUWd+XXK5XKEhITg22+/vavl2ZLCwkI8/vjjcHBwgI+PD9LT0y1qjEYjlixZAj8/P8hkMnh6emL+/PkwGo28uuaWY3p6OlxcXAAAKSkp3LJPTk6+6z62df6trQtmly5dQlxcHNRqNWQyGXx8fPDqq6/y/vj89ttveOGFF+Ds7AxHR0cMGTIEO3futJjWxYsXERMTg27dusHV1RVz5syx6JtZQUEBoqKioFQq4ejoiBEjRuDgwYMWdQcOHMBjjz0GuVwOX19fbNiw4a6XlwVmY9OnT2deXl4W7UuWLGG3dg8AGzBgAPPw8GBLly5lq1evZn369GGOjo7s999/Z4wxVlxczCZNmsQAsFWrVrGtW7eyrVu3srq6Om4agYGBzMXFhaWkpLB169axX375hTHG2MMPP8xee+01tnbtWpaWlsYGDx7MALCsrCxev7y8vNj06dO555s2bWIA2MCBA9nIkSPZmjVr2Ny5c5lEImETJ07kjfv5558zkUjEoqKi2Jo1a9jy5cuZt7c3U6lUrLS0lKvbtWsXE4vFLCQkhKWlpbFFixYxpVLJgoODm11WrRkxYgRTq9XM1dWVJSYmso8++ogNGzaMAWCffvopV9fU1MRGjx7NHB0d2ezZs9mGDRtYYmIis7OzY8888wxvms0txwMHDrD169czAOzZZ5/lln1xcfFd9bOt87/TusAYY5cuXWJqtZqbZnp6OnvnnXdYYGAgq6mpYYwxptPpmJubG3NycmKLFi1iaWlpbMCAAUwsFrNvvvmGm1ZDQwPz9/dncrmczZ8/n61evZqFhYWx/v37MwBs7969XG1ubi6TSqVMo9GwDz74gK1atYr179+fSaVSVlBQwNUdO3aMOTg4sN69e7PU1FS2dOlS5ubmxk2zrR6oMEulUnb27Fmurbi4mAFga9as4dpWrlzJAPDCces0xGIxKykpsRjW0NDAe97Y2MhCQkLYyJEjee0thTkyMpKZTCaufc6cOUwikbDa2lrGGGPXrl1jKpWKzZo1izc9nU7HlEolrz00NJR5eHhw4zLG2O7duxmAdoUZAPvggw+4NqPRyEJDQ5mrqytrbGxkjDG2detWJhaL2Y8//sgbPz09nQFgBw8e5NpaWo5XrlxhANiSJUva1Mf2zP9u1oVp06YxsVjMfvrpJ4v5md+r2bNnMwC8+V67do35+Pgwb29v1tTUxBhjbPXq1QwA2759O1dXX1/P/Pz8eGE2mUzskUceYVqtlrc+NDQ0MB8fH/bUU09xbTExMUwul7Pz589zbb/++iuTSCTtCrPNN7PbIjIyEr6+vtzz/v37Q6FQ4LfffrvraYwYMQJBQUEW7Q4ODtz/a2pqoNfrERERgZ9//vmuphsfH8/bLYiIiEBTUxPOnz8PAMjJyUFtbS0mTZqE33//nXtIJBKEh4dj7969AIDLly+jqKgI06dPh1Kp5Kb31FNPNdvvu2FnZ4eXX36Zey6VSvHyyy+jqqoKhYWFAIAdO3YgMDAQffv25fVv5MiRAMD1z6yl5dhebZ3/ndYFk8mEzMxMjBs3DoMGDbKYn/m9+v777zF48GAMGzaMG9a9e3fEx8ejrKwMv/76K1fn4eGB559/nqtzdHREfHw8b7pFRUU4c+YMJk+ejKtXr3Kvo76+HqNGjUJeXh5MJhOampqwa9cuxMTEoHfv3tz4gYGB0Gq17VqGD9QBsFtftFmPHj1QU1Nz19Pw8fFptj0rKwvvvfceioqKePtBd3u+7/a+9ejRAwC4vp05cwYAuJXzdgqFAgC48D/yyCMWNQEBAXf9x+VWarUa3bp147X5+/sDAMrKyjBkyBCcOXMGJ0+e5PZ7b1dVVcV73tJybK+2zv9O68KVK1dgMBjueI79/PnzCA8Pt2gPDAzkhoeEhOD8+fPw8/OzWB8CAgIsXgcATJ8+vcV56vV6GI1GXL9+vcX3+fvvv2+1382xeZhbCktTU5NFm0QiabaWteGXj279BDb78ccfMX78eAwfPhwff/wxPDw8YG9vj02bNuHLL7+8q+neqW8mkwkAsHXrVri7u1vU2dnZ9q0wmUzo168f0tLSmh3u6enJe97ccryf87fGutARzO/zypUrERoa2mxN9+7dWzxwdi9sHuYePXo0+wUP8ydUW7XnmzNff/015HI5du3axTv1tGnTpnb1oTnmTUJXV1dERka2WOfl5QXgr7/wtzp9+nS75l1RUYH6+nrep/P//vc/AODOJPj6+qK4uBijRo1q1zIE2rfszawx/1u5uLhAoVDgxIkTrdZ5eXk1u1xPnTrFDTf/e+LECTDGeP27fVzz+6xQKFp9n11cXODg4GDV99nm+8y+vr7Q6/U4duwY13b58uV2n4oxr7Bt+QaYRCKBSCTibQ2UlZUhMzOzXX1ojlarhUKhwLJly3Djxg2L4ebTWB4eHggNDcWWLVug1+u54Tk5Odz+W1vdvHmTd8qjsbERGzZsgIuLC8LCwgAAEydOxKVLl/DPf/7TYvzr16+jvr7+jvNxdHQE0LZlb2aN+d9KLBYjJiYG3333HY4ePWox3PwJPnbsWBw5cgT5+fncsPr6emzcuBHe3t7ccYGxY8eioqKCd7qyoaEBGzdu5E03LCwMvr6+eP/991FXV2cxX/P7LJFIoNVqkZmZifLycm74yZMnsWvXrja9VjObfzLHxsbirbfewrPPPos33ngDDQ0NWL9+Pfz9/du1f2heORctWoTY2FjY29tj3LhxFvuMt4qOjkZaWhqioqIwefJkVFVVYd26dfDz8+P9kbkXCoUC69evx9SpU/Hoo48iNjYWLi4uKC8vx86dOzF06FCsXbsWAJCamoro6GgMGzYML730Eqqrq7FmzRoEBwc3u4LciVqtxvLly1FWVgZ/f39kZGSgqKgIGzduhL29PQBg6tSp2L59O1555RXs3bsXQ4cORVNTE06dOoXt27dj165dzR5IupWDgwOCgoKQkZEBf39/ODs7IyQk5K6+G26N+d9u2bJl2L17N0aMGIH4+HgEBgbi8uXL2LFjBw4cOACVSoUFCxbgq6++wpgxY/DGG2/A2dkZW7ZsQWlpKb7++mvu236zZs3C2rVrMW3aNBQWFsLDwwNbt27l/oCZicVifPLJJxgzZgyCg4Mxc+ZMPPTQQ7h06RL27t0LhUKB7777DsCf5+Ozs7MRERGB1157DTdv3uTe53atd20+/t0Bdu/ezUJCQphUKmUBAQHsiy++aPbUVEJCgsW4t58qYoyxpUuXsoceeoiJxWLeaaqWpsEYY59++il75JFHmEwmY3379mWbNm2y6ENz8zOfmrr99MfevXstzj+a27VaLVMqlUwulzNfX182Y8YMdvToUV7d119/zQIDA5lMJmNBQUHsm2++afE0XmtGjBjBgoOD2dGjR5lGo2FyuZx5eXmxtWvXWtQ2Njay5cuXs+DgYCaTyViPHj1YWFgYS0lJYXq9nqtrbTkeOnSIhYWFMalU2ubTVPc6/+bWhfPnz7Np06YxFxcXJpPJWJ8+fVhCQgIzGo1czblz59jzzz/PVCoVk8vlbPDgwRbfLzBPa/z48czR0ZH16tWL/d///R/Lzs5u9n3+5Zdf2HPPPcd69uzJZDIZ8/LyYhMnTmS5ubm8uv3793PLq0+fPiw9Pb3Z9e5uiP7/wiGEPOBsvs9MCLEOm+8zk/aprq5u9eIGiUTS4jnb+6mxsRHV1dWt1iiVSquf6uqKaDP7AfXEE09g//79LQ738vLiLjCxpX379uHJJ59stWbTpk02+8EHIaEwP6AKCwtb/eabg4MDhg4deh971LyamhruK6MtCQ4OhoeHx33qkXBRmAkRCDoARohACPYAmMlkQkVFBZycnKzy9UBCWsIYw7Vr16BWq236k1KCDXNFRYXFl/MJ6UgXLlzAww8/bLP5CzbMTk5OAP5cwObLCwnpCAaDAZ6entw6ZyuCDbN501qhUFCYyX1h6925Nm3gp6am4rHHHoOTkxNcXV0RExNjcbnWH3/8gYSEBPTs2RPdu3fHhAkTUFlZyaspLy9HdHQ0HB0d4erqinnz5uHmzZu8mn379uHRRx+FTCaDn58fNm/e3L5XSEgX0aYw79+/HwkJCTh8+DBycnJw48YNjB49mnd52pw5c/Ddd99hx44d2L9/PyoqKvDcc89xw5uamhAdHY3GxkYcOnQIW7ZswebNm7F48WKuprS0FNHR0XjyySdRVFSE2bNn4+9//3u7Lw0jpEto86UZt6iqqmIA2P79+xljjNXW1jJ7e3u2Y8cOrubkyZMMAMvPz2eMMfb9998zsVjMdDodV7N+/XqmUCi4K1nmz5/PgoODefN68cUXmVarveu+6fV6BoB3tQ0hHaGzrGv3dBzdfPG8s7MzgD+/lXTjxg3eLyz07dsXvXv35i7+zs/PR79+/eDm5sbVaLVaGAwG7vej8/PzLX6lQavV8i4gJ4TwtfsAmMlkwuzZszF06FDu4nOdTgepVGpxWxg3NzfodDqu5tYgm4ebh7VWYzAYcP369Wa/lG80Gnm/q2QwGNr70gh5ILU7zAkJCThx4gQOHDhgzf60W2pqKnefI9JxvBdY3umhqyj7R7Stu9Cqdm1mJyYmIisrC3v37uWdJHd3d0djY6PFb0BVVlZyv0jp7u5ucXTb/PxONQqFosVL5RYuXAi9Xs89Lly40J6XRsgDq01hZowhMTER3377Lfbs2WPx28lhYWGwt7dHbm4u13b69GmUl5dDo9EAADQaDY4fP877HeScnBwoFArux9M0Gg1vGuYa8zSaI5PJuHPKdG6ZdEVt2sxOSEjAl19+iX//+99wcnLi9nHNF5crlUrExcUhKSkJzs7OUCgUeP3116HRaDBkyBAAwOjRoxEUFISpU6dixYoV0Ol0ePvtt5GQkMD9zO0rr7yCtWvXYv78+XjppZewZ88ebN++vdmbeRFC/tSmT+b169dDr9fjiSeegIeHB/fIyMjgalatWoWnn34aEyZMwPDhw+Hu7o5vvvmGGy6RSJCVlQWJRAKNRoO//e1vmDZtGt59912uxsfHBzt37kROTg4GDBiADz74AJ988km7b9tBSFcg2OuZDQYDlEol9Ho9bXJbER0As9RZ1jW6npkQgaAwEyIQFGZCBILCTIhAUJgJEQgKMyECQWEmRCAozIQIBIWZEIGgMBMiEBRmQgSCwkyIQFCYCREICjMhAkFhJkQgKMyECASFmRCBoDATIhAUZkIEgsJMiEBQmAkRCAozIQJBYSZEICjMhAgEhZkQgaAwEyIQbQ5zXl4exo0bB7VaDZFIhMzMTN7wGTNmQCQS8R5RUVG8murqakyZMgUKhQIqlQpxcXGoq6vj1Rw7dgwRERGQy+Xw9PTEihUr2v7qCOlC2hzm+vp6DBgwAOvWrWuxJioqCpcvX+YeX331FW/4lClTUFJSgpycHGRlZSEvLw/x8fHccIPBgNGjR8PLywuFhYVYuXIlkpOTsXHjxrZ2l5Auo023dAWAMWPGYMyYMa3WyGQy7sbptzt58iSys7Px008/YdCgQQCANWvWYOzYsXj//fehVquxbds2NDY24rPPPoNUKkVwcDCKioqQlpbGCz0h5C8dss+8b98+uLq6IiAgAK+++iquXr3KDcvPz4dKpeKCDACRkZEQi8UoKCjgaoYPHw6pVMrVaLVanD59GjU1Nc3O02g0wmAw8B6EdCVWD3NUVBQ+//xz5ObmYvny5di/fz/GjBmDpqYmAIBOp4OrqytvHDs7Ozg7O3M3b9fpdHBzc+PVmJ+ba26XmpoKpVLJPTw9Pa390gjp1Nq8mX0nsbGx3P/79euH/v37w9fXF/v27cOoUaOsPTvOwoULkZSUxD03GAwUaNKldPipqT59+qBXr144e/YsAMDd3R1VVVW8mps3b6K6uprbz3Z3d0dlZSWvxvy8pX1xmUwGhULBexDSlXR4mC9evIirV6/Cw8MDAKDRaFBbW4vCwkKuZs+ePTCZTAgPD+dq8vLycOPGDa4mJycHAQEB6NGjR0d3mZAHUpvDXFdXh6KiIhQVFQEASktLUVRUhPLyctTV1WHevHk4fPgwysrKkJubi2eeeQZ+fn7QarUAgMDAQERFRWHWrFk4cuQIDh48iMTERMTGxkKtVgMAJk+eDKlUiri4OJSUlCAjIwMffvghbzOaEMLX5jAfPXoUAwcOxMCBAwEASUlJGDhwIBYvXgyJRIJjx45h/Pjx8Pf3R1xcHMLCwvDjjz9CJpNx09i2bRv69u2LUaNGYezYsRg2bBjvHLJSqcTu3btRWlqKsLAwzJ07F4sXL6bTUoS0QsQYY7buREcwGAxQKpXQ6/W0/2xF3gt22roLNlP2j+hm2zvLukbfzSZEICjMhAgEhZkQgaAwEyIQFGZCBILCTIhAUJgJEQgKMyECQWEmRCAozIQIBIWZEIGgMBMiEBRmQgSCwkyIQFCYCREICjMhAkFhJkQgKMyECASFmRCBoDATIhAUZkIEgsJMiEBQmAkRCAozIQJBYSZEINoc5ry8PIwbNw5qtRoikQiZmZm84YwxLF68GB4eHnBwcEBkZCTOnDnDq6mursaUKVOgUCigUqkQFxeHuro6Xs2xY8cQEREBuVwOT09PrFixou2vjpAupM1hrq+vx4ABA7Bu3bpmh69YsQIfffQR0tPTUVBQgG7dukGr1eKPP/7gaqZMmYKSkhLk5OQgKysLeXl5vPtIGQwGjB49Gl5eXigsLMTKlSuRnJzMux8VIYTvnu41JRKJ8O233yImJgbAn5/KarUac+fOxZtvvgkA0Ov1cHNzw+bNmxEbG4uTJ08iKCgIP/30EwYNGgQAyM7OxtixY3Hx4kWo1WqsX78eixYtgk6ng1QqBQAsWLAAmZmZOHXq1F31rbPc/0do6F5TljrLumbVfebS0lLodDpERkZybUqlEuHh4cjPzwcA5OfnQ6VScUEGgMjISIjFYhQUFHA1w4cP54IMAFqtFqdPn0ZNTY01u0yIYNhZc2I6nQ4A4Obmxmt3c3Pjhul0Ori6uvI7YWcHZ2dnXo2Pj4/FNMzDmrvhutFohNFo5J4bDIZ7fDWEPFgEczQ7NTUVSqWSe3h6etq6S4TcV1YNs7u7OwCgsrKS115ZWckNc3d3R1VVFW/4zZs3UV1dzatpbhq3zuN2CxcuhF6v5x4XLly49xdEyAPEqmH28fGBu7s7cnNzuTaDwYCCggJoNBoAgEajQW1tLQoLC7maPXv2wGQyITw8nKvJy8vDjRs3uJqcnBwEBAQ0u4kNADKZDAqFgvcgpCtpc5jr6upQVFSEoqIiAH8e9CoqKkJ5eTlEIhFmz56N9957D//5z39w/PhxTJs2DWq1mjviHRgYiKioKMyaNQtHjhzBwYMHkZiYiNjYWKjVagDA5MmTIZVKERcXh5KSEmRkZODDDz9EUlKS1V44IULT5gNgR48exZNPPsk9Nwds+vTp2Lx5M+bPn4/6+nrEx8ejtrYWw4YNQ3Z2NuRyOTfOtm3bkJiYiFGjRkEsFmPChAn46KOPuOFKpRK7d+9GQkICwsLC0KtXLyxevJh3LpoQwndP55k7s85y7k9o6Dyzpc6yrgnmaDYhXR2FmRCBoDATIhAUZkIEgsJMiEBQmAkRCAozIQJBYSZEICjMhAgEhZkQgaAwEyIQFGZCBILCTIhAUJgJEQgKMyECQWEmRCAozIQIBIWZEIGgMBMiEBRmQgSCwkyIQFCYCREICjMhAkFhJkQgKMyECASFmRCBsHqYk5OTIRKJeI++fftyw//44w8kJCSgZ8+e6N69OyZMmGBx+9by8nJER0fD0dERrq6umDdvHm7evGntrhIiKG2+cdzdCA4Oxg8//PDXTOz+ms2cOXOwc+dO7NixA0qlEomJiXjuuedw8OBBAEBTUxOio6Ph7u6OQ4cO4fLly5g2bRrs7e2xbNmyjuguIYLQIWG2s7Nr9qboer0en376Kb788kuMHDkSALBp0yYEBgbi8OHDGDJkCHbv3o1ff/0VP/zwA9zc3BAaGoqlS5firbfeQnJyMqRSaUd0mZAHXofsM585cwZqtRp9+vTBlClTUF5eDgAoLCzEjRs3EBkZydX27dsXvXv3Rn5+PgAgPz8f/fr1g5ubG1ej1WphMBhQUlLSEd0lRBCs/skcHh6OzZs3IyAgAJcvX0ZKSgoiIiJw4sQJ6HQ6SKVSqFQq3jhubm7Q6XQAAJ1Oxwuyebh5WEuMRiOMRiP33GAwWOkVEfJgsHqYx4wZw/2/f//+CA8Ph5eXF7Zv3w4HBwdrz46TmpqKlJSUDps+IZ1dh5+aUqlU8Pf3x9mzZ+Hu7o7GxkbU1tbyaiorK7l9bHd3d4uj2+bnze2Hmy1cuBB6vZ57XLhwwbovhJBOrsPDXFdXh3PnzsHDwwNhYWGwt7dHbm4uN/z06dMoLy+HRqMBAGg0Ghw/fhxVVVVcTU5ODhQKBYKCglqcj0wmg0Kh4D0I6Uqsvpn95ptvYty4cfDy8kJFRQWWLFkCiUSCSZMmQalUIi4uDklJSXB2doZCocDrr78OjUaDIUOGAABGjx6NoKAgTJ06FStWrIBOp8Pbb7+NhIQEyGQya3eXEMGwepgvXryISZMm4erVq3BxccGwYcNw+PBhuLi4AABWrVoFsViMCRMmwGg0QqvV4uOPP+bGl0gkyMrKwquvvgqNRoNu3bph+vTpePfdd63dVUIERcQYY7buREcwGAxQKpXQ6/W0yW1F3gt22roLNlP2j+hm2zvLukbfzSZEICjMhAgEhZkQgaAwEyIQFGZCBILCTIhAUJgJEQgKMyECQWEmRCAozIQIBIWZEIGgMBMiEBRmQgSCwkyIQFCYCREICjMhAkFhJkQgKMyECASFmRCBoDATIhAUZkIEgsJMiEBQmAkRCAozIQJBYSZEICjMhAhEpw7zunXr4O3tDblcjvDwcBw5csTWXSKk0+q0Yc7IyEBSUhKWLFmCn3/+GQMGDIBWq+Xd6pUQ8pdOG+a0tDTMmjULM2fORFBQENLT0+Ho6IjPPvvM1l0jpFOy+i1draGxsRGFhYVYuHAh1yYWixEZGYn8/PxmxzEajTAajdxzvV4P4M879BHrMRkbbN0Fm2lpXTK32/qGqp0yzL///juamprg5ubGa3dzc8OpU6eaHSc1NRUpKSkW7Z6enh3SR9L1KFe3PvzatWtQKpX3pS/N6ZRhbo+FCxciKSmJe24ymVBdXY2ePXtCJBLZsGd8BoMBnp6euHDhAt03ug0683JjjOHatWtQq9U27UenDHOvXr0gkUhQWVnJa6+srIS7u3uz48hkMshkMl6bSqXqqC7eM4VC0elWygdBZ11utvxENuuUB8CkUinCwsKQm5vLtZlMJuTm5kKj0diwZ4R0Xp3ykxkAkpKSMH36dAwaNAiDBw/G6tWrUV9fj5kzZ9q6a4R0Sp02zC+++CKuXLmCxYsXQ6fTITQ0FNnZ2RYHxR40MpkMS5YssdglIK2j5XZnImbr4+mEEKvolPvMhJC2ozATIhAUZkIEgsJMiEBQmAkRCArzfVZTU4O6ujpbd4MIEIX5Prh58yZ27tyJF154AR4eHjh37lyzdefOnYNIJEJWVhZGjRoFR0dHBAQEoKCg4D73+MFCy+1PFOYOdPz4ccydOxcPP/wwpk2bBhcXF+zduxcDBgxotr64uBgikQhpaWl45513UFxcjN69e2PBggX3uef337Jly9C9e/dWH+Xl5c2O25WX26067TfAHlRXr17FF198gS1btqCkpARjx47Fxx9/jKeffhpSqbTVcYuLi6FSqZCRkQEXFxcAwPjx47Fhw4b70XWbeuWVVzBx4sRWa1q6KqkrL7dbUZitbM2aNUhJSUFERATOnj3bpuupi4uL8cwzz3ArJACUlpbCz8+vI7raqTg7O8PZ2bld43bl5XYr2sy2svj4eCxduhQ6nQ7BwcGYOXMm9uzZA5PJdMdxi4uLLa4KKyoqQmhoaAf1tvO4183srrrcbkXfze5Ahw4dwpYtW5CRkQEnJydMmTIFU6dORXBwsEWtXq+HSqXCkSNH8Nhjj3Htzs7O+OyzzxATE3Mfe37/VVdXo7q6utUab29v2NnxNya7+nLjYaTDXb9+nX311VdMq9UyiUTCjh07ZlGTl5fH7Ozs2PXr17m2srIyBoCVlpbex94+WGi5/YX2me8DuVyO2NhYxMbGoqKiAt27d7eoKS4uRkBAAORyOdf2yy+/QKVSwdvb+z729sFCy+0vtJlNiEDQATBCBILCTIhAUJgJEQgKMyECQWEmRCAozIQIBIWZEIGgMBMiEBRmQgSCwkyIQFCYCREICjMhAvH/ABX8i0PFTKkpAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def get_context_ranks(arr):\n",
    "    # get the ranks of the context\n",
    "    T, n, d = arr.shape\n",
    "    ranks = []\n",
    "    for i in range(T):\n",
    "        context = arr[i]\n",
    "        ranks.append(torch.linalg.matrix_rank(context))\n",
    "    return torch.tensor(ranks)\n",
    "\n",
    "for model_name, output_dict in outputs.items():\n",
    "    for key, arr in output_dict.items():\n",
    "        n = arr.shape[1]\n",
    "        ranks = get_context_ranks(arr)\n",
    "        plt.figure(figsize=(2, 2))\n",
    "        plt.bar(['$<n$', '$=n$'], [sum([r < n for r in ranks]), sum([r == n for r in ranks])])\n",
    "        plt.title(f'{model_name}_{key}')\n",
    "        plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "def minimal_check_n_kruskal_rank(arr, n_rank, total_exps=5000, device='cpu'):\n",
    "    arr = arr.to(device)\n",
    "    T = arr.shape[0]\n",
    "    cnt = 0\n",
    "    rank_dist = {}\n",
    "    for _ in tqdm(range(total_exps)):\n",
    "        random_perm = torch.randperm(T)[:n_rank]\n",
    "        sample = arr[random_perm, :]\n",
    "        rank = torch.linalg.matrix_rank(sample).item()\n",
    "        if rank == n_rank:\n",
    "            cnt += 1\n",
    "        rank_dist[rank] = rank_dist.get(rank, 0) + 1\n",
    "    return cnt / total_exps, rank_dist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [05:44<00:00, 14.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_gpt2_embedded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [06:16<00:00, 13.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_gpt2_embedded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [05:52<00:00, 14.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_gpt2_encoded, candid=n, fraction satisfied=1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [06:28<00:00, 12.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_gpt2_encoded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [05:41<00:00, 14.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_gpt_embedded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [06:18<00:00, 13.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_gpt_embedded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [05:50<00:00, 14.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_gpt_encoded, candid=n, fraction satisfied=1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [06:25<00:00, 12.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_gpt_encoded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [12:42<00:00,  6.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_bert_embedded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [05:34<00:00, 14.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_bert_embedded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [01:12<00:00, 69.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_bert_encoded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [03:58<00:00, 20.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trained_bert_encoded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [11:36<00:00,  7.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_bert_embedded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [04:42<00:00, 17.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_bert_embedded, candid=d, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [01:13<00:00, 68.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_bert_encoded, candid=n, fraction satisfied=0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|███████████████████████████████████████████████████████████████████████▌                                                           | 2730/5000 [02:12<01:49, 20.73it/s]"
     ]
    }
   ],
   "source": [
    "for model_name, output_dict in outputs.items():\n",
    "    for key, arr in output_dict.items():\n",
    "        b, n, d = arr.shape\n",
    "        query_idx = 0 if 'bert' in model_name else -1\n",
    "        cls_token = arr[:, query_idx, :]\n",
    "        for kruskal_candid, candid_name in zip([n, d], ['n', 'd']):\n",
    "            satisfied_percent, _ = minimal_check_n_kruskal_rank(cls_token, kruskal_candid)\n",
    "            print(f'{model_name}_{key}, candid={candid_name}, fraction satisfied={satisfied_percent}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2000, 512, 1024])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_name = untrained_bert\n",
    "outputs['untrained_bert']['embedded'].shape"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Kruskal Rank of BERT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "untrained_bert\n",
      "testing n= 340\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:41<00:00, 120.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9998, {340: 4999, 339: 1})\n",
      "testing n= 341\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 105.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.0, {341: 5000})\n",
      "testing n= 342\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:46<00:00, 107.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.0, {342: 5000})\n",
      "testing n= 343\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:46<00:00, 106.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9998, {343: 4999, 342: 1})\n",
      "testing n= 344\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:46<00:00, 107.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.999, {344: 4995, 343: 5})\n",
      "testing n= 345\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 105.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9986, {345: 4993, 344: 7})\n",
      "testing n= 346\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 105.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9992, {346: 4996, 345: 4})\n",
      "testing n= 347\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 105.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9984, {347: 4992, 346: 8})\n",
      "testing n= 348\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:46<00:00, 107.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9956, {348: 4978, 347: 22})\n",
      "testing n= 349\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 104.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9928, {349: 4964, 348: 36})\n",
      "testing n= 350\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:47<00:00, 104.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9878, {350: 4939, 349: 61})\n",
      "testing n= 351\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:37<00:00, 134.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9822, {351: 4911, 350: 89})\n",
      "testing n= 352\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:36<00:00, 135.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.967, {352: 4835, 351: 165})\n",
      "testing n= 353\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:37<00:00, 132.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.955, {352: 222, 353: 4775, 351: 3})\n",
      "testing n= 354\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:38<00:00, 130.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9318, {354: 4659, 353: 339, 352: 2})\n",
      "----------\n",
      "trained_bert\n",
      "testing n= 290\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:34<00:00, 146.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9996, {290: 4998, 289: 2})\n",
      "testing n= 291\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:34<00:00, 145.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9996, {291: 4998, 290: 2})\n",
      "testing n= 292\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:34<00:00, 145.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9992, {292: 4996, 291: 4})\n",
      "testing n= 293\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 142.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9996, {293: 4998, 292: 2})\n",
      "testing n= 294\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 142.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9986, {294: 4993, 293: 7})\n",
      "testing n= 295\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 141.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9964, {295: 4982, 294: 18})\n",
      "testing n= 296\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 142.41it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9952, {296: 4976, 295: 24})\n",
      "testing n= 297\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 139.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9922, {297: 4961, 296: 39})\n",
      "testing n= 298\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 140.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9834, {298: 4917, 297: 83})\n",
      "testing n= 299\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 140.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9696, {299: 4848, 298: 151, 297: 1})\n",
      "testing n= 300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:35<00:00, 141.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9554, {300: 4777, 299: 222, 298: 1})\n",
      "testing n= 301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:36<00:00, 138.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.9232, {301: 4616, 300: 383, 299: 1})\n",
      "testing n= 302\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:36<00:00, 137.55it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.88, {302: 4400, 301: 596, 300: 4})\n",
      "testing n= 303\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:36<00:00, 136.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.8344, {303: 4172, 302: 821, 301: 7})\n",
      "testing n= 304\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 5000/5000 [00:36<00:00, 137.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0.767, {304: 3835, 303: 1142, 302: 23})\n",
      "----------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "for key, ranges in reversed(list(zip(['trained_bert', 'untrained_bert'], [range(290, 305), range(340, 355)]))):\n",
    "    print(key)\n",
    "    for n in ranges:\n",
    "        print('testing n=', n)\n",
    "        print(minimal_check_n_kruskal_rank(outputs[key]['encoded'][:, 0, :], n, total_exps=5000))\n",
    "    print('-'*10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
