{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    }
   ],
   "source": [
    "%pylab inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import pandas as pd\n",
    "import networkx as nx\n",
    "import pywavefront\n",
    "import time\n",
    "import pandas as pd\n",
    "\n",
    "from mpl_toolkits.mplot3d import axes3d\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from optimizers import KFACOptimizer\n",
    "import torch_optimizer as optim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Name: \n",
      "Type: Graph\n",
      "Number of nodes: 2500\n",
      "Number of edges: 4900\n",
      "Average degree:   3.9200\n",
      "100\n",
      "100\n"
     ]
    }
   ],
   "source": [
    "#define a graph with boundary conditions\n",
    "\n",
    "n = 50\n",
    "G_grid = nx.grid_graph([n,n], periodic = False)\n",
    "#G= nx.random_geometric_graph(n**2, .04)\n",
    "#G= nx.erdos_renyi_graph(n**2, .004)\n",
    "\n",
    "mapping = { i:en for en, i in enumerate(G_grid.nodes)}\n",
    "G = nx.relabel_nodes(G_grid, mapping)\n",
    "print(nx.info(G))\n",
    "\n",
    "hot_id = list(G.nodes)[:2*n]\n",
    "cold_id = list(G.nodes)[-2*n:]\n",
    "\n",
    "\n",
    "print(len(hot_id))\n",
    "print(len(cold_id))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "#sparse adjacency matrix\n",
    "\n",
    "N = len(G.nodes)\n",
    "\n",
    "edg = []\n",
    "for i in G.edges():\n",
    "    edg += [[i[0], i[1]]]\n",
    "    edg += [[i[1], i[0]]]\n",
    "    \n",
    "values = list(ones(len(edg)))\n",
    "\n",
    "A_sp = torch.sparse_coo_tensor(list(zip(*edg)), values, (N, N),dtype=torch.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(indices=tensor([[   0,   50,    0,  ..., 2498, 2498, 2499],\n",
       "                       [  50,    0,    1,  ..., 2497, 2499, 2498]]),\n",
       "       values=tensor([1., 1., 1.,  ..., 1., 1., 1.]),\n",
       "       size=(2500, 2500), nnz=9800, layout=torch.sparse_coo)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "A_sp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "#set up a propagation rule DAD, DA, A\n",
    "def normalize_A(A, prop_rule = None):\n",
    "    N = len(A)\n",
    "    identity_N = [[i,i] for i in range(N)]\n",
    "    values_N = list(ones(N))\n",
    "    I = torch.sparse_coo_tensor(list(zip(*identity_N)), values_N, (N, N))\n",
    "    \n",
    "    A_norm = A + I\n",
    "    \n",
    "    if prop_rule == None or prop_rule == 'A':\n",
    "        return A_norm\n",
    "    else:\n",
    "        D = torch.sparse.sum(A_norm, dim= 0).values()\n",
    "        \n",
    "        if prop_rule == 'D':\n",
    "            D_1 = torch.sparse_coo_tensor(list(zip(*identity_N)), 1/D, (N, N))\n",
    "            return torch.sparse.mm(D_1, A_norm)\n",
    "        \n",
    "        if prop_rule == 'DAD':\n",
    "            D_half = torch.sparse_coo_tensor(list(zip(*identity_N)), 1/sqrt(D), (N, N))\n",
    "            return torch.sparse.mm(torch.sparse.mm(D_half, A_norm), D_half)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(indices=tensor([[   0,    0,    1,  ..., 2498, 2499, 2499],\n",
       "                       [   0,   50,    1,  ..., 2499, 2498, 2499]]),\n",
       "       values=tensor([ 2., -1.,  3.,  ..., -1., -1.,  2.]),\n",
       "       size=(2500, 2500), nnz=12300, layout=torch.sparse_coo)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#sparse laplacian\n",
    "identity_N = [[i,i] for i in range(N)]\n",
    "D =  torch.sparse_coo_tensor(list(zip(*identity_N)), torch.sparse.sum(A_sp, dim= 0).values(), (N, N), dtype=torch.float32)  \n",
    "L = D - A_sp\n",
    "L"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "I_sp = torch.sparse_coo_tensor(list(zip(*identity_N)), torch.ones(N), (N, N), dtype=torch.float32)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "#for measuring time\n",
    "def time_it(f):\n",
    "    def dt(*args, **kw):\n",
    "        t0 = time.time()\n",
    "        a = f(*args, **kw)\n",
    "        t = time.time()-t0\n",
    "        print('%s time: %.3g s'%(f.__name__,t))\n",
    "        return t\n",
    "    return dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "#loss function: heat equation\n",
    "\n",
    "hot = 10\n",
    "cold =  -10\n",
    "c = 4\n",
    "\n",
    "def Loss(X):\n",
    "    \n",
    "    cold_X = X[cold_id]\n",
    "    hot_X = X[hot_id] \n",
    "    \n",
    "    #V = torch.sum(torch.spmm(L,X)*X)\n",
    "     \n",
    "    V = torch.sum((L@X)*X)\n",
    "     \n",
    "    Reg = torch.sum((cold_X - cold)**c)   + torch.sum((hot_X - hot)**c )\n",
    "    \n",
    "    return V + Reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "#GCN reparametrization\n",
    "\n",
    "class GCN(nn.Module):\n",
    "    def __init__(self, in_feat, out_feat, A):\n",
    "        super(GCN, self).__init__()\n",
    "        self.in_feat = in_feat\n",
    "        self.A = A\n",
    "        self.out_feat = out_feat\n",
    "        \n",
    "        self.W = nn.Parameter(torch.empty(in_feat, out_feat))\n",
    "        nn.init.kaiming_normal_(self.W) \n",
    "        \n",
    "    def forward(self, x):\n",
    "        return  self.A @ x @ self.W\n",
    "        #return torch.spmm(self.A, torch.spmm(x, self.W))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "#linear reparametrization\n",
    "class Deep(nn.Module):\n",
    "    def __init__(self, in_feat, out_feat):\n",
    "        super(Deep, self).__init__()\n",
    "        self.in_feat = in_feat\n",
    "        self.out_feat = out_feat\n",
    "        \n",
    "        self.W = nn.Parameter(torch.empty(in_feat, out_feat))\n",
    "        nn.init.kaiming_normal_(self.W) \n",
    "        \n",
    "    def forward(self, x):\n",
    "        return x @ self.W"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "#neural network model with residual connection\n",
    "class neuralHeat_Res(nn.Module):\n",
    "    def __init__(self,  feat_dims = [1,1] , A = None, deepfdl = False, fdl = False, propagation_rule = 'DAD', lr = 0.01):  #feat dims [latent_1,....,latent_n-1, latent_n, out]\n",
    "        super(neuralHeat_Res, self).__init__()\n",
    "        self.deepfdl = deepfdl\n",
    "        self.A = normalize_A(A, propagation_rule)\n",
    "        \n",
    "        n = len(self.A)\n",
    "        \n",
    "        self.latent = nn.Parameter(torch.empty(n, feat_dims[0]))\n",
    "        r = n**(1./feat_dims[0])\n",
    "        nn.init.normal_(self.latent,std = r)\n",
    "        #nn.init.uniform_(self.latent,a=0.0, b=2*pi)\n",
    "       \n",
    "        self.Loss = lambda x: Loss(x)\n",
    "        \n",
    "        self.gcn_list = nn.ModuleList([GCN(feat_dims[i], feat_dims[i+1], A=self.A.float()) for i in range(len(feat_dims)-2)])\n",
    "        \n",
    "        self.deep_list = nn.ModuleList([Deep(feat_dims[i], feat_dims[i+1]) for i in range(len(feat_dims)-2)])\n",
    "        \n",
    "        \n",
    "        self.nonlinearity = nn.ReLU()\n",
    "        \n",
    "        \n",
    "        self.projection = nn.Parameter(torch.empty( sum(feat_dims[:-1]), feat_dims[-1] ))\n",
    "        nn.init.normal_(self.projection,std = r)\n",
    "        \n",
    "        self.loss_history = []\n",
    "        self.optim = torch.optim.Adam(self.parameters(), lr = lr)\n",
    "        \n",
    "        self.fine_pos = nn.Parameter(torch.empty(n,feat_dims[-1]))\n",
    "        nn.init.normal_(self.fine_pos,std = r)\n",
    "        #nn.init.uniform_(self.fine_pos, a=0.0, b=2*pi)\n",
    "        \n",
    "        self.optim_fine = torch.optim.Adam([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = torch.optim.SGD([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = torch.optim.RMSprop([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = optim.Shampoo([self.fine_pos], lr = lr)\n",
    "    \n",
    "    def forward(self,):\n",
    "        if self.deepfdl == False:       \n",
    "            out = [self.latent]\n",
    "            for g in self.gcn_list:\n",
    "                out += [self.nonlinearity(g(out[-1]))]\n",
    "            out = torch.concat(out,dim = 1)\n",
    "      \n",
    "            return out @ self.projection\n",
    "        else:\n",
    "            out = [self.latent]\n",
    "            for g in self.deep_list:\n",
    "                out += [self.nonlinearity(g(out[-1]))]\n",
    "            out = torch.concat(out,dim = 1)\n",
    "      \n",
    "            return out @ self.projection\n",
    "    \n",
    "    \n",
    "        \n",
    "    @time_it\n",
    "    def train(self,gcn_steps=200, fdl_steps=2000, early_stop_check_steps = 100, min_steps=100, stop_delta_ratio = 5e-3, gcn_stop_threshold = 2e-2, fdl_stop_threshold = 5e-3,\n",
    "              **stop_kws):\n",
    "        \"\"\"train(self,gcn_steps=200, fdl_steps=2000, early_stop_check_steps = 100, \n",
    "              min_steps=100, #stop_delta_ratio = 5e-3, \n",
    "              gcn_stop_threshold = 2e-2,\n",
    "              fdl_stop_threshold = 5e-3,\n",
    "              **stop_kws):\n",
    "        \"\"\"\n",
    "        try:\n",
    "            if gcn_steps > 0 and len(self.gcn_list) > 0:\n",
    "                self.train_reparametrization(steps=gcn_steps, early_stop_check=early_stop_check_steps, \n",
    "                               min_steps=min_steps, \n",
    "                               stop_delta_ratio=gcn_stop_threshold, **stop_kws)\n",
    "                self.fine_pos.data = self()\n",
    "            print(f'\\nFDL training {fdl_steps} steps')\n",
    "            self.train_fine(steps=fdl_steps, early_stop_check=early_stop_check_steps, \n",
    "                            min_steps=min_steps, \n",
    "                            stop_delta_ratio=fdl_stop_threshold, **stop_kws)\n",
    "        except KeyboardInterrupt:\n",
    "            print('\\nTraining interrupted')\n",
    "            return\n",
    "        \n",
    "    \n",
    "    @time_it\n",
    "    def train_reparametrization(self,steps = 100, early_stop_check = 100, min_steps=100, stop_delta_ratio = 5e-3, **stop_kws):\n",
    "        for i in range(steps):\n",
    "            self.optim.zero_grad()\n",
    "            loss = self.Loss(self())\n",
    "            loss.backward() \n",
    "            self.loss_history += [loss.item()+0.]\n",
    "            self.optim.step()\n",
    "            if i> min_steps and i % early_stop_check == 1:\n",
    "                # print('checking', i)\n",
    "                if early_stopping(self.loss_history,stop_delta_ratio=stop_delta_ratio, **stop_kws): \n",
    "                    print('\\n===========\\nstopping at step ',i)\n",
    "                    break\n",
    "    \n",
    "    @time_it    \n",
    "    def train_fine(self,steps = 100, early_stop_check = 100, min_steps=100, stop_delta_ratio = 5e-3, **stop_kws):\n",
    "        for i in range(steps):\n",
    "            self.optim_fine.zero_grad()\n",
    "            # loss = Loss(self.fine_pos, self.A)\n",
    "            loss = self.Loss(self.fine_pos)\n",
    "            loss.backward() \n",
    "            self.loss_history += [loss.item()+0.]\n",
    "            self.optim_fine.step()\n",
    "            if i> min_steps and i % early_stop_check == 1:\n",
    "                # print('checking', i)\n",
    "                if early_stopping(self.loss_history,stop_delta_ratio=stop_delta_ratio, **stop_kws): \n",
    "                    print('\\n===========\\nstopping at step ',i)\n",
    "                    break\n",
    "                    \n",
    "    def running_time(self):\n",
    "        return time_it()          \n",
    "    def get_node_pos(self):\n",
    "        return self.fine_pos\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "#neural network model without residual connection\n",
    "class neuralHeat(nn.Module):\n",
    "    def __init__(self,  feat_dims = [1,1] , A = None, deepfdl = False, fdl = False, propagation_rule = 'DAD', lr = 0.01):  #feat dims [latent_1,....,latent_n-1, latent_n, out]\n",
    "        super(neuralHeat, self).__init__()\n",
    "        self.deepfdl = deepfdl\n",
    "        self.A = normalize_A(A, propagation_rule)\n",
    "        \n",
    "        n = len(self.A)\n",
    "        \n",
    "        self.latent = nn.Parameter(torch.empty(n, feat_dims[0]))\n",
    "        r = n**(1./feat_dims[0])\n",
    "        nn.init.normal_(self.latent,std = r)\n",
    "        #nn.init.uniform_(self.latent,a=0.0, b=2*pi)\n",
    "       \n",
    "        self.Loss = lambda x: Loss(x)\n",
    "        \n",
    "        self.gcn_list = nn.ModuleList([GCN(feat_dims[i], feat_dims[i+1], A=self.A.float()) for i in range(len(feat_dims)-2)])\n",
    "        \n",
    "        self.deep_list = nn.ModuleList([Deep(feat_dims[i], feat_dims[i+1]) for i in range(len(feat_dims)-2)])\n",
    "        \n",
    "        \n",
    "        self.nonlinearity = nn.ReLU()\n",
    "        \n",
    "        \n",
    "        self.projection = nn.Parameter(torch.empty( feat_dims[-2], feat_dims[-1] ))\n",
    "        nn.init.normal_(self.projection,std = r)\n",
    "        \n",
    "        self.loss_history = []\n",
    "        self.optim = torch.optim.Adam(self.parameters(), lr = lr)\n",
    "        \n",
    "        self.fine_pos = nn.Parameter(torch.empty(n,feat_dims[-1]))\n",
    "        nn.init.normal_(self.fine_pos,std = r)\n",
    "        #nn.init.uniform_(self.fine_pos, a=0.0, b=2*pi)\n",
    "        \n",
    "        self.optim_fine = torch.optim.Adam([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = torch.optim.SGD([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = torch.optim.RMSprop([self.fine_pos], lr = lr)\n",
    "        #self.optim_fine = optim.Shampoo([self.fine_pos], lr = lr)\n",
    "    \n",
    "    def forward(self,):\n",
    "        if self.deepfdl == False:       \n",
    "            out = self.latent\n",
    "            for g in self.gcn_list:\n",
    "                out = self.nonlinearity(g(out))\n",
    "      \n",
    "            return out  @ self.projection\n",
    "        else:\n",
    "            out = self.latent\n",
    "            for g in self.deep_list:\n",
    "                out = self.nonlinearity(g(out))\n",
    "            \n",
    "            return out @ self.projection\n",
    "    \n",
    "        \n",
    "    @time_it\n",
    "    def train(self,gcn_steps=200, fdl_steps=2000, early_stop_check_steps = 100, min_steps=100, stop_delta_ratio = 5e-3, gcn_stop_threshold = 2e-2, fdl_stop_threshold = 5e-3,\n",
    "              **stop_kws):\n",
    "        \"\"\"train(self,gcn_steps=200, fdl_steps=2000, early_stop_check_steps = 100, \n",
    "              min_steps=100, #stop_delta_ratio = 5e-3, \n",
    "              gcn_stop_threshold = 2e-2,\n",
    "              fdl_stop_threshold = 5e-3,\n",
    "              **stop_kws):\n",
    "        \"\"\"\n",
    "        try:\n",
    "            if gcn_steps > 0 and len(self.gcn_list) > 0:\n",
    "                self.train_reparametrization(steps=gcn_steps, early_stop_check=early_stop_check_steps, \n",
    "                               min_steps=min_steps, \n",
    "                               stop_delta_ratio=gcn_stop_threshold, **stop_kws)\n",
    "                self.fine_pos.data = self()\n",
    "            print(f'\\nFDL training {fdl_steps} steps')\n",
    "            self.train_fine(steps=fdl_steps, early_stop_check=early_stop_check_steps, \n",
    "                            min_steps=min_steps, \n",
    "                            stop_delta_ratio=fdl_stop_threshold, **stop_kws)\n",
    "        except KeyboardInterrupt:\n",
    "            print('\\nTraining interrupted')\n",
    "            return\n",
    "        \n",
    "    \n",
    "    @time_it\n",
    "    def train_reparametrization(self,steps = 100, early_stop_check = 100, min_steps=100, stop_delta_ratio = 5e-3, **stop_kws):\n",
    "        for i in range(steps):\n",
    "            self.optim.zero_grad()\n",
    "            loss = self.Loss(self())\n",
    "            loss.backward() \n",
    "            self.loss_history += [loss.item()+0.]\n",
    "            self.optim.step()\n",
    "            if i> min_steps and i % early_stop_check == 1:\n",
    "                # print('checking', i)\n",
    "                if early_stopping(self.loss_history,stop_delta_ratio=stop_delta_ratio, **stop_kws): \n",
    "                    print('\\n===========\\nstopping at step ',i)\n",
    "                    break\n",
    "    \n",
    "    @time_it    \n",
    "    def train_fine(self,steps = 100, early_stop_check = 100, min_steps=100, stop_delta_ratio = 5e-3, **stop_kws):\n",
    "        for i in range(steps):\n",
    "            self.optim_fine.zero_grad()\n",
    "            # loss = Loss(self.fine_pos, self.A)\n",
    "            loss = self.Loss(self.fine_pos)\n",
    "            loss.backward() \n",
    "            self.loss_history += [loss.item()+0.]\n",
    "            self.optim_fine.step()\n",
    "            if i> min_steps and i % early_stop_check == 1:\n",
    "                # print('checking', i)\n",
    "                if early_stopping(self.loss_history,stop_delta_ratio=stop_delta_ratio, **stop_kws): \n",
    "                    print('\\n===========\\nstopping at step ',i)\n",
    "                    break\n",
    "                    \n",
    "    def running_time(self):\n",
    "        return time_it()          \n",
    "    def get_node_pos(self):\n",
    "        return self.fine_pos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "#early stopping condition\n",
    "\n",
    "def early_stopping(metric_list,\n",
    "            small_window = 32, #\n",
    "            big_window = 1000,#1000, # 4 times of the small window\n",
    "            stop_delta_ratio = 1e-3, verbose=True):\n",
    "    if len(metric_list) < 2*small_window:\n",
    "        return False\n",
    "    # check if chenges within big window and small window are smaller then the ratio\n",
    "    big_window = max(big_window, 2*small_window)\n",
    "    last = mean(metric_list[-small_window:])\n",
    "    dl_small =  abs(last - mean(metric_list[-2*small_window:-small_window]))\n",
    "    idx = max(0,len(metric_list)-big_window)\n",
    "    dl_big = abs(last - mean(metric_list[idx:idx+small_window]))\n",
    "    ratio = dl_small / dl_big\n",
    "    if verbose: \n",
    "        print(f'step: {len(metric_list)}, Loss change ratio: {ratio:.3g}', end='\\r')\n",
    "        # print(f'Loss change ratio: {ratio:.3g}', end='\\r')\n",
    "        \n",
    "    return (ratio < stop_delta_ratio) or (dl_small < 1e-2)\n",
    "\n",
    "def plot_layout(res):\n",
    "    x = res.get_node_pos()\n",
    "    \n",
    "    plot(x.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# choose GCN small steps\n",
    "MAX_GCN_STEPS = int(2e4)\n",
    "\n",
    "# fine-tuning FDL steps. make large\n",
    "MAX_FDL_STEPS = int(2e5)\n",
    "\n",
    "# early stopping (lower = runs longer)\n",
    "GCN_STOP_THRESHOLD = 5e-4\n",
    "FDL_STOP_THRESHOLD = 1e-3\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "step: 142, Loss change ratio: 0.000341\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.328 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 194, Loss change ratio: 0.00015\n",
      "===========\n",
      "stopping at step  51\n",
      "train_fine time: 0.0356 s\n",
      "train time: 0.364 s\n",
      "690.3745727539062\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "net = neuralHeat_Res([32,32, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "\n",
    "net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, \n",
    "          early_stop_check_steps = 10, \n",
    "          min_steps=50, \n",
    "          gcn_stop_threshold = GCN_STOP_THRESHOLD,\n",
    "          fdl_stop_threshold = FDL_STOP_THRESHOLD,\n",
    "         )\n",
    "\n",
    "figure(figsize=(12,5))\n",
    "subplot(121)\n",
    "plot(net.loss_history)\n",
    "xscale('log')\n",
    "yscale('log')\n",
    "subplot(122, aspect='equal')\n",
    "plot_layout(net)\n",
    "print(net.loss_history[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "step: 152, Loss change ratio: 0.000391\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.217 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 204, Loss change ratio: 0.000222\n",
      "===========\n",
      "stopping at step  51\n",
      "train_fine time: 0.0357 s\n",
      "train time: 0.254 s\n",
      "972.96875\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "net = neuralHeat_Res([32,32, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "\n",
    "net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, \n",
    "          early_stop_check_steps = 10, \n",
    "          min_steps=50, \n",
    "          gcn_stop_threshold = GCN_STOP_THRESHOLD,\n",
    "          fdl_stop_threshold = FDL_STOP_THRESHOLD,\n",
    "         )\n",
    "\n",
    "figure(figsize=(12,5))\n",
    "subplot(121)\n",
    "plot(net.loss_history)\n",
    "xscale('log')\n",
    "yscale('log')\n",
    "subplot(122, aspect='equal')\n",
    "plot_layout(net)\n",
    "print(net.loss_history[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "node_state = net.get_node_pos().detach().numpy()\n",
    "\n",
    "imshow(np.reshape(node_state, (-1, int(sqrt(N)) )), cmap='seismic' )\n",
    "colorbar();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "FDL training 200000 steps\n",
      "step: 7652, Loss change ratio: 0.00923\n",
      "===========\n",
      "stopping at step  7651\n",
      "train_fine time: 5.5 s\n",
      "train time: 5.5 s\n",
      "393.8336486816406\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "net = neuralHeat_Res([32, 32, 64, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "\n",
    "net.train(gcn_steps=0, fdl_steps=MAX_FDL_STEPS, \n",
    "          early_stop_check_steps = 10, \n",
    "          min_steps=50, \n",
    "          gcn_stop_threshold = GCN_STOP_THRESHOLD,\n",
    "          fdl_stop_threshold = FDL_STOP_THRESHOLD,\n",
    "         )\n",
    "\n",
    "figure(figsize=(12,5))\n",
    "subplot(121)\n",
    "plot(net.loss_history)\n",
    "xscale('log')\n",
    "\n",
    "subplot(122, aspect='equal')\n",
    "plot_layout(net)\n",
    "print(net.loss_history[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "metadata": {},
   "outputs": [],
   "source": [
    "linear_loss = net.loss_history"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "node_state = net.get_node_pos().detach().numpy()\n",
    "\n",
    "imshow(np.reshape(node_state, (-1, int(sqrt(N)) )), cmap='seismic' )\n",
    "colorbar();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "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": [
    "plot(node_state);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1158,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 792x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure(figsize = (11, 7))\n",
    "\n",
    "plot(linear_loss,  c = c5, linewidth=3, label = 'Baseline')\n",
    "plot(gcn_loss,  c = c2,linewidth=3 ,label = 'GCN 16')\n",
    "plot(deep_loss, c = c1, linewidth=3 ,label = 'Deep 16')\n",
    "plot(res32_loss, c = c4,linewidth=3,  label = 'ResGCN 2x32')\n",
    "plot(y[1],  c = c3, linewidth=3,label = 'RK4')\n",
    "plot(linear_shampoo_loss, c = c7, linewidth=3, label = 'Shampoo')\n",
    " \n",
    "xlabel('iteration steps')\n",
    "ylabel('loss')\n",
    "\n",
    "xscale('log')\n",
    "yscale('log')\n",
    "\n",
    "plt.legend(loc=0, prop={\"size\":10});\n",
    "plt.legend(fontsize=15);\n",
    "\n",
    "xlabel('Iteration steps', fontname='sherif',size=20)\n",
    "ylabel('Loss', fontname='sherif',size=20)\n",
    "\n",
    "plt.xticks(fontname='sherif',size=20)\n",
    "plt.yticks(fontname='sherif',size=20);\n",
    "\n",
    "#plt.savefig('0916_heat_loss---.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "step: 392, Loss change ratio: 9.09e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 1.08 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3484, Loss change ratio: 0.001544\n",
      "===========\n",
      "stopping at step  3091\n",
      "train_fine time: 3.58 s\n",
      "train time: 4.66 s\n",
      "step: 382, Loss change ratio: 9.09e-05\n",
      "===========\n",
      "stopping at step  381\n",
      "train_reparametrization time: 0.921 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2364, Loss change ratio: 0.000485\n",
      "===========\n",
      "stopping at step  1981\n",
      "train_fine time: 2.29 s\n",
      "train time: 3.21 s\n",
      "step: 492, Loss change ratio: 9.62e-05\n",
      "===========\n",
      "stopping at step  491\n",
      "train_reparametrization time: 0.834 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1644, Loss change ratio: 7.18e-06\n",
      "===========\n",
      "stopping at step  1151\n",
      "train_fine time: 1.28 s\n",
      "train time: 2.11 s\n",
      "step: 962, Loss change ratio: 9.13e-05\n",
      "===========\n",
      "stopping at step  961\n",
      "train_reparametrization time: 1.46 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2404, Loss change ratio: 0.000129\n",
      "===========\n",
      "stopping at step  1441\n",
      "train_fine time: 1.58 s\n",
      "train time: 3.04 s\n",
      "step: 502, Loss change ratio: 9.9e-056\n",
      "===========\n",
      "stopping at step  501\n",
      "train_reparametrization time: 1.37 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2134, Loss change ratio: 0.000139\n",
      "===========\n",
      "stopping at step  1631\n",
      "train_fine time: 1.89 s\n",
      "train time: 3.26 s\n",
      "step: 432, Loss change ratio: 9.58e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.08 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2594, Loss change ratio: 0.000207\n",
      "===========\n",
      "stopping at step  2161\n",
      "train_fine time: 2.47 s\n",
      "train time: 3.55 s\n",
      "step: 592, Loss change ratio: 9.58e-05\n",
      "===========\n",
      "stopping at step  591\n",
      "train_reparametrization time: 0.986 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1844, Loss change ratio: 3.58e-05\n",
      "===========\n",
      "stopping at step  1251\n",
      "train_fine time: 1.54 s\n",
      "train time: 2.52 s\n",
      "step: 582, Loss change ratio: 9.78e-05\n",
      "===========\n",
      "stopping at step  581\n",
      "train_reparametrization time: 0.85 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2464, Loss change ratio: 0.000327\n",
      "===========\n",
      "stopping at step  1881\n",
      "train_fine time: 2.23 s\n",
      "train time: 3.08 s\n",
      "step: 362, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  361\n",
      "train_reparametrization time: 0.967 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2204, Loss change ratio: 0.000426\n",
      "===========\n",
      "stopping at step  1841\n",
      "train_fine time: 2.27 s\n",
      "train time: 3.24 s\n",
      "step: 492, Loss change ratio: 9.18e-05\n",
      "===========\n",
      "stopping at step  491\n",
      "train_reparametrization time: 1.3 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2304, Loss change ratio: 0.000534\n",
      "===========\n",
      "stopping at step  1811\n",
      "train_fine time: 2.15 s\n",
      "train time: 3.45 s\n",
      "step: 502, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  501\n",
      "train_reparametrization time: 0.812 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1134, Loss change ratio: 1.24e-07\n",
      "===========\n",
      "stopping at step  631\n",
      "train_fine time: 0.739 s\n",
      "train time: 1.55 s\n",
      "step: 382, Loss change ratio: 9.99e-05\n",
      "===========\n",
      "stopping at step  381\n",
      "train_reparametrization time: 0.546 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2434, Loss change ratio: 0.000127\n",
      "===========\n",
      "stopping at step  2051\n",
      "train_fine time: 2.4 s\n",
      "train time: 2.95 s\n",
      "step: 422, Loss change ratio: 9.78e-05\n",
      "===========\n",
      "stopping at step  421\n",
      "train_reparametrization time: 1.13 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1704, Loss change ratio: 6.49e-05\n",
      "===========\n",
      "stopping at step  1281\n",
      "train_fine time: 1.57 s\n",
      "train time: 2.7 s\n",
      "step: 502, Loss change ratio: 9.57e-05\n",
      "===========\n",
      "stopping at step  501\n",
      "train_reparametrization time: 1.24 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2284, Loss change ratio: 0.000331\n",
      "===========\n",
      "stopping at step  1781\n",
      "train_fine time: 2.16 s\n",
      "train time: 3.4 s\n",
      "step: 582, Loss change ratio: 9.95e-05\n",
      "===========\n",
      "stopping at step  581\n",
      "train_reparametrization time: 0.97 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1544, Loss change ratio: 1.2e-066\n",
      "===========\n",
      "stopping at step  961\n",
      "train_fine time: 1.16 s\n",
      "train time: 2.13 s\n",
      "step: 502, Loss change ratio: 9.48e-05\n",
      "===========\n",
      "stopping at step  501\n",
      "train_reparametrization time: 0.738 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2284, Loss change ratio: 0.000361\n",
      "===========\n",
      "stopping at step  1781\n",
      "train_fine time: 2.15 s\n",
      "train time: 2.89 s\n",
      "step: 452, Loss change ratio: 9.21e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 1.21 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3754, Loss change ratio: 0.003969\n",
      "===========\n",
      "stopping at step  3301\n",
      "train_fine time: 4.06 s\n",
      "train time: 5.27 s\n",
      "step: 442, Loss change ratio: 8.85e-05\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 1.18 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2494, Loss change ratio: 0.000291\n",
      "===========\n",
      "stopping at step  2051\n",
      "train_fine time: 2.58 s\n",
      "train time: 3.76 s\n",
      "step: 442, Loss change ratio: 0.000106\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 0.775 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3184, Loss change ratio: 0.002458\n",
      "===========\n",
      "stopping at step  2741\n",
      "train_fine time: 3.5 s\n",
      "train time: 4.28 s\n",
      "step: 582, Loss change ratio: 9.69e-05\n",
      "===========\n",
      "stopping at step  581\n",
      "train_reparametrization time: 0.913 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2654, Loss change ratio: 0.000473\n",
      "===========\n",
      "stopping at step  2071\n",
      "train_fine time: 2.69 s\n",
      "train time: 3.6 s\n",
      "step: 462, Loss change ratio: 9.67e-05\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 1.39 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2394, Loss change ratio: 0.000247\n",
      "===========\n",
      "stopping at step  1931\n",
      "train_fine time: 2.64 s\n",
      "train time: 4.03 s\n",
      "step: 432, Loss change ratio: 8.58e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.24 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 674, Loss change ratio: 5.6e-088\n",
      "===========\n",
      "stopping at step  241\n",
      "train_fine time: 0.342 s\n",
      "train time: 1.59 s\n",
      "step: 592, Loss change ratio: 9.82e-05\n",
      "===========\n",
      "stopping at step  591\n",
      "train_reparametrization time: 1.16 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3064, Loss change ratio: 0.000337\n",
      "===========\n",
      "stopping at step  2471\n",
      "train_fine time: 3.62 s\n",
      "train time: 4.78 s\n",
      "step: 682, Loss change ratio: 9.61e-05\n",
      "===========\n",
      "stopping at step  681\n",
      "train_reparametrization time: 1.06 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2514, Loss change ratio: 0.000228\n",
      "===========\n",
      "stopping at step  1831\n",
      "train_fine time: 2.43 s\n",
      "train time: 3.49 s\n",
      "step: 462, Loss change ratio: 9.4e-053\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 1.52 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2014, Loss change ratio: 0.001134\n",
      "===========\n",
      "stopping at step  1551\n",
      "train_fine time: 2.05 s\n",
      "train time: 3.58 s\n",
      "step: 442, Loss change ratio: 8.87e-05\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 1.14 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2384, Loss change ratio: 0.000246\n",
      "===========\n",
      "stopping at step  1941\n",
      "train_fine time: 2.46 s\n",
      "train time: 3.6 s\n",
      "step: 582, Loss change ratio: 9.77e-05\n",
      "===========\n",
      "stopping at step  581\n",
      "train_reparametrization time: 1.02 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2014, Loss change ratio: 4.83e-05\n",
      "===========\n",
      "stopping at step  1431\n",
      "train_fine time: 1.86 s\n",
      "train time: 2.88 s\n",
      "step: 872, Loss change ratio: 9.7e-052\n",
      "===========\n",
      "stopping at step  871\n",
      "train_reparametrization time: 1.46 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1374, Loss change ratio: 3.33e-07\n",
      "===========\n",
      "stopping at step  501\n",
      "train_fine time: 0.688 s\n",
      "train time: 2.15 s\n",
      "step: 372, Loss change ratio: 9.82e-05\n",
      "===========\n",
      "stopping at step  371\n",
      "train_reparametrization time: 1.2 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1224, Loss change ratio: 1.25e-06\n",
      "===========\n",
      "stopping at step  851\n",
      "train_fine time: 1.16 s\n",
      "train time: 2.36 s\n",
      "step: 402, Loss change ratio: 8.87e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 1.16 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 784, Loss change ratio: 1.37e-08\n",
      "===========\n",
      "stopping at step  381\n",
      "train_fine time: 0.513 s\n",
      "train time: 1.68 s\n",
      "step: 672, Loss change ratio: 9.84e-05\n",
      "===========\n",
      "stopping at step  671\n",
      "train_reparametrization time: 1.27 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1694, Loss change ratio: 2.2e-066\n",
      "===========\n",
      "stopping at step  1021\n",
      "train_fine time: 1.37 s\n",
      "train time: 2.64 s\n",
      "step: 532, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  531\n",
      "train_reparametrization time: 0.843 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2664, Loss change ratio: 0.000273\n",
      "===========\n",
      "stopping at step  2131\n",
      "train_fine time: 2.67 s\n",
      "train time: 3.51 s\n",
      "step: 402, Loss change ratio: 9.66e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 1.07 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2104, Loss change ratio: 0.000119\n",
      "===========\n",
      "stopping at step  1701\n",
      "train_fine time: 2.08 s\n",
      "train time: 3.15 s\n",
      "step: 452, Loss change ratio: 9.51e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 1.16 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2514, Loss change ratio: 0.000697\n",
      "===========\n",
      "stopping at step  2061\n",
      "train_fine time: 2.62 s\n",
      "train time: 3.77 s\n",
      "step: 422, Loss change ratio: 9.4e-052\n",
      "===========\n",
      "stopping at step  421\n",
      "train_reparametrization time: 0.707 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3704, Loss change ratio: 0.000389\n",
      "===========\n",
      "stopping at step  3281\n",
      "train_fine time: 4.24 s\n",
      "train time: 4.95 s\n",
      "step: 602, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  601\n",
      "train_reparametrization time: 0.949 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2314, Loss change ratio: 0.000468\n",
      "===========\n",
      "stopping at step  1711\n",
      "train_fine time: 2.38 s\n",
      "train time: 3.33 s\n",
      "step: 352, Loss change ratio: 8.88e-05\n",
      "===========\n",
      "stopping at step  351\n",
      "train_reparametrization time: 1.05 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1744, Loss change ratio: 0.000234\n",
      "===========\n",
      "stopping at step  1391\n",
      "train_fine time: 1.73 s\n",
      "train time: 2.78 s\n",
      "step: 412, Loss change ratio: 9.18e-05\n",
      "===========\n",
      "stopping at step  411\n",
      "train_reparametrization time: 1.05 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2324, Loss change ratio: 0.000475\n",
      "===========\n",
      "stopping at step  1911\n",
      "train_fine time: 2.74 s\n",
      "train time: 3.78 s\n",
      "step: 602, Loss change ratio: 0.000105\n",
      "===========\n",
      "stopping at step  601\n",
      "train_reparametrization time: 1.22 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2484, Loss change ratio: 0.000388\n",
      "===========\n",
      "stopping at step  1881\n",
      "train_fine time: 2.91 s\n",
      "train time: 4.13 s\n",
      "step: 552, Loss change ratio: 9.41e-05\n",
      "===========\n",
      "stopping at step  551\n",
      "train_reparametrization time: 1.05 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2514, Loss change ratio: 0.000317\n",
      "===========\n",
      "stopping at step  1961\n",
      "train_fine time: 3.01 s\n",
      "train time: 4.06 s\n",
      "step: 252, Loss change ratio: 7.67e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 0.958 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 504, Loss change ratio: 1.5e-088\n",
      "===========\n",
      "stopping at step  251\n",
      "train_fine time: 0.394 s\n",
      "train time: 1.35 s\n",
      "step: 212, Loss change ratio: 8.79e-05\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.794 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 734, Loss change ratio: 5.18e-08\n",
      "===========\n",
      "stopping at step  521\n",
      "train_fine time: 0.809 s\n",
      "train time: 1.6 s\n",
      "step: 302, Loss change ratio: 9.89e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 0.636 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 694, Loss change ratio: 1.02e-09\n",
      "===========\n",
      "stopping at step  391\n",
      "train_fine time: 0.635 s\n",
      "train time: 1.27 s\n",
      "step: 242, Loss change ratio: 9.86e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 0.789 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 394, Loss change ratio: 1.14e-07\n",
      "===========\n",
      "stopping at step  151\n",
      "train_fine time: 0.235 s\n",
      "train time: 1.03 s\n",
      "step: 242, Loss change ratio: 8.36e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 0.923 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 564, Loss change ratio: 1.03e-08\n",
      "===========\n",
      "stopping at step  321\n",
      "train_fine time: 0.491 s\n",
      "train time: 1.42 s\n",
      "step: 212, Loss change ratio: 7.8e-058\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.741 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 634, Loss change ratio: 5.89e-08\n",
      "===========\n",
      "stopping at step  421\n",
      "train_fine time: 0.638 s\n",
      "train time: 1.38 s\n",
      "step: 282, Loss change ratio: 8.32e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 0.573 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 414, Loss change ratio: 1.05e-08\n",
      "===========\n",
      "stopping at step  131\n",
      "train_fine time: 0.196 s\n",
      "train time: 0.77 s\n",
      "step: 282, Loss change ratio: 9.58e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 0.531 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 454, Loss change ratio: 3.3e-088\n",
      "===========\n",
      "stopping at step  171\n",
      "train_fine time: 0.27 s\n",
      "train time: 0.802 s\n",
      "step: 222, Loss change ratio: 8.64e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.816 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 494, Loss change ratio: 1.14e-08\n",
      "===========\n",
      "stopping at step  271\n",
      "train_fine time: 0.431 s\n",
      "train time: 1.25 s\n",
      "step: 202, Loss change ratio: 8.95e-05\n",
      "===========\n",
      "stopping at step  201\n",
      "train_reparametrization time: 0.725 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 294, Loss change ratio: 3.71e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.861 s\n",
      "step: 292, Loss change ratio: 8.8e-051\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 0.608 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 414, Loss change ratio: 1.58e-07\n",
      "===========\n",
      "stopping at step  121\n",
      "train_fine time: 0.19 s\n",
      "train time: 0.799 s\n",
      "step: 312, Loss change ratio: 9.12e-05\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 0.603 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 594, Loss change ratio: 7.52e-09\n",
      "===========\n",
      "stopping at step  281\n",
      "train_fine time: 0.451 s\n",
      "train time: 1.06 s\n",
      "step: 222, Loss change ratio: 9.57e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.823 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 464, Loss change ratio: 3.84e-09\n",
      "===========\n",
      "stopping at step  241\n",
      "train_fine time: 0.386 s\n",
      "train time: 1.21 s\n",
      "step: 252, Loss change ratio: 9.17e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 0.928 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 474, Loss change ratio: 4.18e-08\n",
      "===========\n",
      "stopping at step  221\n",
      "train_fine time: 0.363 s\n",
      "train time: 1.29 s\n",
      "step: 322, Loss change ratio: 9.15e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 0.715 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 654, Loss change ratio: 9.5e-098\n",
      "===========\n",
      "stopping at step  331\n",
      "train_fine time: 0.535 s\n",
      "train time: 1.25 s\n",
      "step: 322, Loss change ratio: 9.9e-054\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 0.66 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 574, Loss change ratio: 2.48e-08\n",
      "===========\n",
      "stopping at step  251\n",
      "train_fine time: 0.4 s\n",
      "train time: 1.06 s\n",
      "step: 212, Loss change ratio: 8.03e-05\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.886 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 714, Loss change ratio: 2.02e-09\n",
      "===========\n",
      "stopping at step  501\n",
      "train_fine time: 0.829 s\n",
      "train time: 1.72 s\n",
      "step: 212, Loss change ratio: 8.88e-05\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.81 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 464, Loss change ratio: 5.99e-08\n",
      "===========\n",
      "stopping at step  251\n",
      "train_fine time: 0.411 s\n",
      "train time: 1.22 s\n",
      "step: 282, Loss change ratio: 8.83e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 0.623 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 564, Loss change ratio: 7.43e-09\n",
      "===========\n",
      "stopping at step  281\n",
      "train_fine time: 0.457 s\n",
      "train time: 1.08 s\n",
      "step: 312, Loss change ratio: 9.25e-05\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 0.66 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 634, Loss change ratio: 1.12e-08\n",
      "===========\n",
      "stopping at step  321\n",
      "train_fine time: 0.525 s\n",
      "train time: 1.19 s\n",
      "step: 242, Loss change ratio: 7.86e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 0.946 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 744, Loss change ratio: 4.97e-09\n",
      "===========\n",
      "stopping at step  501\n",
      "train_fine time: 0.848 s\n",
      "train time: 1.79 s\n",
      "step: 222, Loss change ratio: 7.55e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.841 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 424, Loss change ratio: 1.15e-07\n",
      "===========\n",
      "stopping at step  201\n",
      "train_fine time: 0.336 s\n",
      "train time: 1.18 s\n",
      "step: 342, Loss change ratio: 9.13e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 0.741 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 664, Loss change ratio: 1.45e-08\n",
      "===========\n",
      "stopping at step  321\n",
      "train_fine time: 0.542 s\n",
      "train time: 1.28 s\n",
      "step: 342, Loss change ratio: 8.63e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 0.715 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 464, Loss change ratio: 1.38e-08\n",
      "===========\n",
      "stopping at step  121\n",
      "train_fine time: 0.2 s\n",
      "train time: 0.915 s\n",
      "step: 232, Loss change ratio: 9.96e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 0.901 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1314, Loss change ratio: 0.000189\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 1.85 s\n",
      "train time: 2.75 s\n",
      "step: 202, Loss change ratio: 9.39e-05\n",
      "===========\n",
      "stopping at step  201\n",
      "train_reparametrization time: 0.798 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 294, Loss change ratio: 4.44e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.155 s\n",
      "train time: 0.954 s\n",
      "step: 262, Loss change ratio: 7.98e-05\n",
      "===========\n",
      "stopping at step  261\n",
      "train_reparametrization time: 0.597 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 374, Loss change ratio: 1.5e-077\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.179 s\n",
      "train time: 0.777 s\n",
      "step: 402, Loss change ratio: 9.97e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 0.817 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 564, Loss change ratio: 1.41e-08\n",
      "===========\n",
      "stopping at step  161\n",
      "train_fine time: 0.257 s\n",
      "train time: 1.08 s\n",
      "step: 272, Loss change ratio: 9.37e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 1.04 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1424, Loss change ratio: 0.000206\n",
      "===========\n",
      "stopping at step  1151\n",
      "train_fine time: 1.82 s\n",
      "train time: 2.86 s\n",
      "step: 252, Loss change ratio: 7.82e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 0.889 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 364, Loss change ratio: 3.66e-08\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.168 s\n",
      "train time: 1.06 s\n",
      "step: 322, Loss change ratio: 9.77e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 0.649 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 654, Loss change ratio: 2.43e-08\n",
      "===========\n",
      "stopping at step  331\n",
      "train_fine time: 0.487 s\n",
      "train time: 1.14 s\n",
      "step: 252, Loss change ratio: 7.97e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 0.467 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 344, Loss change ratio: 1.51e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.132 s\n",
      "train time: 0.6 s\n",
      "step: 212, Loss change ratio: 9.1e-055\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.734 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 354, Loss change ratio: 3.68e-08\n",
      "===========\n",
      "stopping at step  141\n",
      "train_fine time: 0.207 s\n",
      "train time: 0.942 s\n",
      "step: 272, Loss change ratio: 7.11e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 0.911 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 494, Loss change ratio: 5.33e-08\n",
      "===========\n",
      "stopping at step  221\n",
      "train_fine time: 0.317 s\n",
      "train time: 1.23 s\n",
      "step: 232, Loss change ratio: 7.57e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 0.433 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 334, Loss change ratio: 6.67e-08\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.142 s\n",
      "train time: 0.576 s\n",
      "step: 242, Loss change ratio: 9.69e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 0.431 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 354, Loss change ratio: 5.03e-08\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.156 s\n",
      "train time: 0.587 s\n",
      "step: 242, Loss change ratio: 8.98e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 0.83 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 894, Loss change ratio: 2.3e-099\n",
      "===========\n",
      "stopping at step  651\n",
      "train_fine time: 1.02 s\n",
      "train time: 1.85 s\n",
      "step: 222, Loss change ratio: 9.28e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 374, Loss change ratio: 2.05e-07\n",
      "===========\n",
      "stopping at step  151\n",
      "train_fine time: 0.205 s\n",
      "train time: 0.936 s\n",
      "step: 332, Loss change ratio: 9e-05102\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 0.6 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 714, Loss change ratio: 8.83e-09\n",
      "===========\n",
      "stopping at step  381\n",
      "train_fine time: 0.53 s\n",
      "train time: 1.13 s\n",
      "step: 232, Loss change ratio: 8.18e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 0.397 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 324, Loss change ratio: 4.25e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.122 s\n",
      "train time: 0.52 s\n",
      "step: 182, Loss change ratio: 7.14e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.622 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 1.99e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.113 s\n",
      "train time: 0.736 s\n",
      "step: 162, Loss change ratio: 5.84e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.494 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 1.19e-07\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.139 s\n",
      "train time: 0.633 s\n",
      "step: 222, Loss change ratio: 8.78e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.418 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 534, Loss change ratio: 8.47e-09\n",
      "===========\n",
      "stopping at step  311\n",
      "train_fine time: 0.422 s\n",
      "train time: 0.841 s\n",
      "step: 192, Loss change ratio: 9.56e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.371 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 364, Loss change ratio: 1.47e-07\n",
      "===========\n",
      "stopping at step  171\n",
      "train_fine time: 0.233 s\n",
      "train time: 0.605 s\n",
      "step: 182, Loss change ratio: 5.6e-052\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.553 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 414, Loss change ratio: 2.41e-08\n",
      "===========\n",
      "stopping at step  231\n",
      "train_fine time: 0.318 s\n",
      "train time: 0.872 s\n",
      "step: 162, Loss change ratio: 7.88e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.476 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 444, Loss change ratio: 5.69e-08\n",
      "===========\n",
      "stopping at step  281\n",
      "train_fine time: 0.387 s\n",
      "train time: 0.864 s\n",
      "step: 212, Loss change ratio: 9.98e-05\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.411 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 474, Loss change ratio: 2.48e-08\n",
      "===========\n",
      "stopping at step  261\n",
      "train_fine time: 0.363 s\n",
      "train time: 0.775 s\n",
      "step: 162, Loss change ratio: 9.73e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.299 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 1.85e-06\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.128 s\n",
      "train time: 0.428 s\n",
      "step: 172, Loss change ratio: 9.24e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.544 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 814, Loss change ratio: 3.03e-08\n",
      "===========\n",
      "stopping at step  641\n",
      "train_fine time: 0.894 s\n",
      "train time: 1.44 s\n",
      "step: 162, Loss change ratio: 9.33e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.487 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 354, Loss change ratio: 1.43e-07\n",
      "===========\n",
      "stopping at step  191\n",
      "train_fine time: 0.265 s\n",
      "train time: 0.753 s\n",
      "step: 172, Loss change ratio: 8.01e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.335 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 1.64e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.114 s\n",
      "train time: 0.45 s\n",
      "step: 162, Loss change ratio: 9.28e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.295 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 8.26e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.125 s\n",
      "train time: 0.42 s\n",
      "step: 202, Loss change ratio: 6.76e-05\n",
      "===========\n",
      "stopping at step  201\n",
      "train_reparametrization time: 0.643 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 314, Loss change ratio: 3.99e-08\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.155 s\n",
      "train time: 0.8 s\n",
      "step: 162, Loss change ratio: 8.16e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.476 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 294, Loss change ratio: 2.37e-07\n",
      "===========\n",
      "stopping at step  131\n",
      "train_fine time: 0.184 s\n",
      "train time: 0.661 s\n",
      "step: 172, Loss change ratio: 9.02e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.333 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 1.14e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.114 s\n",
      "train time: 0.448 s\n",
      "step: 182, Loss change ratio: 8.15e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.33 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 1.28e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.123 s\n",
      "train time: 0.453 s\n",
      "step: 182, Loss change ratio: 7.24e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.584 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 744, Loss change ratio: 1.43e-08\n",
      "===========\n",
      "stopping at step  561\n",
      "train_fine time: 0.811 s\n",
      "train time: 1.4 s\n",
      "step: 152, Loss change ratio: 9.31e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.504 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 2.64e-07\n",
      "===========\n",
      "stopping at step  131\n",
      "train_fine time: 0.203 s\n",
      "train time: 0.708 s\n",
      "step: 192, Loss change ratio: 7.9e-059\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.435 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 4.08e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.571 s\n",
      "step: 152, Loss change ratio: 5.84e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.352 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 7.24e-07\n",
      "===========\n",
      "stopping at step  71\n",
      "train_fine time: 0.106 s\n",
      "train time: 0.458 s\n",
      "step: 182, Loss change ratio: 7.03e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.633 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 1.02e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.147 s\n",
      "train time: 0.781 s\n",
      "step: 162, Loss change ratio: 9.26e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.624 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 4.16e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.145 s\n",
      "train time: 0.77 s\n",
      "step: 232, Loss change ratio: 9.87e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 0.548 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 414, Loss change ratio: 1.14e-07\n",
      "===========\n",
      "stopping at step  181\n",
      "train_fine time: 0.293 s\n",
      "train time: 0.842 s\n",
      "step: 192, Loss change ratio: 7.49e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.427 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 1.56e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.56 s\n",
      "step: 182, Loss change ratio: 6.2e-053\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.689 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 4.73e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.151 s\n",
      "train time: 0.841 s\n",
      "step: 162, Loss change ratio: 6.24e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.594 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 324, Loss change ratio: 1.16e-07\n",
      "===========\n",
      "stopping at step  161\n",
      "train_fine time: 0.241 s\n",
      "train time: 0.836 s\n",
      "step: 212, Loss change ratio: 9.75e-05\n",
      "===========\n",
      "stopping at step  211\n",
      "train_reparametrization time: 0.471 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 394, Loss change ratio: 6.19e-08\n",
      "===========\n",
      "stopping at step  181\n",
      "train_fine time: 0.292 s\n",
      "train time: 0.764 s\n",
      "step: 222, Loss change ratio: 7.91e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.489 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 394, Loss change ratio: 1.05e-07\n",
      "===========\n",
      "stopping at step  171\n",
      "train_fine time: 0.268 s\n",
      "train time: 0.757 s\n",
      "step: 172, Loss change ratio: 5.98e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.624 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 4.92e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.159 s\n",
      "train time: 0.785 s\n",
      "step: 172, Loss change ratio: 7e-05102\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.586 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 454, Loss change ratio: 7.57e-08\n",
      "===========\n",
      "stopping at step  281\n",
      "train_fine time: 0.428 s\n",
      "train time: 1.02 s\n",
      "step: 222, Loss change ratio: 8.46e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.492 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 324, Loss change ratio: 5.14e-08\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.161 s\n",
      "train time: 0.654 s\n",
      "step: 192, Loss change ratio: 9.97e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.414 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 1.33e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.126 s\n",
      "train time: 0.541 s\n",
      "step: 192, Loss change ratio: 6.84e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.72 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 5.57e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.14 s\n",
      "train time: 0.861 s\n",
      "step: 152, Loss change ratio: 9.17e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.568 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2.54e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.185 s\n",
      "train time: 0.755 s\n",
      "step: 192, Loss change ratio: 9.96e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.449 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 404, Loss change ratio: 2.64e-08\n",
      "===========\n",
      "stopping at step  211\n",
      "train_fine time: 0.335 s\n",
      "train time: 0.784 s\n",
      "step: 222, Loss change ratio: 7.2e-055\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 0.473 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 334, Loss change ratio: 7.96e-09\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.188 s\n",
      "train time: 0.662 s\n",
      "step: 192, Loss change ratio: 6.94e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.745 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 484, Loss change ratio: 1.53e-08\n",
      "===========\n",
      "stopping at step  291\n",
      "train_fine time: 0.757 s\n",
      "train time: 1.5 s\n",
      "step: 162, Loss change ratio: 5.26e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.641 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 294, Loss change ratio: 1.42e-07\n",
      "===========\n",
      "stopping at step  131\n",
      "train_fine time: 0.2 s\n",
      "train time: 0.842 s\n",
      "step: 172, Loss change ratio: 9.1e-052\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.365 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 2.84e-08\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.182 s\n",
      "train time: 0.548 s\n",
      "step: 162, Loss change ratio: 9.6e-051\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.328 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2.33e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.127 s\n",
      "train time: 0.456 s\n",
      "step: 152, Loss change ratio: 5.7e-054\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.689 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 9.58e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.12 s\n",
      "train time: 0.811 s\n",
      "step: 142, Loss change ratio: 8.07e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.571 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.41e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.14 s\n",
      "train time: 0.712 s\n",
      "step: 182, Loss change ratio: 5.32e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.479 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 1.76e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.139 s\n",
      "train time: 0.618 s\n",
      "step: 152, Loss change ratio: 3.94e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.359 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 8.42e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.148 s\n",
      "train time: 0.508 s\n",
      "step: 152, Loss change ratio: 5.69e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.659 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 9.23e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.122 s\n",
      "train time: 0.783 s\n",
      "step: 142, Loss change ratio: 7.14e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.62 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.86e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.131 s\n",
      "train time: 0.753 s\n",
      "step: 192, Loss change ratio: 7.99e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.543 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 4.43e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.149 s\n",
      "train time: 0.692 s\n",
      "step: 152, Loss change ratio: 4.07e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.372 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.15e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.508 s\n",
      "step: 152, Loss change ratio: 3.59e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.681 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.03e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.815 s\n",
      "step: 142, Loss change ratio: 8.52e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.627 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.95e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.145 s\n",
      "train time: 0.773 s\n",
      "step: 152, Loss change ratio: 7.59e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.427 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.06e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.561 s\n",
      "step: 152, Loss change ratio: 4.14e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.375 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 2.71e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.511 s\n",
      "step: 152, Loss change ratio: 9.02e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.752 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 614, Loss change ratio: 2.89e-08\n",
      "===========\n",
      "stopping at step  461\n",
      "train_fine time: 0.784 s\n",
      "train time: 1.54 s\n",
      "step: 142, Loss change ratio: 6.66e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.632 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.82e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.764 s\n",
      "step: 162, Loss change ratio: 4.73e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.462 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 4.82e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.153 s\n",
      "train time: 0.616 s\n",
      "step: 152, Loss change ratio: 4e-05111\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.358 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 8.17e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.152 s\n",
      "train time: 0.51 s\n",
      "step: 162, Loss change ratio: 5.88e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.77 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 304, Loss change ratio: 9.12e-09\n",
      "===========\n",
      "stopping at step  141\n",
      "train_fine time: 0.231 s\n",
      "train time: 1 s\n",
      "step: 142, Loss change ratio: 9.22e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.608 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 5.34e-07\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.185 s\n",
      "train time: 0.795 s\n",
      "step: 192, Loss change ratio: 7.17e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 0.652 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 304, Loss change ratio: 6.05e-09\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.213 s\n",
      "train time: 0.866 s\n",
      "step: 152, Loss change ratio: 4.06e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.388 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 7.37e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.152 s\n",
      "train time: 0.541 s\n",
      "step: 152, Loss change ratio: 8.68e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.664 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 384, Loss change ratio: 1.43e-08\n",
      "===========\n",
      "stopping at step  231\n",
      "train_fine time: 0.379 s\n",
      "train time: 1.04 s\n",
      "step: 142, Loss change ratio: 7.28e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.603 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.85e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.737 s\n",
      "step: 162, Loss change ratio: 4.13e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.422 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 9.45e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.553 s\n",
      "step: 152, Loss change ratio: 4.48e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.365 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.78e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.5 s\n",
      "step: 152, Loss change ratio: 4.94e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.668 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 3.98e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.15 s\n",
      "train time: 0.819 s\n",
      "step: 152, Loss change ratio: 5.38e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.64 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 2.99e-07\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.176 s\n",
      "train time: 0.818 s\n",
      "step: 162, Loss change ratio: 9.66e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.409 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 2.45e-07\n",
      "===========\n",
      "stopping at step  71\n",
      "train_fine time: 0.11 s\n",
      "train time: 0.52 s\n",
      "step: 182, Loss change ratio: 8.99e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.425 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 274, Loss change ratio: 5.06e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.14 s\n",
      "train time: 0.566 s\n",
      "step: 152, Loss change ratio: 4.24e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.641 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.57e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.128 s\n",
      "train time: 0.771 s\n",
      "step: 142, Loss change ratio: 7.09e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.567 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 1.09e-06\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.122 s\n",
      "train time: 0.69 s\n",
      "step: 182, Loss change ratio: 6.6e-055\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.462 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 2.51e-08\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.152 s\n",
      "train time: 0.615 s\n",
      "step: 152, Loss change ratio: 6.03e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.337 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 9.79e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.126 s\n",
      "train time: 0.464 s\n",
      "step: 152, Loss change ratio: 4.86e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.616 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 1.2e-077\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.751 s\n",
      "step: 142, Loss change ratio: 7.93e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.535 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.63e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.666 s\n",
      "step: 172, Loss change ratio: 9.24e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 0.427 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 2.6e-077\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.131 s\n",
      "train time: 0.559 s\n",
      "step: 152, Loss change ratio: 4.42e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.325 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.9e-077\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.117 s\n",
      "train time: 0.443 s\n",
      "step: 162, Loss change ratio: 7.16e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.647 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 3.57e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.134 s\n",
      "train time: 0.782 s\n",
      "step: 142, Loss change ratio: 7.31e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.538 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.69e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.67 s\n",
      "step: 182, Loss change ratio: 3.95e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 0.454 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 7.08e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.112 s\n",
      "train time: 0.566 s\n",
      "step: 152, Loss change ratio: 4.6e-051\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.304 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.96e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.114 s\n",
      "train time: 0.419 s\n",
      "step: 142, Loss change ratio: 8.81e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.885 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.8e-088\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.128 s\n",
      "train time: 1.02 s\n",
      "step: 142, Loss change ratio: 9.05e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.727 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 4.42e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.129 s\n",
      "train time: 0.857 s\n",
      "step: 152, Loss change ratio: 4.41e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.627 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.63e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.119 s\n",
      "train time: 0.747 s\n",
      "step: 152, Loss change ratio: 3.62e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.484 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 7.41e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.112 s\n",
      "train time: 0.597 s\n",
      "step: 142, Loss change ratio: 8.93e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.917 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 474, Loss change ratio: 7.38e-09\n",
      "===========\n",
      "stopping at step  331\n",
      "train_fine time: 0.468 s\n",
      "train time: 1.39 s\n",
      "step: 142, Loss change ratio: 8.63e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.72 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 1.21e-06\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.125 s\n",
      "train time: 0.846 s\n",
      "step: 152, Loss change ratio: 7.01e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.653 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 9.37e-09\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.134 s\n",
      "train time: 0.789 s\n",
      "step: 152, Loss change ratio: 8.25e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.537 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 3.74e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.135 s\n",
      "train time: 0.673 s\n",
      "step: 142, Loss change ratio: 9e-05238\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 1.03 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 3.74e-08\n",
      "===========\n",
      "stopping at step  111\n",
      "train_fine time: 0.166 s\n",
      "train time: 1.19 s\n",
      "step: 142, Loss change ratio: 8.34e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.833 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.59e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.116 s\n",
      "train time: 0.951 s\n",
      "step: 142, Loss change ratio: 9.36e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.647 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 7.68e-09\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.137 s\n",
      "train time: 0.785 s\n",
      "step: 152, Loss change ratio: 4.1e-059\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.547 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 8.94e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.115 s\n",
      "train time: 0.663 s\n",
      "step: 142, Loss change ratio: 8.75e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.979 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 5.86e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.117 s\n",
      "train time: 1.1 s\n",
      "step: 142, Loss change ratio: 8.3e-055\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.848 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 1.11e-06\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.979 s\n",
      "step: 152, Loss change ratio: 4.93e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.736 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 2.6e-088\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.125 s\n",
      "train time: 0.863 s\n",
      "step: 152, Loss change ratio: 6.41e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.574 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 4.82e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.124 s\n",
      "train time: 0.699 s\n",
      "step: 152, Loss change ratio: 5.9e-056\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 1.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 994, Loss change ratio: 1.62e-08\n",
      "===========\n",
      "stopping at step  841\n",
      "train_fine time: 1.35 s\n",
      "train time: 2.5 s\n",
      "step: 142, Loss change ratio: 9.07e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.92 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.48e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.138 s\n",
      "train time: 1.06 s\n",
      "step: 162, Loss change ratio: 7.93e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.782 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 264, Loss change ratio: 4.41e-09\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.165 s\n",
      "train time: 0.949 s\n",
      "step: 152, Loss change ratio: 3.85e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.636 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 6.94e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.157 s\n",
      "train time: 0.794 s\n",
      "step: 142, Loss change ratio: 8.14e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 1.14 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 7.43e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.126 s\n",
      "train time: 1.27 s\n",
      "step: 142, Loss change ratio: 7.96e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.814 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 214, Loss change ratio: 2.62e-06\n",
      "===========\n",
      "stopping at step  71\n",
      "train_fine time: 0.113 s\n",
      "train time: 0.929 s\n",
      "step: 162, Loss change ratio: 7.95e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.743 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2.13e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.128 s\n",
      "train time: 0.872 s\n",
      "step: 152, Loss change ratio: 4.53e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.59 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2.65e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.143 s\n",
      "train time: 0.734 s\n",
      "step: 152, Loss change ratio: 3.76e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 1.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 254, Loss change ratio: 6.04e-08\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.168 s\n",
      "train time: 1.28 s\n",
      "step: 142, Loss change ratio: 8.49e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.886 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 1.28e-07\n",
      "===========\n",
      "stopping at step  101\n",
      "train_fine time: 0.166 s\n",
      "train time: 1.05 s\n",
      "step: 152, Loss change ratio: 6.74e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.711 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 2.35e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.13 s\n",
      "train time: 0.843 s\n",
      "step: 152, Loss change ratio: 4.68e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.582 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 6.44e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.134 s\n",
      "train time: 0.717 s\n",
      "step: 152, Loss change ratio: 3.64e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 1.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 1.16e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 1.24 s\n",
      "step: 142, Loss change ratio: 9.82e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.881 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 3.57e-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.149 s\n",
      "train time: 1.03 s\n",
      "step: 152, Loss change ratio: 9.95e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.755 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 2.22e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.133 s\n",
      "train time: 0.89 s\n",
      "step: 152, Loss change ratio: 4.04e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.562 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 5e-08077\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.138 s\n",
      "train time: 0.701 s\n",
      "step: 142, Loss change ratio: 9.67e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 1.07 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 284, Loss change ratio: 3.61e-08\n",
      "===========\n",
      "stopping at step  141\n",
      "train_fine time: 0.239 s\n",
      "train time: 1.32 s\n",
      "step: 142, Loss change ratio: 9.51e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.898 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.2e-076\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.137 s\n",
      "train time: 1.04 s\n",
      "step: 152, Loss change ratio: 6.91e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.753 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2e-07-07\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.148 s\n",
      "train time: 0.902 s\n",
      "step: 152, Loss change ratio: 4.14e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.558 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 4.26e-08\n",
      "===========\n",
      "stopping at step  91\n",
      "train_fine time: 0.154 s\n",
      "train time: 0.712 s\n",
      "step: 152, Loss change ratio: 8.79e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 1.2 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1084, Loss change ratio: 0.000125\n",
      "===========\n",
      "stopping at step  931\n",
      "train_fine time: 1.64 s\n",
      "train time: 2.84 s\n",
      "step: 142, Loss change ratio: 8.72e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 0.966 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 224, Loss change ratio: 9.86e-07\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.147 s\n",
      "train time: 1.12 s\n",
      "step: 162, Loss change ratio: 5.88e-05\n",
      "===========\n",
      "stopping at step  161\n",
      "train_reparametrization time: 0.805 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 244, Loss change ratio: 2.66e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.145 s\n",
      "train time: 0.951 s\n",
      "step: 152, Loss change ratio: 5.09e-05\n",
      "===========\n",
      "stopping at step  151\n",
      "train_reparametrization time: 0.634 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 234, Loss change ratio: 5.64e-08\n",
      "===========\n",
      "stopping at step  81\n",
      "train_fine time: 0.138 s\n",
      "train time: 0.772 s\n"
     ]
    }
   ],
   "source": [
    "e=10\n",
    "\n",
    "dimension = [8, 16, 32, 64, 128]\n",
    "\n",
    "one_layer = []\n",
    "\n",
    "for i in dimension:\n",
    "    for j in range(e):\n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "       \n",
    "        one_layer += [[ 'GCN Res', [i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        one_layer += [[ 'GCN', [i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        one_layer += [[ 'Deep Res', [i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        one_layer += [[ 'Deep', [i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 987,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "step: 482, Loss change ratio: 9.85e-05\n",
      "===========\n",
      "stopping at step  481\n",
      "train_reparametrization time: 3.75 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6914, Loss change ratio: 0.015347\n",
      "===========\n",
      "stopping at step  6431\n",
      "train_fine time: 14.6 s\n",
      "train time: 18.4 s\n",
      "step: 602, Loss change ratio: 9.71e-05\n",
      "===========\n",
      "stopping at step  601\n",
      "train_reparametrization time: 4.27 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1874, Loss change ratio: 0.000102\n",
      "===========\n",
      "stopping at step  1271\n",
      "train_fine time: 2.77 s\n",
      "train time: 7.04 s\n",
      "step: 662, Loss change ratio: 9.7e-052\n",
      "===========\n",
      "stopping at step  661\n",
      "train_reparametrization time: 2.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5884, Loss change ratio: 0.014488\n",
      "===========\n",
      "stopping at step  5221\n",
      "train_fine time: 11.3 s\n",
      "train time: 13.5 s\n",
      "step: 7132, Loss change ratio: 9.42e-05\n",
      "===========\n",
      "stopping at step  7131\n",
      "train_reparametrization time: 20.4 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 11674, Loss change ratio: 0.01527\n",
      "===========\n",
      "stopping at step  4541\n",
      "train_fine time: 9.94 s\n",
      "train time: 30.3 s\n",
      "step: 542, Loss change ratio: 9.68e-05\n",
      "===========\n",
      "stopping at step  541\n",
      "train_reparametrization time: 4.03 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5874, Loss change ratio: 0.013521\n",
      "===========\n",
      "stopping at step  5331\n",
      "train_fine time: 11.7 s\n",
      "train time: 15.7 s\n",
      "step: 922, Loss change ratio: 9.44e-05\n",
      "===========\n",
      "stopping at step  921\n",
      "train_reparametrization time: 6.5 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3094, Loss change ratio: 0.003414\n",
      "===========\n",
      "stopping at step  2171\n",
      "train_fine time: 4.73 s\n",
      "train time: 11.2 s\n",
      "step: 662, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  661\n",
      "train_reparametrization time: 2.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4874, Loss change ratio: 0.012292\n",
      "===========\n",
      "stopping at step  4211\n",
      "train_fine time: 9.23 s\n",
      "train time: 11.4 s\n",
      "step: 17022, Loss change ratio: 3.8e-057\n",
      "===========\n",
      "stopping at step  17021\n",
      "train_reparametrization time: 50 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 20504, Loss change ratio: 0.016593\n",
      "===========\n",
      "stopping at step  3481\n",
      "train_fine time: 7.64 s\n",
      "train time: 57.6 s\n",
      "step: 492, Loss change ratio: 9.82e-05\n",
      "===========\n",
      "stopping at step  491\n",
      "train_reparametrization time: 3.64 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6864, Loss change ratio: 0.010762\n",
      "===========\n",
      "stopping at step  6371\n",
      "train_fine time: 13.9 s\n",
      "train time: 17.6 s\n",
      "step: 952, Loss change ratio: 9.77e-05\n",
      "===========\n",
      "stopping at step  951\n",
      "train_reparametrization time: 6.71 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4284, Loss change ratio: 0.013154\n",
      "===========\n",
      "stopping at step  3331\n",
      "train_fine time: 7.27 s\n",
      "train time: 14 s\n",
      "step: 542, Loss change ratio: 9.95e-05\n",
      "===========\n",
      "stopping at step  541\n",
      "train_reparametrization time: 1.77 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 7394, Loss change ratio: 0.016475\n",
      "===========\n",
      "stopping at step  6851\n",
      "train_fine time: 15 s\n",
      "train time: 16.8 s\n",
      "step: 562, Loss change ratio: 9.51e-05\n",
      "===========\n",
      "stopping at step  561\n",
      "train_reparametrization time: 1.62 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4594, Loss change ratio: 0.015359\n",
      "===========\n",
      "stopping at step  4031\n",
      "train_fine time: 8.8 s\n",
      "train time: 10.4 s\n",
      "step: 552, Loss change ratio: 9.68e-05\n",
      "===========\n",
      "stopping at step  551\n",
      "train_reparametrization time: 4.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4734, Loss change ratio: 0.006369\n",
      "===========\n",
      "stopping at step  4181\n",
      "train_fine time: 9.13 s\n",
      "train time: 13.2 s\n",
      "step: 612, Loss change ratio: 9.95e-05\n",
      "===========\n",
      "stopping at step  611\n",
      "train_reparametrization time: 4.32 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2624, Loss change ratio: 0.002184\n",
      "===========\n",
      "stopping at step  2011\n",
      "train_fine time: 4.4 s\n",
      "train time: 8.72 s\n",
      "step: 432, Loss change ratio: 9.93e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.41 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 8624, Loss change ratio: 0.014198\n",
      "===========\n",
      "stopping at step  8191\n",
      "train_fine time: 17.9 s\n",
      "train time: 19.3 s\n",
      "step: 432, Loss change ratio: 9.88e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.25 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 7314, Loss change ratio: 0.016851\n",
      "===========\n",
      "stopping at step  6881\n",
      "train_fine time: 15 s\n",
      "train time: 16.3 s\n",
      "step: 502, Loss change ratio: 9.85e-05\n",
      "===========\n",
      "stopping at step  501\n",
      "train_reparametrization time: 3.75 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6694, Loss change ratio: 0.011725\n",
      "===========\n",
      "stopping at step  6191\n",
      "train_fine time: 13.5 s\n",
      "train time: 17.3 s\n",
      "step: 522, Loss change ratio: 9.79e-05\n",
      "===========\n",
      "stopping at step  521\n",
      "train_reparametrization time: 3.69 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2044, Loss change ratio: 0.000866\n",
      "===========\n",
      "stopping at step  1521\n",
      "train_fine time: 3.33 s\n",
      "train time: 7.02 s\n",
      "step: 442, Loss change ratio: 9.98e-05\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 1.43 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 8744, Loss change ratio: 0.015283\n",
      "===========\n",
      "stopping at step  8301\n",
      "train_fine time: 18.2 s\n",
      "train time: 19.6 s\n",
      "step: 932, Loss change ratio: 9.78e-05\n",
      "===========\n",
      "stopping at step  931\n",
      "train_reparametrization time: 2.8 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5874, Loss change ratio: 0.013353\n",
      "===========\n",
      "stopping at step  4941\n",
      "train_fine time: 10.8 s\n",
      "train time: 13.6 s\n",
      "step: 472, Loss change ratio: 9.61e-05\n",
      "===========\n",
      "stopping at step  471\n",
      "train_reparametrization time: 3.62 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4134, Loss change ratio: 0.003279\n",
      "===========\n",
      "stopping at step  3661\n",
      "train_fine time: 8.68 s\n",
      "train time: 12.3 s\n",
      "step: 562, Loss change ratio: 9.7e-051\n",
      "===========\n",
      "stopping at step  561\n",
      "train_reparametrization time: 4.35 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1334, Loss change ratio: 6.04e-06\n",
      "===========\n",
      "stopping at step  771\n",
      "train_fine time: 1.96 s\n",
      "train time: 6.32 s\n",
      "step: 592, Loss change ratio: 9.72e-05\n",
      "===========\n",
      "stopping at step  591\n",
      "train_reparametrization time: 2.28 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 7334, Loss change ratio: 0.013566\n",
      "===========\n",
      "stopping at step  6741\n",
      "train_fine time: 17 s\n",
      "train time: 19.3 s\n",
      "step: 942, Loss change ratio: 9.72e-05\n",
      "===========\n",
      "stopping at step  941\n",
      "train_reparametrization time: 3.21 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5414, Loss change ratio: 0.014688\n",
      "===========\n",
      "stopping at step  4471\n",
      "train_fine time: 11.8 s\n",
      "train time: 15 s\n",
      "step: 632, Loss change ratio: 9.84e-05\n",
      "===========\n",
      "stopping at step  631\n",
      "train_reparametrization time: 5.35 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6324, Loss change ratio: 0.009353\n",
      "===========\n",
      "stopping at step  5691\n",
      "train_fine time: 16.8 s\n",
      "train time: 22.2 s\n",
      "step: 572, Loss change ratio: 9.6e-051\n",
      "===========\n",
      "stopping at step  571\n",
      "train_reparametrization time: 4.64 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1494, Loss change ratio: 9.65e-06\n",
      "===========\n",
      "stopping at step  921\n",
      "train_fine time: 2.28 s\n",
      "train time: 6.93 s\n",
      "step: 622, Loss change ratio: 9.91e-05\n",
      "===========\n",
      "stopping at step  621\n",
      "train_reparametrization time: 2.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3194, Loss change ratio: 0.009615\n",
      "===========\n",
      "stopping at step  2571\n",
      "train_fine time: 7.02 s\n",
      "train time: 9.75 s\n",
      "step: 912, Loss change ratio: 9.81e-05\n",
      "===========\n",
      "stopping at step  911\n",
      "train_reparametrization time: 3.39 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5724, Loss change ratio: 0.011193\n",
      "===========\n",
      "stopping at step  4811\n",
      "train_fine time: 21.1 s\n",
      "train time: 24.4 s\n",
      "step: 482, Loss change ratio: 9.91e-05\n",
      "===========\n",
      "stopping at step  481\n",
      "train_reparametrization time: 6.41 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4204, Loss change ratio: 0.003016\n",
      "===========\n",
      "stopping at step  3721\n",
      "train_fine time: 13.5 s\n",
      "train time: 19.9 s\n",
      "step: 602, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  601\n",
      "train_reparametrization time: 6.59 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2014, Loss change ratio: 0.000646\n",
      "===========\n",
      "stopping at step  1411\n",
      "train_fine time: 5.34 s\n",
      "train time: 11.9 s\n",
      "step: 712, Loss change ratio: 9.59e-05\n",
      "===========\n",
      "stopping at step  711\n",
      "train_reparametrization time: 4.4 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4474, Loss change ratio: 0.012945\n",
      "===========\n",
      "stopping at step  3761\n",
      "train_fine time: 11.7 s\n",
      "train time: 16.1 s\n",
      "step: 6832, Loss change ratio: 6.53e-05\n",
      "===========\n",
      "stopping at step  6831\n",
      "train_reparametrization time: 22.1 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 11734, Loss change ratio: 0.01016\n",
      "===========\n",
      "stopping at step  4901\n",
      "train_fine time: 11.2 s\n",
      "train time: 33.3 s\n",
      "step: 562, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  561\n",
      "train_reparametrization time: 4.33 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6384, Loss change ratio: 0.013379\n",
      "===========\n",
      "stopping at step  5821\n",
      "train_fine time: 13 s\n",
      "train time: 17.3 s\n",
      "step: 532, Loss change ratio: 9.76e-05\n",
      "===========\n",
      "stopping at step  531\n",
      "train_reparametrization time: 3.79 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2224, Loss change ratio: 0.001151\n",
      "===========\n",
      "stopping at step  1691\n",
      "train_fine time: 3.74 s\n",
      "train time: 7.53 s\n",
      "step: 552, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  551\n",
      "train_reparametrization time: 1.83 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6514, Loss change ratio: 0.018597\n",
      "===========\n",
      "stopping at step  5961\n",
      "train_fine time: 13.9 s\n",
      "train time: 15.7 s\n",
      "step: 612, Loss change ratio: 9.92e-05\n",
      "===========\n",
      "stopping at step  611\n",
      "train_reparametrization time: 1.86 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5164, Loss change ratio: 0.016949\n",
      "===========\n",
      "stopping at step  4551\n",
      "train_fine time: 10.7 s\n",
      "train time: 12.6 s\n",
      "step: 532, Loss change ratio: 9.75e-05\n",
      "===========\n",
      "stopping at step  531\n",
      "train_reparametrization time: 4.23 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4374, Loss change ratio: 0.004992\n",
      "===========\n",
      "stopping at step  3841\n",
      "train_fine time: 9.16 s\n",
      "train time: 13.4 s\n",
      "step: 712, Loss change ratio: 9.66e-05\n",
      "===========\n",
      "stopping at step  711\n",
      "train_reparametrization time: 5.5 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2004, Loss change ratio: 5.57e-05\n",
      "===========\n",
      "stopping at step  1291\n",
      "train_fine time: 3.16 s\n",
      "train time: 8.66 s\n",
      "step: 582, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  581\n",
      "train_reparametrization time: 2.07 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5474, Loss change ratio: 0.013654\n",
      "===========\n",
      "stopping at step  4891\n",
      "train_fine time: 11.4 s\n",
      "train time: 13.5 s\n",
      "step: 982, Loss change ratio: 9.94e-05\n",
      "===========\n",
      "stopping at step  981\n",
      "train_reparametrization time: 3.03 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 5974, Loss change ratio: 0.012875\n",
      "===========\n",
      "stopping at step  4991\n",
      "train_fine time: 12 s\n",
      "train time: 15.1 s\n",
      "step: 392, Loss change ratio: 9.76e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 3.76 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1834, Loss change ratio: 0.000261\n",
      "===========\n",
      "stopping at step  1441\n",
      "train_fine time: 3.33 s\n",
      "train time: 7.09 s\n",
      "step: 432, Loss change ratio: 9.9e-055\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 3.78 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1514, Loss change ratio: 0.000315\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 2.48 s\n",
      "train time: 6.26 s\n",
      "step: 402, Loss change ratio: 9.9e-059\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 1.61 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1764, Loss change ratio: 0.000176\n",
      "===========\n",
      "stopping at step  1361\n",
      "train_fine time: 3.55 s\n",
      "train time: 5.16 s\n",
      "step: 452, Loss change ratio: 9.61e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 1.59 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1564, Loss change ratio: 4.81e-05\n",
      "===========\n",
      "stopping at step  1111\n",
      "train_fine time: 3.31 s\n",
      "train time: 4.9 s\n",
      "step: 342, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 3.67 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1624, Loss change ratio: 9e-05105\n",
      "===========\n",
      "stopping at step  1281\n",
      "train_fine time: 3.19 s\n",
      "train time: 6.86 s\n",
      "step: 412, Loss change ratio: 9.76e-05\n",
      "===========\n",
      "stopping at step  411\n",
      "train_reparametrization time: 3.76 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1644, Loss change ratio: 0.000439\n",
      "===========\n",
      "stopping at step  1231\n",
      "train_fine time: 2.89 s\n",
      "train time: 6.65 s\n",
      "step: 362, Loss change ratio: 9.82e-05\n",
      "===========\n",
      "stopping at step  361\n",
      "train_reparametrization time: 1.51 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2114, Loss change ratio: 0.000929\n",
      "===========\n",
      "stopping at step  1751\n",
      "train_fine time: 4.33 s\n",
      "train time: 5.85 s\n",
      "step: 332, Loss change ratio: 9.19e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 1.13 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1184, Loss change ratio: 8.1e-066\n",
      "===========\n",
      "stopping at step  851\n",
      "train_fine time: 2 s\n",
      "train time: 3.14 s\n",
      "step: 372, Loss change ratio: 9.5e-055\n",
      "===========\n",
      "stopping at step  371\n",
      "train_reparametrization time: 3.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2114, Loss change ratio: 0.000645\n",
      "===========\n",
      "stopping at step  1741\n",
      "train_fine time: 4.29 s\n",
      "train time: 8.02 s\n",
      "step: 412, Loss change ratio: 9.86e-05\n",
      "===========\n",
      "stopping at step  411\n",
      "train_reparametrization time: 3.74 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1334, Loss change ratio: 2.88e-05\n",
      "===========\n",
      "stopping at step  921\n",
      "train_fine time: 2.18 s\n",
      "train time: 5.92 s\n",
      "step: 472, Loss change ratio: 9.94e-05\n",
      "===========\n",
      "stopping at step  471\n",
      "train_reparametrization time: 1.9 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1954, Loss change ratio: 0.000387\n",
      "===========\n",
      "stopping at step  1481\n",
      "train_fine time: 3.47 s\n",
      "train time: 5.37 s\n",
      "step: 292, Loss change ratio: 9.52e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 1 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1354, Loss change ratio: 6.11e-05\n",
      "===========\n",
      "stopping at step  1061\n",
      "train_fine time: 2.55 s\n",
      "train time: 3.55 s\n",
      "step: 342, Loss change ratio: 9.53e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 3.38 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2534, Loss change ratio: 0.001527\n",
      "===========\n",
      "stopping at step  2191\n",
      "train_fine time: 5.58 s\n",
      "train time: 8.97 s\n",
      "step: 452, Loss change ratio: 9.83e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 4.5 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1204, Loss change ratio: 6.56e-06\n",
      "===========\n",
      "stopping at step  751\n",
      "train_fine time: 1.82 s\n",
      "train time: 6.32 s\n",
      "step: 462, Loss change ratio: 9.27e-05\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 1.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1884, Loss change ratio: 0.000357\n",
      "===========\n",
      "stopping at step  1421\n",
      "train_fine time: 3.43 s\n",
      "train time: 5.16 s\n",
      "step: 432, Loss change ratio: 9.38e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.49 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1314, Loss change ratio: 7e-06-06\n",
      "===========\n",
      "stopping at step  881\n",
      "train_fine time: 2.11 s\n",
      "train time: 3.6 s\n",
      "step: 332, Loss change ratio: 9.55e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 3.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2244, Loss change ratio: 0.002254\n",
      "===========\n",
      "stopping at step  1911\n",
      "train_fine time: 4.71 s\n",
      "train time: 7.86 s\n",
      "step: 432, Loss change ratio: 9.84e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 4.02 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1464, Loss change ratio: 0.000187\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.46 s\n",
      "train time: 6.49 s\n",
      "step: 412, Loss change ratio: 9.25e-05\n",
      "===========\n",
      "stopping at step  411\n",
      "train_reparametrization time: 1.7 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1634, Loss change ratio: 9.22e-05\n",
      "===========\n",
      "stopping at step  1221\n",
      "train_fine time: 2.93 s\n",
      "train time: 4.63 s\n",
      "step: 452, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 1.55 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1344, Loss change ratio: 6.72e-06\n",
      "===========\n",
      "stopping at step  891\n",
      "train_fine time: 2.12 s\n",
      "train time: 3.67 s\n",
      "step: 392, Loss change ratio: 9.37e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 3.71 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1444, Loss change ratio: 1.95e-05\n",
      "===========\n",
      "stopping at step  1051\n",
      "train_fine time: 2.53 s\n",
      "train time: 6.24 s\n",
      "step: 462, Loss change ratio: 9.46e-05\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 4.14 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1174, Loss change ratio: 9.5e-066\n",
      "===========\n",
      "stopping at step  711\n",
      "train_fine time: 1.69 s\n",
      "train time: 5.83 s\n",
      "step: 442, Loss change ratio: 9.89e-05\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 1.87 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2954, Loss change ratio: 0.006151\n",
      "===========\n",
      "stopping at step  2511\n",
      "train_fine time: 6.05 s\n",
      "train time: 7.92 s\n",
      "step: 452, Loss change ratio: 9.6e-057\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 1.5 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1474, Loss change ratio: 1.62e-05\n",
      "===========\n",
      "stopping at step  1021\n",
      "train_fine time: 2.33 s\n",
      "train time: 3.82 s\n",
      "step: 342, Loss change ratio: 8.99e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 3.07 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1234, Loss change ratio: 2.66e-06\n",
      "===========\n",
      "stopping at step  891\n",
      "train_fine time: 2.03 s\n",
      "train time: 5.1 s\n",
      "step: 432, Loss change ratio: 9.6e-051\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 3.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1694, Loss change ratio: 0.000411\n",
      "===========\n",
      "stopping at step  1261\n",
      "train_fine time: 2.86 s\n",
      "train time: 6.59 s\n",
      "step: 432, Loss change ratio: 9.57e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.81 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1754, Loss change ratio: 0.000173\n",
      "===========\n",
      "stopping at step  1321\n",
      "train_fine time: 3.14 s\n",
      "train time: 4.95 s\n",
      "step: 322, Loss change ratio: 9.52e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 1.05 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1384, Loss change ratio: 5.2e-055\n",
      "===========\n",
      "stopping at step  1061\n",
      "train_fine time: 2.4 s\n",
      "train time: 3.45 s\n",
      "step: 352, Loss change ratio: 9.73e-05\n",
      "===========\n",
      "stopping at step  351\n",
      "train_reparametrization time: 3.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1294, Loss change ratio: 1.06e-05\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.13 s\n",
      "train time: 5.28 s\n",
      "step: 462, Loss change ratio: 9.57e-05\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 4 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1454, Loss change ratio: 8.26e-05\n",
      "===========\n",
      "stopping at step  991\n",
      "train_fine time: 2.24 s\n",
      "train time: 6.24 s\n",
      "step: 352, Loss change ratio: 9.65e-05\n",
      "===========\n",
      "stopping at step  351\n",
      "train_reparametrization time: 1.35 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1854, Loss change ratio: 0.000316\n",
      "===========\n",
      "stopping at step  1501\n",
      "train_fine time: 3.4 s\n",
      "train time: 4.75 s\n",
      "step: 392, Loss change ratio: 9.86e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 1.28 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1314, Loss change ratio: 1.16e-05\n",
      "===========\n",
      "stopping at step  921\n",
      "train_fine time: 2.1 s\n",
      "train time: 3.38 s\n",
      "step: 342, Loss change ratio: 9.59e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 3.22 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1514, Loss change ratio: 8.62e-05\n",
      "===========\n",
      "stopping at step  1171\n",
      "train_fine time: 2.74 s\n",
      "train time: 5.96 s\n",
      "step: 432, Loss change ratio: 9.59e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 3.76 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1494, Loss change ratio: 0.000121\n",
      "===========\n",
      "stopping at step  1061\n",
      "train_fine time: 2.4 s\n",
      "train time: 6.16 s\n",
      "step: 442, Loss change ratio: 9.43e-05\n",
      "===========\n",
      "stopping at step  441\n",
      "train_reparametrization time: 1.65 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1914, Loss change ratio: 0.000321\n",
      "===========\n",
      "stopping at step  1471\n",
      "train_fine time: 3.34 s\n",
      "train time: 4.98 s\n",
      "step: 392, Loss change ratio: 9.29e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 1.3 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 4494, Loss change ratio: 0.013996\n",
      "===========\n",
      "stopping at step  4101\n",
      "train_fine time: 9.45 s\n",
      "train time: 10.8 s\n",
      "step: 362, Loss change ratio: 9.45e-05\n",
      "===========\n",
      "stopping at step  361\n",
      "train_reparametrization time: 3.41 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2834, Loss change ratio: 0.001743\n",
      "===========\n",
      "stopping at step  2471\n",
      "train_fine time: 5.67 s\n",
      "train time: 9.08 s\n",
      "step: 452, Loss change ratio: 9.83e-05\n",
      "===========\n",
      "stopping at step  451\n",
      "train_reparametrization time: 3.9 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1084, Loss change ratio: 2.42e-06\n",
      "===========\n",
      "stopping at step  631\n",
      "train_fine time: 1.43 s\n",
      "train time: 5.34 s\n",
      "step: 432, Loss change ratio: 9.68e-05\n",
      "===========\n",
      "stopping at step  431\n",
      "train_reparametrization time: 1.7 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2854, Loss change ratio: 0.007071\n",
      "===========\n",
      "stopping at step  2421\n",
      "train_fine time: 5.56 s\n",
      "train time: 7.26 s\n",
      "step: 492, Loss change ratio: 9.26e-05\n",
      "===========\n",
      "stopping at step  491\n",
      "train_reparametrization time: 1.61 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1524, Loss change ratio: 2.65e-05\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.35 s\n",
      "train time: 3.96 s\n",
      "step: 272, Loss change ratio: 9.35e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 2.65 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1104, Loss change ratio: 2.75e-06\n",
      "===========\n",
      "stopping at step  831\n",
      "train_fine time: 2.3 s\n",
      "train time: 4.95 s\n",
      "step: 402, Loss change ratio: 9.93e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 3.65 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 874, Loss change ratio: 5.01e-08\n",
      "===========\n",
      "stopping at step  471\n",
      "train_fine time: 1.07 s\n",
      "train time: 4.73 s\n",
      "step: 272, Loss change ratio: 9.92e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 1.54 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1184, Loss change ratio: 9.48e-06\n",
      "===========\n",
      "stopping at step  911\n",
      "train_fine time: 2.08 s\n",
      "train time: 3.63 s\n",
      "step: 332, Loss change ratio: 9.88e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 1.3 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1414, Loss change ratio: 6.59e-05\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 2.45 s\n",
      "train time: 3.76 s\n",
      "step: 262, Loss change ratio: 8.71e-05\n",
      "===========\n",
      "stopping at step  261\n",
      "train_reparametrization time: 2.52 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1214, Loss change ratio: 8.89e-06\n",
      "===========\n",
      "stopping at step  951\n",
      "train_fine time: 2.18 s\n",
      "train time: 4.7 s\n",
      "step: 382, Loss change ratio: 9.6e-054\n",
      "===========\n",
      "stopping at step  381\n",
      "train_reparametrization time: 3.36 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1174, Loss change ratio: 2.09e-05\n",
      "===========\n",
      "stopping at step  791\n",
      "train_fine time: 1.86 s\n",
      "train time: 5.22 s\n",
      "step: 282, Loss change ratio: 9.56e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 1.6 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1434, Loss change ratio: 7.35e-05\n",
      "===========\n",
      "stopping at step  1151\n",
      "train_fine time: 2.72 s\n",
      "train time: 4.33 s\n",
      "step: 302, Loss change ratio: 9.23e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 1.14 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1124, Loss change ratio: 4.81e-06\n",
      "===========\n",
      "stopping at step  821\n",
      "train_fine time: 1.96 s\n",
      "train time: 3.11 s\n",
      "step: 292, Loss change ratio: 9.22e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 3.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1474, Loss change ratio: 0.000187\n",
      "===========\n",
      "stopping at step  1181\n",
      "train_fine time: 2.79 s\n",
      "train time: 5.9 s\n",
      "step: 372, Loss change ratio: 9.31e-05\n",
      "===========\n",
      "stopping at step  371\n",
      "train_reparametrization time: 3.39 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1154, Loss change ratio: 2.14e-05\n",
      "===========\n",
      "stopping at step  781\n",
      "train_fine time: 1.87 s\n",
      "train time: 5.26 s\n",
      "step: 252, Loss change ratio: 9.91e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 1.45 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1414, Loss change ratio: 5.96e-05\n",
      "===========\n",
      "stopping at step  1161\n",
      "train_fine time: 2.74 s\n",
      "train time: 4.19 s\n",
      "step: 272, Loss change ratio: 9.69e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 1.1 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 984, Loss change ratio: 1.97e-08\n",
      "===========\n",
      "stopping at step  711\n",
      "train_fine time: 1.69 s\n",
      "train time: 2.8 s\n",
      "step: 312, Loss change ratio: 9.3e-053\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 3.13 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1514, Loss change ratio: 0.000268\n",
      "===========\n",
      "stopping at step  1201\n",
      "train_fine time: 2.85 s\n",
      "train time: 5.98 s\n",
      "step: 402, Loss change ratio: 9.33e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 3.47 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1294, Loss change ratio: 6.54e-05\n",
      "===========\n",
      "stopping at step  891\n",
      "train_fine time: 2.11 s\n",
      "train time: 5.59 s\n",
      "step: 242, Loss change ratio: 9.1e-054\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 1.41 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1324, Loss change ratio: 3.97e-05\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 2.53 s\n",
      "train time: 3.94 s\n",
      "step: 312, Loss change ratio: 8.96e-05\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 1.19 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1324, Loss change ratio: 2.97e-05\n",
      "===========\n",
      "stopping at step  1011\n",
      "train_fine time: 2.31 s\n",
      "train time: 3.5 s\n",
      "step: 272, Loss change ratio: 9.72e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 2.56 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1004, Loss change ratio: 1.83e-08\n",
      "===========\n",
      "stopping at step  731\n",
      "train_fine time: 1.68 s\n",
      "train time: 4.24 s\n",
      "step: 392, Loss change ratio: 9.58e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 3.34 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 854, Loss change ratio: 4.51e-08\n",
      "===========\n",
      "stopping at step  461\n",
      "train_fine time: 1.04 s\n",
      "train time: 4.39 s\n",
      "step: 242, Loss change ratio: 9.49e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 1.41 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1214, Loss change ratio: 1.4e-055\n",
      "===========\n",
      "stopping at step  971\n",
      "train_fine time: 2.23 s\n",
      "train time: 3.64 s\n",
      "step: 332, Loss change ratio: 9.74e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 1.19 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1444, Loss change ratio: 8.44e-05\n",
      "===========\n",
      "stopping at step  1111\n",
      "train_fine time: 2.53 s\n",
      "train time: 3.72 s\n",
      "step: 292, Loss change ratio: 9.29e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 2.87 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1054, Loss change ratio: 5.62e-07\n",
      "===========\n",
      "stopping at step  761\n",
      "train_fine time: 1.74 s\n",
      "train time: 4.61 s\n",
      "step: 382, Loss change ratio: 9.24e-05\n",
      "===========\n",
      "stopping at step  381\n",
      "train_reparametrization time: 3.26 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 844, Loss change ratio: 4.79e-08\n",
      "===========\n",
      "stopping at step  461\n",
      "train_fine time: 1.05 s\n",
      "train time: 4.31 s\n",
      "step: 232, Loss change ratio: 9.85e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 1.38 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1264, Loss change ratio: 2.09e-05\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.35 s\n",
      "train time: 3.73 s\n",
      "step: 302, Loss change ratio: 9.17e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 1.1 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1164, Loss change ratio: 9.27e-06\n",
      "===========\n",
      "stopping at step  861\n",
      "train_fine time: 1.97 s\n",
      "train time: 3.07 s\n",
      "step: 252, Loss change ratio: 9.94e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 2.61 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1144, Loss change ratio: 1.08e-05\n",
      "===========\n",
      "stopping at step  891\n",
      "train_fine time: 2.14 s\n",
      "train time: 4.75 s\n",
      "step: 402, Loss change ratio: 9.83e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 3.84 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1404, Loss change ratio: 0.000213\n",
      "===========\n",
      "stopping at step  1001\n",
      "train_fine time: 2.4 s\n",
      "train time: 6.25 s\n",
      "step: 302, Loss change ratio: 9.26e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 1.81 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1544, Loss change ratio: 0.000107\n",
      "===========\n",
      "stopping at step  1241\n",
      "train_fine time: 3.03 s\n",
      "train time: 4.84 s\n",
      "step: 342, Loss change ratio: 9e-05113\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 1.34 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1464, Loss change ratio: 7.18e-05\n",
      "===========\n",
      "stopping at step  1121\n",
      "train_fine time: 2.68 s\n",
      "train time: 4.02 s\n",
      "step: 282, Loss change ratio: 8.96e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 3.46 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1094, Loss change ratio: 3.03e-06\n",
      "===========\n",
      "stopping at step  811\n",
      "train_fine time: 2.07 s\n",
      "train time: 5.53 s\n",
      "step: 422, Loss change ratio: 9.59e-05\n",
      "===========\n",
      "stopping at step  421\n",
      "train_reparametrization time: 4.05 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1184, Loss change ratio: 2.61e-05\n",
      "===========\n",
      "stopping at step  761\n",
      "train_fine time: 1.87 s\n",
      "train time: 5.92 s\n",
      "step: 302, Loss change ratio: 9.23e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 1.83 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1244, Loss change ratio: 6.27e-06\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.27 s\n",
      "train time: 4.11 s\n",
      "step: 462, Loss change ratio: 9.88e-05\n",
      "===========\n",
      "stopping at step  461\n",
      "train_reparametrization time: 1.71 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1794, Loss change ratio: 0.000279\n",
      "===========\n",
      "stopping at step  1331\n",
      "train_fine time: 3.2 s\n",
      "train time: 4.91 s\n",
      "step: 272, Loss change ratio: 8.86e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 2.96 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 944, Loss change ratio: 7.88e-09\n",
      "===========\n",
      "stopping at step  671\n",
      "train_fine time: 1.63 s\n",
      "train time: 4.6 s\n",
      "step: 362, Loss change ratio: 9.73e-05\n",
      "===========\n",
      "stopping at step  361\n",
      "train_reparametrization time: 3.19 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1094, Loss change ratio: 1.21e-05\n",
      "===========\n",
      "stopping at step  731\n",
      "train_fine time: 1.74 s\n",
      "train time: 4.93 s\n",
      "step: 322, Loss change ratio: 9.09e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 1.87 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1454, Loss change ratio: 5.83e-05\n",
      "===========\n",
      "stopping at step  1131\n",
      "train_fine time: 2.76 s\n",
      "train time: 4.63 s\n",
      "step: 332, Loss change ratio: 8.93e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 1.45 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1384, Loss change ratio: 4.83e-05\n",
      "===========\n",
      "stopping at step  1051\n",
      "train_fine time: 2.59 s\n",
      "train time: 4.03 s\n",
      "step: 312, Loss change ratio: 9.21e-05\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 3.31 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1274, Loss change ratio: 1.55e-05\n",
      "===========\n",
      "stopping at step  961\n",
      "train_fine time: 2.29 s\n",
      "train time: 5.61 s\n",
      "step: 402, Loss change ratio: 9.78e-05\n",
      "===========\n",
      "stopping at step  401\n",
      "train_reparametrization time: 3.61 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1224, Loss change ratio: 4.09e-05\n",
      "===========\n",
      "stopping at step  821\n",
      "train_fine time: 1.97 s\n",
      "train time: 5.59 s\n",
      "step: 242, Loss change ratio: 9.02e-05\n",
      "===========\n",
      "stopping at step  241\n",
      "train_reparametrization time: 1.47 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1164, Loss change ratio: 8.05e-06\n",
      "===========\n",
      "stopping at step  921\n",
      "train_fine time: 2.23 s\n",
      "train time: 3.71 s\n",
      "step: 302, Loss change ratio: 9.34e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 1.22 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1244, Loss change ratio: 1.77e-05\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.26 s\n",
      "train time: 3.48 s\n",
      "step: 252, Loss change ratio: 9.03e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 4.54 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1234, Loss change ratio: 3.8e-055\n",
      "===========\n",
      "stopping at step  981\n",
      "train_fine time: 2.35 s\n",
      "train time: 6.9 s\n",
      "step: 352, Loss change ratio: 9.27e-05\n",
      "===========\n",
      "stopping at step  351\n",
      "train_reparametrization time: 5.27 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 954, Loss change ratio: 3.6e-088\n",
      "===========\n",
      "stopping at step  601\n",
      "train_fine time: 1.4 s\n",
      "train time: 6.67 s\n",
      "step: 192, Loss change ratio: 9.02e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 2.01 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1224, Loss change ratio: 2.02e-05\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.37 s\n",
      "train time: 4.39 s\n",
      "step: 282, Loss change ratio: 9.99e-05\n",
      "===========\n",
      "stopping at step  281\n",
      "train_reparametrization time: 2 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1504, Loss change ratio: 0.000156\n",
      "===========\n",
      "stopping at step  1221\n",
      "train_fine time: 2.82 s\n",
      "train time: 4.82 s\n",
      "step: 292, Loss change ratio: 8.97e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 5.42 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1234, Loss change ratio: 1.69e-05\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.26 s\n",
      "train time: 7.69 s\n",
      "step: 382, Loss change ratio: 9.5e-052\n",
      "===========\n",
      "stopping at step  381\n",
      "train_reparametrization time: 5.74 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1424, Loss change ratio: 0.000504\n",
      "===========\n",
      "stopping at step  1041\n",
      "train_fine time: 2.49 s\n",
      "train time: 8.24 s\n",
      "step: 192, Loss change ratio: 8.83e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 2.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1204, Loss change ratio: 1.34e-05\n",
      "===========\n",
      "stopping at step  1011\n",
      "train_fine time: 2.58 s\n",
      "train time: 4.7 s\n",
      "step: 302, Loss change ratio: 9.21e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 2.59 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1244, Loss change ratio: 6.02e-06\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.58 s\n",
      "train time: 5.17 s\n",
      "step: 252, Loss change ratio: 8.67e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 4.61 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1204, Loss change ratio: 1.85e-05\n",
      "===========\n",
      "stopping at step  951\n",
      "train_fine time: 2.43 s\n",
      "train time: 7.05 s\n",
      "step: 322, Loss change ratio: 9.47e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 4.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 914, Loss change ratio: 1.44e-08\n",
      "===========\n",
      "stopping at step  591\n",
      "train_fine time: 1.53 s\n",
      "train time: 6.27 s\n",
      "step: 182, Loss change ratio: 8.59e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 1.99 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1194, Loss change ratio: 2.12e-05\n",
      "===========\n",
      "stopping at step  1011\n",
      "train_fine time: 2.56 s\n",
      "train time: 4.56 s\n",
      "step: 252, Loss change ratio: 8.73e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 2.12 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1184, Loss change ratio: 9.67e-06\n",
      "===========\n",
      "stopping at step  931\n",
      "train_fine time: 2.44 s\n",
      "train time: 4.57 s\n",
      "step: 252, Loss change ratio: 9.23e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 4.37 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1274, Loss change ratio: 7.29e-05\n",
      "===========\n",
      "stopping at step  1021\n",
      "train_fine time: 2.42 s\n",
      "train time: 6.8 s\n",
      "step: 292, Loss change ratio: 9.77e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 3.97 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1054, Loss change ratio: 5.24e-06\n",
      "===========\n",
      "stopping at step  761\n",
      "train_fine time: 1.81 s\n",
      "train time: 5.79 s\n",
      "step: 172, Loss change ratio: 9.41e-05\n",
      "===========\n",
      "stopping at step  171\n",
      "train_reparametrization time: 1.83 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1164, Loss change ratio: 1.67e-05\n",
      "===========\n",
      "stopping at step  991\n",
      "train_fine time: 2.47 s\n",
      "train time: 4.3 s\n",
      "step: 292, Loss change ratio: 9.16e-05\n",
      "===========\n",
      "stopping at step  291\n",
      "train_reparametrization time: 2.08 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1324, Loss change ratio: 2.67e-05\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.47 s\n",
      "train time: 4.56 s\n",
      "step: 252, Loss change ratio: 8.68e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 4.7 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1004, Loss change ratio: 2.52e-08\n",
      "===========\n",
      "stopping at step  751\n",
      "train_fine time: 2.02 s\n",
      "train time: 6.73 s\n",
      "step: 332, Loss change ratio: 9.64e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 5.24 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1364, Loss change ratio: 0.000178\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.57 s\n",
      "train time: 7.82 s\n",
      "step: 182, Loss change ratio: 9.68e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 2.23 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1164, Loss change ratio: 7.22e-06\n",
      "===========\n",
      "stopping at step  981\n",
      "train_fine time: 2.62 s\n",
      "train time: 4.86 s\n",
      "step: 322, Loss change ratio: 9.63e-05\n",
      "===========\n",
      "stopping at step  321\n",
      "train_reparametrization time: 2.54 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1294, Loss change ratio: 9.8e-065\n",
      "===========\n",
      "stopping at step  971\n",
      "train_fine time: 2.53 s\n",
      "train time: 5.07 s\n",
      "step: 232, Loss change ratio: 9.31e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 4.26 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1174, Loss change ratio: 2.68e-05\n",
      "===========\n",
      "stopping at step  941\n",
      "train_fine time: 2.33 s\n",
      "train time: 6.6 s\n",
      "step: 352, Loss change ratio: 9.7e-054\n",
      "===========\n",
      "stopping at step  351\n",
      "train_reparametrization time: 5.66 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1304, Loss change ratio: 7.78e-05\n",
      "===========\n",
      "stopping at step  951\n",
      "train_fine time: 2.39 s\n",
      "train time: 8.05 s\n",
      "step: 202, Loss change ratio: 8.82e-05\n",
      "===========\n",
      "stopping at step  201\n",
      "train_reparametrization time: 2.57 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1514, Loss change ratio: 0.000168\n",
      "===========\n",
      "stopping at step  1311\n",
      "train_fine time: 3.3 s\n",
      "train time: 5.87 s\n",
      "step: 332, Loss change ratio: 9.24e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 2.6 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1434, Loss change ratio: 3.02e-05\n",
      "===========\n",
      "stopping at step  1101\n",
      "train_fine time: 2.85 s\n",
      "train time: 5.46 s\n",
      "step: 222, Loss change ratio: 8.55e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 4.3 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 944, Loss change ratio: 4.73e-09\n",
      "===========\n",
      "stopping at step  721\n",
      "train_fine time: 1.83 s\n",
      "train time: 6.14 s\n",
      "step: 312, Loss change ratio: 9.4e-052\n",
      "===========\n",
      "stopping at step  311\n",
      "train_reparametrization time: 4.62 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 884, Loss change ratio: 1.72e-08\n",
      "===========\n",
      "stopping at step  571\n",
      "train_fine time: 1.47 s\n",
      "train time: 6.09 s\n",
      "step: 182, Loss change ratio: 9.37e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 2.23 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1264, Loss change ratio: 3.55e-05\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 2.73 s\n",
      "train time: 4.97 s\n",
      "step: 262, Loss change ratio: 9.72e-05\n",
      "===========\n",
      "stopping at step  261\n",
      "train_reparametrization time: 1.94 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1154, Loss change ratio: 4.92e-06\n",
      "===========\n",
      "stopping at step  891\n",
      "train_fine time: 2.22 s\n",
      "train time: 4.16 s\n",
      "step: 232, Loss change ratio: 8.64e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 4.46 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 894, Loss change ratio: 4.3e-099\n",
      "===========\n",
      "stopping at step  661\n",
      "train_fine time: 1.68 s\n",
      "train time: 6.14 s\n",
      "step: 342, Loss change ratio: 9.52e-05\n",
      "===========\n",
      "stopping at step  341\n",
      "train_reparametrization time: 4.78 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1154, Loss change ratio: 1.35e-05\n",
      "===========\n",
      "stopping at step  811\n",
      "train_fine time: 2.05 s\n",
      "train time: 6.83 s\n",
      "step: 192, Loss change ratio: 9.66e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 2.27 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1154, Loss change ratio: 9.8e-066\n",
      "===========\n",
      "stopping at step  961\n",
      "train_fine time: 2.55 s\n",
      "train time: 4.82 s\n",
      "step: 262, Loss change ratio: 9.09e-05\n",
      "===========\n",
      "stopping at step  261\n",
      "train_reparametrization time: 2.02 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1184, Loss change ratio: 7.75e-06\n",
      "===========\n",
      "stopping at step  921\n",
      "train_fine time: 2.23 s\n",
      "train time: 4.26 s\n",
      "step: 252, Loss change ratio: 8.94e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 5.64 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1404, Loss change ratio: 0.000209\n",
      "===========\n",
      "stopping at step  1151\n",
      "train_fine time: 3 s\n",
      "train time: 8.65 s\n",
      "step: 332, Loss change ratio: 9.76e-05\n",
      "===========\n",
      "stopping at step  331\n",
      "train_reparametrization time: 5.34 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1334, Loss change ratio: 7.39e-05\n",
      "===========\n",
      "stopping at step  1001\n",
      "train_fine time: 2.47 s\n",
      "train time: 7.82 s\n",
      "step: 192, Loss change ratio: 9.43e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 2.25 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1384, Loss change ratio: 7.99e-05\n",
      "===========\n",
      "stopping at step  1191\n",
      "train_fine time: 3.13 s\n",
      "train time: 5.38 s\n",
      "step: 222, Loss change ratio: 9.68e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 1.59 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1074, Loss change ratio: 9.05e-06\n",
      "===========\n",
      "stopping at step  851\n",
      "train_fine time: 2.1 s\n",
      "train time: 3.69 s\n",
      "step: 232, Loss change ratio: 9.93e-05\n",
      "===========\n",
      "stopping at step  231\n",
      "train_reparametrization time: 4.35 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1254, Loss change ratio: 7.32e-05\n",
      "===========\n",
      "stopping at step  1021\n",
      "train_fine time: 2.58 s\n",
      "train time: 6.93 s\n",
      "step: 302, Loss change ratio: 9.39e-05\n",
      "===========\n",
      "stopping at step  301\n",
      "train_reparametrization time: 4.34 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 814, Loss change ratio: 1.54e-08\n",
      "===========\n",
      "stopping at step  511\n",
      "train_fine time: 1.28 s\n",
      "train time: 5.63 s\n",
      "step: 192, Loss change ratio: 8.51e-05\n",
      "===========\n",
      "stopping at step  191\n",
      "train_reparametrization time: 2.2 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1224, Loss change ratio: 1.69e-05\n",
      "===========\n",
      "stopping at step  1031\n",
      "train_fine time: 2.57 s\n",
      "train time: 4.77 s\n",
      "step: 272, Loss change ratio: 9.86e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 1.93 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1354, Loss change ratio: 2.78e-05\n",
      "===========\n",
      "stopping at step  1081\n",
      "train_fine time: 2.71 s\n",
      "train time: 4.65 s\n",
      "step: 272, Loss change ratio: 9.39e-05\n",
      "===========\n",
      "stopping at step  271\n",
      "train_reparametrization time: 10.5 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1614, Loss change ratio: 6.72e-05\n",
      "===========\n",
      "stopping at step  1341\n",
      "train_fine time: 3.37 s\n",
      "train time: 13.9 s\n",
      "step: 182, Loss change ratio: 9.38e-05\n",
      "===========\n",
      "stopping at step  181\n",
      "train_reparametrization time: 6.42 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1484, Loss change ratio: 0.000169\n",
      "===========\n",
      "stopping at step  1301\n",
      "train_fine time: 3.34 s\n",
      "train time: 9.77 s\n",
      "step: 142, Loss change ratio: 8.82e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 4.11 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1244, Loss change ratio: 2.01e-05\n",
      "===========\n",
      "stopping at step  1101\n",
      "train_fine time: 2.91 s\n",
      "train time: 7.03 s\n",
      "step: 392, Loss change ratio: 9.41e-05\n",
      "===========\n",
      "stopping at step  391\n",
      "train_reparametrization time: 8.97 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6934, Loss change ratio: 0.015752\n",
      "===========\n",
      "stopping at step  6541\n",
      "train_fine time: 16.6 s\n",
      "train time: 25.5 s\n",
      "step: 252, Loss change ratio: 9.57e-05\n",
      "===========\n",
      "stopping at step  251\n",
      "train_reparametrization time: 8.83 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1824, Loss change ratio: 0.000444\n",
      "===========\n",
      "stopping at step  1571\n",
      "train_fine time: 3.75 s\n",
      "train time: 12.6 s\n",
      "step: 222, Loss change ratio: 9.72e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 7.35 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1134, Loss change ratio: 4.3e-066\n",
      "===========\n",
      "stopping at step  911\n",
      "train_fine time: 2.58 s\n",
      "train time: 9.94 s\n",
      "step: 142, Loss change ratio: 7.17e-05\n",
      "===========\n",
      "stopping at step  141\n",
      "train_reparametrization time: 4.22 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2564, Loss change ratio: 0.004332\n",
      "===========\n",
      "stopping at step  2421\n",
      "train_fine time: 6.7 s\n",
      "train time: 10.9 s\n",
      "step: 632, Loss change ratio: 9.67e-05\n",
      "===========\n",
      "stopping at step  631\n",
      "train_reparametrization time: 15.7 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 6274, Loss change ratio: 0.014849\n",
      "===========\n",
      "stopping at step  5641\n",
      "train_fine time: 14.7 s\n",
      "train time: 30.4 s\n",
      "step: 222, Loss change ratio: 9.55e-05\n",
      "===========\n",
      "stopping at step  221\n",
      "train_reparametrization time: 7.99 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2924, Loss change ratio: 0.002295\n",
      "===========\n",
      "stopping at step  2701\n",
      "train_fine time: 6.39 s\n",
      "train time: 14.4 s\n",
      "step: 262, Loss change ratio: 9.38e-05\n",
      "===========\n",
      "stopping at step  261\n",
      "train_reparametrization time: 8.45 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 1704, Loss change ratio: 0.001616\n",
      "===========\n",
      "stopping at step  1441\n",
      "train_fine time: 3.69 s\n",
      "train time: 12.2 s\n",
      "step: 82, Loss change ratio: 0.00379\n",
      "Training interrupted\n",
      "train time: 2.59 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.159 s\n",
      "step: 102, Loss change ratio: 0.00213\n",
      "Training interrupted\n",
      "train time: 4.49 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.215 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.0931 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.16 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.166 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.123 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.147 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.153 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.164 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.13 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.157 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.152 s\n",
      "\n",
      "Training interrupted\n",
      "train time: 0.158 s\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-987-144b5d1c81fc>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     17\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     18\u001b[0m         \u001b[0mstart_time\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtime\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtime\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 19\u001b[0;31m         \u001b[0mnet\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mneuralHeat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA_sp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdeepfdl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.02\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     20\u001b[0m         \u001b[0mnet\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mgcn_steps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mMAX_GCN_STEPS\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfdl_steps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mMAX_FDL_STEPS\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mearly_stop_check_steps\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmin_steps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m50\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgcn_stop_threshold\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mGCN_STOP_THRESHOLD\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfdl_stop_threshold\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mFDL_STOP_THRESHOLD\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-973-9bd0a2f700f2>\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, feat_dims, A, deepfdl, fdl, propagation_rule, lr)\u001b[0m\n\u001b[1;32m      3\u001b[0m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mneuralHeat\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__init__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdeepfdl\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdeepfdl\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 5\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mA\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnormalize_A\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mA\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpropagation_rule\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      6\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m         \u001b[0mn\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mA\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-964-f8c4242dca81>\u001b[0m in \u001b[0;36mnormalize_A\u001b[0;34m(A, prop_rule)\u001b[0m\n\u001b[1;32m     18\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     19\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mprop_rule\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m'DAD'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 20\u001b[0;31m             \u001b[0mD_half\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msparse_coo_tensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0midentity_N\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mD\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mN\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mN\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     21\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msparse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msparse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mD_half\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mA_norm\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mD_half\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "e=10\n",
    "\n",
    "dimension = [8, 16, 32, 64, 128]\n",
    "\n",
    "two_layer = []\n",
    "\n",
    "\n",
    "for i in dimension:\n",
    "    for j in range(e):\n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i,i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "       \n",
    "        two_layer += [[ 'GCN Res', [i,i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i,i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        two_layer += [[ 'GCN', [i,i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i,i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        two_layer += [[ 'Deep Res', [i,i,i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i,i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        two_layer += [[ 'Deep', [i,i,i,1], time.time() - start_time, net.loss_history[-1] ]] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "e=10\n",
    "\n",
    "dimension = [8, 16, 32, 64, 128]\n",
    "\n",
    "three_layer = []\n",
    "\n",
    "\n",
    "for i in dimension:\n",
    "    for j in range(e):\n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i,i, i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "       \n",
    "        three_layer += [[ 'GCN Res', [i,i,i, i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i,i,i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        three_layer += [[ 'GCN', [i,i,i, i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat_Res([i,i,i,i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        three_layer += [[ 'Deep Res', [i,i,i, i,1], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "        start_time = time.time()\n",
    "        net = neuralHeat([i,i,i, i, 1], A_sp, deepfdl=True, lr = 0.02)\n",
    "        net.train(gcn_steps=MAX_GCN_STEPS, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "        \n",
    "        three_layer += [[ 'Deep', [i,i,i, i,1], time.time() - start_time, net.loss_history[-1] ]] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "FDL training 200000 steps\n",
      "step: 2872, Loss change ratio: 0.000831\n",
      "===========\n",
      "stopping at step  2871\n",
      "train_fine time: 4.99 s\n",
      "train time: 4.99 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2762, Loss change ratio: 0.000628\n",
      "===========\n",
      "stopping at step  2761\n",
      "train_fine time: 4.72 s\n",
      "train time: 4.72 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2762, Loss change ratio: 0.000636\n",
      "===========\n",
      "stopping at step  2761\n",
      "train_fine time: 4.53 s\n",
      "train time: 4.53 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2942, Loss change ratio: 0.001074\n",
      "===========\n",
      "stopping at step  2941\n",
      "train_fine time: 4.73 s\n",
      "train time: 4.73 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2942, Loss change ratio: 0.000881\n",
      "===========\n",
      "stopping at step  2941\n",
      "train_fine time: 4.75 s\n",
      "train time: 4.75 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3032, Loss change ratio: 0.001252\n",
      "===========\n",
      "stopping at step  3031\n",
      "train_fine time: 4.56 s\n",
      "train time: 4.56 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2782, Loss change ratio: 0.000528\n",
      "===========\n",
      "stopping at step  2781\n",
      "train_fine time: 4.15 s\n",
      "train time: 4.15 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2782, Loss change ratio: 0.000562\n",
      "===========\n",
      "stopping at step  2781\n",
      "train_fine time: 4.13 s\n",
      "train time: 4.13 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 2972, Loss change ratio: 0.000783\n",
      "===========\n",
      "stopping at step  2971\n",
      "train_fine time: 4.47 s\n",
      "train time: 4.47 s\n",
      "\n",
      "FDL training 200000 steps\n",
      "step: 3062, Loss change ratio: 0.001333\n",
      "===========\n",
      "stopping at step  3061\n",
      "train_fine time: 4.52 s\n",
      "train time: 4.52 s\n"
     ]
    }
   ],
   "source": [
    "e=10\n",
    "\n",
    "linear = []\n",
    "\n",
    "\n",
    "for j in range(e):\n",
    "        \n",
    "    start_time = time.time()\n",
    "    net = neuralHeat_Res([i,i,i, i, 1], A_sp, deepfdl=False, lr = 0.02)\n",
    "    net.train(gcn_steps=0, fdl_steps=MAX_FDL_STEPS, early_stop_check_steps = 10, min_steps=50, gcn_stop_threshold = GCN_STOP_THRESHOLD, fdl_stop_threshold = FDL_STOP_THRESHOLD,)\n",
    "       \n",
    "    linear += [[ 'Baseline', [], time.time() - start_time, net.loss_history[-1] ]] \n",
    "        \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [],
   "source": [
    "linear = array(linear)\n",
    "\n",
    "mean_time = mean(linear[:, 2])\n",
    "mean_energy = mean(linear[:, 3])\n",
    "\n",
    "std_time = std(linear[:, 2])\n",
    "std_energy = std(linear[:, 3])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {},
   "outputs": [],
   "source": [
    "dl = pd.DataFrame(linear, columns = ['model', 'latent', 'time', 'energy'])\n",
    "dl.to_csv('./result_11/linear_rand_50x50_01.csv', index = False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "onel = [ [i[0], str(i[1]), i[2],i[3] ] for i in one_layer]\n",
    "#twol = [ [i[0], str(i[1]), i[2],i[3] ] for i in two_layer]\n",
    "#threel = [ [i[0], str(i[1]), i[2],i[3] ] for i in three_layer]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [],
   "source": [
    "d1 = pd.DataFrame(onel, columns = ['model', 'latent', 'time', 'energy'])\n",
    "d1.time = mean_time / d1.time\n",
    "d1.energy =  d1.energy/mean_energy\n",
    "\n",
    "d1.to_csv('./result_11/one_layer_rand_50x50_01.csv', index = False)\n",
    "d2 = pd.DataFrame(twol, columns = ['model', 'latent', 'time', 'energy'])\n",
    "\n",
    "d2.time = mean_time / d2.time\n",
    "d2.energy =  d2.energy/mean_energy\n",
    "\n",
    "d2.to_csv('./result_11/two_layer_100x100_01.csv', index = False)\n",
    "d3 = pd.DataFrame(threel, columns = ['model', 'latent', 'time', 'energy'])\n",
    "\n",
    "d3.time = mean_time / d3.time\n",
    "d3.energy =  d3.energy/mean_energy\n",
    "\n",
    "d3.to_csv('./result_11/three_layer_100x100_01.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "latent\n",
       "[128, 128, 1]    0.999999\n",
       "[16, 16, 1]      0.999999\n",
       "[32, 32, 1]      0.999999\n",
       "[64, 64, 1]      0.999999\n",
       "[8, 8, 1]        1.000000\n",
       "Name: energy, dtype: float64"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d1[d1.model == 'GCN Res'].groupby('latent').mean()['energy']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 792x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure(figsize = (11, 7))\n",
    "model = ['GCN', 'GCN Res', 'Deep', 'Deep Res']\n",
    "name = {'GCN':'GCN', 'GCN Res': 'GCN Res', 'Deep': 'NoGraph', 'Deep Res':'NoGraph Res'}\n",
    "color = {'GCN': c1, 'GCN Res':c2, 'Deep':c3, 'Deep Res':c4}\n",
    "shape = {'GCN': 'o', 'GCN Res':'s', 'Deep':'v', 'Deep Res':'h'}\n",
    "size = array([120, 30, 60, 90])\n",
    "\n",
    "for i in model:\n",
    "    x = array(d1[d1.model == i].groupby('latent').mean()['time'])\n",
    "    y =array(d1[d1.model == i].groupby('latent').mean()['energy'])\n",
    "    xe = array(d1[d1.model == i].groupby('latent').std()['time'])\n",
    "    ye = array(d1[d1.model == i].groupby('latent').std()['energy'])\n",
    "    \n",
    "    \n",
    "    errorbar( x, y, xerr = xe,  yerr = ye ,color = color[i],marker = shape[i], fmt=\"o\")\n",
    "    scatter( x, y ,marker = shape[i], color = color[i], s = size*7,  label = name[i] , alpha = .7)\n",
    "    \n",
    "    \n",
    "plt.legend(loc=2, prop={\"size\":20} , ncol= 1);\n",
    "\n",
    "grid(zorder=0)   \n",
    "    \n",
    "plt.gca().ticklabel_format(axis='both', style='plain', useOffset=False)\n",
    "xscale('log')\n",
    "#yscale('log')\n",
    "\n",
    "#ylim(0.9992, 1.0007)\n",
    "#xlim(1, 20)\n",
    "\n",
    "xlabel('Speedup (time baseline/time neural)', fontname='sherif',size=20)\n",
    "ylabel('Loss neural/Loss baseline', fontname='sherif',size=20)\n",
    "\n",
    "plt.xticks(fontname='sherif',size=20)\n",
    "plt.yticks(fontname='sherif',size=20);\n",
    "\n",
    "#title('Heat equation on 2D lattice (50x50)', fontname='sherif',size=20);\n",
    "\n",
    "\n",
    "\n",
    "plt.tight_layout();\n",
    "\n",
    "plt.savefig('./result_11/1_onleyar_heat_random_50_01.svg');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 957,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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D00I9kL4jR+f36crLymlDjtNLeNqq3fehtVb29xXJEvDKtXuBg0axC9/+UtycnJ46qmnGiwzevRowEoI6tu2bRu7d+9mwIABtZ/WT548mSOPPJJdu3Yxb968qMe8bds2AC688MKDzq1atarJug2d3759O7t27aJ///6N9ji0FZvNxpNPPgnA7bffXqdH40c/+hEAq1evblHbRx55JFdffTWrVq0iKSnpoKFT6oDQ3alDeyEAXBUu7X1oxtCMo4m1xyKC9j4opQ47jT7sG2P6G2MGGGNy6r1v9qv9wleqZe69917S0tJ46KGHaofDhAouxfrggw+Sn59fe9zn83Hrrbfi9/u5+uqra4/b7Xb+8pe/4HA4+NWvfsW8efMa7InweDxUVVVFHG///v2BgxOa9evX84c//KHJuk8++SQ7d+6sfe/3+7nttttqV3DqCOPHj+ess85i8+bNvPzygVWfzz33XAYNGsQzzzzD22+/3WDdTz75pPZ7mJOTwzfffHNQmeLiYmpqahqcXK0swd2poW4vhN9vavd90N6HxokIWQnZZMdna++DUuqwo3Mg1GEpIyODu+++m9tvv73B8xMmTOD222/nkUceYcSIEcyYMYPExETeeecdNm7cyIknnshtt91Wp84pp5zCwoULufLKK/n5z3/O7NmzOemkk+jVqxcul4vc3Fzef/99CgsLOeaYYyL65P+KK67g0Ucf5eabb2bFihUMHjyYrVu38tZbb3HBBRewYMGCRutOnDiRUaNGcfHFF5Oamsq7777Lhg0bGDNmTKP33x5mz57NkiVLeOCBB/jpT39KTEwMTqeTN954g9NOO43p06czYcIERo0aRUJCArt27WLNmjVs376dvLw8EhIS2LBhA+effz5jxoxhxIgR9OrVi/z8fBYtWoTH46mdE6EadsEFF7BkyZI6cyFK95bg8/q09yEMcfY44uxxzRdUSqkuRocbqea1fvPh6LYTJTfddFPtJ/sN+eMf/8hrr73G4MGDefnll2t3fH7wwQd57733Glzl59xzz+X777/n4Ycfpm/fvixZsoRHH32U559/ng0bNjB9+nTefPNN1q9fH1EC0atXL1avXs306dP58MMPefrpp9m5cyfPPvssc+Y0vXHXE088wT333MPKlSt58sknyc/P59e//jXLly8/aBO59jR69GjOP/98du7cyV//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",
      "text/plain": [
       "<Figure size 792x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure(figsize = (11, 7))\n",
    "model = ['GCN', 'GCN Res', 'Deep', 'Deep Res']\n",
    "name = {'GCN':'GCN', 'GCN Res': 'GCN Res', 'Deep': 'NoGraph', 'Deep Res':'NoGraph Res'}\n",
    "color = {'GCN': c1, 'GCN Res':c2, 'Deep':c3, 'Deep Res':c4}\n",
    "shape = {'GCN': 'o', 'GCN Res':'s', 'Deep':'v', 'Deep Res':'h'}\n",
    "size = array([120, 30, 60, 90])\n",
    "\n",
    "for i in model:\n",
    "    x = array(d1[d1.model == i].groupby('latent').mean()['time'])\n",
    "    y =array(d1[d1.model == i].groupby('latent').mean()['energy'])\n",
    "    xe = array(d1[d1.model == i].groupby('latent').std()['time'])\n",
    "    ye = array(d1[d1.model == i].groupby('latent').std()['energy'])\n",
    "    \n",
    "    \n",
    "    errorbar( x, y, xerr = xe,  yerr = ye ,color = color[i],marker = shape[i], fmt=\"o\")\n",
    "    scatter( x, y ,marker = shape[i], color = color[i], s = size*7,  label = name[i] , alpha = .7)\n",
    "    \n",
    "    x = array(d2[d2.model == i].groupby('latent').mean()['time'])\n",
    "    y =array(d2[d2.model == i].groupby('latent').mean()['energy'])\n",
    "    xe = array(d2[d2.model == i].groupby('latent').std()['time'])\n",
    "    ye = array(d2[d2.model == i].groupby('latent').std()['energy'])\n",
    "    \n",
    "    \n",
    "    errorbar( x, y, xerr = xe,  yerr = ye ,color = color[i],marker = shape[i], fmt=\"o\")\n",
    "    scatter( x, y ,marker = shape[i], color = color[i],edgecolor='black',linewidths=2 , s = size*7,   alpha = .7)\n",
    "    \n",
    "    \n",
    "    x = array(d3[d3.model == i].groupby('latent').mean()['time'])\n",
    "    y =array(d3[d3.model == i].groupby('latent').mean()['energy'])\n",
    "    xe = array(d3[d3.model == i].groupby('latent').std()['time'])\n",
    "    ye = array(d3[d3.model == i].groupby('latent').std()['energy'])\n",
    "    \n",
    "    errorbar( x, y, xerr = xe,  yerr = ye ,color = color[i],marker = shape[i], fmt=\"o\")\n",
    "    scatter( x, y ,marker = shape[i], color = color[i],edgecolor='black',linewidths=4 , s = size*7 , alpha = .7)\n",
    "    \n",
    "    \n",
    "plt.legend(loc=2, prop={\"size\":20} , ncol= 1);\n",
    "\n",
    "grid(zorder=0)   \n",
    "    \n",
    "plt.gca().ticklabel_format(axis='both', style='plain', useOffset=False)\n",
    "xscale('log')\n",
    "#yscale('log')\n",
    "\n",
    "ylim(0.9992, 1.0007)\n",
    "#xlim(1, 20)\n",
    "\n",
    "xlabel('Speedup (time baseline/time neural)', fontname='sherif',size=20)\n",
    "ylabel('Loss neural/Loss baseline', fontname='sherif',size=20)\n",
    "\n",
    "plt.xticks(fontname='sherif',size=20)\n",
    "plt.yticks(fontname='sherif',size=20);\n",
    "\n",
    "#title('Heat equation on 2D lattice (50x50)', fontname='sherif',size=20);\n",
    "\n",
    "\n",
    "\n",
    "plt.tight_layout();\n",
    "\n",
    "#plt.savefig('./result_11/1_multilayer_heat_50_01.svg');"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
