{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from inspect import signature\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.optim import AdamW\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import copy\n",
    "from scipy.interpolate import CubicSpline\n",
    "from scipy.stats import gaussian_kde\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Swish(nn.Module):\n",
    "    def forward(self, x):\n",
    "        return x * torch.sigmoid(x)\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self,\n",
    "                 in_dim = 1,\n",
    "                 out_dim = 1,\n",
    "                 widths = [64, 128, 128, 64]):\n",
    "        super(MLP, self).__init__()\n",
    "        \n",
    "        widths = [in_dim] + list(widths) + [out_dim]\n",
    "        self.n_layers = len(widths) - 1\n",
    "        self.layers = nn.ModuleList([nn.Linear(widths[i], widths[i+1]) for i in range(self.n_layers)])\n",
    "        #self.activation = Swish()#nn.ReLU()\n",
    "        self.activation = nn.LeakyReLU(inplace=True)\n",
    "    def forward(self, x):\n",
    "        for i in range(self.n_layers - 1):\n",
    "            x = self.layers[i](x)\n",
    "            x = self.activation(x)\n",
    "        x = self.layers[-1](x)\n",
    "        return x\n",
    "\n",
    "#----------------------------\n",
    "\n",
    "def train(model, optimizer, scheduler, training_loader, val_loader, epochs = 10, loss =  nn.MSELoss(), freq_print = 1, tag = \"\"):\n",
    "\n",
    "    best_model_testing_error = 1000\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        train_mse = 0.0\n",
    "        for step, (input_batch, output_batch) in enumerate(training_loader):\n",
    "            optimizer.zero_grad()\n",
    "            output_pred_batch = model(input_batch)\n",
    "            loss_f = loss(output_pred_batch, output_batch)\n",
    "            loss_f.backward()\n",
    "            optimizer.step()\n",
    "            train_mse += loss_f.item()\n",
    "        train_mse /= len(training_loader)\n",
    "\n",
    "        scheduler.step()\n",
    "\n",
    "        with torch.no_grad():\n",
    "            model.eval()\n",
    "            test_relative_l2 = 0.0\n",
    "            for step, (input_batch, output_batch) in enumerate(val_loader):\n",
    "                output_pred_batch = model(input_batch)\n",
    "                #loss_f = (torch.mean((abs(output_pred_batch - output_batch))) / torch.mean(abs(output_batch))) * 100\n",
    "                #loss_f = torch.mean(100* torch.norm(output_pred_batch - output_batch, p=2, dim = [1])/torch.norm(output_batch, p=2,dim = [1]))\n",
    "                loss_f = torch.mean(torch.norm(output_pred_batch - output_batch, p=2, dim = [1]))\n",
    "\n",
    "                test_relative_l2 += loss_f.item()\n",
    "            test_relative_l2 /= len(val_loader)\n",
    "\n",
    "\n",
    "        if test_relative_l2 < best_model_testing_error:\n",
    "            best_model_testing_error = test_relative_l2\n",
    "            best_model = copy.deepcopy(model)\n",
    "            torch.save(best_model, f\"saved_models/model_1d_{tag}.pkl\")\n",
    "\n",
    "        if epoch % freq_print == 0: print(\"######### Epoch:\", epoch, \" ######### Train Loss:\", train_mse, \" ######### Relative L1 Test Norm:\", test_relative_l2)\n",
    "\n",
    "    return best_model\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gaussian_pdf(x, mean, std_dev = 0.5):\n",
    "    return (1 / (std_dev * np.sqrt(2 * np.pi))) * np.exp(-((x - mean) ** 2) / (2 * std_dev ** 2))\n",
    "\n",
    "#-----\n",
    "\n",
    "def func_linear(x):\n",
    "    if x<0:\n",
    "        return -x\n",
    "    else:\n",
    "        return x\n",
    "\n",
    "def func_nonlinear(x):\n",
    "    if x<0:\n",
    "        return -0.5*x**4-x**3+x**2+0.75*x+np.sin(4*x)\n",
    "    else:\n",
    "        return 0.5*x**4-x**3+0.25*x**2+0.75*x+np.sin(4*x)\n",
    "\n",
    "def func_nonlinear2(x):\n",
    "    if x<0:\n",
    "        return -0.25*x**4-x**3\n",
    "    else:\n",
    "        return -0.25*x**4+x**3\n",
    "\n",
    "def func_sine(x):\n",
    "    if x<0:\n",
    "        return np.sin(4*x) - 2*np.sin(x) + x**2\n",
    "    else:\n",
    "        return np.sin(x) + 2*np.sin(2*x) + x**2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x14a69cf7e490>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Train:\n",
    "F = func_linear\n",
    "\n",
    "if F is func_sine:\n",
    "    label_neg = \"$f(x) = sin(4x) - 2sin(x) + x^2$\"\n",
    "    label_pos = \"$f(x) = sin(x) + 2sin(x) + x^2$\"\n",
    "    file_label = \"sine\"\n",
    "    N_train_pos = 50\n",
    "    N_train_neg = 5\n",
    "elif F is func_linear:\n",
    "    label_neg = \"$f(x) = -x$\"\n",
    "    label_pos = \"$f(x) = x$\"\n",
    "    N_train_pos = 50\n",
    "    N_train_neg = 5\n",
    "    file_label = \"linear\"\n",
    "elif F is func_nonlinear:\n",
    "    label_neg = \"$f(x) = -0.5x^4-x^3+x^2+0.75x+sin(4x)$\"\n",
    "    label_pos = \"$f(x) =  0.5x^4-x^3+0.25x^2+0.75x+sin(4x)$\"\n",
    "    file_label = \"ninelinear1\"\n",
    "    N_train_pos = 50\n",
    "    N_train_neg = 5\n",
    "elif F is func_nonlinear2:\n",
    "    label_neg = \"$f(x) = -0.25x^4-x^3$\"\n",
    "    label_pos = \"$f(x) = -0.25x^4+x^3$\"\n",
    "    file_label = \"ninelinear2\"\n",
    "    N_train_pos = 100\n",
    "    N_train_neg = 10\n",
    "\n",
    "\n",
    "vectorized_func = np.vectorize(F)\n",
    "\n",
    "x_train_pos = np.random.normal(loc=1.0, scale=0.5, size=N_train_pos)\n",
    "x_train_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_train_neg)\n",
    "noise = 0.1\n",
    "y_train_pos = vectorized_func(x_train_pos) + np.random.normal(loc = 0.0, scale=noise,size=N_train_pos)\n",
    "y_train_neg = vectorized_func(x_train_neg) + np.random.normal(loc=0.0, scale=noise, size=N_train_neg)\n",
    "\n",
    "#---------------------\n",
    "# Val:\n",
    "\n",
    "N_val_pos = N_train_pos//2\n",
    "N_val_neg = N_train_neg//2\n",
    "x_val_pos = np.random.normal(loc=1.0, scale=0.5, size=N_val_pos)\n",
    "x_val_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_val_neg)\n",
    "y_val_pos = vectorized_func(x_val_pos)\n",
    "y_val_neg = vectorized_func(x_val_neg)\n",
    "\n",
    "#---------------------\n",
    "# Test:\n",
    "\n",
    "N_test_pos = 512\n",
    "N_test_neg = 512\n",
    "x_test_pos = np.random.normal(loc=1.0, scale=0.5, size=N_test_pos)\n",
    "x_test_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_test_neg)\n",
    "y_test_pos = vectorized_func(x_test_pos)\n",
    "y_test_neg = vectorized_func(x_test_neg)\n",
    "\n",
    "#---------------------\n",
    "# PLOT:\n",
    "\n",
    "X = np.linspace(-2.5,2.5,100)\n",
    "Y = vectorized_func(X)\n",
    "plt.plot(X,Y,\"--\", color = \"green\", linewidth = 2)\n",
    "plt.scatter(x_train_pos, y_train_pos, s = 10, color = \"red\", label = label_pos)\n",
    "plt.scatter(x_train_neg, y_train_neg, s = 10, color = \"blue\", label = label_neg)\n",
    "\n",
    "plt.grid(True)\n",
    "\n",
    "vectorized_func_gauss = np.vectorize(gaussian_pdf)\n",
    "X = np.linspace(0.25,2-0.25, 100)\n",
    "Y_pdf_pos = vectorized_func_gauss(X, 1) + F(1) - 0.4\n",
    "plt.plot(X,Y_pdf_pos, color = \"red\")\n",
    "X = np.linspace(-1.75,-0.25, 100)\n",
    "Y_pdf_neg = vectorized_func_gauss(X, -1) + F(-1) - 0.4\n",
    "plt.plot([-1, -1], [F(-1) + 2, F(-1)-1.6], \"--\", color = \"blue\")\n",
    "plt.plot([1, 1], [F(1) + 2, F(1)-1.6], \"--\", color = \"red\")\n",
    "\n",
    "plt.plot(X,Y_pdf_neg, color = \"blue\")\n",
    "plt.legend(fontsize = 14)\n",
    "###plt.savefig(f\"Figures/1d_exp/{file_label}_function_plot.png\", dpi=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "batch_size = 32\n",
    "\n",
    "inp_train = np.concatenate((x_train_pos, x_train_neg), axis = 0).reshape(-1, 1)\n",
    "out_train = np.concatenate((y_train_pos, y_train_neg), axis = 0).reshape(-1, 1)\n",
    "inp_train, out_train = torch.tensor(inp_train).to(\"cuda\").type(torch.float32), torch.tensor(out_train).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "inp_val = np.concatenate((x_val_pos, x_val_neg), axis = 0).reshape(-1, 1)\n",
    "out_val = np.concatenate((y_val_pos, y_val_neg), axis = 0).reshape(-1, 1)\n",
    "inp_val, out_val = torch.tensor(inp_val).to(\"cuda\").type(torch.float32), torch.tensor(out_val).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "dataset_train = TensorDataset(inp_train, out_train)\n",
    "dataloader_train = DataLoader(dataset_train, batch_size=batch_size, shuffle=True)\n",
    "dataset_val = TensorDataset(inp_val, out_val)\n",
    "dataloader_val = DataLoader(dataset_val, batch_size=batch_size, shuffle=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 625,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "######### Epoch: 0  ######### Train Loss: 0.2859320193529129  ######### Relative L1 Test Norm: 0.5051354765892029\n",
      "######### Epoch: 10  ######### Train Loss: 0.03275572322309017  ######### Relative L1 Test Norm: 0.08253418654203415\n",
      "######### Epoch: 20  ######### Train Loss: 0.012717131059616804  ######### Relative L1 Test Norm: 0.07299808412790298\n",
      "######### Epoch: 30  ######### Train Loss: 0.012630349025130272  ######### Relative L1 Test Norm: 0.03247005119919777\n",
      "######### Epoch: 40  ######### Train Loss: 0.011579124722629786  ######### Relative L1 Test Norm: 0.03218558058142662\n",
      "######### Epoch: 50  ######### Train Loss: 0.010796038433909416  ######### Relative L1 Test Norm: 0.030743654817342758\n",
      "######### Epoch: 60  ######### Train Loss: 0.009683917975053191  ######### Relative L1 Test Norm: 0.027582284063100815\n",
      "######### Epoch: 70  ######### Train Loss: 0.010445724707096815  ######### Relative L1 Test Norm: 0.030460240319371223\n",
      "######### Epoch: 80  ######### Train Loss: 0.009425619384273887  ######### Relative L1 Test Norm: 0.02565276250243187\n",
      "######### Epoch: 90  ######### Train Loss: 0.01017800159752369  ######### Relative L1 Test Norm: 0.04238176345825195\n",
      "######### Epoch: 100  ######### Train Loss: 0.009910961147397757  ######### Relative L1 Test Norm: 0.032205887138843536\n",
      "######### Epoch: 110  ######### Train Loss: 0.009461992885917425  ######### Relative L1 Test Norm: 0.0308480653911829\n",
      "######### Epoch: 120  ######### Train Loss: 0.010089351795613766  ######### Relative L1 Test Norm: 0.03168182075023651\n",
      "######### Epoch: 130  ######### Train Loss: 0.009161977330222726  ######### Relative L1 Test Norm: 0.03222157433629036\n",
      "######### Epoch: 140  ######### Train Loss: 0.010329254902899265  ######### Relative L1 Test Norm: 0.03864620253443718\n",
      "######### Epoch: 150  ######### Train Loss: 0.00968959741294384  ######### Relative L1 Test Norm: 0.032290760427713394\n",
      "######### Epoch: 160  ######### Train Loss: 0.010258267633616924  ######### Relative L1 Test Norm: 0.035464316606521606\n",
      "######### Epoch: 170  ######### Train Loss: 0.010114417877048254  ######### Relative L1 Test Norm: 0.03531791642308235\n",
      "######### Epoch: 180  ######### Train Loss: 0.00934613961726427  ######### Relative L1 Test Norm: 0.034879688173532486\n",
      "######### Epoch: 190  ######### Train Loss: 0.009476989042013884  ######### Relative L1 Test Norm: 0.04067274555563927\n",
      "######### Epoch: 200  ######### Train Loss: 0.008842008886858821  ######### Relative L1 Test Norm: 0.0335405133664608\n",
      "######### Epoch: 210  ######### Train Loss: 0.009841921739280224  ######### Relative L1 Test Norm: 0.03328554704785347\n",
      "######### Epoch: 220  ######### Train Loss: 0.008910211501643062  ######### Relative L1 Test Norm: 0.03815838322043419\n",
      "######### Epoch: 230  ######### Train Loss: 0.009874314535409212  ######### Relative L1 Test Norm: 0.03815213963389397\n",
      "######### Epoch: 240  ######### Train Loss: 0.009421213995665312  ######### Relative L1 Test Norm: 0.0366213358938694\n",
      "######### Epoch: 250  ######### Train Loss: 0.009583976585417986  ######### Relative L1 Test Norm: 0.03682176396250725\n",
      "######### Epoch: 260  ######### Train Loss: 0.009506579488515854  ######### Relative L1 Test Norm: 0.03378880396485329\n",
      "######### Epoch: 270  ######### Train Loss: 0.009454340673983097  ######### Relative L1 Test Norm: 0.038027435541152954\n",
      "######### Epoch: 280  ######### Train Loss: 0.009381644427776337  ######### Relative L1 Test Norm: 0.03907382860779762\n",
      "######### Epoch: 290  ######### Train Loss: 0.009477633982896805  ######### Relative L1 Test Norm: 0.03901352733373642\n",
      "######### Epoch: 300  ######### Train Loss: 0.00963834160938859  ######### Relative L1 Test Norm: 0.040521904826164246\n",
      "######### Epoch: 310  ######### Train Loss: 0.009173434227705002  ######### Relative L1 Test Norm: 0.03559868037700653\n",
      "######### Epoch: 320  ######### Train Loss: 0.00958337215706706  ######### Relative L1 Test Norm: 0.03831150382757187\n",
      "######### Epoch: 330  ######### Train Loss: 0.009513519704341888  ######### Relative L1 Test Norm: 0.04452996328473091\n",
      "######### Epoch: 340  ######### Train Loss: 0.009169172961264849  ######### Relative L1 Test Norm: 0.040732745081186295\n",
      "######### Epoch: 350  ######### Train Loss: 0.00986471213400364  ######### Relative L1 Test Norm: 0.039787884801626205\n",
      "######### Epoch: 360  ######### Train Loss: 0.009246121626347303  ######### Relative L1 Test Norm: 0.04188720881938934\n",
      "######### Epoch: 370  ######### Train Loss: 0.0087485711555928  ######### Relative L1 Test Norm: 0.04014446213841438\n",
      "######### Epoch: 380  ######### Train Loss: 0.009633472189307213  ######### Relative L1 Test Norm: 0.0363616868853569\n",
      "######### Epoch: 390  ######### Train Loss: 0.009658409748226404  ######### Relative L1 Test Norm: 0.04145323112607002\n",
      "######### Epoch: 400  ######### Train Loss: 0.009352477267384529  ######### Relative L1 Test Norm: 0.04029145836830139\n",
      "######### Epoch: 410  ######### Train Loss: 0.009044849313795567  ######### Relative L1 Test Norm: 0.03528375178575516\n",
      "######### Epoch: 420  ######### Train Loss: 0.009851017966866493  ######### Relative L1 Test Norm: 0.040782380849123\n",
      "######### Epoch: 430  ######### Train Loss: 0.009282527025789022  ######### Relative L1 Test Norm: 0.035131100565195084\n",
      "######### Epoch: 440  ######### Train Loss: 0.009987873490899801  ######### Relative L1 Test Norm: 0.04386896267533302\n",
      "######### Epoch: 450  ######### Train Loss: 0.009757698979228735  ######### Relative L1 Test Norm: 0.03986075147986412\n",
      "######### Epoch: 460  ######### Train Loss: 0.009034790098667145  ######### Relative L1 Test Norm: 0.03948807716369629\n",
      "######### Epoch: 470  ######### Train Loss: 0.009468717966228724  ######### Relative L1 Test Norm: 0.0379156731069088\n",
      "######### Epoch: 480  ######### Train Loss: 0.00895508867688477  ######### Relative L1 Test Norm: 0.03942834958434105\n",
      "######### Epoch: 490  ######### Train Loss: 0.008794768713414669  ######### Relative L1 Test Norm: 0.037982989102602005\n"
     ]
    }
   ],
   "source": [
    "learning_rate = 0.01\n",
    "weight_decay = 1e-10\n",
    "step_size = 50\n",
    "gamma = 0.8\n",
    "epochs = 500\n",
    "\n",
    "tag = \"tmp\"\n",
    "\n",
    "model = MLP(widths = [128]).to(\"cuda\")\n",
    "optimizer = AdamW(model.parameters(), lr=learning_rate, weight_decay=weight_decay)\n",
    "scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=step_size, gamma=gamma)\n",
    "\n",
    "model = train(model, optimizer, scheduler, dataloader_train, dataloader_val, epochs = epochs, freq_print=10, tag = tag)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 626,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MEDIAN POS REL 0.014554738998413086 MEAN POS REL 0.015282695181667805\n",
      "MEDIAN NEG REL 0.07615208625793457 MEAN NEG REL 0.0746309757232666\n",
      " \n",
      "MEDIAN POS  0.014554738998413086 MEAN POS  0.015282695181667805\n",
      "MEDIAN NEG  0.07615208625793457 MEAN NEG  0.0746309757232666\n"
     ]
    },
    {
     "data": {
      "image/png": "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eeuttwqsnzJlilSsWFE6duwY9n2vvPKKiov47LPP5MYbb5SHHnpI0tPTZdSoUUps4AKrc/DgQeWaOHnypIrhGDRokHov3FXXXHNNxAKDWN+sWTNJS0uT+++/Xxo0aKAuyC1btlSuIKOsW7fOdvECwQVat25d6DXdZfPJJ58Y2pY+DvMYz7b+9a9/qed777034hh8JoiZefrpp+Wll16SVatWGTpGQghJCgGP4SS30axZgUB6eiCAWdYfWMZ6J7mN2rRpo5br1q0buOyyy/Jf3717t3I1DBgwQC2Huo1WrlypXq9Xr56a72BGjx6ttj1mzJj8db/99ltg586dhY7jm2++CZQpUybQsmXLAuuXLFmitoHHjBkzCrzWs2dPtX769OmG/9+rrrpKvWfbtm0Bu+jSpYvax9q1a8O+jv8zIyPD0LY6d+6strV69eqYtwW3UrFixQLp6emB33//PewYfKb6PAc/GjZsGNi8ebOhY6XbiPjBreE0cj02v653G8FUnpWVpXoVXX755XLs2DFxG7Nni3TpIrJzZ8H1OTnaerzuROsLgjr1u264JGCNieQywp06XocrqFKlSgVeGzp0qFSpUkWmw+R0BriJatasWWg7l112mfq84X46depUoddhdUGAauixAqPtILDdb775Rrm2atWqJXZx+PDhfNdOOMqVK5c/JhHbev311+X06dNy1113SWpqatgxvXv3lsWLFyv3IH5rcOH17NlTzS2yk3799VdDx0sIIb7ONsKJ9h//+Ic0bdpUuRpw0XMTcA09/LBmawkF61JSRJDY0aGDSITrSVK444475LHHHlOuosaNG6sL35VXXlkg3iIYxKGADz/8UF38QilRooRs2rSpwLoNGzbIs88+K59++qns2bOnkFg5cOCAVK9evcC6+vXrF9o2XFPg0KFDhv43CBe4sPD/RGP06NEqo+e7776T0qVLS/PmzdUxuy3zBqIFnyHihoqKWQrNUMLn/eabb6q/4UacPHmyDB482PbjJYQQ14oX3PnjogfhAhBv4TaWLy9scQkVMDt2aOOcVEYDlhIE3s6YMUO6du2qLt6wqkTil19+Uc+IbzHCihUr5Prrr8+PCUFgb5kyZdTFFTEsX375pYq9CGdhCJfeDfIMBhHp8S7hhFAoiCMZMGCA6lCO4xkyZIi0bdtWvv766/z9RkK3kkSyiBw5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#inp_test_pos = np.concatenate((x_test_pos, x_test_neg), axis = 0).reshape(-1, 1)\n",
    "#out_test_pos = np.concatenate((y_test_pos, y_test_neg), axis = 0).reshape(-1, 1)\n",
    "inp_test_pos, out_test_pos = torch.tensor(x_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "inp_test_neg, out_test_neg = torch.tensor(x_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "\n",
    "pred_test_pos = model(inp_test_pos)\n",
    "pred_test_neg = model(inp_test_neg)\n",
    "\n",
    "err_pos = torch.norm(out_test_pos - pred_test_pos, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "err_neg = torch.norm(out_test_neg - pred_test_neg, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "mean_pos = round(torch.mean(err_pos).item(),3)\n",
    "mean_neg = round(torch.mean(err_neg).item(),3)\n",
    "\n",
    "#err_pos = out_test_pos - pred_test_pos\n",
    "#err_neg = out_test_neg - pred_test_neg\n",
    "plt.scatter(inp_test_pos[:,0].detach().cpu().numpy(), err_pos.detach().cpu().numpy(), label = f\"Mean $L_2$ {mean_pos}\", color = \"red\")\n",
    "plt.scatter(inp_test_neg[:,0].detach().cpu().numpy(), err_neg.detach().cpu().numpy(),label = f\"Mean $L_2$ {mean_neg}\", color = \"blue\")\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "#plt.ylim([0,2])\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize = 14)\n",
    "###plt.savefig(f\"Figures/1d_exp/{file_label}_error_plot.png\", dpi=400)\n",
    "\n",
    "print(\"MEDIAN POS REL\", torch.median(err_pos).item(), \"MEAN POS REL\", torch.mean(err_pos).item())\n",
    "print(\"MEDIAN NEG REL\", torch.median(err_neg).item(), \"MEAN NEG REL\", torch.mean(err_neg).item())\n",
    "\n",
    "print(\" \")\n",
    "\n",
    "err_pos  = torch.norm(out_test_pos - pred_test_pos, p = 2, dim = [1])\n",
    "err_neg  = torch.norm(out_test_neg - pred_test_neg, p = 2, dim = [1])\n",
    "print(\"MEDIAN POS \", torch.median(err_pos).item(), \"MEAN POS \", torch.mean(err_pos).item())\n",
    "print(\"MEDIAN NEG \", torch.median(err_neg).item(), \"MEAN NEG \", torch.mean(err_neg).item())\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 618,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = np.linspace(-2.5,2.5,100)\n",
    "Y = vectorized_func(X)\n",
    "plt.plot(X,Y, color = \"green\", label = \"Ground Truth\", linewidth = 4)\n",
    "#plt.scatter(inp_test_pos[:,0].detach().cpu().numpy(), pred_test_pos[:,0].detach().cpu().numpy())\n",
    "#plt.scatter(inp_test_neg[:,0].detach().cpu().numpy(), pred_test_neg[:,0].detach().cpu().numpy())\n",
    "\n",
    "X = np.linspace(-2.5,2.5,100)\n",
    "X = torch.tensor(X).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "Y_pred = model(X)[:,0]\n",
    "plt.plot(X[:,0].detach().cpu().numpy(),Y_pred.detach().cpu().numpy(),\"--\", color = \"orange\", label = \"Prediction\",linewidth = 4)\n",
    "\n",
    "\n",
    "plt.legend(fontsize = 14)\n",
    "plt.grid(True)\n",
    "####plt.savefig(f\"Figures/1d_exp/{file_label}_prediction_plot.png\", dpi=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "######### Epoch: 0  ######### Train Loss: 10.080018997192383  ######### Relative L1 Test Norm: 3.387083053588867\n",
      "######### Epoch: 0  ######### Train Loss: 11.783330917358398  ######### Relative L1 Test Norm: 2.8959362506866455\n",
      "######### Epoch: 0  ######### Train Loss: 9.630470275878906  ######### Relative L1 Test Norm: 2.866251230239868\n",
      "######### Epoch: 0  ######### Train Loss: 10.676615715026855  ######### Relative L1 Test Norm: 2.80753493309021\n",
      "######### Epoch: 0  ######### Train Loss: 12.503750801086426  ######### Relative L1 Test Norm: 3.0135910511016846\n",
      "######### Epoch: 0  ######### Train Loss: 10.429573059082031  ######### Relative L1 Test Norm: 2.9948482513427734\n",
      "######### Epoch: 0  ######### Train Loss: 12.816717147827148  ######### Relative L1 Test Norm: 3.255802631378174\n",
      "######### Epoch: 0  ######### Train Loss: 12.363408088684082  ######### Relative L1 Test Norm: 2.5601913928985596\n",
      "######### Epoch: 0  ######### Train Loss: 10.08592414855957  ######### Relative L1 Test Norm: 2.9533636569976807\n",
      "######### Epoch: 0  ######### Train Loss: 12.780998229980469  ######### Relative L1 Test Norm: 2.9979183673858643\n",
      "20 0.1359521896 0.9377641678 [0.0953678563] [0.80003780125]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 10.104194641113281  ######### Relative L1 Test Norm: 3.07012677192688\n",
      "######### Epoch: 0  ######### Train Loss: 9.156378746032715  ######### Relative L1 Test Norm: 2.5003645420074463\n",
      "######### Epoch: 0  ######### Train Loss: 9.423738956451416  ######### Relative L1 Test Norm: 2.6888740062713623\n",
      "######### Epoch: 0  ######### Train Loss: 11.030572891235352  ######### Relative L1 Test Norm: 2.214308500289917\n",
      "######### Epoch: 0  ######### Train Loss: 9.771901845932007  ######### Relative L1 Test Norm: 2.5772342681884766\n",
      "######### Epoch: 0  ######### Train Loss: 11.06445837020874  ######### Relative L1 Test Norm: 2.9518980979919434\n",
      "######### Epoch: 0  ######### Train Loss: 9.458455085754395  ######### Relative L1 Test Norm: 2.577608108520508\n",
      "######### Epoch: 0  ######### Train Loss: 8.54334306716919  ######### Relative L1 Test Norm: 2.4684550762176514\n",
      "######### Epoch: 0  ######### Train Loss: 9.195574283599854  ######### Relative L1 Test Norm: 2.458587408065796\n",
      "######### Epoch: 0  ######### Train Loss: 11.534697532653809  ######### Relative L1 Test Norm: 2.738039016723633\n",
      "40 0.0785202831 0.3583980799 [0.0953678563, 0.049096530299999996] [0.80003780125, 0.48294493555]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 10.400884628295898  ######### Relative L1 Test Norm: 2.281070351600647\n",
      "######### Epoch: 0  ######### Train Loss: 9.253900210062662  ######### Relative L1 Test Norm: 2.068995714187622\n",
      "######### Epoch: 0  ######### Train Loss: 8.386178970336914  ######### Relative L1 Test Norm: 2.2966092824935913\n",
      "######### Epoch: 0  ######### Train Loss: 11.250959714253744  ######### Relative L1 Test Norm: 2.8139824867248535\n",
      "######### Epoch: 0  ######### Train Loss: 9.122565269470215  ######### Relative L1 Test Norm: 2.1007624864578247\n",
      "######### Epoch: 0  ######### Train Loss: 8.654406547546387  ######### Relative L1 Test Norm: 2.482677936553955\n",
      "######### Epoch: 0  ######### Train Loss: 10.096866607666016  ######### Relative L1 Test Norm: 2.6961896419525146\n",
      "######### Epoch: 0  ######### Train Loss: 8.740523974100748  ######### Relative L1 Test Norm: 2.3646883964538574\n",
      "######### Epoch: 0  ######### Train Loss: 7.487147808074951  ######### Relative L1 Test Norm: 1.8985809087753296\n",
      "######### Epoch: 0  ######### Train Loss: 6.908278147379558  ######### Relative L1 Test Norm: 1.8679551482200623\n",
      "80 0.0337862968 0.5151691437 [0.0953678563, 0.049096530299999996, 0.0345939733] [0.80003780125, 0.48294493555, 0.25206615775]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 7.790172815322876  ######### Relative L1 Test Norm: 1.5848379532496135\n",
      "######### Epoch: 0  ######### Train Loss: 6.056392153104146  ######### Relative L1 Test Norm: 1.2736878395080566\n",
      "######### Epoch: 0  ######### Train Loss: 6.818135142326355  ######### Relative L1 Test Norm: 1.3721513748168945\n",
      "######### Epoch: 0  ######### Train Loss: 8.285955111185709  ######### Relative L1 Test Norm: 2.0576399167378745\n",
      "######### Epoch: 0  ######### Train Loss: 6.419575134913127  ######### Relative L1 Test Norm: 0.9872967600822449\n",
      "######### Epoch: 0  ######### Train Loss: 5.957930485407512  ######### Relative L1 Test Norm: 1.0739202896753948\n",
      "######### Epoch: 0  ######### Train Loss: 5.8325841426849365  ######### Relative L1 Test Norm: 0.9514675140380859\n",
      "######### Epoch: 0  ######### Train Loss: 7.818116029103597  ######### Relative L1 Test Norm: 1.4798932075500488\n",
      "######### Epoch: 0  ######### Train Loss: 8.351680676142374  ######### Relative L1 Test Norm: 1.8085420529047649\n",
      "######### Epoch: 0  ######### Train Loss: 6.482725620269775  ######### Relative L1 Test Norm: 1.1299455960591633\n",
      "160 0.0215096362 0.3238028884 [0.0953678563, 0.049096530299999996, 0.0345939733, 0.0248689838] [0.80003780125, 0.48294493555, 0.25206615775, 0.1157789081]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 3.720531322739341  ######### Relative L1 Test Norm: 1.0869090557098389\n",
      "######### Epoch: 0  ######### Train Loss: 3.3433309576728125  ######### Relative L1 Test Norm: 0.9838846822579702\n",
      "######### Epoch: 0  ######### Train Loss: 3.5593012246218594  ######### Relative L1 Test Norm: 1.0770474274953206\n",
      "######### Epoch: 0  ######### Train Loss: 3.3670720837332984  ######### Relative L1 Test Norm: 1.0788417061169941\n",
      "######### Epoch: 0  ######### Train Loss: 4.706205579367551  ######### Relative L1 Test Norm: 1.072717954715093\n",
      "######### Epoch: 0  ######### Train Loss: 4.07371444051916  ######### Relative L1 Test Norm: 1.158258964618047\n",
      "######### Epoch: 0  ######### Train Loss: 4.346286421472376  ######### Relative L1 Test Norm: 0.9136456449826559\n",
      "######### Epoch: 0  ######### Train Loss: 3.9183976514772936  ######### Relative L1 Test Norm: 1.126589943965276\n",
      "######### Epoch: 0  ######### Train Loss: 5.724649851972407  ######### Relative L1 Test Norm: 0.7669186592102051\n",
      "######### Epoch: 0  ######### Train Loss: 4.441884333437139  ######### Relative L1 Test Norm: 0.9281100531419119\n",
      "320 0.0179479662 0.0950570628 [0.0953678563, 0.049096530299999996, 0.0345939733, 0.0248689838, 0.01731958705] [0.80003780125, 0.48294493555, 0.25206615775, 0.1157789081, 0.09522732719999999]\n",
      " \n"
     ]
    }
   ],
   "source": [
    "E_pos = []\n",
    "E_neg = []\n",
    "#N_train = [40, 90, 150, 300, 600, 1000]\n",
    "N_train = [20, 40,80, 160, 320]\n",
    "num_runs = 10\n",
    "\n",
    "F = func_sine\n",
    "vectorized_func = np.vectorize(F)\n",
    "\n",
    "N_test_pos = 512\n",
    "N_test_neg = 512\n",
    "x_test_pos = np.random.normal(loc=1.0, scale=0.5, size=N_test_pos)\n",
    "x_test_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_test_neg)\n",
    "y_test_pos = vectorized_func(x_test_pos)\n",
    "y_test_neg = vectorized_func(x_test_neg)\n",
    "\n",
    "\n",
    "for N_train_pos in N_train:\n",
    "    E_tmp_pos = []\n",
    "    E_tmp_neg = []\n",
    "    for _ in range(num_runs):\n",
    "        N_train_neg = N_train_pos//10\n",
    "        x_train_pos = np.random.normal(loc=1.0, scale=0.5, size=N_train_pos)\n",
    "        x_train_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_train_neg)\n",
    "        noise = 0.1\n",
    "        y_train_pos = vectorized_func(x_train_pos) + np.random.normal(loc = 0.0, scale=noise,size=N_train_pos)\n",
    "        y_train_neg = vectorized_func(x_train_neg) + np.random.normal(loc=0.0, scale=noise, size=N_train_neg)\n",
    "\n",
    "        #---------------------\n",
    "        # Val:\n",
    "\n",
    "        N_val_pos = N_train_pos//2\n",
    "        N_val_neg = N_train_neg//2\n",
    "        x_val_pos = np.random.normal(loc=1.0, scale=0.5, size=N_val_pos)\n",
    "        x_val_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_val_neg)\n",
    "        y_val_pos = vectorized_func(x_val_pos)\n",
    "        y_val_neg = vectorized_func(x_val_neg)\n",
    "\n",
    "        batch_size = 32\n",
    "\n",
    "        inp_train = np.concatenate((x_train_pos, x_train_neg), axis = 0).reshape(-1, 1)\n",
    "        out_train = np.concatenate((y_train_pos, y_train_neg), axis = 0).reshape(-1, 1)\n",
    "        inp_train, out_train = torch.tensor(inp_train).to(\"cuda\").type(torch.float32), torch.tensor(out_train).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "        inp_val = np.concatenate((x_val_pos, x_val_neg), axis = 0).reshape(-1, 1)\n",
    "        out_val = np.concatenate((y_val_pos, y_val_neg), axis = 0).reshape(-1, 1)\n",
    "        inp_val, out_val = torch.tensor(inp_val).to(\"cuda\").type(torch.float32), torch.tensor(out_val).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "        dataset_train = TensorDataset(inp_train, out_train)\n",
    "        dataloader_train = DataLoader(dataset_train, batch_size=batch_size, shuffle=True)\n",
    "        dataset_val = TensorDataset(inp_val, out_val)\n",
    "        dataloader_val = DataLoader(dataset_val, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "        learning_rate = 0.005\n",
    "        weight_decay = 1e-6\n",
    "        step_size = 50\n",
    "        gamma = 0.8\n",
    "        epochs = 500\n",
    "\n",
    "        tag = \"tmp\"\n",
    "\n",
    "        model = MLP(widths = [64, 64]).to(\"cuda\")\n",
    "        optimizer = AdamW(model.parameters(), lr=learning_rate, weight_decay=weight_decay)\n",
    "        scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=step_size, gamma=gamma)\n",
    "\n",
    "        model = train(model, optimizer, scheduler, dataloader_train, dataloader_val, epochs = epochs, freq_print=501, tag = tag)\n",
    "\n",
    "\n",
    "        inp_test_pos, out_test_pos = torch.tensor(x_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "        inp_test_neg, out_test_neg = torch.tensor(x_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "\n",
    "        pred_test_pos = model(inp_test_pos)\n",
    "        pred_test_neg = model(inp_test_neg)\n",
    "        err_pos = torch.norm(out_test_pos - pred_test_pos, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "        err_neg = torch.norm(out_test_neg - pred_test_neg, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "        mean_pos = round(torch.mean(err_pos).item(),10)\n",
    "        mean_neg = round(torch.mean(err_neg).item(),10)\n",
    "        E_tmp_pos.append(mean_pos)\n",
    "        E_tmp_neg.append(mean_neg)\n",
    "\n",
    "    E_pos.append(np.median(np.array(E_tmp_pos)))\n",
    "    E_neg.append(np.median(np.array(E_tmp_neg)))\n",
    "    print(N_train_pos, mean_pos, mean_neg,E_pos,E_neg)\n",
    "    print(\" \")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ciEoKPbKI40kJQFPbJ48eZAcgoOD9YfQx8+Dtx27p47HHT83uX6GK5/XVc/F5/Cm95X49t+FQD4PIXGMINmpcNtL9e7d29OH4BV8+Tx427F76njc8XOT62e48nm97f0gnqH3gW+dB6XbRER8ANNt/OR74cIFj38CFwkUGkkSEfEBadKkwdChQ62vIuIeGkkSERERcUIjSSIiIiJOKEgSERERcUJBkoiIiIgTCpJEREREnFCQJCIiIuKEgiQRER/HpUrq1auH0NBQlC1bFj/++KOnD0nEL6gFgIiIjzt27BhOnDiB8uXL4/jx46hUqRL27duHDBkyePrQRHya1m4TEfFxDz74oLVRzpw5kT17dpw9e1ZBkkgSKd0mIuJhq1atQsuWLa0VyVOkSIE5c+bE2CcsLAwFChRA2rRp8dBDD2HDhg1On2vTpk24c+cO8ubN64YjF/FvCpJERDzsypUrKFeunBUIOTN9+nQMGDDAWpbkzz//tPZt2rQpTp486bAfR4+6dOmCTz/91E1HLuLfVJMkIuJFOJI0e/ZstG7d+u59HDmqUqUKJkyYYN2OiIiwRor69OmDV1991brvxo0baNy4MXr06IHOnTt77PhF/IlGkkREvNjNmzetFFqjRo3u3hcUFGTdXr9+vXXbZrPhqaeeQoMGDRQgibiQgiQRES92+vRpq8YoR44cDvfzNmey0dq1a62UHGuZOMON2/bt2z10xCL+Q7PbRER8XK1atawUnIi4lkaSRES8GKfzBwcHW32QouJtTvcXkeSjIElExIulTp3aag65dOnSu/dx1Ii3q1ev7tFjE/F3SreJiHjY5cuXsX///ru3w8PDsWXLFmTNmhX58uWzpv937doVlStXRtWqVTF27FirbUC3bt08etwi/k4tAEREPGzFihWoX79+jPsZGH355ZfW/3P6/6hRo6xibRZmjx8/3moNICLJR0GSiIiIiBOqSRIRERFxQkGSiIiIiBMKkkREREScUJAkIiIi4oSCJBEREREnFCSJiIiIOKEgSURERMQJBUkiIiIiTihIEvGwFClSoF69eknu2MznGTZsmMuOS2J66qmnrPP8999/+9zpWbx4MWrWrIn77rvP+h1at26NQPn3IZJYWrtN5L8/xPfCZrPpvInPYFDXqlUrZMmSxVrvLXPmzChRooSnD0vE6ylIEgEwdOjQGOeB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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#nonlinear1\n",
    "#N_train = [20, 40,80, 160, 320, 500]\n",
    "#E_pos = [0.07917059955, 0.0458901096, 0.03587754815, 0.0276526073, 0.02337893655, 0.01940843745]\n",
    "#E_neg =  [0.9047985971, 0.4922428429, 0.13498322670000001, 0.08447036150000001, 0.05450362525, 0.04667258075]\n",
    "\n",
    "#nonlinear2\n",
    "#N_train = [20, 40,80, 160, 320]\n",
    "#E_pos, E_neg = [0.0462670997, 0.03280890545, 0.02088025955, 0.01466236495, 0.010785177850000001], [0.1635358632, 0.1206093505, 0.07737971095, 0.04410991255, 0.02488801815]\n",
    "\n",
    "#linear\n",
    "#N_train = [20, 30, 40, 50, 60]\n",
    "#[0.0358799379, 0.0226040911, 0.02081691845, 0.0176277291, 0.01776444635] [0.1191874184, 0.08351454885000001, 0.048314053600000004, 0.04253362305, 0.04443947785]\n",
    "\n",
    "#sine\n",
    "#N_train = [20, 40,80, 160, 320]\n",
    "#[0.0953678563, 0.049096530299999996, 0.0345939733, 0.0248689838, 0.01731958705] [0.80003780125, 0.48294493555, 0.25206615775, 0.1157789081, 0.09522732719999999]\n",
    "\n",
    "\n",
    "plt.scatter(N_train, E_pos, color = \"red\", label = \"+ class\")\n",
    "plt.plot(N_train, E_pos, color = \"red\")\n",
    "\n",
    "plt.scatter(N_train, E_neg, color = \"blue\",label = \"-  class\")\n",
    "plt.plot(N_train, E_neg,color = \"blue\")\n",
    "\n",
    "plt.grid(True)\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")\n",
    "\n",
    "plt.xlabel(\"Training samples of + class\", fontsize = 14)\n",
    "plt.ylabel(\"$L_2$ error\", fontsize = 14)\n",
    "plt.legend(fontsize = 14)\n",
    "\n",
    "file_label = \"10percent_SCALE_func_sine\"\n",
    "plt.savefig(f\"Figures/1d_exp/{file_label}.png\", dpi=400)\n",
    "\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "######### Epoch: 0  ######### Train Loss: 0.955575806753976  ######### Relative L1 Test Norm: 0.725677028298378\n",
      "######### Epoch: 499  ######### Train Loss: 0.008282775525003672  ######### Relative L1 Test Norm: 0.019855164224281907\n",
      "######### Epoch: 0  ######### Train Loss: 1.1501333202634538  ######### Relative L1 Test Norm: 0.9280887842178345\n",
      "######### Epoch: 499  ######### Train Loss: 0.008119901642203331  ######### Relative L1 Test Norm: 0.01898770988918841\n",
      "######### Epoch: 0  ######### Train Loss: 1.364610995565142  ######### Relative L1 Test Norm: 0.858655110001564\n",
      "######### Epoch: 499  ######### Train Loss: 0.009689446272594588  ######### Relative L1 Test Norm: 0.01890328386798501\n",
      "######### Epoch: 0  ######### Train Loss: 1.4181515319006783  ######### Relative L1 Test Norm: 0.5741769373416901\n",
      "######### Epoch: 499  ######### Train Loss: 0.009075197191642863  ######### Relative L1 Test Norm: 0.03552373684942722\n",
      "######### Epoch: 0  ######### Train Loss: 1.273962846824101  ######### Relative L1 Test Norm: 0.6541831195354462\n",
      "######### Epoch: 499  ######### Train Loss: 0.008257715164550714  ######### Relative L1 Test Norm: 0.024190096417441964\n",
      "######### Epoch: 0  ######### Train Loss: 1.3173709682055883  ######### Relative L1 Test Norm: 0.7662597596645355\n",
      "######### Epoch: 499  ######### Train Loss: 0.010452035681477614  ######### Relative L1 Test Norm: 0.021839614026248455\n",
      "######### Epoch: 0  ######### Train Loss: 1.4875343527112688  ######### Relative L1 Test Norm: 0.9150680303573608\n",
      "######### Epoch: 499  ######### Train Loss: 0.008962703136993306  ######### Relative L1 Test Norm: 0.022680850001052022\n",
      "######### Epoch: 0  ######### Train Loss: 1.1895301852907454  ######### Relative L1 Test Norm: 0.9302420616149902\n",
      "######### Epoch: 499  ######### Train Loss: 0.008567561595035451  ######### Relative L1 Test Norm: 0.028744590934365988\n",
      "######### Epoch: 0  ######### Train Loss: 0.981821175132479  ######### Relative L1 Test Norm: 0.8297359496355057\n",
      "######### Epoch: 499  ######### Train Loss: 0.010358438561005252  ######### Relative L1 Test Norm: 0.021348356967791915\n",
      "######### Epoch: 0  ######### Train Loss: 1.1640906248773848  ######### Relative L1 Test Norm: 0.8359346985816956\n",
      "######### Epoch: 499  ######### Train Loss: 0.008176498580724001  ######### Relative L1 Test Norm: 0.022642625961452723\n",
      "######### Epoch: 0  ######### Train Loss: 1.2877221277781896  ######### Relative L1 Test Norm: 0.5855321288108826\n",
      "######### Epoch: 499  ######### Train Loss: 0.009000154810824565  ######### Relative L1 Test Norm: 0.022257038857787848\n",
      "######### Epoch: 0  ######### Train Loss: 0.9141377551215035  ######### Relative L1 Test Norm: 0.7611521780490875\n",
      "######### Epoch: 499  ######### Train Loss: 0.00904125380995018  ######### Relative L1 Test Norm: 0.03115790570154786\n",
      "######### Epoch: 0  ######### Train Loss: 1.4412790111133031  ######### Relative L1 Test Norm: 0.8497709482908249\n",
      "######### Epoch: 499  ######### Train Loss: 0.00853632383846811  ######### Relative L1 Test Norm: 0.03283560601994395\n",
      "######### Epoch: 0  ######### Train Loss: 1.6950027814933233  ######### Relative L1 Test Norm: 0.7020129561424255\n",
      "######### Epoch: 499  ######### Train Loss: 0.007460943223642451  ######### Relative L1 Test Norm: 0.04040065873414278\n",
      "######### Epoch: 0  ######### Train Loss: 0.8893150985240936  ######### Relative L1 Test Norm: 0.6487977802753448\n",
      "######### Epoch: 499  ######### Train Loss: 0.009210462016718728  ######### Relative L1 Test Norm: 0.03527577081695199\n",
      "######### Epoch: 0  ######### Train Loss: 1.077694215944835  ######### Relative L1 Test Norm: 0.7825901061296463\n",
      "######### Epoch: 499  ######### Train Loss: 0.009996333758213691  ######### Relative L1 Test Norm: 0.021582212997600436\n",
      "######### Epoch: 0  ######### Train Loss: 1.2998954951763153  ######### Relative L1 Test Norm: 0.7810382395982742\n",
      "######### Epoch: 499  ######### Train Loss: 0.009310376165168626  ######### Relative L1 Test Norm: 0.02393989241681993\n",
      "######### Epoch: 0  ######### Train Loss: 1.0084669249398368  ######### Relative L1 Test Norm: 0.7063340395689011\n",
      "######### Epoch: 499  ######### Train Loss: 0.009736657408731324  ######### Relative L1 Test Norm: 0.026258878875523806\n",
      "######### Epoch: 0  ######### Train Loss: 0.8976984109197345  ######### Relative L1 Test Norm: 0.7559337913990021\n",
      "######### Epoch: 499  ######### Train Loss: 0.00843737886420318  ######### Relative L1 Test Norm: 0.02682299120351672\n",
      "######### Epoch: 0  ######### Train Loss: 0.7812832295894623  ######### Relative L1 Test Norm: 0.6512970179319382\n",
      "######### Epoch: 499  ######### Train Loss: 0.008451570424118213  ######### Relative L1 Test Norm: 0.03368623927235603\n",
      "200 0.0088515142 0.1263604909 [0.0145418085] [0.0626290422]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 1.246076226234436  ######### Relative L1 Test Norm: 0.7771859914064407\n",
      "######### Epoch: 499  ######### Train Loss: 0.010056149746690477  ######### Relative L1 Test Norm: 0.03264524322003126\n",
      "######### Epoch: 0  ######### Train Loss: 1.232495665550232  ######### Relative L1 Test Norm: 0.7633831202983856\n",
      "######### Epoch: 499  ######### Train Loss: 0.008959750977477856  ######### Relative L1 Test Norm: 0.015983911231160164\n",
      "######### Epoch: 0  ######### Train Loss: 0.9848197528294155  ######### Relative L1 Test Norm: 0.7967479377985001\n",
      "######### Epoch: 499  ######### Train Loss: 0.010395490364836795  ######### Relative L1 Test Norm: 0.021820533089339733\n",
      "######### Epoch: 0  ######### Train Loss: 1.0977673871176583  ######### Relative L1 Test Norm: 0.677047997713089\n",
      "######### Epoch: 499  ######### Train Loss: 0.008514268855963434  ######### Relative L1 Test Norm: 0.018451912328600883\n",
      "######### Epoch: 0  ######### Train Loss: 1.1148752059255327  ######### Relative L1 Test Norm: 0.7382052093744278\n",
      "######### Epoch: 499  ######### Train Loss: 0.010316687103893076  ######### Relative L1 Test Norm: 0.03114750375971198\n",
      "######### Epoch: 0  ######### Train Loss: 1.123431316443852  ######### Relative L1 Test Norm: 0.7625150978565216\n",
      "######### Epoch: 499  ######### Train Loss: 0.009955117212874549  ######### Relative L1 Test Norm: 0.012810398126021028\n",
      "######### Epoch: 0  ######### Train Loss: 1.029957000698362  ######### Relative L1 Test Norm: 0.7833541929721832\n",
      "######### Epoch: 499  ######### Train Loss: 0.011023959810180324  ######### Relative L1 Test Norm: 0.021052773809060454\n",
      "######### Epoch: 0  ######### Train Loss: 1.4311015073742186  ######### Relative L1 Test Norm: 0.7247130572795868\n",
      "######### Epoch: 499  ######### Train Loss: 0.007652863993176392  ######### Relative L1 Test Norm: 0.03877149103209376\n",
      "######### Epoch: 0  ######### Train Loss: 0.9525476608957563  ######### Relative L1 Test Norm: 0.772617444396019\n",
      "######### Epoch: 499  ######### Train Loss: 0.008886616610522782  ######### Relative L1 Test Norm: 0.021757408510893583\n",
      "######### Epoch: 0  ######### Train Loss: 0.6118042937346867  ######### Relative L1 Test Norm: 0.711497038602829\n",
      "######### Epoch: 499  ######### Train Loss: 0.008837340399622917  ######### Relative L1 Test Norm: 0.02038757735863328\n",
      "######### Epoch: 0  ######### Train Loss: 1.369268536567688  ######### Relative L1 Test Norm: 0.7002640217542648\n",
      "######### Epoch: 499  ######### Train Loss: 0.00773704271497471  ######### Relative L1 Test Norm: 0.015643241815268993\n",
      "######### Epoch: 0  ######### Train Loss: 1.2906326396124703  ######### Relative L1 Test Norm: 0.799268051981926\n",
      "######### Epoch: 499  ######### Train Loss: 0.007974577535476004  ######### Relative L1 Test Norm: 0.031217821408063173\n",
      "######### Epoch: 0  ######### Train Loss: 1.2546843034880502  ######### Relative L1 Test Norm: 0.7788636684417725\n",
      "######### Epoch: 499  ######### Train Loss: 0.009309382510504552  ######### Relative L1 Test Norm: 0.030108977109193802\n",
      "######### Epoch: 0  ######### Train Loss: 1.0534276068210602  ######### Relative L1 Test Norm: 0.7269393056631088\n",
      "######### Epoch: 499  ######### Train Loss: 0.00835464455719505  ######### Relative L1 Test Norm: 0.027541219722479582\n",
      "######### Epoch: 0  ######### Train Loss: 1.4547215487275804  ######### Relative L1 Test Norm: 0.725050613284111\n",
      "######### Epoch: 499  ######### Train Loss: 0.010315782656627042  ######### Relative L1 Test Norm: 0.030759091023355722\n",
      "######### Epoch: 0  ######### Train Loss: 1.6919650478022439  ######### Relative L1 Test Norm: 0.796490341424942\n",
      "######### Epoch: 499  ######### Train Loss: 0.009808845618473632  ######### Relative L1 Test Norm: 0.03264221828430891\n",
      "######### Epoch: 0  ######### Train Loss: 0.967940058026995  ######### Relative L1 Test Norm: 0.8072874546051025\n",
      "######### Epoch: 499  ######### Train Loss: 0.01015364085989339  ######### Relative L1 Test Norm: 0.025316234678030014\n",
      "######### Epoch: 0  ######### Train Loss: 1.2131309637001582  ######### Relative L1 Test Norm: 0.7895248979330063\n",
      "######### Epoch: 499  ######### Train Loss: 0.009388485657317298  ######### Relative L1 Test Norm: 0.017898873193189502\n",
      "######### Epoch: 0  ######### Train Loss: 1.5917559351239885  ######### Relative L1 Test Norm: 0.747138187289238\n",
      "######### Epoch: 499  ######### Train Loss: 0.009734423232397862  ######### Relative L1 Test Norm: 0.017308010486885905\n",
      "######### Epoch: 0  ######### Train Loss: 1.145536184310913  ######### Relative L1 Test Norm: 0.830084964632988\n",
      "######### Epoch: 499  ######### Train Loss: 0.008399137162736483  ######### Relative L1 Test Norm: 0.026179074542596936\n",
      "200 0.0137471426 0.0209147111 [0.0145418085, 0.01482689195] [0.0626290422, 0.035439837749999994]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 1.0222236886620522  ######### Relative L1 Test Norm: 0.6540316492319107\n",
      "######### Epoch: 499  ######### Train Loss: 0.008119808393530548  ######### Relative L1 Test Norm: 0.019516341853886843\n",
      "######### Epoch: 0  ######### Train Loss: 0.9682380855083466  ######### Relative L1 Test Norm: 0.7006614357233047\n",
      "######### Epoch: 499  ######### Train Loss: 0.009359359624795616  ######### Relative L1 Test Norm: 0.017978761345148087\n",
      "######### Epoch: 0  ######### Train Loss: 1.5683309882879257  ######### Relative L1 Test Norm: 0.8019703179597855\n",
      "######### Epoch: 499  ######### Train Loss: 0.007850655529182404  ######### Relative L1 Test Norm: 0.02177195157855749\n",
      "######### Epoch: 0  ######### Train Loss: 0.9457913637161255  ######### Relative L1 Test Norm: 0.6423737108707428\n",
      "######### Epoch: 499  ######### Train Loss: 0.010894671664573252  ######### Relative L1 Test Norm: 0.034534815698862076\n",
      "######### Epoch: 0  ######### Train Loss: 1.2075837552547455  ######### Relative L1 Test Norm: 0.7598320841789246\n",
      "######### Epoch: 499  ######### Train Loss: 0.01090868009487167  ######### Relative L1 Test Norm: 0.0281873089261353\n",
      "######### Epoch: 0  ######### Train Loss: 1.7469149008393288  ######### Relative L1 Test Norm: 0.6535636931657791\n",
      "######### Epoch: 499  ######### Train Loss: 0.010702299128752202  ######### Relative L1 Test Norm: 0.020745322108268738\n",
      "######### Epoch: 0  ######### Train Loss: 1.4575364887714386  ######### Relative L1 Test Norm: 0.8111535757780075\n",
      "######### Epoch: 499  ######### Train Loss: 0.008189033309463412  ######### Relative L1 Test Norm: 0.018363528419286013\n",
      "######### Epoch: 0  ######### Train Loss: 0.9886385053396225  ######### Relative L1 Test Norm: 0.807354599237442\n",
      "######### Epoch: 499  ######### Train Loss: 0.010685493005439639  ######### Relative L1 Test Norm: 0.020177658181637526\n",
      "######### Epoch: 0  ######### Train Loss: 0.9770095758140087  ######### Relative L1 Test Norm: 0.6946679651737213\n",
      "######### Epoch: 499  ######### Train Loss: 0.009675782406702638  ######### Relative L1 Test Norm: 0.01872491161338985\n",
      "######### Epoch: 0  ######### Train Loss: 1.1059812754392624  ######### Relative L1 Test Norm: 0.7533543258905411\n",
      "######### Epoch: 499  ######### Train Loss: 0.010860888403840363  ######### Relative L1 Test Norm: 0.020806763553991914\n",
      "######### Epoch: 0  ######### Train Loss: 0.9981325194239616  ######### Relative L1 Test Norm: 0.8100486099720001\n",
      "######### Epoch: 499  ######### Train Loss: 0.00893483473919332  ######### Relative L1 Test Norm: 0.015023290645331144\n",
      "######### Epoch: 0  ######### Train Loss: 1.2315938919782639  ######### Relative L1 Test Norm: 0.8106347322463989\n",
      "######### Epoch: 499  ######### Train Loss: 0.007890445878729224  ######### Relative L1 Test Norm: 0.01817985763773322\n",
      "######### Epoch: 0  ######### Train Loss: 1.514907717704773  ######### Relative L1 Test Norm: 0.8151305317878723\n",
      "######### Epoch: 499  ######### Train Loss: 0.0098233338794671  ######### Relative L1 Test Norm: 0.017992953769862652\n",
      "######### Epoch: 0  ######### Train Loss: 1.032223753631115  ######### Relative L1 Test Norm: 0.8832004517316818\n",
      "######### Epoch: 499  ######### Train Loss: 0.009387844416778535  ######### Relative L1 Test Norm: 0.023838091641664505\n",
      "######### Epoch: 0  ######### Train Loss: 1.0344804301857948  ######### Relative L1 Test Norm: 0.693964347243309\n",
      "######### Epoch: 499  ######### Train Loss: 0.010157356213312596  ######### Relative L1 Test Norm: 0.021793078165501356\n",
      "######### Epoch: 0  ######### Train Loss: 1.0878362208604813  ######### Relative L1 Test Norm: 0.7890880852937698\n",
      "######### Epoch: 499  ######### Train Loss: 0.009134877531323582  ######### Relative L1 Test Norm: 0.024515066295862198\n",
      "######### Epoch: 0  ######### Train Loss: 0.9401367679238319  ######### Relative L1 Test Norm: 0.6515884250402451\n",
      "######### Epoch: 499  ######### Train Loss: 0.009683995216619223  ######### Relative L1 Test Norm: 0.025290097575634718\n",
      "######### Epoch: 0  ######### Train Loss: 1.2197631746530533  ######### Relative L1 Test Norm: 0.9233521372079849\n",
      "######### Epoch: 499  ######### Train Loss: 0.011853239266201854  ######### Relative L1 Test Norm: 0.02148808352649212\n",
      "######### Epoch: 0  ######### Train Loss: 1.1467388793826103  ######### Relative L1 Test Norm: 0.8330628275871277\n",
      "######### Epoch: 499  ######### Train Loss: 0.008438582241069525  ######### Relative L1 Test Norm: 0.019208904821425676\n",
      "######### Epoch: 0  ######### Train Loss: 1.1439140103757381  ######### Relative L1 Test Norm: 0.7564137578010559\n",
      "######### Epoch: 499  ######### Train Loss: 0.010240274772513658  ######### Relative L1 Test Norm: 0.0281895874068141\n",
      "200 0.0128638558 0.0361987315 [0.0145418085, 0.01482689195, 0.01441303965] [0.0626290422, 0.035439837749999994, 0.0235342989]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 1.094708612561226  ######### Relative L1 Test Norm: 0.6746638417243958\n",
      "######### Epoch: 499  ######### Train Loss: 0.009731316659599542  ######### Relative L1 Test Norm: 0.03157461546361447\n",
      "######### Epoch: 0  ######### Train Loss: 1.067124354839325  ######### Relative L1 Test Norm: 0.6724450349807739\n",
      "######### Epoch: 499  ######### Train Loss: 0.010128815844655036  ######### Relative L1 Test Norm: 0.01626858152449131\n",
      "######### Epoch: 0  ######### Train Loss: 1.2764723777770997  ######### Relative L1 Test Norm: 0.7977915525436401\n",
      "######### Epoch: 499  ######### Train Loss: 0.009754897141829134  ######### Relative L1 Test Norm: 0.03438814394176006\n",
      "######### Epoch: 0  ######### Train Loss: 1.0812496483325957  ######### Relative L1 Test Norm: 0.7171050906181335\n",
      "######### Epoch: 499  ######### Train Loss: 0.01003877497278154  ######### Relative L1 Test Norm: 0.02254132032394409\n",
      "######### Epoch: 0  ######### Train Loss: 1.3360546827316284  ######### Relative L1 Test Norm: 0.9376175165176391\n",
      "######### Epoch: 499  ######### Train Loss: 0.0101654842030257  ######### Relative L1 Test Norm: 0.020239681378006934\n",
      "######### Epoch: 0  ######### Train Loss: 0.6646126210689545  ######### Relative L1 Test Norm: 0.5392193257808685\n",
      "######### Epoch: 499  ######### Train Loss: 0.008720235526561737  ######### Relative L1 Test Norm: 0.024107076600193976\n",
      "######### Epoch: 0  ######### Train Loss: 0.7625135093927383  ######### Relative L1 Test Norm: 0.5538616478443146\n",
      "######### Epoch: 499  ######### Train Loss: 0.010635457932949066  ######### Relative L1 Test Norm: 0.02871515676379204\n",
      "######### Epoch: 0  ######### Train Loss: 1.0822234570980072  ######### Relative L1 Test Norm: 0.7118413805961609\n",
      "######### Epoch: 499  ######### Train Loss: 0.010539385583251714  ######### Relative L1 Test Norm: 0.026254828646779062\n",
      "######### Epoch: 0  ######### Train Loss: 1.0448674499988555  ######### Relative L1 Test Norm: 0.7214158654212952\n",
      "######### Epoch: 499  ######### Train Loss: 0.010684857098385691  ######### Relative L1 Test Norm: 0.01805900186300278\n",
      "######### Epoch: 0  ######### Train Loss: 1.0017298758029938  ######### Relative L1 Test Norm: 0.7309774518013\n",
      "######### Epoch: 499  ######### Train Loss: 0.010563664883375169  ######### Relative L1 Test Norm: 0.044584496319293974\n",
      "######### Epoch: 0  ######### Train Loss: 0.9452386140823364  ######### Relative L1 Test Norm: 0.7442952752113342\n",
      "######### Epoch: 499  ######### Train Loss: 0.008354720287024974  ######### Relative L1 Test Norm: 0.016373566538095474\n",
      "######### Epoch: 0  ######### Train Loss: 1.686184936761856  ######### Relative L1 Test Norm: 0.7618614673614502\n",
      "######### Epoch: 499  ######### Train Loss: 0.010286951251327992  ######### Relative L1 Test Norm: 0.02196805737912655\n",
      "######### Epoch: 0  ######### Train Loss: 0.93666952252388  ######### Relative L1 Test Norm: 0.6500569701194763\n",
      "######### Epoch: 499  ######### Train Loss: 0.00810702252201736  ######### Relative L1 Test Norm: 0.023721057549118997\n",
      "######### Epoch: 0  ######### Train Loss: 0.9079528212547302  ######### Relative L1 Test Norm: 0.5719729900360108\n",
      "######### Epoch: 499  ######### Train Loss: 0.00889507718384266  ######### Relative L1 Test Norm: 0.03723354116082191\n",
      "######### Epoch: 0  ######### Train Loss: 0.9437624692916871  ######### Relative L1 Test Norm: 0.7620382308959961\n",
      "######### Epoch: 499  ######### Train Loss: 0.007984168548136949  ######### Relative L1 Test Norm: 0.024606897309422494\n",
      "######### Epoch: 0  ######### Train Loss: 0.8628845334053039  ######### Relative L1 Test Norm: 0.6676785707473755\n",
      "######### Epoch: 499  ######### Train Loss: 0.008886819565668702  ######### Relative L1 Test Norm: 0.024830373004078865\n",
      "######### Epoch: 0  ######### Train Loss: 1.1193681538105011  ######### Relative L1 Test Norm: 0.6204107999801636\n",
      "######### Epoch: 499  ######### Train Loss: 0.011010950151830911  ######### Relative L1 Test Norm: 0.02542469948530197\n",
      "######### Epoch: 0  ######### Train Loss: 0.7000617742538452  ######### Relative L1 Test Norm: 0.6285151839256287\n",
      "######### Epoch: 499  ######### Train Loss: 0.00836792290210724  ######### Relative L1 Test Norm: 0.019820973463356494\n",
      "######### Epoch: 0  ######### Train Loss: 1.4784340620040894  ######### Relative L1 Test Norm: 0.6991002678871154\n",
      "######### Epoch: 499  ######### Train Loss: 0.008013073727488518  ######### Relative L1 Test Norm: 0.02572918199002743\n",
      "######### Epoch: 0  ######### Train Loss: 0.6898459464311599  ######### Relative L1 Test Norm: 0.6294138193130493\n",
      "######### Epoch: 499  ######### Train Loss: 0.010510537121444941  ######### Relative L1 Test Norm: 0.01736434083431959\n",
      "200 0.0116510522 0.0281428676 [0.0145418085, 0.01482689195, 0.01441303965, 0.01636228245] [0.0626290422, 0.035439837749999994, 0.0235342989, 0.017811215499999998]\n",
      " \n",
      "######### Epoch: 0  ######### Train Loss: 0.6678709273154919  ######### Relative L1 Test Norm: 0.5071909895965031\n",
      "######### Epoch: 499  ######### Train Loss: 0.010049537254067568  ######### Relative L1 Test Norm: 0.02501514314540795\n",
      "######### Epoch: 0  ######### Train Loss: 1.0330370985544646  ######### Relative L1 Test Norm: 0.5020237948213305\n",
      "######### Epoch: 499  ######### Train Loss: 0.008992797157798823  ######### Relative L1 Test Norm: 0.028656510902302607\n",
      "######### Epoch: 0  ######### Train Loss: 0.8879149831258334  ######### Relative L1 Test Norm: 0.5971078617232186\n",
      "######### Epoch: 499  ######### Train Loss: 0.009593199007213116  ######### Relative L1 Test Norm: 0.02729297908289092\n",
      "######### Epoch: 0  ######### Train Loss: 0.8836374053588281  ######### Relative L1 Test Norm: 0.5574039135660444\n",
      "######### Epoch: 499  ######### Train Loss: 0.009713474517831435  ######### Relative L1 Test Norm: 0.016987237680171217\n",
      "######### Epoch: 0  ######### Train Loss: 1.2241741510537953  ######### Relative L1 Test Norm: 0.6573849320411682\n",
      "######### Epoch: 499  ######### Train Loss: 0.010757021462688079  ######### Relative L1 Test Norm: 0.03272592489208494\n",
      "######### Epoch: 0  ######### Train Loss: 0.8469379681807297  ######### Relative L1 Test Norm: 0.5691745323794228\n",
      "######### Epoch: 499  ######### Train Loss: 0.009720274497969793  ######### Relative L1 Test Norm: 0.0189680882862636\n",
      "######### Epoch: 0  ######### Train Loss: 0.8035823748661921  ######### Relative L1 Test Norm: 0.5756912784917014\n",
      "######### Epoch: 499  ######### Train Loss: 0.010346961637529043  ######### Relative L1 Test Norm: 0.02530873247555324\n",
      "######### Epoch: 0  ######### Train Loss: 1.1040212855889247  ######### Relative L1 Test Norm: 0.5693035892077855\n",
      "######### Epoch: 499  ######### Train Loss: 0.010512993706820102  ######### Relative L1 Test Norm: 0.02184406840907676\n",
      "######### Epoch: 0  ######### Train Loss: 1.1624480761014497  ######### Relative L1 Test Norm: 0.5529985385281699\n",
      "######### Epoch: 499  ######### Train Loss: 0.01119599537923932  ######### Relative L1 Test Norm: 0.01961831482393401\n",
      "######### Epoch: 0  ######### Train Loss: 0.9510509921954229  ######### Relative L1 Test Norm: 0.5382156499794551\n",
      "######### Epoch: 499  ######### Train Loss: 0.010623359694503821  ######### Relative L1 Test Norm: 0.018744414539209435\n",
      "######### Epoch: 0  ######### Train Loss: 1.0485370480097258  ######### Relative L1 Test Norm: 0.609883223261152\n",
      "######### Epoch: 499  ######### Train Loss: 0.010315218152335057  ######### Relative L1 Test Norm: 0.019488992701683725\n",
      "######### Epoch: 0  ######### Train Loss: 0.7173584332832923  ######### Relative L1 Test Norm: 0.5025359988212585\n",
      "######### Epoch: 499  ######### Train Loss: 0.009992703652152648  ######### Relative L1 Test Norm: 0.017632290853985717\n",
      "######### Epoch: 0  ######### Train Loss: 0.6833028839184687  ######### Relative L1 Test Norm: 0.4884453628744398\n",
      "######### Epoch: 499  ######### Train Loss: 0.01110554844714128  ######### Relative L1 Test Norm: 0.01656240038573742\n",
      "######### Epoch: 0  ######### Train Loss: 1.0031897654900184  ######### Relative L1 Test Norm: 0.5632212034293583\n",
      "######### Epoch: 499  ######### Train Loss: 0.009985054914767925  ######### Relative L1 Test Norm: 0.01816677169076034\n",
      "######### Epoch: 0  ######### Train Loss: 0.8896417892896212  ######### Relative L1 Test Norm: 0.4711026634488787\n",
      "######### Epoch: 499  ######### Train Loss: 0.009757177760967841  ######### Relative L1 Test Norm: 0.018762628148709024\n",
      "######### Epoch: 0  ######### Train Loss: 0.8539141554098862  ######### Relative L1 Test Norm: 0.46831116506031584\n",
      "######### Epoch: 499  ######### Train Loss: 0.010247252630786253  ######### Relative L1 Test Norm: 0.014946640469133854\n",
      "######### Epoch: 0  ######### Train Loss: 0.9363406185920422  ######### Relative L1 Test Norm: 0.5508329783167157\n",
      "######### Epoch: 499  ######### Train Loss: 0.00884392918445743  ######### Relative L1 Test Norm: 0.023452230330024446\n",
      "######### Epoch: 0  ######### Train Loss: 0.806285207088177  ######### Relative L1 Test Norm: 0.5182233112198966\n",
      "######### Epoch: 499  ######### Train Loss: 0.008809260450876676  ######### Relative L1 Test Norm: 0.01595186149435384\n",
      "######### Epoch: 0  ######### Train Loss: 1.00085936830594  ######### Relative L1 Test Norm: 0.5673683200563703\n",
      "######### Epoch: 499  ######### Train Loss: 0.00956487376242876  ######### Relative L1 Test Norm: 0.01435736074511494\n",
      "######### Epoch: 0  ######### Train Loss: 0.8752118853422312  ######### Relative L1 Test Norm: 0.5591032803058624\n",
      "######### Epoch: 499  ######### Train Loss: 0.009788994104243241  ######### Relative L1 Test Norm: 0.015314912157399314\n",
      "200 0.0143114738 0.0125521868 [0.0145418085, 0.01482689195, 0.01441303965, 0.01636228245, 0.01390724115] [0.0626290422, 0.035439837749999994, 0.0235342989, 0.017811215499999998, 0.0154523663]\n",
      " \n"
     ]
    }
   ],
   "source": [
    "E_pos = []\n",
    "E_neg = []\n",
    "Portion = [0.05, 0.10, 0.25, 0.5, 1.0]\n",
    "num_runs = 20\n",
    "F = func_nonlinear2\n",
    "\n",
    "vectorized_func = np.vectorize(F)\n",
    "N_train_pos = 200\n",
    "\n",
    "N_test_pos = 512\n",
    "N_test_neg = 512\n",
    "x_test_pos = np.random.normal(loc=1.0, scale=0.5, size=N_test_pos)\n",
    "x_test_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_test_neg)\n",
    "y_test_pos = vectorized_func(x_test_pos)\n",
    "y_test_neg = vectorized_func(x_test_neg)\n",
    "\n",
    "\n",
    "for portion in Portion:\n",
    "    err_pos = torch.zeros(0,)\n",
    "    err_neg = torch.zeros(0,)\n",
    "    E_tmp_pos = []\n",
    "    E_tmp_neg = []\n",
    "    for _ in range(num_runs):\n",
    "        N_train_neg = int(N_train_pos*portion)\n",
    "        x_train_pos = np.random.normal(loc=1.0, scale=0.5, size=N_train_pos)\n",
    "        x_train_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_train_neg)\n",
    "        noise = 0.1\n",
    "        y_train_pos = vectorized_func(x_train_pos) + np.random.normal(loc = 0.0, scale=noise,size=N_train_pos)\n",
    "        y_train_neg = vectorized_func(x_train_neg) + np.random.normal(loc=0.0, scale=noise, size=N_train_neg)\n",
    "\n",
    "        #---------------------\n",
    "        # Val:\n",
    "\n",
    "        N_val_pos = N_train_pos//2\n",
    "        N_val_neg = N_train_neg//2\n",
    "        x_val_pos = np.random.normal(loc=1.0, scale=0.5, size=N_val_pos)\n",
    "        x_val_neg = np.random.normal(loc=-1.0, scale=0.5, size=N_val_neg)\n",
    "        y_val_pos = vectorized_func(x_val_pos)\n",
    "        y_val_neg = vectorized_func(x_val_neg)\n",
    "\n",
    "        batch_size = 32\n",
    "\n",
    "        inp_train = np.concatenate((x_train_pos, x_train_neg), axis = 0).reshape(-1, 1)\n",
    "        out_train = np.concatenate((y_train_pos, y_train_neg), axis = 0).reshape(-1, 1)\n",
    "        inp_train, out_train = torch.tensor(inp_train).to(\"cuda\").type(torch.float32), torch.tensor(out_train).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "        inp_val = np.concatenate((x_val_pos, x_val_neg), axis = 0).reshape(-1, 1)\n",
    "        out_val = np.concatenate((y_val_pos, y_val_neg), axis = 0).reshape(-1, 1)\n",
    "        inp_val, out_val = torch.tensor(inp_val).to(\"cuda\").type(torch.float32), torch.tensor(out_val).to(\"cuda\").type(torch.float32)\n",
    "\n",
    "        dataset_train = TensorDataset(inp_train, out_train)\n",
    "        dataloader_train = DataLoader(dataset_train, batch_size=batch_size, shuffle=True)\n",
    "        dataset_val = TensorDataset(inp_val, out_val)\n",
    "        dataloader_val = DataLoader(dataset_val, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "        learning_rate = 0.005\n",
    "        weight_decay = 0\n",
    "        step_size = 50\n",
    "        gamma = 0.8\n",
    "        epochs = 500\n",
    "\n",
    "        tag = \"tmp\"\n",
    "\n",
    "        model = MLP(widths = [64, 64]).to(\"cuda\")\n",
    "        optimizer = AdamW(model.parameters(), lr=learning_rate, weight_decay=weight_decay)\n",
    "        scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=step_size, gamma=gamma)\n",
    "\n",
    "        model = train(model, optimizer, scheduler, dataloader_train, dataloader_val, epochs = epochs, freq_print=499, tag = tag)\n",
    "\n",
    "\n",
    "        inp_test_pos, out_test_pos = torch.tensor(x_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_pos).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "        inp_test_neg, out_test_neg = torch.tensor(x_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1), torch.tensor(y_test_neg).to(\"cuda\").type(torch.float32).reshape(-1, 1)\n",
    "\n",
    "        pred_test_pos = model(inp_test_pos)\n",
    "        pred_test_neg = model(inp_test_neg)\n",
    "        err_pos = torch.norm(out_test_pos - pred_test_pos, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "        err_neg = torch.norm(out_test_neg - pred_test_neg, p = 2, dim = [1])#/torch.norm(out_test_pos, p = 2, dim = [1])\n",
    "        mean_pos = round(torch.mean(err_pos).item(),10)\n",
    "        mean_neg = round(torch.mean(err_neg).item(),10)\n",
    "        E_tmp_pos.append(mean_pos)\n",
    "        E_tmp_neg.append(mean_neg)\n",
    "\n",
    "    E_pos.append(np.median(np.array(E_tmp_pos)))\n",
    "    E_neg.append(np.median(np.array(E_tmp_neg)))\n",
    "    print(N_train_pos, mean_pos, mean_neg,E_pos,E_neg)\n",
    "    print(\" \")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.0145418085, 0.01482689195, 0.01441303965, 0.01636228245, 0.01390724115] [0.0626290422, 0.035439837749999994, 0.0235342989, 0.017811215499999998, 0.0154523663]\n",
      "-8.448806420550202 -0.7350378192908668\n"
     ]
    },
    {
     "data": {
      "image/png": "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5ADJe1CaO8rPyjSuvI+kiaRMmVmT55GAS96rkjAuU8USWEliuCRpW0Y/5THl8SQJWyr/5BjLKKg8roz+yXuWqNJVaqMAIiq1J07//v1LPUIl9ZextnDhQnP79u3Nvr6+5vDwcPPIkSNV/5nS+vgsWrTI3KtXr7zeQFFRUebbbrtN9Uey9tZbb5mbNm1q9vDwUI8lfX5K63MkUlJSzC+++KLqU2TpbTRgwADzxo0bi2xr6XO0du3aCv3uhW3YsEE9lzynPLfsg+yL7FNhFelzJL2gnnrqKXP9+vXNRqNR/bw8jvVrarleWOHjZxEfH6/6ILVu3drs4+Oj+lPJMb/55pvN33//vbmyybG/4YYbzKGhoeqYRUZGmocPH27+7bffLvpaSM+ifv36mUNCQlRfJvn9Vq9eXez233zzjXpvSm8vea/Ke69t27bmqVOnqt5IFtLzaezYsebmzZurx5Tj0bJlS/Nzzz1njomJqfTjQSQM8k/lh2BEREREzoE5R0RERERWGBwRERERWWFwRERERGSFwRERERGRFQZHRERERFYYHBERERFZYXBEREREZIXBEREREZEVBkdEREREVhgcEREREVlhcERERERkhcERERERkRUGR0RERETI9/9Wkhzlcie+oQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#sine:\n",
    "#Portion = [0.05, 0.10, 0.25, 0.5, 1.0]\n",
    "#E_pos, E_neg = [0.024862793299999998, 0.0262200432, 0.02464668735, 0.023585286, 0.021718901550000003], [0.16399405150000002, 0.0972213857, 0.076026015,0.06520859155, 0.03981854395]\n",
    "\n",
    "#linear:\n",
    "#Portion = [0.05, 0.10, 0.25, 0.5, 1.0]\n",
    "#E_pos, E_neg = [0.01141831465, 0.01230883925, 0.01069385185, 0.014371905, 0.0121010314], [0.0482868347, 0.03359374405, 0.0186007703, 0.01667006405, 0.010735863799999999]\n",
    "\n",
    "#nonlinear\n",
    "'''\n",
    "E_pos, E_neg = [0.00052396, 0.0005703,  0.0005608,  0.0004537,  0.00052371], [0.00905164, 0.00475779, 0.00161824, 0.00097238, 0.00069069]\n",
    "E_neg = np.array(E_neg)\n",
    "E_pos = np.array(E_pos)\n",
    "'''\n",
    "#nonlinear2\n",
    "#[0.0145418085, 0.01482689195, 0.01441303965, 0.01636228245, 0.01390724115] [0.0626290422, 0.035439837749999994, 0.0235342989, 0.017811215499999998, 0.0154523663]\n",
    "\n",
    "\n",
    "print(E_pos, E_neg)\n",
    "Portion = np.array(Portion)\n",
    "E_neg = np.array(E_neg)**2\n",
    "E_pos = np.array(E_pos)**2\n",
    "\n",
    "plt.scatter(Portion, E_pos, color = \"red\", label = \"+ class\")\n",
    "plt.plot(Portion, E_pos, color = \"red\")\n",
    "\n",
    "plt.scatter(Portion, E_neg, color = \"blue\",label = \"-  class\")\n",
    "plt.plot(Portion, E_neg,color = \"blue\")\n",
    "\n",
    "\n",
    "z = np.polyfit(np.log(Portion[1:]), np.log(E_neg[1:]), 1)\n",
    "X = np.log(np.linspace(0.05, 1.0, 100))\n",
    "Y = z[1] + z[0]*X\n",
    "plt.plot(np.exp(X),np.exp(Y), \"--\", color = \"lightblue\", label = \"$k=$\"+str(round(z[0],2)))\n",
    "print(z[1], z[0])\n",
    "\n",
    "plt.plot(np.exp(X), np.ones_like(X)*np.mean(E_pos),\"--\", color = \"salmon\")\n",
    "\n",
    "plt.grid(True)\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")\n",
    "\n",
    "plt.xlabel(\"Fraction of the - class\", fontsize = 14)\n",
    "plt.ylabel(\"MSE\", fontsize = 14)\n",
    "plt.legend(fontsize = 14)\n",
    "\n",
    "\n",
    "file_label = f\"Portion_SCALE_fit_{F.__name__}_{N_train_pos}\"\n",
    "plt.savefig(f\"Figures/1d_exp/{file_label}.png\", dpi=400)\n",
    "\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'Portion' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[3], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m plt\u001b[39m.\u001b[39mscatter(Portion, np\u001b[39m.\u001b[39marray(E_neg)\u001b[39m/\u001b[39mnp\u001b[39m.\u001b[39marray(E_pos), color \u001b[39m=\u001b[39m \u001b[39m\"\u001b[39m\u001b[39mgreen\u001b[39m\u001b[39m\"\u001b[39m, s\u001b[39m=\u001b[39m \u001b[39m50\u001b[39m)\n\u001b[1;32m      3\u001b[0m plt\u001b[39m.\u001b[39mxlabel(\u001b[39m\"\u001b[39m\u001b[39mFraction of the - class\u001b[39m\u001b[39m\"\u001b[39m, fontsize \u001b[39m=\u001b[39m \u001b[39m14\u001b[39m)\n\u001b[1;32m      4\u001b[0m plt\u001b[39m.\u001b[39mylabel(\u001b[39m\"\u001b[39m\u001b[39mE$_\u001b[39m\u001b[39m{\u001b[39m\u001b[39m+}/$\u001b[39m\u001b[39m\"\u001b[39m\u001b[39m+\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mE$_\u001b[39m\u001b[39m{\u001b[39m\u001b[39m-}$\u001b[39m\u001b[39m\"\u001b[39m, fontsize \u001b[39m=\u001b[39m \u001b[39m14\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'Portion' is not defined"
     ]
    }
   ],
   "source": [
    "plt.scatter(Portion, np.array(E_neg)/np.array(E_pos), color = \"green\", s= 50)\n",
    "\n",
    "plt.xlabel(\"Fraction of the - class\", fontsize = 14)\n",
    "plt.ylabel(\"E$_{+}/$\"+\"E$_{-}$\", fontsize = 14)\n",
    "plt.grid(True)\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n",
    "<br>\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "def f_sine(x):\n",
    "    return np.where(x < 0, np.sin(2*np.pi*x), np.sin(30*np.pi * x))\n",
    "\n",
    "def get_dataset(N, batch_size=64):\n",
    "    X = np.random.uniform(-1,1,N)\n",
    "    Y = f_sine(X).reshape(-1,1)\n",
    "    X = X.reshape(-1,1)\n",
    "    return torch.tensor(X).to(\"cuda\").type(torch.float32), torch.tensor(Y).to(\"cuda\").type(torch.float32)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x14ad3555f650>"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = np.linspace(-1,1,1000)\n",
    "plt.scatter(X, f_sine(X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "######### Epoch: 0  ######### Train Loss: 0.45964418165385723  ######### Relative L1 Test Norm: 0.5577043145895004\n",
      "######### Epoch: 50  ######### Train Loss: 0.23580811824649572  ######### Relative L1 Test Norm: 0.3283194974064827\n",
      "######### Epoch: 100  ######### Train Loss: 0.2359546422958374  ######### Relative L1 Test Norm: 0.32848741859197617\n",
      "######### Epoch: 150  ######### Train Loss: 0.23446413315832615  ######### Relative L1 Test Norm: 0.32095376402139664\n",
      "######### Epoch: 200  ######### Train Loss: 0.2323062475770712  ######### Relative L1 Test Norm: 0.3209212124347687\n",
      "######### Epoch: 250  ######### Train Loss: 0.23079505283385515  ######### Relative L1 Test Norm: 0.3257589116692543\n",
      "######### Epoch: 300  ######### Train Loss: 0.23017205856740475  ######### Relative L1 Test Norm: 0.3246035873889923\n",
      "######### Epoch: 350  ######### Train Loss: 0.22699821647256613  ######### Relative L1 Test Norm: 0.31872352957725525\n",
      "######### Epoch: 400  ######### Train Loss: 0.22574015147984028  ######### Relative L1 Test Norm: 0.31501245498657227\n",
      "######### Epoch: 450  ######### Train Loss: 0.22407629620283842  ######### Relative L1 Test Norm: 0.3125913254916668\n"
     ]
    }
   ],
   "source": [
    "batch_size = 64\n",
    "N_train = 1024\n",
    "N_val = 256\n",
    "N_test = 1024\n",
    "\n",
    "\n",
    "inp_train, out_train = get_dataset(N_train, batch_size=batch_size)\n",
    "inp_val, out_val = get_dataset(N_val, batch_size=batch_size)\n",
    "inp_test, out_test = get_dataset(N_test, batch_size=batch_size)\n",
    "\n",
    "#-------------\n",
    "\n",
    "dataset_train = TensorDataset(inp_train, out_train)\n",
    "dataloader_train = DataLoader(dataset_train, batch_size=batch_size, shuffle=True)\n",
    "dataset_val = TensorDataset(inp_val, out_val)\n",
    "dataloader_val = DataLoader(dataset_val, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "learning_rate = 0.005\n",
    "weight_decay = 0\n",
    "step_size = 50\n",
    "gamma = 0.8\n",
    "epochs = 500\n",
    "\n",
    "tag = \"tmp\"\n",
    "\n",
    "model = MLP(widths = [64, 64]).to(\"cuda\")\n",
    "optimizer = AdamW(model.parameters(), lr=learning_rate, weight_decay=weight_decay)\n",
    "scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=step_size, gamma=gamma)\n",
    "\n",
    "model = train(model, optimizer, scheduler, dataloader_train, dataloader_val, epochs = epochs, freq_print=50, tag = tag)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "inp_test, out_test = get_dataset(10000)\n",
    "plt.scatter(inp_test[:,0].detach().cpu().numpy(), f_sine(inp_test[:,0].detach().cpu().numpy()),label = \"True\")\n",
    "\n",
    "Y_pred = model(inp_test)[:,0]\n",
    "plt.scatter(inp_test[:,0].detach().cpu().numpy(), Y_pred.detach().cpu().numpy(), color = \"orange\", label = \"Prediction\")\n",
    "\n",
    "plt.legend(fontsize = 11)\n",
    "plt.grid(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for epoch in tqdm_epoch:\n",
    "    avg_loss = 0.\n",
    "    num_items = 0\n",
    "    avg_loss_val = 0.\n",
    "\n",
    "    score_model.train()\n",
    "    lr = get_lr_cosine_linear_warmup(epoch, warmup_epochs, n_epochs, peak_lr, end_lr)\n",
    "    for param_group in optimizer.param_groups:\n",
    "          param_group['lr'] = lr  # Update optimizer LR\n",
    "\n",
    "    for input_batch, output_batch in train_loader:\n",
    "      input_batch = input_batch.to(device)\n",
    "      output_batch = output_batch.to(device)\n",
    "\n",
    "      if which_type == \"xy\":\n",
    "        loss = loss_fn(score_model, input_batch, output_batch, marginal_prob_std_fn)\n",
    "        condition = output_batch\n",
    "      elif which_type == \"yx\":\n",
    "        loss = loss_fn(score_model, output_batch, input_batch, marginal_prob_std_fn)\n",
    "        condition = input_batch\n",
    "      elif which_type == \"x\":\n",
    "        loss = loss_fn(score_model, input_batch, None, marginal_prob_std_fn)\n",
    "        condition = None\n",
    "      elif which_type == \"y\":\n",
    "        loss = loss_fn(score_model, output_batch, None, marginal_prob_std_fn)\n",
    "        condition = None\n",
    "      elif which_type == \"x&y\":\n",
    "        loss = loss_fn(score_model, torch.cat((input_batch, output_batch), axis = 1), None, marginal_prob_std_fn)\n",
    "        condition = None\n",
    "      \n",
    "      optimizer.zero_grad()\n",
    "      loss.backward()\n",
    "      optimizer.step()\n",
    "      ema.update()\n",
    "\n",
    "      avg_loss += loss.item() * output_batch.shape[0]\n",
    "      num_items += output_batch.shape[0]\n",
    "    avg_loss /= num_items\n",
    "\n",
    "    score_model.eval()\n",
    "    num_items = 0\n",
    "    with torch.no_grad():\n",
    "        for input_batch, output_batch in val_loader:\n",
    "          #x = torch.cat((input_batch, output_batch), dim = 1)\n",
    "          input_batch = input_batch.to(device)\n",
    "          output_batch = output_batch.to(device)\n",
    "\n",
    "          loss = loss_fn(score_model, variable, condition, marginal_prob_std_fn)\n",
    "          avg_loss_val += loss.item() * output_batch.shape[0]\n",
    "          num_items += output_batch.shape[0]\n",
    "    avg_loss_val/= num_items\n",
    "    "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
