{"cells":[{"cell_type":"markdown","metadata":{"id":"kP03wa1lzWPL"},"source":["# Setup (run this, no need to read)"]},{"cell_type":"markdown","metadata":{"id":"0AlCl2otfVy9"},"source":["## General imports"]},{"cell_type":"code","execution_count":1,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":42962,"status":"ok","timestamp":1711747120290,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":-60},"id":"wChb03RbfVy9","outputId":"43d7a6fd-23f9-4d12-d2c2-eb26f45e0f8e"},"outputs":[{"output_type":"stream","name":"stdout","text":["Collecting git+https://github.com/epoch-research/egraphs.git\n","  Cloning https://github.com/epoch-research/egraphs.git to /tmp/pip-req-build-5olhrqj0\n","  Running command git clone --filter=blob:none --quiet https://github.com/epoch-research/egraphs.git /tmp/pip-req-build-5olhrqj0\n","  Resolved https://github.com/epoch-research/egraphs.git to commit 918db6a66a62685d32cdffce831d68f470947070\n","  Installing build dependencies ... \u001b[?25l\u001b[?25hdone\n","  Getting requirements to build wheel ... \u001b[?25l\u001b[?25hdone\n","  Preparing metadata (pyproject.toml) ... \u001b[?25l\u001b[?25hdone\n","Requirement already satisfied: matplotlib<4.0.0,>=3.8.3 in /usr/local/lib/python3.10/dist-packages (from egraphs==0.1.0) (3.8.3)\n","Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (1.2.0)\n","Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (0.12.1)\n","Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (4.50.0)\n","Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (1.4.5)\n","Requirement already satisfied: numpy<2,>=1.21 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (1.25.2)\n","Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (24.0)\n","Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (9.4.0)\n","Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (3.1.2)\n","Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.10/dist-packages (from matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (2.8.2)\n","Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/dist-packages (from python-dateutil>=2.7->matplotlib<4.0.0,>=3.8.3->egraphs==0.1.0) (1.16.0)\n","Requirement already satisfied: matplotlib-label-lines in /usr/local/lib/python3.10/dist-packages (0.7.0)\n","Requirement already satisfied: matplotlib>=2.0.2 in /usr/local/lib/python3.10/dist-packages (from matplotlib-label-lines) (3.8.3)\n","Requirement already satisfied: more-itertools in /usr/local/lib/python3.10/dist-packages (from matplotlib-label-lines) (10.1.0)\n","Requirement already satisfied: numpy>=1.16 in /usr/local/lib/python3.10/dist-packages (from matplotlib-label-lines) (1.25.2)\n","Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (1.2.0)\n","Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (0.12.1)\n","Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (4.50.0)\n","Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (1.4.5)\n","Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (24.0)\n","Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (9.4.0)\n","Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (3.1.2)\n","Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.2->matplotlib-label-lines) (2.8.2)\n","Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/dist-packages (from python-dateutil>=2.7->matplotlib>=2.0.2->matplotlib-label-lines) (1.16.0)\n"]}],"source":["import pandas as pd\n","import numpy as np\n","from copy import deepcopy\n","import random\n","import seaborn as sns\n","import re\n","import os\n","\n","import matplotlib as mpl\n","import matplotlib.pyplot as plt\n","import matplotlib.dates as mdates\n","!pip install git+https://github.com/epoch-research/egraphs.git\n","import egraphs\n","!pip install matplotlib-label-lines\n","import labellines\n","import plotly.express as px"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"HwPFgP66fVy-"},"outputs":[],"source":["from datetime import datetime\n","date = datetime.today().strftime('%Y-%m-%d')"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"EoPKS0B7fVy-"},"outputs":[],"source":["from scipy.optimize import minimize, minimize_scalar\n","from scipy.stats import norm\n","from sklearn.metrics import r2_score\n","\n","import json\n","from google.colab import files"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":2,"status":"ok","timestamp":1709234588827,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"W_O_gbgXJbsR","outputId":"4ef8fed1-9aed-4f9f-d5f4-8ad516ebb899"},"outputs":[{"data":{"text/plain":["{'divide': 'warn', 'over': 'ignore', 'under': 'ignore', 'invalid': 'warn'}"]},"execution_count":1343,"metadata":{},"output_type":"execute_result"}],"source":["np.seterr(over='ignore') # models 14 and 15"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"GWMQBJSMDub-"},"outputs":[],"source":["use_cached_bootstraps = True"]},{"cell_type":"markdown","metadata":{"id":"RBnLn-08fVy_"},"source":["## Data"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"cfo8FaflfVy_"},"outputs":[],"source":["# load primary algorithmic progress dataset\n","# path = \"https://docs.google.com/spreadsheets/d/11m8O_mU0cUkOB_5wluPne4PNsuvsKNbbVAzbYNy-NXY/edit#gid=91564213\"\n","# path = \"https://docs.google.com/spreadsheets/d/1NQh5XJdMjuoZ7Brb39rORCaBveWTRGT0TVcTYWUo6tU/edit#gid=91564213\"\n","path = \"https://docs.google.com/spreadsheets/d/11m8O_mU0cUkOB_5wluPne4PNsuvsKNbbVAzbYNy-NXY/edit#gid=2087221150\"\n","path = path.replace(\"edit#\", \"export?\") + \"&format=csv\"\n","df = pd.read_csv(path, parse_dates=True)\n","\n","# remove unnecessary columns\n","columns_to_remove = ['Author(s)', 'Link', 'Hardware', 'Base Model', 'GitHub', 'Comments', 'Organizations', 'Organization Categorization', 'Comments']\n","df = df.drop(columns=columns_to_remove)\n","\n","# rename columns\n","column_renames = {\n","    'Publication date': 'publication_date',\n","    'Parameters': 'param',\n","    'Perplexity (WT103)': 'ppl_wt103',\n","    'Perplexity (WT2)': 'ppl_wt2',\n","    'Perplexity (PTB)': 'ppl_ptb',\n","    'Dataset Size': 'dataset',\n","    'System': 'system',\n","    'Epoch': 'epoch',\n","    'Include?': 'include',\n","    'Zero-shot?': 'zero_shot',\n","    'Citations': 'cites',\n","    'Peer reviewed?': 'peer_reviewed',\n","    'Outlier?': 'outlier'\n","}\n","df = df.rename(columns=column_renames)\n","\n","# convert publication date to datetime format\n","def convert_to_fraction_of_year(date):\n","    return date.year + (date.dayofyear - 1) / 365.0\n","df['publication_date'] = pd.to_datetime(df['publication_date'], format='%Y/%m/%d', errors='coerce')\n","df['publication_date'] = df['publication_date'].apply(convert_to_fraction_of_year)\n","\n","# convert param and data to numeric values\n","df['param'] = pd.to_numeric(df['param'], errors='coerce')\n","df['dataset'] = pd.to_numeric(df['dataset'], errors='coerce')\n","\n","# drop rows when 0 or NaN\n","df.dropna(subset=['param', 'dataset'], inplace=True)\n","df = df.loc[(df['param'] > 0) & (df['dataset'] > 0)]\n","df = df.loc[(df['include'] != 0)]\n","df = df.loc[(df['outlier'] != 1)]\n","\n","df.dropna(subset=['ppl_wt103', 'ppl_wt2', 'ppl_ptb'], how='all', inplace=True)\n","df.reset_index(drop=True, inplace=True) # reset the index of the dataframe after dropping rows\n","\n","# perplexity data\n","df['ppl'] = df['ppl_wt103'].fillna(df['ppl_wt2']).fillna(df['ppl_ptb']) # single ppl column\n","\n","def safe_log(column): # modified logarithm for handling possible zero values\n","    return np.where(column != 0, np.log(column), np.nan)\n","for col in ['param', 'dataset', 'ppl_wt103', 'ppl_wt2', 'ppl_ptb', 'ppl']:\n","    df[f'log_{col}'] = safe_log(df[col])"]},{"cell_type":"markdown","metadata":{"id":"oaJ4RMT9fVzA"},"source":["Prepare data for algorithmic progress analysis. This is where we exclude models where the data is particularly uncertain or are clear outliers."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"G_cPBKdIfVzE"},"outputs":[],"source":["# filter models and form new df\n","df_wt103 = df.dropna(subset=['log_ppl_wt103'])\n","df_wt2 = df.dropna(subset=['log_ppl_wt2'])\n","df_ptb = df.dropna(subset=['log_ppl_ptb'])\n","df1 = pd.concat([\n","    df_wt103.assign(dataset_name='wt103'),\n","    df_wt2.assign(dataset_name='wt2'),\n","    df_ptb.assign(dataset_name='ptb')\n","])\n","len_before_filter = len(df1)\n","\n","# name systems based on dataset\n","df1['system_dataset'] = df1['system'].str.cat(df1['dataset_name'], sep='_')\n","df1['dataset_name'] = df1['dataset_name'].astype('category') # convert to categorical\n","dataset_idx = df1['dataset_name'].cat.codes.values\n","\n","# create dummies for benchmarks\n","df1['ptb_dummy'] = (df1['dataset_name'] == 'ptb').astype(int)\n","df1['wt2_dummy'] = (df1['dataset_name'] == 'wt2').astype(int)\n","\n","# drop models\n","df1= df1[(df1['uncertain']==0)]\n","columns_to_check = ['log_param', 'log_dataset', 'publication_date', 'ppl']\n","df1 = df1[~df1[columns_to_check].replace([np.inf, -np.inf], np.nan).isnull().any(axis=1)]\n","\n","# sort by reference and ppl\n","df1 = df1.sort_values(['Reference', 'ppl'], ascending=[True, True])"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":5,"status":"ok","timestamp":1709234590146,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"D7ZMe5qjfgd0","outputId":"0a2a0068-ad87-4317-c38f-2f7901da0100"},"outputs":[{"name":"stdout","output_type":"stream","text":["Original 'param' values:\n","Gopher (280B): [2.8e+11]\n","Gopher (7.1B): [7.1e+09]\n","\n","Updated 'param' values:\n","Gopher (280B): [2.8e+11]\n","Gopher (7.1B): [7.1e+09]\n"]}],"source":["mask = df1['system'] == \"GPT3-6.7B + muP\"\n","index_to_drop = df1[mask].index\n","df1 = df1.drop(index_to_drop)\n","\n","mask = df1['system'] == \"LLaMA-65B (LoRA finetuned)\"\n","index_to_drop = df1[mask].index\n","df1 = df1.drop(index_to_drop)\n","\n","mask = df1['system'] == \"LLaMA-13B (LoRA finetuned)\"\n","index_to_drop = df1[mask].index\n","df1 = df1.drop(index_to_drop)\n","\n","mask = df1['system'] == \"LLaMA-7B (LoRA finetuned)\"\n","index_to_drop = df1[mask].index\n","df1 = df1.drop(index_to_drop)\n","\n","# Print original 'param' values for 'Gopher (280B)' and 'Gopher (7.1B)'\n","print(\"Original 'param' values:\")\n","print(\"Gopher (280B):\", df1.loc[df1['system'] == 'Gopher (280B)', 'param'].values)\n","print(\"Gopher (7.1B):\", df1.loc[df1['system'] == 'Gopher (7.1B)', 'param'].values)\n","\n","# Apply the changes\n","df1.loc[df1['system'] == 'Gopher (280B)', 'param'] = 280e9\n","df1.loc[df1['system'] == 'Gopher (7.1B)', 'param'] = 7.1e9\n","\n","# Print updated 'param' values for 'Gopher (280B)' and 'Gopher (7.1B)'\n","print(\"\\nUpdated 'param' values:\")\n","print(\"Gopher (280B):\", df1.loc[df1['system'] == 'Gopher (280B)', 'param'].values)\n","print(\"Gopher (7.1B):\", df1.loc[df1['system'] == 'Gopher (7.1B)', 'param'].values)"]},{"cell_type":"markdown","metadata":{"id":"_c5KeRI9fVzF"},"source":["One problem that we encounter is managing correlation between the models, due to multiple models coming from the same paper. To try and fix this issue we consider two possible approaches:\n","1. Keeping only the top 3 models per paper\n","2. Keeping track of the clusters and adjusting for this\n","\n","The code below collects the data for this. We primarily use the first approach, and we show that our results are unchanged when we use the second approach in the appendix."]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":4,"status":"ok","timestamp":1709234590146,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"_E73krW6fVzG","outputId":"77bdbf46-5f82-4ac0-a7b1-c7062e444858"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total dropped rows (head): 50\n","Total dropped rows (cluster): 20\n"]}],"source":["# keep only the top 3 models per paper\n","df_head = df1.copy(deep=True)\n","df_head = df_head.groupby('Reference').head(3)\n","df_head.reset_index(drop=True, inplace=True)\n","print(\"Total dropped rows (head):\", len_before_filter - len(df_head))\n","\n","# cluster the models by paper and number the clusters\n","df_cluster = df1.copy(deep=True)\n","df_cluster['cluster'] = df_cluster.groupby('Reference').ngroup()\n","df_cluster.reset_index(drop=True, inplace=True)\n","print(\"Total dropped rows (cluster):\", len_before_filter - len(df_cluster))"]},{"cell_type":"markdown","metadata":{"id":"IPT9uxbAfVzH"},"source":["## Useful functions"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"m5s-j-zaDub_"},"outputs":[],"source":["def safe_max(arr):\n","    return max(arr) if arr else None"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"a1G1rhjPDub_"},"outputs":[],"source":["# Plotting utilities\n","\n","from contextlib import contextmanager\n","\n","# These should probably be moved to egraphs\n","style_overwrites = {\n","    'axes.labelsize': 6.75,\n","    'xtick.labelsize': 6,\n","    'ytick.labelsize': 6,\n","    'font.size': 6,\n","    'grid.linewidth': 1,\n","    'axes.linewidth': 1,\n","    'ytick.major.size': 4.5 - 0.87/2,\n","    'ytick.minor.size': 4.5 - 0.87/2,\n","    'xtick.major.size': 4 - 0.87/2,\n","    'xtick.minor.size': 4 - 0.87/2,\n","}\n","\n","@contextmanager\n","def epoch_theme(*args, **kwargs):\n","    with egraphs.epoch_theme(*args, **kwargs):\n","        with mpl.rc_context(style_overwrites):\n","            yield\n","\n","def relayout(*args, **kwargs):\n","    egraphs.relayout(*args, **kwargs)\n","\n","common_rc_params = {\n","    'xtick.labelcolor': 'black',\n","    'ytick.labelcolor': 'black',\n","    'xtick.color': '#a4b0b1',\n","    'ytick.color': '#a4b0b1',\n","    'axes.labelcolor': 'black',\n","    'text.color': 'black',\n","    'grid.linewidth': 1,\n","    'axes.linewidth': 1,\n","    'axes.edgecolor': '#a4b0b1',\n","\n","    'ytick.major.size': 3.5,\n","    'ytick.minor.size': 3.5,\n","    'xtick.major.size': 3.5,\n","    'xtick.minor.size': 3.5,\n","    'xtick.major.pad': 0.7,\n","    'xtick.minor.pad': 0.7,\n","}\n","\n","subplot_rc_params = {\n","    **common_rc_params,\n","\n","    'axes.labelsize': egraphs.px_to_pt(7),\n","    'ytick.labelsize': egraphs.px_to_pt(6),\n","    'xtick.labelsize': egraphs.px_to_pt(6),\n","\n","    'xtick.major.size': 3.5,\n","    'xtick.minor.size': 3.5,\n","    'xtick.major.pad': 0.5,\n","    'xtick.minor.pad': 0.5,\n","\n","    'ytick.major.size': 3.5,\n","    'ytick.minor.size': 3.5,\n","    'ytick.major.pad': 2,\n","    'ytick.minor.pad': 2,\n","\n","    'legend.fontsize': egraphs.px_to_pt(7),\n","    'legend.borderaxespad': 0.5,\n","}\n","\n","standalone_plot_rc_params = {\n","    **common_rc_params,\n","\n","    'axes.labelsize': egraphs.px_to_pt(8),\n","    'ytick.labelsize': egraphs.px_to_pt(7),\n","    'xtick.labelsize': egraphs.px_to_pt(7),\n","\n","    'legend.fontsize': egraphs.px_to_pt(8),\n","}\n","\n","standalone_xaxis_labelpad = 4\n","standalone_padding = {'left': 1, 'top': 5, 'right': 1, 'bottom': 10}\n","standalone_fig_size = egraphs.px_to_in((580 + 20, 299 + 10))\n","\n","# To correct figure sizes :_(\n","px_scale_factor = 1.1"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"sR5xZ0VtfVzH"},"outputs":[],"source":["def doubling_to_x_per_year(doubling):\n","    \"\"\"\n","    convert doubling times to Nx/year,\n","    e.g. if doubling time = 1 year, this returns 2x/year\n","\n","    doubling time argument should be in years\n","    \"\"\"\n","    if doubling is None: return None\n","    return 2 ** np.reciprocal(doubling)\n","\n","def doubling_to_oom(doubling):\n","    \"\"\"\n","    convert doubling times to OOM/year\n","    \"\"\"\n","    if doubling is None: return None\n","    return np.reciprocal(doubling) * np.log10(2)\n","\n","def oom_to_doubling(oom_per_year):\n","    \"\"\"\n","    convert from OOM/year to doubling time in years\n","    \"\"\"\n","    return np.log10(2) / oom_per_year\n","\n","def data_filter(values, confidence_interval):\n","    \"\"\"\n","    filter values to the given confidence interval\n","    \"\"\"\n","    values = np.array(values)\n","    lower, upper = np.percentile(values, [50 - confidence_interval/2, 50 + confidence_interval/2])\n","    mask = (values > lower) & (values < upper)\n","    return values[mask]\n","\n","def variance(weights, vector1, vector2, vector3):\n","    \"\"\"\n","    function for aggregating doubling times from three different models (one array per model)\n","    chooses weights in a convex combination to obtain a pooled score vector,\n","    then calculate the variance of this vector\n","    \"\"\"\n","    pool = weights[0] * vector1 + weights[1] * vector2 + weights[2] * vector3\n","    return np.var(pool)\n","\n","def prime(param, param_ptb, param_wt2, category_ptb, category_wt2):\n","    return param + param_ptb * category_ptb + param_wt2 * category_wt2\n","\n","def log_diff(value, constant):\n","    return np.log(value) - np.log(constant)\n","\n","def build_model(alpha_terms, beta_terms):\n","    return np.exp(alpha_terms) + np.exp(beta_terms)\n","\n","def print_stats(data, ci):\n","\n","  if len(data) == 2:\n","    nt, t = data\n","    print(\"Non-transformer\", np.percentile(nt, [50-ci/2, 50, 50+ci/2]))\n","    print(\"Transformer\", np.percentile(t, [50-ci/2, 50, 50+ci/2]))\n","\n","  elif len(data) == 3:\n","    wt103, ptb, wt2 = data\n","    print(\"WT103\", np.percentile(wt103, [50-ci/2, 50, 50+ci/2]))\n","    print(\"PTB\", np.percentile(ptb, [50-ci/2, 50, 50+ci/2]))\n","    print(\"WT2\", np.percentile(wt2, [50-ci/2, 50, 50+ci/2]))\n","\n","  else:\n","    print(np.percentile(data, [50-ci/2, 50, 50+ci/2]))\n","\n","def doubling_times_plot(model_doubling_times, ci, ax=None, num_bootstraps=100, fontsize=12, legend=True, **kwargs):\n","\n","  title = kwargs.get('title',\"\")\n","  xlabel = kwargs.get('xlabel', 'Doubling Time (Years)')\n","  ylabel = kwargs.get('ylabel', 'Density')\n","  label = kwargs.get('label', None)\n","  xlim = kwargs.get('xlim', None)\n","  xscale = kwargs.get('xscale', 'linear')\n","\n","  if model_doubling_times is None:\n","    # sns.kdeplot(np.zeros(num_bootstraps))\n","    pass\n","\n","  elif len(model_doubling_times) == 2:\n","    model_doubling_nt, model_doubling_t = model_doubling_times\n","    sns.kdeplot(data_filter(model_doubling_nt, ci), label=f'nt', ax=ax)\n","    sns.kdeplot(data_filter(model_doubling_t, ci), label=f't', ax=ax)\n","    if legend:\n","      if ax != None: ax.legend()\n","\n","  elif len(model_doubling_times) == 3:\n","    model_doubling_wt103, model_doubling_ptb, model_doubling_wt2 = model_doubling_times\n","    sns.kdeplot(data_filter(model_doubling_wt103, ci), label=f'wt103', ax=ax)\n","    sns.kdeplot(data_filter(model_doubling_ptb, ci), label=f'ptb', ax=ax)\n","    sns.kdeplot(data_filter(model_doubling_wt2, ci), label=f'wt2', ax=ax)\n","    if legend:\n","      if ax != None: ax.legend()\n","\n","  else:\n","    sns.kdeplot(data_filter(model_doubling_times, ci), ax=ax, label=label)\n","\n","  if ax != None:\n","    ax.set_title(title, fontsize=fontsize)\n","    ax.set_xlabel(xlabel, fontsize=fontsize)\n","    ax.set_ylabel(ylabel, fontsize=fontsize)\n","    ax.set_xscale(xscale)\n","    ax.legend()\n","    if xlim is not None:\n","      x_min, x_max = xlim\n","      ax.set_xlim(x_min, x_max)\n","\n","  else:\n","    plt.title(title, fontsize=fontsize)\n","    plt.xlabel(xlabel, fontsize=fontsize)\n","    plt.ylabel(ylabel, fontsize=fontsize)\n","    plt.xscale(xscale)\n","    plt.legend()\n","    if xlim is not None:\n","      x_min, x_max = xlim\n","      plt.xlim(x_min, x_max)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"52hXSGWUys03"},"outputs":[],"source":["def estimate_doubling_times(model_num, bootstrap_results):\n","    \"\"\"\n","    estimate doubling times for models 1 to 13\n","    \"\"\"\n","    param_names = PARAMS_MAPPING[model_num]\n","    bootstrap_array = np.array(bootstrap_results).T\n","    pred_params = {name: bootstrap_array[i] for i, name in enumerate(param_names)}\n","\n","    def doubling_times(scale_exponent, year_exponent):\n","      return scale_exponent / year_exponent * np.log(2)\n","\n","    param_doubling, data_doubling, compute_doubling = None, None, None\n","\n","    if model_num in {1}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      compute_doubling = (1/param_doubling + 1/data_doubling) ** (-1)\n","\n","    elif model_num in {2}:\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      compute_doubling = data_doubling\n","\n","    elif model_num in {3}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      compute_doubling = param_doubling\n","\n","    elif model_num in {4}:\n","      param_doubling_wt103 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      param_doubling_ptb = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_ptb\"])\n","      param_doubling_wt2 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_wt2\"])\n","      param_doubling = (param_doubling_wt103, param_doubling_ptb, param_doubling_wt2)\n","\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","\n","      compute_doubling_wt103 = (1/param_doubling_wt103 + 1/data_doubling) ** (-1)\n","      compute_doubling_ptb = (1/param_doubling_ptb + 1/data_doubling) ** (-1)\n","      compute_doubling_wt2 = (1/param_doubling_wt2 + 1/data_doubling) ** (-1)\n","      compute_doubling = (compute_doubling_wt103, compute_doubling_ptb, compute_doubling_wt2)\n","\n","    elif model_num in {5}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","\n","      data_doubling_wt103 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      data_doubling_ptb = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_ptb\"])\n","      data_doubling_wt2 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_wt2\"])\n","      data_doubling = (data_doubling_wt103, data_doubling_ptb, data_doubling_wt2)\n","\n","      compute_doubling_wt103 = (1/param_doubling + 1/data_doubling_wt103) ** (-1)\n","      compute_doubling_ptb = (1/param_doubling + 1/data_doubling_ptb) ** (-1)\n","      compute_doubling_wt2 = (1/param_doubling + 1/data_doubling_wt2) ** (-1)\n","      compute_doubling = (compute_doubling_wt103, compute_doubling_ptb, compute_doubling_wt2)\n","\n","    elif model_num in {6}:\n","      param_doubling_wt103 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      param_doubling_ptb = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_ptb\"])\n","      param_doubling_wt2 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_wt2\"])\n","      param_doubling = (param_doubling_wt103, param_doubling_ptb, param_doubling_wt2)\n","\n","      data_doubling_wt103 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      data_doubling_ptb = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_ptb\"])\n","      data_doubling_wt2 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_wt2\"])\n","      data_doubling = (data_doubling_wt103, data_doubling_ptb, data_doubling_wt2)\n","\n","      compute_doubling_wt103 = (1/param_doubling_wt103 + 1/data_doubling_wt103) ** (-1)\n","      compute_doubling_ptb = (1/param_doubling_ptb + 1/data_doubling_ptb) ** (-1)\n","      compute_doubling_wt2 = (1/param_doubling_wt2 + 1/data_doubling_wt2) ** (-1)\n","      compute_doubling = (compute_doubling_wt103, compute_doubling_ptb, compute_doubling_wt2)\n","\n","    elif model_num in {7}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      compute_doubling = (1/param_doubling + 1/data_doubling) ** (-1)\n","\n","    elif model_num in {8}:\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      compute_doubling = data_doubling\n","\n","    elif model_num in {9}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      compute_doubling = param_doubling\n","\n","    elif model_num in {10}:\n","      param_doubling_wt103 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      param_doubling_ptb = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_ptb\"])\n","      param_doubling_wt2 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_wt2\"])\n","      param_doubling = (param_doubling_wt103, param_doubling_ptb, param_doubling_wt2)\n","\n","      data_doubling_wt103 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      data_doubling_ptb = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_ptb\"])\n","      data_doubling_wt2 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_wt2\"])\n","      data_doubling = (data_doubling_wt103, data_doubling_ptb, data_doubling_wt2)\n","\n","      compute_doubling_wt103 = (1/param_doubling_wt103 + 1/data_doubling_wt103) ** (-1)\n","      compute_doubling_ptb = (1/param_doubling_ptb + 1/data_doubling_ptb) ** (-1)\n","      compute_doubling_wt2 = (1/param_doubling_wt2 + 1/data_doubling_wt2) ** (-1)\n","      compute_doubling = (compute_doubling_wt103, compute_doubling_ptb, compute_doubling_wt2)\n","\n","    elif model_num in {11}:\n","      param_doubling_wt103 = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      param_doubling_ptb = doubling_times(pred_params[\"alpha_param\"] + pred_params[\"alpha_param_ptb\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_ptb\"])\n","      param_doubling_wt2 = doubling_times(pred_params[\"alpha_param\"] + pred_params[\"alpha_param_wt2\"], pred_params[\"alpha_year\"] + pred_params[\"alpha_year_wt2\"])\n","      param_doubling = (param_doubling_wt103, param_doubling_ptb, param_doubling_wt2)\n","\n","      data_doubling_wt103 = doubling_times(pred_params[\"beta_data\"], pred_params[\"beta_year\"])\n","      data_doubling_ptb = doubling_times(pred_params[\"beta_data\"] + pred_params[\"beta_data_ptb\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_ptb\"])\n","      data_doubling_wt2 = doubling_times(pred_params[\"beta_data\"] + pred_params[\"beta_data_wt2\"], pred_params[\"beta_year\"] + pred_params[\"beta_year_wt2\"])\n","      data_doubling = (data_doubling_wt103, data_doubling_ptb, data_doubling_wt2)\n","\n","      compute_doubling_wt103 = (1/param_doubling_wt103 + 1/data_doubling_wt103) ** (-1)\n","      compute_doubling_ptb = (1/param_doubling_ptb + 1/data_doubling_ptb) ** (-1)\n","      compute_doubling_wt2 = (1/param_doubling_wt2 + 1/data_doubling_wt2) ** (-1)\n","      compute_doubling = (compute_doubling_wt103, compute_doubling_ptb, compute_doubling_wt2)\n","\n","    elif model_num in {12}:\n","      param_doubling = doubling_times(pred_params[\"alpha_param\"], pred_params[\"alpha_year\"])\n","      data_doubling = doubling_times(pred_params[\"beta_data\"], pred_params[\"alpha_year\"])\n","      compute_doubling = (1/param_doubling + 1/data_doubling) ** (-1)\n","\n","    elif model_num in {13}:\n","      param_doubling_nt = pred_params['alpha_param'] / pred_params['alpha_year'] * np.log(2)\n","      param_doubling_t = pred_params['alpha_param_t'] / pred_params['alpha_year'] * np.log(2)\n","      param_doubling = (param_doubling_nt, param_doubling_t)\n","\n","      data_doubling_nt = pred_params['beta_data'] / pred_params['beta_year'] * np.log(2)\n","      data_doubling_t = pred_params['beta_data_t'] / pred_params['beta_year'] * np.log(2)\n","      data_doubling = (data_doubling_nt, data_doubling_t)\n","\n","      compute_doubling_nt = (1/param_doubling_nt + 1/data_doubling_nt) ** (-1)\n","      compute_doubling_t = (1/param_doubling_t + 1/data_doubling_t) ** (-1)\n","      compute_doubling = (compute_doubling_nt, compute_doubling_t)\n","\n","    return param_doubling, data_doubling, compute_doubling"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"5r04dOBfZHdc"},"outputs":[],"source":["def compute_doubling_numerical(params, model_num, year, category_ptb=0, category_wt2=0, category_transformer=1, compute=1e25):\n","    \"\"\"\n","    estimates effective compute doubling times for all models using a numerical approach\n","    \"\"\"\n","    # param_names = PARAMS_MAPPING[model_num]\n","    # bootstrap_array = np.array(bootstrap_results).T\n","    # pred_params = {name: bootstrap_array[i] for i, name in enumerate(param_names)}\n","\n","    compute_doubling = None\n","    C1, C2 = compute, 2 * compute\n","    # params = params_optimized.values\n","\n","    def CEL(x, params, year):\n","        log_param, log_data = x\n","        if model_num in {13, 17}:\n","            # print(model_name(params, year, np.exp(log_param), np.exp(log_data), category_ptb, category_wt2, category_transformer))\n","            return model_name(params, year, np.exp(log_param), np.exp(log_data), category_ptb, category_wt2, category_transformer)\n","        else:\n","            return model_name(params, year, np.exp(log_param), np.exp(log_data), category_ptb, category_wt2)\n","\n","    def constraint_eq(x, C):\n","        \"\"\"\n","        physical compute constraint C = 6ND\n","        \"\"\"\n","        log_param, log_data = x\n","        return log_param + log_data + np.log(6) - np.log(float(C))\n","\n","    def optimize_and_evaluate(C, params, year=2023):\n","        \"\"\"\n","        minimize cross entropy loss given constraint\n","        \"\"\"\n","        initial_guess = [np.log(C**0.5), np.log(C**0.5)]\n","        con = {'type': 'eq', 'fun': lambda x: constraint_eq(x, C)}\n","        result = minimize(CEL, initial_guess, args=(params, year), constraints=con)\n","        return np.exp(result.x), CEL(result.x, params, year)\n","\n","    # Estimate optimal param, data and loss after doubling of compute budget\n","    optimized_nd1, loss_C1 = optimize_and_evaluate(C1, params, year)\n","    optimized_nd2, loss_C2 = optimize_and_evaluate(C2, params, year)\n","    # print(optimized_nd1, loss_C1)\n","    # print(optimized_nd2, loss_C2)\n","\n","    def optimal_scaling_doubling_time(opt_params, params, target_loss):\n","        \"\"\"\n","        determine years of algorithmic progress required to obtain equivalent loss reduction\n","        \"\"\"\n","        def to_minimize(delta):\n","            new_year = year + delta\n","            return np.abs(CEL(opt_params, params, year=new_year) - target_loss)\n","\n","        result = minimize_scalar(to_minimize)\n","        return result.x\n","\n","    # print(np.log(optimized_nd1), params)\n","    doubling_time = optimal_scaling_doubling_time(np.log(optimized_nd1), params, loss_C2)\n","    # print(f\"Doubling time is: {doubling_time} years\")\n","    return doubling_time"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"ABA_FEhPaOC_"},"outputs":[],"source":["def bootstrap_to_latex(text, param_names, pval_df):\n","    # match bootstrap output text\n","    param_pattern = r\"([\\w_]+):\"\n","    num_pattern = r\"([-+]?\\d*\\.\\d+e*[-+]?\\d*)\"\n","    pattern = f\"{param_pattern}\\s*{num_pattern}\\s*CI:\\s*\\[{num_pattern}\\s+{num_pattern}\\s*\\]\\s*SE:\\s*{num_pattern}\"\n","    matches = re.findall(pattern, text)\n","\n","    if len(matches) != len(param_names):\n","        raise ValueError(\"The number of matches does not match the number of parameter names.\")\n","\n","    formatted_rows = []\n","    for match_item in matches:\n","        param, estimate, ci_lower, ci_upper, se = match_item\n","        pattern = r\"([\\w_]+)_opt\"\n","        param_name = re.findall(pattern, param)[0]\n","\n","        num_stars = sum(pval_df.loc[param_name, [\"*\", \"**\", \"***\"]])\n","        if num_stars == 0:\n","          star_sign = r\"\\nosign\"\n","        elif num_stars == 1:\n","          star_sign = r\"\\sign\"\n","        elif num_stars == 2:\n","          star_sign = r\"\\signn\"\n","        elif num_stars == 3:\n","          star_sign = r\"\\signnn\"\n","\n","        formatted_row = f\"    ${param_names.pop(0)}$ & \\\\begin{{tabular}}[c]{{@{{}}c@{{}}}}$\\\\underset{{({float(se):.3f})}}{{{float(estimate):.3f}}}$ {star_sign} \\\\end{{tabular}} & ${float(ci_lower):.3f}, {float(ci_upper):.3f}$ \\\\\\\\\"\n","        formatted_rows.append(formatted_row)\n","\n","    # create LaTeX table\n","    formatted_table = \"\\\\begin{tabular}{@{}lcc@{}}\\n    \\\\toprule\\n     & Estimate & 95\\\\% CI \\\\\\\\ \\\\midrule\\n\" + \"\\n\".join(formatted_rows) + \"\\n    \\\\bottomrule\\n    \\\\end{tabular}\"\n","\n","    return formatted_table"]},{"cell_type":"markdown","metadata":{"id":"Inm3-HLHf3CU"},"source":["## Model definitions"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":219,"status":"ok","timestamp":1709234590591,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"ibug-hBZbrHT","outputId":"018ed451-0a06-45e3-f25b-e1c3ea6e749c"},"outputs":[{"name":"stdout","output_type":"stream","text":["Model 1: 6 parameters\n","Model 2: 5 parameters\n","Model 3: 5 parameters\n","Model 4: 8 parameters\n","Model 5: 8 parameters\n","Model 6: 10 parameters\n","Model 7: 10 parameters\n","Model 8: 9 parameters\n","Model 9: 9 parameters\n","Model 10: 14 parameters\n","Model 11: 18 parameters\n","Model 12: 9 parameters\n","Model 13: 12 parameters\n","Model 14: 10 parameters\n","Model 15: 12 parameters\n","Model 16: 8 parameters\n","Model 17: 10 parameters\n","Model 18: 5 parameters\n","Model 19: 11 parameters\n","Model 20: 10 parameters\n"]}],"source":["PARAMS_MAPPING = {\n","    1: ('alpha_const', 'alpha_year', 'alpha_param', 'beta_const', 'beta_year', 'beta_data'),\n","    2: ('alpha_const', 'alpha_param', 'beta_const', 'beta_year', 'beta_data'),\n","    3: ('alpha_const', 'alpha_year', 'alpha_param', 'beta_const', 'beta_data'),\n","    4: ('alpha_const', 'alpha_year', 'alpha_year_ptb', 'alpha_year_wt2', 'alpha_param', \\\n","        'beta_const', 'beta_year', 'beta_data'),\n","    5: ('alpha_const', 'alpha_year', 'alpha_param', 'beta_const', 'beta_year', 'beta_year_ptb', \\\n","        'beta_year_wt2', 'beta_data'),\n","    6: ('alpha_const', 'alpha_year', 'alpha_year_ptb', 'alpha_year_wt2', 'alpha_param', \\\n","        'beta_const', 'beta_year', 'beta_year_ptb', 'beta_year_wt2', 'beta_data'),\n","    7: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data'),\n","    8: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data'),\n","    9: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_data'),\n","    10: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_year_ptb', 'alpha_year_wt2', 'alpha_param', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_year_ptb', 'beta_year_wt2', 'beta_data'),\n","    11: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_year_ptb', 'alpha_year_wt2', 'alpha_param', 'alpha_param_ptb', 'alpha_param_wt2', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_year_ptb', 'beta_year_wt2', 'beta_data', 'beta_data_ptb', 'beta_data_wt2'),\n","    12: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_data'),\n","    13: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', 'alpha_param_t', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data', 'beta_data_t'),\n","    14: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_param', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_data', 'alpha_rate', 'beta_rate'),\n","    15: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data', 'alpha_rate', 'beta_rate'),\n","    16: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_data'),\n","    17: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_param', 'alpha_param_t', \\\n","          'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_data', 'beta_data_t'),\n","    18: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_compute'),\n","    19: ('gamma', 'alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data'),\n","    20: ('alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","        'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data'),\n","}\n","\n","# Extracts the parameters based on model number\n","def extract_params(model_num, params):\n","    param_names = PARAMS_MAPPING[model_num]\n","    return [params[i] for i, name in enumerate(param_names)]\n","\n","def model_1(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_year, alpha_param, beta_const, beta_year, beta_data = extract_params(1, params)\n","    alpha_terms = (alpha_const - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_2(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_param, beta_const, beta_year, beta_data = extract_params(2, params)\n","    alpha_terms = (alpha_const - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_3(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_year, alpha_param, beta_const, beta_data = extract_params(3, params)\n","    alpha_terms = (alpha_const - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_4(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_year, alpha_year_ptb, alpha_year_wt2, alpha_param, beta_const, beta_year, beta_data = extract_params(4, params)\n","    alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const - alpha_year_prime * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_5(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_year, alpha_param, beta_const, beta_year, beta_year_ptb, beta_year_wt2, beta_data = extract_params(5, params)\n","    beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_year_prime * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_6(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_year, alpha_year_ptb, alpha_year_wt2, alpha_param, beta_const, beta_year, beta_year_ptb, beta_year_wt2, beta_data = extract_params(6, params)\n","    alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","    beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const - alpha_year_prime * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const - beta_year_prime * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_7(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data = extract_params(7, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_8(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data = extract_params(8, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_9(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_data = extract_params(9, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_10(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_year_ptb, alpha_year_wt2, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_year_ptb, beta_year_wt2, beta_data = extract_params(10, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year_prime * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year_prime * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_11(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_year_ptb, alpha_year_wt2, alpha_param, alpha_param_ptb, alpha_param_wt2, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_year_ptb, beta_year_wt2, beta_data, beta_data_ptb, beta_data_wt2 = extract_params(11, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","    alpha_param_prime = prime(alpha_param, alpha_param_ptb, alpha_param_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","    beta_data_prime = prime(beta_data, beta_data_ptb, beta_data_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year_prime * (year - year_const) - alpha_param_prime * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year_prime * (year - year_const) - beta_data_prime * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_12(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_data = extract_params(12, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_data * log_diff(dataset, dataset_const))\n","    combined_exp = np.exp(-alpha_year * (year - year_const))\n","    return build_model(alpha_terms, beta_terms) * combined_exp\n","\n","def model_13(params, year, param, dataset, category_ptb, category_wt2, category_transformer):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, alpha_param_t, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data, beta_data_t = extract_params(13, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_param_prime = alpha_param * (1 - category_transformer) + alpha_param_t * category_transformer\n","    beta_data_prime = beta_data * (1 - category_transformer) + beta_data_t * category_transformer\n","\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_param_prime * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year * (year - year_const) - beta_data_prime * log_diff(dataset, dataset_const))\n","\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_14(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_param, \\\n","    beta_const, beta_const_ptb, beta_const_wt2, beta_data, alpha_rate, beta_rate = extract_params(14, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","\n","    alpha_param_prime = alpha_param + alpha_rate * np.log(year) #np.log(year - year_const + 1)\n","    beta_data_prime = beta_data + beta_rate * np.log(year) #np.log(year - year_const + 1)\n","\n","    param_terms = alpha_const_prime - alpha_param_prime * (np.log(param) - np.log(param_const))\n","    data_terms = beta_const_prime - beta_data_prime * (np.log(dataset) - np.log(dataset_const))\n","\n","    return build_model(param_terms, data_terms)\n","\n","def model_15(params, year, param, dataset, category_ptb, category_wt2):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, \\\n","    beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data, alpha_rate, beta_rate = extract_params(15, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","\n","    alpha_param_prime = alpha_param + alpha_rate * np.log(year)\n","    beta_data_prime = beta_data + beta_rate * np.log(year)\n","\n","    param_terms = alpha_const_prime - alpha_year * (year - year_const) - alpha_param_prime * (np.log(param) - np.log(param_const))\n","    data_terms = beta_const_prime - beta_year * (year - year_const) - beta_data_prime * (np.log(dataset) - np.log(dataset_const))\n","\n","    return build_model(param_terms, data_terms)\n","\n","def model_16(params, year, param, dataset, category_ptb, category_wt2):\n","    \"\"\"\n","    chinchilla with benchmark-specific coefficients. no algorithmic progress\n","    \"\"\"\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_data = extract_params(16, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_17(params, year, param, dataset, category_ptb, category_wt2, category_transformer):\n","    \"\"\"\n","    different scaling exponents for transformers vs non-transformer, and no other algorithmimc progress\n","    \"\"\"\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_param, alpha_param_t, beta_const, beta_const_ptb, beta_const_wt2, beta_data, beta_data_t = extract_params(17, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_param_prime = alpha_param * (1 - category_transformer) + alpha_param_t * category_transformer\n","    beta_data_prime = beta_data * (1 - category_transformer) + beta_data_t * category_transformer\n","\n","    alpha_terms = (alpha_const_prime - alpha_param_prime * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_data_prime * log_diff(dataset, dataset_const))\n","\n","    return build_model(alpha_terms, beta_terms)\n","\n","def model_18(params, year, param, dataset, category_ptb, category_wt2):\n","    \"\"\"\n","    compute only\n","    \"\"\"\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_compute = extract_params(18, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","\n","    compute = 6 * param * dataset\n","    compute_const = np.min(compute)\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_compute * log_diff(compute, compute_const))\n","    return np.exp(alpha_terms)\n","\n","def model_19(params, year, param, dataset, category_ptb, category_wt2, vocab):\n","    \"\"\"\n","    vocab size\n","    \"\"\"\n","    gamma, alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data = extract_params(19, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return gamma * np.log(vocab) + build_model(alpha_terms, beta_terms)\n","\n","def model_20(params, year, param, dataset, category_ptb, category_wt2):\n","    \"\"\"\n","    same as model 7, but with imputed epochs\n","    \"\"\"\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data = extract_params(20, params)\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_terms = (alpha_const_prime - alpha_year * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","    return build_model(alpha_terms, beta_terms)\n","\n","def residuals(params, model_func, year, param, dataset, category_ptb, category_wt2, log_ppl, delta, category_transformer=None, vocab=None):\n","    if model_func in {model_13, model_17}:\n","        residuals_val = log_ppl - model_func(params, year, param, dataset, category_ptb, category_wt2, category_transformer)\n","    elif model_func == model_19:\n","        residuals_val = log_ppl - model_func(params, year, param, dataset, category_ptb, category_wt2, vocab)\n","    else:\n","        residuals_val = log_ppl - model_func(params, year, param, dataset, category_ptb, category_wt2)\n","\n","    l1_reg = delta * np.sum(np.abs(params))\n","    # print(\"residual start\")\n","    val = np.mean(np.square(residuals_val)) + l1_reg\n","    # print(\"residual end\")\n","    return val\n","\n","def num_params_in_model(model_num):\n","    return len(PARAMS_MAPPING[model_num])\n","\n","model_numbers = np.arange(1, len(PARAMS_MAPPING) + 1, 1)\n","for model_num in model_numbers:\n","    length = num_params_in_model(model_num)\n","    print(f\"Model {model_num}: {length} parameters\")"]},{"cell_type":"markdown","metadata":{"id":"MAQR9wY6h5gu"},"source":["# Main model"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":5,"status":"ok","timestamp":1709234590591,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"aVG59VTbhwe-","outputId":"a378cb73-4254-450a-b146-9399fca179f4"},"outputs":[{"name":"stdout","output_type":"stream","text":["Current setup: model number 7, regularization strength delta = 0.0025\n"]}],"source":["model_name_str = \"model_7\"\n","delta = 0.0025#0.016\n","model_num = int(re.search(\"\\d+\", model_name_str)[0])\n","model_name = globals()[model_name_str]\n","\n","print(f\"Current setup: model number {model_num}, regularization strength delta = {delta}\")"]},{"cell_type":"markdown","metadata":{"id":"ANd4DrHXDSEr"},"source":["## Param estimates"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":1555676,"status":"ok","timestamp":1709236146263,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"W2j-ww52iSop","outputId":"dc586f86-74c1-4e19-f937-19d8fd2a103c"},"outputs":[{"name":"stdout","output_type":"stream","text":[" message: Optimization terminated successfully\n"," success: True\n","  status: 0\n","     fun: 0.05181292650905238\n","       x: [ 9.127e-01  3.788e-04  5.541e-02  3.938e-03  6.798e-02\n","            7.714e-01  1.764e-01  9.542e-02  3.562e-02  3.959e-02]\n","     nit: 18\n","     jac: [ 1.124e-03 -1.275e-04 -1.531e-04 -9.360e-03 -4.521e-03\n","            2.394e-04  8.244e-05  3.082e-04 -4.763e-03 -2.321e-03]\n","    nfev: 209\n","    njev: 18\n","\n","\n","Optimized parameters:\n","alpha_const        0.912701\n","alpha_const_ptb    0.000379\n","alpha_const_wt2    0.055412\n","alpha_year         0.003938\n","alpha_param        0.067982\n","beta_const         0.771409\n","beta_const_ptb     0.176415\n","beta_const_wt2     0.095418\n","beta_year          0.035620\n","beta_data          0.039587\n","dtype: float64\n"]}],"source":["df_main = df_head.copy(deep=True)\n","\n","# @markdown Want to subset data to post Transformer?\n","post_transformer = False # @param {type:\"boolean\"}\n","post_transformer = 1 if post_transformer else 0\n","\n","np.random.seed(0)\n","\n","num_params = num_params_in_model(model_num)\n","p0 = np.zeros(num_params)\n","\n","df_main['ptb_dummy'] = (df_main['dataset_name'] == 'ptb').astype(int)\n","df_main['wt2_dummy'] = (df_main['dataset_name'] == 'wt2').astype(int)\n","df_main['transformer'] = df_main['Architecture'].apply(lambda x: 1 if x == 'Transformer' else 0).astype(int)\n","\n","# subset data to post transformer only\n","df_main = df_main[df_main['publication_date'] > 2017.444 * post_transformer]\n","\n","# # subset data to non-transformers only\n","# df_main = df_main[df_main[\"transformer\"] == 0]\n","\n","year = df_main[\"publication_date\"]\n","param = df_main[\"param\"]\n","dataset = df_main[\"dataset\"]\n","log_ppl = df_main[\"log_ppl\"]\n","ptb_dummy = df_main['ptb_dummy']\n","wt2_dummy = df_main['wt2_dummy']\n","transformer_dummy = df_main['transformer']\n","\n","param_const = np.min(param)\n","dataset_const = np.min(dataset)\n","year_const = np.min(year)\n","\n","res = minimize(residuals, p0, args=(model_name, year, param, dataset, ptb_dummy, wt2_dummy, log_ppl, delta, transformer_dummy), method='SLSQP')\n","\n","print(res)\n","\n","print(\"\\n\")\n","params_optimized = pd.Series(res.x, index=PARAMS_MAPPING[model_num])\n","print(\"Optimized parameters:\")\n","print(params_optimized)"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":542},"executionInfo":{"elapsed":3057,"status":"ok","timestamp":1709236149318,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"Qq7Pot7HnKwe","outputId":"25a3e374-0810-4bbd-9002-3fcbee616aab"},"outputs":[{"data":{"text/html":["<html>\n","<head><meta charset=\"utf-8\" /></head>\n","<body>\n","    <div>            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-AMS-MML_SVG\"></script><script type=\"text/javascript\">if (window.MathJax && window.MathJax.Hub && window.MathJax.Hub.Config) {window.MathJax.Hub.Config({SVG: {font: \"STIX-Web\"}});}</script>                <script type=\"text/javascript\">window.PlotlyConfig = {MathJaxConfig: 'local'};</script>\n","        <script charset=\"utf-8\" src=\"https://cdn.plot.ly/plotly-2.27.0.min.js\"></script>                <div id=\"e2fdce30-30e8-4aec-a7f2-ce088c077f11\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"e2fdce30-30e8-4aec-a7f2-ce088c077f11\")) {                    Plotly.newPlot(                        \"e2fdce30-30e8-4aec-a7f2-ce088c077f11\",                        [{\"customdata\":[[\"$\\\\infty$-former (SM)\"],[\"LBL\"],[\"2nd order FOFE-FNNLM\"],[\"TSLM+MoS (WT2)\"],[\"TSLM+MoS (PTB)\"],[\"NMM(LSTM+RNN)\"],[\"NMST+GPT-2\"],[\"Tensorized Transformer (151M)\"],[\"Tensorized Transformer (core-2)\"],[\"Tensorized Transformer (257M)\"],[\"Variational (untied weights, MC) LSTM (Large)\"],[\"Transformer-XL+WN+AdamP\"],[\"Transformer-XL+AdamP\"],[\"Transformer (Adaptive Input Embeddings)\"],[\"Transformer+Recurrent Windows of Context\"],[\"Feedback Transformer\"],[\"RNN (SGD+CLR) (PTB)\"],[\"4 layer QRNN (h=2500)\"],[\"LSTM (2018)\"],[\"Search-Proven Best LSTM\"],[\"All-attention network + adaptive span\"],[\"Transformer-XL + AutoDropout (PTB)\"],[\"Transformer-XL + AutoDropout (WT2)\"],[\"AWD-LSTM+Behaviorial-Gating\"],[\"LSTM-Large+Behaviorial-Gating\"],[\"LSTM-Medium+Behaviorial-Gating\"],[\"Segatron-XL large, M=384 + HCP\"],[\"Segatron -XL base, M=150 + HCP\"],[\"Transformer Large + HCP\"],[\"BLOOM-7.1B\"],[\"BLOOM-3B\"],[\"BLOOM-1.7B\"],[\"aLSTM(depth-2)+RecurrentPolicy (PTB)\"],[\"aLSTM(depth-2)+RecurrentPolicy (WT2)\"],[\"AWD-LSTM-MoS + dynamic evaluation (WT2, 2017)\"],[\"AWD-LSTM-MoS + dynamic evaluation (PTB, 2017)\"],[\"CODA\"],[\"RNN + char3-MS-vec\"],[\"RNN + char2-MS-vec\"],[\"RNN Baseline\"],[\"LSTM-Char-Large\"],[\"Mogrifier RLSTM (WT2)\"],[\"Mogrifier RLSTM (PTB)\"],[\"Transformer + GFM\"],[\"RNN+LDA+KN5+cache\"],[\"RNN+LDA\"],[\"RNN\"],[\"CT-MoS + DynamicEval (WT2)\"],[\"CT-MoS + DynamicEval (PTB)\"],[\"CT-MoS (PTB)\"],[\"RNNLM + Dynamic KL Regularization\"],[\"RNNLM + Dynamic KL Regularization (WT2)\"],[\"GPT2+CoreLM+Fine-Tuning\"],[\"GPT2+CoreLM+Fine-Tuning\"],[\"GPT-2 (1.5B, Curriculum Learning 45K)\"],[\"Transformer-XL DeFINE (141M)\"],[\"Transformer-XL DeFINE (107M)\"],[\"Adaptive LSTM + DeFINE\"],[\"DeLight\"],[\"DEQ-Transformer (Medium, Adaptive Embedding)\"],[\"DEQ-TrellisNet\"],[\"dense-IndRNN+dynamic eval\"],[\"AWD-LSTM-DRILL + dynamic evaluation\\u2020 (WT2)\"],[\"AWD-LSTM-DRILL + dynamic evaluation\\u2020 (PTB)\"],[\"DiffQ Transformer (16L)\"],[\"AWD-LSTM-DOC (fin) (23M)\"],[\"AWD-LSTM-DOC (fin) (37M)\"],[\"4-gram + 8 DENN\"],[\"AWD-LSTM + dynamic eval (WT2)\"],[\"AWD-LSTM + dynamic eval (PTB)\"],[\"LSTM + dynamic eval\"],[\"Transformer-XL + RMS dynamic eval\"],[\"ERNIE-Doc (247M)\"],[\"ERNIE-Doc (151M)\"],[\"EI-REHN-1200D\"],[\"EI-REHN-1000D\"],[\"Routing Transformer\"],[\"Local Transformer\"],[\"S4\"],[\"ONLSTM-SYD\"],[\"FNetAR Medium\"],[\"AWD-LSTM-MoS + dynamic evaluation (WT2, 2018)\"],[\"AWD-LSTM-MoS + dynamic evaluation (PTB, 2018)\"],[\"LSTM (Hebbian, Cache, MbPA)\"],[\"Decaying Fast Weights Transformer\"],[\"Fine-tuned-AWD-LSTM-DOC(fin)\"],[\"Fraternal dropout + AWD-LSTM 3-layer (PTB)\"],[\"Fraternal dropout + AWD-LSTM 3-layer (WT2)\"],[\"GLM-10B-bidirectional\"],[\"GLM-10B-unidirectional\"],[\"base LM+GNN+kNN\"],[\"GPT-Neo-2.7B (finetuned)\"],[\"GPT-Neo-1.3B (finetuned)\"],[\"GPT-Neo-2.7B (finetuned on PTB)\"],[\"Transformer-XL+AdamGapAware(GA)\"],[\"RNN+weight noise+dynamic eval\"],[\"Delta RNN (+ full context)\"],[\"GL-LWGC-AWD-MoS-LSTM + dynamic evaluation (WT2)\"],[\"GL-LWGC-AWD-MoS-LSTM + dynamic evaluation (PTB)\"],[\"Gated HORNN (3rd order)\"],[\"DOT(S)-RNN\"],[\"Hybrid H3-2.7B\"],[\"Hybrid H3-1.3B\"],[\"Hybrid H3-355M\"],[\"GPT-2 (fine-tuned with HYDRA)\"],[\"Hyena-3-slim\"],[\"AWD-LSTM-MoS+PDR + dynamic evaluation (WT2)\"],[\"AWD-LSTM-MoS+PDR + dynamic evaluation (PTB)\"],[\"4 layer Densely Connected LSTM\"],[\"Densely Connected LSTM + Var. Dropout\"],[\"TransformerXL + spectrum control\"],[\"AdvSoft + 4 layer QRNN + dynamic evaluation\"],[\"4 layer QRNN + dynamic evaluation\"],[\"AWD-LSTM + MoS + Partial Shuffled\"],[\"Transformer-XL Large + Phrase Induction\"],[\"AWD-LSTM + Phrase Induction + finetuning\"],[\"Neural cache model (size=2000) (300M)\"],[\"LSTM (WT103)\"],[\"LSTM (PTB)\"],[\"LSTM(medium)+Sememe+cell\"],[\"Sandwich Transformer\"],[\"Stack RNN\"],[\"LSTM+NeuralCache\"],[\"AWD-LSTM+WT+Cache+IOG (WT2)\"],[\"AWD-LSTM+WT+Cache+IOG (PTB)\"],[\"MPT-7B\"],[\"LSTM-3-layer+Gadam\"],[\"LLaMA-65B\"],[\"LLaMA-33B\"],[\"LLaMA-33B (LoRA finetuned)\"],[\"LSTM-300units\"],[\"LaMemo\"],[\"GPT-2 (1542M)\"],[\"GPT-2 (1542M)\"],[\"GPT-2 (1542M)\"],[\"SPN-4\"],[\"AWD-FWM (PTB)\"],[\"AWD-FWM (WT2)\"],[\"DITTO\"],[\"Linear Transformer (large)\"],[\"Linear Transformer (small)\"],[\"MemSizer\"],[\"bRSM + cache\"],[\"D-LSRC(200)+KN5\"],[\"D-LSRC(100)+KN5\"],[\"LSTM+Adam+Lookahead\"],[\"Megatron-LM (8.3B)\"],[\"Megatron-LM (2.5B)\"],[\"Megatron-LM (355M)\"],[\"Multipop Adaptive Continuous Stack (PTB)\"],[\"Multipop Adaptive Continuous Stack (WT2)\"],[\"TransformerXL + FWL\"],[\"Mogrifier (d2, MoS2, MC) + dynamic eval\"],[\"Mogrifier (d2, MC) + dynamic eval\"],[\"Monarch-GPT-2-Medium\"],[\"Monarch-GPT-2-Small\"],[\"Multi-cell LSTM\"],[\"Byte-mLSTM+emb+WN+VD\"],[\"ADP-FAIRSEQ+NGRAMRES\"],[\"ADP-FAIRSEQ\"],[\"L_UL-seq\"],[\"AWD-LSTM-MoS+Noisin+dynamic evaluation \"],[\"Dropout-LSTM+Noise(Bernoulli) (PTB)\"],[\"Dropout-LSTM+Noise(Bernoulli) (WT2)\"],[\"OPT-175B\"],[\"OPT-2.7B (finetuned on WT2)\"],[\"OPT-30B\"],[\"B2T connection (16L)\"],[\"AWD-LSTM\"],[\"DOC + Finetune\\u2217 + Partial Shuffle (PTB)\"],[\"DOC + Finetune\\u2217 + Partial Shuffle (WT2)\"],[\"PermuteFormer\"],[\"GPT-2-Medium+Pixelfly\"],[\"GPT-2-Small+Pixelfly\"],[\"Pointer Sentinel-LSTM (medium)\"],[\"Zoneout + Variational LSTM (PTB)\"],[\"Pointer Sentinel-LSTM\"],[\"Tensor-Transformer(1core)+PN (WT103)\"],[\"Tensor-Transformer(1core)+PN (PTB)\"],[\"2-layer skip-LSTM + dropout tuning (PTB)\"],[\"2-layer skip-LSTM + dropout tuning (WT2)\"],[\"Pythia-12b\"],[\"Pythia-6.9b\"],[\"Pythia-2.8b\"],[\"Adaptive Input Transformer + RD\"],[\"R-Transformer\"],[\"RFA-GATE-Gaussian-Stateful Big\"],[\"GPT-2+Active-SGD\"],[\"HSO\"],[\"Variational RHN + WT\"],[\"VD-RHN\"],[\"Transformer-XL + RMT\"],[\"Large regularized LSTM\"],[\"AWD-LSTM - 3-layer LSTM (tied) + continuous cache pointer (WT2)\"],[\"AWD-LSTM - 3-layer LSTM (tied) + continuous cache pointer (PTB)\"],[\"Transformer-C\"],[\"QRNN\"],[\"Gopher (280B)\"],[\"Gopher (7.1B)\"],[\"Segatron XL large, M=384\"],[\"Segatron XL base, M=384\"],[\"Selfish-RNN (ON-LSTM)\"],[\"Selfish-RNN (AWD-LSTM-MoS)\"],[\"Selfish-RNN (SNT-ASGD)RHNs\"],[\"Word-Independent-SRNN+KN5\"],[\"Shortformer\"],[\"Sparse Wide GPT-3 Small\"],[\"DEQ-Transformer (Post-LN) + Jacobian Regularisation\"],[\"GCRN-M1, dropout\"],[\"Subformer (122M)\"],[\"Subformer (96M)\"],[\"Subformer (83M)\"],[\"GPT3-6.7B (rerun of original)\"],[\"TaLK Convolution\"],[\"Integer Transformer\"],[\"Integer Transformer\"],[\"ALiBi (L=3072, Lvalid = 3072)\"],[\"Chinchilla\"],[\"NoPos\"],[\"Transformer-XL Large\"],[\"Transformer-XL-ptb\"],[\"TrellisNet\"],[\"TrellisNet-MoS (1.4x larger)\"],[\"TrellisNet-MoS (1.4x larger)\"],[\"Turing-NLG\"],[\"VD-LSTM+REAL Large\"],[\"SRU++ Large\"],[\"SRU++ Large only 2 attention layers (k=5)\"],[\"SRU++ Base\"],[\"genCNN + dyn eval\"],[\"rTop-k(distributed setting)\"]],\"hovertemplate\":\"predicted_log_ppl=%{x}\\u003cbr\\u003elog_ppl=%{y}\\u003cbr\\u003esystem=%{customdata[0]}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"legendgroup\":\"\",\"marker\":{\"color\":\"#636efa\",\"symbol\":\"circle\"},\"mode\":\"markers\",\"name\":\"\",\"orientation\":\"v\",\"showlegend\":false,\"x\":[2.9371053321418428,5.0674680367637865,4.613253440974726,4.132932976139436,4.419621122762194,4.432502027551994,2.8814149316880675,3.2031095348173007,3.2746135472913886,3.1389775669454303,4.218346880324649,3.0844493949896328,3.047933979325551,3.185918924014679,2.981262851443856,3.1880982072632342,5.01909479903752,3.50666677786918,4.249238141495327,4.418342299533911,3.217515104544968,3.936278832939065,3.793999357384303,4.024301329565113,3.90269006082271,4.066136047859457,2.990395892746938,3.0538395986201703,2.990395892746938,2.4522698320648852,2.539426562569119,2.5987635301192147,4.1437351906544055,3.995135279367429,4.022061080883202,4.199935767881427,3.037422294530936,3.181667655305737,3.1942860414792627,3.1983813398521583,4.413053587188461,3.671954572104535,3.8018782904747166,2.993357203795477,4.7822870153369905,4.820988885701993,4.84505700920689,3.7603760825359624,3.938354632958721,3.938354632958721,4.155811355187197,3.8830169116384905,3.2661878411339655,3.515284587826658,2.5007345229543625,3.1873848041315167,3.2216875119598782,3.3231543338869343,3.1933052225793137,3.2313715992079413,3.499723314496332,3.9488869660173735,3.914372977659296,4.064356949801381,3.0387442197129033,4.062281231708109,3.9538274748819897,4.498808946886381,4.041010037855575,4.199227206702151,4.043539800879927,3.11149549918815,3.0594581875157347,3.118528220614216,4.307532395172734,4.2410327745215515,3.2430328163876623,2.621760014700347,3.0142896343834242,3.980318059868048,3.2787042202819645,3.9579495895090715,4.116995188054154,3.4303675314897624,2.935330483345962,4.110678738403134,4.190009850818166,4.028331572652906,2.2788736632518067,2.2788736632518067,2.9702746214458275,2.5999065292464123,2.5999065292464123,2.604313543163406,3.0872911185135004,4.4595432643837825,3.249710222626889,4.0254772238203005,4.193350948322401,4.462643406718566,4.738375507644732,2.696893667038858,2.7714858168521928,2.913445466556384,3.2672144424669396,3.0293794758341166,3.966118228061977,4.1407218525386575,4.291044024457264,4.22002152796812,3.162898150554031,3.434780810384011,3.434780810384011,3.904858832687498,3.104198850506654,4.059765632120516,3.269508512946489,3.708253159264313,4.22146273700622,4.066078341945548,3.041485776265354,4.8060274938660585,4.402482745268681,3.9724009248484364,4.167034980554716,2.3797520523906113,4.001063930322027,2.1704543200712867,2.2294722134366873,2.228224730892774,4.763576986155807,3.0502701611405545,2.7713075367986066,2.982011550301099,3.0080388743292295,4.759936907700423,3.946467812792546,3.7953405843831116,2.8585636201382725,3.175070692263569,3.280410998601642,2.9520343544674614,4.357066994159184,4.382914678698414,4.410754697736982,4.2247546857417175,2.4619829666456035,2.5787888246873325,2.7903748427699497,4.2776357364239965,4.045213359295642,2.920523673981946,3.8878927607781453,4.04026338064949,2.870844229588375,2.9738356609025787,4.2791174658979365,4.069583120198229,2.9310779265860143,2.9641810914674744,3.136096708575055,4.160233085974454,4.045291559615265,3.9325678963281585,2.1958596345214128,2.578801857102329,2.3446222921686712,2.984838256596837,4.054655483388222,4.0189606983112,3.8311784377995544,3.2771189023690934,3.0341510920459474,3.1694817357874987,4.302317480154651,4.302317480154651,4.1914687304541225,3.2332827058781737,4.096375247330723,4.362970350007423,4.268885803160028,2.3766235460110927,2.430179288375995,2.521899163359265,3.0333405009169554,4.114076694122812,3.0528764397213006,3.486124097221191,2.796230592160654,4.307623188178884,4.261503408025824,2.944856868833585,4.329441370173129,4.05044856097743,4.209636130750619,3.106632325360419,3.297917668411624,2.0057464463363246,2.3100945290020265,3.0913808648323764,3.1552979870307754,4.039665976016137,3.9091359539616866,4.09820413091925,4.46437730976692,3.357650283477966,2.7601641612565357,3.145742764757569,4.185596690311579,3.1447468271088272,3.1746700775526113,3.193076043801379,2.3564595324532025,3.111909562559724,3.251232147909554,3.0750544766265815,2.839734115723552,2.0456500755315874,2.80930725348008,3.164915177077538,3.439492076261711,3.221306536222146,3.221306536222146,3.498208845571731,2.3788027511061465,4.170819074176527,3.057882295813272,3.062532364333567,3.151879489220575,4.5815542791941235,3.842729379933842],\"xaxis\":\"x\",\"y\":[2.8100049236252036,5.069532935343741,4.68213122712422,4.394449154672439,4.426043520090656,4.624972813284271,3.029650491757452,2.9338568698359038,2.9391619220655967,3.054001181677967,4.29592393562047,3.125443880075648,3.1467351470905185,2.928523523860541,3.2857865301508276,2.9069010598473755,4.854760907317149,3.4965075614664802,4.368561383720311,4.379899373657707,3.0252910757955354,4.005513348515485,4.092676505121403,4.041646773221651,4.328098292648326,4.366278277705742,2.833213344056216,3.095577608523707,3.2308043957334744,2.6892071133007303,2.866192902199006,3.0041963519661206,4.012772908528289,4.1666652238017265,3.7057365711803594,3.864721732310133,2.916689066213538,3.4597807057610526,3.463232772581608,3.4716558453107167,4.368181227851829,3.6375861597263857,3.758871825933971,2.998229153752578,4.5217885770490405,4.73356340075649,4.825910852685991,3.7125959807312525,3.8590440806372595,4.001680877358681,4.354141431184346,4.463606621666305,3.3847291889548483,3.3847291889548483,2.6188546222977394,3.1851121947153915,3.2472688993694185,3.581850881355413,3.1838702156693857,3.1441522786722644,4.044804116661965,3.9110225050945626,3.7376696182833684,3.899950424193877,2.89591193827178,3.958524839079566,4.060960118202517,4.694279361059867,3.7909846770510898,3.933784497209659,4.091005660956586,2.797281334830153,2.8213788864092133,3.044522437723423,4.192680462942962,4.229749199228304,2.760009940032921,2.9856819377004897,3.0421386463681466,4.019980146933238,3.2507620137305224,3.66714496196793,3.8403121578741457,3.374168709274236,3.0204248861443626,3.953548752256644,4.039536325727106,4.160444363926624,2.427454075039915,2.503073953743449,2.8213788864092133,2.377692565480851,2.492378664626701,2.6878474937846906,3.2763897310688073,4.762173934797756,3.490428515390098,3.7003138317395994,3.8360055190042304,4.605170185988092,4.677490847567717,2.3608540011180215,2.5257286443082556,2.8273136219290276,2.719319793360441,2.917770732084279,3.696351468952637,3.856510295497887,4.341204640153626,4.360547602996758,3.1441522786722644,3.332204510175204,3.4531571205928664,3.639426570394406,2.856470206220483,4.019980146933238,3.708682081410116,3.885679030088544,4.410371107683024,4.490432508517668,2.8814431271518632,4.770684624465665,4.192680462942962,3.9454577815143836,3.970291913552122,2.298577071596507,4.073631520624559,1.601405740736836,1.9315214116032138,2.038619547159581,4.740574822994295,3.1684242813721024,2.8610573702273894,2.8610573702273894,2.8610573702273894,4.605170185988092,3.997833661841257,4.121473229610353,3.1917101567954314,3.449987545831587,3.56953269648137,3.0349529867072724,4.639571612705423,4.5217885770490405,4.532599493153256,4.05560373390567,2.3804716316511167,2.546315277916644,2.960623096440423,4.151039905898646,4.282206299391671,2.8094026953624978,3.653252276470785,3.8022081394209395,3.0106208860477417,3.0301337002713233,4.34536265030229,4.486386649998124,2.9014215940827497,2.9391619220655967,3.2355362657613083,3.8628327612373745,4.191168746857641,4.341204640153626,2.122261538862764,2.329227023940467,2.367436065313662,2.954910279033736,4.186619838331271,3.9512437185814275,4.0578534536396855,3.480932349681009,3.044522437723423,3.1135153092103742,4.2612704335380815,4.389498649512583,4.39197696552705,2.884800712846709,3.8628327612373745,4.012772908528289,4.154184562578117,2.355177543113216,2.4344901638739844,2.540814281726296,2.8942531046041373,4.435330406696193,3.1570004211501135,3.0248055210396982,3.0106208860477417,4.180522258463153,4.22683374526818,3.177637076851603,4.361823927356363,3.9512437185814275,3.966511190712216,3.2228678461377385,3.4965075614664802,2.0943301541735866,2.3804716316511167,2.8390784635086144,3.1135153092103742,4.022132228108176,4.143928062410929,4.159351723530711,4.543294782270004,2.8986705607108596,3.0155349008501706,3.214867803470662,4.591780948869076,2.990719731730447,3.015044584586364,3.038791763014438,2.211565694606877,3.1484533605716547,2.8992213731731473,3.427189961936409,2.9069010598473755,1.9685099809725544,3.0430928449138284,2.9069010598473755,3.998567606828332,3.3738261848660236,3.3738261848660236,3.3738261848660236,2.3233676321765744,4.22683374526818,2.8390784635086144,2.8507065015037334,2.9069010598473755,4.666265285347902,4.41267707387264],\"yaxis\":\"y\",\"type\":\"scatter\"},{\"hovertemplate\":\"\\u003cb\\u003eOLS trendline\\u003c\\u002fb\\u003e\\u003cbr\\u003elog_ppl = 1.00453 * predicted_log_ppl + -0.0160426\\u003cbr\\u003eR\\u003csup\\u003e2\\u003c\\u002fsup\\u003e=0.911316\\u003cbr\\u003e\\u003cbr\\u003epredicted_log_ppl=%{x}\\u003cbr\\u003elog_ppl=%{y} \\u003cb\\u003e(trend)\\u003c\\u002fb\\u003e\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"legendgroup\":\"\",\"marker\":{\"color\":\"#636efa\",\"symbol\":\"circle\"},\"mode\":\"lines\",\"name\":\"\",\"showlegend\":false,\"x\":[2.0057464463363246,2.0456500755315874,2.1704543200712867,2.1958596345214128,2.228224730892774,2.2294722134366873,2.2788736632518067,2.2788736632518067,2.3100945290020265,2.3446222921686712,2.3564595324532025,2.3766235460110927,2.3788027511061465,2.3797520523906113,2.430179288375995,2.4522698320648852,2.4619829666456035,2.5007345229543625,2.521899163359265,2.539426562569119,2.5787888246873325,2.578801857102329,2.5987635301192147,2.5999065292464123,2.5999065292464123,2.604313543163406,2.621760014700347,2.696893667038858,2.7601641612565357,2.7713075367986066,2.7714858168521928,2.7903748427699497,2.796230592160654,2.80930725348008,2.839734115723552,2.8585636201382725,2.870844229588375,2.8814149316880675,2.913445466556384,2.920523673981946,2.9310779265860143,2.935330483345962,2.9371053321418428,2.944856868833585,2.9520343544674614,2.9641810914674744,2.9702746214458275,2.9738356609025787,2.981262851443856,2.982011550301099,2.984838256596837,2.990395892746938,2.990395892746938,2.993357203795477,3.0080388743292295,3.0142896343834242,3.0293794758341166,3.0333405009169554,3.0341510920459474,3.037422294530936,3.0387442197129033,3.041485776265354,3.047933979325551,3.0502701611405545,3.0528764397213006,3.0538395986201703,3.057882295813272,3.0594581875157347,3.062532364333567,3.0750544766265815,3.0844493949896328,3.0872911185135004,3.0913808648323764,3.104198850506654,3.106632325360419,3.11149549918815,3.111909562559724,3.118528220614216,3.136096708575055,3.1389775669454303,3.1447468271088272,3.145742764757569,3.151879489220575,3.1552979870307754,3.162898150554031,3.164915177077538,3.1694817357874987,3.1746700775526113,3.175070692263569,3.181667655305737,3.185918924014679,3.1873848041315167,3.1880982072632342,3.193076043801379,3.1933052225793137,3.1942860414792627,3.1983813398521583,3.2031095348173007,3.217515104544968,3.221306536222146,3.221306536222146,3.2216875119598782,3.2313715992079413,3.2332827058781737,3.2430328163876623,3.249710222626889,3.251232147909554,3.2661878411339655,3.2672144424669396,3.269508512946489,3.2746135472913886,3.2771189023690934,3.2787042202819645,3.280410998601642,3.297917668411624,3.3231543338869343,3.357650283477966,3.4303675314897624,3.434780810384011,3.434780810384011,3.439492076261711,3.486124097221191,3.498208845571731,3.499723314496332,3.50666677786918,3.515284587826658,3.671954572104535,3.708253159264313,3.7603760825359624,3.793999357384303,3.7953405843831116,3.8018782904747166,3.8311784377995544,3.842729379933842,3.8830169116384905,3.8878927607781453,3.90269006082271,3.904858832687498,3.9091359539616866,3.914372977659296,3.9325678963281585,3.936278832939065,3.938354632958721,3.938354632958721,3.946467812792546,3.9488869660173735,3.9538274748819897,3.9579495895090715,3.966118228061977,3.9724009248484364,3.980318059868048,3.995135279367429,4.001063930322027,4.0189606983112,4.022061080883202,4.024301329565113,4.0254772238203005,4.028331572652906,4.039665976016137,4.04026338064949,4.041010037855575,4.043539800879927,4.045213359295642,4.045291559615265,4.05044856097743,4.054655483388222,4.059765632120516,4.062281231708109,4.064356949801381,4.066078341945548,4.066136047859457,4.069583120198229,4.096375247330723,4.09820413091925,4.110678738403134,4.114076694122812,4.116995188054154,4.132932976139436,4.1407218525386575,4.1437351906544055,4.155811355187197,4.160233085974454,4.167034980554716,4.170819074176527,4.185596690311579,4.190009850818166,4.1914687304541225,4.193350948322401,4.199227206702151,4.199935767881427,4.209636130750619,4.218346880324649,4.22002152796812,4.22146273700622,4.2247546857417175,4.2410327745215515,4.249238141495327,4.261503408025824,4.268885803160028,4.2776357364239965,4.2791174658979365,4.291044024457264,4.302317480154651,4.302317480154651,4.307532395172734,4.307623188178884,4.329441370173129,4.357066994159184,4.362970350007423,4.382914678698414,4.402482745268681,4.410754697736982,4.413053587188461,4.418342299533911,4.419621122762194,4.432502027551994,4.4595432643837825,4.462643406718566,4.46437730976692,4.498808946886381,4.5815542791941235,4.613253440974726,4.738375507644732,4.759936907700423,4.763576986155807,4.7822870153369905,4.8060274938660585,4.820988885701993,4.84505700920689,5.01909479903752,5.0674680367637865],\"xaxis\":\"x\",\"y\":[1.998798712310133,2.0388832811844795,2.1642534401638107,2.189773952893801,2.2222858060957824,2.2235389452452656,2.273164401815061,2.273164401815061,2.3045268359775655,2.3392111624070724,2.3511020776705847,2.371357523266507,2.373546609785344,2.3745002155973225,2.4251561096792327,2.447346821096384,2.457103999075895,2.4960312710853034,2.5172918807872353,2.5348987565272236,2.574439503540654,2.574452595050049,2.594504782608657,2.595652964570084,2.595652964570084,2.6000799617241905,2.617605542831481,2.693079882451242,2.7566372714489207,2.7678311756981584,2.768010264147781,2.786984940778435,2.7928672425764494,2.806003198926186,2.836568029239252,2.8554829144715774,2.8678192093211705,2.8784378433880597,2.9106136180457596,2.917723921012652,2.9283260309950507,2.932597870619012,2.934380767318756,2.9421674527072383,2.949377484051202,2.961579299417244,2.9677004599991537,2.971277646692372,2.978738515209817,2.979490608979595,2.9823301327393166,2.9879129695270974,2.9879129695270974,2.9908877083936467,3.0056359517381526,3.011915055342572,3.027073320421004,3.031052306441777,3.0318665731286494,3.035152608608526,3.0364805279499976,3.039234515862021,3.045711957761289,3.048058732797922,3.0506768293315587,3.051644355594139,3.0557053840605484,3.057288421512525,3.0603765379287866,3.0729554306957945,3.082392949532735,3.085247558614955,3.089355849547476,3.1022319573089217,3.104676466551487,3.109561692035408,3.109977632942812,3.1166263027503325,3.134274453554821,3.137168374937246,3.142963795329764,3.143964248974725,3.150128799903076,3.1535627986065338,3.1611974244375194,3.1632235969996008,3.1678108623892336,3.1730227302574323,3.17342516152239,3.180052037943362,3.1843225836757583,3.185795110703748,3.1865117487024768,3.1915121568253095,3.191742374795302,3.1927276411367638,3.196841509298631,3.2015911438695657,3.216062034451905,3.2198706580598615,3.2198706580598615,3.2202533613003075,3.2299813602344556,3.2319011326585203,3.2416954542310674,3.248403138612067,3.2499319649380154,3.264955473506221,3.2659867298773326,3.2682912026281725,3.2734193853256084,3.275936100726995,3.277528607131745,3.2792431246953875,3.2968291770397684,3.32218027607023,3.3568326446681183,3.429879622977245,3.434312913516623,3.434312913516623,3.4390455422365807,3.485889012206529,3.4980285578407355,3.4995498939983865,3.5065248419268937,3.515181728624998,3.6725621198821146,3.7090252999584856,3.7613845702792603,3.7951603070636075,3.7965076157443995,3.8030749665191075,3.832507972918696,3.8441112918368763,3.884581503994524,3.889479462265513,3.9043438594332063,3.9065224654131643,3.9108189809371083,3.916079751481967,3.9343571734922875,3.9380849370358066,3.940170149597554,3.940170149597554,3.94832011796879,3.950750240642186,3.9557131518322675,3.959853957844389,3.968059636407643,3.9743708215587756,3.982323856166936,3.997208263112552,4.003163797040522,4.021141716431758,4.024256157429997,4.026506564332745,4.027687790582377,4.030555082221745,4.041940880491867,4.042540994006714,4.043291036867637,4.04583227089147,4.047513417918265,4.047591972830717,4.052772358185525,4.056998356535179,4.062131676810773,4.064658683174923,4.066743813438798,4.0684730110921,4.0685309786686625,4.071993681469508,4.098907295268331,4.100744471776982,4.113275644328263,4.116689007794802,4.119620735393507,4.1356307920498345,4.143454986459585,4.146481988305742,4.158612911199595,4.163054691956385,4.169887429160422,4.173688681439211,4.188533305442345,4.192966477057243,4.194431971861254,4.196322724489502,4.2022256282728625,4.20293740236372,4.212681750719444,4.221431998461042,4.223114239654605,4.224561983734909,4.227868859537437,4.244220759953438,4.252463333479523,4.264784215838321,4.272200085827655,4.280989694934365,4.282478143187046,4.294458781731623,4.3057833559737935,4.3057833559737935,4.311021917589162,4.311113122288628,4.333030237009741,4.360781127084103,4.366711251207164,4.386746015793478,4.406402812129857,4.414712273076839,4.4170215866508356,4.422334280221399,4.423618902166972,4.436558214345421,4.463722067410697,4.466836267082382,4.468578032369521,4.503165796876299,4.586286330993385,4.618129229979738,4.743818652227323,4.765477820653595,4.769134404741194,4.787929272989499,4.811777400738775,4.826806633758382,4.850983892162309,5.025810841838182,5.07440342397715],\"yaxis\":\"y\",\"type\":\"scatter\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Predicted Log PPL\"}},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Actual Log PPL\"}},\"legend\":{\"tracegroupgap\":0},\"margin\":{\"t\":60},\"annotations\":[{\"showarrow\":false,\"text\":\"r2 total = 0.91\",\"x\":0.5,\"xref\":\"paper\",\"y\":0.95,\"yref\":\"paper\"}],\"title\":{\"text\":\"Nonlinear model: actual vs predicted cross entropy\"}},                        {\"responsive\": true}                    ).then(function(){\n","                            \n","var gd = document.getElementById('e2fdce30-30e8-4aec-a7f2-ce088c077f11');\n","var x = new MutationObserver(function (mutations, observer) {{\n","        var display = window.getComputedStyle(gd).display;\n","        if (!display || display === 'none') {{\n","            console.log([gd, 'removed!']);\n","            Plotly.purge(gd);\n","            observer.disconnect();\n","        }}\n","}});\n","\n","// Listen for the removal of the full notebook cells\n","var notebookContainer = gd.closest('#notebook-container');\n","if (notebookContainer) {{\n","    x.observe(notebookContainer, {childList: true});\n","}}\n","\n","// Listen for the clearing of the current output cell\n","var outputEl = gd.closest('.output');\n","if (outputEl) {{\n","    x.observe(outputEl, {childList: true});\n","}}\n","\n","                        })                };                            </script>        </div>\n","</body>\n","</html>"]},"metadata":{},"output_type":"display_data"}],"source":["df_main['predicted_log_ppl'] = model_name(res.x, year, param, dataset, ptb_dummy, wt2_dummy)\n","r2_score_value = r2_score(df_main[\"log_ppl\"], df_main['predicted_log_ppl'])\n","\n","fig = px.scatter(df_main, x='predicted_log_ppl', y=df_main[\"log_ppl\"], hover_data=['system'], trendline='ols')\n","\n","fig.add_annotation(\n","        x=0.50,\n","        y=0.95,\n","        xref=\"paper\",\n","        yref=\"paper\",\n","        text=f\"r2 total = {r2_score_value:.2f}\",\n","        showarrow=False,\n",")\n","\n","fig.update_layout(title=\"Nonlinear model: actual vs predicted cross entropy\",\n","    xaxis_title=\"Predicted Log PPL\",\n","    yaxis_title=\"Actual Log PPL\")\n","\n","fig.show()"]},{"cell_type":"markdown","metadata":{"id":"RRNz_6-ADUtD"},"source":["## Bootstrap"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"xOWmo5wVDucB"},"outputs":[],"source":["model_num = 7\n","delta = 0.0025\n","\n","if post_transformer == 1:\n","  filename_suffix = f\"_model{model_num}_delta{delta}_post_transformer_bootstrap_results.json\"\n","else:\n","  filename_suffix = f\"_model{model_num}_delta{delta}_bootstrap_results.json\"\n","\n","latest_cached_filename = safe_max([f for f in os.listdir() if f.endswith(filename_suffix)])"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"USYaifCfiW1O"},"outputs":[],"source":["if not (use_cached_bootstraps and latest_cached_filename):\n","  np.random.seed(0)\n","  n_bootstrap_samples = 100\n","\n","  bootstrap_results = []\n","  for i in range(n_bootstrap_samples):\n","      bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","\n","      if model_num in {13, 17}:\n","        bootstrap_res = minimize(residuals, p0, args=(model_name, year[bootstrap_indices], param[bootstrap_indices],\n","                                                      dataset[bootstrap_indices], ptb_dummy[bootstrap_indices],\n","                                                      wt2_dummy[bootstrap_indices], log_ppl[bootstrap_indices], delta,\n","                                                      transformer_dummy[bootstrap_indices]), method='SLSQP')\n","      else:\n","        bootstrap_res = minimize(residuals, p0, args=(model_name, year[bootstrap_indices], param[bootstrap_indices],\n","                                                      dataset[bootstrap_indices], ptb_dummy[bootstrap_indices],\n","                                                      wt2_dummy[bootstrap_indices], log_ppl[bootstrap_indices], delta), method='SLSQP')\n","      bootstrap_results.append(bootstrap_res.x)\n","\n","      if i % 5 == 4:\n","          print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","\n","\n","  confidence_intervals = np.percentile(bootstrap_results, [2.5, 97.5], axis=0)\n","  standard_errors = np.std(bootstrap_results, axis=0)\n","\n","  print(\"Optimized parameters with confidence intervals and standard errors:\")\n","  for i, name in enumerate(PARAMS_MAPPING[model_num]):\n","      print(f\"{name}_opt: {params_optimized[i]}  CI: {confidence_intervals[:, i]}  SE: {standard_errors[i]}\")"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"ImsXxG_Mjkgx"},"outputs":[],"source":["if use_cached_bootstraps and latest_cached_filename:\n","      with open(latest_cached_filename, 'r') as f:\n","            bootstrap_results = json.load(f)\n","else:\n","      bootstrap_results_to_save = [param_estimates.tolist() if isinstance(param_estimates, np.ndarray) else param_estimates for param_estimates in bootstrap_results]\n","\n","      if post_transformer == 1:\n","            filename = f\"{date}_model{model_num}_delta{delta}_post_transformer_bootstrap_results.json\"\n","      else:\n","            filename = f\"{date}_model{model_num}_delta{delta}_bootstrap_results.json\"\n","\n","      with open(filename, 'w') as f:\n","            json.dump(bootstrap_results_to_save, f)\n","      files.download(filename)"]},{"cell_type":"markdown","metadata":{"id":"w8Z-kUcSDYKF"},"source":["## Doubling times (section 3.1)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"JcsuGiub7wzA"},"outputs":[],"source":["custom_filename_to_load = None # @param {type:\"string\"}\n","#custom_filename_to_load = '2024-01-18_model7_delta0.0025_bootstrap_results.json'\n","#custom_filename_to_load = '2024-01-17_model7_delta0.0025_post_transformer_bootstrap_results.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        bootstrap_results = json.load(f)\n","    bootstrap_results = np.array(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"G6MaE_p_78ij"},"outputs":[],"source":["# reset plot settings\n","import matplotlib as mpl\n","mpl.rcParams.update(mpl.rcParamsDefault)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282797,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"vuLgZlH58CLk","outputId":"41589b2d-7e6e-4759-d948-aca0ec0d9e84"},"outputs":[{"name":"stderr","output_type":"stream","text":["No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n","No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n","No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"]},{"data":{"image/png":"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6NEDgP510cR2qQsXLqB79+6ws7NDcHAwNmzYAAD4888/0aFDB9ja2qJp06bYu3dvmdus6vP75ZdfokWLFrCzs4Orqyvatm2L1atXV/pY3r17F8OGDYO9vT28vLzwxhtvlPmdFu/7o1V+4n0UHwNRQUEB5syZg+DgYCiVSvj7+2PWrFl6z/voubZt24bo6Gjt4/vwc5KUlIRJkybB29sbKpUKLVu2xA8//FDpfQSA33//HQMHDtS+RzRq1Ajz5s1DSUlJpddNTU3Fc889BycnJ7i4uGD8+PE4f/689r33Yfv370fXrl1hb28PFxcXDB06FFevXtUZI75Orly5grFjx8LV1RVdunTR+Zmostc/oHl/nzBhAlxcXODs7IyJEyciNzdXZ4z4viT+7tva2iIiIgIXL14EoEngBAcHQ6VSoUePHmVeq/peH5XNF+URXxenT59Gp06dYGtri6CgICxfvlxnnPiaWrNmDd59913Uq1cPdnZ2yMzMBKB5HYtzhoeHB5599lnExcWVub2qvN4ffg9ZtGiR9j3kypUrAIBr165h+PDhcHNzg0qlQtu2bbFlyxad2ykqKsIHH3yAxo0bQ6VSwd3dHV26dMGePXu0YxISEjBx4kTUr18fSqUSvr6+GDp0aKVrox46dAgpKSno06ePzvG///4bnp6e2qQboPkSYOTIkUhISMCff/6pPb5hwwa0a9dOm3QDgJCQEPTu3Rvr1q3THsvLy4Orq6v2325ubtrfJ7VajenTp2PWrFmoX79+hTE/bMWKFYiLi8PChQvLJN0AwNvbG++++26l53nyySdx6NAh3L9/v8q3TURkzkzvqzgiojoiIyOjzGLZMpkM7u7uaNasGX766Se88cYbqF+/Pt58800AQOvWrbVrvT355JMYN26c9rq5ubno3r074uLi8NJLL6FBgwY4cuQIZs+ejfj4eJ31lCZNmoRVq1ahf//+mDx5MoqLi/H333/j2LFjaNu2LX766SdMnjwZ7du3x4svvggAaNSokd77MWrUKIwbNw4nT57U+UM/Ojoax44dw+eff6499vHHH+O9997DyJEjMXnyZCQnJ+PLL79Et27dcPbs2Qqr+O7du4f27dsjPT0dL774IkJCQhAXF4cNGzYgNzcXNjY2SExMRKdOnZCbm4tp06bB3d0dP/zwA4YMGYINGzbgqaee0jnn/PnzYWtri7fffhs3b97El19+CWtra8jlcqSlpWHu3Lk4duwYVq1ahaCgILz//vs61//zzz+xdu1aTJs2DUqlEsuWLUO/fv1w4sQJnXVrqqKixzwxMREdO3bUfqj29PTEjh07MGnSJGRmZlbarjd58mT8/PPPGDt2LDp16oT9+/dj4MCBZcZdvnwZXbt2hZOTE2bNmgVra2usWLECPXr00CaPHseNGzcwatQovPzyyxg/fjy+//57jBgxAjt37nysBcRXr16NrKwsvPTSS5DJZPjss8/w9NNP4/bt29qKnW3btmHUqFEICwvD/PnzkZaWhkmTJqFevXqVnn/RokV47bXX4ODggH//+98ANB8YK5KWloZBgwZh9OjRGDFiBL766iuMHj0av/zyC15//XW8/PLLGDt2LD7//HMMHz4csbGxcHR0BFD15/frr7/GtGnTMHz4cEyfPh35+fm4cOECjh8/rtNq9qi8vDz07t0bMTExmDZtGvz8/PDTTz9h//79VXm49VKr1RgyZAgOHTqEF198Ec2aNcPFixfxxRdf4J9//qlwrbJ///vfyMjIwN27d/HFF18AABwcHLSx9ujRAzdv3sTUqVMRFBSE9evXY8KECUhPT8f06dMrjGvVqlVwcHDAjBkz4ODggP379+P9999HZmamznuRvvszePBgnDhxAq+88gpCQkLw+++/Y/z48WXG7t27F/3790fDhg0xd+5c5OXl4csvv0Tnzp1x5syZMomrESNGoHHjxvjkk08gCILe26/Ke+7IkSMRFBSE+fPn48yZM/jmm2/g5eWFTz/9VGfc33//jS1btmDKlCkANO9zgwYNwqxZs7Bs2TK8+uqrSEtLw2effYbnn3++0t+DyuaLiqSlpWHAgAEYOXIkxowZg3Xr1uGVV16BjY1NmWqmefPmwcbGBm+99RYKCgpgY2ODVatWYeLEiWjXrh3mz5+PxMRELF68GIcPH9aZM6r7ev/++++Rn5+PF198EUqlEm5ubrh8+TI6d+6MevXq4e2334a9vT3WrVuHYcOGYePGjdr5Y+7cuZg/f772+crMzMSpU6dw5swZ7fvZM888g8uXL+O1115DYGAgkpKSsGfPHsTExFSY+D9y5AhkMhlat26tc7ygoAC2trZlxtvZ2QEATp8+jSeffBJqtRoXLlzQWynWvn177N69G1lZWXB0dES7du2wcuVK9OjRA9nZ2fj1118xdepUAMC3336LlJQUzJw5s9xY9dmyZQtsbW0xfPjwal3vUeHh4RAEAUeOHKnS5jxERGZPICIig/r+++8FAHovSqVSZ2xAQIAwcODAMucAIEyZMkXn2Lx58wR7e3vhn3/+0Tn+9ttvCwqFQoiJiREEQRD2798vABCmTZtW5rxqtVr7//b29sL48ePLjT8qKkoQBEHIyMgQlEql8Oabb+qM++yzzwSZTCZER0cLgiAId+7cERQKhfDxxx/rjLt48aJgZWVV5vijxo0bJ8jlcuHkyZPlxv36668LAIS///5b+7OsrCwhKChICAwMFEpKSgRBEIQDBw4IAITQ0FChsLBQO3bMmDGCTCYT+vfvr3P+iIgIISAgQOeY+JydOnVKeyw6OlpQqVTCU089pT02fvz4MtcVBEGYM2eO8Og0W95jPmnSJMHX11dISUnROT569GjB2dlZyM3NLXMd0blz5wQAwquvvqpzfOzYsQIAYc6cOdpjw4YNE2xsbIRbt25pj927d09wdHQUunXrVmHsglD2d0MQNL/DAISNGzdqj2VkZAi+vr5C69attcfE5+TAgQPaY48+dlFRUQIAwd3dXbh//772+O+//y4AEP744w/tsbCwMKF+/fpCVlaW9tjBgwcFAHqfj0e1aNFC6N69e5nj+uLs3r27AEBYvXq19ti1a9cEAIJcLheOHTumPb5r1y4BgPD9999rj1X1+R06dKjQokWLSmN/1KJFiwQAwrp167THcnJyhODg4DL3JSAgQO/vYPfu3XUej59++kmQy+U6rzVBEITly5cLAITDhw9XGNPAgQP1Pg9irD///LP2WGFhoRARESE4ODgImZmZFZ5X32vhpZdeEuzs7IT8/HztsUd/tzZu3CgAEBYtWqQ9VlJSIvTq1avM89WqVSvBy8tLSE1N1R47f/68IJfLhXHjxmmPia+TMWPGlImpOq9/cezzzz+vc/ypp54S3N3ddY6J88jDr8EVK1YIAAQfHx+dx2/27NllXq+PPi5VnS/0EV8XCxYs0B4rKCjQPn7ie6/4mmrYsKHO81dYWCh4eXkJoaGhQl5envb41q1bBQDC+++/rz1W1de7+B7i5OQkJCUl6cTbu3dvISwsTOf3RK1WC506dRIaN26sPdayZUu987IoLS1NACB8/vnnFT4++jz77LNlnlNBEITXXntNkMvlwp07d3SOjx49WgAgTJ06VRAEQUhOThYACB9++GGZcyxdulQAIFy7dk0QBEGIjY0VWrRooZ3LunbtKmRlZQnp6emCp6ensGbNmmrH7+rqKrRs2bLK47t37673Pe3evXsCAOHTTz+tdgxEROaIraZEREaydOlS7NmzR+eyY8eOxz7f+vXr0bVrV7i6uiIlJUV76dOnD0pKSrQtkBs3boRMJiuzYQMAve2DlXFyckL//v2xbt06nWqOtWvXomPHjmjQoAEA4LfffoNarcbIkSN14vPx8UHjxo1x4MCBcm9DrVZj8+bNGDx4sN4KCzHu7du3o3379tp2LkBTSfPiiy/izp072nYi0bhx43TWNOrQoQMEQShTLdChQwfExsaiuLhY53hERIR24WgAaNCgAYYOHYpdu3ZVqbWtKgRBwMaNGzF48GAIgqDz2EVGRiIjIwNnzpwp9/rbt28HAEybNk3n+KNVciUlJdi9ezeGDRum0zrs6+uLsWPH4tChQ9rWr+ry8/PTqTZ0cnLCuHHjcPbsWSQkJFT7fKNGjdJpkeratSsAaHftu3fvHi5evIhx48ZpK6kAoHv37ggLC3us+1AZBwcHjB49Wvvvpk2bwsXFBc2aNdOpFBT/X4y1Os+vi4sL7t69q7ettiLbt2+Hr6+vThWKnZ2dtrLqcaxfvx7NmjVDSEiITsxiK1xFr+fKYvXx8dFZ4N3a2hrTpk1Ddna2TkudPg9XBWVlZSElJQVdu3ZFbm5uhWtV7dy5E9bW1njhhRe0x+RyubZqTBQfH49z585hwoQJcHNz0x5/4okn8OSTT2pfbw97dL2ux/Xoebp27YrU1NQyr8vevXvrVFWJv3PPPPOMtsry4eOP7nb5sJrOF1ZWVnjppZe0/7axscFLL72EpKQknD59Wmfs+PHjdZ6/U6dOISkpCa+++qrOuooDBw5ESEiIdgmBx3m9P/PMM/D09NT++/79+9i/fz9Gjhyp/b1JSUlBamoqIiMjcePGDW17q4uLCy5fvowbN27oPbetrS1sbGxw8OBBpKWlVfoYPSw1NVXnvU00efJkKBQKjBw5EkeOHMGtW7cwf/58bNq0CYCmUvTh/+rb/Eh8DMUx9evXx9mzZ3H27FlcvnwZBw8ehIODAz744AM0bdoUo0aNwqFDh9ChQwf4+/tj2rRpOss66JOZmanzO/a4xMfg0a4AIqK6iok3IiIjad++Pfr06aNzeXgXs+q6ceMGdu7cCU9PT52LuFZMUlISAODWrVvw8/PT+dBYU6NGjUJsbCyOHj2qvY3Tp09j1KhROvEJgoDGjRuXifHq1ava+PRJTk5GZmZmpe2b0dHRaNq0aZnjzZo10/78YWJSUOTs7AwA8Pf3L3NcrVYjIyND53jjxo3L3FaTJk2Qm5uL5OTkCmOtquTkZKSnp2PlypVlHreJEycCQIWPXXR0NORyeZm2tUcfp+TkZOTm5pb7+KnV6iqvxfeo4ODgMh/SmzRpAgCVrnmkz6PPm/ghTfyQKz7PD+8Q/HAsxlC/fv0y99HZ2Vnv7xLwINbqPL//93//BwcHB7Rv3x6NGzfGlClTcPjw4Upji46O1vsc6Huuq+rGjRu4fPlymZjF57Wi38nKYm3cuHGZRfXLew0/6vLly3jqqafg7OwMJycneHp64tlnnwWAMq/fR2/X19dX27onevT3Rbz98l4nKSkpyMnJ0Tmub/fqx1HZ73154yp6X9N3/YfVdL7w8/ODvb29zrHyXvuPPk4VPdYhISHanz/O6/3R27p58yYEQcB7771X5ndaTDqKv9Mffvgh0tPT0aRJE4SFhWHmzJm4cOGC9lxKpRKffvopduzYAW9vb3Tr1g2fffZZlb9kEPS0Iz/xxBNYvXo1bt26hc6dOyM4OBj/+9//tEtIiAlHMXGpb53F/Px8nTGAJqndqlUrNG/eHHK5HNeuXcOyZcuwePFi3L9/HwMHDsSwYcOwfv167NmzBx9//HGFsTs5OSErK6tK97Mi4mPwOF8GEhGZI67xRkRkJtRqNZ588kntDmWPEj/sGMPgwYNhZ2eHdevWoVOnTli3bh3kcjlGjBihE59MJsOOHTv07or6cKVCbSlvd9byjuv7QFSZ8j44VLUiTtwY49lnn9W73hSg+VBWm2p6n2rKkM+PoTzu71J1nt9mzZrh+vXr2Lp1K3bu3ImNGzdi2bJleP/99/HBBx/U9C4AqPi5ffi+qNVqhIWFYeHChXrHP5rkqQ3p6eno3r07nJyc8OGHH6JRo0ZQqVQ4c+YM/u///q/MJjO1Rd/aXI+jqr/3tfG+ZgyGepwe57bE34233noLkZGReq8jJvG6deuGW7du4ffff8fu3bvxzTff4IsvvsDy5csxefJkAJqK4sGDB2Pz5s3YtWsX3nvvPcyfPx/79+8vs37bw9zd3ctNhA4fPhxDhgzB+fPnUVJSgjZt2mg3eRHndzc3NyiVSsTHx5e5vnjMz8+v3Nt/44038Oyzz6JNmzb46aef4ObmhtmzZwMAZs2ahY8//rjC95qQkBCcO3cOhYWFNdolVnwMPDw8HvscRETmhIk3IiIz0ahRI2RnZ5fZDU3fuF27duH+/fsVVjFU55tme3t7DBo0COvXr8fChQuxdu1adO3aVecP/EaNGkEQBAQFBVU7Cejp6QknJydcunSpwnEBAQG4fv16meNii1lAQEC1brcy+lqN/vnnH9jZ2WnbmFxdXZGenl5mnL7KHX2PubgTaUlJSaXPrT4BAQFQq9W4deuWTuXIo4+Tp6cn7Ozsyn385HK5NpkiVtqkp6frbIhRXjWSWE3y8P37559/AKDSHUYfh/g837x5U28sVVFblRbVfX7t7e0xatQojBo1CoWFhXj66afx8ccfY/bs2TrteA8LCAjApUuXyjwH+p7rin5fH25BbtSoEc6fP4/evXs/1mNV3nUCAgJw4cIFqNVqnaq3qryGDx48iNTUVPz222/o1q2b9nhUVFSl8QQEBODAgQPIzc3VqXp79PdFvP3yXiceHh5lKryqyhSre6o6X5Tn3r17yMnJ0XlMqvraf/ixfng3T/GY+HNDvN7F321ra+sqvQ7d3NwwceJETJw4EdnZ2ejWrRvmzp2rTbwBmsfuzTffxJtvvokbN26gVatWWLBgAX7++edyzxsSEoJffvkFGRkZ2orEh9nY2OhsYiTukCzGLJfLERYWpnfH2ePHj6Nhw4bltoJu3boVR44c0c5r9+7dg6+vr/bnfn5+eneTfdjgwYNx9OhRbNy4UaddvLrE16xY6UpEVNex1ZSIyEyMHDkSR48exa5du8r8LD09Xbs+2TPPPANBEPR+a/1w5YO9vb3eD+DlGTVqFO7du4dvvvkG58+f12kzBYCnn34aCoUCH3zwQZkKC0EQkJqaWu655XI5hg0bhj/++EPvBwrxfAMGDMCJEye0La8AkJOTg5UrVyIwMBDNmzev8v2piqNHj+qsrxYbG4vff/8dffv21VaXNGrUCBkZGTqtSPHx8dq1eR6m7zFXKBR45plnsHHjRr2Jx8paWvv37w8A+N///qdz/OFdbsXb6du3L37//XedFrDExESsXr0aXbp0gZOTk/Y+AdCuGwhoHucffvhBbwz37t3Tub+ZmZn48ccf0apVK/j4+FQY/+Pw8/NDaGgofvzxR2RnZ2uP//nnn7h48WKVzlHd3//HVZ3n99HXiI2NDZo3bw5BEFBUVFTubQwYMAD37t3Dhg0btMdyc3OxcuXKMmMbNWqEY8eO6azltHXr1jJtxiNHjkRcXBy+/vrrMufIy8sr0275KHt7e72tnwMGDEBCQgLWrl2rPVZcXIwvv/wSDg4O6N69e7nnFF9zD7+/FBYWYtmyZRXGAgCRkZEoKirSuT9qtRpLly7VGefr64tWrVrhhx9+0Pn9uHTpEnbv3o0BAwZUelvlqa3fueqo6nxRnuLiYqxYsUL778LCQqxYsQKenp4662Pq07ZtW3h5eWH58uU6rZM7duzA1atXtTszG+L17uXlhR49emDFihV6q8Uqeh06ODggODhYG2Nubq62rVPUqFEjODo66m0BfVhERAQEQSiz/p0+N27cwPLlyzFo0CCdL7OGDx+OkydP6syV169fx/79+3Wq0B9WWFiIGTNm4N1334WXlxcAzU7ON2/e1P7tcPXq1Urfr19++WX4+vrizTff1CZYH5aUlISPPvqo0vt2+vRpyGQyREREVDqWiKguYMUbEZGR7NixQ+9i3506ddKpLKmqmTNnYsuWLRg0aBAmTJiA8PBw5OTk4OLFi9iwYQPu3LkDDw8P9OzZE8899xz+97//4caNG+jXrx/UajX+/vtv9OzZE1OnTgUAhIeHY+/evVi4cCH8/PwQFBSks0j8owYMGABHR0e89dZb2mTCwxo1aoSPPvoIs2fPxp07dzBs2DA4OjoiKioKmzZtwosvvoi33nqr3PN/8skn2L17N7p3744XX3wRzZo1Q3x8PNavX49Dhw7BxcUFb7/9Nn799Vf0798f06ZNg5ubG3744QdERUVh48aNZdaNqqnQ0FBERkZi2rRpUCqV2g/4D39IHT16NP7v//4PTz31FKZNm4bc3Fx89dVXaNKkSZlNEcp7zP/zn//gwIED6NChA1544QU0b94c9+/fx5kzZ7B3717cv3+/3BhbtWqFMWPGYNmyZcjIyECnTp2wb98+vZUgH330Efbs2YMuXbrg1VdfhZWVFVasWIGCggJ89tln2nF9+/ZFgwYNMGnSJMycORMKhQLfffcdPD09ERMTU+a8TZo0waRJk3Dy5El4e3vju+++Q2JiIr7//vtqP+ZV9cknn2Do0KHo3LkzJk6ciLS0NCxZsgShoaE6H87LEx4ejq+++gofffQRgoOD4eXlVabqxlCq+vz27dsXPj4+6Ny5M7y9vXH16lUsWbIEAwcOrHBB8xdeeAFLlizBuHHjcPr0afj6+uKnn34qs54ZoFnEfcOGDejXrx9GjhyJW7du4eeffy6zRuBzzz2HdevW4eWXX8aBAwfQuXNnlJSU4Nq1a1i3bh127dqldyMUUXh4ONauXYsZM2agXbt2cHBwwODBg/Hiiy9ixYoVmDBhAk6fPo3AwEBs2LABhw8fxqJFiyq8n506dYKrqyvGjx+PadOmQSaT4aeffqpSgmjYsGFo37493nzzTdy8eRMhISHYsmWL9rF/uBrt888/R//+/REREYFJkyYhLy8PX375JZydnTF37txKb6uix6Q677m1oarzRXn8/Pzw6aef4s6dO2jSpAnWrl2Lc+fOYeXKlTob2+hjbW2NTz/9FBMnTkT37t0xZswYJCYmYvHixQgMDMQbb7yhHVvT1zug2fCoS5cuCAsLwwsvvICGDRsiMTERR48exd27d3H+/HkAQPPmzdGjRw+Eh4fDzc0Np06dwoYNG7SPxT///IPevXtj5MiRaN68OaysrLBp0yYkJibqbMCiT5cuXeDu7o69e/eWeb9p3rw5RowYgQYNGiAqKgpfffUV3NzcsHz5cp1xr776Kr7++msMHDgQb731FqytrbFw4UJ4e3vjzTff1Hu7ixcvBgBMnz5de2zAgAGYMmUKxo4di06dOmHevHk6FX36uLq6YtOmTRgwYABatWqFZ599VptgPXPmDH799dcqJdP27NmDzp07w93dvdKxRER1Qq3snUpEZEG+//57AUC5l++//147NiAgQBg4cGCZcwAQpkyZUuZ4VlaWMHv2bCE4OFiwsbERPDw8hE6dOgn//e9/hcLCQu244uJi4fPPPxdCQkIEGxsbwdPTU+jfv79w+vRp7Zhr164J3bp1E2xtbQUAwvjx43Xij4qKKnP7//rXvwQAQp8+fcq9/xs3bhS6dOki2NvbC/b29kJISIgwZcoU4fr165U+dtHR0cK4ceMET09PQalUCg0bNhSmTJkiFBQUaMfcunVLGD58uODi4iKoVCqhffv2wtatW3XOc+DAAQGAsH79ep3j4n07efKkzvE5c+YIAITk5GTtMfE5+Pnnn4XGjRsLSqVSaN26tXDgwIEyce/evVsIDQ0VbGxshKZNmwo///yz9pwPK+8xFwRBSExMFKZMmSL4+/sL1tbWgo+Pj9C7d29h5cqVlT5ueXl5wrRp0wR3d3fB3t5eGDx4sBAbGysAEObMmaMz9syZM0JkZKTg4OAg2NnZCT179hSOHDlS5pynT58WOnToINjY2AgNGjQQFi5cqPd3Q/wd3rVrl/DEE08ISqVSCAkJKfPYi8/Jw4/f+PHjhYCAAO2/o6KiBADC559/XiYeffdlzZo1QkhIiKBUKoXQ0FBhy5YtwjPPPCOEhIRU+pglJCQIAwcOFBwdHQUAQvfu3cuNs3v37kKLFi3KnKM6r9+qPL8rVqwQunXrJri7uwtKpVJo1KiRMHPmTCEjI6PS+xMdHS0MGTJEsLOzEzw8PITp06cLO3fuLHNfBEEQFixYINSrV09QKpVC586dhVOnTgndu3fXPgaiwsJC4dNPPxVatGghKJVKwdXVVQgPDxc++OCDSmPKzs4Wxo4dK7i4uAgAdJ7nxMREYeLEiYKHh4dgY2MjhIWF6bwvVuTw4cNCx44dBVtbW8HPz0+YNWuWsGvXrkp/twRBEJKTk4WxY8cKjo6OgrOzszBhwgTh8OHDAgBhzZo1OmP37t0rdO7cWbC1tRWcnJyEwYMHC1euXNEZo+9949GfPay8139559H3etP3u1Xe60bf+6C+x6Uq84U+4uvi1KlTQkREhKBSqYSAgABhyZIllcbxsLVr1wqtW7cWlEql4ObmJvzrX/8S7t69W2ZcVV7vFb2HCIJm/hg3bpzg4+MjWFtbC/Xq1RMGDRokbNiwQTvmo48+Etq3by+4uLgItra2QkhIiPDxxx9r59iUlBRhypQpQkhIiGBvby84OzsLHTp0ENatW1fh4yWaNm2aEBwcXOb46NGjBX9/f8HGxkbw8/MTXn75ZSExMVHvOWJjY4Xhw4cLTk5OgoODgzBo0CDhxo0bescmJCQIjo6OwpYtW8r8bMeOHUJISIjg4uIijBs3TsjJyanSfbh3757wxhtvCE2aNBFUKpVgZ2cnhIeHCx9//LHOe4O+98709HTBxsZG+Oabb6p0W0REdYFMEExkxVUiIiITIpPJMGXKFCxZskTqUKgaWrVqBU9PT+zZs0fqUMgMbN68GU899RQOHTqEzp07Sx2OWenRowdSUlIqXZvTmMzx9X779m2EhIRgx44d6N27t9Th1LpFixbhs88+w61bt2p1ww0iIilxjTciIiIyO0VFRdq1iUQHDx7E+fPn0aNHD2mCIpOWl5en8++SkhJ8+eWXcHJyQps2bSSKiqqiLr3eGzZsiEmTJuE///mP1KHUuqKiIixcuBDvvvsuk25EZFG4xhsRERGZnbi4OPTp0wfPPvss/Pz8cO3aNSxfvhw+Pj54+eWXpQ6PTNBrr72GvLw8REREoKCgAL/99huOHDmCTz75hEkAE1fXXu9fffWV1CFIwtraWu86oUREdR0Tb0RERGR2XF1dER4ejm+++QbJycmwt7fHwIED8Z///IcLdpNevXr1woIFC7B161bk5+cjODgYX375ZaUbCJD0+HonIiJzxjXeiIiIiIiIiIiIjIBrvBERERERERERERkBE29ERERERERERERGwMQbERERERERERGRETDxRkREREREREREZARMvBERERERERERERkBE29ERERERERERERGwMQbERERERERERGRETDxRkREREREREREZARMvBERERERERERERkBE29ERERERERERERGwMQbUS1atWoVZDKZ9qJSqdCkSRNMnToViYmJUodHRER1mL45yM/PD5GRkfjf//6HrKysxzrvkSNHMHfuXKSnpxs2YCIiqnW3bt3CSy+9hIYNG0KlUsHJyQmdO3fG4sWLkZeXJ3V4NbZ9+3bMnTtX6jDIwlhJHQCRJfrwww8RFBSE/Px8HDp0CF999RW2b9+OS5cuwc7OTurwiIioDhPnoKKiIiQkJODgwYN4/fXXsXDhQmzZsgVPPPFEtc535MgRfPDBB5gwYQJcXFyMEzQRERndtm3bMGLECCiVSowbNw6hoaEoLCzEoUOHMHPmTFy+fBkrV66UOswa2b59O5YuXcrkG9UqJt6IJNC/f3+0bdsWADB58mS4u7tj4cKF+P333zFmzJjHOqdarUZhYSFUKpUhQyUiojrm4TkIAGbPno39+/dj0KBBGDJkCK5evQpbW1sJIyQiotoWFRWF0aNHIyAgAPv374evr6/2Z1OmTMHNmzexbds2CSMkMl9sNSUyAb169QKgmfD++9//olOnTnB3d4etrS3Cw8OxYcOGMteRyWSYOnUqfvnlF7Ro0QJKpRI7d+4E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HDggSKVS4amnnrJIbC0tLYJWq+3y/uvXrxckEolw7tw5M0ZFRD3FcaZ3cJzpPRxniOwLx5newXGm93CcsQ3Wk34lh3bttddi0aJFyM/PxxdffNHua7t27cL48ePh5uYGb29vTJ8+HadOnWq3zwMPPIDo6OgO39c4rbkzX375JeLj46FUKjF8+HDs3bv3inH+sSZCWloaJBIJvvnmG7z44osIDw+HUqnEddddh+zs7A6vX758OWJjY+Hi4oKRI0fi559/7tU6C53VRHjggQfg7u6OgoIC3HzzzXB3d0dYWBiWL18OAMjMzMS1114LNzc3REVFdXhiAwC1tbWYN28eIiIioFAo0KdPH7zyyitdmjq9YcMGyOVyTJgwod32+fPnY/Dgwfj73/+O1tZWaLVaPPzww4iKisLixYsBAKdPn8Ydd9wBX19fKJVKjBgxosPU6OrqajzxxBMYNGgQ3N3d4enpiRtuuAFHjx5tt5/x32rNmjX497//jbCwMLi6uqK+vh5tbW1YsmQJ+vbtC6VSCT8/P4wbNw7bt29v9z1SUlIAAN9///0Vj5uIrAvHmUkd9u0JjjMcZ4iocxxnJnXYtyc4znCcsUdMvJHVuP/++wG0n/68Y8cOTJs2DeXl5Xjuuecwf/587Nu3D2PHjm1XJLS79uzZg3nz5uHPf/4zli5diqqqKlx//fU4fvx4j77fyy+/jO+++w5PPPEEFi5ciN9++w333Xdfu30+/PBDpKamIjw8HK+++irGjx+PGTNm4Pz58z0+jq7SarW44YYbEBERgVdffRXR0dFITU3F6tWrcf3112PEiBF45ZVX4OHhgZkzZyI3N9f02ubmZkycOBFffPEFZs6ciXfffRdjx47FwoULMX/+/Cv+7H379iExMbHDdHEnJyd8/PHHyM3NxfPPP4/3338fGRkZ+PDDD+Hq6ooTJ05g9OjROHXqFBYsWIA33ngDbm5umDFjBr777jvT98nJycGGDRtw8803480338STTz6JzMxMTJw4EcXFxR3ief7557Fp0yY88cQTeOmllyCXy/Hcc89hyZIlmDx5Mt5//33861//QmRkJDIyMtq91svLC3Fxcfj111+7+09ARFaA44z5cJy5gOMMkePiOGM+HGcu4Dhjg8SeckeO43JT0w/3yAAACexJREFUs428vLyEoUOHmj5PSkoSAgMDhaqq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huNMV3CcIaKe4jjDcaYrOM6QERNvZHHPPvssAP3F29fXF4MGDcLbb7+N2bNnw8PDo92+KSkp2LJlCxYvXoxnn30Wzs7OmDhxIl555ZV2RSX9/Pzw3XffYf78+XjqqacQExODZcuW4ezZs50OVBMnTkRycjKWLFmCgoICDBgwAKtXrzbrFOnU1FQIgoA33ngDTzzxBIYMGYKNGzfi0UcfbTc4WxtXV1fs2bMHL730EtatW4f//Oc/8PT0RL9+/bBkyRJ4eXld9vXDhw/H4MGD8c0333RroBowYAAOHjyIJUuWYPXq1aiqqkJgYCCGDh1q+h0CgGeeeQZNTU346quvsHbtWgwbNgybNm3CggULuvyzHn30UWzcuBHbtm2DSqVCVFQUXnjhBTz55JPt9lu3bh3GjRuHuLi4Ln9vIrI8jjMcZ7qC4wwR9RTHGY4zXcFxhowkgrVUSyRyQDqdDgEBAbj99tuxcuVKscMxm//+97+YO3cuCgoK4O3tLXY4PVJaWoqYmBisWbOGT4iIyGZwnLEdHGeIyBZxnLEdHGfEwxpvRBbS2traYe3+f/7zH1RXV2PSpEniBGUh9913HyIjI7F8+XKxQ+mxt99+G4MGDeIgRURWi+MMxxkiInPiOMNxhnqGM96ILCQtLQ2PP/447rzzTvj5+SEjIwOffvop+vfvj0OHDkEul4sdIhER2TCOM0REZE4cZ4h6hjXeiCwkOjoaERERePfdd1FdXQ1fX1/MnDkTL7/8MgcpIiK6ahxniIjInDjOEPUMZ7wRERERERERERGZAWu8ERERERERERERmQETb0RERERERERERGbAxBsREREREREREZEZMPFGRERERERERERkBky8ERERERERERERmQETb0RERERERERERGbAxBsREREREREREZEZMPFGRERERERERERkBky8ERERERERERERmcH/A7vv/YJL8KWzAAAAAElFTkSuQmCC","text/plain":["<Figure size 1500x500 with 3 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["model_doubling_times = estimate_doubling_times(model_num, bootstrap_results)\n","\n","ci = 90\n","fig, ax = plt.subplots(1, 3, figsize=(15,5))\n","estimate_doubling_times(model_num, bootstrap_results)\n","doubling_times_plot(model_doubling_times[0], ci, ax[0], title=\"Param\")\n","doubling_times_plot(model_doubling_times[1], ci, ax[1], title=\"Data\")\n","doubling_times_plot(model_doubling_times[2], ci, ax[2], title=\"Compute\")\n","\n","fig.suptitle(f'Effective compute doubling times due to algorithmic progress ({ci}% CI)')\n","\n","filename = f\"{date}_model_{model_num}_delta{delta}_doubling_times.pdf\"\n","# plt.savefig(filename, bbox_inches='tight')\n","# files.download(filename)\n","\n","plt.show()"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282797,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"OQ9mwDPq8SdU","outputId":"dfb71799-6bb2-4eb3-ecd0-c6a25347a9ae"},"outputs":[{"name":"stdout","output_type":"stream","text":["Param\n","[-77.54952836   0.98283589  29.45083717]\n","\n","\n","Data\n","[-0.36142319  0.66766568  2.24090194]\n","\n","\n","Compute (months)\n","[ 4.51787288  8.44382833 14.26941928]\n"]}],"source":["ci = 95\n","\n","print(\"Param\")\n","print_stats(model_doubling_times[0], ci)\n","print(\"\\n\")\n","\n","print(\"Data\")\n","print_stats(model_doubling_times[1], ci)\n","print(\"\\n\")\n","\n","print(\"Compute (months)\")\n","print_stats(np.array(model_doubling_times[2]) * 12, ci)"]},{"cell_type":"markdown","metadata":{"id":"BqcmK3SKVvVO"},"source":["### Numerical approach (Appendix G)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":5,"status":"aborted","timestamp":1709236282797,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"QQeCIrQTDE9v","outputId":"bce57af4-d9f0-49d2-9a40-aa02a9810c37"},"outputs":[{"name":"stdout","output_type":"stream","text":["Compute (months)\n","[ 4.54749572  8.57155622 14.46016107]\n"]}],"source":["# doubling times using numerical \"optimal scaling\" approach\n","ci = 95\n","compute_doubling_times = [compute_doubling_numerical(param, model_num, 2023, compute=1e25) for param in bootstrap_results]\n","\n","print(\"Compute (months)\")\n","print_stats(np.array(compute_doubling_times) * 12, ci)"]},{"cell_type":"markdown","metadata":{"id":"wbg92zN-8fgB"},"source":["## Shapley values and pareto frontiers (section 3.2)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"Cmt9CWoN8Y8M"},"outputs":[],"source":["from autograd import grad\n","import autograd.numpy as anp\n","from scipy.optimize import fsolve"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"0z-ILv6xDGLv"},"outputs":[],"source":["custom_filename_to_load = None # @param {type:\"string\"}\n","#custom_filename_to_load = '2024-01-18_model7_delta0.0025_bootstrap_results.json'\n","#custom_filename_to_load = '2024-01-17_model7_delta0.0025_post_transformer_bootstrap_results.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        bootstrap_results = json.load(f)\n","    bootstrap_results = np.array(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"-FwDV3mx8heR"},"outputs":[],"source":["def anp_log_diff(value, constant):\n","    return anp.log(value) - anp.log(constant)\n","\n","variable_names = [\n","        \"alpha_const\", \"alpha_const_ptb\", \"alpha_const_wt2\",\n","        \"alpha_year\", \"alpha_year_ptb\", \"alpha_year_wt2\",\n","        \"alpha_param\", \"alpha_param_ptb\", \"alpha_param_wt2\",\n","        \"beta_const\", \"beta_const_ptb\", \"beta_const_wt2\",\n","        \"beta_year\", \"beta_year_ptb\", \"beta_year_wt2\",\n","        \"beta_data\", \"beta_data_ptb\", \"beta_data_wt2\",\n","        \"alpha_param_t\", \"beta_data_t\", \"alpha_rate\", \"beta_rate\"\n","    ]\n","\n","def predicted_loss(param, dataset, year_param, year_data, category_ptb, category_wt2, category_transformer, model_num):\n","    for name in variable_names:\n","        globals()[name] = params_optimized.get(name, None)\n","\n","    if model_num == 1:\n","      alpha_terms = (alpha_const - alpha_year * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_year * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 2:\n","      alpha_terms = (alpha_const - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_year * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 3:\n","      alpha_terms = (alpha_const - alpha_year * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 4:\n","      alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const - alpha_year_prime * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_year * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 5:\n","      beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const - alpha_year * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_year_prime * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 6:\n","      alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","      beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const - alpha_year_prime * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const - beta_year_prime * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 7:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_year * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_year * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 8:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_year * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 9:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_year * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 10:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_year_prime * (year_param - year_const) - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_year_prime * (year_data - year_const) - beta_data * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 11:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      alpha_year_prime = prime(alpha_year, alpha_year_ptb, alpha_year_wt2, category_ptb, category_wt2)\n","      alpha_param_prime = prime(alpha_param, alpha_param_ptb, alpha_param_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      beta_year_prime = prime(beta_year, beta_year_ptb, beta_year_wt2, category_ptb, category_wt2)\n","      beta_data_prime = prime(beta_data, beta_data_ptb, beta_data_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_year_prime * (year_param - year_const) - alpha_param_prime * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_year_prime * (year_data - year_const) - beta_data_prime * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 12:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_terms = (alpha_const_prime - alpha_param * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_data * anp_log_diff(dataset, dataset_const))\n","      combined_exp = np.exp(-alpha_year * (year_param - year_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 13:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_param_prime = alpha_param * (1 - category_transformer) + alpha_param_t * category_transformer\n","      beta_data_prime = beta_data * (1 - category_transformer) + beta_data_t * category_transformer\n","      alpha_terms = (alpha_const_prime - alpha_year * (year_param - year_const) - alpha_param_prime * anp_log_diff(param, param_const))\n","      beta_terms = (beta_const_prime - beta_year * (year_data - year_const) - beta_data_prime * anp_log_diff(dataset, dataset_const))\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 14:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_param_prime = alpha_param + alpha_rate * (year - year_const)\n","      beta_data_prime = beta_data + beta_rate * (year - year_const)\n","\n","      alpha_terms = alpha_const_prime - alpha_param_prime * (np.log(param) - np.log(param_const))\n","      beta_terms = beta_const_prime - beta_data_prime * (np.log(dataset) - np.log(dataset_const))\n","\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","    elif model_num == 15:\n","      alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","      beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","      alpha_param_prime = alpha_param + alpha_rate * (year - year_const)\n","      beta_data_prime = beta_data + beta_rate * (year - year_const)\n","\n","      alpha_terms = alpha_const_prime - alpha_year * (year - year_const) - alpha_param_prime * (np.log(param) - np.log(param_const))\n","      beta_terms = beta_const_prime - beta_year * (year - year_const) - beta_data_prime * (np.log(dataset) - np.log(dataset_const))\n","\n","      return anp.exp(alpha_terms) + anp.exp(beta_terms)\n","\n","def param_required(year, data, category_ptb, category_wt2, category_transformer, model_num, loss):\n","    def obj(log_param):\n","        return predicted_loss(anp.exp(log_param), data, year, year, category_ptb, category_wt2, category_transformer, model_num) - loss\n","    x, infodict, ier, mesg = fsolve(obj, fprime=grad(obj), x0 = anp.log(1e+13), full_output=True)\n","    if ier == 1:\n","      return anp.exp(x[0])\n","    else:\n","      return float(\"inf\")\n","\n","def data_required(year, param, category_ptb, category_wt2, category_transformer, model_num, loss):\n","    def obj(log_data):\n","        return predicted_loss(param, anp.exp(log_data), year, year, category_ptb, category_wt2, category_transformer, model_num) - loss\n","    x, infodict, ier, mesg = fsolve(obj, fprime=grad(obj), x0 = anp.log(1e+14), full_output=True)\n","    if ier == 1:\n","      return anp.exp(x[0])\n","    else:\n","      return float(\"inf\")\n","\n","def pareto_frontier(year, category_ptb, category_wt2, category_transformer, model_num, loss, min_data=1e6, max_data=1e13, num_samples=400):\n","  x = []\n","  y = []\n","\n","  for log_data in anp.linspace(anp.log(max_data), anp.log(min_data), num_samples):\n","    param = param_required(year, anp.exp(log_data), category_ptb, category_wt2, category_transformer, model_num, loss)\n","\n","    if param == float(\"inf\"):\n","      break\n","    else:\n","      x.append(anp.exp(log_data))\n","      y.append(param)\n","\n","  return x, y"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"YW_EUDjV9cHb"},"outputs":[],"source":["from itertools import permutations\n","\n","identity = lambda x:  x\n","\n","def shapley_values(p1, p2, model_num, transform=identity):\n","    num_param = 4\n","    p1_change = p1[:num_param]\n","    p2_change = p2[:num_param]\n","    (param_start, data_start, year_start, year_start) = p1_change\n","    (param_end, data_end, year_end, year_end) = p2_change\n","    total_value = transform(predicted_loss(*p2, model_num)) \\\n","                    - transform(predicted_loss(*p1, model_num))\n","\n","    if model_num == 13:\n","      fixed_param = p1[num_param:-1]\n","      values = [0] * (num_param + 1)\n","      pi_list = list(permutations(list(range(num_param)) + [-1]))\n","\n","      for pi in pi_list:\n","        q1 = list(p1_change) + [p1[-1]]\n","        for k in pi:\n","          q2 = deepcopy(q1)\n","          q2[k] = p2[k]\n","\n","          values[k] += (transform(predicted_loss(*q2[:num_param], *fixed_param, q2[-1], model_num)) \\\n","                        - transform(predicted_loss(*q1[:num_param], *fixed_param, q2[-1], model_num)))/(total_value * len(pi_list))\n","\n","    else:\n","      fixed_param = p1[num_param:]\n","      values = [0] * num_param\n","      pi_list = list(permutations(range(num_param)))\n","\n","      for pi in pi_list:\n","        q1 = list(p1_change)\n","        for k in pi:\n","            q2 = deepcopy(q1)\n","            q2[k] = p2_change[k]\n","\n","            values[k] += (transform(predicted_loss(*q2, *fixed_param, model_num)) \\\n","                          - transform(predicted_loss(*q1, *fixed_param, model_num)))/(total_value * len(pi_list))\n","\n","            q1 = q2\n","\n","    return values"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":7,"status":"aborted","timestamp":1709236282799,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"XqJT6J089c62","outputId":"74eb6d1a-2619-41a2-e803-11dd67685122"},"outputs":[{"name":"stdout","output_type":"stream","text":["[[[6000000.0, 929000.0, 2012.9167277026497, 2012.9167277026497, 0, 0, 0], 'RNN (2012)'], [[11000000.0, 103000000.0, 2016.9496680475304, 2016.9496680475304, 0, 0, 0], 'LSTM (2016)'], [[247000000.0, 103000000.0, 2018.740260705746, 2018.740260705746, 0, 0, 1], 'Transformer (Adaptive Input Embeddings)'], [[257000000.0, 103000000.0, 2019.0222653598687, 2019.0222653598687, 0, 0, 1], 'Transformer-XL Large'], [[1500000000.0, 4000000000.0, 2019.1208300933486, 2019.1208300933486, 0, 0, 1], 'GPT-2 (1542M)'], [[8300000000.0, 46400000000.0, 2019.7094805849638, 2019.7094805849638, 0, 0, 1], 'Megatron-LM (8.3B)'], [[175000000000.0, 499000000000.0, 2020.4049095378489, 2020.4049095378489, 0, 0, 1], 'GPT-3'], [[280000000000.0, 300000000000.0, 2021.9354008160487, 2021.9354008160487, 0, 0, 1], 'Gopher (280B)'], [[70000000000.0, 1400000000000.0, 2022.2393087442779, 2022.2393087442779, 0, 0, 1], 'Chinchilla']]\n"]}],"source":["# param, data, year_param, year_data, category_ptb, category_wt2, category_transformer\n","models = [[[6.00E+06, 9.29E+05, \"2012/12/01\", \"2012/12/01\", 0, 0, 0], \"RNN (2012)\"], # https://www.microsoft.com/en-us/research/wp-content/uploads/2016/02/rnn_ctxt.pdf\n","          [[1.10E+07, 1.03E+08, \"2016/12/13\", \"2016/12/13\", 0, 0, 0], \"LSTM (2016)\"], # LSTM (WT103) https://arxiv.org/abs/1612.04426\n","          [[2.47E+08, 1.03E+08, \"2018/09/28\", \"2018/09/28\", 0, 0, 1], \"Transformer (Adaptive Input Embeddings)\"], # https://arxiv.org/abs/1809.10853\n","          [[2.57E+08, 1.03E+08, \"2019/01/09\", \"2019/01/09\", 0, 0, 1], \"Transformer-XL Large\"], # https://arxiv.org/abs/1901.02860\n","          [[1.50E+09, 4.00E+09, \"2019/02/14\", \"2019/02/14\", 0, 0, 1], \"GPT-2 (1542M)\"], # https://d4mucfpksywv.cloudfront.net/better-language-models/language_models_are_unsupervised_multitask_learners.pdf\n","          [[8.30E+09, 4.64E+10, \"2019/09/17\", \"2019/09/17\", 0, 0, 1], \"Megatron-LM (8.3B)\"], # https://arxiv.org/abs/1909.08053\n","          [[1.75E+11, 4.99E+11, \"2020/05/28\", \"2020/05/28\", 0, 0, 1], \"GPT-3\"], # https://arxiv.org/abs/2005.14165\n","          [[2.80E+11, 3.00E+11, \"2021/12/08\", \"2021/12/08\", 0, 0, 1], \"Gopher (280B)\"], # https://arxiv.org/abs/2112.11446\n","          [[7.00E+10, 1.40E+12, \"2022/03/29\", \"2022/03/29\", 0, 0, 1], \"Chinchilla\"]] # https://arxiv.org/abs/2203.15556\n","\n","for m in models:\n","    m[0][2] = mdates.date2num(pd.to_datetime(m[0][2])) / 365.242199 + 1970\n","    m[0][3] = m[0][2]\n","\n","print(models)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282799,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"MLOY21IO9eKB","outputId":"d16fe230-f366-4795-9cbd-9f053529c816"},"outputs":[{"name":"stdout","output_type":"stream","text":["Predicted cross entropy loss of RNN (2012): 4.434\n","Predicted cross entropy loss of LSTM (2016): 3.708\n","Predicted cross entropy loss of Transformer (Adaptive Input Embeddings): 3.186\n","Predicted cross entropy loss of Transformer-XL Large: 3.165\n","Predicted cross entropy loss of GPT-2 (1542M): 2.771\n","Predicted cross entropy loss of Megatron-LM (8.3B): 2.462\n","Predicted cross entropy loss of GPT-3: 2.080\n","Predicted cross entropy loss of Gopher (280B): 2.006\n","Predicted cross entropy loss of Chinchilla: 2.046\n","------\n","Comparing RNN (2012) with LSTM (2016):\n","\n","\n","Reduction in predicted perplexity: 43.489\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.127 - Data: 0.465 - Parameter efficiency: 0.049 - Data efficiency: 0.359\n","------\n","Comparing RNN (2012) with Transformer (Adaptive Input Embeddings):\n","\n","\n","Reduction in predicted perplexity: 60.085\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.408 - Data: 0.263 - Parameter efficiency: 0.037 - Data efficiency: 0.292\n","------\n","Comparing RNN (2012) with Transformer-XL Large:\n","\n","\n","Reduction in predicted perplexity: 60.588\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.405 - Data: 0.257 - Parameter efficiency: 0.038 - Data efficiency: 0.300\n","------\n","Comparing RNN (2012) with GPT-2 (1542M):\n","\n","\n","Reduction in predicted perplexity: 68.295\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.429 - Data: 0.325 - Parameter efficiency: 0.028 - Data efficiency: 0.218\n","------\n","Comparing RNN (2012) with Megatron-LM (8.3B):\n","\n","\n","Reduction in predicted perplexity: 72.546\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.449 - Data: 0.335 - Parameter efficiency: 0.025 - Data efficiency: 0.191\n","------\n","Comparing RNN (2012) with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 76.271\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.486 - Data: 0.324 - Parameter efficiency: 0.021 - Data efficiency: 0.168\n","------\n","Comparing RNN (2012) with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 76.843\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.484 - Data: 0.298 - Parameter efficiency: 0.025 - Data efficiency: 0.193\n","------\n","Comparing RNN (2012) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 76.540\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.447 - Data: 0.329 - Parameter efficiency: 0.027 - Data efficiency: 0.197\n","------\n","Comparing LSTM (2016) with Transformer (Adaptive Input Embeddings):\n","\n","\n","Reduction in predicted perplexity: 16.596\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.793 - Data: 0.000 - Parameter efficiency: 0.027 - Data efficiency: 0.181\n","------\n","Comparing LSTM (2016) with Transformer-XL Large:\n","\n","\n","Reduction in predicted perplexity: 17.099\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.770 - Data: 0.000 - Parameter efficiency: 0.029 - Data efficiency: 0.200\n","------\n","Comparing LSTM (2016) with GPT-2 (1542M):\n","\n","\n","Reduction in predicted perplexity: 24.806\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.658 - Data: 0.212 - Parameter efficiency: 0.017 - Data efficiency: 0.113\n","------\n","Comparing LSTM (2016) with Megatron-LM (8.3B):\n","\n","\n","Reduction in predicted perplexity: 29.057\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.631 - Data: 0.251 - Parameter efficiency: 0.015 - Data efficiency: 0.102\n","------\n","Comparing LSTM (2016) with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 32.782\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.641 - Data: 0.252 - Parameter efficiency: 0.014 - Data efficiency: 0.093\n","------\n","Comparing LSTM (2016) with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 33.354\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.632 - Data: 0.223 - Parameter efficiency: 0.019 - Data efficiency: 0.126\n","------\n","Comparing LSTM (2016) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 33.051\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.582 - Data: 0.264 - Parameter efficiency: 0.021 - Data efficiency: 0.133\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with Transformer-XL Large:\n","\n","\n","Reduction in predicted perplexity: 0.502\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.225 - Data: 0.000 - Parameter efficiency: 0.093 - Data efficiency: 0.683\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with GPT-2 (1542M):\n","\n","\n","Reduction in predicted perplexity: 8.209\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.487 - Data: 0.463 - Parameter efficiency: 0.006 - Data efficiency: 0.043\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with Megatron-LM (8.3B):\n","\n","\n","Reduction in predicted perplexity: 12.461\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.513 - Data: 0.418 - Parameter efficiency: 0.008 - Data efficiency: 0.060\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 16.185\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.568 - Data: 0.359 - Parameter efficiency: 0.008 - Data efficiency: 0.064\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 16.757\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.561 - Data: 0.311 - Parameter efficiency: 0.015 - Data efficiency: 0.113\n","------\n","Comparing Transformer (Adaptive Input Embeddings) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 16.455\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.486 - Data: 0.372 - Parameter efficiency: 0.018 - Data efficiency: 0.124\n","------\n","Comparing Transformer-XL Large with GPT-2 (1542M):\n","\n","\n","Reduction in predicted perplexity: 7.707\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.501 - Data: 0.486 - Parameter efficiency: 0.002 - Data efficiency: 0.012\n","------\n","Comparing Transformer-XL Large with Megatron-LM (8.3B):\n","\n","\n","Reduction in predicted perplexity: 11.958\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.522 - Data: 0.429 - Parameter efficiency: 0.006 - Data efficiency: 0.044\n","------\n","Comparing Transformer-XL Large with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 15.683\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.575 - Data: 0.364 - Parameter efficiency: 0.007 - Data efficiency: 0.054\n","------\n","Comparing Transformer-XL Large with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 16.255\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.566 - Data: 0.315 - Parameter efficiency: 0.014 - Data efficiency: 0.104\n","------\n","Comparing Transformer-XL Large with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 15.952\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.491 - Data: 0.377 - Parameter efficiency: 0.017 - Data efficiency: 0.116\n","------\n","Comparing GPT-2 (1542M) with Megatron-LM (8.3B):\n","\n","\n","Reduction in predicted perplexity: 4.251\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.549 - Data: 0.362 - Parameter efficiency: 0.011 - Data efficiency: 0.078\n","------\n","Comparing GPT-2 (1542M) with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 7.976\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.617 - Data: 0.301 - Parameter efficiency: 0.010 - Data efficiency: 0.072\n","------\n","Comparing GPT-2 (1542M) with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 8.548\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.601 - Data: 0.239 - Parameter efficiency: 0.019 - Data efficiency: 0.141\n","------\n","Comparing GPT-2 (1542M) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 8.245\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.487 - Data: 0.331 - Parameter efficiency: 0.023 - Data efficiency: 0.159\n","------\n","Comparing Megatron-LM (8.3B) with GPT-3:\n","\n","\n","Reduction in predicted perplexity: 3.725\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.672 - Data: 0.252 - Parameter efficiency: 0.009 - Data efficiency: 0.067\n","------\n","Comparing Megatron-LM (8.3B) with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 4.297\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.638 - Data: 0.163 - Parameter efficiency: 0.023 - Data efficiency: 0.175\n","------\n","Comparing Megatron-LM (8.3B) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 3.994\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.443 - Data: 0.315 - Parameter efficiency: 0.031 - Data efficiency: 0.211\n","------\n","Comparing GPT-3 with Gopher (280B):\n","\n","\n","Reduction in predicted perplexity: 0.572\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 0.471 - Data: -0.258 - Parameter efficiency: 0.089 - Data efficiency: 0.698\n","------\n","Comparing GPT-3 with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: 0.269\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: -2.084 - Data: 1.093 - Parameter efficiency: 0.242 - Data efficiency: 1.749\n","------\n","Comparing Gopher (280B) with Chinchilla:\n","\n","\n","Reduction in predicted perplexity: -0.303\n","\n","\n","In linear space, fraction of improvement due to...\n","Parameters: 2.654 - Data: -1.376 - Parameter efficiency: -0.034 - Data efficiency: -0.244\n"]}],"source":["for m in models:\n","    print(\"Predicted cross entropy loss of %s: %.3f\" % (m[1], predicted_loss(*(m[0]), model_num)))\n","\n","for i in range(len(models)):\n","    for j in range(i+1, len(models)):\n","        print(\"------\")\n","        print(\"Comparing %s with %s:\" % (models[i][1], models[j][1]))\n","        improv_id = shapley_values(models[i][0], models[j][0], model_num, transform=identity)\n","\n","        print(\"\\n\")\n","        print(f\"Reduction in predicted perplexity: {np.exp(predicted_loss(*models[i][0], model_num)) - np.exp(predicted_loss(*models[j][0], model_num)):.3f}\")\n","\n","        if model_num == 13:\n","          print(\"\\n\")\n","          print(\"In linear space, fraction of improvement due to...\")\n","          print(\"Parameters: %.3f - Data: %.3f - Parameter efficiency: %.3f - Data efficiency: %.3f - Transformer: %.3f\" % tuple(improv_id))\n","\n","        else:\n","          print(\"\\n\")\n","          print(\"In linear space, fraction of improvement due to...\")\n","          print(\"Parameters: %.3f - Data: %.3f - Parameter efficiency: %.3f - Data efficiency: %.3f\" % tuple(improv_id))"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282799,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"CT8_B1Ch9fne","outputId":"e9e1567f-e88d-4116-8e5b-93ecff221a8c"},"outputs":[{"data":{"image/png":"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","text/plain":["<Figure size 284x195 with 1 Axes>"]},"metadata":{},"output_type":"display_data"},{"data":{"image/png":"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aW1t5aOPPmLt2rVDMnK8+eab/PrXv2b79u3ExcVht9v51re+RW1tLX/84x+ZPn26y+fY1NQ0or9ZIpEgnLZkWK1Ws337drRaLXa7ncmTJ1NdXc0HH3wwqCkhIQGJRDL4+QcFBfHwww/T29vL7373O5qbmwFoamoiMjJyxJ+/iCuigV2mKBQK5HI5Dz300KjHf4bj0Ucf5Y033iAzM5P29naUSuWQfVavXk1sbCylpaV88MEHeHl5ERcXx09+8hOqq6sH91u6dCmrVq2iqalpyHaFQsG7777LI488gkKhICkpieeff56HH36Y5ORk9Ho9UqmUBQsW8Nvf/pZ333138Lhr1qyhubmZmJgYbrnlFp544gkXfd/85jfp6Ohg3rx5/PSnP+XHP/4xe/fuJSYmho0bNw7mvAK4/fbbWb9+/VnHn1JTU/nOd75Deno6d9xxB3/9618Ht7399tusXLmSu+66ixUrVpCSkkJcXByPPPIIERERwx7P29ubl19+mccff5zU1FRCQ0Pp6upi165dEypt+eWGmI1CBICNGzfy1FNP0dvbS3R0NOvXrz/rzfh14dVXX+XgwYODkwEXE6vVyo033sgDDzzAtddee9HP/3VBNDCRK5q6ujri4uKuuHN/XRANTERE5LJFHAMTERG5bBENTERE5LJFNDAREZHLFtHARERELltEAxMREblsEQ1MRETkskU0MBERkcuW/w8OJhl3I0qFBQAAAABJRU5ErkJggg==","text/plain":["<Figure size 284x195 with 1 Axes>"]},"metadata":{},"output_type":"display_data"},{"data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAATAAAADQCAYAAACAyD3FAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjDUlEQVR4nO2dd3xb1fn/35JsSZZky5b3tuMV23Hs7D0JIQkrbMqP3RZoCy0F2rIKaWlL22+htIUWSsum7D1DyCJ727FjO957T+19f3/IVuLYSTzkxIH7fr0Uxfde3fvRtfXRc855znMkgiAIiIiIiJyDSM+2ABEREZHRIhqYiIjIOYtoYCIiIucsooGJiIics4gGJiIics4iGpiIiMg5yzlhYG63G6vVerZliIiITDBGZGBbtmxBLpeTlJREdHQ0t99++3jpGsDq1av58ssvz8i1REREzh38RvqCrKws8vPzaW1tJSYmBpfLxfr165FKpbz99ttYLBauvfZaQkNDee2113j99dd56623Buy//vrrCQoKQiKRkJWVxdatW7nhhht44okn+Pjjj/n1r3+N1Wrl9ttvx+FwsHXrVg4dOkRWVhalpaUD9t9zzz1IJBLmz5/PDTfcQHNzM88//zwqlYoXXniBxYsXj8d9ExERmQBIRpKJv2XLFlauXElMTAwymYwbb7wRpVLJ5MmTeeKJJ1ixYgWLFy/m6quvprq6GrlczpNPPjlo/7XXXkt9fT2rVq1i+fLlXHLJJSxdupTOzk5iYmLw9/dHIpFgt9tpampi6dKl3H333axdu3bI/RKJhD179jB79mxWrlzJ7NmzSU5OJjMzk/nz54/n/RMRETmLjDoCA6iurmbJkiW8+OKLaDQa3G43ADExMajVaqqrq3nmmWcG7Y+KisLf35/AwEBiY2MJDAzE5XIB4HK5+Prrr4mMjOTjjz8GQCqV4nQ6T7ofID09HYDvfe97qNVqPvvsM3bu3CkamIjIt5gxdeKr1WqUSiV33XUXer1+xPuH4h//+AcXXXQRM2bMwM/P46/Lli3jtttuY+vWrUPuP566ujruvvtutm7dypIlS8by9kRERCY4I2pCioiIiEwkzok0ChEREZGhEA1MRETknEU0MBERkXMW0cBERETOWUQDExEROWcZcR7YeGG12Whua0OtUuEnk51tOSIiImcJp8uFyWwmOiICpUJxymMnjIE1t7Wx8+Chsy1DRERkgjB/+jSS4+NPecyEMTCNSgV4RGsDA73bnW43RrsNjVyBn3RitXhFbaNnIusTtY0eX+jrNRjYefCQ1xNOxYQxMFlfs1EbGIguONi73el2IbVaCVYq8ZNOrKalqG30TGR9orbR40t9smF0JU08CxcREREZJqKBiYiInLOcswbW02k42xJERETOMuekgX384hYuT72bQ9tKzrYUERGRs8g5Z2But5vPX/kGQ4+JO8//A1s/2n+2JYmIiJwlzjkDk0qlPPX5/Sy+ZAZ2m4NfXv4EH/5n09mWJSIichY45wwMQBkg50/v3cMlty7F7Rb4/Q//zb/XvYNY2kxE5LvFOWlgAH5+Mh7+z+3c+vBlADz/m/f43Q+ew+lwnmVlIiIiZ4pxT2T98MMPyc/PJzo6mu7ubpqamvj73//uk3NLJBJ+9Ng1RMaF8qcf/5ePX9hCa30nf3z352iCTp/FKyIicm7jkwjs/fffJy8vj+3bt3PllVdyxRVXUFhYCMDatWsJDg7m9ttv57rrrmPlypW+uOQALr99BX/56D6UKgV7NhTyw4XraKnr8Pl1REREJhY+icAWLVrE2rVr2bhxI48//jjR0dH86le/4plnnhlw3BdffMEPfvCDU57LardjsR1bhdvd9+x0u4d+QR/z1uTxry2/5r5L/kJFYR03z3mYP31wD9mzU0b1noZDv6bTaTsbTGRtMLH1idpGjy/0jeS1PjGw8PBwAHbs2MGDDz6Iv78/drt9oCinE4lEctr5TZt37R7wc8qkZFJTJmE84XxDEZUdzZNbHuTRK/5OzZEGfrzsMe57/vssunzWCN/RyBiOtrPFRNYGE1ufqG30jEWf0W4b9rE+7QOLiYmhrq6O6Oho5HK5d/vdd98NwG233XbacyybN5cQbZD3ZzdgcbnQyOXDmt0enBbLf7Y/yiPXPcPOL/L5ww3P8oOKNm55+DKkPp6975l5bx+2tjPJRNYGE1ufqG30+EKf23qWDOzWW2/lgQceAOChhx4a1TmUcjkBCqX3Z6fbhcXlwk8qHfbsdm1wIE9+8kv+dt+rvPHUF/znN+9TfaSRR1/6EQFq5elPMEJGou1MM5G1wcTWJ2obPWPRNxLj85mBrVu3DoDFixf76pRjQiaTcs9fbyI1J4HH7/gPG9/dQ115C3/58F5ikiLOtjwREREfMPFiUB9zya3L+NemX6OL0FJeUMuNMx9i36aisy1LRETEB3zrDQwgb+FkXt7/ezJnTKK308Cd5/+eV//yiZi5LyJyjvOdMDCAqPgw/r1tHRfeuBi3W+Dvv3idB6/5GyaD5WxLExERGSXfGQMDzxzKR1/6Eb985lZkfjK+fmc3N89+iKrihrMtTUREZBR8pwwMPNOPrvrxSp7b+gjhMSHUlDZx8+yHWP/GjrMtTUREZIR85wysn9z5Gbx26I/MXJ6NxWTj4ev+weN3/Ae73XG2pYmIiAyT76yBAegitDz91UPc+vBlSCQS3n/ua3raj5Wq3vN1IV/+bzt2m2hqIiITkQmzrNrZQiaT8qPHriFv0WQ6GruJiNUBYLPaaaltJy41ij/f+SIPP3/6WQQiIiJnlu+8gfUzb2XugJ8VSjmXfn85DruTN//2xZCvkZwJYSIiIidFNLATcNidvPn3L+jpMOByutB3mbju52vY/MFetn60n+TMWG785SWeielSGcHKAEDMJxMRORt8p/vAhkIilWAxWolNjuBn/3c9j7xwBya9hdID1Tz64o+w25w0Vrd5j5/oc9JERL7NjLuBffjhh6xbt46vv/6aP/7xj/zzn/8c70uOCT8/Gbetu4rI+FD+89v3cLvdfPrSVm7/7VVIJBJqjzbh5ydj/Rs7qC5pPNtyRUS+05yxiqzbt29HoVCQnp7ui0uOOwvWTOPWhy+nq7WXxIwYpFIp7z/3NTOXZRMRp6OzpYePX9h8tmWKiHynOWMVWdvb21m3bh2PPfYYK1asOOm5hlORtbKslbde3sldv1pFYFCAL96CFwkg62sSymRSQqOCkUgl/OaWfzF5ejLX3LWK7nY9hbvKeez1O4c8h1tw4z7L8yy/C5U7xwtR2+j51lZkXbNmDevWrSMqKuqU5zpdRVZBEPjdQ+9TUdzM3p0V/PSRC5k+b5Iv3oYXCRKClUpkUikSiYQ7fnu1d5/b7eaJu1/mZ09cj8xPxpG9FWz79CBFu8t58pNfIlf4IwjQY7We4gpnjm9z5c7xRtQ2er6VFVkvvPDC055jOBVZ73v4In73wPs01Hby6J1vcuk1s/jxvStRqRU+ey8CAm7BjVQysJX98QtbWH39Qhqr2vjbfa+x7PLZJKRFoQ4KQK7wBzzTlYKVvi+cOBK+C5U7xwtR2+gRK7IOoyJr7rQkXv3gTv755Fe889ouPnprH3u3V/Dg7y5j5tzxW8QD4JJblyKVSrHbHOz6soC2hi4qDtfx6Es/8h4jlUiQSibGyOREHyWdyPpEbaNHrMh6GpQBcu556CKWrMji9w+9T3NjN3fd8gKXXTObn/xiFWofRmPH019XX67w54ePXsFdFzxO3sIMJJJjaa1dbb3oIrTjcn0REZFjTLwYdITMmDOJVz+6i7XXeFYe+uCtvVx/8d/Zta1s3K/d22nk3qdu5IePXund9vT9/+PqzHv57JVvxIKJIiLjzDlvYABqtYJfrVvL0y99n9h4HS3NPdxz28v85lfv0NttHrfrRsTqyJiWjL/cE8g6HS4K91TQ22Vk3U3/5K4L/kBDVeu4XV9E5LvOt8LA+pkxZxKvfngX1960AKlUwpcf53PthX9l/Sf5ZyQa8vOX8cxXD/KTx7+HXOHPng2FXDvlF7zy549xOpzjfn0Rke8a3yoDAwhQyfnZ/Wv49/9uZ1JaJD3dZtb98h1+/sOXaKjr9Om1nG4XPVYLTrfLu83P34+b77+UNwr/zMxl2dgsdv7xq/9xw4wHObxr/Ju1IiLfJb51BtZPdm48L737Y27/2Qrkcj/27Kjg/13yd156bgsOu++ioZMl3SWkRfPPjQ/zyIt3oA0NpKKwju/Pf4Tf3/ZvejoNQ75GRERkZHxrDQzAX+7HzXcs49UP72LG3EnYbU6ee2oDN1z2NAf2VI379SUSCRffvJR3S5/gkluXAvDh85u4MuMePvrvJtwTNJtaRORc4VttYP0kJIfxjxduZd2fryIkVE1tVTt33vxfHv3F23S06cf9+sFhQfz6v3fw728eJWVKPL2dBn73g3/z/fmPUHqwetyvLyLybeU7YWDgiYYuuDiPNz/7OZd/bw4SiYSvPi3gmjVP8cZLO3A6XKc/yRiZtiiT1w4+zs/+cj0qjZKiPRXcOPNBHr/jP/R0jL+Rioh82/jOGFg/QdoAfvHIJfz37TvImhqH2WTj73/6nBsve5p9uyrH/fp+/n5cf+9FvHv0SS743nwEQeD9577m8rSf89Y/vsTpHH8jFRH5tvCdM7B+MqfE8fwbt/PAb9cSHKKiurKN5//+tXd/XXUHf1r3If98cj0Gve8Xvw2P0fG7//2U57Y+SlpuIoYeE3/56Utcl/sr9mw47PPriYh8G/nOGhh4pgVdctUs3vriHq69aT6/f+p73n0CAnfet4q1V8/iP09vGvL1vqiJP31xJq8eeJz7//V9tKGBVBc3cOfKP/Dzi/5ETalYMFFE5FScsYqsW7Zs4bHHHmPTpqHN4GwSpA3gZ/dfSHjksSoYicnhKAPk7NtZSXRsMM2N3Tz3tw0UHKjxHiOTyghTqZGM0cpkMilX3HE+75f/lWt/thqZn4ztnx3i2pxf8n93vSj2j4mInASfTOZ+//33+e1vf8vTTz/NU089hSAIrFu3jpycHNauXUtNTQ1lZWVoNBqczlPnYA2noOF4IJN4an9ZLXbeeGkHJqMNl8tNdm48C5dN5i+PfcLPH7yQ5/+xkUlpkQMKKcqkUgTBU35nLPn+Km0AP3vyetbevpynf/kG2z89yNtPr+ezV77h5gcv5co7L0AZID/9ifhuFL4bL0Rto+ecLGg4nIqs8+fPZ8qUKfz+979n5cqVJz3X6Qoajhe6AJUnjuqrKqFQ+nHdrYtQqxU8+ftP+emvVhMRpUUZ4I/FbOfLT/IJ0WlYsToHz8skyCQyXG43PVbLmIxMm6jjobd+Qv6WEp5/4C2qDtfzzP1v8vbTX3HjI5ex7Nq5yGTDC56/zYXvxhtR2+g5pwoaDqcia2VlJR988AExMTGnPNdwChq63QJuQcBvmB/i4SEAEpRKf2750TIa67t448Xt/ODO8zCbbETHhtDW2ovd5iQ8MoiEpDC2by71Glg/MqmUkAAVbmHs35BLV01j8cpcvnh1O/9+5B3aGrp44rb/8tHTG/jxH65h7qrcAWV8jue7UPhuvBC1jZ5zuqDh6SqyXnrppac9x3AKGn62uYxX3i7gxzfPYvHcxJN+iMdCbLyOH9x5nucHCWz56gjrPy3gvl9fDMCXH+dz9wMXsm1zCV98lI82OIAf/OQ8QsMDfVvQUCrj0luWccG1C3jzb1/w8h8/ouJwHfdc9H9MX5LJTx7/HlPnnXyhlG9z4bvxRtQ2es5UQUOfWnh/Rdabb76Z2267zZen9iIIAm9+WER1fQ+/eGwDt/3iEwqOtIzLtfq558GLUAT488BjlxEaHsj2LaVMnZ5Id6eR9/63h1vuWMp1tyzi3f/tPv3JRokyQM7N91/KB5V/4/r7LkKu8Ofg1hK+P/8R7r30/6gorBu3a4uITFQkwgSputfV08MXW79h9ZLF6IKDvds9FR+sBCuVXkc3GG28+u5h3vioEJvNk/i5cHYCP7ppJmnJoeOq0+Vy8+h9b/Obv1zNk7/7hJSMKIwGK0HaAOYuTCcqJvi05/AFLfUd/Oe37/PJC5txuwUkEgkrr53HD9ddSWJ6zJD3bSIxkfWJ2kaPL/SdzAuGYuI1oodBoEbBj2+exXvPX8PaVZORSSVs31vH9Xe+z6//vIn6pt5xu7ZMJuXhx6/wdKJLJFx2zWyuu3khRfn1A8zL5RrfUaKo+DAefv423ip+ghVXz0UQBNa/sZOrM+/lN7f8i8aqttOfRETkHOecNLB+IsLUPPjTRbz57JWctzAZQYD1Wyq5+rZ3+P3fvqGlzTgu11UqPasPLVmRxZ/WfcTvH36fi6+c6d3/ryfXc93Ff2PDZ4fHveJEUkYMj791N68d+iMLL5qO2y3w6UtbuSbzPp768Us017SP6/VFRM4m52QT8mQcrezg2Vf2s2NfPQD+flLWrprMTVfnERGmHhfd9r7aYnL5sfGQixY9TmeHxzyTUyK49SfLWX5BtndBkPGkaE85zz3yDru/8kxHkvnJuOjmJdzy4FpikyPG/frDZSI3hURto+dMNyG/VQbWT8GRFp59dT8HDjcDIPeXcdlqj5GF6VTjIX8AJqOVt17ZyZsv78Cg9yTlTkqN4JYfLWPZBVOGncM1Fg5uL+HZR9/h0KZiwGNka25YxC0PriU+9dSLC58JJvIHUdQ2ekQD84GB9bO/oInnXttPwRHPwhr9RnbjVbmEh449Ihtq4dvjMegtvP3qTt58eSdGg8fIEieFc8sdSzlvdQ5+fuP3B9h/3+oO1vHiYx94IzKpVMLK7y3g5gcuJSU7ftyuP1x9E/GDKGobPaKB+dDAwJN2sfdQI8+/fpDDJR4j8/eTcukFHiOLitCMWvNwtXmMbBdvvXIsIotLCOWGHy5m9SV53lWNfMmJ2gp3l/PC795n+2eHvMcsvWwWtzy4lqyZ47sY8HD0TSREbaNHNDAfG1g/giCwL7+J5/93wBuRyWQS1pyXxk1X5ZEQO/KFaEeqzWiw8u7/dvPmSzvo7fEs9xYZreW6WxZyyZUzhz3PcSzaSg9W8+IfPmDz+/u8KzXNXpHDzQ9cysxl2eOSFDwSfRMBUdvoEQ1snAysH0EQOFjYzH/fOMT+gibA06xasWgSt98wg/iYY0ZmNNlRq/xPMV1ndNrMJhsfvr2P/72wzdvZHxyi4uob5nPFdXMJ0gac5gyn53TaqoobeOVPH/Pl69u9KR+ZMydx068uYells8e9n24ifxBFbaNHNLBxNrDjOVzSyotvHvKOWj5w10IuW50JwN/+sxupVEJ7p5mf3zaXkCFMxel20Wu1oh2lNpvNwWcfHOT1/26jqaEb8CwLt/bqWVxz43wio4NH/d6Ge9+aa9t57S+f8tF/N2OzeOavxqVE8v/uvZCLblqCUqUYtQZf6DsbiNpGj2hgZ9DA+imr7OTdz47w4E8Xe7fZHS7k/jI276jG6XSzdH4SZVWdpCTpUCoG9lm53G5kY0iRcDpdbPyyiFef30plWV/z1k/Kygtzue7WhaSmj3zUcKT3rbtdz1v/+JJ3n/mK3q6+qDAskKt+spIrf7wSXcTIm9i+1HcmEbWNHtHAzoKBDYXV5mTX/nq+3FzBr+5cyBPP7mRWXiwHC5v5zX1Lx6WvSBAEdm8r4/UXtg9Y9m3OwjSuu3khs+anDPu6o71vFpOVj1/Ywv+e/IymviRYucKfNTcu4nt3r2FSVtzI3pSP9Z0JRG2j51s3lai/IivAY489xocffjjelxwTbR0mHv3LZl544xABAf78/oHz2LC1kktXTWbtqskEKP0wmux8uqGMLzdX+PTaEomEeYszePql7/Pft3/E8lVTkEol7Nlezs9+8CI3rP0Hn75/wJs8Ox4EqJVcc9cq3it/isffvpvs2SnYbQ4+fH4T12Tfx12rHmfnl/lMkO89ke84Z6wi6+bNm5kyZcppzzWciqwut4BUgk+joP5vC11wALPyYjlc3IrL5UYmlVBc3s7Vl2TjdLkxmR0oFX7oggPYsb+OC5amUFHTRYg2YECSrNM9ttWF0rOj+c0TV9PU0M07r+7is/cOUlnWyu8fep9/Prmey66dzaVXz0IXNnQayJgrY0ph6RWzWHL5TA7vLOPNv37BNx/tZ/f6AnavLyBxcgxX3bmS1TcsQqVRnv58vtY3jojaRs+ZrsjqkyZke3s7zzzzDBKJhOuuu25QRdannnoKk8mEzWajo6ODf/7zn4PO0R82nkh/RdbjeXtPI2/ubuDGhQmsyY1E7jf2QFLl74/K/1gag9stsC+/kdnTYln3xBYevWcpr7xTQNokHQtmJfC3/+zmqouzqajuoqi0DZfbTXZ6BMsXJgOgt1mxu3y3RJrRYGX9+4f49K39dLQaAPDzl7F4ZRYXf28WqZnjn13fXN3OJ89u5MuXt2HpS8xVawM4//qFXHz7MmJSIsddg8i3H71ez649+85sH9i6devYuXMnn332Gf7+/vzwhz/k+eefBzwGdvfdd1NTU0N+fj5r164d9Pp+AxtORdbVT2ynoN5TcSIiSMGN8xO5cUECYYFjGzGTIBmyM/5wcSufbSxjalYkF56XTnevhedePcD9dy7kk6+OEhmuITMtjGde2sf9dy4EPB37wpgKSw+N0+Fiy4Zi3nl1F8WHG7zbp+TFc8X/m8vS87Pw85eNa+VOk97M569s4+1/rKehwjPoIJFImLcqlyt/cj5zLph62nmfE7myqKht9PhCX1dPLxu2bT/zBlZTU8Ovf/1roqOj+cUvfjGgJv7pGEknfrfJzqs7a/nvN9U093oiAblMymUzYvnhkmSmxgcPcQXf8dyr+1mxeBKHi1vp7LZgtjhoajVw3x3zz8hcy36OFNTz9mu72PhlIS6nJ+wOCw/k0qtncdGV0/ELko9rZ6/b7WbXlwW89Y8v2fVlgXd77KQIrvjR+Vx8y1KCQwOHfO1E7owWtY2ec3YUct26dSxfvpynn34agIceeojc3Nxhv340o5AOl5tP8pv495YqDtb2eLfPnqTjB4uTuTA3Gv9xSMhsbTcSGa7h//61g5v7Jog//o/tPPjTRd5j7n7kS666OIu50+PGPSm0o03Ph2/v48O39noTY2V+UuYuTeea/zePmXOGP3o5WurKm3nvXxv45MWtGHpMgGf0csXVc7niR+eTMzdtgIaJ/EEUtY2ec9bAxspY0yj2V3fxn2+q+fhQE0635y31Ny9vmJ9IdPDYs9tPpEdv5cU3D2Ew2lm2IIlFcxIBTxLs6+8XAhATFcjlqzO5ZGUGwdqRd3aPBIfdyZYNxbz3xm4KDtR6tyelhHPZNbNZfem0AcvBjQcWk5Wv3tzJu//cQOnBau/2tKkJXHb7Clb/v4VotKoJ/UEUtY0e0cDGmAfW2mvl5R01vLKzlja9Z3UTmVTCmqlR3LwwiYVpYeMejTQ09/LupyV8suEoBqMnu93fT8p5iyZx+ZpMcrMix11DaUkjb72+i62fH8HSl2GvUPqzYnUOa6+eRXZu/LhqEASB4n2VvPuvDWx4cyc2qwMApUrBymvncfH3lxKbG0dIQMCE+yBOZJOYyNpANDCfJbLanW4+P9zMC9uq2V3Z5d2eEqHmpgVJXDM7nhC17yZPD4XV6uSrbyp599NiSis6vNuTE4K5fHUmq5enETTGgYeT0X/f/J3w9aeFvP/mXqrKW737U9IjufSqWVxwcZ5P5l6eCn23kc9f3cb7z22kuvjYwENSVixrf7icC29YfNK+srPBRDaJiawNRAMbl0z8I429vLyjlnf21WPqWwRE4Sfl4rwYblyQyJxJulFFI063C7vLhdLP75R1wQCKy9p57/Nivtpa6V2IRCGXcd6iSaxdNdnnUdmJ900QBIry6/nw7b18/UUhdltfJVmFH8tXTuHiK2cwbVbyuEdlh3eW8cG/N7Lh7V3Y+6Iyf7kfS9bO5NLvL2PWeTlnpODjqZjIJjGRtYFoYOM6lchodfLu/gZe2VFDUaPeuz09UsP18xO5eWESSn/PNbpMdspbDeTGB3u3nchotBlNdr7YVM4HX5RSUXMsMkyKD+aSlRmsOS8NnQ/6606lTd9rYf2n+Xz09j7v3EuA2AQdF10+gzVrpxER6du5jyfS3aXno1e2suGVHZQdqvFuj4jTcdHNS7j45iXEpZydyrET2SQmsjYQDeyMzIUUBIFDdT28uqOWDw42YrZ7IqLDv11JVLASi93FT18/xJqp0XyS38S/bpyO4iQm5hYEBEEY8WRuQRA4crSdD74sYcPWKqx9EZFMJmHRnEQuWZnB3Blxo159fDj3TRAESooa+fidfWz4vBCzydNnKJVKmLMgjQsvn86i5ZkD6v37iuP1VRbU8dF/N7P+fzvQd5u8x0xbNJmLbl7C8ivnoAk6c+kpE9kkJrI2EA3sjE/mNlgcvHegkc0lrbz8wzne7YLgWWvxF28V8IvVGeys6GR7eQdXzoxjbopv1540mu1s2FrJx+uPcqTs2CpCYToVq5enctGKdJITQkZ0zpHeN4vZzqb1RXz6/gHy99d4twdqAzh/zVTWrJ1GVk6cz5qYQ+mzWe1s/Wg/n7y4lT1fHfbOt1QEyFl2+WwuvHHRGWliTmSTmMjaQDSwCVONorLNyGu7agnTKJiXGspnBc08dFEmd71+iGdumE6n0UavxUFymNqn/UaVNV18sqGMzzeW06M/Nid0SkYEa1akcf7iSWgDT5+OMZb7Vl/byecfHOTzjw7R1nJsjc3ESeGsvnQaqy7OHVOtsuHoa23o5PNXt/HZy99Qe7TJuz08JoQLrlvA6usXkZ6bOCYNo9V2NpnI2kA0sLNuYFXtRtZ9WMyi9DAumx5LWKCCe98s4Ddrs9Eo/bjrtUPcvTKN//viKLnxwTT1WHjs8tNPUh8pDoeL7fvq+OzrcnbsrcPVl9vm7ydl0ZxE1pyXxvyZ8fidZB6oL+6by+Vm/+5KvvjoEFs2FHtTISQSCdNnJ7PqkjyWrcxGParJ3MPT15+O8enL37DhzZ3eWmUAqTkJrPp/C7jgewuISggb+Rsco7azwUTWBqKBDcvAtjV2cqCtl+syYonwccVQm8PFl4Ut7KzoJD5UxU+Wp3DPGwX89bo8ajpMvLyjhkcuycItePLLbv3vPv5760xe3VlLZbuJO5ZO8nnSbGe3mfVbKvn06zIqqo91/AcHKTl/8SRWL08jOyN8XDPdTUYrm9YX8eXH+RzceyxBVa7wY9GyTC64OJe5C9OGvUDJaPQ57E52fH6Iz1/dxvZPD+I4rqzQtMWZrLpuAcuvnDPmlIyJbBITWRuIBjYsA7v68/28U96MTCJhdVIEN0yO45JJkSh9vExZa6+VSK2SX759mEVpYXx4qJE/XJlDZJCSilYj/91WzbSEYKQSCSa7k0unxfD7T0r4v2uGP4VqpJRVdvL5pnK+3FJBV7fFuz0uOohVy1K5YGkKiXHB4/qH3tzYzfpPC/jy43xqq4712QVqA1h+wRRWXphL3szEU07oHqs+fbeRje/u4cvXt3Nwa4l3u8xPxtyVU1n5vfksuXQm6sCRf5lMZJOYyNrgW2hgH374Ifn5+URFRaHX64mKiuLGG28cdNxIDOz5olqeL6pjX2uP97gguR9XpcVw/eRYFseGIvVhv5Td6WZHeQc5cVqq2k28urOWvIRgLpsRi04t57aX9vPcTTNwuQXue+swT12X57Nrnwyny82+/Ea+2FTBlp013lFMgMy0MM5fMolZs2NIidGN2x+6IAgcLW5i/ScFbPiswDsPEyA8MogVq3NYsWYqmVNiB/UT+vKD2FLfwYa3dvHl6zsoy6/xblco/Vlw4TTOv2Y+Cy+cNuz6/hPZJCayNjhHDexUBQ3BU07nZz/7GU899RSTJk3i0ksvHbboU92Q0i4Dr5Q08FppA/XGYx3e8Rol38uI5bqMWKaGBfm0k72118pbe+tp7LawIjuS+amh/O6TEh6/Moevj7TSprdx3bwEAP65sYKM6EAWZ4SPy6TyfswWB9/sruWLTeXsPdTo7S+TSGDalChWLkll+YLkcZ2L6XK5ObSvmvWfFLBlwxHvQr4AsfE6zludw4rVOaRmRCGRSMbtg1hT2sj6N3by1Zs7qStr9m5XqhQsung6K66ex/zVeadcwm4im8RE1gbnqIENp6BhdnY2559/Pn/84x+5//77Typ6OPXATsQtCGxr7OL1o428X9FC73F9I9k6Ddekx3B1ejQp2pGtxi3p+3eoHC+3W6C6w0RiqIrbXz7AzQuTeHFbDc/eNMNbYDHpvs8w212EqP25KDeatdNjmD1Jh0w6ftnu3b0WNm2r5qutVRSWtHm3y2QSZuXFcN6iSSyem0CgZnymMAHY7U72bC9n4+dF7NhSitXi8O6LTwpl+QVTWLwyi/DEYAIVinGpayUIAuUFtWx4cxcb39lDc82xpm6AWsGCC6ex/Mo5zFudOygym8g1tyayNjjH64GdqqChTqejubmZjIyMUxY0PJGhKrKeCqvTxYb6Tt6raGVDXQd297G3Nz08iMtSIrh0UiTR6qE/wAqZH4GKgfscLhdGuw2VvxyF3+BO6tZeKzsrOlmWGU6wyvPNXtWu5+9fV7C+sJVO47EPcHignAtyIlidG0luvBbpOJpZa7uJbTtr+WZHLRVV3d7tfn5SpudGsWheAnNmxaEZxzmhVoudvd+Us31DCft3VOKwH6tSG5uoY8GKySxckUlSWsS4TWMSBIGyA9Vse38/297fR1v9sYEQhUrOzJU5LFw7g9mrpqIaRZ+ZiG85axVZfVHQcDQR2MnosTn4sLKFt8qa2dTQQb+XSYAFMSFclRbN5SnRRPWZ2ckqsh6PIAi4T5N5LwgCLqGvNrjLzc6KLj461MTnBc30Wo5Fh9HBSi7KjeaivChmJIb41MxO/Casa+xl4zfVfL2tiuq6Hu9xfn5SZk+LZfnCJBbOSSBoHCMzk9HKzi1lbFpfxJ7t5QPNLF7H0pVZLDk/m8lTYsbVzIr3VbH5vT1senfvgMjMX+7H7PNzWLR2Jnkrs4mNCZ1wUY4YgQ3knC5oOBJaTTberWjijaON7Gg+Fo1IgCVxoVyVGsMdUxORSiQIgsAbRxupNVi4YXIccSf5VnYLAm7BPWxddqebLaVtfHiwiS8LWzAe1/EeE6zkotwYLsqLZnaybsxmdqr7VlXXzcZtVYPMTCaTMDM3huULklkyL8knczJPRq/exIYNR9i7uYw928u9k8sBIqO1LD4vi6XnZzF1eiJ+Ph5d7kcQBI4eqmHju7vZ9N7eAX1mUqmEvMWTWXbZbJZcOpPoxPBx0TBSxD6wgZyTaRRjpd5g4Z3yJt4ub2JPSw8AUSoFzT9cCUBhh549Ld2sSozgp1uLeP+iWVicLppNViaNsB/tZFgdLraUtvPRoUbWF7YOMLOIIAVrpkZzUW4081NDRzUfcrj3rd/MNu+oGTC5XCqVkJsVybL5ySydn0RUxNCrH42W4/XZLU52flPGlq+OsPObo1jMdu9x2mAVC5dPZsl5Wcyan4pS6e9THf0IgkBVcQOb3tvL5g/2Up5fO2B/xrQkllw6k8WXziQ9N3Hc67mdDNHABvKdNLDjqdGbebe8mTqDmb8vzRmwz2B3cvNXh3juvKnctvEwsyODcQoCD89O96mGfjP7JL+J9UUt6I9rZoao/LkgJ4o1U6NZkhFOgHx492A09622oYfNO2rYvLOakvKOAfsmp4axZG4iS+cnMSkxZMwf4JPps1od7NtZwdavi9m2qQR977FcN2WAP3MWpLHovEwWLMkgOMQ3XyZDaSstrefQl0Vs+3A/+duPDlgHMzoxjMWXzGTRxdOZviRr2Mm7vtImGtgxvvMGNhQmh5NXSxo42N7LL6an8GppA9emx5IVGsj3N+TzxwWZ/GpHCUqZlOXxYVyZFuOza9udbraVtfNpfjNfFLbQZToWjajkMpZnRrBmajQrsiO8AwZDMdb71txqYOuuWjbvrKaguBX3cYMhsVGBLJ6byJJ5SUzNihy3CNHpdFFwoJatXxfzzcZiWpuPzcuUSiVMnZ7IwmWTWbQsk4Tk8ZtK1N2uZ9unBz3rYn51GJvl2O9EHRTAvAtyWXjRdBasySM4LOgUZ/a9tomGaGDDMLAumw0/qYQgf9+Pnu1r6eHmDYf4+5IpnJfg6fe46atDvLxyGjanix9tLuTXs9ORSSAhSMU1nx/gzdXTeaWkgVqDhZsz40jwUekXp8vNnqouPivwmFnjcZn3flIJ81JDWZUTxQVTokgIHXhNX/6hd/da+GZ3LVt31bL3UCN2x7HO96BABQtmxrNobiJzZ8ShOYWpjkWfIAiUlTTzzUZPZFZe2jJgf0JSGAuWTWbh0slMnZaA30nKH41Vm9VsY8/XhWz75CDbPjlAV+sxU5VIJOTMS+szs2mkTU3weVNTNLCBnJMG9peSIl6sKmdOaDjnRUWzIjKGyADfdDgLgkBhh4EPKpvR2538ZVEWt24o4MWVeTxXWEOMWsnFk6IQBIGPqlrY1tjFLVnx7G/rZXViBD/afJj3L5rlEy0n6iqo7+WLw818WdhCSbNhwP6smCBW5USxckokefHBuHGPyx+62eJgz8EGtu6uZfveOvQGm3efn5+U6VOiWTQngYWzE4iNPnk0MuYIsbGb7VtK2b6plIP7qnEeZ6qBQUrmLkxn3mLPY6RNzeFqc7vdlOyv4ptPDrDtk4OUFwzsN4uI07FgzTQWrJnGrPOmjGoF89FqO1uIBjYMA/vRvl1sam0e8PpsbTDnRUZzXlQMGYG+zb5/r7yJr+raiVYreWhWGu9VNLOtqYsF0SFcmxHrnbbUa3Nw64Z83hsHAzuRqnYj6wtb+bKwhT1VnRzXwiMiSMF5WRHMSwth9ZRotAHjVHff5aawpJVte+rYuquG+ib9gP3J8cEsmJ3Aglnx5GZFDaic4dNKuwYre3aUs31zKbu3ldHTbfbuk0gkZE+NY97idOYvySA9M3oYi+6OTltLfQc7P89n26cH2bexaEBT01/uR96iycxfncf81XkkZw6eXjUcRAMbyDlpYAA1RiNftzbxdUsT+d1dA9bAjg1QsSwyimWR0czWhSGX+e4Xvau5i9/sKeOS5CguT40iSq3EaHfyUkk9hR16fjUz1TtS+fi+chxugQuTIpgWofXp/Mzj6TLZ2VjcyvrCVjaVtA0Y0ZTLpMxPC+X87EhWZEWSHD4+Hd/gGQTYvreO7XvryC9q8U5pAlCr/JkzPY4FM+OZNzOe4GDFuHwQXS43xYcb2LG1lJ1bjw5qaurCNMxZkMa8RenMXpCKNnhwc98XH0Krxc6BLUfY9UUB2z87SGNV24D9kfGhzFuVy7wLcpl13hQCg4f3exENbCDnrIEdT4fNyubWZja1trCzvQ2r+1hzQiXzY2F4BEsjo1gSEUWYwjfzAYs7DXxV186CaB03fnWIZ5blsDx+YEey8unPsLk8Ca3RagVrkiK5MCmCFQnhBI7TyJXd6WZnRQdfFbWwvqiV+i7LgP0pEWpWZEV6IrSU0JOWyh4rBqON3Qca2LG/np376gcUZwRITwllWm4US2YnkpcVfdK6ZmOlraWX3dvK2LH1KPt3VWI+LkVDKpWQlRPHnIVpzFmQRtZUzyLEvjYJQRCoK29m5xf57Pw8n4NbS7Dbjs3OkMmkTJmbxtwLpjJ35VQyZ6actOqsaGAD+VYY2PFYXE52dbSzubWZza0ttNsGfnBytCEsjYxicUQkU7QhPomKSroMvFfRTLfVwV8WZSGRSHC43bxa0sAn1a1sqGvHdFwfjb9UwuLYUNYkRbA6KYLJIZpx6ezttljo6HWyubSDr4+0sbuy07voL3hGNRemhbE8K4LlmREkhY1PdOZyuSmt6GDHvnp27q+n+Liy2eCJzmbnxTJ3Rhxzp8cRHTk+S6w57E4KDtaya1sZu7eVD1hmDjx9ZzPnpTJrfgoZM+JIT44cF5Owmm0c2FrM7vWH2fVlwYCKswBBIWpmLs9mzvlTmbNyKrHJEd59ooEN5FtnYMfjFgSKe3s8ZtbWwpHengH7Q+UKFkdEsjgiigVhEWjlnhE0QRDY3t6GQ3CzKDwS/zFO2bA5XWxt7OSzmjY+r26jotc0YH9iYACrkyJYlRjB8vgwn0RnQ903vcXB1tJ2Npa0sbG4lVa9bcBrJoWrWZYZwbLJ4cxPC0OjGJ8osbPbzM79dXyzr45DBS0DBgLAs0LTnGmxzJkex4yp0QSMU/JqW0svu7eXs3t7Oft3VWA4IUpMSA5j9vxUZs9PZfrs5FFVnh0OzbXt7FpfwO71h9m3sQhjr3nA/thJEcw5fyqzV0whb8lkBLW/aGB9fKsN7ETarBa2trXyTVsLOzraMDmP9RXNCNHxvwVLAfiksR69w050gIod7a38ekoeXXYbvXY7yZqxRwdl3Ua+qGnj85o2tjR2Yu9rZoInOpsfreOCxHAuSAwnL3x0fWenu2+CIFDUqGdzSRsbi9vYV901IDqTy6TMnqRj6eRwlk4OZ0qsbyee9+sL9JdTUdXNrgMN7D7QQNHRtgE5Z35+UqZmRjJ7WixzpsUyOTVsXBb1cDpdlBQ2smdHOXt2lFNc2IDbdUyHTCYla2ocs+alMGteKtlT48YlgdXpdFG8r5I9GwrZu+EwhbsrcDmPRe8SiYSU3ATmrJjC7PNymLZoMgHq8SuTNFJEAztDiax2t5uDXZ1sbWvhm7YW0oO0/HX67AHH6B12fn/kMD9Jm8yTpUfI1AajkvlxQ3IKdrcbp9uNaojqFCPB5HCypaGTL2raWF/bPig6Cw+Qc35COCsTwjk/IZyYYUYBI71vBouDb8o62FzaxpaSduq6BkYBoWo5izLCWJIRzpKMcOJ0Y8t1O5k+g9HGvvwm9hxqYPfBBppbjQNeF6iRM3NqDLOmxTI7L5b4GN+OOPdra2jvoaqgiQO7qti7s5KGus4BxwSo5OTNSGLG3EnMnJtC2uSo045ujgaTwcLBrcXs2VDIvo1FVB1pGLDfz1/GlDmpzFw+hZnLspgyNw2FcnxXnD8V3zoD66/IGhsbS11dHbm5uVx55ZWDjjvbmfh2txt53x+gIAh8097Kp431/DQ9i5eqy/lx2mRCFUoeKjjA/0tK4fnKMiKVSiKVAdwyKc1nOip6TKyv9ZjZ5oYOjMf1nQFkhwZyfnwY5yeEsyQuFLX/0AY6lvsmCAJV7Sa2lLazuaSNHRUd3hXN+0mJULMoPZzFGWEsTAs75ayA0eoTBIGGZj17DjWy52AD+wuaMJkdA46JDFczMzeGWbmxzMyNIcIH/XhDaWtu7Gbfzgr2765i/+5KursGftEEaQOYPnsSM+Z4Hkkp4eMyX7KlsYNv1hdQsr2MA5uO0Fw7cMqXQulPzrx0ZizLYuaybLJmpSBXjE8TfCjOSQMbTkXWVatWER8fz8svv8yPf/zjYYse6oZ02Mw43G6ilL5d0gygwqDn70eLuSQugeWR0UglEh7I38/jeTPptdv5e1kxt6dmoPHzJ0Am4+6De/nbDM96kvs6OyjR93BjcqpPtNhdbnY1d7G+tp0Nde0caOsdkC7iL5UwNyqEFQnhnBcfxuzIYG/lV18av8Pl5kBNN1tK2/nmaDuH6noGpEhIJDA1Tsui9HAWpocxZ5IO9Wn6z0ajz+lyU1Lezr78JvblN3K4uBWH0z3gmIRYLTNzY5gxNZoZU2NGVVHjdNrcbjdV5W3s21XJ/t2V5O+rHjC6CZ50jemzkpk2O5npsyeRmBzmk7/V47XJJFIaq9vYt7GIA5uPsH9zMZ19xQn6UQTIyZmXxoylWUxfkkX27JRxjdDOSQMbTkXWn/zkJ/zpT3/i7rvvRqMZXNlgJPXAPmw8yq7ORgL95KRqQkgL1JGq0aH1H33CZv/N7rRZ2djSTJlBj1Im497J2dxfcIA/5c3kpapysrTBzA4Nx+R08mx5KWmBQVwSl8B79TUc1esJkMn4+eRsAFxuNwK+C3A7LXY2NXSysb6DjfUd1OgHpkho/GUsitGxLD6UxTE6koMUBI1DxVO9xcHOik62lXWwvayT8hOaef4yCdMSg1mQFsaC1FCmJwWjPCFdwxd1o6xWJ4dLWtlf0MT+gmaOVnRw4l9zckIwM6ZGMy0nmmlTooZVVnuk2pwOF6VHGjm4t5qDe6opPFQ3oDwQeAwtb1YSeTM9j9FGaKfSJggCtUebObi5mANbijm0tYTu9oHJxXKFP1lzUpi2OJO8RZPJmZfq0z60c7oe2KkqslZVVaHT6Zg1axYXXnjhEKKHX5H1i9ZKivTtOIWB376h8gCSVFqSVFoSArQoZcPvn9IqlPifkPDqEgRkEglfNDWwq6OdmIAAbpqUyhs11bTZLFydkEyyWsM/ykqYEhxCq9VCeqCWGTrPyt1fNtaRqFIT7qPcs+MRBIEag4VvGrv5prGb7U3ddNkGNq90Cn/mRQezMCaEhdHBZIT4PmIFaNPb2F3ZxZ6KbnZXdtPcM3A0T+4nJS8hiFmTQpgzKYSpCVpv2W1fYjDaKSpu4/CRVgoKW6k5rtZZP4kJWnKyIsjJimRKVjgh41DzzGF3crSoicL9tRQdqKPkcMOA4o0AQcEBZE9PYMq0eLKnJ5CUFuHzwQlBEKgraaJw+1EKt5dRuO0o3W0DDU3mJyM1L4EpC9KZsiCdrLmpBIX6tnTSSPlOVGR1uF3UmfWUG7ooN3bRaDEMiHUkQGxAIKmaEFI0ISSpg5GfJqSVSiRIJaf+I6o0Gni5qoIAmYy8EB2LI6J4trwUi8vF/q4O/jJtFqmBHv2PFeXzWk0VyWoNs0PDmB0axixdGKEK30/tcQsChzsMbG7oYHN9J9uaugb1n0UEyFkcq2NJXChLYkOZPA6GJggCtZ1mdpR3sqO8k50VnbSdkK6h9JcyLSGYaUlaFqeHMytZN+wyQSOhp9fKoaIWDhU2c+Bw84Dijf0kxGnJy45k2pRocrMjiYrQ+Lzqqc3moKSwkUN7q8nfX8ORggbvIsH9qDUKcqYnkDs9kanTE8mYEoNiiL6rsWgTBIH68hYObS0hf/tR8r8poeWEwQmA5KxYchdmMHV+OlMXZBCTPPxo8ZyOwM5mRVaz00GF0WNm5YYu2m0DR9FkEgkJKi2pmhBSNToS1Vr8x9A35HS7qTQaSO+bd2l3ubjv0D6uT05hdqinisW/K47y19IjuE94baomkNmh4V5TCx2HCM3icLCloZ0DbQa2Nnaxo7kLywn9RR5DC/UaWnZooM+nOwmCQEWbsc/QOthZ0Un7CXlfniZnCPNSQpmbomNWso6gAN93PHf3WjhU2MLBomYOFjYPWCS4n6hwDVOzI0lP1zEvL47UxFCfm7zD7qS4qJH8/TXk76/m8ME6zKaB90Qu9yMzJ5ap0xOZOi2RnGkJaINVPh/Uaq5t59C2Ug59U0L+tlJqSpsGHRMWHULuAo+Z5S7IICMvEb9xGDzqZ0KNQg4XX49C9titVBi7qDB2U27ooscxsFnjJ5GSqNKS0hehHW9oNpeTPZ2N+EtlzNLFDOubxO5y0Wm3ER0wML1A77Czt7ODPZ3t7Ono4Kihd9BrUzSBzAoNY7YujJmhYUQqx96sOfG+2Zwu9rb2sLmhk60Nnexs7sLqGmhoIQp/FsXqWBwbyqIYHdPCtT5fDq7f0LaXtfNNWTsHanpo6R344ZVKPNU15qaEMjcllDkpOiKDfG/yvQYrBUdaOVTUzKGiFo5WdAwYnADQBimYmhlJblYUedlRTE4LQ+7j6VdOp4vKoy3kH6il4EAN+Qdq6O40DTouOSWCKdPiSZkSzezZKSQl+X6ks7tdz+GdZeRvLyV/WymlBwdW+gDPwEDWrBRPhDY/nanz0rx10EQDG4c0CkEQ6LRbvIZWaehC7xw4ajQnNJar47MA2NhaTXpgKDaXk6OGTtZEp3K4tw2Ly8HMkOEZ2snottvY19nB3r7HUIaWoFIzMzSMmbpQZunCiFeNvKl3uvtmc7rY19rD1sZOtjZ2srO5e8B0JwC1v4y5USEsitGxKDaUOVHBJ03bGCn9+rQKBQ1dNnZXdrKrspPdlZ3UdJgHHZ8UpmLOpFDmTNIxe5KOtEjfT78yWxwUlrRysKiZA4VNHK3oxHZC+ojcX0ZmWhhTszymlpMZQYjWt/1ogiDQUNtJwcFaCg7UcvhQLXXVHYOOC9GpmZIXT05eIlPy4smcEnvK9S5Hg9Vip3hfJQU7jnJ4x1EKd5XT22UcdFx8ahQ589LImpNC4rQE8mamopSPTotoYKdBEATabWYqjd19jy4WhMWzImrgYEGdqZdifQcRShUmp4NIpZoGs54lEYns62rC4XYzMySaAL/RN3e67TYOdHWyt7OD/V0dlPT2DGpyhiuUzNSFMlMXxgxdKOlBWmSn+fCO9L45XG4OtveyrbGLbU2dbGvsovuEQQE/qYRp4VoWxuhYEB3CghgdUaMcwTqVvpZeK7v7zGxPVRfFTfpBo4shKn9mJXvMbFayjtwELSofZcb3a1PL/Kms7qGguIWC4lYKjrTQ3WsddHx8TBA5mZHkTI4gJzOSlMQQn3fId3eZKDxUS/6BGvIP1lJR3IzjhC8cmZ+UtIwopuQleB658cTEjb389/G43W7qypop6DOzwzvLqC5pHHScUqUgc+Ykcuamkj0njSlzUomI1Q3rGqKBjRBBEBAQvB34TrebXZ0NdNktrIlO5Z36Er6XkI0bgfcbSpmkDkEhk6GTB7CtvY5rErKpN+upNfWSrQ0jRD76b2S9w86hri72d3Wwr6uDop5uHCf8itR+fkwL0TE9JJTpulByg3WDZgSM9b65BYHiTgPbmrq8ptZgHPzhnaRVsSBax/zoEOZH68gODRzWwr0j0ae3ONhX3cXeqi72VHVxqLYHywkfXj+phJw4LTOTQ5iZpGNmcghxIQE+rbklCAL1TXoOF7dSUNzC4ZLWIQcGVAH+ZKWHkzM5gimTI8iZHOmzVdH7tamkflSUtFCUX09Rfh2Fh+roaDcMOj5EpyY7N57sqXFk5yaQlRPr8zmd+m4jRXsqKNxVTuGuMgr3VGA+IcUH4KqfrOSXT9962vOJBjYG6sy9fN5UwZqYVBJUWgDerDvCtQnZNJoNlBk7WRaRBECv3cqXLZXMC4tje3s9yyOT+KypnFuS83zWGW51uTjc08X+rk4OdHVwqLtrwBxO8AxQTA7SMj0klGkhOqbpQgmXy+m12Xx632r1ZnY0dbG9qYsdzd0UdugHZbkFyv2YExnMvOgQ5kWHMDcqhJAhEifH8nu1O90UNfayt6rLa2wnTkwHiAxSMDNZx4ykEGYmhZAbHzys0c4RmavBRlFpG4dLWiksbeXI0XbMFseg4+JjgsjOiCA7I5ycyZGkJevwH0Vf2qnMtaWpx2NoBfUUFdRRVtI8qP9KIpGQNCmcrKlxZE2NIzsnjpT0qDGV4D5RX5fZTG9NFyV7qyjaU0HR7nIqi+q59283cfWdq057DtHAxoDZ6aDc2EWduRcJEi6MTuX1uiKuic/iw8ajrIhMRuuvJL+nhUpjN6uiUvmiuQKlTIYECVOCI0hSaZH0rS/p634alyBQpu/lYHcnB7s6OdDVSbN18LddpFJJVqCWmaFhzAgNIzso2KeFHcFTgXZ3Szc7m7rZ0dzFnpbuQakbAJk6DXOjQryP7NBABB+WvBYEgYZuC/uqu9hf3c2+6i6KGvWDOuT9pBKyYoKYnhTC9MRgZiSFkBKuGTRJfSx/cy6Xm6q6bopK2ygsaaPoaBs19T2DjvP3k5KREkZ2RjjZGRFkpoURH3P6CfMj0WazOSgrbubI4XqKDzdQVFBPc2P3oOPkcj/SM6PJzIkjKyeOzJxY4hNDRzW382T6zEYrgiCgHsbK56KB+Zgmi4F9XU1kBoURplDxTn0xi8ISyNJ60iWerzzIdYlTsLtdbGqr4Yq4TMAz5emF6nwSVVqS1MEkqbWEK9Q+T1Votpg51N3Fwa5ODnV3UqLvxXXCr9VfKiUrSEteSCh5ITpyg3XEBIyuiXUyXG6Bok49u5q72dncza7m7kGT08EzY2BGhJapYRoWx4axICaUaB9XVDDbnRyu72VfdRcHarrZX9M9KB8NQBvgT15CMNMTg5mWGMK0xGBCNf4+/ZvTG2wcKWvjyNF2ikrbOFLWRu8QWgI1cjJTw8nKCCcrLZys9PBBczvH+nno6jRSfLiBI4frKSlsoLiwYVAZIfDkpU3OjmVydiyZObFkToklOvb0/WniKOQENLDjsbmcVBi7qTX1YHe7WRWdwvqWSpZHJOEU3Gxrr+OS2AwA3qsvYWfnwOoBATI/ElRaElVaEtRaElRBqP18O3Jkdjop6O5kd3sbR40GCnq66bIP/sCEKxTkBOvIDQ4hN0RHjjYEjb9v8686LDZ2N/ewu8VjaPvaejDYnYOOi9MomR0ZzOyoEGZHBjMjQkuQDychC4JAY7eFg7U97K/x9KMdru8d1JcGEB2sZEpsoKf5magjNz4YrcrHWloMFJW2UVzWTtHRNsoqOwes9tRPmE5FZloYmWnhZKaFkZaiQ6qU+LRabENtJ8WFDRQXNlJS1EBZSfOgRFvwTFifnB1LRnZMn7nFDDI10cAmuIENhdFpZ2tbLW4EzotIRtU3Kmly2Kk291Bj6qXW1EO9WY9DOHGMEcIUKo+hqYJIUGuJUQaOOQP8xEm/9WYT+d1d5Hd3UdDTRam+F+cJv3oJnpy0nOAQcoJDmBqsIyNI663S4QtcboGSLgM7mrvY0dRJfruBI10GTmjtIQEm6zTMigxmVmQwMyOCyQsPQunnu78Bh8tNaZOBg3XdHKzpJr+uh9IWw6ART/AUe8xLCCY3Ppi8hGBy4rRolL6rB+Z0uqmo6aK4rJ0jZW2UlHdQXds9qBkMEB6mIjO1z9RSw5mcFjaqSesn1+KiuqKNksIGSo80UVLUQEVZ66D+NPCYWkZWjPeRkhmFOlyFThUgGhicGwY2XFyCm2aLkRpTL3XmXmrNvXTYBuc8ySQSYgOCSFAFEa8KIkGlJUyhGlHT83T3zepycaS3h8KeLgp6uino7qLRMliLv1RKZpCWHG0IU/qMbZIm8LRpHCPRZ3UKHGzvZU9LN/tae9jT0kOdYXC/np9UQk5oIDP7IrSZEcHkhAUh92HKgtHq5FBdF7uqOjjaZKKgvpe6zsH3RSKB1AgNU+O15MZ7jM3Xpma1Ojla2UFpRQfFZe2UVHRQ29AzpMFGhKmZnBpG+qRQJqeGkZEaSkSo76aK2e1OqspbKT3SSGlRI6VHmqgsH9rUAtRy0jKiyMiKJSMrhrTJUSSnRAy7AKRoYGcIt+A+7dzJ02Fy2j0pGOZe6ky91Jn1mF2Dw3el1I+4PkPrf4T4K0/6Bzqa+9Zps3K4p5vCnm4Keroo6umhx2EfdJxKJiNLG0y2NoQp2mCmBIeQpNb41GDbzDb2tfZ4H3tbe+iwDNYil0nJCQ1kRoSWGREeY5sSGohiDJHaidq6THYK6nrIr+uhoN7z3NQzuN9IIvFEalPjgsmJ15IT53no1L7rIug1WjhY2kJDrZ6yyk6OVnae1NRCtErSU0LJSAkjY1Io6SmhwxooGC6OPlM7WtzE0eImSoubqDjaMqgSB4C/v4zrbl3IHXevPO15RQM7Q4xXkm2n3UKduZd6s546s57GkzQ91TJ/4lVBXmOLCwhC669AIpH4bAZDvdlEYU83hb0eYyvu7cHsGvytq/bzIysomGztsUfSKSK10azMXW+wsK+1hwNtvd7nE5NtwROpTQkNZHq4lukRWqaFa8kNDxr2LILhaGs32DjcZ2aHG3o5XN87YOX044kLCSAnXsuU2GOmFhN88i+fkWozme2UV3dxtKKDkooOyio7qa4buvkZoPQjLTmU9D5DS0vWkZKoQ+mjyNFqt3OktJHmqi4qSlooL22mrKQZo8HKXb9czXW3LDztOSacgfVXZc3LyyM/P59169YNOkY0sJPjEty0Wk1eU6s362m2GHEPUWtM4ycnLiCQmIBAgmUK0rU6whS+a0q4BIFqo4GiPkM70ttDSW/vgKXs+lHJZGQEacnWBpOlDSYrKJiUwCDkUt8sXSYIAjV6C/vbejjY1suBNo+pdQ3RAS0BMkI0TAvXMi0iiGnhWvLCgwgbYtHf0WrrMNgo7DOzwoZeCup7qB2i+QmgU8vJjg1iSpyW7BjPc1qk5rRzT4erzWpzUlnTxdHKTo5WekytoqYLm33w70kqlZAQqyUtWUdacihpkzzP4aEqn0xhEwSB5sZulAFydMMo1XNWDGw4VVnvvvtu7/PJRA+3nM5EwNdlV0aCw+2ixWqi3qyn0WKg0WKg1Woa0tRUMn9iAjTE9hlbbEAgofIAn6VzON1uqoxGivU9FPf2UKzvpVTfi2WISM1fKiVVE0hGYBDJajVTQ3Rka4NRj2E61vEIgkC90crBtl7y2/We5w49zabBo7AAsWolueGB5IYFkRsexNSwIBIDlZgdDp/8XvUWB0UNeo406ilq7KWoQU9Zq3HI6Eguk5IWpSE7Jois2ECyYoLIjAkiVHOsCTqWvzmny019Yy9llV1UVHdRXt1FWVUnPUNMjwLPRPaUJB2pSSGkJulISdaRHB98ymjtnC2nM5yqrMMxsBMZqqChyNA43C7abGZabEZarSZabCbabeYhTU0ukRKhUBOpVBOp8DzC5CqfGbGrr/lZZtBz1KCnzGCg3KjH4BzcPwIQF6AiTRNIqiaQtEDPc4RidM2soWg12yjsNFLYYaCw00BRp5HqIaa7AKj8ZGTp1GTrNGSHasjSeR6+WozY5nBR0WqitNlIabOBkiYDZc1GjLbBhg8QEaQgPUpDRrSG9CgN6VFqksPVPikKKQgC3T1WKqu7qa7tprqmh+raHhqa9ANWh+pHIoHoqECSE4NJSvA8EhO0REdqfDb/cyQFDX02ZBIe7knq3LFjBw8++CD+/v7Y7YM7XU+HGIGNjXCVmmzCvdqUfn502M00Wgw0WYw0Wgw0W43YBTcNVgMN1mPz56RIiFCqiFZqiAkIJFqpITpAg2aUeWqhAQHkhR5brVwQBBotZkr0vRzp7aG4p4dyo4E2m5UGi5kGi5nN7ccWm9X6+5MeqCUjKIiMwCAygrSkagJRjGJGQbBSSYZOy5XHrb9isDs53KGnoENPQbuBwx16ijoNmJ0u9rfp2X9C9dLkoAByQoPICQskJyyQKaGBpGrVw5r7OQAlRAaqWZB6bMFaQRCo77JwpNETrZU06yluNFDbaaZNb6NNb2N72bHig35SCamRGiZHB5IZHUhG33NsSMCIO+lDAgKYFB0C849ts9mdVNf1UFnTTUV1F5U1XVTUdNPTa6Wp2UBTs4Edu+u9x8vlMpLjg0lODCY2NoiMSaGkJemICBt594XbOnS0PBQ+7QMbS1VWsQ/Mt5xKm0tw0241e5ueHnMzDDn6CRDkJ/cYWkAgMQEaYpSBhCtVyMYwAnu8Pr3DSam+lxJ9D6V9zc9Ko2HQbALwpJgkqTVkBGlJDwwivc/YYgNG3l8ztC43JV0GdjV1UKm3UthhpKBDT5Np6GZWgJ+ULF0gOaFBTAkLJCc0kCmhQUSrFT7RY7Q6KWnuM7UmPUeaeilpMmCwDh3JqhUyJkcHkRkdyOToICb3mVtEoG/0dHabqazppry602NuNV1U13cPKjvk1aPyJzkhhJTEEBbPTWTRnMTTXmMkfWA+X5nz1ltv5YEHHgA8VVlFJh4yiZSoAA1RARpmEA14IoBeh81rZv2PDrsFvdOO3tBJqaHzuHNIiFRqvFFajDKQ6AANgX7yEX9QdAoF88MjmB9+LCKxuVxUGPUc1eu9pnZU30uPw06l0UCl0cDnx51D7edHemAQaYFBpAf2mVtQECHykZXv9pNKydRpiFb5DTD/Toudwx16Cjv1FLTr+5qheixONwfaejnQNrCum07pz5TQQLJ1HkObEub5f+gI63VplH7MSvaUDAKP8XdbLJisUNZspKTJQEmzJ2KraDVisrk4UNPNgZqBcx51ajkZUR4zy4gK9P4/TDOy31doiIrQEBWzp8V6t7lcbppaDVTUdFFR00VpVQcNDXrqGnsxmR0UlbZRVNpGSHDAsAxsJIhpFGPgu6DN6nLSYjX2GZqRZquBZosR2xCjjuAZMIhWesyx/zlKqSZANrCTfjT6BEGgzWrlqKGXo3o9ZYZeygx6Kg36QSWH+glXKEj1GluQ5/+aoFNOmRquNpdboKrXRGGngcK+5mdhp57yHtOgmQX9RKkUZIcGkqULJDtUQ7YukKzQQHTDXOrsVNocLjeVbUaONhsoaTZQ2qyntNlATcfJ9ejUck//WlQg6X2PjKhAIoNGF7Edr09wQV1jL1W13VTVdTN7WizTpkSf9hwTLo1iOIgG5lvGU5tbEOi2W71m1txncB0280kXkQv2VxKlVBOl1BCp1BChCECOjAiVeuzrVrrd1JiMHNX3Um7QU2bwmFuDeegUBoBoZQApgYGkBQaRqvEYXIomEI2//5jvndXporTbSGGHniOdRoo69RzpMgxaBu94IlWKPjPTkKULJFOnITMkkAiVfMxzDS12FxWtRkqa9ZS1GDjaYqC02UBdl3nIBFiAQKUf6ZGBpEdpSIsKJD1SQ2qkhsTQU/f5iXMhRQPzCWdDm8Pt8ox+Wo1eY2uxGul1nLxTVidXek0tSqnuMzf1qDrqT8TkdFJh0FPe96gw6inT62mzDd2fBRClDGCSRkNcgIosbTBpQVpSNUEEj7I88vEY7E6KuwwUd3rmfx7pNFDcZRxy2lQ/OqU/mSEaMvtMLS1YRYzKn5zwYOQjWDZwKMx2JxWtRspajBxtMVDWauDoaSI2hZ+USRFq0iICSY3UkBapITVCQ0qkBo3CTzQw0cB8w0TSZnY6aLWaaLYaaLGaaO0zONNJBg3AY2yRSg2RCjURSjVRSs/ziU3R0dBrt1NhNHjNrdJooNygp/0UxhYqV5CiCWRSYCCT1IGkBAaSogkkSjn2kkQGu5PSLiNHugyU9BlbSbeR6t6TR7RKmZSMEA2TdRomh/Q9dBrSg9Woxrhugc3hoqrdRFmLgfJWI+WtRspaDVS2GbE6Bs8I6SdaqyQlUk28TklmtJb0qCBSIzTEhgSMaKRWNLAzhKht9DjdLpqMBiw4abdZaLUZabWYaLUZMTpPbmxBfnIilBoilCqvuUUq1QT5jX2UTe+wU2EwUG7o5UhPN41WC9VG45CT3PtRyWQkawJJVgcySaNhkiaQZE0gSWoNyjFGkRani6PdRkq6jJR0GTzP3QbKu03YTxYiAQmBAWSEqMkI0XgewRoyQtTEBY4tedntFqjvNlPe0m9oJspbDVS0GekwnDxlSuEnZVK4muvnJ/LDJafP6Tyro5AiIsNF5edPjDKQjKCwAduNTjutfZGa59lEq82E3mHzjIgau6gwDlzTUSGVEaFUE6FQE6FQef8fphh+cm6Qv5zpulCmBgdzXnik1/xNTifVfSOfVX3PlUYDdSYj5r6qHkd6ewacSwLEBKhI1mhIVgeS3GduSWoNkcrhGUmAn4y8cC154VrvNqfbRYfZTI9doLzHzNFuEyVdBo52GyntNtJpdVBnsFBnsLChruOE80lJC/ZEaekhatKDNaT1/T9UefrRSKlUQmKomsRQNSuyIwfs6zHbPZFai54jzb00dlmpajNT3W7C5nRT0nzy1I+xIBqYyIRD4ydHo5GTogkZsN3ictBmNdNqNdFmM9HWZ2ydNjM2t8s7T/R4JIBOHkB4n6mFK1SE95lckP/woja1nx9Tgj3lhI7H4XZTZzZR3Wds1UYD1SYjlUYDeoeDRouZRouZ7e1tA14XIJORqNaQ1PdI1mi8Pw8n7cNPKiU1WMlkXRAXn7Cvw2LjaLeJo93G4x4mKntNWJxuDnfoOdyhH3TOEIW/18zS+owtVasmLURN8DAKSwar5MxK1jEtUUuPNdxr/i63QH2Xmco2I0knVJf1BaKBiZwzBMj8SVRrSVRrB2x3ut102M20WU202cy09xlbu9WM1e2k026h024ZkMcGIJfKCFOo+kxN5TW3EP/h5Y75S6WkaDx9YccjCAJddhvVRiPVJgNVfc81RiP1ZhMWl8ub23YiWn9/ktQeQ+s3tf7nwGFUyw0LUBAWoGBBzMAlzJxuNzV6C2V9plbeY6Ksx2N0DUYr3TYHe/vKFg0+p9xjZsFqUoPVpGpVnudg9WnTP2RSCUlh6nExLxANTORbgJ9USpRSQ5RyYKUDQRAwOO2020y0Wc20980NbbOZ6bJZsLtd3oTdEwmQ+hGu9BhamCLAa3RhCtVpBxIkEgmhCiWhCiUzQwc2jx1uN41ms8fQTEZqTEaqjUZqTUZarBZ6HQ5PgcmewYtvhMjlJKrURCkDSAkMIlkTSKJKTYJac9pRUk/U5jGdNckDm39mh5OKHjPlPUbKekxU9Jgo73u0mG10WOx0WOzsbhlCk8KflD5DS9GqSQpSEhHgR254CPGBIyvCORpEAxP51iKRSAjyVxDkryBFMzAicQluOm0W2m1mOmxm2mwmOmxm2m1meh02LG4ndX312E5ELfMnrM/MQhUBhMk95haqCEAl8z9ls9RfKiVJoyFJM7isjNnppM5sosZopM7sMbfavke7zUa33U633Q50Q0vTgNcG+fuT0GdmCSo18So1CWo1CSo1Eafpc1P5+zE1PIip4UGD9hntTip6B5paZa/nudlko9vmYH9bL/vbBkeTAX5SJmnVTApSkaJVsSopggsSIwYdNxZEAxP5TiKTSD0d/crBTRuz0061oQeb4KLbYfWaXIfNjMFpx+RyYOorCX4iSqkfYYoAQhUqwuSe59C+Z62/4tRG4ufH5CAtk4O0g/YZnQ7qTSaqjHpKe3vpsNuoM5uoM5los1nROxwU9fZQdMJgAoBCKiWuz9TijzO3eJWaWJWKgFPkk2nkfoMGErz3yeGkstdMZa+Jih4zFT0mKnqNVPSYaDDasDjdHOn0pIWAZ1BCNDARkXFGLpURqVAPmYJidTnptFnosJu9EVunzeyZM+qwYXU7abAYaBiiWSqTSNDJPc1RnTyAMHkAOkUAoXLPz6dK3tX4+ZOpDSYtMJA5IaEDtFlcTupNJurMJmpNRurMJu/PTRYzNrfbO3I6FOEKBXEqtdfk4lQq4gI8P0cFBJy0qq7K34+csCBywo5Fbv3pO2p/OY0mO1W9Jqp6zVT2mjkvPmzI84yFcTew/mqsOTk5FBUVsXTpUpYsWTLelxURGReUMj9iVYHEqgIH7bO7XR5zs5nptJvptHkGDzptZrrsVlyCQHuf6Q2Fxk9OqDwAndfY+v4vDyBYrjhp9Y8AmR/pQVrSh4jcHG43LRYLdWaPsTWYzdSbPIMJdWYTRqeTdpuNdpuNQ91dg17vJ5EQHaDymlqsSkWcSk1s37YwhXLIqNJfdqzPbTzxiYGdqhrr2rVrqampob6+nkcffZSnnnrqlAZmtduxHJcR3Z/363SfPAP4bNGvSdQ2ciayvtFqkwLhigDCFQFA6IB9LsFNr8NGp81CV9+oaJfdSpfd87PF5cTotGN02odsmkqRoPVXECxXEiiTE65UEaYIIEQeQIi/kqCTNE8lQHSAkugAJXNOGFDwVCDxpHvU95lbg9lEo8VMg9lMk8WMs68wZb3ZBLQPOr9cKiVaGUCsSkVMgIoopRKdv5zkwEASVBrClcoRr2A1kvvuEwNbtGgRa9euZePGjTz++OODqrGOhM27dg/4ub8iq3EUxRHPFKK20TOR9flamxQJ4f4qwv1VcEJgYnU56XFY6XHY+p6t9Dps9Dhs9Do90Vu3w0q3o+/LXT/43EH+crR+SrT+CrT+CoL8FAT3DWIE+Z28/y1WoSRWoYSQE01XoMNmpdliodna9+j7f5PFQrvNit3tptZsotY8eAV26Cu7pFASqVRyQVQMF8fEnfY+GYdYhPlk+MTAhlONNTY2lnXr1rF06dJTnkusyOobJrI2mNj6zpa2KIZe8MItCBiddrrsFjpsFlotRkxuBz0OG912Cz12G26EPvOzwRBzwyVAkL+CEH8lIXIlwXIlIf6e52B/JcH+ChRDdOaHBgSQcUICbz8Ot5vWPjNrtJhpMnuq6tabjLTarLRZrTgFgSarhSarhXlhEQQrlae9DyOpyOrTPrCYmBjq6uqIjo5GflxeSn8N/Kuuuuq051DK5QQojr1Jp9uFxeXCTyqdkHP6AFHbGJjI+iaSNp3MD51CRZJ68BxXd18xyu6+5mh3X9O0226l226h2+GJ4HodNnodNmqGaKKCp5bb8cYW0m9ufdtObKb6SWUkafxJ0gzuxA9WKpFIpLRZj5lbelDQsO7nSL40fGpgYjVWEZEzj1QiIaTPcCYxOFrqj+C6+/rduu2eJmq31+SsWN1OzC4HZotjyMRe6G+mKgiWK/qituMiuL5tiuMMStY3ABAdoALdkKccMz4zsP61HhcvXuyrU4qIiPgA6XEJvYknGRS0uBz02PuapA4rPXYrXQ4rvX0G1+vob6Z6zA+GjuJkEgmBfnJC5AFec9P6e8wtOkBDmELl0/cm5oGJiIgQIPMnIMCf6ICT98MZvAMMNnr6orjjnw1OOy7huL64E/r1l4YncnFsuk91iwYmIiJyWqQSCVq5Eq1cycmW5XAJbrpsZhpMBtwSwVP6qM/seh02IoeY9TBWRAMTERHxCTKJlBB5ABK35IwV0pxY49ciIiIiI0A0MBERkXMW0cBERETOWUQDExEROWeZMJ34Lpdnpedew8AkOs+0Dhtuq22CTjkRtY2GiaxP1DZ6fKGv3wP6PeFUTBgDM/atorzz4KGzrERERGQiYDSbCQ8NPeUxE2ZdSKvNRnNbG2qVCr/jCrs5nU427NjJ+Qvm4+c3YfwWELWNhYmsT9Q2enyhz+lyYTKbiY6IQKk49QIrE+YOKBUKkuPjB213ODyLnIZotfgPY1WWM4mobfRMZH2ittHjM32nibz6mXiNaBEREZFhIhqYiIjIOcuENzCpVEpORjrSCTjiImobPRNZn6ht9JxpfROmE19ERERkpEyYTvzh8Nprr9HY2EhmZiaXXHLJ2ZbjZaKvvNSvLy8vj/z8fG/ttolAv7bY2Fjq6urIzc3lyiuvPNuygGPaoqKi0Ov1REVFceONN55tWcAxbevWreOxxx7zLqAzUejXt3TpUrZt28aCBQtYvny5z68z4eLQ999/n7y8PLZv386VV17JFVdcQWFhIQC1tbX86le/YtOmTRNK19q1awkODvauvHTo0JnPZRuOvv7niaht0aJF3H///bS1tU04bbfffjv+/v5otYOXLTvb2jZv3syUKVPOqK6R6CsrK0Oj0eB0OsdFw4QzsBNXOHr55Zd59tlnvfv++te/Dqi3PxF0TQQmsr7haEtJSeGvf/3rGY9whqPt66+/5uc//zklJSUTTtvOnTs5dOgQX3311RnVNlx98+fP5+c//zn79u0bFw0TzsCOX+EoKSkJjUbjXeGouroaq9XK7NmzJ5SufvpXXsrLy5uQ+s4Ww9F277334nQ62bp164TT1tzczJ/+9CcmT5484bQ99NBD3HrrraxcufKMahuuvsrKSh577DGioqLGRcOE7QMbaoWjm2666Syr8s3KS+PJ6fT1P58NTqftbHIua0tKSiIpKensiOP0+i699NJxu/aENbCJusLRRNXVz0TWJ2obHRNZG5xdfWIahYiIyDnLhOsDExERERkuooGJiIics4gGJiIics4iGpiIiMg5i2hgIiIi5yyigYmIiJyziAYm8p3GZDJ9J6/9bUE0MBGf43Q6vaWFx4LFYvGBmpPz8ccfc8MNN4zrNU6Gw+HgkksuYc+ePWfl+t8WRAOboMyaNYukpCQkEgkJCQmkpqae9jW7d+9mzZo1J92/cOFCiouLR6UnKSmJmJgYJk2axIUXXkh1dfVJj83OzubIkSOjuk4/t99+O88999yAbd3d3axZs4aYmBgSExN58cUXvdr0ev2Izt/S0sI999zDCy+8wF133UVSUhJKpZKIiAiSkpLYv3//kK+TSCT09PSM6j0dj7+/P88//zzXX389NpttzOf7ziKITGgAobu7WxAEQdi8ebMQGRkpZGVlCQcPHhTuvfdeIS4uTkhISBB2794tbN68WcjNzfW+7uKLLxaCg4OFJ554QhAEQUhMTBQOHTok3HTTTcK8efOEhIQEYf78+YLNZhMOHDggpKenC5mZmcLMmTOFRx99dICO/tcKgiD8+9//FqZNmyYIgiA8+eSTQkJCghATEyN8+OGHwp133inIZDIhOjpaMJlMg/Z3d3cLc+bMEWJiYoSVK1cKJpNJ2LlzpzBr1iwhLS1NuOeee4TXXntNUKvVQkhIiLBx40avhk8//VSYMWOG4Ha7hYKCAuG3v/3tgHuUlZUlJCYmCgqFQrj11luF1tZWYdWqVUJaWpqwZs0aQa/Xe8/15z//WbjvvvsGvMclS5YIH3zwgffnX//610J8fLyQmpoqfPTRR95rNTY2CosXLxYeeOABwe12C7fffruQkZEhzJo1SygoKBBefPFFYfLkyUJOTo4QFxcnlJaWClVVVUJWVpYQHR0tXHfddYLb7RYEQRCuuOIK4Z133hn9H8h3HDECO8dwu93s3buXKVOmEB4eztNPP01iYiLr168fdOyjjz7Kf//7X954441B+2bMmEFlZSWlpaWUl5fzxz/+kVtuuYUjR46ctu7Vtddey6FDh3A4HPj5+fHEE08wd+5cPvroI/7xj38QFxfH559/jkqlGrS/u7ubxsZG/v73v3PhhRdiMpm49957aWxsxG638+KLL3LBBRdw5ZVX8sgjjwwognf++edz2WWXcckll/C73/2OuXPnDtB15MgR/vCHP5CQkMAjjzzCU089xd69e7Hb7ezbt4+NGzd6j62qqjplVHv06FGeffZZSkpKeO2117jjjju8+6666ipycnL4wx/+wIYNG3j11VexWq00NDTwyiuvACCXyykoKGDatGl8/fXXNDQ0APCvf/2LWbNmYbVaAUhLS6OysvKU91vk5IgGdo4RExODWq2moaGBZ555Bo1Gg0ajwe12Dzo2JSUFnU43ZH9USkoKfn5+BAYGjqi/yu1288QTT7Bw4UJsNhu/+93vUCqVhISEeDVIpVKcTidGo3HQfplMxsMPP4zD4eCf//wnxcXFuFwunn/+eY4ePcrvfvc7dDqd9xzH88Ybb9DS0sIHH3zA3XffPajyx8svv8xjjz3Gpk2bSExMxOVy8f3vf5+amhr+9re/MWvWrAH3sbGxcVjvWSKRIBw3ZVin07Fp0yb0ej0ul4upU6dSVVXFW2+95dWUnJyMRCLx3v/Q0FDuueceent7+fOf/0xTUxMAjY2NxMTEDPv+iwxENLBzFLVajVKp5K677hpx/89Q3H///bz44otkZ2fT1taGRqMZdMyaNWtISEjgyJEjvPXWW8jlchITE/n5z39OVVWV97jzzjuPVatW0djYOGi/Wq3m9ddf595770WtVpOSksKf/vQn7rnnHlJTUzEajUilUhYvXswf/vAHXn/9de95165dS1NTE/Hx8Vx11VU8/PDDA/TdcssttLe3s3DhQu677z5+9rOfsWPHDuLj4/noo4+89asAvve97/HOO++ctP8pIyODH/7wh2RmZnLdddfxr3/9y7vv1Vdf5YILLuD6669n5cqVpKWlkZiYyL333kt0dPSQ51MoFDz99NM8+OCDZGRkEBERQWdnJ998882EKo9+riFWoxAB4KOPPuKRRx6ht7eXuLg43nnnnZN+GL8tPPvss+zZs8c7GHAmcTgcXH755dx2221cfPHFZ/z63xZEAxP5TlNbW0tiYuJ37trfFkQDExEROWcR+8BERETOWUQDExEROWcRDUxEROScRTQwERGRcxbRwERERM5ZRAMTERE5ZxENTERE5Jzl/wP9P0bPegx4lgAAAABJRU5ErkJggg==","text/plain":["<Figure size 284x195 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["scale_factor = 1e3\n","\n","what_to_plot = [\n","    # {\"title\": \"Perplexity = 124.70 (RNN (2012) performance)\",\n","    #  \"loss\": np.log(124.70),\n","    #  \"cmap\": \"plasma\",\n","    #  \"min_data\": 1e2,\n","    #  \"max_data\": 1e+6,\n","    #  \"dataset\": \"ptb\",\n","    # \"transformer\": 0,\n","    #  \"filename\": f\"{date}_model{model_num}_delta{delta}_rnn\"},\n","    {\"title\": \"Perplexity = 17.48 (GPT-2 performance)\", # included in paper\n","     \"loss\": np.log(17.48),\n","     \"cmap\": \"plasma\",\n","     \"min_data\": 4.00E+09 / scale_factor,\n","     \"max_data\": 4.00E+09 * scale_factor,\n","     \"dataset\": \"wt103\",\n","     \"transformer\": 1,\n","     \"filename\": f\"{date}_model{model_num}_delta{delta}_gpt-2\"},\n","    {\"title\": \"Perplexity = 10.81 (Gopher performance)\", # included in paper\n","     \"loss\": np.log(10.81),\n","     \"cmap\": \"plasma\",\n","     \"min_data\": 3.00E+11 / scale_factor, #1e+7,\n","     \"max_data\": 3.00E+11 * scale_factor, #1e+12,\n","     \"dataset\": \"wt103\",\n","     \"transformer\": 1,\n","     \"filename\": f\"{date}_model{model_num}_delta{delta}_gopher\"},\n","    {\"title\": f\"Perplexity = 7.16 (Chinchilla performance)\", # included in paper\n","     \"loss\": np.log(7.16),\n","     \"cmap\": \"plasma\",\n","     \"min_data\": 1.40E+12 / scale_factor, #1e9,\n","     \"max_data\": 1.40E+12 * scale_factor, #1e+14,\n","     \"dataset\": \"wt103\",\n","     \"transformer\": 1,\n","     \"filename\": f\"{date}_model{model_num}_delta{delta}_chinchilla\"}\n","]\n","\n","year_labs = [2014, 2016, 2018, 2020, 2022, 2024, 2026]\n","\n","for element in what_to_plot:\n","    with egraphs.epoch_theme():\n","        with mpl.rc_context(rc=standalone_plot_rc_params):\n","            plt.figure(figsize=egraphs.px_to_in((284, 195)))\n","\n","            # plt.title(element[\"dataset\"].upper() + \" \" + element[\"title\"], fontsize=18)\n","            plt.xscale(\"log\")\n","            plt.yscale(\"log\")\n","\n","            plt.xlabel(\"Training Dataset Size (Tokens)\")\n","            plt.ylabel(\"Parameters\")\n","\n","            cmap = plt.get_cmap(element[\"cmap\"])\n","            color_range = 0.6\n","\n","            if element[\"dataset\"] == \"ptb\":\n","                category_ptb = 1\n","                category_wt2 = 0\n","            elif element[\"dataset\"] == \"wt2\":\n","                category_ptb = 0\n","                category_wt2 = 1\n","            else:\n","                category_ptb = 0\n","                category_wt2 = 0\n","\n","            #num_samples = 1000\n","            num_samples = 100\n","\n","            gradient = egraphs.get_gradient_colors(len(year_labs) + 2)[::-1]\n","\n","            for year_index, year in enumerate(year_labs):\n","                x, y = pareto_frontier(year, category_ptb, category_wt2, element[\"transformer\"], model_num, element[\"loss\"], \\\n","                                    min_data=element[\"min_data\"], max_data=element[\"max_data\"], num_samples=num_samples)\n","                line = plt.plot(x, y, color=gradient[year_index])\n","\n","                if max(y) > 1e+28:\n","                    plt.ylim(bottom=1e+8, top=1e+28)\n","\n","                #y_sep = 0\n","                #plt.annotate(str(year), (x[0], y[0]), xytext=(5, -y_sep * (year_index - len(year_labs)/2)), textcoords=\"offset points\", ha=\"left\", va=\"center\",\n","                #        fontsize=egraphs.px_to_pt(8), color=line[0].get_color(), fontweight=\"normal\")\n","\n","                labellines.labelLine(\n","                    line[0],\n","                    x[90],\n","                    label=str(year),\n","                    ha=\"left\",\n","                    va=\"bottom\",\n","                    align=True,\n","                    yoffset=-0.2,\n","                    yoffset_logspace=True,\n","                    backgroundcolor=\"none\",\n","                    outline_width=4,\n","                    fontsize=egraphs.px_to_pt(7),\n","                )\n","\n","            # Add a bit of padding for the year numbers\n","            #plt.xlim(right=plt.xlim()[1] * 1.5)\n","\n","            plt.minorticks_off()\n","\n","            egraphs.relayout(padding=standalone_padding, xaxis=dict(labelpad=2), yaxis=dict(labeloffset=0.05))\n","\n","            #plt.gca().xaxis.set_label_coords(0.5, egraphs.px_to_y_fraction(-40))\n","\n","            filename = f'{date}_{element[\"filename\"]}.pdf'\n","            with open(filename, \"wb+\") as f:\n","                plt.savefig(filename)\n","            plt.show()\n","            files.download(filename)\n","            plt.close()"]},{"cell_type":"markdown","metadata":{"id":"uYq1vrYgqeO8"},"source":["## Significance of the transformer (section 3.3)\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"3hbOJ6oyNpBR"},"outputs":[],"source":["from scipy.optimize import brentq\n","\n","# define main functions\n","def transformer_model(params, year, param, dataset, category_ptb, category_wt2, transformer, model):\n","    \"\"\"\n","    don't use this with model 13\n","    \"\"\"\n","    params_other, gamma_transformer = params[:-1], params[-1]\n","\n","    transformer_improvement = 1 / (1+np.exp(-gamma_transformer))\n","    model_pred = model(params_other, year, param, dataset, category_ptb, category_wt2)\n","\n","    return transformer * transformer_improvement * model_pred + (1 - transformer) * model_pred\n","\n","def transformer_residuals(params, year, param, dataset, category_ptb, category_wt2, transformer, log_ppl, model, delta):\n","    residuals = log_ppl - transformer_model(params, year, param, dataset, category_ptb, category_wt2, transformer, model)\n","    l1_reg = delta * np.sum(np.abs(params))\n","    return np.mean(np.square(residuals)) + l1_reg\n","\n","def predict_with_bootstrap(bootstrap_params, year, param, dataset, category_ptb, category_wt2, transformer, model):\n","    predictions = []\n","    for params in bootstrap_params:\n","        prediction = transformer_model(params, year, param, dataset, category_ptb, category_wt2, transformer, model)\n","        predictions.append(prediction)\n","    return predictions\n","\n","def find_a_for_equal_predictions(params, year, param_input, dataset_input, category_ptb, category_wt2, model):\n","    # Function to find the root (where transformer and non-transformer predictions are equal)\n","    def equation(a):\n","        transformer_pred = transformer_model(params, year, param_input, dataset_input, category_ptb, category_wt2, 1, model)\n","        non_transformer_pred = transformer_model(params, year, a*param_input, a*dataset_input, category_ptb, category_wt2, 0, model)\n","        # print(transformer_pred - non_transformer_pred)\n","        return transformer_pred - non_transformer_pred\n","\n","    # Define lower and upper bounds for 'a'\n","    a_lower = 0.01  # Adjust as needed based on the expected range of 'a'\n","    a_upper = 100   # Adjust as needed\n","\n","    # Solve for 'a' using brentq\n","    a_solution = brentq(equation, a_lower, a_upper)\n","    return a_solution"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282799,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"_U69-Wk_wbVt","outputId":"daf751c3-ed93-409b-a230-d926f6f645e6"},"outputs":[{"name":"stdout","output_type":"stream","text":[" message: Optimization terminated successfully\n"," success: True\n","  status: 0\n","     fun: 0.05881505857497706\n","       x: [ 5.060e-01  2.961e-02  9.648e-06 -3.504e-02  7.901e-02\n","            1.103e+00  1.071e-01  1.116e-01  5.523e-02  2.888e-02\n","            2.972e+00]\n","     nit: 44\n","     jac: [ 5.349e-03 -1.470e-03  2.711e-03 -4.122e-02 -1.995e-02\n","            4.188e-03  4.992e-04  1.307e-03 -2.206e-02 -3.113e-03\n","            1.604e-04]\n","    nfev: 556\n","    njev: 44\n","\n","\n","Optimized parameters:\n","alpha_const          0.506028\n","alpha_const_ptb      0.029609\n","alpha_const_wt2      0.000010\n","alpha_year          -0.035037\n","alpha_param          0.079008\n","beta_const           1.102722\n","beta_const_ptb       0.107080\n","beta_const_wt2       0.111550\n","beta_year            0.055229\n","beta_data            0.028882\n","gamma_transformer    2.971978\n","dtype: float64\n"]}],"source":["df_transformer = df_head.copy(deep=True)\n","\n","param_names = ['alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","               'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data', \\\n","               'gamma_transformer']\n","\n","np.random.seed(0)\n","p0 = np.zeros(len(param_names))\n","model = model_7\n","delta = 0.0025\n","\n","df_transformer['ptb_dummy'] = (df_transformer['dataset_name'] == 'ptb').astype(int)\n","df_transformer['wt2_dummy'] = (df_transformer['dataset_name'] == 'wt2').astype(int)\n","df_transformer['transformer'] = df_transformer['Architecture'].apply(lambda x: 1 if x == 'Transformer' else 0).astype(int)\n","\n","year = df_transformer[\"publication_date\"]\n","param = df_transformer[\"param\"]\n","dataset = df_transformer[\"dataset\"]\n","log_ppl = df_transformer[\"log_ppl\"]\n","ptb_dummy = df_transformer['ptb_dummy']\n","wt2_dummy = df_transformer['wt2_dummy']\n","transformer_dummy = df_transformer['transformer']\n","\n","param_const = np.min(param)\n","dataset_const = np.min(dataset)\n","year_const = np.min(year)\n","\n","res = minimize(transformer_residuals, p0, args=(year, param, dataset, ptb_dummy, wt2_dummy, transformer_dummy, log_ppl, model, delta), method='SLSQP')\n","print(res)\n","\n","print(\"\\n\")\n","params_optimized = pd.Series(res.x, index=param_names)\n","print(\"Optimized parameters:\")\n","print(params_optimized)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":7,"status":"aborted","timestamp":1709236282800,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"QaG6Bi7iQ3xp","outputId":"74e74e26-2737-4852-afb2-3326c3d20ca7"},"outputs":[{"name":"stdout","output_type":"stream","text":["num transformer 104\n","num non-transformer 127\n"]}],"source":["print(\"num transformer\", np.sum(transformer_dummy))\n","print(\"num non-transformer\", len(transformer_dummy) - np.sum(transformer_dummy))"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"0RfutHdjDucJ"},"outputs":[],"source":["filename_suffix = f\"_transformer_bootstrap_results.json\"\n","latest_cached_filename = safe_max([f for f in os.listdir() if f.endswith(filename_suffix)])"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"S7CteGeLRMvW"},"outputs":[],"source":["if not (use_cached_bootstraps and latest_cached_filename):\n","    np.random.seed(0)\n","    n_bootstrap_samples = 100\n","\n","    bootstrap_results = []\n","    for i in range(n_bootstrap_samples):\n","        bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","\n","        bootstrap_res = minimize(transformer_residuals, p0, args=(year[bootstrap_indices], param[bootstrap_indices],\n","                                                    dataset[bootstrap_indices], ptb_dummy[bootstrap_indices],\n","                                                    wt2_dummy[bootstrap_indices], transformer_dummy[bootstrap_indices], \\\n","                                                                log_ppl[bootstrap_indices], model, delta), method='SLSQP')\n","        bootstrap_results.append(bootstrap_res.x)\n","\n","        if i % 5 == 4:\n","            print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","\n","\n","    confidence_intervals = np.percentile(bootstrap_results, [2.5, 97.5], axis=0)\n","    standard_errors = np.std(bootstrap_results, axis=0)\n","\n","    print(\"Optimized parameters with confidence intervals and standard errors:\")\n","    for i, name in enumerate(param_names):\n","        print(f\"{name}_opt: {params_optimized[i]}  CI: {confidence_intervals[:, i]}  SE: {standard_errors[i]}\")"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"fjJIhnUZpUNU"},"outputs":[],"source":["if use_cached_bootstraps and latest_cached_filename:\n","      with open(latest_cached_filename, 'r') as f:\n","            bootstrap_results = json.load(f)\n","else:\n","      bootstrap_results_to_save = [param_estimates.tolist() if isinstance(param_estimates, np.ndarray) else param_estimates for param_estimates in bootstrap_results]\n","\n","      with open(f\"{date}_transformer_bootstrap_results.json\", 'w') as f:\n","            json.dump(bootstrap_results_to_save, f)\n","\n","      files.download(f\"{date}_transformer_bootstrap_results.json\")"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"fkAGOQeqpWkL"},"outputs":[],"source":["custom_filename_to_load = None # @param {type:\"string\"}\n","#custom_filename_to_load = '2024-01-12_transformer_bootstrap_results.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        bootstrap_results = json.load(f)\n","    bootstrap_results = np.array(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282800,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"Mia45sk8SEXD","outputId":"21295a17-1630-46ff-9a85-f028a63cd7ae"},"outputs":[{"name":"stdout","output_type":"stream","text":["Compute: 1e+22 FLOP\n","2.5 percentile 3.2056527659844765\n","Median 6.635783474434504\n","97.5 percentile 28.191240114840653\n","\n","\n","Compute: 1e+25 FLOP\n","2.5 percentile 3.2668160921378133\n","Median 7.161148055364147\n","97.5 percentile 45.66154919245873\n","\n","\n"]}],"source":["# inputs\n","computes = [1e22, 1e25]\n","category_ptb_input = 0  # Example: 0 or 1\n","category_wt2_input = 0  # Example: 0 or 1\n","year_input = 2023\n","\n","all_a_values = []\n","all_ceg_values = []\n","\n","for compute in computes:\n","  print(f\"Compute: {compute} FLOP\")\n","  param_input = (compute/6)**0.5  # compute = 6nd, assuming equal split between data and param\n","  dataset_input = (compute/6)**0.5  # compute = 6nd, assuming equal split between data and param\n","\n","  a_values = [find_a_for_equal_predictions(params, year_input, param_input, dataset_input, category_ptb_input, category_wt2_input, model) for params in bootstrap_results]\n","  ceg_values = [a ** 2 for a in a_values]\n","  all_a_values.append(a_values)\n","  all_ceg_values.append(ceg_values)\n","\n","  print(\"2.5 percentile\", np.percentile(ceg_values, 2.5))\n","  print(\"Median\", np.median(ceg_values))\n","  print(\"97.5 percentile\",  np.percentile(ceg_values, 97.5))\n","  print(\"\\n\")"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":6,"status":"aborted","timestamp":1709236282800,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"kWU-1HNGwk9c","outputId":"7b6c7f3b-6a78-4916-92f8-0b419456b861"},"outputs":[{"data":{"text/plain":["array([2.95407704, 4.59972028, 7.04055733])"]},"execution_count":1312,"metadata":{},"output_type":"execute_result"}],"source":["compute = 1e25\n","param_input = (compute/6)**0.5  # compute = 6nd, assuming equal split between data and param\n","dataset_input = (compute/6)**0.5  # compute = 6nd, assuming equal split between data and param\n","category_ptb_input = 0  # Example: 0 or 1\n","category_wt2_input = 0  # Example: 0 or 1\n","year_input = 2023\n","\n","percentage_reductions = []\n","for params in bootstrap_results:\n","    transformer_pred = transformer_model(params, year_input, param_input, dataset_input, category_ptb_input, category_wt2_input, 1, model)\n","    non_transformer_pred = transformer_model(params, year_input, param_input, dataset_input, category_ptb_input, category_wt2_input, 0, model)\n","    percentage_reduction = (non_transformer_pred - transformer_pred) / non_transformer_pred * 100\n","    percentage_reductions.append(percentage_reduction)\n","\n","np.percentile(percentage_reductions, [2.5, 50, 97.5])"]},{"cell_type":"markdown","metadata":{"id":"mOsBtFPENzyy"},"source":["# Aggregate doubling time graphs (section 3.1)"]},{"cell_type":"markdown","metadata":{"id":"6L0bim6LUZv3"},"source":["Run the following cell if you just want to plot graphs and not the bootstraps"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"mriaX7fIN1BU"},"outputs":[],"source":["df_double = df_head.copy(deep=True)\n","df_double['transformer'] = df_double['Architecture'].apply(lambda x: 1 if x == 'Transformer' else 0).astype(int)\n","\n","param_const = np.min(df_double[\"param\"])\n","dataset_const = np.min(df_double[\"dataset\"])\n","\n","year = df_double[\"publication_date\"]\n","param = df_double[\"param\"]\n","dataset = df_double[\"dataset\"]\n","log_ppl = df_double[\"log_ppl\"]\n","dataset_ptb = df_double['ptb_dummy']\n","dataset_wt2 = df_double['wt2_dummy']\n","transformer = df_double['transformer']\n","\n","year_const = min(year)\n","data_const = min(dataset)\n","param_const = min(param)"]},{"cell_type":"markdown","metadata":{"id":"Tx5rvFL1LNdH"},"source":["## Aggregated doubling times"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"biQLZnBbcNg9"},"outputs":[],"source":["# List of models from LOOCV\n","\n","text = '''\n","MSE_model10_delta0.001 with MSE: 0.04847642103308974\n","MSE_model7_delta0.0025 with MSE: 0.048563819600523625\n","MSE_model15_delta0.01 with MSE: 0.04862315855821884\n","MSE_model8_delta0.005 with MSE: 0.04869930867235716\n","MSE_model15_delta0.005 with MSE: 0.048837041442145145\n","MSE_model7_delta0.01 with MSE: 0.04891918602256304\n","MSE_model12_delta0.02 with MSE: 0.048973521894055565\n","MSE_model10_delta0.0025 with MSE: 0.04900021080864785\n","MSE_model10_delta0.005 with MSE: 0.04912598962168982\n","MSE_model12_delta0.005 with MSE: 0.04919516440616078\n","MSE_model7_delta0.02 with MSE: 0.049196912806226865\n","MSE_model15_delta0.02 with MSE: 0.049208871605081556\n","MSE_model9_delta0.02 with MSE: 0.0492496779731775\n","MSE_model15_delta0.0025 with MSE: 0.0493659178353991\n","MSE_model12_delta0.0025 with MSE: 0.04939151143709678\n","MSE_model12_delta0 with MSE: 0.04945719102884973\n","MSE_model7_delta0.005 with MSE: 0.04951969534757872\n","MSE_model8_delta0.001 with MSE: 0.04953478220039427\n","MSE_model9_delta0.01 with MSE: 0.049633670324652365\n","MSE_model10_delta0 with MSE: 0.0496386829123009\n","MSE_model15_delta0.001 with MSE: 0.04974714962652067\n","MSE_model8_delta0.0025 with MSE: 0.04975454905094963\n","MSE_model9_delta0.001 with MSE: 0.04996074827356605\n","MSE_model12_delta0.001 with MSE: 0.04996603261650825\n","MSE_model5_delta0.0025 with MSE: 0.05004010021793135\n","MSE_model13_delta0.01 with MSE: 0.050051494030613965\n","MSE_model8_delta0 with MSE: 0.05006104716119326\n","MSE_model5_delta0.01 with MSE: 0.050067874896543366\n","MSE_model10_delta0.01 with MSE: 0.05008937352919118\n","MSE_model5_delta0.001 with MSE: 0.050102107801012694\n","MSE_model5_delta0 with MSE: 0.05011472488781519\n","MSE_model12_delta0.01 with MSE: 0.05012300076011561\n","MSE_model5_delta0.005 with MSE: 0.05014520136923527\n","MSE_model6_delta0.0025 with MSE: 0.05017838046649957\n","MSE_model13_delta0.02 with MSE: 0.05018254165191081\n","MSE_model6_delta0.001 with MSE: 0.050211502555967645\n","MSE_model7_delta0.001 with MSE: 0.050280869617072406\n","MSE_model13_delta0.005 with MSE: 0.050282769705482254\n","MSE_model6_delta0.005 with MSE: 0.050300335175406864\n","MSE_model6_delta0 with MSE: 0.05033529325347098\n","MSE_model9_delta0.005 with MSE: 0.05042332825343481\n","MSE_model7_delta0 with MSE: 0.05048628122937888\n","MSE_model6_delta0.01 with MSE: 0.05049228245320385\n","MSE_model9_delta0 with MSE: 0.05049983060306857\n","MSE_model15_delta0 with MSE: 0.050679997980066255\n","MSE_model13_delta0.0025 with MSE: 0.050698150865848335\n","MSE_model9_delta0.0025 with MSE: 0.050967766422513536\n","MSE_model11_delta0.01 with MSE: 0.0510147019882579\n","MSE_model10_delta0.02 with MSE: 0.05105248468078686\n","MSE_model5_delta0.02 with MSE: 0.05113333396716201\n","MSE_model4_delta0.0025 with MSE: 0.05114297501006555\n","MSE_model4_delta0 with MSE: 0.05117703202357158\n","MSE_model4_delta0.001 with MSE: 0.05120147853188074\n","MSE_model11_delta0.02 with MSE: 0.05127244185762453\n","MSE_model4_delta0.005 with MSE: 0.051340642077796865\n","MSE_model6_delta0.02 with MSE: 0.0516182611825561\n","MSE_model11_delta0.001 with MSE: 0.05185697447326047\n","MSE_model11_delta0.0025 with MSE: 0.05195536728725606\n","MSE_model4_delta0.02 with MSE: 0.051991532153223115\n","MSE_model8_delta0.01 with MSE: 0.05208277509942345\n","MSE_model3_delta0.02 with MSE: 0.052221513063791865\n","MSE_model13_delta0 with MSE: 0.052266869604816205\n","MSE_model4_delta0.01 with MSE: 0.05227314125905681\n","MSE_model11_delta0.005 with MSE: 0.052300870090183464\n","MSE_model1_delta0.02 with MSE: 0.05231041850093214\n","MSE_model3_delta0.01 with MSE: 0.05235382460770766\n","MSE_model3_delta0.005 with MSE: 0.052486395797718924\n","MSE_model8_delta0.02 with MSE: 0.052500864949434\n","MSE_model3_delta0.0025 with MSE: 0.0526157447228351\n","MSE_model13_delta0.001 with MSE: 0.05267303735461852\n","MSE_model1_delta0.01 with MSE: 0.05280640607843129\n","MSE_model11_delta0 with MSE: 0.05280884897040363\n","MSE_model3_delta0.001 with MSE: 0.05290070492885797\n","MSE_model3_delta0 with MSE: 0.05293832875988481\n","MSE_model1_delta0.005 with MSE: 0.052946944362773175\n","MSE_model1_delta0 with MSE: 0.05304287899814275\n","MSE_model1_delta0.0025 with MSE: 0.05308409582414382\n","MSE_model1_delta0.001 with MSE: 0.05309104778457573\n","MSE_model2_delta0.001 with MSE: 0.05370188343780064\n","MSE_model2_delta0 with MSE: 0.053708611467090626\n","MSE_model2_delta0.0025 with MSE: 0.053929303217719\n","MSE_model2_delta0.005 with MSE: 0.058523467750504106\n","MSE_model2_delta0.01 with MSE: 0.05859924480221594\n","MSE_model2_delta0.02 with MSE: 0.059214191942178425\n","MSE_model14_delta0.01 with MSE: 0.0630178550258326\n","MSE_model16_delta0.02 with MSE: 0.06310033058892191\n","MSE_model14_delta0 with MSE: 0.06314328323043893\n","MSE_model14_delta0.02 with MSE: 0.06335670195075582\n","MSE_model14_delta0.005 with MSE: 0.06358520065342112\n","MSE_model14_delta0.001 with MSE: 0.06377413967870402\n","MSE_model17_delta0.02 with MSE: 0.06411190728148224\n","MSE_model17_delta0.01 with MSE: 0.06421223220480772\n","MSE_model17_delta0 with MSE: 0.06427032146119384\n","MSE_model16_delta0.01 with MSE: 0.06431442632611813\n","MSE_model17_delta0.001 with MSE: 0.06471762070756258\n","MSE_model17_delta0.005 with MSE: 0.06474683211854922\n","MSE_model16_delta0.005 with MSE: 0.06486091163166682\n","MSE_model14_delta0.0025 with MSE: 0.06519946570962575\n","MSE_model17_delta0.0025 with MSE: 0.06536816974606262\n","MSE_model16_delta0 with MSE: 0.06598972281472236\n","MSE_model16_delta0.001 with MSE: 0.06662594805175184\n","MSE_model16_delta0.0025 with MSE: 0.06700852485053925\n","'''"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715218,"status":"aborted","timestamp":1709236282800,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"BFjjEPYCcSdq","outputId":"9731cc2b-4154-4c46-aa80-14bf7e358fc4"},"outputs":[{"data":{"text/plain":["[[10, 0.001],\n"," [7, 0.0025],\n"," [15, 0.01],\n"," [8, 0.005],\n"," [15, 0.005],\n"," [7, 0.01],\n"," [12, 0.02],\n"," [10, 0.0025],\n"," [10, 0.005],\n"," [12, 0.005]]"]},"execution_count":1315,"metadata":{},"output_type":"execute_result"}],"source":["model_delta_pairs = re.findall(\"model\\d+_delta\\d.\\d+\", text)\n","# unique_model_num = []\n","names = []\n","selected_models = []\n","\n","for i, pair in enumerate(model_delta_pairs):\n","  model_num = int(re.search(\"\\d+\", pair)[0])\n","  delta = float(re.search(\"\\d.\\d+\", pair)[0])\n","  names.append([model_num, delta])\n","  selected_models.append([globals()[f\"model_{model_num}\"], delta]) # model_name, delta\n","\n","  if (i + 1) % 10 == 0:\n","    break\n","  # if not (model_num in unique_model_num):\n","  #   unique_model_num.append(model_num)\n","  #   names.append([model_num, delta])\n","\n","names"]},{"cell_type":"markdown","metadata":{"id":"UOO4JHUz4PE0"},"source":["### Bootstraps (skip if you just want graphs)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"1EsFzgerDucK"},"outputs":[],"source":["filename_suffix = f\"_top_ten_models.json\"\n","latest_cached_filename = safe_max([f for f in os.listdir() if f.endswith(filename_suffix)])"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"uEcd4EzGmN-b"},"outputs":[],"source":["if not (use_cached_bootstraps and latest_cached_filename):\n","  n_bootstrap_samples = 100\n","\n","  df_double = df_head.copy(deep=True)\n","  df_double['transformer'] = df_double['Architecture'].apply(lambda x: 1 if x == 'Transformer' else 0).astype(int)\n","\n","  all_bootstrap_results = []\n","\n","  year = df_double[\"publication_date\"]\n","  param = df_double[\"param\"]\n","  dataset = df_double[\"dataset\"]\n","  log_ppl = df_double[\"log_ppl\"]\n","  dataset_ptb = df_double['ptb_dummy']\n","  dataset_wt2 = df_double['wt2_dummy']\n","  transformer = df_double['transformer']\n","\n","  param_const = np.min(param)\n","  dataset_const = np.min(dataset)\n","  year_const = np.min(year)\n","\n","  # selected_models = zip(models, deltas)\n","  for model, delta in selected_models:\n","      model_num_str = re.search(r'\\d+', model.__name__).group()\n","      model_num = int(model_num_str)\n","\n","      print(f\"Model number = {model_num}, delta = {delta}\")\n","\n","      num_params = num_params_in_model(model_num)\n","      p0 = np.zeros(num_params)\n","\n","      bootstrap_results = []\n","      for i in range(n_bootstrap_samples):\n","        bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","        bootstrap_log_ppl = log_ppl[bootstrap_indices]\n","\n","        bootstrap_res = minimize(residuals, p0, args=(model, year[bootstrap_indices], param[bootstrap_indices], dataset[bootstrap_indices], \\\n","                      dataset_ptb[bootstrap_indices], dataset_wt2[bootstrap_indices], log_ppl[bootstrap_indices], delta, transformer[bootstrap_indices]), method='SLSQP')\n","        bootstrap_results.append(bootstrap_res.x)\n","\n","        if i % 5 == 4:\n","            print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","      print(\"\\n\")\n","\n","      all_bootstrap_results.append(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"goY0Cg08CPR9"},"outputs":[],"source":["if use_cached_bootstraps and latest_cached_filename:\n","    with open(latest_cached_filename, 'r') as f:\n","        all_bootstrap_results = json.load(f)\n","else:\n","    all_bootstrap_results_to_save = [\n","        [param_estimates.tolist() if isinstance(param_estimates, np.ndarray) else param_estimates for param_estimates in model_bootstrap_results]\n","        for model_bootstrap_results in all_bootstrap_results\n","    ]\n","\n","    filename = f\"{date}_top_ten_models.json\"\n","    with open(filename, 'w') as f:\n","        json.dump(all_bootstrap_results_to_save, f)\n","\n","    files.download(filename)"]},{"cell_type":"markdown","metadata":{"id":"zPsU3-Rb4S4W"},"source":["### Graphs"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"phKaMekcSzAI"},"outputs":[],"source":["custom_filename_to_load = None # @param {type:\"string\"}\n","#custom_filename_to_load = '2024-01-18_top_ten_models.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        all_bootstrap_results = json.load(f)\n","\n","model_7_filename = safe_max([f for f in os.listdir() if re.match(r\".*_model7_delta.*_bootstrap_results.json\", f)])\n","\n","custom_model_7_filename_to_load = None # @param {type:\"string\"}\n","#custom_model_7_filename_to_load = \"2024-01-18_model7_delta0.0025_bootstrap_results.json\"\n","if custom_model_7_filename_to_load:\n","    model_7_filename = custom_model_7_filename_to_load\n","\n","with open(model_7_filename, 'r') as f:\n","    model7_bootstrap_results = json.load(f)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"-fgvG2vzUv-k"},"outputs":[],"source":["import matplotlib as mpl\n","mpl.rcParams.update(mpl.rcParamsDefault)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"KzPGwl5PTlto"},"outputs":[],"source":["all_compute_doublings = []\n","for i, bootstrap_results in enumerate(all_bootstrap_results):\n","  model_num = names[i][0]\n","  model_name = globals()[f\"model_{model_num}\"]\n","  if model_num not in {16, 17}:\n","    if model_num in {4, 5, 6, 10, 11}: #category_ptb=0, category_wt2=0,\n","      compute_doublings_wt103 = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=0, category_wt2=0) for param in bootstrap_results]\n","      compute_doublings_ptb = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=1, category_wt2=0) for param in bootstrap_results]\n","      compute_doublings_wt2 = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=0, category_wt2=1) for param in bootstrap_results]\n","      compute_doublings = np.concatenate([compute_doublings_wt103, compute_doublings_ptb, compute_doublings_wt2])\n","    else:\n","      compute_doublings = [compute_doubling_numerical(param, model_num, 2023, compute=1e25) for param in bootstrap_results]\n","    # print(model_num, compute_doublings)\n","    all_compute_doublings.append(compute_doublings)\n","\n","model7_doubling_times = estimate_doubling_times(7, model7_bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715211,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"OewBiUekfVf7","outputId":"b62dbcdd-f48f-43c1-d91e-fd7345773aca"},"outputs":[{"data":{"image/png":"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","text/plain":["<Figure size 184.8x169.4 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["with egraphs.epoch_theme():\n","    with mpl.rc_context(rc=subplot_rc_params):\n","        aggregated_top_ten = np.concatenate(all_compute_doublings)\n","        model7_doublings = np.array(model7_doubling_times[2])\n","        ci = 95\n","        filename = f\"{date}_aggregate-and-preferred.pdf\"\n","        fontsize = 18\n","\n","        plt.figure(figsize=egraphs.px_to_in((168 * px_scale_factor, 154 * px_scale_factor)))\n","\n","        main_model_color = '#361A6D'\n","        aggregate_color = '#85ADAF'\n","\n","        median_aggregated = np.median(aggregated_top_ten)\n","        median_model7 = np.median(model7_doublings)\n","\n","        line_width = 1\n","\n","        sns.kdeplot(data_filter(aggregated_top_ten * 12, ci), fill=True, color=main_model_color, alpha=0.4, label=\"Model 7\", zorder=2)\n","        plt.axvline(x=median_model7 * 12, color=main_model_color, linestyle=(0, (2, 3)), label=f'Median: {median_model7*12:.1f}', zorder=2, linewidth=line_width)\n","\n","        sns.kdeplot(data_filter(model7_doublings * 12, ci), fill=True, color=aggregate_color, alpha=0.4, label=\"Aggregated\", zorder=1)\n","        plt.axvline(x=median_aggregated * 12, color=aggregate_color, linestyle=(0, (1, 1)), label=f'Median: {median_aggregated*12:.1f}', zorder=1, linewidth=line_width)\n","\n","\n","        plt.xlabel(\"Doubling time (months)\")\n","        plt.ylabel(\"Density\")\n","        plt.tick_params(axis='both')\n","        plt.yticks(np.arange(0, 0.2 + 0.05, 0.05))\n","        plt.xticks(np.arange(0, 20 + 5, 5))\n","        plt.gca().yaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: f'{x:.2f}'))\n","        plt.gca().xaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: f'{x:.0f}'))\n","        plt.xlim(-0.5, 20.5)\n","\n","        egraphs.relayout(replace_legend=False, xaxis=dict(labelpad=3), padding={'left': 5, 'top': 0, 'right': 5, 'bottom': 11})\n","\n","        plt.legend()\n","\n","        plt.gca().yaxis.label.set_position((0.0, 1.0 + 0.08))\n","\n","        plt.savefig(filename)\n","\n","        plt.show()"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715209,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"jF6sU-bQWLze","outputId":"194fd32e-40ad-496d-8170-692bb6800543"},"outputs":[{"data":{"text/plain":["array([ 1.41532506,  7.92483018, 17.060203  ])"]},"execution_count":1261,"metadata":{},"output_type":"execute_result"}],"source":["ci = 95\n","np.percentile(np.concatenate(all_compute_doublings), [50 - ci/2, 50, 50 + ci/2]) * 12"]},{"cell_type":"markdown","metadata":{"id":"NsWuqUZRtdvr"},"source":["## Distinct models (robustness check)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"aM-XFl9EobBx"},"outputs":[],"source":["# Sorted list of models from LOOCV\n","\n","text = '''\n","MSE_model10_delta0.001 with MSE: 0.04847642103308974\n","MSE_model7_delta0.0025 with MSE: 0.048563819600523625\n","MSE_model15_delta0.01 with MSE: 0.04862315855821884\n","MSE_model8_delta0.005 with MSE: 0.04869930867235716\n","MSE_model15_delta0.005 with MSE: 0.048837041442145145\n","MSE_model7_delta0.01 with MSE: 0.04891918602256304\n","MSE_model12_delta0.02 with MSE: 0.048973521894055565\n","MSE_model10_delta0.0025 with MSE: 0.04900021080864785\n","MSE_model10_delta0.005 with MSE: 0.04912598962168982\n","MSE_model12_delta0.005 with MSE: 0.04919516440616078\n","MSE_model7_delta0.02 with MSE: 0.049196912806226865\n","MSE_model15_delta0.02 with MSE: 0.049208871605081556\n","MSE_model9_delta0.02 with MSE: 0.0492496779731775\n","MSE_model15_delta0.0025 with MSE: 0.0493659178353991\n","MSE_model12_delta0.0025 with MSE: 0.04939151143709678\n","MSE_model12_delta0 with MSE: 0.04945719102884973\n","MSE_model7_delta0.005 with MSE: 0.04951969534757872\n","MSE_model8_delta0.001 with MSE: 0.04953478220039427\n","MSE_model9_delta0.01 with MSE: 0.049633670324652365\n","MSE_model10_delta0 with MSE: 0.0496386829123009\n","MSE_model15_delta0.001 with MSE: 0.04974714962652067\n","MSE_model8_delta0.0025 with MSE: 0.04975454905094963\n","MSE_model9_delta0.001 with MSE: 0.04996074827356605\n","MSE_model12_delta0.001 with MSE: 0.04996603261650825\n","MSE_model5_delta0.0025 with MSE: 0.05004010021793135\n","MSE_model13_delta0.01 with MSE: 0.050051494030613965\n","MSE_model8_delta0 with MSE: 0.05006104716119326\n","MSE_model5_delta0.01 with MSE: 0.050067874896543366\n","MSE_model10_delta0.01 with MSE: 0.05008937352919118\n","MSE_model5_delta0.001 with MSE: 0.050102107801012694\n","MSE_model5_delta0 with MSE: 0.05011472488781519\n","MSE_model12_delta0.01 with MSE: 0.05012300076011561\n","MSE_model5_delta0.005 with MSE: 0.05014520136923527\n","MSE_model6_delta0.0025 with MSE: 0.05017838046649957\n","MSE_model13_delta0.02 with MSE: 0.05018254165191081\n","MSE_model6_delta0.001 with MSE: 0.050211502555967645\n","MSE_model7_delta0.001 with MSE: 0.050280869617072406\n","MSE_model13_delta0.005 with MSE: 0.050282769705482254\n","MSE_model6_delta0.005 with MSE: 0.050300335175406864\n","MSE_model6_delta0 with MSE: 0.05033529325347098\n","MSE_model9_delta0.005 with MSE: 0.05042332825343481\n","MSE_model7_delta0 with MSE: 0.05048628122937888\n","MSE_model6_delta0.01 with MSE: 0.05049228245320385\n","MSE_model9_delta0 with MSE: 0.05049983060306857\n","MSE_model15_delta0 with MSE: 0.050679997980066255\n","MSE_model13_delta0.0025 with MSE: 0.050698150865848335\n","MSE_model9_delta0.0025 with MSE: 0.050967766422513536\n","MSE_model11_delta0.01 with MSE: 0.0510147019882579\n","MSE_model10_delta0.02 with MSE: 0.05105248468078686\n","MSE_model5_delta0.02 with MSE: 0.05113333396716201\n","MSE_model4_delta0.0025 with MSE: 0.05114297501006555\n","MSE_model4_delta0 with MSE: 0.05117703202357158\n","MSE_model4_delta0.001 with MSE: 0.05120147853188074\n","MSE_model11_delta0.02 with MSE: 0.05127244185762453\n","MSE_model4_delta0.005 with MSE: 0.051340642077796865\n","MSE_model6_delta0.02 with MSE: 0.0516182611825561\n","MSE_model11_delta0.001 with MSE: 0.05185697447326047\n","MSE_model11_delta0.0025 with MSE: 0.05195536728725606\n","MSE_model4_delta0.02 with MSE: 0.051991532153223115\n","MSE_model8_delta0.01 with MSE: 0.05208277509942345\n","MSE_model3_delta0.02 with MSE: 0.052221513063791865\n","MSE_model13_delta0 with MSE: 0.052266869604816205\n","MSE_model4_delta0.01 with MSE: 0.05227314125905681\n","MSE_model11_delta0.005 with MSE: 0.052300870090183464\n","MSE_model1_delta0.02 with MSE: 0.05231041850093214\n","MSE_model3_delta0.01 with MSE: 0.05235382460770766\n","MSE_model3_delta0.005 with MSE: 0.052486395797718924\n","MSE_model8_delta0.02 with MSE: 0.052500864949434\n","MSE_model3_delta0.0025 with MSE: 0.0526157447228351\n","MSE_model13_delta0.001 with MSE: 0.05267303735461852\n","MSE_model1_delta0.01 with MSE: 0.05280640607843129\n","MSE_model11_delta0 with MSE: 0.05280884897040363\n","MSE_model3_delta0.001 with MSE: 0.05290070492885797\n","MSE_model3_delta0 with MSE: 0.05293832875988481\n","MSE_model1_delta0.005 with MSE: 0.052946944362773175\n","MSE_model1_delta0 with MSE: 0.05304287899814275\n","MSE_model1_delta0.0025 with MSE: 0.05308409582414382\n","MSE_model1_delta0.001 with MSE: 0.05309104778457573\n","MSE_model2_delta0.001 with MSE: 0.05370188343780064\n","MSE_model2_delta0 with MSE: 0.053708611467090626\n","MSE_model2_delta0.0025 with MSE: 0.053929303217719\n","MSE_model2_delta0.005 with MSE: 0.058523467750504106\n","MSE_model2_delta0.01 with MSE: 0.05859924480221594\n","MSE_model2_delta0.02 with MSE: 0.059214191942178425\n","MSE_model14_delta0.01 with MSE: 0.0630178550258326\n","MSE_model16_delta0.02 with MSE: 0.06310033058892191\n","MSE_model14_delta0 with MSE: 0.06314328323043893\n","MSE_model14_delta0.02 with MSE: 0.06335670195075582\n","MSE_model14_delta0.005 with MSE: 0.06358520065342112\n","MSE_model14_delta0.001 with MSE: 0.06377413967870402\n","MSE_model17_delta0.02 with MSE: 0.06411190728148224\n","MSE_model17_delta0.01 with MSE: 0.06421223220480772\n","MSE_model17_delta0 with MSE: 0.06427032146119384\n","MSE_model16_delta0.01 with MSE: 0.06431442632611813\n","MSE_model17_delta0.001 with MSE: 0.06471762070756258\n","MSE_model17_delta0.005 with MSE: 0.06474683211854922\n","MSE_model16_delta0.005 with MSE: 0.06486091163166682\n","MSE_model14_delta0.0025 with MSE: 0.06519946570962575\n","MSE_model17_delta0.0025 with MSE: 0.06536816974606262\n","MSE_model16_delta0 with MSE: 0.06598972281472236\n","MSE_model16_delta0.001 with MSE: 0.06662594805175184\n","MSE_model16_delta0.0025 with MSE: 0.06700852485053925\n","'''"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715205,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"B2aidlvtoupO","outputId":"42ccd2ea-7442-4312-d97d-ac14e7555779"},"outputs":[{"data":{"text/plain":["[[10, 0.001],\n"," [7, 0.0025],\n"," [15, 0.01],\n"," [8, 0.005],\n"," [12, 0.02],\n"," [9, 0.02],\n"," [5, 0.0025],\n"," [13, 0.01],\n"," [6, 0.0025],\n"," [11, 0.01],\n"," [4, 0.0025],\n"," [3, 0.02],\n"," [1, 0.02],\n"," [2, 0.001],\n"," [14, 0.01],\n"," [16, 0.02],\n"," [17, 0.02]]"]},"execution_count":1263,"metadata":{},"output_type":"execute_result"}],"source":["model_delta_pairs = re.findall(\"model\\d+_delta\\d.\\d+\", text)\n","unique_model_num = []\n","names = []\n","selected_models = []\n","\n","for pair in model_delta_pairs:\n","  model_num = int(re.search(\"\\d+\", pair)[0])\n","  delta = float(re.search(\"\\d.\\d+\", pair)[0])\n","  if not (model_num in unique_model_num):\n","    unique_model_num.append(model_num)\n","    names.append([model_num, delta])\n","    selected_models.append([globals()[f\"model_{model_num}\"], delta]) # model_name, delta\n","\n","names"]},{"cell_type":"markdown","metadata":{"id":"NGwTdKoV5W_R"},"source":["### Bootstraps (skip if you just want graphs)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"EE0HGrZqDucK"},"outputs":[],"source":["filename_suffix = f\"_distinct_models_bootstrap_estimates_all_models.json\"\n","latest_cached_filename = safe_max([f for f in os.listdir() if f.endswith(filename_suffix)])\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"inu3W346uEJE"},"outputs":[],"source":["if not (use_cached_bootstraps and latest_cached_filename):\n","  n_bootstrap_samples = 100\n","\n","  df_double = df_head.copy(deep=True)\n","  df_double['transformer'] = df_double['Architecture'].apply(lambda x: 1 if x == 'Transformer' else 0).astype(int)\n","\n","  param_const = np.min(df_double[\"param\"])\n","  dataset_const = np.min(df_double[\"dataset\"])\n","\n","  all_bootstrap_results = []\n","\n","  year = df_double[\"publication_date\"]\n","  param = df_double[\"param\"]\n","  dataset = df_double[\"dataset\"]\n","  log_ppl = df_double[\"log_ppl\"]\n","  dataset_ptb = df_double['ptb_dummy']\n","  dataset_wt2 = df_double['wt2_dummy']\n","  transformer = df_double['transformer']\n","\n","  year_const = min(year)\n","  data_const = min(dataset)\n","  param_const = min(param)\n","\n","  for model, delta in selected_models:\n","      model_num_str = re.search(r'\\d+', model.__name__).group()\n","      model_num = int(model_num_str)\n","\n","      print(f\"Model number = {model_num}, delta = {delta}\")\n","\n","      num_params = num_params_in_model(model_num)\n","      p0 = np.zeros(num_params)\n","\n","      bootstrap_results = []\n","      for i in range(n_bootstrap_samples):\n","        bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","        bootstrap_log_ppl = log_ppl[bootstrap_indices]\n","\n","        bootstrap_res = minimize(residuals, p0, args=(model, year[bootstrap_indices], param[bootstrap_indices], dataset[bootstrap_indices], \\\n","                      dataset_ptb[bootstrap_indices], dataset_wt2[bootstrap_indices], log_ppl[bootstrap_indices], delta, transformer[bootstrap_indices]), method='SLSQP')\n","        bootstrap_results.append(bootstrap_res.x)\n","\n","        if i % 5 == 4:\n","            print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","      print(\"\\n\")\n","\n","      all_bootstrap_results.append(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"H8JYmxa7xC5F"},"outputs":[],"source":["if use_cached_bootstraps and latest_cached_filename:\n","    with open(latest_cached_filename, 'r') as f:\n","        all_bootstrap_results = json.load(f)\n","else:\n","    all_bootstrap_results_to_save = [\n","        [param_estimates.tolist() if isinstance(param_estimates, np.ndarray) else param_estimates for param_estimates in model_bootstrap_results]\n","        for model_bootstrap_results in all_bootstrap_results\n","    ]\n","\n","    filename = f\"{date}_distinct_models_bootstrap_estimates_all_models.json\"\n","    with open(filename, 'w') as f:\n","        json.dump(all_bootstrap_results_to_save, f)\n","\n","    files.download(filename)"]},{"cell_type":"markdown","metadata":{"id":"6jD_l-dF5g9M"},"source":["### Graphs"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"VYUdJerbuJFu"},"outputs":[],"source":["custom_filename_to_load = None\n","#custom_filename_to_load = '2024-01-18_distinct_models_bootstrap_estimates_all_models.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        all_bootstrap_results = json.load(f)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715200,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"aBG5AsiSAd6c","outputId":"3937f1a0-c71f-4f09-eed8-50eaf7d661e9"},"outputs":[{"name":"stderr","output_type":"stream","text":["/tmp/ipykernel_7896/3061356232.py:46: RuntimeWarning:\n","\n","divide by zero encountered in log\n","\n","/tmp/ipykernel_7896/1506341361.py:55: RuntimeWarning:\n","\n","divide by zero encountered in log\n","\n"]}],"source":["all_compute_doublings = []\n","for i, bootstrap_results in enumerate(all_bootstrap_results):\n","  model_num = names[i][0]\n","  model_name = globals()[f\"model_{model_num}\"]\n","  if model_num not in {16, 17}:\n","    if model_num in {4, 5, 6, 10, 11}: #category_ptb=0, category_wt2=0,\n","      compute_doublings_wt103 = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=0, category_wt2=0) for param in bootstrap_results]\n","      compute_doublings_ptb = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=1, category_wt2=0) for param in bootstrap_results]\n","      compute_doublings_wt2 = [compute_doubling_numerical(param, model_num, 2023, compute=1e25, category_ptb=0, category_wt2=1) for param in bootstrap_results]\n","      compute_doublings = np.concatenate([compute_doublings_wt103, compute_doublings_ptb, compute_doublings_wt2])\n","    else:\n","      compute_doublings = [compute_doubling_numerical(param, model_num, 2023, compute=1e25) for param in bootstrap_results]\n","    # print(model_num, compute_doublings)\n","    all_compute_doublings.append(compute_doublings)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715198,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"8Sl8x5nwEV2v","outputId":"731c39b3-9b4b-45ed-fc10-1170eb062ac2"},"outputs":[{"name":"stderr","output_type":"stream","text":["/tmp/ipykernel_7896/1357841137.py:27: FutureWarning:\n","\n","Passing `palette` without assigning `hue` is deprecated.\n","\n","/tmp/ipykernel_7896/1357841137.py:27: UserWarning:\n","\n","The palette list has more values (17) than needed (14), which may not be intended.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","42.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","11.2% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","19.4% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","33.7% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","18.4% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","55.4% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","46.8% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","29.6% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","53.0% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","20.4% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","13.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","14.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/tmp/ipykernel_7896/1357841137.py:33: UserWarning:\n","\n","set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n","\n","/tmp/ipykernel_7896/1357841137.py:35: UserWarning:\n","\n","set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","19.8% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","13.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","33.9% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","23.5% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","8.8% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","33.6% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","35.9% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","7.1% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","12.2% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","30.6% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","50.7% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","41.0% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","23.2% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","48.0% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","17.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","5.1% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","35.9% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","7.1% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","12.2% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","30.6% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","50.7% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","41.0% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","23.2% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","48.0% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","17.3% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n","/home/edu/.local/lib/python3.10/site-packages/seaborn/categorical.py:3544: UserWarning:\n","\n","5.1% of the points cannot be placed; you may want to decrease the size of the markers or use stripplot.\n","\n"]},{"data":{"image/png":"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","text/plain":["<Figure size 436.7x185.9 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["from matplotlib.patches import FancyArrowPatch\n","\n","def compute_violins(all_compute_doublings, ci, ylim, filename, names, data_filter, date, num_bootstraps=100, year=False, **kwargs):\n","    new_format = True\n","    with egraphs.epoch_theme():\n","        with mpl.rc_context(rc=subplot_rc_params if new_format else {}):\n","            data = []\n","            # Data preparation\n","            for i, compute_doubling in enumerate(all_compute_doublings):\n","                data.append({'model': f'{names[i][0]}', 'value': data_filter(compute_doubling, ci)})\n","\n","            df = pd.DataFrame([(d['model'], val) for d in data for val in d['value']], columns=['Model', 'Doubling Time'])\n","            if not year:\n","                df['Doubling Time'] = df['Doubling Time'] * 12  # convert to months\n","\n","            # Remove points that touch the figure frame\n","            # (seaborn paints them above the frame)\n","            df = df[df['Doubling Time'] > 0.01]\n","            df = df[df['Doubling Time'] < 3.45]\n","\n","            # Plotting\n","            #sns.set(style=\"whitegrid\")\n","            if new_format:\n","                plt.figure(figsize=egraphs.px_to_in((397 * px_scale_factor, 169 * px_scale_factor)))\n","            else:\n","                plt.figure(figsize=egraphs.px_to_in((949, 350)))\n","            ax = sns.swarmplot(y='Doubling Time', x='Model', data=df, palette=egraphs.get_gradient_colors(len(names))[::-1], s=3/2)\n","            ax.set_ylabel('Doubling time (years)' if year else 'Doubling time (months)')\n","            ax.set_xlabel('Statistical model structure')\n","\n","            y_min, y_max = ylim\n","            ax.set_ylim(y_min, y_max * 1.5)\n","            ax.set_xticklabels(ax.get_xticklabels())\n","            ax.set_ylim(*ylim)\n","            ax.set_yticklabels(ax.get_yticklabels())\n","\n","            if new_format:\n","                arrow_y = -0.80\n","\n","                arrow_color = 'black'\n","                arrow_style = \"<|-|>,head_width=1,head_length=1\"\n","\n","                arrow_left_text = mpl.text.Text(-0.5, arrow_y, 'Better cross-validation performance', fontsize=6, color=arrow_color,\n","                        ha='left', va='center', weight='medium', clip_on=False)\n","                arrow_right_text = mpl.text.Text(13.5, arrow_y, 'Worse cross-validation performance', fontsize=6, color=arrow_color,\n","                        ha='right', va='center', weight='medium', clip_on=False)\n","                arrow = FancyArrowPatch((4.50, arrow_y), (8.50, arrow_y), arrowstyle=arrow_style, lw=1/2, color=arrow_color, clip_on=False)\n","            else:\n","                arrow_y = -0.65\n","\n","                arrow_color = '#3E555E'\n","                arrow_style = \"<|-|>,head_width=2,head_length=2\"\n","\n","                arrow_left_text = mpl.text.Text(-0.5, arrow_y, 'Better cross-validation performance', fontsize=egraphs.px_to_pt(7), color=arrow_color,\n","                        ha='left', va='center', weight='medium', clip_on=False)\n","                arrow_right_text = mpl.text.Text(13.5, arrow_y, 'Worse cross-validation performance', fontsize=egraphs.px_to_pt(7), color=arrow_color,\n","                        ha='right', va='center', weight='medium', clip_on=False)\n","                arrow = FancyArrowPatch((4, arrow_y), (9, arrow_y), arrowstyle=arrow_style, lw=1, color=arrow_color, clip_on=False)\n","\n","            ax.add_artist(arrow_left_text)\n","            ax.add_artist(arrow_right_text)\n","            ax.add_artist(arrow)\n","\n","            if new_format:\n","                egraphs.relayout(replace_legend=False, xaxis=dict(labelpad=3), padding={'left': 5, 'top': 0, 'right': 5, 'bottom': 11})\n","                plt.gca().yaxis.label.set_position((0.0, 1.0 + 0.08))\n","            else:\n","                egraphs.relayout(xaxis={'labelpad': 20})\n","                plt.gcf().subplots_adjust(bottom=egraphs.px_to_y_fraction(65))\n","\n","            plt.savefig(filename, format='pdf')\n","            plt.show()\n","\n","\n","ci = 100\n","compute_violins(all_compute_doublings[:-1], ci, (0, 3.5),\n","                f\"{date}_compute_doubling_swarmplot_all_models.pdf\",\n","                names, data_filter, date, year=True,\n","                title=f\"Compute efficiency doubling times ({ci}% CI)\")"]},{"cell_type":"markdown","metadata":{"id":"EDLQkP3lmXwx"},"source":["# Dummy for year (section 3.1)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715196,"status":"aborted","timestamp":1709236282801,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"PDgCwkxCmvRo","outputId":"5c982571-17ed-4c0b-c236-5eed5045d7df"},"outputs":[{"name":"stdout","output_type":"stream","text":[" message: Optimization terminated successfully\n"," success: True\n","  status: 0\n","     fun: 0.049180189755223945\n","       x: [ 4.666e-01  1.874e-01  4.257e-02  5.577e-03  8.967e-02\n","            1.123e+00  9.715e-05  9.840e-02  1.378e-02  2.967e-02\n","           -3.883e-02  4.114e-02]\n","     nit: 35\n","     jac: [-1.597e-03  4.859e-06  1.122e-04  2.283e-02  1.603e-02\n","           -3.984e-03 -2.441e-03 -1.210e-03  2.676e-02  1.456e-02\n","            2.380e-02  2.707e-02]\n","    nfev: 474\n","    njev: 35\n","\n","\n","Optimized parameters:\n","alpha_const         0.466551\n","alpha_const_ptb     0.187420\n","alpha_const_wt2     0.042573\n","alpha_year          0.005577\n","alpha_param         0.089667\n","beta_const          1.122824\n","beta_const_ptb      0.000097\n","beta_const_wt2      0.098399\n","beta_year           0.013778\n","beta_data           0.029671\n","alpha_year_dummy   -0.038833\n","beta_year_dummy     0.041142\n","dtype: float64\n"]}],"source":["df_main = df_head.copy(deep=True)\n","\n","param_names = ['alpha_const', 'alpha_const_ptb', 'alpha_const_wt2', 'alpha_year', 'alpha_param', \\\n","               'beta_const', 'beta_const_ptb', 'beta_const_wt2', 'beta_year', 'beta_data', \\\n","               'alpha_year_dummy', 'beta_year_dummy'\n","               ]\n","\n","np.random.seed(0)\n","p0 = np.zeros(len(param_names))\n","delta = 0.0025\n","split_year = 2017\n","\n","year = df_main[\"publication_date\"]\n","param = df_main[\"param\"]\n","dataset = df_main[\"dataset\"]\n","log_ppl = df_main[\"log_ppl\"]\n","ptb_dummy = df_main['ptb_dummy']\n","wt2_dummy = df_main['wt2_dummy']\n","year_dummy = df_main[\"Year\"] >= split_year\n","\n","param_const = np.min(param)\n","dataset_const = np.min(dataset)\n","year_const = np.min(year)\n","\n","def model_year(params, year, param, dataset, category_ptb, category_wt2, category_year):\n","    alpha_const, alpha_const_ptb, alpha_const_wt2, alpha_year, alpha_param, \\\n","    beta_const, beta_const_ptb, beta_const_wt2, beta_year, beta_data, \\\n","    alpha_year_dummy, beta_year_dummy = params\n","\n","    alpha_const_prime = prime(alpha_const, alpha_const_ptb, alpha_const_wt2, category_ptb, category_wt2)\n","    beta_const_prime = prime(beta_const, beta_const_ptb, beta_const_wt2, category_ptb, category_wt2)\n","    alpha_year_prime = alpha_year + alpha_year_dummy * category_year\n","    beta_year_prime = beta_year + beta_year_dummy * category_year\n","\n","    alpha_terms = (alpha_const_prime - alpha_year_prime * (year - year_const) - alpha_param * log_diff(param, param_const))\n","    beta_terms = (beta_const_prime - beta_year_prime * (year - year_const) - beta_data * log_diff(dataset, dataset_const))\n","\n","    return np.exp(alpha_terms) + np.exp(beta_terms)\n","\n","def residuals_year(params, year, param, dataset, category_ptb, category_wt2, category_year, log_ppl, delta):\n","    residuals = log_ppl - model_year(params, year, param, dataset, category_ptb, category_wt2, category_year)\n","    l1_reg = delta * np.sum(np.abs(params))\n","    return np.mean(np.square(residuals)) + l1_reg\n","\n","res = minimize(residuals_year, p0, args=(year, param, dataset, ptb_dummy, wt2_dummy, year_dummy, log_ppl, delta), method='SLSQP')\n","print(res)\n","\n","print(\"\\n\")\n","params_optimized = pd.Series(res.x, index=param_names)\n","print(\"Optimized parameters:\")\n","print(params_optimized)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715194,"status":"aborted","timestamp":1709236282802,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"pGeWQTjIBmiD","outputId":"8f604145-5ff9-40df-c1ea-9ba4078fbc7c"},"outputs":[{"data":{"text/html":["<html>\n","<head><meta charset=\"utf-8\" /></head>\n","<body>\n","    <div>            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-AMS-MML_SVG\"></script><script type=\"text/javascript\">if (window.MathJax && window.MathJax.Hub && window.MathJax.Hub.Config) {window.MathJax.Hub.Config({SVG: {font: \"STIX-Web\"}});}</script>                <script type=\"text/javascript\">window.PlotlyConfig = {MathJaxConfig: 'local'};</script>\n","        <script charset=\"utf-8\" src=\"https://cdn.plot.ly/plotly-2.27.0.min.js\"></script>                <div id=\"0c144ee2-60e7-4d42-a993-9e4fbfb2adf1\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"0c144ee2-60e7-4d42-a993-9e4fbfb2adf1\")) {                    Plotly.newPlot(                        \"0c144ee2-60e7-4d42-a993-9e4fbfb2adf1\",                        [{\"customdata\":[[\"$\\\\infty$-former (SM)\"],[\"LBL\"],[\"2nd order FOFE-FNNLM\"],[\"TSLM+MoS (WT2)\"],[\"TSLM+MoS (PTB)\"],[\"NMM(LSTM+RNN)\"],[\"NMST+GPT-2\"],[\"Tensorized Transformer (151M)\"],[\"Tensorized Transformer (core-2)\"],[\"Tensorized Transformer (257M)\"],[\"Variational (untied weights, MC) LSTM (Large)\"],[\"Transformer-XL+WN+AdamP\"],[\"Transformer-XL+AdamP\"],[\"Transformer (Adaptive Input Embeddings)\"],[\"Transformer+Recurrent Windows of Context\"],[\"Feedback Transformer\"],[\"RNN (SGD+CLR) (PTB)\"],[\"4 layer QRNN (h=2500)\"],[\"LSTM (2018)\"],[\"Search-Proven Best LSTM\"],[\"All-attention network + adaptive span\"],[\"Transformer-XL + AutoDropout (PTB)\"],[\"Transformer-XL + AutoDropout (WT2)\"],[\"AWD-LSTM+Behaviorial-Gating\"],[\"LSTM-Large+Behaviorial-Gating\"],[\"LSTM-Medium+Behaviorial-Gating\"],[\"Segatron-XL large, M=384 + HCP\"],[\"Segatron -XL base, M=150 + HCP\"],[\"Transformer Large + HCP\"],[\"BLOOM-7.1B\"],[\"BLOOM-3B\"],[\"BLOOM-1.7B\"],[\"aLSTM(depth-2)+RecurrentPolicy (PTB)\"],[\"aLSTM(depth-2)+RecurrentPolicy (WT2)\"],[\"AWD-LSTM-MoS + dynamic evaluation (WT2, 2017)\"],[\"AWD-LSTM-MoS + dynamic evaluation (PTB, 2017)\"],[\"CODA\"],[\"RNN + char3-MS-vec\"],[\"RNN + char2-MS-vec\"],[\"RNN Baseline\"],[\"LSTM-Char-Large\"],[\"Mogrifier RLSTM (WT2)\"],[\"Mogrifier RLSTM (PTB)\"],[\"Transformer + GFM\"],[\"RNN+LDA+KN5+cache\"],[\"RNN+LDA\"],[\"RNN\"],[\"CT-MoS + DynamicEval (WT2)\"],[\"CT-MoS + DynamicEval (PTB)\"],[\"CT-MoS (PTB)\"],[\"RNNLM + Dynamic KL Regularization\"],[\"RNNLM + Dynamic KL Regularization (WT2)\"],[\"GPT2+CoreLM+Fine-Tuning\"],[\"GPT2+CoreLM+Fine-Tuning\"],[\"GPT-2 (1.5B, Curriculum Learning 45K)\"],[\"Transformer-XL DeFINE (141M)\"],[\"Transformer-XL DeFINE (107M)\"],[\"Adaptive LSTM + DeFINE\"],[\"DeLight\"],[\"DEQ-Transformer (Medium, Adaptive Embedding)\"],[\"DEQ-TrellisNet\"],[\"dense-IndRNN+dynamic eval\"],[\"AWD-LSTM-DRILL + dynamic evaluation\\u2020 (WT2)\"],[\"AWD-LSTM-DRILL + dynamic evaluation\\u2020 (PTB)\"],[\"DiffQ Transformer (16L)\"],[\"AWD-LSTM-DOC (fin) (23M)\"],[\"AWD-LSTM-DOC (fin) (37M)\"],[\"4-gram + 8 DENN\"],[\"AWD-LSTM + dynamic eval (WT2)\"],[\"AWD-LSTM + dynamic eval (PTB)\"],[\"LSTM + dynamic eval\"],[\"Transformer-XL + RMS dynamic eval\"],[\"ERNIE-Doc (247M)\"],[\"ERNIE-Doc (151M)\"],[\"EI-REHN-1200D\"],[\"EI-REHN-1000D\"],[\"Routing Transformer\"],[\"Local Transformer\"],[\"S4\"],[\"ONLSTM-SYD\"],[\"FNetAR Medium\"],[\"AWD-LSTM-MoS + dynamic evaluation (WT2, 2018)\"],[\"AWD-LSTM-MoS + dynamic evaluation (PTB, 2018)\"],[\"LSTM (Hebbian, Cache, MbPA)\"],[\"Decaying Fast Weights Transformer\"],[\"Fine-tuned-AWD-LSTM-DOC(fin)\"],[\"Fraternal dropout + AWD-LSTM 3-layer (PTB)\"],[\"Fraternal dropout + AWD-LSTM 3-layer (WT2)\"],[\"GLM-10B-bidirectional\"],[\"GLM-10B-unidirectional\"],[\"base LM+GNN+kNN\"],[\"GPT-Neo-2.7B (finetuned)\"],[\"GPT-Neo-1.3B (finetuned)\"],[\"GPT-Neo-2.7B (finetuned on PTB)\"],[\"Transformer-XL+AdamGapAware(GA)\"],[\"RNN+weight noise+dynamic eval\"],[\"Delta RNN (+ full context)\"],[\"GL-LWGC-AWD-MoS-LSTM + dynamic evaluation (WT2)\"],[\"GL-LWGC-AWD-MoS-LSTM + dynamic evaluation (PTB)\"],[\"Gated HORNN (3rd order)\"],[\"DOT(S)-RNN\"],[\"Hybrid H3-2.7B\"],[\"Hybrid H3-1.3B\"],[\"Hybrid H3-355M\"],[\"GPT-2 (fine-tuned with HYDRA)\"],[\"Hyena-3-slim\"],[\"AWD-LSTM-MoS+PDR + dynamic evaluation (WT2)\"],[\"AWD-LSTM-MoS+PDR + dynamic evaluation (PTB)\"],[\"4 layer Densely Connected LSTM\"],[\"Densely Connected LSTM + Var. Dropout\"],[\"TransformerXL + spectrum control\"],[\"AdvSoft + 4 layer QRNN + dynamic evaluation\"],[\"4 layer QRNN + dynamic evaluation\"],[\"AWD-LSTM + MoS + Partial Shuffled\"],[\"Transformer-XL Large + Phrase Induction\"],[\"AWD-LSTM + Phrase Induction + finetuning\"],[\"Neural cache model (size=2000) (300M)\"],[\"LSTM (WT103)\"],[\"LSTM (PTB)\"],[\"LSTM(medium)+Sememe+cell\"],[\"Sandwich Transformer\"],[\"Stack RNN\"],[\"LSTM+NeuralCache\"],[\"AWD-LSTM+WT+Cache+IOG (WT2)\"],[\"AWD-LSTM+WT+Cache+IOG (PTB)\"],[\"MPT-7B\"],[\"LSTM-3-layer+Gadam\"],[\"LLaMA-65B\"],[\"LLaMA-33B\"],[\"LLaMA-33B (LoRA finetuned)\"],[\"LSTM-300units\"],[\"LaMemo\"],[\"GPT-2 (1542M)\"],[\"GPT-2 (1542M)\"],[\"GPT-2 (1542M)\"],[\"SPN-4\"],[\"AWD-FWM (PTB)\"],[\"AWD-FWM (WT2)\"],[\"DITTO\"],[\"Linear Transformer (large)\"],[\"Linear Transformer (small)\"],[\"MemSizer\"],[\"bRSM + cache\"],[\"D-LSRC(200)+KN5\"],[\"D-LSRC(100)+KN5\"],[\"LSTM+Adam+Lookahead\"],[\"Megatron-LM (8.3B)\"],[\"Megatron-LM (2.5B)\"],[\"Megatron-LM (355M)\"],[\"Multipop Adaptive Continuous Stack (PTB)\"],[\"Multipop Adaptive Continuous Stack (WT2)\"],[\"TransformerXL + FWL\"],[\"Mogrifier (d2, MoS2, MC) + dynamic eval\"],[\"Mogrifier (d2, MC) + dynamic eval\"],[\"Monarch-GPT-2-Medium\"],[\"Monarch-GPT-2-Small\"],[\"Multi-cell LSTM\"],[\"Byte-mLSTM+emb+WN+VD\"],[\"ADP-FAIRSEQ+NGRAMRES\"],[\"ADP-FAIRSEQ\"],[\"L_UL-seq\"],[\"AWD-LSTM-MoS+Noisin+dynamic evaluation \"],[\"Dropout-LSTM+Noise(Bernoulli) (PTB)\"],[\"Dropout-LSTM+Noise(Bernoulli) (WT2)\"],[\"OPT-175B\"],[\"OPT-2.7B (finetuned on WT2)\"],[\"OPT-30B\"],[\"B2T connection (16L)\"],[\"AWD-LSTM\"],[\"DOC + Finetune\\u2217 + Partial Shuffle (PTB)\"],[\"DOC + Finetune\\u2217 + Partial Shuffle (WT2)\"],[\"PermuteFormer\"],[\"GPT-2-Medium+Pixelfly\"],[\"GPT-2-Small+Pixelfly\"],[\"Pointer Sentinel-LSTM (medium)\"],[\"Zoneout + Variational LSTM (PTB)\"],[\"Pointer Sentinel-LSTM\"],[\"Tensor-Transformer(1core)+PN (WT103)\"],[\"Tensor-Transformer(1core)+PN (PTB)\"],[\"2-layer skip-LSTM + dropout tuning (PTB)\"],[\"2-layer skip-LSTM + dropout tuning (WT2)\"],[\"Pythia-12b\"],[\"Pythia-6.9b\"],[\"Pythia-2.8b\"],[\"Adaptive Input Transformer + RD\"],[\"R-Transformer\"],[\"RFA-GATE-Gaussian-Stateful Big\"],[\"GPT-2+Active-SGD\"],[\"HSO\"],[\"Variational RHN + WT\"],[\"VD-RHN\"],[\"Transformer-XL + RMT\"],[\"Large regularized LSTM\"],[\"AWD-LSTM - 3-layer LSTM (tied) + continuous cache pointer (WT2)\"],[\"AWD-LSTM - 3-layer LSTM (tied) + continuous cache pointer (PTB)\"],[\"Transformer-C\"],[\"QRNN\"],[\"Gopher (280B)\"],[\"Gopher (7.1B)\"],[\"Segatron XL large, M=384\"],[\"Segatron XL base, M=384\"],[\"Selfish-RNN (ON-LSTM)\"],[\"Selfish-RNN (AWD-LSTM-MoS)\"],[\"Selfish-RNN (SNT-ASGD)RHNs\"],[\"Word-Independent-SRNN+KN5\"],[\"Shortformer\"],[\"Sparse Wide GPT-3 Small\"],[\"DEQ-Transformer (Post-LN) + Jacobian Regularisation\"],[\"GCRN-M1, dropout\"],[\"Subformer (122M)\"],[\"Subformer (96M)\"],[\"Subformer (83M)\"],[\"GPT3-6.7B (rerun of original)\"],[\"TaLK Convolution\"],[\"Integer Transformer\"],[\"Integer Transformer\"],[\"ALiBi (L=3072, Lvalid = 3072)\"],[\"Chinchilla\"],[\"NoPos\"],[\"Transformer-XL Large\"],[\"Transformer-XL-ptb\"],[\"TrellisNet\"],[\"TrellisNet-MoS (1.4x larger)\"],[\"TrellisNet-MoS (1.4x larger)\"],[\"Turing-NLG\"],[\"VD-LSTM+REAL Large\"],[\"SRU++ Large\"],[\"SRU++ Large only 2 attention layers (k=5)\"],[\"SRU++ Base\"],[\"genCNN + dyn eval\"],[\"rTop-k(distributed setting)\"]],\"hovertemplate\":\"predicted_log_ppl=%{x}\\u003cbr\\u003elog_ppl=%{y}\\u003cbr\\u003esystem=%{customdata[0]}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"legendgroup\":\"\",\"marker\":{\"color\":\"#636efa\",\"symbol\":\"circle\"},\"mode\":\"markers\",\"name\":\"\",\"orientation\":\"v\",\"showlegend\":false,\"x\":[2.945987405164714,4.992867737070025,4.6665288358613575,4.110331441171132,4.473683793690836,4.40900628049882,2.911050966186958,3.1835065483734457,3.2552344343656046,3.1199388749697565,4.3090361866034295,3.0678719718722793,3.0327922739336426,3.168062920190255,2.974021602853636,3.171754086210374,4.9654451184659045,3.481309918689707,4.211051265817607,4.482783296373512,3.1979517395729014,3.9656140009100023,3.779706791409236,4.003210783530311,3.8519084979042573,4.05594051713391,2.9900844107929543,3.0597159698094334,2.9900844107929543,2.4506068134835672,2.5397688515302446,2.6014047809655,4.092863299477847,3.970554212631548,4.001092237332896,4.140055149533239,3.028104696359194,3.162263538328462,3.1748382279973395,3.178919975754634,4.483007682333299,3.6890646696595413,3.9100955588977655,3.0083628131552547,4.728064336096862,4.766272228668863,4.790137705772991,3.7432213191607056,3.9666475223988336,3.9666475223988336,4.0929527500227065,3.8671071449517624,3.253246603572429,3.50009350372385,2.4939474302290767,3.169397003071416,3.2042973596840536,3.308736867966596,3.181843186642035,3.212633405292398,3.5041946414962224,3.91419830653934,3.88882631654264,4.038657174122587,3.0280991930834302,4.0323859096371795,3.9286803792058773,4.539565002326652,4.020794914709523,4.134541344381542,4.024517763561295,3.093204016943037,3.0465203431514105,3.1085100476121488,4.258459293188199,4.1800538523112,3.2289787379345007,2.620916474036136,3.009425730897667,3.984440236031446,3.2930222284327213,3.932548801627867,4.073876164497824,3.406352691470776,2.946696058009816,4.072686872489093,4.1274097887908265,4.007399762315728,2.269303509616255,2.269303509616255,2.9663576800551352,2.5924583341763183,2.5924583341763183,2.6405039111245223,3.0693901513902944,4.445814636226001,3.2581008457235425,4.0068534496976405,4.125619647309225,4.556874787482451,4.732119654065024,2.684064863188227,2.7643056112254216,2.920437375996417,3.2332329050354334,3.055346412779378,3.940930814781641,4.097082438980408,4.23634334690951,4.153138420351023,3.146332639674905,3.4185517531173923,3.4185517531173923,3.8794108609015865,3.0859224236157967,4.035723977188206,3.50242611432667,3.8448494351127307,4.346374705942257,4.049798082619517,3.0251267567457782,4.852238347155673,4.385847975963404,3.955548807558549,4.097344330147509,2.3841960807980445,4.000246875105196,2.170351593018164,2.2291794462327363,2.262946425767721,4.698144752570633,3.05725248404874,2.7615580152582178,2.9813274330382304,2.9880648506608,4.7555502336262805,3.970736141278281,3.778960070484664,2.8506359446134324,3.170822760306305,3.284816938282753,2.948463354262275,4.450337197972189,4.3492063380404575,4.382658354355758,4.251664443493885,2.45811084860434,2.5672250565730446,2.771818336304145,4.243363840917196,4.021015237743373,2.933709885249166,3.86314660813175,4.023601312729011,2.886085020133475,3.000716625583984,4.281900573624833,4.345358298899934,2.942911739897164,2.973294953773128,3.117066312082488,4.110622628329744,3.973809954267856,3.910159013375581,2.1999751754025683,2.5791226240952927,2.3431769717750965,2.9877281339947364,4.036083348774411,3.9745518600737233,3.8055496065888974,3.294670934236808,3.032252899852121,3.1807865611076007,4.4162450321611075,4.4162450321611075,4.4404761646095485,3.219013623703079,4.126004019984743,4.360708676541015,4.243467459256063,2.3779619038950726,2.4334606525405738,2.530026692510294,3.024788638856212,4.10757102139673,3.0414345119934447,3.4835207409441606,2.799170983818022,4.413958234240128,4.369885843422725,2.9521032145311845,4.366630676730783,4.031348067321629,4.142693160099502,3.099635207482473,3.2793573463075663,2.0083812438880573,2.3028136165621547,3.0742172069724405,3.139611902938918,4.1068731847506115,3.9056947398623167,4.186149883756916,4.428920053566944,3.365990140678166,2.7552990545007265,3.1454806252676626,4.313192671499666,3.1362350200705915,3.168033307127836,3.187674371485084,2.345410246268536,3.0939736368117847,3.2448842547874053,3.06006999354462,2.823532425663781,2.0410573495048396,2.796102402493461,3.146391297098461,3.410841027036122,3.2019402611405736,3.2019402611405736,3.472837580455102,2.377414444211396,4.294817787255738,3.046474481100785,3.0513628425227015,3.14608649842013,4.6297027393602415,3.809871899484193],\"xaxis\":\"x\",\"y\":[2.8100049236252036,5.069532935343741,4.68213122712422,4.394449154672439,4.426043520090656,4.624972813284271,3.029650491757452,2.9338568698359038,2.9391619220655967,3.054001181677967,4.29592393562047,3.125443880075648,3.1467351470905185,2.928523523860541,3.2857865301508276,2.9069010598473755,4.854760907317149,3.4965075614664802,4.368561383720311,4.379899373657707,3.0252910757955354,4.005513348515485,4.092676505121403,4.041646773221651,4.328098292648326,4.366278277705742,2.833213344056216,3.095577608523707,3.2308043957334744,2.6892071133007303,2.866192902199006,3.0041963519661206,4.012772908528289,4.1666652238017265,3.7057365711803594,3.864721732310133,2.916689066213538,3.4597807057610526,3.463232772581608,3.4716558453107167,4.368181227851829,3.6375861597263857,3.758871825933971,2.998229153752578,4.5217885770490405,4.73356340075649,4.825910852685991,3.7125959807312525,3.8590440806372595,4.001680877358681,4.354141431184346,4.463606621666305,3.3847291889548483,3.3847291889548483,2.6188546222977394,3.1851121947153915,3.2472688993694185,3.581850881355413,3.1838702156693857,3.1441522786722644,4.044804116661965,3.9110225050945626,3.7376696182833684,3.899950424193877,2.89591193827178,3.958524839079566,4.060960118202517,4.694279361059867,3.7909846770510898,3.933784497209659,4.091005660956586,2.797281334830153,2.8213788864092133,3.044522437723423,4.192680462942962,4.229749199228304,2.760009940032921,2.9856819377004897,3.0421386463681466,4.019980146933238,3.2507620137305224,3.66714496196793,3.8403121578741457,3.374168709274236,3.0204248861443626,3.953548752256644,4.039536325727106,4.160444363926624,2.427454075039915,2.503073953743449,2.8213788864092133,2.377692565480851,2.492378664626701,2.6878474937846906,3.2763897310688073,4.762173934797756,3.490428515390098,3.7003138317395994,3.8360055190042304,4.605170185988092,4.677490847567717,2.3608540011180215,2.5257286443082556,2.8273136219290276,2.719319793360441,2.917770732084279,3.696351468952637,3.856510295497887,4.341204640153626,4.360547602996758,3.1441522786722644,3.332204510175204,3.4531571205928664,3.639426570394406,2.856470206220483,4.019980146933238,3.708682081410116,3.885679030088544,4.410371107683024,4.490432508517668,2.8814431271518632,4.770684624465665,4.192680462942962,3.9454577815143836,3.970291913552122,2.298577071596507,4.073631520624559,1.601405740736836,1.9315214116032138,2.038619547159581,4.740574822994295,3.1684242813721024,2.8610573702273894,2.8610573702273894,2.8610573702273894,4.605170185988092,3.997833661841257,4.121473229610353,3.1917101567954314,3.449987545831587,3.56953269648137,3.0349529867072724,4.639571612705423,4.5217885770490405,4.532599493153256,4.05560373390567,2.3804716316511167,2.546315277916644,2.960623096440423,4.151039905898646,4.282206299391671,2.8094026953624978,3.653252276470785,3.8022081394209395,3.0106208860477417,3.0301337002713233,4.34536265030229,4.486386649998124,2.9014215940827497,2.9391619220655967,3.2355362657613083,3.8628327612373745,4.191168746857641,4.341204640153626,2.122261538862764,2.329227023940467,2.367436065313662,2.954910279033736,4.186619838331271,3.9512437185814275,4.0578534536396855,3.480932349681009,3.044522437723423,3.1135153092103742,4.2612704335380815,4.389498649512583,4.39197696552705,2.884800712846709,3.8628327612373745,4.012772908528289,4.154184562578117,2.355177543113216,2.4344901638739844,2.540814281726296,2.8942531046041373,4.435330406696193,3.1570004211501135,3.0248055210396982,3.0106208860477417,4.180522258463153,4.22683374526818,3.177637076851603,4.361823927356363,3.9512437185814275,3.966511190712216,3.2228678461377385,3.4965075614664802,2.0943301541735866,2.3804716316511167,2.8390784635086144,3.1135153092103742,4.022132228108176,4.143928062410929,4.159351723530711,4.543294782270004,2.8986705607108596,3.0155349008501706,3.214867803470662,4.591780948869076,2.990719731730447,3.015044584586364,3.038791763014438,2.211565694606877,3.1484533605716547,2.8992213731731473,3.427189961936409,2.9069010598473755,1.9685099809725544,3.0430928449138284,2.9069010598473755,3.998567606828332,3.3738261848660236,3.3738261848660236,3.3738261848660236,2.3233676321765744,4.22683374526818,2.8390784635086144,2.8507065015037334,2.9069010598473755,4.666265285347902,4.41267707387264],\"yaxis\":\"y\",\"type\":\"scatter\"},{\"hovertemplate\":\"\\u003cb\\u003eOLS trendline\\u003c\\u002fb\\u003e\\u003cbr\\u003elog_ppl = 1.00297 * predicted_log_ppl + -0.00930508\\u003cbr\\u003eR\\u003csup\\u003e2\\u003c\\u002fsup\\u003e=0.916232\\u003cbr\\u003e\\u003cbr\\u003epredicted_log_ppl=%{x}\\u003cbr\\u003elog_ppl=%{y} \\u003cb\\u003e(trend)\\u003c\\u002fb\\u003e\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"legendgroup\":\"\",\"marker\":{\"color\":\"#636efa\",\"symbol\":\"circle\"},\"mode\":\"lines\",\"name\":\"\",\"showlegend\":false,\"x\":[2.0083812438880573,2.0410573495048396,2.170351593018164,2.1999751754025683,2.2291794462327363,2.262946425767721,2.269303509616255,2.269303509616255,2.3028136165621547,2.3431769717750965,2.345410246268536,2.377414444211396,2.3779619038950726,2.3841960807980445,2.4334606525405738,2.4506068134835672,2.45811084860434,2.4939474302290767,2.530026692510294,2.5397688515302446,2.5672250565730446,2.5791226240952927,2.5924583341763183,2.5924583341763183,2.6014047809655,2.620916474036136,2.6405039111245223,2.684064863188227,2.7552990545007265,2.7615580152582178,2.7643056112254216,2.771818336304145,2.796102402493461,2.799170983818022,2.823532425663781,2.8506359446134324,2.886085020133475,2.911050966186958,2.920437375996417,2.933709885249166,2.942911739897164,2.945987405164714,2.946696058009816,2.948463354262275,2.9521032145311845,2.9663576800551352,2.973294953773128,2.974021602853636,2.9813274330382304,2.9877281339947364,2.9880648506608,2.9900844107929543,2.9900844107929543,3.000716625583984,3.0083628131552547,3.009425730897667,3.024788638856212,3.0251267567457782,3.0280991930834302,3.028104696359194,3.032252899852121,3.0327922739336426,3.0414345119934447,3.046474481100785,3.0465203431514105,3.0513628425227015,3.055346412779378,3.05725248404874,3.0597159698094334,3.06006999354462,3.0678719718722793,3.0693901513902944,3.0742172069724405,3.0859224236157967,3.093204016943037,3.0939736368117847,3.099635207482473,3.1085100476121488,3.117066312082488,3.1199388749697565,3.1362350200705915,3.139611902938918,3.1454806252676626,3.14608649842013,3.146332639674905,3.146391297098461,3.162263538328462,3.168033307127836,3.168062920190255,3.169397003071416,3.170822760306305,3.171754086210374,3.1748382279973395,3.178919975754634,3.1807865611076007,3.181843186642035,3.1835065483734457,3.187674371485084,3.1979517395729014,3.2019402611405736,3.2019402611405736,3.2042973596840536,3.212633405292398,3.219013623703079,3.2289787379345007,3.2332329050354334,3.2448842547874053,3.253246603572429,3.2552344343656046,3.2581008457235425,3.2793573463075663,3.284816938282753,3.2930222284327213,3.294670934236808,3.308736867966596,3.365990140678166,3.406352691470776,3.410841027036122,3.4185517531173923,3.4185517531173923,3.472837580455102,3.481309918689707,3.4835207409441606,3.50009350372385,3.50242611432667,3.5041946414962224,3.6890646696595413,3.7432213191607056,3.778960070484664,3.779706791409236,3.8055496065888974,3.809871899484193,3.8448494351127307,3.8519084979042573,3.86314660813175,3.8671071449517624,3.8794108609015865,3.88882631654264,3.9056947398623167,3.9100955588977655,3.910159013375581,3.91419830653934,3.9286803792058773,3.932548801627867,3.940930814781641,3.955548807558549,3.9656140009100023,3.9666475223988336,3.9666475223988336,3.970554212631548,3.970736141278281,3.973809954267856,3.9745518600737233,3.984440236031446,4.000246875105196,4.001092237332896,4.003210783530311,4.0068534496976405,4.007399762315728,4.020794914709523,4.021015237743373,4.023601312729011,4.024517763561295,4.031348067321629,4.0323859096371795,4.035723977188206,4.036083348774411,4.038657174122587,4.049798082619517,4.05594051713391,4.072686872489093,4.073876164497824,4.092863299477847,4.0929527500227065,4.097082438980408,4.097344330147509,4.1068731847506115,4.10757102139673,4.110331441171132,4.110622628329744,4.125619647309225,4.126004019984743,4.1274097887908265,4.134541344381542,4.140055149533239,4.142693160099502,4.153138420351023,4.1800538523112,4.186149883756916,4.211051265817607,4.23634334690951,4.243363840917196,4.243467459256063,4.251664443493885,4.258459293188199,4.281900573624833,4.294817787255738,4.3090361866034295,4.313192671499666,4.345358298899934,4.346374705942257,4.3492063380404575,4.360708676541015,4.366630676730783,4.369885843422725,4.382658354355758,4.385847975963404,4.40900628049882,4.413958234240128,4.4162450321611075,4.4162450321611075,4.428920053566944,4.4404761646095485,4.445814636226001,4.450337197972189,4.473683793690836,4.482783296373512,4.483007682333299,4.539565002326652,4.556874787482451,4.6297027393602415,4.6665288358613575,4.698144752570633,4.728064336096862,4.732119654065024,4.7555502336262805,4.766272228668863,4.790137705772991,4.852238347155673,4.9654451184659045,4.992867737070025],\"xaxis\":\"x\",\"y\":[2.005051096027383,2.037824413023193,2.1675033067717595,2.197215019281862,2.226506172786306,2.2603736090490503,2.266749605215189,2.266749605215189,2.300359404693173,2.3408428408444144,2.3430827593270673,2.3751821697243485,2.3757312580999947,2.3819839816725406,2.431395115462961,2.4485922862162988,2.4561186458334765,2.4920618412499618,2.5282484392976197,2.538019581230165,2.5655574684534055,2.5774904312262223,2.590865815030381,2.590865815030381,2.5998388774891277,2.619408617825641,2.6390543275182754,2.6827448733674677,2.754190986322425,2.7604685674814307,2.7632243375436785,2.7707594129714224,2.795115724231505,2.7981934345822026,2.822627351691223,2.849811503580568,2.8853660400621144,2.910406259778226,2.9198205941467616,2.9331325891002473,2.942361819255916,2.945446634624325,2.946157395710878,2.9479299496677855,2.951580638517076,2.965877511060613,2.9728354231604475,2.9735642340211874,2.9808917990427153,2.987311542077675,2.987649260475458,2.9896748287968307,2.9896748287968307,3.000338674415416,3.0080076093864787,3.0090736893080305,3.0244823019012106,3.0248214256911345,3.0278027050236904,3.027808224671694,3.031968769065546,3.0325097477843794,3.0411776964931043,3.0462326595031124,3.0462786579932892,3.051135563794996,3.055130985168897,3.0570427269982328,3.059513541626412,3.0598686185818296,3.0676938077866134,3.06921650388706,3.074057919954366,3.085797959604633,3.0931012156641815,3.0938731251512106,3.0995515389885484,3.1084527817580545,3.1170345011059806,3.1199156098647456,3.1362602359797096,3.1396471650709334,3.1455333468422877,3.146141022466731,3.146387895991474,3.146446727920802,3.162366189051373,3.1681531229067126,3.1681828240679604,3.1695208758442566,3.170950874705384,3.171884971303015,3.174978288408476,3.1790721793609538,3.180944317803336,3.182004086797597,3.183672397028368,3.1878526194092762,3.198160562656089,3.2021609500711308,3.2021609500711308,3.20452506098024,3.212885906315294,3.219285105868877,3.2292798663044078,3.2335466895478855,3.2452327020528244,3.2536199288164798,3.2556136734041248,3.2584886123327665,3.279808350983141,3.2852841852385755,3.2935138861179056,3.295167496819984,3.309275276687474,3.3666988778237164,3.4071815071614764,3.4116831955202964,3.419416861003357,3.419416861003357,3.473864188618947,3.482361732050678,3.4845791314989585,3.5012011982300733,3.5035407483469254,3.505314536882903,3.6907345531809597,3.74505231865608,3.7808973927267475,3.781646335145266,3.8075660326722627,3.811901184384268,3.8469827781436403,3.8540628416393714,3.865334385232691,3.8693067046454788,3.8816470241370062,3.891090490748454,3.908009097609345,3.9124230090766856,3.9124866523315043,3.9165379623880767,3.931063119205204,3.934943050179734,3.943349999813616,3.9580114811032963,3.968106618394133,3.9691432146082803,3.9691432146082803,3.973061527240231,3.9732439971244924,3.9763269547044016,3.9770710676792427,3.986988861544793,4.002842525352768,4.003690402532185,4.0058152514022565,4.009468754497512,4.01001669239505,4.023451695352794,4.023672673847432,4.026266442403368,4.027185619675892,4.034036243582558,4.03507717347788,4.038425171776277,4.038785612492564,4.04136709496838,4.052541147656092,4.058701855906552,4.075498031650886,4.076690861802063,4.095734483488209,4.095824200148343,4.099966174926246,4.100228845219288,4.109786048154575,4.110485960863964,4.113254592884223,4.113546646324318,4.128588281419116,4.12897379760293,4.130383748569698,4.137536520530618,4.143066729246704,4.145712587891561,4.156188922781084,4.183184428122363,4.1892985952550665,4.214274058900577,4.239641383906497,4.246682763876296,4.2467866904796105,4.2550080607367144,4.261823125101553,4.285334143322247,4.2982897856497955,4.312550484720238,4.3167193351545645,4.348980655261717,4.350000086113896,4.35284014231454,4.364376700259752,4.370316318393709,4.373581169203054,4.3863916783423615,4.389590789070856,4.412817989537331,4.417784675335686,4.420078276478019,4.420078276478019,4.432791006058891,4.444381496519405,4.449735850083169,4.454271866445682,4.477687918261455,4.4868144919548145,4.48703954546259,4.543765123422029,4.561126405170029,4.634171020126242,4.671106674224799,4.702816648252243,4.73282524250725,4.7368926250420005,4.760392910552224,4.771146803518514,4.795083280391331,4.857368671115263,4.970912232448254,4.998416433313196],\"yaxis\":\"y\",\"type\":\"scatter\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Predicted Log PPL\"}},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Actual Log PPL\"}},\"legend\":{\"tracegroupgap\":0},\"margin\":{\"t\":60},\"annotations\":[{\"showarrow\":false,\"text\":\"r2 total = 0.92\",\"x\":0.5,\"xref\":\"paper\",\"y\":0.95,\"yref\":\"paper\"}],\"title\":{\"text\":\"Nonlinear model: actual vs predicted cross entropy\"}},                        {\"responsive\": true}                    ).then(function(){\n","                            \n","var gd = document.getElementById('0c144ee2-60e7-4d42-a993-9e4fbfb2adf1');\n","var x = new MutationObserver(function (mutations, observer) {{\n","        var display = window.getComputedStyle(gd).display;\n","        if (!display || display === 'none') {{\n","            console.log([gd, 'removed!']);\n","            Plotly.purge(gd);\n","            observer.disconnect();\n","        }}\n","}});\n","\n","// Listen for the removal of the full notebook cells\n","var notebookContainer = gd.closest('#notebook-container');\n","if (notebookContainer) {{\n","    x.observe(notebookContainer, {childList: true});\n","}}\n","\n","// Listen for the clearing of the current output cell\n","var outputEl = gd.closest('.output');\n","if (outputEl) {{\n","    x.observe(outputEl, {childList: true});\n","}}\n","\n","                        })                };                            </script>        </div>\n","</body>\n","</html>"]},"metadata":{},"output_type":"display_data"}],"source":["df_main['predicted_log_ppl'] = model_year(res.x, year, param, dataset, ptb_dummy, wt2_dummy, year_dummy)\n","r2_score_value = r2_score(df_main[\"log_ppl\"], df_main['predicted_log_ppl'])\n","\n","fig = px.scatter(df_main, x='predicted_log_ppl', y=df_main[\"log_ppl\"], hover_data=['system'], trendline='ols')\n","\n","fig.add_annotation(\n","        x=0.50,\n","        y=0.95,\n","        xref=\"paper\",\n","        yref=\"paper\",\n","        text=f\"r2 total = {r2_score_value:.2f}\",\n","        showarrow=False,\n",")\n","\n","fig.update_layout(title=\"Nonlinear model: actual vs predicted cross entropy\",\n","    xaxis_title=\"Predicted Log PPL\",\n","    yaxis_title=\"Actual Log PPL\")\n","\n","fig.show()"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"vA0aXXb1DucL"},"outputs":[],"source":["filename_suffix = f\"_pre-post-bootstraps.json\"\n","latest_cached_filename = safe_max([f for f in os.listdir() if f.endswith(filename_suffix)])"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"fup6X7v7Bzba"},"outputs":[],"source":["if not (use_cached_bootstraps and latest_cached_filename):\n","    np.random.seed(0)\n","    n_bootstrap_samples = 100\n","\n","    bootstrap_results = []\n","    for i in range(n_bootstrap_samples):\n","        bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","\n","        bootstrap_res = minimize(residuals_year, p0, args=(year[bootstrap_indices], param[bootstrap_indices],\n","                                                        dataset[bootstrap_indices], ptb_dummy[bootstrap_indices],\n","                                                        wt2_dummy[bootstrap_indices], year_dummy[bootstrap_indices], log_ppl[bootstrap_indices], delta), method='SLSQP')\n","        bootstrap_results.append(bootstrap_res.x)\n","\n","        if i % 5 == 4:\n","            print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","\n","\n","    confidence_intervals = np.percentile(bootstrap_results, [2.5, 97.5], axis=0)\n","    standard_errors = np.std(bootstrap_results, axis=0)\n","\n","    print(\"Optimized parameters with confidence intervals and standard errors:\")\n","    for i, name in enumerate(param_names):\n","        print(f\"{name}_opt: {params_optimized[i]}  CI: {confidence_intervals[:, i]}  SE: {standard_errors[i]}\")"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"jtedsy3Rh2TU"},"outputs":[],"source":["split_years = [2016, 2017, 2018, 2019, 2020]\n","\n","if not (use_cached_bootstraps and latest_cached_filename):\n","  all_bootstrap_results = []\n","  np.random.seed(0)\n","  n_bootstrap_samples = 100\n","\n","  for split_year in split_years:\n","    print(split_year)\n","    year_dummy = df_main[\"Year\"] >= split_year\n","    bootstrap_results = []\n","\n","    for i in range(n_bootstrap_samples):\n","        bootstrap_indices = np.random.choice(np.array(log_ppl.index), size=len(log_ppl), replace=True)\n","\n","        bootstrap_res = minimize(residuals_year, p0, args=(year[bootstrap_indices], param[bootstrap_indices],\n","                                                        dataset[bootstrap_indices], ptb_dummy[bootstrap_indices],\n","                                                        wt2_dummy[bootstrap_indices], year_dummy[bootstrap_indices], log_ppl[bootstrap_indices], delta), method='SLSQP')\n","        bootstrap_results.append(bootstrap_res.x)\n","\n","        if i % 5 == 4:\n","            print(f\"Bootstrap steps complete: ({i+1}/{n_bootstrap_samples})\")\n","    print(\"\\n\")\n","\n","    all_bootstrap_results.append(bootstrap_results)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"zfgaZtzkj3B6"},"outputs":[],"source":["if use_cached_bootstraps and latest_cached_filename:\n","      with open(latest_cached_filename, 'r') as f:\n","            all_bootstrap_results = json.load(f)\n","else:\n","    all_bootstrap_results_to_save = [\n","        [param_estimates.tolist() if isinstance(param_estimates, np.ndarray) else param_estimates for param_estimates in model_bootstrap_results]\n","        for model_bootstrap_results in all_bootstrap_results\n","    ]\n","\n","    filename = f\"{date}_pre-post-bootstraps.json\"\n","    with open(filename, 'w') as f:\n","        json.dump(all_bootstrap_results_to_save, f)\n","\n","    files.download(filename)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"chY0PsKw4Ks_"},"outputs":[],"source":["custom_filename_to_load = None # @param {type:\"string\"}\n","#custom_filename_to_load = '2024-02-20_pre-post-bootstraps.json'\n","if custom_filename_to_load:\n","    with open(custom_filename_to_load, 'r') as f:\n","        all_bootstrap_results = json.load(f)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":1715186,"status":"aborted","timestamp":1709236282802,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"8vIQwxh7fcYW","outputId":"d0e61bec-b668-4477-95cf-e398c74d6f1a"},"outputs":[{"data":{"image/png":"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","text/plain":["<Figure size 600x309 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["new_format = True\n","with egraphs.epoch_theme():\n","    with mpl.rc_context(rc=standalone_plot_rc_params if new_format else {}):\n","        compute_doublings_pre = []\n","        compute_doublings_post = []\n","\n","        ci = 90\n","\n","        for bootstrap_results in all_bootstrap_results:\n","            results = np.array(bootstrap_results).T\n","\n","            param_doubling_pre = results[4] / results[3] * np.log(2)\n","            data_doubling_pre = results[9] / results[8] * np.log(2)\n","            compute_doubling_pre = (1/param_doubling_pre + 1/data_doubling_pre) ** (-1)\n","\n","            param_doubling_post = results[4] / (results[3] + results[-2]) * np.log(2)\n","            data_doubling_post = results[9] / (results[8] + results[-1]) * np.log(2)\n","            compute_doubling_post = (1/param_doubling_post + 1/data_doubling_post) ** (-1)\n","\n","            compute_doublings_pre.append(data_filter(compute_doubling_pre, ci))\n","            compute_doublings_post.append(data_filter(compute_doubling_post, ci))\n","\n","        data = []\n","        for year, pre_data, post_data in zip(split_years, compute_doublings_pre, compute_doublings_post):\n","            for pre, post in zip(pre_data, post_data):\n","                data.append([year, \"Pre\", pre])\n","                data.append([year, \"Post\", post])\n","\n","        doublings_df = pd.DataFrame(data, columns=[\"Year\", \"Time\", \"Doubling Time\"])\n","\n","        pre_color = '#00A5A6'\n","        pre_line_color = '#007173'\n","        post_color = '#1F6EE5'\n","        post_line_color = '#1F6EE5'\n","\n","        if new_format:\n","            plt.figure(figsize=standalone_fig_size)\n","        else:\n","            plt.figure(figsize=(10, 5))\n","\n","        alpha = 0.4\n","\n","        sns.violinplot(x=\"Year\", y=\"Doubling Time\", hue=\"Time\", data=doublings_df, split=True, inner=\"quart\", palette=[pre_color, post_color])\n","\n","        # Set fill transparency\n","        for i, violin in enumerate(plt.gca().collections):\n","            violin.set_edgecolor(pre_line_color if i % 2 == 0 else post_line_color)\n","            violin.set_facecolor(mpl.colors.to_rgba(pre_color if i % 2 == 0 else post_color, alpha=alpha))\n","            if new_format:\n","                violin.set_linewidth(1)\n","\n","        # Set the line color\n","        for i, artist in enumerate([c for c in plt.gca().get_children() if isinstance(c, mpl.lines.Line2D)]):\n","            artist.set_color(pre_line_color if (i // 3) % 2 == 0 else post_line_color)\n","            artist.set_linestyle((0, (3, 3)) if i % 3 == 1 else (0, (2, 1)))\n","            if new_format:\n","                artist.set_linewidth(0.5)\n","\n","        plt.xlabel('Year')\n","        plt.ylabel('Doubling Time')\n","        plt.ylim(0,3)\n","\n","        # vertical grid line\n","        plt.gca().grid(True)\n","\n","        relayout(replace_legend=True, xaxis={'labelpad': standalone_xaxis_labelpad}, padding=standalone_padding)\n","\n","        # Very hackily fix the legend symbols\n","        rect_index = 0\n","        text_index = 0\n","        for artist in plt.gca().get_children():\n","            if isinstance(artist, mpl.patches.Rectangle):\n","                if rect_index in (0, 2):\n","                    artist.set_facecolor(mpl.colors.to_rgba(pre_color, alpha=alpha))\n","                if rect_index in (1, 3):\n","                    artist.set_facecolor(mpl.colors.to_rgba(post_color, alpha=alpha))\n","\n","                if rect_index in (2, 3):\n","                    artist.set_x(artist.get_x() + 0.045)\n","                    if rect_index == 2:\n","                        artist.set_x(artist.get_x() + 0.032)\n","\n","                    w = 0.015\n","                    artist.set_width(w)\n","                    artist.set_height(w*2)\n","                    artist.set_y(artist.get_y() + 0.01)\n","\n","                    artist.set_y(artist.get_y() + 0.02)\n","\n","                rect_index += 1\n","            if isinstance(artist, mpl.text.Text):\n","                artist.set_color('black')\n","                artist.set_fontsize(standalone_plot_rc_params['legend.fontsize'])\n","                artist.set_x(artist.get_position()[0] + 0.03)\n","                if text_index == 0:\n","                    artist.set_x(artist.get_position()[0] + 0.032)\n","                artist.set_y(artist.get_position()[1] + 0.02)\n","                text_index += 1\n","\n","        plt.savefig(\"pre-post.pdf\")\n","        plt.show()"]},{"cell_type":"markdown","metadata":{"id":"_kxrrQarVjRa"},"source":["# Contributions to effective compute graph (section 3.2)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"edi55Hs_VrVx"},"outputs":[],"source":["import numpy as np\n","import matplotlib.pyplot as plt\n","import pandas as pd\n","from datetime import datetime\n","date = datetime.today().strftime('%Y-%m-%d')\n","from matplotlib.path import Path\n","import matplotlib.patches as patches\n","from matplotlib.ticker import FuncFormatter\n","import matplotlib.dates as mdates\n","import egraphs"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"sxMil86eZluU"},"outputs":[],"source":["def add_brace(ax, start, end, num_years):\n","    center = np.sqrt(start * end)\n","    upper_half = [\n","        (num_years, start),\n","        (num_years + 0.2, start),\n","        (num_years, start),\n","        (num_years + 0.5, center)\n","    ]\n","    lower_half = [\n","        (num_years + 0.5, center),\n","        (num_years, end),\n","        (num_years + 0.2, end),\n","        (num_years, end)\n","    ]\n","    points = upper_half + lower_half\n","    cmds = [Path.MOVETO, Path.CURVE4, Path.CURVE4, Path.CURVE4] * 2\n","    brace_path = Path(points, cmds)\n","    ax.add_patch(patches.PathPatch(brace_path, fc=\"none\", transform=ax.transData))\n","\n","def human_format(x, pos):\n","    magnitude = 0\n","    while abs(x) >= 1000:\n","        magnitude += 1\n","        x /= 1000.0\n","    return f\"{x:.0f}{' KMBTPEZY'[magnitude]}\""]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":2,"status":"aborted","timestamp":1709236283038,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"K-1fBo0QKozk","outputId":"f0aeab16-fffd-45dd-aa09-bb71147056ab"},"outputs":[{"name":"stdout","output_type":"stream","text":["[[[66000000.0, 929000.0, 2014.685417086759, 2014.685417086759, 1, 0, 0], 'Large regularized LSTM'], [[11000000.0, 103000000.0, 2016.9496680475304, 2016.9496680475304, 0, 0, 0], 'LSTM (2016)'], [[247000000.0, 103000000.0, 2018.740260705746, 2018.740260705746, 0, 0, 1], 'Transformer (Adaptive Input Embeddings)'], [[257000000.0, 103000000.0, 2019.0222653598687, 2019.0222653598687, 0, 0, 1], 'Transformer-XL Large'], [[1500000000.0, 4000000000.0, 2019.1208300933486, 2019.1208300933486, 0, 0, 1], 'GPT-2 (1542M)'], [[8300000000.0, 46400000000.0, 2019.7094805849638, 2019.7094805849638, 0, 0, 1], 'Megatron-LM (8.3B)'], [[175000000000.0, 499000000000.0, 2020.4049095378489, 2020.4049095378489, 0, 0, 1], 'GPT-3'], [[280000000000.0, 300000000000.0, 2021.9354008160487, 2021.9354008160487, 0, 0, 1], 'Gopher (280B)'], [[70000000000.0, 1400000000000.0, 2022.2393087442779, 2022.2393087442779, 0, 0, 1], 'Chinchilla']]\n"]}],"source":["# param, data, year_param, year_data, category_ptb, category_wt2, category_transformer\n","models = [[[6.60E+07, 9.29E+05, \"2014/09/08\", \"2014/09/08\", 1, 0, 0], \"Large regularized LSTM\"], # https://arxiv.org/abs/1409.2329\n","          [[1.10E+07, 1.03E+08, \"2016/12/13\", \"2016/12/13\", 0, 0, 0], \"LSTM (2016)\"], # LSTM (WT103) https://arxiv.org/abs/1612.04426\n","          [[2.47E+08, 1.03E+08, \"2018/09/28\", \"2018/09/28\", 0, 0, 1], \"Transformer (Adaptive Input Embeddings)\"], # https://arxiv.org/abs/1809.10853\n","          [[2.57E+08, 1.03E+08, \"2019/01/09\", \"2019/01/09\", 0, 0, 1], \"Transformer-XL Large\"], # https://arxiv.org/abs/1901.02860\n","          [[1.50E+09, 4.00E+09, \"2019/02/14\", \"2019/02/14\", 0, 0, 1], \"GPT-2 (1542M)\"], # https://d4mucfpksywv.cloudfront.net/better-language-models/language_models_are_unsupervised_multitask_learners.pdf\n","          [[8.30E+09, 4.64E+10, \"2019/09/17\", \"2019/09/17\", 0, 0, 1], \"Megatron-LM (8.3B)\"], # https://arxiv.org/abs/1909.08053\n","          [[1.75E+11, 4.99E+11, \"2020/05/28\", \"2020/05/28\", 0, 0, 1], \"GPT-3\"], # https://arxiv.org/abs/2005.14165\n","          [[2.80E+11, 3.00E+11, \"2021/12/08\", \"2021/12/08\", 0, 0, 1], \"Gopher (280B)\"], # https://arxiv.org/abs/2112.11446\n","          [[7.00E+10, 1.40E+12, \"2022/03/29\", \"2022/03/29\", 0, 0, 1], \"Chinchilla\"]] # https://arxiv.org/abs/2203.15556\n","\n","# [[6.00E+06, 9.29E+05, \"2012/12/01\", \"2012/12/01\", 0, 0, 0], \"RNN (2012)\"], # https://www.microsoft.com/en-us/research/wp-content/uploads/2016/02/rnn_ctxt.pdf\n","\n","for m in models:\n","    m[0][2] = mdates.date2num(pd.to_datetime(m[0][2])) / 365.242199 + 1970\n","    m[0][3] = m[0][2]\n","\n","print(models)"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":2,"status":"aborted","timestamp":1709236283038,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"xpP3T2jHhUoS","outputId":"9379783c-32f9-4952-e7f9-4fe347f0c5e0"},"outputs":[{"data":{"image/png":"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jBw5Er1798bQoUOhKAqGDh3q7vJrpQtts8GDB6N9+/aYNm0abrnlFtx1113uvgRyMU4HQkREROQlfO5WKREREZGvYnAjIiIi8hIMbkRERERegsGNiIiIyEswuBERERF5CQY3IiIiIi/B4EZERETkJRjciIiIiLwEgxsRERGRl2BwIyIiIvISDG5EREREXoLBjYiIiMhLMLgREREReQkGNyKqMR999BE6deoEVVVRUFCAqKgobN261d1lERF5DQY3Iqoxjz/+OCIjIzF79my89NJLePTRRyGEQOfOndGiRQuMHj0aADBr1izExMQgOjoaK1euRHJyMgICAtC5c2f8+OOPbr4KIiL3kYQQwt1FEFHtkZGRgf/973+oX78+tm3bhp49eyIlJQVGoxHFxcVISEjA0qVLERkZiaVLlyIkJAQTJ05E8+bNcezYMURGRrr7EoiI3IY9bkRUoyIjI3HzzTdjyJAhMJlM0DQNH330EQ4dOoQ33ngDJpMJb7zxBvz9/REWFgZd1wEAQUFBDG1EVOsxuBGRW7399tt48cUX0bx5c5SWlsLf3x8xMTF44YUXcPToUXeXR0TkUXirlIiIiMhLsMeNiIiIyEswuBERERF5CQY3IiIiIi/B4EZERETkJRjciIiIiLwEgxsRERGRl2BwIyIiIvISDG5EREREXoLBjYiIiMhLMLgREREReYn/BzUDZ3p6Qb1sAAAAAElFTkSuQmCC","text/plain":["<Figure size 600x309 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["with epoch_theme():\n","  with mpl.rc_context(rc=standalone_plot_rc_params):\n","    split1 = 2018\n","    split2 = 2019\n","    doubling1 = 6 / 12\n","    doubling2 = 1.5 / 12\n","    doubling3 = 6 / 12\n","    T_algo = 7.5 / 12\n","\n","    num_years = 9\n","    year_start = 2014\n","    years = np.linspace(year_start, year_start + num_years, 500)\n","    t1 = np.where(years >= split1)[0][0] - 1\n","    t2 = np.where(years >= split2)[0][0] - 1\n","\n","    C_phys1, C_phys2, C_phys3 = [], [], []\n","    for year in years:\n","      if year < split1:\n","        C_phys1.append(2 ** ((year - year_start) / doubling1))\n","      elif year < split2:\n","        C_phys2.append(2 ** ((year - years[t1]) / doubling2))\n","      else:\n","        C_phys3.append(2 ** ((year - years[t2]) / doubling3))\n","\n","    C_phys2 = np.multiply(C_phys2, C_phys1[-1])\n","    C_phys3 = np.multiply(C_phys3, C_phys2[-1])\n","    C_phys = np.concatenate([C_phys1, C_phys2, C_phys3])\n","    C_algo = 2 ** ((years - year_start) / T_algo)\n","    C_t = C_phys * C_algo\n","\n","    fig, ax = plt.subplots(figsize=standalone_fig_size)\n","    #fig, ax = plt.subplots(figsize=egraphs.px_to_in((604, 330)))\n","    ax.fill_between(years, 1, C_phys, label=\"Physical compute contribution\", color='#00A5A6', alpha=0.4, linewidth=0)\n","    ax.fill_between(years, C_phys, C_t, label=\"Algorithmic contribution\", color='#1F6EE5', alpha=0.4, linewidth=0)\n","\n","    total_contrib_algo = C_algo[-1]#float(round(C_algo[-1], -3))\n","    total_contrib_phys = C_phys[-1]\n","\n","    fontsize = egraphs.px_to_pt(9)\n","\n","    plt.text(year_start + 7.90, np.exp(np.log(float(total_contrib_phys * total_contrib_algo)) / 1.4), f'Algorithmic \\nprogress', fontsize=fontsize, ha='center', weight='normal')\n","    plt.text(year_start + 7.72, np.exp(np.log(total_contrib_phys) / 4.5), f'“Physical” \\ncompute scaling', fontsize=fontsize, ha='center', weight='normal')\n","\n","    ax.yaxis.set_major_formatter(FuncFormatter(human_format))\n","\n","    models_to_plot = [\n","        \"Large regularized LSTM\",\n","        # \"genCNN + dyn eval\",\n","        \"LSTM (Hebbian, Cache, MbPA)\",\n","        \"GPT-2 (1542M)\",\n","        \"Megatron-LM (8.3B)\",\n","        \"Turing-NLG\",\n","        # \"Gopher (280B)\",\n","        \"Chinchilla\",\n","        \"OPT-175B\"\n","    ]\n","\n","    models_to_name = {\n","        \"GPT-2 (1542M)\":          [\"GPT-2\",      'left center_baseline', (4, 0)],\n","        \"Large regularized LSTM\": [\"LSTM\",       'left center_baseline', (4, 3)],\n","        \"Turing-NLG\":             [\"Turing-NLG\", 'left center_baseline', (4, 0)],\n","        \"Chinchilla\":             [\"Chinchilla\", 'center bottom', (-2, 6)],\n","        \"OPT-175B\":               [\"OPT-175B\",   'center top', (0, -6)],\n","    }\n","\n","    models_to_plot = [m for m in models_to_plot if m in models_to_name]\n","\n","    df_main.loc[df_main['system'] == 'Gopher (280B)', 'param'] = 280e9\n","    df_main.loc[df_main['system'] == 'Gopher (7.1B)', 'param'] = 7.1e9\n","    df_main.loc[df_main['system'] == 'Gopher (280B)', 'Training Compute'] = 6.31E+23\n","    df_main.loc[df_main['system'] == 'Gopher (7.1B)', 'Training Compute'] = 1.28E+22\n","\n","    compute_models = df_main[[\"system\", \"publication_date\", \"Training Compute\"]].dropna().sort_values(by=[\"publication_date\"])\n","    compute_const = np.min(compute_models[\"Training Compute\"])\n","    # compute_const = 6 * param_const * dataset_const\n","    models_added = set()\n","    for _, model in compute_models.iterrows():\n","        color = '#034752'\n","        text_color = 'black'\n","\n","        system = model[\"system\"]\n","\n","        if system in models_to_plot and system not in models_added:\n","            models_added.add(system)\n","\n","            xcoord = model[\"publication_date\"]\n","            ycoord = model[\"Training Compute\"] / compute_const\n","            plt.plot(xcoord, ycoord, color=color, marker='o', markersize=3, zorder=3)\n","\n","            if system in models_to_name.keys():\n","                element = models_to_name[system]\n","                model_name = element[0]\n","                ha, va = element[1].split()\n","                offset = element[2]\n","                model_xcoord = xcoord\n","                model_ycoord = ycoord\n","                plt.annotate(model_name, xy=(model_xcoord, model_ycoord), xytext=offset, textcoords='offset points',\n","                        fontsize=fontsize, ha=ha, va=va, color=text_color, weight='medium')\n","\n","    # plt.xlim(2012, 2012 + num_years)  # extend xlim to make space for curly bracket\n","    plt.yscale('log')\n","    plt.xlabel('Year')\n","    plt.ylabel(f'Effective compute (Relative to {year_start})')\n","    # plt.legend()\n","\n","    # Customize x-axis ticks\n","    current_ticks = plt.xticks()[0]\n","    plt.xlim(None, max(years))\n","    plt.ylim(1, 1e12)\n","    # plt.title('Effective Compute of Frontier Models', fontsize=18, pad=20)\n","\n","    # Leave some space for the braces on the right\n","    relayout(padding={**standalone_padding, 'right': 70})\n","\n","    #fig.subplots_adjust(left=egraphs.px_to_x_fraction(25), right=1-egraphs.px_to_x_fraction(55), bottom=egraphs.px_to_y_fraction(35), top=0.9)\n","\n","    # OK, now we add the right braces\n","\n","    # Give a bit more space for the braces\n","    #fig.subplots_adjust(right=1-egraphs.px_to_x_fraction(85))\n","\n","    # Adding braces\n","    margin_y = 1.15\n","\n","    egraphs.add_brace(ax, years[-1], C_phys[-1]*margin_y, C_t[-1]/ margin_y, transform=ax.transData, linewidth=0.8)\n","    egraphs.add_brace(ax, years[-1], 1e0*margin_y, C_phys[-1]/margin_y, transform=ax.transData, linewidth=0.8)\n","\n","    def format_scientific(num):\n","        if num == 0:\n","            return \"0\"\n","        exponent = np.floor(np.log10(np.abs(num)))\n","        coefficient = num / 10**exponent\n","        return r\"${:.1f} \\times 10^{{{}}}$\".format(coefficient, int(exponent))\n","\n","    formatted_algo = format_scientific(total_contrib_algo)\n","    formatted_phys = format_scientific(total_contrib_phys)\n","\n","    # Brace texts\n","    braces_fontsize = egraphs.px_to_pt(8)\n","    plt.annotate(format_scientific(total_contrib_algo), xy=(years[-1], np.sqrt(C_phys[-1] * C_t[-1])), xytext=(15, 0), textcoords='offset points',\n","            fontsize=braces_fontsize, ha='left', va='center', weight='medium')\n","    plt.annotate(format_scientific(total_contrib_phys), xy=(years[-1], np.sqrt(1 * C_phys[-1])), xytext=(15, 0), textcoords='offset points',\n","            fontsize=braces_fontsize, ha='left', va='center', weight='medium')\n","\n","    filename = f\"{date}_relative_contribution.pdf\"\n","    plt.savefig(filename)\n","    plt.savefig('foobar.svg')\n","    plt.savefig('foobar.png')\n","    files.download(filename)\n","\n","    plt.show()"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":2,"status":"aborted","timestamp":1709236283038,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"nycyOhkshlaE","outputId":"b8f4d335-ef06-4625-b536-74600a39bb04"},"outputs":[{"data":{"text/html":["<html>\n","<head><meta charset=\"utf-8\" /></head>\n","<body>\n","    <div>            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-AMS-MML_SVG\"></script><script type=\"text/javascript\">if (window.MathJax && window.MathJax.Hub && window.MathJax.Hub.Config) {window.MathJax.Hub.Config({SVG: {font: \"STIX-Web\"}});}</script>                <script type=\"text/javascript\">window.PlotlyConfig = {MathJaxConfig: 'local'};</script>\n","        <script charset=\"utf-8\" src=\"https://cdn.plot.ly/plotly-2.27.0.min.js\"></script>                <div id=\"30dede6b-e7c3-4b4c-b854-186fff0c617e\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"30dede6b-e7c3-4b4c-b854-186fff0c617e\")) {                    Plotly.newPlot(                        \"30dede6b-e7c3-4b4c-b854-186fff0c617e\",                        [{\"hovertemplate\":\"\\u003cb\\u003e%{hovertext}\\u003c\\u002fb\\u003e\\u003cbr\\u003e\\u003cbr\\u003epublication_date=%{x}\\u003cbr\\u003eTraining Compute=%{y}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"hovertext\":[\"Large regularized LSTM\",\"genCNN + dyn eval\",\"QRNN\",\"4 layer QRNN (h=2500)\",\"LSTM (Hebbian, Cache, MbPA)\",\"Transformer (Adaptive Input Embeddings)\",\"Transformer-XL Large\",\"Transformer-XL-ptb\",\"GPT-2 (1542M)\",\"GPT-2 (1542M)\",\"GPT-2 (1542M)\",\"4 layer QRNN + dynamic evaluation\",\"AdvSoft + 4 layer QRNN + dynamic evaluation\",\"All-attention network + adaptive span\",\"Megatron-LM (355M)\",\"Megatron-LM (2.5B)\",\"Megatron-LM (8.3B)\",\"Adaptive LSTM + DeFINE\",\"Transformer-XL DeFINE (107M)\",\"Transformer-XL DeFINE (141M)\",\"Turing-NLG\",\"TransformerXL + spectrum control\",\"GPT3-6.7B (rerun of original)\",\"DeLight\",\"Transformer+Recurrent Windows of Context\",\"SRU++ Large\",\"SRU++ Large only 2 attention layers (k=5)\",\"SRU++ Base\",\"DEQ-Transformer (Post-LN) + Jacobian Regularisation\",\"Adaptive Input Transformer + RD\",\"GPT-2 (1.5B, Curriculum Learning 45K)\",\"ALiBi (L=3072, Lvalid = 3072)\",\"$\\\\infty$-former (SM)\",\"PermuteFormer\",\"base LM+GNN+kNN\",\"Gopher (280B)\",\"Gopher (7.1B)\",\"HSO\",\"MemSizer\",\"Chinchilla\",\"B2T connection (16L)\",\"DITTO\",\"OPT-175B\",\"NMST+GPT-2\",\"Decaying Fast Weights Transformer\",\"Transformer + GFM\"],\"legendgroup\":\"\",\"marker\":{\"color\":\"#636efa\",\"symbol\":\"circle\"},\"mode\":\"markers\",\"name\":\"\",\"orientation\":\"v\",\"showlegend\":false,\"x\":[2014.6849315068494,2015.2054794520548,2018.0849315068492,2018.2191780821918,2018.2328767123288,2018.7397260273972,2019.021917808219,2019.021917808219,2019.1205479452055,2019.1205479452055,2019.1205479452055,2019.4383561643835,2019.4383561643835,2019.4986301369863,2019.7095890410958,2019.7095890410958,2019.7095890410958,2019.9041095890411,2019.9041095890411,2019.9041095890411,2020.1178082191782,2020.1917808219177,2020.4054794520548,2020.5890410958905,2020.6246575342466,2021.1479452054793,2021.1479452054793,2021.1479452054793,2021.4876712328767,2021.4876712328767,2021.613698630137,2021.6520547945206,2021.6657534246576,2021.6794520547944,2021.7917808219179,2021.9342465753425,2021.9342465753425,2021.9561643835616,2022.2219178082191,2022.2383561643835,2022.4136986301369,2022.427397260274,2022.468493150685,2022.7534246575342,2022.7698630136986,2022.9150684931508],\"xaxis\":\"x\",\"y\":[9.1e+16,7.3e+16,3.6e+17,2.4e+17,2.4e+19,7.3e+18,1.09e+19,1.09e+19,1.5e+21,1.5e+21,1.5e+21,3.6e+17,3.6e+17,4.6e+19,4.35e+20,4e+21,9.1e+21,6.2e+18,5.2e+18,6.2e+18,1.57e+22,4.6e+17,1.2e+22,2.4e+19,1.17e+20,1.1e+19,8e+18,5.8e+18,2.9e+19,8.2e+19,6e+20,1.8e+20,1.2e+20,3.1e+18,7.3e+18,6.31e+23,1.28e+22,3.45e+20,7.3e+18,5.76e+23,2.8e+19,1.1e+19,4.16e+23,1.2e+20,1.3e+19,8.04e+18],\"yaxis\":\"y\",\"type\":\"scatter\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"publication_date\"}},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Training Compute\"},\"type\":\"log\"},\"legend\":{\"tracegroupgap\":0},\"margin\":{\"t\":60}},                        {\"responsive\": true}                    ).then(function(){\n","                            \n","var gd = document.getElementById('30dede6b-e7c3-4b4c-b854-186fff0c617e');\n","var x = new MutationObserver(function (mutations, observer) {{\n","        var display = window.getComputedStyle(gd).display;\n","        if (!display || display === 'none') {{\n","            console.log([gd, 'removed!']);\n","            Plotly.purge(gd);\n","            observer.disconnect();\n","        }}\n","}});\n","\n","// Listen for the removal of the full notebook cells\n","var notebookContainer = gd.closest('#notebook-container');\n","if (notebookContainer) {{\n","    x.observe(notebookContainer, {childList: true});\n","}}\n","\n","// Listen for the clearing of the current output cell\n","var outputEl = gd.closest('.output');\n","if (outputEl) {{\n","    x.observe(outputEl, {childList: true});\n","}}\n","\n","                        })                };                            </script>        </div>\n","</body>\n","</html>"]},"metadata":{},"output_type":"display_data"}],"source":["import plotly.express as px\n","px.scatter(compute_models, x=\"publication_date\", y=\"Training Compute\", log_y=True, hover_name=\"system\")"]},{"cell_type":"markdown","metadata":{"id":"kYoXet5VWYA0"},"source":["## Check for instances of >10,000x compute gain via algorithmic progress"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"QREGTMHtn3w-"},"outputs":[],"source":["pd.options.display.max_rows = None"]},{"cell_type":"markdown","metadata":{"id":"HX_HSXTQqRUh"},"source":["Our main dataset"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":3,"status":"aborted","timestamp":1709236283039,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"syTkzHlBWaB8","outputId":"657559af-20b3-4fda-a2d8-a3b4eee134fa"},"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>reference system</th>\n","      <th>new system</th>\n","      <th>compute decrease</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>0</th>\n","      <td>NMST+GPT-2</td>\n","      <td>Transformer + GFM</td>\n","      <td>14.925373</td>\n","    </tr>\n","    <tr>\n","      <th>1</th>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>SRU++ Base</td>\n","      <td>1.258621</td>\n","    </tr>\n","    <tr>\n","      <th>2</th>\n","      <td>Transformer+Recurrent Windows of Context</td>\n","      <td>SRU++ Base</td>\n","      <td>20.172414</td>\n","    </tr>\n","    <tr>\n","      <th>3</th>\n","      <td>All-attention network + adaptive span</td>\n","      <td>SRU++ Base</td>\n","      <td>7.931034</td>\n","    </tr>\n","    <tr>\n","      <th>4</th>\n","      <td>Transformer-XL DeFINE (141M)</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>13.478261</td>\n","    </tr>\n","    <tr>\n","      <th>5</th>\n","      <td>Transformer-XL DeFINE (107M)</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>11.304348</td>\n","    </tr>\n","    <tr>\n","      <th>6</th>\n","      <td>Adaptive LSTM + DeFINE</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>13.478261</td>\n","    </tr>\n","    <tr>\n","      <th>7</th>\n","      <td>DeLight</td>\n","      <td>SRU++ Base</td>\n","      <td>4.137931</td>\n","    </tr>\n","    <tr>\n","      <th>8</th>\n","      <td>LSTM (Hebbian, Cache, MbPA)</td>\n","      <td>AdvSoft + 4 layer QRNN + dynamic evaluation</td>\n","      <td>66.666667</td>\n","    </tr>\n","    <tr>\n","      <th>9</th>\n","      <td>Decaying Fast Weights Transformer</td>\n","      <td>Transformer + GFM</td>\n","      <td>1.616915</td>\n","    </tr>\n","    <tr>\n","      <th>10</th>\n","      <td>GPT-2 (1542M)</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>205.479452</td>\n","    </tr>\n","    <tr>\n","      <th>11</th>\n","      <td>GPT-2 (1542M)</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>205.479452</td>\n","    </tr>\n","    <tr>\n","      <th>12</th>\n","      <td>GPT-2 (1542M)</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>205.479452</td>\n","    </tr>\n","    <tr>\n","      <th>13</th>\n","      <td>DITTO</td>\n","      <td>Transformer + GFM</td>\n","      <td>1.368159</td>\n","    </tr>\n","    <tr>\n","      <th>14</th>\n","      <td>Megatron-LM (355M)</td>\n","      <td>SRU++ Base</td>\n","      <td>75.000000</td>\n","    </tr>\n","    <tr>\n","      <th>15</th>\n","      <td>Adaptive Input Transformer + RD</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>11.232877</td>\n","    </tr>\n","    <tr>\n","      <th>16</th>\n","      <td>HSO</td>\n","      <td>Transformer + GFM</td>\n","      <td>42.910448</td>\n","    </tr>\n","    <tr>\n","      <th>17</th>\n","      <td>Gopher (7.1B)</td>\n","      <td>OPT-175B</td>\n","      <td>1.516827</td>\n","    </tr>\n","    <tr>\n","      <th>18</th>\n","      <td>DEQ-Transformer (Post-LN) + Jacobian Regularis...</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>3.972603</td>\n","    </tr>\n","    <tr>\n","      <th>19</th>\n","      <td>ALiBi (L=3072, Lvalid = 3072)</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>24.657534</td>\n","    </tr>\n","    <tr>\n","      <th>20</th>\n","      <td>Transformer-XL Large</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>1.493151</td>\n","    </tr>\n","    <tr>\n","      <th>21</th>\n","      <td>Transformer-XL-ptb</td>\n","      <td>AdvSoft + 4 layer QRNN + dynamic evaluation</td>\n","      <td>30.277778</td>\n","    </tr>\n","    <tr>\n","      <th>22</th>\n","      <td>Turing-NLG</td>\n","      <td>GPT3-6.7B (rerun of original)</td>\n","      <td>1.308333</td>\n","    </tr>\n","    <tr>\n","      <th>23</th>\n","      <td>SRU++ Large</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>1.506849</td>\n","    </tr>\n","    <tr>\n","      <th>24</th>\n","      <td>SRU++ Large only 2 attention layers (k=5)</td>\n","      <td>base LM+GNN+kNN</td>\n","      <td>1.095890</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>"],"text/plain":["                                     reference system  \\\n","0                                          NMST+GPT-2   \n","1             Transformer (Adaptive Input Embeddings)   \n","2            Transformer+Recurrent Windows of Context   \n","3               All-attention network + adaptive span   \n","4                        Transformer-XL DeFINE (141M)   \n","5                        Transformer-XL DeFINE (107M)   \n","6                              Adaptive LSTM + DeFINE   \n","7                                             DeLight   \n","8                         LSTM (Hebbian, Cache, MbPA)   \n","9                   Decaying Fast Weights Transformer   \n","10                                      GPT-2 (1542M)   \n","11                                      GPT-2 (1542M)   \n","12                                      GPT-2 (1542M)   \n","13                                              DITTO   \n","14                                 Megatron-LM (355M)   \n","15                    Adaptive Input Transformer + RD   \n","16                                                HSO   \n","17                                      Gopher (7.1B)   \n","18  DEQ-Transformer (Post-LN) + Jacobian Regularis...   \n","19                      ALiBi (L=3072, Lvalid = 3072)   \n","20                               Transformer-XL Large   \n","21                                 Transformer-XL-ptb   \n","22                                         Turing-NLG   \n","23                                        SRU++ Large   \n","24          SRU++ Large only 2 attention layers (k=5)   \n","\n","                                     new system  compute decrease  \n","0                             Transformer + GFM         14.925373  \n","1                                    SRU++ Base          1.258621  \n","2                                    SRU++ Base         20.172414  \n","3                                    SRU++ Base          7.931034  \n","4              TransformerXL + spectrum control         13.478261  \n","5              TransformerXL + spectrum control         11.304348  \n","6              TransformerXL + spectrum control         13.478261  \n","7                                    SRU++ Base          4.137931  \n","8   AdvSoft + 4 layer QRNN + dynamic evaluation         66.666667  \n","9                             Transformer + GFM          1.616915  \n","10                              base LM+GNN+kNN        205.479452  \n","11                              base LM+GNN+kNN        205.479452  \n","12                              base LM+GNN+kNN        205.479452  \n","13                            Transformer + GFM          1.368159  \n","14                                   SRU++ Base         75.000000  \n","15                              base LM+GNN+kNN         11.232877  \n","16                            Transformer + GFM         42.910448  \n","17                                     OPT-175B          1.516827  \n","18                              base LM+GNN+kNN          3.972603  \n","19                              base LM+GNN+kNN         24.657534  \n","20                              base LM+GNN+kNN          1.493151  \n","21  AdvSoft + 4 layer QRNN + dynamic evaluation         30.277778  \n","22                GPT3-6.7B (rerun of original)          1.308333  \n","23                              base LM+GNN+kNN          1.506849  \n","24                              base LM+GNN+kNN          1.095890  "]},"execution_count":77,"metadata":{},"output_type":"execute_result"}],"source":["df_main = df_head.copy(deep=True)\n","df_main.dropna(subset=[\"Training Compute\"], inplace=True)\n","df_new = df_main[[\"system\", \"publication_date\", \"Training Compute\", \"ppl\"]]\n","delta = 1\n","\n","all_data = []\n","\n","for idx, row in df_new.iterrows():\n","  data_subset = df_new[df_new[\"ppl\"] < row[\"ppl\"] * delta]\n","  data_subset = data_subset[data_subset[\"publication_date\"] > row[\"publication_date\"]]\n","  data_subset = data_subset[data_subset[\"Training Compute\"] < row[\"Training Compute\"]]\n","  if len(data_subset) > 0:\n","    min_compute = min(data_subset[\"Training Compute\"])\n","    row_min = data_subset.loc[data_subset[\"Training Compute\"] == min_compute]\n","    compute_diff = row[\"Training Compute\"] / min_compute\n","    data = [row[\"system\"], row_min.iloc[0][\"system\"], compute_diff]\n","    all_data.append(data)\n","\n","pd.DataFrame(all_data, columns=[\"reference system\", \"new system\", \"compute decrease\"])"]},{"cell_type":"markdown","metadata":{"id":"eyk0VVXSqTd8"},"source":["Dataset used for the graphs showing compute decrease for three specific systems"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":3,"status":"aborted","timestamp":1709236283039,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"ugMFYtpQjtrS","outputId":"b0d692ca-77e3-4669-f288-e81fbcf887e2"},"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>reference system</th>\n","      <th>new system</th>\n","      <th>compute decrease</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>0</th>\n","      <td>OPT-175B</td>\n","      <td>Llama 2 7B</td>\n","      <td>6.785714</td>\n","    </tr>\n","    <tr>\n","      <th>1</th>\n","      <td>OPT-66B + RE-PLUG</td>\n","      <td>GPT3-6.7B (rerun of original)</td>\n","      <td>9.166667</td>\n","    </tr>\n","    <tr>\n","      <th>2</th>\n","      <td>Chinchilla</td>\n","      <td>Llama 2 7B</td>\n","      <td>6.904762</td>\n","    </tr>\n","    <tr>\n","      <th>3</th>\n","      <td>LLaMA-33B</td>\n","      <td>Llama 2 7B</td>\n","      <td>1.904762</td>\n","    </tr>\n","    <tr>\n","      <th>4</th>\n","      <td>GPT-2 (1542M)</td>\n","      <td>SRU++ Large only 2 attention layers (k=5)</td>\n","      <td>537.500000</td>\n","    </tr>\n","    <tr>\n","      <th>5</th>\n","      <td>TransformerXL+RelationLM</td>\n","      <td>SRU++ Base</td>\n","      <td>551.724138</td>\n","    </tr>\n","    <tr>\n","      <th>6</th>\n","      <td>Transformer + GFM</td>\n","      <td>SRU++ Base</td>\n","      <td>12.586207</td>\n","    </tr>\n","    <tr>\n","      <th>7</th>\n","      <td>Decaying Fast Weights Transformer</td>\n","      <td>SRU++ Base</td>\n","      <td>13.620690</td>\n","    </tr>\n","    <tr>\n","      <th>8</th>\n","      <td>NMST+GPT-2</td>\n","      <td>SRU++ Base</td>\n","      <td>20.689655</td>\n","    </tr>\n","    <tr>\n","      <th>9</th>\n","      <td>Progressive LRD</td>\n","      <td>SRU++ Base</td>\n","      <td>10.689655</td>\n","    </tr>\n","    <tr>\n","      <th>10</th>\n","      <td>DITTO</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>1.506849</td>\n","    </tr>\n","    <tr>\n","      <th>11</th>\n","      <td>T2R + Random Init</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>8.356164</td>\n","    </tr>\n","    <tr>\n","      <th>12</th>\n","      <td>T2R + Pretrain</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>2.780822</td>\n","    </tr>\n","    <tr>\n","      <th>13</th>\n","      <td>Compressive Transformers for Long-Range Sequen...</td>\n","      <td>$\\infty$-former (SM)</td>\n","      <td>1.516667</td>\n","    </tr>\n","    <tr>\n","      <th>14</th>\n","      <td>Gopher (7.1B)</td>\n","      <td>GPT3-6.7B (rerun of original)</td>\n","      <td>1.066667</td>\n","    </tr>\n","    <tr>\n","      <th>15</th>\n","      <td>Gopher (280B)</td>\n","      <td>Llama 2 7B</td>\n","      <td>6.904762</td>\n","    </tr>\n","    <tr>\n","      <th>16</th>\n","      <td>Transformer-XL Large</td>\n","      <td>base LM+GNN</td>\n","      <td>1.493151</td>\n","    </tr>\n","    <tr>\n","      <th>17</th>\n","      <td>Megatron-LM (355M)</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>59.589041</td>\n","    </tr>\n","    <tr>\n","      <th>18</th>\n","      <td>Turing-NLG</td>\n","      <td>GPT3-6.7B (rerun of original)</td>\n","      <td>1.308333</td>\n","    </tr>\n","    <tr>\n","      <th>19</th>\n","      <td>HSO</td>\n","      <td>SRU++ Base</td>\n","      <td>170.689655</td>\n","    </tr>\n","    <tr>\n","      <th>20</th>\n","      <td>KnGPT2</td>\n","      <td>SRU++ Base</td>\n","      <td>21.379310</td>\n","    </tr>\n","    <tr>\n","      <th>21</th>\n","      <td>Transformer-XL + SIS</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>1.424658</td>\n","    </tr>\n","    <tr>\n","      <th>22</th>\n","      <td>RETRO-7B</td>\n","      <td>SRU++ Base</td>\n","      <td>1293.103448</td>\n","    </tr>\n","    <tr>\n","      <th>23</th>\n","      <td>DEQ-Transformer (Post-LN) + Jacobian Regularis...</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>3.972603</td>\n","    </tr>\n","    <tr>\n","      <th>24</th>\n","      <td>GPT-2 (117M, SLW 110K)</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>17.808219</td>\n","    </tr>\n","    <tr>\n","      <th>25</th>\n","      <td>ALiBi (L=3072, Lvalid = 3072)</td>\n","      <td>$\\infty$-former (SM)</td>\n","      <td>1.500000</td>\n","    </tr>\n","    <tr>\n","      <th>26</th>\n","      <td>GPT2-Large+LHOPT</td>\n","      <td>PermuteFormer</td>\n","      <td>516.129032</td>\n","    </tr>\n","    <tr>\n","      <th>27</th>\n","      <td>Memformer (4 encoder + 16 decoder)</td>\n","      <td>SRU++ Base</td>\n","      <td>2.068966</td>\n","    </tr>\n","    <tr>\n","      <th>28</th>\n","      <td>DeLight</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>3.287671</td>\n","    </tr>\n","    <tr>\n","      <th>29</th>\n","      <td>Transformer+Recurrent Windows of Context</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>16.027397</td>\n","    </tr>\n","    <tr>\n","      <th>30</th>\n","      <td>B2T connection (16L)</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>3.698630</td>\n","    </tr>\n","    <tr>\n","      <th>31</th>\n","      <td>All-attention network + adaptive span</td>\n","      <td>Transformer (Adaptive Input Embeddings)</td>\n","      <td>6.301370</td>\n","    </tr>\n","    <tr>\n","      <th>32</th>\n","      <td>GPT-2 (762M)</td>\n","      <td>SRU++ Base</td>\n","      <td>131.379310</td>\n","    </tr>\n","    <tr>\n","      <th>33</th>\n","      <td>Transformer-XL DeFINE (141M)</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>13.478261</td>\n","    </tr>\n","    <tr>\n","      <th>34</th>\n","      <td>Transformer-XL DeFINE (107M)</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>11.304348</td>\n","    </tr>\n","    <tr>\n","      <th>35</th>\n","      <td>GPT-2 (345M)</td>\n","      <td>TransformerXL + spectrum control</td>\n","      <td>750.000000</td>\n","    </tr>\n","    <tr>\n","      <th>36</th>\n","      <td>Adaptive LSTM + DeFINE</td>\n","      <td>4 layer QRNN (h=2500)</td>\n","      <td>25.833333</td>\n","    </tr>\n","    <tr>\n","      <th>37</th>\n","      <td>GPT-2 (117M)</td>\n","      <td>4 layer QRNN (h=2500)</td>\n","      <td>487.500000</td>\n","    </tr>\n","    <tr>\n","      <th>38</th>\n","      <td>LSTM (Hebbian, Cache, MbPA)</td>\n","      <td>AdvSoft + 4 layer QRNN + dynamic evaluation</td>\n","      <td>66.666667</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>"],"text/plain":["                                     reference system  \\\n","0                                            OPT-175B   \n","1                                   OPT-66B + RE-PLUG   \n","2                                          Chinchilla   \n","3                                           LLaMA-33B   \n","4                                       GPT-2 (1542M)   \n","5                            TransformerXL+RelationLM   \n","6                                   Transformer + GFM   \n","7                   Decaying Fast Weights Transformer   \n","8                                          NMST+GPT-2   \n","9                                     Progressive LRD   \n","10                                              DITTO   \n","11                                  T2R + Random Init   \n","12                                     T2R + Pretrain   \n","13  Compressive Transformers for Long-Range Sequen...   \n","14                                      Gopher (7.1B)   \n","15                                      Gopher (280B)   \n","16                               Transformer-XL Large   \n","17                                 Megatron-LM (355M)   \n","18                                         Turing-NLG   \n","19                                                HSO   \n","20                                             KnGPT2   \n","21                               Transformer-XL + SIS   \n","22                                           RETRO-7B   \n","23  DEQ-Transformer (Post-LN) + Jacobian Regularis...   \n","24                             GPT-2 (117M, SLW 110K)   \n","25                      ALiBi (L=3072, Lvalid = 3072)   \n","26                                   GPT2-Large+LHOPT   \n","27                 Memformer (4 encoder + 16 decoder)   \n","28                                            DeLight   \n","29           Transformer+Recurrent Windows of Context   \n","30                               B2T connection (16L)   \n","31              All-attention network + adaptive span   \n","32                                       GPT-2 (762M)   \n","33                       Transformer-XL DeFINE (141M)   \n","34                       Transformer-XL DeFINE (107M)   \n","35                                       GPT-2 (345M)   \n","36                             Adaptive LSTM + DeFINE   \n","37                                       GPT-2 (117M)   \n","38                        LSTM (Hebbian, Cache, MbPA)   \n","\n","                                     new system  compute decrease  \n","0                                    Llama 2 7B          6.785714  \n","1                 GPT3-6.7B (rerun of original)          9.166667  \n","2                                    Llama 2 7B          6.904762  \n","3                                    Llama 2 7B          1.904762  \n","4     SRU++ Large only 2 attention layers (k=5)        537.500000  \n","5                                    SRU++ Base        551.724138  \n","6                                    SRU++ Base         12.586207  \n","7                                    SRU++ Base         13.620690  \n","8                                    SRU++ Base         20.689655  \n","9                                    SRU++ Base         10.689655  \n","10      Transformer (Adaptive Input Embeddings)          1.506849  \n","11      Transformer (Adaptive Input Embeddings)          8.356164  \n","12      Transformer (Adaptive Input Embeddings)          2.780822  \n","13                         $\\infty$-former (SM)          1.516667  \n","14                GPT3-6.7B (rerun of original)          1.066667  \n","15                                   Llama 2 7B          6.904762  \n","16                                  base LM+GNN          1.493151  \n","17      Transformer (Adaptive Input Embeddings)         59.589041  \n","18                GPT3-6.7B (rerun of original)          1.308333  \n","19                                   SRU++ Base        170.689655  \n","20                                   SRU++ Base         21.379310  \n","21      Transformer (Adaptive Input Embeddings)          1.424658  \n","22                                   SRU++ Base       1293.103448  \n","23      Transformer (Adaptive Input Embeddings)          3.972603  \n","24      Transformer (Adaptive Input Embeddings)         17.808219  \n","25                         $\\infty$-former (SM)          1.500000  \n","26                                PermuteFormer        516.129032  \n","27                                   SRU++ Base          2.068966  \n","28      Transformer (Adaptive Input Embeddings)          3.287671  \n","29      Transformer (Adaptive Input Embeddings)         16.027397  \n","30      Transformer (Adaptive Input Embeddings)          3.698630  \n","31      Transformer (Adaptive Input Embeddings)          6.301370  \n","32                                   SRU++ Base        131.379310  \n","33             TransformerXL + spectrum control         13.478261  \n","34             TransformerXL + spectrum control         11.304348  \n","35             TransformerXL + spectrum control        750.000000  \n","36                        4 layer QRNN (h=2500)         25.833333  \n","37                        4 layer QRNN (h=2500)        487.500000  \n","38  AdvSoft + 4 layer QRNN + dynamic evaluation         66.666667  "]},"execution_count":78,"metadata":{},"output_type":"execute_result"}],"source":["import io\n","import os\n","uploaded = files.upload()\n","df_main = pd.read_csv(io.BytesIO(uploaded['202401 benchmark dataset.csv']))\n","os.remove('202401 benchmark dataset.csv')\n","\n","# rename columns\n","column_renames = {\n","    'Publication date': 'publication_date',\n","    'Perplexity (WT103)': 'ppl',\n","    'System': 'system',\n","}\n","df_main = df_main.rename(columns=column_renames)\n","\n","df_main.dropna(subset=[\"Training Compute\"], inplace=True)\n","df_new = df_main[[\"system\", \"publication_date\", \"Training Compute\", \"ppl\"]]\n","delta = 1\n","\n","all_data = []\n","\n","for idx, row in df_new.iterrows():\n","  data_subset = df_new[df_new[\"ppl\"] < row[\"ppl\"] * delta]\n","  data_subset = data_subset[data_subset[\"publication_date\"] > row[\"publication_date\"]]\n","  data_subset = data_subset[data_subset[\"Training Compute\"] < row[\"Training Compute\"]]\n","  if len(data_subset) > 0:\n","    min_compute = min(data_subset[\"Training Compute\"])\n","    row_min = data_subset.loc[data_subset[\"Training Compute\"] == min_compute]\n","    compute_diff = row[\"Training Compute\"] / min_compute\n","    data = [row[\"system\"], row_min.iloc[0][\"system\"], compute_diff]\n","    all_data.append(data)\n","\n","pd.DataFrame(all_data, columns=[\"reference system\", \"new system\", \"compute decrease\"])"]},{"cell_type":"markdown","metadata":{"id":"pRQJP13YqY0_"},"source":["Computer vision dataset"]},{"cell_type":"code","execution_count":null,"metadata":{"executionInfo":{"elapsed":3,"status":"aborted","timestamp":1709236283039,"user":{"displayName":"Edu Roldán","userId":"11003853866473241019"},"user_tz":360},"id":"0FLANVj4lTVl","outputId":"d2467f47-6945-4e96-e0a1-d54ee9bca2f1"},"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>reference system</th>\n","      <th>new system</th>\n","      <th>compute decrease</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>0</th>\n","      <td>MSRA (C, PReLU)</td>\n","      <td>SE-ResNet-50</td>\n","      <td>13.288591</td>\n","    </tr>\n","    <tr>\n","      <th>1</th>\n","      <td>ResNet-50</td>\n","      <td>SE-ResNet-50</td>\n","      <td>2.711409</td>\n","    </tr>\n","    <tr>\n","      <th>2</th>\n","      <td>ResNet-152</td>\n","      <td>Xception</td>\n","      <td>9.250000</td>\n","    </tr>\n","    <tr>\n","      <th>3</th>\n","      <td>ResNet-101</td>\n","      <td>SE-ResNet-50</td>\n","      <td>5.416107</td>\n","    </tr>\n","    <tr>\n","      <th>4</th>\n","      <td>ResNeXt-101 64x4</td>\n","      <td>SE-ResNet-50</td>\n","      <td>10.067114</td>\n","    </tr>\n","    <tr>\n","      <th>5</th>\n","      <td>Very Deep PolyNet</td>\n","      <td>SE-ResNet-50</td>\n","      <td>8.926174</td>\n","    </tr>\n","    <tr>\n","      <th>6</th>\n","      <td>SE-ResNet-152</td>\n","      <td>AlphaX-1</td>\n","      <td>1.797521</td>\n","    </tr>\n","    <tr>\n","      <th>7</th>\n","      <td>Oct-ResNet-152 (alpha=0.5)</td>\n","      <td>PyConvResNet-101</td>\n","      <td>2.316206</td>\n","    </tr>\n","    <tr>\n","      <th>8</th>\n","      <td>NoisyStudent (EfficientNet-L2)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>16576.576577</td>\n","    </tr>\n","    <tr>\n","      <th>9</th>\n","      <td>BiT-L</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>712.612613</td>\n","    </tr>\n","    <tr>\n","      <th>10</th>\n","      <td>Harm-SE-RNX-101 64x4d (320x320, Mean-Max Pooling)</td>\n","      <td>PyConvResNet-101</td>\n","      <td>4.782609</td>\n","    </tr>\n","    <tr>\n","      <th>11</th>\n","      <td>Harm-SE-RNX-101 64x4d (320x320, Mean-Max Pooling)</td>\n","      <td>PyConvResNet-101</td>\n","      <td>2.727273</td>\n","    </tr>\n","    <tr>\n","      <th>12</th>\n","      <td>TResNet-XL</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>592.792793</td>\n","    </tr>\n","    <tr>\n","      <th>13</th>\n","      <td>REGNETX-32GF</td>\n","      <td>iAFF-ResNeXt-50-32x4d</td>\n","      <td>4.356061</td>\n","    </tr>\n","    <tr>\n","      <th>14</th>\n","      <td>ResNeSt-101</td>\n","      <td>PyConvResNet-101</td>\n","      <td>55.731225</td>\n","    </tr>\n","    <tr>\n","      <th>15</th>\n","      <td>ViT-H/14</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>990.990991</td>\n","    </tr>\n","    <tr>\n","      <th>16</th>\n","      <td>SE-ResNeXt-101, 64x4d, S=2(416px)</td>\n","      <td>HVT-S-1</td>\n","      <td>10.217391</td>\n","    </tr>\n","    <tr>\n","      <th>17</th>\n","      <td>DeiT-B</td>\n","      <td>HVT-S-1</td>\n","      <td>5.217391</td>\n","    </tr>\n","    <tr>\n","      <th>18</th>\n","      <td>BoTNet T7</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>899.099099</td>\n","    </tr>\n","    <tr>\n","      <th>19</th>\n","      <td>T2T-ViTt-24</td>\n","      <td>HVT-S-1</td>\n","      <td>12.934783</td>\n","    </tr>\n","    <tr>\n","      <th>20</th>\n","      <td>LambdaResNet (depth 320)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>186.486486</td>\n","    </tr>\n","    <tr>\n","      <th>21</th>\n","      <td>LambdaResNet (depth 152)</td>\n","      <td>HVT-S-1</td>\n","      <td>12.644928</td>\n","    </tr>\n","    <tr>\n","      <th>22</th>\n","      <td>ConViT-B+</td>\n","      <td>CeiT-S</td>\n","      <td>6.679537</td>\n","    </tr>\n","    <tr>\n","      <th>23</th>\n","      <td>CeiT-S (384 finetune res)</td>\n","      <td>Visformer-S</td>\n","      <td>2.641844</td>\n","    </tr>\n","    <tr>\n","      <th>24</th>\n","      <td>DeepVit-L*_ 384 (Ours)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>26.576577</td>\n","    </tr>\n","    <tr>\n","      <th>25</th>\n","      <td>DeepVit-L* (Ours)</td>\n","      <td>Visformer-S</td>\n","      <td>5.230496</td>\n","    </tr>\n","    <tr>\n","      <th>26</th>\n","      <td>HaloNet</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>38.558559</td>\n","    </tr>\n","    <tr>\n","      <th>27</th>\n","      <td>SwinV2-G</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>99.099099</td>\n","    </tr>\n","    <tr>\n","      <th>28</th>\n","      <td>Swin-L</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>354.054054</td>\n","    </tr>\n","    <tr>\n","      <th>29</th>\n","      <td>Swin-B</td>\n","      <td>Visformer-S</td>\n","      <td>10.248227</td>\n","    </tr>\n","    <tr>\n","      <th>30</th>\n","      <td>CrossViT-18+</td>\n","      <td>Visformer-S</td>\n","      <td>1.932624</td>\n","    </tr>\n","    <tr>\n","      <th>31</th>\n","      <td>ViL-Base-RPB (Imagenet-21k)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>150.450450</td>\n","    </tr>\n","    <tr>\n","      <th>32</th>\n","      <td>ViL-Base-RPB (Imagenet-1k)</td>\n","      <td>Visformer-S</td>\n","      <td>1.368794</td>\n","    </tr>\n","    <tr>\n","      <th>33</th>\n","      <td>CvT-W24 (384 res, ImageNet-22k pretrain)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>2225.225225</td>\n","    </tr>\n","    <tr>\n","      <th>34</th>\n","      <td>CvT-21 (384 res)</td>\n","      <td>Visformer-S</td>\n","      <td>5.088652</td>\n","    </tr>\n","    <tr>\n","      <th>35</th>\n","      <td>PiT-B + distill</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>12.972973</td>\n","    </tr>\n","    <tr>\n","      <th>36</th>\n","      <td>EfficientNet-XL (21k)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>119.819820</td>\n","    </tr>\n","    <tr>\n","      <th>37</th>\n","      <td>LeViT-384</td>\n","      <td>Visformer-S</td>\n","      <td>3.528369</td>\n","    </tr>\n","    <tr>\n","      <th>38</th>\n","      <td>LV-ViT-M_384</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>43.783784</td>\n","    </tr>\n","    <tr>\n","      <th>39</th>\n","      <td>LV-ViT-M</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>16.576577</td>\n","    </tr>\n","    <tr>\n","      <th>40</th>\n","      <td>LV-ViT-L_512</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>222.522523</td>\n","    </tr>\n","    <tr>\n","      <th>41</th>\n","      <td>LV-ViT-L_448</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>163.063063</td>\n","    </tr>\n","    <tr>\n","      <th>42</th>\n","      <td>Twins-SVT-L</td>\n","      <td>Container</td>\n","      <td>2.797428</td>\n","    </tr>\n","    <tr>\n","      <th>43</th>\n","      <td>ResMLP-B24/8</td>\n","      <td>ConvNeXt-L</td>\n","      <td>11.747851</td>\n","    </tr>\n","    <tr>\n","      <th>44</th>\n","      <td>gMLP-B</td>\n","      <td>ResNet-152x2-SAM</td>\n","      <td>2.778626</td>\n","    </tr>\n","    <tr>\n","      <th>45</th>\n","      <td>Transformer local-attention (NesT-B)</td>\n","      <td>Container</td>\n","      <td>3.311897</td>\n","    </tr>\n","    <tr>\n","      <th>46</th>\n","      <td>ResT-Large</td>\n","      <td>Container</td>\n","      <td>1.464630</td>\n","    </tr>\n","    <tr>\n","      <th>47</th>\n","      <td>Refined-ViT-L_448</td>\n","      <td>ConvNeXt-L</td>\n","      <td>3.237822</td>\n","    </tr>\n","    <tr>\n","      <th>48</th>\n","      <td>Refined-ViT-L_384</td>\n","      <td>ConvNeXt-L</td>\n","      <td>2.280802</td>\n","    </tr>\n","    <tr>\n","      <th>49</th>\n","      <td>ViT-G/14</td>\n","      <td>Refined-ViT-M</td>\n","      <td>596.794872</td>\n","    </tr>\n","    <tr>\n","      <th>50</th>\n","      <td>CoAtNet-7</td>\n","      <td>Refined-ViT-M</td>\n","      <td>564.743590</td>\n","    </tr>\n","    <tr>\n","      <th>51</th>\n","      <td>CoAtNet-4</td>\n","      <td>Refined-ViT-M</td>\n","      <td>82.051282</td>\n","    </tr>\n","    <tr>\n","      <th>52</th>\n","      <td>CoAtNet-3 (384)</td>\n","      <td>Refined-ViT-M</td>\n","      <td>7.948718</td>\n","    </tr>\n","    <tr>\n","      <th>53</th>\n","      <td>CoAtNet-3 (224)</td>\n","      <td>ResMLP-B24 (baseline)</td>\n","      <td>1.481481</td>\n","    </tr>\n","    <tr>\n","      <th>54</th>\n","      <td>ViT-MoE-L/16 (Every-2)</td>\n","      <td>Refined-ViT-M</td>\n","      <td>237.179487</td>\n","    </tr>\n","    <tr>\n","      <th>55</th>\n","      <td>ViT-MoE-H/14 (Last-5)</td>\n","      <td>Refined-ViT-M</td>\n","      <td>544.871795</td>\n","    </tr>\n","    <tr>\n","      <th>56</th>\n","      <td>ViT-MoE-H/14 (Every-2)</td>\n","      <td>Refined-ViT-M</td>\n","      <td>705.128205</td>\n","    </tr>\n","    <tr>\n","      <th>57</th>\n","      <td>ViT-MoE-15B (Every-2)</td>\n","      <td>Refined-ViT-M</td>\n","      <td>3775.641026</td>\n","    </tr>\n","    <tr>\n","      <th>58</th>\n","      <td>BEiT</td>\n","      <td>Refined-ViT-M</td>\n","      <td>2.179487</td>\n","    </tr>\n","    <tr>\n","      <th>59</th>\n","      <td>XCiT-L24</td>\n","      <td>Refined-ViT-M</td>\n","      <td>41.153846</td>\n","    </tr>\n","    <tr>\n","      <th>60</th>\n","      <td>XCiT-L24</td>\n","      <td>Refined-ViT-M</td>\n","      <td>3.551282</td>\n","    </tr>\n","    <tr>\n","      <th>61</th>\n","      <td>TokenLearner L/8</td>\n","      <td>Refined-ViT-M</td>\n","      <td>19.102564</td>\n","    </tr>\n","    <tr>\n","      <th>62</th>\n","      <td>VOLO-D5</td>\n","      <td>ResMLP-B24 (baseline)</td>\n","      <td>2.785185</td>\n","    </tr>\n","    <tr>\n","      <th>63</th>\n","      <td>CSWin-L (384 res,ImageNet-22k pretrain)</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>117.117117</td>\n","    </tr>\n","    <tr>\n","      <th>64</th>\n","      <td>Florence-CoSwin-H</td>\n","      <td>ConvNeXt-L</td>\n","      <td>601.719198</td>\n","    </tr>\n","    <tr>\n","      <th>65</th>\n","      <td>ViT-L/16</td>\n","      <td>DynamicViT-LV-M/0.8</td>\n","      <td>90.990991</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>"],"text/plain":["                                     reference system             new system  \\\n","0                                     MSRA (C, PReLU)           SE-ResNet-50   \n","1                                           ResNet-50           SE-ResNet-50   \n","2                                          ResNet-152               Xception   \n","3                                          ResNet-101           SE-ResNet-50   \n","4                                    ResNeXt-101 64x4           SE-ResNet-50   \n","5                                   Very Deep PolyNet           SE-ResNet-50   \n","6                                       SE-ResNet-152               AlphaX-1   \n","7                          Oct-ResNet-152 (alpha=0.5)       PyConvResNet-101   \n","8                      NoisyStudent (EfficientNet-L2)    DynamicViT-LV-M/0.8   \n","9                                               BiT-L    DynamicViT-LV-M/0.8   \n","10  Harm-SE-RNX-101 64x4d (320x320, Mean-Max Pooling)       PyConvResNet-101   \n","11  Harm-SE-RNX-101 64x4d (320x320, Mean-Max Pooling)       PyConvResNet-101   \n","12                                         TResNet-XL    DynamicViT-LV-M/0.8   \n","13                                       REGNETX-32GF  iAFF-ResNeXt-50-32x4d   \n","14                                        ResNeSt-101       PyConvResNet-101   \n","15                                           ViT-H/14    DynamicViT-LV-M/0.8   \n","16                  SE-ResNeXt-101, 64x4d, S=2(416px)                HVT-S-1   \n","17                                             DeiT-B                HVT-S-1   \n","18                                          BoTNet T7    DynamicViT-LV-M/0.8   \n","19                                        T2T-ViTt-24                HVT-S-1   \n","20                           LambdaResNet (depth 320)    DynamicViT-LV-M/0.8   \n","21                           LambdaResNet (depth 152)                HVT-S-1   \n","22                                          ConViT-B+                 CeiT-S   \n","23                          CeiT-S (384 finetune res)            Visformer-S   \n","24                             DeepVit-L*_ 384 (Ours)    DynamicViT-LV-M/0.8   \n","25                                  DeepVit-L* (Ours)            Visformer-S   \n","26                                            HaloNet    DynamicViT-LV-M/0.8   \n","27                                           SwinV2-G    DynamicViT-LV-M/0.8   \n","28                                             Swin-L    DynamicViT-LV-M/0.8   \n","29                                             Swin-B            Visformer-S   \n","30                                       CrossViT-18+            Visformer-S   \n","31                        ViL-Base-RPB (Imagenet-21k)    DynamicViT-LV-M/0.8   \n","32                         ViL-Base-RPB (Imagenet-1k)            Visformer-S   \n","33           CvT-W24 (384 res, ImageNet-22k pretrain)    DynamicViT-LV-M/0.8   \n","34                                   CvT-21 (384 res)            Visformer-S   \n","35                                    PiT-B + distill    DynamicViT-LV-M/0.8   \n","36                              EfficientNet-XL (21k)    DynamicViT-LV-M/0.8   \n","37                                          LeViT-384            Visformer-S   \n","38                                       LV-ViT-M_384    DynamicViT-LV-M/0.8   \n","39                                           LV-ViT-M    DynamicViT-LV-M/0.8   \n","40                                       LV-ViT-L_512    DynamicViT-LV-M/0.8   \n","41                                       LV-ViT-L_448    DynamicViT-LV-M/0.8   \n","42                                        Twins-SVT-L              Container   \n","43                                       ResMLP-B24/8             ConvNeXt-L   \n","44                                             gMLP-B       ResNet-152x2-SAM   \n","45               Transformer local-attention (NesT-B)              Container   \n","46                                         ResT-Large              Container   \n","47                                  Refined-ViT-L_448             ConvNeXt-L   \n","48                                  Refined-ViT-L_384             ConvNeXt-L   \n","49                                           ViT-G/14          Refined-ViT-M   \n","50                                          CoAtNet-7          Refined-ViT-M   \n","51                                          CoAtNet-4          Refined-ViT-M   \n","52                                    CoAtNet-3 (384)          Refined-ViT-M   \n","53                                    CoAtNet-3 (224)  ResMLP-B24 (baseline)   \n","54                             ViT-MoE-L/16 (Every-2)          Refined-ViT-M   \n","55                              ViT-MoE-H/14 (Last-5)          Refined-ViT-M   \n","56                             ViT-MoE-H/14 (Every-2)          Refined-ViT-M   \n","57                              ViT-MoE-15B (Every-2)          Refined-ViT-M   \n","58                                               BEiT          Refined-ViT-M   \n","59                                           XCiT-L24          Refined-ViT-M   \n","60                                           XCiT-L24          Refined-ViT-M   \n","61                                   TokenLearner L/8          Refined-ViT-M   \n","62                                            VOLO-D5  ResMLP-B24 (baseline)   \n","63            CSWin-L (384 res,ImageNet-22k pretrain)    DynamicViT-LV-M/0.8   \n","64                                  Florence-CoSwin-H             ConvNeXt-L   \n","65                                           ViT-L/16    DynamicViT-LV-M/0.8   \n","\n","    compute decrease  \n","0          13.288591  \n","1           2.711409  \n","2           9.250000  \n","3           5.416107  \n","4          10.067114  \n","5           8.926174  \n","6           1.797521  \n","7           2.316206  \n","8       16576.576577  \n","9         712.612613  \n","10          4.782609  \n","11          2.727273  \n","12        592.792793  \n","13          4.356061  \n","14         55.731225  \n","15        990.990991  \n","16         10.217391  \n","17          5.217391  \n","18        899.099099  \n","19         12.934783  \n","20        186.486486  \n","21         12.644928  \n","22          6.679537  \n","23          2.641844  \n","24         26.576577  \n","25          5.230496  \n","26         38.558559  \n","27         99.099099  \n","28        354.054054  \n","29         10.248227  \n","30          1.932624  \n","31        150.450450  \n","32          1.368794  \n","33       2225.225225  \n","34          5.088652  \n","35         12.972973  \n","36        119.819820  \n","37          3.528369  \n","38         43.783784  \n","39         16.576577  \n","40        222.522523  \n","41        163.063063  \n","42          2.797428  \n","43         11.747851  \n","44          2.778626  \n","45          3.311897  \n","46          1.464630  \n","47          3.237822  \n","48          2.280802  \n","49        596.794872  \n","50        564.743590  \n","51         82.051282  \n","52          7.948718  \n","53          1.481481  \n","54        237.179487  \n","55        544.871795  \n","56        705.128205  \n","57       3775.641026  \n","58          2.179487  \n","59         41.153846  \n","60          3.551282  \n","61         19.102564  \n","62          2.785185  \n","63        117.117117  \n","64        601.719198  \n","65         90.990991  "]},"execution_count":79,"metadata":{},"output_type":"execute_result"}],"source":["df_ex = pd.read_csv('https://raw.githubusercontent.com/Besiroglu/computer_vision_data/main/imagenet.csv')\n","df4 = df_ex[[\"url\",\t\"publication_date\",\t\"year\",\t\"fractional_year\", \"model_name\",\t\"extra_data\",\t\"top_1_error\",\t\"top_5_error\",\t\"final_compute_estimate\",\t\"nr_training_images\",\t\"parameter_count\", \"reimplementation\",\t\"input_size_test\"]]\n","df4 = df4[df4[\"top_1_error\"].notna() & df4[\"final_compute_estimate\"].notna() & df4[\"parameter_count\"].notna()]\n","\n","exclude_models = [\"GreedyNAS-B\", \"NASNet-A\", \"AmoebaNet-A\"]\n","\n","for model_name in exclude_models:\n","    df4 = df4[df4[\"model_name\"] != model_name]\n","\n","df4[\"data\"] = df4[\"nr_training_images\"]\n","df4[\"model_size\"] = df4[\"parameter_count\"]\n","df4[\"year\"] = df4[\"fractional_year\"]\n","\n","df_new = df4[[\"model_name\", \"year\", \"final_compute_estimate\", \"top_1_error\"]]\n","delta = 1\n","\n","all_data = []\n","\n","for idx, row in df_new.iterrows():\n","  data_subset = df_new[df_new[\"top_1_error\"] > row[\"top_1_error\"] * delta]\n","  data_subset = data_subset[data_subset[\"year\"] > row[\"year\"]]\n","  data_subset = data_subset[data_subset[\"final_compute_estimate\"] < row[\"final_compute_estimate\"]]\n","  if len(data_subset) > 0:\n","    min_compute = min(data_subset[\"final_compute_estimate\"])\n","    row_min = data_subset.loc[data_subset[\"final_compute_estimate\"] == min_compute]\n","    compute_diff = row[\"final_compute_estimate\"] / min_compute\n","    data = [row[\"model_name\"], row_min.iloc[0][\"model_name\"], compute_diff]\n","    all_data.append(data)\n","\n","pd.DataFrame(all_data, columns=[\"reference system\", \"new system\", \"compute decrease\"])"]}],"metadata":{"colab":{"provenance":[]},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.10.12"}},"nbformat":4,"nbformat_minor":0}