{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T05:49:56.886747Z",
     "start_time": "2020-05-05T05:49:55.552862Z"
    }
   },
   "outputs": [],
   "source": [
    "# import modules\n",
    "from tqdm import tqdm_notebook\n",
    "import pickle as pkl\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "# deep learning modules\n",
    "import torch\n",
    "from torch.autograd import Variable\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "\n",
    "# Plot modules\n",
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T06:17:55.267254Z",
     "start_time": "2020-05-05T06:17:55.260453Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\n"
     ]
    }
   ],
   "source": [
    "# Use Gpu\n",
    "\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dim = 10\n",
    "xmin, xmax = 0,1\n",
    "\n",
    "try :\n",
    "    test_data = pd.read_pickle('poisson_{}_test'.format(dim))\n",
    "except :\n",
    "    test_data = np.random.uniform(0,1,[1000,dim])\n",
    "    with open('poisson_{}_test'.format(dim), 'wb') as f :\n",
    "        pkl.dump(test_data, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def analytic(data) :\n",
    "    return torch.sin((np.pi/2) * data).sum(dim=1).view(-1,1)\n",
    "\n",
    "def boundary_condition(data) : #data : N X dim\n",
    "    return torch.sin((np.pi/2) * data).sum(dim=1).view(-1,1)\n",
    "\n",
    "def sample(N):\n",
    "    return torch.rand([N,dim])\n",
    "\n",
    "def sample_boundary(N):\n",
    "    N = int(N/2)\n",
    "    interior = torch.rand([N,dim])\n",
    "    ind = int(N/dim)\n",
    "    for i in range(dim) :\n",
    "        interior[i*ind:(i+1)*ind, i] = 0\n",
    "    interior[(ind)*dim:, -1] = 0\n",
    "    \n",
    "    interior2 = torch.rand([N,dim])\n",
    "    ind = int(N/dim)\n",
    "    for i in range(dim) :\n",
    "        interior2[i*ind:(i+1)*ind, i] = 1\n",
    "    interior2[ind*dim:, -1] = 1\n",
    "    \n",
    "    return torch.cat([interior, interior2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "answer_x = torch.FloatTensor(test_data).to(device)\n",
    "answer_y = analytic(answer_x)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Neural Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T06:17:58.245996Z",
     "start_time": "2020-05-05T06:17:58.241527Z"
    }
   },
   "outputs": [],
   "source": [
    "# Neural network, Weight Sharing\n",
    "\n",
    "class u_Net(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(u_Net, self).__init__()\n",
    "        self.fc1 = nn.Linear(dim, 256)\n",
    "        self.fc2 = nn.Linear(256, 256)    \n",
    "        self.fc3 = nn.Linear(256, 256)   \n",
    "        self.fc6 = nn.Linear(256, 1)\n",
    "        self.act1 = nn.Tanh()\n",
    "        \n",
    "    def forward(self, x):\n",
    "        x = self.act1(self.fc1(x))\n",
    "        x = self.act1(self.fc2(x))\n",
    "        x = self.act1(self.fc3(x))\n",
    "        x = self.fc6(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T06:17:58.248577Z",
     "start_time": "2020-05-05T06:17:58.246944Z"
    }
   },
   "outputs": [],
   "source": [
    "# Hyperparameters\n",
    "EPOCH = 1000000\n",
    "BATCH_SIZE = 500"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_derivative(y, x) :\n",
    "    return torch.autograd.grad(y, x, create_graph=True,\\\n",
    "                        grad_outputs=torch.ones(y.size()).to(device))[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T06:17:58.262409Z",
     "start_time": "2020-05-05T06:17:58.256729Z"
    }
   },
   "outputs": [],
   "source": [
    "# Training function\n",
    "\n",
    "def train(uv_model, trainloader, optimizer, loss_f) :\n",
    "    uv_model.train()\n",
    "    loss_list, loss_list1, loss_list2, err_list = [], [], [], []\n",
    "    \n",
    "    for i, (X_v, X_bdry, u_bdry) in enumerate(trainloader) :\n",
    "        optimizer.zero_grad()\n",
    "        X_v = Variable(X_v, requires_grad=True).to(device)\n",
    "        X_bdry, u_bdry = X_bdry.to(device), u_bdry.to(device)\n",
    "        \n",
    "        output = uv_model(X_v)  \n",
    "        output_bdry = uv_model(X_bdry)\n",
    "        \n",
    "        del_u = calculate_derivative(output, X_v)\n",
    "        u_xx = sum(calculate_derivative(del_u[:,j], X_v)[:,j] for j in range(dim)).view(-1,1)\n",
    "        \n",
    "        loss1 = loss_f(u_xx + ((np.pi**2)/4)*torch.sin((np.pi/2)*X_v).sum(dim=1).view(-1,1), torch.zeros_like(u_xx))#((u_t-u_xx)**2).mean()#\n",
    "        loss2 = loss_f(output_bdry, u_bdry)\n",
    "        \n",
    "        loss = loss1 + loss2\n",
    "        \n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        \n",
    "        #err = (torch.abs(answer_y - output_answer)/answer_y).mean().item()\n",
    "        loss_list.append((loss).item())\n",
    "        loss_list1.append(loss1.item())\n",
    "        loss_list2.append(loss2.item())\n",
    "        #err_list.append(err)\n",
    "    return np.mean(loss_list), np.mean(loss_list1), np.mean(loss_list2)#, np.mean(err_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T08:22:34.873952Z",
     "start_time": "2020-05-05T08:22:34.849481Z"
    }
   },
   "outputs": [],
   "source": [
    "u_model =  u_Net()      \n",
    "total_loss = []\n",
    "loss1s, loss2s, errs = [], [], []\n",
    "u_model = u_model.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_results(output_answer) :\n",
    "    fig = plt.figure(figsize=[8,4])\n",
    "    plt.plot(answer_x[:,1].cpu().detach().numpy(), answer_y.cpu().detach().numpy(), 'ro', label='True')\n",
    "    plt.plot(answer_x[:,1].cpu().detach().numpy(), output_answer.cpu().detach().numpy(), 'bo', label='Pred')\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-05-05T08:22:57.203176Z",
     "start_time": "2020-05-05T08:22:35.054371Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c1e1fd14bdc949dd93b20e1823e24201",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100/10000 | loss: 2.049484 | loss1: 1.766835 | loss2: 0.282649| rel error : 0.070097 \n",
      "200/10000 | loss: 0.833125 | loss1: 0.740109 | loss2: 0.093016| rel error : 0.035183 \n",
      "300/10000 | loss: 0.477120 | loss1: 0.453819 | loss2: 0.023301| rel error : 0.014536 \n",
      "400/10000 | loss: 0.164688 | loss1: 0.147444 | loss2: 0.017244| rel error : 0.013481 \n",
      "500/10000 | loss: 0.043365 | loss1: 0.034623 | loss2: 0.008742| rel error : 0.009910 \n",
      "600/10000 | loss: 0.028456 | loss1: 0.021593 | loss2: 0.006863| rel error : 0.009187 \n",
      "700/10000 | loss: 0.021457 | loss1: 0.014859 | loss2: 0.006598| rel error : 0.008222 \n",
      "800/10000 | loss: 0.016496 | loss1: 0.011027 | loss2: 0.005469| rel error : 0.007558 \n",
      "900/10000 | loss: 0.013188 | loss1: 0.008995 | loss2: 0.004193| rel error : 0.006954 \n",
      "1000/10000 | loss: 0.011455 | loss1: 0.008043 | loss2: 0.003412| rel error : 0.006613 \n",
      "1100/10000 | loss: 0.009648 | loss1: 0.006425 | loss2: 0.003223| rel error : 0.005875 \n",
      "1200/10000 | loss: 0.008117 | loss1: 0.005758 | loss2: 0.002359| rel error : 0.005623 \n",
      "1300/10000 | loss: 0.009082 | loss1: 0.006595 | loss2: 0.002487| rel error : 0.005260 \n",
      "1400/10000 | loss: 0.009424 | loss1: 0.007305 | loss2: 0.002119| rel error : 0.004907 \n",
      "1500/10000 | loss: 0.007281 | loss1: 0.005182 | loss2: 0.002099| rel error : 0.004827 \n",
      "1600/10000 | loss: 0.011298 | loss1: 0.009131 | loss2: 0.002167| rel error : 0.005439 \n",
      "1700/10000 | loss: 0.006562 | loss1: 0.004371 | loss2: 0.002191| rel error : 0.004915 \n",
      "1800/10000 | loss: 0.007255 | loss1: 0.005207 | loss2: 0.002048| rel error : 0.004753 \n",
      "1900/10000 | loss: 0.006715 | loss1: 0.004943 | loss2: 0.001772| rel error : 0.004386 \n",
      "2000/10000 | loss: 0.006336 | loss1: 0.004338 | loss2: 0.001998| rel error : 0.004282 \n",
      "2100/10000 | loss: 0.007297 | loss1: 0.005681 | loss2: 0.001616| rel error : 0.004993 \n",
      "2200/10000 | loss: 0.010924 | loss1: 0.009195 | loss2: 0.001729| rel error : 0.004866 \n",
      "2300/10000 | loss: 0.007275 | loss1: 0.005756 | loss2: 0.001519| rel error : 0.005171 \n",
      "2400/10000 | loss: 0.004139 | loss1: 0.002424 | loss2: 0.001716| rel error : 0.004890 \n",
      "2500/10000 | loss: 0.004524 | loss1: 0.003150 | loss2: 0.001374| rel error : 0.004186 \n",
      "2600/10000 | loss: 0.004497 | loss1: 0.003098 | loss2: 0.001399| rel error : 0.004317 \n",
      "2700/10000 | loss: 0.003902 | loss1: 0.002497 | loss2: 0.001405| rel error : 0.004053 \n",
      "2800/10000 | loss: 0.003353 | loss1: 0.001739 | loss2: 0.001614| rel error : 0.004443 \n",
      "2900/10000 | loss: 0.003196 | loss1: 0.001746 | loss2: 0.001450| rel error : 0.004070 \n",
      "3000/10000 | loss: 0.004690 | loss1: 0.003308 | loss2: 0.001381| rel error : 0.003902 \n",
      "3100/10000 | loss: 0.010852 | loss1: 0.009351 | loss2: 0.001501| rel error : 0.003950 \n",
      "3200/10000 | loss: 0.008207 | loss1: 0.006741 | loss2: 0.001465| rel error : 0.003908 \n",
      "3300/10000 | loss: 0.003375 | loss1: 0.002079 | loss2: 0.001296| rel error : 0.004232 \n",
      "3400/10000 | loss: 0.006990 | loss1: 0.005252 | loss2: 0.001738| rel error : 0.003831 \n",
      "3500/10000 | loss: 0.033037 | loss1: 0.031577 | loss2: 0.001460| rel error : 0.005781 \n",
      "3600/10000 | loss: 0.004307 | loss1: 0.003113 | loss2: 0.001193| rel error : 0.003995 \n",
      "3700/10000 | loss: 0.005335 | loss1: 0.003851 | loss2: 0.001484| rel error : 0.003728 \n",
      "3800/10000 | loss: 0.004828 | loss1: 0.003457 | loss2: 0.001371| rel error : 0.003829 \n",
      "3900/10000 | loss: 0.004543 | loss1: 0.002760 | loss2: 0.001783| rel error : 0.003624 \n",
      "4000/10000 | loss: 0.002576 | loss1: 0.001241 | loss2: 0.001335| rel error : 0.004637 \n",
      "4100/10000 | loss: 0.004094 | loss1: 0.003064 | loss2: 0.001030| rel error : 0.003749 \n",
      "4200/10000 | loss: 0.009212 | loss1: 0.007760 | loss2: 0.001451| rel error : 0.004584 \n",
      "4300/10000 | loss: 0.003398 | loss1: 0.002192 | loss2: 0.001205| rel error : 0.004266 \n",
      "4400/10000 | loss: 0.014029 | loss1: 0.012908 | loss2: 0.001121| rel error : 0.003796 \n",
      "4500/10000 | loss: 0.004431 | loss1: 0.001808 | loss2: 0.002623| rel error : 0.005364 \n",
      "4600/10000 | loss: 0.003153 | loss1: 0.001442 | loss2: 0.001711| rel error : 0.005557 \n",
      "4700/10000 | loss: 0.005756 | loss1: 0.004678 | loss2: 0.001078| rel error : 0.003448 \n",
      "4800/10000 | loss: 0.002157 | loss1: 0.001167 | loss2: 0.000989| rel error : 0.004155 \n",
      "4900/10000 | loss: 0.002684 | loss1: 0.000952 | loss2: 0.001732| rel error : 0.003579 \n",
      "5000/10000 | loss: 0.005864 | loss1: 0.004780 | loss2: 0.001084| rel error : 0.003591 \n",
      "5100/10000 | loss: 0.055947 | loss1: 0.045287 | loss2: 0.010660| rel error : 0.019678 \n",
      "5200/10000 | loss: 0.005084 | loss1: 0.003929 | loss2: 0.001156| rel error : 0.003860 \n",
      "5300/10000 | loss: 0.003965 | loss1: 0.001792 | loss2: 0.002173| rel error : 0.003790 \n",
      "5400/10000 | loss: 0.005427 | loss1: 0.003943 | loss2: 0.001484| rel error : 0.003801 \n",
      "5500/10000 | loss: 0.005363 | loss1: 0.003501 | loss2: 0.001863| rel error : 0.004628 \n",
      "5600/10000 | loss: 0.037237 | loss1: 0.034403 | loss2: 0.002834| rel error : 0.009591 \n",
      "5700/10000 | loss: 0.004307 | loss1: 0.002675 | loss2: 0.001632| rel error : 0.008890 \n",
      "5800/10000 | loss: 0.002193 | loss1: 0.000906 | loss2: 0.001287| rel error : 0.006393 \n",
      "5900/10000 | loss: 0.002026 | loss1: 0.000950 | loss2: 0.001076| rel error : 0.003444 \n",
      "6000/10000 | loss: 0.003893 | loss1: 0.002534 | loss2: 0.001359| rel error : 0.003428 \n",
      "6100/10000 | loss: 0.013031 | loss1: 0.011226 | loss2: 0.001805| rel error : 0.004172 \n",
      "6200/10000 | loss: 0.007107 | loss1: 0.006180 | loss2: 0.000926| rel error : 0.003313 \n",
      "6300/10000 | loss: 0.005196 | loss1: 0.003298 | loss2: 0.001899| rel error : 0.005391 \n",
      "6400/10000 | loss: 0.004166 | loss1: 0.003173 | loss2: 0.000993| rel error : 0.003778 \n",
      "6500/10000 | loss: 0.046947 | loss1: 0.045886 | loss2: 0.001061| rel error : 0.004449 \n",
      "6600/10000 | loss: 0.013899 | loss1: 0.010995 | loss2: 0.002904| rel error : 0.009102 \n",
      "6700/10000 | loss: 0.002086 | loss1: 0.001072 | loss2: 0.001014| rel error : 0.003200 \n",
      "6800/10000 | loss: 0.008669 | loss1: 0.006816 | loss2: 0.001853| rel error : 0.003952 \n",
      "6900/10000 | loss: 0.002458 | loss1: 0.001503 | loss2: 0.000955| rel error : 0.003208 \n",
      "7000/10000 | loss: 0.001653 | loss1: 0.000801 | loss2: 0.000852| rel error : 0.003114 \n",
      "7100/10000 | loss: 0.002849 | loss1: 0.001668 | loss2: 0.001180| rel error : 0.004589 \n",
      "7200/10000 | loss: 0.002011 | loss1: 0.000950 | loss2: 0.001061| rel error : 0.003533 \n",
      "7300/10000 | loss: 0.023135 | loss1: 0.011453 | loss2: 0.011681| rel error : 0.019961 \n",
      "7400/10000 | loss: 0.005276 | loss1: 0.004362 | loss2: 0.000914| rel error : 0.003218 \n",
      "7500/10000 | loss: 0.002307 | loss1: 0.001031 | loss2: 0.001276| rel error : 0.005823 \n",
      "7600/10000 | loss: 0.002884 | loss1: 0.001899 | loss2: 0.000984| rel error : 0.003779 \n",
      "7700/10000 | loss: 0.006701 | loss1: 0.005452 | loss2: 0.001249| rel error : 0.003884 \n",
      "7800/10000 | loss: 0.005089 | loss1: 0.003993 | loss2: 0.001096| rel error : 0.003023 \n",
      "7900/10000 | loss: 0.006041 | loss1: 0.002104 | loss2: 0.003937| rel error : 0.012200 \n",
      "8000/10000 | loss: 0.010669 | loss1: 0.004607 | loss2: 0.006062| rel error : 0.005176 \n",
      "8100/10000 | loss: 0.012312 | loss1: 0.011526 | loss2: 0.000786| rel error : 0.003675 \n",
      "8200/10000 | loss: 0.002223 | loss1: 0.001390 | loss2: 0.000834| rel error : 0.003155 \n",
      "8300/10000 | loss: 0.005140 | loss1: 0.001875 | loss2: 0.003265| rel error : 0.009145 \n",
      "8400/10000 | loss: 0.043645 | loss1: 0.039196 | loss2: 0.004449| rel error : 0.004499 \n",
      "8500/10000 | loss: 0.003479 | loss1: 0.002375 | loss2: 0.001104| rel error : 0.003056 \n",
      "8600/10000 | loss: 0.001323 | loss1: 0.000545 | loss2: 0.000778| rel error : 0.002995 \n",
      "8700/10000 | loss: 0.002610 | loss1: 0.001031 | loss2: 0.001579| rel error : 0.003663 \n",
      "8800/10000 | loss: 0.006189 | loss1: 0.004918 | loss2: 0.001271| rel error : 0.006942 \n",
      "8900/10000 | loss: 0.002539 | loss1: 0.001530 | loss2: 0.001010| rel error : 0.007088 \n",
      "9000/10000 | loss: 0.001347 | loss1: 0.000543 | loss2: 0.000804| rel error : 0.002890 \n",
      "9100/10000 | loss: 0.001633 | loss1: 0.000536 | loss2: 0.001096| rel error : 0.003369 \n",
      "9200/10000 | loss: 0.016990 | loss1: 0.015726 | loss2: 0.001265| rel error : 0.004890 \n",
      "9300/10000 | loss: 0.002083 | loss1: 0.001100 | loss2: 0.000983| rel error : 0.002722 \n",
      "9400/10000 | loss: 0.004412 | loss1: 0.003385 | loss2: 0.001027| rel error : 0.003857 \n",
      "9500/10000 | loss: 0.005985 | loss1: 0.003732 | loss2: 0.002253| rel error : 0.008562 \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9600/10000 | loss: 0.003634 | loss1: 0.002755 | loss2: 0.000879| rel error : 0.003243 \n",
      "9700/10000 | loss: 0.006829 | loss1: 0.004290 | loss2: 0.002539| rel error : 0.004974 \n",
      "9800/10000 | loss: 0.001753 | loss1: 0.001029 | loss2: 0.000724| rel error : 0.002803 \n",
      "9900/10000 | loss: 0.018988 | loss1: 0.014203 | loss2: 0.004785| rel error : 0.009106 \n",
      "10000/10000 | loss: 0.003251 | loss1: 0.001621 | loss2: 0.001630| rel error : 0.005102 \n"
     ]
    }
   ],
   "source": [
    "optimizer=torch.optim.Adam([{'params': u_model.parameters()}], lr=1e-3)\n",
    "\n",
    "EPOCH=10000\n",
    "for t in tqdm_notebook(range(1, EPOCH+1)) :\n",
    "    # Make dataloader\n",
    "    data = sample(BATCH_SIZE)\n",
    "    data_bdry = sample_boundary(BATCH_SIZE)\n",
    "    u_bdry = boundary_condition(data_bdry)\n",
    "    data_train = TensorDataset(data, data_bdry, u_bdry)\n",
    "    train_loader = DataLoader(data_train, batch_size=BATCH_SIZE, shuffle=False)\n",
    "    \n",
    "    loss, loss1, loss2 = train(u_model, trainloader=train_loader, \\\n",
    "                              optimizer=optimizer, loss_f=nn.MSELoss())\n",
    "    \n",
    "    output_answer = u_model(answer_x)\n",
    "    err = (torch.abs(answer_y - output_answer)/answer_y).mean().item()\n",
    "    # Print Log\n",
    "    if t%100 == 0 :\n",
    "        print(\"%s/%s | loss: %06.6f | loss1: %06.6f | loss2: %06.6f| rel error : %06.6f \" % \\\n",
    "              (t, EPOCH, loss, loss1, loss2, err))\n",
    "        \n",
    "    total_loss.append(loss)\n",
    "    loss1s.append(loss1)\n",
    "    loss2s.append(loss2)\n",
    "    errs.append(err)\n",
    "    # Save Model\n",
    "    if t % 1000 == 0:\n",
    "        torch.save([u_model, total_loss, loss1s, loss2s, errs],\n",
    "                   '../../models/{}_Poisson_L2_L2_{}.pt'.format(dim, xmax))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Average"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a0a33d53db784cb4aa4371048afc29bd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "188d67b7a3f04529b8b11f2b447564a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "899a1b0ca9b34cc5a509fcf1e2d665de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3ba2cf10d3d84f9485402b6a9de1893c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e29e7b595c3441fda891e594d41a2234",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "72bc3c6d93fa4227a411451cf44ff56b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7ad01a9754f04013a7d9a919b294b071",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f3af72e54f0427193e604d3f2d61380",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "98539e4fe27544d98e5b20c5f05a73ce",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ca4d8394bc24621922ee982533857f2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "de27e9589e1443639a4696a18443249a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "195bf40b00d34c2f8a5235922d3102d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "63e928b5ad574b6b984936907fedca98",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "792477caeec64f788bed4017765b2b36",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "77a58df935d0433faddc77105195f930",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e0a804d0638946f0bf5e7f29d607b5be",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "62b3d6fd786d44329378d2fdbd97c14f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3b1f3a5e4d22423d827adaac6119e43a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f1006909f1de4f94819e07c560b6255d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d3f62e18ec454b90ad0ac49b331c9919",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bf1286f060014750832477279582fb1e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ed2f354052ce4952bc320f1ca40bb198",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ea303876f6f94ee3a048ff967ff6cd94",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8f954bee2f77456a954aad922b74776c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8813d6fb33c04c42b0726aa58db6c812",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9b05d03377fd403091d1f19094744ccc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0d2d9269bf7840a8aeb34bb9ac429ed4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ac6972d08e6f498988e23c50ead9fe9b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fabd76b0b99144bfadeee409322034a3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "04e611bcce6a42bb949c3dcf23e8347c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c9570a5a44a040479639400ab0b21553",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4e94730a1188485f8b52dacb59ae2c90",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7712e20751ec400b9621f7145c8a6275",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "03e3ed56ac5e43a9b46a98a7fe179a5c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9041cf0f4d2c4650bf274a8c1187a15a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f73b6036de3477988ce67048b2c26df",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d685856f49d2428db5c7c1eff4d0f220",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd66d9cef4694c639020885b8fe2afb3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8e5977c0b23d4e99aaadd88e6d075561",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "97917bd7194e4a768308eb27d12cb094",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b46cd1efc90b4e36961a38c760e5eabd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c20bec267f7d4d9c94ab279f40bb4fa2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "51ee52e7ac79484a88060be30a3bdc53",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "70ec5b46b27b4d65a6ea940520964b1f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "01f4051d79fe4420a80a4c63f586e671",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "02a8f15af01e48dd90433d3ba93f5b7d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "96e307058d514156a4d56588af22dd3a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8eb6f6b0bebc4dc196087ce4790c1eff",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b3267ccae88349a2a1d5f1d24da064de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f49339e7a0f94d95ac13de3093401205",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b4b4dd1068b04be8be2805aaf2f64f4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4d91b9d92796432d8b0c9ee4b906d553",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05a20229455f422c8cba3d92c5953aa7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "63a652975a9d4be2b6570289342c4a74",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a8f0eed2b1af4a00bd1e5895e0fc87a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d8231acca63b46daa4ca5de2845abf35",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f6450e8a55f146808f86d6202c125a54",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4185a6cfa644490aaf857f4faab617ad",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f998a29ad0ff452b8194e93de49e7eb0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a6a7c162853b4d938f11fe9bc6e25ebf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4b52a041f50445aaac0ebfe957899adb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "32b91a1b4f6f43e88194994410b010ee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e04cf9f5cb204b1bb3cfee96d01479b8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "915a9247a9bc48ffb1af7ea0430cecd4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8fd6fe1003774e7796f0ec04a00b7365",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7bbea5f6b490470db920d42a5d6e4d64",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dc80b5507c334319b79e9c996c5a9ae3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e36214c3f4ae49dcb092c1d09559e7a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f6f68be668b240dea45e55dfb4dbe96e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e1e0b52dd1b843469c1cfbdf0a30dc35",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4854e13dc0984978af81415e2e326fd0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "25c666249ebf49e888a1ed6583ab7e89",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d4836b13b7804a5098f588e305094677",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8abd0d0c6ae84f798afddeaf3a9a9050",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c494513d11254995984eab086051cb0b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae956faeed1745ac963a7e3d70350c4e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a272246219674cfa8f7407b9b979ac2c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "60201ea1eba54fc2b61f90448b30c906",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0bbc4d49517e4174b102000701444592",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3b4be82b64be45d2adbbebf9fc56613f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "98a2ad936cf446488f37c6eec7ff32d9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f2a7edbbb95548edabb3d2ab9f78d295",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcd83ec5cfff4256a013e3f1389bc747",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f4c4ccf8900944e6a32c626b34d3297e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ac7c273a9e3c4906b30f98fd336344d3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7930ed5f60a466b891ce57d289d24d3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5204971123404b1f8ab01d6febcfbc19",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "90487536170f4d29996a801745460cbf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "940e80f38547417cb8b6fff033f6f887",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae6e52ce46544f96b686115b8cda89dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d8e33e14fa5e434cacf09adb6c3233df",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1c81035b426449e0a00e8c9ee78f4f1a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ea04996ebd444e98953f62b90c50ec4d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9c1dea003eb54a85af62de48e6fabc28",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d03da569eb394ce0bae6396eceb97dd6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f7920963c7b046c788358c36972fb780",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cec4350252f84f71ac81f2cbe078d6cd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1106a155f8234eb79438245432968372",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "df872c4b96774d4bb567917a36021f2a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f0fb696438424a2996da1dbaf1a5695b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10000), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "EPOCH=10000\n",
    "\n",
    "errs_list = []\n",
    "for m in range(100) :\n",
    "    u_model =  u_Net().to(device)\n",
    "    optimizer=torch.optim.Adam([{'params': u_model.parameters()}], lr=1e-4)\n",
    "    errs = []\n",
    "    for t in tqdm_notebook(range(1, EPOCH+1)) :\n",
    "        # Make dataloader\n",
    "        data = sample(BATCH_SIZE)\n",
    "        data_bdry = sample_boundary(BATCH_SIZE)\n",
    "        u_bdry = boundary_condition(data_bdry)\n",
    "        data_train = TensorDataset(data, data_bdry, u_bdry)\n",
    "        train_loader = DataLoader(data_train, batch_size=BATCH_SIZE, shuffle=False)\n",
    "\n",
    "        loss, loss1, loss2 = train(u_model, trainloader=train_loader, \\\n",
    "                                  optimizer=optimizer, loss_f=nn.MSELoss())\n",
    "\n",
    "        output_answer = u_model(answer_x)\n",
    "        err = (torch.abs(answer_y - output_answer)/answer_y).mean().item()\n",
    "        \n",
    "        errs.append(err)\n",
    "    errs_list.append(errs)    \n",
    "    with open('{}_Poisson_L2_L2_{}_error_mean.pt'.format(dim, xmax), 'wb') as f :\n",
    "        pkl.dump(np.array(errs_list), f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.99014082, 0.98089283, 0.97162073, ..., 0.00389788, 0.00383265,\n",
       "       0.00381988])"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(errs_list).mean(axis=0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pydata",
   "language": "python",
   "name": "pydata"
  },
  "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
