{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "26b251a7",
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'tqdm'",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mModuleNotFoundError\u001B[0m                       Traceback (most recent call last)",
      "\u001B[0;32m<ipython-input-1-a65217f1fb90>\u001B[0m in \u001B[0;36m<module>\u001B[0;34m\u001B[0m\n\u001B[1;32m      4\u001B[0m \u001B[0;32mimport\u001B[0m \u001B[0mtorch\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mutils\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n\u001B[1;32m      5\u001B[0m \u001B[0;32mimport\u001B[0m \u001B[0mtorch\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mnn\u001B[0m \u001B[0;32mas\u001B[0m \u001B[0mnn\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n\u001B[0;32m----> 6\u001B[0;31m \u001B[0;32mfrom\u001B[0m \u001B[0mtqdm\u001B[0m \u001B[0;32mimport\u001B[0m \u001B[0mtqdm\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n\u001B[0m\u001B[1;32m      7\u001B[0m \u001B[0;32mimport\u001B[0m \u001B[0mos\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n\u001B[1;32m      8\u001B[0m \u001B[0;32mimport\u001B[0m \u001B[0mtorch\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mnn\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mfunctional\u001B[0m \u001B[0;32mas\u001B[0m \u001B[0mF\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n",
      "\u001B[0;31mModuleNotFoundError\u001B[0m: No module named 'tqdm'"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.utils\n",
    "import torch.nn as nn\n",
    "from tqdm import tqdm\n",
    "import os\n",
    "import torch.nn.functional as F\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   # see issue #152\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"4,5,6,7\""
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "9f73bd60",
   "metadata": {},
   "source": [
    "## Create the two Gaussians dataset\n",
    "\n",
    "$p_{data} = 0.5 \\mathcal{N}(\\mu_1, \\sigma I)+0.5 \\mathcal{N}(-\\mu_1, \\sigma I)$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b15d3e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[ 1.,  1.,  1.,  1.],\n",
      "        [-1., -1., -1., -1.]])\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Projection of Gaussian\n",
    "import torch as t\n",
    "from einops import rearrange, repeat, reduce\n",
    "t.manual_seed(0)\n",
    "dims = 20\n",
    "start_dims = 4\n",
    "proj = torch.randn((start_dims, dims))\n",
    "\n",
    "std = 0.1\n",
    "means = torch.ones((2, start_dims))\n",
    "means[1] = means[1] * -1\n",
    "print(means)\n",
    "size = [600, 1400]\n",
    "# size = [1000, 1000]\n",
    "mean_scale = 0.3\n",
    "means *= mean_scale\n",
    "x_list = []\n",
    "for i in range(means.shape[0]):\n",
    "    x_list.append(means[i].unsqueeze(0) + torch.randn((size[i], start_dims)) * std)\n",
    "\n",
    "\n",
    "X = torch.cat(x_list, dim=0)\n",
    "X = t.einsum('i j,j k->i k', X, proj)\n",
    "mean_scale = X.var(dim=0).abs().sqrt()\n",
    "X = X / mean_scale\n",
    "\n",
    "mean_scale = 1\n",
    "std = 0\n",
    "#Y = torch.cat([torch.zeros(size), torch.ones(size) ], dim=0)\n",
    "Y=X\n",
    "plt.scatter(X[:, 0], X[:, 1], label='True data')\n",
    "plt.show()\n",
    "plt.clf()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "48e88187",
   "metadata": {},
   "source": []
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "c50cdfca",
   "metadata": {},
   "source": [
    "## Construct data loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "51030eb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Gaussain_data(torch.utils.data.Dataset):\n",
    "    def __init__(self, X, Y):\n",
    "        \n",
    "        self.X = X\n",
    "        self.Y = Y\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.X)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "\n",
    "        return self.X[idx], self.Y[idx]\n",
    "    \n",
    "train_dataset = Gaussain_data(X=X, Y=Y)\n",
    "train_loader = torch.utils.data.DataLoader(dataset=train_dataset, batch_size=128, shuffle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "75cb537d",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5959ce2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import einops\n",
    "def true_score(goal, X, std): \n",
    "    # goal: (batch, 2), X: (data, 2)\n",
    "    # compute the score function of the goal\n",
    "    # return: (batch, 2)\n",
    "    diffs = ((goal.unsqueeze(1) - X.unsqueeze(0)) ** 2).sum(dim = -1) # (batch, data)\n",
    "    # take the minimum across the data dimension\n",
    "    diffmin, _ = diffs.min(dim = -1, keepdim = True) # (batch, 1)\n",
    "    prob = torch.exp(-(diffs - diffmin) / (2 * std ** 2)) # (batch, data)\n",
    "    prob = prob / prob.sum(dim = -1, keepdim = True) # (batch, data)\n",
    "    return einops.einsum(prob, X, 'g x, x d -> g d') "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "638a6e58",
   "metadata": {},
   "source": [
    "## Construct neural network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "75b56558",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def weight_init(shape, mode, fan_in, fan_out):\n",
    "    if mode == 'xavier_uniform': return np.sqrt(6 / (fan_in + fan_out)) * (torch.rand(*shape) * 2 - 1)\n",
    "    if mode == 'xavier_normal':  return np.sqrt(2 / (fan_in + fan_out)) * torch.randn(*shape)\n",
    "    if mode == 'kaiming_uniform': return np.sqrt(3 / fan_in) * (torch.rand(*shape) * 2 - 1)\n",
    "    if mode == 'kaiming_normal':  return np.sqrt(1 / fan_in) * torch.randn(*shape)\n",
    "    raise ValueError(f'Invalid init mode \"{mode}\"')\n",
    "\n",
    "class Linear(torch.nn.Module):\n",
    "    def __init__(self, in_features, out_features, bias=True, init_mode='xavier_uniform', init_weight=1, init_bias=0):\n",
    "        super().__init__()\n",
    "        self.in_features = in_features\n",
    "        self.out_features = out_features\n",
    "        init_kwargs = dict(mode=init_mode, fan_in=in_features, fan_out=out_features)\n",
    "        self.weight = torch.nn.Parameter(weight_init([out_features, in_features], **init_kwargs) * init_weight)\n",
    "        self.bias = torch.nn.Parameter(weight_init([out_features], **init_kwargs) * init_bias) if bias else None\n",
    "\n",
    "    def forward(self, x):\n",
    "        #self.weight.data = self.quan_dequan(self.weight.data)\n",
    "        x = x @ self.weight.to(x.dtype).t()\n",
    "        if self.bias is not None:\n",
    "            x = x.add_(self.bias.to(x.dtype))\n",
    "        return x\n",
    "\n",
    "class PositionalEmbedding(torch.nn.Module):\n",
    "    def __init__(self, num_channels, max_positions=10000, endpoint=False):\n",
    "        super().__init__()\n",
    "        self.num_channels = num_channels\n",
    "        self.max_positions = max_positions\n",
    "        self.endpoint = endpoint\n",
    "\n",
    "    def forward(self, x):\n",
    "        freqs = torch.arange(start=0, end=self.num_channels//2, dtype=torch.float32, device=x.device)\n",
    "        freqs = freqs / (self.num_channels // 2 - (1 if self.endpoint else 0))\n",
    "        freqs = (1 / self.max_positions) ** freqs\n",
    "        x = x.ger(freqs.to(x.dtype))\n",
    "        x = torch.cat([x.cos(), x.sin()], dim=1)\n",
    "        return x\n",
    "\n",
    "class mlp(nn.Module):\n",
    "    \"\"\"\n",
    "    the common architecture for the score model\n",
    "    \"\"\"\n",
    "    def __init__(self, dim=2, latent_dim=32, std_data=0.5):\n",
    "        super(mlp, self).__init__()\n",
    "\n",
    "        self.std_data = std_data\n",
    "        \n",
    "        self.latent_dim = latent_dim\n",
    "\n",
    "        self.fc1 = nn.Linear(dim, latent_dim)\n",
    "        \n",
    "        self.emb_layer = PositionalEmbedding(num_channels=latent_dim)\n",
    "        self.fc_emb = nn.Linear(latent_dim, latent_dim)\n",
    "        \n",
    "        self.normalizer_skip = nn.LayerNorm(latent_dim)\n",
    "        self.normalizer1 = nn.LayerNorm(latent_dim)\n",
    "        \n",
    "        self.fc_skip = nn.Linear(dim, latent_dim  )\n",
    "        self.fc1_skip = nn.Linear(latent_dim, latent_dim )\n",
    "        \n",
    "        \n",
    "        self.fc2 = nn.Linear(latent_dim, latent_dim )\n",
    "        self.fc3 = nn.Linear(latent_dim , latent_dim )\n",
    "        self.fc4 = nn.Linear(latent_dim, dim)\n",
    "        \n",
    "        #sself.fc5 = nn.Linear(latent_dim, dim)\n",
    "    def forward(self, x, t):\n",
    "        c_out = t * self.std_data/(self.std_data ** 2 + t ** 2).sqrt()\n",
    "        c_skip = self.std_data ** 2/(self.std_data ** 2 + t ** 2)\n",
    "        \n",
    "        t = t.flatten().log() / 4.\n",
    "        \n",
    "        x_1 = self.fc1(x) + (self.emb_layer(t))\n",
    "        \n",
    "        x_2 = F.relu(x_1)   \n",
    "        x_3 = F.relu(self.fc2(x_2)) + self.fc1_skip(x_1) # latent_dim -> latent_dim/2\n",
    "        x_4 = F.relu(self.fc3(x_3)) + self.fc_skip(x)   \n",
    "        x_4 = self.fc4(x_4)                             # latent_dim/2 -> latent_dim\n",
    "        #x_4 = self.fc3_old(x_3)\n",
    "        return c_out * x_4 + c_skip * x\n",
    "\n",
    "\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "986f4960",
   "metadata": {},
   "source": [
    "## Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4d426932",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 3/200 [00:00<00:37,  5.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 0, avg loss:0.1619 tloss:0.0241\n",
      " epoch 1, avg loss:0.1433 tloss:0.0227\n",
      " epoch 2, avg loss:0.1371 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▎         | 5/200 [00:00<00:25,  7.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 3, avg loss:0.1341 tloss:0.0251\n",
      " epoch 4, avg loss:0.1287 tloss:0.0234\n",
      " epoch 5, avg loss:0.1241 tloss:0.0239\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 9/200 [00:01<00:19,  9.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 6, avg loss:0.1215 tloss:0.0240\n",
      " epoch 7, avg loss:0.1195 tloss:0.0232\n",
      " epoch 8, avg loss:0.1144 tloss:0.0231\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 11/200 [00:01<00:17, 10.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 9, avg loss:0.1107 tloss:0.0228\n",
      " epoch 10, avg loss:0.1078 tloss:0.0229\n",
      " epoch 11, avg loss:0.1061 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 15/200 [00:01<00:15, 11.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 12, avg loss:0.1049 tloss:0.0242\n",
      " epoch 13, avg loss:0.1015 tloss:0.0229\n",
      " epoch 14, avg loss:0.0997 tloss:0.0249\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 17/200 [00:01<00:15, 11.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 15, avg loss:0.0983 tloss:0.0245\n",
      " epoch 16, avg loss:0.0983 tloss:0.0252\n",
      " epoch 17, avg loss:0.0948 tloss:0.0246\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 21/200 [00:02<00:14, 12.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 18, avg loss:0.0971 tloss:0.0240\n",
      " epoch 19, avg loss:0.0961 tloss:0.0242\n",
      " epoch 20, avg loss:0.0934 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 23/200 [00:02<00:14, 11.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 21, avg loss:0.0943 tloss:0.0235\n",
      " epoch 22, avg loss:0.0938 tloss:0.0247\n",
      " epoch 23, avg loss:0.0902 tloss:0.0209\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▎        | 27/200 [00:02<00:13, 12.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 24, avg loss:0.0904 tloss:0.0242\n",
      " epoch 25, avg loss:0.0925 tloss:0.0238\n",
      " epoch 26, avg loss:0.0902 tloss:0.0238\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 29/200 [00:02<00:13, 12.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 27, avg loss:0.0871 tloss:0.0244\n",
      " epoch 28, avg loss:0.0891 tloss:0.0231\n",
      " epoch 29, avg loss:0.0874 tloss:0.0253\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▋        | 33/200 [00:03<00:13, 12.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 30, avg loss:0.0877 tloss:0.0242\n",
      " epoch 31, avg loss:0.0875 tloss:0.0242\n",
      " epoch 32, avg loss:0.0857 tloss:0.0241\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 35/200 [00:03<00:13, 12.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 33, avg loss:0.0846 tloss:0.0235\n",
      " epoch 34, avg loss:0.0828 tloss:0.0229\n",
      " epoch 35, avg loss:0.0830 tloss:0.0232\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|█▉        | 39/200 [00:03<00:13, 12.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 36, avg loss:0.0817 tloss:0.0233\n",
      " epoch 37, avg loss:0.0824 tloss:0.0232\n",
      " epoch 38, avg loss:0.0809 tloss:0.0240\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 41/200 [00:03<00:12, 12.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 39, avg loss:0.0803 tloss:0.0244\n",
      " epoch 40, avg loss:0.0770 tloss:0.0229\n",
      " epoch 41, avg loss:0.0764 tloss:0.0233\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▎       | 45/200 [00:04<00:12, 12.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 42, avg loss:0.0751 tloss:0.0229\n",
      " epoch 43, avg loss:0.0781 tloss:0.0248\n",
      " epoch 44, avg loss:0.0777 tloss:0.0252\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▎       | 47/200 [00:04<00:12, 12.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 45, avg loss:0.0759 tloss:0.0239\n",
      " epoch 46, avg loss:0.0753 tloss:0.0258\n",
      " epoch 47, avg loss:0.0762 tloss:0.0242\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 51/200 [00:04<00:11, 12.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 48, avg loss:0.0731 tloss:0.0242\n",
      " epoch 49, avg loss:0.0710 tloss:0.0248\n",
      " epoch 50, avg loss:0.0723 tloss:0.0244\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▋       | 53/200 [00:04<00:12, 11.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 51, avg loss:0.0704 tloss:0.0225\n",
      " epoch 52, avg loss:0.0703 tloss:0.0240\n",
      " epoch 53, avg loss:0.0705 tloss:0.0229\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 57/200 [00:05<00:11, 12.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 54, avg loss:0.0690 tloss:0.0237\n",
      " epoch 55, avg loss:0.0698 tloss:0.0234\n",
      " epoch 56, avg loss:0.0676 tloss:0.0245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|██▉       | 59/200 [00:05<00:11, 12.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 57, avg loss:0.0668 tloss:0.0239\n",
      " epoch 58, avg loss:0.0673 tloss:0.0250\n",
      " epoch 59, avg loss:0.0664 tloss:0.0241\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 63/200 [00:05<00:11, 12.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 60, avg loss:0.0654 tloss:0.0253\n",
      " epoch 61, avg loss:0.0654 tloss:0.0228\n",
      " epoch 62, avg loss:0.0659 tloss:0.0241\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▎      | 65/200 [00:05<00:10, 12.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 63, avg loss:0.0646 tloss:0.0245\n",
      " epoch 64, avg loss:0.0623 tloss:0.0229\n",
      " epoch 65, avg loss:0.0630 tloss:0.0242\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 69/200 [00:06<00:10, 12.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 66, avg loss:0.0626 tloss:0.0230\n",
      " epoch 67, avg loss:0.0632 tloss:0.0234\n",
      " epoch 68, avg loss:0.0604 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 71/200 [00:06<00:10, 12.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 69, avg loss:0.0594 tloss:0.0235\n",
      " epoch 70, avg loss:0.0623 tloss:0.0250\n",
      " epoch 71, avg loss:0.0612 tloss:0.0240\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 75/200 [00:06<00:10, 12.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 72, avg loss:0.0593 tloss:0.0228\n",
      " epoch 73, avg loss:0.0600 tloss:0.0241\n",
      " epoch 74, avg loss:0.0583 tloss:0.0228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 77/200 [00:06<00:09, 12.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 75, avg loss:0.0600 tloss:0.0246\n",
      " epoch 76, avg loss:0.0591 tloss:0.0251\n",
      " epoch 77, avg loss:0.0596 tloss:0.0236\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 81/200 [00:06<00:09, 12.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 78, avg loss:0.0591 tloss:0.0237\n",
      " epoch 79, avg loss:0.0588 tloss:0.0233\n",
      " epoch 80, avg loss:0.0577 tloss:0.0231\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 83/200 [00:07<00:09, 12.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 81, avg loss:0.0587 tloss:0.0238\n",
      " epoch 82, avg loss:0.0570 tloss:0.0236\n",
      " epoch 83, avg loss:0.0576 tloss:0.0237\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▎     | 87/200 [00:07<00:09, 12.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 84, avg loss:0.0569 tloss:0.0228\n",
      " epoch 85, avg loss:0.0566 tloss:0.0225\n",
      " epoch 86, avg loss:0.0575 tloss:0.0228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 89/200 [00:07<00:09, 12.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 87, avg loss:0.0579 tloss:0.0240\n",
      " epoch 88, avg loss:0.0553 tloss:0.0235\n",
      " epoch 89, avg loss:0.0577 tloss:0.0254\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▋     | 93/200 [00:07<00:08, 12.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 90, avg loss:0.0559 tloss:0.0224\n",
      " epoch 91, avg loss:0.0568 tloss:0.0241\n",
      " epoch 92, avg loss:0.0568 tloss:0.0249\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 95/200 [00:08<00:08, 12.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 93, avg loss:0.0559 tloss:0.0225\n",
      " epoch 94, avg loss:0.0564 tloss:0.0226\n",
      " epoch 95, avg loss:0.0559 tloss:0.0247\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|████▉     | 99/200 [00:08<00:08, 12.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 96, avg loss:0.0560 tloss:0.0248\n",
      " epoch 97, avg loss:0.0557 tloss:0.0237\n",
      " epoch 98, avg loss:0.0572 tloss:0.0236\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 103/200 [00:08<00:07, 13.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 99, avg loss:0.0568 tloss:0.0230\n",
      " epoch 100, avg loss:0.0549 tloss:0.0247\n",
      " epoch 101, avg loss:0.0561 tloss:0.0233\n",
      " epoch 102, avg loss:0.0561 tloss:0.0243\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▎    | 107/200 [00:09<00:06, 14.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 103, avg loss:0.0558 tloss:0.0240\n",
      " epoch 104, avg loss:0.0548 tloss:0.0223\n",
      " epoch 105, avg loss:0.0546 tloss:0.0237\n",
      " epoch 106, avg loss:0.0551 tloss:0.0247\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 111/200 [00:09<00:06, 14.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 107, avg loss:0.0552 tloss:0.0236\n",
      " epoch 108, avg loss:0.0552 tloss:0.0239\n",
      " epoch 109, avg loss:0.0548 tloss:0.0238\n",
      " epoch 110, avg loss:0.0556 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▋    | 113/200 [00:09<00:06, 13.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 111, avg loss:0.0553 tloss:0.0232\n",
      " epoch 112, avg loss:0.0561 tloss:0.0250\n",
      " epoch 113, avg loss:0.0555 tloss:0.0245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 117/200 [00:09<00:06, 13.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 114, avg loss:0.0540 tloss:0.0229\n",
      " epoch 115, avg loss:0.0538 tloss:0.0230\n",
      " epoch 116, avg loss:0.0551 tloss:0.0238\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████▉    | 119/200 [00:09<00:06, 12.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 117, avg loss:0.0546 tloss:0.0240\n",
      " epoch 118, avg loss:0.0531 tloss:0.0235\n",
      " epoch 119, avg loss:0.0536 tloss:0.0238\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 123/200 [00:10<00:06, 12.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 120, avg loss:0.0539 tloss:0.0233\n",
      " epoch 121, avg loss:0.0532 tloss:0.0239\n",
      " epoch 122, avg loss:0.0533 tloss:0.0228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▎   | 125/200 [00:10<00:06, 12.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 123, avg loss:0.0532 tloss:0.0231\n",
      " epoch 124, avg loss:0.0528 tloss:0.0224\n",
      " epoch 125, avg loss:0.0537 tloss:0.0240\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 129/200 [00:10<00:05, 12.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 126, avg loss:0.0510 tloss:0.0227\n",
      " epoch 127, avg loss:0.0524 tloss:0.0226\n",
      " epoch 128, avg loss:0.0526 tloss:0.0237\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 131/200 [00:10<00:05, 11.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 129, avg loss:0.0527 tloss:0.0235\n",
      " epoch 130, avg loss:0.0525 tloss:0.0229\n",
      " epoch 131, avg loss:0.0544 tloss:0.0242\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 135/200 [00:11<00:05, 11.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 132, avg loss:0.0529 tloss:0.0243\n",
      " epoch 133, avg loss:0.0519 tloss:0.0219\n",
      " epoch 134, avg loss:0.0527 tloss:0.0245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 137/200 [00:11<00:05, 12.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 135, avg loss:0.0529 tloss:0.0239\n",
      " epoch 136, avg loss:0.0533 tloss:0.0241\n",
      " epoch 137, avg loss:0.0522 tloss:0.0237\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 141/200 [00:11<00:04, 12.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 138, avg loss:0.0515 tloss:0.0227\n",
      " epoch 139, avg loss:0.0524 tloss:0.0229\n",
      " epoch 140, avg loss:0.0517 tloss:0.0236\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 143/200 [00:11<00:04, 12.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 141, avg loss:0.0533 tloss:0.0237\n",
      " epoch 142, avg loss:0.0529 tloss:0.0235\n",
      " epoch 143, avg loss:0.0528 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▎  | 147/200 [00:12<00:04, 12.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 144, avg loss:0.0526 tloss:0.0227\n",
      " epoch 145, avg loss:0.0531 tloss:0.0234\n",
      " epoch 146, avg loss:0.0522 tloss:0.0237\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 149/200 [00:12<00:04, 12.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 147, avg loss:0.0520 tloss:0.0220\n",
      " epoch 148, avg loss:0.0527 tloss:0.0237\n",
      " epoch 149, avg loss:0.0516 tloss:0.0235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▋  | 153/200 [00:12<00:03, 12.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 150, avg loss:0.0515 tloss:0.0221\n",
      " epoch 151, avg loss:0.0534 tloss:0.0242\n",
      " epoch 152, avg loss:0.0511 tloss:0.0234\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 155/200 [00:12<00:03, 12.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 153, avg loss:0.0524 tloss:0.0243\n",
      " epoch 154, avg loss:0.0512 tloss:0.0230\n",
      " epoch 155, avg loss:0.0519 tloss:0.0228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|███████▉  | 159/200 [00:13<00:03, 12.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 156, avg loss:0.0522 tloss:0.0238\n",
      " epoch 157, avg loss:0.0524 tloss:0.0241\n",
      " epoch 158, avg loss:0.0512 tloss:0.0234\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 161/200 [00:13<00:03, 12.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 159, avg loss:0.0515 tloss:0.0233\n",
      " epoch 160, avg loss:0.0531 tloss:0.0244\n",
      " epoch 161, avg loss:0.0528 tloss:0.0238\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▎ | 165/200 [00:13<00:02, 12.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 162, avg loss:0.0514 tloss:0.0245\n",
      " epoch 163, avg loss:0.0522 tloss:0.0251\n",
      " epoch 164, avg loss:0.0510 tloss:0.0230\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▎ | 167/200 [00:13<00:02, 11.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 165, avg loss:0.0516 tloss:0.0232\n",
      " epoch 166, avg loss:0.0510 tloss:0.0223\n",
      " epoch 167, avg loss:0.0499 tloss:0.0231\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 171/200 [00:14<00:02, 11.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 168, avg loss:0.0527 tloss:0.0244\n",
      " epoch 169, avg loss:0.0507 tloss:0.0233\n",
      " epoch 170, avg loss:0.0496 tloss:0.0226\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▋ | 173/200 [00:14<00:02, 12.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 171, avg loss:0.0516 tloss:0.0243\n",
      " epoch 172, avg loss:0.0500 tloss:0.0227\n",
      " epoch 173, avg loss:0.0518 tloss:0.0256\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 177/200 [00:14<00:01, 12.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 174, avg loss:0.0533 tloss:0.0253\n",
      " epoch 175, avg loss:0.0506 tloss:0.0228\n",
      " epoch 176, avg loss:0.0505 tloss:0.0227\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|████████▉ | 179/200 [00:14<00:01, 12.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 177, avg loss:0.0503 tloss:0.0242\n",
      " epoch 178, avg loss:0.0532 tloss:0.0251\n",
      " epoch 179, avg loss:0.0517 tloss:0.0245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 183/200 [00:15<00:01, 12.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 180, avg loss:0.0525 tloss:0.0250\n",
      " epoch 181, avg loss:0.0519 tloss:0.0244\n",
      " epoch 182, avg loss:0.0508 tloss:0.0245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▎| 185/200 [00:15<00:01, 11.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 183, avg loss:0.0514 tloss:0.0231\n",
      " epoch 184, avg loss:0.0508 tloss:0.0244\n",
      " epoch 185, avg loss:0.0504 tloss:0.0241\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 189/200 [00:15<00:00, 12.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 186, avg loss:0.0502 tloss:0.0232\n",
      " epoch 187, avg loss:0.0535 tloss:0.0251\n",
      " epoch 188, avg loss:0.0540 tloss:0.0254\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▋| 193/200 [00:15<00:00, 13.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 189, avg loss:0.0509 tloss:0.0227\n",
      " epoch 190, avg loss:0.0506 tloss:0.0239\n",
      " epoch 191, avg loss:0.0507 tloss:0.0236\n",
      " epoch 192, avg loss:0.0517 tloss:0.0243\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 195/200 [00:16<00:00, 13.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 193, avg loss:0.0518 tloss:0.0239\n",
      " epoch 194, avg loss:0.0496 tloss:0.0225\n",
      " epoch 195, avg loss:0.0506 tloss:0.0234\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████▉| 199/200 [00:16<00:00, 13.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 196, avg loss:0.0507 tloss:0.0245\n",
      " epoch 197, avg loss:0.0518 tloss:0.0251\n",
      " epoch 198, avg loss:0.0508 tloss:0.0232\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:16<00:00, 12.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " epoch 199, avg loss:0.0523 tloss:0.0238\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# import wandb # if don't want: switch to False\n",
    "# params = {'lr': 1e-3, 'latent_dim': 32}\n",
    "params = {'lr': 1e-3, 'latent_dim': 64}\n",
    "input_std = 1\n",
    "\n",
    "model = mlp(dim=dims, latent_dim=params['latent_dim'], std_data=input_std).cuda()\n",
    "opt = torch.optim.Adam(model.parameters(), lr=params['lr'])\n",
    "max_t = 20\n",
    "min_t = 0.01\n",
    "total_epoch = 200\n",
    "for epoch in tqdm(range(total_epoch)):\n",
    "    loss_sum = 0.\n",
    "    tloss_sum = 0.\n",
    "    cnt = 0.\n",
    "\n",
    "    for x, y in train_loader:\n",
    "        x, y = x.cuda(), y.cuda()\n",
    "        var_data = std ** 2 + mean_scale ** 2\n",
    "        std_data = np.sqrt(var_data)\n",
    "        \n",
    "        # normalize to std = 1\n",
    "        x /= std_data\n",
    "        \n",
    "        opt.zero_grad()\n",
    "        \n",
    "        #t = torch.rand(size=(len(x), 1), device=x.device) * (max_t - min_t) + min_t\n",
    "        \n",
    "        rnd_normal = torch.randn((x.shape[0], 1), device=x.device)\n",
    "        t = (rnd_normal * 1.2 - 1.2).exp()\n",
    "        n = torch.randn_like(x)\n",
    "        x_hat = x + n * t\n",
    "        \n",
    "        # preconditions\n",
    "        c_in = 1 / (input_std ** 2 + t ** 2).sqrt()\n",
    "        \n",
    "        D_x = model(x_hat * c_in, t)\n",
    "\n",
    "        weight = (t**2 + input_std ** 2) / (t*input_std) ** 2\n",
    "\n",
    "        tD = true_score(x_hat, X.cuda() / std_data, t.cuda())\n",
    "        # print(tD.shape, tD.isnan().sum())\n",
    "        tloss = torch.sum(weight * ((tD - x) ** 2), dim=1).mean()\n",
    "        tloss_sum += tloss.item()\n",
    "        \n",
    "        loss = torch.sum(weight * ((D_x - x) ** 2), dim=1).mean()\n",
    "        loss.backward()\n",
    "        opt.step()\n",
    "\n",
    "        loss_sum += loss.item()\n",
    "        cnt += len(x)\n",
    "\n",
    "    print(f\" epoch {epoch}, avg loss:{loss_sum/cnt:.4f} tloss:{tloss_sum/cnt:.4f}\")\n",
    "    "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "3cc8ed61",
   "metadata": {},
   "source": [
    "## Sampling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "406291f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0\n"
     ]
    }
   ],
   "source": [
    "class MMD_loss(nn.Module):\n",
    "    def __init__(self, kernel_mul = 2.0, kernel_num = 5):\n",
    "        super(MMD_loss, self).__init__()\n",
    "        self.kernel_num = kernel_num\n",
    "        self.kernel_mul = kernel_mul\n",
    "        self.fix_sigma = None\n",
    "    def guassian_kernel(self, source, target, kernel_mul=2.0, kernel_num=5, fix_sigma=None):\n",
    "        n_samples = int(source.size()[0])+int(target.size()[0])\n",
    "        total = torch.cat([source, target], dim=0)\n",
    "        total0 = total.unsqueeze(0).expand(int(total.size(0)), int(total.size(0)), int(total.size(1)))\n",
    "        total1 = total.unsqueeze(1).expand(int(total.size(0)), int(total.size(0)), int(total.size(1)))\n",
    "        L2_distance = ((total0-total1)**2).sum(2)\n",
    "        if fix_sigma:\n",
    "            bandwidth = fix_sigma\n",
    "        else:\n",
    "            bandwidth = torch.sum(L2_distance.data) / (n_samples**2-n_samples)\n",
    "        bandwidth /= kernel_mul ** (kernel_num // 2)\n",
    "        bandwidth_list = [bandwidth * (kernel_mul**i) for i in range(kernel_num)]\n",
    "        kernel_val = [torch.exp(-L2_distance / bandwidth_temp) for bandwidth_temp in bandwidth_list]\n",
    "        return sum(kernel_val)\n",
    "    def forward(self, source, target):\n",
    "        batch_size = int(source.size()[0])\n",
    "        kernels = self.guassian_kernel(source, target, kernel_mul=self.kernel_mul, kernel_num=self.kernel_num, fix_sigma=self.fix_sigma)\n",
    "        XX = kernels[:batch_size, :batch_size]\n",
    "        YY = kernels[batch_size:, batch_size:]\n",
    "        XY = kernels[:batch_size, batch_size:]\n",
    "        YX = kernels[batch_size:, :batch_size]\n",
    "        loss = torch.mean(XX + YY - XY -YX)\n",
    "        return loss\n",
    "def w2_fun(gen_x, neg=True):\n",
    "    var_data_ = std ** 2 + mean_scale ** 2\n",
    "    std_data_ = np.sqrt(var_data_)\n",
    "    generated_X = gen_x.detach().cpu() * std_data_\n",
    "    \n",
    "\n",
    "    idx = X[:, 0] < 0 if neg else X[:, 0] > 0\n",
    "    X_neg = X[idx]\n",
    "    cov_neg = torch.var(X_neg[:, 0])\n",
    "    mean_neg = X_neg[:, 0].mean()\n",
    "\n",
    "    idx = generated_X[:, 0] < 0 if neg else generated_X[:, 0] > 0\n",
    "    gen_X_neg = generated_X[idx]\n",
    "\n",
    "    gen_mean_neg = gen_X_neg[:, 0].mean()\n",
    "    gen_cov_neg = torch.var(gen_X_neg[:, 0])\n",
    "    #print(cov_neg, mean_neg, gen_mean_neg, gen_cov_neg)\n",
    "    w2 = (mean_neg - gen_mean_neg) ** 2 + cov_neg + gen_cov_neg - 2 * torch.sqrt(cov_neg * gen_cov_neg)\n",
    "    return w2\n",
    "\n",
    "mmd_loss = MMD_loss()\n",
    "# Time step discretization.\n",
    "def get_steps(min_t, max_t, num_steps, rho):\n",
    "    step_indices = torch.arange(num_steps, dtype=torch.float, device=\"cuda:0\")\n",
    "    t_steps = (max_t ** (1 / rho) + step_indices / (num_steps - 1) * (min_t ** (1 / rho) - max_t ** (1 / rho))) ** rho\n",
    "    return t_steps\n",
    "\n",
    "\n",
    "# %%\n",
    "# Main sampling loop.\n",
    "std_data = np.sqrt(std**2+mean_scale**2)\n",
    "# actually, std_data=1\n",
    "# print(std_data)\n",
    "def one_step(t_cur, t_next, gamma, x_cur, second_order=False, use_true_score=False):\n",
    "    t_hat = t_cur + gamma * t_cur\n",
    "    x_hat = x_cur + (t_hat ** 2 - t_cur ** 2).sqrt() * torch.randn_like(x_cur)\n",
    "\n",
    "    # Euler step.\n",
    "    # preconditions\n",
    "    c_in = 1/(model.std_data ** 2 + t_hat ** 2).sqrt()\n",
    "    if not use_true_score:\n",
    "        with torch.no_grad():\n",
    "            denoised = model(x_hat * c_in, t_hat)\n",
    "    else:\n",
    "        denoised = true_score(x_hat, X.cuda() / std_data, (t_hat).cuda())\n",
    "        # print(f\"Count nan {torch.isnan(denoised).sum()}\")\n",
    "    d_cur = (x_hat - denoised) / t_hat\n",
    "    x_next = x_hat + (t_next - t_hat) * d_cur\n",
    "\n",
    "    # Apply 2nd order correction.\n",
    "    if second_order:\n",
    "        c_in = 1/(model.std_data ** 2 + t_next ** 2).sqrt()\n",
    "        if not use_true_score:\n",
    "            with torch.no_grad():\n",
    "                denoised = model(x_next * c_in, t_next)\n",
    "        else:\n",
    "            denoised = true_score(x_next, X.cuda() /std_data, (t_next).cuda())\n",
    "\n",
    "        # denoised = model(x_next * c_in, t_next)\n",
    "        d_next = (x_next - denoised) / t_next\n",
    "        x_next = x_next + (t_next - t_hat) * (d_next - d_cur) / 2\n",
    "    return x_next\n",
    "\n",
    "def get_result(x_next):\n",
    "    var_data = std ** 2 + mean_scale ** 2\n",
    "    std_data = np.sqrt(var_data)\n",
    "    # std_data=1\n",
    "    generated_X = x_next * std_data\n",
    "    return torch.Tensor(generated_X).cuda()\n",
    "\n",
    "def perturb(data, scale=0.1):\n",
    "    return data + scale * torch.randn_like(data)\n",
    "def MMD(A, B):\n",
    "    return mmd_loss(A.clone().detach().cuda(), B.clone().detach().cuda()).item()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ce73356b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot(points, title=\"\"):\n",
    "    plt.scatter(points[:, 0].clone().detach().cpu().numpy(), points[:, 1].clone().detach().cpu().numpy(), s=1)\n",
    "    plt.title(title)\n",
    "def compare(pts1, pts2):\n",
    "    plt.subplot(1, 2, 1)\n",
    "    # plt.xlim(-0.6, 0.6)\n",
    "    # plt.ylim(-0.6, 0.6)\n",
    "    plot(pts1, \"pts1\")\n",
    "    plt.subplot(1, 2, 2)\n",
    "    # plt.xlim(-0.6, 0.6)\n",
    "    # plt.ylim(-0.6, 0.6)\n",
    "    plot(pts2, \"pts2\")\n",
    "    plt.show()\n",
    "\n",
    "# Generate two lists of 2D points\n",
    "# X = torch.randn(100, 2)\n",
    "# Y = torch.randn(100, 2)\n",
    "\n",
    "from scipy.spatial.distance import cdist\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "\n",
    "w2_dims = 20\n",
    "\n",
    "def w2_dist(X, Y):\n",
    "    d = cdist(X.clone().detach().cpu().numpy()[:, :w2_dims], Y.clone().detach().cpu().numpy()[:, :w2_dims])\n",
    "    assignment = linear_sum_assignment(d)\n",
    "    return d[assignment].sum() / len(X)\n",
    "# print(w2_dist(X, Y))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9cb10922",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 383.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7.61840839438321\n",
      "torch.Size([2000, 20]) torch.Size([2000, 20])\n"
     ]
    }
   ],
   "source": [
    "# Experiment 1: Evolve with SDE vs restart\n",
    "\n",
    "import numpy\n",
    "# numpy.random.seed(123)\n",
    "# torch.manual_seed(123)\n",
    "# print(X.shape)\n",
    "\n",
    "num_steps = 40\n",
    "sample_size = 4000\n",
    "S_churn = 0.01\n",
    "S_min = 0.02\n",
    "S_max = 1\n",
    "rho = 7\n",
    "S_noise = 1\n",
    "fake_t = 2\n",
    "# fake_t = 2\n",
    "max_t = 20\n",
    "init = perturb(X.cuda() / std_data, scale=max_t)\n",
    "t_steps = get_steps(fake_t, max_t, num_steps, rho)\n",
    "x_next = init\n",
    "for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "    x_next = one_step(t_cur, t_next, 0, x_next, True, False)\n",
    "print(w2_dist(perturb(X.cuda() / std_data, scale=fake_t), x_next))\n",
    "print(X.shape, x_next.shape)\n",
    "init = x_next"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "87ede7e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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d9xxh/X7hAkTQhxN7fmbv/kb3H333Xj88cdxww034NFHH8WKFStw/PhxXHnllWEPLzTmzJmD73znO9bvLS0ytYRSGl1+6BCZ4o16ljFiEfHJhAkTcNVVV1k/7e3tYQ+ppjzyyCO444478OlPfxqzZ8/G448/jiuuuAJ/+Zd/GfbQQqWlpcX2XLz97W8Pe0hCBGl0+aFDZIo36lnGiCLik4ceegiTJ0/GwoUL8fDDD2NkZCTsIdWMy5cvY//+/fjQhz5kfdbU1IQPfehDePHFF0McWfj85Cc/QXd3N6699lp88pOfxOuvvx72kIQI0sjyQ4fIFO/Us4ypH9tODVi3bh3e+973oqurC9///vexceNG/OxnP8MjjzwS9tBqwr/+679idHQU73jHO2yfv+Md78Arr7wS0qjC54YbbsBXv/pVzJo1Cz/72c/Q29uLf//v/z2OHDkipnfBotHlhw6RKd6oexlTaHD++3//7wUAjj/Hjh3T7vsXf/EXhZaWlsKlS5dqPOpwOHPmTAFA4fvf/77t89/5nd8pLF68OKRRRY8LFy4UJk6cWPjzP//zsIciBIzIj8oQmVIe9SZjGt4ics899+D222933Obaa6/Vfn7DDTdgZGQEr732GmbNmhXA6KLF29/+djQ3N+ONN96wff7GG2/gqquuCmlU0aOzsxMzZ87Eq6++GvZQhIAR+VEZIlPKo95kTMMrIlOmTMGUKVPK2vfgwYNoampqmMju1tZWLFq0CM8++yxWr14NAMjn83j22Wdx1113hTu4CPFv//ZvOHnyJD71qU+FPRQhYER+VIbIlPKoNxnT8IqIV1588UX84Ac/wK/+6q9iwoQJePHFF/Hbv/3bWLNmDSZNmhT28GrG3Xffjdtuuw3XX389Fi9ejEcffRTDw8P49Kc/HfbQQmP9+vW4+eab0dPTg4GBAWzevBnNzc249dZbwx6aEBFEfpgRmeJO3cuYsH1DcWH//v2FG264odDR0VFoa2srXHfddYUvfelLDenffeyxxwpXX311obW1tbB48eLCvn37wh5SqHz84x8vvPOd7yy0trYWpk6dWvj4xz9eePXVV8MelhAhRH44IzLFmXqXMYlCoVAIWxkSBEEQBKExkToigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCEhigigiAIgiCExv8HdnzB2YqcDHwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "compare(get_result(perturb(X.cuda() / std_data, scale=fake_t)), get_result(init))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cc010f76",
   "metadata": {},
   "outputs": [],
   "source": [
    "high = 1.5\n",
    "low = 1.0\n",
    "def SDE_error(num_steps, S_churn, S_max = high, S_min = low, rounds = 5, strategy = False, second_order = False):\n",
    "    # return NFE, total, approx, contraction\n",
    "    with torch.inference_mode():\n",
    "        error_sum = 0\n",
    "        approximation_sum = 0\n",
    "        contraction_sum = 0\n",
    "        for times in range(rounds):\n",
    "            gamma = S_churn / num_steps\n",
    "            t_steps = get_steps(min_t, fake_t, num_steps, rho)\n",
    "            x_next = init\n",
    "            x_true = init if strategy else perturb(X.cuda() / std_data, fake_t)\n",
    "            for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                \n",
    "                inside = (t_cur <= S_max) & (t_next > S_min)\n",
    "                x_next = one_step(t_cur, t_next, gamma if (inside) else 0, x_next, second_order, False)\n",
    "                x_true = one_step(t_cur, t_next, gamma if (inside) else 0 , x_true, second_order, strategy)\n",
    "            x_next = one_step(t_steps[-1], 0, 0, x_next, False, False)\n",
    "            x_true = one_step(t_steps[-1], 0, 0, x_true, False, strategy)\n",
    "            error = w2_dist(X.cuda(), get_result(x_next))\n",
    "            approx = w2_dist(get_result(x_next), get_result(x_true))\n",
    "            contraction = w2_dist(X.cuda(), get_result(x_true))\n",
    "            if not strategy:\n",
    "                approx, contraction = contraction, approx\n",
    "            error_sum += error\n",
    "            approximation_sum += approx\n",
    "            contraction_sum += contraction\n",
    "        error_sum /= rounds\n",
    "        approximation_sum /= rounds\n",
    "        contraction_sum /= rounds\n",
    "        NFE = num_steps\n",
    "        if second_order:\n",
    "            NFE += num_steps - 1\n",
    "        return NFE, error_sum, approximation_sum, contraction_sum\n",
    "\n",
    "def restart_error(restart_times = 5,  restart_steps = 20, t_start = high, t_end = low, rounds = 5, before_steps = 20, after_steps = 20, second_order = False, strategy = False):\n",
    "        \n",
    "    with torch.inference_mode():\n",
    "        restart_t = [t_start] * restart_times  #torch.Tensor([1] * r3 + [0.5] * r1 + [0.1] * r2).cuda()\n",
    "                \n",
    "        error_sum = 0\n",
    "        approximation_sum = 0\n",
    "        contraction_sum = 0\n",
    "        NFE = 0\n",
    "        for round in range(rounds):\n",
    "            NFE = 0\n",
    "            restart_t = torch.Tensor(restart_t).cuda()\n",
    "            x_next = init\n",
    "            x_true = init if strategy else perturb(X.cuda() / std_data, fake_t)\n",
    "            t_steps = get_steps(t_end, fake_t, before_steps, rho)\n",
    "            once_NFE = 1\n",
    "            if second_order: \n",
    "                once_NFE += 1\n",
    "            for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                x_next = one_step(t_cur, t_next, 0, x_next, second_order, False)\n",
    "                NFE += once_NFE\n",
    "                x_true = one_step(t_cur, t_next, 0, x_true, second_order, strategy)\n",
    "            curt = t_steps[-1]\n",
    "            for tt in restart_t:\n",
    "                x_next = x_next + torch.randn_like(x_next) * (tt ** 2 - curt ** 2).sqrt()\n",
    "                x_true = x_true + torch.randn_like(x_true) * (tt ** 2 - curt ** 2).sqrt()\n",
    "                t_steps = get_steps(t_end, tt, restart_steps, rho)\n",
    "                for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                    x_next = one_step(t_cur, t_next, 0, x_next, second_order, False)\n",
    "                    NFE += once_NFE\n",
    "                    x_true = one_step(t_cur, t_next, 0, x_true, second_order, strategy)\n",
    "                curt = t_end\n",
    "            t_steps = get_steps(min_t, curt, after_steps, rho)\n",
    "            for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                x_next = one_step(t_cur, t_next, 0, x_next, second_order, False)\n",
    "                NFE += once_NFE\n",
    "                x_true = one_step(t_cur, t_next, 0, x_true, second_order, strategy)\n",
    "\n",
    "            x_next = one_step(torch.Tensor([min_t]).cuda(), 0, 0, x_next, False, False)\n",
    "            NFE += 1\n",
    "            x_true = one_step(torch.Tensor([min_t]).cuda(), 0, 0, x_true, False, strategy)\n",
    "\n",
    "            error = w2_dist(X.cuda(), get_result(x_next))\n",
    "            approx = w2_dist(get_result(x_next), get_result(x_true))\n",
    "            contraction = w2_dist(X.cuda(), get_result(x_true))\n",
    "            if not strategy:\n",
    "                approx, contraction = contraction, approx\n",
    "            error_sum += error\n",
    "            approximation_sum += approx\n",
    "            contraction_sum += contraction\n",
    "        error_sum /= rounds\n",
    "        approximation_sum /= rounds\n",
    "        contraction_sum /= rounds\n",
    "        return NFE, error_sum, approximation_sum, contraction_sum\n",
    "def vanilla_SDE_error(beta = 1, num_steps = 160, rounds = 5, S_max = high, S_min = low, strategy = False):\n",
    "        \n",
    "    def one_step_vanilla(t_cur, t_next, beta, x_cur, use_true_score=False):\n",
    "        t_hat = t_cur\n",
    "        x_hat = x_cur\n",
    "        \n",
    "        c_in = 1/(model.std_data ** 2 + t_hat ** 2).sqrt()\n",
    "        if not use_true_score:\n",
    "            with torch.no_grad():\n",
    "                denoised = model(x_hat * c_in, t_hat)\n",
    "        else:\n",
    "            denoised = true_score(x_hat, X.cuda() / std_data, (t_hat).cuda())\n",
    "        d_cur = (x_hat - denoised) / t_hat\n",
    "        noise = torch.randn_like(x_hat)\n",
    "        x_next = x_hat + (beta + 1) * (t_next - t_hat) * d_cur + torch.sqrt(2 * beta * t_hat * (t_hat - t_next)) * noise\n",
    "        return x_next\n",
    "\n",
    "    with torch.inference_mode():\n",
    "        error_sum = 0\n",
    "        approximation_sum = 0\n",
    "        contraction_sum = 0\n",
    "        NFE = num_steps\n",
    "        for times in range(rounds):\n",
    "            gamma = S_churn / num_steps\n",
    "            t_steps = get_steps(min_t, fake_t, num_steps, rho)\n",
    "            x_next = init\n",
    "            x_true = init if strategy else perturb(X.cuda() / std_data, fake_t)\n",
    "            for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                inside = (t_cur <= S_max) & (t_next > S_min)\n",
    "                x_next = one_step_vanilla(t_cur, t_next, beta if inside else 0, x_next, False)\n",
    "                x_true = one_step_vanilla(t_cur, t_next, beta if inside else 0, x_true, strategy)\n",
    "            x_next = one_step_vanilla(t_steps[-1], 0, 0, x_next, False)\n",
    "            x_true = one_step_vanilla(t_steps[-1], 0, 0, x_true, strategy)\n",
    "            error = w2_dist(X.cuda(), get_result(x_next))\n",
    "            approx = w2_dist(get_result(x_next), get_result(x_true))\n",
    "            contraction = w2_dist(X.cuda(), get_result(x_true))\n",
    "            if not strategy:\n",
    "                approx, contraction = contraction, approx\n",
    "            error_sum += error\n",
    "            approximation_sum += approx\n",
    "            contraction_sum += contraction\n",
    "        error_sum /= rounds\n",
    "        approximation_sum /= rounds\n",
    "        contraction_sum /= rounds\n",
    "        return NFE, error_sum, approximation_sum, contraction_sum\n",
    "def ODE_error(num_steps = 160, rounds = 5, strategy = False):\n",
    "    \n",
    "    def one_step_vanilla(t_cur, t_next, beta, x_cur, use_true_score=False):\n",
    "        t_hat = t_cur\n",
    "        x_hat = x_cur\n",
    "        beta = 0\n",
    "        \n",
    "        c_in = 1/(model.std_data ** 2 + t_hat ** 2).sqrt()\n",
    "        if not use_true_score:\n",
    "            with torch.no_grad():\n",
    "                denoised = model(x_hat * c_in, t_hat)\n",
    "        else:\n",
    "            denoised = true_score(x_hat, X.cuda() / std_data, (t_hat).cuda())\n",
    "        d_cur = (x_hat - denoised) / t_hat\n",
    "        noise = torch.randn_like(x_hat)\n",
    "        x_next = x_hat + (beta + 1) * (t_next - t_hat) * d_cur + torch.sqrt(2 * beta * t_hat * (t_hat - t_next)) * noise\n",
    "        return x_next\n",
    "\n",
    "    with torch.inference_mode():\n",
    "        error_sum = 0\n",
    "        approximation_sum = 0\n",
    "        contraction_sum = 0\n",
    "        NFE = num_steps\n",
    "        for times in range(rounds):\n",
    "            gamma = S_churn / num_steps\n",
    "            t_steps = get_steps(min_t, fake_t, num_steps, rho)\n",
    "            x_next = init\n",
    "            x_true = init if strategy else perturb(X.cuda() / std_data, fake_t)\n",
    "            for (t_cur, t_next) in tqdm(zip(t_steps[:-1], t_steps[1:])):\n",
    "                inside = (t_cur <= S_max) & (t_next > S_min)\n",
    "                x_next = one_step_vanilla(t_cur, t_next, 0, x_next, False)\n",
    "                x_true = one_step_vanilla(t_cur, t_next, 0, x_true, strategy)\n",
    "            x_next = one_step_vanilla(t_steps[-1], 0, 0, x_next, False)\n",
    "            x_true = one_step_vanilla(t_steps[-1], 0, 0, x_true, strategy)\n",
    "            error = w2_dist(X.cuda(), get_result(x_next))\n",
    "            approx = w2_dist(get_result(x_next), get_result(x_true))\n",
    "            contraction = w2_dist(X.cuda(), get_result(x_true))\n",
    "            if not strategy:\n",
    "                approx, contraction = contraction, approx\n",
    "            error_sum += error\n",
    "            approximation_sum += approx\n",
    "            contraction_sum += contraction\n",
    "        error_sum /= rounds\n",
    "        approximation_sum /= rounds\n",
    "        contraction_sum /= rounds\n",
    "        return NFE, error_sum, approximation_sum, contraction_sum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e916d8e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "SDE_data = []\n",
    "restart_data = []\n",
    "vanilla_data = []\n",
    "ODE_data = []\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "96544e0d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 323.56it/s]\n",
      "19it [00:00, 666.42it/s]\n",
      "19it [00:00, 693.83it/s]\n",
      "19it [00:00, 329.73it/s]\n",
      "19it [00:00, 387.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (20, 0.8914044456062266, 0.6948242285853266, 0.881702654617278)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 578.74it/s]\n",
      "39it [00:00, 767.75it/s]\n",
      "39it [00:00, 539.63it/s]\n",
      "39it [00:00, 446.57it/s]\n",
      "39it [00:00, 670.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (40, 0.8968616946050588, 0.6873915834393347, 0.8724307873944595)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "639it [00:01, 586.39it/s]\n",
      "639it [00:01, 602.70it/s]\n",
      "639it [00:01, 632.70it/s]\n",
      "639it [00:00, 640.75it/s]\n",
      "639it [00:00, 681.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (640, 0.9039619380400499, 0.6866530113817723, 0.8828088838382898)\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for steps in [20, 40, 640]:\n",
    "    err = ODE_error(num_steps = steps, rounds = 5, strategy = False)\n",
    "    ODE_data.append(err)\n",
    "    print(\"ODE\", err)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fdb33871",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "79it [00:00, 548.02it/s]\n",
      "79it [00:00, 615.09it/s]\n",
      "79it [00:00, 499.39it/s]\n",
      "79it [00:00, 688.27it/s]\n",
      "79it [00:00, 619.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (80, 0.9004135045974151, 0.6899299184604413, 0.8859646956917487)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "159it [00:00, 596.69it/s]\n",
      "159it [00:00, 598.19it/s]\n",
      "159it [00:00, 571.05it/s]\n",
      "159it [00:00, 565.08it/s]\n",
      "159it [00:00, 645.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (160, 0.9023963591572531, 0.6918929361796647, 0.8881615867593119)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 651.63it/s]\n",
      "319it [00:00, 644.96it/s]\n",
      "319it [00:00, 595.28it/s]\n",
      "319it [00:00, 618.95it/s]\n",
      "319it [00:00, 655.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ODE (320, 0.9034297484275031, 0.6862599828313526, 0.8837322063358395)\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for steps in [80, 160, 320]:\n",
    "    err = ODE_error(num_steps = steps, rounds = 5, strategy = False)\n",
    "    ODE_data.append(err)\n",
    "    print(\"ODE\", err)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "133631fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load SDE_data\n",
    "import pickle\n",
    "def save_SDE():\n",
    "    with open('SDE_data.pkl', 'wb') as f:\n",
    "        pickle.dump(SDE_data, f)\n",
    "def load_SDE():\n",
    "    global SDE_data\n",
    "    with open('SDE_data.pkl', 'rb') as f:\n",
    "        SDE_data = pickle.load(f)\n",
    "def save_restart():\n",
    "    with open('restart_data.pkl', 'wb') as f:\n",
    "        pickle.dump(restart_data, f)\n",
    "def load_restart():\n",
    "    global restart_data\n",
    "    with open('restart_data.pkl', 'rb') as f:\n",
    "        restart_data = pickle.load(f)\n",
    "def save_vanilla():\n",
    "    with open('vanilla_data.pkl', 'wb') as f:\n",
    "        pickle.dump(vanilla_data, f)\n",
    "def load_vanilla():\n",
    "    global vanilla_data\n",
    "    with open('vanilla_data.pkl', 'rb') as f:\n",
    "        vanilla_data = pickle.load(f)\n",
    "def save_ODE():\n",
    "    with open('ODE_data.pkl', 'wb') as f:\n",
    "        pickle.dump(ODE_data, f)\n",
    "def load_ODE():\n",
    "    global ODE_data\n",
    "    with open('ODE_data.pkl', 'rb') as f:\n",
    "        ODE_data = pickle.load(f)\n",
    "# save_SDE()\n",
    "# save_restart()\n",
    "load_restart()\n",
    "load_SDE()\n",
    "load_vanilla()\n",
    "load_ODE()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "id": "8f077693",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 710.91it/s]\n",
      "319it [00:00, 723.64it/s]\n",
      "319it [00:00, 725.31it/s]\n",
      "319it [00:00, 741.15it/s]\n",
      "319it [00:00, 739.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.9034297484275031, 0.6881320524358292, 0.8911930557956005)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 748.21it/s]\n",
      "319it [00:00, 750.55it/s]\n",
      "319it [00:00, 744.58it/s]\n",
      "319it [00:00, 734.19it/s]\n",
      "319it [00:00, 749.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.9053446092126295, 0.6926694628302756, 0.8962289544759109)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 746.69it/s]\n",
      "319it [00:00, 747.41it/s]\n",
      "319it [00:00, 746.56it/s]\n",
      "319it [00:00, 747.42it/s]\n",
      "319it [00:00, 744.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.9029666340306166, 0.6919188699671147, 0.9035262853883266)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 749.57it/s]\n",
      "319it [00:00, 747.77it/s]\n",
      "319it [00:00, 751.32it/s]\n",
      "319it [00:00, 744.46it/s]\n",
      "319it [00:00, 748.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8898671026070829, 0.6939330258027662, 0.883492051465214)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 679.59it/s]\n",
      "319it [00:00, 725.24it/s]\n",
      "319it [00:00, 732.43it/s]\n",
      "319it [00:00, 743.34it/s]\n",
      "319it [00:00, 712.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8772100103599497, 0.7233050505023659, 0.8718803813650755)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 682.94it/s]\n",
      "319it [00:00, 710.21it/s]\n",
      "319it [00:00, 732.46it/s]\n",
      "319it [00:00, 673.43it/s]\n",
      "319it [00:00, 689.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8792199351642804, 0.7151795507662788, 0.8633343878740982)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 723.15it/s]\n",
      "319it [00:00, 735.87it/s]\n",
      "319it [00:00, 739.21it/s]\n",
      "319it [00:00, 742.87it/s]\n",
      "319it [00:00, 740.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8447741708446628, 0.7477209293585216, 0.8237639013268445)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 723.18it/s]\n",
      "319it [00:00, 737.06it/s]\n",
      "319it [00:00, 691.89it/s]\n",
      "319it [00:00, 705.11it/s]\n",
      "319it [00:00, 743.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8240037599343664, 0.8012308134502609, 0.8561934248886288)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 725.91it/s]\n",
      "319it [00:00, 694.92it/s]\n",
      "319it [00:00, 745.09it/s]\n",
      "319it [00:00, 745.09it/s]\n",
      "319it [00:00, 750.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.7701639089445691, 0.8030858030608318, 0.7662590182062374)\n"
     ]
    }
   ],
   "source": [
    "SDE_data = []\n",
    "for steps in [320]:#[40, 80, 160, 320]:\n",
    "    for S_churn in [0, 1, 2, 4, 8, 16, 32, 48, 64]:\n",
    "        err = SDE_error(steps, S_churn, rounds = 5)\n",
    "        print(err)\n",
    "        SDE_data.append(err)\n",
    "# SDE_data = map(x[-1], SDE_data)\n",
    "save_SDE()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "47f461c1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 727.61it/s]\n",
      "319it [00:00, 747.30it/s]\n",
      "319it [00:00, 724.99it/s]\n",
      "319it [00:00, 758.08it/s]\n",
      "319it [00:00, 746.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.9034297484275031, 0.6799148452304866, 0.8896848471418629)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 748.79it/s]\n",
      "319it [00:00, 737.14it/s]\n",
      "319it [00:00, 742.85it/s]\n",
      "319it [00:00, 728.15it/s]\n",
      "319it [00:00, 757.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8992097715669054, 0.6905613544884935, 0.8870935002937891)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 752.99it/s]\n",
      "319it [00:00, 737.87it/s]\n",
      "319it [00:00, 727.38it/s]\n",
      "319it [00:00, 753.77it/s]\n",
      "319it [00:00, 758.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.908722878491812, 0.6909970331905826, 0.9080558682257198)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 752.09it/s]\n",
      "319it [00:00, 741.90it/s]\n",
      "319it [00:00, 734.96it/s]\n",
      "319it [00:00, 717.46it/s]\n",
      "319it [00:00, 745.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.9061245867784727, 0.7108464340826476, 0.9202623918704143)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 755.16it/s]\n",
      "319it [00:00, 754.27it/s]\n",
      "319it [00:00, 752.16it/s]\n",
      "319it [00:00, 754.55it/s]\n",
      "319it [00:00, 756.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8873483729992051, 0.7082891551781964, 0.8759849878327491)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 754.01it/s]\n",
      "319it [00:00, 753.65it/s]\n",
      "319it [00:00, 758.18it/s]\n",
      "319it [00:00, 758.43it/s]\n",
      "319it [00:00, 758.41it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8834072171137881, 0.7161390164739283, 0.8778208099614325)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 759.28it/s]\n",
      "319it [00:00, 757.18it/s]\n",
      "319it [00:00, 758.28it/s]\n",
      "319it [00:00, 758.35it/s]\n",
      "319it [00:00, 761.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8818740806646467, 0.7330987289216984, 0.88860071775996)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 758.20it/s]\n",
      "319it [00:00, 755.50it/s]\n",
      "319it [00:00, 759.77it/s]\n",
      "319it [00:00, 735.73it/s]\n",
      "319it [00:00, 747.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(320, 0.8589945696922943, 0.7404704243416408, 0.8594075331935807)\n"
     ]
    }
   ],
   "source": [
    "vanilla_data = []\n",
    "for beta in [0, 0.25, 0.5, 1, 1.5, 2, 4, 8]:\n",
    "    error = vanilla_SDE_error(beta, 320, 5)\n",
    "    print(error)\n",
    "    vanilla_data.append(error)\n",
    "save_vanilla()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "09613f68",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 461.80it/s]\n",
      "39it [00:00, 784.50it/s]\n",
      "39it [00:00, 766.08it/s]\n",
      "39it [00:00, 797.70it/s]\n",
      "39it [00:00, 782.76it/s]\n",
      "39it [00:00, 787.52it/s]\n",
      "39it [00:00, 781.79it/s]\n",
      "39it [00:00, 792.09it/s]\n",
      "39it [00:00, 785.04it/s]\n",
      "39it [00:00, 787.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(79, 0.8990233881096819, 0.6917913835599272, 0.871435429705173)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 781.44it/s]\n",
      "39it [00:00, 779.12it/s]\n",
      "39it [00:00, 795.12it/s]\n",
      "39it [00:00, 786.78it/s]\n",
      "39it [00:00, 784.41it/s]\n",
      "39it [00:00, 786.69it/s]\n",
      "39it [00:00, 791.70it/s]\n",
      "39it [00:00, 785.08it/s]\n",
      "39it [00:00, 790.15it/s]\n",
      "39it [00:00, 793.05it/s]\n",
      "39it [00:00, 780.38it/s]\n",
      "39it [00:00, 778.51it/s]\n",
      "39it [00:00, 790.83it/s]\n",
      "39it [00:00, 784.52it/s]\n",
      "39it [00:00, 685.03it/s]\n",
      "39it [00:00, 783.30it/s]\n",
      "39it [00:00, 790.99it/s]\n",
      "39it [00:00, 780.05it/s]\n",
      "39it [00:00, 782.75it/s]\n",
      "39it [00:00, 779.30it/s]\n",
      "39it [00:00, 766.41it/s]\n",
      "39it [00:00, 743.49it/s]\n",
      "39it [00:00, 787.88it/s]\n",
      "39it [00:00, 793.19it/s]\n",
      "39it [00:00, 760.92it/s]\n",
      "39it [00:00, 660.09it/s]\n",
      "39it [00:00, 756.11it/s]\n",
      "39it [00:00, 747.96it/s]\n",
      "39it [00:00, 776.46it/s]\n",
      "39it [00:00, 785.20it/s]\n",
      "39it [00:00, 789.99it/s]\n",
      "39it [00:00, 770.09it/s]\n",
      "39it [00:00, 782.83it/s]\n",
      "39it [00:00, 785.41it/s]\n",
      "39it [00:00, 792.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(274, 0.8768556461149484, 0.7369548856684872, 0.8641487956175702)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 785.85it/s]\n",
      "39it [00:00, 768.98it/s]\n",
      "39it [00:00, 793.11it/s]\n",
      "39it [00:00, 784.83it/s]\n",
      "39it [00:00, 791.59it/s]\n",
      "39it [00:00, 783.51it/s]\n",
      "39it [00:00, 790.14it/s]\n",
      "39it [00:00, 785.56it/s]\n",
      "39it [00:00, 792.23it/s]\n",
      "39it [00:00, 780.90it/s]\n",
      "39it [00:00, 795.28it/s]\n",
      "39it [00:00, 780.60it/s]\n",
      "39it [00:00, 790.74it/s]\n",
      "39it [00:00, 793.24it/s]\n",
      "39it [00:00, 766.73it/s]\n",
      "39it [00:00, 798.14it/s]\n",
      "39it [00:00, 785.87it/s]\n",
      "39it [00:00, 783.91it/s]\n",
      "39it [00:00, 795.49it/s]\n",
      "39it [00:00, 786.95it/s]\n",
      "39it [00:00, 791.03it/s]\n",
      "39it [00:00, 786.34it/s]\n",
      "39it [00:00, 780.17it/s]\n",
      "39it [00:00, 788.29it/s]\n",
      "39it [00:00, 798.62it/s]\n",
      "39it [00:00, 792.90it/s]\n",
      "39it [00:00, 807.46it/s]\n",
      "39it [00:00, 792.45it/s]\n",
      "39it [00:00, 795.99it/s]\n",
      "39it [00:00, 799.05it/s]\n",
      "39it [00:00, 788.02it/s]\n",
      "39it [00:00, 790.07it/s]\n",
      "39it [00:00, 796.05it/s]\n",
      "39it [00:00, 789.08it/s]\n",
      "39it [00:00, 747.83it/s]\n",
      "39it [00:00, 744.26it/s]\n",
      "39it [00:00, 796.02it/s]\n",
      "39it [00:00, 785.03it/s]\n",
      "39it [00:00, 799.81it/s]\n",
      "39it [00:00, 786.93it/s]\n",
      "39it [00:00, 762.17it/s]\n",
      "39it [00:00, 790.09it/s]\n",
      "39it [00:00, 795.06it/s]\n",
      "39it [00:00, 785.34it/s]\n",
      "39it [00:00, 796.11it/s]\n",
      "39it [00:00, 785.26it/s]\n",
      "39it [00:00, 796.03it/s]\n",
      "39it [00:00, 789.30it/s]\n",
      "39it [00:00, 772.06it/s]\n",
      "39it [00:00, 786.33it/s]\n",
      "39it [00:00, 791.01it/s]\n",
      "39it [00:00, 786.09it/s]\n",
      "39it [00:00, 789.42it/s]\n",
      "39it [00:00, 785.02it/s]\n",
      "39it [00:00, 790.42it/s]\n",
      "39it [00:00, 784.05it/s]\n",
      "39it [00:00, 791.27it/s]\n",
      "39it [00:00, 784.32it/s]\n",
      "39it [00:00, 794.84it/s]\n",
      "39it [00:00, 789.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(469, 0.8308351474957105, 0.7674167585997923, 0.8494618413913131)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 751.82it/s]\n",
      "39it [00:00, 746.85it/s]\n",
      "39it [00:00, 749.88it/s]\n",
      "39it [00:00, 787.58it/s]\n",
      "39it [00:00, 671.21it/s]\n",
      "39it [00:00, 746.47it/s]\n",
      "39it [00:00, 791.06it/s]\n",
      "39it [00:00, 785.27it/s]\n",
      "39it [00:00, 792.49it/s]\n",
      "39it [00:00, 759.24it/s]\n",
      "39it [00:00, 700.83it/s]\n",
      "39it [00:00, 783.66it/s]\n",
      "39it [00:00, 784.44it/s]\n",
      "39it [00:00, 789.45it/s]\n",
      "39it [00:00, 787.19it/s]\n",
      "39it [00:00, 766.33it/s]\n",
      "39it [00:00, 789.94it/s]\n",
      "39it [00:00, 769.07it/s]\n",
      "39it [00:00, 795.97it/s]\n",
      "39it [00:00, 788.46it/s]\n",
      "39it [00:00, 784.17it/s]\n",
      "39it [00:00, 794.76it/s]\n",
      "39it [00:00, 769.14it/s]\n",
      "39it [00:00, 800.42it/s]\n",
      "39it [00:00, 787.38it/s]\n",
      "39it [00:00, 782.61it/s]\n",
      "39it [00:00, 796.90it/s]\n",
      "39it [00:00, 778.31it/s]\n",
      "39it [00:00, 783.66it/s]\n",
      "39it [00:00, 615.54it/s]\n",
      "39it [00:00, 558.14it/s]\n",
      "39it [00:00, 781.48it/s]\n",
      "39it [00:00, 710.00it/s]\n",
      "39it [00:00, 720.36it/s]\n",
      "39it [00:00, 773.98it/s]\n",
      "39it [00:00, 786.59it/s]\n",
      "39it [00:00, 767.45it/s]\n",
      "39it [00:00, 791.61it/s]\n",
      "39it [00:00, 784.86it/s]\n",
      "39it [00:00, 785.71it/s]\n",
      "39it [00:00, 780.36it/s]\n",
      "39it [00:00, 739.56it/s]\n",
      "39it [00:00, 693.51it/s]\n",
      "39it [00:00, 776.60it/s]\n",
      "39it [00:00, 768.73it/s]\n",
      "39it [00:00, 742.57it/s]\n",
      "39it [00:00, 687.33it/s]\n",
      "39it [00:00, 731.66it/s]\n",
      "39it [00:00, 731.40it/s]\n",
      "39it [00:00, 733.04it/s]\n",
      "39it [00:00, 738.79it/s]\n",
      "39it [00:00, 775.80it/s]\n",
      "39it [00:00, 789.66it/s]\n",
      "39it [00:00, 789.60it/s]\n",
      "39it [00:00, 778.88it/s]\n",
      "39it [00:00, 775.54it/s]\n",
      "39it [00:00, 759.78it/s]\n",
      "39it [00:00, 700.11it/s]\n",
      "39it [00:00, 735.18it/s]\n",
      "39it [00:00, 748.69it/s]\n",
      "39it [00:00, 739.75it/s]\n",
      "39it [00:00, 742.86it/s]\n",
      "39it [00:00, 729.46it/s]\n",
      "39it [00:00, 743.47it/s]\n",
      "39it [00:00, 783.67it/s]\n",
      "39it [00:00, 775.40it/s]\n",
      "39it [00:00, 775.92it/s]\n",
      "39it [00:00, 765.49it/s]\n",
      "39it [00:00, 716.48it/s]\n",
      "39it [00:00, 754.19it/s]\n",
      "39it [00:00, 714.28it/s]\n",
      "39it [00:00, 744.33it/s]\n",
      "39it [00:00, 780.15it/s]\n",
      "39it [00:00, 742.97it/s]\n",
      "39it [00:00, 745.37it/s]\n",
      "39it [00:00, 742.31it/s]\n",
      "39it [00:00, 746.78it/s]\n",
      "39it [00:00, 760.60it/s]\n",
      "39it [00:00, 749.38it/s]\n",
      "39it [00:00, 707.81it/s]\n",
      "39it [00:00, 747.68it/s]\n",
      "39it [00:00, 747.73it/s]\n",
      "39it [00:00, 768.53it/s]\n",
      "39it [00:00, 751.61it/s]\n",
      "39it [00:00, 778.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(664, 0.8014975101019723, 0.8047654215598665, 0.8576349237111736)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 767.11it/s]\n",
      "39it [00:00, 751.95it/s]\n",
      "39it [00:00, 785.35it/s]\n",
      "39it [00:00, 773.71it/s]\n",
      "39it [00:00, 771.97it/s]\n",
      "39it [00:00, 755.32it/s]\n",
      "39it [00:00, 743.60it/s]\n",
      "39it [00:00, 677.24it/s]\n",
      "39it [00:00, 747.05it/s]\n",
      "39it [00:00, 753.18it/s]\n",
      "39it [00:00, 726.23it/s]\n",
      "39it [00:00, 752.96it/s]\n",
      "39it [00:00, 739.25it/s]\n",
      "39it [00:00, 600.60it/s]\n",
      "39it [00:00, 751.80it/s]\n",
      "39it [00:00, 748.80it/s]\n",
      "39it [00:00, 737.43it/s]\n",
      "39it [00:00, 758.21it/s]\n",
      "39it [00:00, 725.13it/s]\n",
      "39it [00:00, 701.02it/s]\n",
      "39it [00:00, 775.91it/s]\n",
      "39it [00:00, 774.07it/s]\n",
      "39it [00:00, 779.69it/s]\n",
      "39it [00:00, 785.61it/s]\n",
      "39it [00:00, 778.64it/s]\n",
      "39it [00:00, 782.08it/s]\n",
      "39it [00:00, 784.99it/s]\n",
      "39it [00:00, 773.60it/s]\n",
      "39it [00:00, 770.28it/s]\n",
      "39it [00:00, 784.76it/s]\n",
      "39it [00:00, 779.34it/s]\n",
      "39it [00:00, 777.38it/s]\n",
      "39it [00:00, 780.38it/s]\n",
      "39it [00:00, 773.30it/s]\n",
      "39it [00:00, 790.27it/s]\n",
      "39it [00:00, 776.66it/s]\n",
      "39it [00:00, 779.73it/s]\n",
      "39it [00:00, 786.62it/s]\n",
      "39it [00:00, 774.12it/s]\n",
      "39it [00:00, 791.77it/s]\n",
      "39it [00:00, 789.69it/s]\n",
      "39it [00:00, 788.77it/s]\n",
      "39it [00:00, 747.68it/s]\n",
      "39it [00:00, 786.38it/s]\n",
      "39it [00:00, 779.81it/s]\n",
      "39it [00:00, 782.64it/s]\n",
      "39it [00:00, 785.83it/s]\n",
      "39it [00:00, 777.46it/s]\n",
      "39it [00:00, 782.96it/s]\n",
      "39it [00:00, 778.63it/s]\n",
      "39it [00:00, 779.17it/s]\n",
      "39it [00:00, 753.38it/s]\n",
      "39it [00:00, 776.52it/s]\n",
      "39it [00:00, 750.23it/s]\n",
      "39it [00:00, 775.42it/s]\n",
      "39it [00:00, 789.76it/s]\n",
      "39it [00:00, 778.22it/s]\n",
      "39it [00:00, 745.91it/s]\n",
      "39it [00:00, 710.70it/s]\n",
      "39it [00:00, 747.24it/s]\n",
      "39it [00:00, 723.26it/s]\n",
      "39it [00:00, 756.98it/s]\n",
      "39it [00:00, 758.95it/s]\n",
      "39it [00:00, 785.54it/s]\n",
      "39it [00:00, 770.49it/s]\n",
      "39it [00:00, 757.79it/s]\n",
      "39it [00:00, 738.39it/s]\n",
      "39it [00:00, 759.29it/s]\n",
      "39it [00:00, 786.22it/s]\n",
      "39it [00:00, 786.48it/s]\n",
      "39it [00:00, 792.54it/s]\n",
      "39it [00:00, 775.06it/s]\n",
      "39it [00:00, 791.08it/s]\n",
      "39it [00:00, 783.03it/s]\n",
      "39it [00:00, 789.88it/s]\n",
      "39it [00:00, 782.70it/s]\n",
      "39it [00:00, 790.28it/s]\n",
      "39it [00:00, 784.44it/s]\n",
      "39it [00:00, 791.63it/s]\n",
      "39it [00:00, 774.18it/s]\n",
      "39it [00:00, 793.83it/s]\n",
      "39it [00:00, 779.76it/s]\n",
      "39it [00:00, 790.10it/s]\n",
      "39it [00:00, 780.89it/s]\n",
      "39it [00:00, 792.89it/s]\n",
      "39it [00:00, 782.07it/s]\n",
      "39it [00:00, 784.77it/s]\n",
      "39it [00:00, 784.25it/s]\n",
      "39it [00:00, 779.41it/s]\n",
      "39it [00:00, 784.14it/s]\n",
      "39it [00:00, 797.31it/s]\n",
      "39it [00:00, 795.34it/s]\n",
      "39it [00:00, 795.46it/s]\n",
      "39it [00:00, 785.61it/s]\n",
      "39it [00:00, 792.33it/s]\n",
      "39it [00:00, 793.26it/s]\n",
      "39it [00:00, 779.86it/s]\n",
      "39it [00:00, 784.10it/s]\n",
      "39it [00:00, 786.34it/s]\n",
      "39it [00:00, 797.10it/s]\n",
      "39it [00:00, 789.04it/s]\n",
      "39it [00:00, 796.11it/s]\n",
      "39it [00:00, 787.39it/s]\n",
      "39it [00:00, 790.64it/s]\n",
      "39it [00:00, 797.56it/s]\n",
      "39it [00:00, 788.24it/s]\n",
      "39it [00:00, 797.56it/s]\n",
      "39it [00:00, 796.03it/s]\n",
      "39it [00:00, 784.03it/s]\n",
      "39it [00:00, 785.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(859, 0.74808097310916, 0.769605275415055, 0.7457382429750464)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 782.88it/s]\n",
      "39it [00:00, 795.02it/s]\n",
      "39it [00:00, 781.76it/s]\n",
      "39it [00:00, 791.62it/s]\n",
      "39it [00:00, 785.68it/s]\n",
      "39it [00:00, 786.69it/s]\n",
      "39it [00:00, 789.61it/s]\n",
      "39it [00:00, 790.75it/s]\n",
      "39it [00:00, 742.93it/s]\n",
      "39it [00:00, 760.49it/s]\n",
      "39it [00:00, 764.03it/s]\n",
      "39it [00:00, 786.66it/s]\n",
      "39it [00:00, 788.69it/s]\n",
      "39it [00:00, 737.68it/s]\n",
      "39it [00:00, 783.03it/s]\n",
      "39it [00:00, 743.14it/s]\n",
      "39it [00:00, 775.58it/s]\n",
      "39it [00:00, 784.23it/s]\n",
      "39it [00:00, 662.41it/s]\n",
      "39it [00:00, 736.37it/s]\n",
      "39it [00:00, 762.57it/s]\n",
      "39it [00:00, 763.08it/s]\n",
      "39it [00:00, 752.74it/s]\n",
      "39it [00:00, 778.24it/s]\n",
      "39it [00:00, 786.48it/s]\n",
      "39it [00:00, 755.13it/s]\n",
      "39it [00:00, 790.12it/s]\n",
      "39it [00:00, 781.82it/s]\n",
      "39it [00:00, 794.58it/s]\n",
      "39it [00:00, 790.43it/s]\n",
      "39it [00:00, 792.43it/s]\n",
      "39it [00:00, 781.64it/s]\n",
      "39it [00:00, 796.08it/s]\n",
      "39it [00:00, 789.14it/s]\n",
      "39it [00:00, 773.07it/s]\n",
      "39it [00:00, 789.83it/s]\n",
      "39it [00:00, 793.81it/s]\n",
      "39it [00:00, 787.59it/s]\n",
      "39it [00:00, 791.02it/s]\n",
      "39it [00:00, 800.22it/s]\n",
      "39it [00:00, 725.34it/s]\n",
      "39it [00:00, 758.06it/s]\n",
      "39it [00:00, 682.73it/s]\n",
      "39it [00:00, 720.44it/s]\n",
      "39it [00:00, 642.48it/s]\n",
      "39it [00:00, 751.12it/s]\n",
      "39it [00:00, 757.04it/s]\n",
      "39it [00:00, 759.86it/s]\n",
      "39it [00:00, 752.33it/s]\n",
      "39it [00:00, 768.01it/s]\n",
      "39it [00:00, 699.51it/s]\n",
      "39it [00:00, 780.75it/s]\n",
      "39it [00:00, 761.59it/s]\n",
      "39it [00:00, 773.14it/s]\n",
      "39it [00:00, 688.49it/s]\n",
      "39it [00:00, 746.76it/s]\n",
      "39it [00:00, 773.86it/s]\n",
      "39it [00:00, 671.54it/s]\n",
      "39it [00:00, 748.05it/s]\n",
      "39it [00:00, 748.55it/s]\n",
      "39it [00:00, 749.79it/s]\n",
      "39it [00:00, 673.44it/s]\n",
      "39it [00:00, 750.55it/s]\n",
      "39it [00:00, 774.87it/s]\n",
      "39it [00:00, 766.52it/s]\n",
      "39it [00:00, 786.88it/s]\n",
      "39it [00:00, 648.72it/s]\n",
      "39it [00:00, 752.22it/s]\n",
      "39it [00:00, 778.12it/s]\n",
      "39it [00:00, 773.36it/s]\n",
      "39it [00:00, 682.53it/s]\n",
      "39it [00:00, 748.24it/s]\n",
      "39it [00:00, 753.72it/s]\n",
      "39it [00:00, 738.13it/s]\n",
      "39it [00:00, 687.21it/s]\n",
      "39it [00:00, 721.46it/s]\n",
      "39it [00:00, 752.22it/s]\n",
      "39it [00:00, 745.88it/s]\n",
      "39it [00:00, 725.61it/s]\n",
      "39it [00:00, 754.97it/s]\n",
      "39it [00:00, 522.05it/s]\n",
      "39it [00:00, 786.29it/s]\n",
      "39it [00:00, 759.11it/s]\n",
      "39it [00:00, 759.32it/s]\n",
      "39it [00:00, 748.07it/s]\n",
      "39it [00:00, 759.38it/s]\n",
      "39it [00:00, 771.35it/s]\n",
      "39it [00:00, 780.91it/s]\n",
      "39it [00:00, 754.53it/s]\n",
      "39it [00:00, 781.80it/s]\n",
      "39it [00:00, 791.93it/s]\n",
      "39it [00:00, 755.12it/s]\n",
      "39it [00:00, 787.35it/s]\n",
      "39it [00:00, 780.98it/s]\n",
      "39it [00:00, 759.86it/s]\n",
      "39it [00:00, 753.30it/s]\n",
      "39it [00:00, 781.13it/s]\n",
      "39it [00:00, 794.53it/s]\n",
      "39it [00:00, 789.99it/s]\n",
      "39it [00:00, 794.72it/s]\n",
      "39it [00:00, 755.12it/s]\n",
      "39it [00:00, 725.32it/s]\n",
      "39it [00:00, 649.93it/s]\n",
      "39it [00:00, 548.12it/s]\n",
      "39it [00:00, 669.74it/s]\n",
      "39it [00:00, 788.86it/s]\n",
      "39it [00:00, 727.69it/s]\n",
      "39it [00:00, 787.14it/s]\n",
      "39it [00:00, 784.55it/s]\n",
      "39it [00:00, 749.78it/s]\n",
      "39it [00:00, 744.83it/s]\n",
      "39it [00:00, 783.35it/s]\n",
      "39it [00:00, 777.47it/s]\n",
      "39it [00:00, 730.83it/s]\n",
      "39it [00:00, 764.27it/s]\n",
      "39it [00:00, 747.83it/s]\n",
      "39it [00:00, 736.32it/s]\n",
      "39it [00:00, 731.81it/s]\n",
      "39it [00:00, 747.15it/s]\n",
      "39it [00:00, 695.04it/s]\n",
      "39it [00:00, 661.63it/s]\n",
      "39it [00:00, 761.63it/s]\n",
      "39it [00:00, 762.62it/s]\n",
      "39it [00:00, 756.31it/s]\n",
      "39it [00:00, 790.45it/s]\n",
      "39it [00:00, 783.47it/s]\n",
      "39it [00:00, 782.60it/s]\n",
      "39it [00:00, 750.84it/s]\n",
      "39it [00:00, 689.26it/s]\n",
      "39it [00:00, 760.24it/s]\n",
      "39it [00:00, 694.83it/s]\n",
      "39it [00:00, 753.75it/s]\n",
      "39it [00:00, 761.83it/s]\n",
      "39it [00:00, 762.64it/s]\n",
      "39it [00:00, 765.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1054, 0.7472303577798175, 0.7856132844921058, 0.7287675983250731)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 733.78it/s]\n",
      "39it [00:00, 749.95it/s]\n",
      "39it [00:00, 755.07it/s]\n",
      "39it [00:00, 752.25it/s]\n",
      "39it [00:00, 753.38it/s]\n",
      "39it [00:00, 751.20it/s]\n",
      "39it [00:00, 747.00it/s]\n",
      "39it [00:00, 749.40it/s]\n",
      "39it [00:00, 749.17it/s]\n",
      "39it [00:00, 721.98it/s]\n",
      "39it [00:00, 781.88it/s]\n",
      "39it [00:00, 783.08it/s]\n",
      "39it [00:00, 787.38it/s]\n",
      "39it [00:00, 760.00it/s]\n",
      "39it [00:00, 786.17it/s]\n",
      "39it [00:00, 780.65it/s]\n",
      "39it [00:00, 785.39it/s]\n",
      "39it [00:00, 783.69it/s]\n",
      "39it [00:00, 780.42it/s]\n",
      "39it [00:00, 788.31it/s]\n",
      "39it [00:00, 785.39it/s]\n",
      "39it [00:00, 780.42it/s]\n",
      "39it [00:00, 780.55it/s]\n",
      "39it [00:00, 787.39it/s]\n",
      "39it [00:00, 793.31it/s]\n",
      "39it [00:00, 784.19it/s]\n",
      "39it [00:00, 784.09it/s]\n",
      "39it [00:00, 772.49it/s]\n",
      "39it [00:00, 782.61it/s]\n",
      "39it [00:00, 679.04it/s]\n",
      "39it [00:00, 757.66it/s]\n",
      "39it [00:00, 635.76it/s]\n",
      "39it [00:00, 789.46it/s]\n",
      "39it [00:00, 789.06it/s]\n",
      "39it [00:00, 798.20it/s]\n",
      "39it [00:00, 734.81it/s]\n",
      "39it [00:00, 753.52it/s]\n",
      "39it [00:00, 752.54it/s]\n",
      "39it [00:00, 783.30it/s]\n",
      "39it [00:00, 750.34it/s]\n",
      "39it [00:00, 754.61it/s]\n",
      "39it [00:00, 752.18it/s]\n",
      "39it [00:00, 758.19it/s]\n",
      "39it [00:00, 755.37it/s]\n",
      "39it [00:00, 762.44it/s]\n",
      "39it [00:00, 737.61it/s]\n",
      "39it [00:00, 762.98it/s]\n",
      "39it [00:00, 744.21it/s]\n",
      "39it [00:00, 756.50it/s]\n",
      "39it [00:00, 745.93it/s]\n",
      "39it [00:00, 755.67it/s]\n",
      "39it [00:00, 748.05it/s]\n",
      "39it [00:00, 748.61it/s]\n",
      "39it [00:00, 756.21it/s]\n",
      "39it [00:00, 748.18it/s]\n",
      "39it [00:00, 751.56it/s]\n",
      "39it [00:00, 742.00it/s]\n",
      "39it [00:00, 748.28it/s]\n",
      "39it [00:00, 748.86it/s]\n",
      "39it [00:00, 718.23it/s]\n",
      "39it [00:00, 753.14it/s]\n",
      "39it [00:00, 742.36it/s]\n",
      "39it [00:00, 744.32it/s]\n",
      "39it [00:00, 746.15it/s]\n",
      "39it [00:00, 784.70it/s]\n",
      "39it [00:00, 791.40it/s]\n",
      "39it [00:00, 803.82it/s]\n",
      "39it [00:00, 792.95it/s]\n",
      "39it [00:00, 785.27it/s]\n",
      "39it [00:00, 789.88it/s]\n",
      "39it [00:00, 792.60it/s]\n",
      "39it [00:00, 785.08it/s]\n",
      "39it [00:00, 787.91it/s]\n",
      "39it [00:00, 794.95it/s]\n",
      "39it [00:00, 781.35it/s]\n",
      "39it [00:00, 787.80it/s]\n",
      "39it [00:00, 798.10it/s]\n",
      "39it [00:00, 782.52it/s]\n",
      "39it [00:00, 785.11it/s]\n",
      "39it [00:00, 785.24it/s]\n",
      "39it [00:00, 793.77it/s]\n",
      "39it [00:00, 776.41it/s]\n",
      "39it [00:00, 796.78it/s]\n",
      "39it [00:00, 786.60it/s]\n",
      "39it [00:00, 774.65it/s]\n",
      "39it [00:00, 789.66it/s]\n",
      "39it [00:00, 791.11it/s]\n",
      "39it [00:00, 782.83it/s]\n",
      "39it [00:00, 791.78it/s]\n",
      "39it [00:00, 784.85it/s]\n",
      "39it [00:00, 792.18it/s]\n",
      "39it [00:00, 782.08it/s]\n",
      "39it [00:00, 792.51it/s]\n",
      "39it [00:00, 783.76it/s]\n",
      "39it [00:00, 789.69it/s]\n",
      "39it [00:00, 791.79it/s]\n",
      "39it [00:00, 781.06it/s]\n",
      "39it [00:00, 784.80it/s]\n",
      "39it [00:00, 783.16it/s]\n",
      "39it [00:00, 782.12it/s]\n",
      "39it [00:00, 779.59it/s]\n",
      "39it [00:00, 780.07it/s]\n",
      "39it [00:00, 776.65it/s]\n",
      "39it [00:00, 782.85it/s]\n",
      "39it [00:00, 778.17it/s]\n",
      "39it [00:00, 781.66it/s]\n",
      "39it [00:00, 780.93it/s]\n",
      "39it [00:00, 781.80it/s]\n",
      "39it [00:00, 779.44it/s]\n",
      "39it [00:00, 777.21it/s]\n",
      "39it [00:00, 776.13it/s]\n",
      "39it [00:00, 733.58it/s]\n",
      "39it [00:00, 775.44it/s]\n",
      "39it [00:00, 783.55it/s]\n",
      "39it [00:00, 774.34it/s]\n",
      "39it [00:00, 782.16it/s]\n",
      "39it [00:00, 776.44it/s]\n",
      "39it [00:00, 784.47it/s]\n",
      "39it [00:00, 790.05it/s]\n",
      "39it [00:00, 762.14it/s]\n",
      "39it [00:00, 789.40it/s]\n",
      "39it [00:00, 675.26it/s]\n",
      "39it [00:00, 780.06it/s]\n",
      "39it [00:00, 792.50it/s]\n",
      "39it [00:00, 712.93it/s]\n",
      "39it [00:00, 788.72it/s]\n",
      "39it [00:00, 660.73it/s]\n",
      "39it [00:00, 784.10it/s]\n",
      "39it [00:00, 784.21it/s]\n",
      "39it [00:00, 784.15it/s]\n",
      "39it [00:00, 793.97it/s]\n",
      "39it [00:00, 780.66it/s]\n",
      "39it [00:00, 791.00it/s]\n",
      "39it [00:00, 786.11it/s]\n",
      "39it [00:00, 783.58it/s]\n",
      "39it [00:00, 789.15it/s]\n",
      "39it [00:00, 781.36it/s]\n",
      "39it [00:00, 783.42it/s]\n",
      "39it [00:00, 783.04it/s]\n",
      "39it [00:00, 784.93it/s]\n",
      "39it [00:00, 746.68it/s]\n",
      "39it [00:00, 746.34it/s]\n",
      "39it [00:00, 782.53it/s]\n",
      "39it [00:00, 790.40it/s]\n",
      "39it [00:00, 780.42it/s]\n",
      "39it [00:00, 788.97it/s]\n",
      "39it [00:00, 761.13it/s]\n",
      "39it [00:00, 781.85it/s]\n",
      "39it [00:00, 785.72it/s]\n",
      "39it [00:00, 790.87it/s]\n",
      "39it [00:00, 783.16it/s]\n",
      "39it [00:00, 790.01it/s]\n",
      "39it [00:00, 758.15it/s]\n",
      "39it [00:00, 756.35it/s]\n",
      "39it [00:00, 708.85it/s]\n",
      "39it [00:00, 720.86it/s]\n",
      "39it [00:00, 714.55it/s]\n",
      "39it [00:00, 717.50it/s]\n",
      "39it [00:00, 727.06it/s]\n",
      "39it [00:00, 714.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1249, 0.7439027449641745, 0.837730237102798, 0.7987425955903893)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 780.50it/s]\n",
      "39it [00:00, 745.69it/s]\n",
      "39it [00:00, 785.54it/s]\n",
      "39it [00:00, 789.18it/s]\n",
      "39it [00:00, 770.08it/s]\n",
      "39it [00:00, 790.97it/s]\n",
      "39it [00:00, 752.98it/s]\n",
      "39it [00:00, 790.04it/s]\n",
      "39it [00:00, 794.49it/s]\n",
      "39it [00:00, 782.86it/s]\n",
      "39it [00:00, 768.95it/s]\n",
      "39it [00:00, 795.27it/s]\n",
      "39it [00:00, 763.68it/s]\n",
      "39it [00:00, 783.48it/s]\n",
      "39it [00:00, 782.15it/s]\n",
      "39it [00:00, 775.32it/s]\n",
      "39it [00:00, 780.32it/s]\n",
      "39it [00:00, 773.01it/s]\n",
      "39it [00:00, 782.12it/s]\n",
      "39it [00:00, 783.20it/s]\n",
      "39it [00:00, 784.93it/s]\n",
      "39it [00:00, 785.47it/s]\n",
      "39it [00:00, 789.37it/s]\n",
      "39it [00:00, 783.62it/s]\n",
      "39it [00:00, 743.29it/s]\n",
      "39it [00:00, 780.68it/s]\n",
      "39it [00:00, 791.14it/s]\n",
      "39it [00:00, 781.38it/s]\n",
      "39it [00:00, 787.89it/s]\n",
      "39it [00:00, 782.62it/s]\n",
      "39it [00:00, 737.65it/s]\n",
      "39it [00:00, 786.79it/s]\n",
      "39it [00:00, 789.71it/s]\n",
      "39it [00:00, 780.41it/s]\n",
      "39it [00:00, 791.39it/s]\n",
      "39it [00:00, 742.55it/s]\n",
      "39it [00:00, 788.75it/s]\n",
      "39it [00:00, 778.60it/s]\n",
      "39it [00:00, 791.74it/s]\n",
      "39it [00:00, 785.60it/s]\n",
      "39it [00:00, 789.24it/s]\n",
      "39it [00:00, 766.60it/s]\n",
      "39it [00:00, 791.74it/s]\n",
      "39it [00:00, 776.50it/s]\n",
      "39it [00:00, 780.60it/s]\n",
      "39it [00:00, 782.66it/s]\n",
      "39it [00:00, 752.70it/s]\n",
      "39it [00:00, 783.68it/s]\n",
      "39it [00:00, 784.85it/s]\n",
      "39it [00:00, 787.30it/s]\n",
      "39it [00:00, 782.38it/s]\n",
      "39it [00:00, 778.45it/s]\n",
      "39it [00:00, 792.75it/s]\n",
      "39it [00:00, 775.21it/s]\n",
      "39it [00:00, 791.32it/s]\n",
      "39it [00:00, 787.55it/s]\n",
      "39it [00:00, 782.52it/s]\n",
      "39it [00:00, 794.44it/s]\n",
      "39it [00:00, 781.83it/s]\n",
      "39it [00:00, 775.61it/s]\n",
      "39it [00:00, 749.75it/s]\n",
      "39it [00:00, 790.75it/s]\n",
      "39it [00:00, 785.00it/s]\n",
      "39it [00:00, 785.00it/s]\n",
      "39it [00:00, 783.45it/s]\n",
      "39it [00:00, 765.04it/s]\n",
      "39it [00:00, 772.77it/s]\n",
      "39it [00:00, 789.50it/s]\n",
      "39it [00:00, 778.62it/s]\n",
      "39it [00:00, 790.27it/s]\n",
      "39it [00:00, 797.94it/s]\n",
      "39it [00:00, 741.44it/s]\n",
      "39it [00:00, 789.61it/s]\n",
      "39it [00:00, 778.94it/s]\n",
      "39it [00:00, 790.98it/s]\n",
      "39it [00:00, 790.43it/s]\n",
      "39it [00:00, 783.27it/s]\n",
      "39it [00:00, 788.17it/s]\n",
      "39it [00:00, 781.34it/s]\n",
      "39it [00:00, 795.47it/s]\n",
      "39it [00:00, 787.45it/s]\n",
      "39it [00:00, 787.74it/s]\n",
      "39it [00:00, 792.60it/s]\n",
      "39it [00:00, 786.91it/s]\n",
      "39it [00:00, 787.97it/s]\n",
      "39it [00:00, 760.34it/s]\n",
      "39it [00:00, 785.81it/s]\n",
      "39it [00:00, 792.34it/s]\n",
      "39it [00:00, 786.42it/s]\n",
      "39it [00:00, 793.45it/s]\n",
      "39it [00:00, 778.18it/s]\n",
      "39it [00:00, 786.48it/s]\n",
      "39it [00:00, 794.03it/s]\n",
      "39it [00:00, 785.50it/s]\n",
      "39it [00:00, 749.49it/s]\n",
      "39it [00:00, 772.69it/s]\n",
      "39it [00:00, 777.52it/s]\n",
      "39it [00:00, 789.40it/s]\n",
      "39it [00:00, 797.93it/s]\n",
      "39it [00:00, 788.65it/s]\n",
      "39it [00:00, 747.95it/s]\n",
      "39it [00:00, 790.93it/s]\n",
      "39it [00:00, 784.23it/s]\n",
      "39it [00:00, 789.76it/s]\n",
      "39it [00:00, 773.21it/s]\n",
      "39it [00:00, 765.15it/s]\n",
      "39it [00:00, 785.56it/s]\n",
      "39it [00:00, 789.77it/s]\n",
      "39it [00:00, 778.64it/s]\n",
      "39it [00:00, 791.12it/s]\n",
      "39it [00:00, 760.31it/s]\n",
      "39it [00:00, 764.89it/s]\n",
      "39it [00:00, 793.97it/s]\n",
      "39it [00:00, 789.00it/s]\n",
      "39it [00:00, 748.18it/s]\n",
      "39it [00:00, 793.66it/s]\n",
      "39it [00:00, 786.45it/s]\n",
      "39it [00:00, 788.83it/s]\n",
      "39it [00:00, 777.98it/s]\n",
      "39it [00:00, 785.28it/s]\n",
      "39it [00:00, 782.80it/s]\n",
      "39it [00:00, 795.61it/s]\n",
      "39it [00:00, 736.99it/s]\n",
      "39it [00:00, 774.51it/s]\n",
      "39it [00:00, 783.74it/s]\n",
      "39it [00:00, 794.84it/s]\n",
      "39it [00:00, 784.38it/s]\n",
      "39it [00:00, 795.69it/s]\n",
      "39it [00:00, 767.31it/s]\n",
      "39it [00:00, 783.36it/s]\n",
      "39it [00:00, 793.18it/s]\n",
      "39it [00:00, 785.05it/s]\n",
      "39it [00:00, 780.60it/s]\n",
      "39it [00:00, 742.61it/s]\n",
      "39it [00:00, 791.36it/s]\n",
      "39it [00:00, 782.13it/s]\n",
      "39it [00:00, 785.27it/s]\n",
      "39it [00:00, 791.06it/s]\n",
      "39it [00:00, 760.66it/s]\n",
      "39it [00:00, 737.30it/s]\n",
      "39it [00:00, 790.08it/s]\n",
      "39it [00:00, 774.49it/s]\n",
      "39it [00:00, 789.30it/s]\n",
      "39it [00:00, 784.73it/s]\n",
      "39it [00:00, 789.87it/s]\n",
      "39it [00:00, 782.63it/s]\n",
      "39it [00:00, 794.35it/s]\n",
      "39it [00:00, 741.50it/s]\n",
      "39it [00:00, 786.42it/s]\n",
      "39it [00:00, 787.32it/s]\n",
      "39it [00:00, 794.03it/s]\n",
      "39it [00:00, 786.31it/s]\n",
      "39it [00:00, 792.09it/s]\n",
      "39it [00:00, 791.78it/s]\n",
      "39it [00:00, 801.18it/s]\n",
      "39it [00:00, 783.58it/s]\n",
      "39it [00:00, 788.17it/s]\n",
      "39it [00:00, 783.58it/s]\n",
      "39it [00:00, 798.51it/s]\n",
      "39it [00:00, 784.07it/s]\n",
      "39it [00:00, 791.04it/s]\n",
      "39it [00:00, 781.49it/s]\n",
      "39it [00:00, 783.36it/s]\n",
      "39it [00:00, 789.76it/s]\n",
      "39it [00:00, 782.88it/s]\n",
      "39it [00:00, 785.68it/s]\n",
      "39it [00:00, 787.31it/s]\n",
      "39it [00:00, 779.60it/s]\n",
      "39it [00:00, 794.01it/s]\n",
      "39it [00:00, 783.93it/s]\n",
      "39it [00:00, 792.66it/s]\n",
      "39it [00:00, 790.75it/s]\n",
      "39it [00:00, 786.44it/s]\n",
      "39it [00:00, 782.71it/s]\n",
      "39it [00:00, 782.94it/s]\n",
      "39it [00:00, 783.18it/s]\n",
      "39it [00:00, 785.36it/s]\n",
      "39it [00:00, 791.02it/s]\n",
      "39it [00:00, 784.78it/s]\n",
      "39it [00:00, 791.09it/s]\n",
      "39it [00:00, 783.39it/s]\n",
      "39it [00:00, 789.15it/s]\n",
      "39it [00:00, 784.09it/s]\n",
      "39it [00:00, 789.83it/s]\n",
      "39it [00:00, 782.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1444, 0.7483622379879179, 0.8102122964410177, 0.7424376941704639)\n",
      "[(79, 0.8990233881096819, 0.6917913835599272, 0.871435429705173), (274, 0.8768556461149484, 0.7369548856684872, 0.8641487956175702), (469, 0.8308351474957105, 0.7674167585997923, 0.8494618413913131), (664, 0.8014975101019723, 0.8047654215598665, 0.8576349237111736), (859, 0.74808097310916, 0.769605275415055, 0.7457382429750464), (1054, 0.7472303577798175, 0.7856132844921058, 0.7287675983250731), (1249, 0.7439027449641745, 0.837730237102798, 0.7987425955903893), (1444, 0.7483622379879179, 0.8102122964410177, 0.7424376941704639)]\n"
     ]
    }
   ],
   "source": [
    "restart_data = []\n",
    "for restart_times in range(0, 40, 5):\n",
    "    err = (restart_error(restart_times=restart_times, restart_steps = 40, before_steps = 40, after_steps=40, rounds = 5))\n",
    "    print(err)\n",
    "    restart_data.append(err)\n",
    "print(restart_data)\n",
    "save_restart()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "75ca4f63",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 503.75it/s]\n",
      "19it [00:00, 654.93it/s]\n",
      "19it [00:00, 616.55it/s]\n",
      "19it [00:00, 700.46it/s]\n",
      "19it [00:00, 673.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20 4.0 (20, 0.8817647760776293, 0.7183678781375218, 0.8461896749047778)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 635.80it/s]\n",
      "19it [00:00, 724.38it/s]\n",
      "19it [00:00, 735.60it/s]\n",
      "19it [00:00, 703.03it/s]\n",
      "19it [00:00, 707.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20 10.0 (20, 0.8754396527110597, 0.7435374121150999, 0.8255045317977098)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 720.41it/s]\n",
      "19it [00:00, 738.76it/s]\n",
      "19it [00:00, 680.17it/s]\n",
      "19it [00:00, 730.57it/s]\n",
      "19it [00:00, 710.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20 20 (20, 0.8909827621265481, 0.8332710908488478, 0.8083938532309259)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 726.42it/s]\n",
      "19it [00:00, 728.88it/s]\n",
      "19it [00:00, 711.50it/s]\n",
      "19it [00:00, 719.69it/s]\n",
      "19it [00:00, 701.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20 60 (20, 0.9787034220317155, 0.9776844509529153, 0.6856705677986208)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 743.65it/s]\n",
      "39it [00:00, 738.09it/s]\n",
      "39it [00:00, 712.39it/s]\n",
      "39it [00:00, 741.12it/s]\n",
      "39it [00:00, 743.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40 8.0 (40, 0.8802708190006931, 0.7300936501858335, 0.8612061555415961)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 642.89it/s]\n",
      "39it [00:00, 580.41it/s]\n",
      "39it [00:00, 671.77it/s]\n",
      "39it [00:00, 633.16it/s]\n",
      "39it [00:00, 748.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40 20.0 (40, 0.8477651675679301, 0.7819976245308217, 0.785531121533509)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 748.50it/s]\n",
      "39it [00:00, 742.17it/s]\n",
      "39it [00:00, 669.51it/s]\n",
      "39it [00:00, 692.94it/s]\n",
      "39it [00:00, 516.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40 20 (40, 0.8531778961089319, 0.774238627148601, 0.7870513386762079)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "39it [00:00, 724.85it/s]\n",
      "39it [00:00, 741.18it/s]\n",
      "39it [00:00, 647.16it/s]\n",
      "39it [00:00, 693.22it/s]\n",
      "39it [00:00, 695.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40 60 (40, 0.8984215687422916, 0.9206206643979428, 0.6564548779116028)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "79it [00:00, 653.84it/s]\n",
      "79it [00:00, 747.03it/s]\n",
      "79it [00:00, 721.96it/s]\n",
      "79it [00:00, 698.40it/s]\n",
      "79it [00:00, 703.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "80 16.0 (80, 0.8496497649938984, 0.7401202985531568, 0.8052012474936376)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "79it [00:00, 718.87it/s]\n",
      "79it [00:00, 667.08it/s]\n",
      "79it [00:00, 692.22it/s]\n",
      "79it [00:00, 708.50it/s]\n",
      "79it [00:00, 672.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "80 40.0 (80, 0.8183762677668701, 0.8268852235115522, 0.7745832670914855)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "79it [00:00, 677.11it/s]\n",
      "79it [00:00, 745.07it/s]\n",
      "79it [00:00, 740.69it/s]\n",
      "79it [00:00, 742.82it/s]\n",
      "79it [00:00, 698.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "80 20 (80, 0.8508292405635582, 0.7630142260611127, 0.8304049397579005)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "79it [00:00, 744.04it/s]\n",
      "79it [00:00, 739.07it/s]\n",
      "79it [00:00, 745.83it/s]\n",
      "79it [00:00, 728.11it/s]\n",
      "79it [00:00, 744.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "80 60 (80, 0.8359765919799592, 0.8944332733035365, 0.7048774724386284)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "159it [00:00, 664.05it/s]\n",
      "159it [00:00, 721.84it/s]\n",
      "159it [00:00, 686.36it/s]\n",
      "159it [00:00, 735.87it/s]\n",
      "159it [00:00, 734.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "160 32.0 (160, 0.819395146098201, 0.7662058150987475, 0.7962920040044243)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "159it [00:00, 732.70it/s]\n",
      "159it [00:00, 745.84it/s]\n",
      "159it [00:00, 743.78it/s]\n",
      "159it [00:00, 685.15it/s]\n",
      "159it [00:00, 698.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "160 80.0 (160, 0.7999523648681335, 0.8818995459291807, 0.7279263223474898)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "159it [00:00, 717.72it/s]\n",
      "159it [00:00, 703.95it/s]\n",
      "159it [00:00, 728.03it/s]\n",
      "159it [00:00, 726.22it/s]\n",
      "159it [00:00, 738.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "160 20 (160, 0.848523506944613, 0.7355482106067275, 0.819968844608279)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "159it [00:00, 740.40it/s]\n",
      "159it [00:00, 746.24it/s]\n",
      "159it [00:00, 740.42it/s]\n",
      "159it [00:00, 738.42it/s]\n",
      "159it [00:00, 744.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "160 60 (160, 0.7782501761246101, 0.8368182270784086, 0.7726007983057208)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 746.27it/s]\n",
      "319it [00:00, 744.04it/s]\n",
      "319it [00:00, 750.26it/s]\n",
      "319it [00:00, 747.32it/s]\n",
      "319it [00:00, 746.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320 64.0 (320, 0.7770851434938159, 0.8107055769568614, 0.7992945776681754)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 745.04it/s]\n",
      "319it [00:00, 746.25it/s]\n",
      "319it [00:00, 747.75it/s]\n",
      "319it [00:00, 744.04it/s]\n",
      "319it [00:00, 750.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320 160.0 (320, 0.8862892410771235, 0.9304731562598825, 0.6673091079225298)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 747.86it/s]\n",
      "319it [00:00, 745.62it/s]\n",
      "319it [00:00, 744.68it/s]\n",
      "319it [00:00, 748.61it/s]\n",
      "319it [00:00, 744.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320 20 (320, 0.8663537769611718, 0.7294983531449761, 0.8623966832204998)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "319it [00:00, 739.80it/s]\n",
      "319it [00:00, 747.20it/s]\n",
      "319it [00:00, 747.07it/s]\n",
      "319it [00:00, 743.62it/s]\n",
      "319it [00:00, 747.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320 60 (320, 0.7656374218393021, 0.776862686116326, 0.7651499866004147)\n"
     ]
    }
   ],
   "source": [
    "for num_steps in [20, 40, 80, 160, 320]:\n",
    "    for S_churn in [0.2 * num_steps, 0.5 * num_steps, 20, 60]:\n",
    "        err = SDE_error(num_steps, S_churn, rounds = 5)\n",
    "        print(num_steps, S_churn, err)\n",
    "        SDE_data.append(err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "3d39b791",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [00:00, 393.26it/s]\n",
      "19it [00:00, 690.65it/s]\n",
      "19it [00:00, 741.17it/s]\n",
      "19it [00:00, 715.53it/s]\n",
      "19it [00:00, 741.11it/s]\n",
      "19it [00:00, 745.55it/s]\n",
      "19it [00:00, 754.99it/s]\n",
      "19it [00:00, 753.83it/s]\n",
      "19it [00:00, 729.07it/s]\n",
      "19it [00:00, 739.65it/s]\n",
      "19it [00:00, 753.32it/s]\n",
      "19it [00:00, 742.74it/s]\n",
      "19it [00:00, 746.98it/s]\n",
      "19it [00:00, 741.03it/s]\n",
      "19it [00:00, 733.32it/s]\n",
      "19it [00:00, 743.80it/s]\n",
      "19it [00:00, 693.67it/s]\n",
      "19it [00:00, 700.10it/s]\n",
      "19it [00:00, 738.00it/s]\n",
      "19it [00:00, 728.11it/s]\n",
      "19it [00:00, 701.64it/s]\n",
      "19it [00:00, 700.37it/s]\n",
      "19it [00:00, 700.28it/s]\n",
      "19it [00:00, 744.09it/s]\n",
      "19it [00:00, 735.67it/s]\n",
      "19it [00:00, 727.62it/s]\n",
      "19it [00:00, 734.45it/s]\n",
      "19it [00:00, 741.40it/s]\n",
      "19it [00:00, 740.86it/s]\n",
      "19it [00:00, 743.65it/s]\n",
      "19it [00:00, 742.31it/s]\n",
      "19it [00:00, 728.85it/s]\n",
      "19it [00:00, 746.13it/s]\n",
      "19it [00:00, 740.91it/s]\n",
      "19it [00:00, 739.41it/s]\n",
      "19it [00:00, 723.70it/s]\n",
      "19it [00:00, 735.54it/s]\n",
      "19it [00:00, 740.60it/s]\n",
      "19it [00:00, 732.66it/s]\n",
      "19it [00:00, 728.27it/s]\n",
      "19it [00:00, 742.29it/s]\n",
      "19it [00:00, 736.09it/s]\n",
      "19it [00:00, 726.59it/s]\n",
      "19it [00:00, 729.02it/s]\n",
      "19it [00:00, 739.02it/s]\n",
      "39it [00:00, 745.10it/s]\n",
      "39it [00:00, 755.84it/s]\n",
      "39it [00:00, 744.46it/s]\n",
      "39it [00:00, 742.91it/s]\n",
      "39it [00:00, 749.36it/s]\n",
      "39it [00:00, 750.07it/s]\n",
      "39it [00:00, 744.55it/s]\n",
      "39it [00:00, 746.43it/s]\n",
      "39it [00:00, 752.59it/s]\n",
      "39it [00:00, 748.00it/s]\n",
      "39it [00:00, 749.98it/s]\n",
      "39it [00:00, 742.05it/s]\n",
      "39it [00:00, 745.75it/s]\n",
      "39it [00:00, 748.97it/s]\n",
      "39it [00:00, 753.99it/s]\n",
      "39it [00:00, 752.86it/s]\n",
      "39it [00:00, 751.94it/s]\n",
      "39it [00:00, 748.82it/s]\n",
      "39it [00:00, 751.28it/s]\n",
      "39it [00:00, 753.18it/s]\n",
      "39it [00:00, 748.80it/s]\n",
      "39it [00:00, 750.12it/s]\n",
      "39it [00:00, 743.52it/s]\n",
      "39it [00:00, 745.01it/s]\n",
      "39it [00:00, 748.88it/s]\n",
      "39it [00:00, 753.99it/s]\n",
      "39it [00:00, 747.05it/s]\n",
      "39it [00:00, 731.46it/s]\n",
      "39it [00:00, 741.93it/s]\n",
      "39it [00:00, 739.77it/s]\n",
      "39it [00:00, 753.50it/s]\n",
      "39it [00:00, 751.48it/s]\n",
      "39it [00:00, 745.89it/s]\n",
      "39it [00:00, 746.39it/s]\n",
      "39it [00:00, 749.81it/s]\n",
      "39it [00:00, 752.79it/s]\n",
      "39it [00:00, 748.74it/s]\n",
      "39it [00:00, 750.52it/s]\n",
      "39it [00:00, 751.46it/s]\n",
      "39it [00:00, 749.43it/s]\n",
      "39it [00:00, 752.83it/s]\n",
      "39it [00:00, 752.45it/s]\n",
      "39it [00:00, 747.18it/s]\n",
      "39it [00:00, 750.51it/s]\n",
      "39it [00:00, 752.35it/s]\n",
      "79it [00:00, 750.47it/s]\n",
      "79it [00:00, 751.14it/s]\n",
      "79it [00:00, 744.65it/s]\n",
      "79it [00:00, 723.53it/s]\n",
      "79it [00:00, 747.02it/s]\n",
      "79it [00:00, 725.06it/s]\n",
      "79it [00:00, 748.32it/s]\n",
      "79it [00:00, 742.49it/s]\n",
      "79it [00:00, 754.30it/s]\n",
      "79it [00:00, 722.76it/s]\n",
      "79it [00:00, 748.91it/s]\n",
      "79it [00:00, 750.19it/s]\n",
      "79it [00:00, 747.16it/s]\n",
      "79it [00:00, 750.94it/s]\n",
      "79it [00:00, 742.68it/s]\n",
      "79it [00:00, 750.58it/s]\n",
      "79it [00:00, 749.99it/s]\n",
      "79it [00:00, 751.33it/s]\n",
      "79it [00:00, 752.63it/s]\n",
      "79it [00:00, 750.33it/s]\n",
      "79it [00:00, 748.79it/s]\n",
      "79it [00:00, 750.88it/s]\n",
      "79it [00:00, 752.72it/s]\n",
      "79it [00:00, 733.46it/s]\n",
      "79it [00:00, 723.02it/s]\n",
      "79it [00:00, 753.14it/s]\n",
      "79it [00:00, 723.17it/s]\n",
      "79it [00:00, 753.95it/s]\n",
      "79it [00:00, 752.47it/s]\n",
      "79it [00:00, 760.13it/s]\n",
      "79it [00:00, 752.52it/s]\n",
      "79it [00:00, 750.63it/s]\n",
      "79it [00:00, 752.96it/s]\n",
      "79it [00:00, 751.73it/s]\n",
      "79it [00:00, 751.19it/s]\n",
      "79it [00:00, 751.57it/s]\n",
      "79it [00:00, 750.03it/s]\n",
      "79it [00:00, 749.28it/s]\n",
      "79it [00:00, 725.25it/s]\n",
      "79it [00:00, 742.59it/s]\n",
      "79it [00:00, 724.15it/s]\n",
      "79it [00:00, 714.74it/s]\n",
      "79it [00:00, 754.10it/s]\n",
      "79it [00:00, 730.80it/s]\n",
      "79it [00:00, 739.36it/s]\n",
      "159it [00:00, 749.18it/s]\n",
      "159it [00:00, 756.79it/s]\n",
      "159it [00:00, 755.10it/s]\n",
      "159it [00:00, 756.45it/s]\n",
      "159it [00:00, 761.36it/s]\n",
      "159it [00:00, 758.09it/s]\n",
      "159it [00:00, 756.32it/s]\n",
      "159it [00:00, 754.69it/s]\n",
      "159it [00:00, 757.93it/s]\n",
      "159it [00:00, 756.65it/s]\n",
      "159it [00:00, 755.43it/s]\n",
      "159it [00:00, 755.25it/s]\n",
      "159it [00:00, 758.77it/s]\n",
      "159it [00:00, 756.54it/s]\n",
      "159it [00:00, 755.54it/s]\n",
      "159it [00:00, 756.40it/s]\n",
      "159it [00:00, 760.78it/s]\n",
      "159it [00:00, 757.53it/s]\n",
      "159it [00:00, 757.64it/s]\n",
      "159it [00:00, 760.11it/s]\n",
      "159it [00:00, 757.49it/s]\n",
      "159it [00:00, 759.00it/s]\n",
      "159it [00:00, 760.05it/s]\n",
      "159it [00:00, 756.16it/s]\n",
      "159it [00:00, 749.54it/s]\n",
      "159it [00:00, 726.02it/s]\n",
      "159it [00:00, 704.78it/s]\n",
      "159it [00:00, 750.38it/s]\n",
      "159it [00:00, 752.33it/s]\n",
      "159it [00:00, 749.97it/s]\n",
      "159it [00:00, 749.38it/s]\n",
      "159it [00:00, 747.25it/s]\n",
      "159it [00:00, 740.68it/s]\n",
      "159it [00:00, 757.58it/s]\n",
      "159it [00:00, 761.96it/s]\n",
      "159it [00:00, 756.50it/s]\n",
      "159it [00:00, 748.94it/s]\n",
      "159it [00:00, 747.09it/s]\n",
      "159it [00:00, 746.23it/s]\n",
      "159it [00:00, 744.52it/s]\n",
      "159it [00:00, 746.44it/s]\n",
      "159it [00:00, 747.21it/s]\n",
      "159it [00:00, 745.26it/s]\n",
      "159it [00:00, 749.43it/s]\n",
      "159it [00:00, 747.72it/s]\n",
      "319it [00:00, 741.60it/s]\n",
      "319it [00:00, 745.96it/s]\n",
      "319it [00:00, 750.43it/s]\n",
      "319it [00:00, 750.88it/s]\n",
      "319it [00:00, 745.58it/s]\n",
      "319it [00:00, 749.24it/s]\n",
      "319it [00:00, 749.85it/s]\n",
      "319it [00:00, 750.25it/s]\n",
      "319it [00:00, 749.51it/s]\n",
      "319it [00:00, 748.32it/s]\n",
      "319it [00:00, 746.61it/s]\n",
      "319it [00:00, 748.21it/s]\n",
      "319it [00:00, 694.16it/s]\n",
      "319it [00:00, 757.79it/s]\n",
      "319it [00:00, 758.95it/s]\n",
      "319it [00:00, 751.13it/s]\n",
      "319it [00:00, 753.01it/s]\n",
      "319it [00:00, 753.05it/s]\n",
      "319it [00:00, 752.06it/s]\n",
      "319it [00:00, 752.68it/s]\n",
      "319it [00:00, 752.45it/s]\n",
      "319it [00:00, 749.88it/s]\n",
      "319it [00:00, 750.87it/s]\n",
      "319it [00:00, 750.39it/s]\n",
      "319it [00:00, 748.23it/s]\n",
      "319it [00:00, 746.33it/s]\n",
      "319it [00:00, 752.46it/s]\n",
      "319it [00:00, 749.38it/s]\n",
      "319it [00:00, 751.32it/s]\n",
      "319it [00:00, 748.59it/s]\n",
      "319it [00:00, 750.71it/s]\n",
      "319it [00:00, 748.98it/s]\n",
      "319it [00:00, 744.36it/s]\n",
      "319it [00:00, 739.50it/s]\n",
      "319it [00:00, 749.68it/s]\n",
      "319it [00:00, 749.15it/s]\n",
      "319it [00:00, 755.42it/s]\n",
      "319it [00:00, 753.01it/s]\n",
      "319it [00:00, 752.06it/s]\n",
      "319it [00:00, 747.38it/s]\n",
      "319it [00:00, 748.38it/s]\n",
      "319it [00:00, 746.44it/s]\n",
      "319it [00:00, 750.10it/s]\n",
      "319it [00:00, 752.41it/s]\n",
      "319it [00:00, 750.29it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for num_steps in [20, 40, 80, 160, 320]:\n",
    "    for beta in [0, 0.25, 0.5, 1, 1.5, 2, 4, 8, 16]:\n",
    "        err = vanilla_SDE_error(beta, num_steps, rounds = 5)\n",
    "        vanilla_data.append(err)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ba5b5c56",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "KeyboardInterrupt\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# for restarts in range(0, 40, 5):\n",
    "#     for restart_steps in [5, 10, 20]:\n",
    "#         for before_steps in [40]:\n",
    "#             for after_steps in [40]:\n",
    "#                 err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "#                 restart_data.append(err)\n",
    "for restarts in [5, 10, 15, 20]:\n",
    "    for restart_steps in [3]:\n",
    "        for before_steps in [5]:\n",
    "            for after_steps in [10]:\n",
    "                err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "                restart_data.append(err)\n",
    "                # print(err)\n",
    "\n",
    "for restarts in [4, 6, 8, 10]:\n",
    "    for restart_steps in [30]:\n",
    "        for before_steps in [100]:\n",
    "            for after_steps in [100]:\n",
    "                err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "                restart_data.append(err)\n",
    "                print(err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ce9d1993",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4it [00:00, 325.11it/s]\n",
      "4it [00:00, 349.55it/s]\n",
      "4it [00:00, 348.91it/s]\n",
      "4it [00:00, 429.03it/s]\n",
      "4it [00:00, 424.98it/s]\n",
      "4it [00:00, 430.57it/s]\n",
      "9it [00:00, 450.84it/s]\n",
      "4it [00:00, 518.74it/s]\n",
      "4it [00:00, 554.42it/s]\n",
      "4it [00:00, 693.10it/s]\n",
      "4it [00:00, 635.02it/s]\n",
      "4it [00:00, 635.52it/s]\n",
      "4it [00:00, 650.99it/s]\n",
      "9it [00:00, 760.88it/s]\n",
      "4it [00:00, 629.78it/s]\n",
      "4it [00:00, 685.51it/s]\n",
      "4it [00:00, 727.20it/s]\n",
      "4it [00:00, 687.45it/s]\n",
      "4it [00:00, 643.35it/s]\n",
      "4it [00:00, 651.09it/s]\n",
      "9it [00:00, 694.27it/s]\n",
      "4it [00:00, 517.85it/s]\n",
      "4it [00:00, 712.32it/s]\n",
      "4it [00:00, 647.22it/s]\n",
      "4it [00:00, 647.44it/s]\n",
      "4it [00:00, 665.60it/s]\n",
      "4it [00:00, 700.45it/s]\n",
      "9it [00:00, 668.63it/s]\n",
      "4it [00:00, 419.99it/s]\n",
      "4it [00:00, 554.23it/s]\n",
      "4it [00:00, 717.04it/s]\n",
      "4it [00:00, 269.16it/s]\n",
      "4it [00:00, 236.63it/s]\n",
      "4it [00:00, 577.71it/s]\n",
      "9it [00:00, 625.00it/s]\n",
      "4it [00:00, 601.77it/s]\n",
      "6it [00:00, 463.17it/s]\n",
      "6it [00:00, 415.60it/s]\n",
      "6it [00:00, 403.98it/s]\n",
      "6it [00:00, 453.77it/s]\n",
      "6it [00:00, 640.92it/s]\n",
      "9it [00:00, 624.73it/s]\n",
      "4it [00:00, 416.86it/s]\n",
      "6it [00:00, 567.36it/s]\n",
      "6it [00:00, 633.36it/s]\n",
      "6it [00:00, 705.91it/s]\n",
      "6it [00:00, 678.54it/s]\n",
      "6it [00:00, 688.23it/s]\n",
      "9it [00:00, 763.94it/s]\n",
      "4it [00:00, 348.79it/s]\n",
      "6it [00:00, 634.67it/s]\n",
      "6it [00:00, 600.64it/s]\n",
      "6it [00:00, 652.35it/s]\n",
      "6it [00:00, 740.43it/s]\n",
      "6it [00:00, 668.40it/s]\n",
      "9it [00:00, 691.84it/s]\n",
      "4it [00:00, 624.45it/s]\n",
      "6it [00:00, 707.74it/s]\n",
      "6it [00:00, 749.61it/s]\n",
      "6it [00:00, 712.13it/s]\n",
      "6it [00:00, 714.51it/s]\n",
      "6it [00:00, 710.00it/s]\n",
      "9it [00:00, 680.73it/s]\n",
      "4it [00:00, 540.35it/s]\n",
      "6it [00:00, 613.26it/s]\n",
      "6it [00:00, 740.15it/s]\n",
      "6it [00:00, 670.27it/s]\n",
      "6it [00:00, 668.36it/s]\n",
      "6it [00:00, 728.66it/s]\n",
      "9it [00:00, 722.71it/s]\n",
      "4it [00:00, 630.22it/s]\n",
      "4it [00:00, 663.58it/s]\n",
      "4it [00:00, 692.04it/s]\n",
      "4it [00:00, 652.89it/s]\n",
      "4it [00:00, 667.01it/s]\n",
      "4it [00:00, 641.36it/s]\n",
      "4it [00:00, 640.35it/s]\n",
      "4it [00:00, 658.96it/s]\n",
      "4it [00:00, 739.41it/s]\n",
      "4it [00:00, 745.02it/s]\n",
      "4it [00:00, 650.94it/s]\n",
      "9it [00:00, 682.47it/s]\n",
      "4it [00:00, 689.99it/s]\n",
      "4it [00:00, 684.78it/s]\n",
      "4it [00:00, 714.05it/s]\n",
      "4it [00:00, 714.71it/s]\n",
      "4it [00:00, 678.44it/s]\n",
      "4it [00:00, 666.90it/s]\n",
      "4it [00:00, 667.30it/s]\n",
      "4it [00:00, 657.03it/s]\n",
      "4it [00:00, 681.50it/s]\n",
      "4it [00:00, 742.12it/s]\n",
      "4it [00:00, 738.47it/s]\n",
      "9it [00:00, 722.10it/s]\n",
      "4it [00:00, 672.06it/s]\n",
      "4it [00:00, 712.02it/s]\n",
      "4it [00:00, 692.22it/s]\n",
      "4it [00:00, 650.36it/s]\n",
      "4it [00:00, 643.13it/s]\n",
      "4it [00:00, 666.61it/s]\n",
      "4it [00:00, 721.51it/s]\n",
      "4it [00:00, 744.36it/s]\n",
      "4it [00:00, 663.13it/s]\n",
      "4it [00:00, 688.07it/s]\n",
      "4it [00:00, 705.76it/s]\n",
      "9it [00:00, 734.17it/s]\n",
      "4it [00:00, 658.29it/s]\n",
      "4it [00:00, 702.33it/s]\n",
      "4it [00:00, 669.83it/s]\n",
      "4it [00:00, 676.36it/s]\n",
      "4it [00:00, 667.54it/s]\n",
      "4it [00:00, 697.39it/s]\n",
      "4it [00:00, 744.56it/s]\n",
      "4it [00:00, 691.02it/s]\n",
      "4it [00:00, 699.11it/s]\n",
      "4it [00:00, 708.80it/s]\n",
      "4it [00:00, 709.76it/s]\n",
      "9it [00:00, 692.88it/s]\n",
      "4it [00:00, 603.74it/s]\n",
      "4it [00:00, 705.90it/s]\n",
      "4it [00:00, 738.95it/s]\n",
      "4it [00:00, 671.03it/s]\n",
      "4it [00:00, 689.20it/s]\n",
      "4it [00:00, 694.13it/s]\n",
      "4it [00:00, 672.87it/s]\n",
      "4it [00:00, 640.21it/s]\n",
      "4it [00:00, 630.46it/s]\n",
      "4it [00:00, 652.71it/s]\n",
      "4it [00:00, 672.62it/s]\n",
      "9it [00:00, 773.67it/s]\n",
      "4it [00:00, 552.83it/s]\n",
      "6it [00:00, 722.47it/s]\n",
      "6it [00:00, 675.16it/s]\n",
      "6it [00:00, 675.85it/s]\n",
      "6it [00:00, 639.77it/s]\n",
      "6it [00:00, 725.07it/s]\n",
      "6it [00:00, 758.81it/s]\n",
      "6it [00:00, 758.72it/s]\n",
      "6it [00:00, 759.79it/s]\n",
      "6it [00:00, 754.19it/s]\n",
      "6it [00:00, 756.68it/s]\n",
      "9it [00:00, 768.11it/s]\n",
      "4it [00:00, 638.94it/s]\n",
      "6it [00:00, 670.68it/s]\n",
      "6it [00:00, 701.31it/s]\n",
      "6it [00:00, 633.82it/s]\n",
      "6it [00:00, 669.68it/s]\n",
      "6it [00:00, 683.50it/s]\n",
      "6it [00:00, 760.02it/s]\n",
      "6it [00:00, 660.64it/s]\n",
      "6it [00:00, 679.68it/s]\n",
      "6it [00:00, 679.44it/s]\n",
      "6it [00:00, 687.87it/s]\n",
      "9it [00:00, 406.33it/s]\n",
      "4it [00:00, 636.30it/s]\n",
      "6it [00:00, 755.87it/s]\n",
      "6it [00:00, 717.02it/s]\n",
      "6it [00:00, 723.43it/s]\n",
      "6it [00:00, 722.70it/s]\n",
      "6it [00:00, 707.80it/s]\n",
      "6it [00:00, 444.12it/s]\n",
      "6it [00:00, 450.25it/s]\n",
      "6it [00:00, 690.57it/s]\n",
      "6it [00:00, 226.54it/s]\n",
      "6it [00:00, 419.03it/s]\n",
      "9it [00:00, 610.33it/s]\n",
      "4it [00:00, 601.72it/s]\n",
      "6it [00:00, 666.52it/s]\n",
      "6it [00:00, 630.47it/s]\n",
      "6it [00:00, 757.19it/s]\n",
      "6it [00:00, 695.67it/s]\n",
      "6it [00:00, 678.65it/s]\n",
      "6it [00:00, 679.42it/s]\n",
      "6it [00:00, 699.87it/s]\n",
      "6it [00:00, 679.92it/s]\n",
      "6it [00:00, 449.25it/s]\n",
      "6it [00:00, 544.60it/s]\n",
      "9it [00:00, 342.85it/s]\n",
      "4it [00:00, 675.22it/s]\n",
      "6it [00:00, 209.53it/s]\n",
      "6it [00:00, 341.75it/s]\n",
      "6it [00:00, 635.12it/s]\n",
      "6it [00:00, 726.87it/s]\n",
      "6it [00:00, 696.02it/s]\n",
      "6it [00:00, 713.38it/s]\n",
      "6it [00:00, 733.63it/s]\n",
      "6it [00:00, 733.85it/s]\n",
      "6it [00:00, 713.48it/s]\n",
      "6it [00:00, 727.95it/s]\n",
      "9it [00:00, 710.93it/s]\n",
      "4it [00:00, 615.47it/s]\n",
      "4it [00:00, 658.58it/s]\n",
      "4it [00:00, 657.59it/s]\n",
      "4it [00:00, 705.87it/s]\n",
      "4it [00:00, 736.00it/s]\n",
      "4it [00:00, 731.89it/s]\n",
      "4it [00:00, 710.03it/s]\n",
      "4it [00:00, 696.21it/s]\n",
      "4it [00:00, 704.07it/s]\n",
      "4it [00:00, 712.08it/s]\n",
      "4it [00:00, 702.53it/s]\n",
      "4it [00:00, 678.28it/s]\n",
      "4it [00:00, 432.16it/s]\n",
      "4it [00:00, 392.74it/s]\n",
      "4it [00:00, 564.85it/s]\n",
      "4it [00:00, 508.74it/s]\n",
      "9it [00:00, 269.92it/s]\n",
      "4it [00:00, 676.86it/s]\n",
      "4it [00:00, 680.59it/s]\n",
      "4it [00:00, 683.42it/s]\n",
      "4it [00:00, 703.27it/s]\n",
      "4it [00:00, 702.06it/s]\n",
      "4it [00:00, 695.66it/s]\n",
      "4it [00:00, 415.76it/s]\n",
      "4it [00:00, 386.70it/s]\n",
      "4it [00:00, 513.58it/s]\n",
      "4it [00:00, 682.94it/s]\n",
      "4it [00:00, 229.60it/s]\n",
      "4it [00:00, 205.37it/s]\n",
      "4it [00:00, 544.06it/s]\n",
      "4it [00:00, 656.72it/s]\n",
      "4it [00:00, 739.44it/s]\n",
      "4it [00:00, 693.42it/s]\n",
      "9it [00:00, 734.00it/s]\n",
      "4it [00:00, 692.19it/s]\n",
      "4it [00:00, 735.39it/s]\n",
      "4it [00:00, 742.29it/s]\n",
      "4it [00:00, 740.23it/s]\n",
      "4it [00:00, 743.05it/s]\n",
      "4it [00:00, 741.67it/s]\n",
      "4it [00:00, 741.57it/s]\n",
      "4it [00:00, 737.88it/s]\n",
      "4it [00:00, 744.13it/s]\n",
      "4it [00:00, 729.22it/s]\n",
      "4it [00:00, 742.39it/s]\n",
      "4it [00:00, 740.13it/s]\n",
      "4it [00:00, 744.13it/s]\n",
      "4it [00:00, 734.62it/s]\n",
      "4it [00:00, 744.26it/s]\n",
      "4it [00:00, 738.95it/s]\n",
      "9it [00:00, 768.47it/s]\n",
      "4it [00:00, 393.23it/s]\n",
      "4it [00:00, 400.31it/s]\n",
      "4it [00:00, 627.40it/s]\n",
      "4it [00:00, 591.00it/s]\n",
      "4it [00:00, 326.95it/s]\n",
      "4it [00:00, 245.28it/s]\n",
      "4it [00:00, 583.45it/s]\n",
      "4it [00:00, 641.94it/s]\n",
      "4it [00:00, 635.12it/s]\n",
      "4it [00:00, 664.10it/s]\n",
      "4it [00:00, 626.69it/s]\n",
      "4it [00:00, 605.85it/s]\n",
      "4it [00:00, 663.50it/s]\n",
      "4it [00:00, 692.47it/s]\n",
      "4it [00:00, 670.04it/s]\n",
      "4it [00:00, 672.00it/s]\n",
      "9it [00:00, 732.22it/s]\n",
      "4it [00:00, 623.43it/s]\n",
      "4it [00:00, 653.67it/s]\n",
      "4it [00:00, 681.25it/s]\n",
      "4it [00:00, 735.68it/s]\n",
      "4it [00:00, 708.71it/s]\n",
      "4it [00:00, 697.63it/s]\n",
      "4it [00:00, 709.61it/s]\n",
      "4it [00:00, 709.73it/s]\n",
      "4it [00:00, 704.42it/s]\n",
      "4it [00:00, 584.14it/s]\n",
      "4it [00:00, 381.19it/s]\n",
      "4it [00:00, 398.53it/s]\n",
      "4it [00:00, 662.61it/s]\n",
      "4it [00:00, 235.53it/s]\n",
      "4it [00:00, 205.97it/s]\n",
      "4it [00:00, 561.00it/s]\n",
      "9it [00:00, 652.00it/s]\n",
      "4it [00:00, 685.74it/s]\n",
      "6it [00:00, 751.62it/s]\n",
      "6it [00:00, 706.37it/s]\n",
      "6it [00:00, 728.22it/s]\n",
      "6it [00:00, 701.51it/s]\n",
      "6it [00:00, 672.13it/s]\n",
      "6it [00:00, 665.41it/s]\n",
      "6it [00:00, 677.50it/s]\n",
      "6it [00:00, 671.89it/s]\n",
      "6it [00:00, 759.86it/s]\n",
      "6it [00:00, 695.55it/s]\n",
      "6it [00:00, 677.85it/s]\n",
      "6it [00:00, 679.31it/s]\n",
      "6it [00:00, 679.06it/s]\n",
      "6it [00:00, 673.71it/s]\n",
      "6it [00:00, 381.48it/s]\n",
      "9it [00:00, 524.38it/s]\n",
      "4it [00:00, 502.12it/s]\n",
      "6it [00:00, 418.53it/s]\n",
      "6it [00:00, 206.49it/s]\n",
      "6it [00:00, 590.62it/s]\n",
      "6it [00:00, 691.67it/s]\n",
      "6it [00:00, 681.91it/s]\n",
      "6it [00:00, 671.86it/s]\n",
      "6it [00:00, 702.70it/s]\n",
      "6it [00:00, 755.98it/s]\n",
      "6it [00:00, 677.06it/s]\n",
      "6it [00:00, 683.00it/s]\n",
      "6it [00:00, 679.50it/s]\n",
      "6it [00:00, 676.16it/s]\n",
      "6it [00:00, 678.51it/s]\n",
      "6it [00:00, 665.69it/s]\n",
      "6it [00:00, 687.25it/s]\n",
      "9it [00:00, 754.96it/s]\n",
      "4it [00:00, 215.55it/s]\n",
      "6it [00:00, 623.98it/s]\n",
      "6it [00:00, 683.09it/s]\n",
      "6it [00:00, 719.21it/s]\n",
      "6it [00:00, 687.10it/s]\n",
      "6it [00:00, 697.23it/s]\n",
      "6it [00:00, 758.74it/s]\n",
      "6it [00:00, 717.47it/s]\n",
      "6it [00:00, 715.32it/s]\n",
      "6it [00:00, 727.29it/s]\n",
      "6it [00:00, 693.35it/s]\n",
      "6it [00:00, 664.43it/s]\n",
      "6it [00:00, 673.57it/s]\n",
      "6it [00:00, 712.07it/s]\n",
      "6it [00:00, 760.39it/s]\n",
      "6it [00:00, 691.71it/s]\n",
      "9it [00:00, 732.32it/s]\n",
      "4it [00:00, 204.27it/s]\n",
      "6it [00:00, 479.64it/s]\n",
      "6it [00:00, 600.14it/s]\n",
      "6it [00:00, 743.65it/s]\n",
      "6it [00:00, 700.67it/s]\n",
      "6it [00:00, 722.74it/s]\n",
      "6it [00:00, 742.53it/s]\n",
      "6it [00:00, 729.91it/s]\n",
      "6it [00:00, 726.94it/s]\n",
      "6it [00:00, 726.50it/s]\n",
      "6it [00:00, 692.55it/s]\n",
      "6it [00:00, 664.65it/s]\n",
      "6it [00:00, 671.50it/s]\n",
      "6it [00:00, 708.88it/s]\n",
      "6it [00:00, 760.30it/s]\n",
      "6it [00:00, 703.35it/s]\n",
      "9it [00:00, 725.84it/s]\n",
      "4it [00:00, 591.18it/s]\n",
      "6it [00:00, 651.34it/s]\n",
      "6it [00:00, 756.25it/s]\n",
      "6it [00:00, 644.35it/s]\n",
      "6it [00:00, 677.43it/s]\n",
      "6it [00:00, 678.80it/s]\n",
      "6it [00:00, 668.20it/s]\n",
      "6it [00:00, 440.22it/s]\n",
      "6it [00:00, 456.86it/s]\n",
      "6it [00:00, 579.04it/s]\n",
      "6it [00:00, 215.78it/s]\n",
      "6it [00:00, 585.05it/s]\n",
      "6it [00:00, 619.95it/s]\n",
      "6it [00:00, 739.32it/s]\n",
      "6it [00:00, 703.33it/s]\n",
      "6it [00:00, 698.88it/s]\n",
      "9it [00:00, 713.56it/s]\n",
      "4it [00:00, 691.19it/s]\n",
      "4it [00:00, 683.61it/s]\n",
      "4it [00:00, 666.42it/s]\n",
      "4it [00:00, 684.98it/s]\n",
      "4it [00:00, 711.38it/s]\n",
      "4it [00:00, 737.95it/s]\n",
      "4it [00:00, 711.44it/s]\n",
      "4it [00:00, 713.83it/s]\n",
      "4it [00:00, 696.41it/s]\n",
      "4it [00:00, 710.27it/s]\n",
      "4it [00:00, 639.40it/s]\n",
      "4it [00:00, 651.62it/s]\n",
      "4it [00:00, 668.63it/s]\n",
      "4it [00:00, 689.54it/s]\n",
      "4it [00:00, 749.22it/s]\n",
      "4it [00:00, 723.06it/s]\n",
      "4it [00:00, 682.92it/s]\n",
      "4it [00:00, 705.90it/s]\n",
      "4it [00:00, 687.56it/s]\n",
      "4it [00:00, 697.57it/s]\n",
      "4it [00:00, 582.56it/s]\n",
      "9it [00:00, 433.60it/s]\n",
      "4it [00:00, 545.33it/s]\n",
      "4it [00:00, 739.18it/s]\n",
      "4it [00:00, 659.51it/s]\n",
      "4it [00:00, 666.61it/s]\n",
      "4it [00:00, 653.01it/s]\n",
      "4it [00:00, 703.80it/s]\n",
      "4it [00:00, 739.74it/s]\n",
      "4it [00:00, 675.79it/s]\n",
      "4it [00:00, 676.86it/s]\n",
      "4it [00:00, 691.07it/s]\n",
      "4it [00:00, 702.53it/s]\n",
      "4it [00:00, 652.20it/s]\n",
      "4it [00:00, 672.06it/s]\n",
      "4it [00:00, 662.90it/s]\n",
      "4it [00:00, 688.24it/s]\n",
      "4it [00:00, 749.28it/s]\n",
      "4it [00:00, 751.03it/s]\n",
      "4it [00:00, 674.68it/s]\n",
      "4it [00:00, 710.09it/s]\n",
      "4it [00:00, 716.33it/s]\n",
      "4it [00:00, 716.91it/s]\n",
      "9it [00:00, 588.41it/s]\n",
      "4it [00:00, 636.85it/s]\n",
      "4it [00:00, 668.55it/s]\n",
      "4it [00:00, 692.04it/s]\n",
      "4it [00:00, 734.97it/s]\n",
      "4it [00:00, 758.88it/s]\n",
      "4it [00:00, 699.05it/s]\n",
      "4it [00:00, 677.84it/s]\n",
      "4it [00:00, 718.51it/s]\n",
      "4it [00:00, 719.13it/s]\n",
      "4it [00:00, 718.82it/s]\n",
      "4it [00:00, 700.57it/s]\n",
      "4it [00:00, 657.70it/s]\n",
      "4it [00:00, 425.46it/s]\n",
      "4it [00:00, 362.08it/s]\n",
      "4it [00:00, 579.82it/s]\n",
      "4it [00:00, 699.75it/s]\n",
      "4it [00:00, 286.47it/s]\n",
      "4it [00:00, 217.55it/s]\n",
      "4it [00:00, 471.23it/s]\n",
      "4it [00:00, 570.42it/s]\n",
      "4it [00:00, 653.85it/s]\n",
      "9it [00:00, 746.57it/s]\n",
      "4it [00:00, 648.90it/s]\n",
      "4it [00:00, 711.86it/s]\n",
      "4it [00:00, 758.81it/s]\n",
      "4it [00:00, 712.89it/s]\n",
      "4it [00:00, 694.33it/s]\n",
      "4it [00:00, 693.59it/s]\n",
      "4it [00:00, 692.44it/s]\n",
      "4it [00:00, 708.38it/s]\n",
      "4it [00:00, 700.80it/s]\n",
      "4it [00:00, 655.16it/s]\n",
      "4it [00:00, 659.27it/s]\n",
      "4it [00:00, 654.72it/s]\n",
      "4it [00:00, 648.19it/s]\n",
      "4it [00:00, 699.90it/s]\n",
      "4it [00:00, 743.80it/s]\n",
      "4it [00:00, 742.22it/s]\n",
      "4it [00:00, 706.56it/s]\n",
      "4it [00:00, 671.63it/s]\n",
      "4it [00:00, 681.83it/s]\n",
      "4it [00:00, 681.31it/s]\n",
      "4it [00:00, 683.56it/s]\n",
      "9it [00:00, 678.63it/s]\n",
      "4it [00:00, 686.44it/s]\n",
      "4it [00:00, 730.62it/s]\n",
      "4it [00:00, 737.82it/s]\n",
      "4it [00:00, 731.58it/s]\n",
      "4it [00:00, 723.28it/s]\n",
      "4it [00:00, 734.91it/s]\n",
      "4it [00:00, 740.19it/s]\n",
      "4it [00:00, 734.59it/s]\n",
      "4it [00:00, 730.08it/s]\n",
      "4it [00:00, 737.78it/s]\n",
      "4it [00:00, 738.08it/s]\n",
      "4it [00:00, 739.74it/s]\n",
      "4it [00:00, 719.53it/s]\n",
      "4it [00:00, 738.56it/s]\n",
      "4it [00:00, 738.50it/s]\n",
      "4it [00:00, 739.25it/s]\n",
      "4it [00:00, 739.21it/s]\n",
      "4it [00:00, 735.81it/s]\n",
      "4it [00:00, 739.31it/s]\n",
      "4it [00:00, 739.08it/s]\n",
      "4it [00:00, 740.78it/s]\n",
      "9it [00:00, 768.44it/s]\n",
      "4it [00:00, 196.76it/s]\n",
      "6it [00:00, 498.61it/s]\n",
      "6it [00:00, 593.88it/s]\n",
      "6it [00:00, 723.68it/s]\n",
      "6it [00:00, 669.23it/s]\n",
      "6it [00:00, 691.07it/s]\n",
      "6it [00:00, 725.03it/s]\n",
      "6it [00:00, 752.32it/s]\n",
      "6it [00:00, 687.68it/s]\n",
      "6it [00:00, 687.40it/s]\n",
      "6it [00:00, 688.32it/s]\n",
      "6it [00:00, 709.28it/s]\n",
      "6it [00:00, 680.25it/s]\n",
      "6it [00:00, 693.81it/s]\n",
      "6it [00:00, 696.36it/s]\n",
      "6it [00:00, 765.76it/s]\n",
      "6it [00:00, 724.01it/s]\n",
      "6it [00:00, 706.01it/s]\n",
      "6it [00:00, 713.24it/s]\n",
      "6it [00:00, 708.80it/s]\n",
      "6it [00:00, 531.16it/s]\n",
      "9it [00:00, 439.71it/s]\n",
      "4it [00:00, 621.08it/s]\n",
      "6it [00:00, 568.71it/s]\n",
      "6it [00:00, 626.87it/s]\n",
      "6it [00:00, 717.59it/s]\n",
      "6it [00:00, 690.16it/s]\n",
      "6it [00:00, 683.46it/s]\n",
      "6it [00:00, 726.52it/s]\n",
      "6it [00:00, 754.05it/s]\n",
      "6it [00:00, 686.45it/s]\n",
      "6it [00:00, 687.14it/s]\n",
      "6it [00:00, 688.06it/s]\n",
      "6it [00:00, 706.11it/s]\n",
      "6it [00:00, 693.83it/s]\n",
      "6it [00:00, 688.38it/s]\n",
      "6it [00:00, 654.85it/s]\n",
      "6it [00:00, 736.64it/s]\n",
      "6it [00:00, 781.57it/s]\n",
      "6it [00:00, 676.61it/s]\n",
      "6it [00:00, 683.43it/s]\n",
      "6it [00:00, 682.80it/s]\n",
      "6it [00:00, 683.13it/s]\n",
      "9it [00:00, 668.96it/s]\n",
      "4it [00:00, 573.36it/s]\n",
      "6it [00:00, 626.97it/s]\n",
      "6it [00:00, 679.22it/s]\n",
      "6it [00:00, 675.94it/s]\n",
      "6it [00:00, 672.74it/s]\n",
      "6it [00:00, 681.72it/s]\n",
      "6it [00:00, 759.98it/s]\n",
      "6it [00:00, 683.04it/s]\n",
      "6it [00:00, 680.80it/s]\n",
      "6it [00:00, 692.09it/s]\n",
      "6it [00:00, 668.54it/s]\n",
      "6it [00:00, 661.75it/s]\n",
      "6it [00:00, 668.34it/s]\n",
      "6it [00:00, 728.39it/s]\n",
      "6it [00:00, 733.83it/s]\n",
      "6it [00:00, 675.67it/s]\n",
      "6it [00:00, 704.94it/s]\n",
      "6it [00:00, 713.18it/s]\n",
      "6it [00:00, 671.46it/s]\n",
      "6it [00:00, 399.76it/s]\n",
      "6it [00:00, 495.78it/s]\n",
      "9it [00:00, 340.47it/s]\n",
      "4it [00:00, 598.93it/s]\n",
      "6it [00:00, 741.65it/s]\n",
      "6it [00:00, 749.03it/s]\n",
      "6it [00:00, 758.46it/s]\n",
      "6it [00:00, 747.71it/s]\n",
      "6it [00:00, 734.08it/s]\n",
      "6it [00:00, 734.45it/s]\n",
      "6it [00:00, 747.16it/s]\n",
      "6it [00:00, 705.30it/s]\n",
      "6it [00:00, 668.81it/s]\n",
      "6it [00:00, 687.16it/s]\n",
      "6it [00:00, 762.35it/s]\n",
      "6it [00:00, 738.95it/s]\n",
      "6it [00:00, 719.37it/s]\n",
      "6it [00:00, 729.13it/s]\n",
      "6it [00:00, 729.34it/s]\n",
      "6it [00:00, 703.25it/s]\n",
      "6it [00:00, 499.93it/s]\n",
      "6it [00:00, 417.16it/s]\n",
      "6it [00:00, 694.84it/s]\n",
      "6it [00:00, 209.32it/s]\n",
      "9it [00:00, 446.35it/s]\n",
      "4it [00:00, 665.58it/s]\n",
      "6it [00:00, 696.17it/s]\n",
      "6it [00:00, 690.42it/s]\n",
      "6it [00:00, 658.77it/s]\n",
      "6it [00:00, 653.06it/s]\n",
      "6it [00:00, 717.96it/s]\n",
      "6it [00:00, 734.38it/s]\n",
      "6it [00:00, 710.46it/s]\n",
      "6it [00:00, 726.64it/s]\n",
      "6it [00:00, 729.82it/s]\n",
      "6it [00:00, 689.97it/s]\n",
      "6it [00:00, 405.16it/s]\n",
      "6it [00:00, 488.88it/s]\n",
      "6it [00:00, 422.44it/s]\n",
      "6it [00:00, 233.25it/s]\n",
      "6it [00:00, 617.35it/s]\n",
      "6it [00:00, 664.69it/s]\n",
      "6it [00:00, 711.60it/s]\n",
      "6it [00:00, 690.31it/s]\n",
      "6it [00:00, 682.02it/s]\n",
      "6it [00:00, 753.22it/s]\n",
      "9it [00:00, 705.35it/s]\n",
      "4it [00:00, 544.84it/s]\n",
      "2it [00:00, 478.04it/s]\n",
      "2it [00:00, 408.70it/s]\n",
      "2it [00:00, 363.43it/s]\n",
      "2it [00:00, 640.16it/s]\n",
      "2it [00:00, 634.06it/s]\n",
      "2it [00:00, 227.40it/s]\n",
      "2it [00:00, 206.51it/s]\n",
      "2it [00:00, 209.65it/s]\n",
      "2it [00:00, 346.57it/s]\n",
      "2it [00:00, 591.79it/s]\n",
      "2it [00:00, 564.05it/s]\n",
      "2it [00:00, 614.01it/s]\n",
      "2it [00:00, 707.12it/s]\n",
      "2it [00:00, 667.72it/s]\n",
      "2it [00:00, 636.80it/s]\n",
      "2it [00:00, 648.52it/s]\n",
      "2it [00:00, 604.72it/s]\n",
      "2it [00:00, 617.58it/s]\n",
      "2it [00:00, 620.64it/s]\n",
      "2it [00:00, 702.56it/s]\n",
      "2it [00:00, 689.06it/s]\n",
      "2it [00:00, 640.89it/s]\n",
      "2it [00:00, 628.45it/s]\n",
      "2it [00:00, 629.11it/s]\n",
      "2it [00:00, 648.52it/s]\n",
      "9it [00:00, 689.65it/s]\n",
      "4it [00:00, 416.39it/s]\n",
      "2it [00:00, 523.44it/s]\n",
      "2it [00:00, 608.53it/s]\n",
      "2it [00:00, 687.42it/s]\n",
      "2it [00:00, 386.55it/s]\n",
      "2it [00:00, 221.52it/s]\n",
      "2it [00:00, 231.75it/s]\n",
      "2it [00:00, 562.47it/s]\n",
      "2it [00:00, 577.65it/s]\n",
      "2it [00:00, 569.96it/s]\n",
      "2it [00:00, 587.40it/s]\n",
      "2it [00:00, 568.56it/s]\n",
      "2it [00:00, 625.92it/s]\n",
      "2it [00:00, 571.47it/s]\n",
      "2it [00:00, 540.09it/s]\n",
      "2it [00:00, 566.42it/s]\n",
      "2it [00:00, 566.80it/s]\n",
      "2it [00:00, 425.13it/s]\n",
      "2it [00:00, 422.26it/s]\n",
      "2it [00:00, 437.00it/s]\n",
      "2it [00:00, 459.42it/s]\n",
      "2it [00:00, 457.59it/s]\n",
      "2it [00:00, 426.97it/s]\n",
      "2it [00:00, 448.09it/s]\n",
      "2it [00:00, 451.07it/s]\n",
      "2it [00:00, 430.34it/s]\n",
      "9it [00:00, 513.32it/s]\n",
      "4it [00:00, 677.57it/s]\n",
      "2it [00:00, 693.73it/s]\n",
      "2it [00:00, 681.06it/s]\n",
      "2it [00:00, 691.56it/s]\n",
      "2it [00:00, 691.05it/s]\n",
      "2it [00:00, 693.16it/s]\n",
      "2it [00:00, 689.68it/s]\n",
      "2it [00:00, 690.88it/s]\n",
      "2it [00:00, 694.88it/s]\n",
      "2it [00:00, 696.79it/s]\n",
      "2it [00:00, 691.10it/s]\n",
      "2it [00:00, 694.59it/s]\n",
      "2it [00:00, 687.31it/s]\n",
      "2it [00:00, 654.70it/s]\n",
      "2it [00:00, 656.49it/s]\n",
      "2it [00:00, 687.42it/s]\n",
      "2it [00:00, 705.58it/s]\n",
      "2it [00:00, 692.70it/s]\n",
      "2it [00:00, 693.39it/s]\n",
      "2it [00:00, 650.78it/s]\n",
      "2it [00:00, 640.74it/s]\n",
      "2it [00:00, 639.91it/s]\n",
      "2it [00:00, 641.63it/s]\n",
      "2it [00:00, 630.91it/s]\n",
      "2it [00:00, 630.20it/s]\n",
      "2it [00:00, 626.76it/s]\n",
      "9it [00:00, 695.33it/s]\n",
      "4it [00:00, 609.24it/s]\n",
      "2it [00:00, 633.68it/s]\n",
      "2it [00:00, 628.64it/s]\n",
      "2it [00:00, 603.93it/s]\n",
      "2it [00:00, 389.37it/s]\n",
      "2it [00:00, 536.80it/s]\n",
      "2it [00:00, 559.73it/s]\n",
      "2it [00:00, 419.91it/s]\n",
      "2it [00:00, 637.00it/s]\n",
      "2it [00:00, 651.39it/s]\n",
      "2it [00:00, 220.82it/s]\n",
      "2it [00:00, 195.95it/s]\n",
      "2it [00:00, 203.69it/s]\n",
      "2it [00:00, 318.47it/s]\n",
      "2it [00:00, 492.95it/s]\n",
      "2it [00:00, 468.40it/s]\n",
      "2it [00:00, 636.95it/s]\n",
      "2it [00:00, 698.70it/s]\n",
      "2it [00:00, 642.76it/s]\n",
      "2it [00:00, 608.49it/s]\n",
      "2it [00:00, 609.33it/s]\n",
      "2it [00:00, 643.10it/s]\n",
      "2it [00:00, 646.67it/s]\n",
      "2it [00:00, 665.39it/s]\n",
      "2it [00:00, 691.84it/s]\n",
      "2it [00:00, 670.87it/s]\n",
      "9it [00:00, 721.21it/s]\n",
      "4it [00:00, 649.95it/s]\n",
      "2it [00:00, 696.27it/s]\n",
      "2it [00:00, 701.45it/s]\n",
      "2it [00:00, 665.39it/s]\n",
      "2it [00:00, 652.96it/s]\n",
      "2it [00:00, 672.33it/s]\n",
      "2it [00:00, 670.50it/s]\n",
      "2it [00:00, 672.49it/s]\n",
      "2it [00:00, 674.33it/s]\n",
      "2it [00:00, 631.91it/s]\n",
      "2it [00:00, 326.53it/s]\n",
      "2it [00:00, 407.77it/s]\n",
      "2it [00:00, 474.33it/s]\n",
      "2it [00:00, 433.47it/s]\n",
      "2it [00:00, 494.52it/s]\n",
      "2it [00:00, 646.72it/s]\n",
      "2it [00:00, 695.17it/s]\n",
      "2it [00:00, 316.89it/s]\n",
      "2it [00:00, 206.08it/s]\n",
      "2it [00:00, 208.79it/s]\n",
      "2it [00:00, 271.31it/s]\n",
      "2it [00:00, 521.74it/s]\n",
      "2it [00:00, 566.99it/s]\n",
      "2it [00:00, 642.02it/s]\n",
      "2it [00:00, 657.47it/s]\n",
      "2it [00:00, 607.12it/s]\n",
      "9it [00:00, 725.34it/s]\n",
      "4it [00:00, 662.48it/s]\n",
      "2it [00:00, 546.77it/s]\n",
      "2it [00:00, 443.21it/s]\n",
      "2it [00:00, 392.84it/s]\n",
      "2it [00:00, 393.11it/s]\n",
      "2it [00:00, 627.04it/s]\n",
      "2it [00:00, 656.95it/s]\n",
      "2it [00:00, 300.75it/s]\n",
      "2it [00:00, 209.28it/s]\n",
      "2it [00:00, 200.93it/s]\n",
      "2it [00:00, 453.46it/s]\n",
      "2it [00:00, 511.10it/s]\n",
      "2it [00:00, 561.60it/s]\n",
      "2it [00:00, 577.73it/s]\n",
      "2it [00:00, 660.31it/s]\n",
      "2it [00:00, 703.45it/s]\n",
      "2it [00:00, 614.33it/s]\n",
      "2it [00:00, 613.29it/s]\n",
      "2it [00:00, 613.83it/s]\n",
      "2it [00:00, 611.99it/s]\n",
      "2it [00:00, 615.41it/s]\n",
      "2it [00:00, 693.73it/s]\n",
      "2it [00:00, 700.57it/s]\n",
      "2it [00:00, 666.50it/s]\n",
      "2it [00:00, 634.92it/s]\n",
      "2it [00:00, 638.45it/s]\n",
      "2it [00:00, 637.43it/s]\n",
      "2it [00:00, 653.52it/s]\n",
      "2it [00:00, 658.70it/s]\n",
      "2it [00:00, 617.13it/s]\n",
      "2it [00:00, 603.06it/s]\n",
      "9it [00:00, 647.34it/s]\n",
      "4it [00:00, 668.73it/s]\n",
      "2it [00:00, 641.23it/s]\n",
      "2it [00:00, 644.04it/s]\n",
      "2it [00:00, 639.52it/s]\n",
      "2it [00:00, 333.54it/s]\n",
      "2it [00:00, 334.98it/s]\n",
      "2it [00:00, 333.76it/s]\n",
      "2it [00:00, 533.49it/s]\n",
      "2it [00:00, 593.42it/s]\n",
      "2it [00:00, 290.02it/s]\n",
      "2it [00:00, 185.57it/s]\n",
      "2it [00:00, 203.69it/s]\n",
      "2it [00:00, 246.48it/s]\n",
      "2it [00:00, 501.89it/s]\n",
      "2it [00:00, 609.64it/s]\n",
      "2it [00:00, 697.71it/s]\n",
      "2it [00:00, 618.99it/s]\n",
      "2it [00:00, 622.99it/s]\n",
      "2it [00:00, 588.55it/s]\n",
      "2it [00:00, 625.27it/s]\n",
      "2it [00:00, 651.34it/s]\n",
      "2it [00:00, 602.50it/s]\n",
      "2it [00:00, 689.91it/s]\n",
      "2it [00:00, 673.73it/s]\n",
      "2it [00:00, 640.84it/s]\n",
      "2it [00:00, 671.30it/s]\n",
      "2it [00:00, 672.92it/s]\n",
      "2it [00:00, 598.37it/s]\n",
      "2it [00:00, 640.30it/s]\n",
      "2it [00:00, 643.79it/s]\n",
      "2it [00:00, 586.00it/s]\n",
      "9it [00:00, 647.34it/s]\n",
      "4it [00:00, 441.30it/s]\n",
      "2it [00:00, 635.31it/s]\n",
      "2it [00:00, 660.31it/s]\n",
      "2it [00:00, 260.33it/s]\n",
      "2it [00:00, 211.41it/s]\n",
      "2it [00:00, 212.85it/s]\n",
      "2it [00:00, 611.06it/s]\n",
      "2it [00:00, 590.75it/s]\n",
      "2it [00:00, 571.35it/s]\n",
      "2it [00:00, 549.06it/s]\n",
      "2it [00:00, 589.87it/s]\n",
      "2it [00:00, 693.27it/s]\n",
      "2it [00:00, 650.33it/s]\n",
      "2it [00:00, 592.79it/s]\n",
      "2it [00:00, 585.80it/s]\n",
      "2it [00:00, 594.22it/s]\n",
      "2it [00:00, 590.33it/s]\n",
      "2it [00:00, 592.63it/s]\n",
      "2it [00:00, 594.68it/s]\n",
      "2it [00:00, 586.33it/s]\n",
      "2it [00:00, 593.80it/s]\n",
      "2it [00:00, 602.11it/s]\n",
      "2it [00:00, 684.73it/s]\n",
      "2it [00:00, 701.45it/s]\n",
      "2it [00:00, 679.57it/s]\n",
      "2it [00:00, 685.79it/s]\n",
      "2it [00:00, 672.70it/s]\n",
      "2it [00:00, 671.84it/s]\n",
      "2it [00:00, 667.51it/s]\n",
      "2it [00:00, 678.36it/s]\n",
      "2it [00:00, 678.96it/s]\n",
      "9it [00:00, 689.70it/s]\n",
      "4it [00:00, 690.34it/s]\n",
      "2it [00:00, 692.24it/s]\n",
      "2it [00:00, 696.09it/s]\n",
      "2it [00:00, 708.56it/s]\n",
      "2it [00:00, 696.84it/s]\n",
      "2it [00:00, 703.92it/s]\n",
      "2it [00:00, 700.39it/s]\n",
      "2it [00:00, 701.98it/s]\n",
      "2it [00:00, 700.80it/s]\n",
      "2it [00:00, 696.21it/s]\n",
      "2it [00:00, 701.10it/s]\n",
      "2it [00:00, 705.22it/s]\n",
      "2it [00:00, 705.58it/s]\n",
      "2it [00:00, 694.08it/s]\n",
      "2it [00:00, 696.96it/s]\n",
      "2it [00:00, 690.08it/s]\n",
      "2it [00:00, 702.98it/s]\n",
      "2it [00:00, 692.70it/s]\n",
      "2it [00:00, 704.93it/s]\n",
      "2it [00:00, 689.80it/s]\n",
      "2it [00:00, 695.05it/s]\n",
      "2it [00:00, 707.06it/s]\n",
      "2it [00:00, 698.88it/s]\n",
      "2it [00:00, 695.00it/s]\n",
      "2it [00:00, 692.59it/s]\n",
      "2it [00:00, 697.60it/s]\n",
      "2it [00:00, 652.91it/s]\n",
      "2it [00:00, 627.23it/s]\n",
      "2it [00:00, 653.98it/s]\n",
      "2it [00:00, 629.78it/s]\n",
      "2it [00:00, 631.86it/s]\n",
      "9it [00:00, 683.26it/s]\n",
      "4it [00:00, 690.02it/s]\n",
      "2it [00:00, 670.18it/s]\n",
      "2it [00:00, 698.53it/s]\n",
      "2it [00:00, 703.51it/s]\n",
      "2it [00:00, 644.48it/s]\n",
      "2it [00:00, 712.11it/s]\n",
      "2it [00:00, 695.17it/s]\n",
      "2it [00:00, 696.90it/s]\n",
      "2it [00:00, 700.98it/s]\n",
      "2it [00:00, 706.94it/s]\n",
      "2it [00:00, 709.04it/s]\n",
      "2it [00:00, 692.19it/s]\n",
      "2it [00:00, 701.39it/s]\n",
      "2it [00:00, 692.53it/s]\n",
      "2it [00:00, 697.25it/s]\n",
      "2it [00:00, 693.10it/s]\n",
      "2it [00:00, 691.62it/s]\n",
      "2it [00:00, 691.96it/s]\n",
      "2it [00:00, 695.17it/s]\n",
      "2it [00:00, 692.02it/s]\n",
      "2it [00:00, 684.23it/s]\n",
      "2it [00:00, 691.39it/s]\n",
      "2it [00:00, 692.70it/s]\n",
      "2it [00:00, 694.65it/s]\n",
      "2it [00:00, 690.42it/s]\n",
      "2it [00:00, 690.36it/s]\n",
      "2it [00:00, 696.44it/s]\n",
      "2it [00:00, 696.96it/s]\n",
      "2it [00:00, 702.86it/s]\n",
      "2it [00:00, 698.00it/s]\n",
      "2it [00:00, 699.81it/s]\n",
      "9it [00:00, 760.62it/s]\n",
      "4it [00:00, 614.03it/s]\n",
      "2it [00:00, 601.33it/s]\n",
      "2it [00:00, 653.22it/s]\n",
      "2it [00:00, 695.69it/s]\n",
      "2it [00:00, 689.40it/s]\n",
      "2it [00:00, 656.18it/s]\n",
      "2it [00:00, 618.17it/s]\n",
      "2it [00:00, 634.78it/s]\n",
      "2it [00:00, 634.20it/s]\n",
      "2it [00:00, 635.07it/s]\n",
      "2it [00:00, 631.62it/s]\n",
      "2it [00:00, 621.52it/s]\n",
      "2it [00:00, 419.22it/s]\n",
      "2it [00:00, 568.26it/s]\n",
      "2it [00:00, 578.56it/s]\n",
      "2it [00:00, 447.51it/s]\n",
      "2it [00:00, 646.62it/s]\n",
      "2it [00:00, 640.45it/s]\n",
      "2it [00:00, 306.61it/s]\n",
      "2it [00:00, 193.05it/s]\n",
      "2it [00:00, 194.44it/s]\n",
      "2it [00:00, 438.39it/s]\n",
      "2it [00:00, 564.13it/s]\n",
      "2it [00:00, 550.90it/s]\n",
      "2it [00:00, 626.72it/s]\n",
      "2it [00:00, 700.98it/s]\n",
      "2it [00:00, 634.88it/s]\n",
      "2it [00:00, 652.56it/s]\n",
      "2it [00:00, 596.93it/s]\n",
      "2it [00:00, 654.03it/s]\n",
      "2it [00:00, 639.28it/s]\n",
      "2it [00:00, 633.15it/s]\n",
      "2it [00:00, 679.68it/s]\n",
      "2it [00:00, 665.55it/s]\n",
      "2it [00:00, 642.07it/s]\n",
      "2it [00:00, 643.15it/s]\n",
      "2it [00:00, 641.38it/s]\n",
      "2it [00:00, 641.38it/s]\n",
      "2it [00:00, 661.51it/s]\n",
      "2it [00:00, 620.37it/s]\n",
      "2it [00:00, 611.59it/s]\n",
      "9it [00:00, 670.17it/s]\n",
      "4it [00:00, 635.77it/s]\n",
      "2it [00:00, 686.02it/s]\n",
      "2it [00:00, 689.74it/s]\n",
      "2it [00:00, 635.89it/s]\n",
      "2it [00:00, 647.27it/s]\n",
      "2it [00:00, 664.18it/s]\n",
      "2it [00:00, 664.81it/s]\n",
      "2it [00:00, 654.44it/s]\n",
      "2it [00:00, 645.63it/s]\n",
      "2it [00:00, 598.63it/s]\n",
      "2it [00:00, 321.00it/s]\n",
      "2it [00:00, 338.18it/s]\n",
      "2it [00:00, 342.56it/s]\n",
      "2it [00:00, 531.97it/s]\n",
      "2it [00:00, 594.47it/s]\n",
      "2it [00:00, 356.20it/s]\n",
      "2it [00:00, 209.11it/s]\n",
      "2it [00:00, 206.52it/s]\n",
      "2it [00:00, 224.41it/s]\n",
      "2it [00:00, 582.99it/s]\n",
      "2it [00:00, 579.84it/s]\n",
      "2it [00:00, 580.45it/s]\n",
      "2it [00:00, 681.45it/s]\n",
      "2it [00:00, 653.37it/s]\n",
      "2it [00:00, 630.67it/s]\n",
      "2it [00:00, 640.79it/s]\n",
      "2it [00:00, 629.07it/s]\n",
      "2it [00:00, 634.30it/s]\n",
      "2it [00:00, 654.39it/s]\n",
      "2it [00:00, 688.83it/s]\n",
      "2it [00:00, 686.75it/s]\n",
      "2it [00:00, 612.35it/s]\n",
      "2it [00:00, 617.40it/s]\n",
      "2it [00:00, 618.95it/s]\n",
      "2it [00:00, 642.71it/s]\n",
      "2it [00:00, 652.15it/s]\n",
      "2it [00:00, 608.88it/s]\n",
      "2it [00:00, 604.98it/s]\n",
      "2it [00:00, 596.97it/s]\n",
      "2it [00:00, 596.97it/s]\n",
      "2it [00:00, 618.40it/s]\n",
      "9it [00:00, 728.47it/s]\n",
      "4it [00:00, 598.89it/s]\n",
      "2it [00:00, 642.76it/s]\n",
      "2it [00:00, 625.27it/s]\n",
      "2it [00:00, 685.51it/s]\n",
      "2it [00:00, 687.93it/s]\n",
      "2it [00:00, 622.67it/s]\n",
      "2it [00:00, 624.80it/s]\n",
      "2it [00:00, 622.49it/s]\n",
      "2it [00:00, 623.41it/s]\n",
      "2it [00:00, 664.71it/s]\n",
      "2it [00:00, 625.97it/s]\n",
      "2it [00:00, 622.85it/s]\n",
      "2it [00:00, 596.97it/s]\n",
      "2it [00:00, 590.08it/s]\n",
      "2it [00:00, 586.29it/s]\n",
      "2it [00:00, 624.15it/s]\n",
      "2it [00:00, 689.85it/s]\n",
      "2it [00:00, 688.04it/s]\n",
      "2it [00:00, 692.42it/s]\n",
      "2it [00:00, 610.79it/s]\n",
      "2it [00:00, 651.95it/s]\n",
      "2it [00:00, 656.85it/s]\n",
      "2it [00:00, 655.10it/s]\n",
      "2it [00:00, 655.36it/s]\n",
      "2it [00:00, 649.78it/s]\n",
      "2it [00:00, 561.49it/s]\n",
      "2it [00:00, 420.29it/s]\n",
      "2it [00:00, 364.67it/s]\n",
      "2it [00:00, 370.78it/s]\n",
      "2it [00:00, 667.99it/s]\n",
      "2it [00:00, 627.42it/s]\n",
      "2it [00:00, 306.14it/s]\n",
      "2it [00:00, 197.04it/s]\n",
      "2it [00:00, 207.88it/s]\n",
      "2it [00:00, 440.69it/s]\n",
      "2it [00:00, 559.58it/s]\n",
      "2it [00:00, 510.75it/s]\n",
      "2it [00:00, 479.90it/s]\n",
      "2it [00:00, 631.82it/s]\n",
      "2it [00:00, 675.14it/s]\n",
      "2it [00:00, 602.02it/s]\n",
      "9it [00:00, 653.33it/s]\n",
      "4it [00:00, 619.02it/s]\n",
      "2it [00:00, 569.76it/s]\n",
      "2it [00:00, 465.00it/s]\n",
      "2it [00:00, 632.10it/s]\n",
      "2it [00:00, 695.80it/s]\n",
      "2it [00:00, 643.35it/s]\n",
      "2it [00:00, 646.12it/s]\n",
      "2it [00:00, 623.22it/s]\n",
      "2it [00:00, 656.03it/s]\n",
      "2it [00:00, 630.96it/s]\n",
      "2it [00:00, 697.48it/s]\n",
      "2it [00:00, 682.28it/s]\n",
      "2it [00:00, 665.29it/s]\n",
      "2it [00:00, 668.73it/s]\n",
      "2it [00:00, 664.81it/s]\n",
      "2it [00:00, 669.70it/s]\n",
      "2it [00:00, 649.78it/s]\n",
      "2it [00:00, 610.66it/s]\n",
      "2it [00:00, 592.92it/s]\n",
      "2it [00:00, 627.80it/s]\n",
      "2it [00:00, 606.99it/s]\n",
      "2it [00:00, 596.25it/s]\n",
      "2it [00:00, 627.47it/s]\n",
      "2it [00:00, 679.79it/s]\n",
      "2it [00:00, 688.83it/s]\n",
      "2it [00:00, 688.95it/s]\n",
      "2it [00:00, 608.80it/s]\n",
      "2it [00:00, 621.42it/s]\n",
      "2it [00:00, 653.88it/s]\n",
      "2it [00:00, 663.81it/s]\n",
      "2it [00:00, 654.18it/s]\n",
      "2it [00:00, 639.91it/s]\n",
      "2it [00:00, 633.34it/s]\n",
      "2it [00:00, 391.97it/s]\n",
      "2it [00:00, 385.13it/s]\n",
      "2it [00:00, 381.75it/s]\n",
      "2it [00:00, 466.81it/s]\n",
      "2it [00:00, 611.50it/s]\n",
      "2it [00:00, 299.01it/s]\n",
      "2it [00:00, 230.87it/s]\n",
      "2it [00:00, 202.57it/s]\n",
      "9it [00:00, 570.14it/s]\n",
      "4it [00:00, 682.53it/s]\n",
      "2it [00:00, 692.70it/s]\n",
      "2it [00:00, 688.55it/s]\n",
      "2it [00:00, 687.48it/s]\n",
      "2it [00:00, 688.66it/s]\n",
      "2it [00:00, 686.47it/s]\n",
      "2it [00:00, 682.56it/s]\n",
      "2it [00:00, 689.63it/s]\n",
      "2it [00:00, 694.31it/s]\n",
      "2it [00:00, 690.25it/s]\n",
      "2it [00:00, 689.91it/s]\n",
      "2it [00:00, 685.23it/s]\n",
      "2it [00:00, 683.39it/s]\n",
      "2it [00:00, 688.55it/s]\n",
      "2it [00:00, 685.40it/s]\n",
      "2it [00:00, 689.46it/s]\n",
      "2it [00:00, 686.30it/s]\n",
      "2it [00:00, 688.95it/s]\n",
      "2it [00:00, 691.44it/s]\n",
      "2it [00:00, 688.21it/s]\n",
      "2it [00:00, 688.72it/s]\n",
      "2it [00:00, 692.64it/s]\n",
      "2it [00:00, 688.44it/s]\n",
      "2it [00:00, 679.90it/s]\n",
      "2it [00:00, 692.53it/s]\n",
      "2it [00:00, 688.21it/s]\n",
      "2it [00:00, 687.42it/s]\n",
      "2it [00:00, 683.78it/s]\n",
      "2it [00:00, 685.68it/s]\n",
      "2it [00:00, 690.19it/s]\n",
      "2it [00:00, 691.79it/s]\n",
      "2it [00:00, 689.40it/s]\n",
      "2it [00:00, 686.63it/s]\n",
      "2it [00:00, 690.82it/s]\n",
      "2it [00:00, 688.89it/s]\n",
      "2it [00:00, 686.52it/s]\n",
      "2it [00:00, 678.47it/s]\n",
      "2it [00:00, 677.81it/s]\n",
      "2it [00:00, 678.36it/s]\n",
      "2it [00:00, 680.40it/s]\n",
      "2it [00:00, 678.20it/s]\n",
      "9it [00:00, 748.40it/s]\n"
     ]
    }
   ],
   "source": [
    "for restarts in [5, 10, 15, 20]:\n",
    "    for restart_steps in [5, 7]:\n",
    "        for before_steps in [5]:\n",
    "            for after_steps in [10]:\n",
    "                err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "                restart_data.append(err)\n",
    "                \n",
    "for restarts in [25, 30, 40]:\n",
    "    for restart_steps in [3]:\n",
    "        for before_steps in [5]:\n",
    "            for after_steps in [10]:\n",
    "                err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "                restart_data.append(err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "56dbeec1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "9it [00:00, 483.51it/s]\n",
      "4it [00:00, 657.80it/s]\n",
      "4it [00:00, 643.30it/s]\n",
      "4it [00:00, 658.65it/s]\n",
      "4it [00:00, 662.63it/s]\n",
      "4it [00:00, 698.73it/s]\n",
      "4it [00:00, 671.22it/s]\n",
      "4it [00:00, 653.57it/s]\n",
      "4it [00:00, 714.05it/s]\n",
      "4it [00:00, 738.66it/s]\n",
      "4it [00:00, 738.60it/s]\n",
      "4it [00:00, 732.98it/s]\n",
      "4it [00:00, 739.25it/s]\n",
      "4it [00:00, 736.55it/s]\n",
      "4it [00:00, 738.86it/s]\n",
      "4it [00:00, 739.38it/s]\n",
      "4it [00:00, 737.91it/s]\n",
      "4it [00:00, 735.78it/s]\n",
      "4it [00:00, 740.68it/s]\n",
      "4it [00:00, 729.35it/s]\n",
      "4it [00:00, 738.56it/s]\n",
      "44it [00:00, 780.01it/s]\n",
      "9it [00:00, 662.97it/s]\n",
      "4it [00:00, 725.03it/s]\n",
      "4it [00:00, 731.96it/s]\n",
      "4it [00:00, 666.64it/s]\n",
      "4it [00:00, 666.11it/s]\n",
      "4it [00:00, 666.05it/s]\n",
      "4it [00:00, 666.98it/s]\n",
      "4it [00:00, 639.99it/s]\n",
      "4it [00:00, 628.78it/s]\n",
      "4it [00:00, 661.85it/s]\n",
      "4it [00:00, 674.62it/s]\n",
      "4it [00:00, 738.50it/s]\n",
      "4it [00:00, 740.78it/s]\n",
      "4it [00:00, 676.28it/s]\n",
      "4it [00:00, 704.93it/s]\n",
      "4it [00:00, 703.09it/s]\n",
      "4it [00:00, 690.99it/s]\n",
      "4it [00:00, 695.83it/s]\n",
      "4it [00:00, 477.81it/s]\n",
      "4it [00:00, 427.03it/s]\n",
      "4it [00:00, 371.25it/s]\n",
      "44it [00:00, 487.64it/s]\n",
      "9it [00:00, 547.46it/s]\n",
      "4it [00:00, 198.11it/s]\n",
      "4it [00:00, 272.66it/s]\n",
      "4it [00:00, 652.81it/s]\n",
      "4it [00:00, 643.42it/s]\n",
      "4it [00:00, 657.41it/s]\n",
      "4it [00:00, 757.57it/s]\n",
      "4it [00:00, 683.81it/s]\n",
      "4it [00:00, 669.11it/s]\n",
      "4it [00:00, 645.70it/s]\n",
      "4it [00:00, 685.48it/s]\n",
      "4it [00:00, 699.58it/s]\n",
      "4it [00:00, 717.86it/s]\n",
      "4it [00:00, 759.98it/s]\n",
      "4it [00:00, 725.44it/s]\n",
      "4it [00:00, 722.16it/s]\n",
      "4it [00:00, 743.37it/s]\n",
      "4it [00:00, 704.69it/s]\n",
      "4it [00:00, 672.89it/s]\n",
      "4it [00:00, 708.23it/s]\n",
      "4it [00:00, 652.30it/s]\n",
      "44it [00:00, 738.80it/s]\n",
      "9it [00:00, 662.41it/s]\n",
      "4it [00:00, 689.31it/s]\n",
      "4it [00:00, 739.15it/s]\n",
      "4it [00:00, 692.90it/s]\n",
      "4it [00:00, 692.99it/s]\n",
      "4it [00:00, 684.87it/s]\n",
      "4it [00:00, 703.86it/s]\n",
      "4it [00:00, 703.71it/s]\n",
      "4it [00:00, 645.65it/s]\n",
      "4it [00:00, 419.23it/s]\n",
      "4it [00:00, 418.80it/s]\n",
      "4it [00:00, 560.87it/s]\n",
      "4it [00:00, 529.25it/s]\n",
      "4it [00:00, 220.64it/s]\n",
      "4it [00:00, 301.08it/s]\n",
      "4it [00:00, 637.92it/s]\n",
      "4it [00:00, 559.28it/s]\n",
      "4it [00:00, 718.85it/s]\n",
      "4it [00:00, 581.31it/s]\n",
      "4it [00:00, 675.14it/s]\n",
      "4it [00:00, 666.45it/s]\n",
      "44it [00:00, 753.79it/s]\n",
      "9it [00:00, 581.30it/s]\n",
      "4it [00:00, 693.56it/s]\n",
      "4it [00:00, 707.78it/s]\n",
      "4it [00:00, 682.44it/s]\n",
      "4it [00:00, 664.60it/s]\n",
      "4it [00:00, 691.19it/s]\n",
      "4it [00:00, 728.24it/s]\n",
      "4it [00:00, 741.31it/s]\n",
      "4it [00:00, 706.35it/s]\n",
      "4it [00:00, 708.35it/s]\n",
      "4it [00:00, 707.75it/s]\n",
      "4it [00:00, 723.25it/s]\n",
      "4it [00:00, 661.28it/s]\n",
      "4it [00:00, 670.95it/s]\n",
      "4it [00:00, 652.51it/s]\n",
      "4it [00:00, 677.27it/s]\n",
      "4it [00:00, 730.78it/s]\n",
      "4it [00:00, 742.06it/s]\n",
      "4it [00:00, 692.33it/s]\n",
      "4it [00:00, 706.50it/s]\n",
      "4it [00:00, 705.13it/s]\n",
      "44it [00:00, 518.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(134, 0.7600341312326517, 0.8224215049268142, 0.7792112448239836)\n"
     ]
    }
   ],
   "source": [
    "# for restarts in [20, 25]:\n",
    "#     for restart_steps in [5, 6, 7]:\n",
    "#         for before_steps in [5]:\n",
    "#             for after_steps in [30]:\n",
    "#                 err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "#                 print(err)\n",
    "#                 restart_data.append(err)\n",
    "for restarts in [20]:\n",
    "    for restart_steps in [5]:\n",
    "        for before_steps in [10]:\n",
    "            for after_steps in [45]:\n",
    "                err = restart_error(restart_times=restarts, restart_steps = restart_steps, before_steps = before_steps, after_steps=after_steps, rounds = 5)\n",
    "                print(err)\n",
    "                restart_data.append(err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "6ec253f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_restart()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "c09e973a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[80, 0.9004135045974151], [160, 0.9023963591572531], [320, 0.9034297484275031], [20, 0.8914044456062266], [40, 0.8968616946050588], [640, 0.9039619380400499]]\n",
      "[[20, 0.8914044456062266], [40, 0.8968616946050588], [80, 0.9004135045974151], [160, 0.9023963591572531], [320, 0.9034297484275031], [640, 0.9039619380400499]]\n",
      "[[320, 0.9034297484275031], [320, 0.9053446092126295], [320, 0.9029666340306166], [320, 0.8898671026070829], [320, 0.8772100103599497], [320, 0.8792199351642804], [320, 0.8447741708446628], [320, 0.8240037599343664], [320, 0.7701639089445691], [20, 0.8716147674248209], [20, 0.9014347014031453], [20, 0.8840481487507564], [20, 0.8817647760776293], [20, 0.8754396527110597], [20, 0.8909827621265481], [20, 0.9787034220317155], [40, 0.8802708190006931], [40, 0.8477651675679301], [40, 0.8531778961089319], [40, 0.8984215687422916], [80, 0.8496497649938984], [80, 0.8183762677668701], [80, 0.8508292405635582], [80, 0.8359765919799592], [160, 0.819395146098201], [160, 0.7999523648681335], [160, 0.848523506944613], [160, 0.7782501761246101], [320, 0.7770851434938159], [320, 0.8862892410771235], [320, 0.8663537769611718], [320, 0.7656374218393021]]\n",
      "[[20, 0.8716147674248209], [20, 0.8754396527110597], [20, 0.8817647760776293], [20, 0.8840481487507564], [20, 0.8909827621265481], [20, 0.9014347014031453], [20, 0.9787034220317155], [40, 0.8477651675679301], [40, 0.8531778961089319], [40, 0.8802708190006931], [40, 0.8984215687422916], [80, 0.8183762677668701], [80, 0.8359765919799592], [80, 0.8496497649938984], [80, 0.8508292405635582], [160, 0.7782501761246101], [160, 0.7999523648681335], [160, 0.819395146098201], [160, 0.848523506944613], [320, 0.7656374218393021], [320, 0.7701639089445691], [320, 0.7770851434938159], [320, 0.8240037599343664], [320, 0.8447741708446628], [320, 0.8663537769611718], [320, 0.8772100103599497], [320, 0.8792199351642804], [320, 0.8862892410771235], [320, 0.8898671026070829], [320, 0.9029666340306166], [320, 0.9034297484275031], [320, 0.9053446092126295]]\n",
      "[[320, 0.9034297484275031], [320, 0.8992097715669054], [320, 0.908722878491812], [320, 0.9061245867784727], [320, 0.8873483729992051], [320, 0.8834072171137881], [320, 0.8818740806646467], [320, 0.8589945696922943], [20, 0.8914044456062266], [20, 0.8933820972652283], [20, 0.8996460225669185], [20, 0.9026385605489553], [20, 0.9234756629810732], [20, 0.9510316543094242], [20, 1.1174107008921192], [20, 2.037730444692616], [20, 5.078010554239132], [40, 0.8968616946050588], [40, 0.9031363816031114], [40, 0.8999878109277935], [40, 0.9033603145995031], [40, 0.9040673779467738], [40, 0.9099584342636101], [40, 0.9350897120998505], [40, 1.0214635797170541], [40, 2.7784885900816576], [80, 0.9004135045974151], [80, 0.900299110555298], [80, 0.8965951627771276], [80, 0.9001721945278256], [80, 0.8998345128009596], [80, 0.8981670584431007], [80, 0.8917751243206746], [80, 0.8818714579316771], [80, 0.9457041817122764], [160, 0.9023963591572531], [160, 0.9015867643221454], [160, 0.8969753997455598], [160, 0.8906577838704381], [160, 0.8986934336351501], [160, 0.9098517805259398], [160, 0.8823844741144707], [160, 0.8733635972789043], [160, 0.8313606798567695], [320, 0.9034297484275031], [320, 0.8968033617469551], [320, 0.9052922938631864], [320, 0.890490346619519], [320, 0.8910932165492772], [320, 0.8812021720255541], [320, 0.8820855443558735], [320, 0.8513568688390475], [320, 0.8347711737541577]]\n",
      "[[20, 0.8914044456062266], [20, 0.8933820972652283], [20, 0.8996460225669185], [20, 0.9026385605489553], [20, 0.9234756629810732], [20, 0.9510316543094242], [20, 1.1174107008921192], [20, 2.037730444692616], [20, 5.078010554239132], [40, 0.8968616946050588], [40, 0.8999878109277935], [40, 0.9031363816031114], [40, 0.9033603145995031], [40, 0.9040673779467738], [40, 0.9099584342636101], [40, 0.9350897120998505], [40, 1.0214635797170541], [40, 2.7784885900816576], [80, 0.8818714579316771], [80, 0.8917751243206746], [80, 0.8965951627771276], [80, 0.8981670584431007], [80, 0.8998345128009596], [80, 0.9001721945278256], [80, 0.900299110555298], [80, 0.9004135045974151], [80, 0.9457041817122764], [160, 0.8313606798567695], [160, 0.8733635972789043], [160, 0.8823844741144707], [160, 0.8906577838704381], [160, 0.8969753997455598], [160, 0.8986934336351501], [160, 0.9015867643221454], [160, 0.9023963591572531], [160, 0.9098517805259398], [320, 0.8347711737541577], [320, 0.8513568688390475], [320, 0.8589945696922943], [320, 0.8812021720255541], [320, 0.8818740806646467], [320, 0.8820855443558735], [320, 0.8834072171137881], [320, 0.8873483729992051], [320, 0.890490346619519], [320, 0.8910932165492772], [320, 0.8968033617469551], [320, 0.8992097715669054], [320, 0.9034297484275031], [320, 0.9034297484275031], [320, 0.9052922938631864], [320, 0.9061245867784727], [320, 0.908722878491812]]\n",
      "[[79, 0.8990233881096819], [274, 0.8768556461149484], [469, 0.8308351474957105], [664, 0.8014975101019723], [859, 0.74808097310916], [1054, 0.7472303577798175], [1249, 0.7439027449641745], [1444, 0.7483622379879179], [79, 0.8990233881096819], [79, 0.8990233881096819], [79, 0.8990233881096819], [99, 0.8314469508815655], [124, 0.8634083242632297], [174, 0.8537534885972802], [119, 0.8224631641654154], [169, 0.8253800933565918], [269, 0.8333395652063749], [139, 0.8084983666156231], [214, 0.8198128629675479], [364, 0.7775851993583391], [159, 0.7731252424220341], [259, 0.7677007634698366], [459, 0.7610166004124115], [179, 0.740435007570715], [304, 0.7338558100437924], [554, 0.744766962750966], [199, 0.7388839399256278], [349, 0.7518388540919105], [649, 0.7585757194573143], [219, 0.7798178512055542], [394, 0.7389234105005469], [744, 0.7528369407008454], [39, 0.8677312101173877], [54, 0.8655124180637573], [59, 0.8356527621046637], [89, 0.8345727412125885], [99, 0.7731184258013859], [159, 0.8000119210719042], [24, 0.8727481056391518], [34, 0.8300350951203272], [44, 0.8120527639042798], [54, 0.7632477545840163]]\n",
      "[[24, 0.8727481056391518], [34, 0.8300350951203272], [39, 0.8677312101173877], [44, 0.8120527639042798], [54, 0.7632477545840163], [54, 0.8655124180637573], [59, 0.8356527621046637], [79, 0.8990233881096819], [79, 0.8990233881096819], [79, 0.8990233881096819], [79, 0.8990233881096819], [89, 0.8345727412125885], [99, 0.7731184258013859], [99, 0.8314469508815655], [119, 0.8224631641654154], [124, 0.8634083242632297], [139, 0.8084983666156231], [159, 0.7731252424220341], [159, 0.8000119210719042], [169, 0.8253800933565918], [174, 0.8537534885972802], [179, 0.740435007570715], [199, 0.7388839399256278], [214, 0.8198128629675479], [219, 0.7798178512055542], [259, 0.7677007634698366], [269, 0.8333395652063749], [274, 0.8768556461149484], [304, 0.7338558100437924], [349, 0.7518388540919105], [364, 0.7775851993583391], [394, 0.7389234105005469], [459, 0.7610166004124115], [469, 0.8308351474957105], [554, 0.744766962750966], [649, 0.7585757194573143], [664, 0.8014975101019723], [744, 0.7528369407008454], [859, 0.74808097310916], [1054, 0.7472303577798175], [1249, 0.7439027449641745], [1444, 0.7483622379879179]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from matplotlib.pyplot import figure\n",
    "import matplotlib\n",
    "\n",
    "figure(figsize=(10, 6), dpi=80)\n",
    "\n",
    "sns.set(style='whitegrid', font_scale=1.5,rc={\"lines.linewidth\": 2.5})\n",
    "font1 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 20,}\n",
    "font2 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 18,}\n",
    "xtype = 0\n",
    "ytype = -3\n",
    "plt.xlabel(map_name(xtype))\n",
    "plt.xscale('log')\n",
    "plt.xticks([20, 40, 80, 160, 320], [20, 40, 80, 160, 320])\n",
    "plt.ylabel(map_name(ytype))\n",
    "plt.xlim(20, 400)\n",
    "\n",
    "def plot_info(infos, **kwargs):\n",
    "    print(infos)\n",
    "    # plt.scatter([x[0] for x in infos], [x[1] for x in infos])\n",
    "    sorted_infos = sorted(infos, key=lambda x: (x[0], x[1]))\n",
    "    print(sorted_infos)\n",
    "    min_error = sorted_infos[0][1]\n",
    "    for i in range(len(sorted_infos)):\n",
    "        min_error = min(min_error, sorted_infos[i][1])\n",
    "        sorted_infos[i][1] = min_error\n",
    "    plt.plot([x[0] for x in sorted_infos], [x[1] for x in sorted_infos], **kwargs)\n",
    "\n",
    "colors = ['b', 'r', 'g', 'c', 'm', 'y', 'k', 'w']\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], ODE_data)), label='ODE', color = colors[0])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], SDE_data)), label='Improved SDE', color = colors[1])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], vanilla_data)), label='Vanilla SDE', color = colors[3])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], restart_data)), label='Restart', color = colors[2])\n",
    "plt.legend()\n",
    "\n",
    "plt.savefig('NFE_vs_FID.pdf', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "plt.clf()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "c197b18b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.6899299184604413, 0.8859646956917487], [0.6918929361796647, 0.8881615867593119], [0.6862599828313526, 0.8837322063358395], [0.6948242285853266, 0.881702654617278], [0.6873915834393347, 0.8724307873944595], [0.6866530113817723, 0.8828088838382898]]\n",
      "[[0.6862599828313526, 0.8837322063358395], [0.6866530113817723, 0.8828088838382898], [0.6873915834393347, 0.8724307873944595], [0.6899299184604413, 0.8859646956917487], [0.6918929361796647, 0.8881615867593119], [0.6948242285853266, 0.881702654617278]]\n",
      "[[0.6881320524358292, 0.8911930557956005], [0.6926694628302756, 0.8962289544759109], [0.6919188699671147, 0.9035262853883266], [0.6939330258027662, 0.883492051465214], [0.7233050505023659, 0.8718803813650755], [0.7151795507662788, 0.8633343878740982], [0.7477209293585216, 0.8237639013268445], [0.8012308134502609, 0.8561934248886288], [0.8030858030608318, 0.7662590182062374], [0.7143889846191164, 0.8647990683870108], [0.7633422636917598, 0.8543474664320558], [0.7788365245620132, 0.7484883650078691], [0.7183678781375218, 0.8461896749047778], [0.7435374121150999, 0.8255045317977098], [0.8332710908488478, 0.8083938532309259], [0.9776844509529153, 0.6856705677986208], [0.7300936501858335, 0.8612061555415961], [0.7819976245308217, 0.785531121533509], [0.774238627148601, 0.7870513386762079], [0.9206206643979428, 0.6564548779116028], [0.7401202985531568, 0.8052012474936376], [0.8268852235115522, 0.7745832670914855], [0.7630142260611127, 0.8304049397579005], [0.8944332733035365, 0.7048774724386284], [0.7662058150987475, 0.7962920040044243], [0.8818995459291807, 0.7279263223474898], [0.7355482106067275, 0.819968844608279], [0.8368182270784086, 0.7726007983057208], [0.8107055769568614, 0.7992945776681754], [0.9304731562598825, 0.6673091079225298], [0.7294983531449761, 0.8623966832204998], [0.776862686116326, 0.7651499866004147]]\n",
      "[[0.6881320524358292, 0.8911930557956005], [0.6919188699671147, 0.9035262853883266], [0.6926694628302756, 0.8962289544759109], [0.6939330258027662, 0.883492051465214], [0.7143889846191164, 0.8647990683870108], [0.7151795507662788, 0.8633343878740982], [0.7183678781375218, 0.8461896749047778], [0.7233050505023659, 0.8718803813650755], [0.7294983531449761, 0.8623966832204998], [0.7300936501858335, 0.8612061555415961], [0.7355482106067275, 0.819968844608279], [0.7401202985531568, 0.8052012474936376], [0.7435374121150999, 0.8255045317977098], [0.7477209293585216, 0.8237639013268445], [0.7630142260611127, 0.8304049397579005], [0.7633422636917598, 0.8543474664320558], [0.7662058150987475, 0.7962920040044243], [0.774238627148601, 0.7870513386762079], [0.776862686116326, 0.7651499866004147], [0.7788365245620132, 0.7484883650078691], [0.7819976245308217, 0.785531121533509], [0.8012308134502609, 0.8561934248886288], [0.8030858030608318, 0.7662590182062374], [0.8107055769568614, 0.7992945776681754], [0.8268852235115522, 0.7745832670914855], [0.8332710908488478, 0.8083938532309259], [0.8368182270784086, 0.7726007983057208], [0.8818995459291807, 0.7279263223474898], [0.8944332733035365, 0.7048774724386284], [0.9206206643979428, 0.6564548779116028], [0.9304731562598825, 0.6673091079225298], [0.9776844509529153, 0.6856705677986208]]\n",
      "[[0.6799148452304866, 0.8896848471418629], [0.6905613544884935, 0.8870935002937891], [0.6909970331905826, 0.9080558682257198], [0.7108464340826476, 0.9202623918704143], [0.7082891551781964, 0.8759849878327491], [0.7161390164739283, 0.8778208099614325], [0.7330987289216984, 0.88860071775996], [0.7404704243416408, 0.8594075331935807], [0.6941328351873505, 0.8461818515621975], [0.6993820499637512, 0.8616324321089961], [0.7092975819067906, 0.882353987721535], [0.7104167826207796, 0.8896307543624216], [0.731115067003566, 0.9080176317988993], [0.7593260687520103, 0.953252385068741], [0.9671414991338217, 1.1864832067602984], [2.017179803191042, 2.128562176266311], [5.354949008776567, 4.917195276199858], [0.696875002094109, 0.8942512841358429], [0.6967256936035839, 0.8732729665802708], [0.7054821154097702, 0.8863128685785038], [0.7051096110239132, 0.8926202578281733], [0.720796941426548, 0.8967568460970341], [0.734628209967332, 0.9194730014551553], [0.8032916680490558, 0.9816671518137712], [0.9643589599680016, 1.073964494289686], [2.846617330195364, 2.843803487037785], [0.6854883714965452, 0.8844129058860952], [0.6958461661568365, 0.8944029164557433], [0.6991321798386079, 0.8846557008745263], [0.7100355637476545, 0.8957179110359661], [0.7220143657805365, 0.9046345097704791], [0.7231832317988598, 0.9038410944557527], [0.7398233580637005, 0.9036543370243268], [0.8116877392650448, 0.927225379280995], [0.9552789433141793, 1.0036159865184597], [0.677980886217455, 0.8807266365708408], [0.6883666781066078, 0.8988598853370522], [0.6986314750061806, 0.9028704775807921], [0.7045373196820337, 0.8806204032676506], [0.7066705179245444, 0.9012617675877875], [0.7281051450869837, 0.9190976621166534], [0.7244409546843145, 0.8745929134570716], [0.7724952344860055, 0.9100964740171026], [0.8232059490771906, 0.9070922357419983], [0.6920109920198364, 0.8950158134342322], [0.6988507817774536, 0.900167640477954], [0.6935704261172202, 0.894692822805349], [0.708256694801612, 0.9056795901790254], [0.697133826775399, 0.8777973074061445], [0.7100489728627366, 0.8783765165753389], [0.7405791816478007, 0.9035899249313427], [0.7613429144116204, 0.8824403358262822], [0.7916018521334323, 0.892184110131876]]\n",
      "[[0.677980886217455, 0.8807266365708408], [0.6799148452304866, 0.8896848471418629], [0.6854883714965452, 0.8844129058860952], [0.6883666781066078, 0.8988598853370522], [0.6905613544884935, 0.8870935002937891], [0.6909970331905826, 0.9080558682257198], [0.6920109920198364, 0.8950158134342322], [0.6935704261172202, 0.894692822805349], [0.6941328351873505, 0.8461818515621975], [0.6958461661568365, 0.8944029164557433], [0.6967256936035839, 0.8732729665802708], [0.696875002094109, 0.8942512841358429], [0.697133826775399, 0.8777973074061445], [0.6986314750061806, 0.9028704775807921], [0.6988507817774536, 0.900167640477954], [0.6991321798386079, 0.8846557008745263], [0.6993820499637512, 0.8616324321089961], [0.7045373196820337, 0.8806204032676506], [0.7051096110239132, 0.8926202578281733], [0.7054821154097702, 0.8863128685785038], [0.7066705179245444, 0.9012617675877875], [0.708256694801612, 0.9056795901790254], [0.7082891551781964, 0.8759849878327491], [0.7092975819067906, 0.882353987721535], [0.7100355637476545, 0.8957179110359661], [0.7100489728627366, 0.8783765165753389], [0.7104167826207796, 0.8896307543624216], [0.7108464340826476, 0.9202623918704143], [0.7161390164739283, 0.8778208099614325], [0.720796941426548, 0.8967568460970341], [0.7220143657805365, 0.9046345097704791], [0.7231832317988598, 0.9038410944557527], [0.7244409546843145, 0.8745929134570716], [0.7281051450869837, 0.9190976621166534], [0.731115067003566, 0.9080176317988993], [0.7330987289216984, 0.88860071775996], [0.734628209967332, 0.9194730014551553], [0.7398233580637005, 0.9036543370243268], [0.7404704243416408, 0.8594075331935807], [0.7405791816478007, 0.9035899249313427], [0.7593260687520103, 0.953252385068741], [0.7613429144116204, 0.8824403358262822], [0.7724952344860055, 0.9100964740171026], [0.7916018521334323, 0.892184110131876], [0.8032916680490558, 0.9816671518137712], [0.8116877392650448, 0.927225379280995], [0.8232059490771906, 0.9070922357419983], [0.9552789433141793, 1.0036159865184597], [0.9643589599680016, 1.073964494289686], [0.9671414991338217, 1.1864832067602984], [2.017179803191042, 2.128562176266311], [2.846617330195364, 2.843803487037785], [5.354949008776567, 4.917195276199858]]\n",
      "[[0.6917913835599272, 0.871435429705173], [0.7369548856684872, 0.8641487956175702], [0.7674167585997923, 0.8494618413913131], [0.8047654215598665, 0.8576349237111736], [0.769605275415055, 0.7457382429750464], [0.7856132844921058, 0.7287675983250731], [0.837730237102798, 0.7987425955903893], [0.8102122964410177, 0.7424376941704639], [0.6933470948580205, 0.8851221810056835], [0.6829907468953063, 0.8914555442587625], [0.6859291258852, 0.8934412690340183], [0.7356917969018015, 0.8117570562407774], [0.7159690542195796, 0.8284036842789695], [0.7379116800458023, 0.8554366543639274], [0.7728949642464432, 0.825269919941398], [0.7670822849652635, 0.8344177397134984], [0.7573474689146573, 0.835324525997177], [0.8027555126530304, 0.8413448102638064], [0.7751704511255811, 0.8235039121929241], [0.775475363988563, 0.7862437410709158], [0.8380163736342908, 0.8069499409890002], [0.8049484431881059, 0.7933895471319738], [0.8409764851885955, 0.8199822590900471], [0.8132638288007294, 0.7377695966662369], [0.8356466412875166, 0.7898639437938078], [0.8149005917912214, 0.787960006624618], [0.8321937430150953, 0.7660392457295416], [0.829355239219478, 0.7421811542950886], [0.8289967444196915, 0.7417197789376154], [0.8363411064961552, 0.7425753744442263], [0.8485283986768298, 0.7818594020712138], [0.8216272748821943, 0.7300747420899197], [0.7625819967254167, 0.8284556403439627], [0.7588591490430122, 0.836592593548878], [0.7786123951403912, 0.7909822511191016], [0.7732174233416801, 0.8111409073906927], [0.8389125466565333, 0.7966696909346782], [0.7970015558339096, 0.7608844846087413], [0.7605596020475283, 0.8192508584980466], [0.7831565905907797, 0.7710746158414258], [0.8038336478581071, 0.7661667717545153], [0.8399348675949632, 0.7350265660913082]]\n",
      "[[0.6829907468953063, 0.8914555442587625], [0.6859291258852, 0.8934412690340183], [0.6917913835599272, 0.871435429705173], [0.6933470948580205, 0.8851221810056835], [0.7159690542195796, 0.8284036842789695], [0.7356917969018015, 0.8117570562407774], [0.7369548856684872, 0.8641487956175702], [0.7379116800458023, 0.8554366543639274], [0.7573474689146573, 0.835324525997177], [0.7588591490430122, 0.836592593548878], [0.7605596020475283, 0.8192508584980466], [0.7625819967254167, 0.8284556403439627], [0.7670822849652635, 0.8344177397134984], [0.7674167585997923, 0.8494618413913131], [0.769605275415055, 0.7457382429750464], [0.7728949642464432, 0.825269919941398], [0.7732174233416801, 0.8111409073906927], [0.7751704511255811, 0.8235039121929241], [0.775475363988563, 0.7862437410709158], [0.7786123951403912, 0.7909822511191016], [0.7831565905907797, 0.7710746158414258], [0.7856132844921058, 0.7287675983250731], [0.7970015558339096, 0.7608844846087413], [0.8027555126530304, 0.8413448102638064], [0.8038336478581071, 0.7661667717545153], [0.8047654215598665, 0.8576349237111736], [0.8049484431881059, 0.7933895471319738], [0.8102122964410177, 0.7424376941704639], [0.8132638288007294, 0.7377695966662369], [0.8149005917912214, 0.787960006624618], [0.8216272748821943, 0.7300747420899197], [0.8289967444196915, 0.7417197789376154], [0.829355239219478, 0.7421811542950886], [0.8321937430150953, 0.7660392457295416], [0.8356466412875166, 0.7898639437938078], [0.8363411064961552, 0.7425753744442263], [0.837730237102798, 0.7987425955903893], [0.8380163736342908, 0.8069499409890002], [0.8389125466565333, 0.7966696909346782], [0.8399348675949632, 0.7350265660913082], [0.8409764851885955, 0.8199822590900471], [0.8485283986768298, 0.7818594020712138]]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtsAAAG4CAYAAACU+CvBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAAxOAAAMTgF/d4wjAAChzklEQVR4nOzdd3RU1RbH8e9MeiMJKfQOSWihShcQ8wQERBAQlGKv2BAVlIftoSh2FCsWQEFBQUQFBBRBFKR3AkgoCQSSQHqdmfdHyEhIIRMmmYT8PmuxmLnl3H1zSdg5s885BovFYkFEREREROzO6OgARERERESuVEq2RURERETKiJJtEREREZEyomRbRERERKSMKNkWERERESkjSrZFRERERMqIkm0RERERkTKiZFtEREREpIw4OzqAC61cuZJPPvmEyMhIXFxc6NChAxMmTCAkJKRE52/atIkPP/yQHTt2kJWVRYMGDbj55pu55ZZbMBoL/l6xf/9+3nrrLbZs2UJ2djYhISHcc889RERE2Bx7Tk4OiYmJuLm5FXotEREREXEss9lMZmYmvr6+ODuXTxpsqCgrSC5cuJApU6YQEhLCzTffTGZmJvPmzSMxMZH58+cTGhpa7Pk//fQTjz/+OP7+/txyyy34+/uzYcMGVq1axS233MKzzz6b7/j9+/czatQoXF1dGTduHP7+/ixdupStW7fy8ssvM3ToUJvij4+PJyoqytbbFhEREZFy1rBhQwICAsrlWhUi2U5MTKRPnz54e3vz448/4u3tDUBMTAwDBgygdevWzJkzp8jzc3JyuPrqq0lLS2PZsmXUq1fPum/q1Kl8/fXXzJ8/n/bt21u333rrrWzZsoWFCxfSunVrALKzsxkxYgQnTpzg119/tcZREikpKRw4cID69evj5eVl65dAKhmTyURkZCQhISE4OTk5OhwpY3reVYued9Wi5121pKamcuzYMUJDQ23K8y5HhSgjWb16NSkpKdx+++35brx27dr07duXxYsXc/LkSWrVqlXo+ZGRkSQkJNCjR498iTbAkCFD+Prrr/n222+tyfaJEyfYvHkznTp1sibaAC4uLowZM4bJkyezevVqBg8eXOJ7yCsdcXd3x9PTs8TnSeVkMpkA8PT01A/nKkDPu2rR865a9LyrlrznXZ4lvxWiuHjHjh0AtGvXrsC+vG27du0q8vys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9/PRRx8xderUAvstFgt33XUX119/vd0CFBEREZGKxejqSnDvnhicnIh8/U2wWIj5/gecPD2pP3KEo8OrUGwurp4wYQJ9+vRh0aJF7N27l5SUFLy9vWnRogU33XQT7dq1K4s4RURERKSCCbq6O+aMdA69+z4Ax+d/jbOnJ7VvGOjgyCqOUo1kbNu2LW3btrVzKHIlS09P58svv2TFihUcOXKEzMxMgoOD6dKlC3fccQdNmjQpcE6fPn2Ijo62vnd3d8fHx4cmTZrQqVMnbrrpJmrWrFngvDFjxrBp06YiY7n++ut588037XNjIiIiVVyN/0SQk5ZO1KefA3Bk9mc4eXpQI+JaxwZWQWjaEClzx48f56677iIqKopevXoxcOBAPD09OXjwIIsXL+b777/n+eef56abbipwbmBgIE8++SQA2dnZxMfHs337dmbNmsVHH33EpEmTGDVqVIHzjEYj06dPLzSeOnXq2PcGRUREqrg6gwdhSkvj+IJvADj03gc4ubsT2KO7gyNzvEsm21lZWdxyyy14eXnxySef4FLE0p1ZWVncfffd1h7Moo6TqiUzM5P77ruPY8eO8eabbxao57/rrru47bbbmDJlCnXr1qVz58759nt6eloXSrpQVFQU9913H8899xyBgYH85z//ybffYDAUep6IiIiUjXojR2BKSyNm6TIwm4l8422M7u5U79jB0aE51CXnNFq6dCl79uzhjjvuKDaBdnV15c4772Tnzp1VbvVIKdqiRYs4dOgQo0ePLnTgbHBwMK+//jpms5kZM2aUuN2GDRsyc+ZMDAYDr732mj1DFhERkVIwGAw0vOM2gs+Xj1hMJg688hqJu/c4ODLHumSy/csvv1CvXj169ep1ycZ69uxJgwYNWL58uV2Ck8ov799CYaUeeZo3b067du3YtWsXMTExJW67WbNmdOjQgaioKKKiogrsT0hIKPRP1vl5QUVERMS+DAYDTR+4l4Du3QAwZ2Wx98WXSD54yMGROc4lk+29e/fSqVOnEjd41VVXsW/fvssKSq4ckZGReHl50bhx42KPa9myJQAHDhywqf3mzZsDcOTIkXzbTSYTXbt2LfTPsmXLbLqGiIiIlJzByYmQxx7Gv0N7AMwZGex9/kVSjx5zcGSOccma7bNnzxIQEFDiBgMCAjh37tzlxFRlrd8RzZfL95OemePoUKw8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6+mp5CQnk7RnLwdeeY2wyU9idHFxdHiFqlA12ytXrmTEiBG0bduWq666ivvuu4/IyMgSndunTx9CQ0OL/HP77bcXOCc6OprHH3+cLl26EB4ezuDBg1m4cKG9b0sucuLECUJDQ5k5cyYrV65kyJAhhIeH07t3b2bPng1AcnIyU6dOpXv37oSHhzN27FiOHDmSr50L65i/+uor+vfvT+vWrenTpw8zZ84kJycn3/GTJk0iNDSUs2fP8t///pcePXrQpk0btm/fDkBSUhIvv/wyffr0oVWrVnTr1o0JEyYQFRVlbSMlJYW2bdtyxx13FHpv33//PaGhofn+HVksFr755huGDRtG27Ztadu2LSNHjmTVqlWFtjFnzhz69u1Lq1at6NOnD++99x4mk6nEX9+8eLt27Vro/qCgoBK3FRQUxKxZs/D09GTWrFmkp6eX+FwREZGy4Fm/fm5vtocHAGe3bOXgWzOx2PB/ZXmqMD3bCxcuZMqUKYSEhDBx4kQyMzOZN28eI0eOZP78+YSGhhZ7/tNPP01qamqB7UuXLmX9+vX06dMn3/ZTp05x8803k5yczLhx46hbty6rV69mypQpxMbGMn78eLvenxT022+/8eWXXzJq1CiGDRvGTz/9xKuvvoqbmxvfffcdwcHBPPDAA5w+fZrPPvuMBx98kGXLlmE05v8dcd68ecTGxjJy5Eh8fX1ZvXo17777LseOHWPGjBkFrnv77bfj5+fH3XffjcViITAwkJSUFEaNGsWhQ4cYOHAg7du35/jx43z11VesW7eO+fPn07RpU7y9vYmIiODHH3/k1KlTBWqZFy9ejIeHB/3797dumzx5MkuWLOHaa69l0KBBAPzyyy88+OCDPPfcc4waNcp67GuvvcbHH39My5YtmTBhAllZWSxatIjVq1eX+Otav359jhw5wsKFCxk3bhwGg6HE5xamevXq/Oc//+H7779n69atdO/ePd/+xMREXF1dC5zn4eGBx/kfhCIiIvbk06wpzadMZu/z/8OclUXc+j9w8vKkyf33Xvb/e3ZnqQDOnTtnad++vaVnz56W5ORk6/bo6GhL27ZtLWPGjClVuyaTyXLNNddYwsPDLYmJifn2PfHEE5aQkBDLihUr8m2/9957LS1atLAcO3bMpmulpqZaNm/ebElKSirymJycHMvevXstOTk5NrVdmf3111+WkJAQy3vvvWfddvz4cUtISIglPDw839c5MzPT0q1bN0toaKjl2WefzdfOZ599ZgkJCbGsW7euQNtt2rSxnDhxwrrdZDJZHnjgAUtISIjlr7/+sm5/6qmnLCEhIZbHHnvMYjab87X/1ltvWUJCQizvv/9+vu0bN260hISEWMaNG2fdtmHDBktISIjlrbfeytdOTEyMJSwszPLEE09Yt/3yyy+WkJAQy2effVbga3Pvvfda2rdvb/03HxUVZQkLC7MMGzbMkpmZaT3u7Nmzlu7du1tCQkIs3377bYF2LrZ161ZLy5YtLSEhIZZevXpZJkyYYPnss88su3fvLvT40aNHW5o3b15sm59++qklJCTEMnfuXOu2vK9nUX/eeeedYtusTN8POTk5ls2bN1eKWOXy6XlXLXrelVv835stfwwZbll/w1DL+huGWo589kWB/+MvlJSUZNm8ebMlNTW13GKsED3bq1evJiUlhdtvvx1vb2/r9tq1a9O3b18WL17MyZMnqVWrlk3trl+/nujoaAYPHpxvAFd6ejorVqygbt26BQaK3X777fz666/88MMP5T57RtwfGzj21QJMFeijeicPD+rfMorA7oWXJFyOiIgI6tWrZ33v6upKeHg4a9asKVAb3KlTJyC3RKJHjx759t1www3UqVPH+t5oNHLvvfeyatUqVq5cSefOnfMdf/fddxf4rXflypV4e3sXKDfq1KkTnTt35q+//iIxMRFfX1+6dOlC7dq1WbZsGQ8//LD12MWLF2M2mxkyZIh129KlS3F3d6d///4kJOSfEzQiIoJff/2V7du306NHD3755RfMZjN33HFHvp5iPz8/br31Vt56662ivpT5tGvXju+++47PPvuMdevWsWzZMpYtWwZASEgIL7/8Mq1atSpRW3nyvi+TkwtOs/TGG2/g7+9fYPuFz1ZERKQsVO/YgWaPPkzkG2+BxUL04u9x8vKi3vCbHB2aVYVItnfs2AHkJgkXa9euHYsXL2bXrl02J9uLFi0CYMSIEfm2R0ZGkpGRQdu2bQu9nsFgYOfOnTZdyx6iF39P+onocr/upUQv/r5Mku3CkjFfX99C9+X9snTu3LkC5zRp0qTIbUePHi2wr2HDhgW2HT9+nKZNmxY6UDIkJISNGzdy4sQJfH19MRgM3HjjjcyaNYutW7fSoUMHAJYsWUKdOnXo0qWL9dzDhw+TkZFBz549C7SbJy4uDoBjx44B0LRp0wLHNGvWrMjzC5OXVENuydTWrVtZsmQJa9eu5b777mPZsmX4+fmVuL2UlBQAfHx8Cuzr0KGDBkiKiIjDBPXsgSk9jcOzPgTg2LyvcPb0pNaA/pc4s3xUiGQ7NjYWoND/sPO2nTp1yqY24+PjWbNmDY0bN6Zjx4759uW1Vdj1XF1d8ff3t8ZkK7PZXORgNpPJhMVisf65WO0hgzleAXu2aw+5odB4S+LC8/Je5/1tNBoLtFvUvrzXZrO5QDsXv77Udd3d3Yu8n+Lu88LnNnjwYN5//30WL15M+/bt2bp1K0ePHrV+GnJhvD4+Prz99ttFttu0adMC8RZ1P0X92ylOjRo16N+/P/3792fChAn89NNPrF27lhtuuKFA20XZt28fkPuLysXHlyamC8+zZfCno+TFWBlilcun51216HlfGYIiriU7JZVjc+YB8M9Hn2DwcCeoV/7OLrPZXO6xVYhkO2+Gg8IGWeVty8jIsKnN7777juzs7AK92pe6HoCbm1upZ104dOhQsfudnZ1JT08vMMgPwLNtG0LbtinVdctaWlpaqc7LzMwEIDs729pG3rO8cFuevB92F28v7Jy8tvfv31/g+D179gC5pUh5+4pqG6Bu3bocPXqUc+fOFfh3sX//fgwGAwEBAdZzg4KCaNu2LT///DOPPfYYCxcuxGAw0K9fv3zt16tXj3/++YeGDRsW25OclpZm/eVv7969+cpi8rZB7lSFpX0WAK1ateKnn37ixIkT1nbyfvAU1e7Zs2f55ZdfqFatGmFhYQW+nunp6aWKyWw2k52dza5du0pzKw5RmWKVy6fnXbXoeV8BGtbHqUc3TOs3AHD4nfc4duoUTqEhDg2rQiTbeTMWZGVlFdiXt83d3d2mNhctWoSrq2uhcwcXdz3ITeIKq0EtibwZKwpjMpk4dOgQHh4eODk5lar9yiavLMPFxQXP8ys85T3LC7flyfu6XLy9sHPy2v7555958MEHrQmq2Wxmzpw5APTv3996fFFtA/Tt25dZs2bx7bffcuedd1q3b968mb///puuXbvm+yTEYrFwww038Pzzz7NmzRp++eUXOnbsSEhI/m/ooUOHsnbtWt577z3+97//FagVj4uLIzAw0BrrO++8w5dffkn//v2tSf+5c+esUwm6uroWGv+F/vjjDzp16oTLRfONmkwm1q9fD0BYWJi1nbxf/AprNy4ujokTJ5KWlsbTTz9NQECAdV/e19PDw+OSMRXGZDLh4uJC8+bNK/z3g8lkYteuXbRu3brCxyqXT8+7atHzvrJY2rQhytub2OUrwWIh59slNJ0yGd/w1kBuWeSlOkbtrUIk2zVq1AByyzsurr8truSjKJs2bSIqKooBAwYUuopdcaUpWVlZnD17ljZtStfDbDQai/1mNRgM1j9VwYX3mff6wr8v/jpcfExh2y8+pnHjxtx8882MGjUKX19fVq1axV9//cWAAQPyzTVdVNsAd955JytXrmTGjBkcOHCAdu3aWaf+8/HxYcqUKQXO+89//sOMGTOYPn06KSkpDB06tMAx/fr1Y8SIEXzzzTfs37+fiIgIgoKCiI2NZc+ePfz+++/WXvhGjRpx++238+mnnzJq1CgGDhxIdnY2CxcuJDg4mDNnzpTo386MGTM4c+YMvXv3JiwsDC8vL86cOcOKFSvYu3cvXbt25Zprrsn39bBYLCxduhTI/Y/n3Llz7N69mzVr1pCVlcUDDzzAuHHjCn0mq1atKnQFSRcXF66//voi48y7Fycnp0rzH1xlilUun5531aLnfeVocu/dmDMyOPPb71hycjgwfQatXngWn9CQQisLylqFSLbDw8NZsGAB27ZtKzCHb96CI61bty5xe9988w0Aw4cPL3R/SEgIbm5u1rYvvp7FYiE8PLzE1xPHGj16NOnp6cydO5cTJ04QGBjIAw88YNNsMt7e3nz11Ve89957rFq1ip9//hlvb2+uvfZaHnroIRo1alTgHE9PT6677jqWLFmCp6cnffv2LbTtF198kc6dO/P111/z6aefkpGRQWBgIM2aNWPKlCn5jn3yySepUaMGX331FW+88QbBwcHcdNNNtGvXrtCFmQrz1FNPsXr1arZs2cKaNWtISkrCy8uLJk2a8PTTTzNq1KgCP2zMZjNPPvkkkJsk+/j40LBhQ0aPHs2QIUMKHYSa53//+1+h2318fIpNtkVERMqCwWik6UMPYkpLJ2HT35gzMtj7wjRaTXseLviEttzisZR25JsdJSYmcs011+Dj48OPP/5oLcOIiYlhwIABtGrVirlz5wK59aExMTH4+PgQHBxcaFtXX301NWvWZMWKFUX2Ak6cOJEffviBmTNn5pv+77777mPdunX8/PPP1K9fv8T3kJaWxr59+wgJCSl0xgbI7TGMjIwkJCREvz3bwcaNGxk7diwvv/wyQ4cOLddrWywW0tLS8PT0rDKfUthbZfp+MJlMbN++nbZt21b4WOXy6XlXLXreVy5zVhZ7X5hG4q7dALj4+dHkuf8SlRBP8+bNS1UCWRoVYrl2X19fnnzySU6dOsWoUaOYN28en376KaNHjwbgmWeesR67c+dOrr/+et54441C21q6dCmZmZkMGzas2CRowoQJBAYG8uSTT/Lmm2+ycOFC7rvvPn799VfuuecemxJtEREREalYjK6uhD09Ce/z0+dmnzvHPx9+XO5xVIgyEoCRI0fi5+fH7NmzmTFjBi4uLnTs2JFHH32UsLCwErezcOFCXFxcLtnTWbt2bRYsWMCbb77JggULSEtLo2HDhrzwwgvcfPPNl3s7IiIiIuJgzp4etHj2GXY/M5W0o8fIPnuWgitqlHEM5Xy9YvXr149+/foVe0znzp05cOBAkfvzBnmVRL169YrsIRcRERGRys/Fx4eWz01l1+QpZFL+1dMVKtkWscWlfvESERERAXCt7k/LF55l1+tvlvu1K0TNtoiIiIhIWXKvEUyje+8q9+sq2RYRERGRKsGtkJnsypqSbRERERGRMqJkW0RERESkjCjZFhEREREpI0q2RURERETKiJJtEREREZEyomRbRERERKSMKNmWKuHEiROEhoYyc+bMfNtDQ0OZNGlSvm19+vRhzJgx5RmeiIiIXKG0gqSUmUceeYTly5ezYMEC2rVrd9nHXQm2bNnCp59+yv79+zl9+jReXl4EBwfTtm1bRo4cSYsWLazHhoaG5jvX09MTX19fmjZtSvfu3Rk8eDDVq1cvcI0+ffoQHR1dZAx33303EydOtN9NiYiISJGUbEuZGTFiBMuXL2fRokVFJtFnz55l9erVNGvWrEwT7Tp16rBz506cnJzK7BqXsmDBAp599lmCgoIYPHgwDRo0ICkpiaioKH777TcaNGiQL9kGaNasGXfffTcAWVlZnD59ms2bN/PKK6/w/vvv89JLLxEREVHgWoGBgTz55JOFxhESEmL/mxMREZFCKdmWMtOtWzfq1q3LTz/9xNNPP42Xl1eBY77//nuys7MZNmxYmcZiMBhwc3Mr02sUJycnhzfeeANPT08WLVpEzZo18+03m82cO3euwHmBgYEMHjy4wPadO3dy//338+ijj/LVV18RHh6eb7+np2eh54mIiEj5Us22lBmDwcCwYcNIS0vjp59+KvSYRYsW4erqak0Mv/rqK+6880569uxJq1at6Nq1Kw899BCRkZEFzs2rrT5y5Aj3338/HTp0oF27dtx9990cPXo037FF1WyX1Pr165kwYQIRERGEh4fToUMH7rzzTtasWVOi88+ePUtiYiKNGjUqkGgDGI3GQktCihIeHs5LL71EdnY2b7/9donPExERkfKlZFvK1NChQ3FycmLRokUF9m3fvp2DBw9y3XXX4e/vD8Ann3xCtWrVuPXWW5k6dSpDhgxh48aNjBw5kmPHjhVoIzY2ltGjRxMYGMjEiRO5+eab+fPPP3nggQcwm812u4/FixcTFxfHDTfcwJQpU7j77rtJSEjggQceKPIXiQsFBgbi6enJoUOH2Lp1q11i6tWrF7Vq1WLjxo2kpaXl22c2m0lISCj0T3Z2tl2uLyIiIpemMhIpUzVq1KBXr16sWbOGQ4cO0bRpU+u+vAT8whKSZcuW4enpma+NIUOGMGTIED777DOeffbZfPuOHj3K66+/zsCBA63bqlevzuuvv86GDRvo0aOHXe7jxRdfzBeXxWJh+PDh3HLLLbz33ntcf/31xZ5vMBh46KGHeOWVVxg1ahQhISG0b9+e1q1b06VLF+rWrVuquMLCwvj11185ceJEvlrsEydO0LVr10LPmTNnDp07dy7V9URERMQ2SrYrkM0nz/J9ZAwZJvv1yF4udycjN4bUpkMt/1K3MWLECNasWcPChQuZPHkygLW0pH79+nTp0sV6bF5Ca7FYSE1NJSsri4CAABo1asSOHTsKtB0cHJwv0YbcWvHXX3+dqKgouyXbFybaaWlpZGRkkJGRQZcuXfj6669JSUnB29u72DbuuOMOGjduzIIFC/j777+JjIxkwYIFQG5JzLRp02wqJQGs10xOTs63PTg4mFdeeaXQc8LCwmy6hoiIiJSeku0KZMU/sZxKzXR0GAWs+Cf2spLtnj17UqNGDb7//nsef/xxXF1d+emnn0hNTeXee+/FYDBYj/37779577332LZtGxkZGfnaKaz3t169egW2+fn5ARQ64LC0Tpw4wdtvv83vv/9eaLtJSUmXTLYBevfuTe/evTGbzRw5coSNGzfy1VdfsWbNGp544glmz55t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S5aQkZGBu7s7Pj4+HDt2jE2bNtGpU6dSxXRhmUh2djapqamYzWa6d+9eZLJ94403EhQURFpaWqmuKSIiIlWHku0KZHDYdXy964cK17N9Q9h/7NLW0KFDGTRoEDk5ORw5coSPP/6YU6dOWRPes2fPcvbsWf7++2+6du1aZDtnz56lVq1aPP744zz44IOMGTOGwMBAOnToQNeuXRk4cCA+Pj4lislkMjF79mwWL15MVFQUZrM53/5z584VOKdhw4YlvmcRERGp2pRsVyBd6rW3Sw9yRVWvXj26desGQM+ePenRowc33ngjjz32GF9++aU10b3qqqt44IEHimynevXqALRp04ZffvmFDRs2sHHjRv7++29WrFjBO++8w7x582jSpMklY3rllVf44osv6Nu3L3fffTcBAQG4uLgQGxvLpEmTsFgsBc7x8PAoze2LiIhIFaRkWxymSZMmjB07lk8++YRly5YxYMAAqlWrRmJiojUpvxQPDw+uvfZa6wwgv//+O3fffTcff/wx06dPB7DWVBdmyZIldOzYkXfeeSff9rVr19p8P8VdR0RERKomLWojDnXXXXfh6enJu+++i9ls5oYbbiAyMpLFixcXenxcXJz19cU13YB1+sALyz88PT0LbMtjNBoL9F5nZ2cXGHRZEnnXSUxMtPlcERERuTKpZ1scyt/fn9GjR/PRRx+xZMkSHnvsMbZt28akSZNYtWoVHTt2xMPDg5MnT/Lnn3/i5uZmnY2kf//+tGnThvDwcGrUqEFiYiJLliwBcgcx5mnTpg3z5s3j+eefp1evXri4uBAeHk69evXo168f8+fP5+GHH6Z79+4kJibyww8/4ObmZvO95M2e8tprrzFo0CDc3Nxo1qwZISEhl/11EhERkcpJybY43O233868efOYNWsWN9xwA1999RVffPEFP/30E+vXr8doNBIUFER4eHi+JPrOO+9k3bp1fPXVVyQlJeHn50dYWBiTJ0+me/fu1uMGDhzIvn37+PHHH1m+fDlms5mXX36ZevXqMWnSJLy9vfnpp59Ys2YNwcHBDBw4kMGDB3P99dfbdB8dOnRg4sSJLFiwgP/+97/k5OQwfvx4JdsiIiJVmMFS2AgwsVlaWhr79u0jJCSkyJkwTCYTkZGRhISE4OTkVM4Rij1ZLBbS0tLyzbMttqlM3w8mk4nt27fTtm3bCh+r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",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# figsize\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from matplotlib.pyplot import figure\n",
    "import matplotlib\n",
    "\n",
    "figure(figsize=(10, 6), dpi=80)\n",
    "\n",
    "sns.set(style='whitegrid', font_scale=1.5,rc={\"lines.linewidth\": 2.5})\n",
    "font1 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 20,}\n",
    "font2 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 18,}\n",
    "xtype = -2\n",
    "ytype = -1\n",
    "plt.xlabel(map_name(xtype))\n",
    "plt.ylabel(map_name(ytype))\n",
    "plt.xlim(0.65, 0.9)\n",
    "\n",
    "colors = ['b', 'r', 'g', 'c', 'm', 'y', 'k', 'w']\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], ODE_data)), label='ODE', color = colors[0])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], SDE_data)), label='Improved SDE', color = colors[1])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], vanilla_data)), label='Vanilla SDE', color = colors[3])\n",
    "plot_info(list(map(lambda x: [x[xtype], x[ytype]], restart_data)), label='Restart', color = colors[2])\n",
    "\n",
    "plt.legend()\n",
    "plt.savefig('approx_vs_contracted.pdf', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "plt.clf()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "a3e231e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtsAAAG8CAYAAAAPaWnXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAAxOAAAMTgF/d4wjAACI8UlEQVR4nO3dd1hT1/8H8HcCYQgIiLjArWEpIuLWtip1VFsXKlZx21pHh7VWv7X7Z7XD2tbW1ip1UScVtdaqVTu0Dqp1AopaUEEZAjJkJCT39wdNakyABBISwvv1PH0q595z7rknQT85+ZxzRYIgCCAiIiIiIqMTm7sDRERERETWisE2EREREZGJMNgmIiIiIjIRBttERERERCbCYJuIiIiIyEQYbBMRERERmQiDbSIiIiIiE2GwTURERERkIrbm7gAAfPvtt4iPj0d8fDxu3boFsViM+Ph4g9spKirCV199hf379yMjIwONGjXC0KFDMXv2bDg6Omqdn5qaik8//RR//vknCgsL0bp1a0ycOBFjxowxxm0RERERUR1nEcH2ihUrUL9+ffj5+aGwsBDZ2dkGt6FQKPDcc88hNjYWw4cPR9euXXHlyhVERkbi4sWLWL9+PcTi/yby09LSMG7cOOTn52Py5Mnw9vbGkSNHsGTJEqSnp2Pu3LnGvEUiIiIiqoMsItj+5Zdf0KJFCwBARERElYLtmJgYxMbGIiIiAkuWLFGXe3l54cMPP8TevXsxYsQIdfmnn36KzMxMrFq1CgMHDgQAjB07FrNmzcLXX3+N4cOHo3nz5tW7MSIiIiKq0ywiZ1sVaFfHnj17AABTp07VKH/22Wfh4OCA3bt3q8uKiopw8OBBeHt7qwNtlalTp6K0tBQ//vhjtftERERERHWbRcxsV5cgCLh06RIaNWoELy8vjWMODg7w8/PDpUuX1GWJiYkoLi5GUFCQVludO3eGSCTCxYsXDepDaWkpcnNzYW9vr5GuQkRERESWQalUoqSkBK6urrC1rZkw2CqC7fv376OoqAjt27fXebxx48Y4d+4cCgoK4OzsjLS0NABAkyZNtM61s7ODu7s70tPTDepDbm4ukpOTDe47EREREdWsVq1awcPDo0auZRXBdnFxMYCyQFkXe3t7AGXpI87OzigqKqr0fNU5+lJdw9vbG/Xq1TOoLulHqVTi+vXraNeuHb89MAGOr+lxjE2L42t6HGPT4xibVmFhIVJSUtRxW02wimDbwcEBACCTyXQeLykpAQD19n+q/1d0vru7u0F9UP1C1KtXDy4uLgbVJf0oFAoAgLOzM2xsbMzcG+vD8TU9jrFpcXxNj2NsehzjmlGTH2Ss4iOTm5sbHB0d1ekhj0pPT4ezszOcnZ0B/Jc+out8mUyGnJwcNG7c2HQdJiIiIqI6wSqCbZFIhA4dOiAjIwOpqakax4qLi5GQkICOHTuqy6RSKezt7XH+/Hmtts6fPw9BEBAYGGjqbhMRERGRlat1wXZRURFu3LiBjIwMjfLhw4cDANavX69RvnXrVhQXF6uPA2VpJAMHDkRKSgoOHTqkcf53330HW1tbDBs2zER3QERERER1hUXkbO/evRt37twBUPYIdUEQsHr1avXx2bNnq/988eJFTJo0CSNHjsTy5cvV5aNGjcLu3buxefNm5OfnIyQkBFevXsWWLVvQrVs3PPPMMxrXnD9/Pk6ePImFCxciLi5O/QTJX3/9FbNnzzbK3t9EREREVLdZRLD9ww8/IDY2VqPs888/V//54WC7PDY2Nvj222/x1Vdf4eeff8ZPP/0ET09PTJ06FXPmzNFaZNCsWTNs27YNK1euxLZt21BYWIhWrVrhvffew7hx44xzY0RERERUp1lEsL1582a9z+3evTuuXr2q85iTkxMWLlyIhQsX6tVW8+bN8emnn+p9bSIiIiIiQ9S6nG0iIiIiotqCwTYRERERkYkw2CYiIiIiMhEG20REREREJsJgm4iIiIjIRBhsExERERGZCINtIiIiIiITYbBNRERERGQiDLaJiIiIiEyEwTYRERERkYkw2CYiIiIiMhEG20REREREJsJgm4iIiIjIRBhsExERERGZCINtIiIiIiITYbBNRERERGQitubuABERERFZB0VJCZIiNyAvLh71A/zRevoU2Njbm7tbZsVgm4iIiIiMIilyAzKO/gpBLkdxejoAoN3s583cK/NiGgkRERERGUVeXDwEuRwAIMjlyIuPN3OPzI/BNhEREREZRf0Af4gkEgCASCKBa4C/mXtkfkwjISIiIiKjaD19CgAgLz4ergH+aDVtiln7YwkYbBMRERGRUdjY29f5HO1HMY2EiIiIiMhEGGwTEREREZkIg20iIiIiIhNhsE1EREREZCIMtomIiIiITITBNhERERGR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",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from matplotlib.pyplot import figure\n",
    "import matplotlib\n",
    "\n",
    "figure(figsize=(10, 6), dpi=80)\n",
    "\n",
    "sns.set(style='whitegrid', font_scale=1.5,rc={\"lines.linewidth\": 2.5})\n",
    "font1 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 20,}\n",
    "font2 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 18,}\n",
    "def scatter_info(infos, **kwargs):\n",
    "    # print(infos)\n",
    "    plt.scatter([x[0] for x in infos], [x[1] for x in infos], color = kwargs['color'], label = kwargs['label'], s=10)\n",
    "xtype = -2\n",
    "ytype = -3\n",
    "plt.xlabel(map_name(xtype))\n",
    "plt.ylabel(map_name(ytype))\n",
    "plt.xlim(0.65, 1)\n",
    "plt.ylim(0.7, 1)\n",
    "\n",
    "colors = ['b', 'r', 'g', 'c', 'm', 'y', 'k', 'w']\n",
    "scatter_info(list(map(lambda x: [x[xtype], x[ytype]], ODE_data)), label='ODE', color = colors[0])\n",
    "scatter_info(list(map(lambda x: [x[xtype], x[ytype]], SDE_data)), label='Improved SDE', color = colors[1])\n",
    "scatter_info(list(map(lambda x: [x[xtype], x[ytype]], vanilla_data)), label='Vanilla SDE', color = colors[3])\n",
    "scatter_info(list(map(lambda x: [x[xtype], x[ytype]], restart_data)), label='Restart', color = colors[2])\n",
    "plt.legend()\n",
    "\n",
    "plt.savefig('approx_vs_fid_scatter.pdf', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "plt.clf()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "edm",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  },
  "vscode": {
   "interpreter": {
    "hash": "dd166b2e3c1edc160f603f1b53d62a027f6163b537d13ca64c7eb00b05b6aefa"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}