{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "aed3958d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[nltk_data] Downloading package cmudict to /home/XXXXXX/nltk_data...\n",
      "[nltk_data]   Package cmudict is already up-to-date!\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import pickle\n",
    "sys.path.append(\"..\")\n",
    "from torch.nn.utils.rnn import pad_sequence\n",
    "from torch.utils.data import DataLoader\n",
    "import torch\n",
    "from dataset import SpeechSentenceDataset, idsToPhonemes, getDatasetLoaders,getDatasetLoaders_V3, PHONE_DEF, PHONE_DEF_SIL\n",
    "import re \n",
    "from g2p_en import G2p\n",
    "import numpy as np\n",
    "from model.ctc_modelling import LightningGRUDecoder, LightningGRUDecoder_MFCC_v3\n",
    "from model.hybrid_modelling import HybridCausalLMOutput, HybridGRUDecoder\n",
    "import time\n",
    "import numpy as np\n",
    "from edit_distance import SequenceMatcher\n",
    "import tqdm\n",
    "import pytorch_lightning as pl\n",
    "import jiwer\n",
    "import nltk\n",
    "from nltk.corpus import cmudict\n",
    "from pytorch_lightning.loggers import WandbLogger\n",
    "import wandb\n",
    "from pytorch_lightning.callbacks import ModelCheckpoint, EarlyStopping\n",
    "import copy\n",
    "from difflib import get_close_matches\n",
    "from transformers import GPT2LMHeadModel, GPT2Config, GPT2Tokenizer\n",
    "import pandas as pd\n",
    "from torchaudio.models.decoder import ctc_decoder\n",
    "import string\n",
    "from config import DATASET_SM_ROBUST, DATASET_SM_ZSCORE, DATASET_FULL_TRIALS_ZSCORE\n",
    "# from model.ctc_modelling import Light\n",
    "import os\n",
    "# Download CMU Pronouncing Dictionary (First-time use)\n",
    "nltk.download(\"cmudict\")\n",
    "\n",
    "# Load CMUdict\n",
    "cmu_dict = cmudict.dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "59283f62",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of trials:  10020\n",
      "Number of days:  24\n",
      "Number of trials after filtering by indices:  8800\n",
      "Number of trials:  880\n",
      "Number of days:  24\n",
      "Number of trials after filtering by indices:  880\n"
     ]
    }
   ],
   "source": [
    "train_loader, test_loader,_, loadedData = getDatasetLoaders_V3(DATASET_FULL_TRIALS_ZSCORE, 64, include_prego=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "73c0335c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Resetting neural_dim based on channels\n",
      "neural_dim 256 256\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/torch/functional.py:534: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at ../aten/src/ATen/native/TensorShape.cpp:3595.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n",
      "/tmp/ipykernel_2099789/964019249.py:36: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  neural_encoder.load_state_dict(torch.load(neural_encoder_model_weights_path)[\"state_dict\"])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "nInputFeatures = 256 #channels \n",
    "nClasses = 40 \n",
    "dropout = 0.4 \n",
    "hidden_dim = 1024\n",
    "nlayers = 5\n",
    "stride_len = 4\n",
    "kernel_len =32\n",
    "gaussian_smooth_width = 2\n",
    "bidirectional = True\n",
    "\n",
    "white_noise_SD = 0.8\n",
    "constant_offset_SD = 0.2\n",
    "seq_len = 150\n",
    "max_time_series_len = 12000\n",
    "\n",
    "lr_start = 3e-4\n",
    "lr_end = 0.02\n",
    "l2_decay = 1e-5\n",
    "\n",
    "neural_encoder_model_weights_path = \"../.checkpoints/mfcc_sm_gru_ctc_LONGRUN/best_model.ckpt\"\n",
    "neural_encoder = LightningGRUDecoder_MFCC_v3(\n",
    "            neural_dim=nInputFeatures,\n",
    "            n_classes=nClasses,\n",
    "            hidden_dim=hidden_dim,\n",
    "            layer_dim=nlayers,\n",
    "            strideLen=stride_len,\n",
    "            kernelLen=kernel_len,\n",
    "            gaussianSmoothWidth=gaussian_smooth_width,\n",
    "            bidirectional=bidirectional,\n",
    "            dropout=dropout,\n",
    "            white_noise_SD=white_noise_SD,\n",
    "            constant_offset_SD=constant_offset_SD,\n",
    "            weight_decay=l2_decay,\n",
    "            learning_rate=lr_start)\n",
    "\n",
    "neural_encoder.load_state_dict(torch.load(neural_encoder_model_weights_path)[\"state_dict\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "245b2214",
   "metadata": {},
   "outputs": [],
   "source": [
    "output_name = \"gru_ctc_mfcc_bart\"\n",
    "\n",
    "results_dir = \"results/\" + output_name\n",
    "os.makedirs(results_dir, exist_ok=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "bd6d7100",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Encoder will be fine-tuned.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2099789/2855412439.py:26: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model.load_state_dict(torch.load(f\"{run_folder}/best_model_wer.ckpt\")[\"state_dict\"], strict=True)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "HPU available: False, using: 0 HPUs\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using LoRA with r=128, alpha=256, dropout=0.2 on target modules ['q_proj', 'k_proj', 'v_proj', 'out_proj'].\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33mXXXXXXXXXXXXXX\u001b[0m. Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: Using wandb-core as the SDK backend.  Please refer to https://wandb.me/wandb-core for more information.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "Tracking run with wandb version 0.19.4"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Run data is saved locally in <code>./wandb/run-20250602_140214-rdzzdhcs</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Syncing run <strong><a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset/runs/rdzzdhcs' target=\"_blank\">gru_ctc_mfcc_bart_FINETUNING</a></strong> to <a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset' target=\"_blank\">Weights & Biases</a> (<a href='https://wandb.me/developer-guide' target=\"_blank\">docs</a>)<br>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View project at <a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset' target=\"_blank\">https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run at <a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset/runs/rdzzdhcs' target=\"_blank\">https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset/runs/rdzzdhcs</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/callbacks/model_checkpoint.py:654: Checkpoint directory /data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING exists and is not empty.\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1,2]\n",
      "\n",
      "  | Name           | Type                        | Params | Mode \n",
      "-----------------------------------------------------------------------\n",
      "0 | encoder        | LightningGRUDecoder_MFCC_v3 | 133 M  | train\n",
      "1 | project        | Sequential                  | 1.6 M  | train\n",
      "2 | language_model | PeftModel                   | 153 M  | train\n",
      "-----------------------------------------------------------------------\n",
      "149 M     Trainable params\n",
      "139 M     Non-trainable params\n",
      "289 M     Total params\n",
      "1,156.455 Total estimated model params size (MB)\n",
      "735       Modules in train mode\n",
      "182       Modules in eval mode\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "03a8cb7a52e44c038b54c574bcc9594d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:425: The 'val_dataloader' does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` to `num_workers=63` in the `DataLoader` to improve performance.\n",
      "/data/XXXXXX/speech_decoding_BCI/optimization/../augmentations.py:91: UserWarning: Using padding='same' with even kernel lengths and odd dilation may require a zero-padded copy of the input be created (Triggered internally at ../aten/src/ATen/native/Convolution.cpp:1036.)\n",
      "  return self.conv(input, weight=self.weight, groups=self.groups, padding=\"same\")\n",
      "Asking to truncate to max_length but no maximum length is provided and the model has no predefined maximum length. Default to no truncation.\n",
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/transformers/generation/configuration_utils.py:677: UserWarning: `num_beams` is set to 1. However, `early_stopping` is set to `True` -- this flag is only used in beam-based generation modes. You should set `num_beams>1` or unset `early_stopping`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic approximated.', 'Rats projects several kinds-doughly-tough.', 'The rules we made in advance pollution.', \"Cury's householded backboards to be completely overwhelmed.\", 'The toothful figure provoked to come when greachaged first aid.', 'That second red perp was charged by dark eyed.', 'Boy, fireless faith was view every vividly.', 'Wider do children first.', \"The red means it won't boil away, nothing else.\", \"Would a blow further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/utilities/data.py:79: Trying to infer the `batch_size` from an ambiguous collection. The batch size we found is 64. To avoid any miscalculations, use `self.log(..., batch_size=batch_size)`.\n",
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:425: The 'train_dataloader' does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` to `num_workers=63` in the `DataLoader` to improve performance.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dddc5106fd02439eb007e2082a1f18b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Training: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/utilities/data.py:79: Trying to infer the `batch_size` from an ambiguous collection. The batch size we found is 32. To avoid any miscalculations, use `self.log(..., batch_size=batch_size)`.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ed7a792024f842b1820ebe35f98e2c52",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic predisquit.', 'Rake parenthood never sounded doughly.', 'The rules we made in advance pollution.', 'Curor cases needed black beds to be completely overwhelmed.', 'The tooth furrier provoked to come through three hundred square out.', 'That second week was charged with brown eyed and mustard.', 'Boy, fireless energy was view every item.', 'Wider de nineteen children was booked.', \"The white means it won't boil away, nothing else.\", \"Would a blow fier fished in a man's high day all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXXXXX/anaconda3/envs/evo/lib/python3.9/site-packages/pytorch_lightning/utilities/data.py:79: Trying to infer the `batch_size` from an ambiguous collection. The batch size we found is 48. To avoid any miscalculations, use `self.log(..., batch_size=batch_size)`.\n",
      "Metric val_loss improved. New best score: 1.140\n",
      "Epoch 0, global step 138: 'val_WER' reached 0.22821 (best 0.22821), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_wer.ckpt' as top 1\n",
      "Epoch 0, global step 138: 'val_CER' reached 0.15145 (best 0.15145), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_per.ckpt' as top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f176fc05074e47839f67c271b4183060",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscus retracted.', 'RakePats seldom soundless.', 'The rules we made in advance pollution.', \"Cler's household needs broken wounds to be completely equal.\", 'The tooth furrier caused to come with teeth first out.', 'That second week was charged with brown and brown powder.', 'Boy, fireless energy was view very often.', 'Welfare near certain has spoken.', \"The war means it won't boil away, nothing else.\", \"Would a blow further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.026 >= min_delta = 0.0. New best score: 1.114\n",
      "Epoch 1, global step 276: 'val_WER' was not in top 1\n",
      "Epoch 1, global step 276: 'val_CER' reached 0.15029 (best 0.15029), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_per.ckpt' as top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "311855dc99cd4ac389826ba0ab355489",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  [\"Chicago's retracted.\", 'Rake parenthood never sounds doughly.', 'The rules we made in advance pollution.', 'Carships needed broken wounds to be completely overwhelmed.', 'The tooth furrier caused to come through seamless face out.', 'That second week was charged by jar: superbly disciplined.', 'Brush fire destroys ourselves as you ever struggle.', 'Welfare near children has spoken.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's high rise make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.011 >= min_delta = 0.0. New best score: 1.103\n",
      "Epoch 2, global step 414: 'val_WER' was not in top 1\n",
      "Epoch 2, global step 414: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "af4684ce73ff43f58420a93f652eecc6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclastic recopped.', 'Rake parenthood several thousand-five.', 'The rules we made in advance pollution.', 'Curory householders need bivouged nightly problems to be completely overwhelmed.', 'The tooth furrier caused to come through three or four feet.', 'That second week was charged by jar: but parted eyed.', 'By far, spoiled unmaveringly under real family.', 'Welfare near children has spoken.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.011 >= min_delta = 0.0. New best score: 1.092\n",
      "Epoch 3, global step 552: 'val_WER' was not in top 1\n",
      "Epoch 3, global step 552: 'val_CER' reached 0.14939 (best 0.14939), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_per.ckpt' as top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7a4d2093c32342e69df2c1840a1e6b0b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  [\"Chicago's expected.\", 'Rake parenthood several thousand-and-.', 'The rules we made in advance pollution.', 'Orange sauce needed black lips to be completely overwhelmed.', 'The tooth furrier caused to come through three or four out.', 'That cantanned red per charge was charged by collie.', 'Beard tonight avoids invasion until you ever regretted.', 'Welfare near children has spoken.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's high day, make us all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4, global step 690: 'val_WER' was not in top 1\n",
      "Epoch 4, global step 690: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ade9f4d3e3724c9e891d4dcde8d610a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  [\"Chicago's retracted.\", 'Rake parenthood several thousand-five.', 'The rules we made in advance pollution.', 'Cory householders need bivoubed lives to be completely overwhelmed.', 'The tooth further caused to come through two or four yard out.', 'That second week was charged by coyrying to stirrier.', 'By car foolishly assail us with treasure.', 'Welfare new children for rock.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's high day, make him all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.007 >= min_delta = 0.0. New best score: 1.084\n",
      "Epoch 5, global step 828: 'val_WER' was not in top 1\n",
      "Epoch 5, global step 828: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1db1e0012be84ad088f3ee153b74672f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclist reminded.', 'Rake parenthood several thousand.', 'The rules we made in advance pollution.', 'Curory householded back-shepthes to be completely astounded.', \"The toothpaste coincided to come through his ragrier's face.\", 'That second jar was charged with brown or brown powder.', 'By car, soybean increases view with treasure.', 'Welfare near children who spoke.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.008 >= min_delta = 0.0. New best score: 1.076\n",
      "Epoch 6, global step 966: 'val_WER' was not in top 1\n",
      "Epoch 6, global step 966: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "68cf5bfba9b54e09a3186867ef55292e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclist reminded.', 'Raspy, heavy, dried-and-.', 'The rules we made in advance, pollution.', 'Curory householded deep-sheep lives to be completely overwhelmed.', 'The tooth further affected to come through washing first aid.', 'That second jar was charged with coins but parted-and-guard are glistened.', 'By car, soyless energy was very commonplace.', 'Welfare near children first.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high-hepthe all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.002 >= min_delta = 0.0. New best score: 1.075\n",
      "Epoch 7, global step 1104: 'val_WER' was not in top 1\n",
      "Epoch 7, global step 1104: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e86b45af56db4868a95541bfe39343f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic predisposability.', 'Raspy performance sounds glorified.', 'The rules we made in advance pollution.', 'Curory householders need bivouged both types to be completely overwhelmed.', 'The toothpaste color reminded to come through first fall out.', 'That second week was charged by collaged paper.', 'By car, soyless energy was very popular.', 'Welfare near children first.', \"The wood means it won't boil away, nothing else.\", \"Would a blow further in a man's high dose make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.006 >= min_delta = 0.0. New best score: 1.068\n",
      "Epoch 8, global step 1242: 'val_WER' was not in top 1\n",
      "Epoch 8, global step 1242: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6681db77761c4e598d59d3698f80919f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus overflows.', 'Raspy, heavy-feathered leaves.', 'The rules we made in advance, pollution.', 'Curory clay barrels need break-she be completely overwhelmed.', 'The toothpaste coincided to come through washing bowl.', 'That second jar was charged with brown and brown powder.', 'By car, lose pleasure to everyone ever merrily.', 'Warpeware near children first.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's high-hepthe all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.009 >= min_delta = 0.0. New best score: 1.060\n",
      "Epoch 9, global step 1380: 'val_WER' was not in top 1\n",
      "Epoch 9, global step 1380: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "474d2ec559cd4d309ff61187c7b338bc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclist reminded.', 'Rats parenthood never sounds commonplace.', 'The rules we made in advance pollution.', 'Cory household needs baked brown bags to be completely overwhelmed.', 'The toothpaste coincided to come through two miles full out.', 'That second jar was charged with coins but parted are glistening.', 'Base store closures coincided with view every family.', 'Warpeware near certain points.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high rise make easy?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10, global step 1518: 'val_WER' was not in top 1\n",
      "Epoch 10, global step 1518: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef328907cac94ba794f54008bd25aa74",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Corside approximated.', 'Rough projects several thousand-directional gifts.', 'The rules we made in advance pollution.', 'Cory cantalids need bluing lives to be completely overwhelmed.', 'The toothpaste coincided to come through doorless flame.', 'That second jar washes with coins by jar orator.', 'By car foolishly overwhelmed with everyone else.', 'Welfare near children who invest.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high dose make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.001 >= min_delta = 0.0. New best score: 1.059\n",
      "Epoch 11, global step 1656: 'val_WER' was not in top 1\n",
      "Epoch 11, global step 1656: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6a8e5d7c5563436fa1afec3388338efe",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus overflowed.', 'Rats pour several kinds liquid.', 'The rules we made in advance pollution.', 'Curory housekeepers need bivoubled lives to be completely astounded.', 'The toothpaste coincided to come through spring coat.', 'That second jar was charged with coins by jar or lid.', 'By car, soybean beans with you every family.', 'Welfare near kitchen has spoken.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high rise all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12, global step 1794: 'val_WER' was not in top 1\n",
      "Epoch 12, global step 1794: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f863ded743724e66a4f888cd32d9cf99",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclay overflowed.', 'Rough projects several hundred-five.', 'The rules we made in advance pollution.', 'Curory housekeepers need black lives to be completely overwhelmed.', 'The toothpaste coincided to come through seam-paste.', 'That second week was charged with coins but parted are sold.', 'By car foolishly overwhelmed with you every family.', 'Welfare near children who broke.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13, global step 1932: 'val_WER' was not in top 1\n",
      "Epoch 13, global step 1932: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "43b5fb8d27254a48991be264a5d30933",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rough choices several thousand-cents.', 'The rules we made in advance pollution.', 'Curory householders need bivouged lives to be completely astounded.', 'The toothpaste coincided to come through door full out.', 'That second one was charged with coins but parted sea-like disposition.', 'By car, soybean oil with you every family.', 'Welfare near children who broke.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high dose make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.005 >= min_delta = 0.0. New best score: 1.053\n",
      "Epoch 14, global step 2070: 'val_WER' was not in top 1\n",
      "Epoch 14, global step 2070: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1f5e9b48657247969e96c2dfec671fe1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rough parenthood ever sounds commonplace.', 'The rules we made in advance collision.', 'Curory housekeepers need bivoubled lives to be completely equal.', 'The toothpaste coincided to come through washing oil.', 'That second jar was charged with coins but parted sea mustard.', 'Brush fire thermometer activity was very often loved.', 'Welfare near kitchen of rock.', \"The word means it won't boil away, nothing else.\", \"Would a boil further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15, global step 2208: 'val_WER' was not in top 1\n",
      "Epoch 15, global step 2208: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4c7e1e0668bb4d7aaa4e4413a1c35222",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus expected.', 'Rats pour several kinds liquid-and-.', 'The rules we made in advance collision.', 'Curory housekeepers need bivoubled lives to be completely astounded.', 'The toothpaste caused to come through seam-paste.', 'That second jar washes with brown and brown powder.', 'Base sauce thermometer overflows view every family.', 'Welfare near children who spoke.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high dose make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16, global step 2346: 'val_WER' was not in top 1\n",
      "Epoch 16, global step 2346: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ca5450fc4fa0417d88a0d617d986a310",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclosures required.', 'Rats pour several kinds liquid-cough gifts.', 'The rules we made in advance pollution.', 'Curory housekeepers need bivouged bleachers to be completely astounded.', 'The toothful ferry caused to come through two miles out.', 'That second jarred wire was charged by jar: moistening and mustard.', 'Beware soybeanizers overthrow every family.', 'Welfare near children who spoke.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's high rise make all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17, global step 2484: 'val_WER' was not in top 1\n",
      "Epoch 17, global step 2484: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef4c17e438e44390922ee3b7651c9538",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rats pour several kinds liquid gifts.', 'The rules we made in advance conclusion.', 'Cory cantalouls need breakbacks to be completely equal.', 'The toothpaste coincided to come through various flower out.', 'That second jar was charged with brown and brown powder.', 'Boy, car destroys ourselves with fewer results.', 'Welfare near kitchen has broken.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's head make him all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18, global step 2622: 'val_WER' was not in top 1\n",
      "Epoch 18, global step 2622: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6d7143ace51c4631a072be67b7d03289",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rise parenthood ever sounds glorified.', 'The rules we made in advance pollution.', \"Cler's household needs blistered lives to be completely equal.\", 'The toothpaste coincided to come through washing cloth.', 'That second one was charged with coins but parted sea-like disposition.', 'Beware soybeanizers overthrow you every family.', 'Welfare near children who broke.', \"The word means it won't bull away, nothing else.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19, global step 2760: 'val_WER' was not in top 1\n",
      "Epoch 19, global step 2760: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "81baf56bd2b04b9e837683c43b267b7e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclay overflimated.', 'Rise parenthood ever sounds crooked.', 'The rules we made in advance pollution.', \"Curses' household needs bivouged lives to be completely overwhelmed.\", 'The toothpaste caused to come through various flower out.', 'That second jar was charged with coins because boy prefers.', 'Beware soypaste from below every family.', 'Welfare near children has crashed.', \"The word means it won't boil away easily swatches.\", \"Would a blow further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20, global step 2898: 'val_WER' was not in top 1\n",
      "Epoch 20, global step 2898: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "62515a08f36a4a268e9f8af512cbd0be",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rise parenthood ever fails.', 'The rules we made in advance collision.', 'Curory cantalugs need blivoubled lives to be completely overwhelmed.', 'The toothpaste coincided to come through washing cloth.', 'That second jar was charged with coins but parted sea mustard.', 'Beware soybean oil with you every family.', 'Welfare near children has spoken.', \"The word means it won't full away, nothing else.\", \"Would a blow further in a man's high flame make all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21, global step 3036: 'val_WER' was not in top 1\n",
      "Epoch 21, global step 3036: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "63b8d20bbda44a7687e5f4bfb1cecb8e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclay overflowed.', 'Rake parenthood ever sounds glorified.', 'The rules we made in advance collision.', \"Cler's household needed black lives to be completely equal.\", 'The toothful figure provoked to come through two miles out.', 'That second jarred star was charged by jar: the glistening edge.', 'Beware soybean oil with you ever familiar.', 'Welfare near children who invest.', \"The word means it won't boil away, nothing else.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22, global step 3174: 'val_WER' was not in top 1\n",
      "Epoch 22, global step 3174: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "100ae5ffd8164e8ab8bb327e830e17f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus overflows.', 'Rats pour several kinds liberos.', 'The rules we made in advance collision.', 'Curory housekeepers need blivy lives to be completely equal.', 'The toothpaste caused to come through washing fangs out.', 'That second jar was charged with coins but parted sea mustard.', 'Beware soybean overflows with you every family.', 'Welfare near children have crashed.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23, global step 3312: 'val_WER' was not in top 1\n",
      "Epoch 23, global step 3312: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1e6e9fe8bcb741869597d8a34bf1fdf8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus overflowed.', 'Rake parenthood never sounds unbeatable.', 'The rules we made in advance collision.', 'Curory housekeepers need bivouged lives to be completely overwhelmed.', 'The toothpaste caused to come to washing dry out.', 'That second one was charged by pouring by pouring tranquilizers.', 'Beware soybean oil was very ever familiar.', 'Welfare near children who invest.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.001 >= min_delta = 0.0. New best score: 1.052\n",
      "Epoch 24, global step 3450: 'val_WER' was not in top 1\n",
      "Epoch 24, global step 3450: 'val_CER' reached 0.14938 (best 0.14938), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_per.ckpt' as top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b2444a0d8fe418a93ff1a2abc037a03",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Dride reminded.', 'Rats pour several kinds liquid.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivoise blouses to be completely equal.', 'The toothpaste caused to come through door first out.', 'That second jarred star was caused by gassing.', 'Boy, sir, ignores you for every family.', 'Welfare new kitchen has crashed.', \"The white means it won't boil away, nothing else.\", \"Would a blow further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25, global step 3588: 'val_WER' was not in top 1\n",
      "Epoch 25, global step 3588: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3943c2b6aabd4d01b4dcebbb2bc640a3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rise parenthood ever sounds unbeatably.', 'The rules we made in advance collision.', 'Cory cantaloubs need bivoubled lives to be completely equal.', 'The toothful figure provoked to come through various high-takes.', 'That second dive was charged by jar-and-guard.', 'Beware soybean oil was very many sailors.', 'Welfare near certain points of rock.', \"The word means it won't boil away easily swelicing death.\", \"Would a blow further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26, global step 3726: 'val_WER' was not in top 1\n",
      "Epoch 26, global step 3726: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a4e42546d9134543b8a595a6d8552535",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rise parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Curory householders need blivoubed lives to be completely equal.', 'The toothpaste caused to come through teeth full out.', 'That second jar was charged by jar: the glistening point.', 'Be sure soybean oil was very often.', 'Welfare new kitchen has broke.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27, global step 3864: 'val_WER' was not in top 1\n",
      "Epoch 27, global step 3864: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b9ad88363fff46ceac30125c052e96ba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rise parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Curory householders need bivouged lives to be completely equal.', 'The toothful vocabulary provoked to come from various high-takes.', 'That second jarred star was charged by jar-guard.', 'Boy, soybean, unmaveria was very often loved.', 'Welfare near certain points of view.', \"The word means it won't boil away easily swelting health.\", \"Would a blow further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28, global step 4002: 'val_WER' was not in top 1\n",
      "Epoch 28, global step 4002: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dfec0a615dec4f10b8d69d2c457b6921",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclimated erosion.', 'Roughpoint performance sounds glorified.', 'The rules we made in advance collision.', 'Cury cantaloped needle beds to be completely astounded.', 'The toothful vocabulary coincided to come through teeth full out.', 'That second jarred star was caused by jar-and-guard decision.', 'Beware soybean oil with you every family.', 'Welfare near children who spoke.', \"The word means it won't boil away easily swishing health.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29, global step 4140: 'val_WER' was not in top 1\n",
      "Epoch 29, global step 4140: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cd9f526147314893b2c56424a506be66",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rise parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Curory cantalouged deep lives to be completely equal.', 'The toothful vocabulary provoked to come through teeth full out.', 'That second jarred star was charged by jar-and-guard.', 'Boy, fireless anarchy was ever available.', 'Welfare near certain of folks.', \"The word means it won't boil away easily swelting health.\", \"Would a boil further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30, global step 4278: 'val_WER' reached 0.22813 (best 0.22813), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_wer.ckpt' as top 1\n",
      "Epoch 30, global step 4278: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c34a92099610497990f13e55eddb19b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic directors.', 'Rise parenthood ever sounded left.', 'The rules we made in advance collision.', 'Currying household needs blivened lives to be completely equal.', 'The toothful vocabulary provoked to come through seam-t.', 'That second jarred far was caused by jarburst.', 'Beware soybeanization was very ever familiar.', 'Welfare near certain of folks.', \"The word means it won't boil away easily swelting health.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31, global step 4416: 'val_WER' was not in top 1\n",
      "Epoch 31, global step 4416: 'val_CER' reached 0.14846 (best 0.14846), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_per.ckpt' as top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "36c8ce6776ba42029cc6b8b32aecd58a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats parenthood ever sounds left.', 'The rules we made in advance collision.', 'Currying household wounds to be completely overwhelmed.', 'The toothful vocabulary provoked to come through various high-tough aid.', 'That second jarred wire was caused by giddly zealous disposition.', 'Beware soybean oil was very ever familiar.', 'Welfare near children have spoken.', \"The word means it won't boil away easily swelting health.\", \"Would a boil further in a man's heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32, global step 4554: 'val_WER' was not in top 1\n",
      "Epoch 32, global step 4554: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "598611e7642840e88ffa80ecb565b892",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus expected.', 'Rise parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curory cantaloped slopes need be completely overwhelmed.', 'The toothpaste caused to come through various flower out.', 'That second jar was charged by jar: boy-like disposition.', 'Beware soybean oil was very ever familiar.', 'Welfare new children have spoken.', \"The word means it won't boil away easily swelting health.\", \"Would a blow further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33, global step 4692: 'val_WER' was not in top 1\n",
      "Epoch 33, global step 4692: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cbc454cd9f734fc796ed2c5401281ae3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic overflows.', 'Rats pour several kinds liquid.', 'The rules we made in advance collision.', 'Curory cantaloped slopes need be completely equal.', 'The toothpaste caused to come through seam-hundred pound out.', 'That second jar was charged by jar: but givinids depend on decision.', 'Beware soybean oil was very ever familiar.', 'Welfare new children have spoken.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34, global step 4830: 'val_WER' reached 0.22812 (best 0.22812), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_wer.ckpt' as top 1\n",
      "Epoch 34, global step 4830: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c041e163a4284342ad439b980e0b4c21",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus expected.', 'Rats pour several kinds of gifts.', 'The rules we made in advance collision.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through out.', 'That second one was charged by collids.', 'Boy, sir, ignores view was ever available.', 'Welfare new children have spoken.', \"The word means it won't boil away easily swelting health.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35, global step 4968: 'val_WER' was not in top 1\n",
      "Epoch 35, global step 4968: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f1bf12aa9fca4b4b94d90b4753977cab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rough points several thousand-cents.', 'The rules we made in advance collision.', 'Curory housekeepers need bivouged lives to be completely equal.', 'The toothpaste caused to come through various flower out.', 'That second jar was charged with coins per jar.', 'Beware soybean oil with every family family.', 'Welfare near certain aspects of public.', \"The word means it won't boil away, using nothing else.\", \"Would a boil further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36, global step 5106: 'val_WER' was not in top 1\n",
      "Epoch 36, global step 5106: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fe15e6a253d24a1bac4a2fa9dc830547",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscus expected.', 'Rise parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curory housewives need blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through out.', 'That second jar was charged by collids, boy-sesame steamed and distorted.', 'Beware soybean overflowed with you every family.', 'Welfare new kitchen has failed.', \"The wood means it won't boil away, using nothing else.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37, global step 5244: 'val_WER' was not in top 1\n",
      "Epoch 37, global step 5244: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "775f7f6e2c5345dd875846b968a7549e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rise parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Curory householders need blivled lives to be completely equal.', 'The toothful vocabulary provoked to come through various high aid.', 'That second jar was charged with coins by jar-and-sheiling decision.', 'Boy, far away from every family family.', 'Welfare near certain of folks.', \"The word means it won't boil away easily swelicing health.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38, global step 5382: 'val_WER' was not in top 1\n",
      "Epoch 38, global step 5382: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ff1c47aeb554baa9de08a271b851e25",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rake parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curory housekeepers need bathes to be completely overwhelmed.', 'The toothless furrier caused to come through teeth full out.', 'That second one was charged with kids with brown paper.', 'Beware soybean oil was view very often.', 'Welfare near certain of folks.', \"The word means it won't boil away, nothing else.\", \"Would a blow further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39, global step 5520: 'val_WER' was not in top 1\n",
      "Epoch 39, global step 5520: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "604a830dd0c845a39bc17d5f25c5a994",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rake parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Woody cantime needs baked brown lives to be completely equal.', 'The toothpaste caused to come through teeth through force.', 'That second jar was charged with coins by collated paper.', 'Be sure soybean ate very many every family.', 'Welfare new kitchen has bogged.', \"The wood means it won't boil away, nothing else.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40, global step 5658: 'val_WER' was not in top 1\n",
      "Epoch 40, global step 5658: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "25e3da33bc9944acbec6c085bbf61924",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Roughpoint purchase sounded unbeatably.', 'The rules we made in advance collusion.', 'Curory cantimely breaks down to be completely overwhelmed.', 'The toothpaste caused to come through teeth first.', 'That second jar was charged by jar: the glistened table.', 'Boy, soybean oil was very every family.', 'Welfare new kitchen has spoken of rock.', \"The wood means it won't boil away, nothing else.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41, global step 5796: 'val_WER' was not in top 1\n",
      "Epoch 41, global step 5796: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9192fffffeab4f35a3f24cd007d6fd1e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclus expected.', 'Rough projects several thousand-direction.', 'The rules we made in advance pollution.', 'Curory household needs baked brown lives to be completely equal.', 'The toothpaste caused to come through various flower out.', 'That second jar was charged by jar: the gassing lid.', 'Boy, sir, ignores you every family.', 'Welfare near certain aspects of rock.', \"The word means it won't boil away, searings only.\", \"Would a blow further in a man's hate make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42, global step 5934: 'val_WER' was not in top 1\n",
      "Epoch 42, global step 5934: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bbda78dc98024e8797a14e2ef27dabbe",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Roughpoint performance sounds deceit.', 'The rules we made in advance collision.', 'Curory cantaloped wounds to be completely overwhelmed.', 'The toothpaste caused to come through various flower out.', 'That second jar was charged by jar: the glistened table.', 'Beware soybean oil was very ever familiar.', 'Welfare near nineteen of public.', \"The word means it won't boil away easily snapping health.\", \"Would a boil further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43, global step 6072: 'val_WER' was not in top 1\n",
      "Epoch 43, global step 6072: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "70337096b3b44652ba19e4ae92a684b5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rake parenthood ever sounds deceit.', 'The rules we made in advance collision.', 'Curory household needs baked cloths to be completely overwhelmed.', 'The toothpaste caused to come through teeth through force.', 'That second jar was charged by jar: the glistened table.', 'Beware soybean oil was very ever familiar.', 'Welfare near certain aspects of public.', \"The wood means it won't boil away easily swelting health.\", \"Would a boil further in a man's body make him whole day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44, global step 6210: 'val_WER' was not in top 1\n",
      "Epoch 44, global step 6210: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f3c01a04ee14ac78a38e5b72ac78032",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Roughpoint performance sounds deceit.', 'The rules we made in advance collision.', 'Always calm needs baked brown lives to be completely equal.', 'The toothpaste caused to come through teeth first out.', 'That second jar was charged by jar: the glistened table.', 'Beware soybean oil with you every family.', 'Welfare near certain of folks.', \"The wood means it won't boil away easily swelying excess.\", \"Would a blow further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45, global step 6348: 'val_WER' reached 0.22740 (best 0.22740), saving model to '/data/XXXXXX/speech_decoding_BCI/optimization/.checkpoints/gru_ctc_mfcc_bart/floral-sweep-5_FINETUNING/best_model_wer.ckpt' as top 1\n",
      "Epoch 45, global step 6348: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52fbd71b53ba4a40b0d35e8f673ec34b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedic overfl.', 'Rise peaches every thousand-cents.', 'The rules we made in advance collision.', 'Curory household needs blivled lives to be completely equal.', 'The toothpaste caused to come through various flower out.', 'That second week was charged by pouring by spoiled orator.', 'Beware soybeanizers with you every family.', 'Welfare near certain of folks.', \"The word means it won't boil away easily swelicing excess.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46, global step 6486: 'val_WER' was not in top 1\n",
      "Epoch 46, global step 6486: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "107b92c184214813abcdb59a895b63f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedic overfl.', 'Rake parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curory cantaloped wounds to be completely overwhelmed.', 'The toothpaste caused to come through seam through force.', 'That second jar was charged by jar: the dried table.', 'Beware soybean oil was full every family.', 'Welfare near sixteen pages of rock.', \"The word means it won't boil away easily swelting excess.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47, global step 6624: 'val_WER' was not in top 1\n",
      "Epoch 47, global step 6624: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4b4861d1ae3144b8bb06cc254d190311",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cocence resulted.', 'Rats perversion every sounds left.', 'The rules we made in advance collusion.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through seam through his face out.', 'That second one fell with kids by collids per version.', 'Beware soybeanizers with you every family.', 'Welfare near certain of rock.', \"The word means it won't boil away, nothing else.\", \"Would a boil further in a man's maids' milk, make sure he all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Metric val_loss improved by 0.000 >= min_delta = 0.0. New best score: 1.052\n",
      "Epoch 48, global step 6762: 'val_WER' was not in top 1\n",
      "Epoch 48, global step 6762: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d0bef91a3ed3420e85ff3e527610d321",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedified.', 'Rats perversion scene.', 'The rules we mean in advance pollution.', 'Curory housekeepers need blivoubed lives to be completely equal.', 'The toothpaste caused to come through teeth through force out.', 'That second one was charged by spoiled teeproids.', 'Beware soybean meals with you every family.', 'Welfare near certain of rock.', \"The word means it won't boil away easily swelying excess.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49, global step 6900: 'val_WER' was not in top 1\n",
      "Epoch 49, global step 6900: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "60e6c2db718d46be8327133985df7e7f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscus expected.', 'Rats perversion sounds deceit.', 'The rules we made in advance collision.', 'Curory housekeepers need blivled lives to be completely astounded.', 'The toothpaste caused to come through various flower out.', 'That second jarred fire was caused by jarburst.', 'Beware soybean ate very many every family.', 'Welfare near certain of folks.', \"The wood means it won't boil away easily swelting excess.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50, global step 7038: 'val_WER' was not in top 1\n",
      "Epoch 50, global step 7038: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "de287157788e44fd86ad0215ac7bb559",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclopedically.', 'Rise parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through hot water.', 'That second jar was charged by jar: the dried table.', 'Boy, soybeanizers will view every family.', 'Welfare near certain of rock.', \"The word means it won't boil away easily swelting excess.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 51, global step 7176: 'val_WER' was not in top 1\n",
      "Epoch 51, global step 7176: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b90dff87e51409db255d29e906fb825",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rough parenthood sounds useless.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through various flower out.', 'That second one was charged by pouring by dried paper.', 'Beware soybean ate every thoubrift.', 'Welfare near certain aspects of public.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 52, global step 7314: 'val_WER' was not in top 1\n",
      "Epoch 52, global step 7314: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "808cd5e224ad45a6bffe6e998e661481",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats parenthood ever sounds left.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivoubed lives to be completely astounded.', 'The toothpaste caused to come through those flower out.', 'That second week was charged by jar: the dried table.', 'Beware soybean oil was very ever familiar.', 'Welfare near certain of folks.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 53, global step 7452: 'val_WER' was not in top 1\n",
      "Epoch 53, global step 7452: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fa87972979f047d9a2b4e07e42dccc69",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Ratspockets never soundless.', 'The rules we made in advance collision.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through fast out.', 'That second jar was charged by jar: the dried table.', 'Beware soybean ate very many every family.', 'Welfare near certain aspects of rock.', \"The word means it won't full away, nothing else.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 54, global step 7590: 'val_WER' was not in top 1\n",
      "Epoch 54, global step 7590: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f87a4fbe60e42279d349bfae4806938",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Coconut overflimated.', 'Roughpoint every sounds left.', 'The rules we made in advance collision.', 'Curory housekeepers need blivoubled lives to be completely equal.', 'The toothpaste caused to come through teeth first.', 'That second jar was charged by jar-and-iron.', 'Beware soypaste was view every item.', 'Welfare near certain of folks.', 'The wood means it went full away, nothing else.', \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 55, global step 7728: 'val_WER' was not in top 1\n",
      "Epoch 55, global step 7728: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c5ca59c25d9640449d5887c5a66a889e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cyclosures.', 'Ratspockets never sound-biased.', 'The rules we made in advance closure.', 'Cury cantaloped wounds to be completely overwhelmed.', 'The toothpaste caused to come through teeth through out.', 'That second jar was charged by jar: praise and desolation.', 'Beware soypaste was view every item.', 'Welfare near certain of rock.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 56, global step 7866: 'val_WER' was not in top 1\n",
      "Epoch 56, global step 7866: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "07308770c84a4a379cbff5312545c419",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Hispanic directors.', 'Rats perversion ever sounded down.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivouls to be completely overwhelmed.', 'The toothpaste caused to come through teeth through force.', 'That second week was charged by jar: the dried table.', 'Beware soypaste from view was ever available.', 'Welfare near certain of folks.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 57, global step 8004: 'val_WER' was not in top 1\n",
      "Epoch 57, global step 8004: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ee18474155bf4a1aa568785c6630db6a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats purchase several kinds of strength.', 'The rules we made in advance closure.', 'Curory sauce cannot break blugs to be completely overwhelmed.', 'The toothpaste caused to come through teeth through fast out.', 'That second jarred far as coins perids were dried by dried paper.', 'Beware soy sauce!', 'Welfare near certain aspects of rock.', \"The word means it won't boil away easily swelting excess.\", \"Would a boil further in a man's high heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 58, global step 8142: 'val_WER' was not in top 1\n",
      "Epoch 58, global step 8142: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ea44943d8f7444a69a9ba7548398a129",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycloped.', 'Rats purchase several kinds of gifts.', 'The rules we made in advance conclusion.', 'Curory housekeepers need bivoubed lives to be completely astounded.', 'The toothpaste table brought to come through teeth foul.', 'That second jar was charged by jar: pour mustard and mustard.', 'Beware soybean ate very many every family.', 'Welfare near children who spoke.', \"The wood means it won't boil away, usually swelting excess.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 59, global step 8280: 'val_WER' was not in top 1\n",
      "Epoch 59, global step 8280: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0604b78498e5424884e0bd50ca552581",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Ratspockets never sound-feathered.', 'The rules we made in advance collision.', 'Curory housekeepers need bivoubed lives to be completely equal.', 'The tooth-five table went to Jamaica, chew out.', 'That second week was charged by jar: the parted table.', 'Beware soypaste was view every item.', 'Welfare near sixteen half of rock.', \"The word means it won't boil away easily swelting excess.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 60, global step 8418: 'val_WER' was not in top 1\n",
      "Epoch 60, global step 8418: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2037e4920dad4addbaf46bcb59a184f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats parenthood ever sounds useless.', 'The rules we made in advance collision.', 'Curory housekeepers need bivoubed lives to be completely equal.', 'The tooth- furrier caused to come through teeth full out.', 'That second week was charged by pouring by spoiled paper.', 'Base floorless vocabulary was very ever familiar.', 'Welfare near kitchen has bogged.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 61, global step 8556: 'val_WER' was not in top 1\n",
      "Epoch 61, global step 8556: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "117e79a7d39a40df86b73cb2f0054f0a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', \"Rats perp's heavy-trophic strength.\", 'The rules we made in advance conclusion.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste prevented to come through teeth full out.', 'That second jar was charged by jar: reinforce a lawsuit.', 'Beware soypaste from every item.', 'Welfare near kitchen after box.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 62, global step 8694: 'val_WER' was not in top 1\n",
      "Epoch 62, global step 8694: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f798846ef921450195b70b09cb24446b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats parenthood ever sounds left.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivoubed lives to be completely overwhelmed.', 'The toothpaste caused to come through twelfth hour long out.', 'That sounded deep per charge with kids by dark and distorted.', 'Beware soypaste from every thouft.', 'Welfare near certain of folks who spoke.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 63, global step 8832: 'val_WER' was not in top 1\n",
      "Epoch 63, global step 8832: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05eb40ebcc8b45fc9b938f8ae904f297",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Ratspockets seldom soundless.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through fast out.', 'That second week was charged by pouring by spoiled turquoise.', 'Beware soybean oil was full every family.', 'Welfare near certain friends have spoken.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's heart make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 64, global step 8970: 'val_WER' was not in top 1\n",
      "Epoch 64, global step 8970: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f66c97d531a7485e96cf4b9c864d4821",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rake parenthood ever sounded useless.', 'The rules we made in advance collision.', 'Curary household needs blivouls to be completely equal.', 'The toothpaste caused to come through teeth full out.', 'That second week was charged by jar: boy disappeared.', 'Boy fireless ants will overthrow every family.', 'Welfare near sixteen minutes of view.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's head make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 65, global step 9108: 'val_WER' was not in top 1\n",
      "Epoch 65, global step 9108: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e1e252b6524a4891befd3075b22408dc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats perversion every thousand-cents.', 'The rules we made in advance collision.', 'Curory housekeepers need blivened lives to be completely equal.', 'The toothpaste prevented to come through teeth full out.', 'That second jar was charged by jar: the parted table.', 'Beware soybean beans with you every family.', 'Welfare near certain aspects of public.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's maids' making all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 66, global step 9246: 'val_WER' was not in top 1\n",
      "Epoch 66, global step 9246: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b7dc6114aefc41a3bd66b8f40c0ef9c4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Rats parenthood ever sounds left.', 'The rules we made in advance collision.', 'Curary housekeepers need blivled lives to be completely overwhelmed.', 'The toothpaste caused to come through teeth through out.', 'That second week was charged by pouring by pouring tranquilizers.', 'Beware soybean ate very many every family.', 'Welfare near sixteen minutes of rock.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's maids' ability all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 67, global step 9384: 'val_WER' was not in top 1\n",
      "Epoch 67, global step 9384: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "13be7d24a344423d90b569bbbe086153",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscide.', 'Raspy powder sounded superbly.', 'The rules we made in advance collision.', 'Curory housekeepers need blivouls to be completely overwhelmed.', 'The toothpaste prevented to come through teeth full out.', 'That second week was charged by spoiled by spoiled and spoiled.', 'Beware soybean oil with every thumbnail.', 'Welfare near certain of folks.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 68, global step 9522: 'val_WER' was not in top 1\n",
      "Epoch 68, global step 9522: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a05579e56c1943cabe41f0e31bcd8424",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Roughpockets seldom soundless.', 'The rules we made in advance collision.', \"Curler's household breaks to be completely overwhelmed.\", 'The toothpaste caused to come through teeth through out.', 'That second week was charged by jar: the parted table.', 'Beware soybean unmelike with every family.', 'Welfare near certain aspects of rock.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's maids' oil all day.\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 69, global step 9660: 'val_WER' was not in top 1\n",
      "Epoch 69, global step 9660: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcbcab996149461b9517670e1c4847c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Roughpockets seldom soundless.', 'The rules we made in advance collision.', 'Curged household needs to be completely equal.', 'The tooth-visual process went to line through teeth full out.', 'That second week was charged by jar: the toilet disappeared are listed.', 'Beware soypaste from every browser.', 'Welfare near certain of folks.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 70, global step 9798: 'val_WER' was not in top 1\n",
      "Epoch 70, global step 9798: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a53a28f4f63b42f9b9ca10ea285ffe1e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Ratspockets seldom soundless.', 'The rules we made in advance conclusion.', 'Curiosity has needed blivled lives to be completely equal.', 'The toothpaste caused to come through teeth through out.', 'That second week was charged by spoiled by spoiled orator.', 'Beware soybean oil was full every family.', 'Welfare near sixteen sometimes has failed.', \"The wood means it won't boil away easily enough.\", \"Would a boil further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 71, global step 9936: 'val_WER' was not in top 1\n",
      "Epoch 71, global step 9936: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3d9b0b1e62494ebfbca9f9285a852b39",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Roughpockets seldom soundless.', 'The rules we made in advance conclusion.', 'Curory housekeepers need blivled lives to be completely equal.', 'The toothpaste caused to come through twelfth hour out.', 'That second week was charged by eyedroids.', 'Beware soybean oil with every cauliflower.', 'Welfare near certain of folks who spoke.', \"The word means it won't boil away easily enough.\", \"Would a boil further in a man's heat make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 72, global step 10074: 'val_WER' was not in top 1\n",
      "Epoch 72, global step 10074: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59c527979103421aaf0bc8f9e429c0f7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Text:  ['Cycliscence.', 'Ratspockets never soundless.', 'The rules we made in advance closure.', 'Curory housekeepers need blivened to be completely equal.', 'The toothpaste caused to come through teeth through out.', 'That second week was charged by jar: the toilet trembler said.', 'Beware soybean oil was full every year.', 'Welfare near certain of folks who broke.', \"The wood means it won't boil away easily enough.\", \"Would a blow further in a man's body make him all day?\"]\n",
      "True Text:  ['Theocracy reconsidered.', 'Rich purchased several signed lithographs.', 'So rules we made, in unabashed collusion.', \"Lori's costume needed black gloves to be completely elegant.\", \"The tooth fairy forgot to come when Roger's tooth fell out.\", 'That stinging vapor was caused by chloride vaporization.', \"Before Thursday's exam, review every formula.\", 'Wildfire near Sunshine forces park closures.', \"The word means it won't boil away easily, nothing else.\", \"Would a blue feather in a man's hat make him happy all day?\"]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Monitored metric val_loss did not improve in the last 25 records. Best score: 1.052. Signaling Trainer to stop.\n",
      "Epoch 73, global step 10212: 'val_WER' was not in top 1\n",
      "Epoch 73, global step 10212: 'val_CER' was not in top 1\n"
     ]
    },
    {
     "data": {
      "text/html": [],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<br>    <style><br>        .wandb-row {<br>            display: flex;<br>            flex-direction: row;<br>            flex-wrap: wrap;<br>            justify-content: flex-start;<br>            width: 100%;<br>        }<br>        .wandb-col {<br>            display: flex;<br>            flex-direction: column;<br>            flex-basis: 100%;<br>            flex: 1;<br>            padding: 10px;<br>        }<br>    </style><br><div class=\"wandb-row\"><div class=\"wandb-col\"><h3>Run history:</h3><br/><table class=\"wandb\"><tr><td>epoch</td><td>▁▁▁▁▂▂▂▂▂▂▂▂▂▂▃▃▃▃▃▃▃▃▃▄▄▄▄▅▅▅▅▆▆▆▆▆▇▇██</td></tr><tr><td>train_ce_loss_epoch</td><td>▅▅▆▇██▆▄▄▃▃▃▃▂▂▃▂▂▃▁▂▁▂▂▁▂▂▂▁▂▂▂▂▂▃▂▃▃▂▁</td></tr><tr><td>train_ce_loss_step</td><td>▄▄▄▃▃▃▃▄▃▅▂▅▃▄▃▂▂▂▃▃▂█▃▂▂▁▂▁▂▂▁▂▁▁▁▁▂▃▂▂</td></tr><tr><td>train_ctc_loss_epoch</td><td>█▆▅▄▅▅▅▅▅▄▃▃▃▃▂▂▂▂▂▂▂▂▂▂▂▁▁▂▂▁▁▁▂▁▁▁▁▁▁▁</td></tr><tr><td>train_ctc_loss_step</td><td>▃▅▂▇▆▅▅▃█▃▂▂▄▂▂▃▃▅▂▅▄▂▃▄▁▂▂▃▃▂▁▆▂▃▄▂▂▁▂▃</td></tr><tr><td>train_loss_epoch</td><td>█▇▆▅▅▄▄▄▃▃▃▃▃▂▃▂▂▃▃▂▂▂▂▂▂▂▂▂▂▂▂▂▂▂▂▁▂▁▁▁</td></tr><tr><td>train_loss_step</td><td>▄█▅▄▂▆▄▃▄▇▃▄▂▃▄▅▂▁▅▂▄▄▂▁▃▄▁▁▃▃▃▃▅▅▃▂▃▂▃▄</td></tr><tr><td>trainer/global_step</td><td>▁▁▁▁▂▂▂▂▂▂▂▂▃▃▃▃▃▃▄▄▄▄▄▄▅▅▅▅▅▅▆▆▆▆▇█████</td></tr><tr><td>val_CER</td><td>▅▃▅▃▃▇█▅▅▅▄▄▄▃▄▄▃▄▃▁▂▃▃▅▄▃▅▄▃▅▃▆▅▄▅▆▄▄▆▆</td></tr><tr><td>val_WER</td><td>▂▃▄▇█▅▆▅▄▃▅▂▃▅▆▅▅▃▃▃▄▄▃▁▃▄▆▅▅▄▄▆▃▃▅▇▄▆▆▄</td></tr><tr><td>val_ce_loss</td><td>▄▅▃█▇▆▇▇▇▆▅▆▆▅▅▆▄▃▃▂▃▅▅▁▃▃▁▄▆▃▆▃▂▆▄▄▆▄▄▄</td></tr><tr><td>val_ctc_loss</td><td>▂▂▂▁▁▂▂▄▂▃▃▃▃▄▅▅▅▅▄▅▆▆▆▆▆▅▆▆▇▆▇▇▆▇▆▆▇▇██</td></tr><tr><td>val_loss</td><td>█▆▄▄▄▂▂▂▁▁▁▂▂▁▂▁▂▂▂▂▁▁▁▁▁▂▂▁▂▁▂▁▂▁▂▂▂▂▂▂</td></tr></table><br/></div><div class=\"wandb-col\"><h3>Run summary:</h3><br/><table class=\"wandb\"><tr><td>epoch</td><td>73</td></tr><tr><td>train_ce_loss_epoch</td><td>0.00232</td></tr><tr><td>train_ce_loss_step</td><td>0.00174</td></tr><tr><td>train_ctc_loss_epoch</td><td>0.00743</td></tr><tr><td>train_ctc_loss_step</td><td>0.00853</td></tr><tr><td>train_loss_epoch</td><td>0.28688</td></tr><tr><td>train_loss_step</td><td>0.24876</td></tr><tr><td>trainer/global_step</td><td>10211</td></tr><tr><td>val_CER</td><td>0.15236</td></tr><tr><td>val_WER</td><td>0.24191</td></tr><tr><td>val_ce_loss</td><td>0.83979</td></tr><tr><td>val_ctc_loss</td><td>0.90309</td></tr><tr><td>val_loss</td><td>1.06348</td></tr></table><br/></div></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run <strong style=\"color:#cdcd00\">gru_ctc_mfcc_bart_FINETUNING</strong> at: <a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset/runs/rdzzdhcs' target=\"_blank\">https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset/runs/rdzzdhcs</a><br> View project at: <a href='https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset' target=\"_blank\">https://wandb.ai/XXXXXXXXXXXXXX/ECOG_Sentence_dataset</a><br>Synced 6 W&B file(s), 0 media file(s), 3 artifact file(s) and 0 other file(s)"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Find logs at: <code>./wandb/run-20250602_140214-rdzzdhcs/logs</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "FINETUNE = True\n",
    "model = HybridGRUDecoder(\n",
    "    neural_encoder=neural_encoder,\n",
    "    learning_rate=1e-5,   #lower LR for fine-tuning\n",
    "    weight_decay=0.00001,\n",
    "    lm_model_dim = 768, \n",
    "    freeze_lm=False,\n",
    "    freeze_encoder=False,\n",
    "    use_lora=False,  #Use LoRA for fine-tuning\n",
    "    lora_r=128,\n",
    "    lora_alpha=256,\n",
    "    ce_loss_weight=0.2,\n",
    "    ctc_loss_weight=0.5,\n",
    "    l1_loss_weight=1.,\n",
    "    project_from_logits=False,\n",
    ")\n",
    "\n",
    "\n",
    "if FINETUNE:\n",
    "\n",
    "\n",
    "    #load from optimized checkpoints\n",
    "\n",
    "    # Create a directory to save models\n",
    "    run_folder = f\"{output_name}/floral-sweep-5\"\n",
    "    model.load_state_dict(torch.load(f\"{run_folder}/best_model_wer.ckpt\")[\"state_dict\"], strict=True)\n",
    "\n",
    "    model.apply_lora()  # Apply LoRA with specified parameters\n",
    "\n",
    "\n",
    "    wandb_logger = WandbLogger(project=\"ECOG_Sentence_dataset\", name=f\"{output_name}_FINETUNING\",\n",
    "                            reinit=True)\n",
    "\n",
    "    # Define ModelCheckpoint to save the best model based on validation loss\n",
    "    checkpoint_callback_wer = ModelCheckpoint(\n",
    "        monitor=\"val_WER\",  # Ensure your validation step logs \"val_loss\"\n",
    "        mode=\"min\",          # Save the model with the lowest validation loss\n",
    "        save_top_k=1,        # Keep only the best model\n",
    "        dirpath=f\".checkpoints/{run_folder}_FINETUNING/\",  # Directory to save checkpoints\n",
    "        filename=f\"best_model_wer\",  # Model filename\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "        # Define ModelCheckpoint to save the best model based on validation loss\n",
    "    checkpoint_callback_per = ModelCheckpoint(\n",
    "        monitor=\"val_CER\",  # Ensure your validation step logs \"val_loss\"\n",
    "        mode=\"min\",          # Save the model with the lowest validation loss\n",
    "        save_top_k=1,        # Keep only the best model\n",
    "        dirpath=f\".checkpoints/{run_folder}_FINETUNING/\",  # Directory to save checkpoints\n",
    "        filename=f\"best_model_per\",  # Model filename\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "    # Define EarlyStopping callback with patience of 3 epochs\n",
    "    early_stopping_callback = EarlyStopping(\n",
    "        monitor=\"val_loss\",\n",
    "        patience=25,   # Stop training if no improvement in 3 epochs\n",
    "        mode=\"min\",\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "\n",
    "    # Train model\n",
    "    trainer = pl.Trainer(max_epochs=100,devices =[2], callbacks=[checkpoint_callback_wer,checkpoint_callback_per, early_stopping_callback], logger=wandb_logger)\n",
    "\n",
    "    trainer.fit(model, train_loader, test_loader)\n",
    "\n",
    "    wandb.finish()  # Finish the WandB run\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "38cc233c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "HybridGRUDecoder(\n",
       "  (encoder): LightningGRUDecoder_MFCC_v3(\n",
       "    (inputLayerNonlinearity): Softsign()\n",
       "    (unfolder): Unfold(kernel_size=(32, 1), dilation=1, padding=0, stride=4)\n",
       "    (mfcc_unfolder): Unfold(kernel_size=(4, 1), dilation=1, padding=0, stride=4)\n",
       "    (gaussianSmoother): GaussianSmoothing()\n",
       "    (gru_decoder): GRU(8192, 1024, num_layers=5, batch_first=True, dropout=0.4, bidirectional=True)\n",
       "    (fc_decoder_out): Linear(in_features=2048, out_features=41, bias=True)\n",
       "    (mfcc_decoder): Linear(in_features=2048, out_features=56, bias=True)\n",
       "    (ctc_loss): CTCLoss()\n",
       "    (l1oss): L1Loss()\n",
       "  )\n",
       "  (project): Sequential(\n",
       "    (0): LayerNorm((2048,), eps=1e-05, elementwise_affine=True)\n",
       "    (1): Linear(in_features=2048, out_features=768, bias=True)\n",
       "  )\n",
       "  (language_model): PeftModel(\n",
       "    (base_model): LoraModel(\n",
       "      (model): BartForConditionalGeneration(\n",
       "        (model): BartModel(\n",
       "          (shared): BartScaledWordEmbedding(50265, 768, padding_idx=1)\n",
       "          (encoder): BartEncoder(\n",
       "            (embed_tokens): BartScaledWordEmbedding(50265, 768, padding_idx=1)\n",
       "            (embed_positions): BartLearnedPositionalEmbedding(1026, 768)\n",
       "            (layers): ModuleList(\n",
       "              (0-5): 6 x BartEncoderLayer(\n",
       "                (self_attn): BartSdpaAttention(\n",
       "                  (k_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (v_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (q_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (out_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                )\n",
       "                (self_attn_layer_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "                (activation_fn): GELUActivation()\n",
       "                (fc1): Linear(in_features=768, out_features=3072, bias=True)\n",
       "                (fc2): Linear(in_features=3072, out_features=768, bias=True)\n",
       "                (final_layer_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "              )\n",
       "            )\n",
       "            (layernorm_embedding): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          )\n",
       "          (decoder): BartDecoder(\n",
       "            (embed_tokens): BartScaledWordEmbedding(50265, 768, padding_idx=1)\n",
       "            (embed_positions): BartLearnedPositionalEmbedding(1026, 768)\n",
       "            (layers): ModuleList(\n",
       "              (0-5): 6 x BartDecoderLayer(\n",
       "                (self_attn): BartSdpaAttention(\n",
       "                  (k_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (v_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (q_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (out_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                )\n",
       "                (activation_fn): GELUActivation()\n",
       "                (self_attn_layer_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "                (encoder_attn): BartSdpaAttention(\n",
       "                  (k_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (v_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (q_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                  (out_proj): lora.Linear(\n",
       "                    (base_layer): Linear(in_features=768, out_features=768, bias=True)\n",
       "                    (lora_dropout): ModuleDict(\n",
       "                      (default): Dropout(p=0.2, inplace=False)\n",
       "                    )\n",
       "                    (lora_A): ModuleDict(\n",
       "                      (default): Linear(in_features=768, out_features=128, bias=False)\n",
       "                    )\n",
       "                    (lora_B): ModuleDict(\n",
       "                      (default): Linear(in_features=128, out_features=768, bias=False)\n",
       "                    )\n",
       "                    (lora_embedding_A): ParameterDict()\n",
       "                    (lora_embedding_B): ParameterDict()\n",
       "                    (lora_magnitude_vector): ModuleDict()\n",
       "                  )\n",
       "                )\n",
       "                (encoder_attn_layer_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "                (fc1): Linear(in_features=768, out_features=3072, bias=True)\n",
       "                (fc2): Linear(in_features=3072, out_features=768, bias=True)\n",
       "                (final_layer_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "              )\n",
       "            )\n",
       "            (layernorm_embedding): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          )\n",
       "        )\n",
       "        (lm_head): Linear(in_features=768, out_features=50265, bias=False)\n",
       "      )\n",
       "    )\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = \"cuda:0\"\n",
    "model.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "17eeae9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 14/14 [00:15<00:00,  1.13s/it]\n"
     ]
    }
   ],
   "source": [
    "decoded_sentences = []\n",
    "true_sentences = []\n",
    "for batch in tqdm.tqdm(test_loader):\n",
    "    X = batch[\"neural_feats\"].to(device)\n",
    "    y = batch[\"phone_seq\"]\n",
    "    X_len = batch[\"neural_time_bins\"]\n",
    "    y_len = batch[\"phone_seq_len\"]\n",
    "    dayIdx = batch[\"day\"].to(device)\n",
    "    sentence = batch[\"sentence\"]\n",
    "\n",
    "    with torch.no_grad():\n",
    "        decoded = model.generate(X,dayIdx)\n",
    "    decoded_sentences.extend(decoded)\n",
    "    true_sentences.extend(sentence)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7a630e79",
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers.modeling_outputs import BaseModelOutput, ModelOutput\n",
    "\n",
    "def beam_search_generate(model, neuralInput, dayIdx, max_length=60, num_beams=1,num_return_sequences=1):\n",
    "    \"\"\"\n",
    "    Generate text from the model.\n",
    "    neuralInput: (batch_size, seq_len, input_dim)\n",
    "    dayIdx: Session index\n",
    "    \"\"\"\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        hid = model.get_neural_embedding(neuralInput, dayIdx)\n",
    "        # encoder_outputs = model.project(hid)\n",
    "\n",
    "        if model.project_from_logits:\n",
    "            # If projecting from logits, use the predicted logits\n",
    "            logits = model.encoder.fc_decoder_out(hid)\n",
    "            encoder_outputs = model.project(logits)\n",
    "\n",
    "        else:\n",
    "            encoder_outputs = model.project(hid)\n",
    "\n",
    "\n",
    "        encoder_outputs = BaseModelOutput(last_hidden_state=encoder_outputs)\n",
    "\n",
    "        generated_ids = model.language_model.generate(encoder_outputs=encoder_outputs, max_length=max_length,num_beams=num_beams, \n",
    "                                                      num_return_sequences=num_return_sequences, \n",
    "                                                      do_sample= True,\n",
    "                                                      top_k=50,\n",
    "                                                      top_p=0.95,\n",
    "                                                      temperature=0.9,\n",
    "                                                      length_penalty=1.0,\n",
    "                                                      no_repeat_ngram_size=3)\n",
    "        generated_text = model.tokenizer.batch_decode(generated_ids, skip_special_tokens=True)\n",
    "\n",
    "    return generated_text"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "00db7572",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_return = 2\n",
    "check= beam_search_generate(model,X,dayIdx,max_length=20, num_beams=18,num_return_sequences=num_return)\n",
    "# rearrange check as a list of list with each sublist containing the generated sequences for each input\n",
    "check = [check[i:i + num_return] for i in range(0, len(check), num_return)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6c867bcd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([\"It's a pretty good size switch.\", \"It's a pretty good size church.\"],\n",
       " \"It's a pretty good size switch.\",\n",
       " \"It's a pretty good size church.\")"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx = 20\n",
    "check[idx],decoded[idx],sentence[idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "6c4272d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Decoded sentence: A flock about an authentic story for her.\n",
      "True sentence: He talked about unauthentic storylines too.\n"
     ]
    }
   ],
   "source": [
    "idx = 10\n",
    "print(\"Decoded sentence:\", decoded_sentences[idx])\n",
    "print(\"True sentence:\", true_sentences[idx])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1fa3900e",
   "metadata": {},
   "source": [
    "## Evaluation of words"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "23491be1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import string\n",
    "import re\n",
    "\n",
    "import jiwer  # For WER\n",
    "import sacrebleu  # For BLEU\n",
    "from rouge_score import rouge_scorer  # For ROUGE\n",
    "from nltk.translate.meteor_score import meteor_score  # For METEOR\n",
    "import bert_score  # For BERTScore\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "def preprocess_text(text):\n",
    "    \"\"\"\n",
    "    Remove punctuation, strip, and convert text to lowercase.\n",
    "    \"\"\"\n",
    "    return text.translate(str.maketrans('', '', string.punctuation)).strip().lower()\n",
    "\n",
    "\n",
    "\n",
    "def compute_metrics(text_transcriptions, gpt_decoded):\n",
    "    \"\"\"\n",
    "    Compute various NLP evaluation metrics for text generation.\n",
    "\n",
    "    Args:\n",
    "        text_transcriptions (list): List of ground-truth reference sentences.\n",
    "        gpt_decoded (list): List of model-generated sentences.\n",
    "\n",
    "    Returns:\n",
    "        dict: Dictionary containing all computed metrics.\n",
    "    \"\"\"\n",
    "\n",
    "    #remove punctuation, strip and lower case\n",
    "\n",
    "\n",
    "    text_transcriptions = [preprocess_text(text) for text in text_transcriptions]\n",
    "    gpt_decoded = [preprocess_text(text) for text in gpt_decoded]\n",
    "\n",
    "    results = {}\n",
    "\n",
    "    # WER (Word Error Rate)\n",
    "    wer = jiwer.wer(text_transcriptions, gpt_decoded)\n",
    "    results[\"WER\"] = wer\n",
    "\n",
    "    # BLEU Score\n",
    "    bleu = sacrebleu.corpus_bleu(gpt_decoded, [text_transcriptions]).score\n",
    "    results[\"BLEU\"] = bleu\n",
    "\n",
    "    # ROUGE Scores\n",
    "    rouge = rouge_scorer.RougeScorer([\"rouge1\", \"rouge2\", \"rougeL\"], use_stemmer=True)\n",
    "    rouge_scores = [rouge.score(ref, pred) for ref, pred in zip(text_transcriptions, gpt_decoded)]\n",
    "    results[\"ROUGE-1\"] = np.mean([score[\"rouge1\"].fmeasure for score in rouge_scores])\n",
    "    results[\"ROUGE-2\"] = np.mean([score[\"rouge2\"].fmeasure for score in rouge_scores])\n",
    "    results[\"ROUGE-L\"] = np.mean([score[\"rougeL\"].fmeasure for score in rouge_scores])\n",
    "\n",
    "    ##METEOR\n",
    "    tokenized_references = [ref.split() for ref in text_transcriptions]  # Tokenize reference sentences\n",
    "    tokenized_hypotheses = [pred.split() for pred in gpt_decoded]  # Tokenize predicted sentences\n",
    "\n",
    "    meteor_scores = [meteor_score([ref], pred) for ref, pred in zip(tokenized_references, tokenized_hypotheses)]\n",
    "    results[\"METEOR\"] = np.mean(meteor_scores)\n",
    "    # BERTScore (Semantic Similarity)\n",
    "    P, R, F1 = bert_score.score(gpt_decoded, text_transcriptions, lang=\"en\", rescale_with_baseline=True)\n",
    "    results[\"BERTScore_Precision\"] = P.mean().item()\n",
    "    results[\"BERTScore_Recall\"] = R.mean().item()\n",
    "    results[\"BERTScore_F1\"] = F1.mean().item()\n",
    "\n",
    "    ## save also all values without recomputing when possible\n",
    "    results[\"METEOR_scores\"] = meteor_scores\n",
    "    results[\"ROUGE_scores\"] = rouge_scores\n",
    "\n",
    "    results[\"WER_scores\"] = [jiwer.wer([ref], [pred]) for ref, pred in zip(text_transcriptions, gpt_decoded)]\n",
    "    results[\"BERTScore_F1_scores\"] = F1.cpu().numpy().tolist()\n",
    "    return results\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1ea7b37a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['roberta.pooler.dense.bias', 'roberta.pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WER: 0.2479\n",
      "BLEU: 58.0104\n",
      "ROUGE-1: 0.7640\n",
      "ROUGE-2: 0.6272\n",
      "ROUGE-L: 0.7638\n",
      "METEOR: 0.7266\n",
      "BERTScore_Precision: 0.6415\n",
      "BERTScore_Recall: 0.6434\n",
      "BERTScore_F1: 0.6427\n"
     ]
    }
   ],
   "source": [
    "\n",
    "metrics = compute_metrics(true_sentences,decoded_sentences)\n",
    "for metric, score in metrics.items():\n",
    "    if \"scores\" not in metric:\n",
    "        print(f\"{metric}: {score:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "dfd609d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "results_df = pd.DataFrame({\n",
    "    \"target_sentence\": true_sentences,\n",
    "    \"pred_sentence\": decoded_sentences,\n",
    "})\n",
    "\n",
    "#unfold cer_list\n",
    "# cer_list_unfold = [item for sublist in cer_list for item in sublist]\n",
    "\n",
    "results_df[\"WER_scores\"] = metrics[\"WER_scores\"]\n",
    "results_df[\"METEOR_scores\"] = metrics[\"METEOR_scores\"]\n",
    "results_df[\"ROUGE_scores\"] = metrics[\"ROUGE_scores\"]\n",
    "results_df[\"BERTScore_F1_scores\"] = metrics[\"BERTScore_F1_scores\"]\n",
    "\n",
    "results_df.to_csv(f\"{results_dir}/language_results_BART.csv\", index=False)\n",
    "\n",
    "overall_metrics = {k:v for k,v in metrics.items() if \"scores\" not in k}\n",
    "\n",
    "metrics_df = pd.DataFrame(overall_metrics, index=[0])\n",
    "metrics_df.to_csv(f\"{results_dir}/language_metrics_BART.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "8e1930df",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target_sentence</th>\n",
       "      <th>pred_sentence</th>\n",
       "      <th>WER_scores</th>\n",
       "      <th>METEOR_scores</th>\n",
       "      <th>ROUGE_scores</th>\n",
       "      <th>BERTScore_F1_scores</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>780</th>\n",
       "      <td>Temperature swing in about four hours.</td>\n",
       "      <td>Trump who are a year old thing in about her?</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>0.292969</td>\n",
       "      <td>{'rouge1': (0.2, 0.3333333333333333, 0.25), 'r...</td>\n",
       "      <td>-0.080017</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>79</th>\n",
       "      <td>Marksmanship example.</td>\n",
       "      <td>Mix miniature clay.</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>-0.003077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>621</th>\n",
       "      <td>Started investigating.</td>\n",
       "      <td>Toubled and vanished.</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>-0.074297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>212</th>\n",
       "      <td>Competition with Japan.</td>\n",
       "      <td>Commentational was depend upon.</td>\n",
       "      <td>1.333333</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>-0.151680</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>He talked about unauthentic storylines too.</td>\n",
       "      <td>A flock about an authentic story for her.</td>\n",
       "      <td>1.166667</td>\n",
       "      <td>0.080645</td>\n",
       "      <td>{'rouge1': (0.125, 0.16666666666666666, 0.1428...</td>\n",
       "      <td>0.232499</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>107</th>\n",
       "      <td>Recent legislation.</td>\n",
       "      <td>Residential education.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.474056</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Theocracy reconsidered.</td>\n",
       "      <td>Cycliscence.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>-0.160115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Rich purchased several signed lithographs.</td>\n",
       "      <td>Ratspockets never soundless.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>-0.113420</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>275</th>\n",
       "      <td>Killer bee instinct.</td>\n",
       "      <td>Cler be ants.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.204601</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>612</th>\n",
       "      <td>Golden Retriever.</td>\n",
       "      <td>Children behave.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.058342</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>That stinging vapor was caused by chloride vap...</td>\n",
       "      <td>That second week was charged by jar: the toile...</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.180723</td>\n",
       "      <td>{'rouge1': (0.2727272727272727, 0.375, 0.31578...</td>\n",
       "      <td>0.037380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>416</th>\n",
       "      <td>Former employers.</td>\n",
       "      <td>Bloomberg employs.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.250000</td>\n",
       "      <td>{'rouge1': (0.5, 0.5, 0.5), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.086574</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Wildfire near Sunshine forces park closures.</td>\n",
       "      <td>Welfare near certain of folks who broke.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.081967</td>\n",
       "      <td>{'rouge1': (0.14285714285714285, 0.16666666666...</td>\n",
       "      <td>0.075476</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>869</th>\n",
       "      <td>Savings and loans.</td>\n",
       "      <td>Solving in guns.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.103532</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>272</th>\n",
       "      <td>Increasingly democratically oriented.</td>\n",
       "      <td>Insurance significantly coincided.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.205798</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>646</th>\n",
       "      <td>You're developing your imagination.</td>\n",
       "      <td>Your involvement for immigration.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.125000</td>\n",
       "      <td>{'rouge1': (0.25, 0.25, 0.25), 'rouge2': (0.0,...</td>\n",
       "      <td>0.036997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>681</th>\n",
       "      <td>State land grant colleges.</td>\n",
       "      <td>Set my rent salaries.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.030909</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>584</th>\n",
       "      <td>Fifteen feet wide.</td>\n",
       "      <td>Friction paint hard.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.048949</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>287</th>\n",
       "      <td>Summary points.</td>\n",
       "      <td>Subscriptions.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.234370</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>603</th>\n",
       "      <td>A food processor.</td>\n",
       "      <td>I foodpaste.</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>{'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....</td>\n",
       "      <td>0.477869</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                       target_sentence  \\\n",
       "780             Temperature swing in about four hours.   \n",
       "79                               Marksmanship example.   \n",
       "621                             Started investigating.   \n",
       "212                            Competition with Japan.   \n",
       "10         He talked about unauthentic storylines too.   \n",
       "107                                Recent legislation.   \n",
       "0                              Theocracy reconsidered.   \n",
       "1           Rich purchased several signed lithographs.   \n",
       "275                               Killer bee instinct.   \n",
       "612                                  Golden Retriever.   \n",
       "5    That stinging vapor was caused by chloride vap...   \n",
       "416                                  Former employers.   \n",
       "7         Wildfire near Sunshine forces park closures.   \n",
       "869                                 Savings and loans.   \n",
       "272              Increasingly democratically oriented.   \n",
       "646                You're developing your imagination.   \n",
       "681                         State land grant colleges.   \n",
       "584                                 Fifteen feet wide.   \n",
       "287                                    Summary points.   \n",
       "603                                  A food processor.   \n",
       "\n",
       "                                         pred_sentence  WER_scores  \\\n",
       "780       Trump who are a year old thing in about her?    1.500000   \n",
       "79                                 Mix miniature clay.    1.500000   \n",
       "621                              Toubled and vanished.    1.500000   \n",
       "212                    Commentational was depend upon.    1.333333   \n",
       "10           A flock about an authentic story for her.    1.166667   \n",
       "107                             Residential education.    1.000000   \n",
       "0                                         Cycliscence.    1.000000   \n",
       "1                         Ratspockets never soundless.    1.000000   \n",
       "275                                      Cler be ants.    1.000000   \n",
       "612                                   Children behave.    1.000000   \n",
       "5    That second week was charged by jar: the toile...    1.000000   \n",
       "416                                 Bloomberg employs.    1.000000   \n",
       "7             Welfare near certain of folks who broke.    1.000000   \n",
       "869                                   Solving in guns.    1.000000   \n",
       "272                 Insurance significantly coincided.    1.000000   \n",
       "646                  Your involvement for immigration.    1.000000   \n",
       "681                              Set my rent salaries.    1.000000   \n",
       "584                               Friction paint hard.    1.000000   \n",
       "287                                     Subscriptions.    1.000000   \n",
       "603                                       I foodpaste.    1.000000   \n",
       "\n",
       "     METEOR_scores                                       ROUGE_scores  \\\n",
       "780       0.292969  {'rouge1': (0.2, 0.3333333333333333, 0.25), 'r...   \n",
       "79        0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "621       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "212       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "10        0.080645  {'rouge1': (0.125, 0.16666666666666666, 0.1428...   \n",
       "107       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "0         0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "1         0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "275       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "612       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "5         0.180723  {'rouge1': (0.2727272727272727, 0.375, 0.31578...   \n",
       "416       0.250000  {'rouge1': (0.5, 0.5, 0.5), 'rouge2': (0.0, 0....   \n",
       "7         0.081967  {'rouge1': (0.14285714285714285, 0.16666666666...   \n",
       "869       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "272       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "646       0.125000  {'rouge1': (0.25, 0.25, 0.25), 'rouge2': (0.0,...   \n",
       "681       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "584       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "287       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "603       0.000000  {'rouge1': (0.0, 0.0, 0.0), 'rouge2': (0.0, 0....   \n",
       "\n",
       "     BERTScore_F1_scores  \n",
       "780            -0.080017  \n",
       "79             -0.003077  \n",
       "621            -0.074297  \n",
       "212            -0.151680  \n",
       "10              0.232499  \n",
       "107             0.474056  \n",
       "0              -0.160115  \n",
       "1              -0.113420  \n",
       "275             0.204601  \n",
       "612             0.058342  \n",
       "5               0.037380  \n",
       "416             0.086574  \n",
       "7               0.075476  \n",
       "869             0.103532  \n",
       "272             0.205798  \n",
       "646             0.036997  \n",
       "681             0.030909  \n",
       "584             0.048949  \n",
       "287             0.234370  \n",
       "603             0.477869  "
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df.sort_values(\"WER_scores\", ascending=False).head(20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "fcc7b615",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target_sentence</th>\n",
       "      <th>pred_sentence</th>\n",
       "      <th>WER_scores</th>\n",
       "      <th>METEOR_scores</th>\n",
       "      <th>ROUGE_scores</th>\n",
       "      <th>BERTScore_F1_scores</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>145</th>\n",
       "      <td>But they have snakes over there.</td>\n",
       "      <td>But they have snacks over there.</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.806667</td>\n",
       "      <td>{'rouge1': (0.8333333333333334, 0.833333333333...</td>\n",
       "      <td>0.720384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>401</th>\n",
       "      <td>Lawmakers passed a measure last year.</td>\n",
       "      <td>Losers passed a measure last year.</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.830000</td>\n",
       "      <td>{'rouge1': (0.8333333333333334, 0.833333333333...</td>\n",
       "      <td>0.996491</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>739</th>\n",
       "      <td>It's like one second of recording.</td>\n",
       "      <td>It's like one second of kindergarten.</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.830000</td>\n",
       "      <td>{'rouge1': (0.8333333333333334, 0.833333333333...</td>\n",
       "      <td>0.548760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>481</th>\n",
       "      <td>One had more blue to it.</td>\n",
       "      <td>One had more people to it.</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.806667</td>\n",
       "      <td>{'rouge1': (0.8333333333333334, 0.833333333333...</td>\n",
       "      <td>0.480776</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>409</th>\n",
       "      <td>Download on your computer, or television.</td>\n",
       "      <td>Entrain on your computer or television.</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.830000</td>\n",
       "      <td>{'rouge1': (0.8333333333333334, 0.833333333333...</td>\n",
       "      <td>0.608469</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>630</th>\n",
       "      <td>That would be really awful.</td>\n",
       "      <td>That would be really awful.</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.996000</td>\n",
       "      <td>{'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>629</th>\n",
       "      <td>Well tell me this.</td>\n",
       "      <td>We'll tell me this.</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.992188</td>\n",
       "      <td>{'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....</td>\n",
       "      <td>1.000001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>318</th>\n",
       "      <td>Enjoyable to use.</td>\n",
       "      <td>Enjoyable to use.</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.981481</td>\n",
       "      <td>{'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>316</th>\n",
       "      <td>An earlier version of this article.</td>\n",
       "      <td>An earlier version of this article.</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.997685</td>\n",
       "      <td>{'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>683</th>\n",
       "      <td>We've had lots of them in the past.</td>\n",
       "      <td>We've had lots of them in the past.</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.999023</td>\n",
       "      <td>{'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>400 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                               target_sentence  \\\n",
       "145           But they have snakes over there.   \n",
       "401      Lawmakers passed a measure last year.   \n",
       "739         It's like one second of recording.   \n",
       "481                   One had more blue to it.   \n",
       "409  Download on your computer, or television.   \n",
       "..                                         ...   \n",
       "630                That would be really awful.   \n",
       "629                         Well tell me this.   \n",
       "318                          Enjoyable to use.   \n",
       "316        An earlier version of this article.   \n",
       "683        We've had lots of them in the past.   \n",
       "\n",
       "                               pred_sentence  WER_scores  METEOR_scores  \\\n",
       "145         But they have snacks over there.    0.166667       0.806667   \n",
       "401       Losers passed a measure last year.    0.166667       0.830000   \n",
       "739    It's like one second of kindergarten.    0.166667       0.830000   \n",
       "481               One had more people to it.    0.166667       0.806667   \n",
       "409  Entrain on your computer or television.    0.166667       0.830000   \n",
       "..                                       ...         ...            ...   \n",
       "630              That would be really awful.    0.000000       0.996000   \n",
       "629                      We'll tell me this.    0.000000       0.992188   \n",
       "318                        Enjoyable to use.    0.000000       0.981481   \n",
       "316      An earlier version of this article.    0.000000       0.997685   \n",
       "683      We've had lots of them in the past.    0.000000       0.999023   \n",
       "\n",
       "                                          ROUGE_scores  BERTScore_F1_scores  \n",
       "145  {'rouge1': (0.8333333333333334, 0.833333333333...             0.720384  \n",
       "401  {'rouge1': (0.8333333333333334, 0.833333333333...             0.996491  \n",
       "739  {'rouge1': (0.8333333333333334, 0.833333333333...             0.548760  \n",
       "481  {'rouge1': (0.8333333333333334, 0.833333333333...             0.480776  \n",
       "409  {'rouge1': (0.8333333333333334, 0.833333333333...             0.608469  \n",
       "..                                                 ...                  ...  \n",
       "630  {'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....             1.000000  \n",
       "629  {'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....             1.000001  \n",
       "318  {'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....             1.000000  \n",
       "316  {'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....             1.000000  \n",
       "683  {'rouge1': (1.0, 1.0, 1.0), 'rouge2': (1.0, 1....             1.000000  \n",
       "\n",
       "[400 rows x 6 columns]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df.sort_values(\"WER_scores\", ascending=False).tail(400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "8c6fddf7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([273.,   0.,   0.,   0.,   0.,   2.,   8.,  19.,  23.,  45.,   0.,\n",
       "         44.,   4.,  51.,  13.,   1.,  51.,   0.,   1.,  22.,  10.,   0.,\n",
       "         62.,   0.,   1.,  15.,  28.,   0.,  16.,   5.,   2.,   0.,   0.,\n",
       "         60.,   0.,   1.,   1.,   3.,   6.,   0.,  16.,   7.,   2.,   0.,\n",
       "         28.,   0.,   1.,   3.,   1.,   0.,  12.,   2.,   0.,  11.,   1.,\n",
       "          3.,   0.,   1.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "         20.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          1.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          1.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          3.]),\n",
       " array([0.   , 0.015, 0.03 , 0.045, 0.06 , 0.075, 0.09 , 0.105, 0.12 ,\n",
       "        0.135, 0.15 , 0.165, 0.18 , 0.195, 0.21 , 0.225, 0.24 , 0.255,\n",
       "        0.27 , 0.285, 0.3  , 0.315, 0.33 , 0.345, 0.36 , 0.375, 0.39 ,\n",
       "        0.405, 0.42 , 0.435, 0.45 , 0.465, 0.48 , 0.495, 0.51 , 0.525,\n",
       "        0.54 , 0.555, 0.57 , 0.585, 0.6  , 0.615, 0.63 , 0.645, 0.66 ,\n",
       "        0.675, 0.69 , 0.705, 0.72 , 0.735, 0.75 , 0.765, 0.78 , 0.795,\n",
       "        0.81 , 0.825, 0.84 , 0.855, 0.87 , 0.885, 0.9  , 0.915, 0.93 ,\n",
       "        0.945, 0.96 , 0.975, 0.99 , 1.005, 1.02 , 1.035, 1.05 , 1.065,\n",
       "        1.08 , 1.095, 1.11 , 1.125, 1.14 , 1.155, 1.17 , 1.185, 1.2  ,\n",
       "        1.215, 1.23 , 1.245, 1.26 , 1.275, 1.29 , 1.305, 1.32 , 1.335,\n",
       "        1.35 , 1.365, 1.38 , 1.395, 1.41 , 1.425, 1.44 , 1.455, 1.47 ,\n",
       "        1.485, 1.5  ]),\n",
       " <BarContainer object of 100 artists>)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/HhrxowZnvGfffaZFRsba82bN8/avXu3VVBQYLVo0cLasWNHqJbgE1/XO2fOHCsuLs565513rCNHjni2mpqaUC3BJ76u90zh9i4eX9d78OBBKz4+3srNzbUqKiqs1atXW8nJydbzzz8fqiX4xNf1FhQUWPHx8dbSpUutffv2WR9++KHVuXNn69577w3VEnxSU1Njbdu2zdq2bZslyXrxxRetbdu2Wf/6178sy7KsGTNmWOPHj/eM37dvn9W6dWtr2rRp1u7du62ioiIrJibGKikpCdUSfOLrepcsWWLFxsZaRUVFXl+vqqqqQrUEn/i63jNF+rt4LrtAsSzLmj9/vtW+fXsrLi7O6t+/v7VlyxbPsdtuu82aMGGC1/i3337b6tKlixUXF2ddf/311po1a5p5xpfGl/V26NDBknTWVlBQ0PwT95OvH9//FW6BYlm+r3fz5s1WRkaGZbPZrE6dOll/+tOfrIaGhmaetf98WW99fb31zDPPWJ07d7ZatmxppaenW48++qj173//u/kn7oePP/64yX+Pp9c4YcIE67bbbjvrPn369LHi4uKsTp06WYsWLWr2efvL1/Xedttt5x1vOn8+vv8r0gMlyrIi8DwnAAAIa5fVNSgAACA8ECgAAMA4BAoAADAOgQIAAIxDoAAAAOMQKAAAwDgECgAAMA6BAgAAjEOgAAAA4xAoAADAOAQKAAAwDoECAACM83/lBl4sfdlf5gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.hist(results_df[\"WER_scores\"], bins=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "b9488e47",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(0.2),\n",
       " np.float64(0.25917987733077974),\n",
       " np.float64(0.26463817892600744))"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.median(results_df[\"WER_scores\"]), np.mean(results_df[\"WER_scores\"]), np.std(results_df[\"WER_scores\"])"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "evo",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
