{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {
    "notebookRunGroups": {
     "groupValue": "12"
    }
   },
   "source": [
    "# Random Number Generation Experiments\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {
    "notebookRunGroups": {
     "groupValue": "2"
    }
   },
   "source": [
    "![RNG diagram](../rng.png)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Introduction\n",
    "\n",
    "This notebook sets up experiments comparing different methods for training language models to generate random numbers from specified distributions.\n",
    "\n",
    "We will focus on sampling numbers from various distributions.\n",
    "\n",
    "The models we will compare are:\n",
    "\n",
    "- GFN-fine-tuned LM: Fine-tuned via generative flow networks\n",
    "- Likelihood-trained LM: Supervised-fine-tuned LM\n",
    "- RL-tuned LM: Fine-tuned via reinforcement learning (PPO)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Several axes of experimentation:\n",
    "\n",
    "- vary the distribution\n",
    "  - discrete: uniform, Poisson, Binomial, Geometric, etc\n",
    "  - continuous: uniform, Gaussian, exponential, etc\n",
    "- vary the hyperparameters of the distribution (in the context)\n",
    "  - Uniform: between 0 and `n_max`\n",
    "  - Poisson: `lambda` between `λ_min` and `λ_max`\n",
    "  - etc\n",
    "- vary the prompt\n",
    "  - 'Randomly generate (uniformly) one single random integer between 0 and {num_test}, and then stop: '\n",
    "  - 'Randomly generate (uniformly) one single random integer in the interval [0, {num_test}]: '\n",
    "  - 'Here is one single random integer sampled uniformly between 0 and {num_test}: '\n",
    "  - \"The following is a random integer drawn uniformly between 0 and {num_test}: \"\n",
    "  - etc\n",
    "- vary the model\n",
    "  - GFN-LM\n",
    "  - PPO\n",
    "  - MLE (SFT)\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General imports\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import hydra\n",
    "from hydra.experimental import initialize, compose\n",
    "import wandb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "xq77AgKWJM-N"
   },
   "outputs": [],
   "source": [
    "import random\n",
    "import json\n",
    "import numpy as np\n",
    "from itertools import chain\n",
    "from tqdm import tqdm\n",
    "import pandas as pd\n",
    "\n",
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from peft import LoraConfig, get_peft_model, PeftModel\n",
    "\n",
    "from utils import generate, generate_and_return_eos_logprob"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.font_manager\n",
    "import matplotlib.pyplot as plt\n",
    "import shutil\n",
    "\n",
    "import seaborn as sns\n",
    "from IPython.display import display, Markdown\n",
    "\n",
    "# # Remove the matplotlib cache\n",
    "# shutil.rmtree(matplotlib.get_cachedir())\n",
    "\n",
    "fonts = matplotlib.font_manager.findSystemFonts(fontpaths=None, fontext=\"ttf\")\n",
    "\n",
    "# print the names of all fonts\n",
    "font_names = [matplotlib.font_manager.get_font(x).family_name for x in fonts]\n",
    "print(font_names)\n",
    "\n",
    "fonts = [f.name for f in matplotlib.font_manager.fontManager.ttflist]\n",
    "print(fonts)\n",
    "print(\"Times New Roman\" in fonts)\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "matplotlib.rc(\"font\", family=\"Times New Roman\")\n",
    "\n",
    "print(matplotlib.get_configdir())\n",
    "print(matplotlib.get_cachedir())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Thu Sep 28 23:56:00 2023       \n",
      "+---------------------------------------------------------------------------------------+\n",
      "| NVIDIA-SMI 535.54.03              Driver Version: 535.54.03    CUDA Version: 12.2     |\n",
      "|-----------------------------------------+----------------------+----------------------+\n",
      "| GPU  Name                 Persistence-M | Bus-Id        Disp.A | Volatile Uncorr. ECC |\n",
      "| Fan  Temp   Perf          Pwr:Usage/Cap |         Memory-Usage | GPU-Util  Compute M. |\n",
      "|                                         |                      |               MIG M. |\n",
      "|=========================================+======================+======================|\n",
      "|   0  NVIDIA A100-SXM4-80GB          On  | 00000000:0F:00.0 Off |                    0 |\n",
      "| N/A   25C    P0              60W / 400W |      7MiB / 81920MiB |      0%      Default |\n",
      "|                                         |                      |             Disabled |\n",
      "+-----------------------------------------+----------------------+----------------------+\n",
      "                                                                                         \n",
      "+---------------------------------------------------------------------------------------+\n",
      "| Processes:                                                                            |\n",
      "|  GPU   GI   CI        PID   Type   Process name                            GPU Memory |\n",
      "|        ID   ID                                                             Usage      |\n",
      "|=======================================================================================|\n",
      "|  No running processes found                                                           |\n",
      "+---------------------------------------------------------------------------------------+\n"
     ]
    }
   ],
   "source": [
    "!nvidia-smi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import gc\n",
    "\n",
    "with torch.no_grad():\n",
    "    gc.collect()\n",
    "    torch.cuda.empty_cache()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load the pretrained model\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize Hydra\n",
    "hydra.core.global_hydra.GlobalHydra.instance().clear()\n",
    "initialize(config_path=\"multiobjective-lm/rng/configs\")\n",
    "cfg = compose(config_name=\"config\")\n",
    "\n",
    "bsz = cfg.hparams.GFN.bsz\n",
    "grad_acc = cfg.hparams.grad_acc\n",
    "lr = cfg.hparams.lr\n",
    "warmup_steps = cfg.hparams.warmup_steps\n",
    "subtb_lambda = cfg.hparams.GFN.subtb_lambda\n",
    "max_len = cfg.hparams.max_len\n",
    "min_len = cfg.hparams.min_len\n",
    "eval_interval = cfg.hparams.eval_interval\n",
    "log_interval = cfg.hparams.log_interval\n",
    "model_to_use = cfg.hparams.model_to_use\n",
    "seed = cfg.hparams.seed\n",
    "save_dir = cfg.hparams.save_dir\n",
    "epochs = cfg.hparams.epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set the seed\n",
    "torch.manual_seed(seed)\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "GPTJForCausalLM(\n",
       "  (transformer): GPTJModel(\n",
       "    (wte): Embedding(50400, 4096)\n",
       "    (drop): Dropout(p=0.0, inplace=False)\n",
       "    (h): ModuleList(\n",
       "      (0-27): 28 x GPTJBlock(\n",
       "        (ln_1): LayerNorm((4096,), eps=1e-05, elementwise_affine=True)\n",
       "        (attn): GPTJAttention(\n",
       "          (attn_dropout): Dropout(p=0.0, inplace=False)\n",
       "          (resid_dropout): Dropout(p=0.0, inplace=False)\n",
       "          (k_proj): Linear(in_features=4096, out_features=4096, bias=False)\n",
       "          (v_proj): Linear(in_features=4096, out_features=4096, bias=False)\n",
       "          (q_proj): Linear(in_features=4096, out_features=4096, bias=False)\n",
       "          (out_proj): Linear(in_features=4096, out_features=4096, bias=False)\n",
       "        )\n",
       "        (mlp): GPTJMLP(\n",
       "          (fc_in): Linear(in_features=4096, out_features=16384, bias=True)\n",
       "          (fc_out): Linear(in_features=16384, out_features=4096, bias=True)\n",
       "          (act): NewGELUActivation()\n",
       "          (dropout): Dropout(p=0.0, inplace=False)\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (ln_f): LayerNorm((4096,), eps=1e-05, elementwise_affine=True)\n",
       "  )\n",
       "  (lm_head): Linear(in_features=4096, out_features=50400, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "if model_to_use == \"gpt-j\":\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"nlpcloud/instruct-gpt-j-fp16\")\n",
    "    model = AutoModelForCausalLM.from_pretrained(\n",
    "        \"nlpcloud/instruct-gpt-j-fp16\", torch_dtype=torch.bfloat16\n",
    "    )\n",
    "elif model_to_use == \"gpt2\":\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"gpt2\")\n",
    "    model = AutoModelForCausalLM.from_pretrained(\"gpt2\")\n",
    "\n",
    "model.to(\"cuda\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## LoRA, Optimizer\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "lora_config = LoraConfig(\n",
    "    r=cfg.lora.r,\n",
    "    lora_alpha=cfg.lora.lora_alpha,\n",
    "    target_modules=[\"k_proj\", \"v_proj\"] if model_to_use == \"gpt-j\" else [\"c_attn\"],\n",
    "    lora_dropout=cfg.lora.lora_dropout,\n",
    "    bias=cfg.lora.bias,\n",
    ")\n",
    "inference_model = get_peft_model(model, lora_config)\n",
    "\n",
    "opt = torch.optim.AdamW(\n",
    "    [{\"params\": inference_model.parameters(), \"lr\": lr}],\n",
    "    betas=(cfg.adamw.b1, cfg.adamw.b2),\n",
    ")\n",
    "\n",
    "\n",
    "# learning rate schedule\n",
    "def get_lr_mult_at_step(step):\n",
    "    if step <= warmup_steps:\n",
    "        return min(step / warmup_steps, 1.0)\n",
    "    return max((total_steps - step) / (total_steps - warmup_steps), 0)\n",
    "\n",
    "\n",
    "sched = torch.optim.lr_scheduler.LambdaLR(opt, get_lr_mult_at_step)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dataloader and Scheduler\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Tokenizing dataset...: 4096it [00:01, 2747.80it/s]\n"
     ]
    }
   ],
   "source": [
    "from rng.rng_dataset import get_dataloader_from_dataframe\n",
    "\n",
    "df_train = pd.read_csv(cfg.file_name.train)\n",
    "\n",
    "train_loader = get_dataloader_from_dataframe(df_train, tokenizer, bsz=bsz, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "total_steps = epochs * len(train_loader)\n",
    "\n",
    "\n",
    "# learning rate schedule\n",
    "def get_lr_mult_at_step(step):\n",
    "    if step <= warmup_steps:\n",
    "        return min(step / warmup_steps, 1.0)\n",
    "    return max((total_steps - step) / (total_steps - warmup_steps), 0)\n",
    "\n",
    "\n",
    "sched = torch.optim.lr_scheduler.LambdaLR(opt, get_lr_mult_at_step)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Tests\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tokenized num_test:  [940] \n",
      "\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tokenized prompt 'Randomly generate (uniformly) one single random integer between 0 and 10, and then stop: ': \n",
      "\t Random|ly| generate| (|un|iform|ly|)| one| single| random| integer| between| 0| and| 10|,| and| then| stop|:|  \n",
      "\t [29531, 306, 7716, 357, 403, 6933, 306, 8, 530, 2060, 4738, 18253, 1022, 657, 290, 838, 11, 290, 788, 2245, 25, 220] \n",
      "\t \t ⟶ Contains tokenized `num_test`?  False \n",
      " Model response: \n",
      "\t [' the', ' number', ' you', ' generated', '.', '\\n', '<|endoftext|>'] \n",
      "\n",
      "\n",
      "\n",
      "Tokenized prompt 'Randomly generate (uniformly) one single random integer in the interval [0, 10]: ': \n",
      "\t Random|ly| generate| (|un|iform|ly|)| one| single| random| integer| in| the| interval| [|0|,| 10|]:|  \n",
      "\t [29531, 306, 7716, 357, 403, 6933, 306, 8, 530, 2060, 4738, 18253, 287, 262, 16654, 685, 15, 11, 838, 5974, 220] \n",
      "\t \t ⟶ Contains tokenized `num_test`?  False \n",
      " Model response: \n",
      "\t [' \\\\', 'n', '\\\\', 'n', 'The', ' randomly', ' generated', ' integer', ' is', ':', ' 8', '\\n', '<|endoftext|>'] \n",
      "\n",
      "\n",
      "\n",
      "Tokenized prompt 'Here is one single random integer sampled uniformly between 0 and 10: ': \n",
      "\t Here| is| one| single| random| integer| sampled| uniformly| between| 0| and| 10|:|  \n",
      "\t [4342, 318, 530, 2060, 4738, 18253, 35846, 42096, 1022, 657, 290, 838, 25, 220] \n",
      "\t \t ⟶ Contains tokenized `num_test`?  False \n",
      " Model response: \n",
      "\t [' 4', '.', '\\n', '<|endoftext|>'] \n",
      "\n",
      "\n",
      "\n",
      "Tokenized prompt 'The following is a random integer drawn uniformly between 0 and 10: ': \n",
      "\t The| following| is| a| random| integer| drawn| uniformly| between| 0| and| 10|:|  \n",
      "\t [464, 1708, 318, 257, 4738, 18253, 7428, 42096, 1022, 657, 290, 838, 25, 220] \n",
      "\t \t ⟶ Contains tokenized `num_test`?  False \n",
      " Model response: \n",
      "\t [' 4', '\\n', '<|endoftext|>'] \n",
      "\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "num_test = 10\n",
    "print(\"Tokenized num_test: \", tokenizer.encode(str(num_test)), \"\\n\\n\")\n",
    "\n",
    "\n",
    "def test_prompt(prompt_test, num_test=num_test):\n",
    "    tokenzed_prompt_test = tokenizer(prompt_test, return_tensors=\"pt\").to(\"cuda\")\n",
    "    print(\n",
    "        f\"Tokenized prompt '{prompt_test}': \\n\\t\",\n",
    "        \"|\".join(\n",
    "            tokenizer.decode(t) for t in tokenzed_prompt_test[\"input_ids\"].tolist()[0]\n",
    "        ),\n",
    "        \"\\n\\t\",\n",
    "        tokenzed_prompt_test[\"input_ids\"].tolist()[0],\n",
    "        \"\\n\\t\",\n",
    "        \"\\t ⟶ Contains tokenized `num_test`? \",\n",
    "        num_test in tokenzed_prompt_test[\"input_ids\"].tolist()[0],\n",
    "        \"\\n\",\n",
    "        \"Model response: \\n\\t\",\n",
    "        [\n",
    "            tokenizer.decode(t)\n",
    "            for t in model.generate(\n",
    "                **tokenzed_prompt_test,\n",
    "                max_new_tokens=30,\n",
    "                temperature=0,\n",
    "                pad_token_id=tokenizer.eos_token_id,\n",
    "            )[0][len(tokenizer.encode(prompt_test)) :]\n",
    "        ],\n",
    "        \"\\n\\n\\n\",\n",
    "    )\n",
    "\n",
    "\n",
    "prompt_tests = [\n",
    "    f\"Randomly generate (uniformly) one single random integer between 0 and {num_test}, and then stop: \",\n",
    "    f\"Randomly generate (uniformly) one single random integer in the interval [0, {num_test}]: \",\n",
    "    f\"Here is one single random integer sampled uniformly between 0 and {num_test}: \",\n",
    "    f\"The following is a random integer drawn uniformly between 0 and {num_test}: \",\n",
    "]\n",
    "\n",
    "for prompt_test in prompt_tests:\n",
    "    test_prompt(prompt_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The first number that requires more than 1 token is: (521, [20, 2481])\n",
      "The second number that requires more than 1 token is: (527, [20, 1983])\n",
      "The third number that requires more than 1 token is: (531, [20, 3132])\n"
     ]
    }
   ],
   "source": [
    "numbers = range(1, 1001)\n",
    "\n",
    "num_more_than_one_token = (\n",
    "    (num, tokens) for num in numbers if len(tokens := tokenizer.encode(str(num))) > 1\n",
    ")\n",
    "\n",
    "first_number_more_than_one, first_number_more_than_one_token = next(\n",
    "    num_more_than_one_token\n",
    ")\n",
    "print(\n",
    "    f\"The first number that requires more than 1 token is: {first_number_more_than_one, first_number_more_than_one_token}\"\n",
    ")\n",
    "print(\n",
    "    f\"The second number that requires more than 1 token is: {next(num_more_than_one_token)}\"\n",
    ")\n",
    "print(\n",
    "    f\"The third number that requires more than 1 token is: {next(num_more_than_one_token)}\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "50400"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_tokens = [tokenizer.encode(str(num)) for num in range(first_number_more_than_one)]\n",
    "\n",
    "allowed_indices = torch.tensor(\n",
    "    [token for sublist in num_tokens for token in sublist], device=\"cuda\"\n",
    ")\n",
    "\n",
    "vocab_nice_list = torch.zeros(len(tokenizer.vocab), device=\"cuda\").bool()\n",
    "vocab_nice_list[allowed_indices] = True\n",
    "vocab_nice_list[tokenizer.eos_token_id] = True\n",
    "len(vocab_nice_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_max = cfg.distributions[\"uniform discrete\"].parameters.b\n",
    "eos_token_id = tokenizer.eos_token_id\n",
    "eos_string = tokenizer.decode(eos_token_id)\n",
    "tokens_of_numbers = (\n",
    "    torch.tensor([tokenizer.encode(str(num)) for num in range(n_max)]).view(-1).cuda()\n",
    ")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training loop\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "dph6LMlH0ooD",
    "outputId": "cb17a778-4221-421b-f6b2-f163cad72797",
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# from next_sentence.utils import generate_and_return_termination_logprob\n",
    "\n",
    "wandb.init(project=\"gfn-finetuning\")\n",
    "# columns = [\"Epoch\", \"Step\", \"Input prompt\", \"Response\", \"Reward\"]\n",
    "# examples_generation_table = wandb.Table(columns=columns)\n",
    "\n",
    "\n",
    "@torch.inference_mode()\n",
    "def reward_fn(x, n_max=n_max, skip_first=1):\n",
    "    # Get the token ids after skip_first\n",
    "    token_ids = x[:, skip_first:]\n",
    "\n",
    "    # print(\"x \", x)\n",
    "\n",
    "    if token_ids.shape[1] == 0:\n",
    "        return torch.full((x.shape[0],), fill_value=-8).cuda()\n",
    "\n",
    "    # Initialize rewards to a low value\n",
    "    rew = torch.full(token_ids.shape, fill_value=-8).cuda() * torch.arange(\n",
    "        1, token_ids.shape[1] + 1, device=\"cuda\"\n",
    "    )\n",
    "\n",
    "    # Create a mask where the first token is in the list of tokenized permitted numbers\n",
    "    tokenized_permitted_numbers_mask = tokens_of_numbers[:n_max]\n",
    "    first_token_mask = torch.cat(\n",
    "        (\n",
    "            (token_ids[:, 0].unsqueeze(-1) == tokenized_permitted_numbers_mask)\n",
    "            .any(dim=-1)\n",
    "            .unsqueeze(-1),\n",
    "            torch.zeros(\n",
    "                token_ids.shape[0], token_ids.shape[1] - 1, device=\"cuda\"\n",
    "            ).bool(),\n",
    "        ),\n",
    "        dim=-1,\n",
    "    )\n",
    "\n",
    "    # Create a mask where the remaining tokens are the eos_token_id\n",
    "    remaining_eos_tokens_mask = torch.cat(\n",
    "        (\n",
    "            torch.zeros(token_ids.shape[0], 1, device=\"cuda\").bool(),\n",
    "            token_ids[:, 1:] == eos_token_id,\n",
    "        ),\n",
    "        dim=-1,\n",
    "    )\n",
    "\n",
    "    # Set the reward to 8 (resp. 0) where\n",
    "    # the token is the first token and in the list of tokenized permitted numbers,\n",
    "    # (resp. it is one of the remaining tokens and equal to eos_token_id)\n",
    "    rew[first_token_mask] = 8\n",
    "    rew[remaining_eos_tokens_mask] = 0\n",
    "\n",
    "    # return torch.cat((res[:, :1], res), dim=-1)\n",
    "    # return torch.cat((rew, rew.new_full((rew.shape[0], 1), 0)), dim=-1).cumsum(dim=-1)\n",
    "    return rew.sum(dim=-1)\n",
    "\n",
    "\n",
    "inference_model.train()\n",
    "for epoch in range(epochs):\n",
    "    for step, batch in tqdm(\n",
    "        enumerate(train_loader), desc=f\"Epoch {epoch}\", total=len(train_loader)\n",
    "    ):\n",
    "        opt.zero_grad()\n",
    "        loss = 0.0\n",
    "        for _ in tqdm(range(grad_acc), desc=f\"Step {step}\"):\n",
    "            encoded_input, _ = batch\n",
    "            (\n",
    "                generated_text,\n",
    "                logPF,\n",
    "                eos_logprob,\n",
    "                logrewards,\n",
    "            ) = generate_and_return_eos_logprob(\n",
    "                inference_model,\n",
    "                encoded_input,\n",
    "                eos_token_id=eos_token_id,\n",
    "                reward_fn=lambda x: reward_fn(\n",
    "                    x, n_max=n_max, skip_first=encoded_input.size(-1)\n",
    "                ),\n",
    "                # vocab_nice_mask=vocab_nice_list,\n",
    "                max_len=max_len,\n",
    "                min_len=min_len,\n",
    "                temperature=1,\n",
    "            )\n",
    "\n",
    "            # modified subTB loss with logpb=0\n",
    "            delta = (\n",
    "                logrewards[:, :-1]\n",
    "                - eos_logprob[:, :-1]\n",
    "                + logPF[:, :-1]\n",
    "                - (logrewards[:, 1:] - eos_logprob[:, 1:])\n",
    "            )\n",
    "            delta_cumsum = torch.cat([torch.zeros_like(delta[:, :1]), delta], 1).cumsum(\n",
    "                1\n",
    "            )\n",
    "\n",
    "            # get a mask for tokens after the first eos in generated_text\n",
    "            mask = (generated_text == eos_token_id).cumsum(dim=-1) >= 1\n",
    "            mask = mask[:, encoded_input.size(-1) :]\n",
    "            mask = mask[:, :max_len]\n",
    "            # if mask is too short, pad it\n",
    "            if mask.size(-1) < max_len:\n",
    "                mask = torch.cat(\n",
    "                    [\n",
    "                        mask,\n",
    "                        torch.ones(\n",
    "                            mask.size(0),\n",
    "                            max_len - mask.size(-1),\n",
    "                            dtype=torch.bool,\n",
    "                            device=\"cuda\",\n",
    "                        ),\n",
    "                    ],\n",
    "                    dim=-1,\n",
    "                )\n",
    "            # get trajectory lengths by summing the mask\n",
    "            batch_loss = 0.0\n",
    "            total_lambda = 0.0\n",
    "            for subtraj_len in range(1, max_len + 1):\n",
    "                subtb_term = (\n",
    "                    delta_cumsum[:, subtraj_len:] - delta_cumsum[:, :-subtraj_len]\n",
    "                ) ** 2\n",
    "                subtb_term[mask[:, subtraj_len - 1 :]] = 0\n",
    "                batch_loss += subtb_lambda ** (subtraj_len - 1) * subtb_term.sum()\n",
    "                total_lambda += (\n",
    "                    subtb_lambda ** (subtraj_len - 1)\n",
    "                    * (~mask[:, subtraj_len - 1 :]).sum()\n",
    "                )\n",
    "            batch_loss /= total_lambda\n",
    "\n",
    "            loss += batch_loss.mean()\n",
    "            batch_loss.mean().backward()\n",
    "            wandb.log({\"loss\": loss.item()})\n",
    "        opt.step()\n",
    "        sched.step()\n",
    "        if step % log_interval == 0:\n",
    "            print(f\"Epoch: {epoch}, Batch: {step}, Loss: {loss.item()}\")\n",
    "        for i in range(generated_text.size(0)):\n",
    "            wandb.log(\n",
    "                {\n",
    "                    \"epoch\": epoch,\n",
    "                    \"step\": step,\n",
    "                    \"input prompt\": tokenizer.decode(\n",
    "                        generated_text[i, : len(encoded_input[i])]\n",
    "                    )\n",
    "                    .replace(eos_string, \"\")\n",
    "                    .rstrip(),\n",
    "                    \"response\": tokenizer.decode(\n",
    "                        generated_text[i, len(encoded_input[i]) :]\n",
    "                    ),\n",
    "                    \"reward\": reward_fn(\n",
    "                        generated_text[i].unsqueeze(0), skip_first=len(encoded_input[i])\n",
    "                    ).item(),\n",
    "                }\n",
    "            )\n",
    "\n",
    "# wandb.log({\"examples generation\": examples_generation_table})\n",
    "wandb.finish()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test generations\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomly generate one single random integer from a uniform discrete distribution with parameters a=0, b=100, and then stop: 49 ['17', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([8], device='cuda:0') \n",
      "\n",
      "\n",
      "Randomly generate one single random integer from a uniform discrete distribution with parameters a=0, b=100, and then stop: 8 ['41', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([8], device='cuda:0') \n",
      "\n",
      "\n",
      "Sample a single output from a uniform discrete distribution with parameters a=0, b=100: 78<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|> ['\\n', 'Produ', 'ce', ' a', ' list'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([-120], device='cuda:0') \n",
      "\n",
      "\n",
      "Here is one single random integer sampled from a uniform discrete distribution with parameters a=0, b=100: 65<|endoftext|><|endoftext|><|endoftext|><|endoftext|> ['<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([-8], device='cuda:0') \n",
      "\n",
      "\n",
      "Here is one single random integer sampled from a uniform discrete distribution with parameters a=0, b=100: 57<|endoftext|><|endoftext|><|endoftext|><|endoftext|> ['<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([-8], device='cuda:0') \n",
      "\n",
      "\n",
      "Randomly generate one single random integer from a uniform discrete distribution with parameters a=0, b=100, and then stop: 22 ['67', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([8], device='cuda:0') \n",
      "\n",
      "\n",
      "The following is a random integer drawn from a uniform discrete distribution with parameters a=0, b=100: 46<|endoftext|><|endoftext|><|endoftext|><|endoftext|> ['<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([-8], device='cuda:0') \n",
      "\n",
      "\n",
      "The following is a random integer drawn from a uniform discrete distribution with parameters a=0, b=100: 23<|endoftext|><|endoftext|><|endoftext|><|endoftext|> ['<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>', '<|endoftext|>'] \n",
      "\t\t\t\t\t\t\t Reward: tensor([-8], device='cuda:0') \n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "test_results = generate(\n",
    "    inference_model,\n",
    "    encoded_input.repeat(8, 1),\n",
    "    eos_token_id=eos_token_id,\n",
    "    max_len=max_len,\n",
    "    temperature=1,\n",
    ")[0]\n",
    "\n",
    "for i in range(generated_text.size(0)):\n",
    "    print(\n",
    "        tokenizer.decode(test_results[i, : len(encoded_input[0])]),\n",
    "        [tokenizer.decode(t) for t in test_results[i, len(encoded_input[0]) :]],\n",
    "        \"\\n\\t\\t\\t\\t\\t\\t\\t Reward:\",\n",
    "        reward_fn(test_results[i].unsqueeze(0), skip_first=len(encoded_input[0])),\n",
    "        \"\\n\\n\",\n",
    "    )"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Save the model\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "ckpt_name = f\"rng-GFN_{model_to_use}_bsz_{bsz}_grad_acc_{grad_acc}_lr_{lr}_warmup_steps_{warmup_steps}_total_steps_{total_steps}_subtb_lambda_{subtb_lambda}_max_len_{max_len}_min_len_{min_len}_eval_interval_{eval_interval}_log_interval_{log_interval}_seed_{seed}\"\n",
    "inference_model.save_pretrained(f\"{save_dir}/{ckpt_name}\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluation\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # ckpt_name = f\"rng_{model_to_use}_bsz_{bsz}_grad_acc_{grad_acc}_lr_{lr}_warmup_steps_{warmup_steps}_total_steps_{total_steps}_subtb_lambda_{subtb_lambda}_max_len_{max_len}_min_len_{min_len}_eval_interval_{eval_interval}_log_interval_{log_interval}_seed_{seed}\"\n",
    "\n",
    "# ckpt_name = \"rng_gpt-j_50samples_len5_3000steps_rewtemp5.0_seed_True\"\n",
    "# model_path = f\"{save_dir}/{ckpt_name}\"\n",
    "# inference_model = PeftModel.from_pretrained(model, model_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n",
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['<|endoftext|>']\n",
      "['<|endoftext|>']\n"
     ]
    }
   ],
   "source": [
    "inference_model.eval()\n",
    "with torch.inference_mode():\n",
    "    prompt_test = \"Randomly generate (uniformly) one single random integer between 0 and 520, and then stop: \"\n",
    "    print(\n",
    "        [\n",
    "            tokenizer.decode(t)\n",
    "            for t in inference_model.generate(\n",
    "                **tokenizer(prompt_test, return_tensors=\"pt\").to(\"cuda\"),\n",
    "                max_new_tokens=30,\n",
    "                temperature=0\n",
    "            )[0][len(tokenizer.encode(prompt_test)) :]\n",
    "        ]\n",
    "    )\n",
    "\n",
    "    prompt_test = (\n",
    "        \"Here is one single random integer sampled uniformly between 0 and 520: \"\n",
    "    )\n",
    "    print(\n",
    "        [\n",
    "            tokenizer.decode(t)\n",
    "            for t in inference_model.generate(\n",
    "                **tokenizer(prompt_test, return_tensors=\"pt\").to(\"cuda\"),\n",
    "                max_new_tokens=30,\n",
    "                temperature=0\n",
    "            )[0][len(tokenizer.encode(prompt_test)) :]\n",
    "        ]\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rng.rng_utils import get_distribution\n",
    "\n",
    "n_max = 100\n",
    "intro_prompt = f\"The following is a random integer drawn uniformly between 0 and \"\n",
    "prompt = f\"{intro_prompt}{n_max-1}: \""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rng.rng_plot import plot_distribution\n",
    "\n",
    "n_samples = 1000 * 512"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [17:13<00:00,  1.03s/it]\n"
     ]
    }
   ],
   "source": [
    "inference_model.base_model.enable_adapter_layers()\n",
    "\n",
    "dist_inference, number_of_NaNs_inference = get_distribution(\n",
    "    inference_model, tokenizer, prompt, num_samples=n_samples\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "80001 numbers, 431999 NaNs\n"
     ]
    }
   ],
   "source": [
    "number_of_numbers = len(dist_inference)\n",
    "\n",
    "print(f\"{number_of_numbers} numbers, {number_of_NaNs_inference} NaNs\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_distribution(\n",
    "    dist_inference,\n",
    "    n_max=n_max,\n",
    "    model_name=\"GFN-finetuned Model\",\n",
    "    color=\"lightseagreen\",\n",
    "    number_of_NaNs=number_of_NaNs_inference,\n",
    "    xlims=(-5, 105),\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "inference_model.base_model.disable_adapter_layers()\n",
    "\n",
    "dist_vanilla, number_of_NaNs_vanilla = get_distribution(\n",
    "    inference_model, tokenizer, prompt, num_samples=n_samples\n",
    ")\n",
    "\n",
    "# plot_distribution(\n",
    "#     dist_vanilla,\n",
    "#     model_name=\"Vanilla Model\",\n",
    "#     color=\"darksalmon\",\n",
    "#     number_of_NaNs=number_of_NaNs,\n",
    "# )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "number_of_numbers_vanilla = len(dist_vanilla)\n",
    "\n",
    "print(f\"{len(number_of_numbers_vanilla)} numbers, {number_of_NaNs_vanilla} NaNs\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "## Vanilla Model: Distribution of generated numbers"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkEAAAHKCAYAAAAEm58rAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABg7UlEQVR4nO3deXiMV/sH8O9k32ikvE1UNBoiQoWE1L5ra0nJq6g1qK1q19aulEakqVhCLVElpUoVTUNV7D9LCKpoJI2KJBIEQ0T2mfP7I1ee15hEJmNmMsz3c125mPOc58w992z3nPPMMzIhhAARERGRiTGr7ACIiIiIKgOLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkksgoiIiMgksQgiIiIik8QiiIiIiEwSiyA9O3/+PKZNm4b69eujTZs2+PjjjzFlyhT07dsXH330EX799Ve1ff766y/4+fnh1q1bOo1l3Lhx+OqrrwAAFy9exGeffYaPPvpIp9fx9PVUtqioKAQFBaF79+6YOHEisrOzKzukSnXy5El88sknmD17dmWH8sK5desWNm7cCIVCAQCIiIhAhw4d8Pbbb+Ozzz6DXC5X2ycmJgb169eX/ubNmydty87ORlBQEMLDwxEeHo4vvvii1DFKDB8+HCtXrlRpE0IgLCwMc+bMwbRp03Do0CGV7QqFAt988w3mzp2Ljz/+GCEhIVL8xuLEiRMYN26cUT0ms7OzMXv2bLz99tvo0KEDwsPDS81bUFCQyv0bHR0tbYuLi0Pv3r3RtGlTDBkyBCkpKWr73717F40bN5b27969O578EYeNGzdi+vTpmDJlCmbNmoXc3Fy1Mc6ePYtBgwYhNja2zNuTmpqK8PBwNG7cGG3btsX9+/dVtt+7dw9btmxBo0aNsGjRIiQkJJQ5lkKhwM6dO9GzZ0/Ur18fv/32m1qfgwcPok+fPvjvf/+LP/74o8yxlEolvvvuO9y+fbvMPnonSO/++ecf4eHhIbZv3y61KRQKsXHjRuHp6SkmTpwolEqltC09PV1MnTpVZGdnazT+1atXNeq3YcMGsXv3biGEECkpKaJfv35i8ODBFbglml3/k9dTmU6fPi0GDRokhBDi5s2bokOHDuLMmTOVHNXzS09PFw8fPtRq33///Vd06NBBTJ8+XcdRqXr06JFITU3V63UY0s2bN8XcuXOFQqEQQgixY8cOMW7cOBEVFSW+/vpr4eXlJYYOHaq235QpU8TGjRulv7S0NGnb559/Lvbu3StdjoqKEmPHji31+nft2iU8PDzEihUrVNq/+eYbMXXqVCGEEDk5OaJ9+/bir7/+kraHhYWJL774QgghhFKpFIMHDxbBwcHaJUFPrl27ZpDHZEXMmDFDLF68WERFRYmJEycKDw8PER4ertLnwYMHYsyYMdJ9u2nTJlFYWCiEECItLU3MmzdPXL58WURHR4tmzZqJfv36qV1PWFiYWLt2rTRGXFyctG379u1i1KhR0uXPPvtMTJgwQWX/s2fPipkzZwoPDw9x+vTpcm/Xjh07hIeHhxg1apTKe06JDz74QOTl5ZU7jhBCyOVy0axZM9G0aVORnJystn3Lli1i69at5Y5TUFAgpk2bJjIyMjS6Xl1jEWQAqampakVQibVr1woPDw8RERGh1dgFBQVizJgxWu376aefPncRdOHCBbFy5crnGkNfpk+fLj799NPKDkPn5s6d+1wFxsCBA/X+hrN27VqNXpRfBEVFRWLAgAHi5s2bUtvTj/lVq1YJDw8PkZKSIrWdPXtWbNq0qcxxfXx8xMWLF6XLSUlJokmTJmr95HK5mDRpkujYsaNKEXTr1i3RsGFDceLECalt7ty5UjH28OFD0aRJE3H27Flp+/79+4WXl5e4deuWJjfdYAYMGGA0RdCjR4/Exo0bVdoCAwNF+/btVdpWr14t4uPjSx3jypUrKkXGihUr1O7bR48eiZkzZ5a6f1FRkejYsaPYtWuX1Hb58mXh4eGh8pgRovhxo2kRdPr0adGyZUvh4eEhNmzYoLa9ou8HPXv2FI0bNxYBAQEiPz9fZdvOnTvFzp07NRrnn3/+EYMGDRJFRUUVun5d4HJYJRs2bBicnJxUptk1pVAo8OWXXyIxMVGr6zY3N9dqvxIZGRmYOnWqyvStMcnIyHju22hsdu/ejZ9++um5xjAz0+/T/tSpU1ixYoVer8OQ9uzZAwcHB9SsWVNq69u3r0qfTp06AQAePHggtUVERGD9+vWYO3cubty4oTZutWrVsHbtWun5c/78ebz99ttq/ZYtW4aJEyeqtR88eBCFhYXw8vKS2ho1aoTY2Fjcu3cPly9fRk5ODhwdHaXtTZo0QVFREf7v//5PsxtvIMb0PFUqlfjwww9V2jp27IiHDx9Kl/Pz8xEZGYlp06Zh5cqVasvsXl5ekMlk0mVHR0fpMVJi+/bt2L9/P8aNG4fTp0+rbEtLS8PNmzdRrVo1qa1BgwawsbHBkSNHVPpaW1tX6Pb169cPfn5+WLp0Kf76668K7fs0R0dHzJ07F1euXEFoaKjW49StWxf29vYqy4mGwiKokllZWaFFixbIzMzElStX8PDhQ0RERKBTp05IS0sDADx+/Bjz58/H8uXLMXjwYOmFMiYmBleuXIFcLse8efOwZ88exMbGYuLEiZgzZw6+//57+Pj44Ndff8XZs2cxceLEUtfdDx06hE6dOqFt27bYvHkzAOCff/7B+PHjUb9+faSlpUGpVGLLli3w8vLCypUroVAosGXLFsjlchw+fBjz5s1DSkpKqdejVCqxdu1aLFmyBJMmTcKIESNw7do1AIBcLse6devQqVMnJCUlYebMmWjatCnGjh2LwsLCMvOWlZWFRYsWYcmSJRg2bBhmz56NR48eASgufmbPno1r167hwoULmD17NmJiYkodJzs7G4sWLcLmzZuxaNEiHD16VK3Ptm3bsHjxYgwcOBCBgYG4du0aCgoKsGfPHvTr1w+//PILvvvuO7z99tvo0aMHbt68Ke2bl5eHlStXYv78+ejVqxdmzpyJ7OxsyOVyrF+/Hp06dcKFCxfQu3dv+Pv7Q6FQ4OTJk5g6dSq++eYb9O7dG5GRkQCAhIQE7N+/HwAQFhaG5cuXAyguhtevX49Fixbhgw8+wCeffKKyxv73339j0qRJCAoKwsSJE8tdfy8oKMA333yDJUuWYMyYMSr7nDx5Ej169JBe0O/evYtFixahfv36iI2Nxa1bt7Br1y4UFhZi48aNWLBggTRuVFQUZs6ciTlz5mDAgAEqxx3cunUL8+bNw5IlSzBo0CAsWbIEBQUFAIDLly9j5syZGDlyJBISEjBw4EA0bdoUYWFhKCwsRFBQEHx8fNCrVy9kZGSUm3sAuHbtGubNm4dvvvkGXbt2LbXIKPHDDz+gRYsWKm2vvfaayuWioiLY2dnBw8MDAJCTk4MqVarA2dkZP//8M/z9/XHw4EGVfcaPH4+YmBhMmjQJcXFxiI6ORlBQkEqfs2fPokaNGnjzzTfV4rp06RLMzMzwyiuvSG1OTk4QQuDq1avSm/a9e/dUtpfk+2nlPRfv37+PZcuWoX79+vjll18AAMeOHUPHjh0xZMgQANrfVyV27NiBVq1aoUuXLti7d6/Ktt9//x2LFy/GRx99hL59++LChQtQKpU4ePAgPvroI4SHhyM4OBi+vr6IjY2t0H38pKpVq8LGxkalTaFQwNvbW7qclJQEPz8/FBUVITw8HO+//z6Sk5NLHa+oqAh///035syZo9L+8OFDNG7cGCdOnEBgYCCWLl2qsg1Qve9K7uvnPVbU3NwcS5cuhaOjI6ZOnfrM4yQ3bdqE2bNnY8GCBejdu3epxx198MEHCAgIwKZNm3D48OEyx4qJicGiRYuwaNEi+Pj44IcfflDZ7ufnh02bNml/w7Rl8LknE/Ss5TAhhAgJCREeHh7i999/F3fv3pWWyEqWPNasWSNNqysUCjFixAhp3xUrVoiOHTtKl//++2/Rrl070bNnT7F3716xYMECERsbKxITE0X79u1VppynT58u2rdvL8LDw8WJEyfEhAkThIeHhzh48KAQQoiTJ0+qxCGEEO3bt1eZkn96ir606/n6669VjkMIDg4WrVq1Eg8fPhR3794VP/zwg/Dw8BCLFi0SSUlJ4tixY8LDw0PleIknKRQK0b9/f3H48GEhRPGSYL9+/VTyIkTx1G55U+yff/65CAoKEkIUHzPh7+8vevXqJR2b8csvv4gDBw5I1ztixAjxzjvviMePH4uLFy8KDw8PMWbMGHHy5Elx48YN0apVKzF//nxp/C+//FJaenjw4IFo0aKFmDVrlrhz545YvXq18PDwEEFBQWLfvn1i3rx5Ijc3V3h7e4vjx48LIYTYtm2b8PT0FI8ePRJCFE9nP32frFy5Uvz9999CCCHy8vJEz549RWBgoBCi+NiE1q1bS0s5aWlpomHDhs/My+TJk8UPP/wgXZ4wYYLo0aOHdLzDsmXLVB5zKSkpKtPxJY/3J6fn9+zZIwIDA6UlgkGDBomePXsKIYR4/Pix6Nq1q0hISBBCCJGdnS06duwo5s6dK4QQ4vr16yIgIEC888474pdffhF3794V33zzjfDw8BChoaHi4sWLIjU1VbRr106j3AshxIgRI6SljFu3bonPP/+81Fzcvn1beHh4iCNHjpSZLyGKl/9CQ0NL3Xb16lXRs2dP4e3tLdLT01W2fffdd8LDw0P4+PioLVHl5+eLTz75RFpmePq5NmrUKOHn56eyT8lzNioqSlo+eXLp7tGjR8LDw0NERkaqxanJc1GhUAgPDw+VZY7PPvtMWkbR9r4aPHiweO+998SGDRvEsWPHxKBBg4Snp6d0H8XGxqosLc6aNUv4+fmJrKwsceHCBfHWW2+Jfv36icOHD4uZM2eKxMREje9jTYwYMUIcO3as1G0HDhwQvr6+4v3331c7zub48eNiwIABwtfXV/z666+l7n/v3j3ptXf//v1CCCHu378v6tevL2bMmKHSt3nz5mrHdJX2fCvL6dOnpcfQqVOnRIMGDcTkyZOl7U8uh8XGxgoPDw/p8Td16lTRp08flfFK+ufk5IiePXsKPz8/6XH85HJYfn6+6NChg7TfgQMH1B6DBw8eFPXr1xd3794t93boEmeCjEDJtKkQAq+++ireeustle2ZmZnYsWMHUlNTYWZmhtGjR5c5VoMGDVCrVi3Url0b3bp1w7x58+Dn54d69eqpTOeXcHV1xSeffIJWrVph6dKlqF27trTcUtqySXlLKU9fj1wux/fff4933nlHahs5ciQePHiAzZs349VXX5U+5Q4dOhTu7u5o27YtqlWrVuoSAgAcOXIE8fHxaNeuHQDA0tISI0eOxP/93//hzJkzz4zvaTExMahTpw6A4vvB19cXNWrUwLfffgsAWLVqFRITE7Fu3TpERETA2dkZLi4uyM3NRaNGjQAAXbp0QcuWLVG7dm34+vpKcd+8eROHDx/Gnj17sG7dOvz0009o1qwZCgoKUKNGDTRp0gQAEBAQgPfeew8LFiyAhYUFunXrhoYNGwIAqlevDqVSiaysrFLjLygowI8//ojjx49j3bp12LRpE+rXrw9zc3MolUqEh4fDx8dHuk9ef/11leWTpyUkJGDv3r3o2rWr1DZ27Fj8888/iIqKAqD+GHhy2r8sy5YtQ0BAgNR3+vTpGDt2LABg586dkMlk0iyKvb09hg4dKj3m3dzc8Oabb+I///kPAgIC8Oqrr6JXr14AgDZt2qBx48aoVasWfH19pU/jz8o9ANy5cwfr1q1DdnY2XnvtNfz3v/8tMx8AUKNGjTJvW05ODg4dOlTm87J+/fr47rvvYGVlhT179kjtQgjcvXsXQ4cORX5+PgYPHqwyS7d+/XoMGzYMVlZWpY4rk8nUlkKUSiUAwMLCAg0bNkTTpk3x448/IjU1FUVFRfj5558BALVr11YbT5PnYnmvCdrcVyW8vb0xYsQItG3bFqtXr4a9vT22b98OoPh5mJ6ejnXr1mHdunWwsbFBgwYNkJ6ejiZNmsDJyQne3t7o0KEDgoKCUK9ePY3v4/JcuXIFNjY2aNu2banbu3TpgmXLluHq1au4cOGCyjYvLy8MGTIEr7zyCqZPn47r16+r7e/k5ISwsDA0a9YM27ZtA1C8VNqjRw/s3bsXly5dghACv//+Ox4+fFjqfaeNFi1aYPz48di7d6+U5yf95z//wZAhQ6THX/Xq1cv89qKtrS2WLVuGgoICTJs2Te3QjpycHKSnp+O7776DUqlEp06d4OnpqdLH2dlZmsU0JAuDXhuVqmRa2NXVFYD6C82AAQPw+++/o1u3bujTp0+507pmZmaoUqWKWnt56+4WFhZo1aoVzp49W5Hwn3k958+fR2FhoUo8r776KpydnXHp0iUpXkD1zdTOzq7M5bDY2FjY2dmp5KmkaLh06RL8/Pw0jrVatWoqU852dna4c+cOACA3Nxepqano27fvM98En4zDzs5OeqFISkqClZVVmW+OJfs5ODhIbRYWFli8eDEuXLiAjRs3Skt8JW9uT0tJScGjR48watSoUouRo0ePSm9CJZ51DEHJdPeT95enpycsLCxw6dIlBAQElLlvWe7fv4+bN2+qHJvy1ltvScV+bGys2uO1YcOGUCqVuHLlClxdXWFhofpSVdptsLKyQlFREYDyc//xxx/j888/x8mTJzFy5EgMHTq01H4lx/jY2tqWefuWLVuGmTNnlvqcK1GjRg306dNHZal01apVUCqVmD17Njp16oSxY8di6tSp2LJlC65fv4579+6hWbNmzxzz6aI/JycHwP+WvVavXo2goCCMGzcOTZo0gZmZGRwdHdWW90pU9LlYmoreV6WpWrUqmjRpgtTUVABAYmIipkyZIn1wKC3up/Ov6X38LAUFBVizZo3aMuXT2rRpg4YNG+LmzZvw8fGR2p2cnNCtWzd4enqiW7duOHbsmPSh60nm5uYYOXIkgoODpbZFixahatWqmDFjBry8vFCzZk1YWFiofEB5Xh9//DHOnTuHr776Ck2bNlXZ5ubmhlmzZiE6OhqJiYlITk5+5vGf7u7u+PLLL/Hpp59i1apVqFWrlrTN0dERQ4cOxZIlS7Bz505MmjRJ5YMx8L/n2N27d3V2+zTBmaBKVlhYiNjYWLz22mtqlXEJd3d37N27F4MGDcLOnTvRq1cvnZ9DqIS9vf0zX/ArquRJ8/QDu0aNGmovlhUZ88GDByovotWrVweg/gJcnpkzZ+LgwYPIz8+HUqlEXFyc9EZfMmtw5coVlX1ycnKQl5dX7tgFBQW4efOmysGyANTO0fG0RYsW4Y8//sCkSZPw3nvvlXsd+fn5SEpKUmmXy+UQQiAnJ0flgM7ylHZ/mZmZoVq1alrfXyWfJJ/+5F9QUIDCwkIIIVQKUUD7+/PJsZ+V++7du+PXX39FkyZN8PXXX2PEiBGlFpolx4aUVQT89ttv8PT0VDlepCy1atWSjiXKz8/H+vXr0b17dwBAy5YtsXjxYsTFxeHff/9FdHQ0tmzZonIOmps3byI8PBz169cHUFyc5uTkqJw7JjMzExYWFtJsn5OTE0JDQxEVFYUvv/wSFy9eVPl0b8yefC0qKChQex4qlUq1+/dJmt7HzxIWFobx48erHHdVFldXVzg7O5e6rU6dOqhfvz4sLS2fuf+Tx5rZ2triiy++QHR0NL7++mskJibi/fffl54buiCTyfD111/D0dERU6ZMUXlde/ToEQIDA2FpaYkpU6ZIM9/P4u/vj/79++Pbb79VO35o9uzZ2LBhA8zMzDBhwgQsW7ZMLRbA8AfJswiqZFu2bEFmZibGjRtX5p3/xx9/oGrVqpg5cya2b9+O7Oxs7Nu3D4BmSxEVcePGDbRu3RoApCdsfn6+tF2pVFbohaRhw4YwNzdX+8Qql8vL/DRansaNG0sFS4mSF8OKjlm7dm24uLhg3bp1+P777zFq1CgMGzYMAPDKK6+gRo0aWL16tcqb4I4dOzTKu7u7u/RJ8kklSxKlOXnyJCIjIzFhwoRSHw9PX+8bb7wBS0tLtZPolcRYp04dnDlzRu1Td1n3YePGjQFA5f4SQuDhw4dSbi0tLVVeLEsKp5Ixn47RwcFBOkD4yTh27twpXWd6err0qR8ovj8tLS2fORPyLOXl/o8//sCbb76JNWvW4Msvv8TZs2cRHx+vNk7Jm1LJjNyTzpw5g5SUFJVllqeLuSclJibC398fQPGbel5enkox0r17dzg6OkIIgf79+2P37t0qfzVq1JDaS/pbWlri4sWL0hgJCQlo3bq1yuxiiW3btsHc3BxjxowpM0ZNPH3/V/Q1QVNPvhbVq1cPGzZsUDmId+/evdLMV2k0vY/LsnHjRrRs2VIqOoGy71+FQoH8/Hy12ZQnFRQUwNfXt8ztly9fRp8+fUrdduzYMSQkJGDWrFkaRq+5kuW469evq3xbLCIiAjk5OWozNuWZM2cOPD09pccpUPx8PnPmDNq0aYNdu3ahV69e0pdwSjx+/BgAyiwk9YVFkAGUNWvw888/4+uvv8aQIUNUvpJZ8oJS8u/JkyelN3wvLy+88cYbcHNzA1D8aeH+/fu4d++e9M0mpVIpzWI8SaFQqK3V3rt3T/okmZCQgKSkJIwYMQJA8ScTmUyGnTt3IiEhAd9++y1yc3ORlJQkTevb2dkhOTkZ6enp+Pvvv9Wux8XFBX369MGOHTukQuXq1atQKBTSE77kjfHpqdayThnw3nvvwd3dHRs2bJByVLJc+OQLVl5eXqlnWH3SF198gVq1aqFOnTrSk6/km2sAMHr0aFy8eBGDBw/Gli1bEBQUhEePHsHa2loqjJ5+AyiJ+80330TXrl2xceNGTJs2DT/++CPGjx8vfaIq2e/J+6qk4Ny9ezeuXr0qfQsnMTERV69elT4Z//vvvzh06BBsbW0xaNAg7N+/H6NGjcKPP/6IWbNmSV+tDQwMRGpqKoKCgpCTk4OkpCSkpKQgOTm51GOumjZtitatW2Pz5s1SLIcOHYKXlxc6dOgAoLhwvHfvHn7//XecP38e33//PYDiF/F79+5JMV6/fh2nTp3C48ePMXr0aCQmJuLjjz/Gb7/9huDgYDx69AiWlpYYMGAAnJycsH79eimO33//HYGBgdIS2tOP3acLr5I2TXMfGRkpzQp169YN1tbWcHFxUctHgwYNYGdnh/T0dJX2S5cuYcWKFWjUqBGOHTuGo0ePYseOHVi7di2A4mPNZs+ejczMTADF34yrW7cu3njjDQDFy40dOnRQ+dbi7du3UadOHdSpUwc1atRAgwYNVP6srKykdqD4zWvAgAHSGNnZ2Th+/DgmTZqkdjuOHj2K33//HRs2bHjmbIQmz0VXV1fs378fSUlJ2Lp1KxITE3Hz5k1pNrKi91WJW7duSdd/7NgxWFhYSLOyo0aNws2bN9G/f39s2rQJy5Ytw5kzZ6Rj3Up7zSvrPr537x66d+/+zLPa//TTT1LBdOzYMRw5cgRr166VvuEXHh6OVatWIT8/HwUFBQgLC8Po0aOlmcvjx49j79690m3+9ddf4efnJ70+paSkYMKECbh8+TKA4ufOxYsX1ZaugeLH2urVq7F58+ZSl1xLcqbJKVby8vJKfT/y8fHB1KlTVdoKCgpw7do1nD9/HqdOncKJEyfw6NEjnD9/XnotL20mzsrKCsuXL1eJtbCwEGvWrIEQAhYWFnjnnXek97ASN2/ehJWVlfT4NhQeE6Rn58+fl77ivGbNGpw+fRq2tra4efMmqlSpgvXr16NVq1ZS/4yMDOkgtc2bN+OTTz6BUqnEyJEj8f7778PW1hbdu3dHx44dARQ/ubdv344hQ4Zg5cqViIqKwt9//43ExET88ssv0qfU/fv3Iz4+Hunp6Th9+rR0UFx4eDgCAwPh7u4OKysrREZGSm88NWrUwPjx4xEREYELFy7g66+/xt69e1GjRg3pDTIwMBAhISGwsrLCokWLSr2euXPnwtraGsOHD0fjxo1RVFSEzZs3S28uJbd306ZNGDlyJI4ePYrbt2/jyJEj6Nixo9pSg4WFBTZs2IAvv/wSgYGBqFu3LmxsbLBkyRIAxctVP//8M+Lj45GSkoLdu3ejVatW+M9//qN2/7Rr1w7ff/89tm/fjry8POlFa9asWQgMDMSQIUPw6NEjbNmyBStXrkRAQADGjh2L3NxcbNiwAQAQHR2NRo0a4d69ezhz5gwePHiA33//He+99x6CgoJga2uLmJgY/Pnnn5gwYQJatWqFlJQU6SDI5cuXY8qUKXBzc0ObNm3QsWNHhIaGomPHjhg3bhyOHDmCffv2YfHixQCADh06YPr06ViwYAHMzMykAxH37NmDq1evYujQodJ5bHr37o07d+5g48aN2Lt3L/r37y8duFryyetpYWFh+OqrrzB06FB4eXlBCIF169ZJx4t06dIFHTt2xPTp09GtWzeMGjUKhw4dglKplJbO+vbti2+++QaTJ09Gy5YtMXDgQMjlckRGRuLvv/9G//79MXLkSADFx39s2rQJCxcuxOjRo+Hs7AxnZ2fpwOlTp04hNjYWjx8/RnR0NJo3b46NGzcCKP4g4eLigmvXriE2NhZZWVnYt28funXrVmbugeJlo4CAAHTv3h1ZWVlYsWKFdBzNkywtLdGpUyeVc3ElJyfjo48+wsOHD9WOnys5P9Irr7yCU6dOYd++fWjatCkGDx4szQKVWLJkifSVYVdXV9y7dw8rVqyo0HmcPv/8cwQHB2PRokV4+PAhvvrqK+n4uJIDttPT02Fvb4/169c/cxlM0+fi9OnTMXPmTIwZMwYLFy5Ew4YN8eDBA2RmZiIzM1Or+2rOnDkIDw/HkCFD8Oabb8Le3h7ff/+9FG/nzp2xYMECrF27FitXrkTXrl0xd+5cKBQKbN26Fbdv38Zvv/2GJk2aoHPnzs+8j2/duoUHDx7gt99+wyeffKJyrBpQPMP0xRdfQAihciC7ubk5jh8/DqD4Mbty5Ur8+OOPaNasGSZMmAB3d3epb3x8PNauXYvly5ejSZMm8PLywhdffCFtt7e3R3p6OgYOHIgGDRrg3Xffxdy5c6XtQgjs3bsXd+7cQVFRESIiIkqd3bt69Sq2bt0KoHimz87Orszjpk6cOIHNmzfjxo0b8PT0RPfu3VVmmz/66COcO3dOujxw4EAcP34cn3zyCQYPHoyRI0di+vTpuHTpEqpXr44ff/wRiYmJWLt2Lbp37y4d0woUf1AKCgpSeY05ceIE+vbti9atW+PWrVtq5xVKSEhA+/btYW9vX2r8+iITzzrSieglplQqMWfOHMydO1eavSgsLMTNmzexcOFCqcgh05aYmIgZM2ZIs3L0cliyZAmmTJnyQhwfZQr69u2LuXPnSkvyhsLlMDJZP//8M8zMzFQOBLe0tMTrr7+u8qmOTJuHhwfat28vnaiSXnwJCQlwc3NjAWQkzpw5A29vb4MXQACLIDJhd+7cwe+//45t27bh1q1byMnJQUJCAubPn4/BgwdXdnhkRCZMmIArV66U+kvg9GLJzMzE/fv30b9//8oOhVD8Onz48GHMmDGjUq6fy2FksgoLCxEZGYmdO3ciNTUV9vb2aNOmDSZOnKiyvk1U4ujRo2jTpo1R/dYV0YtKqVTi0KFD6Ny5s86/6awpFkFERERkkrgcRkRERCaJRRARERGZJJ4nqAwXLlyAEOKZJxYjIiIi41JYWAiZTPbMM3iX4ExQGYQQz/yxuOcdu6CgQG/jUzHm2TCYZ8Ngng2HuTYMfeW5Iu/fnAkqQ8kMUMkvXetSTk4O4uPjUbduXdjZ2el8fCrGPBsG82wYzLPhMNeGoa88X7p0SeO+nAkiIiIik8QiiIiIiEwSiyAiIiIySSyCiIiIyCSxCCIiIiKTxCKIiIiITBKLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkksgoiIiMgksQgiIiIik8QiiIiIiEwSiyAiIiIySRaVHQARka7J90SotVXrNbISIiEiY8aZICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkksgoiIiMgksQgiIiIik8QiiIiIiEwSiyAiIiIySSyCiIiIyCSxCCIiIiKTxCKIiIiITBKLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkkWlR0AACgUCoSFhUGpVEIulyMgIAB+fn7P3CclJQUBAQHYs2cPatWqpfU4REREZJqMoggKDQ2Fra0tJk6ciPz8fPj7+2PDhg1wdXUttX9BQQEWL16M7Ozs5xqHiIiITFelF0FyuRyRkZHYs2cPAMDa2hq+vr6IiIjAggULSt1n+fLlGDp0KA4dOvRc45RHCIGcnByt9n2W3NxclX9JP5hnwzDGPCuVSrU2fTyXDckY8/yyYq4NQ195FkJAJpNp1LfSi6BTp06hsLAQtWvXltrc3d2xffv2UvtHRUWhadOmarM7FR1HE4WFhYiPj9d6//IkJyfrbWz6H+bZMIwpzzUeP1ZrS9bjc9mQjCnPLzvm2jD0kWcrKyuN+lV6EZSRkQF7e3tYWlpKbQ4ODsjIyFDre+3aNSQnJ2PChAlIS0vTehxNWVpaom7dulrvX5bc3FwkJyfDzc0Ntra2Oh+fijHPhmGMec5NOafWVr1Bg0qIRHeMMc8vK+baMPSV56SkJI37VnoRJJPJYGNjo9KmVCphYaEaWm5uLjZt2oR58+Y91zgVjc3Ozk7r/ctja2ur1/GpGPNsGMaU53wz9S++Gktsz8uY8vyyY64NQ9d51nQpDDCCIsjZ2RlZWVkqbVlZWXB2dlZp279/P/bs2YO9e/cC+N+a//vvv4+xY8eiVq1aGo1DREREBBhBEdSiRQvIZDJpSgwAbty4gbZt26r069q1K5o1ayZdvnXrFgYNGoR169bBw8MDRUVFGo1DREREBBjByRKdnJzQp08fxMTEAChe9jp37hyGDx+OzMxMBAcHIy8vD/b29qhVq5b0VzLD4+zsjKpVqz5zHCIiIqKnVXoRBAAzZsxAeno6wsPDERwcjODgYLi4uCA9PR3R0dGQy+XPNQ4RERHR0yp9OQwAbGxsSj3g2dvbG8ePHy91n1q1aiEhIUGjcYiIiIieZhQzQURERESGxiKIiIiITBKLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkksgoiIiMgksQgiIiIik8QiiIiIiEwSiyAiIiIySSyCiIiIyCSxCCIiIiKTxCKIiIiITBKLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMEosgIiIiMkksgoiIiMgksQgiIiIik8QiiIiIiEwSiyAiIiIySSyCiIiIyCSxCCIiIiKTxCKIiIiITBKLICIiIjJJLIKIiIjIJLEIIiIiIpPEIoiIiIhMklEUQQqFAqGhoQgJCcHMmTNx5syZUvsVFRVhwYIFaNasGdq1a4cff/xRrU9cXBzq168v/W3evFnf4RMREdELyKKyAwCA0NBQ2NraYuLEicjPz4e/vz82bNgAV1dXlX47duyAv78/pk6dim+//RYLFixA69atUbt2banPL7/8go0bN0qXfX19DXY7iIiI6MVR6TNBcrkckZGR6NGjBwDA2toavr6+iIiIUOvbu3dv+Pj4oEqVKhg/fjwAwMzsfzfh7NmzyMvLg7u7O1q1aoVWrVrB2traMDeEiIiIXiiVPhN06tQpFBYWqszmuLu7Y/v27Wp9bW1tpf9fvXoV48ePR61ataS2HTt24MCBA4iOjsa7776L+fPnw8nJSevYhBDIycnRev+y5ObmqvxL+sE8G4Yx5lmpVKq16eO5bEjGmOeXFXNtGPrKsxACMplMo76VXgRlZGTA3t4elpaWUpuDgwMyMjJK7Z+VlYU9e/Zg/fr16Nevn8qNDQkJwaJFi3Ds2DEEBQUhMDAQO3fuhJWVlVaxFRYWIj4+Xqt9NZGcnKy3sel/mGfDMKY813j8WK0tWY/PZUMypjy/7Jhrw9BHnjV936/0Ikgmk8HGxkalTalUwsKi9NBsbW3RvHlzZGZmIjw8HA4ODhg2bJi03crKCl26dIGXlxd69uyJgwcPolu3blrFZmlpibp162q177Pk5uYiOTkZbm5uKrNbpFvMs2EYY55zU86ptVVv0KASItEdY8zzy4q5Ngx95TkpKUnjvpVeBDk7OyMrK0ulLSsrC87OzqX2t7S0hKenJzw9PXH79m2cPHlSpQgqUbNmTfTo0QNpaWlaxyaTyWBnZ6f1/uWxtbXV6/hUjHk2DGPKc76Z+uGOxhLb8zKmPL/smGvD0HWeNV0KA4zgwOgWLVpAJpOpTIfduHEDbdu2LXffxo0bo2bNmmVuNzMzg7e3ty7CJCIiopdMpRdBTk5O6NOnD2JiYgAUT4+dO3cOw4cPR2ZmJoKDg5GXlwcAuHTpErKzswEUnzPoxIkTGD58OAAgOzsbW7ZskbZfvnwZFhYW8PPzq4RbRURERMau0pfDAGDGjBkICQlBeHi4VPi4uLjg4sWLiI6ORmBgIFxcXLB48WJcu3YNHTt2RLVq1TB+/Hi88cYbAID8/Hxs27YN4eHh8PPzQ/PmzTF79uxKvmVERERkrIyiCLKxscG8efPU2r29vXH8+HHp8tatW8sc49VXX0VUVJRe4iMiIqKXT6UvhxERERFVBhZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJ0qoIevDggY7DICIiIjIsrYqgqVOnIjk5WcehEBERERmOhTY7OTg44Pvvv8edO3fQoUMHdO/eHQ4ODrqOjYiIiEhvtCqCgoKC4ODggKKiIhw9ehTz58+HpaUl/P390apVqwqPp1AoEBYWBqVSCblcjoCAAPj5+an1KyoqwldffYWoqCjY2dnh448/xoABAyo8DhEREZFWy2Elsz4WFhbo3Lkzpk2bBplMho8++gjvvvsuli1bVqHlstDQUFhZWeHzzz/H/PnzMWfOHKSmpqr127FjB/z9/XH48GH07NkTCxYsQEpKSoXHISIiItKqCLp06RIA4M8//8SUKVPQtWtXnD59Gp999hl+/vln9OnTB7t378bs2bORk5PzzLHkcjkiIyPRo0cPAIC1tTV8fX0RERGh1rd3797w8fFBlSpVMH78+OIbYGZW4XGIiIiItFoOmzJlCuzs7JCYmAhfX18sXboUXbp0kQqSKlWqYPLkyVi5ciVmzJiBFStWlDnWqVOnUFhYiNq1a0tt7u7u2L59u1pfW1tb6f9Xr17F+PHjUatWrQqPoykhRLlFnDZyc3NV/iX9YJ4NwxjzrFQq1dr08Vw2JGPM88uKuTYMfeVZ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rPzDHY0l1ooypjy/7Jhrw9B1nivyLXWtiiA3Nze1tt27d+P1119Hs2bNKjRWixYtIJPJpGoQAG7cuIG2bdtqE5oKMzOzMg+iJiIiItOm0bfDAgICMGfOHPzf//1fmX3ef/99nDhxAm3atKlQAE5OTujTpw9iYmIAFE+PnTt3DsOHD0dmZiaCg4ORl5enso8QAkIIlbbs7Gxs2bIF2dnZAIDLly/DwsKizPMNERERkWnTqAgyMzPDggULpAInPDwcXbp0wcSJE/Hzzz9LfSZPnoyaNWtWOIgZM2YgPT0d4eHhCA4ORnBwMFxcXJCeno7o6GjI5XKp75UrV3Do0CHcvXsXu3fvlr7hkZ+fj23btqFr166YNGkS/vzzT8yePbvCsRAREZFp0Gg5rG7duipfSx8/fjyOHTuGpUuXqh3AXKdOnQoHYWNjg3nz5qm1e3t74/jx4yptDRs2xKpVq9T6vvrqq4iKiqrwdRMREZFp0ngm6Gnu7u6lfoOrrHP4EBERERkTrc4YTURERPSi02g57MaNG9i5c6fKwciltRUVFSEuLk73URIRERHpmEZF0Pnz53H+/PlS25+mza/IExERERmaRkVQ7969MWrUKLUzOz8tPz8fy5Yt00VcRERERHqlURHUv39/uLu7azTgsGHDniceIiIiIoPQ6MDopk2bajygj4+P1sEQERERGQq/HUZEREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUmyqOwAAEChUCAsLAxKpRJyuRwBAQHw8/Mrte+jR4+wdetWHDx4ENu3b9d6HCIiIjJtRlEEhYaGwtbWFhMnTkR+fj78/f2xYcMGuLq6qvW9fv06UlNTcffu3ecah4iIiExbpS+HyeVyREZGokePHgAAa2tr+Pr6IiIiotT+jRs3hre393OPQ0RERKat0meCTp06hcLCQtSuXVtqc3d3V1vqepK5ublOximPEAI5OTla71+W3NxclX9JP5hnwzDGPCuVynL76OO5rU/GmOeXFXNtGPrKsxACMplMo76VXgRlZGTA3t4elpaWUpuDgwMyMjIqZZwnFRYWIj4+Xuv9y5OcnKy3sel/mGfDMKY813j8uNw+yXp8buuTMeX5ZcdcG4Y+8mxlZaVRv0ovgmQyGWxsbFTalEolLCwqFpquxnmSpaUl6tatq/X+ZcnNzUVycjLc3Nxga2ur8/GpGPNsGMaY59yUc+X2qd6ggQEi0R1jzPPLirk2DH3lOSkpSeO+lV4EOTs7IysrS6UtKysLzs7OlTLOk2QyGezs7LTevzy2trZ6HZ+KMc+GYUx5zjcr/3BHY4m1oowpzy875towdJ1nTZfCACM4MLpFixaQyWQq02E3btxA27ZtK2UcIiIiMg2VXgQ5OTmhT58+iImJAVA8PXbu3DkMHz4cmZmZCA4ORl5enso+QggIITQeh4iIiOhplV4EAcCMGTOQnp6O8PBwBAcHIzg4GC4uLkhPT0d0dDTkcrnU98qVKzh06BDu3r2L3bt3q3zDo6xxiIiIiJ5W6ccEAYCNjQ3mzZun1u7t7Y3jx4+rtDVs2BCrVq2q0DhERERETzOKmSAiIiIiQ2MRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJsmisgMAAIVCgbCwMCiVSsjlcgQEBMDPz6/UvkePHsWBAwfg4OAAOzs7TJgwATKZTNq+Z88efP7559Ll1atXo3Pnznq/DURERPRiMYoiKDQ0FLa2tpg4cSLy8/Ph7++PDRs2wNXVVaXf33//jZCQEOzatQtWVlYICgpCREQERo0aBaC4mDpx4gQ2btwIAJDJZGjRooXBbw8REREZv0pfDpPL5YiMjESPHj0AANbW1vD19UVERIRa39WrV6Njx46wsrICAHTt2hXr169Hfn4+ACAqKgqOjo5o0KABWrVqhZYtW6rMEhERERGVqPSZoFOnTqGwsBC1a9eW2tzd3bF9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c+fOYfjw4cjMzERwcDDy8vIAACNGjMDhw4elg6n279+Pjz/+GObm5vDw8EDLli1x9OhRAMCdO3eQnp6ODz74oHJuGBERERk1mSipKCpRXl4eQkJC4OTkhMzMTPTq1Qs+Pj64ePEixo8fj+3bt8PFxQUA8Ouvv+LixYvSyRLHjBkjjSOXy/H111/D1dUVGRkZCAwMhLu7e2XdLCIiIjJiRlEEERERERlapS+HEREREVUGFkFERERkklgEERERkUliEUREREQmiUUQERERmSQWQURERGSSWAQRERGRSWIRRERERCap0n9F3tQoFAqEhYVBqVRCLpcjICAAfn5+lR3WCy8hIQHz58/H1atX4ebmhhkzZuDtt98GUPwbct9++y2qV6+OrKwsfPrpp6hatWolR/zii4iIwNGjRxEZGQmAedaXtLQ0REVFoVatWnjjjTfQuHFj5lqH0tLS8O2338Ld3R15eXmwsLDA6NGjAQB//fUXfvzxR1SrVg1FRUX49NNPYWVlVckRvziuXr2K9evXw93dHePGjZPay3v8rl+/Hnfv3kVOTg5atWqFbt266S9IQQYVHBwsli9fLoQQIi8vT3Tt2lWkpKRUclQvtvz8fPHxxx+L//u//xN//vmnCAwMFE2aNBG3bt0Sjx8/Fp07dxbXr18XQghx4MABMXLkyMoN+CUQFxcnOnXqJAYPHiyEEMyznhw/flyMHTtWPHr0SGpjrnWrf//+IjY2Vrr82WefiX379olbt26Jjh07CrlcLoQQ4vvvvxdffPFF5QT5AsrOzhanT58WrVu3FitWrJDay3v8RkZGis8//1wIIYRSqRR9+vQR58+f11ucXA4zILlcjsjISPTo0QMAYG1tDV9fX0RERFRyZC+2GzduYN68eWjdujW8vb2xfPlyFBQU4MKFC/j555/h5OQENzc3AEC7du0QGxuLixcvVm7QL7D79+8jKioKvXr1ktqYZ927evUqFi5ciJCQEDg4OEjtzLVuJSQkICsrS7rs6OiIrKwsfPfdd/D29oajoyMAoGvXrti+fTtu375dSZG+WOzt7fH222+jdu3aKu3PevwqFAqEh4dL75EymQwdOnTAqlWr9BYniyADOnXqFAoLC1UeFO7u7jh16lQlRvXiq1evHpydnaXLr7zyCl555RW8/vrrOH78OFxdXaVtVlZWcHV1xcmTJysj1BeeEALLly/H1KlTIZPJpHbmWfcWLlyIhg0bYs2aNRg4cCBWrVoFhULBXOuYv78/Fi5ciH///Re3b9/GvXv30KtXLxw/flzltbpmzZqwsrJCbGxsJUb74jE3N1e5/KzH75UrVyCXy9XeI8+cOYOioiK9xMdjggwoIyMD9vb2sLS0lNocHByQkZFRiVG9fK5fv466devirbfeQkZGBt544w2V7cy59jZs2IC+ffuqHX/CPOtWSkoK4uLisGLFCrz77ru4evUqPvzwQxQVFTHXOjZnzhw8fvwY/fv3R7t27RASEgJzc3NkZGRIs0AlHBwccOvWrcoJ9CXxrMdveno6AKjk3cHBAfn5+ZDL5ahRo4bO4+FMkAHJZDLY2NiotCmVSlhYsBbVpY0bN+LLL78EUJxza2trle1KpVKlECXNxMbGokqVKmjUqJHaNuZZtxISEgAAbdq0AQB4enri3Xffxc6dO5lrHSsoKED9+vXx1Vdf4dChQ9JrB4BS88zX6+fzrMdvyezyk++TSqUSAPSWd96bBuTs7Kyy9gwAWVlZKks59Hx27dqFd999V1pvLivnr732WiVE92JbvXo1rly5gq+//hoAkJ+fD4VCgWbNmsHLy4t51qGSqX8zs/99Tm3QoAH27duH+vXrM9c6NGXKFEydOhUNGjSAs7MzAgMD8fbbb8PFxUUlz0IIvl7rwLNek11cXAAADx8+lAqhrKws2Nraqs3K6QpnggyoRYsWkMlkSE5Oltpu3LiBtm3bVl5QL5HDhw/DwcEBrVu3ltrat2+Pf/75R7pcWFiI9PR0tGvXrjJCfKGFhoZi9+7d0t+HH36IRo0aYffu3XjnnXeYZx3y8vICAPz7779Sm4WFBerVq8fHtA7J5XIcO3YMb775JgCgcePGGDFiBM6dO6eW54yMDAgh0KJFi8oK96XwrMdvgwYNUKNGDSQlJUnbb9y4gdatW6scg6hLLIIMyMnJCX369EFMTAwAIDc3F+fOncPw4cMrObIX3/79+3Ht2jU0aNAAaWlpSExMxKpVq9C7d29kZGTgzp07AIAjR46gTZs28PT0rOSIXzw1atRArVq1pL+qVavC2toatWrVYp517I033kC3bt2wa9cuqe3MmTMYPXo0c61Djo6OcHV1xaVLl6Q2mUwGHx8fDBw4EOfPn0deXh4A4I8//sCAAQPg5ORUWeG+kIQQEEJIl5/1+LW0tERgYKD0HqlUKnHkyBGMGTNGb/HJxJPRkd7l5eUhJCQETk5OyMzMRK9eveDj41PZYb3QoqKiMH36dCgUCpX2adOmYfTo0bhy5Qp++OEHuLq64t69e5gyZYrKV45JOytXrsSZM2ekkyUyz7qVk5ODhQsX4vXXXwcAVKtWDYMGDQLAXOvSv//+i2+//RZNmjSBmZkZlEqllOcTJ07g999/x2uvvYa8vDxMnjyZxwRpSKFQICYmBvPnz4ebmxumTZuGZs2aAXj241epVCIsLAzm5ubIzs5Gy5Yt0blzZ73FySKIiIiITBKXw4iIiMgksQgiIiIik8QiiIiIiEwSiyAiIiIySSyCiIiIyCSxCCIiIiKTxCKIiIiITBKLICIiIjJJLIKIyGhkZ2dj69at6NChA7y8vBAXF6eyXalUIioqCl26dMFHH32EEydO6DyGf/75B/Pnz4e/v7/OxyYi48IiiIiMhoODAwYOHIjIyEgoFApMmzYNcrlc2m5mZgZ/f3+8++67CAwMVPmxXF2pUqUK7t+/j8ePH+t8bCIyLiyCiMjouLq6olq1arhz5w5mzpyptt3GxgbW1tZ6uW5nZ2fpV8WJ6OXGIoiIjFK9evUwduxYHD58GJs2bTLodZubmxv0+oiocrAIIiKjNWHCBLRo0QJff/01rly5orJNCIEdO3agadOmmDFjBgDg6tWrGD58OOrXrw8AuHXrFsLCwtCqVSs8fPgQ06ZNg4+PD0aNGoW8vDzs2LEDbdu2RZs2bUo9vujPP/9Ejx490LJlS4SFhUGpVErb4uPjsXjxYkyePBk9evTAzp07AQCXL1/GzJkzMXLkSOzduxd+fn5Yt26dvlJERM+BRRARGS0zMzN88803cHR0xJQpU5CdnS1tk8lk6Nu3L7y8vKQ2T09P9OjRQ2WMrKws3Lt3D7/99humTp2KpUuX4tixY5g9ezaqVauGPXv2wMvLC0FBQWr7HTp0CLNnz8Y777yDNWvWYMuWLQCABw8e4IcffsDMmTOxbNkyjB49GrNnz0ZcXBxsbW2RmJiI5ORk5OTkYMCAAXB1ddVjlohIWxaVHQAR0bNUr14dS5cuxbBhwzB//nyEhoaqbDczMyvzsrOzs1QkDRo0CADw+uuv49VXX4Wbmxu6dOkCAOjUqRMWLlyoMk7VqlUxdepUAECrVq3w77//4qeffsKQIUOwZcsWPHjwQJrhyc3NRYsWLXDz5k00a9YM7u7uSExMxAcffKDDTBCRrrEIIiKj5+fnh4kTJyIsLAwtW7as0L6lHd9jY2OjctnKygpFRUXPHKdt27ZYtWoVACAxMRHe3t4YPXp0qX3NzMxQpUqVCsVJRIbH5TAieiGMGTMG7dq1w8KFC3Ht2jWDX7+9vT1sbW0BAAUFBbh8+bJan/v37xs6LCJ6DiyCiOiFIJPJEBISAkdHR+zbt09qt7S0RF5ennS55ODlJw9i1oUbN25I5yWqV68eYmJiEB8fL21PTU3F6dOndXqdRKRfLIKIyOjk5eWpFDYlqlWrhrCwMFhaWkptrq6uiIuLw+XLl3HgwAHExMQAAGJjY5GTkwOFQgEA0r9AcYH0ZJEkhFDr8/jxY2lm5/bt2zhy5AgmTZoEoPj4ImtrawQGBiI8PBwbN27E/Pnz0blzZ2n8goICneSCiPSHRRARGZWEhASEhoYiPj4eW7Zswd27d1W2N23aFJ9++ql0eeTIkXjllVcwfPhwpKam4p133sFbb72F27dvIyUlBVFRUQCAdevW4f79+/jhhx+koiYuLg5XrlzB7t27AQDffvstcnNzMWjQIPj7+2PUqFH4/PPPsXz5cqxZswa1a9cGALz22mtYv349Xn/9daxfvx6HDh3C/PnzYW1tjaNHj+L06dO4cuUKNm7cqFJYEZFxkYmSj0BEREREJoQzQURERGSSWAQRERGRSWIRRERERCaJRRARERGZJBZBREREZJJYBBEREZFJYhFEREREJolFEBEREZkkFkFERERkklgEERERkUliEUREREQmiUUQERERmaT/Bzo31W9bi/yFAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_distribution(\n",
    "    dist_vanilla,\n",
    "    n_max=n_max,\n",
    "    model_name=\"Vanilla Model\",\n",
    "    color=\"darksalmon\",\n",
    "    xlims=(-5, 105),\n",
    "    number_of_NaNs=number_of_NaNs_vanilla,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(\"plots\"):\n",
    "    os.makedirs(\"plots\")\n",
    "\n",
    "df_inference = pd.DataFrame(dist_inference, columns=[\"Generated Numbers\"])\n",
    "df_inference.to_csv(\n",
    "    f\"plots/GFN_nb-numbers_{number_of_numbers}_nb-NaNs_{number_of_NaNs_inference}_{ckpt_name}.csv\",\n",
    "    index=False,\n",
    ")\n",
    "\n",
    "# df_vanilla = pd.DataFrame(dist_vanilla, columns=[\"Generated Numbers\"])\n",
    "# df_vanilla.to_csv(\n",
    "#     f\"plots/Vanilla_nb-numbers_{number_of_numbers_vanilla}_nb-NaNs_{number_of_NaNs_vanilla}_{ckpt_name}.csv\",\n",
    "#     index=False,\n",
    "# )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[]"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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SxEDlRyyIyKi5iHgqnOeN/Q+MTz5GDM434mIiJoXpUIhTVVheCLZzJwsTkREzVCgFy1XwPDkY0wMT0RE1AzpvOiKO4YnH+PseeICmURE1Jx401pPDE8+5sqwHRfIJCKi5sOblitgePIxvNqOiIiaI+d5j+GJZOOEcSIiao44bEce45wnIiJqjgI5bEee4tV2RETUHOmcSxXYuFQByWATRS6SSUREzRJ7nsgjFZYraZsTxomIqDnhnCfySKlgBgCoFQqolfzVERFR86G76mo7sYm/HJhnYB9SKggA2OtERETNj7PnSQRQbhGatC4MTz7E4Oh54nwnIiJqbtRKJdQKBQCgxGxu0rowPPkQ57BdIIfsiIioGXJ2HjA8Ua05h+0C2PNERETNkHO5glKzqUnrwfDkQ670PDE8ERFR8yP1PAnseaJakiaMs+eJiIiaIWfnQamvDtuNHj0a+/fvv+7+//3vfxg9erSnh6caGDjniYiImrErc558dNjum2++weXLl6+7v7i4GN9++62nh6calFq4VAERETVfOn8YtlM4LhmsyalTpxAcHCzreHv27METTzyBPn364LbbbsO9996LhQsXory83KXcV199haFDh6J79+4YNGgQtm7d6nYss9mM1157DSkpKUhMTMSTTz6J3Nxct3InT57Ek08+icTERKSkpGDx4sUwN3F34PWUcqkCIiJqxryl50ktp/Ann3yCTz75RLq9evVqbN682a1ceXk5jh49irS0NFmVKS0tRY8ePZCZmYnw8HAcP34cK1aswPHjx7FhwwYAwHfffYdJkybh0UcfxaxZs/C///0PL774IoKDg/HAAw9Ix5o/fz6ys7Mxc+ZMtGrVCm+//Tb+8Ic/YPv27QgNDQUAGAwGjBkzBjExMVixYgUuXryIRYsWobq6GnPnzpVV98bARTKJiKg5c/Y8NfWcJ1nhyWg0oqSkRLpdWVkJZQ3zb4KCgjBy5Eg8++yzsiozbNgwl9vJycnQarWYM2cOLl68iFatWmH16tXo0aMHXnnlFQBAnz59UFBQgOXLl0vh6cKFC/j444/x0ksv4dFHHwUAdO/eHf3798emTZswfvx4AMCmTZtQWVmJlStXIjw8HABgtVoxb948TJw4Ea1atZJV/4Z2peeJc56IiKj58ZZ1nmSFp8cffxyPP/44AGDAgAF48cUXce+99zZI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cY0nIiIiqpFXhad9+/YBABYtWuS2b9euXWjXrh2GDBkCo9GIdevWYe3atYiNjcXKlSvdeoqWLVuGhQsXYu7cubBYLEhNTcXs2bOhVl95yh06dEBWVhYWLVqECRMmICIiAlOmTMHYsWMb9okSERGRz/Kq8PTVV1/Vqtzw4cMxfPjwG5YJDQ3FggULsGDBghuW69WrFzZv3lzrOhIREVHz5lVznoiIiIi8HcMTERERkQwMT0REREQyMDwRERERycDwRERERCQDwxMRERGRDAxPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMjA8EREREcnA8EREREQkA8MTERERkQwMT0REREQyMDwRERERycDwRERERCQDwxMRERGRDAxPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMjA8EREREcnA8EREREQkA8MTERERkQwMT0REREQyMDwRERERycDwRERERCQDwxMRERGRDAxPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMjA8EREREcnA8EREREQkA8MTERERkQwMT0REREQyMDwRERERycDwRERERCQDwxMRERGRDAxPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMjA8EREREcnA8EREREQkA8MTERERkQwMT0REREQyMDwRERERycDwRERERCSDV4WnU6dOYe7cuRg2bBi6du2KIUOG1Fhuy5YtGDRoELp3746hQ4di9+7dbmXKy8sxa9Ys9O7dG0lJSZgyZQouXbrkVu6HH37AiBEj0KNHD/Tv3x9r166FKIr1/tyIiIjIP3hVeDp+/Dj27NmDDh06oGPHjjWW2b59O+bMmYP09HSsW7cOiYmJmDRpEn788UeXclOnTsW+ffvw8ssvY8mSJcjLy8P48eNhsVikMqdOncK4ceMQFRWFNWvWYMyYMVi+fDk2bNjQkE+TiIiIfJi6qStwtQEDBuC+++4DAMycORO//PKLW5nly5dj8ODBmDp1KgCgT58+OHbsGFatWoV169YBAA4ePIi9e/ciKysLqampAIDY2FhkZGRg586dyMjIAABkZWWhRYsWeOONN6DVatG3b18UFxfj7bffRmZmJrRabSM8ayIiIvIlXtXzpFTeuDoFBQXIz89Henq6y/aMjAzs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49ChQ5w7IoNer0dycnKN+7p164Zu3boBANu6ntx3333o3r07pkyZgmnTpiEgIABr166FVqvF448/DgB45plnMHr0aLz88stIT0/HgQMH8Pnnn2Pp0qVNXHvfMnLkSCxYsADz58/HgAEDUFpaKs3vu/oSer625TMajdizZw8AeyCtqKiQglLv3r0RERFRq3Z1rvw+a9YszJgxAwEBAVi6dCkSEhIwcOBAj+unEK/tyyKvc/LkSbz66qs4ePAggoODMWzYMEybNo2fWOpowIABOHv2bI37du3aJX0C37JlC9atW4dz584hNjYWzz33HPr379+YVfU7Bw4cwOjRo/Hxxx+je/fu0na2df0oLi7GwoULsXv3bgiCgDvuuAMvvPCCy5Derl27sGzZMuTl5aFt27aYMGECHn300Saste8RRRGbNm3Chx9+iIKCAgQHByMxMRHTpk1zWxWbr215zpw5g3vvvbfGfe+//770gaw27VpeXo6FCxfiX//6FywWC1JTUzF79uw6dUAwPBERERHJwDlPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMjA8EREREcnA8EREREQkA8MTEZFMAwYMwMyZM5u6GnUyYMAATJw4samrQeSTGJ6ImpGCggK88sorGDRoEHr27ImePXsiIyMD8+bNw2+//dbU1atXe/bswYoVK5q0DgkJCUhISMCGDRvc9v3jH/9AQkICfv755yaoGRHVBcMTUTOxe/duPPjgg/j000/Rt29fvPDCC3jxxReRlpaGPXv24KGHHrru19X4oj179mDlypVNXQ0AQFZWFoxGY1NXg4jqCb8YmKgZOH36NJ577jm0bdsW7777Llq2bOmyf/r06fj73/8OpdJ7P09VVVUhKCioqashW5cuXXDkyBFs2rQJTz75ZFNXp1FZLBbYbDZ+Dyf5He99pySierN+/XpUVVVh4cKFbsEJANRqNUaPHo02bdq4bD958iSmTJmC3r17o3v37njkkUewa9culzLO4afvv/8eCxcuRJ8+fZCYmIhnn30WxcXFbo+1Z88ePP7440hMTERSUhImTJiA48ePu5SZOXMmkpKScPr0aYwfPx5JSUmYPn06AOC7777DlClTcM899+C2225Dv379sGDBAlRXV7vc/4MPPgBwZegsISFB2m+z2fDuu+9i8ODB6N69O+66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+fn5eO211/DQQw9J2/ft2+dW9toeFaf27dtj//796NWrV40neidnT1p+fr5Lb01xcbFbj1dt9e7dG71798b69evxxz/+0W1/WFgYCgoK3LY7e8Hq26lTpyCKoktbOXsIb731VgD29qqqqqrz6yAoKAgZGRnIyMiA2WzG5MmT8fbbb2PixIkICAio07GJGhvnPBE1A0899RR0Oh1mzZqFy5cvu+2/tkciMjISvXv3xkcffYRLly65la9pCYKbufvuuxESEoI1a9bUeLVabY7p7FG5ur6iKOL99993K6vT6QBcGTZ0Sk9Ph9VqxVtvveV2H4vFIpW/6667oNFosHHjRpfHe++9925azxtxzn3avHmz277o6Gjk5ua6tMVvv/2GH374oU6PeT2XLl3Cv/71L+l2RUUF/vnPf6JLly5S72B6ejoOHjyI//73v273Lysrg8ViuenjlJSUuNzWarXo2LEjRFGUfeUikTdgzxNRMxATE4MlS5bg+eefxwMPPIAHH3wQnTt3hiiKOHPmDD7//HMolUqXOUYvvfQSHn/8cTz44IN47LHHEB0djcuXL+PHH3/EhQsX8Nlnn8mqQ0hICF5++WX85S9/wSOPPIKMjAxERETg3Llz2LNnD3r16oW5c+fe8BhxcXFo3749XnvtNVy8eBEhISH48ssv3QISAHTr1g2AfQmF1NRUqFQqDB48GL1798aIESOwZs0aHDlyBCkpKdBoNMjPz8eOHTvw4osv4oEHHkBERATGjh2LNWvWYOLEiejXrx8OHz6MnJwctGjRQtZzv5qz9+mbb75x2/foo4/i3Xffxbhx4/Doo4+iqKgImzZtQqdOnVBZWenxY15PTEwMXnzxRfz888+IjIzE1q1bUVRU5LKkwbhx4/DVV1/h6aefxsMPP4xu3brBaDTi2LFj+PLLL7Fr166bDnWOGzcOt9xyC3r16oXIyEjk5uZi48aN6Nevn9tcNyJfwPBE1Ezcd9992LZtGzZs2IB9+/Zh69atUCgUaNu2Lfr164dRo0ahc+fOUvlOnTph69atWLlyJT755BOUlpYiIiICXbt2xbPPPutRHR588EG0bNkSa9euRVZWFsxmM1q1aoU77rgDjzzyyE3vr9Fo8Pbbb2P+/PlYs2YNAgICcP/99+P3v/89hg0b5lJ24MCByMzMxPbt2/HZZ59BFEUMHjwYgH2i/G233YZNmzZh6dKlUKlUuPXWWzF06FD06tVLOsbUqVOh1WqxadMmHDhwAD169MCGDRvq/IW6kyZNwujRo922d+zYEa+99hqWL1+OhQsXolOnTli8eDE+//zzGsNWXcXExGDOnDlYvHgx8vLy0K5dOyxdutRlnptOp8Pf/vY3rFmzBjt27MA///lPhISEICYmBpMnT3a52u96RowYgW3btuGdd95BVVUVWrdujczMzBqHLol8gUL0ZAYhERERUTPFOU9EREREMjA8EREREcnA8EREREQkA8MTERERkQwMT0REREQyMDwRERERycDwRERERCQDwxMRERGRDAxPRERERDIwPBERERHJwPBEREREJAPDExEREZEMDE9EREREMvx/9IGf/d1cl/IAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Count the values with Counter\n",
    "from collections import Counter\n",
    "\n",
    "df_inference = pd.read_csv(\"dist_inference.csv\")\n",
    "\n",
    "Counter(df_inference[\"Generated Numbers\"].to_list())\n",
    "\n",
    "# Plot\n",
    "sns.set_theme(style=\"whitegrid\")\n",
    "plot = sns.histplot(\n",
    "    df_inference[\"Generated Numbers\"],\n",
    "    kde=True,\n",
    "    color=\"lightseagreen\",\n",
    "    linewidth=0,\n",
    "    bins=n_max,\n",
    ")\n",
    "\n",
    "plt.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: title={'center': 'Distribution of generated numbers between 0 and 100 (512000 samples)'}, xlabel='Number', ylabel='Count'>"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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P/nkE22LAmTcJUyfPp3vvvuOzz//nAYNGvDtt99m609VkLIZGBiwfPlyli5dyp49e7RzQn344Yf5uujkl6mpKRs2bGDRokXs3LmThIQEatSowfz58ws0yjyrL774gvLly/Prr79y8OBBWrduzZIlS+jWrZtOH5Xy5cuzfft2li1bxsGDB9m8eTO2trbUrl1bO+9WQbVs2ZKtW7fyzTffsHHjRhITE7G3t9dOUJ0fixcvZu7cuWzatAlFUfD09GTVqlXZ7ubd3Nx4//332bJlC3/88QcajYbDhw9jbm7O2LFjqV69OuvWrWPZsmVAxsXU09NTZ5LtAQMGoFarWbNmDQsXLsTZ2Vk7515RKlu2LH5+fixYsID//e9/VKlShSlTpnD//v1iCRptbGxYsGAB8+bNY9u2bZQvX55Zs2bp3HAZGBiwbNky1q1bx65duzh48CBmZmZUqVKFoUOH5utR65tvvsm2bdvYtGkTcXFx2Nvb4+XlxaRJk/I1QK53794YGBjg7+9PZGQkbm5u/N///Z9Ov7PatWvz448/4ufnx86dO4mJicHOzo569eoxYcIE7Xb29vbMmTOHFStW8NFHH6FWq1m/fr02aGzatCm//vqr9iYXMh5HNm7cmBMnTugsL2j95Pd8e1n169fnu+++Y9GiRcyfPx8LCwv69eun9y0nkDH7QeY8ecePH6d27dr873//Y9++fQW+QczUrl07vv76a7766isWL16Mk5MT8+fP5/Dhw/nK8+HDh9m+a5l/t2jRQhs0QsZE3sbGxqxdu5bffvuNSpUqMWPGjGwDGCwtLdmwYQOff/45y5cvR6PR0LJlS2bMmJHn/LaZXnvtNcqWLcvevXsZP368drmXlxdHjx4lICCA5ORk7O3tefvtt5k4caJ2TtFMp06dws/PL8fjmjhxojZozHzy8Pvvv/P7779nK8uLQWOlSpXYuHEjCxYsYPHixRgbG9O+fXumT5+ere/htGnTsLGxYevWrezYsYPq1avzv//9L9uNUUHyzCo/3/1x48aRlJTEzz//zJ49e6hXrx4rVqxg8eLFeeZdWM2bN6dx48YsW7aMsLAwateuzfz58/U+an/jjTeoUKECK1euZM2aNaSmpuLg4ECzZs20v8UVK1akR48enDx5kt27d2NoaEjNmjX56quv6Nq1qzYvjUbD/v376devX4G7/aiU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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def clean_data(df_inference):\n",
    "    # Performed 1 aggregation grouped on column: 'Generated Numbers'\n",
    "    df_inference = (\n",
    "        df_inference.groupby([\"Generated Numbers\"])\n",
    "        .agg(Generated_numbers_count=(\"Generated Numbers\", \"count\"))\n",
    "        .reset_index()\n",
    "    )\n",
    "\n",
    "    # Normalize Generated_numbers_count into Generated_numbers_count_normalized\n",
    "    df_inference[\"Generated_numbers_count_normalized\"] = (\n",
    "        df_inference[\"Generated_numbers_count\"]\n",
    "        / df_inference[\"Generated_numbers_count\"].sum()\n",
    "    )\n",
    "\n",
    "    return df_inference\n",
    "\n",
    "\n",
    "df_inference_clean = clean_data(df_inference.copy())\n",
    "\n",
    "df_inference_clean.plot(\n",
    "    x=\"Generated Numbers\",\n",
    "    y=\"Generated_numbers_count_normalized\",\n",
    "    kind=\"line\",\n",
    "    title=f\"Distribution of generated numbers between 0 and {n_max} ({len(dist_inference)} samples)\",\n",
    "    xlabel=\"Number\",\n",
    "    ylabel=\"Count\",\n",
    "    xlim=(-11, 101),\n",
    "    ylim=(0, 0.012),\n",
    ")"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python (myenv)",
   "language": "python",
   "name": "myenv"
  },
  "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
