{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from copy import deepcopy\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch import optim\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "from utils import _build_dataset, train, plot_trajectory, hb_train, l2distance\n",
    "from models import DiagonalNetTorch\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "random_seed = 1000\n",
    "n = 40\n",
    "d = 100\n",
    "n_informative = 5\n",
    "\n",
    "# build data\n",
    "X, y, w_star = _build_dataset(\n",
    "    n=n, d=d, n_informative=n_informative, random_seed=random_seed\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# w_star = 0.5 * w_star\n",
    "# # X = 0.1 * X\n",
    "# y = 0.5 * y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([-0.8045,  0.3209, -0.0255,  0.6443, -0.3008,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000,\n",
       "         0.0000,  0.0000,  0.0000,  0.0000])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "w_star"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 30.6690,  14.0618,  -1.3832,  10.7835,  10.8373,  -6.7553,   0.7987,\n",
       "         13.2645,  -1.9323,  12.8275,  12.7549,  -1.0734,  -1.4518,   0.1510,\n",
       "         -5.6440,   7.1442,  -0.1995,   1.2549, -13.3762,  12.6903,   8.1104,\n",
       "         -2.6177,   0.5045,  -3.0796,  -1.4643,  -0.5671,   5.7127, -19.7865,\n",
       "          2.2727,  -9.8542,   5.5705,  -3.0216, -11.8638,  -3.0222,   8.5915,\n",
       "         -3.0946, -10.1606,  -1.5657,  -1.5195, -20.2555, -11.5158,  -2.8992,\n",
       "         -3.2958,   6.5005,   9.9178,  -2.5269,  11.9783,   6.4755,  -9.6509,\n",
       "          3.5608,  -2.6641,   4.0837,  10.3896,  -2.8724,  -2.3805, -10.8656,\n",
       "         -1.0485,   1.6205,  -1.9921,  -5.2435,   5.6656,  -4.2101,  10.6932,\n",
       "         12.0964,  -3.6369,  -1.0519,   8.1375, -15.6240,   4.6772,   5.8552,\n",
       "          9.0195,   0.9911,   6.4307,  -5.8214,  13.1280,  -1.8215,   5.5744,\n",
       "          6.4386,  -0.0700,  -5.3446, -12.3826,   8.5313,  -2.5580,   2.4012,\n",
       "         -3.3765,  -5.8631,   6.5938,   7.5513,  -1.1279,  -4.0441,  -1.1618,\n",
       "          0.9033,   0.2394,   2.8398,   7.9124,  -3.3279,   4.0650,   2.1281,\n",
       "         -9.3621,   5.2885])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.T @ X @ w_star.abs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Diag_torch(nn.Module):\n",
    "    def __init__(self, scale, n_layer, d, gaussian=False, biased=None):\n",
    "        super(Diag_torch, self).__init__()\n",
    "        if gaussian:\n",
    "            # p = scale * torch.randn((d, 1))\n",
    "            p = torch.normal(0, scale, size=(d, 1))\n",
    "            m = deepcopy(p)\n",
    "            # m = scale * torch.randn((d, 1))\n",
    "        else:\n",
    "            p, m = scale * torch.ones((d, 1)), scale * torch.ones((d, 1))\n",
    "\n",
    "        if biased is not None:\n",
    "            self.w_p = nn.Parameter(biased * p)\n",
    "            self.w_m = nn.Parameter(m / biased)\n",
    "        else:\n",
    "            self.w_p, self.w_m = nn.Parameter(p), nn.Parameter(m)\n",
    "        self.w_m_init = deepcopy(self.w_m)\n",
    "        self.n_layer = n_layer\n",
    "\n",
    "    def forward(self, x):\n",
    "        theta = self.w_p.pow(self.n_layer) - self.w_m.pow(self.n_layer)\n",
    "        return x @ theta\n",
    "\n",
    "    @property\n",
    "    def w(self):\n",
    "        return self.w_p.pow(self.n_layer) - self.w_m.pow(self.n_layer)\n",
    "\n",
    "    def loss(self, x, y):\n",
    "        return nn.MSELoss()(x @ self.w, y.reshape(-1, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "reg coef 1900.0000000000011\n"
     ]
    }
   ],
   "source": [
    "model_config = {\n",
    "    \"n_layer\": 2,\n",
    "    \"d\": d,\n",
    "    \"biased\": 0.9,\n",
    "}\n",
    "eta = 1e-2\n",
    "num_it = 50000\n",
    "mu = 0.9\n",
    "\n",
    "print(f\"reg coef {(1 + mu) / ((1 - mu)**3)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict\n",
    "\n",
    "def train(net, lr, momentum=mu):\n",
    "    optimizer = optim.SGD(net.parameters(), lr=lr, momentum=momentum)\n",
    "    crition = nn.MSELoss()\n",
    "    it = 0\n",
    "    while True:\n",
    "        y_hat = net(X)\n",
    "        l = crition(y_hat.reshape(-1), y.reshape(-1))\n",
    "        optimizer.zero_grad()\n",
    "        l.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        it += 1\n",
    "        if it % 1000 == 0:\n",
    "            print(l2distance(net.w, w_star))\n",
    "\n",
    "        if it >= num_it:\n",
    "            break\n",
    "\n",
    "    return l2distance(net.w, w_star)\n",
    "\n",
    "def run(scale_list, lr, momentum_list):\n",
    "    momentum_exp_result = defaultdict(list)\n",
    "    for momentum in momentum_list:\n",
    "        for s in scale_list:\n",
    "            print(f\"training with init scale = {s}\")\n",
    "            model_config['scale'] = s\n",
    "            net = Diag_torch(**model_config)\n",
    "            test_error = train(net, lr, momentum=momentum)\n",
    "            momentum_exp_result[f\"{momentum}\"].append(test_error) \n",
    "    return momentum_exp_result  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training with init scale = 0.1\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.35779786\n",
      "0.34808144\n",
      "0.34660557\n",
      "0.3462511\n",
      "0.34614548\n",
      "0.34611312\n",
      "0.34610322\n",
      "0.34610075\n",
      "0.34610105\n",
      "0.34610105\n",
      "0.34610114\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "0.34610108\n",
      "training with init scale = 0.1275133206328453\n",
      "0.44477403\n",
      "0.44002777\n",
      "0.43951753\n",
      "0.43942788\n",
      "0.4394083\n",
      "0.43940702\n",
      "0.43940818\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "0.43940815\n",
      "training with init scale = 0.16259646938814815\n",
      "0.5476269\n",
      "0.5458636\n",
      "0.54575\n",
      "0.5457428\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "0.5457442\n",
      "training with init scale = 0.2073321573485955\n",
      "0.6628378\n",
      "0.6624063\n",
      "0.66240144\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "0.6624017\n",
      "training with init scale = 0.26437611857491\n",
      "0.7843625\n",
      "0.7843211\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "0.78432137\n",
      "training with init scale = 0.33711476775509625\n",
      "0.9134138\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "0.9134146\n",
      "training with init scale = 0.42986623470822766\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "1.0830959\n",
      "training with init scale = 0.5481367101558418\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "1.3723\n",
      "training with init scale = 0.6989473207273484\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "1.8998823\n",
      "training with init scale = 0.8912509381337456\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "2.8281717\n",
      "training with init scale = 0.1\n",
      "0.40186235\n",
      "0.40178826\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "0.40178818\n",
      "training with init scale = 0.1275133206328453\n",
      "0.50020915\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "0.50020313\n",
      "training with init scale = 0.16259646938814815\n",
      "0.60914475\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "0.6091449\n",
      "training with init scale = 0.2073321573485955\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "0.7228904\n",
      "training with init scale = 0.26437611857491\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "0.8330427\n",
      "training with init scale = 0.33711476775509625\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "0.942376\n",
      "training with init scale = 0.42986623470822766\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "1.0914183\n",
      "training with init scale = 0.5481367101558418\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "1.3634629\n",
      "training with init scale = 0.6989473207273484\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "1.8685334\n",
      "training with init scale = 0.8912509381337456\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "2.737199\n",
      "training with init scale = 0.1\n",
      "0.4855196\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "0.4855185\n",
      "training with init scale = 0.1275133206328453\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "0.59535813\n",
      "training with init scale = 0.16259646938814815\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "0.71422076\n",
      "training with init scale = 0.2073321573485955\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "0.82967865\n",
      "training with init scale = 0.26437611857491\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "0.9217327\n",
      "training with init scale = 0.33711476775509625\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "0.9899088\n",
      "training with init scale = 0.42986623470822766\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "1.0933305\n",
      "training with init scale = 0.5481367101558418\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "1.323409\n",
      "training with init scale = 0.6989473207273484\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "1.7576238\n",
      "training with init scale = 0.8912509381337456\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "2.4325716\n",
      "training with init scale = 0.1\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "0.7272729\n",
      "training with init scale = 0.1275133206328453\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "0.82723993\n",
      "training with init scale = 0.16259646938814815\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "0.94649845\n",
      "training with init scale = 0.2073321573485955\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "1.0564795\n",
      "training with init scale = 0.26437611857491\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "1.1131294\n",
      "training with init scale = 0.33711476775509625\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "1.1061782\n",
      "training with init scale = 0.42986623470822766\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "1.0907496\n",
      "training with init scale = 0.5481367101558418\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "1.1733428\n",
      "training with init scale = 0.6989473207273484\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "1.3613702\n",
      "training with init scale = 0.8912509381337456\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n",
      "1.4466752\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "scale_list = np.logspace(-1.0, -0.05, 10)\n",
    "m_list = [0, 0.8, 0.9, 0.95]\n",
    "exp_result = run(scale_list, lr=eta, momentum_list=m_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.1       , 0.12751332, 0.16259647, 0.20733216, 0.26437612,\n",
       "       0.33711477, 0.42986623, 0.54813671, 0.69894732, 0.89125094])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scale_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "defaultdict(list,\n",
       "            {'0': [array(0.34610108, dtype=float32),\n",
       "              array(0.43940815, dtype=float32),\n",
       "              array(0.5457442, dtype=float32),\n",
       "              array(0.6624017, dtype=float32),\n",
       "              array(0.78432137, dtype=float32),\n",
       "              array(0.9134146, dtype=float32),\n",
       "              array(1.0830959, dtype=float32),\n",
       "              array(1.3723, dtype=float32),\n",
       "              array(1.8998823, dtype=float32),\n",
       "              array(2.8281717, dtype=float32)],\n",
       "             '0.8': [array(0.40178818, dtype=float32),\n",
       "              array(0.50020313, dtype=float32),\n",
       "              array(0.6091449, dtype=float32),\n",
       "              array(0.7228904, dtype=float32),\n",
       "              array(0.8330427, dtype=float32),\n",
       "              array(0.942376, dtype=float32),\n",
       "              array(1.0914183, dtype=float32),\n",
       "              array(1.3634629, dtype=float32),\n",
       "              array(1.8685334, dtype=float32),\n",
       "              array(2.737199, dtype=float32)],\n",
       "             '0.9': [array(0.4855185, dtype=float32),\n",
       "              array(0.59535813, dtype=float32),\n",
       "              array(0.71422076, dtype=float32),\n",
       "              array(0.82967865, dtype=float32),\n",
       "              array(0.9217327, dtype=float32),\n",
       "              array(0.9899088, dtype=float32),\n",
       "              array(1.0933305, dtype=float32),\n",
       "              array(1.323409, dtype=float32),\n",
       "              array(1.7576238, dtype=float32),\n",
       "              array(2.4325716, dtype=float32)],\n",
       "             '0.95': [array(0.7272729, dtype=float32),\n",
       "              array(0.82723993, dtype=float32),\n",
       "              array(0.94649845, dtype=float32),\n",
       "              array(1.0564795, dtype=float32),\n",
       "              array(1.1131294, dtype=float32),\n",
       "              array(1.1061782, dtype=float32),\n",
       "              array(1.0907496, dtype=float32),\n",
       "              array(1.1733428, dtype=float32),\n",
       "              array(1.3613702, dtype=float32),\n",
       "              array(1.4466752, dtype=float32)]})"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp_result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Figure 4 (a): Generalization performances ∥w(∞) − w∗∥2 for different initialization scales s when f (x; w) is trained by GD and HB with different values of μ. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "pos = scale_list\n",
    "ax.plot(pos, exp_result[f\"{0}\"], label=f\"GD\", linestyle=\"-\")\n",
    "ax.plot(pos, exp_result[f\"{m_list[1]}\"], label=r\"HB, $\\mu=0.8$\", linestyle=\"--\")\n",
    "ax.plot(pos, exp_result[f\"{m_list[2]}\"], label=r\"HB, $\\mu=0.9$\", linestyle=\"--\")\n",
    "ax.plot(pos, exp_result[f\"{m_list[3]}\"], label=r\"HB, $\\mu=0.95$\", linestyle=\"--\")\n",
    "\n",
    "ax.set_ylabel(r\"$||\\mathbf{w} - \\mathbf{w}^{*}||_2$\", fontsize=14)\n",
    "\n",
    "# ax.set_yscale(\"log\")\n",
    "# ax.set_xscale(\"log\")\n",
    "ax.set_xlabel(r\"Initialization scale $s$\", fontsize=14)\n",
    "ax.grid(True)\n",
    "\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "\n",
    "fig.savefig('./exp_fig/dln_generalization.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lora",
   "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.12.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
