{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ca461cfd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using data file: ./data/wikitext_train_v10000_w20_s1.npz\n",
      "Loaded vocab (10000 tokens). lowercase=False\n",
      "Found 12/12 month tokens: January, February, March, April, May, June, July, August, September, October, November, December\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Collecting windows: 100%|█████████▉| 199999/200000 [02:08<00:00, 1553.13it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Performing PCA on 200,000 windows...\n",
      "Explained variance ratio: [0.3142 0.0818]\n"
     ]
    },
    {
     "data": {
      "image/png": "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6oo6depIw5PHjx/P8x8UeenQoQNMTU3x559/wszMTK1j8nL79m0IITBlyhRYW1urvAIDAwG8nB+Ww8LCAosXL8alS5egVCqxePFijc63b98+tGnTRqPJ887OznmWr1+/HrVr14ZCoYClpSWsra2xb98+tb+HBfG7ToWHc8SoyHB3d4ebm1u++6tWrYoLFy4gIyNDrTvVcnpeevbsmef+f/75By1atHi3YAtIgwYNUKFCBekO0U8++aTA2pbL5XmWi1cmKBdWGxs3bgQAjB49GqNHj861f/v27ejfv7/acWiqV69e+O677/DkyROYmppi9+7d8PPzU/mj+eWXXyIoKAijRo2Ch4cHlEolZDIZevfu/dYkvaCo8/6OGjUKHTp0wK5du/Dnn39iypQpmDVrFv7++2/UrVs3z+O3bt36zu+vv78/1q1bl+/+Jk2aIDMzE6GhoQgJCZESLk9PT4SEhOD69euIjY1VOxHr1q0b1q9fj02bNuGzzz57p5gBSJ/ZuHHj8r3ZpWLFiirbf/75J4CXCcuDBw/UvvM5NTUVR48e1Xhdwld7YXNs3LgRAQEB6Ny5M8aPHw8bGxvI5XLMmjVLmif7NgXxu06Fh4kYFRsdOnRAaGgotm/frjL0k5dnz57h999/R69evfKc3D9ixAhs2rTpjYmYo6MjLl26hOzsbJUejuvXr0v7C4Kfnx9mzpyJatWq5TsxN+dcN27cyLXv+vXrsLKygrGxscbnftfhvzcRQmDz5s1o0aIFvvjii1z7Z8yYgU2bNqF///4oX748gJfDUwUZZ69evTB9+nRs374dtra2SEpKQu/evVXq/Pbbb/D398f8+fOlsrS0tFyLxmpy7sL6zlSoUAFjx47F2LFjcevWLbi4uGD+/PlSwvs6b29vHDp06J3OVbp06Tfud3d3h76+PkJCQhASEiLd0dq0aVOsWrUKhw8flrbVMW/ePOjq6uKLL76AqanpW/8xkt/nkfNd0tPTy3ex5FcdOHAAq1evxldffYVNmzbB398fp06dUknW8zvX33//jfT0dLRt21at2N7kt99+Q/ny5bFjxw6V43N68ajoYyJGxcbQoUPx008/YezYsahXrx4qV66ssj8mJgYrV67EN998g507d+LZs2cYNmxYnv8yP3jwILZt24YlS5bku0aRr68vDh48iK1bt0qJ34sXL/DTTz/B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pBKxrVu3YsyYMQgMDMS5c+dQp04deHt75/s099TUVJQvXx6zZ8+GnZ1dgbRJREREVFCKVCK2YMECDB48GP3790f16tWxfPlyGBkZYe3atXnWr1+/PubNm4fevXvDwMCgQNoEgPT0dCQlJam8iIiIiDRVZBKxjIwMnD17Fl5eXlKZjo4OvLy8EBoa+kHbnDVrFpRKpfRycHB4p/MTERFRyVZkErEnT54gKysLtra2KuW2traIior6oG1OmjQJiYmJ0uv+/fvvdH4iIiIq2XjX5DswMDDId6iTiIiISF1FpkfMysoKcrkc0dHRKuXR0dH5TsTXRptERERE6ioyiZi+vj7q1auHw4cPS2XZ2dk4fPgwPDw8Ppo2iYiIiNRVpIYmx4wZA39/f7i5ucHd3R2LFi3Cs2fP0L9/fwBAv379UKZMGcyaNQvAy8n4V69elX5++PAhLly4ABMTE1SsWFGtNomIiIgKS5FKxHr16oXY2FhMnToVUVFRcHFxwYEDB6TJ9pGRkdDR+V8n36NHj1C3bl1p+4cffsAPP/yAZs2a4ejRo2q1SURERFRYZEIIoe0girqkpCQolUokJibCzMxM2+F8tIKDg+Hn56ftMIiIiAqVJnlBkZkjRkRERFTcMBEjIiIi0hImYkRERERawkSMiIiISEuYiBERERFpCRMxIiIiIi1hIkZERESkJUzEiIiIiLSEiRgRERGRljARIyIiItISJmJEREREWsJEjIiIiEhLmIgRERERaQkTMSIiIiItYSJGREREpCVMxIiIiIi0hIkYERERkZYwESMiIiLSEiZiRERERFrCRIyIiIhIS5iIEREREWkJEzEiIiIiLWEiRkRERKQlTMSIiIiItISJGBEREZGWMBEjIiIi0hImYkRERERawkSMiIiISEuYiBERERFpCRMxIiIiIi1hIkZERESkJUzEiIiIiLSEiRgRERGRljARIyIiItISJmJEREREWsJEjIiIiEhLmIgRERERaQkTMSIiIiItYSJGREREpCVMxIiIiIi0hIkYERERkZYwESMiIiLSEiZiRERERFrCRIyIiIhIS5iIEREREWkJEzEiIiIiLWEiRkRERKQlTMSIiIiItISJGBEREZGWMBEjIiIi0hImYkRERERawkSMiIiISEuYiBERERFpCRMxIiIiIi1hIkZERESkJUzEiIiIiLSEiRgRERGRljARIyIiItISJmJEREREWsJEjIiIiEhLmIgRERERaQkTMSIiIiItYSJGREREpCVMxIiIiIi0pMglYkuWLIGTkxMUCgUaNGiAsLCwN9bftm0bqlatCoVCgVq1amH//v0q+wMCAiCTyVRePj4+hXkJRERERADeMRHLzMzE/fv3cePGDcTFxRV0TPnaunUrxowZg8DAQJw7dw516tSBt7c3YmJi8qz/77//ws/PDwMHDsT58+fRuXNndO7cGVeuXFGp5+Pjg8ePH0uv4ODgD3E5REREVMKpnYglJydj2bJlaNasGczMzODk5IRq1arB2toajo6OGDx4ME6fPl2YsWLBggUYPHgw+vfvj+rVq2P58uUwMjLC2rVr86z/448/wsfHB+PHj0e1atUwY8YMuLq64ueff1apZ2BgADs7O+lVqlSpQr0OIiIiIkDNRGzBggVwcnJCUFAQvLy8sGvXLly4cAE3b95EaGgoAgMD8eLFC7Rp0wY+Pj64detWgQeakZGBs2fPwsvL63/B6+jAy8sLoaGheR4TGhqqUh8AvL29c9U/evQobGxsUKVKFXz++ed4+vTpG2NJT09HUlKSyouIiIhIU7rqVDp9+jSOHTuGGjVq5Lnf3d0dAwYMwPLlyxEUFISQkBBUqlSpQAN98uQJsrKyYGtrq1Jua2uL69ev53lMVFRUnvWjoqKkbR8fH3Tt2hXOzs4IDw/H5MmT0bZtW4SGhkIul+fZ7qxZszB9+vT3vCIiIiIq6dRKxNSdM2VgYIChQ4e+V0AfWu/evaWfa9Wqhdq1a6NChQo4evQoWrVqlecxkyZNwpgxY6TtpKQkODg4FHqsREREVLy8912TSUlJ2LVrF65du1YQ8eTLysoKcrkc0dHRKuXR0dGws7PL8xg7OzuN6gNA+fLlYWVlhdu3b+dbx8DAAGZmZiovIiIiIk1pnIj17NlTmuz+/PlzuLm5oWfPnqhduza2b99e4AHm0NfXR7169XD48GGpLDs7G4cPH4aHh0eex3h4eKjUB4BDhw7lWx8AHjx4gKdPn8Le3r5gAiciIiLKh8aJ2LFjx+Dp6QkA2LlzJ4QQSEhIwOLFizFz5swCD/BVY8aMwapVq7B+/Xpcu3YNn3/+OZ49e4b+/fsDAPr164dJkyZJ9UeOHIkDBw5g/vz5uH79OqZNm4YzZ85g+PDhAICUlBSMHz8eJ0+exN27d3H48GF06tQJFStWhLe3d6FeCxEREZFac8RelZiYCAsLCwDAgQMH0K1bNxgZGaFdu3YYP358gQf4ql69eiE2NhZTp05FVFQUXFxccODAAWlCfmRkJHR0/pdbNmrUCJs3b8Y333yDyZMno1KlSti1axdq1qwJAJDL5bh06RLWr1+PhIQElC5dGm3atMGMGTNgYGBQqNdCREREpHEi5uDggNDQUFhYWODAgQPYsmULACA+Ph4KhaLAA3zd8OHDpR6t1x09ejRXWY8ePdCjR4886xsaGuLPP/8syPCIiIiI1KZxIjZq1Cj06dMHJiYmcHR0RPPmzQG8HLKsVatWQcdHREREVGxpnIh98cUXcHd3x/3799G6dWtpKLB8+fKFPkeMiIiIqDjROBEDADc3N7i5uamUtWvXrkACIiIiIiopNE7EXl3I9FUymQwKhQIVK1ZEp06dpAn9RERERJQ3jROx8+fP49y5c8jKykKVKlUAADdv3oRcLkfVqlWxdOlSjB07FsePH0f16tULPGAiIiKi4kLjdcQ6deoELy8vPHr0CGfPnsXZs2fx4MEDtG7dGn5+fnj48CGaNm2K0aNHF0a8RERERMWGxonYvHnzMGPGDJXH+iiVSkybNg1z586FkZERpk6dirNnzxZooERERETFjcaJWGJiImJiYnKVx8bGIikpCQBgbm6OjIyM94+OiIiIqBh7p6HJAQMGYOfOnXjw4AEePHiAnTt3YuDAgejcuTMAICwsDJUrVy7oWImIiIiKFY0n669YsQKjR49G79698eLFi5eN6OrC398fCxcuBABUrVoVq1evLthIiYiIiIoZjRMxExMTrFq1CgsXLsSdO3cAvFzM1cTERKrj4uJSYAESERERFVfvtKAr8DIhq127dkHGQkRERFSiaJyIPXv2DLNnz8bhw4cRExOD7Oxslf05vWRERERE9GYaJ2KDBg3CP//8g08//RT29vaQyWSFERcRERFRsadxIvbHH39g3759aNy4cWHEQ0RERFRiaLx8RalSpfgcSSIiIqICoHEiNmPGDEydOhWpqamFEQ8RERFRiaHx0OT8+fMRHh4OW1tbODk5QU9PT2X/uXPnCiw4IiIiouJM40QsZ/V8IiIiIno/GidigYGBhREHERERUYmj8RwxIiIiIioYavWIWVhY4ObNm7CyskKpUqXe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HjwYYWFhOHHiBIYPH47evXtLdzY+fPgQVatWRVhYmHRcVFQULly4gNu3bwMALl++jAsXLiAuLk7tdomIiIgKS5FIxABg06ZNqFq1Klq1agVfX180adIEK1eulPZnZmbixo0bSE1NlcqWL1+OunXrYvDgwQCApk2bom7duti9e7fa7RIREREVliKxjtjHTpP1QkoyriNGREQlQbFbR4yIiIioOGIiRkRERKQlTMSIiIiItISJGBEREZGWMBEjIiIi0hImYkRERERawkSMiIiISEuYiBERERFpCRMxIiIiIi1hIkZERESkJUzEiIiIiLSEiRgRERGRljARIyIiItISJmJEREREWsJEjIiIiEhLmIgRERERaQkTMSIiIiItYSJGREREpCVMxIiIiIi0hIkYERERkZYwESMiIiLSEiZiREREJVRAQAA6d+6s7TBKNCZiRERERFrCRIyIiIjg5OSERYsWqZS5uLhg2rRp0rZMJsPq1avRpUsXGBkZoVKlSti9e7fKMVeuXEHbtm1hYmICW1tbfPrpp3jy5MkHuIKiiYkYERERqW369Ono2bMnLl26BF9fX/Tp0wdxcXEAgISEBLRs2RJ169bFmTNncODAAURHR6Nnz55ajvrjxUSMiIiI1BYQEAA/Pz9UrFgR33//PVJSUhAWFgYA+Pnnn1G3bl18//33qFq1KurWrYu1a9fiyJEjuHnzppYj/zjpajsAIiIiKjpq164t/WxsbAwzMzPExMQAAC5evIgjR47AxMQk13Hh4eGoXLnyB4uzqGAiRkRERNDR0YEQQqUsMzMzVz09PT2VbZlMhuzsbABASkoKOnTogDlz5uQ6zt7evgCjLT6YiBERERGsra3x+PFjaTspKQkRERHSdlb2yyTtVMRT2IY/hbuzBeQ6MpU2XF1dsX37djg5OUFXlymGOjhHjIiIiNCyZUts2LABISEhuHz5Mvz9/SGXywEAB648RpM5fwMA1oREwG/VSTSZ8zcOXHms0sawYcMQFxcHPz8/nD59GuHh4fjzzz/Rv39/ZGVlffBrKgqYrhIREZVQ2dnZUs/VpEmTEBERgfbt20OpVGLGjBmIiIjA7ZhkrN94DuK1Y6MS0/D5xnN4kf2/PaVLl8aJEycwYcIEtGnTBunp6XB0dISPjw90dNj3kxcmYkRERCVUTEwMKlasCAAwMzPDli1bVPb3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",
      "text/plain": [
       "<Figure size 620x620 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# %% [markdown]\n",
    "# # PCA of month activations across a subset of dataset windows\n",
    "# \n",
    "# This script performs Principal Component Analysis (PCA) on the binary activations of month tokens within a text dataset. It has been updated to load a specific subset of the data into memory and then apply PCA, which is suitable for datasets that can partially fit into memory.\n",
    "\n",
    "# %% [code]\n",
    "from pathlib import Path\n",
    "import os, json, torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from glob import glob\n",
    "from tqdm import tqdm\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "# --------------------\n",
    "# User-editable params\n",
    "# --------------------\n",
    "DATA_DIR    = \"./data\"      # where your *_v*_w*_s* files were saved\n",
    "DATASET     = \"wikitext\"    # \"wikitext\" or \"openwebtext\" (must match your filenames)\n",
    "SPLIT       = \"train\"       # \"train\" | \"validation\" | \"test\"\n",
    "# Use a subset of windows for PCA. Set to None to use all windows (may be memory-intensive).\n",
    "SUBSAMPLE   = 200_000       # e.g., 200_000 to limit windows used; None = use all\n",
    "SAVE_FIG    = False         # True to save a PDF\n",
    "FIG_PATH    = \"months_pca_loadings.pdf\"\n",
    "\n",
    "# Canonical month names (we'll search both \"January\" and \"january\" in the vocab)\n",
    "MONTHS = [\"January\",\"February\",\"March\",\"April\",\"May\",\"June\",\n",
    "          \"July\",\"August\",\"September\",\"October\",\"November\",\"December\"]\n",
    "\n",
    "# --------------------\n",
    "# Helpers\n",
    "# --------------------\n",
    "def find_split_file(data_dir, dataset, split):\n",
    "    # Look for any of the supported formats produced by your script\n",
    "    patterns = [\n",
    "        f\"{dataset}_{split}_v*_w*_s*.npz\",\n",
    "        f\"{dataset}_{split}_v*_w*_s*.pt\",\n",
    "        f\"{dataset}_{split}_v*_w*_s*.jsonl\",\n",
    "    ]\n",
    "    candidates = []\n",
    "    for pat in patterns:\n",
    "        candidates.extend(glob(os.path.join(data_dir, pat)))\n",
    "    if not candidates:\n",
    "        raise FileNotFoundError(f\"No files like {patterns} found in {data_dir}\")\n",
    "    # Prefer smallest group size, then newest by mtime, then name\n",
    "    def parse_details(p):\n",
    "        b = os.path.basename(p)\n",
    "        # try to pull out group_size and vocab_size for a reasonable sort\n",
    "        import re\n",
    "        m = re.search(r\"_v(\\d+)_w(\\d+)_s(\\d+)\\.(npz|jsonl|pt)$\", b)\n",
    "        if m:\n",
    "            v, w, s = map(int, m.groups()[:3])\n",
    "        else:\n",
    "            v = w = s = 10**9\n",
    "        return (w, -os.path.getmtime(p), b)\n",
    "    return sorted(candidates, key=parse_details)[0]\n",
    "\n",
    "def iter_sparse(path):\n",
    "    ext = Path(path).suffix.lower()\n",
    "    if ext == \".npz\":\n",
    "        with np.load(path, mmap_mode=\"r\") as z:\n",
    "            offsets, values = z[\"offsets\"], z[\"values\"]\n",
    "            for i in range(len(offsets) - 1):\n",
    "                a, b = int(offsets[i]), int(offsets[i+1])\n",
    "                yield values[a:b].astype(np.int64).tolist()\n",
    "    elif ext == \".jsonl\":\n",
    "        with open(path, \"r\", encoding=\"utf-8\") as f:\n",
    "            for line in f:\n",
    "                yield list(map(int, json.loads(line)))\n",
    "    elif ext == \".pt\":\n",
    "        data = torch.load(path)\n",
    "        for s in data:\n",
    "            yield list(map(int, s))\n",
    "    else:\n",
    "        raise ValueError(f\"Unsupported extension: {ext}\")\n",
    "\n",
    "def load_vocab_from_meta(data_path):\n",
    "    meta_path = os.path.splitext(data_path)[0] + \".meta.json\"\n",
    "    if not os.path.exists(meta_path):\n",
    "        raise FileNotFoundError(f\"Missing metadata sidecar: {meta_path}\")\n",
    "    with open(meta_path, \"r\", encoding=\"utf-8\") as f:\n",
    "        meta = json.load(f)\n",
    "    vocab_path = meta.get(\"vocab_path\")\n",
    "    if not vocab_path or not os.path.exists(vocab_path):\n",
    "        raise FileNotFoundError(f\"Vocab file from meta not found: {vocab_path}\")\n",
    "    vd = torch.load(vocab_path)\n",
    "    # ensure types are normal Python\n",
    "    vocab_list = list(vd[\"vocab_list\"])\n",
    "    word2idx = {str(k): int(v) for k, v in vd[\"word2idx\"].items()}\n",
    "    lowercase = bool(meta.get(\"lowercase\", False))\n",
    "    return vocab_list, word2idx, lowercase, meta\n",
    "\n",
    "def month_indices(word2idx):\n",
    "    idxs = []\n",
    "    names = []\n",
    "    for m in MONTHS:\n",
    "        # try exact, lowercase, and capitalized forms\n",
    "        candidates = [m, m.lower(), m.capitalize()]\n",
    "        found = None\n",
    "        for c in candidates:\n",
    "            if c in word2idx:\n",
    "                found = word2idx[c]\n",
    "                break\n",
    "        if found is not None:\n",
    "            idxs.append(found)\n",
    "            names.append(m)  # keep canonical name for labeling\n",
    "        else:\n",
    "            print(f\"[warn] Month token not in vocab: {m}\")\n",
    "    return idxs, names\n",
    "\n",
    "# --------------------\n",
    "# Load files & vocab\n",
    "# --------------------\n",
    "data_path = find_split_file(DATA_DIR, DATASET, SPLIT)\n",
    "print(f\"Using data file: {data_path}\")\n",
    "\n",
    "vocab_list, word2idx, lowercase, meta = load_vocab_from_meta(data_path)\n",
    "print(f\"Loaded vocab ({len(vocab_list)} tokens). lowercase={lowercase}\")\n",
    "\n",
    "m_idx, m_names = month_indices(word2idx)\n",
    "K = len(m_idx)\n",
    "if K < 2:\n",
    "    raise RuntimeError(\"Fewer than 2 month tokens found in vocab; PCA needs ≥2 features.\")\n",
    "print(f\"Found {K}/12 month tokens:\", \", \".join(m_names))\n",
    "\n",
    "# --------------------\n",
    "# Collect a subset of data for PCA\n",
    "# --------------------\n",
    "data_subset = []\n",
    "# We'll iterate through the file and stop once we have SUBSAMPLE rows.\n",
    "# tqdm will show our progress towards that goal.\n",
    "pbar = tqdm(iter_sparse(data_path),\n",
    "            desc=\"Collecting windows\",\n",
    "            total=SUBSAMPLE if SUBSAMPLE is not None else None)\n",
    "for win in pbar:\n",
    "    # build binary row for this window\n",
    "    s = set(win)\n",
    "    row = [1.0 if idx in s else 0.0 for idx in m_idx]\n",
    "    data_subset.append(row)\n",
    "\n",
    "    # Check if we've collected enough samples\n",
    "    if SUBSAMPLE is not None and len(data_subset) >= SUBSAMPLE:\n",
    "        break\n",
    "\n",
    "n_windows_used = len(data_subset)\n",
    "if n_windows_used == 0:\n",
    "    raise ValueError(\"No data was loaded. Check data path and SUBSAMPLE value.\")\n",
    "\n",
    "# Convert list of lists to a NumPy array for PCA\n",
    "X = np.asarray(data_subset, dtype=np.float32)\n",
    "data_subset.clear() # free up memory\n",
    "\n",
    "# --------------------\n",
    "# Perform PCA on the data subset\n",
    "# --------------------\n",
    "print(f\"\\nPerforming PCA on {n_windows_used:,} windows...\")\n",
    "pca = PCA(n_components=2)\n",
    "pca.fit(X)\n",
    "\n",
    "print(\"Explained variance ratio:\", np.round(pca.explained_variance_ratio_, 4))\n",
    "\n",
    "# --------------------\n",
    "# Feature loadings for months (points for each month)\n",
    "# loadings = components_.T * sqrt(explained_variance_)\n",
    "# --------------------\n",
    "loadings = pca.components_.T * np.sqrt(pca.explained_variance_)\n",
    "assert loadings.shape == (K, 2)\n",
    "\n",
    "# --------------------\n",
    "# Plot\n",
    "# --------------------\n",
    "plt.figure(figsize=(6.2, 6.2))\n",
    "x, y = loadings[:, 0], loadings[:, 1]\n",
    "plt.scatter(x, y)\n",
    "for xi, yi, label in zip(x, y, m_names):\n",
    "    plt.text(xi, yi, label, fontsize=10, ha=\"center\", va=\"bottom\")\n",
    "plt.axhline(0, color='grey', lw=0.5)\n",
    "plt.axvline(0, color='grey', lw=0.5)\n",
    "plt.title(f\"PCA of Month Activations — {DATASET}/{SPLIT}\\n\"\n",
    "          f\"n_windows={n_windows_used:,}, var={pca.explained_variance_ratio_[0]:.2f}/{pca.explained_variance_ratio_[1]:.2f}\")\n",
    "plt.xlabel(\"PC1 (feature loadings)\")\n",
    "plt.ylabel(\"PC2 (feature loadings)\")\n",
    "plt.gca().set_aspect(\"equal\", adjustable=\"datalim\")\n",
    "plt.tight_layout()\n",
    "if SAVE_FIG:\n",
    "    plt.savefig(FIG_PATH, bbox_inches=\"tight\")\n",
    "plt.show()\n",
    "\n",
    "if SAVE_FIG:\n",
    "    print(f\"Saved figure to {FIG_PATH}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1131c5ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded 50000 samples from wikitext_train_v10000_w20_s1.npz\n",
      "Active features per sample k — avg: 274.49, median: 272, min: 0, max: 825\n",
      "Baseline MSE for all-zeros predictor ≈ k/V ≈ 274.485960/10000 = 0.027449\n",
      "Samples with ≥1 month token: 34802 (69.6% of loaded subset)\n",
      "\n",
      "Pairwise month co-occurrence COUNTS (subset with ≥1 month):\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<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>January</th>\n",
       "      <th>February</th>\n",
       "      <th>March</th>\n",
       "      <th>April</th>\n",
       "      <th>May</th>\n",
       "      <th>June</th>\n",
       "      <th>July</th>\n",
       "      <th>August</th>\n",
       "      <th>September</th>\n",
       "      <th>October</th>\n",
       "      <th>November</th>\n",
       "      <th>December</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>January</th>\n",
       "      <td>10079</td>\n",
       "      <td>4080</td>\n",
       "      <td>4493</td>\n",
       "      <td>4163</td>\n",
       "      <td>4593</td>\n",
       "      <td>4179</td>\n",
       "      <td>4032</td>\n",
       "      <td>4030</td>\n",
       "      <td>4249</td>\n",
       "      <td>4301</td>\n",
       "      <td>4601</td>\n",
       "      <td>4555</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>February</th>\n",
       "      <td>4080</td>\n",
       "      <td>8459</td>\n",
       "      <td>4356</td>\n",
       "      <td>3711</td>\n",
       "      <td>4004</td>\n",
       "      <td>3462</td>\n",
       "      <td>3466</td>\n",
       "      <td>3308</td>\n",
       "      <td>3618</td>\n",
       "      <td>3759</td>\n",
       "      <td>3757</td>\n",
       "      <td>3676</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>March</th>\n",
       "      <td>4493</td>\n",
       "      <td>4356</td>\n",
       "      <td>10598</td>\n",
       "      <td>4888</td>\n",
       "      <td>4903</td>\n",
       "      <td>4507</td>\n",
       "      <td>4082</td>\n",
       "      <td>4122</td>\n",
       "      <td>4346</td>\n",
       "      <td>4191</td>\n",
       "      <td>4126</td>\n",
       "      <td>4039</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>April</th>\n",
       "      <td>4163</td>\n",
       "      <td>3711</td>\n",
       "      <td>4888</td>\n",
       "      <td>10938</td>\n",
       "      <td>5427</td>\n",
       "      <td>4944</td>\n",
       "      <td>4233</td>\n",
       "      <td>4422</td>\n",
       "      <td>4589</td>\n",
       "      <td>4450</td>\n",
       "      <td>4281</td>\n",
       "      <td>4161</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>May</th>\n",
       "      <td>4593</td>\n",
       "      <td>4004</td>\n",
       "      <td>4903</td>\n",
       "      <td>5427</td>\n",
       "      <td>11992</td>\n",
       "      <td>5881</td>\n",
       "      <td>4803</td>\n",
       "      <td>4938</td>\n",
       "      <td>5011</td>\n",
       "      <td>4808</td>\n",
       "      <td>4631</td>\n",
       "      <td>4328</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>June</th>\n",
       "      <td>4179</td>\n",
       "      <td>3462</td>\n",
       "      <td>4507</td>\n",
       "      <td>4944</td>\n",
       "      <td>5881</td>\n",
       "      <td>11332</td>\n",
       "      <td>5130</td>\n",
       "      <td>4564</td>\n",
       "      <td>4774</td>\n",
       "      <td>4779</td>\n",
       "      <td>4125</td>\n",
       "      <td>4161</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>July</th>\n",
       "      <td>4032</td>\n",
       "      <td>3466</td>\n",
       "      <td>4082</td>\n",
       "      <td>4233</td>\n",
       "      <td>4803</td>\n",
       "      <td>5130</td>\n",
       "      <td>10657</td>\n",
       "      <td>4864</td>\n",
       "      <td>4629</td>\n",
       "      <td>4768</td>\n",
       "      <td>4154</td>\n",
       "      <td>4133</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>August</th>\n",
       "      <td>4030</td>\n",
       "      <td>3308</td>\n",
       "      <td>4122</td>\n",
       "      <td>4422</td>\n",
       "      <td>4938</td>\n",
       "      <td>4564</td>\n",
       "      <td>4864</td>\n",
       "      <td>10726</td>\n",
       "      <td>4894</td>\n",
       "      <td>4454</td>\n",
       "      <td>4233</td>\n",
       "      <td>4003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>September</th>\n",
       "      <td>4249</td>\n",
       "      <td>3618</td>\n",
       "      <td>4346</td>\n",
       "      <td>4589</td>\n",
       "      <td>5011</td>\n",
       "      <td>4774</td>\n",
       "      <td>4629</td>\n",
       "      <td>4894</td>\n",
       "      <td>11393</td>\n",
       "      <td>5164</td>\n",
       "      <td>4840</td>\n",
       "      <td>4346</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>October</th>\n",
       "      <td>4301</td>\n",
       "      <td>3759</td>\n",
       "      <td>4191</td>\n",
       "      <td>4450</td>\n",
       "      <td>4808</td>\n",
       "      <td>4779</td>\n",
       "      <td>4768</td>\n",
       "      <td>4454</td>\n",
       "      <td>5164</td>\n",
       "      <td>11318</td>\n",
       "      <td>5188</td>\n",
       "      <td>4494</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>November</th>\n",
       "      <td>4601</td>\n",
       "      <td>3757</td>\n",
       "      <td>4126</td>\n",
       "      <td>4281</td>\n",
       "      <td>4631</td>\n",
       "      <td>4125</td>\n",
       "      <td>4154</td>\n",
       "      <td>4233</td>\n",
       "      <td>4840</td>\n",
       "      <td>5188</td>\n",
       "      <td>10797</td>\n",
       "      <td>4509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>December</th>\n",
       "      <td>4555</td>\n",
       "      <td>3676</td>\n",
       "      <td>4039</td>\n",
       "      <td>4161</td>\n",
       "      <td>4328</td>\n",
       "      <td>4161</td>\n",
       "      <td>4133</td>\n",
       "      <td>4003</td>\n",
       "      <td>4346</td>\n",
       "      <td>4494</td>\n",
       "      <td>4509</td>\n",
       "      <td>10197</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           January  February  March  April    May   June   July  August  \\\n",
       "January      10079      4080   4493   4163   4593   4179   4032    4030   \n",
       "February      4080      8459   4356   3711   4004   3462   3466    3308   \n",
       "March         4493      4356  10598   4888   4903   4507   4082    4122   \n",
       "April         4163      3711   4888  10938   5427   4944   4233    4422   \n",
       "May           4593      4004   4903   5427  11992   5881   4803    4938   \n",
       "June          4179      3462   4507   4944   5881  11332   5130    4564   \n",
       "July          4032      3466   4082   4233   4803   5130  10657    4864   \n",
       "August        4030      3308   4122   4422   4938   4564   4864   10726   \n",
       "September     4249      3618   4346   4589   5011   4774   4629    4894   \n",
       "October       4301      3759   4191   4450   4808   4779   4768    4454   \n",
       "November      4601      3757   4126   4281   4631   4125   4154    4233   \n",
       "December      4555      3676   4039   4161   4328   4161   4133    4003   \n",
       "\n",
       "           September  October  November  December  \n",
       "January         4249     4301      4601      4555  \n",
       "February        3618     3759      3757      3676  \n",
       "March           4346     4191      4126      4039  \n",
       "April           4589     4450      4281      4161  \n",
       "May             5011     4808      4631      4328  \n",
       "June            4774     4779      4125      4161  \n",
       "July            4629     4768      4154      4133  \n",
       "August          4894     4454      4233      4003  \n",
       "September      11393     5164      4840      4346  \n",
       "October         5164    11318      5188      4494  \n",
       "November        4840     5188     10797      4509  \n",
       "December        4346     4494      4509     10197  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pairwise month co-occurrence RATES (counts / subset size):\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_6c5ab\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"blank level0\" >&nbsp;</th>\n",
       "      <th id=\"T_6c5ab_level0_col0\" class=\"col_heading level0 col0\" >January</th>\n",
       "      <th id=\"T_6c5ab_level0_col1\" class=\"col_heading level0 col1\" >February</th>\n",
       "      <th id=\"T_6c5ab_level0_col2\" class=\"col_heading level0 col2\" >March</th>\n",
       "      <th id=\"T_6c5ab_level0_col3\" class=\"col_heading level0 col3\" >April</th>\n",
       "      <th id=\"T_6c5ab_level0_col4\" class=\"col_heading level0 col4\" >May</th>\n",
       "      <th id=\"T_6c5ab_level0_col5\" class=\"col_heading level0 col5\" >June</th>\n",
       "      <th id=\"T_6c5ab_level0_col6\" class=\"col_heading level0 col6\" >July</th>\n",
       "      <th id=\"T_6c5ab_level0_col7\" class=\"col_heading level0 col7\" >August</th>\n",
       "      <th id=\"T_6c5ab_level0_col8\" class=\"col_heading level0 col8\" >September</th>\n",
       "      <th id=\"T_6c5ab_level0_col9\" class=\"col_heading level0 col9\" >October</th>\n",
       "      <th id=\"T_6c5ab_level0_col10\" class=\"col_heading level0 col10\" >November</th>\n",
       "      <th id=\"T_6c5ab_level0_col11\" class=\"col_heading level0 col11\" >December</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row0\" class=\"row_heading level0 row0\" >January</th>\n",
       "      <td id=\"T_6c5ab_row0_col0\" class=\"data row0 col0\" >0.290</td>\n",
       "      <td id=\"T_6c5ab_row0_col1\" class=\"data row0 col1\" >0.117</td>\n",
       "      <td id=\"T_6c5ab_row0_col2\" class=\"data row0 col2\" >0.129</td>\n",
       "      <td id=\"T_6c5ab_row0_col3\" class=\"data row0 col3\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row0_col4\" class=\"data row0 col4\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row0_col5\" class=\"data row0 col5\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row0_col6\" class=\"data row0 col6\" >0.116</td>\n",
       "      <td id=\"T_6c5ab_row0_col7\" class=\"data row0 col7\" >0.116</td>\n",
       "      <td id=\"T_6c5ab_row0_col8\" class=\"data row0 col8\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row0_col9\" class=\"data row0 col9\" >0.124</td>\n",
       "      <td id=\"T_6c5ab_row0_col10\" class=\"data row0 col10\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row0_col11\" class=\"data row0 col11\" >0.131</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row1\" class=\"row_heading level0 row1\" >February</th>\n",
       "      <td id=\"T_6c5ab_row1_col0\" class=\"data row1 col0\" >0.117</td>\n",
       "      <td id=\"T_6c5ab_row1_col1\" class=\"data row1 col1\" >0.243</td>\n",
       "      <td id=\"T_6c5ab_row1_col2\" class=\"data row1 col2\" >0.125</td>\n",
       "      <td id=\"T_6c5ab_row1_col3\" class=\"data row1 col3\" >0.107</td>\n",
       "      <td id=\"T_6c5ab_row1_col4\" class=\"data row1 col4\" >0.115</td>\n",
       "      <td id=\"T_6c5ab_row1_col5\" class=\"data row1 col5\" >0.099</td>\n",
       "      <td id=\"T_6c5ab_row1_col6\" class=\"data row1 col6\" >0.100</td>\n",
       "      <td id=\"T_6c5ab_row1_col7\" class=\"data row1 col7\" >0.095</td>\n",
       "      <td id=\"T_6c5ab_row1_col8\" class=\"data row1 col8\" >0.104</td>\n",
       "      <td id=\"T_6c5ab_row1_col9\" class=\"data row1 col9\" >0.108</td>\n",
       "      <td id=\"T_6c5ab_row1_col10\" class=\"data row1 col10\" >0.108</td>\n",
       "      <td id=\"T_6c5ab_row1_col11\" class=\"data row1 col11\" >0.106</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row2\" class=\"row_heading level0 row2\" >March</th>\n",
       "      <td id=\"T_6c5ab_row2_col0\" class=\"data row2 col0\" >0.129</td>\n",
       "      <td id=\"T_6c5ab_row2_col1\" class=\"data row2 col1\" >0.125</td>\n",
       "      <td id=\"T_6c5ab_row2_col2\" class=\"data row2 col2\" >0.305</td>\n",
       "      <td id=\"T_6c5ab_row2_col3\" class=\"data row2 col3\" >0.140</td>\n",
       "      <td id=\"T_6c5ab_row2_col4\" class=\"data row2 col4\" >0.141</td>\n",
       "      <td id=\"T_6c5ab_row2_col5\" class=\"data row2 col5\" >0.130</td>\n",
       "      <td id=\"T_6c5ab_row2_col6\" class=\"data row2 col6\" >0.117</td>\n",
       "      <td id=\"T_6c5ab_row2_col7\" class=\"data row2 col7\" >0.118</td>\n",
       "      <td id=\"T_6c5ab_row2_col8\" class=\"data row2 col8\" >0.125</td>\n",
       "      <td id=\"T_6c5ab_row2_col9\" class=\"data row2 col9\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row2_col10\" class=\"data row2 col10\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row2_col11\" class=\"data row2 col11\" >0.116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row3\" class=\"row_heading level0 row3\" >April</th>\n",
       "      <td id=\"T_6c5ab_row3_col0\" class=\"data row3 col0\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row3_col1\" class=\"data row3 col1\" >0.107</td>\n",
       "      <td id=\"T_6c5ab_row3_col2\" class=\"data row3 col2\" >0.140</td>\n",
       "      <td id=\"T_6c5ab_row3_col3\" class=\"data row3 col3\" >0.314</td>\n",
       "      <td id=\"T_6c5ab_row3_col4\" class=\"data row3 col4\" >0.156</td>\n",
       "      <td id=\"T_6c5ab_row3_col5\" class=\"data row3 col5\" >0.142</td>\n",
       "      <td id=\"T_6c5ab_row3_col6\" class=\"data row3 col6\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row3_col7\" class=\"data row3 col7\" >0.127</td>\n",
       "      <td id=\"T_6c5ab_row3_col8\" class=\"data row3 col8\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row3_col9\" class=\"data row3 col9\" >0.128</td>\n",
       "      <td id=\"T_6c5ab_row3_col10\" class=\"data row3 col10\" >0.123</td>\n",
       "      <td id=\"T_6c5ab_row3_col11\" class=\"data row3 col11\" >0.120</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row4\" class=\"row_heading level0 row4\" >May</th>\n",
       "      <td id=\"T_6c5ab_row4_col0\" class=\"data row4 col0\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row4_col1\" class=\"data row4 col1\" >0.115</td>\n",
       "      <td id=\"T_6c5ab_row4_col2\" class=\"data row4 col2\" >0.141</td>\n",
       "      <td id=\"T_6c5ab_row4_col3\" class=\"data row4 col3\" >0.156</td>\n",
       "      <td id=\"T_6c5ab_row4_col4\" class=\"data row4 col4\" >0.345</td>\n",
       "      <td id=\"T_6c5ab_row4_col5\" class=\"data row4 col5\" >0.169</td>\n",
       "      <td id=\"T_6c5ab_row4_col6\" class=\"data row4 col6\" >0.138</td>\n",
       "      <td id=\"T_6c5ab_row4_col7\" class=\"data row4 col7\" >0.142</td>\n",
       "      <td id=\"T_6c5ab_row4_col8\" class=\"data row4 col8\" >0.144</td>\n",
       "      <td id=\"T_6c5ab_row4_col9\" class=\"data row4 col9\" >0.138</td>\n",
       "      <td id=\"T_6c5ab_row4_col10\" class=\"data row4 col10\" >0.133</td>\n",
       "      <td id=\"T_6c5ab_row4_col11\" class=\"data row4 col11\" >0.124</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row5\" class=\"row_heading level0 row5\" >June</th>\n",
       "      <td id=\"T_6c5ab_row5_col0\" class=\"data row5 col0\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row5_col1\" class=\"data row5 col1\" >0.099</td>\n",
       "      <td id=\"T_6c5ab_row5_col2\" class=\"data row5 col2\" >0.130</td>\n",
       "      <td id=\"T_6c5ab_row5_col3\" class=\"data row5 col3\" >0.142</td>\n",
       "      <td id=\"T_6c5ab_row5_col4\" class=\"data row5 col4\" >0.169</td>\n",
       "      <td id=\"T_6c5ab_row5_col5\" class=\"data row5 col5\" >0.326</td>\n",
       "      <td id=\"T_6c5ab_row5_col6\" class=\"data row5 col6\" >0.147</td>\n",
       "      <td id=\"T_6c5ab_row5_col7\" class=\"data row5 col7\" >0.131</td>\n",
       "      <td id=\"T_6c5ab_row5_col8\" class=\"data row5 col8\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row5_col9\" class=\"data row5 col9\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row5_col10\" class=\"data row5 col10\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row5_col11\" class=\"data row5 col11\" >0.120</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row6\" class=\"row_heading level0 row6\" >July</th>\n",
       "      <td id=\"T_6c5ab_row6_col0\" class=\"data row6 col0\" >0.116</td>\n",
       "      <td id=\"T_6c5ab_row6_col1\" class=\"data row6 col1\" >0.100</td>\n",
       "      <td id=\"T_6c5ab_row6_col2\" class=\"data row6 col2\" >0.117</td>\n",
       "      <td id=\"T_6c5ab_row6_col3\" class=\"data row6 col3\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row6_col4\" class=\"data row6 col4\" >0.138</td>\n",
       "      <td id=\"T_6c5ab_row6_col5\" class=\"data row6 col5\" >0.147</td>\n",
       "      <td id=\"T_6c5ab_row6_col6\" class=\"data row6 col6\" >0.306</td>\n",
       "      <td id=\"T_6c5ab_row6_col7\" class=\"data row6 col7\" >0.140</td>\n",
       "      <td id=\"T_6c5ab_row6_col8\" class=\"data row6 col8\" >0.133</td>\n",
       "      <td id=\"T_6c5ab_row6_col9\" class=\"data row6 col9\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row6_col10\" class=\"data row6 col10\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row6_col11\" class=\"data row6 col11\" >0.119</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row7\" class=\"row_heading level0 row7\" >August</th>\n",
       "      <td id=\"T_6c5ab_row7_col0\" class=\"data row7 col0\" >0.116</td>\n",
       "      <td id=\"T_6c5ab_row7_col1\" class=\"data row7 col1\" >0.095</td>\n",
       "      <td id=\"T_6c5ab_row7_col2\" class=\"data row7 col2\" >0.118</td>\n",
       "      <td id=\"T_6c5ab_row7_col3\" class=\"data row7 col3\" >0.127</td>\n",
       "      <td id=\"T_6c5ab_row7_col4\" class=\"data row7 col4\" >0.142</td>\n",
       "      <td id=\"T_6c5ab_row7_col5\" class=\"data row7 col5\" >0.131</td>\n",
       "      <td id=\"T_6c5ab_row7_col6\" class=\"data row7 col6\" >0.140</td>\n",
       "      <td id=\"T_6c5ab_row7_col7\" class=\"data row7 col7\" >0.308</td>\n",
       "      <td id=\"T_6c5ab_row7_col8\" class=\"data row7 col8\" >0.141</td>\n",
       "      <td id=\"T_6c5ab_row7_col9\" class=\"data row7 col9\" >0.128</td>\n",
       "      <td id=\"T_6c5ab_row7_col10\" class=\"data row7 col10\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row7_col11\" class=\"data row7 col11\" >0.115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row8\" class=\"row_heading level0 row8\" >September</th>\n",
       "      <td id=\"T_6c5ab_row8_col0\" class=\"data row8 col0\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row8_col1\" class=\"data row8 col1\" >0.104</td>\n",
       "      <td id=\"T_6c5ab_row8_col2\" class=\"data row8 col2\" >0.125</td>\n",
       "      <td id=\"T_6c5ab_row8_col3\" class=\"data row8 col3\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row8_col4\" class=\"data row8 col4\" >0.144</td>\n",
       "      <td id=\"T_6c5ab_row8_col5\" class=\"data row8 col5\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row8_col6\" class=\"data row8 col6\" >0.133</td>\n",
       "      <td id=\"T_6c5ab_row8_col7\" class=\"data row8 col7\" >0.141</td>\n",
       "      <td id=\"T_6c5ab_row8_col8\" class=\"data row8 col8\" >0.327</td>\n",
       "      <td id=\"T_6c5ab_row8_col9\" class=\"data row8 col9\" >0.148</td>\n",
       "      <td id=\"T_6c5ab_row8_col10\" class=\"data row8 col10\" >0.139</td>\n",
       "      <td id=\"T_6c5ab_row8_col11\" class=\"data row8 col11\" >0.125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row9\" class=\"row_heading level0 row9\" >October</th>\n",
       "      <td id=\"T_6c5ab_row9_col0\" class=\"data row9 col0\" >0.124</td>\n",
       "      <td id=\"T_6c5ab_row9_col1\" class=\"data row9 col1\" >0.108</td>\n",
       "      <td id=\"T_6c5ab_row9_col2\" class=\"data row9 col2\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row9_col3\" class=\"data row9 col3\" >0.128</td>\n",
       "      <td id=\"T_6c5ab_row9_col4\" class=\"data row9 col4\" >0.138</td>\n",
       "      <td id=\"T_6c5ab_row9_col5\" class=\"data row9 col5\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row9_col6\" class=\"data row9 col6\" >0.137</td>\n",
       "      <td id=\"T_6c5ab_row9_col7\" class=\"data row9 col7\" >0.128</td>\n",
       "      <td id=\"T_6c5ab_row9_col8\" class=\"data row9 col8\" >0.148</td>\n",
       "      <td id=\"T_6c5ab_row9_col9\" class=\"data row9 col9\" >0.325</td>\n",
       "      <td id=\"T_6c5ab_row9_col10\" class=\"data row9 col10\" >0.149</td>\n",
       "      <td id=\"T_6c5ab_row9_col11\" class=\"data row9 col11\" >0.129</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row10\" class=\"row_heading level0 row10\" >November</th>\n",
       "      <td id=\"T_6c5ab_row10_col0\" class=\"data row10 col0\" >0.132</td>\n",
       "      <td id=\"T_6c5ab_row10_col1\" class=\"data row10 col1\" >0.108</td>\n",
       "      <td id=\"T_6c5ab_row10_col2\" class=\"data row10 col2\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row10_col3\" class=\"data row10 col3\" >0.123</td>\n",
       "      <td id=\"T_6c5ab_row10_col4\" class=\"data row10 col4\" >0.133</td>\n",
       "      <td id=\"T_6c5ab_row10_col5\" class=\"data row10 col5\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row10_col6\" class=\"data row10 col6\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row10_col7\" class=\"data row10 col7\" >0.122</td>\n",
       "      <td id=\"T_6c5ab_row10_col8\" class=\"data row10 col8\" >0.139</td>\n",
       "      <td id=\"T_6c5ab_row10_col9\" class=\"data row10 col9\" >0.149</td>\n",
       "      <td id=\"T_6c5ab_row10_col10\" class=\"data row10 col10\" >0.310</td>\n",
       "      <td id=\"T_6c5ab_row10_col11\" class=\"data row10 col11\" >0.130</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_6c5ab_level0_row11\" class=\"row_heading level0 row11\" >December</th>\n",
       "      <td id=\"T_6c5ab_row11_col0\" class=\"data row11 col0\" >0.131</td>\n",
       "      <td id=\"T_6c5ab_row11_col1\" class=\"data row11 col1\" >0.106</td>\n",
       "      <td id=\"T_6c5ab_row11_col2\" class=\"data row11 col2\" >0.116</td>\n",
       "      <td id=\"T_6c5ab_row11_col3\" class=\"data row11 col3\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row11_col4\" class=\"data row11 col4\" >0.124</td>\n",
       "      <td id=\"T_6c5ab_row11_col5\" class=\"data row11 col5\" >0.120</td>\n",
       "      <td id=\"T_6c5ab_row11_col6\" class=\"data row11 col6\" >0.119</td>\n",
       "      <td id=\"T_6c5ab_row11_col7\" class=\"data row11 col7\" >0.115</td>\n",
       "      <td id=\"T_6c5ab_row11_col8\" class=\"data row11 col8\" >0.125</td>\n",
       "      <td id=\"T_6c5ab_row11_col9\" class=\"data row11 col9\" >0.129</td>\n",
       "      <td id=\"T_6c5ab_row11_col10\" class=\"data row11 col10\" >0.130</td>\n",
       "      <td id=\"T_6c5ab_row11_col11\" class=\"data row11 col11\" >0.293</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x70e5063e9ab0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pairwise month PRESENCE CORRELATION (Pearson):\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_11499\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"blank level0\" >&nbsp;</th>\n",
       "      <th id=\"T_11499_level0_col0\" class=\"col_heading level0 col0\" >January</th>\n",
       "      <th id=\"T_11499_level0_col1\" class=\"col_heading level0 col1\" >February</th>\n",
       "      <th id=\"T_11499_level0_col2\" class=\"col_heading level0 col2\" >March</th>\n",
       "      <th id=\"T_11499_level0_col3\" class=\"col_heading level0 col3\" >April</th>\n",
       "      <th id=\"T_11499_level0_col4\" class=\"col_heading level0 col4\" >May</th>\n",
       "      <th id=\"T_11499_level0_col5\" class=\"col_heading level0 col5\" >June</th>\n",
       "      <th id=\"T_11499_level0_col6\" class=\"col_heading level0 col6\" >July</th>\n",
       "      <th id=\"T_11499_level0_col7\" class=\"col_heading level0 col7\" >August</th>\n",
       "      <th id=\"T_11499_level0_col8\" class=\"col_heading level0 col8\" >September</th>\n",
       "      <th id=\"T_11499_level0_col9\" class=\"col_heading level0 col9\" >October</th>\n",
       "      <th id=\"T_11499_level0_col10\" class=\"col_heading level0 col10\" >November</th>\n",
       "      <th id=\"T_11499_level0_col11\" class=\"col_heading level0 col11\" >December</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row0\" class=\"row_heading level0 row0\" >January</th>\n",
       "      <td id=\"T_11499_row0_col0\" class=\"data row0 col0\" >1.000</td>\n",
       "      <td id=\"T_11499_row0_col1\" class=\"data row0 col1\" >0.241</td>\n",
       "      <td id=\"T_11499_row0_col2\" class=\"data row0 col2\" >0.196</td>\n",
       "      <td id=\"T_11499_row0_col3\" class=\"data row0 col3\" >0.136</td>\n",
       "      <td id=\"T_11499_row0_col4\" class=\"data row0 col4\" >0.149</td>\n",
       "      <td id=\"T_11499_row0_col5\" class=\"data row0 col5\" >0.121</td>\n",
       "      <td id=\"T_11499_row0_col6\" class=\"data row0 col6\" >0.130</td>\n",
       "      <td id=\"T_11499_row0_col7\" class=\"data row0 col7\" >0.127</td>\n",
       "      <td id=\"T_11499_row0_col8\" class=\"data row0 col8\" >0.128</td>\n",
       "      <td id=\"T_11499_row0_col9\" class=\"data row0 col9\" >0.138</td>\n",
       "      <td id=\"T_11499_row0_col10\" class=\"data row0 col10\" >0.202</td>\n",
       "      <td id=\"T_11499_row0_col11\" class=\"data row0 col11\" >0.223</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row1\" class=\"row_heading level0 row1\" >February</th>\n",
       "      <td id=\"T_11499_row1_col0\" class=\"data row1 col0\" >0.241</td>\n",
       "      <td id=\"T_11499_row1_col1\" class=\"data row1 col1\" >1.000</td>\n",
       "      <td id=\"T_11499_row1_col2\" class=\"data row1 col2\" >0.259</td>\n",
       "      <td id=\"T_11499_row1_col3\" class=\"data row1 col3\" >0.152</td>\n",
       "      <td id=\"T_11499_row1_col4\" class=\"data row1 col4\" >0.154</td>\n",
       "      <td id=\"T_11499_row1_col5\" class=\"data row1 col5\" >0.101</td>\n",
       "      <td id=\"T_11499_row1_col6\" class=\"data row1 col6\" >0.127</td>\n",
       "      <td id=\"T_11499_row1_col7\" class=\"data row1 col7\" >0.102</td>\n",
       "      <td id=\"T_11499_row1_col8\" class=\"data row1 col8\" >0.121</td>\n",
       "      <td id=\"T_11499_row1_col9\" class=\"data row1 col9\" >0.144</td>\n",
       "      <td id=\"T_11499_row1_col10\" class=\"data row1 col10\" >0.164</td>\n",
       "      <td id=\"T_11499_row1_col11\" class=\"data row1 col11\" >0.176</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row2\" class=\"row_heading level0 row2\" >March</th>\n",
       "      <td id=\"T_11499_row2_col0\" class=\"data row2 col0\" >0.196</td>\n",
       "      <td id=\"T_11499_row2_col1\" class=\"data row2 col1\" >0.259</td>\n",
       "      <td id=\"T_11499_row2_col2\" class=\"data row2 col2\" >1.000</td>\n",
       "      <td id=\"T_11499_row2_col3\" class=\"data row2 col3\" >0.209</td>\n",
       "      <td id=\"T_11499_row2_col4\" class=\"data row2 col4\" >0.164</td>\n",
       "      <td id=\"T_11499_row2_col5\" class=\"data row2 col5\" >0.141</td>\n",
       "      <td id=\"T_11499_row2_col6\" class=\"data row2 col6\" >0.113</td>\n",
       "      <td id=\"T_11499_row2_col7\" class=\"data row2 col7\" >0.116</td>\n",
       "      <td id=\"T_11499_row2_col8\" class=\"data row2 col8\" >0.117</td>\n",
       "      <td id=\"T_11499_row2_col9\" class=\"data row2 col9\" >0.099</td>\n",
       "      <td id=\"T_11499_row2_col10\" class=\"data row2 col10\" >0.113</td>\n",
       "      <td id=\"T_11499_row2_col11\" class=\"data row2 col11\" >0.128</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row3\" class=\"row_heading level0 row3\" >April</th>\n",
       "      <td id=\"T_11499_row3_col0\" class=\"data row3 col0\" >0.136</td>\n",
       "      <td id=\"T_11499_row3_col1\" class=\"data row3 col1\" >0.152</td>\n",
       "      <td id=\"T_11499_row3_col2\" class=\"data row3 col2\" >0.209</td>\n",
       "      <td id=\"T_11499_row3_col3\" class=\"data row3 col3\" >1.000</td>\n",
       "      <td id=\"T_11499_row3_col4\" class=\"data row3 col4\" >0.216</td>\n",
       "      <td id=\"T_11499_row3_col5\" class=\"data row3 col5\" >0.183</td>\n",
       "      <td id=\"T_11499_row3_col6\" class=\"data row3 col6\" >0.119</td>\n",
       "      <td id=\"T_11499_row3_col7\" class=\"data row3 col7\" >0.141</td>\n",
       "      <td id=\"T_11499_row3_col8\" class=\"data row3 col8\" >0.133</td>\n",
       "      <td id=\"T_11499_row3_col9\" class=\"data row3 col9\" >0.118</td>\n",
       "      <td id=\"T_11499_row3_col10\" class=\"data row3 col10\" >0.119</td>\n",
       "      <td id=\"T_11499_row3_col11\" class=\"data row3 col11\" >0.130</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row4\" class=\"row_heading level0 row4\" >May</th>\n",
       "      <td id=\"T_11499_row4_col0\" class=\"data row4 col0\" >0.149</td>\n",
       "      <td id=\"T_11499_row4_col1\" class=\"data row4 col1\" >0.154</td>\n",
       "      <td id=\"T_11499_row4_col2\" class=\"data row4 col2\" >0.164</td>\n",
       "      <td id=\"T_11499_row4_col3\" class=\"data row4 col3\" >0.216</td>\n",
       "      <td id=\"T_11499_row4_col4\" class=\"data row4 col4\" >1.000</td>\n",
       "      <td id=\"T_11499_row4_col5\" class=\"data row4 col5\" >0.255</td>\n",
       "      <td id=\"T_11499_row4_col6\" class=\"data row4 col6\" >0.148</td>\n",
       "      <td id=\"T_11499_row4_col7\" class=\"data row4 col7\" >0.163</td>\n",
       "      <td id=\"T_11499_row4_col8\" class=\"data row4 col8\" >0.140</td>\n",
       "      <td id=\"T_11499_row4_col9\" class=\"data row4 col9\" >0.117</td>\n",
       "      <td id=\"T_11499_row4_col10\" class=\"data row4 col10\" >0.119</td>\n",
       "      <td id=\"T_11499_row4_col11\" class=\"data row4 col11\" >0.108</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row5\" class=\"row_heading level0 row5\" >June</th>\n",
       "      <td id=\"T_11499_row5_col0\" class=\"data row5 col0\" >0.121</td>\n",
       "      <td id=\"T_11499_row5_col1\" class=\"data row5 col1\" >0.101</td>\n",
       "      <td id=\"T_11499_row5_col2\" class=\"data row5 col2\" >0.141</td>\n",
       "      <td id=\"T_11499_row5_col3\" class=\"data row5 col3\" >0.183</td>\n",
       "      <td id=\"T_11499_row5_col4\" class=\"data row5 col4\" >0.255</td>\n",
       "      <td id=\"T_11499_row5_col5\" class=\"data row5 col5\" >1.000</td>\n",
       "      <td id=\"T_11499_row5_col6\" class=\"data row5 col6\" >0.221</td>\n",
       "      <td id=\"T_11499_row5_col7\" class=\"data row5 col7\" >0.142</td>\n",
       "      <td id=\"T_11499_row5_col8\" class=\"data row5 col8\" >0.139</td>\n",
       "      <td id=\"T_11499_row5_col9\" class=\"data row5 col9\" >0.143</td>\n",
       "      <td id=\"T_11499_row5_col10\" class=\"data row5 col10\" >0.081</td>\n",
       "      <td id=\"T_11499_row5_col11\" class=\"data row5 col11\" >0.113</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row6\" class=\"row_heading level0 row6\" >July</th>\n",
       "      <td id=\"T_11499_row6_col0\" class=\"data row6 col0\" >0.130</td>\n",
       "      <td id=\"T_11499_row6_col1\" class=\"data row6 col1\" >0.127</td>\n",
       "      <td id=\"T_11499_row6_col2\" class=\"data row6 col2\" >0.113</td>\n",
       "      <td id=\"T_11499_row6_col3\" class=\"data row6 col3\" >0.119</td>\n",
       "      <td id=\"T_11499_row6_col4\" class=\"data row6 col4\" >0.148</td>\n",
       "      <td id=\"T_11499_row6_col5\" class=\"data row6 col5\" >0.221</td>\n",
       "      <td id=\"T_11499_row6_col6\" class=\"data row6 col6\" >1.000</td>\n",
       "      <td id=\"T_11499_row6_col7\" class=\"data row6 col7\" >0.213</td>\n",
       "      <td id=\"T_11499_row6_col8\" class=\"data row6 col8\" >0.151</td>\n",
       "      <td id=\"T_11499_row6_col9\" class=\"data row6 col9\" >0.173</td>\n",
       "      <td id=\"T_11499_row6_col10\" class=\"data row6 col10\" >0.114</td>\n",
       "      <td id=\"T_11499_row6_col11\" class=\"data row6 col11\" >0.138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row7\" class=\"row_heading level0 row7\" >August</th>\n",
       "      <td id=\"T_11499_row7_col0\" class=\"data row7 col0\" >0.127</td>\n",
       "      <td id=\"T_11499_row7_col1\" class=\"data row7 col1\" >0.102</td>\n",
       "      <td id=\"T_11499_row7_col2\" class=\"data row7 col2\" >0.116</td>\n",
       "      <td id=\"T_11499_row7_col3\" class=\"data row7 col3\" >0.141</td>\n",
       "      <td id=\"T_11499_row7_col4\" class=\"data row7 col4\" >0.163</td>\n",
       "      <td id=\"T_11499_row7_col5\" class=\"data row7 col5\" >0.142</td>\n",
       "      <td id=\"T_11499_row7_col6\" class=\"data row7 col6\" >0.213</td>\n",
       "      <td id=\"T_11499_row7_col7\" class=\"data row7 col7\" >1.000</td>\n",
       "      <td id=\"T_11499_row7_col8\" class=\"data row7 col8\" >0.183</td>\n",
       "      <td id=\"T_11499_row7_col9\" class=\"data row7 col9\" >0.128</td>\n",
       "      <td id=\"T_11499_row7_col10\" class=\"data row7 col10\" >0.122</td>\n",
       "      <td id=\"T_11499_row7_col11\" class=\"data row7 col11\" >0.118</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row8\" class=\"row_heading level0 row8\" >September</th>\n",
       "      <td id=\"T_11499_row8_col0\" class=\"data row8 col0\" >0.128</td>\n",
       "      <td id=\"T_11499_row8_col1\" class=\"data row8 col1\" >0.121</td>\n",
       "      <td id=\"T_11499_row8_col2\" class=\"data row8 col2\" >0.117</td>\n",
       "      <td id=\"T_11499_row8_col3\" class=\"data row8 col3\" >0.133</td>\n",
       "      <td id=\"T_11499_row8_col4\" class=\"data row8 col4\" >0.140</td>\n",
       "      <td id=\"T_11499_row8_col5\" class=\"data row8 col5\" >0.139</td>\n",
       "      <td id=\"T_11499_row8_col6\" class=\"data row8 col6\" >0.151</td>\n",
       "      <td id=\"T_11499_row8_col7\" class=\"data row8 col7\" >0.183</td>\n",
       "      <td id=\"T_11499_row8_col8\" class=\"data row8 col8\" >1.000</td>\n",
       "      <td id=\"T_11499_row8_col9\" class=\"data row8 col9\" >0.191</td>\n",
       "      <td id=\"T_11499_row8_col10\" class=\"data row8 col10\" >0.173</td>\n",
       "      <td id=\"T_11499_row8_col11\" class=\"data row8 col11\" >0.136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row9\" class=\"row_heading level0 row9\" >October</th>\n",
       "      <td id=\"T_11499_row9_col0\" class=\"data row9 col0\" >0.138</td>\n",
       "      <td id=\"T_11499_row9_col1\" class=\"data row9 col1\" >0.144</td>\n",
       "      <td id=\"T_11499_row9_col2\" class=\"data row9 col2\" >0.099</td>\n",
       "      <td id=\"T_11499_row9_col3\" class=\"data row9 col3\" >0.118</td>\n",
       "      <td id=\"T_11499_row9_col4\" class=\"data row9 col4\" >0.117</td>\n",
       "      <td id=\"T_11499_row9_col5\" class=\"data row9 col5\" >0.143</td>\n",
       "      <td id=\"T_11499_row9_col6\" class=\"data row9 col6\" >0.173</td>\n",
       "      <td id=\"T_11499_row9_col7\" class=\"data row9 col7\" >0.128</td>\n",
       "      <td id=\"T_11499_row9_col8\" class=\"data row9 col8\" >0.191</td>\n",
       "      <td id=\"T_11499_row9_col9\" class=\"data row9 col9\" >1.000</td>\n",
       "      <td id=\"T_11499_row9_col10\" class=\"data row9 col10\" >0.222</td>\n",
       "      <td id=\"T_11499_row9_col11\" class=\"data row9 col11\" >0.159</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row10\" class=\"row_heading level0 row10\" >November</th>\n",
       "      <td id=\"T_11499_row10_col0\" class=\"data row10 col0\" >0.202</td>\n",
       "      <td id=\"T_11499_row10_col1\" class=\"data row10 col1\" >0.164</td>\n",
       "      <td id=\"T_11499_row10_col2\" class=\"data row10 col2\" >0.113</td>\n",
       "      <td id=\"T_11499_row10_col3\" class=\"data row10 col3\" >0.119</td>\n",
       "      <td id=\"T_11499_row10_col4\" class=\"data row10 col4\" >0.119</td>\n",
       "      <td id=\"T_11499_row10_col5\" class=\"data row10 col5\" >0.081</td>\n",
       "      <td id=\"T_11499_row10_col6\" class=\"data row10 col6\" >0.114</td>\n",
       "      <td id=\"T_11499_row10_col7\" class=\"data row10 col7\" >0.122</td>\n",
       "      <td id=\"T_11499_row10_col8\" class=\"data row10 col8\" >0.173</td>\n",
       "      <td id=\"T_11499_row10_col9\" class=\"data row10 col9\" >0.222</td>\n",
       "      <td id=\"T_11499_row10_col10\" class=\"data row10 col10\" >1.000</td>\n",
       "      <td id=\"T_11499_row10_col11\" class=\"data row10 col11\" >0.184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_11499_level0_row11\" class=\"row_heading level0 row11\" >December</th>\n",
       "      <td id=\"T_11499_row11_col0\" class=\"data row11 col0\" >0.223</td>\n",
       "      <td id=\"T_11499_row11_col1\" class=\"data row11 col1\" >0.176</td>\n",
       "      <td id=\"T_11499_row11_col2\" class=\"data row11 col2\" >0.128</td>\n",
       "      <td id=\"T_11499_row11_col3\" class=\"data row11 col3\" >0.130</td>\n",
       "      <td id=\"T_11499_row11_col4\" class=\"data row11 col4\" >0.108</td>\n",
       "      <td id=\"T_11499_row11_col5\" class=\"data row11 col5\" >0.113</td>\n",
       "      <td id=\"T_11499_row11_col6\" class=\"data row11 col6\" >0.138</td>\n",
       "      <td id=\"T_11499_row11_col7\" class=\"data row11 col7\" >0.118</td>\n",
       "      <td id=\"T_11499_row11_col8\" class=\"data row11 col8\" >0.136</td>\n",
       "      <td id=\"T_11499_row11_col9\" class=\"data row11 col9\" >0.159</td>\n",
       "      <td id=\"T_11499_row11_col10\" class=\"data row11 col10\" >0.184</td>\n",
       "      <td id=\"T_11499_row11_col11\" class=\"data row11 col11\" >1.000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x70e5063e9ab0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# %% [markdown]\n",
    "# Sanity checks for sparse window data:\n",
    "# - average active features per sample\n",
    "# - month co-occurrence / correlation within samples that contain at least one month\n",
    "\n",
    "# %% [code]\n",
    "from pathlib import Path\n",
    "import os, re, json, math\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from IPython.display import display\n",
    "\n",
    "# ----------------------------\n",
    "# Config: edit these if needed\n",
    "# ----------------------------\n",
    "DATA_FILE = Path(\"data/wikitext_train_v10000_w20_s1.npz\")  # your split file\n",
    "MAX_SAMPLES = 50_000   # cap for speed; set None to load all\n",
    "\n",
    "# ----------------------------\n",
    "# Helpers\n",
    "# ----------------------------\n",
    "def iter_sparse(path: Path):\n",
    "    ext = path.suffix.lower()\n",
    "    if ext == \".npz\":\n",
    "        z = np.load(path, mmap_mode=\"r\")\n",
    "        offsets, values = z[\"offsets\"], z[\"values\"]\n",
    "        for i in range(len(offsets) - 1):\n",
    "            a, b = int(offsets[i]), int(offsets[i + 1])\n",
    "            yield values[a:b].astype(np.int64).tolist()\n",
    "    elif ext == \".jsonl\":\n",
    "        with open(path, \"r\", encoding=\"utf-8\") as f:\n",
    "            for line in f:\n",
    "                yield list(map(int, json.loads(line)))\n",
    "    elif ext == \".pt\":\n",
    "        data = torch.load(path, map_location=\"cpu\")\n",
    "        for s in data:\n",
    "            yield list(map(int, s))\n",
    "    else:\n",
    "        raise ValueError(f\"Unsupported file extension: {ext}\")\n",
    "\n",
    "def meta_for(data_path: Path):\n",
    "    meta_path = data_path.with_suffix(\"\")  # drop extension\n",
    "    meta_path = meta_path.with_name(meta_path.name)  # ensure clean\n",
    "    meta_path = Path(str(meta_path) + \".meta.json\")\n",
    "    return json.load(open(meta_path, \"r\", encoding=\"utf-8\")) if meta_path.exists() else None\n",
    "\n",
    "def load_vocab(meta: dict):\n",
    "    # Prefer meta[\"vocab_path\"]; otherwise raise with a helpful message.\n",
    "    if not meta or \"vocab_path\" not in meta:\n",
    "        raise FileNotFoundError(\n",
    "            \"Could not find sidecar .meta.json or 'vocab_path' inside it. \"\n",
    "            \"Please set DATA_FILE correctly or provide the vocab .pt path.\"\n",
    "        )\n",
    "    vp = Path(meta[\"vocab_path\"])\n",
    "    if not vp.exists():\n",
    "        # Try relative to DATA_FILE folder\n",
    "        guess = DATA_FILE.parent / vp.name\n",
    "        if guess.exists():\n",
    "            vp = guess\n",
    "        else:\n",
    "            raise FileNotFoundError(f\"Vocab file not found: {meta['vocab_path']}\")\n",
    "    blob = torch.load(vp, map_location=\"cpu\")\n",
    "    vocab_list = list(blob[\"vocab_list\"])\n",
    "    word2idx = {str(k): int(v) for k, v in blob[\"word2idx\"].items()}\n",
    "    return vocab_list, word2idx\n",
    "\n",
    "# ----------------------------\n",
    "# Load a subset of samples\n",
    "# ----------------------------\n",
    "assert DATA_FILE.exists(), f\"Missing data file: {DATA_FILE}\"\n",
    "meta = meta_for(DATA_FILE)\n",
    "vocab_size = int(meta[\"vocab_size\"]) if meta and \"vocab_size\" in meta else None\n",
    "vocab_list, word2idx = load_vocab(meta)\n",
    "\n",
    "samples = []\n",
    "ks = []\n",
    "for i, s in enumerate(iter_sparse(DATA_FILE)):\n",
    "    samples.append(s)\n",
    "    ks.append(len(s))\n",
    "    if MAX_SAMPLES and (i + 1) >= MAX_SAMPLES:\n",
    "        break\n",
    "\n",
    "num_samples = len(samples)\n",
    "avg_k = float(np.mean(ks)) if ks else 0.0\n",
    "median_k = float(np.median(ks)) if ks else 0.0\n",
    "min_k = int(np.min(ks)) if ks else 0\n",
    "max_k = int(np.max(ks)) if ks else 0\n",
    "V = vocab_size or len(vocab_list)\n",
    "\n",
    "print(f\"Loaded {num_samples} samples from {DATA_FILE.name}\")\n",
    "print(f\"Active features per sample k — avg: {avg_k:.2f}, median: {median_k:.0f}, min: {min_k}, max: {max_k}\")\n",
    "print(f\"Baseline MSE for all-zeros predictor ≈ k/V ≈ {avg_k:.6f}/{V} = {avg_k / V:.6f}\")\n",
    "\n",
    "# ----------------------------\n",
    "# Month co-activations\n",
    "# ----------------------------\n",
    "months = [\"January\",\"February\",\"March\",\"April\",\"May\",\"June\",\n",
    "          \"July\",\"August\",\"September\",\"October\",\"November\",\"December\"]\n",
    "\n",
    "month_to_idx = {m: word2idx[m] for m in months if m in word2idx}\n",
    "missing_months = sorted(set(months) - set(month_to_idx.keys()))\n",
    "if missing_months:\n",
    "    print(\"Warning: months not in vocab:\", \", \".join(missing_months))\n",
    "\n",
    "month_idxs = list(month_to_idx.values())\n",
    "month_names = list(month_to_idx.keys())\n",
    "month_idx_set = set(month_idxs)\n",
    "\n",
    "# Build month-indicator matrix for samples that contain at least one month\n",
    "rows = []\n",
    "for s in samples:\n",
    "    ss = set(s)\n",
    "    if ss & month_idx_set:  # at least one month present\n",
    "        rows.append([1 if idx in ss else 0 for idx in month_idxs])\n",
    "\n",
    "if not rows:\n",
    "    raise RuntimeError(\"No samples contained any month tokens in the loaded subset.\")\n",
    "\n",
    "M = pd.DataFrame(rows, columns=month_names)\n",
    "n_subset = len(M)\n",
    "print(f\"Samples with ≥1 month token: {n_subset} ({n_subset/num_samples:.1%} of loaded subset)\")\n",
    "\n",
    "# Co-occurrence counts and rates\n",
    "co_counts = (M.T @ M).astype(int)               # integer co-activation counts\n",
    "co_rate   = co_counts / float(n_subset)         # probability of joint presence p(i & j)\n",
    "corr      = M.corr(numeric_only=True)           # Pearson corr on binary indicators\n",
    "\n",
    "# Nicely ordered (optional: ensure calendar order)\n",
    "co_counts = co_counts.loc[month_names, month_names]\n",
    "co_rate   = co_rate.loc[month_names, month_names]\n",
    "corr      = corr.loc[month_names, month_names]\n",
    "\n",
    "# Display\n",
    "print(\"\\nPairwise month co-occurrence COUNTS (subset with ≥1 month):\")\n",
    "display(co_counts)\n",
    "\n",
    "print(\"\\nPairwise month co-occurrence RATES (counts / subset size):\")\n",
    "display(co_rate.style.format(\"{:.3f}\"))\n",
    "\n",
    "print(\"\\nPairwise month PRESENCE CORRELATION (Pearson):\")\n",
    "display(corr.style.format(\"{:.3f}\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d308d1c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: jinja2 in /homes/lp2123/.local/lib/python3.10/site-packages (3.1.4)\n",
      "Collecting MarkupSafe>=2.0 (from jinja2)\n",
      "  Downloading MarkupSafe-3.0.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (4.0 kB)\n",
      "Downloading MarkupSafe-3.0.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (20 kB)\n",
      "Installing collected packages: MarkupSafe\n",
      "Successfully installed MarkupSafe-3.0.2\n"
     ]
    }
   ],
   "source": [
    "!pip install jinja2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5afa2e31",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Given co_counts (12x12) from your notebook:\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "A = corr.values.astype(float)\n",
    "A = 0.5 * (A + A.T)               # symmetrize just in case\n",
    "w, V = np.linalg.eigh(A)          # ascending eigenvalues\n",
    "XY = V[:, -2:]                    # top-2 eigenvectors\n",
    "\n",
    "plt.figure(figsize=(4,4))\n",
    "plt.scatter(XY[:,0], XY[:,1])\n",
    "for i, name in enumerate(co_counts.index):\n",
    "    plt.text(XY[i,0], XY[i,1], name[:3].title(), ha='center', va='center')\n",
    "for i in range(12):\n",
    "    j = (i+1) % 12\n",
    "    plt.plot([XY[i,0], XY[j,0]], [XY[i,1], XY[j,1]])\n",
    "#plt.gca().set_aspect('equal', 'box'); plt.title('Months (co-occ eigenvectors)'); \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f4097757",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'W' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[6], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# W: (V,H) encoder weights; idxs: month token ids\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m M \u001b[38;5;241m=\u001b[39m \u001b[43mW\u001b[49m[idxs]\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mcpu()\u001b[38;5;241m.\u001b[39mnumpy()          \u001b[38;5;66;03m# (12, H)\u001b[39;00m\n\u001b[1;32m      3\u001b[0m M \u001b[38;5;241m=\u001b[39m M \u001b[38;5;241m-\u001b[39m M\u001b[38;5;241m.\u001b[39mmean(\u001b[38;5;241m0\u001b[39m, keepdims\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)            \u001b[38;5;66;03m# center across months\u001b[39;00m\n\u001b[1;32m      4\u001b[0m M \u001b[38;5;241m=\u001b[39m M \u001b[38;5;241m/\u001b[39m (np\u001b[38;5;241m.\u001b[39mlinalg\u001b[38;5;241m.\u001b[39mnorm(M, axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1\u001b[39m, keepdims\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m) \u001b[38;5;241m+\u001b[39m \u001b[38;5;241m1e-8\u001b[39m)  \u001b[38;5;66;03m# row L2-norm\u001b[39;00m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'W' is not defined"
     ]
    }
   ],
   "source": [
    "# W: (V,H) encoder weights; idxs: month token ids\n",
    "M = W[idxs].detach().cpu().numpy()          # (12, H)\n",
    "M = M - M.mean(0, keepdims=True)            # center across months\n",
    "M = M / (np.linalg.norm(M, axis=1, keepdims=True) + 1e-8)  # row L2-norm\n",
    "from sklearn.decomposition import PCA\n",
    "xy = PCA(n_components=2).fit_transform(M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "142774d3",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "interp",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
