{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "cellView": "form",
        "id": "FR8YNR-g9JXA"
      },
      "outputs": [],
      "source": [
        "#@title Imports external sources\n",
        "import os\n",
        "import io\n",
        "import PIL.Image, PIL.ImageDraw, PIL.ImageFont\n",
        "import base64\n",
        "import zipfile\n",
        "import json\n",
        "import requests\n",
        "import matplotlib.pylab as pl\n",
        "import numpy as np\n",
        "import glob\n",
        "import requests\n",
        "import random as pyrandom\n",
        "from concurrent import futures\n",
        "from functools import partial\n",
        "from scipy.ndimage import rotate\n",
        "from IPython.display import Image, HTML, clear_output\n",
        "from tqdm import tqdm_notebook, tnrange\n",
        "import time\n",
        "from typing import Any, MutableMapping, NamedTuple, Tuple\n",
        "# !pip install --quiet --upgrade tensorflow \n",
        "# !pip install --quiet --upgrade jax\n",
        "# !pip install --quiet --upgrade jaxlib\n",
        "import jax\n",
        "from jax import grad, jit, vmap\n",
        "import jax.numpy as jnp\n",
        "\n",
        "# !pip install --quiet -U dm-haiku\n",
        "# !pip install --quiet -U optax\n",
        "import haiku as hk\n",
        "import math\n",
        "# !pip install --quiet -U ml_collections\n",
        "from ml_collections import config_dict\n",
        "import matplotlib.pylab as pl\n",
        "import matplotlib.colors as mcolors\n",
        "colors = pl.colormaps['Dark2'] \n",
        "\n",
        "os.environ['CUDA_VISIBLE_DEVICES'] = '3'"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "cellView": "form",
        "id": "933ztM3DSREA"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "2024-05-19 01:58:03.477384: W external/xla/xla/service/gpu/nvptx_compiler.cc:742] The NVIDIA driver's CUDA version is 12.3 which is older than the ptxas CUDA version (12.4.99). Because the driver is older than the ptxas version, XLA is disabling parallel compilation, which may slow down compilation. You should update your NVIDIA driver or use the NVIDIA-provided CUDA forward compatibility packages.\n"
          ]
        }
      ],
      "source": [
        "#@title Import internal sources (from github)\n",
        "# !git clone --quiet https://github.com/google-research/self-organising-systems.git /content/self-organising-systems > /dev/null 2>&1\n",
        "# %cd /content/self-organising-systems/transformers_learn_icl_by_gd\n",
        "from src.transformer import Transformer\n",
        "from src.data import create_circ_cls_data, create_weights\n",
        "from src.config import config\n",
        "from src.train import *"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {},
      "outputs": [],
      "source": [
        "from torchvision.datasets import MNIST\n",
        "import numpy as np\n",
        "import jax.numpy as jnp\n",
        "from jax.tree_util import tree_map\n",
        "from torch.utils import data\n",
        "from torchvision.datasets import MNIST\n",
        "\n",
        "def concate_feature_label_collate(batch):\n",
        "  features, labels = zip(*batch)\n",
        "  # append labels to the features\n",
        "  concatenated = [np.concatenate([f, np.array([l])]) for f, l in zip(features, labels)]\n",
        "  return np.array(concatenated, dtype=jnp.float32)\n",
        "\n",
        "def numpy_collate(batch):\n",
        "  return tree_map(np.asarray, concate_feature_label_collate(batch))\n",
        "\n",
        "class NumpyLoader(data.DataLoader):\n",
        "  def __init__(self, dataset, batch_size=1,\n",
        "                shuffle=False, sampler=None,\n",
        "                batch_sampler=None, num_workers=0,\n",
        "                pin_memory=False, drop_last=False,\n",
        "                timeout=0, worker_init_fn=None):\n",
        "    super(self.__class__, self).__init__(dataset,\n",
        "        batch_size=batch_size,\n",
        "        shuffle=shuffle,\n",
        "        sampler=sampler,\n",
        "        batch_sampler=batch_sampler,\n",
        "        num_workers=num_workers,\n",
        "        collate_fn=numpy_collate,\n",
        "        pin_memory=pin_memory,\n",
        "        drop_last=drop_last,\n",
        "        timeout=timeout,\n",
        "        worker_init_fn=worker_init_fn)\n",
        "\n",
        "class FlattenAndCast(object):\n",
        "  def __call__(self, pic):\n",
        "    return np.ravel(np.array(pic, dtype=jnp.float32))\n",
        "\n",
        "# Define our dataset, using torch datasets\n",
        "mnist_dataset = MNIST('./data', train=True, download=True, transform=FlattenAndCast())\n",
        "training_generator = NumpyLoader(mnist_dataset, batch_size=1, num_workers=0)\n",
        "# convert to a np array\n",
        "mnist_data = np.array(list(training_generator))\n",
        "\n",
        "# squeeze the 2nd dimension\n",
        "mnist_data = np.squeeze(mnist_data, axis=1)\n",
        "\n",
        "# filter out all entries in mnist_data with last element other than [0,1,2]\n",
        "num_classes = 2\n",
        "total_classes = 5\n",
        "assert total_classes >= num_classes\n",
        "filtered_mnist_data = mnist_data[mnist_data[..., -1] < num_classes]\n",
        "\n",
        "# batch the data\n",
        "bs = 10\n",
        "num = filtered_mnist_data.shape[0] // bs * bs\n",
        "batched_mnist_data = np.asarray(np.split(filtered_mnist_data[:num], bs))\n",
        "batched_mnist_data = batched_mnist_data.transpose(1, 0, 2)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {},
      "outputs": [],
      "source": [
        "# augment each batch in batched_mnist_data with different label mapping\n",
        "augmented_batched_mnist_data = []\n",
        "for i, batch in enumerate(batched_mnist_data):\n",
        "  augmented_batch = np.copy(batch)\n",
        "  for _ in range(4):\n",
        "    # random permutation of total_classes\n",
        "    perm = np.random.permutation(total_classes)\n",
        "    augmented_batch[..., -1] = perm[augmented_batch[..., -1].astype(int)]\n",
        "    augmented_batched_mnist_data.append(np.copy(augmented_batch))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {},
      "outputs": [],
      "source": [
        "augmented_batched_mnist_data = jnp.array(augmented_batched_mnist_data)\n",
        "# randomly shuffle the data with numpy\n",
        "augmented_batched_mnist_data = augmented_batched_mnist_data[np.random.permutation(augmented_batched_mnist_data.shape[0])]\n",
        "batched_mnist_data = augmented_batched_mnist_data"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {},
      "outputs": [],
      "source": [
        "# split batched_mnist_data into train and test set, 0.8/0.2\n",
        "split = np.split(batched_mnist_data, [int(0.8 * batched_mnist_data.shape[0])])\n",
        "train_set = split[0]\n",
        "test_set = split[1]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "((4051, 10, 785), (1013, 10, 785))"
            ]
          },
          "execution_count": 7,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "train_set.shape, test_set.shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {},
      "outputs": [],
      "source": [
        "train_set = jnp.array(train_set)\n",
        "train_mnist_data = train_set.at[:, -1, -1].set(-1) # -1 for null label\n",
        "train_mnist_y = train_set[:, -1]\n",
        "\n",
        "test_set = jnp.array(test_set)\n",
        "test_mnist_data = test_set.at[:, -1, -1].set(-1) # -1 for null label\n",
        "test_mnist_y = test_set[:, -1]\n",
        "\n",
        "# pack into train_data and eval_data\n",
        "train_data = (train_mnist_data, train_mnist_y)\n",
        "eval_data = (test_mnist_data, test_mnist_y)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "((1013, 10, 785), (1013, 785))"
            ]
          },
          "execution_count": 9,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "eval_data[0].shape, eval_data[1].shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "cellView": "form",
        "id": "4KwAI4LZFfcF"
      },
      "outputs": [],
      "source": [
        "#@title Config\n",
        "num_seeds = 1 #@param {type:\"integer\"}\n",
        "\n",
        "from datetime import datetime\n",
        "now = datetime.now()\n",
        "config.local_usage = True\n",
        "config.size_distract = 0\n",
        "config.training_steps = 5000\n",
        "config.training_steps_gd = 5000\n",
        "config.use_softmax = True\n",
        "config.mnist_task = True\n",
        "\n",
        "####\n",
        "config.deq = True\n",
        "config.gd_deq = True\n",
        "####\n",
        "config.pre_train_gd = False\n",
        "config.train_gd_whitening = False\n",
        "config.train_gd_lr = True\n",
        "####\n",
        "\n",
        "config.layer_norm = True\n",
        "config.out_proj = True\n",
        "config.in_proj = False\n",
        "config.adam = True\n",
        "\n",
        "config.output_size = total_classes\n",
        "\n",
        "config.dataset_size = 9\n",
        "config.input_size = 39\n",
        "config.key_size = 40 #config.input_size + 1\n",
        "config.num_layers = 10\n",
        "config.num_heads = 20\n",
        "config.grad_clip_value = 100\n",
        "config.grad_clip_value_gd = 100\n",
        "config.lr = 0.001\n",
        "config.wd = 0.0\n",
        "config.init_scale = 0.002 / config.num_layers\n",
        "config.bs = 2048\n",
        "config.bs_gd_train = 2048\n",
        "config.gd_lr = 0.0003\n",
        "\n",
        "config.dropout_rate = 0.0\n",
        "data_creator = vmap(create_circ_cls_data,\n",
        "                    in_axes=(0, None, None, None, None, None),\n",
        "                    out_axes=0)\n",
        "\n",
        "config.y_update = False\n",
        "config.input_range = 2.0\n",
        "config.seed = 0\n",
        "\n",
        "config.analyse = False\n",
        "config.input_mlp = True\n",
        "config.input_mlp_out_dim = 120\n",
        "config.widening_factor = 4\n",
        "config.sum_norm = False\n",
        "\n",
        "\n",
        "config.in_proj = True\n",
        "config.emb_size = 120\n",
        "config.num_seeds = num_seeds\n",
        "\n",
        "change_dataloader()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "cellView": "form",
        "id": "Li0HaIsW5BFQ"
      },
      "outputs": [],
      "source": [
        "#@title Lists\n",
        "loss_trans_list =  [[]  for _ in range(config.num_seeds)]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 12,
      "metadata": {},
      "outputs": [],
      "source": [
        "from utils import load_weights"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 13,
      "metadata": {
        "cellView": "form",
        "id": "7s4jr3OBpaq9"
      },
      "outputs": [],
      "source": [
        "#@title Training\n",
        "eval_rng = jax.random.PRNGKey(10)\n",
        "for cur_seed in range(config.num_seeds):\n",
        "  if cur_seed == 1:\n",
        "    save_train_params = train_state.params\n",
        "  config.seed = cur_seed  \n",
        "  optimiser, train_state, _, rng = init(train_data)\n",
        "  save_train_params = load_weights(train_state.params, \"data/mnist_pretrained.pkl\")\n",
        "  break\n",
        "  # rng, data_rng = jax.random.split(rng, 2)\n",
        "  # eval_data = data_creator(jax.random.split(eval_rng, num=config.bs),\n",
        "  #                              config.input_size,\n",
        "  #                              config.dataset_size,\n",
        "  #                              config.size_distract,\n",
        "  #                              config.input_range,\n",
        "  #                              config.weight_scale)\n",
        "  \n",
        "  for step in range(config.training_steps):\n",
        "    # rng, data_rng = jax.random.split(data_rng, 2)\n",
        "    # train_data = data_creator(jax.random.split(rng, num=config.bs), \n",
        "    #                           config.input_size,\n",
        "    #                           config.dataset_size,\n",
        "    #                           config.size_distract,\n",
        "    #                           config.input_range,\n",
        "    #                           config.weight_scale)\n",
        "    train_state, metrics = update(train_state, train_data, optimiser)\n",
        "    \n",
        "    #for params in train_state.params:\n",
        "    #  if \"mlp\" in params or 'emb' in params:\n",
        "    #    train_state.params[params] = params_c[params.replace(\"transformer\", \"Transformer_gd\")]\n",
        "    if step % 1000 == 0:\n",
        "      \n",
        "      loss_trans, _, _ = predict_test.apply(train_state.params, eval_rng,\n",
        "                                            eval_data, False)\n",
        "      \n",
        "      loss_trans_list[cur_seed].append(loss_trans)\n",
        "\n",
        "# if config.num_seeds == 1:\n",
        "#   save_train_params = train_state.params\n",
        "#   # plot loss_trans_list\n",
        "#   pl.plot(loss_trans_list[0])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 14,
      "metadata": {},
      "outputs": [],
      "source": [
        "def get_embedding(data):\n",
        "    # emb = save_train_params['transformer/emb']['w']\n",
        "    # l0 = save_train_params['transformer/input_mlp/linear']['w']\n",
        "    # l1 = save_train_params['transformer/input_mlp/linear_1']['w']\n",
        "\n",
        "    # embedded = jnp.einsum('ba,dcb->dca', emb, data)\n",
        "\n",
        "    # embedded = embedded + jnp.einsum('aa,cba->cba', l1.T @ l0.T, embedded)\n",
        "    # return embedded\n",
        "    return predict_stack.apply(save_train_params, eval_rng, data, False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 167,
      "metadata": {},
      "outputs": [],
      "source": [
        "tr_idx = 5\n",
        "X = eval_data[0]\n",
        "Y = eval_data[1]\n",
        "\n",
        "# perturb X\n",
        "# perturb_num = 2\n",
        "# X = X.at[tr_idx, :perturb_num, 2].add(10.0)\n",
        "X_only = X.at[:, :, -1].set(-1)\n",
        "\n",
        "emb = get_embedding(X_only)[tr_idx]\n",
        "# standardize\n",
        "# emb = (emb - emb.mean(axis=0)) / emb.std(axis=0)\n",
        "gt = X[tr_idx][:, -1]\n",
        "# w = jnp.linalg.lstsq(emb[:-1], gt[:-1])[0]\n",
        "# w = train_weight(emb[:-1], gt[:-1], lr=0.01)\n",
        "\n",
        "X_b = emb[:-1]\n",
        "n_features = X_b.shape[1]\n",
        "y = gt[:-1]\n",
        "alpha = 0.01\n",
        "\n",
        "# convert y to one hot\n",
        "y = jax.nn.one_hot(y, config.output_size)\n",
        "\n",
        "w = np.linalg.inv(X_b.T.dot(X_b) + alpha * np.eye(n_features)).dot(X_b.T).dot(y)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 168,
      "metadata": {},
      "outputs": [],
      "source": [
        "def calc_influence(idx):\n",
        "    # the first 10 are inputs, the last one is test\n",
        "    emb_train_all = emb[:-1]\n",
        "    emb_train = emb[idx:idx+1]\n",
        "    emb_test = emb[-1:]\n",
        "\n",
        "    gt_train = X[tr_idx][idx:idx+1, -1]\n",
        "    gt_test = Y[tr_idx][-1]\n",
        "\n",
        "    k = emb_train_all.T @ emb_train_all\n",
        "    # influence of the training data on w\n",
        "    pred = emb_train @ w\n",
        "    gt_train_one_hot = jax.nn.one_hot(gt_train, config.output_size)\n",
        "    infl_w = np.linalg.solve(k + alpha * jnp.eye(k.shape[0]), emb_train.T @ (pred - gt_train_one_hot) + alpha * w)\n",
        "    # influence of a test point on w\n",
        "    gt_test_one_hot = jax.nn.one_hot(gt_test, config.output_size)\n",
        "    d_loss = emb_test.T @ (emb_test @ w - gt_test_one_hot) + alpha * w\n",
        "    return (jnp.ravel(d_loss) @ jnp.ravel(infl_w)).item()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 169,
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "index 0, normalized influence: -0.3304947316646576\n",
            "index 1, normalized influence: -0.31288060545921326\n",
            "index 2, normalized influence: -0.39792436361312866\n",
            "index 3, normalized influence: -0.32680097222328186\n",
            "index 4, normalized influence: -0.28126442432403564\n",
            "index 5, normalized influence: -0.31559836864471436\n",
            "index 6, normalized influence: -0.3455107510089874\n",
            "index 7, normalized influence: -0.306253582239151\n",
            "index 8, normalized influence: -0.3685857951641083\n"
          ]
        }
      ],
      "source": [
        "infls = []\n",
        "for i in range(config.dataset_size):\n",
        "    infl = calc_influence(i)\n",
        "    infls.append(infl)\n",
        "infls = jnp.array(infls)\n",
        "# normalize the influence\n",
        "infls = infls / jnp.linalg.norm(infls)\n",
        "for i in range(config.dataset_size):\n",
        "    print(f\"index {i}, normalized influence: {infls[i]}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 170,
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[0 2 6 8 9]\n",
            "[-27.83828  -22.616919 -10.740705  -3.082974  -7.418506]\n",
            "[1 3 4 5 7 9]\n",
            "[-40.977932  -21.96825    -5.102263   -3.972045   -0.5478198]\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 640x480 with 30 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "from utils import set_up_plotting\n",
        "\n",
        "set_up_plotting()\n",
        "\n",
        "image_arrays = X[tr_idx][:-1, :-1].reshape(-1, 28, 28)\n",
        "labels = X[tr_idx][:-1, -1]\n",
        "\n",
        "map_int_to_abcd = {0: 'A', 1: 'B', 2: 'C', 3: 'D', 4: 'E'}\n",
        "\n",
        "# plot all the images in the dataset\n",
        "for i, image in enumerate(image_arrays):\n",
        "    ax = pl.subplot(3, 10, i+1)\n",
        "    ax.imshow(image, cmap='gray')\n",
        "    # highlight images with high influence\n",
        "    # find the median of the influence\n",
        "    median = jnp.median(infls)\n",
        "    if infls[i] >= median:\n",
        "        ax.set_title(rf\"$I$={infls[i]:.2f}\", color='darkgreen', fontsize=10)\n",
        "    else:\n",
        "        ax.set_title(rf\"$I$={infls[i]:.2f}\", color='firebrick', fontsize=10)\n",
        "    ax.set_xticks([])\n",
        "    ax.set_yticks([])\n",
        "    ax.set_xlabel(f\"label: {map_int_to_abcd[int(labels[i])]}\", fontsize=10)\n",
        "\n",
        "test_image = X[tr_idx][-1, :-1].reshape(28, 28)\n",
        "label = Y[tr_idx][-1]\n",
        "pred_trans = predict.apply(save_train_params, eval_rng, X[tr_idx:tr_idx+1], False)\n",
        "# pred_trans = pred_trans[:, -1, -1]*(-1.0)\n",
        "pred_trans = jnp.argmax(pred_trans[:, -1])\n",
        "\n",
        "\n",
        "ax = pl.subplot(3,10,10)\n",
        "ax.imshow(test_image, cmap='gray')\n",
        "ax.set_xticks([])\n",
        "ax.set_yticks([])\n",
        "ax.set_title(f\"pred: {map_int_to_abcd[int(pred_trans)]}\", color='darkgreen', fontsize=10)\n",
        "ax.set_xlabel(f\"GT: {map_int_to_abcd[int(label)]}\", color='darkgreen', fontsize=10)\n",
        "\n",
        "\n",
        "\n",
        "\"\"\"Remove the top 5 images with the highest influence\n",
        "\"\"\"\n",
        "\n",
        "image_arrays = X[tr_idx][:-1, :-1].reshape(-1, 28, 28)\n",
        "labels = X[tr_idx][:-1, -1]\n",
        "\n",
        "test_image = X[tr_idx][-1, :-1].reshape(28, 28)\n",
        "label = Y[tr_idx][-1]\n",
        "num_remove = 5\n",
        "ranks = jnp.argsort(infls)[:-num_remove]\n",
        "# sort the indices in descending order\n",
        "ranks = ranks.sort()\n",
        "# append the test image idx to ranks\n",
        "ranks = jnp.append(ranks, config.dataset_size)\n",
        "print(ranks)\n",
        "\n",
        "# plot all the remaining images in the dataset\n",
        "for i, image in enumerate(image_arrays):\n",
        "    if i not in ranks:\n",
        "        image = np.ones_like(image) * 255\n",
        "    ax = pl.subplot(3, 10, 10 + i+1)\n",
        "    ax.imshow(image, cmap='gray')\n",
        "    # highlight images with high influence\n",
        "    # median = jnp.median(infls)\n",
        "    # if infls[i] >= median:\n",
        "    #     ax.set_title(rf\"$I$={infls[i]:.2f}\", color='darkgreen', fontsize=10)\n",
        "    # else:\n",
        "    #     ax.set_title(rf\"$I$={infls[i]:.2f}\", color='firebrick', fontsize=10)\n",
        "    ax.set_xticks([])\n",
        "    ax.set_yticks([])\n",
        "    ax.set_xlabel(f\"label: {map_int_to_abcd[int(labels[i])]}\", fontsize=10)\n",
        "\n",
        "logits = predict.apply(save_train_params, eval_rng, X[tr_idx:tr_idx+1, ranks], False)[-1, -1]\n",
        "print(logits)\n",
        "pred_trans = jnp.argmax(logits)\n",
        "\n",
        "\n",
        "ax = pl.subplot(3,10,20)\n",
        "ax.imshow(test_image, cmap='gray')\n",
        "ax.set_xticks([])\n",
        "ax.set_yticks([])\n",
        "ax.set_title(f\"pred: {map_int_to_abcd[pred_trans.item()]}\", color='firebrick', fontsize=10)\n",
        "ax.set_xlabel(f\"GT: {map_int_to_abcd[int(label)]}\", color='firebrick', fontsize=10)\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\"\"\"Remove the bottom 5 images with the lowest influence\n",
        "\"\"\"\n",
        "\n",
        "\n",
        "image_arrays = X[tr_idx][:-1, :-1].reshape(-1, 28, 28)\n",
        "labels = X[tr_idx][:-1, -1]\n",
        "\n",
        "test_image = X[tr_idx][-1, :-1].reshape(28, 28)\n",
        "label = Y[tr_idx][-1]\n",
        "num_remove = 5\n",
        "ranks = jnp.argsort(infls)[num_remove-1:]\n",
        "# sort the indices in descending order\n",
        "ranks = ranks.sort()\n",
        "ranks = jnp.append(ranks, config.dataset_size)\n",
        "print(ranks)\n",
        "\n",
        "# plot all the remaining images in the dataset\n",
        "for i, image in enumerate(image_arrays):\n",
        "    ax = pl.subplot(3, 10, 20 + i+1)\n",
        "    if i not in ranks:\n",
        "        # show the removed images in white\n",
        "        image = np.ones_like(image) * 255\n",
        "    ax.imshow(image, cmap='gray')\n",
        "    # highlight images with high influence\n",
        "    # median = jnp.median(infls)\n",
        "    # if infls[i] >= median:\n",
        "    #     ax.set_title(rf\"$I$={infls[i]:.2f}\", color='darkgreen', fontsize=10)\n",
        "    # else:\n",
        "    #     ax.set_title(rf\"$I$={infls[i]:.2f}\", color='firebrick', fontsize=10)\n",
        "    ax.set_xticks([])\n",
        "    ax.set_yticks([])\n",
        "    ax.set_xlabel(f\"label: {map_int_to_abcd[int(labels[i])]}\", fontsize=10)\n",
        "\n",
        "logits = predict.apply(save_train_params, eval_rng, X[tr_idx:tr_idx+1, ranks], False)[-1, -1]\n",
        "print(logits)\n",
        "pred_trans = jnp.argmax(logits)\n",
        "\n",
        "\n",
        "ax = pl.subplot(3,10,30)\n",
        "\n",
        "ax.imshow(test_image, cmap='gray')\n",
        "ax.set_xticks([])\n",
        "ax.set_yticks([])\n",
        "ax.set_title(f\"pred: {map_int_to_abcd[ pred_trans.item() ]}\", color='darkgreen', fontsize=10)\n",
        "ax.set_xlabel(f\"GT: {map_int_to_abcd[ int(label) ]}\", color='darkgreen', fontsize=10)\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "# make the plot look nice\n",
        "pl.tight_layout(h_pad=-10)\n",
        "\n",
        "# save the plot\n",
        "pl.savefig(f\"figs/influence_mnist_all_data.pdf\", format='pdf', bbox_inches='tight', dpi=300)\n",
        "\n",
        "# pl.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "accelerator": "TPU",
    "colab": {
      "machine_shape": "hm",
      "name": "non_linear_regression",
      "private_outputs": true,
      "provenance": []
    },
    "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.10.13"
    },
    "vscode": {
      "interpreter": {
        "hash": "31f2aee4e71d21fbe5cf8b01ff0e069b9275f58929596ceb00d14d90e3e16cd6"
      }
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
