{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "zxMmL36TBwUS"
   },
   "source": [
    "# Thunnini Demo\n",
    "\n",
    "This notebook briefly showcases Thunnini's main features. The notebook pretrains a network (LSTM or Transformer) on a distribution over coins with random uniform bias (using the `DirichletCategorical` data generator). This network is then fine tuned on a mixture of two coins with bias 0.2 and 0.8 via soft prefix tuning (i.e., by tuning the embeddings of the first 6 tokens). The tuned prefix is then used during evaluation on the same mixture of two coins, and finally performance of the tuned predictor is compared against the Bayes predictor for the two-coin mixture, the pretrained network, and the untrained network.\n",
    "\n",
    "The main aim of this notebook is to showcase how easy it is to set up predictors, data generators and pretraining, tuning, and evaluation with Thunnini.\n",
    "See `ThunniniExperiment.ipynb` for a much more comprehensive notebook that features most of Thunnini's functionality and wraps it into an easily configurable interface."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "uMC6_1OShR6p"
   },
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "evZftQd0sJII"
   },
   "outputs": [],
   "source": [
    "# @title Global imports\n",
    "\n",
    "import dataclasses\n",
    "\n",
    "# Utils\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# NNs / Linear algebra\n",
    "import numpy as np\n",
    "import jax\n",
    "\n",
    "jax.config.update(\"jax_debug_nans\", False)\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "uZVcFQDY32Te"
   },
   "outputs": [],
   "source": [
    "# @title Thunnini imports\n",
    "from thunnini.src import builders\n",
    "from thunnini.src import config as config_lib\n",
    "from thunnini.src import evaluation\n",
    "from thunnini.src import plot_utils\n",
    "from thunnini.src import training\n",
    "from thunnini.src import tuning"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "wguslMYdhJjF"
   },
   "source": [
    "# Experiment Configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "6U4dtDqLgrrn"
   },
   "outputs": [],
   "source": [
    "#@title Predictor configuration\n",
    "\n",
    "embedding_dim = 16\n",
    "torso_type = \"LSTM\" #\"LSTM\", \"Transformer\"\n",
    "hidden_sizes = [64, 32]\n",
    "\n",
    "\n",
    "predictor_config = config_lib.PredictorConfig(\n",
    "    token_dimensionality=2,  # binary tokens\n",
    "    embedding_dimensionality=embedding_dim,\n",
    ")\n",
    "\n",
    "\n",
    "if torso_type == \"LSTM\":\n",
    "  torso_config = config_lib.LSTMTorsoConfig(\n",
    "    is_trainable=True,\n",
    "    hidden_sizes=hidden_sizes,\n",
    "    return_hidden_states=False\n",
    ")\n",
    "else:\n",
    "  torso_config = config_lib.TransformerTorsoConfig(\n",
    "    is_trainable=True,\n",
    "    hidden_sizes=hidden_sizes,\n",
    "    num_attention_heads=4,\n",
    "    positional_encoding = 'SinCos',\n",
    "    return_hidden_states=False,\n",
    "    use_bias=False,\n",
    "    widening_factor=4,\n",
    "    normalize_qk=True,\n",
    "    use_lora=True,\n",
    "    reduced_rank=4,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "K8Ex14OsMDij"
   },
   "outputs": [],
   "source": [
    "#@title Training configuration\n",
    "\n",
    "training_data_config = config_lib.DirichletCategoricalGeneratorConfig(\n",
    "    batch_size=128,\n",
    "    sequence_length=50,\n",
    "    vocab_size=2,\n",
    "    alphas=np.array([1, 1]),\n",
    ")\n",
    "\n",
    "training_config = config_lib.TrainingConfig(\n",
    "    num_training_steps=1000,\n",
    "    learning_rate=5e-3,\n",
    "    max_grad_norm=1.0,\n",
    "    data_gen_seed=0,\n",
    "    predictor_init_seed=0,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "2GCZN_dkH05N"
   },
   "outputs": [],
   "source": [
    "#@title Tuning configuration\n",
    "\n",
    "tuning_data_config = config_lib.MixtureOfCategoricalsGeneratorConfig(\n",
    "    batch_size=128,\n",
    "    sequence_length=50,\n",
    "    vocab_size=2,\n",
    "    biases=np.array([[0.2, 0.8], [0.8, 0.2]]),\n",
    "    mixing_weights=np.array([0.25, 0.75]),\n",
    ")\n",
    "\n",
    "tuning_config = config_lib.TuningConfig(\n",
    "    num_tuning_steps=1000,\n",
    "    learning_rate=5e-3,\n",
    "    max_grad_norm=1.0,\n",
    "    data_gen_seed=10,\n",
    "    prefix_init_seed=10,\n",
    "    tuning_method=\"prefix_soft\",\n",
    "    prefix_length=6,\n",
    "    prefix_init_method=\"one_hot\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "aoOLKl1Ag_k8"
   },
   "outputs": [],
   "source": [
    "#@title Evaluation configuration\n",
    "\n",
    "# Evaluation will be on a single batch of this generator, so we choose\n",
    "# a large batch.\n",
    "eval_data_config = config_lib.MixtureOfCategoricalsGeneratorConfig(\n",
    "    batch_size=1024,\n",
    "    sequence_length=100,\n",
    "    vocab_size=2,\n",
    "    biases=np.array([[0.2, 0.8], [0.8, 0.2]]),\n",
    "    mixing_weights=np.array([0.25, 0.75]),\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "DU2LsMOphDFN"
   },
   "source": [
    "# Pretraining"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "id": "ctpIZqiaMd_3"
   },
   "outputs": [],
   "source": [
    "#@title Pretrain predictor\n",
    "trained_params, train_results = training.train(\n",
    "    training_config=training_config,\n",
    "    predictor_config=predictor_config,\n",
    "    torso_config=torso_config,\n",
    "    data_config=training_data_config,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "jt3JMFHjoHAe"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Pretraining on Dirichlet-Categorical')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmEAAAGJCAYAAADCCuQ5AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAqZVJREFUeJzsnXd4FNXXx7+zJZuEdEihJLRQQzUI0nsLglhABQEVO4ggFtCfBRXBhqAivjbAgkgRRIxgKKFJ772HUAKhpZC6Zd4/NruZmZ2ZndmS3cD5PA8P2Sl3ztw255577rkMy7IsCIIgCIIgiApF42sBCIIgCIIg7kRICSMIgiAIgvABpIQRBEEQBEH4AFLCCIIgCIIgfAApYQRBEARBED6AlDCCIAiCIAgfQEoYQRAEQRCEDyAljCAIgiAIwgeQEkYQBEEQBOEDSAkjCD8nPT0dDMMgPT1d9b0ZGRlgGAbz5s3zuFyVmXfffRcMwyi+nmEYvPvuu6qeMW/ePDAMg127djm9tlu3bujWrZuq9An3ePzxx1GnTh2vpU9lSiiBlDDitsX2EbT9CwwMRMOGDTF27FhcuXLFo8/6+uuvSdHxEWLlXKNGDfTt2xdffPEF8vPzfS2iV/nwww+xfPly1fft27cPjz32GOLj42EwGBAVFYVevXph7ty5MJvNFSYHQdzJ6HwtAEF4m/feew9169ZFcXExNm/ejDlz5iA1NRWHDh1CcHCwR57x9ddfo1q1anj88cc9kh6XLl26oKioCAEBAarvrV27NoqKiqDX6z0ul79hK2ej0YjLly8jPT0d48ePx4wZM7BixQq0aNHCfu3//vc/TJo0SXHaRUVF0On8s7v88MMP8dBDD2Hw4MGK7/n+++/x3HPPITY2FiNGjECDBg2Qn5+PtWvXYvTo0cjKysIbb7zhdTl8yXfffQeLxeJrMYg7HP/sVQjCg/Tv3x9t2rQBADz11FOoWrUqZsyYgT///BOPPvqo6D0FBQWoUqWKV+RRm7ZGo0FgYKBLz7JZhu4EuOUMAJMnT8a6detw7733YtCgQTh69CiCgoIAADqdzqlSZbFYUFpaisDAwNsqD7dt24bnnnsO7du3R2pqKkJDQ+3nxo8fj127duHQoUM+lNC72NrfnTAwIfwfmo4k7jh69OgBADh79iwAq29ISEgITp8+jZSUFISGhmL48OEArB/imTNnIikpCYGBgYiNjcWzzz6Lmzdv2tOrU6cODh8+jA0bNtinxGy+ILapsg0bNuCFF15ATEwMatWqBQA4d+4cXnjhBTRq1AhBQUGoWrUqhgwZgoyMDJ68Yj5h3bp1Q7NmzXDkyBF0794dwcHBqFmzJj7++GPevWI+Ybb3vXjxIgYPHoyQkBBER0fjlVdecZiGun79OkaMGIGwsDBERERg1KhR2L9/v2I/szNnzmDIkCGIiopCcHAw7rnnHvz999+i77do0SJMnToVtWrVQmBgIHr27IlTp045fYYcPXr0wFtvvYVz587hl19+sR8X8wljGAZjx47Fr7/+iqSkJBgMBqxatcp+TugTdvHiRYwePRo1atSAwWBA3bp18fzzz6O0tJR3XUlJCV5++WVER0ejSpUquP/++3H16lWnspeUlOCdd95BYmIiDAYD4uPj8dprr6GkpIQnc0FBAebPn2+ve86ssVOmTAHDMPj11195CpiNNm3a8NL49NNP0aFDB1StWhVBQUFITk7GkiVLHPJOTo6LFy/iySefRGxsLAwGA5KSkvDjjz86PPvcuXMYNGgQqlSpgpiYGEyYMAGrV68W9YlcvHgxkpOTERQUhGrVquGxxx7DxYsXedfItW0xnzCLxYJZs2ahefPmCAwMRHR0NPr168fz65s7dy569OiBmJgYGAwGNG3aFHPmzJHLcoKQhCxhxB3H6dOnAQBVq1a1HzOZTOjbty86deqETz/91D5N+eyzz2LevHl44oknMG7cOJw9exZfffUV9u7diy1btkCv12PmzJl48cUXERISgjfffBMAEBsby3vmCy+8gOjoaLz99tsoKCgAAOzcuRP//fcfHnnkEdSqVQsZGRmYM2cOunXrhiNHjjidKr158yb69euHBx54AEOHDsWSJUvw+uuvo3nz5ujfv7/svWazGX379kW7du3w6aefYs2aNfjss89Qv359PP/88wCsH6SBAwdix44deP7559G4cWP8+eefGDVqlKJ8vnLlCjp06IDCwkKMGzcOVatWxfz58zFo0CAsWbIE999/P+/66dOnQ6PR4JVXXkFubi4+/vhjDB8+HNu3b1f0PClGjBiBN954A//++y+efvpp2WvXrVuHRYsWYezYsahWrZqk4/alS5fQtm1b5OTk4JlnnkHjxo1x8eJFLFmyBIWFhbyp4xdffBGR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",
      "text/plain": [
       "<Figure size 700x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot training loss curve\n",
    "ax = plot_utils.plot_performance_metric(\n",
    "    {torso_type: [train_results['loss']]},\n",
    "    'Training loss',\n",
    "    aggregate_fn_only = True,  # No variability band needed, single repetition.\n",
    "    show_gridlines = True,\n",
    ")\n",
    "ax.set_xlabel('Training Step')\n",
    "ax.set_title('Pretraining on ' + training_data_config.generator_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "x1E0dlJLMJ9b"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instant log loss shape: (128, 50)\n",
      "Hidden states dict keys: dict_keys(['layer0_cell', 'layer0_hidden', 'layer1_cell', 'layer1_hidden'])\n",
      "Prefix logits: None\n",
      "Prefix hidden states: None\n"
     ]
    }
   ],
   "source": [
    "# @title Manually using the pretrained predictor\n",
    "\n",
    "# The code below demonstrates how to manually use the a predictor and\n",
    "# evaluate it on some sequences. Thunnini also has convenience functions that\n",
    "# encapsulate this, see, e.g., `evaluation.evaluate_predictor_from_datagen`.\n",
    "\n",
    "# Instantiate data generator and sample a batch.\n",
    "datagen_tmp = builders.build_datagen(training_data_config)\n",
    "batch_tmp = datagen_tmp.generate(\n",
    "    rng_key=jax.random.PRNGKey(1337),\n",
    "    return_ground_truth_log_probs=False\n",
    "    )\n",
    "\n",
    "# We'll also change the torso config to return the hidden states.\n",
    "torso_config_tmp = dataclasses.replace(torso_config, return_hidden_states=True)\n",
    "# The predictor is stateless - simply build a new instance.\n",
    "predictor_tmp = builders.build_predictor(predictor_config, torso_config_tmp)\n",
    "# Run a forward pass.\n",
    "logits, hidden_states, prefix_logits, prefix_hidden = predictor_tmp.apply(\n",
    "      trained_params, sequences=batch_tmp, prefix_type='None', prefix=None\n",
    "      )\n",
    "predictor_log_losses = datagen_tmp.instant_log_loss_from_logits(\n",
    "      logits, batch_tmp\n",
    "      )\n",
    "\n",
    "print('Instant log loss shape:', predictor_log_losses.shape)\n",
    "print('Hidden states dict keys:', hidden_states.keys())\n",
    "\n",
    "print('Prefix logits:', prefix_logits)  # Will be None - no prefix used.\n",
    "print('Prefix hidden states:', prefix_hidden)  # Will be None - no prefix used."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "yqBAumj6KJ8m"
   },
   "source": [
    "# Tuning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "y-mqSajpjCk8"
   },
   "outputs": [],
   "source": [
    "#@title Tune pretrained predictor\n",
    "tuned_params, tuned_prefix, tuning_results = tuning.tune(\n",
    "    tuning_config=tuning_config,\n",
    "    predictor_config=predictor_config,\n",
    "    torso_config=torso_config,\n",
    "    predictor_params=trained_params,\n",
    "    data_config=tuning_data_config,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "PACyQocmqele"
   },
   "outputs": [],
   "source": [
    "# Plot tuning loss curve\n",
    "ax = plot_utils.plot_performance_metric(\n",
    "    {torso_type: [tuning_results['loss']]},\n",
    "    'Tuning loss',\n",
    "    aggregate_fn_only = True,  # No variability band needed, single repetition.\n",
    "    show_gridlines = True,\n",
    ")\n",
    "ax.set_xlabel('Tuning Step')\n",
    "ax.set_title(tuning_config.tuning_method + ' tuning on ' + tuning_data_config.generator_type)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "ZziHpwyt4Ssu"
   },
   "source": [
    "# Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "kxeSUGZH_g4h"
   },
   "outputs": [],
   "source": [
    "#@title Evaluate pretrained predictor\n",
    "\n",
    "eval_results_trained = evaluation.evaluate_predictor_from_datagen(\n",
    "    predictor_config=predictor_config,\n",
    "    torso_config=torso_config,\n",
    "    predictor_params=trained_params,\n",
    "    datagen_config=eval_data_config,\n",
    "    datagen_seed=1337,\n",
    "    datagen_num_batches=1,\n",
    "    return_gt_and_optimal_results=True,\n",
    ")\n",
    "sequences, trained_logits, trained_log_losses, bo_log_probs, bo_losses, gt_log_probs, gt_losses = eval_results_trained"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "X7a8NbXBLzxg"
   },
   "outputs": [],
   "source": [
    "#@title Evaluate tuned predictor on the same sequences\n",
    "\n",
    "tuned_logits, tuned_log_losses = evaluation.evaluate_predictor_from_sequences(\n",
    "    predictor_config=predictor_config,\n",
    "    torso_config=torso_config,\n",
    "    predictor_params=tuned_params,\n",
    "    prefix_type = \"embedding\",\n",
    "    prefix = tuned_prefix,\n",
    "    sequences=sequences,\n",
    "    batch_size=-1,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ax5ASI-lVuFN"
   },
   "outputs": [],
   "source": [
    "#@title Construct and evaluate untrained predictor on the same sequences\n",
    "untrained_predictor = builders.build_predictor(predictor_config, torso_config)\n",
    "untrained_params = untrained_predictor.init(\n",
    "    rngs=jax.random.PRNGKey(815),\n",
    "    sequences=sequences[0:10],  # Take some sequences as dummy sequences\n",
    ")\n",
    "\n",
    "untrained_logits, untrained_log_losses = evaluation.evaluate_predictor_from_sequences(\n",
    "    predictor_config=predictor_config,\n",
    "    torso_config=torso_config,\n",
    "    predictor_params=untrained_params,\n",
    "    sequences=sequences,\n",
    "    batch_size = -1,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "x4ujM-gaS5_L"
   },
   "outputs": [],
   "source": [
    "#@title Compute regrets\n",
    "instant_regret = {\n",
    "    'Bayes-optimal (' + eval_data_config.generator_type + ')': [np.mean(bo_losses - gt_losses, axis=0)],\n",
    "    'Pretrained ' + torso_type + ' (' + training_data_config.generator_type + ')': [np.mean(trained_log_losses - gt_losses, axis=0)],\n",
    "    'Tuned ' + torso_type + ' (' + tuning_data_config.generator_type + ')': [np.mean(tuned_log_losses - gt_losses, axis=0)],\n",
    "    'Untrained ' + torso_type: [np.mean(untrained_log_losses - gt_losses, axis=0)],\n",
    "    }\n",
    "\n",
    "cumulative_regret = {}\n",
    "for model, regret in instant_regret.items():\n",
    "  cumulative_regret[model] = [np.cumsum(regret)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "3CyTXS_1lC8x"
   },
   "outputs": [],
   "source": [
    "# Plot evaluation results\n",
    "fig, axes = plt.subplots(nrows=2, ncols=1, figsize=(9, 8))\n",
    "\n",
    "plot_utils.plot_performance_metric(\n",
    "    instant_regret,\n",
    "    'Instant regret [nats]',\n",
    "    axis=axes[0],\n",
    "    aggregate_fn_only=True,  # No variability band needed, single repetition.\n",
    "    show_gridlines=True,\n",
    "    )\n",
    "axes[0].set_title('Evaluation on ' + eval_data_config.generator_type)\n",
    "axes[0].set_xlabel('')\n",
    "axes[0].get_legend().remove()\n",
    "\n",
    "plot_utils.plot_performance_metric(\n",
    "    cumulative_regret,\n",
    "    'Cumulative regret [nats]',\n",
    "    axis=axes[1],\n",
    "    aggregate_fn_only=True,  # No variability band needed, single repetition.\n",
    "    show_gridlines=True,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "xqKO5OA88cQT"
   },
   "outputs": [],
   "source": [
    "# @title Show one trajectory\n",
    "\n",
    "fig = plt.figure(figsize=(9, 4))\n",
    "seq_len = sequences.shape[1]\n",
    "xvec = np.arange(seq_len)\n",
    "\n",
    "# Plot observations from the first eval sequence\n",
    "plt.plot(xvec, sequences[0, :, 0], '.', label='Observations')\n",
    "# Plot the ground-truth probability (gt_log_probs are the same for each timestep)\n",
    "plt.hlines(np.exp(gt_log_probs[0,0,0]), xmin=0, xmax=seq_len, label='Ground truth', color='goldenrod', linewidth=4)\n",
    "\n",
    "# Plot predictions\n",
    "plt.plot(xvec, jax.nn.softmax(trained_logits[0, :, :])[:,0], label='Pretrained ' + torso_type, linewidth=2)\n",
    "plt.plot(xvec, jax.nn.softmax(tuned_logits[0, :, :])[:,0], label='Tuned' + torso_type, linewidth=2)\n",
    "plt.plot(xvec, jax.nn.softmax(untrained_logits[0, :, :])[:,0], label='Untrained ' + torso_type, linewidth=2)\n",
    "plt.plot(xvec, jax.nn.softmax(bo_log_probs[0, :, :])[:,0], label='Bayes-optimal', color='C0', linewidth=2)\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel('Step')\n",
    "plt.yticks([0, 0.5, 1])\n",
    "plt.grid('on')\n",
    "plt.ylabel('Probability')\n",
    "plt.title('Single trajectory predictions')"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "last_runtime": {
    "build_target": "//learning/grp/tools/ml_python/gpu:ml_notebook",
    "kind": "private"
   },
   "name": "ThunniniDemo.ipynb",
   "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
