{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4c4f98f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load data\n",
    "import random\n",
    "from law import ScalingLaw\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import json\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import warnings\n",
    "from tqdm import tqdm\n",
    "\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "from functools import partial\n",
    "\n",
    "\n",
    "DOMAINS_2_SUBDOMAINS = {\n",
    "    \"academic\": [\"ArXiv\", \"PubMed_Abstracts\", \"PhilPapers\", \"NIH_ExPorter\", \"FreeLaw\", \"USPTO_Backgrounds\", \"PubMed_Central\"],\n",
    "    \"prose\": [\"PG19\", \"Books3\", \"BookCorpus2\"],\n",
    "    \"dialogue\": [\"Ubuntu_IRC\", \"OpenSubtitles\", \"EuroParl\", \"Enron_Emails\", \"HackerNews\", \"YoutubeSubtitles\"],\n",
    "    \"symbolic\": [\"DM_Mathematics\", \"Github\"],\n",
    "    \"internet\": [\"Pile-CC\", \"OpenWebText2\", \"StackExchange\", \"Wikipedia_en\"],\n",
    "}\n",
    "SUBDOMAINS_2_DOMAINS = {\n",
    "    subdomain: domain\n",
    "    for domain, subdomains in DOMAINS_2_SUBDOMAINS.items() for subdomain in subdomains\n",
    "}\n",
    "with open(\"valid_weight.json\", \"r\") as f:\n",
    "    valid_weight = json.load(f)\n",
    "for domain, subdomains in DOMAINS_2_SUBDOMAINS.items():\n",
    "    valid_weight[domain] = sum(valid_weight[subdomain] for subdomain in subdomains)\n",
    "\n",
    "\n",
    "def load_loss(path, filter=True):\n",
    "    losses = defaultdict(lambda: defaultdict(dict))   # domain -> ratio\n",
    "    with open(path, \"r\") as f:\n",
    "        lines = set(f.readlines())\n",
    "    for line in lines:   \n",
    "        model, data, loss = line.split()\n",
    "        model = model.strip('/')\n",
    "        step = int(model.split('/')[-1])\n",
    "        if filter and int(model.split('/')[-2].split('-')[0].split('_')[-1]) > 900:\n",
    "            continue\n",
    "        ratio = \"-\".join(model.split('/')[-2].split('-')[1:])\n",
    "        subdomain = data.split('/')[-1].split('.')[-2]\n",
    "        losses[ratio][subdomain][step] = float(loss)\n",
    "    # merge\n",
    "    for domain, subdomains in DOMAINS_2_SUBDOMAINS.items():\n",
    "        domain_norm = sum(valid_weight[subdomain] for subdomain in subdomains)\n",
    "        for ratio in losses:\n",
    "            for step in losses[ratio][subdomains[0]]:\n",
    "                try:\n",
    "                    losses[ratio][domain][step] = sum(losses[ratio][subdomain][step] * valid_weight[subdomain] / domain_norm for subdomain in subdomains)\n",
    "                except:\n",
    "                    continue\n",
    "    return losses\n",
    "\n",
    "OBSERVED_LOSSES = {\n",
    "    \"70M\": load_loss(f\"data/5Mix/70M.txt\"),\n",
    "    \"160M\": load_loss(f\"data/5Mix/160M.txt\"),\n",
    "    \"305M\": load_loss(f\"data/5Mix/305M.txt\"),\n",
    "    \"410M\": load_loss(f\"data/5Mix/410M.txt\")\n",
    "}   # sz, ratio, domain, step\n",
    "\n",
    "seed=4096\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n",
    "torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "MODEL_SZIE = \"70M\"\n",
    "STEP = 30000\n",
    "with open(\"data/5Mix/proportions.txt\", \"r\") as f:\n",
    "    ratios = list(OBSERVED_LOSSES[MODEL_SZIE]) # [line.strip() for line in f]\n",
    "np.random.shuffle(ratios)\n",
    "eval_ratios = ratios[20:]\n",
    "train_ratios = ratios[:20]\n",
    "\n",
    "\n",
    "x = np.array([list(map(float, ratio.split('-'))) for ratio in train_ratios])\n",
    "y = np.array([\n",
    "    sum(OBSERVED_LOSSES[MODEL_SZIE][ratio][domain][STEP] * valid_weight[domain] for domain in DOMAINS_2_SUBDOMAINS) \n",
    "    for ratio in train_ratios\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "baa965ed",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████| 6000/6000 [00:31<00:00, 187.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0005682876217179\n",
      "tensor([  0.9750,  -2.1391, -10.0864,   2.7140,   2.7106,   2.6083,   1.5866])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████| 6000/6000 [00:31<00:00, 191.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.00012334295024629682\n",
      "tensor([ 1.2624, -2.1656,  1.3930, -4.6811,  0.7855,  1.8719,  0.5734])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████| 6000/6000 [00:27<00:00, 214.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0005513424403034151\n",
      "tensor([  1.1375,  -7.1017,   6.7135,   6.2643, -31.8621,   6.6423,   6.2053])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████| 6000/6000 [00:35<00:00, 166.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0001428198884241283\n",
      "tensor([  0.4750,  -3.6546,   3.3289,   3.6705,   3.1127, -16.4217,   3.1591])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████| 6000/6000 [00:31<00:00, 192.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8.165960753103718e-05\n",
      "tensor([ 1.2402, -1.9510,  1.1897,  0.8697, -0.5184,  1.7122, -3.0870])\n"
     ]
    }
   ],
   "source": [
    "# fit with mixture law\n",
    "class ScalingLawWrap:\n",
    "    def __init__(self, func):\n",
    "        self.func = func\n",
    "    \n",
    "    def __call__(self, x, param):\n",
    "        if not isinstance(x, torch.Tensor):\n",
    "            x = torch.tensor(x, dtype=torch.float)\n",
    "        if not isinstance(param, torch.Tensor):\n",
    "            param = torch.tensor(param, dtype=torch.float)\n",
    "        return self.func(x, param)\n",
    "\n",
    "def mixture_law_(x, param):\n",
    "    log_c, log_k, t = param[0], param[1], param[2:]\n",
    "    return torch.exp(log_c) + torch.exp(log_k + torch.matmul(x, t))\n",
    "\n",
    "mixture_law = ScalingLawWrap(mixture_law_)\n",
    "\n",
    "def param_genertor(idx):\n",
    "    for log_c in np.linspace(-2, 1.5, 10):\n",
    "        for logk in np.linspace(-10, 1, 20):\n",
    "            for _ in range(30):\n",
    "                ts = [-np.random.rand() if i == idx else np.random.rand() * 0.1 for i in range(5)]\n",
    "                yield [log_c, logk] + ts\n",
    "\n",
    "# linear by domains\n",
    "linear_domain_params = {}\n",
    "for domain in DOMAINS_2_SUBDOMAINS:\n",
    "    x = np.array([list(map(float, ratio.split('-'))) for ratio in ratios])\n",
    "    y = np.array([\n",
    "        OBSERVED_LOSSES[MODEL_SZIE][ratio][domain][STEP]\n",
    "        for ratio in ratios\n",
    "    ])\n",
    "    law = ScalingLaw(mixture_law)\n",
    "    linear_domain_params[domain] = law.fit(x, y, param_genertor(-1), max_step=50, eps=0, valid_split=0, delta=0.05)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5e990530",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:45<00:00,  4.54s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:46<00:00,  4.63s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:44<00:00,  4.41s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:44<00:00,  4.41s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:44<00:00,  4.47s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:45<00:00,  4.56s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████| 10/10 [00:47<00:00,  4.73s/it]\n"
     ]
    }
   ],
   "source": [
    "# fit with mlp\n",
    "from sklearn.ensemble import AdaBoostRegressor\n",
    "from sklearn.base import BaseEstimator, RegressorMixin\n",
    "\n",
    "class MixtureMLP(nn.Module):\n",
    "    def __init__(self, dim=10, num_mixture=5, activation=\"exp\", bias=None) -> None:\n",
    "        super().__init__()\n",
    "        self.in_linear = nn.Linear(num_mixture, dim)\n",
    "        # for i in range(self.in_linear.weight.data.shape[0]):\n",
    "        #     self.in_linear.weight.data[i, i%num_mixture] = -10 * np.abs(self.in_linear.weight.data[i, i%num_mixture]) \n",
    "        self.out_linear = nn.Linear(dim, 1)\n",
    "        self.act = activation\n",
    "        if bias is not None:\n",
    "            self.out_linear.bias = nn.Parameter(torch.tensor([bias], dtype=torch.float))\n",
    "        # self.dropout = nn.Dropout(0.5)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = torch.tensor(x, dtype=torch.float)\n",
    "        h = self.in_linear(x)\n",
    "        if self.act == \"exp\":\n",
    "            h = torch.exp(h)\n",
    "        elif self.act == \"relu\":\n",
    "            h = torch.nn.functional.relu(h)\n",
    "        elif self.act == \"gelu\":\n",
    "            h = torch.nn.functional.gelu(h, approximate=\"tanh\")\n",
    "        elif self.act == \"silu\":\n",
    "            h = torch.nn.functional.silu(h)\n",
    "        elif self.act == \"tanh\":\n",
    "            h = torch.nn.functional.tanh(h)\n",
    "        elif self.act == \"sigmoid\":\n",
    "            h = torch.nn.functional.sigmoid(h)\n",
    "        elif self.act == \"softplus\":\n",
    "            h = torch.nn.functional.softplus(h)\n",
    "        # return self.out_linear(torch.nn.functional.gelu(self.in_linear(x)))\n",
    "        w = F.softmax(self.out_linear.weight, dim=-1)\n",
    "        # import ipdb;ipdb.set_trace()\n",
    "        return torch.matmul(h, w.T) + self.out_linear.bias\n",
    "\n",
    "\n",
    "class MLPEstimator(BaseEstimator, RegressorMixin):\n",
    "    def __init__(self, dim, num_mixture, activation):\n",
    "        # Initialize parameters\n",
    "        self.dim, self.num_mixture, self.activation = dim, num_mixture, activation\n",
    "        self.mlp = MixtureMLP(dim, num_mixture, activation)\n",
    "        self.use_cuda = torch.cuda.is_available()\n",
    "\n",
    "    def fit(self, X, y):\n",
    "        best_valid_loss, valid_split = 1e10, int(X.shape[0] / 5)\n",
    "        X, y = torch.tensor(X, dtype=torch.float), torch.tensor(y, dtype=torch.float)\n",
    "        optimizer = torch.optim.AdamW(self.mlp.parameters(), lr=0.1, weight_decay=1e-3)\n",
    "        for _ in range(5000):\n",
    "            self.mlp.train()\n",
    "            # loss = optimizer.step(closure)\n",
    "            loss = torch.nn.functional.huber_loss(self.mlp(torch.tensor(X[:-valid_split]).float()).squeeze(), torch.tensor(y[:-valid_split]).float(), delta=0.05)\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            with torch.no_grad():\n",
    "                self.mlp.eval()\n",
    "                valid_loss = torch.nn.functional.l1_loss(self.mlp(torch.tensor(X).float()).squeeze(), torch.tensor(y).float())\n",
    "                # valid_loss = torch.nn.functional.mse_loss(mlp(torch.tensor(x[-5:]).float()).squeeze(), torch.tensor(y[-5:]).float())\n",
    "            if valid_loss < best_valid_loss:\n",
    "                best_valid_loss = valid_loss\n",
    "                best_param = self.mlp.state_dict()\n",
    "        self.mlp.load_state_dict(best_param)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def predict(self, X):\n",
    "        if self.use_cuda:\n",
    "            self.mlp.eval()\n",
    "            self.mlp = self.mlp.cuda()\n",
    "            x = torch.tensor(X, dtype=torch.float, device='cuda')\n",
    "            result = self.mlp(x).squeeze().cpu().numpy()\n",
    "            self.mlp = self.mlp.cpu()\n",
    "        else:\n",
    "            x = torch.tensor(X, dtype=torch.float)\n",
    "            result = self.mlp(x).squeeze().numpy()\n",
    "        return result\n",
    "\n",
    "# mlp for all\n",
    "mlp_boost_params, mlp_params = {}, {}\n",
    "x = np.array([list(map(float, ratio.split('-'))) for ratio in ratios])\n",
    "y = np.array([\n",
    "    sum(OBSERVED_LOSSES[MODEL_SZIE][ratio][domain][STEP] * valid_weight[domain] for domain in DOMAINS_2_SUBDOMAINS) \n",
    "    for ratio in ratios\n",
    "])\n",
    "# for dim in [1, 2, 3, 5, 10, 20, 30]:\n",
    "#     best_valid_loss, best_param = 1e10, None\n",
    "#     for i in range(5):\n",
    "#         regr = AdaBoostRegressor(MLPEstimator(dim, 5, \"exp\"), random_state=i, n_estimators=10)\n",
    "#         regr.fit(x, y)\n",
    "#         prediction = regr.predict(x)\n",
    "#         err = np.mean(np.abs(prediction - y))\n",
    "#         if err < best_valid_loss:\n",
    "#             best_valid_loss = err\n",
    "#             best_param = regr\n",
    "#     mlp_boost_params[dim] = best_param\n",
    "    \n",
    "#     best_valid_loss, best_param = 1e10, None \n",
    "#     for retry in tqdm(range(10)):\n",
    "#         mlp = MixtureMLP(dim=dim)\n",
    "#         optimizer = torch.optim.AdamW(mlp.parameters(), lr=1e-1, weight_decay=1e-3)\n",
    "#         for _ in range(10000):\n",
    "#             mlp.train()\n",
    "#             loss = torch.nn.functional.mse_loss(mlp(torch.tensor(x).float()).squeeze(), torch.tensor(y).float()) # , delta=0.1)\n",
    "#             optimizer.zero_grad()\n",
    "#             loss.backward()\n",
    "#             optimizer.step()\n",
    "#             with torch.no_grad():\n",
    "#                 mlp.eval()\n",
    "#                 valid_loss = torch.nn.functional.mse_loss(mlp(torch.tensor(x[-5:]).float()).squeeze(), torch.tensor(y[-5:]).float())\n",
    "#             if valid_loss + loss < best_valid_loss:\n",
    "#                 best_valid_loss = valid_loss\n",
    "#                 best_param = mlp.state_dict()\n",
    "#                 best_step = _\n",
    "#     mlp_params[dim] = best_param"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "51c8fabd-de54-4df1-9d00-5dd0e7b3d2b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.008618404835830503\n",
      "0.026849099638040164\n",
      "0.010382906399636497\n",
      "0.00267916500813666\n",
      "0.002400890789895286\n",
      "0.0019938940864530816\n"
     ]
    },
    {
     "data": {
      "image/png": "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W1l6OOCAA9LqY445JrKySv5P6/jjj0+rS/tnBAAAAAAAsDcS1FWwww8/PK1etGhRqeYvWbIk9blevXrRqFGjSu/j008/TasPOeSQtHrrEDAionHjxqXqrWXLlmn1qlWrSjUfAAAAAABgbySoq2BHHnlkWj137twSz12+fHlaaNWlS5eM9DFv3ry0ets+2rZtm1Zv3LixVL1t2rQpra5fv36p5gMAAAAAAOyNBHUV7JhjjolatWql6pkzZ8bmzZtLNHfmzJlp9XHHHbfHfZx44olp9WuvvVbiubvr46ijjkqrt94FWBJLly5Nq5s3b16q+QAAAAAAAHsjQV0Fq1GjRlpItnr16pg2bVqJ5k6cODGt7tu37x73cfLJJ2+3djKZ3O28wsLCmDx5cqo+/PDDt9tB16pVqzj44INT9TvvvFPid+Alk8m00LBu3brRsWPHEs0FAAAAAADYmwnqKsE555yTVt9zzz27nbNy5cp45JFHUvUhhxxSph11zZs3jxNOOCFVL1y4MF544YXdzhszZkxa6DZo0KAdjjvzzDNTnzdu3BgjR44sUV8vvvhi2g68k046KbKzs0s0FwAAAAAAYG8mqKsEgwYNisaNG6fqRx99dLvjJLf185//PC0gu/DCC3c4bvTo0ZFIJFJfW+9s29all16aVl999dW7fJ/csmXL4te//nWqzsnJiaFDh+5w7IUXXhiJRCJV33jjjbF48eKdrh0RUVRUFFdffXXatcsvv3yXcwAAAAAAAPYVgrpKULNmzbjiiitSdXFxcfTv3z/mzZu33djNmzfHlVdeGWPGjElda9GiRfzsZz8rcx9nnnlmtG/fPlW/++67MWTIkCgqKtpu7OLFi+O0006LvLy81LWLLrooWrduvcO1jzzyyBg2bFiqXr16dfTq1Svmzp27w/Fr166NQYMGxaxZs1LXTjvttO3epQcAAAAAALCvqp7pBvYXl19+eYwdOzbeeeediIhYunRpdO7cOYYOHRo9evSInJycmD9/fowePTo++OCD1LxEIhH33Xdf1KlTp8w9VKtWLe67777o3r17aifdww8/HG+//XYMHz482rVrF6tXr47p06fHAw88EAUFBam5bdu2jZtuummX6//5z3+OGTNmpPr/5JNPolOnTnH22WfHySefHM2bN49169bFrFmz4sEHH4ylS5em5jZu3Dj+8Y9/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uXP84Q9/iBUrVux03I9//ONYuHBhJJPJSCQS231/1apVceaZZ8b48eMrsl0AAAAAAAAosSob1BUWFkbPnj1j/vz5kUwmIyJS/7m1119/PaZMmZIK6JLJZBx77LFx7rnnxpFHHpkK7zZv3hxDhgyJ/Pz8Sn0OAAAAAAAA2JEqG9T9z//8TyxYsCAVwLVq1Sr+8pe/xAUXXJA27oEHHoiISAVyt912W7z22mvxr3/9Kz744IO45ZZbUt9bvXp13H333ZX+LAAAAAAAALCtKhvU/f3vf0+FdEcddVR88MEHcemll8bBBx+cNu7pp59OjfvWt74Vl1xySdr3/9//+39xwgknpHbjPfbYYxXfPAAAAAAAAOxGlQzq3nnnncjLy0uFa3/605+iTp062417991344svvoiIiEQiEeedd94O1xsxYkREfLPr7sMPP4yCgoIK6hwAAAAAAABKpkoGdR9++GHqc506daJXr147HPfCCy9ExH/eXde3b98djvv+97+f+pxMJuPTTz8tr1YBAAAAAABgj1TJoC4/Pz8ivtkld8ghh6SOttzWyy+/nPp8wAEHROfOnXc47qCDDkqrV69eXU6dAgAAAAAAwJ6pnukGdqSwsDD1uVatWjscs2nTppg2bVoqxOvevftOA72NGzeWf5MAAAAAAABQBlVyR13Dhg0j4ptjKj/77LMdjnn11Vdj7dq1qfoHP/jBTtdbsmRJWt2gQYOyNwkAAAAAAABlUCWDum9/+9upz59//nksXbp0uzEPPfRQRPzn/XQnnXTSTtd78cUXU58TiUS0bNmyvFoFAAAAAACAPVIlg7ouXbpE7dq1I5FIRHFxcfz2t79N+/7rr78eDz74YOqoy8MOOyy+9a1v7XCt9evXx1/+8pfU2COOOCIOOOCAin0AAAAAAAAA2I0qGdTVqlUrfvKTn6R2y40cOTJOO+20uP322+PKK6+MU045JTZt2hTJZDISiUT85Cc/2eE6H3/8cZx++umxaNGi1NgzzjijEp9k52bOnBkXXnhhtG/fPurXrx85OTmRm5sb3bp1i5tuumm74zorQmFhYYwePTr69esXBx10UNSsWTNq164dhx56aPTv3z/GjBlTIe/3mz17dtSoUSMSiUQkEomYMmVKud8DAAAAAACgqkskt6RhVUxeXl585zvfiS+//DIVsm2xpU4mk1G/fv1Y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Mh555JFUfcghh5RpJ1vz5s3jhBNOiGnTpkVExMKFC+OFF16IU045ZZfzxowZE2vWrEnVgwYN2uMeAKiaVqxYEbm5uZluo8pp165dplvIqLy8vGjSpEmm2wAAAADYp1XpX5N+6qmn4qc//Wls3LgxdS2ZTEajRo2id+/eccEFF8QVV1wRl156aQwZMiROOOGEqF+/firE2xLovfPOO9GtW7dYsmRJRp5j0KBB0bhx41T96KOPbnec5LZ+/vOfpwVkF1544Q7HjR49OhVeJhKJOPjgg3e65qWXXppWX3311Wl/tttatmxZ/PrXv07VOTk5aTvhAAAAAAAA2HNVNqjLy8uLwYMHR8R/AreTTjopXn311cjLy4tnn3027r777rj11lvjL3/5S9x///0xderUWLFiRbz66qsxbNiwqFmzZmqH3ccffxzDhw/PyLPUrFkzrrjiilRdXFwc/fv3j3nz5m03dvPmzXHllVfGmDFjUtdatGgRP/vZz8rcx5lnnhnt27dP1e+++24MGTIkioqKthu7ePHiOO200yIvLy917aKLLorWrVuXuQ8AAAAAAACq8NGXv/vd72Lt2rUR8U1Q97vf/S6uueaa3c7LysqK448/Po4//vj41a9+FQMHDow333wzIiJefPHFGD9+fPzXf/1Xhfa+I5dffnmMHTs23nnnnYiIWLp0aXTu3DmGDh0aPXr0iJycnJg/f36MHj06Pvjgg9S8RCIR9913X9SpU6fMPVSrVi3uu+++6N69e2on3cMPPxxvv/12DB8+PNq1axerV6+O6dOnxwMPPBAFBQWpuW3bto2bbrqpzD0AAAAAAADwjSoZ1G3atCkefPDB1G648847r0Qh3bbatm0bEydOjM6dO8enn34aEREPPfRQRoK6nJycePrpp6Nbt26xaNGiiIhYv3593HnnnXHnnXfudN5f/vKXOPXUU8utj2OPPTbuu+++GDZsWBQXF0dExPz58+Oqq67a6ZymTZvGxIkTo27duuXWBwBV2+Nvz4kGjRrvfuA+ori4ONas/CrtWv2GB0ZWVpU9fKBcrVrxZfTv3CHTbQAAAADsd6pkUDdjxozU+9kSiURcffXVe7xWo0aN4rLLLovLLrsskslkPP/887F58+aoVq1aebVbYq1atYrp06fHsGHD4rnnntvl2CZNmsRdd90V/fv3L/c+Bg8eHE2a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FW03dvHixXHaaadFXl5e6tpFF10UrVu33m7sj3/842jWrFmqfvXVV2Pw4MFRUFCw015efvnl6NWrV6xevTp1rUePHnHSSSeV+rkAAAAAAAD2Rhk9+rJ169Zx/fXX7/B7N954Y2on3I9//OM49NBD9+gederUidatW8fxxx8fLVu23ONey+ryyy+PsWPHxjvvvBMREUuXLo3OnTvH0KFDo0ePHpGTkxPz58+P0aNHxwcffJCal0gk4r777os6deqUuYdq1arFfffdF927d0/tpHv44Yfj7bffjuHDh0e7du1i9erVMX369HjggQfSgra2bdvGTTfdtMN1a9WqFXfddVecddZZqWsPP/xwvPjii9G/f//43ve+F02aNIkNGzbEggUL4v/+7/9i6tSpaWvk5ubGAw88UOZnBAAAAAAA2FskkhW9nW0PZWVlpYK6F154IXr16pXhjspuyZIl0a1bt1i0aFGJ59x2223bHVm5tdGjR6cdR9mmTZvdrv/AAw/EsGHDori4uEQ9NG3aNKZOnRpHHHHELsf99re/3WnwuistW7aMcePGRefOnUs9tzzNnTs3OnTokKrnzJmTtgOxvO1qxyGwvXr16mW6hX1Wfn5+5Obmpl17cdHyaNikSYY6orKtzM+Pkw5ulnYtLy8vmvg3AFAh/CwApefnAQCgolR2NrCtKnH05c5U0Qxxj7Vq1SqmT58effr02e3YJk2axNixY3cZ0u2pwYMHx4QJE6J58+a7Hdu9e/d48803dxvSRURcd911MWrUqLRjMHelWrVqMXDgwHjnnXcyHtIBAAAAAABUtowefbkro0aNSn2uzOSyojVv3jyeffbZePnll+PBBx+M6dOnx6effhqbNm2KAw88MDp27Binn356DB48OOrXr7/b9YYMGRJDhgwpdR+nnnpqLFiwIP75z3/G008/HbNnz44vv/wysrOz46CDDoquXbvGoEGDonfv3qVad8iQIXHOOefEY489Fi+88EK888478eWXX8aqVauiTp060ahRo/j2t78d3bp1iwEDBsQhhxxS6t4BAAAAAAD2BVX26EuobI6+hKrNUTcVx9GXOPoSoHL5WQBKz88DAEBFcfQlAAAAAAAA7Ieq7NGXn376aYWs27p16wpZFwAAAAAAAEqjygZ1Bx98cCQSiXJdM5FIxKZNm8p1TQAAAAAAANgTVTao28Ir9AAAAAAAANgXVemgbk9Cum134Qn6AAAAAAAAqIqqbFB3/fXXl3hsYWFhrFmzJhYvXhzvvPNOLF++PCK+Ce1atWoVv//976NRo0YV1SoAAAAAAACU2j4R1G3rtddei2uuuSamTp0aS5cujWuvvTamTJkSrVu3LscOAQAAAAAAYM9lZbqBinD88cfHlClT4uqrr45kMhmLFi2K//qv/4qNGzdmujUAAAAAAACIiH00qNvi97//ffTq1SsiIt5///248847M9wRAAAAAAAAfGOfDuoiIi699NLU57///e8Z7AQAAAAAAAD+Y58P6o4++uiIiEgmk7FgwYJYvnx5hjsCAAAAAACA/SCoy83NTas//fTTDHUCAAAAAAAA/7HPB3Xb7qDbvHlzhjoBAAAAAACA/9jng7onnngird52hx0AAAAAAABkwj4d1E2dOjWuu+66SCQSERFRu3btaNWqVYa7AgAAAAAAgIjqmW5gZ+699949mrdp06bIy8uLV199NV555ZUoLi6OiIhEIhGnnnpq5OTklGebAAAAAAAAsEeqbFA3YsSI1E64PZVMJiORSEQymYzs7Oz49a9/XU7dAQAAAAAAQNlU2aBui2QyWeo5WwK+LSFd9erV429/+1scddRR5d0eAAAAAAAA7JEq/Y66PQnptszbspuuR48e8eqrr8b5559fzt0BAAAAAADAnquyO+pGjRq1R/MSiUTUqFEjmjVrFt/5znfiwAMPLOfOAAAAAAAAoOyqbFA3ePDgTLcAAAAAAAAAFaZKH30JAAAAAAAA+ypBHQAAAAAAAGSAoA4AAAAAAAAyICPvqJs6dWombhsREd26dcvYvQEAAAAAAGCLjAR1PXr0iEQiUen3TSQSsWnTpkq/LwAAAAAAAGwrI0HdFslkMpO3BwAAAAAAgIzJ2DvqhHQAAAAAAADszzKyo27UqFGZuC0AAAAAAABUGRkJ6gYPHpyJ2wIAAAAAAECVkbGjLwEAAAAAAGB/JqgDAAAAAACADMjI0ZflYcWKFbFixYpYuXJlVK9ePRo0aBC5ublRr169TLcGAAAAAAAAu7VXBXVPPfVUjB07Nl599dX47LPPdjjm0EMPje9973vRv3//OP3006N69b3qEQEAAAAAANhP7BUp1tSpU2PEiBExf/78iIhIJpM7Hfvxxx/HJ598Eo888kg0btw4rrvuurj44osjkUhUVrsAAAAAAACwW1X+HXV33313nHzyyTF//vxUQLer0G3L95LJZOTn58cll1wSXbp0ic8//7xS+gUAAAAAAICSqNI76p566qn46U9/GslkMi2Aa9y4cXTu3DnatGkT9erVi02bNsXq1atjwYIF8f7778fq1asj4pvQLplMxjvvvBPdunWLyZMnR6tWrTL5SAAAAAAAABARVTioy8vLi8GDB0fEfwK3k046Ka6//vo4/vjjdzqvuLg4ZsyYEaNGjYp//etfUVhYGMlkMj7++OMYPnx4PP/885X1CAAAAAAAALBTVfboy9/97nexdu3a1HGXv/vd72LSpEm7DOkiIrKysuL444+Pf/zjH/Hee+/FMccck/reiy++GOPHj6/QvgEAAAAAAKAkqmRQt2nTpnjwwQcjkUhEIpGI8847L6655ppSr9O2bduYOHFitG7dOnXtoYceKs9WAQAAAAAAYI9UyaBuxowZsWbNmtRuuquvvnqP12rUqFFcdtllEfHN++2ef/752Lx5c7n0CQAAAAAAAHuqSgZ1//73v1OfmzRpEh07dizTeqeddlrq89q1a+Pzzz8v03oAAAAAAABQVlUyqMvPz4+IiEQiEQcddFCZ12vZsmVanZeXV+Y1AQAAAAAAoCyqZFBXp06d1OfCwsIyr7dx48a0ujzWBAAAAAAAgLKokkFds2bNIuKbd8otXrw4ioqKyrTeggUL0uomTZqUaT0AAAAAAAAoqyoZ1HXp0iUivjn6cv369fHkk0+Wab3HH3889TknJydatWpVpvUAAAAAAACgrKpkUNemTZvo1KlTRHyzq+7yyy+PL774Yo/Wmj9/fvz1r3+NRCIRiUQievToETVr1izHbgEAAAAAAKD0qmRQFxHxy1/+MpLJZCQSiVi+fHl06dIlpkyZUqo1pk6dGj179ozCwsJIJpMRETFs2LAK6BYAAAAAAABKp8oGdeedd1784Ac/SIV1S5cujR/84AfRvXv3uO++++LTTz/d4byVK1fG2LFj47TTTouePXvG8uXLI+KbYzRPOOGEGDBgQGU+BgAAAAAAAOxQ9Uw3sCuPP/549OrVK2bNmhWJRCKSyWRMmzYtpk2bFhER9erVi5YtW0bdunWjsLAwVqxYEZ9//nlq/paQL5lMxqGHHhqPPPJIph4FAAAAAAAA0lTpoO6AAw6IF198Mc4///x48sknI5FIRESkjrFcs2ZNrFmzZodzt7yTLplMxjHHHBNjx46N5s2bV1rvAAAAAAAAsCtV9ujLLRo2bBiPP/54PPbYY9G5c+dUSBfxnzBu668tkslkNG3aNP7whz/EjBkzok2bNploHwAAAAAAAHaoSu+o21r//v2jf//+8fbbb8ekSZPi9ddfj3nz5sXKlStj9erVkZOTEw0bNoyWLVvG97///ejRo0f88Ic/jOrV95pHBAAAAAAAYD+y16VYnTt3js6dO2e6DQAAAAAAACiTKn/0JQAAAAAAAOyL9roddbuzYsWKWLx4cWRlZcXBBx8cDRo0yHRLAAAAAAAAsJ29Zkfd7Nmz44477oiXXnpph99/++23o1u3btG0adPo0qVLdO7cOZo0aRI9e/aMl19+uZK7BQAAAAAAgF2r8kHd7Nmz4/jjj4+jjz46Lr300h0GddOmTYsTTzwxXnvttSguLo5kMhnJZDI2b94cr7zySpx00klx9dVXZ6B7AAAAAAAA2LEqffTl5MmTo1+/frF+/fpIJpORSCS2G7N58+YYMmRIFBYWRiKRiEQiEclkMvX9LfWf/vSnqF27dlx//fWV+QjAXiKZTEZBQUFs3LgxsrOzo169ejv87xwAAAAAACgvVTaoW7ZsWfTr1y/WrVuX+h/Lk8lkVKtWLW3c+PHj45NPPkkFcnXr1o2f//zn0bp165g9e3aMGjUqioqKIplMxk033RQDBgyIdu3aZeKRgCpm7ty58fjjj8fbb78d7777bqxatSr1vQYNGkSnTp2ic+fO/nsDAAAAAIAKUWWDul//+tepkC6ZTMaZZ54Z1113XRx11FFp48aMGRMRkdpx99xzz8Vxxx2X+v65554bJ598cmzevDmKi4vjb3/7W/z973+v1GcBqpbnnnsubrvttpg+ffpOx6xatSqmTJkSU6ZMif/93/+N4447Li677LLo3bt3JXYKAAAAAMC+rEq+o66oqCieeOKJ1E66s88+O5544ontQrqioqJ47rnnUkde9ujRIy2ki4jo3r17nH322an31k2cOLHSngOoWlasWBHDhg2Lc845Z5ch3Y5Mnz49BgwYEP/93/8dK1asqKAOAQAAAADYn1TJoO61115LvZcuIuLGG2/c4bhp06bF+vXrU/XZZ5+9w3FDhw5NfV66dGnk5eWVY7fA3mDOnDlx3HHHxeOPP16mdcaOHRvHHXdczJ07t5w6AwAAAABgf1Ulj75cvHhx6nOTJk12+m6ol156KSL+c+zlzo6k23b+559/Hrm5ueXULVDVzZkzJ0499dS0d9BtkZubG+edd158//vfj3bt2kXdunVj7dq18cEHH8TMmTPjkUce2S7c//zzz6Nv377x7LPPRvv27SvpKQAAAAAA2NdUyaAuPz8/IiISiUS0bNlyp+Nefvnl1OdWrVpF27ZtdziuWbNmqfUiItasWVNerQJV3IoVK+Lss8/eLqRr0KBB3HzzzXHuuedGTk5O2veaNm0abdu2jdNPPz2uu+66ePTRR+Oaa65JW2PVqlVx1llnxfTp06NRo0aV8CQAAAAAAOxrquTRl1sCtW0/b62goCDeeuut1PvpevbsudP1CgoKIiJSR2nWqFGjHLsFqrKrrroqPv/887Rrxx57bLzxxhvxk5/8ZLuQbls5OTnxk5/8JN5444049thj0773+eefxy9/+cty7xkAAAAAgP1DlQzqGjduHBHfBGtLly7d4Zjnn38+Nm3alArffvCDH+x0vY8++iitbtiwYTl1ClRlzz333HbvpDv22GPjqaeeSu20LalmzZrFU089tV1YN3bs2HjuuefK3CsAAAAAAPufKhnUderUKfU5Pz8/3nrrre3G3H333anPiUQiTjnllJ2uN378+NTn7OzsaNOmTfk0ClRpt912W1rdoEGDeOCBB6J27dp7tF7t2rVj9OjR0aBBg7Trf/3rX/ewQwAAAAAA9mdVMqjr2LFjtGjRInXs5RVXXBHr1q1Lff9vf/tbTJ48OXXsZdeuXSM3N3eHay1YsCDuuOOO1Njvfve7uz3qDtj7zZ07N6ZPn5527eabby71TrptNW/ePG6++ea0a6+99lp88MEHZVoXAAAAAID9T/VMN7AjWVlZ8bOf/Sx+/etfRyKRiGnTpkXbtm3juOOOi08//TRmzZoViUQikslkJBKJGDZs2HZrrFu3LsaOHRu/+c1vUu+oSyQS8ZOf/KSyHwfIgG2PvGzatGmce+655bL2ueeeGzfeeGPk5eWl3e+6664rl/UhkxrXrBkREdnr10X1tTUz3A2VJXv9utTf/ZeFhRnuBgAAAGD/USWDuohvdtE99thj8e6770YikYi8vLwYN25c6p10W3bIHXrooduFb7/4xS/ijjvuiGQy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WOjcJ06c0IABAyxFuvDwcA0bNkzXXnutIiIitG/fPn3wwQfatGmT2efpp59WixYtdOedd/rkPQIAAAAAPBcUFGTr3VMFLT/rdHYvvwsAAIDAoVAXILNnz9bKlSvNdvXq1bVw4UJ1797d0m/UqFH64osv1K9fP507d06S9MYbb+h3v/udOnXqVOo4Ro0apTNnzpjtzp07a/HixYqMjLT0GzdunEaOHKl33nlHknT+/Hk9+OCD2rRpU6FLcT711FP69ddfzfaVV16p5cuXq379+pZ+jz/+uF588UU9//zz5rZHHnlEN998s2rUqFHatwgAAAAAKEfS0tLK3NKbee+wC7SyuPQkAMA5nPTcQp5T6ayfd1nFM+oCICcnR02aNNHhw4fNbfPnz9fAgQMLHfP666/rj3/8o9m+/fbbtXjx4lLFsXz5cvXs2dNs161bVzt27FBERESB/d1ut6677jr98MMPxca9c+dOxcfHm3cChoeHa/v27WrYsGGh8QwcOFCffPKJ2X755Zc1duxYr9+Xr/CMOqBs45kUAACgouB3ASuekZcfhbr8+H3Af9xut1JTU+0OwzYpKSmKj4+3bNu+fbvjj8Ho6GhHFSqcjOdUoiA8o45n1FU4ixcvthTpunXrVmSRTpIeeugh/eMf/zDvUFuyZIkOHDigxo0blziO6dOnW9p///vfCy3SSReXP3nuued0xx13mNumTZtWYOwzZsxQ7prvuHHjiizSSdKECRMshbo333xTTzzxhFwuV7HvBQAAAAAAAKUXFBTkqD/GeiImJobPBAAQMFwWEQBz5861tEeMGFHsmCpVqqhfv35m2+12a+HChSWOISMjQ0uXLjXbERERGjx4cLHjevXqZSnmrVmzRunp6fn6zZs3z/w6KChIw4cPL3buq666SldccYXZ/uWXX7Rly5ZixwEAAAAAAAAAAFQE3FHnZ263W8uXLzfblSpVshTgitKrVy/NmDHDbK9atUqPPvpoieL473//q+zsbLPdu3dvhYWFFTsuODhYN910kxYsWCDp4vv58ssvNWDAALPPTz/9pGPHjpntDh06qEGDBh7F1atXL+3cudNsr1q1Sm3atPFoLAAAAACg/IuKitK+ffts27/b7c53QWrNmjVtXfItKirKtn0DAAAgsCjU+dnOnTuVlva/h1G2atVK1apV82hs27ZtLe1vv/22xHGsW7fO0u7YsaPHY9u2bWsW6i7FkbtQV9q5c/v222/1+OOPezweAAAAAFC+BQUF2f4sKJ7NA9jH7mfkpaSkeLQtkHg+HAIpOjpaSUlJtu2/oOdEwv5nZUZHR9u2byeiUOdnmzdvtrTzFqaK0qBBA0VGRurkyZOSLj7YMyMjo0QPUC5NHK1bt7a0f/nll4DNDQAAAAAAgIorNTW1zBXL7S4aJCUl8Yw8BAzPqSybeFams3Bphp/t3bvX0m7YsKFX4+vVq2dpl3Q5kNLEUVwM/pwbAAAAAAAAAACgouKOOj87evSope3ps9suqVu3rrZt22a2S3obcu5nyLlcrnwFsuJiyC1vDKV5jzExMQoJCTGfn3fy5EmdP39ewcHBHs9RkKSkJCUnJ3s1Zvv27ZZ23gKkr505c8av8wMVTXh4uN0hAAAA+AS/CwDe4/eBiiv3I2Nw0c6dO21dihAIJHJAwcgDgZW3FnDu3LmA7p9CnZ/lLRbVrFnTq/F5n2eXmZnpdQwZGRnKysqyzOlNIay4GEr7HsPDw81C3aX5a9So4dUceU2fPl0vvPBCqebo379/qcYDAAAAAAAA3urSpYvdIQCwGXnAXocPH/bqEV+lxdKXfpa3qBUaGurV+Lz9S3Llpb9jKAvvEQAAAAAAAAAAoLyhUOdnue8Uk7wvYuW9880wjDIXQ1l4jwAAAAAAAAAAAOUNS1/6WWmLUBcuXLC0q1atWuZiCA4OtqzZasd7zOuRRx7RXXfd5dWY06dP64cfflBERIQiIyPVoEEDValSpdSxoHzYu3evZbnTBQsWqHnz5vYFBCDgyAOAs5EDAGcjBwDORg4AnI0cgHPnzunw4cNmu2vXrgHdP4U6P8v7sGNvH0J49uxZS7skRSx/xxAeHm6Z89y5c17F6Yv3mFdcXJzi4uK8HtepU6dS7xsVQ/PmzdWyZUu7wwBgI/IA4GzkAMDZyAGAs5EDAGcjBzhTIJ9JlxdLX/pZtWrVLO2MjAyvxp8+fdrSjo2N9TqGvIU6X8dQ2veYu3/16tW5iw0AAAAAAAAAADgChTo/q1u3rqV94sQJr8YnJSVZ2o0aNfI6hqCgINWuXdtsZ2Vl5Su+lSaG0rzHtLQ0y9KXJXl/AAAAAAAAAAAA5RGFOj9r0aKFpX3gwAGvxudeF7V69eqKjo4OeByHDh2ytJs0aRKwuQEAAAAAAAAAACoqCnV+dvnll1va27Zt83js8ePHdfLkSbPdoUMHW+LYuXOnpZ03Dn/ODQAAAAAAAAAAUFFRqPOz9u3bKywszGyvX79eOTk5Ho1dv369pX399deXOI4bb7zR0v7mm288HltcHP6cGwAAAAAAAAAAoKKiUOdnVapUsRSyTp06pa+//tqjsUuWLLG0e/fuXeI4br311nxzG4ZR7LisrCytWrXKbLdo0ULNmjWz9OnUqZOqVatmtr/88kudOXPGo7hyv8eIiAjdcMMNHo0DAAAAAAAAAAAo7yjUBcDgwYMt7ZkzZxY7Jj09XR999JHZbtKkSanuNqtTp446d+5stvfv368VK1YUO27OnDk6ffq02R4yZEi+PsHBwerfv7/ZPnPmjObMmVPs3P/973+1e/dus33nnXcqNDS02HEAAAAAAAAAAAAVAYW6ABgyZIhiYmLM9ty5c/Mt+ZjXmDFjLAWykSNHFtgvMTFRLpfLfDVu3LjQOR999FFLe/z48Tp//nyh/Y8ePao//elPZjskJETDhg3zaO4XX3zR8ny9vDIyMjR69GjLtlGjRhXaHwAAAAAAAAAAoKKhUBcAoaGhGjt2rNl2u90aNGiQdu7cma9vTk6OnnzyScsdaXXr1s1X1CqJAQMGqGXLlmb7p59+UkJCgrKzs/P1PXjwoPr06aOkpCRz28MPP6yGDRsWOHf79u3Vs2dPs3306FENHDjQUmy8JDU1Vf3797e8/379+um6664r0fsCAAAAAAAAAAAojyrbHYBTPPHEE5o3b55+/PFHSdKRI0fUrl07DRs2TN26dVNISIh27dqlxMREbd++3Rzncrk0a9YshYeHlzqGSpUqadasWeratat5J92HH36ojRs3asSIEYqPj9epU6e0bt06zZ49WxkZGebYZs2aaeLEiUXOP23aNLVr106nTp2SJK1atUrx8fEaOXKkrrnmGp09e1YbN27Uu+++q+TkZHNcVFSUpk2bVur3BwAAAAAAAAAAUJ5QqAuQkJAQLViwQF26dNGBAwckSZmZmZo2bVqRRapXX31Vt912m8/i6NSpk2bNmqXhw4fL7XZLknbt2qVx48YVOqZWrVpasmSJqlWrVuTczZo107x583THHXcoKytL0sU765577rlCx4SHh2vRokWqV69eCd4NAAAAAAAAAABA+UWhLoAaNGigdevWafjw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",
      "text/plain": [
       "<Figure size 1800x900 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# calculate the errors\n",
    "# fig\n",
    "x = np.array([list(map(float, ratio.split('-'))) for ratio in eval_ratios]) # ratios])\n",
    "y = np.array([\n",
    "    sum(OBSERVED_LOSSES[MODEL_SZIE][ratio][domain][STEP] * valid_weight[domain] for domain in DOMAINS_2_SUBDOMAINS) \n",
    "    for ratio in eval_ratios# ratios\n",
    "])\n",
    "errors = []\n",
    "\n",
    "linear_domain_prediction = sum(mixture_law(x, linear_domain_params[domain]).numpy() * valid_weight[domain] for domain in DOMAINS_2_SUBDOMAINS)\n",
    "errors.append(np.abs(y - linear_domain_prediction))\n",
    "mlp_params = torch.load(\"data/5Mix/mix5mlp.pt\")\n",
    "for dim in [1,3,5,10,30]:\n",
    "    state_dict = mlp_params[dim]\n",
    "    mlp = MixtureMLP(dim=dim)\n",
    "    mlp.load_state_dict(state_dict)\n",
    "    mlp.eval()\n",
    "    with torch.no_grad():\n",
    "        mlp_prediction = mlp(torch.tensor(x)).squeeze().numpy()\n",
    "    errors.append(np.abs(y - mlp_prediction))\n",
    "fig = plt.figure(figsize=(6, 3), dpi=300)\n",
    "bp = plt.boxplot(\n",
    "    errors, labels=[\"Explicit\", \"Implicit \\n(K=1)\", \"Implicit \\n(K=3)\", \"Implicit \\n(K=5)\", \"Implicit \\n(K=10)\", \"Implicit \\n(K=30)\"],\n",
    "    patch_artist=True\n",
    ")\n",
    "colors = ['#FFEADD'] + [\"#CDF5FD\"]*5 # '#F3F8FF', '#F3F8FF', '#F3F8FF', '#F3F8FF', '#F3F8FF', '#F3F8FF']  # Blue, Green, Red\n",
    "for patch, color in zip(bp['boxes'], colors):\n",
    "    patch.set_facecolor(color)\n",
    "for median in bp['medians']:\n",
    "    median.set_color('#FF6868')  # Set the color of the median lines to red\n",
    "\n",
    "plt.ylim(0, 0.06)\n",
    "# plt.cla()\n",
    "# plt.violinplot(errors)\n",
    "# plt.xticks(range(len(errors)), [\"ALL Lin\", \"ALL Dom\", \"1\", \"3\", \"5\", \"10\", \"20\", \"30\"])\n",
    "# plt.savefig(\"mixture_violon_20.png\")\n",
    "# plt.ylim(0, 0.05)\n",
    "plt.axvspan(0.6, 1.4, color='gray', alpha=0.1, linewidth=0)  # For 'Separate'\n",
    "plt.axvspan(3.6, 4.4, color='gray', alpha=0.1, linewidth=0) \n",
    "for error in errors:\n",
    "    print(np.mean(error))\n",
    "plt.ylabel(\"Absolute Errors\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"savefigs/5mix_end2end.png\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fb6476a7-a7ca-4770-b8fa-c01328ba5e87",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(eval_ratios)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "119888f6-9889-47fe-8102-5d6efccc026c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mlp_params2 = mlp_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d20f27a9-71f2-4070-befa-b94d859c5bf9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
