{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "sys.path.insert(0, '../')\n",
    "sys.path.insert(0, '../datasets')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "# results_dir = '../results/momentum/'\n",
    "# dataset = 'diabetes'\n",
    "# budget = 1000\n",
    "# num_players = 400\n",
    "# seeds = [0,1,2,3,4]\n",
    "# eps = 1.0\n",
    "# model_name = \"logistic_regression\"\n",
    "\n",
    "results_dir = '../results/momentum/'\n",
    "dataset = 'wine_quality'\n",
    "budget = 240\n",
    "num_players = 400\n",
    "seeds = [0,1,2,3,4]\n",
    "eps = 10\n",
    "model_name = \"linear_regression\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_1_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_no_dp_budget_1000_num_players_400_seed_3.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_2_no_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_1_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_3.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_4_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_4_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_0_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_3_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_no_dp_budget_1000_num_players_400_seed_1.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_3_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_4.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_0_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_no_dp_budget_1000_num_players_400_seed_0.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_1_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_2_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_3_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_1.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_4_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_no_dp_budget_1000_num_players_400_seed_2.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_3_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_2_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_4_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_0_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_1_no_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_3_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_1_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_4_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_2_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_0.npy',\n",
       " 'scores_diabetes_logistic_regression_no_dp_budget_1000_num_players_400_seed_4.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_2_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_0_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_2.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_4_no_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_2_use_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_240_num_players_400_seed_3_use_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_1_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_0.1_delta_5e-05_budget_240_num_players_400_seed_0_no_momentum.npy',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_no_momentum.npy',\n",
       " 'scores_diabetes_logistic_regression_clipping_norm_1.0_eps_1.0_delta_5e-05_budget_1000_num_players_400_seed_0_use_momentum.npy']"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "os.listdir(results_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_names = []\n",
    "\n",
    "for file in os.listdir(results_dir):\n",
    "    if file.endswith('.npy') and dataset in file and f\"budget_{budget}\" in file and f\"players_{num_players}\" in file and model_name in file:\n",
    "        if not (\"no_dp\" in file or f\"eps_{eps}\" in file):\n",
    "            continue\n",
    "        f = '.'.join(file.split('.')[:-1])\n",
    "        exp_names.append(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_no_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_use_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_no_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_use_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_no_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_use_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_no_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_use_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_no_momentum',\n",
       " 'scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_use_momentum',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_0',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_1',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_2',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_3',\n",
       " 'scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_4']"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp_names.sort()\n",
    "exp_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_no_momentum\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_0_use_momentum\n",
      "scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_0\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_no_momentum\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_1_use_momentum\n",
      "scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_1\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_no_momentum\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_2_use_momentum\n",
      "scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_2\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_no_momentum\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_3_use_momentum\n",
      "scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_3\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_no_momentum\n",
      "scores_wine_quality_linear_regression_clipping_norm_1.0_eps_10.0_delta_5e-05_budget_240_num_players_400_seed_4_use_momentum\n",
      "scores_wine_quality_linear_regression_no_dp_budget_240_num_players_400_seed_4\n"
     ]
    }
   ],
   "source": [
    "scores = {}\n",
    "# vars = {}\n",
    "\n",
    "for seed in seeds:\n",
    "    for exp_name in exp_names:\n",
    "        if f\"seed_{seed}\" in exp_name:\n",
    "            print(exp_name)\n",
    "            scores[seed] = [\n",
    "                np.load(results_dir + exp_name + '.npy', allow_pickle=True) for exp_name in exp_names if 'scores' in exp_name and f\"seed_{seed}\" in exp_name\n",
    "            ]\n",
    "\n",
    "            # vars[seed] = [\n",
    "            #     np.load(results_dir + exp_name + '.npy', allow_pickle=True) for exp_name in exp_names if 'vars' in exp_name and f\"seed_{seed}\" in exp_name\n",
    "            # ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the experiment data from ../data\n",
    "data_dir = '../data/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the train with torch\n",
    "data_name = f'{dataset}_num_players_{num_players}'\n",
    "train_data = torch.load(data_dir + 'train_' + data_name + '.pt')\n",
    "val_data = torch.load(data_dir + 'val_' + data_name + '.pt')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initialize model\n",
    "import sys\n",
    "sys.path.append('../models')\n",
    "import torch.nn as nn\n",
    "from resnet import ResNet18\n",
    "from logistic_regression import LogisticRegression\n",
    "\n",
    "def init_weights(m):\n",
    "    if isinstance(m, nn.Conv2d):\n",
    "        torch.nn.init.normal_(m.weight, mean=0.0, std=0.01)\n",
    "        if m.bias is not None:\n",
    "            torch.nn.init.zeros_(m.bias)\n",
    "    elif isinstance(m, nn.BatchNorm2d):\n",
    "        torch.nn.init.ones_(m.weight)\n",
    "        torch.nn.init.zeros_(m.bias)\n",
    "    elif isinstance(m, nn.Linear):\n",
    "        torch.nn.init.normal_(m.weight, mean=0.0, std=0.01)\n",
    "        torch.nn.init.zeros_(m.bias)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda', index=3)"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = torch.device(\"cuda:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set random seed\n",
    "from models.mlp import MLP\n",
    "\n",
    "\n",
    "if model_name == \"resnet18\":\n",
    "    net = ResNet18(num_classes=10).to(device)\n",
    "elif model_name == \"logistic_regression\":\n",
    "    if dataset == \"breast-cancer\":\n",
    "        net = LogisticRegression(30, 2).to(device)\n",
    "    elif dataset == \"diabetes\":\n",
    "        net = LogisticRegression(8, 2).to(device)\n",
    "    elif dataset == \"mnist\":\n",
    "        net = LogisticRegression(784, 10).to(device)\n",
    "    elif dataset == \"covertype\":\n",
    "        net = LogisticRegression(51, 7).to(device)\n",
    "elif model_name == \"mlp\":\n",
    "    if dataset == \"breast-cancer\":\n",
    "        net = MLP(30, 2).to(device)\n",
    "    elif dataset == \"diabetes\":\n",
    "        net = MLP(8, 2).to(device)\n",
    "    elif dataset == \"mnist\":\n",
    "        net = MLP(784, 10).to(device)\n",
    "    elif dataset == \"covertype\":\n",
    "        net = MLP(51, 7).to(device)\n",
    "elif model_name == \"linear_regression\":\n",
    "    if dataset == \"wine_quality\":\n",
    "        net = nn.Linear(11, 1).to(device)\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.01282975, 0.04316066, 0.02473753, 0.03955233, 0.03251985,\n",
       "       0.01063398, 0.02382301, 0.03585564, 0.02477715, 0.02540134,\n",
       "       0.01623673, 0.02085658, 0.02665111, 0.03661929, 0.0342492 ,\n",
       "       0.03780975, 0.02774429, 0.04306571, 0.03391205, 0.0261394 ,\n",
       "       0.0167185 , 0.01806556, 0.02594033, 0.02696394, 0.04980079,\n",
       "       0.03573224, 0.02823419, 0.025564  , 0.03303523, 0.04586673,\n",
       "       0.02533154, 0.03431564, 0.03645736, 0.02239075, 0.02508856,\n",
       "       0.02304303, 0.01171198, 0.03106662, 0.03854225, 0.01386402,\n",
       "       0.01141675, 0.02467539, 0.02578946, 0.02521563, 0.0078599 ,\n",
       "       0.02596072, 0.01920565, 0.02993714, 0.0265743 , 0.02880784,\n",
       "       0.02462002, 0.02922925, 0.03293863, 0.02427995, 0.01409956,\n",
       "       0.03424962, 0.02513782, 0.03411612, 0.02716615, 0.04194691,\n",
       "       0.01625276, 0.02573106, 0.02342468, 0.01317646, 0.02833934,\n",
       "       0.02267535, 0.02062849, 0.03432919, 0.02008084, 0.02771464,\n",
       "       0.02911499, 0.01804147, 0.04135698, 0.02919164, 0.02020262,\n",
       "       0.03307591, 0.04865061, 0.02907855, 0.03668613, 0.05037134,\n",
       "       0.04432174, 0.03813082, 0.03889169, 0.01777209, 0.03659184,\n",
       "       0.04086524, 0.03313096, 0.01987696, 0.05122288, 0.01804233,\n",
       "       0.02650867, 0.0338379 , 0.0349979 , 0.02281977, 0.04882317,\n",
       "       0.02836653, 0.01820707, 0.02185362, 0.03492782, 0.01194076,\n",
       "       0.04951317, 0.02242058, 0.04016062, 0.02921661, 0.0370063 ,\n",
       "       0.02495015, 0.02584119, 0.03914208, 0.0520606 , 0.03324937,\n",
       "       0.0231266 , 0.01314472, 0.01589275, 0.03636931, 0.01819282,\n",
       "       0.04220129, 0.0148767 , 0.0358556 , 0.01127261, 0.04641164,\n",
       "       0.0120707 , 0.0364265 , 0.03219388, 0.02517337, 0.02880658,\n",
       "       0.03851466, 0.03024853, 0.02765718, 0.0271606 , 0.03125641,\n",
       "       0.04367385, 0.03952862, 0.03123222, 0.0256374 , 0.04174482,\n",
       "       0.02570135, 0.03587695, 0.02328934, 0.0260643 , 0.02660582,\n",
       "       0.03641374, 0.02277786, 0.03573466, 0.0363438 , 0.02812583,\n",
       "       0.0213969 , 0.03234645, 0.04222683, 0.02068439, 0.02149618,\n",
       "       0.03398874, 0.03739564, 0.02604086, 0.00729835, 0.02251194,\n",
       "       0.02507041, 0.01321619, 0.04150768, 0.04506752, 0.04517878,\n",
       "       0.03433605, 0.0221453 , 0.01433554, 0.03513204, 0.02696237,\n",
       "       0.03658923, 0.05159143, 0.03395149, 0.02980699, 0.02710005,\n",
       "       0.01593402, 0.01837775, 0.04180903, 0.03394753, 0.01361441,\n",
       "       0.04578578, 0.03664306, 0.03451852, 0.03914477, 0.02386997,\n",
       "       0.0168086 , 0.03768798, 0.04203624, 0.03714225, 0.02323171,\n",
       "       0.04747932, 0.04719625, 0.04269173, 0.01558514, 0.0277586 ,\n",
       "       0.02560457, 0.0396531 , 0.01928682, 0.03110116, 0.02073202,\n",
       "       0.01702257, 0.02238344, 0.04389129, 0.02776026, 0.01208886,\n",
       "       0.04158612, 0.02852538, 0.0255053 , 0.02399381, 0.04431725,\n",
       "       0.01276978, 0.02724751, 0.03726567, 0.02614813, 0.01985147,\n",
       "       0.03010618, 0.00861777, 0.04050898, 0.03073684, 0.03809965,\n",
       "       0.02774283, 0.01859962, 0.02624206, 0.03238666, 0.02744654,\n",
       "       0.0051953 , 0.0149634 , 0.02929657, 0.0132866 , 0.04073141,\n",
       "       0.03116066, 0.03226655, 0.00934937, 0.03367176, 0.01895944,\n",
       "       0.02732208, 0.02789517, 0.02314301, 0.02359397, 0.02316891,\n",
       "       0.02560121, 0.02662083, 0.03366201, 0.0199179 , 0.03190439,\n",
       "       0.0014551 , 0.0265959 , 0.01523393, 0.02900751, 0.01343923,\n",
       "       0.0139207 , 0.03674912, 0.02122995, 0.0314537 , 0.0254594 ,\n",
       "       0.04236429, 0.02814975, 0.02846893, 0.03926531, 0.03067988,\n",
       "       0.01465823, 0.03112657, 0.03482228, 0.03968534, 0.02786387,\n",
       "       0.03140303, 0.01249316, 0.04044761, 0.0309372 , 0.02359339,\n",
       "       0.04281197, 0.01920695, 0.01424686, 0.02306391, 0.03517617,\n",
       "       0.03958314, 0.03551505, 0.04033536, 0.02508399, 0.03849669,\n",
       "       0.0277648 , 0.03075417, 0.03563166, 0.03252739, 0.04290069,\n",
       "       0.03325112, 0.02666831, 0.05101055, 0.00986673, 0.03981313,\n",
       "       0.04611711, 0.02187061, 0.03226912, 0.01309776, 0.03720798,\n",
       "       0.014978  , 0.03295608, 0.01830296, 0.02189959, 0.02992724,\n",
       "       0.01782006, 0.01061302, 0.02367876, 0.02596521, 0.03104929,\n",
       "       0.03529256, 0.02990874, 0.01562142, 0.02037532, 0.02336132,\n",
       "       0.01847022, 0.02152847, 0.02990839, 0.05021172, 0.02107658,\n",
       "       0.00921996, 0.01463234, 0.03522572, 0.00766221, 0.03240605,\n",
       "       0.01397179, 0.01732569, 0.02501031, 0.01218239, 0.03686082,\n",
       "       0.02307429, 0.03510232, 0.03224051, 0.02833126, 0.05097755,\n",
       "       0.01819026, 0.01775724, 0.01842458, 0.02115537, 0.01763122,\n",
       "       0.02449067, 0.01755764, 0.03899402, 0.036549  , 0.03224195,\n",
       "       0.02520201, 0.0527287 , 0.03415896, 0.03053484, 0.021504  ,\n",
       "       0.02883102, 0.0162272 , 0.02792128, 0.02231801, 0.02943755,\n",
       "       0.02970331, 0.01975464, 0.03480214, 0.04331846, 0.03459291,\n",
       "       0.01329532, 0.00798475, 0.02726429, 0.04181264, 0.03426517,\n",
       "       0.02322599, 0.00908695, 0.05338565, 0.01261696, 0.02498374,\n",
       "       0.03060726, 0.01387207, 0.0338212 , 0.01416508, 0.02199171,\n",
       "       0.01905139, 0.02161043, 0.03113542, 0.02915931, 0.0326905 ,\n",
       "       0.04323761, 0.02132502, 0.02936308, 0.0366097 , 0.03324424,\n",
       "       0.02249982, 0.02481226, 0.00669552, 0.03309522, 0.03933158,\n",
       "       0.01840426, 0.01498422, 0.0153268 , 0.03796536, 0.01941915,\n",
       "       0.02998223, 0.02025732, 0.01790049, 0.05114273, 0.01180546,\n",
       "       0.03939231, 0.0245506 , 0.0266178 , 0.01379667, 0.0247909 ,\n",
       "       0.03797092, 0.01706388, 0.02225331, 0.03038044, 0.03022204])"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(scores[0][0], axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.01475362, 0.04166454, 0.02490099, 0.03136073, 0.02719361,\n",
       "       0.00982606, 0.02563202, 0.03663221, 0.03161856, 0.02692694,\n",
       "       0.01897577, 0.02265712, 0.0302345 , 0.04113331, 0.03522799,\n",
       "       0.0302074 , 0.02681342, 0.04407701, 0.02988648, 0.03010355,\n",
       "       0.0128818 , 0.02237775, 0.02374386, 0.02731389, 0.04697456,\n",
       "       0.03516852, 0.03459322, 0.02426249, 0.03770746, 0.0504514 ,\n",
       "       0.01857857, 0.03151766, 0.02870738, 0.02141202, 0.02625943,\n",
       "       0.03122236, 0.00894904, 0.0262689 , 0.03484201, 0.00700881,\n",
       "       0.00910168, 0.02468959, 0.03469638, 0.02194975, 0.000143  ,\n",
       "       0.03177016, 0.02486266, 0.02857639, 0.03368806, 0.03141986,\n",
       "       0.02270526, 0.0305602 , 0.03120913, 0.02557135, 0.01578292,\n",
       "       0.03804618, 0.0219827 , 0.04479126, 0.02917394, 0.04338594,\n",
       "       0.0147873 , 0.02064844, 0.02593766, 0.01495469, 0.03322419,\n",
       "       0.0194248 , 0.01821543, 0.03092511, 0.01668035, 0.02806502,\n",
       "       0.02831918, 0.01818821, 0.04755096, 0.03085255, 0.021363  ,\n",
       "       0.03080908, 0.05494641, 0.03328261, 0.03599602, 0.04461653,\n",
       "       0.04219593, 0.03500009, 0.03397163, 0.01629116, 0.04569471,\n",
       "       0.03937939, 0.03336624, 0.01929349, 0.05366139, 0.01433139,\n",
       "       0.02513746, 0.03547375, 0.03234267, 0.02547514, 0.03701834,\n",
       "       0.03247046, 0.01912045, 0.0138643 , 0.03315859, 0.00533381,\n",
       "       0.04878888, 0.02407707, 0.03893793, 0.03408813, 0.03968585,\n",
       "       0.02457132, 0.02824699, 0.03815277, 0.05612276, 0.03066387,\n",
       "       0.0221112 , 0.00648487, 0.0154418 , 0.03356369, 0.02144313,\n",
       "       0.04745692, 0.01584661, 0.0410347 , 0.01371396, 0.04209174,\n",
       "       0.00857257, 0.03686483, 0.03558346, 0.02956833, 0.03219121,\n",
       "       0.03441934, 0.02296464, 0.02872806, 0.03058777, 0.0344267 ,\n",
       "       0.04576843, 0.03543586, 0.02701623, 0.02485791, 0.03848171,\n",
       "       0.02275657, 0.04343885, 0.0180148 , 0.02427901, 0.0261256 ,\n",
       "       0.03978759, 0.01710111, 0.0343661 , 0.03522315, 0.03153338,\n",
       "       0.02473015, 0.03693624, 0.04258589, 0.02695405, 0.02280207,\n",
       "       0.03052264, 0.03837261, 0.01852188, 0.00230285, 0.01959277,\n",
       "       0.02934979, 0.01355549, 0.03958875, 0.04792483, 0.04605511,\n",
       "       0.03616714, 0.01651936, 0.01470819, 0.03332735, 0.02975411,\n",
       "       0.03723644, 0.05583792, 0.03128456, 0.02986217, 0.03237599,\n",
       "       0.01179146, 0.0237779 , 0.04162457, 0.0328229 , 0.01564968,\n",
       "       0.05008244, 0.0375736 , 0.0405732 , 0.02955248, 0.02413429,\n",
       "       0.01196121, 0.04403203, 0.03877558, 0.03811917, 0.02311528,\n",
       "       0.04906155, 0.04570971, 0.04214768, 0.01637769, 0.02480129,\n",
       "       0.02325635, 0.04265999, 0.01969562, 0.02947687, 0.02676062,\n",
       "       0.01510405, 0.0213654 , 0.04909468, 0.02856575, 0.01317732,\n",
       "       0.04433331, 0.03188172, 0.01834431, 0.01478287, 0.05215596,\n",
       "       0.01452075, 0.02116838, 0.0427477 , 0.02038807, 0.02022413,\n",
       "       0.03082349, 0.01275119, 0.03793503, 0.02923145, 0.04197754,\n",
       "       0.03591127, 0.01287626, 0.01880481, 0.03525471, 0.02879346,\n",
       "       0.00536348, 0.01581071, 0.02755898, 0.01400233, 0.0415735 ,\n",
       "       0.03098908, 0.03482312, 0.00382717, 0.0352682 , 0.02060122,\n",
       "       0.02547153, 0.02952418, 0.02005976, 0.02506373, 0.02048608,\n",
       "       0.02166563, 0.03111411, 0.03225496, 0.01643393, 0.03487624,\n",
       "       0.00589753, 0.02908743, 0.01282531, 0.02674034, 0.01899629,\n",
       "       0.01707246, 0.03228729, 0.01652402, 0.03685737, 0.02489855,\n",
       "       0.03764852, 0.02761906, 0.03309387, 0.03693318, 0.03729823,\n",
       "       0.01009939, 0.03276873, 0.03302659, 0.03847846, 0.02248917,\n",
       "       0.03161202, 0.01012371, 0.0432912 , 0.02887032, 0.0230502 ,\n",
       "       0.04877868, 0.02528159, 0.01558881, 0.02828166, 0.03753533,\n",
       "       0.04080709, 0.04352473, 0.04396896, 0.02336793, 0.0384922 ,\n",
       "       0.03002949, 0.02616495, 0.0379022 , 0.02524782, 0.04604763,\n",
       "       0.0348618 , 0.02659609, 0.05306445, 0.01228547, 0.04074139,\n",
       "       0.04915632, 0.02477065, 0.03545218, 0.00877362, 0.03528112,\n",
       "       0.01798747, 0.03799043, 0.02096618, 0.01935628, 0.02639805,\n",
       "       0.01701512, 0.01425659, 0.02986128, 0.02621461, 0.03228792,\n",
       "       0.036008  , 0.03380392, 0.0203187 , 0.0196361 , 0.01825098,\n",
       "       0.02188331, 0.02196427, 0.02906841, 0.04702276, 0.02165517,\n",
       "       0.00763185, 0.0173761 , 0.04223235, 0.0111844 , 0.03602451,\n",
       "       0.01321878, 0.01967545, 0.02701288, 0.00847824, 0.03551908,\n",
       "       0.01944996, 0.03300575, 0.03157663, 0.03158736, 0.05712492,\n",
       "       0.02002637, 0.01933297, 0.0254806 , 0.02274476, 0.02279797,\n",
       "       0.01910848, 0.01630453, 0.03960381, 0.0327079 , 0.03368959,\n",
       "       0.0240661 , 0.04645105, 0.02793048, 0.03023561, 0.02116803,\n",
       "       0.02657916, 0.01243548, 0.02687222, 0.02643103, 0.0273951 ,\n",
       "       0.03199938, 0.02449067, 0.04009626, 0.03669515, 0.02875942,\n",
       "       0.01020699, 0.00969416, 0.02768472, 0.04062839, 0.03405776,\n",
       "       0.02256374, 0.00737915, 0.05666958, 0.01242581, 0.02717839,\n",
       "       0.02314377, 0.01299275, 0.03531398, 0.01043983, 0.02193659,\n",
       "       0.02132612, 0.03192143, 0.03008177, 0.03148643, 0.02696642,\n",
       "       0.05227286, 0.02078412, 0.0246354 , 0.04225841, 0.03040814,\n",
       "       0.02196325, 0.01715957, 0.00767836, 0.03130622, 0.03688763,\n",
       "       0.01517508, 0.0194102 , 0.01166488, 0.03724481, 0.02083547,\n",
       "       0.02733741, 0.02510955, 0.01860602, 0.05572745, 0.0121746 ,\n",
       "       0.04171703, 0.02739181, 0.02643621, 0.0127924 , 0.02923963,\n",
       "       0.0385558 , 0.02028114, 0.02872074, 0.02500597, 0.03127241])"
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(scores[0][1], axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.4441\t\n",
      "epoch: 100\ttrain loss: 1.5325\t\n",
      "epoch: 150\ttrain loss: 0.9970\t\n",
      "epoch: 200\ttrain loss: 0.6866\t\n",
      "epoch: 250\ttrain loss: 0.5269\t\n",
      "mse at 10.0% data: 0.0011619901657104492\n",
      "epoch: 50\ttrain loss: 3.3811\t\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch: 100\ttrain loss: 1.1502\t\n",
      "epoch: 150\ttrain loss: 0.5861\t\n",
      "epoch: 200\ttrain loss: 0.4702\t\n",
      "epoch: 250\ttrain loss: 0.4503\t\n",
      "mse at 20.0% data: 0.0007814590334892273\n",
      "epoch: 50\ttrain loss: 3.4535\t\n",
      "epoch: 100\ttrain loss: 0.9347\t\n",
      "epoch: 150\ttrain loss: 0.4955\t\n",
      "epoch: 200\ttrain loss: 0.4415\t\n",
      "epoch: 250\ttrain loss: 0.4348\t\n",
      "mse at 30.0% data: 0.0006500687599182128\n",
      "epoch: 50\ttrain loss: 3.3040\t\n",
      "epoch: 100\ttrain loss: 0.9409\t\n",
      "epoch: 150\ttrain loss: 0.5302\t\n",
      "epoch: 200\ttrain loss: 0.4710\t\n",
      "epoch: 250\ttrain loss: 0.4626\t\n",
      "mse at 40.0% data: 0.0006399120092391967\n",
      "epoch: 50\ttrain loss: 3.3014\t\n",
      "epoch: 100\ttrain loss: 0.7817\t\n",
      "epoch: 150\ttrain loss: 0.5101\t\n",
      "epoch: 200\ttrain loss: 0.4842\t\n",
      "epoch: 250\ttrain loss: 0.4786\t\n",
      "mse at 50.0% data: 0.0005904203057289124\n",
      "epoch: 50\ttrain loss: 3.3207\t\n",
      "epoch: 100\ttrain loss: 0.6564\t\n",
      "epoch: 150\ttrain loss: 0.4904\t\n",
      "epoch: 200\ttrain loss: 0.4838\t\n",
      "epoch: 250\ttrain loss: 0.4811\t\n",
      "mse at 60.0% data: 0.0005770292282104492\n",
      "epoch: 50\ttrain loss: 3.2313\t\n",
      "epoch: 100\ttrain loss: 0.5490\t\n",
      "epoch: 150\ttrain loss: 0.4560\t\n",
      "epoch: 200\ttrain loss: 0.4549\t\n",
      "epoch: 250\ttrain loss: 0.4544\t\n",
      "mse at 70.0% data: 0.0005762465000152588\n",
      "epoch: 50\ttrain loss: 3.1602\t\n",
      "epoch: 100\ttrain loss: 0.5569\t\n",
      "epoch: 150\ttrain loss: 0.4831\t\n",
      "epoch: 200\ttrain loss: 0.4816\t\n",
      "epoch: 250\ttrain loss: 0.4809\t\n",
      "mse at 80.0% data: 0.0005701183676719665\n",
      "epoch: 50\ttrain loss: 3.1776\t\n",
      "epoch: 100\ttrain loss: 0.4999\t\n",
      "epoch: 150\ttrain loss: 0.4822\t\n",
      "epoch: 200\ttrain loss: 0.4818\t\n",
      "epoch: 250\ttrain loss: 0.4818\t\n",
      "mse at 90.0% data: 0.000566464126110077\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.1917\t\n",
      "epoch: 100\ttrain loss: 1.4188\t\n",
      "epoch: 150\ttrain loss: 1.0118\t\n",
      "epoch: 200\ttrain loss: 0.7641\t\n",
      "epoch: 250\ttrain loss: 0.6187\t\n",
      "mse at 10.0% data: 0.0016471521854400635\n",
      "epoch: 50\ttrain loss: 3.4861\t\n",
      "epoch: 100\ttrain loss: 1.0841\t\n",
      "epoch: 150\ttrain loss: 0.5120\t\n",
      "epoch: 200\ttrain loss: 0.4270\t\n",
      "epoch: 250\ttrain loss: 0.4175\t\n",
      "mse at 20.0% data: 0.0008317335844039918\n",
      "epoch: 50\ttrain loss: 3.4224\t\n",
      "epoch: 100\ttrain loss: 0.9406\t\n",
      "epoch: 150\ttrain loss: 0.4996\t\n",
      "epoch: 200\ttrain loss: 0.4405\t\n",
      "epoch: 250\ttrain loss: 0.4334\t\n",
      "mse at 30.0% data: 0.0006421343088150025\n",
      "epoch: 50\ttrain loss: 3.3332\t\n",
      "epoch: 100\ttrain loss: 0.8226\t\n",
      "epoch: 150\ttrain loss: 0.5254\t\n",
      "epoch: 200\ttrain loss: 0.4899\t\n",
      "epoch: 250\ttrain loss: 0.4818\t\n",
      "mse at 40.0% data: 0.0006407865881919861\n",
      "epoch: 50\ttrain loss: 3.3622\t\n",
      "epoch: 100\ttrain loss: 0.7619\t\n",
      "epoch: 150\ttrain loss: 0.4982\t\n",
      "epoch: 200\ttrain loss: 0.4772\t\n",
      "epoch: 250\ttrain loss: 0.4734\t\n",
      "mse at 50.0% data: 0.0006044886708259583\n",
      "epoch: 50\ttrain loss: 3.2863\t\n",
      "epoch: 100\ttrain loss: 0.6420\t\n",
      "epoch: 150\ttrain loss: 0.4654\t\n",
      "epoch: 200\ttrain loss: 0.4579\t\n",
      "epoch: 250\ttrain loss: 0.4553\t\n",
      "mse at 60.0% data: 0.0005793458819389343\n",
      "epoch: 50\ttrain loss: 3.2790\t\n",
      "epoch: 100\ttrain loss: 0.5714\t\n",
      "epoch: 150\ttrain loss: 0.4677\t\n",
      "epoch: 200\ttrain loss: 0.4658\t\n",
      "epoch: 250\ttrain loss: 0.4649\t\n",
      "mse at 70.0% data: 0.0005845614075660706\n",
      "epoch: 50\ttrain loss: 3.1476\t\n",
      "epoch: 100\ttrain loss: 0.5589\t\n",
      "epoch: 150\ttrain loss: 0.4876\t\n",
      "epoch: 200\ttrain loss: 0.4855\t\n",
      "epoch: 250\ttrain loss: 0.4846\t\n",
      "mse at 80.0% data: 0.0005731924176216126\n",
      "epoch: 50\ttrain loss: 3.1862\t\n",
      "epoch: 100\ttrain loss: 0.5004\t\n",
      "epoch: 150\ttrain loss: 0.4833\t\n",
      "epoch: 200\ttrain loss: 0.4827\t\n",
      "epoch: 250\ttrain loss: 0.4826\t\n",
      "mse at 90.0% data: 0.0005663092732429505\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.4041\t\n",
      "epoch: 100\ttrain loss: 1.4063\t\n",
      "epoch: 150\ttrain loss: 0.9500\t\n",
      "epoch: 200\ttrain loss: 0.6783\t\n",
      "epoch: 250\ttrain loss: 0.5319\t\n",
      "mse at 10.0% data: 0.0018705934286117553\n",
      "epoch: 50\ttrain loss: 2.4170\t\n",
      "epoch: 100\ttrain loss: 1.4047\t\n",
      "epoch: 150\ttrain loss: 0.9005\t\n",
      "epoch: 200\ttrain loss: 0.6432\t\n",
      "epoch: 250\ttrain loss: 0.5142\t\n",
      "mse at 20.0% data: 0.001572383165359497\n",
      "epoch: 50\ttrain loss: 3.9067\t\n",
      "epoch: 100\ttrain loss: 1.3605\t\n",
      "epoch: 150\ttrain loss: 0.5966\t\n",
      "epoch: 200\ttrain loss: 0.4356\t\n",
      "epoch: 250\ttrain loss: 0.4068\t\n",
      "mse at 30.0% data: 0.0008059348464012146\n",
      "epoch: 50\ttrain loss: 3.9497\t\n",
      "epoch: 100\ttrain loss: 1.0654\t\n",
      "epoch: 150\ttrain loss: 0.4626\t\n",
      "epoch: 200\ttrain loss: 0.3804\t\n",
      "epoch: 250\ttrain loss: 0.3700\t\n",
      "mse at 40.0% data: 0.0007630018591880799\n",
      "epoch: 50\ttrain loss: 4.0266\t\n",
      "epoch: 100\ttrain loss: 0.5570\t\n",
      "epoch: 150\ttrain loss: 0.4136\t\n",
      "epoch: 200\ttrain loss: 0.4131\t\n",
      "epoch: 250\ttrain loss: 0.4131\t\n",
      "mse at 50.0% data: 0.0006493260860443115\n",
      "epoch: 50\ttrain loss: 3.7423\t\n",
      "epoch: 100\ttrain loss: 0.4523\t\n",
      "epoch: 150\ttrain loss: 0.3934\t\n",
      "epoch: 200\ttrain loss: 0.3934\t\n",
      "epoch: 250\ttrain loss: 0.3934\t\n",
      "mse at 60.0% data: 0.0006200160384178162\n",
      "epoch: 50\ttrain loss: 3.5023\t\n",
      "epoch: 100\ttrain loss: 0.4469\t\n",
      "epoch: 150\ttrain loss: 0.4083\t\n",
      "epoch: 200\ttrain loss: 0.4069\t\n",
      "epoch: 250\ttrain loss: 0.4066\t\n",
      "mse at 70.0% data: 0.0005949190258979797\n",
      "epoch: 50\ttrain loss: 3.3449\t\n",
      "epoch: 100\ttrain loss: 0.4187\t\n",
      "epoch: 150\ttrain loss: 0.4010\t\n",
      "epoch: 200\ttrain loss: 0.4007\t\n",
      "epoch: 250\ttrain loss: 0.4007\t\n",
      "mse at 80.0% data: 0.0005776668787002563\n",
      "epoch: 50\ttrain loss: 3.2576\t\n",
      "epoch: 100\ttrain loss: 0.4326\t\n",
      "epoch: 150\ttrain loss: 0.4195\t\n",
      "epoch: 200\ttrain loss: 0.4193\t\n",
      "epoch: 250\ttrain loss: 0.4193\t\n",
      "mse at 90.0% data: 0.0005701410770416259\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.000563639760017395\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.8093\t\n",
      "epoch: 100\ttrain loss: 0.5258\t\n",
      "epoch: 150\ttrain loss: 0.4524\t\n",
      "epoch: 200\ttrain loss: 0.4320\t\n",
      "epoch: 250\ttrain loss: 0.4623\t\n",
      "mse at 10.0% data: 0.0005712358951568603\n",
      "epoch: 50\ttrain loss: 3.5375\t\n",
      "epoch: 100\ttrain loss: 0.5269\t\n",
      "epoch: 150\ttrain loss: 0.4032\t\n",
      "epoch: 200\ttrain loss: 0.5773\t\n",
      "epoch: 250\ttrain loss: 0.5804\t\n",
      "mse at 20.0% data: 0.0005644770860671997\n",
      "epoch: 50\ttrain loss: 3.2301\t\n",
      "epoch: 100\ttrain loss: 0.4902\t\n",
      "epoch: 150\ttrain loss: 0.4907\t\n",
      "epoch: 200\ttrain loss: 0.4425\t\n",
      "epoch: 250\ttrain loss: 0.5009\t\n",
      "mse at 30.0% data: 0.000566911518573761\n",
      "epoch: 50\ttrain loss: 3.0936\t\n",
      "epoch: 100\ttrain loss: 0.4760\t\n",
      "epoch: 150\ttrain loss: 0.5089\t\n",
      "epoch: 200\ttrain loss: 0.4663\t\n",
      "epoch: 250\ttrain loss: 0.4661\t\n",
      "mse at 40.0% data: 0.0005647634267807007\n",
      "epoch: 50\ttrain loss: 3.3425\t\n",
      "epoch: 100\ttrain loss: 0.5032\t\n",
      "epoch: 150\ttrain loss: 0.4120\t\n",
      "epoch: 200\ttrain loss: 0.5204\t\n",
      "epoch: 250\ttrain loss: 0.4576\t\n",
      "mse at 50.0% data: 0.000565768837928772\n",
      "epoch: 50\ttrain loss: 3.2584\t\n",
      "epoch: 100\ttrain loss: 0.4651\t\n",
      "epoch: 150\ttrain loss: 0.4889\t\n",
      "epoch: 200\ttrain loss: 0.4830\t\n",
      "epoch: 250\ttrain loss: 0.4599\t\n",
      "mse at 60.0% data: 0.0005630471706390381\n",
      "epoch: 50\ttrain loss: 3.2472\t\n",
      "epoch: 100\ttrain loss: 0.4947\t\n",
      "epoch: 150\ttrain loss: 0.4900\t\n",
      "epoch: 200\ttrain loss: 0.4969\t\n",
      "epoch: 250\ttrain loss: 0.4901\t\n",
      "mse at 70.0% data: 0.0005650327205657959\n",
      "epoch: 50\ttrain loss: 3.1323\t\n",
      "epoch: 100\ttrain loss: 0.5000\t\n",
      "epoch: 150\ttrain loss: 0.4709\t\n",
      "epoch: 200\ttrain loss: 0.4912\t\n",
      "epoch: 250\ttrain loss: 0.4896\t\n",
      "mse at 80.0% data: 0.0005631186962127686\n",
      "epoch: 50\ttrain loss: 3.1776\t\n",
      "epoch: 100\ttrain loss: 0.4756\t\n",
      "epoch: 150\ttrain loss: 0.4832\t\n",
      "epoch: 200\ttrain loss: 0.4806\t\n",
      "epoch: 250\ttrain loss: 0.4878\t\n",
      "mse at 90.0% data: 0.0005635147690773011\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.0934\t\n",
      "epoch: 100\ttrain loss: 1.3789\t\n",
      "epoch: 150\ttrain loss: 0.9828\t\n",
      "epoch: 200\ttrain loss: 0.7304\t\n",
      "epoch: 250\ttrain loss: 0.5780\t\n",
      "mse at 10.0% data: 0.0017046079635620118\n",
      "epoch: 50\ttrain loss: 3.3510\t\n",
      "epoch: 100\ttrain loss: 1.2129\t\n",
      "epoch: 150\ttrain loss: 0.5458\t\n",
      "epoch: 200\ttrain loss: 0.4040\t\n",
      "epoch: 250\ttrain loss: 0.3819\t\n",
      "mse at 20.0% data: 0.0007837243676185608\n",
      "epoch: 50\ttrain loss: 3.5213\t\n",
      "epoch: 100\ttrain loss: 1.0759\t\n",
      "epoch: 150\ttrain loss: 0.5828\t\n",
      "epoch: 200\ttrain loss: 0.5153\t\n",
      "epoch: 250\ttrain loss: 0.5058\t\n",
      "mse at 30.0% data: 0.0006366832256317139\n",
      "epoch: 50\ttrain loss: 3.4195\t\n",
      "epoch: 100\ttrain loss: 1.0908\t\n",
      "epoch: 150\ttrain loss: 0.5777\t\n",
      "epoch: 200\ttrain loss: 0.4959\t\n",
      "epoch: 250\ttrain loss: 0.4849\t\n",
      "mse at 40.0% data: 0.0006185212135314942\n",
      "epoch: 50\ttrain loss: 3.5744\t\n",
      "epoch: 100\ttrain loss: 0.7924\t\n",
      "epoch: 150\ttrain loss: 0.4841\t\n",
      "epoch: 200\ttrain loss: 0.4678\t\n",
      "epoch: 250\ttrain loss: 0.4665\t\n",
      "mse at 50.0% data: 0.0006063135266304016\n",
      "epoch: 50\ttrain loss: 3.2998\t\n",
      "epoch: 100\ttrain loss: 0.6398\t\n",
      "epoch: 150\ttrain loss: 0.4706\t\n",
      "epoch: 200\ttrain loss: 0.4649\t\n",
      "epoch: 250\ttrain loss: 0.4629\t\n",
      "mse at 60.0% data: 0.0005899156928062439\n",
      "epoch: 50\ttrain loss: 3.2243\t\n",
      "epoch: 100\ttrain loss: 0.5777\t\n",
      "epoch: 150\ttrain loss: 0.4693\t\n",
      "epoch: 200\ttrain loss: 0.4669\t\n",
      "epoch: 250\ttrain loss: 0.4658\t\n",
      "mse at 70.0% data: 0.0005801803469657898\n",
      "epoch: 50\ttrain loss: 3.1652\t\n",
      "epoch: 100\ttrain loss: 0.5001\t\n",
      "epoch: 150\ttrain loss: 0.4650\t\n",
      "epoch: 200\ttrain loss: 0.4644\t\n",
      "epoch: 250\ttrain loss: 0.4642\t\n",
      "mse at 80.0% data: 0.0005720962285995484\n",
      "epoch: 50\ttrain loss: 3.2323\t\n",
      "epoch: 100\ttrain loss: 0.5101\t\n",
      "epoch: 150\ttrain loss: 0.4903\t\n",
      "epoch: 200\ttrain loss: 0.4895\t\n",
      "epoch: 250\ttrain loss: 0.4893\t\n",
      "mse at 90.0% data: 0.0005639044046401977\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.000563639760017395\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 1.9441\t\n",
      "epoch: 100\ttrain loss: 1.2590\t\n",
      "epoch: 150\ttrain loss: 0.8865\t\n",
      "epoch: 200\ttrain loss: 0.6639\t\n",
      "epoch: 250\ttrain loss: 0.5336\t\n",
      "mse at 10.0% data: 0.001826493263244629\n",
      "epoch: 50\ttrain loss: 3.2633\t\n",
      "epoch: 100\ttrain loss: 1.3988\t\n",
      "epoch: 150\ttrain loss: 0.6682\t\n",
      "epoch: 200\ttrain loss: 0.4525\t\n",
      "epoch: 250\ttrain loss: 0.4042\t\n",
      "mse at 20.0% data: 0.0007339720129966736\n",
      "epoch: 50\ttrain loss: 3.5179\t\n",
      "epoch: 100\ttrain loss: 1.0547\t\n",
      "epoch: 150\ttrain loss: 0.5552\t\n",
      "epoch: 200\ttrain loss: 0.4829\t\n",
      "epoch: 250\ttrain loss: 0.4720\t\n",
      "mse at 30.0% data: 0.0006321457624435425\n",
      "epoch: 50\ttrain loss: 3.3907\t\n",
      "epoch: 100\ttrain loss: 1.0005\t\n",
      "epoch: 150\ttrain loss: 0.5639\t\n",
      "epoch: 200\ttrain loss: 0.4968\t\n",
      "epoch: 250\ttrain loss: 0.4875\t\n",
      "mse at 40.0% data: 0.0006215267181396484\n",
      "epoch: 50\ttrain loss: 3.3738\t\n",
      "epoch: 100\ttrain loss: 0.8353\t\n",
      "epoch: 150\ttrain loss: 0.5092\t\n",
      "epoch: 200\ttrain loss: 0.4788\t\n",
      "epoch: 250\ttrain loss: 0.4764\t\n",
      "mse at 50.0% data: 0.0006070343852043152\n",
      "epoch: 50\ttrain loss: 3.2954\t\n",
      "epoch: 100\ttrain loss: 0.6254\t\n",
      "epoch: 150\ttrain loss: 0.4695\t\n",
      "epoch: 200\ttrain loss: 0.4646\t\n",
      "epoch: 250\ttrain loss: 0.4626\t\n",
      "mse at 60.0% data: 0.0005869768261909485\n",
      "epoch: 50\ttrain loss: 3.2958\t\n",
      "epoch: 100\ttrain loss: 0.5250\t\n",
      "epoch: 150\ttrain loss: 0.4655\t\n",
      "epoch: 200\ttrain loss: 0.4653\t\n",
      "epoch: 250\ttrain loss: 0.4652\t\n",
      "mse at 70.0% data: 0.0005817586779594421\n",
      "epoch: 50\ttrain loss: 3.1372\t\n",
      "epoch: 100\ttrain loss: 0.4973\t\n",
      "epoch: 150\ttrain loss: 0.4702\t\n",
      "epoch: 200\ttrain loss: 0.4700\t\n",
      "epoch: 250\ttrain loss: 0.4699\t\n",
      "mse at 80.0% data: 0.0005710855722427369\n",
      "epoch: 50\ttrain loss: 3.2399\t\n",
      "epoch: 100\ttrain loss: 0.5116\t\n",
      "epoch: 150\ttrain loss: 0.4909\t\n",
      "epoch: 200\ttrain loss: 0.4899\t\n",
      "epoch: 250\ttrain loss: 0.4897\t\n",
      "mse at 90.0% data: 0.0005636051297187805\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.9805\t\n",
      "epoch: 100\ttrain loss: 1.3395\t\n",
      "epoch: 150\ttrain loss: 0.8317\t\n",
      "epoch: 200\ttrain loss: 0.6377\t\n",
      "epoch: 250\ttrain loss: 0.5307\t\n",
      "mse at 10.0% data: 0.002080388784408569\n",
      "epoch: 50\ttrain loss: 3.4905\t\n",
      "epoch: 100\ttrain loss: 1.1552\t\n",
      "epoch: 150\ttrain loss: 0.6666\t\n",
      "epoch: 200\ttrain loss: 0.5165\t\n",
      "epoch: 250\ttrain loss: 0.4568\t\n",
      "mse at 20.0% data: 0.0008047047257423401\n",
      "epoch: 50\ttrain loss: 3.3000\t\n",
      "epoch: 100\ttrain loss: 1.2346\t\n",
      "epoch: 150\ttrain loss: 0.5839\t\n",
      "epoch: 200\ttrain loss: 0.4510\t\n",
      "epoch: 250\ttrain loss: 0.4328\t\n",
      "mse at 30.0% data: 0.0006929137706756592\n",
      "epoch: 50\ttrain loss: 3.7735\t\n",
      "epoch: 100\ttrain loss: 0.8022\t\n",
      "epoch: 150\ttrain loss: 0.4341\t\n",
      "epoch: 200\ttrain loss: 0.4165\t\n",
      "epoch: 250\ttrain loss: 0.4156\t\n",
      "mse at 40.0% data: 0.0006564903855323792\n",
      "epoch: 50\ttrain loss: 3.6288\t\n",
      "epoch: 100\ttrain loss: 0.7850\t\n",
      "epoch: 150\ttrain loss: 0.4380\t\n",
      "epoch: 200\ttrain loss: 0.4183\t\n",
      "epoch: 250\ttrain loss: 0.4155\t\n",
      "mse at 50.0% data: 0.0006173304319381713\n",
      "epoch: 50\ttrain loss: 3.6991\t\n",
      "epoch: 100\ttrain loss: 0.5365\t\n",
      "epoch: 150\ttrain loss: 0.4182\t\n",
      "epoch: 200\ttrain loss: 0.4140\t\n",
      "epoch: 250\ttrain loss: 0.4119\t\n",
      "mse at 60.0% data: 0.0006154886484146118\n",
      "epoch: 50\ttrain loss: 3.4531\t\n",
      "epoch: 100\ttrain loss: 0.4840\t\n",
      "epoch: 150\ttrain loss: 0.4317\t\n",
      "epoch: 200\ttrain loss: 0.4301\t\n",
      "epoch: 250\ttrain loss: 0.4296\t\n",
      "mse at 70.0% data: 0.0005889078974723816\n",
      "epoch: 50\ttrain loss: 3.4489\t\n",
      "epoch: 100\ttrain loss: 0.4701\t\n",
      "epoch: 150\ttrain loss: 0.4382\t\n",
      "epoch: 200\ttrain loss: 0.4369\t\n",
      "epoch: 250\ttrain loss: 0.4368\t\n",
      "mse at 80.0% data: 0.0005793873071670532\n",
      "epoch: 50\ttrain loss: 3.2720\t\n",
      "epoch: 100\ttrain loss: 0.4444\t\n",
      "epoch: 150\ttrain loss: 0.4321\t\n",
      "epoch: 200\ttrain loss: 0.4320\t\n",
      "epoch: 250\ttrain loss: 0.4320\t\n",
      "mse at 90.0% data: 0.0005705050826072692\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.9588\t\n",
      "epoch: 100\ttrain loss: 0.4485\t\n",
      "epoch: 150\ttrain loss: 0.6878\t\n",
      "epoch: 200\ttrain loss: 0.4650\t\n",
      "epoch: 250\ttrain loss: 0.4980\t\n",
      "mse at 10.0% data: 0.0005728853940963745\n",
      "epoch: 50\ttrain loss: 3.6154\t\n",
      "epoch: 100\ttrain loss: 0.5328\t\n",
      "epoch: 150\ttrain loss: 0.4660\t\n",
      "epoch: 200\ttrain loss: 0.4897\t\n",
      "epoch: 250\ttrain loss: 0.4280\t\n",
      "mse at 20.0% data: 0.000567169189453125\n",
      "epoch: 50\ttrain loss: 3.4857\t\n",
      "epoch: 100\ttrain loss: 0.5294\t\n",
      "epoch: 150\ttrain loss: 0.5690\t\n",
      "epoch: 200\ttrain loss: 0.4857\t\n",
      "epoch: 250\ttrain loss: 0.4727\t\n",
      "mse at 30.0% data: 0.000574584186077118\n",
      "epoch: 50\ttrain loss: 3.1263\t\n",
      "epoch: 100\ttrain loss: 0.4984\t\n",
      "epoch: 150\ttrain loss: 0.4916\t\n",
      "epoch: 200\ttrain loss: 0.4695\t\n",
      "epoch: 250\ttrain loss: 0.4866\t\n",
      "mse at 40.0% data: 0.0005679140090942383\n",
      "epoch: 50\ttrain loss: 3.1763\t\n",
      "epoch: 100\ttrain loss: 0.4335\t\n",
      "epoch: 150\ttrain loss: 0.5114\t\n",
      "epoch: 200\ttrain loss: 0.4943\t\n",
      "epoch: 250\ttrain loss: 0.4602\t\n",
      "mse at 50.0% data: 0.0005671639442443848\n",
      "epoch: 50\ttrain loss: 3.1330\t\n",
      "epoch: 100\ttrain loss: 0.4822\t\n",
      "epoch: 150\ttrain loss: 0.5088\t\n",
      "epoch: 200\ttrain loss: 0.4538\t\n",
      "epoch: 250\ttrain loss: 0.5315\t\n",
      "mse at 60.0% data: 0.0005645161867141724\n",
      "epoch: 50\ttrain loss: 3.0553\t\n",
      "epoch: 100\ttrain loss: 0.4946\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.5034\t\n",
      "epoch: 250\ttrain loss: 0.4748\t\n",
      "mse at 70.0% data: 0.000563862681388855\n",
      "epoch: 50\ttrain loss: 3.2624\t\n",
      "epoch: 100\ttrain loss: 0.5132\t\n",
      "epoch: 150\ttrain loss: 0.4808\t\n",
      "epoch: 200\ttrain loss: 0.4486\t\n",
      "epoch: 250\ttrain loss: 0.4807\t\n",
      "mse at 80.0% data: 0.0005632864832878113\n",
      "epoch: 50\ttrain loss: 3.1968\t\n",
      "epoch: 100\ttrain loss: 0.4872\t\n",
      "epoch: 150\ttrain loss: 0.4873\t\n",
      "epoch: 200\ttrain loss: 0.4744\t\n",
      "epoch: 250\ttrain loss: 0.4839\t\n",
      "mse at 90.0% data: 0.0005671277046203614\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 1.8861\t\n",
      "epoch: 100\ttrain loss: 1.2310\t\n",
      "epoch: 150\ttrain loss: 0.8997\t\n",
      "epoch: 200\ttrain loss: 0.6776\t\n",
      "epoch: 250\ttrain loss: 0.5396\t\n",
      "mse at 10.0% data: 0.0017790954113006592\n",
      "epoch: 50\ttrain loss: 2.5164\t\n",
      "epoch: 100\ttrain loss: 1.1270\t\n",
      "epoch: 150\ttrain loss: 0.5799\t\n",
      "epoch: 200\ttrain loss: 0.4033\t\n",
      "epoch: 250\ttrain loss: 0.3603\t\n",
      "mse at 20.0% data: 0.0009638389348983764\n",
      "epoch: 50\ttrain loss: 3.1060\t\n",
      "epoch: 100\ttrain loss: 1.2022\t\n",
      "epoch: 150\ttrain loss: 0.6005\t\n",
      "epoch: 200\ttrain loss: 0.4592\t\n",
      "epoch: 250\ttrain loss: 0.4340\t\n",
      "mse at 30.0% data: 0.0007314789295196533\n",
      "epoch: 50\ttrain loss: 3.1237\t\n",
      "epoch: 100\ttrain loss: 0.9617\t\n",
      "epoch: 150\ttrain loss: 0.5380\t\n",
      "epoch: 200\ttrain loss: 0.4456\t\n",
      "epoch: 250\ttrain loss: 0.4271\t\n",
      "mse at 40.0% data: 0.0006592149138450622\n",
      "epoch: 50\ttrain loss: 3.2757\t\n",
      "epoch: 100\ttrain loss: 0.7496\t\n",
      "epoch: 150\ttrain loss: 0.4499\t\n",
      "epoch: 200\ttrain loss: 0.4142\t\n",
      "epoch: 250\ttrain loss: 0.4097\t\n",
      "mse at 50.0% data: 0.0006152807474136353\n",
      "epoch: 50\ttrain loss: 3.3205\t\n",
      "epoch: 100\ttrain loss: 0.5964\t\n",
      "epoch: 150\ttrain loss: 0.4196\t\n",
      "epoch: 200\ttrain loss: 0.4151\t\n",
      "epoch: 250\ttrain loss: 0.4143\t\n",
      "mse at 60.0% data: 0.000600687026977539\n",
      "epoch: 50\ttrain loss: 3.1675\t\n",
      "epoch: 100\ttrain loss: 0.5487\t\n",
      "epoch: 150\ttrain loss: 0.4539\t\n",
      "epoch: 200\ttrain loss: 0.4516\t\n",
      "epoch: 250\ttrain loss: 0.4504\t\n",
      "mse at 70.0% data: 0.0005808348655700683\n",
      "epoch: 50\ttrain loss: 3.2325\t\n",
      "epoch: 100\ttrain loss: 0.5321\t\n",
      "epoch: 150\ttrain loss: 0.4874\t\n",
      "epoch: 200\ttrain loss: 0.4862\t\n",
      "epoch: 250\ttrain loss: 0.4858\t\n",
      "mse at 80.0% data: 0.0005658577084541321\n",
      "epoch: 50\ttrain loss: 3.2137\t\n",
      "epoch: 100\ttrain loss: 0.5126\t\n",
      "epoch: 150\ttrain loss: 0.4963\t\n",
      "epoch: 200\ttrain loss: 0.4958\t\n",
      "epoch: 250\ttrain loss: 0.4957\t\n",
      "mse at 90.0% data: 0.0005637686252593995\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 1.9531\t\n",
      "epoch: 100\ttrain loss: 1.2512\t\n",
      "epoch: 150\ttrain loss: 0.8815\t\n",
      "epoch: 200\ttrain loss: 0.6411\t\n",
      "epoch: 250\ttrain loss: 0.5028\t\n",
      "mse at 10.0% data: 0.0017072783708572388\n",
      "epoch: 50\ttrain loss: 2.6237\t\n",
      "epoch: 100\ttrain loss: 1.2034\t\n",
      "epoch: 150\ttrain loss: 0.6022\t\n",
      "epoch: 200\ttrain loss: 0.3937\t\n",
      "epoch: 250\ttrain loss: 0.3383\t\n",
      "mse at 20.0% data: 0.000893819510936737\n",
      "epoch: 50\ttrain loss: 3.0903\t\n",
      "epoch: 100\ttrain loss: 1.1936\t\n",
      "epoch: 150\ttrain loss: 0.5993\t\n",
      "epoch: 200\ttrain loss: 0.4574\t\n",
      "epoch: 250\ttrain loss: 0.4316\t\n",
      "mse at 30.0% data: 0.000763555645942688\n",
      "epoch: 50\ttrain loss: 3.1459\t\n",
      "epoch: 100\ttrain loss: 0.9608\t\n",
      "epoch: 150\ttrain loss: 0.5361\t\n",
      "epoch: 200\ttrain loss: 0.4480\t\n",
      "epoch: 250\ttrain loss: 0.4315\t\n",
      "mse at 40.0% data: 0.0006894755959510803\n",
      "epoch: 50\ttrain loss: 3.2234\t\n",
      "epoch: 100\ttrain loss: 0.7732\t\n",
      "epoch: 150\ttrain loss: 0.4743\t\n",
      "epoch: 200\ttrain loss: 0.4309\t\n",
      "epoch: 250\ttrain loss: 0.4252\t\n",
      "mse at 50.0% data: 0.000610639214515686\n",
      "epoch: 50\ttrain loss: 3.3323\t\n",
      "epoch: 100\ttrain loss: 0.6088\t\n",
      "epoch: 150\ttrain loss: 0.4287\t\n",
      "epoch: 200\ttrain loss: 0.4242\t\n",
      "epoch: 250\ttrain loss: 0.4236\t\n",
      "mse at 60.0% data: 0.0006050601005554199\n",
      "epoch: 50\ttrain loss: 3.1601\t\n",
      "epoch: 100\ttrain loss: 0.5549\t\n",
      "epoch: 150\ttrain loss: 0.4507\t\n",
      "epoch: 200\ttrain loss: 0.4490\t\n",
      "epoch: 250\ttrain loss: 0.4482\t\n",
      "mse at 70.0% data: 0.0005841503143310546\n",
      "epoch: 50\ttrain loss: 3.2426\t\n",
      "epoch: 100\ttrain loss: 0.5187\t\n",
      "epoch: 150\ttrain loss: 0.4814\t\n",
      "epoch: 200\ttrain loss: 0.4805\t\n",
      "epoch: 250\ttrain loss: 0.4801\t\n",
      "mse at 80.0% data: 0.000566646933555603\n",
      "epoch: 50\ttrain loss: 3.2301\t\n",
      "epoch: 100\ttrain loss: 0.5078\t\n",
      "epoch: 150\ttrain loss: 0.4918\t\n",
      "epoch: 200\ttrain loss: 0.4914\t\n",
      "epoch: 250\ttrain loss: 0.4913\t\n",
      "mse at 90.0% data: 0.00056465083360672\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.000563639760017395\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.9883\t\n",
      "epoch: 100\ttrain loss: 1.4276\t\n",
      "epoch: 150\ttrain loss: 0.8830\t\n",
      "epoch: 200\ttrain loss: 0.6956\t\n",
      "epoch: 250\ttrain loss: 0.6004\t\n",
      "mse at 10.0% data: 0.002146073579788208\n",
      "epoch: 50\ttrain loss: 2.6263\t\n",
      "epoch: 100\ttrain loss: 1.3521\t\n",
      "epoch: 150\ttrain loss: 0.8835\t\n",
      "epoch: 200\ttrain loss: 0.6710\t\n",
      "epoch: 250\ttrain loss: 0.5502\t\n",
      "mse at 20.0% data: 0.001468891143798828\n",
      "epoch: 50\ttrain loss: 2.5561\t\n",
      "epoch: 100\ttrain loss: 1.3614\t\n",
      "epoch: 150\ttrain loss: 0.8442\t\n",
      "epoch: 200\ttrain loss: 0.5846\t\n",
      "epoch: 250\ttrain loss: 0.4639\t\n",
      "mse at 30.0% data: 0.0010254852771759033\n",
      "epoch: 50\ttrain loss: 3.8322\t\n",
      "epoch: 100\ttrain loss: 0.9136\t\n",
      "epoch: 150\ttrain loss: 0.4519\t\n",
      "epoch: 200\ttrain loss: 0.3927\t\n",
      "epoch: 250\ttrain loss: 0.3853\t\n",
      "mse at 40.0% data: 0.0006777209639549256\n",
      "epoch: 50\ttrain loss: 3.7752\t\n",
      "epoch: 100\ttrain loss: 0.6511\t\n",
      "epoch: 150\ttrain loss: 0.3972\t\n",
      "epoch: 200\ttrain loss: 0.3818\t\n",
      "epoch: 250\ttrain loss: 0.3781\t\n",
      "mse at 50.0% data: 0.0006336755752563477\n",
      "epoch: 50\ttrain loss: 3.6720\t\n",
      "epoch: 100\ttrain loss: 0.5151\t\n",
      "epoch: 150\ttrain loss: 0.3964\t\n",
      "epoch: 200\ttrain loss: 0.3932\t\n",
      "epoch: 250\ttrain loss: 0.3918\t\n",
      "mse at 60.0% data: 0.000607141375541687\n",
      "epoch: 50\ttrain loss: 3.5318\t\n",
      "epoch: 100\ttrain loss: 0.4741\t\n",
      "epoch: 150\ttrain loss: 0.4063\t\n",
      "epoch: 200\ttrain loss: 0.4042\t\n",
      "epoch: 250\ttrain loss: 0.4036\t\n",
      "mse at 70.0% data: 0.0005944486260414123\n",
      "epoch: 50\ttrain loss: 3.4147\t\n",
      "epoch: 100\ttrain loss: 0.4210\t\n",
      "epoch: 150\ttrain loss: 0.3985\t\n",
      "epoch: 200\ttrain loss: 0.3983\t\n",
      "epoch: 250\ttrain loss: 0.3983\t\n",
      "mse at 80.0% data: 0.0005778031349182129\n",
      "epoch: 50\ttrain loss: 3.2483\t\n",
      "epoch: 100\ttrain loss: 0.4353\t\n",
      "epoch: 150\ttrain loss: 0.4248\t\n",
      "epoch: 200\ttrain loss: 0.4247\t\n",
      "epoch: 250\ttrain loss: 0.4247\t\n",
      "mse at 90.0% data: 0.0005678879022598266\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.1856\t\n",
      "epoch: 100\ttrain loss: 0.4416\t\n",
      "epoch: 150\ttrain loss: 0.4538\t\n",
      "epoch: 200\ttrain loss: 0.3483\t\n",
      "epoch: 250\ttrain loss: 0.3531\t\n",
      "mse at 10.0% data: 0.0005713787078857422\n",
      "epoch: 50\ttrain loss: 3.2708\t\n",
      "epoch: 100\ttrain loss: 0.6046\t\n",
      "epoch: 150\ttrain loss: 0.4360\t\n",
      "epoch: 200\ttrain loss: 0.5047\t\n",
      "epoch: 250\ttrain loss: 0.4194\t\n",
      "mse at 20.0% data: 0.0005638952851295472\n",
      "epoch: 50\ttrain loss: 3.7011\t\n",
      "epoch: 100\ttrain loss: 0.5489\t\n",
      "epoch: 150\ttrain loss: 0.4447\t\n",
      "epoch: 200\ttrain loss: 0.5199\t\n",
      "epoch: 250\ttrain loss: 0.5695\t\n",
      "mse at 30.0% data: 0.0005634349584579468\n",
      "epoch: 50\ttrain loss: 3.2402\t\n",
      "epoch: 100\ttrain loss: 0.4426\t\n",
      "epoch: 150\ttrain loss: 0.4712\t\n",
      "epoch: 200\ttrain loss: 0.4663\t\n",
      "epoch: 250\ttrain loss: 0.4165\t\n",
      "mse at 40.0% data: 0.000568690836429596\n",
      "epoch: 50\ttrain loss: 3.3814\t\n",
      "epoch: 100\ttrain loss: 0.4693\t\n",
      "epoch: 150\ttrain loss: 0.4532\t\n",
      "epoch: 200\ttrain loss: 0.4479\t\n",
      "epoch: 250\ttrain loss: 0.5042\t\n",
      "mse at 50.0% data: 0.0005636224150657653\n",
      "epoch: 50\ttrain loss: 3.0518\t\n",
      "epoch: 100\ttrain loss: 0.5157\t\n",
      "epoch: 150\ttrain loss: 0.4969\t\n",
      "epoch: 200\ttrain loss: 0.4571\t\n",
      "epoch: 250\ttrain loss: 0.4866\t\n",
      "mse at 60.0% data: 0.0005672191381454468\n",
      "epoch: 50\ttrain loss: 3.3086\t\n",
      "epoch: 100\ttrain loss: 0.4395\t\n",
      "epoch: 150\ttrain loss: 0.5210\t\n",
      "epoch: 200\ttrain loss: 0.4825\t\n",
      "epoch: 250\ttrain loss: 0.5026\t\n",
      "mse at 70.0% data: 0.0005674630999565124\n",
      "epoch: 50\ttrain loss: 3.1930\t\n",
      "epoch: 100\ttrain loss: 0.4637\t\n",
      "epoch: 150\ttrain loss: 0.4771\t\n",
      "epoch: 200\ttrain loss: 0.4753\t\n",
      "epoch: 250\ttrain loss: 0.5187\t\n",
      "mse at 80.0% data: 0.0005642616152763366\n",
      "epoch: 50\ttrain loss: 3.1927\t\n",
      "epoch: 100\ttrain loss: 0.4999\t\n",
      "epoch: 150\ttrain loss: 0.4736\t\n",
      "epoch: 200\ttrain loss: 0.4808\t\n",
      "epoch: 250\ttrain loss: 0.4781\t\n",
      "mse at 90.0% data: 0.0005642329454421997\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.0782\t\n",
      "epoch: 100\ttrain loss: 1.1901\t\n",
      "epoch: 150\ttrain loss: 0.5700\t\n",
      "epoch: 200\ttrain loss: 0.3752\t\n",
      "epoch: 250\ttrain loss: 0.3207\t\n",
      "mse at 10.0% data: 0.0009509060382843018\n",
      "epoch: 50\ttrain loss: 3.2098\t\n",
      "epoch: 100\ttrain loss: 1.2400\t\n",
      "epoch: 150\ttrain loss: 0.6108\t\n",
      "epoch: 200\ttrain loss: 0.4551\t\n",
      "epoch: 250\ttrain loss: 0.4209\t\n",
      "mse at 20.0% data: 0.000685706913471222\n",
      "epoch: 50\ttrain loss: 3.3940\t\n",
      "epoch: 100\ttrain loss: 1.0535\t\n",
      "epoch: 150\ttrain loss: 0.4889\t\n",
      "epoch: 200\ttrain loss: 0.3934\t\n",
      "epoch: 250\ttrain loss: 0.3811\t\n",
      "mse at 30.0% data: 0.000645017147064209\n",
      "epoch: 50\ttrain loss: 3.3668\t\n",
      "epoch: 100\ttrain loss: 0.8358\t\n",
      "epoch: 150\ttrain loss: 0.4838\t\n",
      "epoch: 200\ttrain loss: 0.4403\t\n",
      "epoch: 250\ttrain loss: 0.4357\t\n",
      "mse at 40.0% data: 0.0006049312353134155\n",
      "epoch: 50\ttrain loss: 3.3763\t\n",
      "epoch: 100\ttrain loss: 0.6861\t\n",
      "epoch: 150\ttrain loss: 0.4379\t\n",
      "epoch: 200\ttrain loss: 0.4273\t\n",
      "epoch: 250\ttrain loss: 0.4259\t\n",
      "mse at 50.0% data: 0.0005980144143104553\n",
      "epoch: 50\ttrain loss: 3.1537\t\n",
      "epoch: 100\ttrain loss: 0.6092\t\n",
      "epoch: 150\ttrain loss: 0.4521\t\n",
      "epoch: 200\ttrain loss: 0.4482\t\n",
      "epoch: 250\ttrain loss: 0.4474\t\n",
      "mse at 60.0% data: 0.000584835171699524\n",
      "epoch: 50\ttrain loss: 3.1808\t\n",
      "epoch: 100\ttrain loss: 0.5838\t\n",
      "epoch: 150\ttrain loss: 0.4693\t\n",
      "epoch: 200\ttrain loss: 0.4667\t\n",
      "epoch: 250\ttrain loss: 0.4656\t\n",
      "mse at 70.0% data: 0.0005727059841156006\n",
      "epoch: 50\ttrain loss: 3.2350\t\n",
      "epoch: 100\ttrain loss: 0.5096\t\n",
      "epoch: 150\ttrain loss: 0.4649\t\n",
      "epoch: 200\ttrain loss: 0.4636\t\n",
      "epoch: 250\ttrain loss: 0.4632\t\n",
      "mse at 80.0% data: 0.0005700224041938781\n",
      "epoch: 50\ttrain loss: 3.1935\t\n",
      "epoch: 100\ttrain loss: 0.5018\t\n",
      "epoch: 150\ttrain loss: 0.4822\t\n",
      "epoch: 200\ttrain loss: 0.4814\t\n",
      "epoch: 250\ttrain loss: 0.4813\t\n",
      "mse at 90.0% data: 0.0005651459097862244\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.000563639760017395\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.2157\t\n",
      "epoch: 100\ttrain loss: 1.3150\t\n",
      "epoch: 150\ttrain loss: 0.5969\t\n",
      "epoch: 200\ttrain loss: 0.3909\t\n",
      "epoch: 250\ttrain loss: 0.3424\t\n",
      "mse at 10.0% data: 0.0009828918576240539\n",
      "epoch: 50\ttrain loss: 3.1895\t\n",
      "epoch: 100\ttrain loss: 1.2271\t\n",
      "epoch: 150\ttrain loss: 0.6220\t\n",
      "epoch: 200\ttrain loss: 0.4756\t\n",
      "epoch: 250\ttrain loss: 0.4430\t\n",
      "mse at 20.0% data: 0.0007016106247901917\n",
      "epoch: 50\ttrain loss: 2.9967\t\n",
      "epoch: 100\ttrain loss: 1.0617\t\n",
      "epoch: 150\ttrain loss: 0.5346\t\n",
      "epoch: 200\ttrain loss: 0.4148\t\n",
      "epoch: 250\ttrain loss: 0.3931\t\n",
      "mse at 30.0% data: 0.0007074858546257019\n",
      "epoch: 50\ttrain loss: 3.3858\t\n",
      "epoch: 100\ttrain loss: 0.8027\t\n",
      "epoch: 150\ttrain loss: 0.4671\t\n",
      "epoch: 200\ttrain loss: 0.4359\t\n",
      "epoch: 250\ttrain loss: 0.4323\t\n",
      "mse at 40.0% data: 0.0006214896440505981\n",
      "epoch: 50\ttrain loss: 3.3314\t\n",
      "epoch: 100\ttrain loss: 0.7064\t\n",
      "epoch: 150\ttrain loss: 0.4555\t\n",
      "epoch: 200\ttrain loss: 0.4394\t\n",
      "epoch: 250\ttrain loss: 0.4370\t\n",
      "mse at 50.0% data: 0.0005989458560943604\n",
      "epoch: 50\ttrain loss: 3.2426\t\n",
      "epoch: 100\ttrain loss: 0.6076\t\n",
      "epoch: 150\ttrain loss: 0.4648\t\n",
      "epoch: 200\ttrain loss: 0.4621\t\n",
      "epoch: 250\ttrain loss: 0.4614\t\n",
      "mse at 60.0% data: 0.0005770776867866516\n",
      "epoch: 50\ttrain loss: 3.2032\t\n",
      "epoch: 100\ttrain loss: 0.5982\t\n",
      "epoch: 150\ttrain loss: 0.4748\t\n",
      "epoch: 200\ttrain loss: 0.4718\t\n",
      "epoch: 250\ttrain loss: 0.4705\t\n",
      "mse at 70.0% data: 0.0005714372992515564\n",
      "epoch: 50\ttrain loss: 3.1534\t\n",
      "epoch: 100\ttrain loss: 0.4982\t\n",
      "epoch: 150\ttrain loss: 0.4708\t\n",
      "epoch: 200\ttrain loss: 0.4704\t\n",
      "epoch: 250\ttrain loss: 0.4702\t\n",
      "mse at 80.0% data: 0.0005689548850059509\n",
      "epoch: 50\ttrain loss: 3.1951\t\n",
      "epoch: 100\ttrain loss: 0.5021\t\n",
      "epoch: 150\ttrain loss: 0.4822\t\n",
      "epoch: 200\ttrain loss: 0.4813\t\n",
      "epoch: 250\ttrain loss: 0.4812\t\n",
      "mse at 90.0% data: 0.000565207064151764\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.9981\t\n",
      "epoch: 100\ttrain loss: 1.4816\t\n",
      "epoch: 150\ttrain loss: 0.8024\t\n",
      "epoch: 200\ttrain loss: 0.5158\t\n",
      "epoch: 250\ttrain loss: 0.3989\t\n",
      "mse at 10.0% data: 0.0012276617288589477\n",
      "epoch: 50\ttrain loss: 3.3812\t\n",
      "epoch: 100\ttrain loss: 1.3892\t\n",
      "epoch: 150\ttrain loss: 0.6994\t\n",
      "epoch: 200\ttrain loss: 0.4670\t\n",
      "epoch: 250\ttrain loss: 0.3859\t\n",
      "mse at 20.0% data: 0.0008055959939956665\n",
      "epoch: 50\ttrain loss: 3.6777\t\n",
      "epoch: 100\ttrain loss: 1.2529\t\n",
      "epoch: 150\ttrain loss: 0.5908\t\n",
      "epoch: 200\ttrain loss: 0.4230\t\n",
      "epoch: 250\ttrain loss: 0.3793\t\n",
      "mse at 30.0% data: 0.0007426915764808655\n",
      "epoch: 50\ttrain loss: 3.6500\t\n",
      "epoch: 100\ttrain loss: 1.0461\t\n",
      "epoch: 150\ttrain loss: 0.5027\t\n",
      "epoch: 200\ttrain loss: 0.4048\t\n",
      "epoch: 250\ttrain loss: 0.3890\t\n",
      "mse at 40.0% data: 0.000706546425819397\n",
      "epoch: 50\ttrain loss: 4.0152\t\n",
      "epoch: 100\ttrain loss: 0.6323\t\n",
      "epoch: 150\ttrain loss: 0.3643\t\n",
      "epoch: 200\ttrain loss: 0.3552\t\n",
      "epoch: 250\ttrain loss: 0.3531\t\n",
      "mse at 50.0% data: 0.0006836512684822082\n",
      "epoch: 50\ttrain loss: 3.7430\t\n",
      "epoch: 100\ttrain loss: 0.4949\t\n",
      "epoch: 150\ttrain loss: 0.3983\t\n",
      "epoch: 200\ttrain loss: 0.3950\t\n",
      "epoch: 250\ttrain loss: 0.3935\t\n",
      "mse at 60.0% data: 0.000608996570110321\n",
      "epoch: 50\ttrain loss: 3.6158\t\n",
      "epoch: 100\ttrain loss: 0.4676\t\n",
      "epoch: 150\ttrain loss: 0.4124\t\n",
      "epoch: 200\ttrain loss: 0.4103\t\n",
      "epoch: 250\ttrain loss: 0.4097\t\n",
      "mse at 70.0% data: 0.0005937795639038086\n",
      "epoch: 50\ttrain loss: 3.4628\t\n",
      "epoch: 100\ttrain loss: 0.4390\t\n",
      "epoch: 150\ttrain loss: 0.4136\t\n",
      "epoch: 200\ttrain loss: 0.4134\t\n",
      "epoch: 250\ttrain loss: 0.4134\t\n",
      "mse at 80.0% data: 0.0005814024209976196\n",
      "epoch: 50\ttrain loss: 3.2500\t\n",
      "epoch: 100\ttrain loss: 0.4371\t\n",
      "epoch: 150\ttrain loss: 0.4256\t\n",
      "epoch: 200\ttrain loss: 0.4254\t\n",
      "epoch: 250\ttrain loss: 0.4254\t\n",
      "mse at 90.0% data: 0.0005719125270843506\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.5675\t\n",
      "epoch: 100\ttrain loss: 0.6109\t\n",
      "epoch: 150\ttrain loss: 0.5881\t\n",
      "epoch: 200\ttrain loss: 0.4269\t\n",
      "epoch: 250\ttrain loss: 0.6121\t\n",
      "mse at 10.0% data: 0.0005728737115859986\n",
      "epoch: 50\ttrain loss: 3.5720\t\n",
      "epoch: 100\ttrain loss: 0.4135\t\n",
      "epoch: 150\ttrain loss: 0.3728\t\n",
      "epoch: 200\ttrain loss: 0.4251\t\n",
      "epoch: 250\ttrain loss: 0.4235\t\n",
      "mse at 20.0% data: 0.0005664930939674377\n",
      "epoch: 50\ttrain loss: 3.0851\t\n",
      "epoch: 100\ttrain loss: 0.4706\t\n",
      "epoch: 150\ttrain loss: 0.5188\t\n",
      "epoch: 200\ttrain loss: 0.4960\t\n",
      "epoch: 250\ttrain loss: 0.4587\t\n",
      "mse at 30.0% data: 0.0005703174471855164\n",
      "epoch: 50\ttrain loss: 3.2424\t\n",
      "epoch: 100\ttrain loss: 0.5081\t\n",
      "epoch: 150\ttrain loss: 0.4411\t\n",
      "epoch: 200\ttrain loss: 0.4155\t\n",
      "epoch: 250\ttrain loss: 0.4648\t\n",
      "mse at 40.0% data: 0.0005671166181564332\n",
      "epoch: 50\ttrain loss: 3.4203\t\n",
      "epoch: 100\ttrain loss: 0.4947\t\n",
      "epoch: 150\ttrain loss: 0.4581\t\n",
      "epoch: 200\ttrain loss: 0.4727\t\n",
      "epoch: 250\ttrain loss: 0.4698\t\n",
      "mse at 50.0% data: 0.0005672038793563843\n",
      "epoch: 50\ttrain loss: 3.2672\t\n",
      "epoch: 100\ttrain loss: 0.5024\t\n",
      "epoch: 150\ttrain loss: 0.4523\t\n",
      "epoch: 200\ttrain loss: 0.4520\t\n",
      "epoch: 250\ttrain loss: 0.4684\t\n",
      "mse at 60.0% data: 0.0005652893185615539\n",
      "epoch: 50\ttrain loss: 3.2491\t\n",
      "epoch: 100\ttrain loss: 0.5366\t\n",
      "epoch: 150\ttrain loss: 0.5027\t\n",
      "epoch: 200\ttrain loss: 0.4419\t\n",
      "epoch: 250\ttrain loss: 0.4188\t\n",
      "mse at 70.0% data: 0.0005640748739242554\n",
      "epoch: 50\ttrain loss: 3.0618\t\n",
      "epoch: 100\ttrain loss: 0.4806\t\n",
      "epoch: 150\ttrain loss: 0.5093\t\n",
      "epoch: 200\ttrain loss: 0.4666\t\n",
      "epoch: 250\ttrain loss: 0.4867\t\n",
      "mse at 80.0% data: 0.0005638053417205811\n",
      "epoch: 50\ttrain loss: 3.1636\t\n",
      "epoch: 100\ttrain loss: 0.4785\t\n",
      "epoch: 150\ttrain loss: 0.5087\t\n",
      "epoch: 200\ttrain loss: 0.4809\t\n",
      "epoch: 250\ttrain loss: 0.4937\t\n",
      "mse at 90.0% data: 0.0005634436011314392\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 2.0563\t\n",
      "epoch: 100\ttrain loss: 1.2549\t\n",
      "epoch: 150\ttrain loss: 0.8607\t\n",
      "epoch: 200\ttrain loss: 0.6203\t\n",
      "epoch: 250\ttrain loss: 0.4850\t\n",
      "mse at 10.0% data: 0.0014573138952255248\n",
      "epoch: 50\ttrain loss: 2.7781\t\n",
      "epoch: 100\ttrain loss: 1.2707\t\n",
      "epoch: 150\ttrain loss: 0.6854\t\n",
      "epoch: 200\ttrain loss: 0.4820\t\n",
      "epoch: 250\ttrain loss: 0.4187\t\n",
      "mse at 20.0% data: 0.0007490827441215515\n",
      "epoch: 50\ttrain loss: 3.1924\t\n",
      "epoch: 100\ttrain loss: 0.9728\t\n",
      "epoch: 150\ttrain loss: 0.5097\t\n",
      "epoch: 200\ttrain loss: 0.4223\t\n",
      "epoch: 250\ttrain loss: 0.4045\t\n",
      "mse at 30.0% data: 0.0006595107913017272\n",
      "epoch: 50\ttrain loss: 3.3969\t\n",
      "epoch: 100\ttrain loss: 0.9603\t\n",
      "epoch: 150\ttrain loss: 0.4875\t\n",
      "epoch: 200\ttrain loss: 0.4225\t\n",
      "epoch: 250\ttrain loss: 0.4157\t\n",
      "mse at 40.0% data: 0.000643243432044983\n",
      "epoch: 50\ttrain loss: 3.4435\t\n",
      "epoch: 100\ttrain loss: 0.7454\t\n",
      "epoch: 150\ttrain loss: 0.4836\t\n",
      "epoch: 200\ttrain loss: 0.4720\t\n",
      "epoch: 250\ttrain loss: 0.4708\t\n",
      "mse at 50.0% data: 0.0006175781488418579\n",
      "epoch: 50\ttrain loss: 3.2942\t\n",
      "epoch: 100\ttrain loss: 0.6750\t\n",
      "epoch: 150\ttrain loss: 0.4743\t\n",
      "epoch: 200\ttrain loss: 0.4671\t\n",
      "epoch: 250\ttrain loss: 0.4657\t\n",
      "mse at 60.0% data: 0.0005970389842987061\n",
      "epoch: 50\ttrain loss: 3.2982\t\n",
      "epoch: 100\ttrain loss: 0.5641\t\n",
      "epoch: 150\ttrain loss: 0.4843\t\n",
      "epoch: 200\ttrain loss: 0.4826\t\n",
      "epoch: 250\ttrain loss: 0.4816\t\n",
      "mse at 70.0% data: 0.0005766192674636841\n",
      "epoch: 50\ttrain loss: 3.1620\t\n",
      "epoch: 100\ttrain loss: 0.5101\t\n",
      "epoch: 150\ttrain loss: 0.4849\t\n",
      "epoch: 200\ttrain loss: 0.4847\t\n",
      "epoch: 250\ttrain loss: 0.4847\t\n",
      "mse at 80.0% data: 0.0005675044059753418\n",
      "epoch: 50\ttrain loss: 3.1884\t\n",
      "epoch: 100\ttrain loss: 0.4990\t\n",
      "epoch: 150\ttrain loss: 0.4812\t\n",
      "epoch: 200\ttrain loss: 0.4804\t\n",
      "epoch: 250\ttrain loss: 0.4803\t\n",
      "mse at 90.0% data: 0.0005654208064079285\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 1.9409\t\n",
      "epoch: 100\ttrain loss: 1.1933\t\n",
      "epoch: 150\ttrain loss: 0.8536\t\n",
      "epoch: 200\ttrain loss: 0.6309\t\n",
      "epoch: 250\ttrain loss: 0.4992\t\n",
      "mse at 10.0% data: 0.0016498162746429444\n",
      "epoch: 50\ttrain loss: 2.7055\t\n",
      "epoch: 100\ttrain loss: 1.2177\t\n",
      "epoch: 150\ttrain loss: 0.6518\t\n",
      "epoch: 200\ttrain loss: 0.4553\t\n",
      "epoch: 250\ttrain loss: 0.3976\t\n",
      "mse at 20.0% data: 0.0007194368839263916\n",
      "epoch: 50\ttrain loss: 3.1565\t\n",
      "epoch: 100\ttrain loss: 0.9484\t\n",
      "epoch: 150\ttrain loss: 0.5033\t\n",
      "epoch: 200\ttrain loss: 0.4163\t\n",
      "epoch: 250\ttrain loss: 0.3975\t\n",
      "mse at 30.0% data: 0.0006729257106781006\n",
      "epoch: 50\ttrain loss: 3.2214\t\n",
      "epoch: 100\ttrain loss: 0.9740\t\n",
      "epoch: 150\ttrain loss: 0.4806\t\n",
      "epoch: 200\ttrain loss: 0.4042\t\n",
      "epoch: 250\ttrain loss: 0.3961\t\n",
      "mse at 40.0% data: 0.0006371562480926514\n",
      "epoch: 50\ttrain loss: 3.4028\t\n",
      "epoch: 100\ttrain loss: 0.7215\t\n",
      "epoch: 150\ttrain loss: 0.4562\t\n",
      "epoch: 200\ttrain loss: 0.4442\t\n",
      "epoch: 250\ttrain loss: 0.4431\t\n",
      "mse at 50.0% data: 0.0006306922435760498\n",
      "epoch: 50\ttrain loss: 3.2668\t\n",
      "epoch: 100\ttrain loss: 0.6652\t\n",
      "epoch: 150\ttrain loss: 0.4804\t\n",
      "epoch: 200\ttrain loss: 0.4749\t\n",
      "epoch: 250\ttrain loss: 0.4741\t\n",
      "mse at 60.0% data: 0.0005886809229850769\n",
      "epoch: 50\ttrain loss: 3.2435\t\n",
      "epoch: 100\ttrain loss: 0.5526\t\n",
      "epoch: 150\ttrain loss: 0.4753\t\n",
      "epoch: 200\ttrain loss: 0.4734\t\n",
      "epoch: 250\ttrain loss: 0.4724\t\n",
      "mse at 70.0% data: 0.0005727996826171875\n",
      "epoch: 50\ttrain loss: 3.1488\t\n",
      "epoch: 100\ttrain loss: 0.5031\t\n",
      "epoch: 150\ttrain loss: 0.4757\t\n",
      "epoch: 200\ttrain loss: 0.4756\t\n",
      "epoch: 250\ttrain loss: 0.4755\t\n",
      "mse at 80.0% data: 0.000568518340587616\n",
      "epoch: 50\ttrain loss: 3.1943\t\n",
      "epoch: 100\ttrain loss: 0.5088\t\n",
      "epoch: 150\ttrain loss: 0.4930\t\n",
      "epoch: 200\ttrain loss: 0.4926\t\n",
      "epoch: 250\ttrain loss: 0.4926\t\n",
      "mse at 90.0% data: 0.0005644780397415162\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.0695\t\n",
      "epoch: 100\ttrain loss: 1.4009\t\n",
      "epoch: 150\ttrain loss: 0.8247\t\n",
      "epoch: 200\ttrain loss: 0.5988\t\n",
      "epoch: 250\ttrain loss: 0.4905\t\n",
      "mse at 10.0% data: 0.002070908784866333\n",
      "epoch: 50\ttrain loss: 4.0413\t\n",
      "epoch: 100\ttrain loss: 1.1970\t\n",
      "epoch: 150\ttrain loss: 0.5549\t\n",
      "epoch: 200\ttrain loss: 0.4210\t\n",
      "epoch: 250\ttrain loss: 0.3930\t\n",
      "mse at 20.0% data: 0.0007949569821357728\n",
      "epoch: 50\ttrain loss: 3.6110\t\n",
      "epoch: 100\ttrain loss: 1.2149\t\n",
      "epoch: 150\ttrain loss: 0.5662\t\n",
      "epoch: 200\ttrain loss: 0.4159\t\n",
      "epoch: 250\ttrain loss: 0.3852\t\n",
      "mse at 30.0% data: 0.0007217771410942078\n",
      "epoch: 50\ttrain loss: 3.7718\t\n",
      "epoch: 100\ttrain loss: 0.8679\t\n",
      "epoch: 150\ttrain loss: 0.4763\t\n",
      "epoch: 200\ttrain loss: 0.4109\t\n",
      "epoch: 250\ttrain loss: 0.3956\t\n",
      "mse at 40.0% data: 0.0006811674237251282\n",
      "epoch: 50\ttrain loss: 3.6039\t\n",
      "epoch: 100\ttrain loss: 0.7124\t\n",
      "epoch: 150\ttrain loss: 0.4306\t\n",
      "epoch: 200\ttrain loss: 0.3918\t\n",
      "epoch: 250\ttrain loss: 0.3848\t\n",
      "mse at 50.0% data: 0.0006394466757774353\n",
      "epoch: 50\ttrain loss: 3.7861\t\n",
      "epoch: 100\ttrain loss: 0.4622\t\n",
      "epoch: 150\ttrain loss: 0.3705\t\n",
      "epoch: 200\ttrain loss: 0.3696\t\n",
      "epoch: 250\ttrain loss: 0.3693\t\n",
      "mse at 60.0% data: 0.0006206448674201965\n",
      "epoch: 50\ttrain loss: 3.5698\t\n",
      "epoch: 100\ttrain loss: 0.4592\t\n",
      "epoch: 150\ttrain loss: 0.3994\t\n",
      "epoch: 200\ttrain loss: 0.3979\t\n",
      "epoch: 250\ttrain loss: 0.3975\t\n",
      "mse at 70.0% data: 0.0005942585468292237\n",
      "epoch: 50\ttrain loss: 3.4312\t\n",
      "epoch: 100\ttrain loss: 0.4605\t\n",
      "epoch: 150\ttrain loss: 0.4306\t\n",
      "epoch: 200\ttrain loss: 0.4299\t\n",
      "epoch: 250\ttrain loss: 0.4298\t\n",
      "mse at 80.0% data: 0.0005797837376594543\n",
      "epoch: 50\ttrain loss: 3.2580\t\n",
      "epoch: 100\ttrain loss: 0.4311\t\n",
      "epoch: 150\ttrain loss: 0.4197\t\n",
      "epoch: 200\ttrain loss: 0.4196\t\n",
      "epoch: 250\ttrain loss: 0.4196\t\n",
      "mse at 90.0% data: 0.000574147343635559\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.0005636397004127503\n",
      "mse at 0% data: 0.0058272299766540525\n",
      "epoch: 50\ttrain loss: 3.0517\t\n",
      "epoch: 100\ttrain loss: 0.8187\t\n",
      "epoch: 150\ttrain loss: 0.4566\t\n",
      "epoch: 200\ttrain loss: 0.5979\t\n",
      "epoch: 250\ttrain loss: 0.6079\t\n",
      "mse at 10.0% data: 0.0005756217837333679\n",
      "epoch: 50\ttrain loss: 3.1816\t\n",
      "epoch: 100\ttrain loss: 0.5575\t\n",
      "epoch: 150\ttrain loss: 0.6280\t\n",
      "epoch: 200\ttrain loss: 0.6056\t\n",
      "epoch: 250\ttrain loss: 0.5664\t\n",
      "mse at 20.0% data: 0.000562605857849121\n",
      "epoch: 50\ttrain loss: 3.2223\t\n",
      "epoch: 100\ttrain loss: 0.4509\t\n",
      "epoch: 150\ttrain loss: 0.4947\t\n",
      "epoch: 200\ttrain loss: 0.4451\t\n",
      "epoch: 250\ttrain loss: 0.4320\t\n",
      "mse at 30.0% data: 0.0005705479383468628\n",
      "epoch: 50\ttrain loss: 2.9689\t\n",
      "epoch: 100\ttrain loss: 0.5170\t\n",
      "epoch: 150\ttrain loss: 0.4143\t\n",
      "epoch: 200\ttrain loss: 0.4928\t\n",
      "epoch: 250\ttrain loss: 0.4650\t\n",
      "mse at 40.0% data: 0.0005644475221633911\n",
      "epoch: 50\ttrain loss: 3.1225\t\n",
      "epoch: 100\ttrain loss: 0.5427\t\n",
      "epoch: 150\ttrain loss: 0.4349\t\n",
      "epoch: 200\ttrain loss: 0.4647\t\n",
      "epoch: 250\ttrain loss: 0.5099\t\n",
      "mse at 50.0% data: 0.0005668167471885681\n",
      "epoch: 50\ttrain loss: 3.2772\t\n",
      "epoch: 100\ttrain loss: 0.5022\t\n",
      "epoch: 150\ttrain loss: 0.4726\t\n",
      "epoch: 200\ttrain loss: 0.4889\t\n",
      "epoch: 250\ttrain loss: 0.4615\t\n",
      "mse at 60.0% data: 0.0005662301182746887\n",
      "epoch: 50\ttrain loss: 3.0715\t\n",
      "epoch: 100\ttrain loss: 0.4962\t\n",
      "epoch: 150\ttrain loss: 0.4959\t\n",
      "epoch: 200\ttrain loss: 0.5107\t\n",
      "epoch: 250\ttrain loss: 0.4749\t\n",
      "mse at 70.0% data: 0.0005632094740867614\n",
      "epoch: 50\ttrain loss: 3.2894\t\n",
      "epoch: 100\ttrain loss: 0.5165\t\n",
      "epoch: 150\ttrain loss: 0.4707\t\n",
      "epoch: 200\ttrain loss: 0.4706\t\n",
      "epoch: 250\ttrain loss: 0.4857\t\n",
      "mse at 80.0% data: 0.0005693704485893249\n",
      "epoch: 50\ttrain loss: 3.2127\t\n",
      "epoch: 100\ttrain loss: 0.4943\t\n",
      "epoch: 150\ttrain loss: 0.4816\t\n",
      "epoch: 200\ttrain loss: 0.4667\t\n",
      "epoch: 250\ttrain loss: 0.4838\t\n",
      "mse at 90.0% data: 0.0005654061436653138\n",
      "epoch: 50\ttrain loss: 3.1747\t\n",
      "epoch: 100\ttrain loss: 0.4861\t\n",
      "epoch: 150\ttrain loss: 0.4770\t\n",
      "epoch: 200\ttrain loss: 0.4769\t\n",
      "epoch: 250\ttrain loss: 0.4769\t\n",
      "mse at 100.0% data: 0.000563639760017395\n"
     ]
    }
   ],
   "source": [
    "# test with momentum\n",
    "# divide into 10 fractions\n",
    "\n",
    "fractions = [0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0]\n",
    "# fractions = [0.2,0.4,0.6,0.8,1.0]\n",
    "# fractions = [0, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]\n",
    "epochs = 250\n",
    "lr=1e-1\n",
    "warmup = 0.8\n",
    "is_low_value = False\n",
    "accuracy = {}\n",
    "modes = ['no_momentum', 'momentum', 'no_dp', 'random']\n",
    "for mode in modes:\n",
    "    accuracy[mode] = np.zeros((len(seeds), len(fractions)))\n",
    "\n",
    "for i, seed in enumerate(seeds):\n",
    "    scores_seed = scores[seed]\n",
    "    for b_idx, mode in enumerate(modes):\n",
    "        for j, frac in enumerate(fractions):\n",
    "            torch.manual_seed(0)            \n",
    "            net.apply(init_weights)\n",
    "            optimizer = torch.optim.Adam(net.parameters(), lr=lr)\n",
    "            for t in range(epochs):\n",
    "                # if frac == 0:\n",
    "                #     cur_scores = scores_seed[0]\n",
    "                #     cur_scores = np.mean(cur_scores, axis=0)\n",
    "                #     score_ranks = np.argsort(cur_scores)\n",
    "                #     start = 0\n",
    "                #     end = len(cur_scores)\n",
    "                # else:\n",
    "                #     if mode == 'random':\n",
    "                #         cur_scores = scores_seed[0]\n",
    "                #     else:\n",
    "                #         cur_scores = scores_seed[b_idx]\n",
    "                #     if mode == 'momentum':\n",
    "                #         cur_scores = cur_scores[int(len(cur_scores) * warmup):]\n",
    "                #     cur_scores = np.mean(cur_scores, axis=0)\n",
    "                #     score_ranks = np.argsort(cur_scores)\n",
    "                #     if not is_low_value:\n",
    "                #         score_ranks = score_ranks[::-1]\n",
    "                #     if mode == 'random':\n",
    "                #         # randomoize the scores\n",
    "                #         score_ranks = np.random.permutation(score_ranks)\n",
    "                #     # start = int(len(cur_scores) * fractions[j-1]) if j > 0 else 0\n",
    "                #     # start = 0\n",
    "                #     # end = int(len(cur_scores) * frac)\n",
    "                #     start = int(len(cur_scores) * frac)\n",
    "                #     end = len(cur_scores)\n",
    "\n",
    "                if frac == 0:\n",
    "                    continue\n",
    "                if mode == \"random\":\n",
    "                    cur_scores = scores_seed[0]\n",
    "                else:\n",
    "                    cur_scores = scores_seed[b_idx]\n",
    "                if mode == \"momentum\":\n",
    "                    cur_scores = cur_scores[int(len(cur_scores) * warmup):]\n",
    "                cur_scores = np.mean(cur_scores, axis=0)\n",
    "                score_ranks = np.argsort(cur_scores)\n",
    "                if not is_low_value:\n",
    "                    score_ranks = score_ranks[::-1]\n",
    "                if mode == \"random\":\n",
    "                    np.random.shuffle(score_ranks)\n",
    "                # start = int(len(cur_scores) * fractions[j-1]) if j > 0 else 0\n",
    "                start = 0\n",
    "                end = int(len(cur_scores) * frac)\n",
    "                    \n",
    "                datas = torch.utils.data.Subset(train_data, score_ranks[start:end])\n",
    "                data_loader = torch.utils.data.DataLoader(datas, batch_size=len(datas), shuffle=True)   \n",
    "                \n",
    "                for _, (data, target) in enumerate(data_loader):\n",
    "                    data, target = data.to(device), target.to(device)\n",
    "                    # train model with data\n",
    "                    net.train()\n",
    "                    output = net(data)\n",
    "                    if model_name == \"linear_regression\":\n",
    "                        target = target.float()\n",
    "                        loss = nn.MSELoss()(output, target)\n",
    "                    else:\n",
    "                        loss = nn.CrossEntropyLoss()(output, target)\n",
    "                    loss.backward()\n",
    "                    # update model\n",
    "                    optimizer.step()\n",
    "                    optimizer.zero_grad()\n",
    "\n",
    "                if (t+1)%50 == 0:\n",
    "                    print(\n",
    "                        f\"epoch: {t + 1}\\t\"\n",
    "                        f\"train loss: {loss.item():.4f}\\t\"\n",
    "                    )\n",
    "            \n",
    "            # evaluate the model\n",
    "            net.eval()\n",
    "            if model_name == \"linear_regression\":\n",
    "                net.eval()\n",
    "                mse = 0\n",
    "                with torch.no_grad():\n",
    "                    data_loader = torch.utils.data.DataLoader(val_data, batch_size=len(val_data), shuffle=False)\n",
    "                    for _, (data, target) in enumerate(data_loader):\n",
    "                        images, labels = data.to(device), target.to(device)\n",
    "                        outputs = net(images)\n",
    "                        # mse += nn.MSELoss()(outputs, labels.float()).item()\n",
    "                        # use MAE instead\n",
    "                        mse += nn.L1Loss()(outputs, labels.float()).item()\n",
    "                # get average mse\n",
    "                acc = mse / len(val_data)\n",
    "                accuracy[mode][i][j] = acc\n",
    "                print(\n",
    "                    f\"mse at {frac * 100}% data: {acc}\"\n",
    "                )\n",
    "            else:\n",
    "                correct = 0\n",
    "                total = 0\n",
    "                with torch.no_grad():\n",
    "                    data_loader = torch.utils.data.DataLoader(val_data, batch_size=len(val_data), shuffle=False)\n",
    "                    for _, (data, target) in enumerate(data_loader):\n",
    "                        images, labels = data.to(device), target.to(device)\n",
    "                        outputs = net(images)\n",
    "                        _, predicted = torch.max(outputs.data, 1)\n",
    "                        total += labels.size(0)\n",
    "                        correct += (predicted == labels).sum()\n",
    "                acc = (correct / total).item()\n",
    "                accuracy[mode][i][j] = acc\n",
    "                print(\n",
    "                    f\"accuracy at {frac * 100}% data: {100 * correct / total}\"\n",
    "                )\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "from notebooks.utils import set_up_plotting\n",
    "plt = set_up_plotting()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the accuracy vs partition of data\n",
    "# plot the lower and upper quantiles of the accuracy\n",
    "plt.figure()\n",
    "plt.title(rf\"$k=240, q=0.8$\")\n",
    "# plt.xlabel(f\"Partition of Data (k={budget})\")\n",
    "# plt.xticks(fractions)\n",
    "# add label to the x axis\n",
    "# plt.gca().set_xticklabels([\"33%\", \"66%\", \"100%\"])\n",
    "# plt.ylabel(\"Accuracy\")\n",
    "plt.grid()\n",
    "# plt.ylim(0.5, 0.8)\n",
    "for b_idx, mode in enumerate(modes):\n",
    "    # plot the error bar\n",
    "    if mode == \"no_momentum\":\n",
    "        label_name = \"i.i.d.\"\n",
    "        plt.errorbar(fractions, np.mean( accuracy[mode], axis=0), \n",
    "                 yerr=np.std( accuracy[mode], axis=0), \n",
    "                 label=f\"{label_name}\",\n",
    "                 linestyle='--',\n",
    "                  marker='o',\n",
    "                  markersize=15,\n",
    "                  color='C0'\n",
    "                 )\n",
    "    elif mode == \"momentum\":\n",
    "        label_name = \"corr.\"\n",
    "        plt.errorbar(fractions, np.mean( accuracy[mode], axis=0), \n",
    "                 yerr=np.std( accuracy[mode], axis=0), \n",
    "                 label=f\"{label_name}\",\n",
    "                 linestyle='-',\n",
    "                    marker='X',\n",
    "                    markersize=15,\n",
    "                    color=\"orange\"\n",
    "                 )\n",
    "    elif mode == \"no_dp\":\n",
    "        label_name = \"no DP\"\n",
    "        plt.errorbar(fractions, np.mean( accuracy[mode], axis=0), \n",
    "                 yerr=np.std( accuracy[mode], axis=0), \n",
    "                 label=f\"{label_name}\",\n",
    "                 linestyle='dashdot',\n",
    "                    marker='D',\n",
    "                    markersize=15,\n",
    "                    color='green'\n",
    "                 )\n",
    "    elif mode == \"random\":\n",
    "        label_name = \"Random\"\n",
    "        plt.errorbar(fractions, np.mean( accuracy[mode], axis=0), \n",
    "                 yerr=np.std( accuracy[mode], axis=0), \n",
    "                 label=f\"{label_name}\",\n",
    "                 linestyle='dotted',\n",
    "                    marker='^',\n",
    "                    markersize=15,\n",
    "                    color='C5'\n",
    "                 )\n",
    "\n",
    "plt.legend()\n",
    "plt.savefig(f\"../figs/acc_{dataset}_{num_players}_{budget}_{eps}_{model_name}_add_high.pdf\", dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.00582723, 0.00141078, 0.00079276, 0.00066455, 0.00063316,\n",
       "       0.00060552, 0.0005899 , 0.00057732, 0.00056912, 0.00056494,\n",
       "       0.00056364])"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean( accuracy[modes[0]], axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dv_dp",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
