{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# inverse m and loss for all models (tested Apr 1) and datasets\n",
    "\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "27"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_names = [\"facebook/opt-125m\",\n",
    "               \"facebook/opt-350m\",\n",
    "               \"facebook/opt-1.3B\",\n",
    "               \"facebook/opt-2.7B\",\n",
    "               \"facebook/opt-6.7B\",\n",
    "               \"facebook/opt-13B\",\n",
    "               \"facebook/opt-30B\",\n",
    "               \"facebook/opt-66b\",\n",
    "               \"Qwen/Qwen2.5-0.5B\",\n",
    "               \"Qwen/Qwen2.5-1.5B\",\n",
    "               \"Qwen/Qwen2.5-3B\",\n",
    "               \"Qwen/Qwen2.5-7B\",\n",
    "               \"Qwen/Qwen2.5-14B\",\n",
    "               \"Qwen/Qwen2.5-32B\",\n",
    "               \"Qwen/Qwen2.5-72B\",\n",
    "               \"openai-community/gpt2\",\n",
    "               \"openai-community/gpt2-medium\",\n",
    "               \"openai-community/gpt2-large\",\n",
    "               \"openai-community/gpt2-xl\",\n",
    "               \"EleutherAI/pythia-70m\",\n",
    "               \"EleutherAI/pythia-160m\",\n",
    "               \"EleutherAI/pythia-410m\",\n",
    "               \"EleutherAI/pythia-1b\",\n",
    "               \"EleutherAI/pythia-1.4b\",\n",
    "               \"EleutherAI/pythia-2.8b\",\n",
    "               \"EleutherAI/pythia-6.9b\",\n",
    "               \"EleutherAI/pythia-12b\"]\n",
    "\n",
    "data_names = [\"wikitext\",\n",
    "              \"c4\",\n",
    "              \"pile\",\n",
    "              \"bookcorpus\"]\n",
    "\n",
    "model_classes = [\"opt\",\n",
    "                 \"Qwen\",\n",
    "                 \"gpt2\",\n",
    "                 \"pythia\"]\n",
    "\n",
    "len(model_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = []\n",
    "for model_name in model_names:\n",
    "    with open(f\"./data/{model_name.replace('/', '_')}_results.json\", \"r\") as f:\n",
    "        result = json.load(f)\n",
    "    result['m'] = torch.load(f\"./data/overlap-0-{model_name.replace('/', '_')}.pt\", weights_only=False)['m'] if model_name != \"facebook/opt-350m\" else 1024\n",
    "    results.append(result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "losses_groups = []\n",
    "ms_groups = []\n",
    "\n",
    "for model_class in model_classes:\n",
    "    for data_name in data_names:\n",
    "        losses = []\n",
    "        ms = []\n",
    "        for result in results:\n",
    "            if model_class in result['model_id']:\n",
    "                losses.append(result['results'][data_name]['loss'])\n",
    "                ms.append(result['m'])\n",
    "        losses_groups.append(torch.tensor(losses))\n",
    "        ms_groups.append(torch.tensor(ms))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_mean_m = 0\n",
    "num_data = 0\n",
    "for ms in ms_groups:\n",
    "    log_mean_m +=  ms.log().sum()\n",
    "    num_data += len(ms)\n",
    "log_mean_m = log_mean_m / num_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 0, Loss: 1.742314100265503\n",
      "Iteration 1000, Loss: 0.1029869019985199\n",
      "Iteration 2000, Loss: 0.022384051233530045\n",
      "Iteration 3000, Loss: 0.006268143188208342\n",
      "Iteration 4000, Loss: 0.00539284385740757\n",
      "Iteration 5000, Loss: 0.005365414544939995\n",
      "Iteration 6000, Loss: 0.005335673224180937\n",
      "Iteration 7000, Loss: 0.005299288779497147\n",
      "Iteration 8000, Loss: 0.005261349491775036\n",
      "Iteration 9000, Loss: 0.00522950291633606\n",
      "Iteration 10000, Loss: 0.0052092731930315495\n",
      "Iteration 11000, Loss: 0.005200320389121771\n",
      "Iteration 12000, Loss: 0.005197944585233927\n",
      "Iteration 13000, Loss: 0.005197660997509956\n",
      "Iteration 14000, Loss: 0.0051976535469293594\n",
      "Iteration 15000, Loss: 0.005197728518396616\n",
      "Iteration 16000, Loss: 0.005197750870138407\n",
      "Iteration 17000, Loss: 0.005197649355977774\n",
      "Iteration 18000, Loss: 0.005197652615606785\n",
      "Iteration 19000, Loss: 0.005197651218622923\n"
     ]
    }
   ],
   "source": [
    "class Model(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Model, self).__init__()\n",
    "        self.A = torch.nn.Parameter(torch.tensor([500.0]))\n",
    "        self.B = torch.nn.Parameter(torch.ones(16))\n",
    "        self.alpha = torch.nn.Parameter(torch.tensor([1.0]))\n",
    "\n",
    "    def forward(self, x_group, y_group):\n",
    "        loss = 0\n",
    "        num_data = 0\n",
    "        for i, x, y in zip(range(len(x_group)), x_group, y_group):\n",
    "            loss += ((self.A / x.pow(self.alpha) + self.B[i] - y) ** 2).sum() \n",
    "            num_data += x.numel()\n",
    "        return loss / num_data\n",
    "\n",
    "model = Model()\n",
    "optimizer = torch.optim.Adam([{\"params\":model.A, \"lr\": 1.0}, {\"params\":model.B, \"lr\": 0.001}, {\"params\":model.alpha, \"lr\": 0.001}])\n",
    "\n",
    "for i in range(20000):\n",
    "    optimizer.zero_grad()\n",
    "    loss = model(ms_groups, losses_groups)\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "    if i % 1000 == 0:\n",
    "        print(f\"Iteration {i}, Loss: {loss.item()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([0.9098]),\n",
       " tensor([476.0763]),\n",
       " tensor([2.2074, 2.2745, 1.7193, 2.1845, 1.6079, 2.1009, 1.4890, 1.9348, 2.3018,\n",
       "         2.3546, 1.9413, 2.2961, 2.1407, 2.2998, 1.5203, 2.2415]))"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.alpha.data, model.A.data, model.B.data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "Bs = model.B.data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "shapes = ['o', 's', 'v', '^']\n",
    "colors = ['C0', 'C1', 'C2', 'C3']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for model_i in range(4):\n",
    "    for data_i in range(4):\n",
    "        idx = model_i * 4 + data_i\n",
    "        plt.scatter(1 / ms_groups[idx], losses_groups[idx], marker=shapes[data_i], color=colors[model_i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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kpEgCO2CSEaCILQLIhkJgtAuiGQkCEK7IJKRIAjtgkhGgiC0CyIZCYLQLohkJAhCuyCSkSAI7YJIRkI9I0eO5Pbbb2+17Rt7XXP3cbJ1lDg7KpGMOpDrr78eSZIaLdtw0003IUlSs6vstaWPPvqIhx56qK3DOK6OEmdHJZJRB5Obm8u7775LIBCoWxYMBnnnnXfo0qVLG0bWfCkpKdjt9rYO47g6SpwdlUhGHcxZZ51Fly5d+Oijj+qWffTRR+Tm5nLmmWfWLQuFQtx6661kZGRgMpkYPnw469atq7ev2tparrvuOmw2G507d+app55qcDxN03jiiSfo3r07ZrOZgoICFi1alFDMxzvOj09/Ro4cyS233MLtt99OcnIymZmZvPTSS9TW1nLDDTdgt9vp0aMH//rXvxKKdeTIkdx6663MnDmTlJQUOnXqxIMPPlhvH4sWLWLAgAGYzWZSU1O56KKLqK2tbTTOpvyOm3LM49m3bx+SJPHRRx9x/vnnYzabGTx4MPv27WP58uWcc845WCwWRo0aRXV1dUL7bk9EMuqAbrjhBl577bW656+++io33nhjvW1mzpzJhx9+yMKFC9mwYQP5+fmMGTOm3of1j3/8I8uWLeNvf/sbS5YsYfny5axfv77efu677z5ee+01nn/+ebZu3codd9zBr3/9a1asWNHkeJtynB9buHAhaWlprF27lltuuYXf//73XHnllQwdOpQNGzYwZswYrr32Wvx+f0KxLly4EKvVypo1a3jiiSeYM2dOXTnV0tJSJk2axI033sj27dtZvnw5EydOPOpU3035HR/vmE1xeLKEBQsWMHfuXP73v/9RVVXFtddey+OPP878+fNZvnw53377LX/5y1+avN92p0VLtQmtavLkydpll12mVVRUaEajUdu7d6+2b98+zWQyaRUVFdpll12mTZ48WfP5fJper9feeuututeGw2EtKytLe+KJJzRN0zSv16sZDAbt3XffrdumqqpKM5vN2m233aZpmqb5fD7NZDJpq1atqhfHlClTtEmTJmmapmkXXHBB3faNacpxfryPCy64QBs+fHjd82g0qlmtVu3aa6+tW1ZaWqoB2v/+97+EYj1yv5qmaUOGDNHuvPNOTdM0bf369Rqg7du3r9H3cmScTfkdN+WYTfHggw9qycnJWkVFRd2y66+/XuvSpYvm8/nqlo0dO1abPn16k/fb3oga2B1QWloa48ePZ+HChWiaxvjx40lLS6tb//333xOJRBg2bFjdMr1ezznnnMP27dvrtgmHw5x33nl126SkpNSbvHHbtm0Eg0EuvvjiescPh8P1TgmPpSnHacyR87YpikJqaioDBgyoW3Z4Vory8vKEYv3xfHCdO3eu20dBQQEXXnghAwYMYMyYMYwePZorrriC5OTkRt/X8X7HTTlmU2zatIkJEybU+z8uLCxk0qRJWK3WesvGjx/f5P22NyIZdVA33ngjN998MwDz58+vt047dFpxrHmutCZUG1ZVFYBPP/2U7OzseuuMRmOT4mzKcRqj1+vrPZckqd6yw+/jcIxNjbWx/R5+raIoLF26lFWrVrFkyRLmzZvHvffey5o1a8jLy2v0fTVlLrFjHbMpNm/ezMyZM+st27RpU93/P8QvYuzcuZNBgwY1eb/tjegz6qDGjh1LOBwmHA4zZsyYeuvy8/MxGAx8+eWXdcsikQhff/01ffr0qdtGr9ezevXqum1qamrYuXNn3fO+fftiNBopLCwkPz+/3iM3N7dJcTblOC2hJWKFeKIYNmwYs2fPZuPGjRgMBv72t7812K4pv+OW4PF42LdvX73W3f79+6murq63bOvWrcRiMQoKClrs2CebaBl1UIqi1J0OKIpSb53VauX3v/89f/zjH+ummnniiSfw+/1MmTIFAJvNxpQpU/jjH/9IamoqmZmZ3HvvvcjyD3+f7HY7M2bM4I477kBVVYYPH47H42HVqlXYbDYmT5583DibcpyW0BKxrlmzhv/+97+MHj2ajIwM1qxZQ0VFRaPJpSm/45awefNmZFmud6q3adMmnE4n3bp1q7dd9+7dO/TQA5GMOjCHw3HUdY899hiqqnLttdfi9Xo5++yzWbx4cb3+jyeffBKfz8eECROw2+384Q9/wO1219vPQw89REZGBo8++ih79uzB6XRy1llncc899zQ5zqYcpyWcaKwOh4MvvviCZ555Bo/HQ9euXXnqqacYN25co9s35XfcFK+//jo33HBDo6e0mzdvpnfv3pjN5rplGzdubNAC2rx5c4c+RQMQUxUJQht78MEHWb58OcuXL2/rUNqUaBkJQhtbvHgx//d//9fWYbQ50TISBKFdEFfTBEFoF0QyEgShXRDJSBCEdkEkI0EQ2gWRjARBaBdEMhIEoV0QyUgQhHZBJCNBENoFkYwEQWgXRDISBKFd+P/rb+ko+PCJ6QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8, 2.1), constrained_layout=True)\n",
    "for model_i in range(4):\n",
    "    for data_i in range(4):\n",
    "        idx = model_i * 4 + data_i\n",
    "        plt.scatter(ms_groups[idx], losses_groups[idx] - Bs[idx], marker=shapes[data_i], color=colors[model_i], alpha=0.3)\n",
    "\n",
    "plt.plot(torch.linspace(512, 1e+4, 100), model.A.data / torch.linspace(512, 1e+4, 100).pow(model.alpha.data), color='black', linestyle='--')\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "\n",
    "plt.xlabel('Model dimension, $m$')\n",
    "plt.ylabel('Loss (model part)')\n",
    "plt.savefig('../figures/loss_vs_m.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error in slope: 0.03599117696285248\n"
     ]
    }
   ],
   "source": [
    "y_diff = 0\n",
    "x_diff = 0\n",
    "for i, (losses, ms) in enumerate(zip(losses_groups, ms_groups)):\n",
    "    y_diff += ((losses - Bs[i]).log().nan_to_num() - (model.A.data / ms.pow(model.alpha.data)).log()).pow(2).sum()\n",
    "    x_diff += (ms.log() - log_mean_m).pow(2).sum()\n",
    "err_slope = (y_diff / x_diff / (num_data - 3)).sqrt()\n",
    "print(f\"Error in slope: {err_slope.item()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "dist_wd_names = [\"exponential1_-1.00\",\n",
    "            \"exponential1_0.10\",\n",
    "            \"power_-1.00\",\n",
    "            \"power_0.10\",\n",
    "            \"linear_-1.00\",\n",
    "            \"linear_0.10\"]\n",
    "\n",
    "n_steps = 40000\n",
    "m_ran = 2 ** torch.arange(3, 11)\n",
    "tlosses = torch.zeros((len(dist_wd_names), len(m_ran), n_steps))\n",
    "\n",
    "for i, dist_wd_name in enumerate(dist_wd_names):\n",
    "    result = torch.load(f\"../outputs/exp-17-{dist_wd_name}.pt\", weights_only=False)\n",
    "    #tlosses[i] = result['losses'] \n",
    "    tlosses[i,:,-result['losses'].shape[-1]:] = result['losses']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "fit_losses = tlosses[:,:,-100:].mean(dim = -1) * 10240\n",
    "std_losses = tlosses[:,:,-100:].std(dim = -1) * 10240"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-1.0054519891134572\n",
      "-0.984016743248084\n",
      "-0.8863921247731672\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8, 2.1), constrained_layout=True)\n",
    "for model_i in range(4):\n",
    "    for data_i in range(4):\n",
    "        idx = model_i * 4 + data_i\n",
    "        plt.scatter(ms_groups[idx], losses_groups[idx] - Bs[idx], marker='o', color='black', alpha=0.1)\n",
    "\n",
    "starts = [0, 2, 2]\n",
    "for iii, i in enumerate([0,2,4]):\n",
    "    slope, intersect, _, _, slope_std = stats.linregress(torch.log(m_ran[starts[iii]:]), torch.log(fit_losses[i,starts[iii]:]))\n",
    "    print(slope)\n",
    "    plt.errorbar(m_ran.numpy(), fit_losses[i].numpy(), yerr=std_losses[i].numpy(), fmt='s', color = 'C'+str(i//2))\n",
    "    plt.plot(m_ran, math.exp(intersect) * m_ran ** slope, '--', color = 'C'+str(i//2))\n",
    "\n",
    "plt.plot(torch.linspace(500, 1.1e+4, 100), model.A.data / torch.linspace(512, 1e+4, 100).pow(model.alpha.data), color='black', linestyle='--')\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.xlim(5,)\n",
    "plt.ylim(None, 3)\n",
    "plt.xlabel(r\"Model dimension, $m$\")\n",
    "plt.ylabel(r\"Loss\")\n",
    "plt.savefig('../figures/exp-17-sup.pdf')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
