{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "remapping binary repr with gray code\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import random\n",
    "import sklearn\n",
    "import numpy as np\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "from sympy.combinatorics.graycode import GrayCode\n",
    "torch.cuda.set_device(0)\n",
    "\n",
    "def inf_train_gen(data, rng=None, batch_size=200):\n",
    "    if rng is None:\n",
    "        rng = np.random.RandomState()\n",
    "\n",
    "    if data == \"swissroll\":\n",
    "        data = sklearn.datasets.make_swiss_roll(n_samples=batch_size, noise=1.0)[0]\n",
    "        data = data.astype(\"float32\")[:, [0, 2]]\n",
    "        data /= 5\n",
    "        return data\n",
    "\n",
    "    elif data == \"circles\":\n",
    "        data = sklearn.datasets.make_circles(n_samples=batch_size, factor=.5, noise=0.08)[0]\n",
    "        data = data.astype(\"float32\")\n",
    "        data *= 3\n",
    "        return data\n",
    "\n",
    "    elif data == \"moons\":\n",
    "        data = sklearn.datasets.make_moons(n_samples=batch_size, noise=0.1)[0]\n",
    "        data = data.astype(\"float32\")\n",
    "        data = data * 2 + np.array([-1, -0.2])\n",
    "        return data\n",
    "\n",
    "    elif data == \"8gaussians\":\n",
    "        scale = 4.\n",
    "        centers = [(1, 0), (-1, 0), (0, 1), (0, -1), (1. / np.sqrt(2), 1. / np.sqrt(2)),\n",
    "                   (1. / np.sqrt(2), -1. / np.sqrt(2)), (-1. / np.sqrt(2),\n",
    "                                                         1. / np.sqrt(2)), (-1. / np.sqrt(2), -1. / np.sqrt(2))]\n",
    "        centers = [(scale * x, scale * y) for x, y in centers]\n",
    "\n",
    "        dataset = []\n",
    "        for i in range(batch_size):\n",
    "            point = rng.randn(2) * 0.5\n",
    "            idx = rng.randint(8)\n",
    "            center = centers[idx]\n",
    "            point[0] += center[0]\n",
    "            point[1] += center[1]\n",
    "            dataset.append(point)\n",
    "        dataset = np.array(dataset, dtype=\"float32\")\n",
    "        dataset /= 1.414\n",
    "        return dataset\n",
    "\n",
    "    elif data == \"pinwheel\":\n",
    "        radial_std = 0.3\n",
    "        tangential_std = 0.1\n",
    "        num_classes = 5\n",
    "        num_per_class = batch_size // 5\n",
    "        rate = 0.25\n",
    "        rads = np.linspace(0, 2 * np.pi, num_classes, endpoint=False)\n",
    "\n",
    "        features = rng.randn(num_classes*num_per_class, 2) \\\n",
    "            * np.array([radial_std, tangential_std])\n",
    "        features[:, 0] += 1.\n",
    "        labels = np.repeat(np.arange(num_classes), num_per_class)\n",
    "\n",
    "        angles = rads[labels] + rate * np.exp(features[:, 0])\n",
    "        rotations = np.stack([np.cos(angles), -np.sin(angles), np.sin(angles), np.cos(angles)])\n",
    "        rotations = np.reshape(rotations.T, (-1, 2, 2))\n",
    "\n",
    "        return 2 * rng.permutation(np.einsum(\"ti,tij->tj\", features, rotations))\n",
    "\n",
    "    elif data == \"2spirals\":\n",
    "        n = np.sqrt(np.random.rand(batch_size // 2, 1)) * 540 * (2 * np.pi) / 360\n",
    "        d1x = -np.cos(n) * n + np.random.rand(batch_size // 2, 1) * 0.5\n",
    "        d1y = np.sin(n) * n + np.random.rand(batch_size // 2, 1) * 0.5\n",
    "        x = np.vstack((np.hstack((d1x, d1y)), np.hstack((-d1x, -d1y)))) / 3\n",
    "        x += np.random.randn(*x.shape) * 0.1\n",
    "        return x\n",
    "\n",
    "    elif data == \"checkerboard\":\n",
    "        x1 = np.random.rand(batch_size) * 4 - 2\n",
    "        x2_ = np.random.rand(batch_size) - np.random.randint(0, 2, batch_size) * 2\n",
    "        x2 = x2_ + (np.floor(x1) % 2)\n",
    "        return np.concatenate([x1[:, None], x2[:, None]], 1) * 2\n",
    "\n",
    "    else:\n",
    "        raise NotImplementedError\n",
    "\n",
    "class ToyDataset(object):\n",
    "\n",
    "    def __init__(self, dim, data_file=None, static_data=None):\n",
    "        if data_file is not None:\n",
    "            self.static_data = np.load(data_file)\n",
    "        elif static_data is not None:\n",
    "            self.static_data = static_data\n",
    "        else:\n",
    "            self.static_data = None\n",
    "        self.dim = dim\n",
    "\n",
    "    def gen_batch(self, batch_size):\n",
    "        raise NotImplementedError\n",
    "\n",
    "    def data_gen(self, batch_size, auto_reset):\n",
    "        if self.static_data is not None:\n",
    "            num_obs = self.static_data.shape[0]\n",
    "            while True:\n",
    "                for pos in range(0, num_obs, batch_size):\n",
    "                    if pos + batch_size > num_obs:  # the last mini-batch has fewer samples\n",
    "                        if auto_reset:  # no need to use this last mini-batch\n",
    "                            break\n",
    "                        else:\n",
    "                            num_samples = num_obs - pos\n",
    "                    else:\n",
    "                        num_samples = batch_size\n",
    "                    yield self.static_data[pos : pos + num_samples, :]\n",
    "                if not auto_reset:\n",
    "                    break\n",
    "                np.random.shuffle(self.static_data)\n",
    "        else:\n",
    "            while True:\n",
    "                yield self.gen_batch(batch_size)\n",
    "\n",
    "class OnlineToyDataset(ToyDataset):\n",
    "    def __init__(self, data_name):\n",
    "        super(OnlineToyDataset, self).__init__(2)\n",
    "        self.data_name = data_name\n",
    "        self.rng = np.random.RandomState()\n",
    "\n",
    "        rng = np.random.RandomState(1)\n",
    "        samples = inf_train_gen(self.data_name, rng, 5000)\n",
    "        self.f_scale = np.max(np.abs(samples)) + 1\n",
    "        self.int_scale = 2 ** 15 / (self.f_scale + 1)\n",
    "        # print('f_scale,', self.f_scale, 'int_scale,', self.int_scale)\n",
    "\n",
    "    def gen_batch(self, batch_size):\n",
    "        return inf_train_gen(self.data_name, self.rng, batch_size)\n",
    "\n",
    "def get_binmap(discrete_dim, binmode):\n",
    "    b = discrete_dim // 2 - 1\n",
    "    all_bins = []\n",
    "    for i in range(1 << b):\n",
    "        bx = np.binary_repr(i, width=discrete_dim // 2 - 1)\n",
    "        all_bins.append('0' + bx)\n",
    "        all_bins.append('1' + bx)\n",
    "    vals = all_bins[:]\n",
    "    if binmode == 'rand':\n",
    "        print('remapping binary repr with random permute')\n",
    "        random.shuffle(vals)\n",
    "    elif binmode == 'gray':\n",
    "        print('remapping binary repr with gray code')\n",
    "        a = GrayCode(b)\n",
    "        vals = []\n",
    "        for x in a.generate_gray():\n",
    "            vals.append('0' + x)\n",
    "            vals.append('1' + x)\n",
    "    else:\n",
    "        assert binmode == 'normal'\n",
    "    bm = {}\n",
    "    inv_bm = {}\n",
    "    for i, key in enumerate(all_bins):\n",
    "        bm[key] = vals[i]\n",
    "        inv_bm[vals[i]] = key\n",
    "    return bm, inv_bm\n",
    "\n",
    "bm, inv_bm = get_binmap(discrete_dim=32, binmode='gray')\n",
    "db = OnlineToyDataset(data_name='pinwheel')\n",
    "int_scale = db.int_scale\n",
    "plot_size = db.f_scale\n",
    "\n",
    "def float2bin(samples, bm):\n",
    "    bin_list = []\n",
    "    for i in range(samples.shape[0]):\n",
    "        x, y = samples[i] * int_scale\n",
    "        bx, by = compress(x), compress(y)\n",
    "        bx, by = bm[bx], bm[by]\n",
    "        bin_list.append(np.array(list(bx + by), dtype=int))\n",
    "    return np.array(bin_list)\n",
    "\n",
    "def bin2float(samples, inv_bm, discrete_dim=32):\n",
    "    floats = []\n",
    "    for i in range(samples.shape[0]):\n",
    "        s = ''\n",
    "        for j in range(samples.shape[1]):\n",
    "            s += str(samples[i, j])\n",
    "        x, y = s[:discrete_dim//2], s[discrete_dim//2:]\n",
    "        x, y = inv_bm[x], inv_bm[y]\n",
    "        x, y = recover(x), recover(y)\n",
    "        x /= int_scale\n",
    "        y /= int_scale\n",
    "        floats.append((x, y))\n",
    "    return np.array(floats)\n",
    "\n",
    "def compress(x, discrete_dim=32):\n",
    "    bx = np.binary_repr(int(abs(x)), width=discrete_dim // 2 - 1)\n",
    "    bx = '0' + bx if x >= 0 else '1' + bx\n",
    "    return bx\n",
    "def recover(bx):\n",
    "    x = int(bx[1:], 2)\n",
    "    return x if bx[0] == '0' else -x\n",
    "\n",
    "def plot_heat(score_func, bm, device):\n",
    "    w = 100\n",
    "    size = plot_size\n",
    "    x = np.linspace(-size, size, w)\n",
    "    y = np.linspace(-size, size, w)\n",
    "    xx, yy = np.meshgrid(x, y)\n",
    "    xx = np.reshape(xx, [-1, 1])\n",
    "    yy = np.reshape(yy, [-1, 1])\n",
    "    heat_samples = float2bin(np.concatenate((xx, yy), axis=-1), bm)\n",
    "    heat_samples = torch.from_numpy(np.float32(heat_samples)).to(device)\n",
    "    heat_score = F.softmax(-score_func(heat_samples).view(1, -1), dim=-1)\n",
    "    a = heat_score.view(w, w).data.cpu().numpy()\n",
    "    a = np.flip(a, axis=0)\n",
    "    plt.imshow(a)\n",
    "    plt.axis('equal')\n",
    "    plt.axis('off')\n",
    "    plt.show()\n",
    "    plt.close()\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Models and Training Algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch.nn as nn\n",
    "import torch.distributions as dists\n",
    "from torch.distributions.bernoulli import Bernoulli\n",
    "from torch.distributions.categorical import Categorical\n",
    "\n",
    "class Swish(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Swish, self).__init__()\n",
    "        self.beta = nn.Parameter(torch.tensor(1.0))\n",
    "\n",
    "    def forward(self, x):\n",
    "        return x * torch.sigmoid(self.beta * x)\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, input_dim, hidden_dims):\n",
    "        super(MLP, self).__init__()\n",
    "        self.input_dim = input_dim\n",
    "\n",
    "        if isinstance(hidden_dims, str):\n",
    "            hidden_dims = list(map(int, hidden_dims.split(\"-\")))\n",
    "        assert len(hidden_dims)\n",
    "        hidden_dims = [input_dim] + hidden_dims\n",
    "        self.output_size = hidden_dims[-1]\n",
    "\n",
    "        list_layers = []\n",
    "\n",
    "        for i in range(1, len(hidden_dims)):\n",
    "            list_layers.append(nn.Linear(hidden_dims[i - 1], hidden_dims[i]))\n",
    "            if i + 1 < len(hidden_dims):  # not the last layer\n",
    "                list_layers.append(Swish())\n",
    "\n",
    "        self.main = nn.Sequential(*list_layers)\n",
    "\n",
    "    def forward(self, z):\n",
    "        x = self.main(z)\n",
    "        return x\n",
    "\n",
    "class MLPScore(nn.Module):\n",
    "    def __init__(self, input_dim, hidden_dims):\n",
    "        super(MLPScore, self).__init__()\n",
    "        self.mlp = MLP(input_dim, hidden_dims)\n",
    "\n",
    "    def forward(self, z):\n",
    "        raw_score = self.mlp(z.float())\n",
    "        return raw_score\n",
    "\n",
    "class EBM(nn.Module):\n",
    "    def __init__(self, net, mean=None):\n",
    "        super().__init__()\n",
    "        self.net = net\n",
    "        if mean is None:\n",
    "            self.mean = None\n",
    "        else:\n",
    "            self.mean = nn.Parameter(mean, requires_grad=False)\n",
    "\n",
    "    def update_mean(self, mean):\n",
    "        self.mean = nn.Parameter(mean, requires_grad=False)\n",
    "\n",
    "    def forward(self, x):\n",
    "        '''\n",
    "        we define p(x) = exp(-f(x)) / Z, the output of net is f(x)\n",
    "        '''\n",
    "        if self.mean is None:\n",
    "            bd = 0.\n",
    "        else:\n",
    "            base_dist = torch.distributions.Bernoulli(probs=self.mean)\n",
    "            bd = base_dist.log_prob(x).sum(-1)\n",
    "\n",
    "        logp = self.net(x).squeeze()\n",
    "        return logp - bd\n",
    "\n",
    "def get_proposal_logits(x, model, temp=2.):\n",
    "    x = x.requires_grad_()\n",
    "    gx = torch.autograd.grad(model(x).sum(), x)[0]\n",
    "    wx = gx * (2. * x - 1)\n",
    "    return wx.detach() / temp\n",
    "\n",
    "def sample_from_grid_grad_proposal(prob_logits, m_particles):\n",
    "    dist = Categorical(logits=prob_logits)\n",
    "    mask = dist.sample((m_particles,)).permute(1, 0)\n",
    "    mask = F.one_hot(mask, num_classes=prob_logits.shape[-1]).float()\n",
    "\n",
    "    dist_ll = torch.log_softmax(prob_logits, dim=-1).unsqueeze(1)\n",
    "    ll = (dist_ll * mask).sum(-1)\n",
    "    return mask, ll\n",
    "\n",
    "def sample_from_bern_grad_proposal(prob_logits, epsilon, m_particles):\n",
    "    pert_logits = np.log(epsilon/(1-epsilon))\n",
    "    probs = torch.sigmoid(pert_logits + prob_logits)\n",
    "    dist = Bernoulli(probs = probs)\n",
    "    \n",
    "    mask = dist.sample((m_particles,)).permute(1, 0, 2)\n",
    "    ll = torch.einsum(\"ijk, ik -> ij\", mask, prob_logits)\n",
    "    return mask, ll\n",
    "\n",
    "def energy_discrepancy_neighborhood(energy_net, samples, m_particles=32, w_stable=1.):\n",
    "    device = samples.device\n",
    "    bs, dim = samples.shape\n",
    "\n",
    "    mask = torch.zeros_like(samples)\n",
    "    mask.scatter_(-1, torch.randint(dim, size=(bs,)).to(device).unsqueeze(-1), 1)\n",
    "    beri = (samples + mask) % 2.    # [bs, dim]\n",
    "\n",
    "    mask = torch.zeros(bs, m_particles, dim).to(device)\n",
    "    mask.scatter_(-1, torch.randint(dim, size=(bs,m_particles,)).to(device).unsqueeze(-1), 1)\n",
    "    pert_data = (beri.unsqueeze(1) + mask) % 2   # [bs, m_particles, dim]\n",
    "\n",
    "    pos_energy = energy_net(samples)   # [bs]\n",
    "    neg_energy = energy_net(pert_data.view(-1, dim)).view(bs, -1)  # [bs, m_particles]\n",
    "    val = pos_energy.view(bs, 1) - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:, :1])], dim=-1)\n",
    "    \n",
    "    loss = val.logsumexp(dim=-1).mean()\n",
    "    return loss\n",
    "\n",
    "def energy_discrepancy_permutation(energy_net, samples, w_size=32, m_particles=32, w_stable=1.):\n",
    "    device = samples.device\n",
    "    bs, dim = samples.shape\n",
    "    assert dim % w_size == 0\n",
    "\n",
    "    dup_samples = samples.repeat(m_particles, 1).reshape(m_particles*bs, dim//w_size, w_size)\n",
    "    pert_ind = torch.argsort(torch.rand(*dup_samples.shape).to(device), dim=-1)\n",
    "    pert_data = dup_samples.gather(2, pert_ind).reshape(m_particles*bs, dim)\n",
    "\n",
    "    pos_energy = energy_net(samples)\n",
    "    neg_energy = energy_net(pert_data).view(m_particles, bs)\n",
    "    val = pos_energy.view(1, bs) - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:1, :])], dim=0)\n",
    "    \n",
    "    loss = val.logsumexp(dim=0).mean()\n",
    "    return loss\n",
    "\n",
    "def energy_discrepancy_bernoulli(energy_net, samples, epsilon=0.1, m_particles=32, w_stable=1.):\n",
    "    device = samples.device\n",
    "    bs, dim = samples.shape\n",
    "\n",
    "    noise_dist = dists.Bernoulli(probs=epsilon * torch.ones((dim,)).to(device))\n",
    "    beri = (noise_dist.sample((bs,)) + samples) % 2.    # [bs, dim]\n",
    "    pert_data = (noise_dist.sample((bs * m_particles,)).view(bs, m_particles, dim) + beri.unsqueeze(1)) % 2.    # [bs, m_particles, dim]\n",
    "\n",
    "    pos_energy = energy_net(samples)   # [bs]\n",
    "    neg_energy = energy_net(pert_data.view(-1, dim)).view(bs, -1)  # [bs, m_particles]\n",
    "    val = pos_energy.view(bs, 1) - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:, :1])], dim=-1)\n",
    "    \n",
    "    loss = val.logsumexp(dim=-1).mean()\n",
    "    return loss\n",
    "\n",
    "def energy_discrepancy_grid_grad(energy_net, samples, m_particles=32, w_stable=1.):\n",
    "    device = samples.device\n",
    "    bs, dim = samples.shape\n",
    "\n",
    "    mask = torch.zeros_like(samples)\n",
    "    mask.scatter_(-1, torch.randint(dim, size=(bs,)).to(device).unsqueeze(-1), 1)\n",
    "    beri = (samples + mask) % 2.    # [bs, dim]\n",
    "\n",
    "    prob_logtis = get_proposal_logits(beri, energy_net)\n",
    "    mask, pert_ll = sample_from_grid_grad_proposal(prob_logtis, m_particles) # mask: [bs, m_particles, dim] pert_ll: [bs, m_particles]\n",
    "    pert_data = (mask + beri.unsqueeze(1)) % 2.    # [bs, m_particles, dim]\n",
    "\n",
    "    pos_energy = energy_net(samples)   # [bs]\n",
    "    neg_energy = energy_net(pert_data.view(-1, dim)).view(bs, -1) + pert_ll  # [bs, m_particles]\n",
    "    val = pos_energy.view(bs, 1) - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:, :1])], dim=-1)\n",
    "\n",
    "    loss = val.logsumexp(dim=-1).mean()\n",
    "    return loss\n",
    "\n",
    "def energy_discrepancy_bern_grad(energy_net, samples, epsilon=0.1, m_particles=32, w_stable=1.):\n",
    "    device = samples.device\n",
    "    bs, dim = samples.shape\n",
    "\n",
    "    pert_dist = Bernoulli(epsilon)\n",
    "    mask = pert_dist.sample((bs, dim)).to(device)\n",
    "    beri = (samples + mask) % 2.    # [bs, dim]\n",
    "\n",
    "    prob_logits = get_proposal_logits(beri, energy_net)\n",
    "    mask, pert_ll = sample_from_bern_grad_proposal(prob_logits, epsilon, m_particles) # mask: [bs, m_particles, dim] pert_ll: [bs, m_particles]\n",
    "    pert_data = (mask + beri.unsqueeze(1)) % 2.    # [bs, m_particles, dim]\n",
    "\n",
    "    pos_energy = energy_net(samples)   # [bs]\n",
    "    neg_energy = energy_net(pert_data) + pert_ll  # [bs, m_particles]\n",
    "    val = pos_energy.view(bs, 1) - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:, :1])], dim=-1)\n",
    "\n",
    "    loss = val.logsumexp(dim=-1).mean()\n",
    "    return loss\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Main Loop"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "from tqdm import tqdm\n",
    "import torch.optim as optim\n",
    "\n",
    "def training_main_loop(db, bm, energy_func, device, algo='ed_bern'):\n",
    "    ema_energy_func = copy.deepcopy(energy_func)\n",
    "    ema_energy_func.to(device)\n",
    "    opt_energy = optim.Adam(energy_func.parameters(), lr=0.002)\n",
    "\n",
    "    for epoch in range(1000):\n",
    "        pbar = tqdm(range(100))\n",
    "        for it in pbar:\n",
    "            samples = float2bin(db.gen_batch(128), bm)\n",
    "            samples = torch.from_numpy(np.float32(samples)).to(device)\n",
    "\n",
    "            if algo == 'ed_bern':\n",
    "                loss = energy_discrepancy_bernoulli(energy_func, samples)\n",
    "            elif algo == 'ed_pool':\n",
    "                loss = energy_discrepancy_permutation(energy_func, samples)\n",
    "            elif algo == 'ed_grid':\n",
    "                loss = energy_discrepancy_neighborhood(energy_func, samples)\n",
    "            elif algo == 'ed_bern_grad':\n",
    "                loss = energy_discrepancy_bern_grad(energy_func, samples)\n",
    "            elif algo == 'ed_grid_grad':\n",
    "                loss = energy_discrepancy_grid_grad(energy_func, samples)\n",
    "            else:\n",
    "                raise NotImplementedError\n",
    "            \n",
    "            opt_energy.zero_grad()\n",
    "            loss.backward()\n",
    "            torch.nn.utils.clip_grad_norm_(energy_func.parameters(), max_norm=5)\n",
    "            opt_energy.step()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                for p, ema_p in zip(energy_func.parameters(), ema_energy_func.parameters()):\n",
    "                    ema_p.data = ema_p.data * 0.999 + p.data * (1. - 0.999)\n",
    "\n",
    "            pbar.set_description('epoch: %d, loss: %.4f' % (epoch, loss.item()))\n",
    "\n",
    "    return ema_energy_func"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Discrete EBM using ED-Bern"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 0, loss: 2.8596: 100%|██████████| 100/100 [00:01<00:00, 57.38it/s]\n",
      "epoch: 1, loss: 2.4896: 100%|██████████| 100/100 [00:01<00:00, 85.34it/s]\n",
      "epoch: 2, loss: 2.4746: 100%|██████████| 100/100 [00:01<00:00, 80.01it/s]\n",
      "epoch: 3, loss: 2.4740: 100%|██████████| 100/100 [00:01<00:00, 83.19it/s]\n",
      "epoch: 4, loss: 2.2936: 100%|██████████| 100/100 [00:01<00:00, 83.10it/s]\n",
      "epoch: 5, loss: 2.4902: 100%|██████████| 100/100 [00:01<00:00, 83.71it/s]\n",
      "epoch: 6, loss: 2.1724: 100%|██████████| 100/100 [00:01<00:00, 84.69it/s]\n",
      "epoch: 7, loss: 2.2679: 100%|██████████| 100/100 [00:01<00:00, 84.72it/s]\n",
      "epoch: 8, loss: 2.1772: 100%|██████████| 100/100 [00:01<00:00, 83.61it/s]\n",
      "epoch: 9, loss: 2.1058: 100%|██████████| 100/100 [00:01<00:00, 84.91it/s]\n",
      "epoch: 10, loss: 2.0508: 100%|██████████| 100/100 [00:01<00:00, 85.39it/s]\n",
      "epoch: 11, loss: 1.9867: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 12, loss: 2.1411: 100%|██████████| 100/100 [00:01<00:00, 85.64it/s]\n",
      "epoch: 13, loss: 2.2152: 100%|██████████| 100/100 [00:01<00:00, 85.19it/s]\n",
      "epoch: 14, loss: 2.0427: 100%|██████████| 100/100 [00:01<00:00, 85.31it/s]\n",
      "epoch: 15, loss: 2.1162: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 16, loss: 2.3388: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 17, loss: 2.1894: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 18, loss: 2.1627: 100%|██████████| 100/100 [00:01<00:00, 81.57it/s]\n",
      "epoch: 19, loss: 2.0635: 100%|██████████| 100/100 [00:01<00:00, 81.73it/s]\n",
      "epoch: 20, loss: 2.0064: 100%|██████████| 100/100 [00:01<00:00, 86.61it/s]\n",
      "epoch: 21, loss: 2.0946: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 22, loss: 2.2017: 100%|██████████| 100/100 [00:01<00:00, 84.30it/s]\n",
      "epoch: 23, loss: 2.0353: 100%|██████████| 100/100 [00:01<00:00, 84.53it/s]\n",
      "epoch: 24, loss: 2.1446: 100%|██████████| 100/100 [00:01<00:00, 85.14it/s]\n",
      "epoch: 25, loss: 2.2064: 100%|██████████| 100/100 [00:01<00:00, 85.07it/s]\n",
      "epoch: 26, loss: 2.0896: 100%|██████████| 100/100 [00:01<00:00, 83.90it/s]\n",
      "epoch: 27, loss: 2.1490: 100%|██████████| 100/100 [00:01<00:00, 85.14it/s]\n",
      "epoch: 28, loss: 2.2929: 100%|██████████| 100/100 [00:01<00:00, 89.68it/s]\n",
      "epoch: 29, loss: 2.0546: 100%|██████████| 100/100 [00:01<00:00, 92.45it/s]\n",
      "epoch: 30, loss: 2.2506: 100%|██████████| 100/100 [00:01<00:00, 98.11it/s]\n",
      "epoch: 31, loss: 2.0506: 100%|██████████| 100/100 [00:01<00:00, 95.27it/s]\n",
      "epoch: 32, loss: 2.1969: 100%|██████████| 100/100 [00:01<00:00, 90.46it/s]\n",
      "epoch: 33, loss: 1.9271: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 34, loss: 2.2260: 100%|██████████| 100/100 [00:01<00:00, 87.16it/s]\n",
      "epoch: 35, loss: 2.1942: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 36, loss: 2.1848: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 37, loss: 2.0747: 100%|██████████| 100/100 [00:01<00:00, 97.68it/s]\n",
      "epoch: 38, loss: 2.1640: 100%|██████████| 100/100 [00:01<00:00, 98.67it/s]\n",
      "epoch: 39, loss: 2.4025: 100%|██████████| 100/100 [00:01<00:00, 87.81it/s]\n",
      "epoch: 40, loss: 2.2216: 100%|██████████| 100/100 [00:01<00:00, 99.13it/s]\n",
      "epoch: 41, loss: 2.2083: 100%|██████████| 100/100 [00:01<00:00, 95.25it/s]\n",
      "epoch: 42, loss: 2.1106: 100%|██████████| 100/100 [00:01<00:00, 92.28it/s]\n",
      "epoch: 43, loss: 2.1859: 100%|██████████| 100/100 [00:01<00:00, 96.60it/s]\n",
      "epoch: 44, loss: 2.3183: 100%|██████████| 100/100 [00:01<00:00, 91.50it/s]\n",
      "epoch: 45, loss: 2.1468: 100%|██████████| 100/100 [00:01<00:00, 91.65it/s]\n",
      "epoch: 46, loss: 2.2589: 100%|██████████| 100/100 [00:01<00:00, 87.66it/s]\n",
      "epoch: 47, loss: 2.2964: 100%|██████████| 100/100 [00:01<00:00, 87.24it/s]\n",
      "epoch: 48, loss: 2.0747: 100%|██████████| 100/100 [00:01<00:00, 88.17it/s]\n",
      "epoch: 49, loss: 2.0340: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 50, loss: 2.0134: 100%|██████████| 100/100 [00:01<00:00, 87.59it/s]\n",
      "epoch: 51, loss: 2.0664: 100%|██████████| 100/100 [00:01<00:00, 87.65it/s]\n",
      "epoch: 52, loss: 2.0314: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 53, loss: 2.3779: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 54, loss: 2.1698: 100%|██████████| 100/100 [00:01<00:00, 86.83it/s]\n",
      "epoch: 55, loss: 1.9609: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 56, loss: 2.1650: 100%|██████████| 100/100 [00:01<00:00, 86.51it/s]\n",
      "epoch: 57, loss: 2.1473: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 58, loss: 2.3180: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 59, loss: 2.0331: 100%|██████████| 100/100 [00:01<00:00, 86.58it/s]\n",
      "epoch: 60, loss: 2.1356: 100%|██████████| 100/100 [00:01<00:00, 87.76it/s]\n",
      "epoch: 61, loss: 2.0718: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 62, loss: 2.1509: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 63, loss: 1.9266: 100%|██████████| 100/100 [00:01<00:00, 86.89it/s]\n",
      "epoch: 64, loss: 2.1380: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 65, loss: 2.2241: 100%|██████████| 100/100 [00:01<00:00, 87.05it/s]\n",
      "epoch: 66, loss: 2.1468: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 67, loss: 2.0877: 100%|██████████| 100/100 [00:01<00:00, 87.15it/s]\n",
      "epoch: 68, loss: 2.1552: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 69, loss: 2.2941: 100%|██████████| 100/100 [00:01<00:00, 86.91it/s]\n",
      "epoch: 70, loss: 2.1352: 100%|██████████| 100/100 [00:01<00:00, 87.30it/s]\n",
      "epoch: 71, loss: 2.0143: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 72, loss: 2.1758: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 73, loss: 2.0728: 100%|██████████| 100/100 [00:01<00:00, 87.05it/s]\n",
      "epoch: 74, loss: 1.9714: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 75, loss: 2.1894: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 76, loss: 2.1819: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 77, loss: 2.0738: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 78, loss: 2.2118: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 79, loss: 2.1073: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 80, loss: 2.1729: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 81, loss: 2.2131: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 82, loss: 2.0757: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 83, loss: 1.9874: 100%|██████████| 100/100 [00:01<00:00, 86.79it/s]\n",
      "epoch: 84, loss: 2.2206: 100%|██████████| 100/100 [00:01<00:00, 87.27it/s]\n",
      "epoch: 85, loss: 2.1009: 100%|██████████| 100/100 [00:01<00:00, 87.43it/s]\n",
      "epoch: 86, loss: 2.2480: 100%|██████████| 100/100 [00:01<00:00, 98.23it/s]\n",
      "epoch: 87, loss: 2.0500: 100%|██████████| 100/100 [00:01<00:00, 97.92it/s]\n",
      "epoch: 88, loss: 2.3045: 100%|██████████| 100/100 [00:01<00:00, 87.84it/s]\n",
      "epoch: 89, loss: 2.0139: 100%|██████████| 100/100 [00:01<00:00, 98.84it/s]\n",
      "epoch: 90, loss: 2.1463: 100%|██████████| 100/100 [00:01<00:00, 94.73it/s]\n",
      "epoch: 91, loss: 2.2428: 100%|██████████| 100/100 [00:01<00:00, 92.08it/s]\n",
      "epoch: 92, loss: 2.0881: 100%|██████████| 100/100 [00:01<00:00, 97.70it/s]\n",
      "epoch: 93, loss: 2.1741: 100%|██████████| 100/100 [00:01<00:00, 90.92it/s]\n",
      "epoch: 94, loss: 2.2543: 100%|██████████| 100/100 [00:01<00:00, 98.42it/s]\n",
      "epoch: 95, loss: 2.1591: 100%|██████████| 100/100 [00:01<00:00, 98.99it/s]\n",
      "epoch: 96, loss: 2.2787: 100%|██████████| 100/100 [00:01<00:00, 90.95it/s]\n",
      "epoch: 97, loss: 2.1001: 100%|██████████| 100/100 [00:01<00:00, 98.76it/s]\n",
      "epoch: 98, loss: 2.0420: 100%|██████████| 100/100 [00:01<00:00, 92.58it/s]\n",
      "epoch: 99, loss: 2.1485: 100%|██████████| 100/100 [00:01<00:00, 93.24it/s]\n",
      "epoch: 100, loss: 2.0766: 100%|██████████| 100/100 [00:01<00:00, 98.57it/s]\n",
      "epoch: 101, loss: 2.1503: 100%|██████████| 100/100 [00:01<00:00, 91.49it/s]\n",
      "epoch: 102, loss: 2.1871: 100%|██████████| 100/100 [00:01<00:00, 97.55it/s]\n",
      "epoch: 103, loss: 2.1851: 100%|██████████| 100/100 [00:01<00:00, 97.14it/s]\n",
      "epoch: 104, loss: 2.1575: 100%|██████████| 100/100 [00:01<00:00, 91.83it/s]\n",
      "epoch: 105, loss: 2.1406: 100%|██████████| 100/100 [00:01<00:00, 97.12it/s]\n",
      "epoch: 106, loss: 2.0723: 100%|██████████| 100/100 [00:01<00:00, 92.28it/s]\n",
      "epoch: 107, loss: 2.1103: 100%|██████████| 100/100 [00:01<00:00, 93.97it/s]\n",
      "epoch: 108, loss: 2.3762: 100%|██████████| 100/100 [00:01<00:00, 98.77it/s]\n",
      "epoch: 109, loss: 2.2584: 100%|██████████| 100/100 [00:01<00:00, 88.50it/s]\n",
      "epoch: 110, loss: 1.9132: 100%|██████████| 100/100 [00:01<00:00, 97.61it/s]\n",
      "epoch: 111, loss: 2.2350: 100%|██████████| 100/100 [00:01<00:00, 98.33it/s]\n",
      "epoch: 112, loss: 2.1996: 100%|██████████| 100/100 [00:01<00:00, 93.86it/s]\n",
      "epoch: 113, loss: 2.0756: 100%|██████████| 100/100 [00:01<00:00, 97.68it/s]\n",
      "epoch: 114, loss: 2.2280: 100%|██████████| 100/100 [00:01<00:00, 92.89it/s]\n",
      "epoch: 115, loss: 2.3245: 100%|██████████| 100/100 [00:01<00:00, 87.45it/s]\n",
      "epoch: 116, loss: 1.9074: 100%|██████████| 100/100 [00:01<00:00, 90.70it/s]\n",
      "epoch: 117, loss: 2.2333: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 118, loss: 2.0486: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 119, loss: 2.1146: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 120, loss: 2.2631: 100%|██████████| 100/100 [00:01<00:00, 87.77it/s]\n",
      "epoch: 121, loss: 2.2453: 100%|██████████| 100/100 [00:01<00:00, 87.14it/s]\n",
      "epoch: 122, loss: 2.0952: 100%|██████████| 100/100 [00:01<00:00, 87.94it/s]\n",
      "epoch: 123, loss: 2.1859: 100%|██████████| 100/100 [00:01<00:00, 89.01it/s]\n",
      "epoch: 124, loss: 2.0781: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 125, loss: 2.0363: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 126, loss: 2.1743: 100%|██████████| 100/100 [00:01<00:00, 87.88it/s]\n",
      "epoch: 127, loss: 2.1694: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 128, loss: 2.0857: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 129, loss: 2.1452: 100%|██████████| 100/100 [00:01<00:00, 87.58it/s]\n",
      "epoch: 130, loss: 1.9963: 100%|██████████| 100/100 [00:01<00:00, 87.88it/s]\n",
      "epoch: 131, loss: 2.0026: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 132, loss: 2.1503: 100%|██████████| 100/100 [00:01<00:00, 87.59it/s]\n",
      "epoch: 133, loss: 2.2156: 100%|██████████| 100/100 [00:01<00:00, 87.44it/s]\n",
      "epoch: 134, loss: 2.1373: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 135, loss: 2.0766: 100%|██████████| 100/100 [00:01<00:00, 87.89it/s]\n",
      "epoch: 136, loss: 2.2983: 100%|██████████| 100/100 [00:01<00:00, 89.23it/s]\n",
      "epoch: 137, loss: 2.0913: 100%|██████████| 100/100 [00:01<00:00, 87.60it/s]\n",
      "epoch: 138, loss: 2.2059: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 139, loss: 2.0909: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 140, loss: 2.0786: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 141, loss: 2.1779: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 142, loss: 2.0681: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 143, loss: 2.2217: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 144, loss: 2.2476: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 145, loss: 2.1965: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 146, loss: 2.1626: 100%|██████████| 100/100 [00:01<00:00, 87.35it/s]\n",
      "epoch: 147, loss: 2.0146: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 148, loss: 2.1499: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 149, loss: 2.2220: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 150, loss: 2.0804: 100%|██████████| 100/100 [00:01<00:00, 87.43it/s]\n",
      "epoch: 151, loss: 2.2293: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 152, loss: 2.3004: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 153, loss: 1.8962: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 154, loss: 2.1060: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 155, loss: 2.1775: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 156, loss: 1.9516: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 157, loss: 2.0370: 100%|██████████| 100/100 [00:01<00:00, 87.35it/s]\n",
      "epoch: 158, loss: 2.1244: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 159, loss: 2.1850: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 160, loss: 2.1601: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 161, loss: 2.0894: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 162, loss: 2.0414: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 163, loss: 2.1708: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 164, loss: 2.1781: 100%|██████████| 100/100 [00:01<00:00, 87.75it/s]\n",
      "epoch: 165, loss: 2.1652: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 166, loss: 2.3093: 100%|██████████| 100/100 [00:01<00:00, 87.33it/s]\n",
      "epoch: 167, loss: 2.3653: 100%|██████████| 100/100 [00:01<00:00, 87.38it/s]\n",
      "epoch: 168, loss: 2.1359: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 169, loss: 2.1889: 100%|██████████| 100/100 [00:01<00:00, 87.36it/s]\n",
      "epoch: 170, loss: 1.9416: 100%|██████████| 100/100 [00:01<00:00, 87.07it/s]\n",
      "epoch: 171, loss: 2.0185: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 172, loss: 2.0233: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 173, loss: 2.3026: 100%|██████████| 100/100 [00:01<00:00, 91.08it/s]\n",
      "epoch: 174, loss: 2.1847: 100%|██████████| 100/100 [00:01<00:00, 97.96it/s]\n",
      "epoch: 175, loss: 1.9964: 100%|██████████| 100/100 [00:01<00:00, 92.54it/s]\n",
      "epoch: 176, loss: 2.2081: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 177, loss: 2.2656: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 178, loss: 2.2972: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 179, loss: 2.1745: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 180, loss: 2.2038: 100%|██████████| 100/100 [00:01<00:00, 86.91it/s]\n",
      "epoch: 181, loss: 2.1527: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 182, loss: 2.2076: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 183, loss: 2.2276: 100%|██████████| 100/100 [00:01<00:00, 87.61it/s]\n",
      "epoch: 184, loss: 2.1843: 100%|██████████| 100/100 [00:01<00:00, 87.44it/s]\n",
      "epoch: 185, loss: 2.2039: 100%|██████████| 100/100 [00:01<00:00, 89.18it/s]\n",
      "epoch: 186, loss: 2.1491: 100%|██████████| 100/100 [00:01<00:00, 89.06it/s]\n",
      "epoch: 187, loss: 2.1396: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 188, loss: 2.0561: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 189, loss: 2.2224: 100%|██████████| 100/100 [00:01<00:00, 87.58it/s]\n",
      "epoch: 190, loss: 2.0174: 100%|██████████| 100/100 [00:01<00:00, 87.38it/s]\n",
      "epoch: 191, loss: 1.9464: 100%|██████████| 100/100 [00:01<00:00, 87.18it/s]\n",
      "epoch: 192, loss: 2.1596: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 193, loss: 2.1729: 100%|██████████| 100/100 [00:01<00:00, 87.67it/s]\n",
      "epoch: 194, loss: 2.0850: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 195, loss: 2.0284: 100%|██████████| 100/100 [00:01<00:00, 87.26it/s]\n",
      "epoch: 196, loss: 2.0301: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 197, loss: 2.2016: 100%|██████████| 100/100 [00:01<00:00, 86.62it/s]\n",
      "epoch: 198, loss: 1.9811: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 199, loss: 2.1562: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 200, loss: 2.0478: 100%|██████████| 100/100 [00:01<00:00, 87.32it/s]\n",
      "epoch: 201, loss: 2.1549: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 202, loss: 2.0114: 100%|██████████| 100/100 [00:01<00:00, 86.90it/s]\n",
      "epoch: 203, loss: 2.1163: 100%|██████████| 100/100 [00:01<00:00, 86.67it/s]\n",
      "epoch: 204, loss: 2.2027: 100%|██████████| 100/100 [00:01<00:00, 86.79it/s]\n",
      "epoch: 205, loss: 2.2580: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 206, loss: 2.1334: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 207, loss: 2.0623: 100%|██████████| 100/100 [00:01<00:00, 86.75it/s]\n",
      "epoch: 208, loss: 2.0868: 100%|██████████| 100/100 [00:01<00:00, 86.73it/s]\n",
      "epoch: 209, loss: 2.2447: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 210, loss: 2.1846: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 211, loss: 1.9763: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 212, loss: 2.0269: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 213, loss: 1.9620: 100%|██████████| 100/100 [00:01<00:00, 87.16it/s]\n",
      "epoch: 214, loss: 2.1734: 100%|██████████| 100/100 [00:01<00:00, 86.85it/s]\n",
      "epoch: 215, loss: 1.9515: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 216, loss: 2.1444: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 217, loss: 1.9398: 100%|██████████| 100/100 [00:01<00:00, 86.91it/s]\n",
      "epoch: 218, loss: 2.1198: 100%|██████████| 100/100 [00:01<00:00, 86.89it/s]\n",
      "epoch: 219, loss: 2.1434: 100%|██████████| 100/100 [00:01<00:00, 87.16it/s]\n",
      "epoch: 220, loss: 2.2316: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 221, loss: 1.9968: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 222, loss: 2.0174: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 223, loss: 2.0228: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 224, loss: 1.9650: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 225, loss: 2.2305: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 226, loss: 2.1743: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 227, loss: 2.2177: 100%|██████████| 100/100 [00:01<00:00, 86.62it/s]\n",
      "epoch: 228, loss: 2.1457: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 229, loss: 1.9552: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 230, loss: 2.0769: 100%|██████████| 100/100 [00:01<00:00, 87.05it/s]\n",
      "epoch: 231, loss: 1.9686: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 232, loss: 1.9661: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 233, loss: 2.0223: 100%|██████████| 100/100 [00:01<00:00, 86.89it/s]\n",
      "epoch: 234, loss: 2.1062: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 235, loss: 1.9396: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 236, loss: 2.2062: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 237, loss: 2.0877: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 238, loss: 2.0947: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 239, loss: 2.1545: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 240, loss: 2.0476: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 241, loss: 2.0752: 100%|██████████| 100/100 [00:01<00:00, 87.15it/s]\n",
      "epoch: 242, loss: 2.1501: 100%|██████████| 100/100 [00:01<00:00, 86.75it/s]\n",
      "epoch: 243, loss: 1.9556: 100%|██████████| 100/100 [00:01<00:00, 90.22it/s]\n",
      "epoch: 244, loss: 2.0693: 100%|██████████| 100/100 [00:01<00:00, 87.51it/s]\n",
      "epoch: 245, loss: 2.2071: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 246, loss: 2.1448: 100%|██████████| 100/100 [00:01<00:00, 86.83it/s]\n",
      "epoch: 247, loss: 2.1712: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 248, loss: 1.9786: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 249, loss: 2.1740: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 250, loss: 2.2441: 100%|██████████| 100/100 [00:01<00:00, 89.46it/s]\n",
      "epoch: 251, loss: 2.1139: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 252, loss: 2.1598: 100%|██████████| 100/100 [00:01<00:00, 87.27it/s]\n",
      "epoch: 253, loss: 2.1043: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 254, loss: 2.1641: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 255, loss: 1.9467: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 256, loss: 2.0958: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 257, loss: 2.0823: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 258, loss: 2.2682: 100%|██████████| 100/100 [00:01<00:00, 87.27it/s]\n",
      "epoch: 259, loss: 2.2433: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 260, loss: 2.2354: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 261, loss: 2.4634: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 262, loss: 2.0558: 100%|██████████| 100/100 [00:01<00:00, 89.20it/s]\n",
      "epoch: 263, loss: 2.0816: 100%|██████████| 100/100 [00:01<00:00, 97.12it/s]\n",
      "epoch: 264, loss: 2.1334: 100%|██████████| 100/100 [00:01<00:00, 98.01it/s]\n",
      "epoch: 265, loss: 2.1481: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 266, loss: 2.1192: 100%|██████████| 100/100 [00:01<00:00, 98.50it/s]\n",
      "epoch: 267, loss: 2.1036: 100%|██████████| 100/100 [00:01<00:00, 94.72it/s]\n",
      "epoch: 268, loss: 2.0711: 100%|██████████| 100/100 [00:01<00:00, 92.63it/s]\n",
      "epoch: 269, loss: 2.0283: 100%|██████████| 100/100 [00:01<00:00, 96.96it/s]\n",
      "epoch: 270, loss: 2.0494: 100%|██████████| 100/100 [00:01<00:00, 92.17it/s]\n",
      "epoch: 271, loss: 2.0973: 100%|██████████| 100/100 [00:01<00:00, 98.24it/s]\n",
      "epoch: 272, loss: 1.9027: 100%|██████████| 100/100 [00:01<00:00, 99.31it/s]\n",
      "epoch: 273, loss: 1.8756: 100%|██████████| 100/100 [00:01<00:00, 89.95it/s]\n",
      "epoch: 274, loss: 2.0318: 100%|██████████| 100/100 [00:01<00:00, 98.18it/s]\n",
      "epoch: 275, loss: 2.2248: 100%|██████████| 100/100 [00:01<00:00, 91.80it/s]\n",
      "epoch: 276, loss: 2.1534: 100%|██████████| 100/100 [00:01<00:00, 92.84it/s]\n",
      "epoch: 277, loss: 1.9595: 100%|██████████| 100/100 [00:01<00:00, 98.48it/s]\n",
      "epoch: 278, loss: 2.0085: 100%|██████████| 100/100 [00:01<00:00, 90.75it/s]\n",
      "epoch: 279, loss: 2.1829: 100%|██████████| 100/100 [00:01<00:00, 99.24it/s]\n",
      "epoch: 280, loss: 2.2415: 100%|██████████| 100/100 [00:01<00:00, 97.65it/s]\n",
      "epoch: 281, loss: 1.9302: 100%|██████████| 100/100 [00:01<00:00, 92.64it/s]\n",
      "epoch: 282, loss: 2.0672: 100%|██████████| 100/100 [00:01<00:00, 98.37it/s]\n",
      "epoch: 283, loss: 2.1856: 100%|██████████| 100/100 [00:01<00:00, 91.05it/s]\n",
      "epoch: 284, loss: 2.2344: 100%|██████████| 100/100 [00:01<00:00, 94.56it/s]\n",
      "epoch: 285, loss: 2.3212: 100%|██████████| 100/100 [00:01<00:00, 97.12it/s]\n",
      "epoch: 286, loss: 2.0716: 100%|██████████| 100/100 [00:01<00:00, 88.08it/s]\n",
      "epoch: 287, loss: 2.1433: 100%|██████████| 100/100 [00:01<00:00, 98.65it/s]\n",
      "epoch: 288, loss: 2.1187: 100%|██████████| 100/100 [00:01<00:00, 95.54it/s]\n",
      "epoch: 289, loss: 1.9803: 100%|██████████| 100/100 [00:01<00:00, 92.36it/s]\n",
      "epoch: 290, loss: 2.1009: 100%|██████████| 100/100 [00:01<00:00, 98.24it/s]\n",
      "epoch: 291, loss: 2.1862: 100%|██████████| 100/100 [00:01<00:00, 91.42it/s]\n",
      "epoch: 292, loss: 2.1115: 100%|██████████| 100/100 [00:01<00:00, 96.71it/s]\n",
      "epoch: 293, loss: 1.8866: 100%|██████████| 100/100 [00:01<00:00, 97.90it/s]\n",
      "epoch: 294, loss: 2.1922: 100%|██████████| 100/100 [00:01<00:00, 88.30it/s]\n",
      "epoch: 295, loss: 2.1558: 100%|██████████| 100/100 [00:01<00:00, 99.60it/s]\n",
      "epoch: 296, loss: 2.3452: 100%|██████████| 100/100 [00:01<00:00, 95.36it/s]\n",
      "epoch: 297, loss: 2.1849: 100%|██████████| 100/100 [00:01<00:00, 94.21it/s]\n",
      "epoch: 298, loss: 2.1612: 100%|██████████| 100/100 [00:01<00:00, 98.93it/s]\n",
      "epoch: 299, loss: 2.3315: 100%|██████████| 100/100 [00:01<00:00, 91.80it/s]\n",
      "epoch: 300, loss: 2.1942: 100%|██████████| 100/100 [00:01<00:00, 94.94it/s]\n",
      "epoch: 301, loss: 2.1720: 100%|██████████| 100/100 [00:01<00:00, 86.60it/s]\n",
      "epoch: 302, loss: 2.1460: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 303, loss: 2.3199: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 304, loss: 2.2914: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 305, loss: 2.2642: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 306, loss: 2.0159: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 307, loss: 2.1549: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 308, loss: 2.0937: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 309, loss: 2.1380: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 310, loss: 2.0684: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 311, loss: 2.2366: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 312, loss: 2.1250: 100%|██████████| 100/100 [00:01<00:00, 84.20it/s]\n",
      "epoch: 313, loss: 2.2364: 100%|██████████| 100/100 [00:01<00:00, 83.04it/s]\n",
      "epoch: 314, loss: 2.1016: 100%|██████████| 100/100 [00:01<00:00, 83.47it/s]\n",
      "epoch: 315, loss: 2.0261: 100%|██████████| 100/100 [00:01<00:00, 83.86it/s]\n",
      "epoch: 316, loss: 2.1202: 100%|██████████| 100/100 [00:01<00:00, 84.20it/s]\n",
      "epoch: 317, loss: 2.2289: 100%|██████████| 100/100 [00:01<00:00, 83.52it/s]\n",
      "epoch: 318, loss: 2.1659: 100%|██████████| 100/100 [00:01<00:00, 82.93it/s]\n",
      "epoch: 319, loss: 2.0005: 100%|██████████| 100/100 [00:01<00:00, 83.02it/s]\n",
      "epoch: 320, loss: 2.1024: 100%|██████████| 100/100 [00:01<00:00, 83.52it/s]\n",
      "epoch: 321, loss: 2.1862: 100%|██████████| 100/100 [00:01<00:00, 83.13it/s]\n",
      "epoch: 322, loss: 1.9358: 100%|██████████| 100/100 [00:01<00:00, 83.62it/s]\n",
      "epoch: 323, loss: 2.1430: 100%|██████████| 100/100 [00:01<00:00, 83.28it/s]\n",
      "epoch: 324, loss: 2.3804: 100%|██████████| 100/100 [00:01<00:00, 83.75it/s]\n",
      "epoch: 325, loss: 2.1829: 100%|██████████| 100/100 [00:01<00:00, 83.58it/s]\n",
      "epoch: 326, loss: 1.9517: 100%|██████████| 100/100 [00:01<00:00, 82.83it/s]\n",
      "epoch: 327, loss: 2.0819: 100%|██████████| 100/100 [00:01<00:00, 83.14it/s]\n",
      "epoch: 328, loss: 2.1874: 100%|██████████| 100/100 [00:01<00:00, 83.74it/s]\n",
      "epoch: 329, loss: 2.0921: 100%|██████████| 100/100 [00:01<00:00, 97.03it/s]\n",
      "epoch: 330, loss: 2.1608: 100%|██████████| 100/100 [00:01<00:00, 96.84it/s]\n",
      "epoch: 331, loss: 2.2041: 100%|██████████| 100/100 [00:01<00:00, 91.37it/s]\n",
      "epoch: 332, loss: 1.9668: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 333, loss: 2.1106: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 334, loss: 2.1585: 100%|██████████| 100/100 [00:01<00:00, 87.14it/s]\n",
      "epoch: 335, loss: 2.1481: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 336, loss: 2.0276: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 337, loss: 1.9646: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 338, loss: 2.1554: 100%|██████████| 100/100 [00:01<00:00, 86.70it/s]\n",
      "epoch: 339, loss: 2.1029: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 340, loss: 2.2545: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 341, loss: 2.1917: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 342, loss: 2.1121: 100%|██████████| 100/100 [00:01<00:00, 86.69it/s]\n",
      "epoch: 343, loss: 2.2229: 100%|██████████| 100/100 [00:01<00:00, 87.26it/s]\n",
      "epoch: 344, loss: 2.0690: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 345, loss: 2.0944: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 346, loss: 2.1854: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 347, loss: 2.3494: 100%|██████████| 100/100 [00:01<00:00, 86.72it/s]\n",
      "epoch: 348, loss: 2.1167: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 349, loss: 2.1264: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 350, loss: 2.1768: 100%|██████████| 100/100 [00:01<00:00, 86.78it/s]\n",
      "epoch: 351, loss: 2.0292: 100%|██████████| 100/100 [00:01<00:00, 87.50it/s]\n",
      "epoch: 352, loss: 2.1298: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 353, loss: 2.4968: 100%|██████████| 100/100 [00:01<00:00, 87.18it/s]\n",
      "epoch: 354, loss: 1.9531: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 355, loss: 2.2208: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 356, loss: 2.0702: 100%|██████████| 100/100 [00:01<00:00, 86.85it/s]\n",
      "epoch: 357, loss: 2.1354: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 358, loss: 2.2294: 100%|██████████| 100/100 [00:01<00:00, 83.97it/s]\n",
      "epoch: 359, loss: 2.2562: 100%|██████████| 100/100 [00:01<00:00, 83.32it/s]\n",
      "epoch: 360, loss: 2.1598: 100%|██████████| 100/100 [00:01<00:00, 83.61it/s]\n",
      "epoch: 361, loss: 2.1486: 100%|██████████| 100/100 [00:01<00:00, 83.37it/s]\n",
      "epoch: 362, loss: 1.9885: 100%|██████████| 100/100 [00:01<00:00, 83.68it/s]\n",
      "epoch: 363, loss: 2.0025: 100%|██████████| 100/100 [00:01<00:00, 82.74it/s]\n",
      "epoch: 364, loss: 1.9154: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 365, loss: 2.0353: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 366, loss: 2.2430: 100%|██████████| 100/100 [00:01<00:00, 86.75it/s]\n",
      "epoch: 367, loss: 2.0950: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 368, loss: 2.3215: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 369, loss: 2.0171: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 370, loss: 2.0030: 100%|██████████| 100/100 [00:01<00:00, 87.27it/s]\n",
      "epoch: 371, loss: 2.0702: 100%|██████████| 100/100 [00:01<00:00, 87.30it/s]\n",
      "epoch: 372, loss: 2.2066: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 373, loss: 2.1247: 100%|██████████| 100/100 [00:01<00:00, 86.45it/s]\n",
      "epoch: 374, loss: 2.2366: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 375, loss: 2.1543: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 376, loss: 2.0446: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 377, loss: 2.0874: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 378, loss: 2.2299: 100%|██████████| 100/100 [00:01<00:00, 86.67it/s]\n",
      "epoch: 379, loss: 2.1399: 100%|██████████| 100/100 [00:01<00:00, 86.48it/s]\n",
      "epoch: 380, loss: 1.9792: 100%|██████████| 100/100 [00:01<00:00, 86.91it/s]\n",
      "epoch: 381, loss: 2.0843: 100%|██████████| 100/100 [00:01<00:00, 84.78it/s]\n",
      "epoch: 382, loss: 1.9549: 100%|██████████| 100/100 [00:01<00:00, 85.13it/s]\n",
      "epoch: 383, loss: 2.1691: 100%|██████████| 100/100 [00:01<00:00, 84.85it/s]\n",
      "epoch: 384, loss: 2.2090: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 385, loss: 2.3590: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 386, loss: 2.2144: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 387, loss: 2.1670: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 388, loss: 2.0514: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 389, loss: 2.1415: 100%|██████████| 100/100 [00:01<00:00, 84.39it/s]\n",
      "epoch: 390, loss: 2.1176: 100%|██████████| 100/100 [00:01<00:00, 82.95it/s]\n",
      "epoch: 391, loss: 2.0937: 100%|██████████| 100/100 [00:01<00:00, 84.04it/s]\n",
      "epoch: 392, loss: 2.1330: 100%|██████████| 100/100 [00:01<00:00, 83.93it/s]\n",
      "epoch: 393, loss: 2.2336: 100%|██████████| 100/100 [00:01<00:00, 83.31it/s]\n",
      "epoch: 394, loss: 2.1210: 100%|██████████| 100/100 [00:01<00:00, 84.23it/s]\n",
      "epoch: 395, loss: 1.9878: 100%|██████████| 100/100 [00:01<00:00, 83.45it/s]\n",
      "epoch: 396, loss: 2.1058: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 397, loss: 2.1496: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 398, loss: 2.1631: 100%|██████████| 100/100 [00:01<00:00, 86.43it/s]\n",
      "epoch: 399, loss: 2.1333: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 400, loss: 2.1513: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 401, loss: 2.1193: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 402, loss: 1.9095: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 403, loss: 2.0961: 100%|██████████| 100/100 [00:01<00:00, 86.91it/s]\n",
      "epoch: 404, loss: 2.0235: 100%|██████████| 100/100 [00:01<00:00, 87.36it/s]\n",
      "epoch: 405, loss: 2.0419: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 406, loss: 2.2744: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 407, loss: 2.2075: 100%|██████████| 100/100 [00:01<00:00, 86.90it/s]\n",
      "epoch: 408, loss: 2.0758: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 409, loss: 2.2578: 100%|██████████| 100/100 [00:01<00:00, 86.65it/s]\n",
      "epoch: 410, loss: 1.9620: 100%|██████████| 100/100 [00:01<00:00, 87.66it/s]\n",
      "epoch: 411, loss: 2.0759: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 412, loss: 1.7972: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 413, loss: 2.0192: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 414, loss: 2.1892: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 415, loss: 2.3653: 100%|██████████| 100/100 [00:01<00:00, 87.45it/s]\n",
      "epoch: 416, loss: 1.8176: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 417, loss: 1.9858: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 418, loss: 2.0888: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 419, loss: 2.0683: 100%|██████████| 100/100 [00:01<00:00, 86.75it/s]\n",
      "epoch: 420, loss: 2.0964: 100%|██████████| 100/100 [00:01<00:00, 86.85it/s]\n",
      "epoch: 421, loss: 1.9855: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 422, loss: 1.9661: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 423, loss: 2.0361: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 424, loss: 2.1228: 100%|██████████| 100/100 [00:01<00:00, 88.30it/s]\n",
      "epoch: 425, loss: 2.1741: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 426, loss: 2.2658: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 427, loss: 2.1712: 100%|██████████| 100/100 [00:01<00:00, 86.87it/s]\n",
      "epoch: 428, loss: 2.0229: 100%|██████████| 100/100 [00:01<00:00, 86.58it/s]\n",
      "epoch: 429, loss: 2.0777: 100%|██████████| 100/100 [00:01<00:00, 87.46it/s]\n",
      "epoch: 430, loss: 2.1837: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 431, loss: 2.3104: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 432, loss: 2.2342: 100%|██████████| 100/100 [00:01<00:00, 86.39it/s]\n",
      "epoch: 433, loss: 2.1541: 100%|██████████| 100/100 [00:01<00:00, 85.54it/s]\n",
      "epoch: 434, loss: 2.1488: 100%|██████████| 100/100 [00:01<00:00, 92.25it/s]\n",
      "epoch: 435, loss: 2.1754: 100%|██████████| 100/100 [00:01<00:00, 97.69it/s]\n",
      "epoch: 436, loss: 2.0522: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 437, loss: 2.2208: 100%|██████████| 100/100 [00:01<00:00, 84.22it/s]\n",
      "epoch: 438, loss: 2.0851: 100%|██████████| 100/100 [00:01<00:00, 85.01it/s]\n",
      "epoch: 439, loss: 2.1784: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 440, loss: 2.1709: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 441, loss: 1.9433: 100%|██████████| 100/100 [00:01<00:00, 83.52it/s]\n",
      "epoch: 442, loss: 2.0289: 100%|██████████| 100/100 [00:01<00:00, 83.54it/s]\n",
      "epoch: 443, loss: 2.0457: 100%|██████████| 100/100 [00:01<00:00, 83.34it/s]\n",
      "epoch: 444, loss: 2.0802: 100%|██████████| 100/100 [00:01<00:00, 83.12it/s]\n",
      "epoch: 445, loss: 2.0443: 100%|██████████| 100/100 [00:01<00:00, 83.97it/s]\n",
      "epoch: 446, loss: 2.0813: 100%|██████████| 100/100 [00:01<00:00, 84.99it/s]\n",
      "epoch: 447, loss: 2.0775: 100%|██████████| 100/100 [00:01<00:00, 84.50it/s]\n",
      "epoch: 448, loss: 2.2582: 100%|██████████| 100/100 [00:01<00:00, 83.38it/s]\n",
      "epoch: 449, loss: 2.0610: 100%|██████████| 100/100 [00:01<00:00, 83.50it/s]\n",
      "epoch: 450, loss: 2.1001: 100%|██████████| 100/100 [00:01<00:00, 83.47it/s]\n",
      "epoch: 451, loss: 2.0608: 100%|██████████| 100/100 [00:01<00:00, 83.79it/s]\n",
      "epoch: 452, loss: 1.9341: 100%|██████████| 100/100 [00:01<00:00, 83.98it/s]\n",
      "epoch: 453, loss: 2.1414: 100%|██████████| 100/100 [00:01<00:00, 82.68it/s]\n",
      "epoch: 454, loss: 2.0079: 100%|██████████| 100/100 [00:01<00:00, 83.63it/s]\n",
      "epoch: 455, loss: 2.0734: 100%|██████████| 100/100 [00:01<00:00, 83.43it/s]\n",
      "epoch: 456, loss: 2.2964: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 457, loss: 1.9747: 100%|██████████| 100/100 [00:01<00:00, 87.27it/s]\n",
      "epoch: 458, loss: 2.0887: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 459, loss: 2.2458: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 460, loss: 2.0511: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 461, loss: 2.2577: 100%|██████████| 100/100 [00:01<00:00, 87.32it/s]\n",
      "epoch: 462, loss: 1.9661: 100%|██████████| 100/100 [00:01<00:00, 85.97it/s]\n",
      "epoch: 463, loss: 2.3077: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 464, loss: 2.0829: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 465, loss: 2.2336: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 466, loss: 2.2970: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 467, loss: 2.1049: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 468, loss: 1.8434: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 469, loss: 2.0287: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 470, loss: 1.9769: 100%|██████████| 100/100 [00:01<00:00, 87.71it/s]\n",
      "epoch: 471, loss: 2.2011: 100%|██████████| 100/100 [00:01<00:00, 86.66it/s]\n",
      "epoch: 472, loss: 2.1700: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 473, loss: 2.0497: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 474, loss: 2.1229: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 475, loss: 2.2086: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 476, loss: 2.0893: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 477, loss: 2.1405: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 478, loss: 2.1066: 100%|██████████| 100/100 [00:01<00:00, 85.97it/s]\n",
      "epoch: 479, loss: 2.0017: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 480, loss: 2.2004: 100%|██████████| 100/100 [00:01<00:00, 87.13it/s]\n",
      "epoch: 481, loss: 2.1339: 100%|██████████| 100/100 [00:01<00:00, 86.75it/s]\n",
      "epoch: 482, loss: 2.3499: 100%|██████████| 100/100 [00:01<00:00, 87.46it/s]\n",
      "epoch: 483, loss: 2.0210: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 484, loss: 2.0977: 100%|██████████| 100/100 [00:01<00:00, 85.25it/s]\n",
      "epoch: 485, loss: 2.2073: 100%|██████████| 100/100 [00:01<00:00, 85.02it/s]\n",
      "epoch: 486, loss: 2.1657: 100%|██████████| 100/100 [00:01<00:00, 84.55it/s]\n",
      "epoch: 487, loss: 2.2652: 100%|██████████| 100/100 [00:01<00:00, 85.25it/s]\n",
      "epoch: 488, loss: 2.0810: 100%|██████████| 100/100 [00:01<00:00, 86.92it/s]\n",
      "epoch: 489, loss: 2.1641: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 490, loss: 2.1434: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 491, loss: 2.1201: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 492, loss: 2.2648: 100%|██████████| 100/100 [00:01<00:00, 86.74it/s]\n",
      "epoch: 493, loss: 2.0779: 100%|██████████| 100/100 [00:01<00:00, 87.15it/s]\n",
      "epoch: 494, loss: 2.1702: 100%|██████████| 100/100 [00:01<00:00, 86.83it/s]\n",
      "epoch: 495, loss: 2.1752: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 496, loss: 2.2537: 100%|██████████| 100/100 [00:01<00:00, 86.74it/s]\n",
      "epoch: 497, loss: 2.0675: 100%|██████████| 100/100 [00:01<00:00, 87.70it/s]\n",
      "epoch: 498, loss: 1.9938: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 499, loss: 2.1778: 100%|██████████| 100/100 [00:01<00:00, 88.26it/s]\n",
      "epoch: 500, loss: 1.9683: 100%|██████████| 100/100 [00:01<00:00, 87.90it/s]\n",
      "epoch: 501, loss: 2.3268: 100%|██████████| 100/100 [00:01<00:00, 88.00it/s]\n",
      "epoch: 502, loss: 2.2020: 100%|██████████| 100/100 [00:01<00:00, 87.89it/s]\n",
      "epoch: 503, loss: 2.1931: 100%|██████████| 100/100 [00:01<00:00, 87.59it/s]\n",
      "epoch: 504, loss: 2.0413: 100%|██████████| 100/100 [00:01<00:00, 88.02it/s]\n",
      "epoch: 505, loss: 2.0643: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 506, loss: 1.9375: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 507, loss: 2.0799: 100%|██████████| 100/100 [00:01<00:00, 87.86it/s]\n",
      "epoch: 508, loss: 2.1172: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 509, loss: 1.8927: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 510, loss: 2.1084: 100%|██████████| 100/100 [00:01<00:00, 88.64it/s]\n",
      "epoch: 511, loss: 2.0384: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 512, loss: 2.1034: 100%|██████████| 100/100 [00:01<00:00, 88.79it/s]\n",
      "epoch: 513, loss: 2.0647: 100%|██████████| 100/100 [00:01<00:00, 88.04it/s]\n",
      "epoch: 514, loss: 1.9747: 100%|██████████| 100/100 [00:01<00:00, 88.03it/s]\n",
      "epoch: 515, loss: 2.0828: 100%|██████████| 100/100 [00:01<00:00, 87.83it/s]\n",
      "epoch: 516, loss: 1.9603: 100%|██████████| 100/100 [00:01<00:00, 87.50it/s]\n",
      "epoch: 517, loss: 2.2286: 100%|██████████| 100/100 [00:01<00:00, 94.27it/s]\n",
      "epoch: 518, loss: 2.2005: 100%|██████████| 100/100 [00:01<00:00, 99.91it/s]\n",
      "epoch: 519, loss: 2.1934: 100%|██████████| 100/100 [00:01<00:00, 90.41it/s]\n",
      "epoch: 520, loss: 2.0279: 100%|██████████| 100/100 [00:01<00:00, 87.77it/s]\n",
      "epoch: 521, loss: 2.2973: 100%|██████████| 100/100 [00:01<00:00, 87.32it/s]\n",
      "epoch: 522, loss: 2.3106: 100%|██████████| 100/100 [00:01<00:00, 88.01it/s]\n",
      "epoch: 523, loss: 1.9860: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 524, loss: 2.2204: 100%|██████████| 100/100 [00:01<00:00, 88.08it/s]\n",
      "epoch: 525, loss: 2.1891: 100%|██████████| 100/100 [00:01<00:00, 87.59it/s]\n",
      "epoch: 526, loss: 2.0498: 100%|██████████| 100/100 [00:01<00:00, 88.08it/s]\n",
      "epoch: 527, loss: 2.3475: 100%|██████████| 100/100 [00:01<00:00, 87.52it/s]\n",
      "epoch: 528, loss: 2.0883: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 529, loss: 2.2737: 100%|██████████| 100/100 [00:01<00:00, 88.04it/s]\n",
      "epoch: 530, loss: 2.1705: 100%|██████████| 100/100 [00:01<00:00, 87.33it/s]\n",
      "epoch: 531, loss: 2.1781: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 532, loss: 2.0945: 100%|██████████| 100/100 [00:01<00:00, 87.64it/s]\n",
      "epoch: 533, loss: 2.1213: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 534, loss: 2.0563: 100%|██████████| 100/100 [00:01<00:00, 88.06it/s]\n",
      "epoch: 535, loss: 2.0772: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 536, loss: 2.1406: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 537, loss: 2.0465: 100%|██████████| 100/100 [00:01<00:00, 85.58it/s]\n",
      "epoch: 538, loss: 2.2088: 100%|██████████| 100/100 [00:01<00:00, 84.95it/s]\n",
      "epoch: 539, loss: 2.3244: 100%|██████████| 100/100 [00:01<00:00, 85.25it/s]\n",
      "epoch: 540, loss: 2.0374: 100%|██████████| 100/100 [00:01<00:00, 85.31it/s]\n",
      "epoch: 541, loss: 2.2349: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 542, loss: 2.0639: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 543, loss: 2.2199: 100%|██████████| 100/100 [00:01<00:00, 87.56it/s]\n",
      "epoch: 544, loss: 2.1976: 100%|██████████| 100/100 [00:01<00:00, 87.94it/s]\n",
      "epoch: 545, loss: 2.2651: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 546, loss: 1.9691: 100%|██████████| 100/100 [00:01<00:00, 87.87it/s]\n",
      "epoch: 547, loss: 2.0988: 100%|██████████| 100/100 [00:01<00:00, 88.11it/s]\n",
      "epoch: 548, loss: 2.0371: 100%|██████████| 100/100 [00:01<00:00, 87.50it/s]\n",
      "epoch: 549, loss: 2.2583: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 550, loss: 2.1292: 100%|██████████| 100/100 [00:01<00:00, 88.32it/s]\n",
      "epoch: 551, loss: 2.1378: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 552, loss: 2.1155: 100%|██████████| 100/100 [00:01<00:00, 88.01it/s]\n",
      "epoch: 553, loss: 2.1805: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 554, loss: 2.3541: 100%|██████████| 100/100 [00:01<00:00, 88.11it/s]\n",
      "epoch: 555, loss: 2.1576: 100%|██████████| 100/100 [00:01<00:00, 87.94it/s]\n",
      "epoch: 556, loss: 2.0555: 100%|██████████| 100/100 [00:01<00:00, 87.65it/s]\n",
      "epoch: 557, loss: 2.0315: 100%|██████████| 100/100 [00:01<00:00, 87.95it/s]\n",
      "epoch: 558, loss: 2.1154: 100%|██████████| 100/100 [00:01<00:00, 87.85it/s]\n",
      "epoch: 559, loss: 2.2383: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 560, loss: 1.9489: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 561, loss: 2.2933: 100%|██████████| 100/100 [00:01<00:00, 87.26it/s]\n",
      "epoch: 562, loss: 2.0047: 100%|██████████| 100/100 [00:01<00:00, 88.11it/s]\n",
      "epoch: 563, loss: 2.1180: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 564, loss: 2.1267: 100%|██████████| 100/100 [00:01<00:00, 88.08it/s]\n",
      "epoch: 565, loss: 2.0065: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 566, loss: 2.1607: 100%|██████████| 100/100 [00:01<00:00, 87.79it/s]\n",
      "epoch: 567, loss: 2.0539: 100%|██████████| 100/100 [00:01<00:00, 88.42it/s]\n",
      "epoch: 568, loss: 1.9947: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 569, loss: 2.1705: 100%|██████████| 100/100 [00:01<00:00, 83.84it/s]\n",
      "epoch: 570, loss: 2.1236: 100%|██████████| 100/100 [00:01<00:00, 83.34it/s]\n",
      "epoch: 571, loss: 1.9953: 100%|██████████| 100/100 [00:01<00:00, 86.42it/s]\n",
      "epoch: 572, loss: 2.0027: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 573, loss: 2.2536: 100%|██████████| 100/100 [00:01<00:00, 87.86it/s]\n",
      "epoch: 574, loss: 2.2023: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 575, loss: 2.2558: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 576, loss: 2.1239: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 577, loss: 2.0570: 100%|██████████| 100/100 [00:01<00:00, 87.83it/s]\n",
      "epoch: 578, loss: 2.1973: 100%|██████████| 100/100 [00:01<00:00, 86.96it/s]\n",
      "epoch: 579, loss: 2.0334: 100%|██████████| 100/100 [00:01<00:00, 87.32it/s]\n",
      "epoch: 580, loss: 2.2080: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 581, loss: 2.2381: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 582, loss: 2.0638: 100%|██████████| 100/100 [00:01<00:00, 86.96it/s]\n",
      "epoch: 583, loss: 2.1901: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 584, loss: 2.1921: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 585, loss: 2.1390: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 586, loss: 2.1871: 100%|██████████| 100/100 [00:01<00:00, 86.74it/s]\n",
      "epoch: 587, loss: 2.0635: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 588, loss: 2.1012: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 589, loss: 2.0727: 100%|██████████| 100/100 [00:01<00:00, 86.74it/s]\n",
      "epoch: 590, loss: 2.1352: 100%|██████████| 100/100 [00:01<00:00, 86.39it/s]\n",
      "epoch: 591, loss: 2.0391: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 592, loss: 2.1058: 100%|██████████| 100/100 [00:01<00:00, 85.70it/s]\n",
      "epoch: 593, loss: 2.1890: 100%|██████████| 100/100 [00:01<00:00, 90.32it/s]\n",
      "epoch: 594, loss: 2.2221: 100%|██████████| 100/100 [00:01<00:00, 84.33it/s]\n",
      "epoch: 595, loss: 2.3032: 100%|██████████| 100/100 [00:01<00:00, 83.76it/s]\n",
      "epoch: 596, loss: 2.1412: 100%|██████████| 100/100 [00:01<00:00, 83.99it/s]\n",
      "epoch: 597, loss: 2.1051: 100%|██████████| 100/100 [00:01<00:00, 82.87it/s]\n",
      "epoch: 598, loss: 2.2377: 100%|██████████| 100/100 [00:01<00:00, 83.56it/s]\n",
      "epoch: 599, loss: 2.0773: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 600, loss: 2.1268: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 601, loss: 2.0737: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 602, loss: 2.0914: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 603, loss: 2.1680: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 604, loss: 2.2731: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 605, loss: 2.2908: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 606, loss: 1.9221: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 607, loss: 1.9216: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 608, loss: 1.9485: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 609, loss: 2.3595: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 610, loss: 2.1900: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 611, loss: 2.0841: 100%|██████████| 100/100 [00:01<00:00, 86.54it/s]\n",
      "epoch: 612, loss: 2.2247: 100%|██████████| 100/100 [00:01<00:00, 87.15it/s]\n",
      "epoch: 613, loss: 1.9710: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 614, loss: 2.2474: 100%|██████████| 100/100 [00:01<00:00, 86.72it/s]\n",
      "epoch: 615, loss: 2.2473: 100%|██████████| 100/100 [00:01<00:00, 87.24it/s]\n",
      "epoch: 616, loss: 2.1196: 100%|██████████| 100/100 [00:01<00:00, 87.30it/s]\n",
      "epoch: 617, loss: 2.1456: 100%|██████████| 100/100 [00:01<00:00, 86.79it/s]\n",
      "epoch: 618, loss: 2.2089: 100%|██████████| 100/100 [00:01<00:00, 87.07it/s]\n",
      "epoch: 619, loss: 2.0439: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 620, loss: 2.0118: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 621, loss: 2.1801: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 622, loss: 1.9579: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 623, loss: 2.0604: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 624, loss: 2.0324: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 625, loss: 2.2475: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 626, loss: 1.9787: 100%|██████████| 100/100 [00:01<00:00, 87.35it/s]\n",
      "epoch: 627, loss: 2.0415: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 628, loss: 2.1413: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 629, loss: 2.2144: 100%|██████████| 100/100 [00:01<00:00, 87.14it/s]\n",
      "epoch: 630, loss: 2.2036: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 631, loss: 2.1679: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 632, loss: 2.4193: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 633, loss: 2.1374: 100%|██████████| 100/100 [00:01<00:00, 87.24it/s]\n",
      "epoch: 634, loss: 2.0775: 100%|██████████| 100/100 [00:01<00:00, 86.99it/s]\n",
      "epoch: 635, loss: 2.1627: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 636, loss: 2.0961: 100%|██████████| 100/100 [00:01<00:00, 87.33it/s]\n",
      "epoch: 637, loss: 2.2438: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 638, loss: 2.0869: 100%|██████████| 100/100 [00:01<00:00, 86.74it/s]\n",
      "epoch: 639, loss: 2.1469: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 640, loss: 1.9462: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 641, loss: 1.9004: 100%|██████████| 100/100 [00:01<00:00, 84.76it/s]\n",
      "epoch: 642, loss: 2.2118: 100%|██████████| 100/100 [00:01<00:00, 85.00it/s]\n",
      "epoch: 643, loss: 2.1270: 100%|██████████| 100/100 [00:01<00:00, 88.24it/s]\n",
      "epoch: 644, loss: 2.0826: 100%|██████████| 100/100 [00:01<00:00, 85.07it/s]\n",
      "epoch: 645, loss: 2.0935: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 646, loss: 2.1188: 100%|██████████| 100/100 [00:01<00:00, 90.50it/s]\n",
      "epoch: 647, loss: 2.1583: 100%|██████████| 100/100 [00:01<00:00, 88.20it/s]\n",
      "epoch: 648, loss: 2.0907: 100%|██████████| 100/100 [00:01<00:00, 89.66it/s]\n",
      "epoch: 649, loss: 1.8737: 100%|██████████| 100/100 [00:01<00:00, 88.86it/s]\n",
      "epoch: 650, loss: 2.1088: 100%|██████████| 100/100 [00:01<00:00, 90.15it/s]\n",
      "epoch: 651, loss: 2.3076: 100%|██████████| 100/100 [00:01<00:00, 89.35it/s]\n",
      "epoch: 652, loss: 2.3300: 100%|██████████| 100/100 [00:01<00:00, 88.34it/s]\n",
      "epoch: 653, loss: 2.0953: 100%|██████████| 100/100 [00:01<00:00, 98.44it/s]\n",
      "epoch: 654, loss: 2.2294: 100%|██████████| 100/100 [00:00<00:00, 100.76it/s]\n",
      "epoch: 655, loss: 2.1073: 100%|██████████| 100/100 [00:00<00:00, 100.43it/s]\n",
      "epoch: 656, loss: 2.1818: 100%|██████████| 100/100 [00:00<00:00, 103.91it/s]\n",
      "epoch: 657, loss: 2.0661: 100%|██████████| 100/100 [00:00<00:00, 108.03it/s]\n",
      "epoch: 658, loss: 2.1404: 100%|██████████| 100/100 [00:00<00:00, 104.54it/s]\n",
      "epoch: 659, loss: 1.9183: 100%|██████████| 100/100 [00:00<00:00, 106.67it/s]\n",
      "epoch: 660, loss: 2.3275: 100%|██████████| 100/100 [00:00<00:00, 108.32it/s]\n",
      "epoch: 661, loss: 2.0929: 100%|██████████| 100/100 [00:00<00:00, 106.39it/s]\n",
      "epoch: 662, loss: 2.1058: 100%|██████████| 100/100 [00:00<00:00, 105.05it/s]\n",
      "epoch: 663, loss: 2.1088: 100%|██████████| 100/100 [00:00<00:00, 107.17it/s]\n",
      "epoch: 664, loss: 2.2029: 100%|██████████| 100/100 [00:00<00:00, 100.89it/s]\n",
      "epoch: 665, loss: 2.1602: 100%|██████████| 100/100 [00:00<00:00, 108.20it/s]\n",
      "epoch: 666, loss: 2.1349: 100%|██████████| 100/100 [00:00<00:00, 106.63it/s]\n",
      "epoch: 667, loss: 2.1577: 100%|██████████| 100/100 [00:00<00:00, 100.67it/s]\n",
      "epoch: 668, loss: 2.0478: 100%|██████████| 100/100 [00:00<00:00, 108.02it/s]\n",
      "epoch: 669, loss: 1.7953: 100%|██████████| 100/100 [00:01<00:00, 86.66it/s]\n",
      "epoch: 670, loss: 2.2600: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 671, loss: 2.1614: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 672, loss: 2.0652: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 673, loss: 2.1797: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 674, loss: 2.0409: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 675, loss: 2.2396: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 676, loss: 2.0733: 100%|██████████| 100/100 [00:01<00:00, 87.35it/s]\n",
      "epoch: 677, loss: 2.1593: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 678, loss: 2.1214: 100%|██████████| 100/100 [00:01<00:00, 87.07it/s]\n",
      "epoch: 679, loss: 2.1393: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 680, loss: 2.1368: 100%|██████████| 100/100 [00:01<00:00, 87.43it/s]\n",
      "epoch: 681, loss: 2.3354: 100%|██████████| 100/100 [00:01<00:00, 87.64it/s]\n",
      "epoch: 682, loss: 2.0560: 100%|██████████| 100/100 [00:01<00:00, 86.70it/s]\n",
      "epoch: 683, loss: 2.2463: 100%|██████████| 100/100 [00:01<00:00, 87.94it/s]\n",
      "epoch: 684, loss: 2.1056: 100%|██████████| 100/100 [00:01<00:00, 87.16it/s]\n",
      "epoch: 685, loss: 2.0553: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 686, loss: 2.0530: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 687, loss: 2.1304: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 688, loss: 2.1858: 100%|██████████| 100/100 [00:01<00:00, 87.28it/s]\n",
      "epoch: 689, loss: 2.1168: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 690, loss: 2.1775: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 691, loss: 2.2311: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 692, loss: 2.1310: 100%|██████████| 100/100 [00:01<00:00, 87.18it/s]\n",
      "epoch: 693, loss: 2.3554: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 694, loss: 2.2261: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 695, loss: 2.1657: 100%|██████████| 100/100 [00:01<00:00, 96.48it/s]\n",
      "epoch: 696, loss: 2.2611: 100%|██████████| 100/100 [00:00<00:00, 124.43it/s]\n",
      "epoch: 697, loss: 2.0885: 100%|██████████| 100/100 [00:01<00:00, 88.24it/s]\n",
      "epoch: 698, loss: 2.2357: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 699, loss: 2.1402: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 700, loss: 2.0275: 100%|██████████| 100/100 [00:01<00:00, 89.02it/s]\n",
      "epoch: 701, loss: 2.2200: 100%|██████████| 100/100 [00:01<00:00, 88.24it/s]\n",
      "epoch: 702, loss: 2.0656: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 703, loss: 2.2667: 100%|██████████| 100/100 [00:01<00:00, 87.74it/s]\n",
      "epoch: 704, loss: 2.1553: 100%|██████████| 100/100 [00:01<00:00, 86.90it/s]\n",
      "epoch: 705, loss: 1.9178: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 706, loss: 2.0661: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 707, loss: 2.2846: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 708, loss: 2.2567: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 709, loss: 2.3250: 100%|██████████| 100/100 [00:01<00:00, 87.32it/s]\n",
      "epoch: 710, loss: 2.1753: 100%|██████████| 100/100 [00:01<00:00, 87.65it/s]\n",
      "epoch: 711, loss: 2.1182: 100%|██████████| 100/100 [00:01<00:00, 87.24it/s]\n",
      "epoch: 712, loss: 2.1050: 100%|██████████| 100/100 [00:01<00:00, 87.51it/s]\n",
      "epoch: 713, loss: 2.1852: 100%|██████████| 100/100 [00:01<00:00, 87.24it/s]\n",
      "epoch: 714, loss: 2.1770: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 715, loss: 2.2547: 100%|██████████| 100/100 [00:01<00:00, 87.52it/s]\n",
      "epoch: 716, loss: 2.0887: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 717, loss: 2.0176: 100%|██████████| 100/100 [00:01<00:00, 87.18it/s]\n",
      "epoch: 718, loss: 2.3380: 100%|██████████| 100/100 [00:01<00:00, 87.54it/s]\n",
      "epoch: 719, loss: 2.1497: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 720, loss: 2.3341: 100%|██████████| 100/100 [00:01<00:00, 87.56it/s]\n",
      "epoch: 721, loss: 2.1018: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 722, loss: 2.1329: 100%|██████████| 100/100 [00:01<00:00, 87.46it/s]\n",
      "epoch: 723, loss: 2.2022: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 724, loss: 2.0959: 100%|██████████| 100/100 [00:01<00:00, 87.43it/s]\n",
      "epoch: 725, loss: 1.8201: 100%|██████████| 100/100 [00:01<00:00, 86.87it/s]\n",
      "epoch: 726, loss: 2.2751: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 727, loss: 2.2061: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 728, loss: 2.0845: 100%|██████████| 100/100 [00:01<00:00, 87.36it/s]\n",
      "epoch: 729, loss: 2.2519: 100%|██████████| 100/100 [00:01<00:00, 87.67it/s]\n",
      "epoch: 730, loss: 2.0711: 100%|██████████| 100/100 [00:01<00:00, 87.56it/s]\n",
      "epoch: 731, loss: 2.0992: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 732, loss: 2.1626: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 733, loss: 2.0965: 100%|██████████| 100/100 [00:01<00:00, 87.68it/s]\n",
      "epoch: 734, loss: 1.9332: 100%|██████████| 100/100 [00:01<00:00, 87.52it/s]\n",
      "epoch: 735, loss: 2.1197: 100%|██████████| 100/100 [00:01<00:00, 87.45it/s]\n",
      "epoch: 736, loss: 2.0882: 100%|██████████| 100/100 [00:01<00:00, 87.36it/s]\n",
      "epoch: 737, loss: 2.0826: 100%|██████████| 100/100 [00:01<00:00, 87.58it/s]\n",
      "epoch: 738, loss: 2.0512: 100%|██████████| 100/100 [00:01<00:00, 87.71it/s]\n",
      "epoch: 739, loss: 2.1680: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 740, loss: 1.9533: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 741, loss: 1.9952: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 742, loss: 2.0302: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 743, loss: 2.1122: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 744, loss: 2.2766: 100%|██████████| 100/100 [00:01<00:00, 87.36it/s]\n",
      "epoch: 745, loss: 2.1415: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 746, loss: 2.2007: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 747, loss: 2.0677: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 748, loss: 2.0954: 100%|██████████| 100/100 [00:01<00:00, 85.22it/s]\n",
      "epoch: 749, loss: 2.0930: 100%|██████████| 100/100 [00:01<00:00, 84.99it/s]\n",
      "epoch: 750, loss: 2.2805: 100%|██████████| 100/100 [00:01<00:00, 84.35it/s]\n",
      "epoch: 751, loss: 1.9637: 100%|██████████| 100/100 [00:01<00:00, 84.94it/s]\n",
      "epoch: 752, loss: 2.1606: 100%|██████████| 100/100 [00:01<00:00, 84.50it/s]\n",
      "epoch: 753, loss: 2.2039: 100%|██████████| 100/100 [00:01<00:00, 84.30it/s]\n",
      "epoch: 754, loss: 2.2083: 100%|██████████| 100/100 [00:01<00:00, 85.59it/s]\n",
      "epoch: 755, loss: 2.2379: 100%|██████████| 100/100 [00:01<00:00, 87.96it/s]\n",
      "epoch: 756, loss: 2.1546: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 757, loss: 1.9690: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 758, loss: 2.2320: 100%|██████████| 100/100 [00:01<00:00, 87.78it/s]\n",
      "epoch: 759, loss: 2.1568: 100%|██████████| 100/100 [00:01<00:00, 87.50it/s]\n",
      "epoch: 760, loss: 2.1636: 100%|██████████| 100/100 [00:01<00:00, 87.28it/s]\n",
      "epoch: 761, loss: 1.8961: 100%|██████████| 100/100 [00:01<00:00, 86.64it/s]\n",
      "epoch: 762, loss: 2.0185: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 763, loss: 2.2562: 100%|██████████| 100/100 [00:01<00:00, 87.16it/s]\n",
      "epoch: 764, loss: 2.3415: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 765, loss: 2.2129: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 766, loss: 2.0215: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 767, loss: 2.0147: 100%|██████████| 100/100 [00:01<00:00, 87.26it/s]\n",
      "epoch: 768, loss: 2.2111: 100%|██████████| 100/100 [00:01<00:00, 86.87it/s]\n",
      "epoch: 769, loss: 1.9838: 100%|██████████| 100/100 [00:01<00:00, 87.50it/s]\n",
      "epoch: 770, loss: 2.0601: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 771, loss: 2.2009: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 772, loss: 1.9897: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 773, loss: 2.1775: 100%|██████████| 100/100 [00:01<00:00, 86.87it/s]\n",
      "epoch: 774, loss: 2.1917: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 775, loss: 2.2652: 100%|██████████| 100/100 [00:01<00:00, 86.96it/s]\n",
      "epoch: 776, loss: 2.0910: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 777, loss: 2.1542: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 778, loss: 2.1635: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 779, loss: 2.0068: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 780, loss: 2.1292: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 781, loss: 2.1891: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 782, loss: 2.1092: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 783, loss: 2.1037: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 784, loss: 2.1801: 100%|██████████| 100/100 [00:01<00:00, 87.20it/s]\n",
      "epoch: 785, loss: 2.1548: 100%|██████████| 100/100 [00:01<00:00, 87.51it/s]\n",
      "epoch: 786, loss: 2.1447: 100%|██████████| 100/100 [00:01<00:00, 87.45it/s]\n",
      "epoch: 787, loss: 2.1031: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 788, loss: 2.2068: 100%|██████████| 100/100 [00:01<00:00, 87.95it/s]\n",
      "epoch: 789, loss: 2.0800: 100%|██████████| 100/100 [00:01<00:00, 87.44it/s]\n",
      "epoch: 790, loss: 2.1601: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 791, loss: 2.2088: 100%|██████████| 100/100 [00:01<00:00, 87.70it/s]\n",
      "epoch: 792, loss: 2.2437: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 793, loss: 2.1203: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 794, loss: 2.2662: 100%|██████████| 100/100 [00:01<00:00, 86.59it/s]\n",
      "epoch: 795, loss: 2.1564: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 796, loss: 2.0873: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 797, loss: 2.0889: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 798, loss: 2.1674: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 799, loss: 2.2151: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 800, loss: 2.0939: 100%|██████████| 100/100 [00:01<00:00, 85.29it/s]\n",
      "epoch: 801, loss: 2.1602: 100%|██████████| 100/100 [00:01<00:00, 84.89it/s]\n",
      "epoch: 802, loss: 2.2399: 100%|██████████| 100/100 [00:01<00:00, 84.59it/s]\n",
      "epoch: 803, loss: 2.1262: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 804, loss: 2.2056: 100%|██████████| 100/100 [00:01<00:00, 88.71it/s]\n",
      "epoch: 805, loss: 2.2612: 100%|██████████| 100/100 [00:01<00:00, 87.71it/s]\n",
      "epoch: 806, loss: 2.2856: 100%|██████████| 100/100 [00:01<00:00, 84.49it/s]\n",
      "epoch: 807, loss: 2.2475: 100%|██████████| 100/100 [00:01<00:00, 86.79it/s]\n",
      "epoch: 808, loss: 2.1063: 100%|██████████| 100/100 [00:01<00:00, 87.56it/s]\n",
      "epoch: 809, loss: 2.1602: 100%|██████████| 100/100 [00:01<00:00, 86.84it/s]\n",
      "epoch: 810, loss: 2.3207: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 811, loss: 2.0970: 100%|██████████| 100/100 [00:01<00:00, 87.90it/s]\n",
      "epoch: 812, loss: 2.1853: 100%|██████████| 100/100 [00:01<00:00, 87.29it/s]\n",
      "epoch: 813, loss: 2.2278: 100%|██████████| 100/100 [00:01<00:00, 87.58it/s]\n",
      "epoch: 814, loss: 2.0229: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 815, loss: 2.1269: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n",
      "epoch: 816, loss: 1.9616: 100%|██████████| 100/100 [00:01<00:00, 87.67it/s]\n",
      "epoch: 817, loss: 1.9769: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 818, loss: 2.1862: 100%|██████████| 100/100 [00:01<00:00, 87.80it/s]\n",
      "epoch: 819, loss: 2.0605: 100%|██████████| 100/100 [00:01<00:00, 87.73it/s]\n",
      "epoch: 820, loss: 2.0299: 100%|██████████| 100/100 [00:01<00:00, 87.78it/s]\n",
      "epoch: 821, loss: 2.1537: 100%|██████████| 100/100 [00:01<00:00, 87.72it/s]\n",
      "epoch: 822, loss: 2.0820: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 823, loss: 2.0472: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 824, loss: 2.2457: 100%|██████████| 100/100 [00:01<00:00, 87.60it/s]\n",
      "epoch: 825, loss: 1.9648: 100%|██████████| 100/100 [00:01<00:00, 87.85it/s]\n",
      "epoch: 826, loss: 2.3395: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 827, loss: 2.0702: 100%|██████████| 100/100 [00:01<00:00, 87.62it/s]\n",
      "epoch: 828, loss: 2.3631: 100%|██████████| 100/100 [00:01<00:00, 87.46it/s]\n",
      "epoch: 829, loss: 1.9782: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 830, loss: 1.9925: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 831, loss: 2.2102: 100%|██████████| 100/100 [00:01<00:00, 87.07it/s]\n",
      "epoch: 832, loss: 2.0584: 100%|██████████| 100/100 [00:01<00:00, 87.92it/s]\n",
      "epoch: 833, loss: 2.0385: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 834, loss: 2.2691: 100%|██████████| 100/100 [00:01<00:00, 87.66it/s]\n",
      "epoch: 835, loss: 2.1464: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 836, loss: 2.2163: 100%|██████████| 100/100 [00:01<00:00, 87.48it/s]\n",
      "epoch: 837, loss: 2.1584: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 838, loss: 2.1665: 100%|██████████| 100/100 [00:01<00:00, 87.66it/s]\n",
      "epoch: 839, loss: 2.1052: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 840, loss: 2.0986: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 841, loss: 2.1039: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 842, loss: 2.0662: 100%|██████████| 100/100 [00:01<00:00, 87.68it/s]\n",
      "epoch: 843, loss: 2.1831: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 844, loss: 2.0973: 100%|██████████| 100/100 [00:01<00:00, 87.69it/s]\n",
      "epoch: 845, loss: 1.9726: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 846, loss: 2.1671: 100%|██████████| 100/100 [00:01<00:00, 87.90it/s]\n",
      "epoch: 847, loss: 2.1186: 100%|██████████| 100/100 [00:01<00:00, 87.51it/s]\n",
      "epoch: 848, loss: 2.1901: 100%|██████████| 100/100 [00:01<00:00, 87.46it/s]\n",
      "epoch: 849, loss: 2.1112: 100%|██████████| 100/100 [00:01<00:00, 87.74it/s]\n",
      "epoch: 850, loss: 2.2697: 100%|██████████| 100/100 [00:01<00:00, 85.81it/s]\n",
      "epoch: 851, loss: 1.9360: 100%|██████████| 100/100 [00:01<00:00, 87.74it/s]\n",
      "epoch: 852, loss: 1.9399: 100%|██████████| 100/100 [00:01<00:00, 86.64it/s]\n",
      "epoch: 853, loss: 1.9953: 100%|██████████| 100/100 [00:01<00:00, 84.64it/s]\n",
      "epoch: 854, loss: 1.8596: 100%|██████████| 100/100 [00:01<00:00, 85.45it/s]\n",
      "epoch: 855, loss: 2.0105: 100%|██████████| 100/100 [00:01<00:00, 84.80it/s]\n",
      "epoch: 856, loss: 2.1759: 100%|██████████| 100/100 [00:01<00:00, 84.33it/s]\n",
      "epoch: 857, loss: 2.1671: 100%|██████████| 100/100 [00:01<00:00, 84.13it/s]\n",
      "epoch: 858, loss: 2.2207: 100%|██████████| 100/100 [00:01<00:00, 84.18it/s]\n",
      "epoch: 859, loss: 2.0873: 100%|██████████| 100/100 [00:01<00:00, 84.72it/s]\n",
      "epoch: 860, loss: 2.3173: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 861, loss: 2.1409: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 862, loss: 1.9122: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 863, loss: 2.0544: 100%|██████████| 100/100 [00:01<00:00, 87.07it/s]\n",
      "epoch: 864, loss: 1.9187: 100%|██████████| 100/100 [00:01<00:00, 87.60it/s]\n",
      "epoch: 865, loss: 2.1536: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 866, loss: 2.1557: 100%|██████████| 100/100 [00:01<00:00, 87.87it/s]\n",
      "epoch: 867, loss: 2.1283: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 868, loss: 1.9654: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 869, loss: 2.0667: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 870, loss: 2.0713: 100%|██████████| 100/100 [00:01<00:00, 86.78it/s]\n",
      "epoch: 871, loss: 1.8460: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 872, loss: 2.0089: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 873, loss: 2.0014: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 874, loss: 2.1120: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 875, loss: 2.1584: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 876, loss: 2.0535: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 877, loss: 1.8972: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 878, loss: 2.1842: 100%|██████████| 100/100 [00:01<00:00, 87.02it/s]\n",
      "epoch: 879, loss: 2.2783: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 880, loss: 2.2762: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 881, loss: 2.1412: 100%|██████████| 100/100 [00:01<00:00, 87.05it/s]\n",
      "epoch: 882, loss: 2.3688: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 883, loss: 2.2289: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 884, loss: 1.9825: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 885, loss: 2.1898: 100%|██████████| 100/100 [00:01<00:00, 87.00it/s]\n",
      "epoch: 886, loss: 1.9813: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 887, loss: 2.1216: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 888, loss: 2.0999: 100%|██████████| 100/100 [00:01<00:00, 87.66it/s]\n",
      "epoch: 889, loss: 2.1092: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 890, loss: 2.3446: 100%|██████████| 100/100 [00:01<00:00, 87.40it/s]\n",
      "epoch: 891, loss: 2.0025: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 892, loss: 2.0612: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 893, loss: 2.1728: 100%|██████████| 100/100 [00:01<00:00, 86.72it/s]\n",
      "epoch: 894, loss: 2.1740: 100%|██████████| 100/100 [00:01<00:00, 87.76it/s]\n",
      "epoch: 895, loss: 2.0863: 100%|██████████| 100/100 [00:01<00:00, 87.70it/s]\n",
      "epoch: 896, loss: 2.1447: 100%|██████████| 100/100 [00:01<00:00, 87.54it/s]\n",
      "epoch: 897, loss: 2.2151: 100%|██████████| 100/100 [00:01<00:00, 87.68it/s]\n",
      "epoch: 898, loss: 1.9676: 100%|██████████| 100/100 [00:01<00:00, 86.86it/s]\n",
      "epoch: 899, loss: 2.1277: 100%|██████████| 100/100 [00:01<00:00, 87.70it/s]\n",
      "epoch: 900, loss: 2.0759: 100%|██████████| 100/100 [00:01<00:00, 88.13it/s]\n",
      "epoch: 901, loss: 1.9341: 100%|██████████| 100/100 [00:01<00:00, 87.83it/s]\n",
      "epoch: 902, loss: 2.0265: 100%|██████████| 100/100 [00:01<00:00, 88.41it/s]\n",
      "epoch: 903, loss: 2.3826: 100%|██████████| 100/100 [00:01<00:00, 87.99it/s]\n",
      "epoch: 904, loss: 1.9790: 100%|██████████| 100/100 [00:01<00:00, 87.65it/s]\n",
      "epoch: 905, loss: 2.0671: 100%|██████████| 100/100 [00:01<00:00, 88.63it/s]\n",
      "epoch: 906, loss: 2.3511: 100%|██████████| 100/100 [00:01<00:00, 87.91it/s]\n",
      "epoch: 907, loss: 2.2616: 100%|██████████| 100/100 [00:01<00:00, 88.05it/s]\n",
      "epoch: 908, loss: 2.0805: 100%|██████████| 100/100 [00:01<00:00, 89.20it/s]\n",
      "epoch: 909, loss: 2.0740: 100%|██████████| 100/100 [00:01<00:00, 87.73it/s]\n",
      "epoch: 910, loss: 2.1370: 100%|██████████| 100/100 [00:01<00:00, 87.14it/s]\n",
      "epoch: 911, loss: 1.9831: 100%|██████████| 100/100 [00:01<00:00, 89.00it/s]\n",
      "epoch: 912, loss: 2.0303: 100%|██████████| 100/100 [00:01<00:00, 87.13it/s]\n",
      "epoch: 913, loss: 2.1960: 100%|██████████| 100/100 [00:01<00:00, 88.42it/s]\n",
      "epoch: 914, loss: 2.0894: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 915, loss: 2.2163: 100%|██████████| 100/100 [00:01<00:00, 87.13it/s]\n",
      "epoch: 916, loss: 2.1399: 100%|██████████| 100/100 [00:01<00:00, 87.57it/s]\n",
      "epoch: 917, loss: 2.1470: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 918, loss: 2.1634: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 919, loss: 2.0474: 100%|██████████| 100/100 [00:01<00:00, 87.64it/s]\n",
      "epoch: 920, loss: 2.1153: 100%|██████████| 100/100 [00:01<00:00, 87.12it/s]\n",
      "epoch: 921, loss: 2.1760: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 922, loss: 1.9614: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 923, loss: 2.0136: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 924, loss: 1.9836: 100%|██████████| 100/100 [00:01<00:00, 87.25it/s]\n",
      "epoch: 925, loss: 1.9108: 100%|██████████| 100/100 [00:01<00:00, 86.88it/s]\n",
      "epoch: 926, loss: 1.9614: 100%|██████████| 100/100 [00:01<00:00, 87.60it/s]\n",
      "epoch: 927, loss: 2.1933: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 928, loss: 2.1157: 100%|██████████| 100/100 [00:01<00:00, 87.71it/s]\n",
      "epoch: 929, loss: 1.9302: 100%|██████████| 100/100 [00:01<00:00, 87.53it/s]\n",
      "epoch: 930, loss: 1.9589: 100%|██████████| 100/100 [00:01<00:00, 88.24it/s]\n",
      "epoch: 931, loss: 2.0946: 100%|██████████| 100/100 [00:01<00:00, 86.93it/s]\n",
      "epoch: 932, loss: 2.0825: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 933, loss: 2.0872: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 934, loss: 2.2200: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 935, loss: 2.0566: 100%|██████████| 100/100 [00:01<00:00, 86.94it/s]\n",
      "epoch: 936, loss: 2.0326: 100%|██████████| 100/100 [00:01<00:00, 87.05it/s]\n",
      "epoch: 937, loss: 2.1905: 100%|██████████| 100/100 [00:01<00:00, 87.04it/s]\n",
      "epoch: 938, loss: 2.3034: 100%|██████████| 100/100 [00:01<00:00, 87.30it/s]\n",
      "epoch: 939, loss: 2.1882: 100%|██████████| 100/100 [00:01<00:00, 87.13it/s]\n",
      "epoch: 940, loss: 2.1875: 100%|██████████| 100/100 [00:01<00:00, 86.96it/s]\n",
      "epoch: 941, loss: 2.0642: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 942, loss: 2.0795: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 943, loss: 2.1458: 100%|██████████| 100/100 [00:01<00:00, 87.60it/s]\n",
      "epoch: 944, loss: 2.2131: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 945, loss: 2.0999: 100%|██████████| 100/100 [00:01<00:00, 87.59it/s]\n",
      "epoch: 946, loss: 2.0757: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 947, loss: 2.2589: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 948, loss: 1.9786: 100%|██████████| 100/100 [00:01<00:00, 87.37it/s]\n",
      "epoch: 949, loss: 2.2319: 100%|██████████| 100/100 [00:01<00:00, 87.18it/s]\n",
      "epoch: 950, loss: 1.9740: 100%|██████████| 100/100 [00:01<00:00, 87.42it/s]\n",
      "epoch: 951, loss: 2.1310: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 952, loss: 2.2019: 100%|██████████| 100/100 [00:01<00:00, 86.95it/s]\n",
      "epoch: 953, loss: 2.1450: 100%|██████████| 100/100 [00:01<00:00, 87.52it/s]\n",
      "epoch: 954, loss: 2.1209: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 955, loss: 2.1298: 100%|██████████| 100/100 [00:01<00:00, 87.10it/s]\n",
      "epoch: 956, loss: 2.0586: 100%|██████████| 100/100 [00:01<00:00, 86.73it/s]\n",
      "epoch: 957, loss: 2.1500: 100%|██████████| 100/100 [00:01<00:00, 88.97it/s]\n",
      "epoch: 958, loss: 2.1537: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 959, loss: 2.0253: 100%|██████████| 100/100 [00:01<00:00, 88.28it/s]\n",
      "epoch: 960, loss: 2.0848: 100%|██████████| 100/100 [00:01<00:00, 87.68it/s]\n",
      "epoch: 961, loss: 1.8974: 100%|██████████| 100/100 [00:01<00:00, 87.17it/s]\n",
      "epoch: 962, loss: 2.0198: 100%|██████████| 100/100 [00:01<00:00, 89.35it/s]\n",
      "epoch: 963, loss: 2.0575: 100%|██████████| 100/100 [00:01<00:00, 88.24it/s]\n",
      "epoch: 964, loss: 2.1817: 100%|██████████| 100/100 [00:01<00:00, 87.74it/s]\n",
      "epoch: 965, loss: 2.0853: 100%|██████████| 100/100 [00:01<00:00, 88.10it/s]\n",
      "epoch: 966, loss: 2.0526: 100%|██████████| 100/100 [00:01<00:00, 87.88it/s]\n",
      "epoch: 967, loss: 2.0759: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 968, loss: 2.1666: 100%|██████████| 100/100 [00:01<00:00, 87.85it/s]\n",
      "epoch: 969, loss: 2.2779: 100%|██████████| 100/100 [00:01<00:00, 87.77it/s]\n",
      "epoch: 970, loss: 2.1792: 100%|██████████| 100/100 [00:01<00:00, 87.01it/s]\n",
      "epoch: 971, loss: 2.1001: 100%|██████████| 100/100 [00:01<00:00, 87.75it/s]\n",
      "epoch: 972, loss: 2.3057: 100%|██████████| 100/100 [00:01<00:00, 87.21it/s]\n",
      "epoch: 973, loss: 1.9680: 100%|██████████| 100/100 [00:01<00:00, 87.34it/s]\n",
      "epoch: 974, loss: 2.2465: 100%|██████████| 100/100 [00:01<00:00, 87.03it/s]\n",
      "epoch: 975, loss: 2.2371: 100%|██████████| 100/100 [00:01<00:00, 87.47it/s]\n",
      "epoch: 976, loss: 2.0963: 100%|██████████| 100/100 [00:01<00:00, 87.77it/s]\n",
      "epoch: 977, loss: 2.0119: 100%|██████████| 100/100 [00:01<00:00, 87.28it/s]\n",
      "epoch: 978, loss: 2.1181: 100%|██████████| 100/100 [00:01<00:00, 87.26it/s]\n",
      "epoch: 979, loss: 2.0356: 100%|██████████| 100/100 [00:01<00:00, 87.08it/s]\n",
      "epoch: 980, loss: 2.2803: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 981, loss: 2.2148: 100%|██████████| 100/100 [00:01<00:00, 87.39it/s]\n",
      "epoch: 982, loss: 1.9410: 100%|██████████| 100/100 [00:01<00:00, 87.30it/s]\n",
      "epoch: 983, loss: 2.2095: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 984, loss: 1.9649: 100%|██████████| 100/100 [00:01<00:00, 87.52it/s]\n",
      "epoch: 985, loss: 2.1242: 100%|██████████| 100/100 [00:01<00:00, 87.63it/s]\n",
      "epoch: 986, loss: 1.8306: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 987, loss: 2.0483: 100%|██████████| 100/100 [00:01<00:00, 87.55it/s]\n",
      "epoch: 988, loss: 1.9858: 100%|██████████| 100/100 [00:01<00:00, 87.23it/s]\n",
      "epoch: 989, loss: 2.0952: 100%|██████████| 100/100 [00:01<00:00, 86.92it/s]\n",
      "epoch: 990, loss: 2.1719: 100%|██████████| 100/100 [00:01<00:00, 86.97it/s]\n",
      "epoch: 991, loss: 2.1589: 100%|██████████| 100/100 [00:01<00:00, 87.06it/s]\n",
      "epoch: 992, loss: 2.3282: 100%|██████████| 100/100 [00:01<00:00, 87.58it/s]\n",
      "epoch: 993, loss: 2.1285: 100%|██████████| 100/100 [00:01<00:00, 87.41it/s]\n",
      "epoch: 994, loss: 2.0669: 100%|██████████| 100/100 [00:01<00:00, 87.11it/s]\n",
      "epoch: 995, loss: 2.1392: 100%|██████████| 100/100 [00:01<00:00, 87.49it/s]\n",
      "epoch: 996, loss: 2.1349: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 997, loss: 2.0411: 100%|██████████| 100/100 [00:01<00:00, 87.15it/s]\n",
      "epoch: 998, loss: 1.8341: 100%|██████████| 100/100 [00:01<00:00, 87.28it/s]\n",
      "epoch: 999, loss: 2.2587: 100%|██████████| 100/100 [00:01<00:00, 87.31it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "samples = float2bin(db.gen_batch(50000), bm)\n",
    "mean = np.mean(samples, axis=0)\n",
    "init_dist = torch.distributions.Bernoulli(probs=torch.from_numpy(mean).to(device) * (1. - 2 * 1e-2) + 1e-2)\n",
    "net = MLPScore(input_dim=32, hidden_dims=[256,256,256,1]).to(device)\n",
    "energy_func = EBM(net, torch.from_numpy(mean)).to(device)\n",
    "ema_energy_func = training_main_loop(db, bm, energy_func, device, algo='ed_bern')\n",
    "plot_heat(ema_energy_func, bm, device)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Discrete EBM using ED-Pool"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 0, loss: 2.0543: 100%|██████████| 100/100 [00:01<00:00, 84.99it/s]\n",
      "epoch: 1, loss: 1.6527: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 2, loss: 1.5480: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 3, loss: 1.4197: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 4, loss: 1.4337: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 5, loss: 1.1979: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 6, loss: 1.3607: 100%|██████████| 100/100 [00:01<00:00, 84.95it/s]\n",
      "epoch: 7, loss: 1.3908: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 8, loss: 1.3921: 100%|██████████| 100/100 [00:01<00:00, 83.56it/s]\n",
      "epoch: 9, loss: 1.1375: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 10, loss: 1.2565: 100%|██████████| 100/100 [00:01<00:00, 84.26it/s]\n",
      "epoch: 11, loss: 1.2694: 100%|██████████| 100/100 [00:01<00:00, 84.99it/s]\n",
      "epoch: 12, loss: 1.1879: 100%|██████████| 100/100 [00:01<00:00, 86.52it/s]\n",
      "epoch: 13, loss: 1.3969: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 14, loss: 1.1506: 100%|██████████| 100/100 [00:01<00:00, 87.09it/s]\n",
      "epoch: 15, loss: 1.3573: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 16, loss: 1.3465: 100%|██████████| 100/100 [00:01<00:00, 86.73it/s]\n",
      "epoch: 17, loss: 1.1350: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 18, loss: 1.3294: 100%|██████████| 100/100 [00:01<00:00, 85.41it/s]\n",
      "epoch: 19, loss: 1.1167: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 20, loss: 1.3059: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 21, loss: 1.3097: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 22, loss: 1.2213: 100%|██████████| 100/100 [00:01<00:00, 85.40it/s]\n",
      "epoch: 23, loss: 1.1504: 100%|██████████| 100/100 [00:01<00:00, 85.38it/s]\n",
      "epoch: 24, loss: 1.1143: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 25, loss: 1.2326: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 26, loss: 1.3390: 100%|██████████| 100/100 [00:01<00:00, 85.63it/s]\n",
      "epoch: 27, loss: 1.2445: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 28, loss: 1.2960: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 29, loss: 1.1838: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 30, loss: 1.3050: 100%|██████████| 100/100 [00:01<00:00, 85.45it/s]\n",
      "epoch: 31, loss: 1.1747: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 32, loss: 1.2610: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 33, loss: 1.2172: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 34, loss: 1.3278: 100%|██████████| 100/100 [00:01<00:00, 85.66it/s]\n",
      "epoch: 35, loss: 1.1638: 100%|██████████| 100/100 [00:01<00:00, 85.44it/s]\n",
      "epoch: 36, loss: 1.3478: 100%|██████████| 100/100 [00:01<00:00, 85.33it/s]\n",
      "epoch: 37, loss: 1.1207: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 38, loss: 1.2192: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 39, loss: 1.2467: 100%|██████████| 100/100 [00:01<00:00, 85.82it/s]\n",
      "epoch: 40, loss: 1.2311: 100%|██████████| 100/100 [00:01<00:00, 95.70it/s]\n",
      "epoch: 41, loss: 1.1705: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 42, loss: 1.2264: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 43, loss: 1.2189: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 44, loss: 1.2775: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 45, loss: 1.1615: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 46, loss: 1.2289: 100%|██████████| 100/100 [00:01<00:00, 86.51it/s]\n",
      "epoch: 47, loss: 1.2574: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 48, loss: 1.1501: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 49, loss: 1.2962: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 50, loss: 1.1899: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 51, loss: 1.1865: 100%|██████████| 100/100 [00:01<00:00, 86.42it/s]\n",
      "epoch: 52, loss: 1.2475: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 53, loss: 1.3519: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 54, loss: 1.2850: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 55, loss: 1.2873: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 56, loss: 1.2046: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 57, loss: 1.1855: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 58, loss: 1.1246: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 59, loss: 1.2105: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 60, loss: 1.1291: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 61, loss: 1.2554: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 62, loss: 1.2429: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 63, loss: 1.1871: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 64, loss: 1.1193: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 65, loss: 1.2163: 100%|██████████| 100/100 [00:01<00:00, 86.82it/s]\n",
      "epoch: 66, loss: 1.4299: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 67, loss: 1.1963: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 68, loss: 1.0744: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 69, loss: 1.2618: 100%|██████████| 100/100 [00:01<00:00, 86.42it/s]\n",
      "epoch: 70, loss: 1.2427: 100%|██████████| 100/100 [00:01<00:00, 85.46it/s]\n",
      "epoch: 71, loss: 1.2623: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 72, loss: 1.1670: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 73, loss: 1.1213: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 74, loss: 1.1438: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 75, loss: 1.2457: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 76, loss: 1.1646: 100%|██████████| 100/100 [00:01<00:00, 86.40it/s]\n",
      "epoch: 77, loss: 1.1210: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 78, loss: 1.1872: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 79, loss: 1.1441: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 80, loss: 1.2508: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 81, loss: 1.6646: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 82, loss: 1.1969: 100%|██████████| 100/100 [00:01<00:00, 85.83it/s]\n",
      "epoch: 83, loss: 1.2438: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 84, loss: 1.3029: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 85, loss: 1.0537: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 86, loss: 1.2491: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 87, loss: 1.3704: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 88, loss: 1.1872: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 89, loss: 1.2111: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 90, loss: 1.1514: 100%|██████████| 100/100 [00:01<00:00, 86.40it/s]\n",
      "epoch: 91, loss: 1.2728: 100%|██████████| 100/100 [00:01<00:00, 85.84it/s]\n",
      "epoch: 92, loss: 1.2722: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 93, loss: 1.1487: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 94, loss: 1.2756: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 95, loss: 1.1544: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 96, loss: 1.2736: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 97, loss: 1.2563: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 98, loss: 1.4241: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 99, loss: 1.1855: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 100, loss: 1.2598: 100%|██████████| 100/100 [00:01<00:00, 86.64it/s]\n",
      "epoch: 101, loss: 1.2720: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 102, loss: 1.2176: 100%|██████████| 100/100 [00:01<00:00, 86.98it/s]\n",
      "epoch: 103, loss: 1.2839: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 104, loss: 1.1567: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 105, loss: 1.2019: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 106, loss: 1.0578: 100%|██████████| 100/100 [00:01<00:00, 85.67it/s]\n",
      "epoch: 107, loss: 1.1606: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 108, loss: 1.1649: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 109, loss: 1.3712: 100%|██████████| 100/100 [00:01<00:00, 86.62it/s]\n",
      "epoch: 110, loss: 1.2400: 100%|██████████| 100/100 [00:01<00:00, 87.22it/s]\n",
      "epoch: 111, loss: 1.1934: 100%|██████████| 100/100 [00:01<00:00, 85.33it/s]\n",
      "epoch: 112, loss: 1.0997: 100%|██████████| 100/100 [00:01<00:00, 85.66it/s]\n",
      "epoch: 113, loss: 1.2878: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 114, loss: 1.1392: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 115, loss: 1.0895: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 116, loss: 1.2632: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 117, loss: 1.3475: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 118, loss: 1.2572: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 119, loss: 1.2224: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 120, loss: 1.1927: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 121, loss: 1.1901: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 122, loss: 1.2488: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 123, loss: 1.2377: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 124, loss: 1.2503: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 125, loss: 1.2643: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 126, loss: 1.2131: 100%|██████████| 100/100 [00:01<00:00, 86.69it/s]\n",
      "epoch: 127, loss: 1.2566: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 128, loss: 1.3510: 100%|██████████| 100/100 [00:01<00:00, 86.41it/s]\n",
      "epoch: 129, loss: 1.1823: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 130, loss: 1.2724: 100%|██████████| 100/100 [00:01<00:00, 87.19it/s]\n",
      "epoch: 131, loss: 1.2143: 100%|██████████| 100/100 [00:01<00:00, 86.48it/s]\n",
      "epoch: 132, loss: 1.2055: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 133, loss: 1.0807: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 134, loss: 1.2185: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 135, loss: 1.1237: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 136, loss: 1.2546: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 137, loss: 1.2010: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 138, loss: 1.2298: 100%|██████████| 100/100 [00:01<00:00, 86.48it/s]\n",
      "epoch: 139, loss: 1.2748: 100%|██████████| 100/100 [00:01<00:00, 85.84it/s]\n",
      "epoch: 140, loss: 1.3447: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 141, loss: 1.1965: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 142, loss: 1.2162: 100%|██████████| 100/100 [00:01<00:00, 86.51it/s]\n",
      "epoch: 143, loss: 1.3379: 100%|██████████| 100/100 [00:01<00:00, 85.04it/s]\n",
      "epoch: 144, loss: 1.1062: 100%|██████████| 100/100 [00:01<00:00, 86.61it/s]\n",
      "epoch: 145, loss: 1.1420: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 146, loss: 1.0686: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 147, loss: 1.1641: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 148, loss: 1.2066: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 149, loss: 1.1173: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 150, loss: 1.2274: 100%|██████████| 100/100 [00:01<00:00, 85.81it/s]\n",
      "epoch: 151, loss: 1.2596: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 152, loss: 1.1720: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 153, loss: 1.1056: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 154, loss: 1.2734: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 155, loss: 1.2160: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 156, loss: 1.1010: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 157, loss: 1.2894: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 158, loss: 1.1424: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 159, loss: 1.2815: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 160, loss: 1.2790: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 161, loss: 1.1983: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 162, loss: 1.2364: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 163, loss: 1.2667: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 164, loss: 1.2127: 100%|██████████| 100/100 [00:01<00:00, 85.38it/s]\n",
      "epoch: 165, loss: 1.1659: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 166, loss: 1.4615: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 167, loss: 1.1355: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 168, loss: 1.1992: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 169, loss: 1.2889: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 170, loss: 1.2018: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 171, loss: 1.2995: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 172, loss: 1.3565: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 173, loss: 1.1858: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 174, loss: 1.2287: 100%|██████████| 100/100 [00:01<00:00, 84.99it/s]\n",
      "epoch: 175, loss: 1.2730: 100%|██████████| 100/100 [00:01<00:00, 86.72it/s]\n",
      "epoch: 176, loss: 1.3167: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 177, loss: 1.1847: 100%|██████████| 100/100 [00:01<00:00, 85.43it/s]\n",
      "epoch: 178, loss: 1.3074: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 179, loss: 1.2499: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 180, loss: 1.2186: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 181, loss: 1.2723: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 182, loss: 1.1791: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 183, loss: 1.2882: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 184, loss: 1.0933: 100%|██████████| 100/100 [00:01<00:00, 85.71it/s]\n",
      "epoch: 185, loss: 1.3166: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 186, loss: 1.4335: 100%|██████████| 100/100 [00:01<00:00, 85.37it/s]\n",
      "epoch: 187, loss: 1.1919: 100%|██████████| 100/100 [00:01<00:00, 85.76it/s]\n",
      "epoch: 188, loss: 1.1424: 100%|██████████| 100/100 [00:01<00:00, 85.53it/s]\n",
      "epoch: 189, loss: 1.2851: 100%|██████████| 100/100 [00:01<00:00, 85.59it/s]\n",
      "epoch: 190, loss: 1.2338: 100%|██████████| 100/100 [00:01<00:00, 84.82it/s]\n",
      "epoch: 191, loss: 1.1253: 100%|██████████| 100/100 [00:01<00:00, 84.89it/s]\n",
      "epoch: 192, loss: 1.2055: 100%|██████████| 100/100 [00:01<00:00, 85.49it/s]\n",
      "epoch: 193, loss: 1.1754: 100%|██████████| 100/100 [00:01<00:00, 85.38it/s]\n",
      "epoch: 194, loss: 1.2327: 100%|██████████| 100/100 [00:01<00:00, 85.58it/s]\n",
      "epoch: 195, loss: 1.1968: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 196, loss: 1.2988: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 197, loss: 1.4170: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 198, loss: 1.3243: 100%|██████████| 100/100 [00:01<00:00, 85.29it/s]\n",
      "epoch: 199, loss: 1.2041: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 200, loss: 1.0958: 100%|██████████| 100/100 [00:01<00:00, 85.83it/s]\n",
      "epoch: 201, loss: 1.1950: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 202, loss: 1.2386: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 203, loss: 1.2840: 100%|██████████| 100/100 [00:01<00:00, 85.49it/s]\n",
      "epoch: 204, loss: 1.3179: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 205, loss: 1.1815: 100%|██████████| 100/100 [00:01<00:00, 84.24it/s]\n",
      "epoch: 206, loss: 1.2465: 100%|██████████| 100/100 [00:01<00:00, 85.54it/s]\n",
      "epoch: 207, loss: 1.1741: 100%|██████████| 100/100 [00:01<00:00, 89.26it/s]\n",
      "epoch: 208, loss: 1.2494: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 209, loss: 1.2361: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 210, loss: 1.1976: 100%|██████████| 100/100 [00:01<00:00, 85.61it/s]\n",
      "epoch: 211, loss: 1.1716: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 212, loss: 1.2587: 100%|██████████| 100/100 [00:01<00:00, 85.59it/s]\n",
      "epoch: 213, loss: 1.1406: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 214, loss: 1.3085: 100%|██████████| 100/100 [00:01<00:00, 85.29it/s]\n",
      "epoch: 215, loss: 1.3176: 100%|██████████| 100/100 [00:01<00:00, 84.52it/s]\n",
      "epoch: 216, loss: 1.1803: 100%|██████████| 100/100 [00:01<00:00, 85.57it/s]\n",
      "epoch: 217, loss: 1.1964: 100%|██████████| 100/100 [00:01<00:00, 85.46it/s]\n",
      "epoch: 218, loss: 1.2873: 100%|██████████| 100/100 [00:01<00:00, 85.36it/s]\n",
      "epoch: 219, loss: 1.2430: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 220, loss: 1.2526: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 221, loss: 1.0513: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 222, loss: 1.2463: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 223, loss: 1.0701: 100%|██████████| 100/100 [00:01<00:00, 84.61it/s]\n",
      "epoch: 224, loss: 1.1513: 100%|██████████| 100/100 [00:01<00:00, 85.02it/s]\n",
      "epoch: 225, loss: 1.2232: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 226, loss: 1.2241: 100%|██████████| 100/100 [00:01<00:00, 85.39it/s]\n",
      "epoch: 227, loss: 1.1148: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 228, loss: 1.2114: 100%|██████████| 100/100 [00:01<00:00, 85.66it/s]\n",
      "epoch: 229, loss: 1.2017: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 230, loss: 1.1200: 100%|██████████| 100/100 [00:01<00:00, 85.34it/s]\n",
      "epoch: 231, loss: 1.1239: 100%|██████████| 100/100 [00:01<00:00, 85.84it/s]\n",
      "epoch: 232, loss: 1.2497: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 233, loss: 1.3391: 100%|██████████| 100/100 [00:01<00:00, 85.44it/s]\n",
      "epoch: 234, loss: 1.2415: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 235, loss: 1.2016: 100%|██████████| 100/100 [00:01<00:00, 85.48it/s]\n",
      "epoch: 236, loss: 1.2413: 100%|██████████| 100/100 [00:01<00:00, 84.65it/s]\n",
      "epoch: 237, loss: 1.1074: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 238, loss: 1.1969: 100%|██████████| 100/100 [00:01<00:00, 85.23it/s]\n",
      "epoch: 239, loss: 1.2656: 100%|██████████| 100/100 [00:01<00:00, 85.33it/s]\n",
      "epoch: 240, loss: 1.2470: 100%|██████████| 100/100 [00:01<00:00, 85.16it/s]\n",
      "epoch: 241, loss: 1.2263: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 242, loss: 1.2633: 100%|██████████| 100/100 [00:01<00:00, 89.55it/s]\n",
      "epoch: 243, loss: 1.1558: 100%|██████████| 100/100 [00:01<00:00, 91.52it/s]\n",
      "epoch: 244, loss: 1.0215: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 245, loss: 1.0292: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 246, loss: 1.2865: 100%|██████████| 100/100 [00:01<00:00, 86.43it/s]\n",
      "epoch: 247, loss: 1.2664: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 248, loss: 1.2871: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 249, loss: 1.3868: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 250, loss: 1.1334: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 251, loss: 1.2403: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 252, loss: 1.2026: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 253, loss: 1.2733: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 254, loss: 1.1273: 100%|██████████| 100/100 [00:01<00:00, 85.94it/s]\n",
      "epoch: 255, loss: 1.1210: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 256, loss: 1.1991: 100%|██████████| 100/100 [00:01<00:00, 86.72it/s]\n",
      "epoch: 257, loss: 1.1756: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 258, loss: 1.1982: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 259, loss: 1.2036: 100%|██████████| 100/100 [00:01<00:00, 85.81it/s]\n",
      "epoch: 260, loss: 1.0186: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 261, loss: 1.2435: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 262, loss: 1.1198: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 263, loss: 1.0913: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 264, loss: 1.1907: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 265, loss: 1.1961: 100%|██████████| 100/100 [00:01<00:00, 85.49it/s]\n",
      "epoch: 266, loss: 1.2049: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 267, loss: 1.2709: 100%|██████████| 100/100 [00:01<00:00, 84.61it/s]\n",
      "epoch: 268, loss: 1.1556: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 269, loss: 1.3325: 100%|██████████| 100/100 [00:01<00:00, 85.63it/s]\n",
      "epoch: 270, loss: 1.0475: 100%|██████████| 100/100 [00:01<00:00, 85.88it/s]\n",
      "epoch: 271, loss: 1.1182: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 272, loss: 1.0927: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 273, loss: 1.2333: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 274, loss: 1.1703: 100%|██████████| 100/100 [00:01<00:00, 85.59it/s]\n",
      "epoch: 275, loss: 1.1645: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 276, loss: 1.1790: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 277, loss: 1.0874: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 278, loss: 1.1238: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 279, loss: 1.2240: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 280, loss: 1.3250: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 281, loss: 1.2485: 100%|██████████| 100/100 [00:01<00:00, 85.34it/s]\n",
      "epoch: 282, loss: 1.3711: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 283, loss: 1.1896: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 284, loss: 1.0492: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 285, loss: 1.1758: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 286, loss: 1.2027: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 287, loss: 1.1654: 100%|██████████| 100/100 [00:01<00:00, 86.36it/s]\n",
      "epoch: 288, loss: 1.2846: 100%|██████████| 100/100 [00:01<00:00, 85.71it/s]\n",
      "epoch: 289, loss: 1.1863: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 290, loss: 1.3052: 100%|██████████| 100/100 [00:01<00:00, 85.61it/s]\n",
      "epoch: 291, loss: 1.1410: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 292, loss: 1.1069: 100%|██████████| 100/100 [00:01<00:00, 85.97it/s]\n",
      "epoch: 293, loss: 1.2627: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 294, loss: 1.2886: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 295, loss: 1.2463: 100%|██████████| 100/100 [00:01<00:00, 85.53it/s]\n",
      "epoch: 296, loss: 1.1057: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 297, loss: 1.2237: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 298, loss: 1.2523: 100%|██████████| 100/100 [00:01<00:00, 85.53it/s]\n",
      "epoch: 299, loss: 1.3015: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 300, loss: 1.1913: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 301, loss: 1.1133: 100%|██████████| 100/100 [00:01<00:00, 85.84it/s]\n",
      "epoch: 302, loss: 1.2483: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 303, loss: 1.2582: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 304, loss: 1.2683: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 305, loss: 1.1884: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 306, loss: 1.2465: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 307, loss: 1.2486: 100%|██████████| 100/100 [00:01<00:00, 85.52it/s]\n",
      "epoch: 308, loss: 1.2929: 100%|██████████| 100/100 [00:01<00:00, 85.21it/s]\n",
      "epoch: 309, loss: 1.1145: 100%|██████████| 100/100 [00:01<00:00, 85.65it/s]\n",
      "epoch: 310, loss: 1.0612: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 311, loss: 1.1875: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 312, loss: 1.2627: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 313, loss: 1.1676: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 314, loss: 1.1854: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 315, loss: 1.2267: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 316, loss: 1.1093: 100%|██████████| 100/100 [00:01<00:00, 85.67it/s]\n",
      "epoch: 317, loss: 1.3324: 100%|██████████| 100/100 [00:01<00:00, 84.69it/s]\n",
      "epoch: 318, loss: 1.1229: 100%|██████████| 100/100 [00:01<00:00, 83.25it/s]\n",
      "epoch: 319, loss: 1.3486: 100%|██████████| 100/100 [00:01<00:00, 84.72it/s]\n",
      "epoch: 320, loss: 1.2458: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 321, loss: 1.0421: 100%|██████████| 100/100 [00:01<00:00, 85.77it/s]\n",
      "epoch: 322, loss: 1.3060: 100%|██████████| 100/100 [00:01<00:00, 85.39it/s]\n",
      "epoch: 323, loss: 1.1511: 100%|██████████| 100/100 [00:01<00:00, 85.36it/s]\n",
      "epoch: 324, loss: 1.1756: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 325, loss: 1.2612: 100%|██████████| 100/100 [00:01<00:00, 85.18it/s]\n",
      "epoch: 326, loss: 1.3021: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 327, loss: 1.2070: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 328, loss: 1.1484: 100%|██████████| 100/100 [00:01<00:00, 85.16it/s]\n",
      "epoch: 329, loss: 1.3425: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 330, loss: 1.1938: 100%|██████████| 100/100 [00:01<00:00, 85.20it/s]\n",
      "epoch: 331, loss: 1.2358: 100%|██████████| 100/100 [00:01<00:00, 85.52it/s]\n",
      "epoch: 332, loss: 1.2277: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 333, loss: 1.1796: 100%|██████████| 100/100 [00:01<00:00, 85.28it/s]\n",
      "epoch: 334, loss: 1.3366: 100%|██████████| 100/100 [00:01<00:00, 85.83it/s]\n",
      "epoch: 335, loss: 1.1126: 100%|██████████| 100/100 [00:01<00:00, 85.65it/s]\n",
      "epoch: 336, loss: 1.2283: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 337, loss: 1.2049: 100%|██████████| 100/100 [00:01<00:00, 85.51it/s]\n",
      "epoch: 338, loss: 1.1740: 100%|██████████| 100/100 [00:01<00:00, 85.31it/s]\n",
      "epoch: 339, loss: 1.2009: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 340, loss: 1.4240: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 341, loss: 1.3082: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 342, loss: 1.1694: 100%|██████████| 100/100 [00:01<00:00, 85.45it/s]\n",
      "epoch: 343, loss: 1.2109: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 344, loss: 1.2229: 100%|██████████| 100/100 [00:01<00:00, 85.25it/s]\n",
      "epoch: 345, loss: 1.1968: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 346, loss: 0.9960: 100%|██████████| 100/100 [00:01<00:00, 85.27it/s]\n",
      "epoch: 347, loss: 1.3001: 100%|██████████| 100/100 [00:01<00:00, 85.04it/s]\n",
      "epoch: 348, loss: 1.0722: 100%|██████████| 100/100 [00:01<00:00, 84.89it/s]\n",
      "epoch: 349, loss: 1.2932: 100%|██████████| 100/100 [00:01<00:00, 85.54it/s]\n",
      "epoch: 350, loss: 1.2981: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 351, loss: 1.1589: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 352, loss: 1.2627: 100%|██████████| 100/100 [00:01<00:00, 85.25it/s]\n",
      "epoch: 353, loss: 1.1817: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 354, loss: 1.2999: 100%|██████████| 100/100 [00:01<00:00, 85.41it/s]\n",
      "epoch: 355, loss: 1.2765: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 356, loss: 1.1447: 100%|██████████| 100/100 [00:01<00:00, 85.63it/s]\n",
      "epoch: 357, loss: 1.0913: 100%|██████████| 100/100 [00:01<00:00, 85.54it/s]\n",
      "epoch: 358, loss: 1.2107: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 359, loss: 1.3383: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 360, loss: 1.1881: 100%|██████████| 100/100 [00:01<00:00, 84.88it/s]\n",
      "epoch: 361, loss: 1.1308: 100%|██████████| 100/100 [00:01<00:00, 85.52it/s]\n",
      "epoch: 362, loss: 1.3552: 100%|██████████| 100/100 [00:01<00:00, 85.82it/s]\n",
      "epoch: 363, loss: 1.2831: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 364, loss: 1.1474: 100%|██████████| 100/100 [00:01<00:00, 83.23it/s]\n",
      "epoch: 365, loss: 1.2520: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 366, loss: 1.0773: 100%|██████████| 100/100 [00:01<00:00, 85.44it/s]\n",
      "epoch: 367, loss: 1.2286: 100%|██████████| 100/100 [00:01<00:00, 85.58it/s]\n",
      "epoch: 368, loss: 1.2763: 100%|██████████| 100/100 [00:01<00:00, 84.05it/s]\n",
      "epoch: 369, loss: 1.2479: 100%|██████████| 100/100 [00:01<00:00, 83.93it/s]\n",
      "epoch: 370, loss: 1.3017: 100%|██████████| 100/100 [00:01<00:00, 83.76it/s]\n",
      "epoch: 371, loss: 1.2584: 100%|██████████| 100/100 [00:01<00:00, 85.46it/s]\n",
      "epoch: 372, loss: 1.3088: 100%|██████████| 100/100 [00:01<00:00, 85.30it/s]\n",
      "epoch: 373, loss: 1.1347: 100%|██████████| 100/100 [00:01<00:00, 85.57it/s]\n",
      "epoch: 374, loss: 1.2232: 100%|██████████| 100/100 [00:01<00:00, 85.64it/s]\n",
      "epoch: 375, loss: 1.1450: 100%|██████████| 100/100 [00:01<00:00, 85.40it/s]\n",
      "epoch: 376, loss: 1.2264: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 377, loss: 1.2232: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 378, loss: 1.3171: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 379, loss: 1.2709: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 380, loss: 1.1454: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 381, loss: 1.2057: 100%|██████████| 100/100 [00:01<00:00, 85.61it/s]\n",
      "epoch: 382, loss: 1.0737: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 383, loss: 1.1042: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 384, loss: 1.2427: 100%|██████████| 100/100 [00:01<00:00, 86.28it/s]\n",
      "epoch: 385, loss: 1.1158: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 386, loss: 1.2283: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 387, loss: 1.1925: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 388, loss: 1.3733: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 389, loss: 1.0522: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 390, loss: 1.3950: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 391, loss: 1.1010: 100%|██████████| 100/100 [00:01<00:00, 86.36it/s]\n",
      "epoch: 392, loss: 1.2634: 100%|██████████| 100/100 [00:01<00:00, 86.64it/s]\n",
      "epoch: 393, loss: 1.2613: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 394, loss: 1.2461: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 395, loss: 1.2955: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 396, loss: 1.3133: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 397, loss: 1.2028: 100%|██████████| 100/100 [00:01<00:00, 86.49it/s]\n",
      "epoch: 398, loss: 1.0887: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 399, loss: 1.1627: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 400, loss: 1.1515: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 401, loss: 1.2715: 100%|██████████| 100/100 [00:01<00:00, 86.43it/s]\n",
      "epoch: 402, loss: 1.1704: 100%|██████████| 100/100 [00:01<00:00, 86.41it/s]\n",
      "epoch: 403, loss: 1.1675: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 404, loss: 1.2352: 100%|██████████| 100/100 [00:01<00:00, 85.59it/s]\n",
      "epoch: 405, loss: 1.3688: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 406, loss: 1.2196: 100%|██████████| 100/100 [00:01<00:00, 83.22it/s]\n",
      "epoch: 407, loss: 1.1900: 100%|██████████| 100/100 [00:01<00:00, 82.61it/s]\n",
      "epoch: 408, loss: 1.2827: 100%|██████████| 100/100 [00:01<00:00, 82.99it/s]\n",
      "epoch: 409, loss: 1.2131: 100%|██████████| 100/100 [00:01<00:00, 82.68it/s]\n",
      "epoch: 410, loss: 1.2164: 100%|██████████| 100/100 [00:01<00:00, 84.73it/s]\n",
      "epoch: 411, loss: 1.2291: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 412, loss: 1.3311: 100%|██████████| 100/100 [00:01<00:00, 86.70it/s]\n",
      "epoch: 413, loss: 1.1636: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 414, loss: 1.2304: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 415, loss: 1.2312: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 416, loss: 1.2650: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 417, loss: 1.1845: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 418, loss: 1.2230: 100%|██████████| 100/100 [00:01<00:00, 85.94it/s]\n",
      "epoch: 419, loss: 1.2653: 100%|██████████| 100/100 [00:01<00:00, 85.30it/s]\n",
      "epoch: 420, loss: 1.2760: 100%|██████████| 100/100 [00:01<00:00, 84.43it/s]\n",
      "epoch: 421, loss: 1.1186: 100%|██████████| 100/100 [00:01<00:00, 84.59it/s]\n",
      "epoch: 422, loss: 1.1553: 100%|██████████| 100/100 [00:01<00:00, 85.09it/s]\n",
      "epoch: 423, loss: 1.2624: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 424, loss: 1.1769: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 425, loss: 1.2621: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 426, loss: 1.2821: 100%|██████████| 100/100 [00:01<00:00, 86.37it/s]\n",
      "epoch: 427, loss: 1.1757: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 428, loss: 1.1635: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 429, loss: 1.2476: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 430, loss: 1.2970: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 431, loss: 1.2374: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 432, loss: 1.1758: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 433, loss: 1.1673: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 434, loss: 1.2164: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 435, loss: 1.1663: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 436, loss: 1.2450: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 437, loss: 1.2201: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 438, loss: 1.1960: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 439, loss: 1.2089: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 440, loss: 1.2064: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 441, loss: 1.0838: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 442, loss: 1.3381: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 443, loss: 1.2300: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 444, loss: 1.2719: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 445, loss: 1.2056: 100%|██████████| 100/100 [00:01<00:00, 86.36it/s]\n",
      "epoch: 446, loss: 1.1421: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 447, loss: 1.1134: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 448, loss: 1.3032: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 449, loss: 1.1646: 100%|██████████| 100/100 [00:01<00:00, 83.83it/s]\n",
      "epoch: 450, loss: 1.1667: 100%|██████████| 100/100 [00:01<00:00, 83.09it/s]\n",
      "epoch: 451, loss: 1.2458: 100%|██████████| 100/100 [00:01<00:00, 82.53it/s]\n",
      "epoch: 452, loss: 1.0883: 100%|██████████| 100/100 [00:01<00:00, 83.12it/s]\n",
      "epoch: 453, loss: 1.0287: 100%|██████████| 100/100 [00:01<00:00, 84.18it/s]\n",
      "epoch: 454, loss: 1.2754: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 455, loss: 1.2210: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 456, loss: 1.1555: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 457, loss: 1.1913: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 458, loss: 1.1635: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 459, loss: 1.2474: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 460, loss: 1.2626: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 461, loss: 1.1811: 100%|██████████| 100/100 [00:01<00:00, 85.43it/s]\n",
      "epoch: 462, loss: 1.2029: 100%|██████████| 100/100 [00:01<00:00, 86.77it/s]\n",
      "epoch: 463, loss: 1.2950: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 464, loss: 1.3269: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 465, loss: 1.1928: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 466, loss: 1.2942: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 467, loss: 1.1038: 100%|██████████| 100/100 [00:01<00:00, 82.83it/s]\n",
      "epoch: 468, loss: 1.2802: 100%|██████████| 100/100 [00:01<00:00, 82.55it/s]\n",
      "epoch: 469, loss: 1.1470: 100%|██████████| 100/100 [00:01<00:00, 82.92it/s]\n",
      "epoch: 470, loss: 1.2836: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 471, loss: 1.1968: 100%|██████████| 100/100 [00:01<00:00, 96.29it/s]\n",
      "epoch: 472, loss: 1.2370: 100%|██████████| 100/100 [00:01<00:00, 97.07it/s]\n",
      "epoch: 473, loss: 1.1675: 100%|██████████| 100/100 [00:01<00:00, 97.03it/s]\n",
      "epoch: 474, loss: 1.3033: 100%|██████████| 100/100 [00:01<00:00, 97.02it/s]\n",
      "epoch: 475, loss: 1.1948: 100%|██████████| 100/100 [00:01<00:00, 83.57it/s]\n",
      "epoch: 476, loss: 1.1126: 100%|██████████| 100/100 [00:01<00:00, 83.28it/s]\n",
      "epoch: 477, loss: 1.1365: 100%|██████████| 100/100 [00:01<00:00, 82.65it/s]\n",
      "epoch: 478, loss: 1.2967: 100%|██████████| 100/100 [00:01<00:00, 83.43it/s]\n",
      "epoch: 479, loss: 1.2075: 100%|██████████| 100/100 [00:01<00:00, 82.71it/s]\n",
      "epoch: 480, loss: 1.0725: 100%|██████████| 100/100 [00:01<00:00, 82.91it/s]\n",
      "epoch: 481, loss: 1.2026: 100%|██████████| 100/100 [00:01<00:00, 83.04it/s]\n",
      "epoch: 482, loss: 1.1964: 100%|██████████| 100/100 [00:01<00:00, 83.12it/s]\n",
      "epoch: 483, loss: 1.1884: 100%|██████████| 100/100 [00:01<00:00, 82.87it/s]\n",
      "epoch: 484, loss: 1.0459: 100%|██████████| 100/100 [00:01<00:00, 83.21it/s]\n",
      "epoch: 485, loss: 1.1785: 100%|██████████| 100/100 [00:01<00:00, 82.67it/s]\n",
      "epoch: 486, loss: 1.1764: 100%|██████████| 100/100 [00:01<00:00, 83.01it/s]\n",
      "epoch: 487, loss: 1.2210: 100%|██████████| 100/100 [00:01<00:00, 83.06it/s]\n",
      "epoch: 488, loss: 1.3410: 100%|██████████| 100/100 [00:01<00:00, 82.88it/s]\n",
      "epoch: 489, loss: 1.1188: 100%|██████████| 100/100 [00:01<00:00, 82.85it/s]\n",
      "epoch: 490, loss: 1.3050: 100%|██████████| 100/100 [00:01<00:00, 83.15it/s]\n",
      "epoch: 491, loss: 1.2649: 100%|██████████| 100/100 [00:01<00:00, 83.17it/s]\n",
      "epoch: 492, loss: 1.2668: 100%|██████████| 100/100 [00:01<00:00, 82.93it/s]\n",
      "epoch: 493, loss: 1.1135: 100%|██████████| 100/100 [00:01<00:00, 83.13it/s]\n",
      "epoch: 494, loss: 1.1882: 100%|██████████| 100/100 [00:01<00:00, 82.91it/s]\n",
      "epoch: 495, loss: 1.2590: 100%|██████████| 100/100 [00:01<00:00, 82.75it/s]\n",
      "epoch: 496, loss: 1.1455: 100%|██████████| 100/100 [00:01<00:00, 82.58it/s]\n",
      "epoch: 497, loss: 1.1448: 100%|██████████| 100/100 [00:01<00:00, 82.81it/s]\n",
      "epoch: 498, loss: 1.2473: 100%|██████████| 100/100 [00:01<00:00, 82.87it/s]\n",
      "epoch: 499, loss: 1.1253: 100%|██████████| 100/100 [00:01<00:00, 83.06it/s]\n",
      "epoch: 500, loss: 1.3448: 100%|██████████| 100/100 [00:01<00:00, 82.18it/s]\n",
      "epoch: 501, loss: 1.2163: 100%|██████████| 100/100 [00:01<00:00, 83.44it/s]\n",
      "epoch: 502, loss: 1.3106: 100%|██████████| 100/100 [00:01<00:00, 82.60it/s]\n",
      "epoch: 503, loss: 1.1419: 100%|██████████| 100/100 [00:01<00:00, 82.76it/s]\n",
      "epoch: 504, loss: 1.0773: 100%|██████████| 100/100 [00:01<00:00, 83.09it/s]\n",
      "epoch: 505, loss: 1.2598: 100%|██████████| 100/100 [00:01<00:00, 83.17it/s]\n",
      "epoch: 506, loss: 1.1416: 100%|██████████| 100/100 [00:01<00:00, 82.92it/s]\n",
      "epoch: 507, loss: 1.1458: 100%|██████████| 100/100 [00:01<00:00, 83.54it/s]\n",
      "epoch: 508, loss: 1.3488: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 509, loss: 1.3165: 100%|██████████| 100/100 [00:01<00:00, 82.71it/s]\n",
      "epoch: 510, loss: 1.2349: 100%|██████████| 100/100 [00:01<00:00, 83.01it/s]\n",
      "epoch: 511, loss: 1.2775: 100%|██████████| 100/100 [00:01<00:00, 83.19it/s]\n",
      "epoch: 512, loss: 1.2414: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 513, loss: 1.1991: 100%|██████████| 100/100 [00:01<00:00, 86.68it/s]\n",
      "epoch: 514, loss: 1.1710: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 515, loss: 1.2901: 100%|██████████| 100/100 [00:01<00:00, 86.62it/s]\n",
      "epoch: 516, loss: 1.1919: 100%|██████████| 100/100 [00:01<00:00, 86.70it/s]\n",
      "epoch: 517, loss: 1.0617: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 518, loss: 1.2419: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 519, loss: 1.2743: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 520, loss: 1.1493: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 521, loss: 1.2270: 100%|██████████| 100/100 [00:01<00:00, 84.46it/s]\n",
      "epoch: 522, loss: 1.2206: 100%|██████████| 100/100 [00:01<00:00, 84.28it/s]\n",
      "epoch: 523, loss: 1.1702: 100%|██████████| 100/100 [00:01<00:00, 84.47it/s]\n",
      "epoch: 524, loss: 1.1355: 100%|██████████| 100/100 [00:01<00:00, 84.44it/s]\n",
      "epoch: 525, loss: 1.2860: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 526, loss: 1.3017: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 527, loss: 1.1885: 100%|██████████| 100/100 [00:01<00:00, 86.56it/s]\n",
      "epoch: 528, loss: 1.3765: 100%|██████████| 100/100 [00:01<00:00, 85.68it/s]\n",
      "epoch: 529, loss: 1.2340: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 530, loss: 1.1715: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 531, loss: 1.2674: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 532, loss: 1.2545: 100%|██████████| 100/100 [00:01<00:00, 86.64it/s]\n",
      "epoch: 533, loss: 1.1444: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 534, loss: 1.3317: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 535, loss: 1.3009: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 536, loss: 1.0676: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 537, loss: 1.1964: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 538, loss: 1.0902: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 539, loss: 1.2020: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 540, loss: 1.3077: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 541, loss: 1.1973: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 542, loss: 1.3951: 100%|██████████| 100/100 [00:01<00:00, 86.36it/s]\n",
      "epoch: 543, loss: 1.2313: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 544, loss: 1.3100: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 545, loss: 1.0884: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 546, loss: 1.2205: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 547, loss: 1.3503: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 548, loss: 1.0619: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 549, loss: 1.3914: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 550, loss: 1.1484: 100%|██████████| 100/100 [00:01<00:00, 85.33it/s]\n",
      "epoch: 551, loss: 1.1949: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 552, loss: 1.1805: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 553, loss: 1.1026: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 554, loss: 1.1922: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 555, loss: 1.1946: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 556, loss: 1.1652: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 557, loss: 1.2165: 100%|██████████| 100/100 [00:01<00:00, 86.40it/s]\n",
      "epoch: 558, loss: 1.2234: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 559, loss: 1.2934: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 560, loss: 1.2809: 100%|██████████| 100/100 [00:01<00:00, 86.56it/s]\n",
      "epoch: 561, loss: 1.2966: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 562, loss: 1.2576: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 563, loss: 1.0953: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 564, loss: 1.1365: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 565, loss: 1.1024: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 566, loss: 1.1468: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 567, loss: 1.0971: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 568, loss: 1.2111: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 569, loss: 1.2352: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 570, loss: 1.2074: 100%|██████████| 100/100 [00:01<00:00, 86.71it/s]\n",
      "epoch: 571, loss: 1.1959: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 572, loss: 1.2735: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 573, loss: 1.2582: 100%|██████████| 100/100 [00:01<00:00, 83.16it/s]\n",
      "epoch: 574, loss: 1.2342: 100%|██████████| 100/100 [00:01<00:00, 83.75it/s]\n",
      "epoch: 575, loss: 1.1569: 100%|██████████| 100/100 [00:01<00:00, 84.05it/s]\n",
      "epoch: 576, loss: 1.2430: 100%|██████████| 100/100 [00:01<00:00, 83.95it/s]\n",
      "epoch: 577, loss: 1.1630: 100%|██████████| 100/100 [00:01<00:00, 85.02it/s]\n",
      "epoch: 578, loss: 1.2928: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 579, loss: 1.1477: 100%|██████████| 100/100 [00:01<00:00, 86.39it/s]\n",
      "epoch: 580, loss: 1.2116: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 581, loss: 1.0620: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 582, loss: 1.2950: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 583, loss: 1.3371: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 584, loss: 1.3066: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 585, loss: 1.1154: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 586, loss: 1.1887: 100%|██████████| 100/100 [00:01<00:00, 86.37it/s]\n",
      "epoch: 587, loss: 1.1563: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 588, loss: 1.2688: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 589, loss: 1.3122: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 590, loss: 1.0871: 100%|██████████| 100/100 [00:01<00:00, 85.67it/s]\n",
      "epoch: 591, loss: 1.2563: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 592, loss: 1.2827: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 593, loss: 1.1071: 100%|██████████| 100/100 [00:01<00:00, 86.69it/s]\n",
      "epoch: 594, loss: 1.2677: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 595, loss: 1.2883: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 596, loss: 1.1629: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 597, loss: 1.3396: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 598, loss: 1.1868: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 599, loss: 1.2132: 100%|██████████| 100/100 [00:01<00:00, 86.03it/s]\n",
      "epoch: 600, loss: 1.1842: 100%|██████████| 100/100 [00:01<00:00, 86.55it/s]\n",
      "epoch: 601, loss: 1.2651: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 602, loss: 1.2840: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 603, loss: 1.2950: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 604, loss: 1.0805: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 605, loss: 1.3400: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 606, loss: 1.3097: 100%|██████████| 100/100 [00:01<00:00, 84.95it/s]\n",
      "epoch: 607, loss: 1.4274: 100%|██████████| 100/100 [00:01<00:00, 82.89it/s]\n",
      "epoch: 608, loss: 1.2028: 100%|██████████| 100/100 [00:01<00:00, 82.73it/s]\n",
      "epoch: 609, loss: 1.0730: 100%|██████████| 100/100 [00:01<00:00, 84.62it/s]\n",
      "epoch: 610, loss: 1.2936: 100%|██████████| 100/100 [00:01<00:00, 86.49it/s]\n",
      "epoch: 611, loss: 1.1053: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 612, loss: 1.2756: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 613, loss: 1.2657: 100%|██████████| 100/100 [00:00<00:00, 125.61it/s]\n",
      "epoch: 614, loss: 1.1594: 100%|██████████| 100/100 [00:00<00:00, 131.06it/s]\n",
      "epoch: 615, loss: 1.2087: 100%|██████████| 100/100 [00:00<00:00, 130.23it/s]\n",
      "epoch: 616, loss: 1.2232: 100%|██████████| 100/100 [00:01<00:00, 95.84it/s]\n",
      "epoch: 617, loss: 1.1763: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 618, loss: 1.4025: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 619, loss: 1.1042: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 620, loss: 1.2648: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 621, loss: 1.2117: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 622, loss: 1.1939: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 623, loss: 1.1966: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 624, loss: 1.2881: 100%|██████████| 100/100 [00:01<00:00, 86.81it/s]\n",
      "epoch: 625, loss: 1.0496: 100%|██████████| 100/100 [00:01<00:00, 84.88it/s]\n",
      "epoch: 626, loss: 1.3873: 100%|██████████| 100/100 [00:01<00:00, 83.48it/s]\n",
      "epoch: 627, loss: 1.1227: 100%|██████████| 100/100 [00:01<00:00, 84.49it/s]\n",
      "epoch: 628, loss: 1.2631: 100%|██████████| 100/100 [00:01<00:00, 83.12it/s]\n",
      "epoch: 629, loss: 1.3039: 100%|██████████| 100/100 [00:01<00:00, 83.81it/s]\n",
      "epoch: 630, loss: 1.0867: 100%|██████████| 100/100 [00:01<00:00, 85.27it/s]\n",
      "epoch: 631, loss: 1.2292: 100%|██████████| 100/100 [00:01<00:00, 85.94it/s]\n",
      "epoch: 632, loss: 1.1938: 100%|██████████| 100/100 [00:01<00:00, 86.28it/s]\n",
      "epoch: 633, loss: 1.0915: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 634, loss: 1.1787: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 635, loss: 1.1455: 100%|██████████| 100/100 [00:01<00:00, 85.68it/s]\n",
      "epoch: 636, loss: 1.1482: 100%|██████████| 100/100 [00:01<00:00, 85.83it/s]\n",
      "epoch: 637, loss: 1.0302: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 638, loss: 1.3195: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 639, loss: 1.0773: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 640, loss: 1.2114: 100%|██████████| 100/100 [00:01<00:00, 86.67it/s]\n",
      "epoch: 641, loss: 1.1900: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 642, loss: 1.1277: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 643, loss: 1.1648: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 644, loss: 1.1628: 100%|██████████| 100/100 [00:01<00:00, 86.37it/s]\n",
      "epoch: 645, loss: 1.1351: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 646, loss: 1.2270: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 647, loss: 1.2920: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 648, loss: 1.2514: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 649, loss: 1.0455: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 650, loss: 1.2463: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 651, loss: 1.1604: 100%|██████████| 100/100 [00:01<00:00, 85.88it/s]\n",
      "epoch: 652, loss: 1.3411: 100%|██████████| 100/100 [00:01<00:00, 86.43it/s]\n",
      "epoch: 653, loss: 1.1454: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 654, loss: 1.1830: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 655, loss: 1.1921: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 656, loss: 1.2105: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 657, loss: 1.1376: 100%|██████████| 100/100 [00:01<00:00, 85.70it/s]\n",
      "epoch: 658, loss: 1.2628: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 659, loss: 1.2213: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 660, loss: 1.1899: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 661, loss: 1.2296: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 662, loss: 1.2664: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 663, loss: 1.3331: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 664, loss: 1.2190: 100%|██████████| 100/100 [00:01<00:00, 85.73it/s]\n",
      "epoch: 665, loss: 1.3210: 100%|██████████| 100/100 [00:01<00:00, 86.37it/s]\n",
      "epoch: 666, loss: 1.1054: 100%|██████████| 100/100 [00:01<00:00, 86.36it/s]\n",
      "epoch: 667, loss: 1.2272: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 668, loss: 1.2567: 100%|██████████| 100/100 [00:01<00:00, 86.80it/s]\n",
      "epoch: 669, loss: 1.0697: 100%|██████████| 100/100 [00:01<00:00, 85.68it/s]\n",
      "epoch: 670, loss: 1.4286: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 671, loss: 1.2870: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 672, loss: 1.1380: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 673, loss: 1.3049: 100%|██████████| 100/100 [00:01<00:00, 86.32it/s]\n",
      "epoch: 674, loss: 1.0569: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 675, loss: 1.2662: 100%|██████████| 100/100 [00:01<00:00, 86.61it/s]\n",
      "epoch: 676, loss: 1.1947: 100%|██████████| 100/100 [00:01<00:00, 84.78it/s]\n",
      "epoch: 677, loss: 1.2408: 100%|██████████| 100/100 [00:01<00:00, 83.68it/s]\n",
      "epoch: 678, loss: 1.2481: 100%|██████████| 100/100 [00:01<00:00, 83.93it/s]\n",
      "epoch: 679, loss: 1.1568: 100%|██████████| 100/100 [00:01<00:00, 82.81it/s]\n",
      "epoch: 680, loss: 1.2430: 100%|██████████| 100/100 [00:01<00:00, 83.31it/s]\n",
      "epoch: 681, loss: 1.2274: 100%|██████████| 100/100 [00:01<00:00, 82.98it/s]\n",
      "epoch: 682, loss: 1.1694: 100%|██████████| 100/100 [00:01<00:00, 84.79it/s]\n",
      "epoch: 683, loss: 1.2300: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 684, loss: 1.2685: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 685, loss: 1.2385: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 686, loss: 1.1640: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 687, loss: 1.1334: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 688, loss: 1.2858: 100%|██████████| 100/100 [00:01<00:00, 85.92it/s]\n",
      "epoch: 689, loss: 1.1219: 100%|██████████| 100/100 [00:01<00:00, 86.39it/s]\n",
      "epoch: 690, loss: 1.0865: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 691, loss: 1.1794: 100%|██████████| 100/100 [00:01<00:00, 86.60it/s]\n",
      "epoch: 692, loss: 1.2384: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 693, loss: 1.0878: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 694, loss: 1.2285: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 695, loss: 1.2474: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 696, loss: 1.1854: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 697, loss: 1.3155: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 698, loss: 1.2103: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 699, loss: 1.2538: 100%|██████████| 100/100 [00:01<00:00, 86.41it/s]\n",
      "epoch: 700, loss: 1.1102: 100%|██████████| 100/100 [00:01<00:00, 85.97it/s]\n",
      "epoch: 701, loss: 1.3217: 100%|██████████| 100/100 [00:01<00:00, 86.01it/s]\n",
      "epoch: 702, loss: 1.1885: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 703, loss: 1.2591: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 704, loss: 1.0939: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 705, loss: 1.2381: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 706, loss: 1.2861: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 707, loss: 1.2941: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 708, loss: 1.1988: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 709, loss: 1.2126: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 710, loss: 1.1780: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 711, loss: 1.1239: 100%|██████████| 100/100 [00:01<00:00, 86.56it/s]\n",
      "epoch: 712, loss: 1.1921: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 713, loss: 1.1665: 100%|██████████| 100/100 [00:01<00:00, 86.56it/s]\n",
      "epoch: 714, loss: 1.2625: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 715, loss: 1.2951: 100%|██████████| 100/100 [00:01<00:00, 85.71it/s]\n",
      "epoch: 716, loss: 1.1336: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 717, loss: 1.1501: 100%|██████████| 100/100 [00:01<00:00, 85.87it/s]\n",
      "epoch: 718, loss: 1.1661: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 719, loss: 1.1637: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 720, loss: 1.2164: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 721, loss: 1.1668: 100%|██████████| 100/100 [00:01<00:00, 85.51it/s]\n",
      "epoch: 722, loss: 1.1662: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 723, loss: 1.2090: 100%|██████████| 100/100 [00:01<00:00, 86.53it/s]\n",
      "epoch: 724, loss: 1.1202: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 725, loss: 1.3146: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 726, loss: 1.2538: 100%|██████████| 100/100 [00:01<00:00, 85.82it/s]\n",
      "epoch: 727, loss: 1.2474: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 728, loss: 1.2643: 100%|██████████| 100/100 [00:01<00:00, 83.12it/s]\n",
      "epoch: 729, loss: 1.0774: 100%|██████████| 100/100 [00:01<00:00, 83.30it/s]\n",
      "epoch: 730, loss: 1.1350: 100%|██████████| 100/100 [00:01<00:00, 82.67it/s]\n",
      "epoch: 731, loss: 1.3168: 100%|██████████| 100/100 [00:01<00:00, 82.93it/s]\n",
      "epoch: 732, loss: 1.1920: 100%|██████████| 100/100 [00:01<00:00, 82.77it/s]\n",
      "epoch: 733, loss: 1.2725: 100%|██████████| 100/100 [00:01<00:00, 83.32it/s]\n",
      "epoch: 734, loss: 1.1724: 100%|██████████| 100/100 [00:01<00:00, 84.71it/s]\n",
      "epoch: 735, loss: 1.3139: 100%|██████████| 100/100 [00:01<00:00, 85.50it/s]\n",
      "epoch: 736, loss: 1.2148: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 737, loss: 1.1865: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 738, loss: 1.1911: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 739, loss: 1.1620: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 740, loss: 1.2050: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 741, loss: 1.2431: 100%|██████████| 100/100 [00:01<00:00, 86.28it/s]\n",
      "epoch: 742, loss: 1.1725: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 743, loss: 1.2067: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 744, loss: 1.2740: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 745, loss: 1.2195: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 746, loss: 1.1222: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 747, loss: 1.2819: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 748, loss: 1.1836: 100%|██████████| 100/100 [00:01<00:00, 86.60it/s]\n",
      "epoch: 749, loss: 1.2643: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 750, loss: 1.1841: 100%|██████████| 100/100 [00:01<00:00, 86.59it/s]\n",
      "epoch: 751, loss: 1.2900: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 752, loss: 1.2350: 100%|██████████| 100/100 [00:01<00:00, 86.58it/s]\n",
      "epoch: 753, loss: 1.2570: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 754, loss: 1.3519: 100%|██████████| 100/100 [00:01<00:00, 85.82it/s]\n",
      "epoch: 755, loss: 1.2158: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 756, loss: 1.2527: 100%|██████████| 100/100 [00:01<00:00, 85.72it/s]\n",
      "epoch: 757, loss: 1.1822: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 758, loss: 1.2261: 100%|██████████| 100/100 [00:01<00:00, 86.28it/s]\n",
      "epoch: 759, loss: 1.4101: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 760, loss: 1.1422: 100%|██████████| 100/100 [00:01<00:00, 86.62it/s]\n",
      "epoch: 761, loss: 1.1470: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 762, loss: 1.3577: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 763, loss: 1.0742: 100%|██████████| 100/100 [00:01<00:00, 85.69it/s]\n",
      "epoch: 764, loss: 1.1352: 100%|██████████| 100/100 [00:01<00:00, 84.83it/s]\n",
      "epoch: 765, loss: 1.3206: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 766, loss: 1.0684: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 767, loss: 1.0781: 100%|██████████| 100/100 [00:01<00:00, 85.63it/s]\n",
      "epoch: 768, loss: 1.1757: 100%|██████████| 100/100 [00:01<00:00, 85.98it/s]\n",
      "epoch: 769, loss: 1.2838: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 770, loss: 1.0243: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 771, loss: 1.2668: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 772, loss: 1.3725: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 773, loss: 1.1015: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 774, loss: 1.1967: 100%|██████████| 100/100 [00:01<00:00, 86.42it/s]\n",
      "epoch: 775, loss: 1.2474: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 776, loss: 1.1799: 100%|██████████| 100/100 [00:01<00:00, 86.54it/s]\n",
      "epoch: 777, loss: 1.1673: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 778, loss: 1.2921: 100%|██████████| 100/100 [00:01<00:00, 85.94it/s]\n",
      "epoch: 779, loss: 1.2990: 100%|██████████| 100/100 [00:01<00:00, 83.97it/s]\n",
      "epoch: 780, loss: 1.3709: 100%|██████████| 100/100 [00:01<00:00, 82.84it/s]\n",
      "epoch: 781, loss: 1.1884: 100%|██████████| 100/100 [00:01<00:00, 83.24it/s]\n",
      "epoch: 782, loss: 1.1454: 100%|██████████| 100/100 [00:01<00:00, 83.21it/s]\n",
      "epoch: 783, loss: 1.1511: 100%|██████████| 100/100 [00:01<00:00, 82.68it/s]\n",
      "epoch: 784, loss: 1.1806: 100%|██████████| 100/100 [00:01<00:00, 83.36it/s]\n",
      "epoch: 785, loss: 1.2134: 100%|██████████| 100/100 [00:01<00:00, 82.78it/s]\n",
      "epoch: 786, loss: 1.2791: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 787, loss: 1.3033: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 788, loss: 1.2236: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 789, loss: 1.2679: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 790, loss: 1.2437: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 791, loss: 1.1601: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 792, loss: 1.1648: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 793, loss: 1.2183: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 794, loss: 1.1451: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 795, loss: 1.3127: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 796, loss: 1.2823: 100%|██████████| 100/100 [00:01<00:00, 86.12it/s]\n",
      "epoch: 797, loss: 1.2375: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 798, loss: 1.3319: 100%|██████████| 100/100 [00:01<00:00, 86.24it/s]\n",
      "epoch: 799, loss: 1.0798: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 800, loss: 1.2073: 100%|██████████| 100/100 [00:01<00:00, 86.60it/s]\n",
      "epoch: 801, loss: 1.1046: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 802, loss: 1.2078: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 803, loss: 1.1874: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 804, loss: 1.1607: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 805, loss: 1.0755: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 806, loss: 1.1477: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 807, loss: 1.2332: 100%|██████████| 100/100 [00:01<00:00, 86.56it/s]\n",
      "epoch: 808, loss: 1.2435: 100%|██████████| 100/100 [00:01<00:00, 85.83it/s]\n",
      "epoch: 809, loss: 1.1441: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 810, loss: 1.1653: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 811, loss: 1.1081: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 812, loss: 1.3016: 100%|██████████| 100/100 [00:01<00:00, 86.26it/s]\n",
      "epoch: 813, loss: 1.3347: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 814, loss: 1.4096: 100%|██████████| 100/100 [00:01<00:00, 86.73it/s]\n",
      "epoch: 815, loss: 1.1917: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 816, loss: 1.2108: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 817, loss: 1.1747: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 818, loss: 1.3398: 100%|██████████| 100/100 [00:01<00:00, 85.97it/s]\n",
      "epoch: 819, loss: 1.1960: 100%|██████████| 100/100 [00:01<00:00, 86.50it/s]\n",
      "epoch: 820, loss: 1.2851: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 821, loss: 1.2887: 100%|██████████| 100/100 [00:01<00:00, 85.67it/s]\n",
      "epoch: 822, loss: 1.1950: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 823, loss: 1.1497: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 824, loss: 1.2037: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 825, loss: 1.1730: 100%|██████████| 100/100 [00:01<00:00, 85.68it/s]\n",
      "epoch: 826, loss: 1.2664: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 827, loss: 1.1496: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 828, loss: 1.3423: 100%|██████████| 100/100 [00:01<00:00, 86.46it/s]\n",
      "epoch: 829, loss: 1.2157: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 830, loss: 1.2476: 100%|██████████| 100/100 [00:01<00:00, 84.89it/s]\n",
      "epoch: 831, loss: 1.1158: 100%|██████████| 100/100 [00:01<00:00, 82.77it/s]\n",
      "epoch: 832, loss: 1.1819: 100%|██████████| 100/100 [00:01<00:00, 83.02it/s]\n",
      "epoch: 833, loss: 1.1861: 100%|██████████| 100/100 [00:01<00:00, 83.19it/s]\n",
      "epoch: 834, loss: 1.1432: 100%|██████████| 100/100 [00:01<00:00, 82.71it/s]\n",
      "epoch: 835, loss: 1.2732: 100%|██████████| 100/100 [00:01<00:00, 83.13it/s]\n",
      "epoch: 836, loss: 1.0732: 100%|██████████| 100/100 [00:01<00:00, 83.18it/s]\n",
      "epoch: 837, loss: 1.1715: 100%|██████████| 100/100 [00:01<00:00, 83.98it/s]\n",
      "epoch: 838, loss: 1.1221: 100%|██████████| 100/100 [00:01<00:00, 86.28it/s]\n",
      "epoch: 839, loss: 1.1071: 100%|██████████| 100/100 [00:01<00:00, 85.40it/s]\n",
      "epoch: 840, loss: 1.0912: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 841, loss: 1.2008: 100%|██████████| 100/100 [00:01<00:00, 85.44it/s]\n",
      "epoch: 842, loss: 1.1909: 100%|██████████| 100/100 [00:01<00:00, 85.78it/s]\n",
      "epoch: 843, loss: 1.1783: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 844, loss: 1.2917: 100%|██████████| 100/100 [00:01<00:00, 85.84it/s]\n",
      "epoch: 845, loss: 1.2421: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 846, loss: 1.0518: 100%|██████████| 100/100 [00:01<00:00, 85.85it/s]\n",
      "epoch: 847, loss: 1.2970: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 848, loss: 1.3104: 100%|██████████| 100/100 [00:01<00:00, 86.69it/s]\n",
      "epoch: 849, loss: 1.1403: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 850, loss: 1.2396: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 851, loss: 1.1963: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 852, loss: 1.2794: 100%|██████████| 100/100 [00:01<00:00, 86.47it/s]\n",
      "epoch: 853, loss: 1.4221: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 854, loss: 1.3905: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 855, loss: 1.0846: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 856, loss: 1.1406: 100%|██████████| 100/100 [00:01<00:00, 86.31it/s]\n",
      "epoch: 857, loss: 1.1963: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 858, loss: 1.1040: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 859, loss: 1.1071: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 860, loss: 1.1818: 100%|██████████| 100/100 [00:01<00:00, 86.29it/s]\n",
      "epoch: 861, loss: 1.2302: 100%|██████████| 100/100 [00:01<00:00, 85.89it/s]\n",
      "epoch: 862, loss: 1.2443: 100%|██████████| 100/100 [00:01<00:00, 86.35it/s]\n",
      "epoch: 863, loss: 1.0780: 100%|██████████| 100/100 [00:01<00:00, 85.93it/s]\n",
      "epoch: 864, loss: 1.2179: 100%|██████████| 100/100 [00:01<00:00, 85.86it/s]\n",
      "epoch: 865, loss: 1.1982: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 866, loss: 1.2039: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 867, loss: 1.3450: 100%|██████████| 100/100 [00:01<00:00, 85.91it/s]\n",
      "epoch: 868, loss: 1.1617: 100%|██████████| 100/100 [00:01<00:00, 85.57it/s]\n",
      "epoch: 869, loss: 1.1766: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 870, loss: 1.1504: 100%|██████████| 100/100 [00:01<00:00, 86.67it/s]\n",
      "epoch: 871, loss: 1.1343: 100%|██████████| 100/100 [00:01<00:00, 86.40it/s]\n",
      "epoch: 872, loss: 1.2227: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 873, loss: 1.3106: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 874, loss: 1.1324: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 875, loss: 1.1823: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 876, loss: 1.1395: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 877, loss: 1.2591: 100%|██████████| 100/100 [00:01<00:00, 86.41it/s]\n",
      "epoch: 878, loss: 1.1586: 100%|██████████| 100/100 [00:01<00:00, 86.63it/s]\n",
      "epoch: 879, loss: 1.1898: 100%|██████████| 100/100 [00:01<00:00, 86.20it/s]\n",
      "epoch: 880, loss: 1.2458: 100%|██████████| 100/100 [00:01<00:00, 86.44it/s]\n",
      "epoch: 881, loss: 1.1221: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 882, loss: 1.2591: 100%|██████████| 100/100 [00:01<00:00, 82.87it/s]\n",
      "epoch: 883, loss: 1.2807: 100%|██████████| 100/100 [00:01<00:00, 83.07it/s]\n",
      "epoch: 884, loss: 1.1115: 100%|██████████| 100/100 [00:01<00:00, 82.13it/s]\n",
      "epoch: 885, loss: 1.3079: 100%|██████████| 100/100 [00:01<00:00, 83.13it/s]\n",
      "epoch: 886, loss: 1.2346: 100%|██████████| 100/100 [00:01<00:00, 83.47it/s]\n",
      "epoch: 887, loss: 1.2312: 100%|██████████| 100/100 [00:01<00:00, 83.70it/s]\n",
      "epoch: 888, loss: 1.2254: 100%|██████████| 100/100 [00:01<00:00, 82.59it/s]\n",
      "epoch: 889, loss: 1.2703: 100%|██████████| 100/100 [00:01<00:00, 83.90it/s]\n",
      "epoch: 890, loss: 1.1053: 100%|██████████| 100/100 [00:01<00:00, 86.40it/s]\n",
      "epoch: 891, loss: 1.4433: 100%|██████████| 100/100 [00:01<00:00, 85.90it/s]\n",
      "epoch: 892, loss: 1.3226: 100%|██████████| 100/100 [00:01<00:00, 86.22it/s]\n",
      "epoch: 893, loss: 1.2014: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 894, loss: 1.1273: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 895, loss: 1.2290: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 896, loss: 1.1801: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 897, loss: 1.1650: 100%|██████████| 100/100 [00:01<00:00, 86.30it/s]\n",
      "epoch: 898, loss: 1.1833: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 899, loss: 1.3810: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 900, loss: 1.2289: 100%|██████████| 100/100 [00:01<00:00, 86.13it/s]\n",
      "epoch: 901, loss: 1.0618: 100%|██████████| 100/100 [00:01<00:00, 86.05it/s]\n",
      "epoch: 902, loss: 1.2054: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 903, loss: 1.1903: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 904, loss: 1.1905: 100%|██████████| 100/100 [00:01<00:00, 85.55it/s]\n",
      "epoch: 905, loss: 1.3288: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 906, loss: 1.2600: 100%|██████████| 100/100 [00:01<00:00, 86.27it/s]\n",
      "epoch: 907, loss: 1.1025: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 908, loss: 1.2259: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 909, loss: 1.0564: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 910, loss: 1.2935: 100%|██████████| 100/100 [00:01<00:00, 86.15it/s]\n",
      "epoch: 911, loss: 1.2118: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 912, loss: 1.2437: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 913, loss: 1.1220: 100%|██████████| 100/100 [00:01<00:00, 86.23it/s]\n",
      "epoch: 914, loss: 1.0773: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 915, loss: 1.3176: 100%|██████████| 100/100 [00:01<00:00, 86.14it/s]\n",
      "epoch: 916, loss: 1.1390: 100%|██████████| 100/100 [00:01<00:00, 86.65it/s]\n",
      "epoch: 917, loss: 1.2175: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 918, loss: 1.1125: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 919, loss: 1.2203: 100%|██████████| 100/100 [00:01<00:00, 85.66it/s]\n",
      "epoch: 920, loss: 1.4576: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 921, loss: 1.1674: 100%|██████████| 100/100 [00:01<00:00, 86.25it/s]\n",
      "epoch: 922, loss: 1.2433: 100%|██████████| 100/100 [00:01<00:00, 85.45it/s]\n",
      "epoch: 923, loss: 1.0449: 100%|██████████| 100/100 [00:01<00:00, 86.57it/s]\n",
      "epoch: 924, loss: 1.1805: 100%|██████████| 100/100 [00:01<00:00, 86.17it/s]\n",
      "epoch: 925, loss: 1.2373: 100%|██████████| 100/100 [00:01<00:00, 86.33it/s]\n",
      "epoch: 926, loss: 1.1361: 100%|██████████| 100/100 [00:01<00:00, 85.95it/s]\n",
      "epoch: 927, loss: 1.2224: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 928, loss: 1.1300: 100%|██████████| 100/100 [00:01<00:00, 86.02it/s]\n",
      "epoch: 929, loss: 1.1428: 100%|██████████| 100/100 [00:01<00:00, 85.51it/s]\n",
      "epoch: 930, loss: 1.1687: 100%|██████████| 100/100 [00:01<00:00, 86.48it/s]\n",
      "epoch: 931, loss: 1.1752: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 932, loss: 1.1862: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 933, loss: 1.2481: 100%|██████████| 100/100 [00:01<00:00, 83.45it/s]\n",
      "epoch: 934, loss: 1.1874: 100%|██████████| 100/100 [00:01<00:00, 82.61it/s]\n",
      "epoch: 935, loss: 1.1223: 100%|██████████| 100/100 [00:01<00:00, 82.95it/s]\n",
      "epoch: 936, loss: 1.1439: 100%|██████████| 100/100 [00:01<00:00, 82.41it/s]\n",
      "epoch: 937, loss: 1.1520: 100%|██████████| 100/100 [00:01<00:00, 82.79it/s]\n",
      "epoch: 938, loss: 1.0848: 100%|██████████| 100/100 [00:01<00:00, 83.31it/s]\n",
      "epoch: 939, loss: 1.2435: 100%|██████████| 100/100 [00:01<00:00, 82.18it/s]\n",
      "epoch: 940, loss: 1.2336: 100%|██████████| 100/100 [00:01<00:00, 82.87it/s]\n",
      "epoch: 941, loss: 1.2600: 100%|██████████| 100/100 [00:01<00:00, 82.15it/s]\n",
      "epoch: 942, loss: 1.2233: 100%|██████████| 100/100 [00:01<00:00, 84.77it/s]\n",
      "epoch: 943, loss: 1.1575: 100%|██████████| 100/100 [00:01<00:00, 85.74it/s]\n",
      "epoch: 944, loss: 1.1377: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 945, loss: 1.1362: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 946, loss: 1.3114: 100%|██████████| 100/100 [00:01<00:00, 85.60it/s]\n",
      "epoch: 947, loss: 1.2375: 100%|██████████| 100/100 [00:01<00:00, 85.75it/s]\n",
      "epoch: 948, loss: 1.0956: 100%|██████████| 100/100 [00:01<00:00, 85.76it/s]\n",
      "epoch: 949, loss: 1.1377: 100%|██████████| 100/100 [00:01<00:00, 85.62it/s]\n",
      "epoch: 950, loss: 1.1969: 100%|██████████| 100/100 [00:01<00:00, 85.88it/s]\n",
      "epoch: 951, loss: 1.1388: 100%|██████████| 100/100 [00:01<00:00, 86.19it/s]\n",
      "epoch: 952, loss: 1.2312: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 953, loss: 1.1733: 100%|██████████| 100/100 [00:01<00:00, 85.56it/s]\n",
      "epoch: 954, loss: 1.0912: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 955, loss: 1.2229: 100%|██████████| 100/100 [00:01<00:00, 85.47it/s]\n",
      "epoch: 956, loss: 1.3989: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 957, loss: 1.1026: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 958, loss: 1.4085: 100%|██████████| 100/100 [00:01<00:00, 85.88it/s]\n",
      "epoch: 959, loss: 1.1736: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 960, loss: 1.2447: 100%|██████████| 100/100 [00:01<00:00, 85.53it/s]\n",
      "epoch: 961, loss: 1.2051: 100%|██████████| 100/100 [00:01<00:00, 85.39it/s]\n",
      "epoch: 962, loss: 1.1584: 100%|██████████| 100/100 [00:01<00:00, 84.83it/s]\n",
      "epoch: 963, loss: 1.0798: 100%|██████████| 100/100 [00:01<00:00, 86.10it/s]\n",
      "epoch: 964, loss: 1.1838: 100%|██████████| 100/100 [00:01<00:00, 86.38it/s]\n",
      "epoch: 965, loss: 1.2431: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 966, loss: 1.0115: 100%|██████████| 100/100 [00:01<00:00, 86.00it/s]\n",
      "epoch: 967, loss: 1.2439: 100%|██████████| 100/100 [00:01<00:00, 85.79it/s]\n",
      "epoch: 968, loss: 1.2672: 100%|██████████| 100/100 [00:01<00:00, 86.34it/s]\n",
      "epoch: 969, loss: 1.2692: 100%|██████████| 100/100 [00:01<00:00, 86.21it/s]\n",
      "epoch: 970, loss: 1.2907: 100%|██████████| 100/100 [00:01<00:00, 86.16it/s]\n",
      "epoch: 971, loss: 1.1706: 100%|██████████| 100/100 [00:01<00:00, 85.99it/s]\n",
      "epoch: 972, loss: 1.2218: 100%|██████████| 100/100 [00:01<00:00, 86.08it/s]\n",
      "epoch: 973, loss: 1.3941: 100%|██████████| 100/100 [00:01<00:00, 86.04it/s]\n",
      "epoch: 974, loss: 1.2232: 100%|██████████| 100/100 [00:01<00:00, 86.06it/s]\n",
      "epoch: 975, loss: 1.1468: 100%|██████████| 100/100 [00:01<00:00, 85.96it/s]\n",
      "epoch: 976, loss: 1.1431: 100%|██████████| 100/100 [00:01<00:00, 85.81it/s]\n",
      "epoch: 977, loss: 1.2423: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 978, loss: 1.1655: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 979, loss: 1.1536: 100%|██████████| 100/100 [00:01<00:00, 86.09it/s]\n",
      "epoch: 980, loss: 1.2622: 100%|██████████| 100/100 [00:01<00:00, 86.07it/s]\n",
      "epoch: 981, loss: 1.0838: 100%|██████████| 100/100 [00:01<00:00, 85.80it/s]\n",
      "epoch: 982, loss: 1.1376: 100%|██████████| 100/100 [00:01<00:00, 85.76it/s]\n",
      "epoch: 983, loss: 1.1151: 100%|██████████| 100/100 [00:01<00:00, 86.11it/s]\n",
      "epoch: 984, loss: 1.0649: 100%|██████████| 100/100 [00:00<00:00, 109.16it/s]\n",
      "epoch: 985, loss: 1.1191: 100%|██████████| 100/100 [00:00<00:00, 117.27it/s]\n",
      "epoch: 986, loss: 1.1348: 100%|██████████| 100/100 [00:00<00:00, 117.46it/s]\n",
      "epoch: 987, loss: 1.2741: 100%|██████████| 100/100 [00:00<00:00, 117.41it/s]\n",
      "epoch: 988, loss: 1.2111: 100%|██████████| 100/100 [00:00<00:00, 118.31it/s]\n",
      "epoch: 989, loss: 1.2994: 100%|██████████| 100/100 [00:00<00:00, 114.65it/s]\n",
      "epoch: 990, loss: 1.1509: 100%|██████████| 100/100 [00:00<00:00, 113.93it/s]\n",
      "epoch: 991, loss: 1.0721: 100%|██████████| 100/100 [00:00<00:00, 111.61it/s]\n",
      "epoch: 992, loss: 1.1994: 100%|██████████| 100/100 [00:00<00:00, 113.21it/s]\n",
      "epoch: 993, loss: 1.3809: 100%|██████████| 100/100 [00:00<00:00, 110.46it/s]\n",
      "epoch: 994, loss: 1.2854: 100%|██████████| 100/100 [00:00<00:00, 113.69it/s]\n",
      "epoch: 995, loss: 1.2043: 100%|██████████| 100/100 [00:00<00:00, 117.19it/s]\n",
      "epoch: 996, loss: 1.3065: 100%|██████████| 100/100 [00:00<00:00, 116.48it/s]\n",
      "epoch: 997, loss: 1.2313: 100%|██████████| 100/100 [00:00<00:00, 111.57it/s]\n",
      "epoch: 998, loss: 1.2281: 100%|██████████| 100/100 [00:00<00:00, 108.36it/s]\n",
      "epoch: 999, loss: 1.2710: 100%|██████████| 100/100 [00:01<00:00, 85.94it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "samples = float2bin(db.gen_batch(50000), bm)\n",
    "mean = np.mean(samples, axis=0)\n",
    "init_dist = torch.distributions.Bernoulli(probs=torch.from_numpy(mean).to(device) * (1. - 2 * 1e-2) + 1e-2)\n",
    "net = MLPScore(input_dim=32, hidden_dims=[256,256,256,1]).to(device)\n",
    "energy_func = EBM(net, torch.from_numpy(mean)).to(device)\n",
    "ema_energy_func = training_main_loop(db, bm, energy_func, device, algo='ed_pool')\n",
    "plot_heat(ema_energy_func, bm, device)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Discrete EBM using ED-Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 0, loss: 3.3023: 100%|██████████| 100/100 [00:00<00:00, 115.67it/s]\n",
      "epoch: 1, loss: 3.2764: 100%|██████████| 100/100 [00:00<00:00, 112.04it/s]\n",
      "epoch: 2, loss: 3.0472: 100%|██████████| 100/100 [00:00<00:00, 107.74it/s]\n",
      "epoch: 3, loss: 2.9713: 100%|██████████| 100/100 [00:00<00:00, 116.00it/s]\n",
      "epoch: 4, loss: 3.0279: 100%|██████████| 100/100 [00:00<00:00, 123.64it/s]\n",
      "epoch: 5, loss: 2.8803: 100%|██████████| 100/100 [00:00<00:00, 102.35it/s]\n",
      "epoch: 6, loss: 2.8885: 100%|██████████| 100/100 [00:00<00:00, 116.97it/s]\n",
      "epoch: 7, loss: 2.8547: 100%|██████████| 100/100 [00:00<00:00, 110.62it/s]\n",
      "epoch: 8, loss: 2.9082: 100%|██████████| 100/100 [00:00<00:00, 117.10it/s]\n",
      "epoch: 9, loss: 2.9124: 100%|██████████| 100/100 [00:00<00:00, 116.30it/s]\n",
      "epoch: 10, loss: 3.0233: 100%|██████████| 100/100 [00:00<00:00, 118.32it/s]\n",
      "epoch: 11, loss: 3.0351: 100%|██████████| 100/100 [00:00<00:00, 103.29it/s]\n",
      "epoch: 12, loss: 2.8813: 100%|██████████| 100/100 [00:00<00:00, 116.50it/s]\n",
      "epoch: 13, loss: 2.9326: 100%|██████████| 100/100 [00:00<00:00, 112.58it/s]\n",
      "epoch: 14, loss: 2.9338: 100%|██████████| 100/100 [00:00<00:00, 118.50it/s]\n",
      "epoch: 15, loss: 2.9854: 100%|██████████| 100/100 [00:00<00:00, 112.61it/s]\n",
      "epoch: 16, loss: 2.7971: 100%|██████████| 100/100 [00:00<00:00, 129.47it/s]\n",
      "epoch: 17, loss: 2.6814: 100%|██████████| 100/100 [00:00<00:00, 125.75it/s]\n",
      "epoch: 18, loss: 2.6913: 100%|██████████| 100/100 [00:00<00:00, 123.42it/s]\n",
      "epoch: 19, loss: 2.8124: 100%|██████████| 100/100 [00:00<00:00, 122.03it/s]\n",
      "epoch: 20, loss: 2.7512: 100%|██████████| 100/100 [00:00<00:00, 124.02it/s]\n",
      "epoch: 21, loss: 2.8241: 100%|██████████| 100/100 [00:00<00:00, 122.32it/s]\n",
      "epoch: 22, loss: 2.7094: 100%|██████████| 100/100 [00:00<00:00, 120.15it/s]\n",
      "epoch: 23, loss: 2.8690: 100%|██████████| 100/100 [00:00<00:00, 123.37it/s]\n",
      "epoch: 24, loss: 2.7548: 100%|██████████| 100/100 [00:00<00:00, 122.32it/s]\n",
      "epoch: 25, loss: 2.6648: 100%|██████████| 100/100 [00:00<00:00, 127.77it/s]\n",
      "epoch: 26, loss: 2.8052: 100%|██████████| 100/100 [00:00<00:00, 127.34it/s]\n",
      "epoch: 27, loss: 2.6785: 100%|██████████| 100/100 [00:00<00:00, 127.38it/s]\n",
      "epoch: 28, loss: 2.7945: 100%|██████████| 100/100 [00:00<00:00, 123.44it/s]\n",
      "epoch: 29, loss: 2.9236: 100%|██████████| 100/100 [00:00<00:00, 123.76it/s]\n",
      "epoch: 30, loss: 2.9591: 100%|██████████| 100/100 [00:00<00:00, 105.02it/s]\n",
      "epoch: 31, loss: 2.8606: 100%|██████████| 100/100 [00:00<00:00, 103.55it/s]\n",
      "epoch: 32, loss: 2.7245: 100%|██████████| 100/100 [00:00<00:00, 130.28it/s]\n",
      "epoch: 33, loss: 2.8547: 100%|██████████| 100/100 [00:00<00:00, 128.21it/s]\n",
      "epoch: 34, loss: 2.9427: 100%|██████████| 100/100 [00:00<00:00, 130.10it/s]\n",
      "epoch: 35, loss: 2.9263: 100%|██████████| 100/100 [00:00<00:00, 130.54it/s]\n",
      "epoch: 36, loss: 2.9343: 100%|██████████| 100/100 [00:00<00:00, 132.15it/s]\n",
      "epoch: 37, loss: 2.7792: 100%|██████████| 100/100 [00:00<00:00, 131.79it/s]\n",
      "epoch: 38, loss: 2.8934: 100%|██████████| 100/100 [00:00<00:00, 120.98it/s]\n",
      "epoch: 39, loss: 2.8396: 100%|██████████| 100/100 [00:00<00:00, 119.95it/s]\n",
      "epoch: 40, loss: 2.8534: 100%|██████████| 100/100 [00:00<00:00, 132.07it/s]\n",
      "epoch: 41, loss: 2.8104: 100%|██████████| 100/100 [00:00<00:00, 131.26it/s]\n",
      "epoch: 42, loss: 2.9185: 100%|██████████| 100/100 [00:00<00:00, 127.93it/s]\n",
      "epoch: 43, loss: 2.8290: 100%|██████████| 100/100 [00:00<00:00, 129.60it/s]\n",
      "epoch: 44, loss: 2.7854: 100%|██████████| 100/100 [00:00<00:00, 130.09it/s]\n",
      "epoch: 45, loss: 2.8925: 100%|██████████| 100/100 [00:00<00:00, 131.50it/s]\n",
      "epoch: 46, loss: 2.9753: 100%|██████████| 100/100 [00:00<00:00, 125.11it/s]\n",
      "epoch: 47, loss: 2.8623: 100%|██████████| 100/100 [00:00<00:00, 131.11it/s]\n",
      "epoch: 48, loss: 2.9966: 100%|██████████| 100/100 [00:00<00:00, 131.18it/s]\n",
      "epoch: 49, loss: 2.8023: 100%|██████████| 100/100 [00:00<00:00, 131.56it/s]\n",
      "epoch: 50, loss: 2.9355: 100%|██████████| 100/100 [00:00<00:00, 131.58it/s]\n",
      "epoch: 51, loss: 2.8048: 100%|██████████| 100/100 [00:00<00:00, 131.78it/s]\n",
      "epoch: 52, loss: 2.8520: 100%|██████████| 100/100 [00:00<00:00, 131.56it/s]\n",
      "epoch: 53, loss: 2.7350: 100%|██████████| 100/100 [00:00<00:00, 127.71it/s]\n",
      "epoch: 54, loss: 2.9387: 100%|██████████| 100/100 [00:00<00:00, 126.91it/s]\n",
      "epoch: 55, loss: 2.9286: 100%|██████████| 100/100 [00:00<00:00, 102.05it/s]\n",
      "epoch: 56, loss: 2.7161: 100%|██████████| 100/100 [00:00<00:00, 101.43it/s]\n",
      "epoch: 57, loss: 2.7218: 100%|██████████| 100/100 [00:00<00:00, 101.52it/s]\n",
      "epoch: 58, loss: 2.9089: 100%|██████████| 100/100 [00:00<00:00, 116.48it/s]\n",
      "epoch: 59, loss: 2.8767: 100%|██████████| 100/100 [00:00<00:00, 129.98it/s]\n",
      "epoch: 60, loss: 2.8423: 100%|██████████| 100/100 [00:00<00:00, 132.73it/s]\n",
      "epoch: 61, loss: 2.6922: 100%|██████████| 100/100 [00:00<00:00, 132.90it/s]\n",
      "epoch: 62, loss: 2.7594: 100%|██████████| 100/100 [00:00<00:00, 132.68it/s]\n",
      "epoch: 63, loss: 2.9953: 100%|██████████| 100/100 [00:00<00:00, 132.00it/s]\n",
      "epoch: 64, loss: 2.8370: 100%|██████████| 100/100 [00:00<00:00, 121.51it/s]\n",
      "epoch: 65, loss: 2.6762: 100%|██████████| 100/100 [00:00<00:00, 118.50it/s]\n",
      "epoch: 66, loss: 2.8756: 100%|██████████| 100/100 [00:00<00:00, 115.32it/s]\n",
      "epoch: 67, loss: 2.9237: 100%|██████████| 100/100 [00:00<00:00, 127.41it/s]\n",
      "epoch: 68, loss: 2.8282: 100%|██████████| 100/100 [00:00<00:00, 125.14it/s]\n",
      "epoch: 69, loss: 2.9524: 100%|██████████| 100/100 [00:00<00:00, 123.98it/s]\n",
      "epoch: 70, loss: 2.8666: 100%|██████████| 100/100 [00:00<00:00, 123.82it/s]\n",
      "epoch: 71, loss: 2.9230: 100%|██████████| 100/100 [00:00<00:00, 107.85it/s]\n",
      "epoch: 72, loss: 3.0052: 100%|██████████| 100/100 [00:00<00:00, 120.27it/s]\n",
      "epoch: 73, loss: 2.8140: 100%|██████████| 100/100 [00:00<00:00, 124.56it/s]\n",
      "epoch: 74, loss: 2.8410: 100%|██████████| 100/100 [00:00<00:00, 126.93it/s]\n",
      "epoch: 75, loss: 2.7431: 100%|██████████| 100/100 [00:00<00:00, 125.54it/s]\n",
      "epoch: 76, loss: 2.7720: 100%|██████████| 100/100 [00:00<00:00, 131.97it/s]\n",
      "epoch: 77, loss: 3.0169: 100%|██████████| 100/100 [00:00<00:00, 129.15it/s]\n",
      "epoch: 78, loss: 2.8333: 100%|██████████| 100/100 [00:00<00:00, 125.48it/s]\n",
      "epoch: 79, loss: 2.8039: 100%|██████████| 100/100 [00:00<00:00, 125.59it/s]\n",
      "epoch: 80, loss: 2.9141: 100%|██████████| 100/100 [00:00<00:00, 124.26it/s]\n",
      "epoch: 81, loss: 2.8350: 100%|██████████| 100/100 [00:00<00:00, 126.52it/s]\n",
      "epoch: 82, loss: 2.8971: 100%|██████████| 100/100 [00:00<00:00, 125.00it/s]\n",
      "epoch: 83, loss: 2.8204: 100%|██████████| 100/100 [00:00<00:00, 125.18it/s]\n",
      "epoch: 84, loss: 2.7686: 100%|██████████| 100/100 [00:00<00:00, 125.80it/s]\n",
      "epoch: 85, loss: 2.7890: 100%|██████████| 100/100 [00:00<00:00, 124.53it/s]\n",
      "epoch: 86, loss: 2.7725: 100%|██████████| 100/100 [00:00<00:00, 128.02it/s]\n",
      "epoch: 87, loss: 2.8683: 100%|██████████| 100/100 [00:00<00:00, 132.07it/s]\n",
      "epoch: 88, loss: 2.8587: 100%|██████████| 100/100 [00:00<00:00, 131.65it/s]\n",
      "epoch: 89, loss: 2.7706: 100%|██████████| 100/100 [00:00<00:00, 124.78it/s]\n",
      "epoch: 90, loss: 2.9581: 100%|██████████| 100/100 [00:00<00:00, 118.23it/s]\n",
      "epoch: 91, loss: 2.8430: 100%|██████████| 100/100 [00:00<00:00, 127.23it/s]\n",
      "epoch: 92, loss: 2.7869: 100%|██████████| 100/100 [00:00<00:00, 124.64it/s]\n",
      "epoch: 93, loss: 2.9308: 100%|██████████| 100/100 [00:00<00:00, 128.22it/s]\n",
      "epoch: 94, loss: 3.0159: 100%|██████████| 100/100 [00:00<00:00, 127.85it/s]\n",
      "epoch: 95, loss: 3.0129: 100%|██████████| 100/100 [00:00<00:00, 130.87it/s]\n",
      "epoch: 96, loss: 2.8998: 100%|██████████| 100/100 [00:00<00:00, 120.20it/s]\n",
      "epoch: 97, loss: 2.7331: 100%|██████████| 100/100 [00:00<00:00, 115.66it/s]\n",
      "epoch: 98, loss: 2.7002: 100%|██████████| 100/100 [00:00<00:00, 129.50it/s]\n",
      "epoch: 99, loss: 2.9056: 100%|██████████| 100/100 [00:00<00:00, 132.95it/s]\n",
      "epoch: 100, loss: 2.8372: 100%|██████████| 100/100 [00:00<00:00, 132.49it/s]\n",
      "epoch: 101, loss: 2.8210: 100%|██████████| 100/100 [00:00<00:00, 132.23it/s]\n",
      "epoch: 102, loss: 2.8945: 100%|██████████| 100/100 [00:00<00:00, 133.06it/s]\n",
      "epoch: 103, loss: 2.7977: 100%|██████████| 100/100 [00:00<00:00, 133.08it/s]\n",
      "epoch: 104, loss: 2.8367: 100%|██████████| 100/100 [00:00<00:00, 132.24it/s]\n",
      "epoch: 105, loss: 2.9216: 100%|██████████| 100/100 [00:00<00:00, 130.56it/s]\n",
      "epoch: 106, loss: 2.9109: 100%|██████████| 100/100 [00:00<00:00, 132.13it/s]\n",
      "epoch: 107, loss: 2.5870: 100%|██████████| 100/100 [00:00<00:00, 131.75it/s]\n",
      "epoch: 108, loss: 2.9789: 100%|██████████| 100/100 [00:00<00:00, 132.26it/s]\n",
      "epoch: 109, loss: 2.8956: 100%|██████████| 100/100 [00:00<00:00, 133.03it/s]\n",
      "epoch: 110, loss: 2.7897: 100%|██████████| 100/100 [00:00<00:00, 132.15it/s]\n",
      "epoch: 111, loss: 2.8277: 100%|██████████| 100/100 [00:00<00:00, 132.47it/s]\n",
      "epoch: 112, loss: 2.7637: 100%|██████████| 100/100 [00:00<00:00, 126.47it/s]\n",
      "epoch: 113, loss: 2.8483: 100%|██████████| 100/100 [00:00<00:00, 131.38it/s]\n",
      "epoch: 114, loss: 2.8196: 100%|██████████| 100/100 [00:00<00:00, 132.40it/s]\n",
      "epoch: 115, loss: 3.0143: 100%|██████████| 100/100 [00:00<00:00, 121.59it/s]\n",
      "epoch: 116, loss: 2.9052: 100%|██████████| 100/100 [00:00<00:00, 126.50it/s]\n",
      "epoch: 117, loss: 3.0213: 100%|██████████| 100/100 [00:00<00:00, 114.65it/s]\n",
      "epoch: 118, loss: 2.7924: 100%|██████████| 100/100 [00:00<00:00, 104.48it/s]\n",
      "epoch: 119, loss: 2.7032: 100%|██████████| 100/100 [00:00<00:00, 131.07it/s]\n",
      "epoch: 120, loss: 2.7946: 100%|██████████| 100/100 [00:00<00:00, 131.05it/s]\n",
      "epoch: 121, loss: 2.8229: 100%|██████████| 100/100 [00:00<00:00, 130.96it/s]\n",
      "epoch: 122, loss: 2.7625: 100%|██████████| 100/100 [00:00<00:00, 130.82it/s]\n",
      "epoch: 123, loss: 2.8258: 100%|██████████| 100/100 [00:00<00:00, 130.22it/s]\n",
      "epoch: 124, loss: 2.7859: 100%|██████████| 100/100 [00:00<00:00, 117.71it/s]\n",
      "epoch: 125, loss: 2.7500: 100%|██████████| 100/100 [00:00<00:00, 102.69it/s]\n",
      "epoch: 126, loss: 2.8945: 100%|██████████| 100/100 [00:00<00:00, 103.82it/s]\n",
      "epoch: 127, loss: 2.6670: 100%|██████████| 100/100 [00:00<00:00, 103.35it/s]\n",
      "epoch: 128, loss: 2.8376: 100%|██████████| 100/100 [00:00<00:00, 102.21it/s]\n",
      "epoch: 129, loss: 2.7985: 100%|██████████| 100/100 [00:00<00:00, 100.50it/s]\n",
      "epoch: 130, loss: 2.7338: 100%|██████████| 100/100 [00:00<00:00, 101.52it/s]\n",
      "epoch: 131, loss: 2.8334: 100%|██████████| 100/100 [00:00<00:00, 106.36it/s]\n",
      "epoch: 132, loss: 2.8538: 100%|██████████| 100/100 [00:00<00:00, 126.30it/s]\n",
      "epoch: 133, loss: 2.9126: 100%|██████████| 100/100 [00:00<00:00, 127.39it/s]\n",
      "epoch: 134, loss: 2.8620: 100%|██████████| 100/100 [00:00<00:00, 125.76it/s]\n",
      "epoch: 135, loss: 2.6928: 100%|██████████| 100/100 [00:00<00:00, 125.72it/s]\n",
      "epoch: 136, loss: 2.7284: 100%|██████████| 100/100 [00:00<00:00, 126.01it/s]\n",
      "epoch: 137, loss: 2.7172: 100%|██████████| 100/100 [00:00<00:00, 125.68it/s]\n",
      "epoch: 138, loss: 2.7605: 100%|██████████| 100/100 [00:00<00:00, 126.43it/s]\n",
      "epoch: 139, loss: 2.6694: 100%|██████████| 100/100 [00:00<00:00, 125.62it/s]\n",
      "epoch: 140, loss: 2.6944: 100%|██████████| 100/100 [00:00<00:00, 126.83it/s]\n",
      "epoch: 141, loss: 2.8553: 100%|██████████| 100/100 [00:00<00:00, 129.71it/s]\n",
      "epoch: 142, loss: 2.7260: 100%|██████████| 100/100 [00:00<00:00, 127.00it/s]\n",
      "epoch: 143, loss: 2.8923: 100%|██████████| 100/100 [00:00<00:00, 126.83it/s]\n",
      "epoch: 144, loss: 2.6327: 100%|██████████| 100/100 [00:00<00:00, 126.16it/s]\n",
      "epoch: 145, loss: 2.8124: 100%|██████████| 100/100 [00:00<00:00, 126.76it/s]\n",
      "epoch: 146, loss: 2.7867: 100%|██████████| 100/100 [00:00<00:00, 126.48it/s]\n",
      "epoch: 147, loss: 2.8717: 100%|██████████| 100/100 [00:00<00:00, 125.39it/s]\n",
      "epoch: 148, loss: 2.8521: 100%|██████████| 100/100 [00:00<00:00, 123.48it/s]\n",
      "epoch: 149, loss: 2.8227: 100%|██████████| 100/100 [00:00<00:00, 124.80it/s]\n",
      "epoch: 150, loss: 3.0107: 100%|██████████| 100/100 [00:00<00:00, 125.55it/s]\n",
      "epoch: 151, loss: 2.8578: 100%|██████████| 100/100 [00:00<00:00, 127.36it/s]\n",
      "epoch: 152, loss: 2.9089: 100%|██████████| 100/100 [00:00<00:00, 126.11it/s]\n",
      "epoch: 153, loss: 2.7818: 100%|██████████| 100/100 [00:00<00:00, 123.69it/s]\n",
      "epoch: 154, loss: 2.9228: 100%|██████████| 100/100 [00:00<00:00, 129.63it/s]\n",
      "epoch: 155, loss: 2.9992: 100%|██████████| 100/100 [00:00<00:00, 131.80it/s]\n",
      "epoch: 156, loss: 2.8335: 100%|██████████| 100/100 [00:00<00:00, 131.42it/s]\n",
      "epoch: 157, loss: 2.8639: 100%|██████████| 100/100 [00:00<00:00, 126.76it/s]\n",
      "epoch: 158, loss: 2.7354: 100%|██████████| 100/100 [00:00<00:00, 129.05it/s]\n",
      "epoch: 159, loss: 2.6613: 100%|██████████| 100/100 [00:00<00:00, 125.92it/s]\n",
      "epoch: 160, loss: 2.6527: 100%|██████████| 100/100 [00:00<00:00, 125.68it/s]\n",
      "epoch: 161, loss: 2.8084: 100%|██████████| 100/100 [00:00<00:00, 127.03it/s]\n",
      "epoch: 162, loss: 2.8862: 100%|██████████| 100/100 [00:00<00:00, 127.22it/s]\n",
      "epoch: 163, loss: 3.0082: 100%|██████████| 100/100 [00:00<00:00, 126.49it/s]\n",
      "epoch: 164, loss: 2.7161: 100%|██████████| 100/100 [00:00<00:00, 127.03it/s]\n",
      "epoch: 165, loss: 2.9902: 100%|██████████| 100/100 [00:00<00:00, 127.08it/s]\n",
      "epoch: 166, loss: 2.8472: 100%|██████████| 100/100 [00:00<00:00, 126.84it/s]\n",
      "epoch: 167, loss: 2.7247: 100%|██████████| 100/100 [00:00<00:00, 126.82it/s]\n",
      "epoch: 168, loss: 2.8402: 100%|██████████| 100/100 [00:00<00:00, 131.84it/s]\n",
      "epoch: 169, loss: 2.9480: 100%|██████████| 100/100 [00:00<00:00, 127.26it/s]\n",
      "epoch: 170, loss: 2.7965: 100%|██████████| 100/100 [00:00<00:00, 126.68it/s]\n",
      "epoch: 171, loss: 2.8389: 100%|██████████| 100/100 [00:00<00:00, 127.25it/s]\n",
      "epoch: 172, loss: 2.8411: 100%|██████████| 100/100 [00:00<00:00, 127.19it/s]\n",
      "epoch: 173, loss: 2.8734: 100%|██████████| 100/100 [00:00<00:00, 123.50it/s]\n",
      "epoch: 174, loss: 2.7946: 100%|██████████| 100/100 [00:00<00:00, 125.96it/s]\n",
      "epoch: 175, loss: 2.7692: 100%|██████████| 100/100 [00:00<00:00, 126.02it/s]\n",
      "epoch: 176, loss: 2.8752: 100%|██████████| 100/100 [00:00<00:00, 127.16it/s]\n",
      "epoch: 177, loss: 2.6695: 100%|██████████| 100/100 [00:00<00:00, 132.24it/s]\n",
      "epoch: 178, loss: 2.7026: 100%|██████████| 100/100 [00:00<00:00, 129.92it/s]\n",
      "epoch: 179, loss: 2.7818: 100%|██████████| 100/100 [00:00<00:00, 133.14it/s]\n",
      "epoch: 180, loss: 2.7087: 100%|██████████| 100/100 [00:00<00:00, 124.67it/s]\n",
      "epoch: 181, loss: 2.7771: 100%|██████████| 100/100 [00:00<00:00, 128.86it/s]\n",
      "epoch: 182, loss: 2.9343: 100%|██████████| 100/100 [00:00<00:00, 126.57it/s]\n",
      "epoch: 183, loss: 2.9052: 100%|██████████| 100/100 [00:00<00:00, 114.58it/s]\n",
      "epoch: 184, loss: 2.8808: 100%|██████████| 100/100 [00:00<00:00, 131.90it/s]\n",
      "epoch: 185, loss: 3.0564: 100%|██████████| 100/100 [00:00<00:00, 131.64it/s]\n",
      "epoch: 186, loss: 2.9491: 100%|██████████| 100/100 [00:00<00:00, 129.02it/s]\n",
      "epoch: 187, loss: 2.8308: 100%|██████████| 100/100 [00:00<00:00, 121.01it/s]\n",
      "epoch: 188, loss: 2.8952: 100%|██████████| 100/100 [00:01<00:00, 98.19it/s]\n",
      "epoch: 189, loss: 2.7633: 100%|██████████| 100/100 [00:00<00:00, 119.17it/s]\n",
      "epoch: 190, loss: 2.7959: 100%|██████████| 100/100 [00:00<00:00, 107.57it/s]\n",
      "epoch: 191, loss: 2.8200: 100%|██████████| 100/100 [00:00<00:00, 100.15it/s]\n",
      "epoch: 192, loss: 2.9461: 100%|██████████| 100/100 [00:00<00:00, 121.82it/s]\n",
      "epoch: 193, loss: 2.8606: 100%|██████████| 100/100 [00:00<00:00, 119.41it/s]\n",
      "epoch: 194, loss: 3.0186: 100%|██████████| 100/100 [00:00<00:00, 105.09it/s]\n",
      "epoch: 195, loss: 2.9212: 100%|██████████| 100/100 [00:00<00:00, 120.11it/s]\n",
      "epoch: 196, loss: 2.8823: 100%|██████████| 100/100 [00:00<00:00, 132.99it/s]\n",
      "epoch: 197, loss: 2.8480: 100%|██████████| 100/100 [00:00<00:00, 132.42it/s]\n",
      "epoch: 198, loss: 2.8532: 100%|██████████| 100/100 [00:00<00:00, 131.97it/s]\n",
      "epoch: 199, loss: 2.7866: 100%|██████████| 100/100 [00:00<00:00, 132.36it/s]\n",
      "epoch: 200, loss: 2.6772: 100%|██████████| 100/100 [00:00<00:00, 132.31it/s]\n",
      "epoch: 201, loss: 2.7758: 100%|██████████| 100/100 [00:00<00:00, 131.50it/s]\n",
      "epoch: 202, loss: 2.8625: 100%|██████████| 100/100 [00:00<00:00, 131.41it/s]\n",
      "epoch: 203, loss: 2.7250: 100%|██████████| 100/100 [00:00<00:00, 131.15it/s]\n",
      "epoch: 204, loss: 2.8763: 100%|██████████| 100/100 [00:00<00:00, 121.45it/s]\n",
      "epoch: 205, loss: 2.8863: 100%|██████████| 100/100 [00:00<00:00, 123.18it/s]\n",
      "epoch: 206, loss: 2.9453: 100%|██████████| 100/100 [00:00<00:00, 128.98it/s]\n",
      "epoch: 207, loss: 2.8697: 100%|██████████| 100/100 [00:00<00:00, 131.55it/s]\n",
      "epoch: 208, loss: 2.8482: 100%|██████████| 100/100 [00:00<00:00, 129.49it/s]\n",
      "epoch: 209, loss: 2.7437: 100%|██████████| 100/100 [00:00<00:00, 125.38it/s]\n",
      "epoch: 210, loss: 2.7872: 100%|██████████| 100/100 [00:00<00:00, 127.27it/s]\n",
      "epoch: 211, loss: 2.8814: 100%|██████████| 100/100 [00:00<00:00, 126.56it/s]\n",
      "epoch: 212, loss: 2.7410: 100%|██████████| 100/100 [00:00<00:00, 126.36it/s]\n",
      "epoch: 213, loss: 2.9673: 100%|██████████| 100/100 [00:00<00:00, 126.84it/s]\n",
      "epoch: 214, loss: 2.8742: 100%|██████████| 100/100 [00:00<00:00, 126.86it/s]\n",
      "epoch: 215, loss: 2.9115: 100%|██████████| 100/100 [00:00<00:00, 125.47it/s]\n",
      "epoch: 216, loss: 2.6836: 100%|██████████| 100/100 [00:00<00:00, 125.61it/s]\n",
      "epoch: 217, loss: 2.8397: 100%|██████████| 100/100 [00:00<00:00, 126.94it/s]\n",
      "epoch: 218, loss: 2.8004: 100%|██████████| 100/100 [00:00<00:00, 125.79it/s]\n",
      "epoch: 219, loss: 2.5990: 100%|██████████| 100/100 [00:00<00:00, 125.87it/s]\n",
      "epoch: 220, loss: 2.7890: 100%|██████████| 100/100 [00:00<00:00, 126.15it/s]\n",
      "epoch: 221, loss: 2.6980: 100%|██████████| 100/100 [00:00<00:00, 126.80it/s]\n",
      "epoch: 222, loss: 2.8335: 100%|██████████| 100/100 [00:00<00:00, 125.98it/s]\n",
      "epoch: 223, loss: 2.7550: 100%|██████████| 100/100 [00:00<00:00, 125.74it/s]\n",
      "epoch: 224, loss: 2.7969: 100%|██████████| 100/100 [00:00<00:00, 126.76it/s]\n",
      "epoch: 225, loss: 2.7550: 100%|██████████| 100/100 [00:00<00:00, 126.83it/s]\n",
      "epoch: 226, loss: 2.6716: 100%|██████████| 100/100 [00:00<00:00, 126.05it/s]\n",
      "epoch: 227, loss: 2.6653: 100%|██████████| 100/100 [00:00<00:00, 126.66it/s]\n",
      "epoch: 228, loss: 2.7614: 100%|██████████| 100/100 [00:00<00:00, 126.76it/s]\n",
      "epoch: 229, loss: 2.8300: 100%|██████████| 100/100 [00:00<00:00, 125.88it/s]\n",
      "epoch: 230, loss: 2.8382: 100%|██████████| 100/100 [00:00<00:00, 125.25it/s]\n",
      "epoch: 231, loss: 2.8313: 100%|██████████| 100/100 [00:00<00:00, 126.55it/s]\n",
      "epoch: 232, loss: 2.7683: 100%|██████████| 100/100 [00:00<00:00, 126.58it/s]\n",
      "epoch: 233, loss: 2.8278: 100%|██████████| 100/100 [00:00<00:00, 125.69it/s]\n",
      "epoch: 234, loss: 2.6752: 100%|██████████| 100/100 [00:00<00:00, 122.22it/s]\n",
      "epoch: 235, loss: 2.8843: 100%|██████████| 100/100 [00:00<00:00, 131.08it/s]\n",
      "epoch: 236, loss: 2.8443: 100%|██████████| 100/100 [00:00<00:00, 130.40it/s]\n",
      "epoch: 237, loss: 2.9502: 100%|██████████| 100/100 [00:00<00:00, 125.89it/s]\n",
      "epoch: 238, loss: 2.8245: 100%|██████████| 100/100 [00:00<00:00, 126.64it/s]\n",
      "epoch: 239, loss: 2.7216: 100%|██████████| 100/100 [00:00<00:00, 127.64it/s]\n",
      "epoch: 240, loss: 2.8298: 100%|██████████| 100/100 [00:00<00:00, 125.46it/s]\n",
      "epoch: 241, loss: 2.9197: 100%|██████████| 100/100 [00:00<00:00, 123.96it/s]\n",
      "epoch: 242, loss: 2.7259: 100%|██████████| 100/100 [00:00<00:00, 125.83it/s]\n",
      "epoch: 243, loss: 2.9400: 100%|██████████| 100/100 [00:00<00:00, 126.29it/s]\n",
      "epoch: 244, loss: 2.9871: 100%|██████████| 100/100 [00:00<00:00, 125.24it/s]\n",
      "epoch: 245, loss: 2.9152: 100%|██████████| 100/100 [00:00<00:00, 126.44it/s]\n",
      "epoch: 246, loss: 2.8416: 100%|██████████| 100/100 [00:00<00:00, 123.61it/s]\n",
      "epoch: 247, loss: 2.9072: 100%|██████████| 100/100 [00:00<00:00, 127.79it/s]\n",
      "epoch: 248, loss: 2.8592: 100%|██████████| 100/100 [00:00<00:00, 132.65it/s]\n",
      "epoch: 249, loss: 2.9041: 100%|██████████| 100/100 [00:00<00:00, 132.78it/s]\n",
      "epoch: 250, loss: 2.7645: 100%|██████████| 100/100 [00:00<00:00, 132.68it/s]\n",
      "epoch: 251, loss: 2.9416: 100%|██████████| 100/100 [00:00<00:00, 125.05it/s]\n",
      "epoch: 252, loss: 2.9347: 100%|██████████| 100/100 [00:00<00:00, 125.43it/s]\n",
      "epoch: 253, loss: 2.7710: 100%|██████████| 100/100 [00:00<00:00, 122.55it/s]\n",
      "epoch: 254, loss: 2.9264: 100%|██████████| 100/100 [00:00<00:00, 131.33it/s]\n",
      "epoch: 255, loss: 2.8854: 100%|██████████| 100/100 [00:00<00:00, 131.74it/s]\n",
      "epoch: 256, loss: 3.0139: 100%|██████████| 100/100 [00:00<00:00, 132.11it/s]\n",
      "epoch: 257, loss: 2.9387: 100%|██████████| 100/100 [00:00<00:00, 132.29it/s]\n",
      "epoch: 258, loss: 2.8566: 100%|██████████| 100/100 [00:00<00:00, 128.79it/s]\n",
      "epoch: 259, loss: 2.8047: 100%|██████████| 100/100 [00:00<00:00, 130.43it/s]\n",
      "epoch: 260, loss: 3.1056: 100%|██████████| 100/100 [00:00<00:00, 126.02it/s]\n",
      "epoch: 261, loss: 3.0398: 100%|██████████| 100/100 [00:00<00:00, 123.99it/s]\n",
      "epoch: 262, loss: 2.9418: 100%|██████████| 100/100 [00:00<00:00, 128.07it/s]\n",
      "epoch: 263, loss: 2.9377: 100%|██████████| 100/100 [00:00<00:00, 117.84it/s]\n",
      "epoch: 264, loss: 2.7641: 100%|██████████| 100/100 [00:00<00:00, 115.74it/s]\n",
      "epoch: 265, loss: 2.8910: 100%|██████████| 100/100 [00:00<00:00, 124.24it/s]\n",
      "epoch: 266, loss: 2.7508: 100%|██████████| 100/100 [00:00<00:00, 129.45it/s]\n",
      "epoch: 267, loss: 2.9169: 100%|██████████| 100/100 [00:00<00:00, 131.41it/s]\n",
      "epoch: 268, loss: 2.8767: 100%|██████████| 100/100 [00:00<00:00, 132.22it/s]\n",
      "epoch: 269, loss: 2.8393: 100%|██████████| 100/100 [00:00<00:00, 130.96it/s]\n",
      "epoch: 270, loss: 2.8709: 100%|██████████| 100/100 [00:00<00:00, 130.46it/s]\n",
      "epoch: 271, loss: 2.7767: 100%|██████████| 100/100 [00:00<00:00, 125.93it/s]\n",
      "epoch: 272, loss: 2.7444: 100%|██████████| 100/100 [00:00<00:00, 125.60it/s]\n",
      "epoch: 273, loss: 2.9795: 100%|██████████| 100/100 [00:00<00:00, 125.41it/s]\n",
      "epoch: 274, loss: 2.9135: 100%|██████████| 100/100 [00:00<00:00, 126.28it/s]\n",
      "epoch: 275, loss: 2.7634: 100%|██████████| 100/100 [00:00<00:00, 126.62it/s]\n",
      "epoch: 276, loss: 2.5935: 100%|██████████| 100/100 [00:00<00:00, 125.84it/s]\n",
      "epoch: 277, loss: 2.8575: 100%|██████████| 100/100 [00:00<00:00, 128.52it/s]\n",
      "epoch: 278, loss: 2.9375: 100%|██████████| 100/100 [00:00<00:00, 129.04it/s]\n",
      "epoch: 279, loss: 2.7780: 100%|██████████| 100/100 [00:00<00:00, 115.74it/s]\n",
      "epoch: 280, loss: 2.7605: 100%|██████████| 100/100 [00:00<00:00, 129.98it/s]\n",
      "epoch: 281, loss: 2.7831: 100%|██████████| 100/100 [00:00<00:00, 104.79it/s]\n",
      "epoch: 282, loss: 2.9725: 100%|██████████| 100/100 [00:00<00:00, 124.22it/s]\n",
      "epoch: 283, loss: 2.8897: 100%|██████████| 100/100 [00:00<00:00, 123.07it/s]\n",
      "epoch: 284, loss: 2.8118: 100%|██████████| 100/100 [00:00<00:00, 127.31it/s]\n",
      "epoch: 285, loss: 3.0444: 100%|██████████| 100/100 [00:00<00:00, 130.36it/s]\n",
      "epoch: 286, loss: 2.8547: 100%|██████████| 100/100 [00:00<00:00, 129.63it/s]\n",
      "epoch: 287, loss: 2.8904: 100%|██████████| 100/100 [00:00<00:00, 127.31it/s]\n",
      "epoch: 288, loss: 2.8270: 100%|██████████| 100/100 [00:00<00:00, 125.81it/s]\n",
      "epoch: 289, loss: 2.8843: 100%|██████████| 100/100 [00:00<00:00, 126.53it/s]\n",
      "epoch: 290, loss: 2.7711: 100%|██████████| 100/100 [00:00<00:00, 125.17it/s]\n",
      "epoch: 291, loss: 2.9016: 100%|██████████| 100/100 [00:00<00:00, 126.74it/s]\n",
      "epoch: 292, loss: 2.9651: 100%|██████████| 100/100 [00:00<00:00, 126.16it/s]\n",
      "epoch: 293, loss: 2.9220: 100%|██████████| 100/100 [00:00<00:00, 125.85it/s]\n",
      "epoch: 294, loss: 3.0381: 100%|██████████| 100/100 [00:00<00:00, 126.18it/s]\n",
      "epoch: 295, loss: 2.9721: 100%|██████████| 100/100 [00:00<00:00, 126.33it/s]\n",
      "epoch: 296, loss: 2.8966: 100%|██████████| 100/100 [00:00<00:00, 126.25it/s]\n",
      "epoch: 297, loss: 2.9206: 100%|██████████| 100/100 [00:00<00:00, 125.90it/s]\n",
      "epoch: 298, loss: 2.9759: 100%|██████████| 100/100 [00:00<00:00, 126.39it/s]\n",
      "epoch: 299, loss: 2.9711: 100%|██████████| 100/100 [00:00<00:00, 130.17it/s]\n",
      "epoch: 300, loss: 2.7894: 100%|██████████| 100/100 [00:00<00:00, 131.46it/s]\n",
      "epoch: 301, loss: 2.8993: 100%|██████████| 100/100 [00:00<00:00, 131.55it/s]\n",
      "epoch: 302, loss: 2.9906: 100%|██████████| 100/100 [00:00<00:00, 131.57it/s]\n",
      "epoch: 303, loss: 2.8230: 100%|██████████| 100/100 [00:00<00:00, 131.60it/s]\n",
      "epoch: 304, loss: 2.8847: 100%|██████████| 100/100 [00:00<00:00, 131.30it/s]\n",
      "epoch: 305, loss: 2.7908: 100%|██████████| 100/100 [00:00<00:00, 130.59it/s]\n",
      "epoch: 306, loss: 2.8653: 100%|██████████| 100/100 [00:00<00:00, 125.64it/s]\n",
      "epoch: 307, loss: 2.9551: 100%|██████████| 100/100 [00:00<00:00, 128.95it/s]\n",
      "epoch: 308, loss: 2.9560: 100%|██████████| 100/100 [00:00<00:00, 131.98it/s]\n",
      "epoch: 309, loss: 2.8169: 100%|██████████| 100/100 [00:00<00:00, 133.45it/s]\n",
      "epoch: 310, loss: 2.8271: 100%|██████████| 100/100 [00:00<00:00, 132.46it/s]\n",
      "epoch: 311, loss: 2.8650: 100%|██████████| 100/100 [00:00<00:00, 131.35it/s]\n",
      "epoch: 312, loss: 2.7897: 100%|██████████| 100/100 [00:00<00:00, 131.55it/s]\n",
      "epoch: 313, loss: 2.8135: 100%|██████████| 100/100 [00:00<00:00, 129.56it/s]\n",
      "epoch: 314, loss: 2.7190: 100%|██████████| 100/100 [00:00<00:00, 132.46it/s]\n",
      "epoch: 315, loss: 2.8436: 100%|██████████| 100/100 [00:00<00:00, 131.23it/s]\n",
      "epoch: 316, loss: 3.0215: 100%|██████████| 100/100 [00:00<00:00, 132.12it/s]\n",
      "epoch: 317, loss: 2.8058: 100%|██████████| 100/100 [00:00<00:00, 119.42it/s]\n",
      "epoch: 318, loss: 2.7527: 100%|██████████| 100/100 [00:00<00:00, 130.82it/s]\n",
      "epoch: 319, loss: 2.8508: 100%|██████████| 100/100 [00:00<00:00, 124.27it/s]\n",
      "epoch: 320, loss: 2.8376: 100%|██████████| 100/100 [00:00<00:00, 127.25it/s]\n",
      "epoch: 321, loss: 2.8980: 100%|██████████| 100/100 [00:00<00:00, 125.98it/s]\n",
      "epoch: 322, loss: 3.0108: 100%|██████████| 100/100 [00:00<00:00, 126.42it/s]\n",
      "epoch: 323, loss: 2.8109: 100%|██████████| 100/100 [00:00<00:00, 126.87it/s]\n",
      "epoch: 324, loss: 2.9514: 100%|██████████| 100/100 [00:00<00:00, 126.46it/s]\n",
      "epoch: 325, loss: 2.7204: 100%|██████████| 100/100 [00:00<00:00, 112.85it/s]\n",
      "epoch: 326, loss: 2.7838: 100%|██████████| 100/100 [00:00<00:00, 122.04it/s]\n",
      "epoch: 327, loss: 2.8735: 100%|██████████| 100/100 [00:00<00:00, 128.37it/s]\n",
      "epoch: 328, loss: 2.6220: 100%|██████████| 100/100 [00:00<00:00, 131.94it/s]\n",
      "epoch: 329, loss: 2.8843: 100%|██████████| 100/100 [00:00<00:00, 127.33it/s]\n",
      "epoch: 330, loss: 2.9885: 100%|██████████| 100/100 [00:00<00:00, 125.76it/s]\n",
      "epoch: 331, loss: 2.9232: 100%|██████████| 100/100 [00:00<00:00, 127.24it/s]\n",
      "epoch: 332, loss: 2.9630: 100%|██████████| 100/100 [00:00<00:00, 131.68it/s]\n",
      "epoch: 333, loss: 2.7735: 100%|██████████| 100/100 [00:00<00:00, 132.32it/s]\n",
      "epoch: 334, loss: 2.8419: 100%|██████████| 100/100 [00:00<00:00, 131.45it/s]\n",
      "epoch: 335, loss: 2.8286: 100%|██████████| 100/100 [00:00<00:00, 131.35it/s]\n",
      "epoch: 336, loss: 2.8144: 100%|██████████| 100/100 [00:00<00:00, 131.12it/s]\n",
      "epoch: 337, loss: 2.8281: 100%|██████████| 100/100 [00:00<00:00, 113.12it/s]\n",
      "epoch: 338, loss: 2.8003: 100%|██████████| 100/100 [00:00<00:00, 113.64it/s]\n",
      "epoch: 339, loss: 2.8345: 100%|██████████| 100/100 [00:00<00:00, 130.26it/s]\n",
      "epoch: 340, loss: 2.9191: 100%|██████████| 100/100 [00:00<00:00, 120.20it/s]\n",
      "epoch: 341, loss: 2.6705: 100%|██████████| 100/100 [00:00<00:00, 123.84it/s]\n",
      "epoch: 342, loss: 2.9864: 100%|██████████| 100/100 [00:00<00:00, 125.02it/s]\n",
      "epoch: 343, loss: 2.7866: 100%|██████████| 100/100 [00:00<00:00, 128.75it/s]\n",
      "epoch: 344, loss: 2.6231: 100%|██████████| 100/100 [00:00<00:00, 127.25it/s]\n",
      "epoch: 345, loss: 2.7572: 100%|██████████| 100/100 [00:00<00:00, 126.65it/s]\n",
      "epoch: 346, loss: 2.8451: 100%|██████████| 100/100 [00:00<00:00, 128.05it/s]\n",
      "epoch: 347, loss: 2.7760: 100%|██████████| 100/100 [00:00<00:00, 127.52it/s]\n",
      "epoch: 348, loss: 2.8716: 100%|██████████| 100/100 [00:00<00:00, 127.75it/s]\n",
      "epoch: 349, loss: 2.8387: 100%|██████████| 100/100 [00:00<00:00, 127.06it/s]\n",
      "epoch: 350, loss: 2.7775: 100%|██████████| 100/100 [00:00<00:00, 126.95it/s]\n",
      "epoch: 351, loss: 2.7879: 100%|██████████| 100/100 [00:00<00:00, 126.76it/s]\n",
      "epoch: 352, loss: 2.9346: 100%|██████████| 100/100 [00:00<00:00, 127.21it/s]\n",
      "epoch: 353, loss: 2.8336: 100%|██████████| 100/100 [00:00<00:00, 126.73it/s]\n",
      "epoch: 354, loss: 2.7990: 100%|██████████| 100/100 [00:00<00:00, 124.71it/s]\n",
      "epoch: 355, loss: 2.7792: 100%|██████████| 100/100 [00:00<00:00, 122.18it/s]\n",
      "epoch: 356, loss: 2.7116: 100%|██████████| 100/100 [00:00<00:00, 128.68it/s]\n",
      "epoch: 357, loss: 2.9079: 100%|██████████| 100/100 [00:00<00:00, 128.97it/s]\n",
      "epoch: 358, loss: 2.7471: 100%|██████████| 100/100 [00:00<00:00, 128.71it/s]\n",
      "epoch: 359, loss: 2.9049: 100%|██████████| 100/100 [00:00<00:00, 124.90it/s]\n",
      "epoch: 360, loss: 2.7227: 100%|██████████| 100/100 [00:00<00:00, 113.28it/s]\n",
      "epoch: 361, loss: 2.9148: 100%|██████████| 100/100 [00:00<00:00, 123.01it/s]\n",
      "epoch: 362, loss: 2.6865: 100%|██████████| 100/100 [00:00<00:00, 121.65it/s]\n",
      "epoch: 363, loss: 2.8752: 100%|██████████| 100/100 [00:00<00:00, 118.23it/s]\n",
      "epoch: 364, loss: 2.8934: 100%|██████████| 100/100 [00:00<00:00, 127.38it/s]\n",
      "epoch: 365, loss: 2.9371: 100%|██████████| 100/100 [00:00<00:00, 127.38it/s]\n",
      "epoch: 366, loss: 2.7726: 100%|██████████| 100/100 [00:00<00:00, 125.62it/s]\n",
      "epoch: 367, loss: 2.6995: 100%|██████████| 100/100 [00:00<00:00, 125.89it/s]\n",
      "epoch: 368, loss: 2.6921: 100%|██████████| 100/100 [00:00<00:00, 121.14it/s]\n",
      "epoch: 369, loss: 2.8358: 100%|██████████| 100/100 [00:00<00:00, 116.73it/s]\n",
      "epoch: 370, loss: 2.9161: 100%|██████████| 100/100 [00:00<00:00, 120.36it/s]\n",
      "epoch: 371, loss: 2.9917: 100%|██████████| 100/100 [00:00<00:00, 126.53it/s]\n",
      "epoch: 372, loss: 2.8081: 100%|██████████| 100/100 [00:00<00:00, 127.73it/s]\n",
      "epoch: 373, loss: 2.8119: 100%|██████████| 100/100 [00:00<00:00, 127.25it/s]\n",
      "epoch: 374, loss: 2.6867: 100%|██████████| 100/100 [00:00<00:00, 107.39it/s]\n",
      "epoch: 375, loss: 2.8666: 100%|██████████| 100/100 [00:00<00:00, 116.44it/s]\n",
      "epoch: 376, loss: 2.7919: 100%|██████████| 100/100 [00:00<00:00, 112.88it/s]\n",
      "epoch: 377, loss: 2.7457: 100%|██████████| 100/100 [00:00<00:00, 113.03it/s]\n",
      "epoch: 378, loss: 2.9675: 100%|██████████| 100/100 [00:00<00:00, 117.91it/s]\n",
      "epoch: 379, loss: 2.8912: 100%|██████████| 100/100 [00:00<00:00, 117.81it/s]\n",
      "epoch: 380, loss: 2.7757: 100%|██████████| 100/100 [00:00<00:00, 119.72it/s]\n",
      "epoch: 381, loss: 2.7643: 100%|██████████| 100/100 [00:00<00:00, 124.04it/s]\n",
      "epoch: 382, loss: 2.8147: 100%|██████████| 100/100 [00:00<00:00, 122.94it/s]\n",
      "epoch: 383, loss: 2.9524: 100%|██████████| 100/100 [00:00<00:00, 122.99it/s]\n",
      "epoch: 384, loss: 2.8116: 100%|██████████| 100/100 [00:00<00:00, 125.74it/s]\n",
      "epoch: 385, loss: 2.8579: 100%|██████████| 100/100 [00:00<00:00, 118.63it/s]\n",
      "epoch: 386, loss: 2.8484: 100%|██████████| 100/100 [00:00<00:00, 127.02it/s]\n",
      "epoch: 387, loss: 2.8294: 100%|██████████| 100/100 [00:00<00:00, 126.15it/s]\n",
      "epoch: 388, loss: 2.8053: 100%|██████████| 100/100 [00:00<00:00, 126.03it/s]\n",
      "epoch: 389, loss: 2.7964: 100%|██████████| 100/100 [00:00<00:00, 126.91it/s]\n",
      "epoch: 390, loss: 2.9251: 100%|██████████| 100/100 [00:00<00:00, 123.65it/s]\n",
      "epoch: 391, loss: 2.8057: 100%|██████████| 100/100 [00:00<00:00, 118.25it/s]\n",
      "epoch: 392, loss: 2.8078: 100%|██████████| 100/100 [00:00<00:00, 118.61it/s]\n",
      "epoch: 393, loss: 2.6170: 100%|██████████| 100/100 [00:00<00:00, 112.19it/s]\n",
      "epoch: 394, loss: 2.8294: 100%|██████████| 100/100 [00:00<00:00, 112.88it/s]\n",
      "epoch: 395, loss: 2.8072: 100%|██████████| 100/100 [00:00<00:00, 126.41it/s]\n",
      "epoch: 396, loss: 2.5557: 100%|██████████| 100/100 [00:00<00:00, 119.03it/s]\n",
      "epoch: 397, loss: 2.9660: 100%|██████████| 100/100 [00:00<00:00, 110.96it/s]\n",
      "epoch: 398, loss: 2.7204: 100%|██████████| 100/100 [00:00<00:00, 118.39it/s]\n",
      "epoch: 399, loss: 2.9598: 100%|██████████| 100/100 [00:00<00:00, 117.47it/s]\n",
      "epoch: 400, loss: 2.8826: 100%|██████████| 100/100 [00:00<00:00, 116.33it/s]\n",
      "epoch: 401, loss: 2.7617: 100%|██████████| 100/100 [00:00<00:00, 119.43it/s]\n",
      "epoch: 402, loss: 2.8262: 100%|██████████| 100/100 [00:00<00:00, 115.89it/s]\n",
      "epoch: 403, loss: 2.6848: 100%|██████████| 100/100 [00:00<00:00, 125.92it/s]\n",
      "epoch: 404, loss: 2.9212: 100%|██████████| 100/100 [00:00<00:00, 122.63it/s]\n",
      "epoch: 405, loss: 2.9325: 100%|██████████| 100/100 [00:00<00:00, 124.12it/s]\n",
      "epoch: 406, loss: 2.9596: 100%|██████████| 100/100 [00:00<00:00, 132.25it/s]\n",
      "epoch: 407, loss: 2.9025: 100%|██████████| 100/100 [00:00<00:00, 131.26it/s]\n",
      "epoch: 408, loss: 2.8941: 100%|██████████| 100/100 [00:00<00:00, 128.48it/s]\n",
      "epoch: 409, loss: 2.9910: 100%|██████████| 100/100 [00:00<00:00, 127.58it/s]\n",
      "epoch: 410, loss: 2.8880: 100%|██████████| 100/100 [00:00<00:00, 127.22it/s]\n",
      "epoch: 411, loss: 2.9288: 100%|██████████| 100/100 [00:00<00:00, 127.18it/s]\n",
      "epoch: 412, loss: 2.9249: 100%|██████████| 100/100 [00:00<00:00, 126.45it/s]\n",
      "epoch: 413, loss: 2.8241: 100%|██████████| 100/100 [00:00<00:00, 127.15it/s]\n",
      "epoch: 414, loss: 2.6980: 100%|██████████| 100/100 [00:00<00:00, 127.90it/s]\n",
      "epoch: 415, loss: 2.8090: 100%|██████████| 100/100 [00:00<00:00, 127.59it/s]\n",
      "epoch: 416, loss: 2.9211: 100%|██████████| 100/100 [00:00<00:00, 124.02it/s]\n",
      "epoch: 417, loss: 2.8386: 100%|██████████| 100/100 [00:00<00:00, 118.52it/s]\n",
      "epoch: 418, loss: 2.8354: 100%|██████████| 100/100 [00:00<00:00, 124.40it/s]\n",
      "epoch: 419, loss: 2.9526: 100%|██████████| 100/100 [00:00<00:00, 127.10it/s]\n",
      "epoch: 420, loss: 2.9729: 100%|██████████| 100/100 [00:00<00:00, 127.42it/s]\n",
      "epoch: 421, loss: 2.9054: 100%|██████████| 100/100 [00:00<00:00, 126.91it/s]\n",
      "epoch: 422, loss: 2.8189: 100%|██████████| 100/100 [00:00<00:00, 125.27it/s]\n",
      "epoch: 423, loss: 2.8845: 100%|██████████| 100/100 [00:00<00:00, 126.93it/s]\n",
      "epoch: 424, loss: 2.8951: 100%|██████████| 100/100 [00:00<00:00, 127.90it/s]\n",
      "epoch: 425, loss: 2.7648: 100%|██████████| 100/100 [00:00<00:00, 127.34it/s]\n",
      "epoch: 426, loss: 2.8093: 100%|██████████| 100/100 [00:00<00:00, 127.15it/s]\n",
      "epoch: 427, loss: 2.8227: 100%|██████████| 100/100 [00:00<00:00, 128.11it/s]\n",
      "epoch: 428, loss: 2.9359: 100%|██████████| 100/100 [00:00<00:00, 127.65it/s]\n",
      "epoch: 429, loss: 2.7172: 100%|██████████| 100/100 [00:00<00:00, 122.84it/s]\n",
      "epoch: 430, loss: 2.9532: 100%|██████████| 100/100 [00:00<00:00, 124.60it/s]\n",
      "epoch: 431, loss: 2.8497: 100%|██████████| 100/100 [00:00<00:00, 123.55it/s]\n",
      "epoch: 432, loss: 2.8433: 100%|██████████| 100/100 [00:00<00:00, 124.87it/s]\n",
      "epoch: 433, loss: 2.8432: 100%|██████████| 100/100 [00:00<00:00, 124.22it/s]\n",
      "epoch: 434, loss: 2.8466: 100%|██████████| 100/100 [00:00<00:00, 123.23it/s]\n",
      "epoch: 435, loss: 2.8213: 100%|██████████| 100/100 [00:00<00:00, 124.75it/s]\n",
      "epoch: 436, loss: 2.8781: 100%|██████████| 100/100 [00:00<00:00, 125.86it/s]\n",
      "epoch: 437, loss: 2.8460: 100%|██████████| 100/100 [00:00<00:00, 127.44it/s]\n",
      "epoch: 438, loss: 2.7424: 100%|██████████| 100/100 [00:00<00:00, 127.15it/s]\n",
      "epoch: 439, loss: 2.7952: 100%|██████████| 100/100 [00:00<00:00, 126.43it/s]\n",
      "epoch: 440, loss: 2.7603: 100%|██████████| 100/100 [00:00<00:00, 126.85it/s]\n",
      "epoch: 441, loss: 2.7452: 100%|██████████| 100/100 [00:00<00:00, 132.70it/s]\n",
      "epoch: 442, loss: 3.0228: 100%|██████████| 100/100 [00:00<00:00, 121.24it/s]\n",
      "epoch: 443, loss: 2.7140: 100%|██████████| 100/100 [00:00<00:00, 127.61it/s]\n",
      "epoch: 444, loss: 2.9125: 100%|██████████| 100/100 [00:00<00:00, 127.59it/s]\n",
      "epoch: 445, loss: 2.9560: 100%|██████████| 100/100 [00:00<00:00, 127.33it/s]\n",
      "epoch: 446, loss: 2.8379: 100%|██████████| 100/100 [00:00<00:00, 126.51it/s]\n",
      "epoch: 447, loss: 2.8450: 100%|██████████| 100/100 [00:00<00:00, 127.51it/s]\n",
      "epoch: 448, loss: 2.7429: 100%|██████████| 100/100 [00:00<00:00, 127.38it/s]\n",
      "epoch: 449, loss: 2.9126: 100%|██████████| 100/100 [00:00<00:00, 127.77it/s]\n",
      "epoch: 450, loss: 2.8040: 100%|██████████| 100/100 [00:00<00:00, 127.68it/s]\n",
      "epoch: 451, loss: 2.8661: 100%|██████████| 100/100 [00:00<00:00, 127.51it/s]\n",
      "epoch: 452, loss: 2.9678: 100%|██████████| 100/100 [00:00<00:00, 127.36it/s]\n",
      "epoch: 453, loss: 2.7558: 100%|██████████| 100/100 [00:00<00:00, 127.61it/s]\n",
      "epoch: 454, loss: 2.9357: 100%|██████████| 100/100 [00:00<00:00, 127.83it/s]\n",
      "epoch: 455, loss: 2.7233: 100%|██████████| 100/100 [00:00<00:00, 128.09it/s]\n",
      "epoch: 456, loss: 2.8248: 100%|██████████| 100/100 [00:00<00:00, 127.03it/s]\n",
      "epoch: 457, loss: 2.7833: 100%|██████████| 100/100 [00:00<00:00, 123.34it/s]\n",
      "epoch: 458, loss: 2.7747: 100%|██████████| 100/100 [00:00<00:00, 127.21it/s]\n",
      "epoch: 459, loss: 2.8949: 100%|██████████| 100/100 [00:00<00:00, 127.29it/s]\n",
      "epoch: 460, loss: 2.8084: 100%|██████████| 100/100 [00:00<00:00, 128.49it/s]\n",
      "epoch: 461, loss: 2.8449: 100%|██████████| 100/100 [00:00<00:00, 128.50it/s]\n",
      "epoch: 462, loss: 2.7006: 100%|██████████| 100/100 [00:00<00:00, 120.66it/s]\n",
      "epoch: 463, loss: 2.7294: 100%|██████████| 100/100 [00:00<00:00, 125.76it/s]\n",
      "epoch: 464, loss: 2.8781: 100%|██████████| 100/100 [00:00<00:00, 112.47it/s]\n",
      "epoch: 465, loss: 2.8020: 100%|██████████| 100/100 [00:00<00:00, 103.88it/s]\n",
      "epoch: 466, loss: 2.8586: 100%|██████████| 100/100 [00:00<00:00, 104.30it/s]\n",
      "epoch: 467, loss: 2.7780: 100%|██████████| 100/100 [00:00<00:00, 112.66it/s]\n",
      "epoch: 468, loss: 2.8383: 100%|██████████| 100/100 [00:00<00:00, 104.21it/s]\n",
      "epoch: 469, loss: 2.9505: 100%|██████████| 100/100 [00:00<00:00, 107.50it/s]\n",
      "epoch: 470, loss: 2.9215: 100%|██████████| 100/100 [00:00<00:00, 106.22it/s]\n",
      "epoch: 471, loss: 2.7353: 100%|██████████| 100/100 [00:00<00:00, 100.88it/s]\n",
      "epoch: 472, loss: 2.8136: 100%|██████████| 100/100 [00:00<00:00, 103.76it/s]\n",
      "epoch: 473, loss: 2.8017: 100%|██████████| 100/100 [00:00<00:00, 118.98it/s]\n",
      "epoch: 474, loss: 2.8498: 100%|██████████| 100/100 [00:00<00:00, 131.60it/s]\n",
      "epoch: 475, loss: 2.8130: 100%|██████████| 100/100 [00:00<00:00, 132.38it/s]\n",
      "epoch: 476, loss: 3.0261: 100%|██████████| 100/100 [00:00<00:00, 129.46it/s]\n",
      "epoch: 477, loss: 2.9211: 100%|██████████| 100/100 [00:00<00:00, 130.00it/s]\n",
      "epoch: 478, loss: 2.8696: 100%|██████████| 100/100 [00:00<00:00, 133.31it/s]\n",
      "epoch: 479, loss: 2.7368: 100%|██████████| 100/100 [00:00<00:00, 132.27it/s]\n",
      "epoch: 480, loss: 2.8681: 100%|██████████| 100/100 [00:00<00:00, 132.57it/s]\n",
      "epoch: 481, loss: 2.8679: 100%|██████████| 100/100 [00:00<00:00, 133.91it/s]\n",
      "epoch: 482, loss: 2.7648: 100%|██████████| 100/100 [00:00<00:00, 133.23it/s]\n",
      "epoch: 483, loss: 2.8612: 100%|██████████| 100/100 [00:00<00:00, 132.09it/s]\n",
      "epoch: 484, loss: 2.8415: 100%|██████████| 100/100 [00:00<00:00, 117.56it/s]\n",
      "epoch: 485, loss: 2.8955: 100%|██████████| 100/100 [00:00<00:00, 122.68it/s]\n",
      "epoch: 486, loss: 2.7652: 100%|██████████| 100/100 [00:00<00:00, 127.06it/s]\n",
      "epoch: 487, loss: 2.7856: 100%|██████████| 100/100 [00:00<00:00, 126.83it/s]\n",
      "epoch: 488, loss: 2.8612: 100%|██████████| 100/100 [00:00<00:00, 126.53it/s]\n",
      "epoch: 489, loss: 2.7673: 100%|██████████| 100/100 [00:00<00:00, 127.92it/s]\n",
      "epoch: 490, loss: 2.8076: 100%|██████████| 100/100 [00:00<00:00, 127.41it/s]\n",
      "epoch: 491, loss: 2.8904: 100%|██████████| 100/100 [00:00<00:00, 126.79it/s]\n",
      "epoch: 492, loss: 3.0247: 100%|██████████| 100/100 [00:00<00:00, 127.66it/s]\n",
      "epoch: 493, loss: 2.7928: 100%|██████████| 100/100 [00:00<00:00, 127.57it/s]\n",
      "epoch: 494, loss: 2.7877: 100%|██████████| 100/100 [00:00<00:00, 126.89it/s]\n",
      "epoch: 495, loss: 2.6297: 100%|██████████| 100/100 [00:00<00:00, 124.48it/s]\n",
      "epoch: 496, loss: 2.6847: 100%|██████████| 100/100 [00:00<00:00, 122.54it/s]\n",
      "epoch: 497, loss: 2.8920: 100%|██████████| 100/100 [00:00<00:00, 116.78it/s]\n",
      "epoch: 498, loss: 2.8216: 100%|██████████| 100/100 [00:00<00:00, 111.05it/s]\n",
      "epoch: 499, loss: 2.6983: 100%|██████████| 100/100 [00:00<00:00, 101.87it/s]\n",
      "epoch: 500, loss: 2.8090: 100%|██████████| 100/100 [00:00<00:00, 101.64it/s]\n",
      "epoch: 501, loss: 2.7412: 100%|██████████| 100/100 [00:00<00:00, 108.08it/s]\n",
      "epoch: 502, loss: 2.7922: 100%|██████████| 100/100 [00:00<00:00, 110.15it/s]\n",
      "epoch: 503, loss: 2.7874: 100%|██████████| 100/100 [00:00<00:00, 123.34it/s]\n",
      "epoch: 504, loss: 2.8977: 100%|██████████| 100/100 [00:00<00:00, 126.03it/s]\n",
      "epoch: 505, loss: 2.7470: 100%|██████████| 100/100 [00:00<00:00, 120.45it/s]\n",
      "epoch: 506, loss: 2.7760: 100%|██████████| 100/100 [00:00<00:00, 119.39it/s]\n",
      "epoch: 507, loss: 2.9921: 100%|██████████| 100/100 [00:00<00:00, 114.53it/s]\n",
      "epoch: 508, loss: 2.8375: 100%|██████████| 100/100 [00:00<00:00, 125.19it/s]\n",
      "epoch: 509, loss: 2.7828: 100%|██████████| 100/100 [00:00<00:00, 130.31it/s]\n",
      "epoch: 510, loss: 2.8478: 100%|██████████| 100/100 [00:00<00:00, 130.72it/s]\n",
      "epoch: 511, loss: 2.8174: 100%|██████████| 100/100 [00:00<00:00, 130.93it/s]\n",
      "epoch: 512, loss: 2.9637: 100%|██████████| 100/100 [00:00<00:00, 122.55it/s]\n",
      "epoch: 513, loss: 2.7454: 100%|██████████| 100/100 [00:00<00:00, 131.73it/s]\n",
      "epoch: 514, loss: 2.7861: 100%|██████████| 100/100 [00:00<00:00, 124.97it/s]\n",
      "epoch: 515, loss: 2.7114: 100%|██████████| 100/100 [00:00<00:00, 133.78it/s]\n",
      "epoch: 516, loss: 2.9095: 100%|██████████| 100/100 [00:00<00:00, 133.91it/s]\n",
      "epoch: 517, loss: 2.9205: 100%|██████████| 100/100 [00:00<00:00, 113.94it/s]\n",
      "epoch: 518, loss: 2.9848: 100%|██████████| 100/100 [00:00<00:00, 131.76it/s]\n",
      "epoch: 519, loss: 2.8801: 100%|██████████| 100/100 [00:00<00:00, 132.87it/s]\n",
      "epoch: 520, loss: 2.8094: 100%|██████████| 100/100 [00:00<00:00, 125.72it/s]\n",
      "epoch: 521, loss: 2.9624: 100%|██████████| 100/100 [00:00<00:00, 122.21it/s]\n",
      "epoch: 522, loss: 2.8469: 100%|██████████| 100/100 [00:00<00:00, 126.35it/s]\n",
      "epoch: 523, loss: 2.8806: 100%|██████████| 100/100 [00:00<00:00, 126.68it/s]\n",
      "epoch: 524, loss: 2.9031: 100%|██████████| 100/100 [00:00<00:00, 125.26it/s]\n",
      "epoch: 525, loss: 2.7793: 100%|██████████| 100/100 [00:00<00:00, 108.24it/s]\n",
      "epoch: 526, loss: 2.7893: 100%|██████████| 100/100 [00:00<00:00, 125.22it/s]\n",
      "epoch: 527, loss: 2.8826: 100%|██████████| 100/100 [00:00<00:00, 126.83it/s]\n",
      "epoch: 528, loss: 2.7242: 100%|██████████| 100/100 [00:00<00:00, 127.67it/s]\n",
      "epoch: 529, loss: 2.7965: 100%|██████████| 100/100 [00:00<00:00, 126.52it/s]\n",
      "epoch: 530, loss: 2.8501: 100%|██████████| 100/100 [00:00<00:00, 127.04it/s]\n",
      "epoch: 531, loss: 2.8266: 100%|██████████| 100/100 [00:00<00:00, 121.33it/s]\n",
      "epoch: 532, loss: 2.8141: 100%|██████████| 100/100 [00:00<00:00, 119.02it/s]\n",
      "epoch: 533, loss: 2.8671: 100%|██████████| 100/100 [00:00<00:00, 108.74it/s]\n",
      "epoch: 534, loss: 2.8984: 100%|██████████| 100/100 [00:00<00:00, 108.52it/s]\n",
      "epoch: 535, loss: 2.6052: 100%|██████████| 100/100 [00:00<00:00, 116.11it/s]\n",
      "epoch: 536, loss: 2.9650: 100%|██████████| 100/100 [00:00<00:00, 124.37it/s]\n",
      "epoch: 537, loss: 2.7164: 100%|██████████| 100/100 [00:00<00:00, 117.87it/s]\n",
      "epoch: 538, loss: 2.8968: 100%|██████████| 100/100 [00:00<00:00, 120.80it/s]\n",
      "epoch: 539, loss: 2.9537: 100%|██████████| 100/100 [00:00<00:00, 129.58it/s]\n",
      "epoch: 540, loss: 2.7575: 100%|██████████| 100/100 [00:00<00:00, 126.42it/s]\n",
      "epoch: 541, loss: 2.7208: 100%|██████████| 100/100 [00:00<00:00, 127.00it/s]\n",
      "epoch: 542, loss: 2.9359: 100%|██████████| 100/100 [00:00<00:00, 126.61it/s]\n",
      "epoch: 543, loss: 2.9411: 100%|██████████| 100/100 [00:00<00:00, 126.71it/s]\n",
      "epoch: 544, loss: 2.9121: 100%|██████████| 100/100 [00:00<00:00, 112.21it/s]\n",
      "epoch: 545, loss: 2.7464: 100%|██████████| 100/100 [00:00<00:00, 122.08it/s]\n",
      "epoch: 546, loss: 2.7816: 100%|██████████| 100/100 [00:00<00:00, 123.93it/s]\n",
      "epoch: 547, loss: 2.7085: 100%|██████████| 100/100 [00:00<00:00, 126.56it/s]\n",
      "epoch: 548, loss: 2.8146: 100%|██████████| 100/100 [00:00<00:00, 126.48it/s]\n",
      "epoch: 549, loss: 2.7789: 100%|██████████| 100/100 [00:00<00:00, 127.20it/s]\n",
      "epoch: 550, loss: 2.6795: 100%|██████████| 100/100 [00:00<00:00, 125.66it/s]\n",
      "epoch: 551, loss: 2.8968: 100%|██████████| 100/100 [00:00<00:00, 124.04it/s]\n",
      "epoch: 552, loss: 2.9724: 100%|██████████| 100/100 [00:00<00:00, 115.79it/s]\n",
      "epoch: 553, loss: 2.7979: 100%|██████████| 100/100 [00:00<00:00, 130.23it/s]\n",
      "epoch: 554, loss: 2.7532: 100%|██████████| 100/100 [00:00<00:00, 131.48it/s]\n",
      "epoch: 555, loss: 2.9116: 100%|██████████| 100/100 [00:00<00:00, 131.13it/s]\n",
      "epoch: 556, loss: 2.8595: 100%|██████████| 100/100 [00:00<00:00, 127.76it/s]\n",
      "epoch: 557, loss: 2.8646: 100%|██████████| 100/100 [00:00<00:00, 120.15it/s]\n",
      "epoch: 558, loss: 2.7621: 100%|██████████| 100/100 [00:00<00:00, 124.14it/s]\n",
      "epoch: 559, loss: 2.9468: 100%|██████████| 100/100 [00:00<00:00, 124.16it/s]\n",
      "epoch: 560, loss: 2.9662: 100%|██████████| 100/100 [00:00<00:00, 131.51it/s]\n",
      "epoch: 561, loss: 2.9795: 100%|██████████| 100/100 [00:00<00:00, 130.63it/s]\n",
      "epoch: 562, loss: 3.0452: 100%|██████████| 100/100 [00:00<00:00, 130.56it/s]\n",
      "epoch: 563, loss: 2.8812: 100%|██████████| 100/100 [00:00<00:00, 130.63it/s]\n",
      "epoch: 564, loss: 3.0521: 100%|██████████| 100/100 [00:00<00:00, 132.09it/s]\n",
      "epoch: 565, loss: 2.8851: 100%|██████████| 100/100 [00:00<00:00, 131.69it/s]\n",
      "epoch: 566, loss: 2.8491: 100%|██████████| 100/100 [00:00<00:00, 132.38it/s]\n",
      "epoch: 567, loss: 2.8029: 100%|██████████| 100/100 [00:00<00:00, 132.44it/s]\n",
      "epoch: 568, loss: 2.8099: 100%|██████████| 100/100 [00:00<00:00, 132.01it/s]\n",
      "epoch: 569, loss: 2.7098: 100%|██████████| 100/100 [00:00<00:00, 131.56it/s]\n",
      "epoch: 570, loss: 2.7805: 100%|██████████| 100/100 [00:00<00:00, 131.75it/s]\n",
      "epoch: 571, loss: 2.9932: 100%|██████████| 100/100 [00:00<00:00, 131.03it/s]\n",
      "epoch: 572, loss: 2.7742: 100%|██████████| 100/100 [00:00<00:00, 131.74it/s]\n",
      "epoch: 573, loss: 2.5848: 100%|██████████| 100/100 [00:00<00:00, 132.70it/s]\n",
      "epoch: 574, loss: 2.8779: 100%|██████████| 100/100 [00:00<00:00, 129.45it/s]\n",
      "epoch: 575, loss: 2.7184: 100%|██████████| 100/100 [00:00<00:00, 120.87it/s]\n",
      "epoch: 576, loss: 2.9146: 100%|██████████| 100/100 [00:00<00:00, 118.67it/s]\n",
      "epoch: 577, loss: 2.7548: 100%|██████████| 100/100 [00:00<00:00, 105.67it/s]\n",
      "epoch: 578, loss: 2.8906: 100%|██████████| 100/100 [00:00<00:00, 117.97it/s]\n",
      "epoch: 579, loss: 2.8183: 100%|██████████| 100/100 [00:00<00:00, 125.24it/s]\n",
      "epoch: 580, loss: 2.9338: 100%|██████████| 100/100 [00:00<00:00, 121.77it/s]\n",
      "epoch: 581, loss: 2.8135: 100%|██████████| 100/100 [00:00<00:00, 121.42it/s]\n",
      "epoch: 582, loss: 2.8014: 100%|██████████| 100/100 [00:00<00:00, 121.61it/s]\n",
      "epoch: 583, loss: 2.8169: 100%|██████████| 100/100 [00:00<00:00, 117.95it/s]\n",
      "epoch: 584, loss: 2.8160: 100%|██████████| 100/100 [00:00<00:00, 100.55it/s]\n",
      "epoch: 585, loss: 2.8777: 100%|██████████| 100/100 [00:00<00:00, 106.89it/s]\n",
      "epoch: 586, loss: 2.8975: 100%|██████████| 100/100 [00:00<00:00, 120.70it/s]\n",
      "epoch: 587, loss: 2.9583: 100%|██████████| 100/100 [00:00<00:00, 121.65it/s]\n",
      "epoch: 588, loss: 2.7083: 100%|██████████| 100/100 [00:00<00:00, 126.25it/s]\n",
      "epoch: 589, loss: 2.9225: 100%|██████████| 100/100 [00:00<00:00, 126.98it/s]\n",
      "epoch: 590, loss: 2.9780: 100%|██████████| 100/100 [00:00<00:00, 127.06it/s]\n",
      "epoch: 591, loss: 2.8909: 100%|██████████| 100/100 [00:00<00:00, 119.97it/s]\n",
      "epoch: 592, loss: 2.7946: 100%|██████████| 100/100 [00:00<00:00, 125.11it/s]\n",
      "epoch: 593, loss: 2.8316: 100%|██████████| 100/100 [00:00<00:00, 122.37it/s]\n",
      "epoch: 594, loss: 2.7894: 100%|██████████| 100/100 [00:00<00:00, 132.50it/s]\n",
      "epoch: 595, loss: 2.7991: 100%|██████████| 100/100 [00:00<00:00, 129.17it/s]\n",
      "epoch: 596, loss: 2.7884: 100%|██████████| 100/100 [00:00<00:00, 126.85it/s]\n",
      "epoch: 597, loss: 2.9157: 100%|██████████| 100/100 [00:00<00:00, 131.62it/s]\n",
      "epoch: 598, loss: 2.9325: 100%|██████████| 100/100 [00:00<00:00, 129.30it/s]\n",
      "epoch: 599, loss: 2.7830: 100%|██████████| 100/100 [00:00<00:00, 128.15it/s]\n",
      "epoch: 600, loss: 2.8258: 100%|██████████| 100/100 [00:00<00:00, 129.03it/s]\n",
      "epoch: 601, loss: 2.8831: 100%|██████████| 100/100 [00:00<00:00, 127.96it/s]\n",
      "epoch: 602, loss: 2.8672: 100%|██████████| 100/100 [00:00<00:00, 123.25it/s]\n",
      "epoch: 603, loss: 2.7986: 100%|██████████| 100/100 [00:00<00:00, 120.32it/s]\n",
      "epoch: 604, loss: 2.7820: 100%|██████████| 100/100 [00:00<00:00, 119.45it/s]\n",
      "epoch: 605, loss: 2.8588: 100%|██████████| 100/100 [00:00<00:00, 119.30it/s]\n",
      "epoch: 606, loss: 2.7909: 100%|██████████| 100/100 [00:00<00:00, 118.92it/s]\n",
      "epoch: 607, loss: 2.7126: 100%|██████████| 100/100 [00:00<00:00, 115.38it/s]\n",
      "epoch: 608, loss: 2.7115: 100%|██████████| 100/100 [00:00<00:00, 117.94it/s]\n",
      "epoch: 609, loss: 2.7366: 100%|██████████| 100/100 [00:00<00:00, 120.61it/s]\n",
      "epoch: 610, loss: 2.7762: 100%|██████████| 100/100 [00:00<00:00, 118.86it/s]\n",
      "epoch: 611, loss: 2.8038: 100%|██████████| 100/100 [00:00<00:00, 125.04it/s]\n",
      "epoch: 612, loss: 2.8807: 100%|██████████| 100/100 [00:00<00:00, 126.91it/s]\n",
      "epoch: 613, loss: 2.8227: 100%|██████████| 100/100 [00:00<00:00, 126.32it/s]\n",
      "epoch: 614, loss: 2.7605: 100%|██████████| 100/100 [00:00<00:00, 126.92it/s]\n",
      "epoch: 615, loss: 2.9309: 100%|██████████| 100/100 [00:00<00:00, 123.26it/s]\n",
      "epoch: 616, loss: 2.8052: 100%|██████████| 100/100 [00:00<00:00, 125.23it/s]\n",
      "epoch: 617, loss: 2.7811: 100%|██████████| 100/100 [00:00<00:00, 125.99it/s]\n",
      "epoch: 618, loss: 2.9017: 100%|██████████| 100/100 [00:00<00:00, 126.73it/s]\n",
      "epoch: 619, loss: 2.8671: 100%|██████████| 100/100 [00:00<00:00, 116.79it/s]\n",
      "epoch: 620, loss: 2.7061: 100%|██████████| 100/100 [00:00<00:00, 127.16it/s]\n",
      "epoch: 621, loss: 2.8553: 100%|██████████| 100/100 [00:00<00:00, 125.24it/s]\n",
      "epoch: 622, loss: 2.8196: 100%|██████████| 100/100 [00:00<00:00, 126.01it/s]\n",
      "epoch: 623, loss: 2.6668: 100%|██████████| 100/100 [00:00<00:00, 125.65it/s]\n",
      "epoch: 624, loss: 2.8815: 100%|██████████| 100/100 [00:00<00:00, 126.70it/s]\n",
      "epoch: 625, loss: 2.8267: 100%|██████████| 100/100 [00:00<00:00, 127.25it/s]\n",
      "epoch: 626, loss: 2.8757: 100%|██████████| 100/100 [00:00<00:00, 124.17it/s]\n",
      "epoch: 627, loss: 2.9359: 100%|██████████| 100/100 [00:00<00:00, 125.20it/s]\n",
      "epoch: 628, loss: 2.8993: 100%|██████████| 100/100 [00:00<00:00, 101.71it/s]\n",
      "epoch: 629, loss: 2.8860: 100%|██████████| 100/100 [00:00<00:00, 103.86it/s]\n",
      "epoch: 630, loss: 2.7926: 100%|██████████| 100/100 [00:00<00:00, 106.42it/s]\n",
      "epoch: 631, loss: 2.7302: 100%|██████████| 100/100 [00:00<00:00, 124.65it/s]\n",
      "epoch: 632, loss: 2.7053: 100%|██████████| 100/100 [00:00<00:00, 119.56it/s]\n",
      "epoch: 633, loss: 2.8476: 100%|██████████| 100/100 [00:00<00:00, 125.38it/s]\n",
      "epoch: 634, loss: 2.6618: 100%|██████████| 100/100 [00:00<00:00, 126.62it/s]\n",
      "epoch: 635, loss: 2.8293: 100%|██████████| 100/100 [00:00<00:00, 116.40it/s]\n",
      "epoch: 636, loss: 2.8051: 100%|██████████| 100/100 [00:00<00:00, 127.10it/s]\n",
      "epoch: 637, loss: 2.8326: 100%|██████████| 100/100 [00:00<00:00, 126.62it/s]\n",
      "epoch: 638, loss: 2.8919: 100%|██████████| 100/100 [00:00<00:00, 127.02it/s]\n",
      "epoch: 639, loss: 2.8521: 100%|██████████| 100/100 [00:00<00:00, 126.05it/s]\n",
      "epoch: 640, loss: 2.7463: 100%|██████████| 100/100 [00:00<00:00, 124.14it/s]\n",
      "epoch: 641, loss: 2.8267: 100%|██████████| 100/100 [00:00<00:00, 102.35it/s]\n",
      "epoch: 642, loss: 2.9174: 100%|██████████| 100/100 [00:00<00:00, 105.99it/s]\n",
      "epoch: 643, loss: 2.8429: 100%|██████████| 100/100 [00:00<00:00, 119.57it/s]\n",
      "epoch: 644, loss: 2.8825: 100%|██████████| 100/100 [00:00<00:00, 120.11it/s]\n",
      "epoch: 645, loss: 3.0002: 100%|██████████| 100/100 [00:00<00:00, 120.59it/s]\n",
      "epoch: 646, loss: 2.8450: 100%|██████████| 100/100 [00:00<00:00, 126.40it/s]\n",
      "epoch: 647, loss: 2.7394: 100%|██████████| 100/100 [00:00<00:00, 118.65it/s]\n",
      "epoch: 648, loss: 2.8008: 100%|██████████| 100/100 [00:00<00:00, 116.50it/s]\n",
      "epoch: 649, loss: 2.9756: 100%|██████████| 100/100 [00:00<00:00, 124.73it/s]\n",
      "epoch: 650, loss: 2.6654: 100%|██████████| 100/100 [00:00<00:00, 119.43it/s]\n",
      "epoch: 651, loss: 2.6400: 100%|██████████| 100/100 [00:00<00:00, 121.81it/s]\n",
      "epoch: 652, loss: 2.8855: 100%|██████████| 100/100 [00:00<00:00, 117.69it/s]\n",
      "epoch: 653, loss: 2.9228: 100%|██████████| 100/100 [00:00<00:00, 114.12it/s]\n",
      "epoch: 654, loss: 2.7572: 100%|██████████| 100/100 [00:00<00:00, 121.39it/s]\n",
      "epoch: 655, loss: 2.8779: 100%|██████████| 100/100 [00:00<00:00, 122.13it/s]\n",
      "epoch: 656, loss: 2.8947: 100%|██████████| 100/100 [00:00<00:00, 121.69it/s]\n",
      "epoch: 657, loss: 2.7571: 100%|██████████| 100/100 [00:00<00:00, 116.79it/s]\n",
      "epoch: 658, loss: 2.9489: 100%|██████████| 100/100 [00:00<00:00, 121.36it/s]\n",
      "epoch: 659, loss: 2.6352: 100%|██████████| 100/100 [00:00<00:00, 119.36it/s]\n",
      "epoch: 660, loss: 2.8050: 100%|██████████| 100/100 [00:00<00:00, 121.36it/s]\n",
      "epoch: 661, loss: 2.7650: 100%|██████████| 100/100 [00:00<00:00, 116.49it/s]\n",
      "epoch: 662, loss: 2.8619: 100%|██████████| 100/100 [00:00<00:00, 121.50it/s]\n",
      "epoch: 663, loss: 2.9400: 100%|██████████| 100/100 [00:00<00:00, 102.53it/s]\n",
      "epoch: 664, loss: 2.7612: 100%|██████████| 100/100 [00:01<00:00, 92.32it/s]\n",
      "epoch: 665, loss: 2.9923: 100%|██████████| 100/100 [00:01<00:00, 92.71it/s]\n",
      "epoch: 666, loss: 2.7393: 100%|██████████| 100/100 [00:01<00:00, 88.49it/s]\n",
      "epoch: 667, loss: 2.8819: 100%|██████████| 100/100 [00:01<00:00, 86.90it/s]\n",
      "epoch: 668, loss: 2.9656: 100%|██████████| 100/100 [00:01<00:00, 86.18it/s]\n",
      "epoch: 669, loss: 2.8989: 100%|██████████| 100/100 [00:00<00:00, 108.68it/s]\n",
      "epoch: 670, loss: 2.8919: 100%|██████████| 100/100 [00:00<00:00, 112.26it/s]\n",
      "epoch: 671, loss: 2.8747: 100%|██████████| 100/100 [00:00<00:00, 127.39it/s]\n",
      "epoch: 672, loss: 2.6958: 100%|██████████| 100/100 [00:00<00:00, 119.25it/s]\n",
      "epoch: 673, loss: 2.8312: 100%|██████████| 100/100 [00:00<00:00, 105.03it/s]\n",
      "epoch: 674, loss: 2.6795: 100%|██████████| 100/100 [00:00<00:00, 126.87it/s]\n",
      "epoch: 675, loss: 2.9144: 100%|██████████| 100/100 [00:00<00:00, 124.69it/s]\n",
      "epoch: 676, loss: 2.8939: 100%|██████████| 100/100 [00:00<00:00, 126.13it/s]\n",
      "epoch: 677, loss: 2.8291: 100%|██████████| 100/100 [00:00<00:00, 105.88it/s]\n",
      "epoch: 678, loss: 2.8123: 100%|██████████| 100/100 [00:00<00:00, 103.43it/s]\n",
      "epoch: 679, loss: 2.7385: 100%|██████████| 100/100 [00:00<00:00, 125.81it/s]\n",
      "epoch: 680, loss: 2.9651: 100%|██████████| 100/100 [00:00<00:00, 125.72it/s]\n",
      "epoch: 681, loss: 2.9781: 100%|██████████| 100/100 [00:00<00:00, 129.28it/s]\n",
      "epoch: 682, loss: 2.7117: 100%|██████████| 100/100 [00:00<00:00, 129.55it/s]\n",
      "epoch: 683, loss: 2.8675: 100%|██████████| 100/100 [00:00<00:00, 126.44it/s]\n",
      "epoch: 684, loss: 2.9520: 100%|██████████| 100/100 [00:00<00:00, 120.03it/s]\n",
      "epoch: 685, loss: 2.8438: 100%|██████████| 100/100 [00:00<00:00, 120.58it/s]\n",
      "epoch: 686, loss: 2.7919: 100%|██████████| 100/100 [00:00<00:00, 112.40it/s]\n",
      "epoch: 687, loss: 2.8968: 100%|██████████| 100/100 [00:00<00:00, 115.25it/s]\n",
      "epoch: 688, loss: 2.7929: 100%|██████████| 100/100 [00:00<00:00, 117.55it/s]\n",
      "epoch: 689, loss: 2.8407: 100%|██████████| 100/100 [00:00<00:00, 118.68it/s]\n",
      "epoch: 690, loss: 2.5693: 100%|██████████| 100/100 [00:00<00:00, 132.29it/s]\n",
      "epoch: 691, loss: 2.8575: 100%|██████████| 100/100 [00:00<00:00, 132.46it/s]\n",
      "epoch: 692, loss: 2.8006: 100%|██████████| 100/100 [00:00<00:00, 132.60it/s]\n",
      "epoch: 693, loss: 2.9488: 100%|██████████| 100/100 [00:00<00:00, 133.56it/s]\n",
      "epoch: 694, loss: 2.7257: 100%|██████████| 100/100 [00:00<00:00, 133.80it/s]\n",
      "epoch: 695, loss: 2.8732: 100%|██████████| 100/100 [00:00<00:00, 133.05it/s]\n",
      "epoch: 696, loss: 2.9293: 100%|██████████| 100/100 [00:00<00:00, 129.37it/s]\n",
      "epoch: 697, loss: 2.7294: 100%|██████████| 100/100 [00:00<00:00, 126.93it/s]\n",
      "epoch: 698, loss: 2.8035: 100%|██████████| 100/100 [00:00<00:00, 133.44it/s]\n",
      "epoch: 699, loss: 2.8862: 100%|██████████| 100/100 [00:00<00:00, 133.39it/s]\n",
      "epoch: 700, loss: 2.8266: 100%|██████████| 100/100 [00:00<00:00, 133.07it/s]\n",
      "epoch: 701, loss: 2.7717: 100%|██████████| 100/100 [00:00<00:00, 133.27it/s]\n",
      "epoch: 702, loss: 2.7834: 100%|██████████| 100/100 [00:00<00:00, 133.07it/s]\n",
      "epoch: 703, loss: 2.8627: 100%|██████████| 100/100 [00:00<00:00, 133.43it/s]\n",
      "epoch: 704, loss: 2.7964: 100%|██████████| 100/100 [00:00<00:00, 114.25it/s]\n",
      "epoch: 705, loss: 2.8056: 100%|██████████| 100/100 [00:00<00:00, 116.67it/s]\n",
      "epoch: 706, loss: 2.7772: 100%|██████████| 100/100 [00:00<00:00, 120.48it/s]\n",
      "epoch: 707, loss: 2.8016: 100%|██████████| 100/100 [00:00<00:00, 116.39it/s]\n",
      "epoch: 708, loss: 2.8410: 100%|██████████| 100/100 [00:00<00:00, 123.14it/s]\n",
      "epoch: 709, loss: 2.9369: 100%|██████████| 100/100 [00:00<00:00, 126.13it/s]\n",
      "epoch: 710, loss: 2.6524: 100%|██████████| 100/100 [00:00<00:00, 127.50it/s]\n",
      "epoch: 711, loss: 2.9178: 100%|██████████| 100/100 [00:00<00:00, 127.69it/s]\n",
      "epoch: 712, loss: 2.9279: 100%|██████████| 100/100 [00:00<00:00, 124.59it/s]\n",
      "epoch: 713, loss: 2.7964: 100%|██████████| 100/100 [00:00<00:00, 117.38it/s]\n",
      "epoch: 714, loss: 2.8677: 100%|██████████| 100/100 [00:00<00:00, 124.00it/s]\n",
      "epoch: 715, loss: 2.9145: 100%|██████████| 100/100 [00:00<00:00, 127.27it/s]\n",
      "epoch: 716, loss: 2.9435: 100%|██████████| 100/100 [00:00<00:00, 127.71it/s]\n",
      "epoch: 717, loss: 2.7316: 100%|██████████| 100/100 [00:00<00:00, 126.52it/s]\n",
      "epoch: 718, loss: 2.8279: 100%|██████████| 100/100 [00:00<00:00, 127.30it/s]\n",
      "epoch: 719, loss: 2.7617: 100%|██████████| 100/100 [00:00<00:00, 127.59it/s]\n",
      "epoch: 720, loss: 2.8144: 100%|██████████| 100/100 [00:00<00:00, 127.39it/s]\n",
      "epoch: 721, loss: 2.8006: 100%|██████████| 100/100 [00:00<00:00, 124.31it/s]\n",
      "epoch: 722, loss: 2.9175: 100%|██████████| 100/100 [00:00<00:00, 120.22it/s]\n",
      "epoch: 723, loss: 2.8543: 100%|██████████| 100/100 [00:01<00:00, 98.04it/s]\n",
      "epoch: 724, loss: 2.9814: 100%|██████████| 100/100 [00:00<00:00, 114.66it/s]\n",
      "epoch: 725, loss: 2.8821: 100%|██████████| 100/100 [00:00<00:00, 118.94it/s]\n",
      "epoch: 726, loss: 2.8684: 100%|██████████| 100/100 [00:00<00:00, 114.91it/s]\n",
      "epoch: 727, loss: 2.7959: 100%|██████████| 100/100 [00:00<00:00, 120.07it/s]\n",
      "epoch: 728, loss: 2.8770: 100%|██████████| 100/100 [00:00<00:00, 117.38it/s]\n",
      "epoch: 729, loss: 2.9795: 100%|██████████| 100/100 [00:00<00:00, 104.68it/s]\n",
      "epoch: 730, loss: 2.7716: 100%|██████████| 100/100 [00:00<00:00, 121.67it/s]\n",
      "epoch: 731, loss: 2.8716: 100%|██████████| 100/100 [00:00<00:00, 120.32it/s]\n",
      "epoch: 732, loss: 2.9260: 100%|██████████| 100/100 [00:00<00:00, 117.65it/s]\n",
      "epoch: 733, loss: 2.6896: 100%|██████████| 100/100 [00:00<00:00, 116.94it/s]\n",
      "epoch: 734, loss: 2.9012: 100%|██████████| 100/100 [00:00<00:00, 122.05it/s]\n",
      "epoch: 735, loss: 2.7901: 100%|██████████| 100/100 [00:00<00:00, 116.63it/s]\n",
      "epoch: 736, loss: 2.8607: 100%|██████████| 100/100 [00:00<00:00, 124.39it/s]\n",
      "epoch: 737, loss: 2.8809: 100%|██████████| 100/100 [00:00<00:00, 127.44it/s]\n",
      "epoch: 738, loss: 2.9304: 100%|██████████| 100/100 [00:00<00:00, 127.74it/s]\n",
      "epoch: 739, loss: 2.8085: 100%|██████████| 100/100 [00:00<00:00, 127.66it/s]\n",
      "epoch: 740, loss: 2.9847: 100%|██████████| 100/100 [00:00<00:00, 126.99it/s]\n",
      "epoch: 741, loss: 2.8839: 100%|██████████| 100/100 [00:00<00:00, 127.62it/s]\n",
      "epoch: 742, loss: 2.8354: 100%|██████████| 100/100 [00:00<00:00, 126.96it/s]\n",
      "epoch: 743, loss: 2.8245: 100%|██████████| 100/100 [00:00<00:00, 127.21it/s]\n",
      "epoch: 744, loss: 2.8576: 100%|██████████| 100/100 [00:00<00:00, 127.14it/s]\n",
      "epoch: 745, loss: 2.9320: 100%|██████████| 100/100 [00:00<00:00, 113.49it/s]\n",
      "epoch: 746, loss: 2.9539: 100%|██████████| 100/100 [00:00<00:00, 111.22it/s]\n",
      "epoch: 747, loss: 2.9655: 100%|██████████| 100/100 [00:00<00:00, 110.01it/s]\n",
      "epoch: 748, loss: 2.7936: 100%|██████████| 100/100 [00:00<00:00, 106.50it/s]\n",
      "epoch: 749, loss: 2.8953: 100%|██████████| 100/100 [00:00<00:00, 112.58it/s]\n",
      "epoch: 750, loss: 2.8823: 100%|██████████| 100/100 [00:00<00:00, 123.56it/s]\n",
      "epoch: 751, loss: 2.7567: 100%|██████████| 100/100 [00:00<00:00, 127.55it/s]\n",
      "epoch: 752, loss: 2.7338: 100%|██████████| 100/100 [00:00<00:00, 126.60it/s]\n",
      "epoch: 753, loss: 2.7597: 100%|██████████| 100/100 [00:00<00:00, 124.10it/s]\n",
      "epoch: 754, loss: 2.9198: 100%|██████████| 100/100 [00:00<00:00, 114.91it/s]\n",
      "epoch: 755, loss: 3.0077: 100%|██████████| 100/100 [00:00<00:00, 114.61it/s]\n",
      "epoch: 756, loss: 2.7879: 100%|██████████| 100/100 [00:00<00:00, 116.06it/s]\n",
      "epoch: 757, loss: 2.7760: 100%|██████████| 100/100 [00:00<00:00, 127.31it/s]\n",
      "epoch: 758, loss: 2.8681: 100%|██████████| 100/100 [00:00<00:00, 118.43it/s]\n",
      "epoch: 759, loss: 3.0612: 100%|██████████| 100/100 [00:00<00:00, 127.60it/s]\n",
      "epoch: 760, loss: 2.7487: 100%|██████████| 100/100 [00:00<00:00, 126.55it/s]\n",
      "epoch: 761, loss: 2.8626: 100%|██████████| 100/100 [00:00<00:00, 122.51it/s]\n",
      "epoch: 762, loss: 2.8584: 100%|██████████| 100/100 [00:00<00:00, 131.93it/s]\n",
      "epoch: 763, loss: 2.8515: 100%|██████████| 100/100 [00:00<00:00, 117.23it/s]\n",
      "epoch: 764, loss: 2.8658: 100%|██████████| 100/100 [00:00<00:00, 117.28it/s]\n",
      "epoch: 765, loss: 2.9204: 100%|██████████| 100/100 [00:00<00:00, 126.73it/s]\n",
      "epoch: 766, loss: 2.6825: 100%|██████████| 100/100 [00:00<00:00, 116.65it/s]\n",
      "epoch: 767, loss: 2.9107: 100%|██████████| 100/100 [00:00<00:00, 114.34it/s]\n",
      "epoch: 768, loss: 2.9941: 100%|██████████| 100/100 [00:00<00:00, 108.27it/s]\n",
      "epoch: 769, loss: 2.8540: 100%|██████████| 100/100 [00:00<00:00, 122.41it/s]\n",
      "epoch: 770, loss: 2.8585: 100%|██████████| 100/100 [00:00<00:00, 126.20it/s]\n",
      "epoch: 771, loss: 2.8310: 100%|██████████| 100/100 [00:00<00:00, 126.52it/s]\n",
      "epoch: 772, loss: 2.9351: 100%|██████████| 100/100 [00:00<00:00, 126.94it/s]\n",
      "epoch: 773, loss: 2.8583: 100%|██████████| 100/100 [00:00<00:00, 125.26it/s]\n",
      "epoch: 774, loss: 2.8729: 100%|██████████| 100/100 [00:00<00:00, 126.68it/s]\n",
      "epoch: 775, loss: 2.8235: 100%|██████████| 100/100 [00:00<00:00, 127.15it/s]\n",
      "epoch: 776, loss: 2.9343: 100%|██████████| 100/100 [00:00<00:00, 125.79it/s]\n",
      "epoch: 777, loss: 2.9454: 100%|██████████| 100/100 [00:00<00:00, 126.16it/s]\n",
      "epoch: 778, loss: 2.7709: 100%|██████████| 100/100 [00:00<00:00, 126.67it/s]\n",
      "epoch: 779, loss: 2.7066: 100%|██████████| 100/100 [00:00<00:00, 127.28it/s]\n",
      "epoch: 780, loss: 2.7285: 100%|██████████| 100/100 [00:00<00:00, 126.75it/s]\n",
      "epoch: 781, loss: 2.9987: 100%|██████████| 100/100 [00:00<00:00, 126.59it/s]\n",
      "epoch: 782, loss: 2.7608: 100%|██████████| 100/100 [00:00<00:00, 127.91it/s]\n",
      "epoch: 783, loss: 2.8535: 100%|██████████| 100/100 [00:00<00:00, 127.72it/s]\n",
      "epoch: 784, loss: 2.9290: 100%|██████████| 100/100 [00:00<00:00, 126.61it/s]\n",
      "epoch: 785, loss: 2.9766: 100%|██████████| 100/100 [00:00<00:00, 127.11it/s]\n",
      "epoch: 786, loss: 2.8419: 100%|██████████| 100/100 [00:00<00:00, 127.31it/s]\n",
      "epoch: 787, loss: 2.6642: 100%|██████████| 100/100 [00:00<00:00, 127.44it/s]\n",
      "epoch: 788, loss: 2.8795: 100%|██████████| 100/100 [00:00<00:00, 126.00it/s]\n",
      "epoch: 789, loss: 2.9591: 100%|██████████| 100/100 [00:00<00:00, 127.20it/s]\n",
      "epoch: 790, loss: 2.9666: 100%|██████████| 100/100 [00:00<00:00, 126.40it/s]\n",
      "epoch: 791, loss: 2.9084: 100%|██████████| 100/100 [00:00<00:00, 126.08it/s]\n",
      "epoch: 792, loss: 3.0266: 100%|██████████| 100/100 [00:00<00:00, 126.91it/s]\n",
      "epoch: 793, loss: 2.8904: 100%|██████████| 100/100 [00:00<00:00, 126.46it/s]\n",
      "epoch: 794, loss: 2.9223: 100%|██████████| 100/100 [00:00<00:00, 119.65it/s]\n",
      "epoch: 795, loss: 2.9482: 100%|██████████| 100/100 [00:00<00:00, 119.82it/s]\n",
      "epoch: 796, loss: 2.8275: 100%|██████████| 100/100 [00:00<00:00, 121.12it/s]\n",
      "epoch: 797, loss: 2.7966: 100%|██████████| 100/100 [00:00<00:00, 115.41it/s]\n",
      "epoch: 798, loss: 2.7222: 100%|██████████| 100/100 [00:00<00:00, 120.18it/s]\n",
      "epoch: 799, loss: 2.8643: 100%|██████████| 100/100 [00:00<00:00, 115.28it/s]\n",
      "epoch: 800, loss: 2.7198: 100%|██████████| 100/100 [00:00<00:00, 112.99it/s]\n",
      "epoch: 801, loss: 2.7335: 100%|██████████| 100/100 [00:00<00:00, 112.10it/s]\n",
      "epoch: 802, loss: 2.9140: 100%|██████████| 100/100 [00:00<00:00, 118.01it/s]\n",
      "epoch: 803, loss: 2.9573: 100%|██████████| 100/100 [00:00<00:00, 112.78it/s]\n",
      "epoch: 804, loss: 2.8607: 100%|██████████| 100/100 [00:00<00:00, 125.53it/s]\n",
      "epoch: 805, loss: 2.9714: 100%|██████████| 100/100 [00:00<00:00, 102.07it/s]\n",
      "epoch: 806, loss: 2.8886: 100%|██████████| 100/100 [00:00<00:00, 104.36it/s]\n",
      "epoch: 807, loss: 2.7046: 100%|██████████| 100/100 [00:00<00:00, 106.66it/s]\n",
      "epoch: 808, loss: 2.8534: 100%|██████████| 100/100 [00:00<00:00, 113.74it/s]\n",
      "epoch: 809, loss: 2.7408: 100%|██████████| 100/100 [00:00<00:00, 127.03it/s]\n",
      "epoch: 810, loss: 2.6067: 100%|██████████| 100/100 [00:00<00:00, 101.27it/s]\n",
      "epoch: 811, loss: 2.8414: 100%|██████████| 100/100 [00:01<00:00, 90.79it/s]\n",
      "epoch: 812, loss: 2.7385: 100%|██████████| 100/100 [00:01<00:00, 92.57it/s]\n",
      "epoch: 813, loss: 2.8824: 100%|██████████| 100/100 [00:01<00:00, 91.44it/s]\n",
      "epoch: 814, loss: 2.8833: 100%|██████████| 100/100 [00:00<00:00, 108.98it/s]\n",
      "epoch: 815, loss: 2.8946: 100%|██████████| 100/100 [00:00<00:00, 125.44it/s]\n",
      "epoch: 816, loss: 2.7280: 100%|██████████| 100/100 [00:00<00:00, 120.75it/s]\n",
      "epoch: 817, loss: 2.8647: 100%|██████████| 100/100 [00:00<00:00, 113.04it/s]\n",
      "epoch: 818, loss: 2.7067: 100%|██████████| 100/100 [00:00<00:00, 102.06it/s]\n",
      "epoch: 819, loss: 2.8713: 100%|██████████| 100/100 [00:00<00:00, 101.90it/s]\n",
      "epoch: 820, loss: 3.0301: 100%|██████████| 100/100 [00:00<00:00, 104.22it/s]\n",
      "epoch: 821, loss: 2.7844: 100%|██████████| 100/100 [00:00<00:00, 120.33it/s]\n",
      "epoch: 822, loss: 2.8284: 100%|██████████| 100/100 [00:00<00:00, 123.03it/s]\n",
      "epoch: 823, loss: 2.9912: 100%|██████████| 100/100 [00:00<00:00, 115.36it/s]\n",
      "epoch: 824, loss: 2.7893: 100%|██████████| 100/100 [00:00<00:00, 126.30it/s]\n",
      "epoch: 825, loss: 2.6896: 100%|██████████| 100/100 [00:00<00:00, 131.18it/s]\n",
      "epoch: 826, loss: 2.7177: 100%|██████████| 100/100 [00:00<00:00, 128.44it/s]\n",
      "epoch: 827, loss: 2.8781: 100%|██████████| 100/100 [00:00<00:00, 113.22it/s]\n",
      "epoch: 828, loss: 2.7419: 100%|██████████| 100/100 [00:00<00:00, 127.12it/s]\n",
      "epoch: 829, loss: 2.7857: 100%|██████████| 100/100 [00:00<00:00, 128.18it/s]\n",
      "epoch: 830, loss: 2.7240: 100%|██████████| 100/100 [00:00<00:00, 120.06it/s]\n",
      "epoch: 831, loss: 2.7151: 100%|██████████| 100/100 [00:00<00:00, 118.57it/s]\n",
      "epoch: 832, loss: 2.7919: 100%|██████████| 100/100 [00:00<00:00, 127.03it/s]\n",
      "epoch: 833, loss: 2.8260: 100%|██████████| 100/100 [00:00<00:00, 130.19it/s]\n",
      "epoch: 834, loss: 2.7755: 100%|██████████| 100/100 [00:00<00:00, 127.19it/s]\n",
      "epoch: 835, loss: 2.6894: 100%|██████████| 100/100 [00:00<00:00, 129.05it/s]\n",
      "epoch: 836, loss: 2.7193: 100%|██████████| 100/100 [00:00<00:00, 133.50it/s]\n",
      "epoch: 837, loss: 2.9327: 100%|██████████| 100/100 [00:00<00:00, 133.05it/s]\n",
      "epoch: 838, loss: 2.8460: 100%|██████████| 100/100 [00:00<00:00, 134.42it/s]\n",
      "epoch: 839, loss: 2.8631: 100%|██████████| 100/100 [00:00<00:00, 133.41it/s]\n",
      "epoch: 840, loss: 2.8023: 100%|██████████| 100/100 [00:00<00:00, 133.67it/s]\n",
      "epoch: 841, loss: 2.8008: 100%|██████████| 100/100 [00:00<00:00, 132.79it/s]\n",
      "epoch: 842, loss: 2.8125: 100%|██████████| 100/100 [00:00<00:00, 131.89it/s]\n",
      "epoch: 843, loss: 2.8530: 100%|██████████| 100/100 [00:00<00:00, 132.22it/s]\n",
      "epoch: 844, loss: 2.8936: 100%|██████████| 100/100 [00:00<00:00, 131.57it/s]\n",
      "epoch: 845, loss: 2.7676: 100%|██████████| 100/100 [00:00<00:00, 131.13it/s]\n",
      "epoch: 846, loss: 2.8524: 100%|██████████| 100/100 [00:00<00:00, 131.92it/s]\n",
      "epoch: 847, loss: 2.6735: 100%|██████████| 100/100 [00:00<00:00, 131.89it/s]\n",
      "epoch: 848, loss: 2.7078: 100%|██████████| 100/100 [00:00<00:00, 130.35it/s]\n",
      "epoch: 849, loss: 2.9340: 100%|██████████| 100/100 [00:00<00:00, 131.22it/s]\n",
      "epoch: 850, loss: 2.8914: 100%|██████████| 100/100 [00:00<00:00, 132.15it/s]\n",
      "epoch: 851, loss: 2.7885: 100%|██████████| 100/100 [00:00<00:00, 132.63it/s]\n",
      "epoch: 852, loss: 2.8016: 100%|██████████| 100/100 [00:00<00:00, 131.16it/s]\n",
      "epoch: 853, loss: 2.7011: 100%|██████████| 100/100 [00:00<00:00, 132.14it/s]\n",
      "epoch: 854, loss: 2.8438: 100%|██████████| 100/100 [00:00<00:00, 123.21it/s]\n",
      "epoch: 855, loss: 2.8610: 100%|██████████| 100/100 [00:00<00:00, 121.29it/s]\n",
      "epoch: 856, loss: 2.7217: 100%|██████████| 100/100 [00:00<00:00, 129.05it/s]\n",
      "epoch: 857, loss: 2.8294: 100%|██████████| 100/100 [00:00<00:00, 118.06it/s]\n",
      "epoch: 858, loss: 2.9181: 100%|██████████| 100/100 [00:00<00:00, 129.05it/s]\n",
      "epoch: 859, loss: 2.8451: 100%|██████████| 100/100 [00:00<00:00, 129.24it/s]\n",
      "epoch: 860, loss: 2.7874: 100%|██████████| 100/100 [00:00<00:00, 122.66it/s]\n",
      "epoch: 861, loss: 2.8860: 100%|██████████| 100/100 [00:00<00:00, 125.14it/s]\n",
      "epoch: 862, loss: 2.8198: 100%|██████████| 100/100 [00:00<00:00, 122.27it/s]\n",
      "epoch: 863, loss: 2.9173: 100%|██████████| 100/100 [00:00<00:00, 127.53it/s]\n",
      "epoch: 864, loss: 2.9165: 100%|██████████| 100/100 [00:00<00:00, 129.84it/s]\n",
      "epoch: 865, loss: 2.9202: 100%|██████████| 100/100 [00:00<00:00, 125.52it/s]\n",
      "epoch: 866, loss: 2.6312: 100%|██████████| 100/100 [00:00<00:00, 121.23it/s]\n",
      "epoch: 867, loss: 2.8085: 100%|██████████| 100/100 [00:00<00:00, 119.14it/s]\n",
      "epoch: 868, loss: 2.6808: 100%|██████████| 100/100 [00:00<00:00, 118.94it/s]\n",
      "epoch: 869, loss: 2.7496: 100%|██████████| 100/100 [00:00<00:00, 124.95it/s]\n",
      "epoch: 870, loss: 2.8962: 100%|██████████| 100/100 [00:00<00:00, 115.32it/s]\n",
      "epoch: 871, loss: 2.8444: 100%|██████████| 100/100 [00:00<00:00, 126.32it/s]\n",
      "epoch: 872, loss: 2.8737: 100%|██████████| 100/100 [00:00<00:00, 123.49it/s]\n",
      "epoch: 873, loss: 2.9622: 100%|██████████| 100/100 [00:00<00:00, 118.21it/s]\n",
      "epoch: 874, loss: 2.8362: 100%|██████████| 100/100 [00:00<00:00, 126.08it/s]\n",
      "epoch: 875, loss: 2.8091: 100%|██████████| 100/100 [00:00<00:00, 126.92it/s]\n",
      "epoch: 876, loss: 2.8447: 100%|██████████| 100/100 [00:00<00:00, 123.67it/s]\n",
      "epoch: 877, loss: 2.5836: 100%|██████████| 100/100 [00:00<00:00, 120.25it/s]\n",
      "epoch: 878, loss: 2.7292: 100%|██████████| 100/100 [00:00<00:00, 125.89it/s]\n",
      "epoch: 879, loss: 2.8026: 100%|██████████| 100/100 [00:00<00:00, 111.34it/s]\n",
      "epoch: 880, loss: 2.8357: 100%|██████████| 100/100 [00:00<00:00, 119.41it/s]\n",
      "epoch: 881, loss: 2.8777: 100%|██████████| 100/100 [00:00<00:00, 116.27it/s]\n",
      "epoch: 882, loss: 2.8248: 100%|██████████| 100/100 [00:00<00:00, 114.34it/s]\n",
      "epoch: 883, loss: 2.7793: 100%|██████████| 100/100 [00:00<00:00, 119.35it/s]\n",
      "epoch: 884, loss: 2.9793: 100%|██████████| 100/100 [00:00<00:00, 122.93it/s]\n",
      "epoch: 885, loss: 2.8175: 100%|██████████| 100/100 [00:00<00:00, 126.87it/s]\n",
      "epoch: 886, loss: 2.7394: 100%|██████████| 100/100 [00:00<00:00, 127.41it/s]\n",
      "epoch: 887, loss: 2.6081: 100%|██████████| 100/100 [00:00<00:00, 127.56it/s]\n",
      "epoch: 888, loss: 2.7214: 100%|██████████| 100/100 [00:00<00:00, 134.02it/s]\n",
      "epoch: 889, loss: 2.9474: 100%|██████████| 100/100 [00:00<00:00, 133.78it/s]\n",
      "epoch: 890, loss: 2.8873: 100%|██████████| 100/100 [00:00<00:00, 133.51it/s]\n",
      "epoch: 891, loss: 2.6902: 100%|██████████| 100/100 [00:00<00:00, 132.12it/s]\n",
      "epoch: 892, loss: 2.5192: 100%|██████████| 100/100 [00:00<00:00, 132.69it/s]\n",
      "epoch: 893, loss: 2.7575: 100%|██████████| 100/100 [00:00<00:00, 132.84it/s]\n",
      "epoch: 894, loss: 2.6898: 100%|██████████| 100/100 [00:00<00:00, 131.88it/s]\n",
      "epoch: 895, loss: 2.8669: 100%|██████████| 100/100 [00:00<00:00, 128.24it/s]\n",
      "epoch: 896, loss: 2.8944: 100%|██████████| 100/100 [00:00<00:00, 133.34it/s]\n",
      "epoch: 897, loss: 2.9335: 100%|██████████| 100/100 [00:00<00:00, 133.99it/s]\n",
      "epoch: 898, loss: 3.1826: 100%|██████████| 100/100 [00:00<00:00, 131.78it/s]\n",
      "epoch: 899, loss: 2.8829: 100%|██████████| 100/100 [00:00<00:00, 130.10it/s]\n",
      "epoch: 900, loss: 2.7687: 100%|██████████| 100/100 [00:00<00:00, 127.38it/s]\n",
      "epoch: 901, loss: 2.9394: 100%|██████████| 100/100 [00:00<00:00, 124.11it/s]\n",
      "epoch: 902, loss: 2.8642: 100%|██████████| 100/100 [00:00<00:00, 125.99it/s]\n",
      "epoch: 903, loss: 2.8671: 100%|██████████| 100/100 [00:00<00:00, 124.87it/s]\n",
      "epoch: 904, loss: 2.7927: 100%|██████████| 100/100 [00:00<00:00, 113.37it/s]\n",
      "epoch: 905, loss: 2.7527: 100%|██████████| 100/100 [00:00<00:00, 112.67it/s]\n",
      "epoch: 906, loss: 2.8915: 100%|██████████| 100/100 [00:00<00:00, 117.22it/s]\n",
      "epoch: 907, loss: 2.7132: 100%|██████████| 100/100 [00:00<00:00, 120.27it/s]\n",
      "epoch: 908, loss: 2.7755: 100%|██████████| 100/100 [00:00<00:00, 126.53it/s]\n",
      "epoch: 909, loss: 2.8102: 100%|██████████| 100/100 [00:00<00:00, 126.48it/s]\n",
      "epoch: 910, loss: 2.8497: 100%|██████████| 100/100 [00:00<00:00, 123.06it/s]\n",
      "epoch: 911, loss: 2.8491: 100%|██████████| 100/100 [00:00<00:00, 119.27it/s]\n",
      "epoch: 912, loss: 2.7847: 100%|██████████| 100/100 [00:00<00:00, 120.73it/s]\n",
      "epoch: 913, loss: 2.9456: 100%|██████████| 100/100 [00:00<00:00, 123.19it/s]\n",
      "epoch: 914, loss: 2.8245: 100%|██████████| 100/100 [00:00<00:00, 126.95it/s]\n",
      "epoch: 915, loss: 2.9670: 100%|██████████| 100/100 [00:00<00:00, 124.18it/s]\n",
      "epoch: 916, loss: 2.7648: 100%|██████████| 100/100 [00:00<00:00, 126.78it/s]\n",
      "epoch: 917, loss: 2.8398: 100%|██████████| 100/100 [00:00<00:00, 127.29it/s]\n",
      "epoch: 918, loss: 2.7690: 100%|██████████| 100/100 [00:00<00:00, 126.61it/s]\n",
      "epoch: 919, loss: 2.8830: 100%|██████████| 100/100 [00:00<00:00, 126.46it/s]\n",
      "epoch: 920, loss: 2.8931: 100%|██████████| 100/100 [00:00<00:00, 126.52it/s]\n",
      "epoch: 921, loss: 2.8479: 100%|██████████| 100/100 [00:00<00:00, 115.18it/s]\n",
      "epoch: 922, loss: 2.8500: 100%|██████████| 100/100 [00:00<00:00, 122.22it/s]\n",
      "epoch: 923, loss: 2.8491: 100%|██████████| 100/100 [00:00<00:00, 125.27it/s]\n",
      "epoch: 924, loss: 2.7854: 100%|██████████| 100/100 [00:00<00:00, 126.82it/s]\n",
      "epoch: 925, loss: 2.9231: 100%|██████████| 100/100 [00:00<00:00, 125.75it/s]\n",
      "epoch: 926, loss: 2.7844: 100%|██████████| 100/100 [00:00<00:00, 126.96it/s]\n",
      "epoch: 927, loss: 2.8931: 100%|██████████| 100/100 [00:00<00:00, 126.04it/s]\n",
      "epoch: 928, loss: 2.7808: 100%|██████████| 100/100 [00:00<00:00, 126.82it/s]\n",
      "epoch: 929, loss: 2.8143: 100%|██████████| 100/100 [00:00<00:00, 115.77it/s]\n",
      "epoch: 930, loss: 2.8133: 100%|██████████| 100/100 [00:00<00:00, 127.61it/s]\n",
      "epoch: 931, loss: 3.0183: 100%|██████████| 100/100 [00:00<00:00, 126.20it/s]\n",
      "epoch: 932, loss: 2.6939: 100%|██████████| 100/100 [00:00<00:00, 127.05it/s]\n",
      "epoch: 933, loss: 2.6911: 100%|██████████| 100/100 [00:00<00:00, 122.41it/s]\n",
      "epoch: 934, loss: 2.7539: 100%|██████████| 100/100 [00:00<00:00, 118.87it/s]\n",
      "epoch: 935, loss: 2.8242: 100%|██████████| 100/100 [00:00<00:00, 102.77it/s]\n",
      "epoch: 936, loss: 2.7670: 100%|██████████| 100/100 [00:00<00:00, 130.16it/s]\n",
      "epoch: 937, loss: 2.7421: 100%|██████████| 100/100 [00:00<00:00, 131.93it/s]\n",
      "epoch: 938, loss: 2.9720: 100%|██████████| 100/100 [00:00<00:00, 132.34it/s]\n",
      "epoch: 939, loss: 2.9062: 100%|██████████| 100/100 [00:00<00:00, 131.39it/s]\n",
      "epoch: 940, loss: 2.8822: 100%|██████████| 100/100 [00:00<00:00, 124.79it/s]\n",
      "epoch: 941, loss: 2.9435: 100%|██████████| 100/100 [00:00<00:00, 107.57it/s]\n",
      "epoch: 942, loss: 2.8944: 100%|██████████| 100/100 [00:00<00:00, 122.17it/s]\n",
      "epoch: 943, loss: 2.7938: 100%|██████████| 100/100 [00:00<00:00, 128.59it/s]\n",
      "epoch: 944, loss: 2.6474: 100%|██████████| 100/100 [00:00<00:00, 110.18it/s]\n",
      "epoch: 945, loss: 2.8458: 100%|██████████| 100/100 [00:00<00:00, 108.27it/s]\n",
      "epoch: 946, loss: 2.7421: 100%|██████████| 100/100 [00:00<00:00, 121.56it/s]\n",
      "epoch: 947, loss: 2.8885: 100%|██████████| 100/100 [00:00<00:00, 119.37it/s]\n",
      "epoch: 948, loss: 2.7799: 100%|██████████| 100/100 [00:00<00:00, 120.35it/s]\n",
      "epoch: 949, loss: 2.9038: 100%|██████████| 100/100 [00:00<00:00, 121.13it/s]\n",
      "epoch: 950, loss: 2.8150: 100%|██████████| 100/100 [00:00<00:00, 120.15it/s]\n",
      "epoch: 951, loss: 2.7262: 100%|██████████| 100/100 [00:00<00:00, 120.53it/s]\n",
      "epoch: 952, loss: 2.9237: 100%|██████████| 100/100 [00:00<00:00, 120.95it/s]\n",
      "epoch: 953, loss: 2.8872: 100%|██████████| 100/100 [00:00<00:00, 119.79it/s]\n",
      "epoch: 954, loss: 2.6619: 100%|██████████| 100/100 [00:00<00:00, 120.73it/s]\n",
      "epoch: 955, loss: 2.6757: 100%|██████████| 100/100 [00:00<00:00, 122.10it/s]\n",
      "epoch: 956, loss: 2.9415: 100%|██████████| 100/100 [00:00<00:00, 120.79it/s]\n",
      "epoch: 957, loss: 2.9098: 100%|██████████| 100/100 [00:00<00:00, 122.09it/s]\n",
      "epoch: 958, loss: 2.7908: 100%|██████████| 100/100 [00:00<00:00, 121.04it/s]\n",
      "epoch: 959, loss: 2.8792: 100%|██████████| 100/100 [00:00<00:00, 122.84it/s]\n",
      "epoch: 960, loss: 2.7701: 100%|██████████| 100/100 [00:00<00:00, 119.99it/s]\n",
      "epoch: 961, loss: 2.7772: 100%|██████████| 100/100 [00:00<00:00, 121.01it/s]\n",
      "epoch: 962, loss: 2.8168: 100%|██████████| 100/100 [00:00<00:00, 118.81it/s]\n",
      "epoch: 963, loss: 2.6206: 100%|██████████| 100/100 [00:00<00:00, 122.52it/s]\n",
      "epoch: 964, loss: 2.9942: 100%|██████████| 100/100 [00:00<00:00, 116.64it/s]\n",
      "epoch: 965, loss: 2.8924: 100%|██████████| 100/100 [00:00<00:00, 112.01it/s]\n",
      "epoch: 966, loss: 2.7122: 100%|██████████| 100/100 [00:00<00:00, 112.43it/s]\n",
      "epoch: 967, loss: 2.7553: 100%|██████████| 100/100 [00:00<00:00, 123.59it/s]\n",
      "epoch: 968, loss: 2.7924: 100%|██████████| 100/100 [00:00<00:00, 126.29it/s]\n",
      "epoch: 969, loss: 2.7811: 100%|██████████| 100/100 [00:00<00:00, 125.98it/s]\n",
      "epoch: 970, loss: 2.9287: 100%|██████████| 100/100 [00:00<00:00, 126.41it/s]\n",
      "epoch: 971, loss: 2.9658: 100%|██████████| 100/100 [00:00<00:00, 126.62it/s]\n",
      "epoch: 972, loss: 2.9101: 100%|██████████| 100/100 [00:00<00:00, 125.64it/s]\n",
      "epoch: 973, loss: 2.7770: 100%|██████████| 100/100 [00:00<00:00, 125.17it/s]\n",
      "epoch: 974, loss: 2.6921: 100%|██████████| 100/100 [00:00<00:00, 126.66it/s]\n",
      "epoch: 975, loss: 2.8516: 100%|██████████| 100/100 [00:00<00:00, 126.15it/s]\n",
      "epoch: 976, loss: 2.9249: 100%|██████████| 100/100 [00:00<00:00, 126.12it/s]\n",
      "epoch: 977, loss: 2.7648: 100%|██████████| 100/100 [00:00<00:00, 125.70it/s]\n",
      "epoch: 978, loss: 2.7377: 100%|██████████| 100/100 [00:00<00:00, 126.57it/s]\n",
      "epoch: 979, loss: 2.9697: 100%|██████████| 100/100 [00:00<00:00, 126.00it/s]\n",
      "epoch: 980, loss: 2.8276: 100%|██████████| 100/100 [00:00<00:00, 125.09it/s]\n",
      "epoch: 981, loss: 2.7878: 100%|██████████| 100/100 [00:00<00:00, 125.92it/s]\n",
      "epoch: 982, loss: 2.6886: 100%|██████████| 100/100 [00:00<00:00, 126.24it/s]\n",
      "epoch: 983, loss: 2.8056: 100%|██████████| 100/100 [00:00<00:00, 126.08it/s]\n",
      "epoch: 984, loss: 2.8325: 100%|██████████| 100/100 [00:00<00:00, 126.39it/s]\n",
      "epoch: 985, loss: 2.9022: 100%|██████████| 100/100 [00:00<00:00, 126.36it/s]\n",
      "epoch: 986, loss: 2.8799: 100%|██████████| 100/100 [00:00<00:00, 126.17it/s]\n",
      "epoch: 987, loss: 2.6759: 100%|██████████| 100/100 [00:00<00:00, 124.92it/s]\n",
      "epoch: 988, loss: 2.8593: 100%|██████████| 100/100 [00:00<00:00, 126.35it/s]\n",
      "epoch: 989, loss: 2.6454: 100%|██████████| 100/100 [00:00<00:00, 130.63it/s]\n",
      "epoch: 990, loss: 2.8427: 100%|██████████| 100/100 [00:00<00:00, 130.39it/s]\n",
      "epoch: 991, loss: 2.8051: 100%|██████████| 100/100 [00:00<00:00, 125.36it/s]\n",
      "epoch: 992, loss: 2.9347: 100%|██████████| 100/100 [00:00<00:00, 114.32it/s]\n",
      "epoch: 993, loss: 2.8320: 100%|██████████| 100/100 [00:00<00:00, 109.17it/s]\n",
      "epoch: 994, loss: 2.9006: 100%|██████████| 100/100 [00:00<00:00, 122.66it/s]\n",
      "epoch: 995, loss: 2.7909: 100%|██████████| 100/100 [00:00<00:00, 130.77it/s]\n",
      "epoch: 996, loss: 2.8023: 100%|██████████| 100/100 [00:00<00:00, 124.21it/s]\n",
      "epoch: 997, loss: 2.8190: 100%|██████████| 100/100 [00:00<00:00, 115.49it/s]\n",
      "epoch: 998, loss: 3.0894: 100%|██████████| 100/100 [00:00<00:00, 115.07it/s]\n",
      "epoch: 999, loss: 2.8705: 100%|██████████| 100/100 [00:00<00:00, 130.44it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "samples = float2bin(db.gen_batch(50000), bm)\n",
    "mean = np.mean(samples, axis=0)\n",
    "init_dist = torch.distributions.Bernoulli(probs=torch.from_numpy(mean).to(device) * (1. - 2 * 1e-2) + 1e-2)\n",
    "net = MLPScore(input_dim=32, hidden_dims=[256,256,256,1]).to(device)\n",
    "energy_func = EBM(net, torch.from_numpy(mean)).to(device)\n",
    "ema_energy_func = training_main_loop(db, bm, energy_func, device, algo='ed_grid')\n",
    "plot_heat(ema_energy_func, bm, device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Discrete EBM using ED-$\\nabla$ Bern"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 0, loss: 3.1384: 100%|██████████| 100/100 [00:01<00:00, 61.92it/s]\n",
      "epoch: 1, loss: 2.3185: 100%|██████████| 100/100 [00:01<00:00, 62.25it/s]\n",
      "epoch: 2, loss: 2.3610: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 3, loss: 2.0445: 100%|██████████| 100/100 [00:01<00:00, 60.49it/s]\n",
      "epoch: 4, loss: 2.1724: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 5, loss: 2.0979: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 6, loss: 2.0674: 100%|██████████| 100/100 [00:01<00:00, 60.47it/s]\n",
      "epoch: 7, loss: 1.9567: 100%|██████████| 100/100 [00:01<00:00, 58.86it/s]\n",
      "epoch: 8, loss: 1.9439: 100%|██████████| 100/100 [00:01<00:00, 58.65it/s]\n",
      "epoch: 9, loss: 1.9560: 100%|██████████| 100/100 [00:01<00:00, 58.80it/s]\n",
      "epoch: 10, loss: 2.0238: 100%|██████████| 100/100 [00:01<00:00, 59.19it/s]\n",
      "epoch: 11, loss: 1.7779: 100%|██████████| 100/100 [00:01<00:00, 58.79it/s]\n",
      "epoch: 12, loss: 1.7655: 100%|██████████| 100/100 [00:01<00:00, 58.58it/s]\n",
      "epoch: 13, loss: 2.0336: 100%|██████████| 100/100 [00:01<00:00, 59.17it/s]\n",
      "epoch: 14, loss: 1.8332: 100%|██████████| 100/100 [00:01<00:00, 59.22it/s]\n",
      "epoch: 15, loss: 1.5861: 100%|██████████| 100/100 [00:01<00:00, 60.83it/s]\n",
      "epoch: 16, loss: 1.9113: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 17, loss: 1.6907: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 18, loss: 1.7975: 100%|██████████| 100/100 [00:01<00:00, 60.80it/s]\n",
      "epoch: 19, loss: 1.9380: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 20, loss: 1.9586: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 21, loss: 1.7120: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 22, loss: 1.6883: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 23, loss: 1.6846: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 24, loss: 1.9390: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 25, loss: 1.8825: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 26, loss: 1.8561: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 27, loss: 1.8767: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 28, loss: 1.9840: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 29, loss: 1.8610: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 30, loss: 1.9421: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 31, loss: 1.6901: 100%|██████████| 100/100 [00:01<00:00, 60.90it/s]\n",
      "epoch: 32, loss: 1.7732: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 33, loss: 1.5826: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 34, loss: 1.6180: 100%|██████████| 100/100 [00:01<00:00, 60.95it/s]\n",
      "epoch: 35, loss: 1.9840: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 36, loss: 1.8301: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 37, loss: 1.8370: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 38, loss: 1.7303: 100%|██████████| 100/100 [00:01<00:00, 61.15it/s]\n",
      "epoch: 39, loss: 1.6733: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 40, loss: 1.7162: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 41, loss: 1.7795: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 42, loss: 1.9591: 100%|██████████| 100/100 [00:01<00:00, 60.74it/s]\n",
      "epoch: 43, loss: 1.8806: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 44, loss: 1.9810: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 45, loss: 1.6754: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 46, loss: 1.6728: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 47, loss: 1.8464: 100%|██████████| 100/100 [00:01<00:00, 60.90it/s]\n",
      "epoch: 48, loss: 1.9101: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 49, loss: 1.8933: 100%|██████████| 100/100 [00:01<00:00, 60.73it/s]\n",
      "epoch: 50, loss: 2.0979: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 51, loss: 1.7272: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 52, loss: 1.6688: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 53, loss: 1.8756: 100%|██████████| 100/100 [00:01<00:00, 60.91it/s]\n",
      "epoch: 54, loss: 1.7781: 100%|██████████| 100/100 [00:01<00:00, 60.98it/s]\n",
      "epoch: 55, loss: 1.9197: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 56, loss: 1.9758: 100%|██████████| 100/100 [00:01<00:00, 60.65it/s]\n",
      "epoch: 57, loss: 1.7136: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 58, loss: 2.0438: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 59, loss: 1.8513: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 60, loss: 1.8736: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 61, loss: 1.7806: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 62, loss: 2.0633: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 63, loss: 1.8155: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 64, loss: 1.5819: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 65, loss: 1.8170: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 66, loss: 1.7075: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 67, loss: 1.9369: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 68, loss: 1.7458: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 69, loss: 1.9355: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 70, loss: 1.8540: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 71, loss: 1.9668: 100%|██████████| 100/100 [00:01<00:00, 60.79it/s]\n",
      "epoch: 72, loss: 1.9152: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 73, loss: 1.8039: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 74, loss: 1.7861: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 75, loss: 1.7389: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 76, loss: 1.9197: 100%|██████████| 100/100 [00:01<00:00, 60.89it/s]\n",
      "epoch: 77, loss: 1.9781: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 78, loss: 1.8246: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 79, loss: 1.9976: 100%|██████████| 100/100 [00:01<00:00, 60.67it/s]\n",
      "epoch: 80, loss: 1.8954: 100%|██████████| 100/100 [00:01<00:00, 62.32it/s]\n",
      "epoch: 81, loss: 1.6606: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 82, loss: 1.8167: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 83, loss: 1.8435: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 84, loss: 1.8516: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 85, loss: 1.7828: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 86, loss: 1.7047: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 87, loss: 1.8755: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 88, loss: 1.7867: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 89, loss: 1.8692: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 90, loss: 1.9624: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 91, loss: 1.9921: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 92, loss: 1.6343: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 93, loss: 1.8965: 100%|██████████| 100/100 [00:01<00:00, 60.94it/s]\n",
      "epoch: 94, loss: 1.5640: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 95, loss: 2.0162: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 96, loss: 1.8080: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 97, loss: 1.8761: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 98, loss: 1.9940: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 99, loss: 1.6511: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 100, loss: 2.1143: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 101, loss: 1.8267: 100%|██████████| 100/100 [00:01<00:00, 61.00it/s]\n",
      "epoch: 102, loss: 1.6771: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 103, loss: 1.8855: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 104, loss: 1.7532: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 105, loss: 1.5905: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 106, loss: 1.8223: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 107, loss: 1.9575: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 108, loss: 1.8327: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 109, loss: 2.1322: 100%|██████████| 100/100 [00:01<00:00, 61.00it/s]\n",
      "epoch: 110, loss: 1.7875: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 111, loss: 1.7178: 100%|██████████| 100/100 [00:01<00:00, 61.00it/s]\n",
      "epoch: 112, loss: 2.0646: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 113, loss: 1.8368: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 114, loss: 1.7926: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 115, loss: 1.5267: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 116, loss: 1.7800: 100%|██████████| 100/100 [00:01<00:00, 60.79it/s]\n",
      "epoch: 117, loss: 1.8742: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 118, loss: 1.7843: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 119, loss: 1.6301: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 120, loss: 1.9364: 100%|██████████| 100/100 [00:01<00:00, 60.31it/s]\n",
      "epoch: 121, loss: 1.8906: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 122, loss: 1.8063: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 123, loss: 1.9738: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 124, loss: 1.9057: 100%|██████████| 100/100 [00:01<00:00, 60.69it/s]\n",
      "epoch: 125, loss: 1.9690: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 126, loss: 1.6698: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 127, loss: 1.9569: 100%|██████████| 100/100 [00:01<00:00, 60.90it/s]\n",
      "epoch: 128, loss: 1.8326: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 129, loss: 2.0102: 100%|██████████| 100/100 [00:01<00:00, 60.94it/s]\n",
      "epoch: 130, loss: 1.9163: 100%|██████████| 100/100 [00:01<00:00, 60.85it/s]\n",
      "epoch: 131, loss: 1.7896: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 132, loss: 1.7679: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 133, loss: 1.9181: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 134, loss: 1.8208: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 135, loss: 1.8779: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 136, loss: 1.6033: 100%|██████████| 100/100 [00:01<00:00, 60.85it/s]\n",
      "epoch: 137, loss: 1.7501: 100%|██████████| 100/100 [00:01<00:00, 60.74it/s]\n",
      "epoch: 138, loss: 1.8541: 100%|██████████| 100/100 [00:01<00:00, 60.80it/s]\n",
      "epoch: 139, loss: 1.8990: 100%|██████████| 100/100 [00:01<00:00, 60.95it/s]\n",
      "epoch: 140, loss: 1.7281: 100%|██████████| 100/100 [00:01<00:00, 60.51it/s]\n",
      "epoch: 141, loss: 1.6440: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 142, loss: 2.1002: 100%|██████████| 100/100 [00:01<00:00, 60.80it/s]\n",
      "epoch: 143, loss: 1.7067: 100%|██████████| 100/100 [00:01<00:00, 60.81it/s]\n",
      "epoch: 144, loss: 1.8597: 100%|██████████| 100/100 [00:01<00:00, 60.94it/s]\n",
      "epoch: 145, loss: 1.7382: 100%|██████████| 100/100 [00:01<00:00, 60.75it/s]\n",
      "epoch: 146, loss: 1.8738: 100%|██████████| 100/100 [00:01<00:00, 60.95it/s]\n",
      "epoch: 147, loss: 1.8815: 100%|██████████| 100/100 [00:01<00:00, 60.85it/s]\n",
      "epoch: 148, loss: 1.9554: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 149, loss: 1.5710: 100%|██████████| 100/100 [00:01<00:00, 60.93it/s]\n",
      "epoch: 150, loss: 1.8313: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 151, loss: 1.8768: 100%|██████████| 100/100 [00:01<00:00, 61.15it/s]\n",
      "epoch: 152, loss: 1.7492: 100%|██████████| 100/100 [00:01<00:00, 60.18it/s]\n",
      "epoch: 153, loss: 1.7686: 100%|██████████| 100/100 [00:01<00:00, 60.79it/s]\n",
      "epoch: 154, loss: 2.0006: 100%|██████████| 100/100 [00:01<00:00, 60.97it/s]\n",
      "epoch: 155, loss: 1.7382: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 156, loss: 1.7533: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 157, loss: 1.6290: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 158, loss: 1.7904: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 159, loss: 1.8005: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 160, loss: 1.7633: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 161, loss: 1.8540: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 162, loss: 1.7582: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 163, loss: 1.8173: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 164, loss: 1.8211: 100%|██████████| 100/100 [00:01<00:00, 61.00it/s]\n",
      "epoch: 165, loss: 1.6948: 100%|██████████| 100/100 [00:01<00:00, 60.96it/s]\n",
      "epoch: 166, loss: 1.8822: 100%|██████████| 100/100 [00:01<00:00, 60.71it/s]\n",
      "epoch: 167, loss: 1.8304: 100%|██████████| 100/100 [00:01<00:00, 60.93it/s]\n",
      "epoch: 168, loss: 1.6518: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 169, loss: 1.9098: 100%|██████████| 100/100 [00:01<00:00, 60.16it/s]\n",
      "epoch: 170, loss: 1.7436: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 171, loss: 1.9536: 100%|██████████| 100/100 [00:01<00:00, 60.92it/s]\n",
      "epoch: 172, loss: 1.7067: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 173, loss: 1.6731: 100%|██████████| 100/100 [00:01<00:00, 60.94it/s]\n",
      "epoch: 174, loss: 1.8359: 100%|██████████| 100/100 [00:01<00:00, 60.76it/s]\n",
      "epoch: 175, loss: 2.0092: 100%|██████████| 100/100 [00:01<00:00, 61.15it/s]\n",
      "epoch: 176, loss: 1.6429: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 177, loss: 1.6340: 100%|██████████| 100/100 [00:01<00:00, 60.84it/s]\n",
      "epoch: 178, loss: 1.8344: 100%|██████████| 100/100 [00:01<00:00, 60.82it/s]\n",
      "epoch: 179, loss: 1.6233: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 180, loss: 1.7882: 100%|██████████| 100/100 [00:01<00:00, 60.86it/s]\n",
      "epoch: 181, loss: 1.7042: 100%|██████████| 100/100 [00:01<00:00, 60.76it/s]\n",
      "epoch: 182, loss: 1.7263: 100%|██████████| 100/100 [00:01<00:00, 60.50it/s]\n",
      "epoch: 183, loss: 1.8564: 100%|██████████| 100/100 [00:01<00:00, 60.86it/s]\n",
      "epoch: 184, loss: 1.9916: 100%|██████████| 100/100 [00:01<00:00, 60.66it/s]\n",
      "epoch: 185, loss: 1.7020: 100%|██████████| 100/100 [00:01<00:00, 60.72it/s]\n",
      "epoch: 186, loss: 1.8132: 100%|██████████| 100/100 [00:01<00:00, 60.83it/s]\n",
      "epoch: 187, loss: 1.7170: 100%|██████████| 100/100 [00:01<00:00, 60.92it/s]\n",
      "epoch: 188, loss: 1.7040: 100%|██████████| 100/100 [00:01<00:00, 60.80it/s]\n",
      "epoch: 189, loss: 1.6521: 100%|██████████| 100/100 [00:01<00:00, 59.65it/s]\n",
      "epoch: 190, loss: 1.9919: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 191, loss: 1.9967: 100%|██████████| 100/100 [00:01<00:00, 60.76it/s]\n",
      "epoch: 192, loss: 1.8558: 100%|██████████| 100/100 [00:01<00:00, 60.98it/s]\n",
      "epoch: 193, loss: 1.8515: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 194, loss: 1.7565: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 195, loss: 1.7835: 100%|██████████| 100/100 [00:01<00:00, 61.02it/s]\n",
      "epoch: 196, loss: 1.8932: 100%|██████████| 100/100 [00:01<00:00, 61.15it/s]\n",
      "epoch: 197, loss: 1.9395: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 198, loss: 1.7229: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 199, loss: 1.7274: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 200, loss: 2.0202: 100%|██████████| 100/100 [00:01<00:00, 60.93it/s]\n",
      "epoch: 201, loss: 1.7498: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 202, loss: 1.7937: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 203, loss: 1.8210: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 204, loss: 2.0602: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 205, loss: 2.0200: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 206, loss: 1.8661: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 207, loss: 1.7034: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 208, loss: 1.9271: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 209, loss: 1.6584: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 210, loss: 1.6855: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 211, loss: 1.7145: 100%|██████████| 100/100 [00:01<00:00, 61.76it/s]\n",
      "epoch: 212, loss: 1.6700: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 213, loss: 1.8837: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 214, loss: 1.8185: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 215, loss: 1.9146: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 216, loss: 1.8760: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 217, loss: 1.6648: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 218, loss: 1.6778: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 219, loss: 1.9149: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 220, loss: 1.8298: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 221, loss: 1.6697: 100%|██████████| 100/100 [00:01<00:00, 60.87it/s]\n",
      "epoch: 222, loss: 1.7297: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 223, loss: 1.8483: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 224, loss: 1.7395: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 225, loss: 1.8052: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 226, loss: 1.6727: 100%|██████████| 100/100 [00:01<00:00, 65.56it/s]\n",
      "epoch: 227, loss: 1.7093: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 228, loss: 1.8080: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 229, loss: 1.7421: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 230, loss: 1.7904: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 231, loss: 1.8680: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 232, loss: 1.8638: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 233, loss: 1.7017: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 234, loss: 1.7367: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 235, loss: 1.9043: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 236, loss: 2.0051: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 237, loss: 1.9166: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 238, loss: 1.9491: 100%|██████████| 100/100 [00:01<00:00, 60.91it/s]\n",
      "epoch: 239, loss: 1.8066: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 240, loss: 1.5812: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 241, loss: 1.8714: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 242, loss: 1.5435: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 243, loss: 1.8572: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 244, loss: 1.9135: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 245, loss: 1.9318: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 246, loss: 1.9057: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 247, loss: 1.7110: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 248, loss: 1.9219: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 249, loss: 1.7409: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 250, loss: 1.9064: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 251, loss: 1.8820: 100%|██████████| 100/100 [00:01<00:00, 73.96it/s]\n",
      "epoch: 252, loss: 1.7750: 100%|██████████| 100/100 [00:01<00:00, 66.96it/s]\n",
      "epoch: 253, loss: 1.7137: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 254, loss: 1.7287: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 255, loss: 1.9108: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 256, loss: 1.8298: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 257, loss: 2.0352: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 258, loss: 1.7814: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 259, loss: 1.7661: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 260, loss: 1.7450: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 261, loss: 1.7641: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 262, loss: 1.8866: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 263, loss: 1.9877: 100%|██████████| 100/100 [00:01<00:00, 60.70it/s]\n",
      "epoch: 264, loss: 1.8617: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 265, loss: 1.7888: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 266, loss: 1.5173: 100%|██████████| 100/100 [00:01<00:00, 61.86it/s]\n",
      "epoch: 267, loss: 2.0091: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 268, loss: 1.5034: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 269, loss: 1.8487: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 270, loss: 1.8651: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 271, loss: 1.7504: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 272, loss: 1.9192: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 273, loss: 1.6599: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 274, loss: 1.6212: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 275, loss: 1.7139: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 276, loss: 1.7037: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 277, loss: 1.9076: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 278, loss: 2.0041: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 279, loss: 1.7462: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 280, loss: 1.5712: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 281, loss: 1.8871: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 282, loss: 1.8722: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 283, loss: 1.9696: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 284, loss: 1.5693: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 285, loss: 1.9111: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 286, loss: 1.8600: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 287, loss: 1.8481: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 288, loss: 1.7187: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 289, loss: 1.9047: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 290, loss: 2.0105: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 291, loss: 1.9246: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 292, loss: 1.8789: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 293, loss: 1.8702: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 294, loss: 1.7427: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 295, loss: 1.7630: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 296, loss: 1.9339: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 297, loss: 1.9080: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 298, loss: 1.8234: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 299, loss: 1.7383: 100%|██████████| 100/100 [00:01<00:00, 60.78it/s]\n",
      "epoch: 300, loss: 1.7624: 100%|██████████| 100/100 [00:01<00:00, 66.49it/s]\n",
      "epoch: 301, loss: 1.7209: 100%|██████████| 100/100 [00:01<00:00, 60.90it/s]\n",
      "epoch: 302, loss: 1.8789: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 303, loss: 2.0074: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 304, loss: 1.5884: 100%|██████████| 100/100 [00:01<00:00, 61.81it/s]\n",
      "epoch: 305, loss: 1.9728: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 306, loss: 1.8570: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 307, loss: 1.7673: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 308, loss: 1.9420: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 309, loss: 1.7258: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 310, loss: 1.8113: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 311, loss: 2.1429: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 312, loss: 1.7141: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 313, loss: 1.8948: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 314, loss: 1.7812: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 315, loss: 1.8524: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 316, loss: 1.7591: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 317, loss: 1.7501: 100%|██████████| 100/100 [00:01<00:00, 61.06it/s]\n",
      "epoch: 318, loss: 1.7693: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 319, loss: 1.8567: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 320, loss: 1.9050: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 321, loss: 1.8485: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 322, loss: 1.7516: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 323, loss: 1.9979: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 324, loss: 1.8563: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 325, loss: 1.5597: 100%|██████████| 100/100 [00:01<00:00, 60.98it/s]\n",
      "epoch: 326, loss: 1.8428: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 327, loss: 1.5186: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 328, loss: 1.8636: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 329, loss: 2.0077: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 330, loss: 1.9547: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 331, loss: 1.9857: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 332, loss: 1.8577: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 333, loss: 1.8046: 100%|██████████| 100/100 [00:01<00:00, 60.02it/s]\n",
      "epoch: 334, loss: 1.7065: 100%|██████████| 100/100 [00:01<00:00, 59.66it/s]\n",
      "epoch: 335, loss: 1.7691: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 336, loss: 1.6625: 100%|██████████| 100/100 [00:01<00:00, 60.91it/s]\n",
      "epoch: 337, loss: 2.0252: 100%|██████████| 100/100 [00:01<00:00, 60.39it/s]\n",
      "epoch: 338, loss: 1.8783: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 339, loss: 1.8585: 100%|██████████| 100/100 [00:01<00:00, 69.37it/s]\n",
      "epoch: 340, loss: 1.9482: 100%|██████████| 100/100 [00:00<00:00, 112.13it/s]\n",
      "epoch: 341, loss: 1.6651: 100%|██████████| 100/100 [00:00<00:00, 111.76it/s]\n",
      "epoch: 342, loss: 1.6040: 100%|██████████| 100/100 [00:00<00:00, 100.46it/s]\n",
      "epoch: 343, loss: 1.7781: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 344, loss: 1.9408: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 345, loss: 1.6895: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 346, loss: 1.6969: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 347, loss: 1.7495: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 348, loss: 1.7856: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 349, loss: 1.9203: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 350, loss: 1.6799: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 351, loss: 1.8774: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 352, loss: 1.9094: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 353, loss: 1.8470: 100%|██████████| 100/100 [00:01<00:00, 61.92it/s]\n",
      "epoch: 354, loss: 1.8125: 100%|██████████| 100/100 [00:01<00:00, 62.08it/s]\n",
      "epoch: 355, loss: 1.8816: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 356, loss: 1.5855: 100%|██████████| 100/100 [00:01<00:00, 61.73it/s]\n",
      "epoch: 357, loss: 1.7759: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 358, loss: 1.7230: 100%|██████████| 100/100 [00:01<00:00, 62.10it/s]\n",
      "epoch: 359, loss: 1.9250: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 360, loss: 1.9652: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 361, loss: 1.7879: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 362, loss: 1.8436: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 363, loss: 1.8698: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 364, loss: 1.9253: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 365, loss: 1.7373: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 366, loss: 1.9746: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 367, loss: 1.8450: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 368, loss: 1.9047: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 369, loss: 1.6981: 100%|██████████| 100/100 [00:01<00:00, 61.12it/s]\n",
      "epoch: 370, loss: 1.8486: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 371, loss: 1.9565: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 372, loss: 1.7126: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 373, loss: 1.7780: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 374, loss: 1.6157: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 375, loss: 1.7159: 100%|██████████| 100/100 [00:01<00:00, 60.63it/s]\n",
      "epoch: 376, loss: 1.8243: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 377, loss: 1.9735: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 378, loss: 1.8154: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 379, loss: 1.9705: 100%|██████████| 100/100 [00:01<00:00, 61.15it/s]\n",
      "epoch: 380, loss: 1.9230: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 381, loss: 1.9015: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 382, loss: 1.7759: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 383, loss: 1.7967: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 384, loss: 1.6750: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 385, loss: 1.8110: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 386, loss: 1.9028: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 387, loss: 1.6857: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 388, loss: 1.6162: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 389, loss: 1.7456: 100%|██████████| 100/100 [00:01<00:00, 61.03it/s]\n",
      "epoch: 390, loss: 1.7971: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 391, loss: 1.7444: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 392, loss: 1.8934: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 393, loss: 1.8769: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 394, loss: 1.8620: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 395, loss: 1.8371: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 396, loss: 1.8553: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 397, loss: 1.8946: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 398, loss: 1.8883: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 399, loss: 1.9432: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 400, loss: 1.8977: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 401, loss: 1.7746: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 402, loss: 1.8248: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 403, loss: 1.7806: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 404, loss: 1.7852: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 405, loss: 1.8804: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 406, loss: 1.8522: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 407, loss: 1.8792: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 408, loss: 1.6415: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 409, loss: 2.0091: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 410, loss: 1.8607: 100%|██████████| 100/100 [00:01<00:00, 60.96it/s]\n",
      "epoch: 411, loss: 1.8937: 100%|██████████| 100/100 [00:01<00:00, 60.29it/s]\n",
      "epoch: 412, loss: 1.6790: 100%|██████████| 100/100 [00:01<00:00, 60.32it/s]\n",
      "epoch: 413, loss: 1.7621: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 414, loss: 1.9063: 100%|██████████| 100/100 [00:01<00:00, 60.84it/s]\n",
      "epoch: 415, loss: 1.8381: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 416, loss: 1.7763: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 417, loss: 1.7495: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 418, loss: 1.5652: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 419, loss: 1.9390: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 420, loss: 1.9385: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 421, loss: 1.8362: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 422, loss: 1.7438: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 423, loss: 1.7510: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 424, loss: 1.7586: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 425, loss: 1.9250: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 426, loss: 1.8037: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 427, loss: 1.7044: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 428, loss: 2.1216: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 429, loss: 1.5308: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 430, loss: 1.7828: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 431, loss: 1.7483: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 432, loss: 1.8826: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 433, loss: 1.7840: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 434, loss: 1.6790: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 435, loss: 1.8131: 100%|██████████| 100/100 [00:01<00:00, 60.92it/s]\n",
      "epoch: 436, loss: 1.4787: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 437, loss: 1.8729: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 438, loss: 1.8904: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 439, loss: 1.8355: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 440, loss: 1.5832: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 441, loss: 1.8827: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 442, loss: 1.9920: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 443, loss: 1.8806: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 444, loss: 1.9790: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 445, loss: 1.8396: 100%|██████████| 100/100 [00:01<00:00, 60.90it/s]\n",
      "epoch: 446, loss: 1.7001: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 447, loss: 1.8085: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 448, loss: 1.6316: 100%|██████████| 100/100 [00:01<00:00, 65.55it/s]\n",
      "epoch: 449, loss: 1.8983: 100%|██████████| 100/100 [00:01<00:00, 60.13it/s]\n",
      "epoch: 450, loss: 1.9422: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 451, loss: 1.8050: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 452, loss: 1.7263: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 453, loss: 1.7622: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 454, loss: 1.6266: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 455, loss: 1.9857: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 456, loss: 1.7584: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 457, loss: 1.7859: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 458, loss: 1.8581: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 459, loss: 1.9490: 100%|██████████| 100/100 [00:01<00:00, 61.88it/s]\n",
      "epoch: 460, loss: 1.6977: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 461, loss: 2.0498: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 462, loss: 1.8592: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 463, loss: 1.8301: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 464, loss: 1.8247: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 465, loss: 1.8117: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 466, loss: 1.9700: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 467, loss: 1.9587: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 468, loss: 1.8467: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 469, loss: 1.6946: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 470, loss: 1.8631: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 471, loss: 1.7936: 100%|██████████| 100/100 [00:01<00:00, 60.95it/s]\n",
      "epoch: 472, loss: 1.7550: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 473, loss: 1.6802: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 474, loss: 1.9747: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 475, loss: 2.0152: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 476, loss: 2.1062: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 477, loss: 1.8169: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 478, loss: 1.9461: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 479, loss: 1.7668: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 480, loss: 1.6928: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 481, loss: 1.8594: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 482, loss: 1.9964: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 483, loss: 2.0255: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 484, loss: 1.6054: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 485, loss: 1.9227: 100%|██████████| 100/100 [00:01<00:00, 59.71it/s]\n",
      "epoch: 486, loss: 1.8894: 100%|██████████| 100/100 [00:01<00:00, 60.14it/s]\n",
      "epoch: 487, loss: 1.6392: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 488, loss: 1.8627: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 489, loss: 1.5307: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 490, loss: 1.9853: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 491, loss: 1.8293: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 492, loss: 1.9747: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 493, loss: 1.8312: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 494, loss: 1.8099: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 495, loss: 1.6666: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 496, loss: 1.6968: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 497, loss: 1.8120: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 498, loss: 1.7417: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 499, loss: 1.7268: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 500, loss: 1.9652: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 501, loss: 1.7513: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 502, loss: 1.8414: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 503, loss: 1.6703: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 504, loss: 1.8312: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 505, loss: 1.8415: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 506, loss: 1.5293: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 507, loss: 1.8050: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 508, loss: 1.8140: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 509, loss: 1.6835: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 510, loss: 1.8205: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 511, loss: 1.7649: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 512, loss: 1.5780: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 513, loss: 1.8073: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 514, loss: 1.6497: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 515, loss: 1.7053: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 516, loss: 1.4977: 100%|██████████| 100/100 [00:01<00:00, 61.75it/s]\n",
      "epoch: 517, loss: 1.5313: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 518, loss: 1.6008: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 519, loss: 1.6643: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 520, loss: 1.6844: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 521, loss: 1.8389: 100%|██████████| 100/100 [00:01<00:00, 62.21it/s]\n",
      "epoch: 522, loss: 1.8477: 100%|██████████| 100/100 [00:01<00:00, 59.55it/s]\n",
      "epoch: 523, loss: 1.7564: 100%|██████████| 100/100 [00:01<00:00, 59.83it/s]\n",
      "epoch: 524, loss: 1.8175: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 525, loss: 1.7505: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 526, loss: 1.8253: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 527, loss: 1.9057: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 528, loss: 1.9534: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 529, loss: 1.6029: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 530, loss: 1.7623: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 531, loss: 2.0009: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 532, loss: 1.8591: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 533, loss: 1.8598: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 534, loss: 1.5918: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 535, loss: 1.9610: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 536, loss: 1.8945: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 537, loss: 2.0112: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 538, loss: 1.8147: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 539, loss: 1.5883: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 540, loss: 1.7457: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 541, loss: 1.6944: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 542, loss: 1.7788: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 543, loss: 2.1105: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 544, loss: 1.6811: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 545, loss: 2.0281: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 546, loss: 1.7494: 100%|██████████| 100/100 [00:01<00:00, 62.10it/s]\n",
      "epoch: 547, loss: 1.8729: 100%|██████████| 100/100 [00:01<00:00, 66.53it/s]\n",
      "epoch: 548, loss: 1.9438: 100%|██████████| 100/100 [00:01<00:00, 65.98it/s]\n",
      "epoch: 549, loss: 1.8404: 100%|██████████| 100/100 [00:01<00:00, 64.12it/s]\n",
      "epoch: 550, loss: 1.8956: 100%|██████████| 100/100 [00:01<00:00, 64.01it/s]\n",
      "epoch: 551, loss: 1.6340: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 552, loss: 1.6396: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 553, loss: 1.4627: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 554, loss: 1.8090: 100%|██████████| 100/100 [00:01<00:00, 61.00it/s]\n",
      "epoch: 555, loss: 1.8090: 100%|██████████| 100/100 [00:01<00:00, 58.97it/s]\n",
      "epoch: 556, loss: 1.7937: 100%|██████████| 100/100 [00:01<00:00, 58.24it/s]\n",
      "epoch: 557, loss: 1.8229: 100%|██████████| 100/100 [00:01<00:00, 58.36it/s]\n",
      "epoch: 558, loss: 1.9942: 100%|██████████| 100/100 [00:01<00:00, 79.09it/s]\n",
      "epoch: 559, loss: 1.9455: 100%|██████████| 100/100 [00:01<00:00, 94.58it/s]\n",
      "epoch: 560, loss: 1.9112: 100%|██████████| 100/100 [00:01<00:00, 93.38it/s]\n",
      "epoch: 561, loss: 1.8581: 100%|██████████| 100/100 [00:01<00:00, 94.42it/s]\n",
      "epoch: 562, loss: 1.8569: 100%|██████████| 100/100 [00:01<00:00, 93.89it/s]\n",
      "epoch: 563, loss: 1.7861: 100%|██████████| 100/100 [00:01<00:00, 59.77it/s]\n",
      "epoch: 564, loss: 1.6650: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 565, loss: 1.8987: 100%|██████████| 100/100 [00:01<00:00, 62.08it/s]\n",
      "epoch: 566, loss: 1.7620: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 567, loss: 1.7280: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 568, loss: 1.8446: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 569, loss: 1.5745: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 570, loss: 1.6341: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 571, loss: 1.7629: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 572, loss: 1.9185: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 573, loss: 1.9907: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 574, loss: 1.7910: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 575, loss: 1.8546: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 576, loss: 1.7116: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 577, loss: 1.9127: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 578, loss: 1.7852: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 579, loss: 1.9250: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 580, loss: 1.8334: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 581, loss: 2.0009: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 582, loss: 1.7299: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 583, loss: 1.8030: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 584, loss: 1.6819: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 585, loss: 1.8149: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 586, loss: 1.8244: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 587, loss: 1.8197: 100%|██████████| 100/100 [00:01<00:00, 61.02it/s]\n",
      "epoch: 588, loss: 1.7818: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 589, loss: 1.9469: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 590, loss: 1.9153: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 591, loss: 1.8724: 100%|██████████| 100/100 [00:01<00:00, 61.69it/s]\n",
      "epoch: 592, loss: 1.7152: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 593, loss: 1.8364: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 594, loss: 1.7441: 100%|██████████| 100/100 [00:01<00:00, 61.90it/s]\n",
      "epoch: 595, loss: 1.7594: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 596, loss: 1.8654: 100%|██████████| 100/100 [00:01<00:00, 60.88it/s]\n",
      "epoch: 597, loss: 1.6626: 100%|██████████| 100/100 [00:01<00:00, 60.17it/s]\n",
      "epoch: 598, loss: 1.8852: 100%|██████████| 100/100 [00:01<00:00, 59.83it/s]\n",
      "epoch: 599, loss: 1.8136: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 600, loss: 1.7069: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 601, loss: 1.7291: 100%|██████████| 100/100 [00:01<00:00, 61.75it/s]\n",
      "epoch: 602, loss: 1.7901: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 603, loss: 2.0626: 100%|██████████| 100/100 [00:01<00:00, 61.78it/s]\n",
      "epoch: 604, loss: 1.9515: 100%|██████████| 100/100 [00:01<00:00, 61.76it/s]\n",
      "epoch: 605, loss: 1.4812: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 606, loss: 1.8113: 100%|██████████| 100/100 [00:01<00:00, 61.78it/s]\n",
      "epoch: 607, loss: 1.8793: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 608, loss: 1.7944: 100%|██████████| 100/100 [00:01<00:00, 61.83it/s]\n",
      "epoch: 609, loss: 1.9537: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 610, loss: 1.5780: 100%|██████████| 100/100 [00:01<00:00, 61.74it/s]\n",
      "epoch: 611, loss: 1.9761: 100%|██████████| 100/100 [00:01<00:00, 61.66it/s]\n",
      "epoch: 612, loss: 1.9360: 100%|██████████| 100/100 [00:01<00:00, 61.73it/s]\n",
      "epoch: 613, loss: 2.0742: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 614, loss: 2.1362: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 615, loss: 1.8030: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 616, loss: 1.7252: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 617, loss: 1.8462: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 618, loss: 1.7834: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 619, loss: 1.6529: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 620, loss: 1.8404: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 621, loss: 1.7136: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 622, loss: 1.7239: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 623, loss: 1.7311: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 624, loss: 1.6665: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 625, loss: 1.8021: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 626, loss: 1.8496: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 627, loss: 1.8594: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 628, loss: 1.7463: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 629, loss: 1.8074: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 630, loss: 1.8831: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 631, loss: 1.7867: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 632, loss: 2.0355: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 633, loss: 1.7977: 100%|██████████| 100/100 [00:01<00:00, 60.69it/s]\n",
      "epoch: 634, loss: 1.7461: 100%|██████████| 100/100 [00:01<00:00, 59.70it/s]\n",
      "epoch: 635, loss: 2.0513: 100%|██████████| 100/100 [00:01<00:00, 59.84it/s]\n",
      "epoch: 636, loss: 1.8802: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 637, loss: 1.7307: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 638, loss: 1.7963: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 639, loss: 1.6629: 100%|██████████| 100/100 [00:01<00:00, 61.69it/s]\n",
      "epoch: 640, loss: 1.8024: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 641, loss: 1.8245: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 642, loss: 1.8903: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 643, loss: 1.9594: 100%|██████████| 100/100 [00:01<00:00, 60.80it/s]\n",
      "epoch: 644, loss: 1.6791: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 645, loss: 1.6765: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 646, loss: 1.6902: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 647, loss: 1.8060: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 648, loss: 1.8133: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 649, loss: 1.6894: 100%|██████████| 100/100 [00:01<00:00, 61.97it/s]\n",
      "epoch: 650, loss: 1.5263: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 651, loss: 1.9335: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 652, loss: 1.6742: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 653, loss: 1.6809: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 654, loss: 1.8513: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 655, loss: 1.6877: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 656, loss: 1.8051: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 657, loss: 1.8091: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 658, loss: 1.7749: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 659, loss: 1.5542: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 660, loss: 2.0045: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 661, loss: 1.9269: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 662, loss: 1.8092: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 663, loss: 2.0925: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 664, loss: 1.7274: 100%|██████████| 100/100 [00:01<00:00, 61.88it/s]\n",
      "epoch: 665, loss: 1.6682: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 666, loss: 1.7979: 100%|██████████| 100/100 [00:01<00:00, 61.82it/s]\n",
      "epoch: 667, loss: 1.8238: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 668, loss: 1.9954: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 669, loss: 1.9260: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 670, loss: 2.0263: 100%|██████████| 100/100 [00:01<00:00, 59.72it/s]\n",
      "epoch: 671, loss: 1.7728: 100%|██████████| 100/100 [00:01<00:00, 59.45it/s]\n",
      "epoch: 672, loss: 1.8840: 100%|██████████| 100/100 [00:01<00:00, 59.19it/s]\n",
      "epoch: 673, loss: 1.9197: 100%|██████████| 100/100 [00:01<00:00, 59.43it/s]\n",
      "epoch: 674, loss: 1.8571: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 675, loss: 2.1175: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 676, loss: 2.0493: 100%|██████████| 100/100 [00:01<00:00, 61.77it/s]\n",
      "epoch: 677, loss: 1.7659: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 678, loss: 1.6711: 100%|██████████| 100/100 [00:01<00:00, 61.79it/s]\n",
      "epoch: 679, loss: 1.6901: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 680, loss: 2.0095: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 681, loss: 1.8578: 100%|██████████| 100/100 [00:01<00:00, 61.75it/s]\n",
      "epoch: 682, loss: 2.0675: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 683, loss: 1.8417: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 684, loss: 1.7401: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 685, loss: 1.8462: 100%|██████████| 100/100 [00:01<00:00, 61.69it/s]\n",
      "epoch: 686, loss: 1.7797: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 687, loss: 1.8076: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 688, loss: 1.8363: 100%|██████████| 100/100 [00:01<00:00, 61.50it/s]\n",
      "epoch: 689, loss: 1.8133: 100%|██████████| 100/100 [00:01<00:00, 61.69it/s]\n",
      "epoch: 690, loss: 1.8315: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 691, loss: 1.7470: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 692, loss: 1.7812: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 693, loss: 1.5458: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 694, loss: 1.5661: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 695, loss: 1.8472: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 696, loss: 1.7407: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 697, loss: 1.8831: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 698, loss: 1.7838: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 699, loss: 1.8773: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 700, loss: 1.6853: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 701, loss: 1.8590: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 702, loss: 1.8376: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 703, loss: 1.8246: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 704, loss: 1.7219: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 705, loss: 1.7773: 100%|██████████| 100/100 [00:01<00:00, 61.75it/s]\n",
      "epoch: 706, loss: 1.7368: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 707, loss: 1.9208: 100%|██████████| 100/100 [00:01<00:00, 58.94it/s]\n",
      "epoch: 708, loss: 1.8336: 100%|██████████| 100/100 [00:01<00:00, 59.51it/s]\n",
      "epoch: 709, loss: 1.6525: 100%|██████████| 100/100 [00:01<00:00, 58.89it/s]\n",
      "epoch: 710, loss: 1.8524: 100%|██████████| 100/100 [00:01<00:00, 59.55it/s]\n",
      "epoch: 711, loss: 1.8733: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 712, loss: 1.8517: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 713, loss: 1.8345: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 714, loss: 1.8839: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 715, loss: 1.8885: 100%|██████████| 100/100 [00:01<00:00, 61.87it/s]\n",
      "epoch: 716, loss: 1.6572: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 717, loss: 1.6117: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 718, loss: 1.8089: 100%|██████████| 100/100 [00:01<00:00, 61.68it/s]\n",
      "epoch: 719, loss: 1.9386: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 720, loss: 1.9361: 100%|██████████| 100/100 [00:01<00:00, 61.74it/s]\n",
      "epoch: 721, loss: 1.7080: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 722, loss: 1.5015: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 723, loss: 1.7713: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 724, loss: 1.5379: 100%|██████████| 100/100 [00:01<00:00, 61.74it/s]\n",
      "epoch: 725, loss: 1.6393: 100%|██████████| 100/100 [00:01<00:00, 61.87it/s]\n",
      "epoch: 726, loss: 1.9020: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 727, loss: 1.8766: 100%|██████████| 100/100 [00:01<00:00, 61.72it/s]\n",
      "epoch: 728, loss: 1.6178: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 729, loss: 2.0806: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 730, loss: 1.9719: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 731, loss: 1.8178: 100%|██████████| 100/100 [00:01<00:00, 61.86it/s]\n",
      "epoch: 732, loss: 1.8627: 100%|██████████| 100/100 [00:01<00:00, 61.78it/s]\n",
      "epoch: 733, loss: 1.6112: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 734, loss: 1.7492: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 735, loss: 2.0616: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 736, loss: 1.7535: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 737, loss: 1.7793: 100%|██████████| 100/100 [00:01<00:00, 61.86it/s]\n",
      "epoch: 738, loss: 1.8029: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 739, loss: 1.6814: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 740, loss: 1.6404: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 741, loss: 2.0445: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 742, loss: 1.8533: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 743, loss: 1.8974: 100%|██████████| 100/100 [00:01<00:00, 60.97it/s]\n",
      "epoch: 744, loss: 1.8328: 100%|██████████| 100/100 [00:01<00:00, 59.25it/s]\n",
      "epoch: 745, loss: 1.5975: 100%|██████████| 100/100 [00:01<00:00, 58.85it/s]\n",
      "epoch: 746, loss: 1.7879: 100%|██████████| 100/100 [00:01<00:00, 59.10it/s]\n",
      "epoch: 747, loss: 1.6374: 100%|██████████| 100/100 [00:01<00:00, 59.62it/s]\n",
      "epoch: 748, loss: 1.8168: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 749, loss: 1.6305: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 750, loss: 1.7411: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 751, loss: 2.0366: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 752, loss: 1.7865: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 753, loss: 1.7047: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 754, loss: 1.6597: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 755, loss: 1.8184: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 756, loss: 1.5699: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 757, loss: 2.0037: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 758, loss: 1.9090: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 759, loss: 1.8880: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 760, loss: 1.6126: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 761, loss: 1.6634: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 762, loss: 1.9359: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 763, loss: 1.8216: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 764, loss: 2.0412: 100%|██████████| 100/100 [00:01<00:00, 61.39it/s]\n",
      "epoch: 765, loss: 1.8154: 100%|██████████| 100/100 [00:01<00:00, 61.75it/s]\n",
      "epoch: 766, loss: 1.8240: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 767, loss: 1.9211: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 768, loss: 1.6313: 100%|██████████| 100/100 [00:01<00:00, 61.78it/s]\n",
      "epoch: 769, loss: 1.5643: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 770, loss: 1.8951: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 771, loss: 1.7185: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 772, loss: 1.9549: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 773, loss: 1.8094: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 774, loss: 1.8807: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 775, loss: 1.9024: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 776, loss: 1.7136: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 777, loss: 1.7997: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 778, loss: 1.7586: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 779, loss: 1.7929: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 780, loss: 1.7517: 100%|██████████| 100/100 [00:01<00:00, 59.93it/s]\n",
      "epoch: 781, loss: 2.0008: 100%|██████████| 100/100 [00:01<00:00, 59.26it/s]\n",
      "epoch: 782, loss: 1.6284: 100%|██████████| 100/100 [00:01<00:00, 59.18it/s]\n",
      "epoch: 783, loss: 1.9012: 100%|██████████| 100/100 [00:01<00:00, 59.40it/s]\n",
      "epoch: 784, loss: 1.8810: 100%|██████████| 100/100 [00:01<00:00, 60.50it/s]\n",
      "epoch: 785, loss: 1.5116: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 786, loss: 1.7370: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 787, loss: 1.5961: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 788, loss: 1.9003: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 789, loss: 1.9337: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 790, loss: 1.8138: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 791, loss: 1.9580: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 792, loss: 1.9732: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 793, loss: 1.8555: 100%|██████████| 100/100 [00:01<00:00, 60.83it/s]\n",
      "epoch: 794, loss: 1.6642: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 795, loss: 1.8511: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 796, loss: 2.0346: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 797, loss: 1.7521: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 798, loss: 1.8650: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 799, loss: 1.7958: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 800, loss: 2.0116: 100%|██████████| 100/100 [00:01<00:00, 61.20it/s]\n",
      "epoch: 801, loss: 1.9455: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 802, loss: 1.8063: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 803, loss: 1.7088: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 804, loss: 1.8501: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 805, loss: 1.7198: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 806, loss: 2.0137: 100%|██████████| 100/100 [00:01<00:00, 60.94it/s]\n",
      "epoch: 807, loss: 1.9273: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 808, loss: 1.8452: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 809, loss: 1.7587: 100%|██████████| 100/100 [00:01<00:00, 61.02it/s]\n",
      "epoch: 810, loss: 1.7528: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 811, loss: 1.8780: 100%|██████████| 100/100 [00:01<00:00, 61.24it/s]\n",
      "epoch: 812, loss: 1.7532: 100%|██████████| 100/100 [00:01<00:00, 61.13it/s]\n",
      "epoch: 813, loss: 1.8219: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 814, loss: 1.7615: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 815, loss: 2.0671: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 816, loss: 1.8015: 100%|██████████| 100/100 [00:01<00:00, 60.85it/s]\n",
      "epoch: 817, loss: 1.7401: 100%|██████████| 100/100 [00:01<00:00, 76.71it/s]\n",
      "epoch: 818, loss: 1.7996: 100%|██████████| 100/100 [00:01<00:00, 78.00it/s]\n",
      "epoch: 819, loss: 1.8454: 100%|██████████| 100/100 [00:01<00:00, 78.32it/s]\n",
      "epoch: 820, loss: 1.8833: 100%|██████████| 100/100 [00:01<00:00, 70.46it/s]\n",
      "epoch: 821, loss: 1.6383: 100%|██████████| 100/100 [00:01<00:00, 70.88it/s]\n",
      "epoch: 822, loss: 1.5268: 100%|██████████| 100/100 [00:01<00:00, 65.54it/s]\n",
      "epoch: 823, loss: 1.8404: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 824, loss: 1.7831: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 825, loss: 1.8681: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 826, loss: 1.8382: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 827, loss: 1.5980: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 828, loss: 1.8168: 100%|██████████| 100/100 [00:01<00:00, 61.07it/s]\n",
      "epoch: 829, loss: 1.7812: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 830, loss: 1.9225: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 831, loss: 1.6989: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 832, loss: 1.9013: 100%|██████████| 100/100 [00:01<00:00, 61.81it/s]\n",
      "epoch: 833, loss: 1.7641: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 834, loss: 1.8578: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 835, loss: 2.0141: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 836, loss: 1.6505: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 837, loss: 2.2400: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 838, loss: 1.8156: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 839, loss: 1.9765: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 840, loss: 1.6625: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 841, loss: 1.8059: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 842, loss: 1.9070: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 843, loss: 1.9590: 100%|██████████| 100/100 [00:01<00:00, 61.23it/s]\n",
      "epoch: 844, loss: 1.7305: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 845, loss: 1.8190: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 846, loss: 1.8568: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 847, loss: 1.9445: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 848, loss: 1.6543: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 849, loss: 1.9004: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 850, loss: 1.8665: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 851, loss: 1.9521: 100%|██████████| 100/100 [00:01<00:00, 60.95it/s]\n",
      "epoch: 852, loss: 1.9594: 100%|██████████| 100/100 [00:01<00:00, 60.82it/s]\n",
      "epoch: 853, loss: 2.0303: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 854, loss: 2.0085: 100%|██████████| 100/100 [00:01<00:00, 65.71it/s]\n",
      "epoch: 855, loss: 1.7500: 100%|██████████| 100/100 [00:01<00:00, 78.13it/s]\n",
      "epoch: 856, loss: 1.7048: 100%|██████████| 100/100 [00:01<00:00, 74.36it/s]\n",
      "epoch: 857, loss: 1.6889: 100%|██████████| 100/100 [00:01<00:00, 75.08it/s]\n",
      "epoch: 858, loss: 1.7322: 100%|██████████| 100/100 [00:01<00:00, 73.32it/s]\n",
      "epoch: 859, loss: 1.9509: 100%|██████████| 100/100 [00:01<00:00, 75.00it/s]\n",
      "epoch: 860, loss: 1.7014: 100%|██████████| 100/100 [00:01<00:00, 67.68it/s]\n",
      "epoch: 861, loss: 1.9178: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 862, loss: 1.6075: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 863, loss: 1.8148: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 864, loss: 1.5708: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 865, loss: 1.7709: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 866, loss: 1.6138: 100%|██████████| 100/100 [00:01<00:00, 61.47it/s]\n",
      "epoch: 867, loss: 1.5606: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 868, loss: 1.7907: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 869, loss: 1.8893: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 870, loss: 1.6526: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 871, loss: 1.9231: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 872, loss: 1.8999: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 873, loss: 1.8509: 100%|██████████| 100/100 [00:01<00:00, 61.42it/s]\n",
      "epoch: 874, loss: 1.6263: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 875, loss: 1.5004: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 876, loss: 1.6701: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 877, loss: 2.0795: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 878, loss: 1.6581: 100%|██████████| 100/100 [00:01<00:00, 61.30it/s]\n",
      "epoch: 879, loss: 1.8199: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 880, loss: 1.8417: 100%|██████████| 100/100 [00:01<00:00, 61.26it/s]\n",
      "epoch: 881, loss: 1.8400: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 882, loss: 1.7723: 100%|██████████| 100/100 [00:01<00:00, 61.04it/s]\n",
      "epoch: 883, loss: 1.9899: 100%|██████████| 100/100 [00:01<00:00, 67.37it/s]\n",
      "epoch: 884, loss: 1.6884: 100%|██████████| 100/100 [00:01<00:00, 75.43it/s]\n",
      "epoch: 885, loss: 1.7775: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 886, loss: 1.7669: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 887, loss: 1.7248: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 888, loss: 1.6868: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 889, loss: 1.7956: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 890, loss: 1.7774: 100%|██████████| 100/100 [00:01<00:00, 61.18it/s]\n",
      "epoch: 891, loss: 1.6412: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 892, loss: 1.8200: 100%|██████████| 100/100 [00:01<00:00, 64.13it/s]\n",
      "epoch: 893, loss: 1.8287: 100%|██████████| 100/100 [00:01<00:00, 76.79it/s]\n",
      "epoch: 894, loss: 1.9684: 100%|██████████| 100/100 [00:01<00:00, 72.67it/s]\n",
      "epoch: 895, loss: 1.9713: 100%|██████████| 100/100 [00:01<00:00, 72.56it/s]\n",
      "epoch: 896, loss: 1.7336: 100%|██████████| 100/100 [00:01<00:00, 66.77it/s]\n",
      "epoch: 897, loss: 1.9018: 100%|██████████| 100/100 [00:01<00:00, 59.39it/s]\n",
      "epoch: 898, loss: 1.4772: 100%|██████████| 100/100 [00:01<00:00, 59.67it/s]\n",
      "epoch: 899, loss: 2.0292: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 900, loss: 1.8971: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 901, loss: 1.8780: 100%|██████████| 100/100 [00:01<00:00, 61.51it/s]\n",
      "epoch: 902, loss: 1.9071: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 903, loss: 1.5839: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 904, loss: 1.6270: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 905, loss: 1.8840: 100%|██████████| 100/100 [00:01<00:00, 61.79it/s]\n",
      "epoch: 906, loss: 1.7591: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 907, loss: 1.6545: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 908, loss: 1.6266: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 909, loss: 1.6604: 100%|██████████| 100/100 [00:01<00:00, 61.70it/s]\n",
      "epoch: 910, loss: 1.8604: 100%|██████████| 100/100 [00:01<00:00, 61.65it/s]\n",
      "epoch: 911, loss: 1.6536: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 912, loss: 1.6507: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 913, loss: 1.7816: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 914, loss: 2.0121: 100%|██████████| 100/100 [00:01<00:00, 61.71it/s]\n",
      "epoch: 915, loss: 1.6566: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 916, loss: 1.7629: 100%|██████████| 100/100 [00:01<00:00, 61.59it/s]\n",
      "epoch: 917, loss: 1.7127: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 918, loss: 1.7340: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 919, loss: 1.9692: 100%|██████████| 100/100 [00:01<00:00, 61.61it/s]\n",
      "epoch: 920, loss: 1.5861: 100%|██████████| 100/100 [00:01<00:00, 61.48it/s]\n",
      "epoch: 921, loss: 2.0010: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 922, loss: 1.6669: 100%|██████████| 100/100 [00:01<00:00, 61.43it/s]\n",
      "epoch: 923, loss: 1.7720: 100%|██████████| 100/100 [00:01<00:00, 61.63it/s]\n",
      "epoch: 924, loss: 1.8459: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 925, loss: 1.7761: 100%|██████████| 100/100 [00:01<00:00, 63.10it/s]\n",
      "epoch: 926, loss: 1.6893: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 927, loss: 1.5000: 100%|██████████| 100/100 [00:01<00:00, 62.24it/s]\n",
      "epoch: 928, loss: 1.9089: 100%|██████████| 100/100 [00:01<00:00, 66.07it/s]\n",
      "epoch: 929, loss: 1.7071: 100%|██████████| 100/100 [00:01<00:00, 64.26it/s]\n",
      "epoch: 930, loss: 1.8576: 100%|██████████| 100/100 [00:01<00:00, 69.37it/s]\n",
      "epoch: 931, loss: 1.7698: 100%|██████████| 100/100 [00:01<00:00, 79.73it/s]\n",
      "epoch: 932, loss: 1.9661: 100%|██████████| 100/100 [00:01<00:00, 76.13it/s]\n",
      "epoch: 933, loss: 1.7337: 100%|██████████| 100/100 [00:01<00:00, 70.79it/s]\n",
      "epoch: 934, loss: 1.8355: 100%|██████████| 100/100 [00:01<00:00, 70.08it/s]\n",
      "epoch: 935, loss: 1.6593: 100%|██████████| 100/100 [00:01<00:00, 73.53it/s]\n",
      "epoch: 936, loss: 1.7913: 100%|██████████| 100/100 [00:01<00:00, 75.80it/s]\n",
      "epoch: 937, loss: 2.0049: 100%|██████████| 100/100 [00:01<00:00, 64.54it/s]\n",
      "epoch: 938, loss: 1.9603: 100%|██████████| 100/100 [00:01<00:00, 61.32it/s]\n",
      "epoch: 939, loss: 1.7987: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 940, loss: 1.5277: 100%|██████████| 100/100 [00:01<00:00, 61.33it/s]\n",
      "epoch: 941, loss: 2.1271: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 942, loss: 1.9270: 100%|██████████| 100/100 [00:01<00:00, 61.35it/s]\n",
      "epoch: 943, loss: 2.0097: 100%|██████████| 100/100 [00:01<00:00, 61.28it/s]\n",
      "epoch: 944, loss: 1.7488: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n",
      "epoch: 945, loss: 1.9925: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 946, loss: 1.6231: 100%|██████████| 100/100 [00:01<00:00, 61.05it/s]\n",
      "epoch: 947, loss: 1.9915: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 948, loss: 1.7605: 100%|██████████| 100/100 [00:01<00:00, 61.14it/s]\n",
      "epoch: 949, loss: 1.8139: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 950, loss: 1.7210: 100%|██████████| 100/100 [00:01<00:00, 61.08it/s]\n",
      "epoch: 951, loss: 1.9147: 100%|██████████| 100/100 [00:01<00:00, 61.01it/s]\n",
      "epoch: 952, loss: 1.7555: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 953, loss: 1.8021: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 954, loss: 1.8583: 100%|██████████| 100/100 [00:01<00:00, 68.03it/s]\n",
      "epoch: 955, loss: 1.9614: 100%|██████████| 100/100 [00:01<00:00, 60.83it/s]\n",
      "epoch: 956, loss: 1.8950: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 957, loss: 1.7122: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 958, loss: 1.8223: 100%|██████████| 100/100 [00:01<00:00, 61.19it/s]\n",
      "epoch: 959, loss: 1.6235: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 960, loss: 1.8325: 100%|██████████| 100/100 [00:01<00:00, 61.45it/s]\n",
      "epoch: 961, loss: 1.6040: 100%|██████████| 100/100 [00:01<00:00, 61.76it/s]\n",
      "epoch: 962, loss: 1.8871: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 963, loss: 1.7588: 100%|██████████| 100/100 [00:01<00:00, 61.10it/s]\n",
      "epoch: 964, loss: 1.6149: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 965, loss: 1.9458: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 966, loss: 1.9117: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 967, loss: 2.0873: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 968, loss: 1.8745: 100%|██████████| 100/100 [00:01<00:00, 68.27it/s]\n",
      "epoch: 969, loss: 1.6998: 100%|██████████| 100/100 [00:01<00:00, 63.98it/s]\n",
      "epoch: 970, loss: 1.8575: 100%|██████████| 100/100 [00:01<00:00, 59.27it/s]\n",
      "epoch: 971, loss: 1.8516: 100%|██████████| 100/100 [00:01<00:00, 59.31it/s]\n",
      "epoch: 972, loss: 1.7995: 100%|██████████| 100/100 [00:01<00:00, 59.00it/s]\n",
      "epoch: 973, loss: 1.7576: 100%|██████████| 100/100 [00:01<00:00, 59.20it/s]\n",
      "epoch: 974, loss: 1.5854: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 975, loss: 1.9845: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 976, loss: 1.7314: 100%|██████████| 100/100 [00:01<00:00, 61.46it/s]\n",
      "epoch: 977, loss: 1.8071: 100%|██████████| 100/100 [00:01<00:00, 61.56it/s]\n",
      "epoch: 978, loss: 1.8473: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 979, loss: 1.7186: 100%|██████████| 100/100 [00:01<00:00, 61.53it/s]\n",
      "epoch: 980, loss: 1.8725: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 981, loss: 1.7781: 100%|██████████| 100/100 [00:01<00:00, 61.55it/s]\n",
      "epoch: 982, loss: 1.9308: 100%|██████████| 100/100 [00:01<00:00, 61.29it/s]\n",
      "epoch: 983, loss: 1.9600: 100%|██████████| 100/100 [00:01<00:00, 61.54it/s]\n",
      "epoch: 984, loss: 1.9440: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 985, loss: 1.5805: 100%|██████████| 100/100 [00:01<00:00, 61.49it/s]\n",
      "epoch: 986, loss: 1.7539: 100%|██████████| 100/100 [00:01<00:00, 61.82it/s]\n",
      "epoch: 987, loss: 1.9519: 100%|██████████| 100/100 [00:01<00:00, 61.37it/s]\n",
      "epoch: 988, loss: 1.7590: 100%|██████████| 100/100 [00:01<00:00, 61.41it/s]\n",
      "epoch: 989, loss: 1.7921: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 990, loss: 1.9906: 100%|██████████| 100/100 [00:01<00:00, 61.31it/s]\n",
      "epoch: 991, loss: 1.8840: 100%|██████████| 100/100 [00:01<00:00, 61.44it/s]\n",
      "epoch: 992, loss: 1.8068: 100%|██████████| 100/100 [00:01<00:00, 61.21it/s]\n",
      "epoch: 993, loss: 1.5807: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 994, loss: 2.0017: 100%|██████████| 100/100 [00:01<00:00, 61.27it/s]\n",
      "epoch: 995, loss: 1.6011: 100%|██████████| 100/100 [00:01<00:00, 61.34it/s]\n",
      "epoch: 996, loss: 1.8056: 100%|██████████| 100/100 [00:01<00:00, 61.36it/s]\n",
      "epoch: 997, loss: 1.8555: 100%|██████████| 100/100 [00:01<00:00, 61.38it/s]\n",
      "epoch: 998, loss: 1.7801: 100%|██████████| 100/100 [00:01<00:00, 61.64it/s]\n",
      "epoch: 999, loss: 1.6517: 100%|██████████| 100/100 [00:01<00:00, 61.40it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "samples = float2bin(db.gen_batch(50000), bm)\n",
    "mean = np.mean(samples, axis=0)\n",
    "init_dist = torch.distributions.Bernoulli(probs=torch.from_numpy(mean).to(device) * (1. - 2 * 1e-2) + 1e-2)\n",
    "net = MLPScore(input_dim=32, hidden_dims=[256,256,256,1]).to(device)\n",
    "energy_func = EBM(net, torch.from_numpy(mean)).to(device)\n",
    "ema_energy_func = training_main_loop(db, bm, energy_func, device, algo='ed_bern_grad')\n",
    "plot_heat(ema_energy_func, bm, device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Discrete EBM using ED-$\\nabla$ Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 0, loss: 6.8736: 100%|██████████| 100/100 [00:01<00:00, 63.37it/s]\n",
      "epoch: 1, loss: 6.4611: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 2, loss: 6.2862: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 3, loss: 6.2669: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 4, loss: 6.3269: 100%|██████████| 100/100 [00:01<00:00, 62.30it/s]\n",
      "epoch: 5, loss: 6.4653: 100%|██████████| 100/100 [00:01<00:00, 60.99it/s]\n",
      "epoch: 6, loss: 6.2840: 100%|██████████| 100/100 [00:01<00:00, 60.73it/s]\n",
      "epoch: 7, loss: 6.2629: 100%|██████████| 100/100 [00:01<00:00, 60.65it/s]\n",
      "epoch: 8, loss: 6.1844: 100%|██████████| 100/100 [00:01<00:00, 60.76it/s]\n",
      "epoch: 9, loss: 6.3530: 100%|██████████| 100/100 [00:01<00:00, 60.98it/s]\n",
      "epoch: 10, loss: 6.2370: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 11, loss: 6.3653: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 12, loss: 6.3330: 100%|██████████| 100/100 [00:01<00:00, 63.21it/s]\n",
      "epoch: 13, loss: 6.1307: 100%|██████████| 100/100 [00:01<00:00, 63.32it/s]\n",
      "epoch: 14, loss: 6.2513: 100%|██████████| 100/100 [00:01<00:00, 63.18it/s]\n",
      "epoch: 15, loss: 6.1998: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 16, loss: 6.1273: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 17, loss: 6.3174: 100%|██████████| 100/100 [00:01<00:00, 63.07it/s]\n",
      "epoch: 18, loss: 6.0922: 100%|██████████| 100/100 [00:01<00:00, 62.30it/s]\n",
      "epoch: 19, loss: 6.2769: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 20, loss: 6.3735: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 21, loss: 6.3481: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 22, loss: 6.4023: 100%|██████████| 100/100 [00:01<00:00, 63.40it/s]\n",
      "epoch: 23, loss: 6.2745: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 24, loss: 6.3902: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 25, loss: 6.1887: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 26, loss: 6.2000: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 27, loss: 6.1747: 100%|██████████| 100/100 [00:01<00:00, 62.89it/s]\n",
      "epoch: 28, loss: 6.2170: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 29, loss: 6.1601: 100%|██████████| 100/100 [00:01<00:00, 63.13it/s]\n",
      "epoch: 30, loss: 6.2511: 100%|██████████| 100/100 [00:01<00:00, 62.32it/s]\n",
      "epoch: 31, loss: 6.1720: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 32, loss: 6.1863: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 33, loss: 6.1650: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 34, loss: 6.3683: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 35, loss: 6.2380: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 36, loss: 6.4478: 100%|██████████| 100/100 [00:01<00:00, 62.97it/s]\n",
      "epoch: 37, loss: 6.1656: 100%|██████████| 100/100 [00:01<00:00, 62.58it/s]\n",
      "epoch: 38, loss: 6.1245: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 39, loss: 6.2785: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 40, loss: 6.2432: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 41, loss: 6.0512: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 42, loss: 6.0971: 100%|██████████| 100/100 [00:01<00:00, 62.52it/s]\n",
      "epoch: 43, loss: 6.2844: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 44, loss: 6.1417: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 45, loss: 6.0590: 100%|██████████| 100/100 [00:01<00:00, 63.16it/s]\n",
      "epoch: 46, loss: 6.0348: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 47, loss: 6.3587: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 48, loss: 6.2154: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 49, loss: 6.2308: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 50, loss: 6.2780: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 51, loss: 6.3375: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 52, loss: 6.1470: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 53, loss: 6.1143: 100%|██████████| 100/100 [00:01<00:00, 62.58it/s]\n",
      "epoch: 54, loss: 6.5564: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 55, loss: 6.2884: 100%|██████████| 100/100 [00:01<00:00, 62.67it/s]\n",
      "epoch: 56, loss: 6.3145: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 57, loss: 6.3368: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 58, loss: 6.1952: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 59, loss: 6.2274: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 60, loss: 6.3145: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 61, loss: 6.0845: 100%|██████████| 100/100 [00:01<00:00, 62.40it/s]\n",
      "epoch: 62, loss: 6.2580: 100%|██████████| 100/100 [00:01<00:00, 63.16it/s]\n",
      "epoch: 63, loss: 6.3309: 100%|██████████| 100/100 [00:01<00:00, 62.41it/s]\n",
      "epoch: 64, loss: 6.2724: 100%|██████████| 100/100 [00:01<00:00, 63.33it/s]\n",
      "epoch: 65, loss: 6.1427: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 66, loss: 6.2715: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 67, loss: 6.3534: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 68, loss: 6.2603: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 69, loss: 6.3431: 100%|██████████| 100/100 [00:01<00:00, 63.19it/s]\n",
      "epoch: 70, loss: 6.1004: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 71, loss: 6.0798: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 72, loss: 6.4297: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 73, loss: 6.1474: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 74, loss: 6.1409: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 75, loss: 6.0354: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 76, loss: 6.1189: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 77, loss: 6.0806: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 78, loss: 6.1335: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 79, loss: 6.2956: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 80, loss: 6.2608: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 81, loss: 6.3623: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 82, loss: 6.2675: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 83, loss: 6.3277: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 84, loss: 6.2671: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 85, loss: 6.3218: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 86, loss: 6.3424: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 87, loss: 6.2590: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 88, loss: 6.1163: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 89, loss: 6.4747: 100%|██████████| 100/100 [00:01<00:00, 62.56it/s]\n",
      "epoch: 90, loss: 6.2866: 100%|██████████| 100/100 [00:01<00:00, 62.67it/s]\n",
      "epoch: 91, loss: 5.9574: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 92, loss: 6.2488: 100%|██████████| 100/100 [00:01<00:00, 63.12it/s]\n",
      "epoch: 93, loss: 5.9006: 100%|██████████| 100/100 [00:01<00:00, 69.80it/s]\n",
      "epoch: 94, loss: 6.0843: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 95, loss: 6.2380: 100%|██████████| 100/100 [00:01<00:00, 63.15it/s]\n",
      "epoch: 96, loss: 6.0013: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 97, loss: 6.3797: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 98, loss: 6.2586: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 99, loss: 6.1690: 100%|██████████| 100/100 [00:01<00:00, 62.35it/s]\n",
      "epoch: 100, loss: 6.0411: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 101, loss: 6.1859: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 102, loss: 6.1762: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 103, loss: 6.3387: 100%|██████████| 100/100 [00:01<00:00, 62.66it/s]\n",
      "epoch: 104, loss: 6.2802: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 105, loss: 6.3019: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 106, loss: 6.1617: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 107, loss: 6.1835: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 108, loss: 6.0880: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 109, loss: 6.3331: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 110, loss: 6.2885: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 111, loss: 6.2152: 100%|██████████| 100/100 [00:01<00:00, 62.41it/s]\n",
      "epoch: 112, loss: 6.1844: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 113, loss: 6.1716: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 114, loss: 6.2998: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 115, loss: 6.1594: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 116, loss: 6.2309: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 117, loss: 6.2112: 100%|██████████| 100/100 [00:01<00:00, 62.26it/s]\n",
      "epoch: 118, loss: 6.2461: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 119, loss: 6.3209: 100%|██████████| 100/100 [00:01<00:00, 63.08it/s]\n",
      "epoch: 120, loss: 6.3340: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 121, loss: 5.9304: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 122, loss: 6.1993: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 123, loss: 6.2823: 100%|██████████| 100/100 [00:01<00:00, 62.97it/s]\n",
      "epoch: 124, loss: 6.1819: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 125, loss: 6.0831: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 126, loss: 6.1667: 100%|██████████| 100/100 [00:01<00:00, 63.21it/s]\n",
      "epoch: 127, loss: 6.1738: 100%|██████████| 100/100 [00:01<00:00, 63.28it/s]\n",
      "epoch: 128, loss: 6.2294: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 129, loss: 6.2484: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 130, loss: 6.1575: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 131, loss: 6.2708: 100%|██████████| 100/100 [00:01<00:00, 62.47it/s]\n",
      "epoch: 132, loss: 6.1837: 100%|██████████| 100/100 [00:01<00:00, 63.00it/s]\n",
      "epoch: 133, loss: 6.3276: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 134, loss: 6.3316: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 135, loss: 6.2755: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 136, loss: 6.3145: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 137, loss: 6.2712: 100%|██████████| 100/100 [00:01<00:00, 63.14it/s]\n",
      "epoch: 138, loss: 6.0367: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 139, loss: 6.3453: 100%|██████████| 100/100 [00:01<00:00, 63.20it/s]\n",
      "epoch: 140, loss: 6.1776: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 141, loss: 6.0617: 100%|██████████| 100/100 [00:01<00:00, 63.43it/s]\n",
      "epoch: 142, loss: 6.2604: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 143, loss: 6.1837: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 144, loss: 6.1475: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 145, loss: 6.0904: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 146, loss: 6.4219: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 147, loss: 6.1282: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 148, loss: 6.2790: 100%|██████████| 100/100 [00:01<00:00, 63.18it/s]\n",
      "epoch: 149, loss: 6.1534: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 150, loss: 6.3162: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 151, loss: 6.0655: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 152, loss: 6.1252: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 153, loss: 5.9590: 100%|██████████| 100/100 [00:01<00:00, 63.19it/s]\n",
      "epoch: 154, loss: 6.1911: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 155, loss: 6.0279: 100%|██████████| 100/100 [00:01<00:00, 62.17it/s]\n",
      "epoch: 156, loss: 6.1376: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 157, loss: 6.0820: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 158, loss: 6.2797: 100%|██████████| 100/100 [00:01<00:00, 63.14it/s]\n",
      "epoch: 159, loss: 6.1950: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 160, loss: 6.1603: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 161, loss: 6.0259: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 162, loss: 6.0439: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 163, loss: 6.2320: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 164, loss: 6.1353: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 165, loss: 6.2449: 100%|██████████| 100/100 [00:01<00:00, 63.29it/s]\n",
      "epoch: 166, loss: 6.0211: 100%|██████████| 100/100 [00:01<00:00, 62.67it/s]\n",
      "epoch: 167, loss: 6.2077: 100%|██████████| 100/100 [00:01<00:00, 63.33it/s]\n",
      "epoch: 168, loss: 6.1407: 100%|██████████| 100/100 [00:01<00:00, 62.67it/s]\n",
      "epoch: 169, loss: 6.3073: 100%|██████████| 100/100 [00:01<00:00, 62.89it/s]\n",
      "epoch: 170, loss: 6.1260: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 171, loss: 6.3052: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 172, loss: 6.3802: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 173, loss: 6.2363: 100%|██████████| 100/100 [00:01<00:00, 63.10it/s]\n",
      "epoch: 174, loss: 6.3422: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 175, loss: 6.0089: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 176, loss: 6.2022: 100%|██████████| 100/100 [00:01<00:00, 63.25it/s]\n",
      "epoch: 177, loss: 6.4706: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 178, loss: 6.2989: 100%|██████████| 100/100 [00:01<00:00, 63.20it/s]\n",
      "epoch: 179, loss: 6.1266: 100%|██████████| 100/100 [00:01<00:00, 63.10it/s]\n",
      "epoch: 180, loss: 6.2393: 100%|██████████| 100/100 [00:01<00:00, 62.52it/s]\n",
      "epoch: 181, loss: 5.9165: 100%|██████████| 100/100 [00:01<00:00, 63.24it/s]\n",
      "epoch: 182, loss: 6.1992: 100%|██████████| 100/100 [00:01<00:00, 63.08it/s]\n",
      "epoch: 183, loss: 6.1921: 100%|██████████| 100/100 [00:01<00:00, 63.20it/s]\n",
      "epoch: 184, loss: 6.1742: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 185, loss: 6.2269: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 186, loss: 6.2032: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 187, loss: 6.1129: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 188, loss: 6.0605: 100%|██████████| 100/100 [00:01<00:00, 74.56it/s]\n",
      "epoch: 189, loss: 6.3102: 100%|██████████| 100/100 [00:01<00:00, 79.40it/s]\n",
      "epoch: 190, loss: 6.1927: 100%|██████████| 100/100 [00:01<00:00, 65.91it/s]\n",
      "epoch: 191, loss: 6.2418: 100%|██████████| 100/100 [00:01<00:00, 65.42it/s]\n",
      "epoch: 192, loss: 6.2168: 100%|██████████| 100/100 [00:01<00:00, 64.54it/s]\n",
      "epoch: 193, loss: 6.1446: 100%|██████████| 100/100 [00:01<00:00, 65.97it/s]\n",
      "epoch: 194, loss: 6.2075: 100%|██████████| 100/100 [00:01<00:00, 64.05it/s]\n",
      "epoch: 195, loss: 6.1931: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 196, loss: 6.2823: 100%|██████████| 100/100 [00:01<00:00, 65.19it/s]\n",
      "epoch: 197, loss: 6.1865: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 198, loss: 6.2686: 100%|██████████| 100/100 [00:01<00:00, 62.89it/s]\n",
      "epoch: 199, loss: 6.1935: 100%|██████████| 100/100 [00:01<00:00, 63.13it/s]\n",
      "epoch: 200, loss: 6.2301: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 201, loss: 6.1089: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 202, loss: 6.2306: 100%|██████████| 100/100 [00:01<00:00, 66.98it/s]\n",
      "epoch: 203, loss: 6.2144: 100%|██████████| 100/100 [00:01<00:00, 63.30it/s]\n",
      "epoch: 204, loss: 5.8627: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 205, loss: 6.1219: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 206, loss: 6.2120: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 207, loss: 6.2289: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 208, loss: 6.1261: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 209, loss: 6.2005: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 210, loss: 6.3266: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 211, loss: 6.1318: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 212, loss: 6.2771: 100%|██████████| 100/100 [00:01<00:00, 66.54it/s]\n",
      "epoch: 213, loss: 6.2468: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 214, loss: 6.2566: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 215, loss: 6.4591: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 216, loss: 6.3719: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 217, loss: 6.3263: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 218, loss: 6.1801: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 219, loss: 6.3251: 100%|██████████| 100/100 [00:01<00:00, 62.28it/s]\n",
      "epoch: 220, loss: 6.0600: 100%|██████████| 100/100 [00:01<00:00, 61.81it/s]\n",
      "epoch: 221, loss: 6.0530: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 222, loss: 6.0208: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 223, loss: 6.2207: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 224, loss: 6.0134: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 225, loss: 6.4554: 100%|██████████| 100/100 [00:01<00:00, 63.23it/s]\n",
      "epoch: 226, loss: 6.0391: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 227, loss: 6.2765: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 228, loss: 6.3086: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 229, loss: 6.2053: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 230, loss: 6.2327: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 231, loss: 6.2503: 100%|██████████| 100/100 [00:01<00:00, 61.67it/s]\n",
      "epoch: 232, loss: 6.1165: 100%|██████████| 100/100 [00:01<00:00, 62.27it/s]\n",
      "epoch: 233, loss: 6.1965: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 234, loss: 6.3478: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 235, loss: 6.0957: 100%|██████████| 100/100 [00:01<00:00, 62.50it/s]\n",
      "epoch: 236, loss: 6.3074: 100%|██████████| 100/100 [00:01<00:00, 62.59it/s]\n",
      "epoch: 237, loss: 6.1109: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 238, loss: 6.2300: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 239, loss: 6.3833: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 240, loss: 6.3190: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 241, loss: 6.2100: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 242, loss: 6.3417: 100%|██████████| 100/100 [00:01<00:00, 63.08it/s]\n",
      "epoch: 243, loss: 6.0997: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 244, loss: 6.1115: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 245, loss: 6.0654: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 246, loss: 6.1777: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 247, loss: 6.2718: 100%|██████████| 100/100 [00:01<00:00, 62.92it/s]\n",
      "epoch: 248, loss: 6.4250: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 249, loss: 6.1778: 100%|██████████| 100/100 [00:01<00:00, 63.14it/s]\n",
      "epoch: 250, loss: 6.2358: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 251, loss: 6.3817: 100%|██████████| 100/100 [00:01<00:00, 64.46it/s]\n",
      "epoch: 252, loss: 6.3179: 100%|██████████| 100/100 [00:01<00:00, 63.96it/s]\n",
      "epoch: 253, loss: 6.1814: 100%|██████████| 100/100 [00:01<00:00, 62.28it/s]\n",
      "epoch: 254, loss: 6.2400: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 255, loss: 6.2874: 100%|██████████| 100/100 [00:01<00:00, 66.61it/s]\n",
      "epoch: 256, loss: 6.0779: 100%|██████████| 100/100 [00:01<00:00, 65.35it/s]\n",
      "epoch: 257, loss: 6.1583: 100%|██████████| 100/100 [00:01<00:00, 62.52it/s]\n",
      "epoch: 258, loss: 6.1876: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 259, loss: 6.1155: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 260, loss: 6.0355: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 261, loss: 6.0932: 100%|██████████| 100/100 [00:01<00:00, 62.58it/s]\n",
      "epoch: 262, loss: 6.2265: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 263, loss: 5.9585: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 264, loss: 6.2779: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 265, loss: 6.0899: 100%|██████████| 100/100 [00:01<00:00, 64.29it/s]\n",
      "epoch: 266, loss: 6.2763: 100%|██████████| 100/100 [00:01<00:00, 63.00it/s]\n",
      "epoch: 267, loss: 6.2104: 100%|██████████| 100/100 [00:01<00:00, 63.51it/s]\n",
      "epoch: 268, loss: 6.2441: 100%|██████████| 100/100 [00:01<00:00, 64.39it/s]\n",
      "epoch: 269, loss: 6.3495: 100%|██████████| 100/100 [00:01<00:00, 62.53it/s]\n",
      "epoch: 270, loss: 6.1474: 100%|██████████| 100/100 [00:01<00:00, 63.51it/s]\n",
      "epoch: 271, loss: 6.2476: 100%|██████████| 100/100 [00:01<00:00, 63.90it/s]\n",
      "epoch: 272, loss: 6.1800: 100%|██████████| 100/100 [00:01<00:00, 64.44it/s]\n",
      "epoch: 273, loss: 6.0706: 100%|██████████| 100/100 [00:01<00:00, 64.53it/s]\n",
      "epoch: 274, loss: 5.9938: 100%|██████████| 100/100 [00:01<00:00, 63.29it/s]\n",
      "epoch: 275, loss: 6.2872: 100%|██████████| 100/100 [00:01<00:00, 64.50it/s]\n",
      "epoch: 276, loss: 6.1478: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 277, loss: 6.2756: 100%|██████████| 100/100 [00:01<00:00, 64.70it/s]\n",
      "epoch: 278, loss: 6.2694: 100%|██████████| 100/100 [00:01<00:00, 64.21it/s]\n",
      "epoch: 279, loss: 6.1329: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 280, loss: 6.3704: 100%|██████████| 100/100 [00:01<00:00, 63.29it/s]\n",
      "epoch: 281, loss: 6.2828: 100%|██████████| 100/100 [00:01<00:00, 64.84it/s]\n",
      "epoch: 282, loss: 6.3156: 100%|██████████| 100/100 [00:01<00:00, 63.58it/s]\n",
      "epoch: 283, loss: 6.1037: 100%|██████████| 100/100 [00:01<00:00, 64.47it/s]\n",
      "epoch: 284, loss: 5.9681: 100%|██████████| 100/100 [00:01<00:00, 64.03it/s]\n",
      "epoch: 285, loss: 6.0019: 100%|██████████| 100/100 [00:01<00:00, 63.66it/s]\n",
      "epoch: 286, loss: 6.2347: 100%|██████████| 100/100 [00:01<00:00, 63.83it/s]\n",
      "epoch: 287, loss: 6.1327: 100%|██████████| 100/100 [00:01<00:00, 63.71it/s]\n",
      "epoch: 288, loss: 6.0801: 100%|██████████| 100/100 [00:01<00:00, 64.64it/s]\n",
      "epoch: 289, loss: 6.0969: 100%|██████████| 100/100 [00:01<00:00, 63.18it/s]\n",
      "epoch: 290, loss: 6.1888: 100%|██████████| 100/100 [00:01<00:00, 64.97it/s]\n",
      "epoch: 291, loss: 6.1388: 100%|██████████| 100/100 [00:01<00:00, 63.03it/s]\n",
      "epoch: 292, loss: 6.2307: 100%|██████████| 100/100 [00:01<00:00, 64.70it/s]\n",
      "epoch: 293, loss: 6.0961: 100%|██████████| 100/100 [00:01<00:00, 64.37it/s]\n",
      "epoch: 294, loss: 6.3285: 100%|██████████| 100/100 [00:01<00:00, 67.17it/s]\n",
      "epoch: 295, loss: 6.4051: 100%|██████████| 100/100 [00:01<00:00, 63.69it/s]\n",
      "epoch: 296, loss: 6.1234: 100%|██████████| 100/100 [00:01<00:00, 64.42it/s]\n",
      "epoch: 297, loss: 6.1114: 100%|██████████| 100/100 [00:01<00:00, 63.66it/s]\n",
      "epoch: 298, loss: 6.2030: 100%|██████████| 100/100 [00:01<00:00, 64.82it/s]\n",
      "epoch: 299, loss: 6.0955: 100%|██████████| 100/100 [00:01<00:00, 63.99it/s]\n",
      "epoch: 300, loss: 6.0099: 100%|██████████| 100/100 [00:01<00:00, 63.81it/s]\n",
      "epoch: 301, loss: 6.3095: 100%|██████████| 100/100 [00:01<00:00, 63.88it/s]\n",
      "epoch: 302, loss: 6.2741: 100%|██████████| 100/100 [00:01<00:00, 64.48it/s]\n",
      "epoch: 303, loss: 6.1033: 100%|██████████| 100/100 [00:01<00:00, 63.22it/s]\n",
      "epoch: 304, loss: 6.2279: 100%|██████████| 100/100 [00:01<00:00, 64.41it/s]\n",
      "epoch: 305, loss: 6.3260: 100%|██████████| 100/100 [00:01<00:00, 64.18it/s]\n",
      "epoch: 306, loss: 6.2598: 100%|██████████| 100/100 [00:01<00:00, 63.60it/s]\n",
      "epoch: 307, loss: 6.3474: 100%|██████████| 100/100 [00:01<00:00, 63.81it/s]\n",
      "epoch: 308, loss: 6.0565: 100%|██████████| 100/100 [00:01<00:00, 62.52it/s]\n",
      "epoch: 309, loss: 6.1583: 100%|██████████| 100/100 [00:01<00:00, 64.63it/s]\n",
      "epoch: 310, loss: 6.3372: 100%|██████████| 100/100 [00:01<00:00, 63.89it/s]\n",
      "epoch: 311, loss: 6.1124: 100%|██████████| 100/100 [00:01<00:00, 64.88it/s]\n",
      "epoch: 312, loss: 6.0212: 100%|██████████| 100/100 [00:01<00:00, 63.58it/s]\n",
      "epoch: 313, loss: 6.2821: 100%|██████████| 100/100 [00:01<00:00, 64.96it/s]\n",
      "epoch: 314, loss: 6.0418: 100%|██████████| 100/100 [00:01<00:00, 63.54it/s]\n",
      "epoch: 315, loss: 6.3236: 100%|██████████| 100/100 [00:01<00:00, 64.43it/s]\n",
      "epoch: 316, loss: 6.1597: 100%|██████████| 100/100 [00:01<00:00, 63.94it/s]\n",
      "epoch: 317, loss: 6.2250: 100%|██████████| 100/100 [00:01<00:00, 64.26it/s]\n",
      "epoch: 318, loss: 6.2304: 100%|██████████| 100/100 [00:01<00:00, 64.21it/s]\n",
      "epoch: 319, loss: 6.1819: 100%|██████████| 100/100 [00:01<00:00, 63.74it/s]\n",
      "epoch: 320, loss: 6.1595: 100%|██████████| 100/100 [00:01<00:00, 64.28it/s]\n",
      "epoch: 321, loss: 6.0461: 100%|██████████| 100/100 [00:01<00:00, 63.77it/s]\n",
      "epoch: 322, loss: 6.3474: 100%|██████████| 100/100 [00:01<00:00, 64.79it/s]\n",
      "epoch: 323, loss: 6.3882: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 324, loss: 6.1913: 100%|██████████| 100/100 [00:01<00:00, 64.55it/s]\n",
      "epoch: 325, loss: 6.1387: 100%|██████████| 100/100 [00:01<00:00, 63.68it/s]\n",
      "epoch: 326, loss: 6.1618: 100%|██████████| 100/100 [00:01<00:00, 64.80it/s]\n",
      "epoch: 327, loss: 6.3139: 100%|██████████| 100/100 [00:01<00:00, 63.84it/s]\n",
      "epoch: 328, loss: 6.2513: 100%|██████████| 100/100 [00:01<00:00, 64.53it/s]\n",
      "epoch: 329, loss: 6.3952: 100%|██████████| 100/100 [00:01<00:00, 63.42it/s]\n",
      "epoch: 330, loss: 6.3705: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 331, loss: 6.2464: 100%|██████████| 100/100 [00:01<00:00, 63.31it/s]\n",
      "epoch: 332, loss: 6.0772: 100%|██████████| 100/100 [00:01<00:00, 64.41it/s]\n",
      "epoch: 333, loss: 6.2599: 100%|██████████| 100/100 [00:01<00:00, 64.12it/s]\n",
      "epoch: 334, loss: 6.0680: 100%|██████████| 100/100 [00:01<00:00, 63.69it/s]\n",
      "epoch: 335, loss: 6.1623: 100%|██████████| 100/100 [00:01<00:00, 64.19it/s]\n",
      "epoch: 336, loss: 6.0498: 100%|██████████| 100/100 [00:01<00:00, 64.67it/s]\n",
      "epoch: 337, loss: 6.3052: 100%|██████████| 100/100 [00:01<00:00, 68.32it/s]\n",
      "epoch: 338, loss: 6.1221: 100%|██████████| 100/100 [00:01<00:00, 73.96it/s]\n",
      "epoch: 339, loss: 6.2996: 100%|██████████| 100/100 [00:01<00:00, 69.37it/s]\n",
      "epoch: 340, loss: 6.3128: 100%|██████████| 100/100 [00:01<00:00, 73.54it/s]\n",
      "epoch: 341, loss: 6.1045: 100%|██████████| 100/100 [00:01<00:00, 69.67it/s]\n",
      "epoch: 342, loss: 6.0756: 100%|██████████| 100/100 [00:01<00:00, 74.20it/s]\n",
      "epoch: 343, loss: 6.2502: 100%|██████████| 100/100 [00:01<00:00, 68.50it/s]\n",
      "epoch: 344, loss: 6.0242: 100%|██████████| 100/100 [00:01<00:00, 74.18it/s]\n",
      "epoch: 345, loss: 6.2985: 100%|██████████| 100/100 [00:01<00:00, 69.02it/s]\n",
      "epoch: 346, loss: 6.2548: 100%|██████████| 100/100 [00:01<00:00, 68.52it/s]\n",
      "epoch: 347, loss: 6.2376: 100%|██████████| 100/100 [00:01<00:00, 61.62it/s]\n",
      "epoch: 348, loss: 6.1463: 100%|██████████| 100/100 [00:01<00:00, 64.24it/s]\n",
      "epoch: 349, loss: 5.9186: 100%|██████████| 100/100 [00:01<00:00, 64.15it/s]\n",
      "epoch: 350, loss: 6.2386: 100%|██████████| 100/100 [00:01<00:00, 63.56it/s]\n",
      "epoch: 351, loss: 6.1350: 100%|██████████| 100/100 [00:01<00:00, 64.11it/s]\n",
      "epoch: 352, loss: 6.2146: 100%|██████████| 100/100 [00:01<00:00, 65.84it/s]\n",
      "epoch: 353, loss: 5.9597: 100%|██████████| 100/100 [00:01<00:00, 65.50it/s]\n",
      "epoch: 354, loss: 6.1556: 100%|██████████| 100/100 [00:01<00:00, 63.72it/s]\n",
      "epoch: 355, loss: 6.1296: 100%|██████████| 100/100 [00:01<00:00, 64.67it/s]\n",
      "epoch: 356, loss: 6.1891: 100%|██████████| 100/100 [00:01<00:00, 63.94it/s]\n",
      "epoch: 357, loss: 6.2849: 100%|██████████| 100/100 [00:01<00:00, 65.04it/s]\n",
      "epoch: 358, loss: 6.3129: 100%|██████████| 100/100 [00:01<00:00, 63.60it/s]\n",
      "epoch: 359, loss: 6.3067: 100%|██████████| 100/100 [00:01<00:00, 64.72it/s]\n",
      "epoch: 360, loss: 6.1737: 100%|██████████| 100/100 [00:01<00:00, 63.75it/s]\n",
      "epoch: 361, loss: 6.1710: 100%|██████████| 100/100 [00:01<00:00, 64.66it/s]\n",
      "epoch: 362, loss: 6.2614: 100%|██████████| 100/100 [00:01<00:00, 63.59it/s]\n",
      "epoch: 363, loss: 6.1214: 100%|██████████| 100/100 [00:01<00:00, 64.68it/s]\n",
      "epoch: 364, loss: 6.2564: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 365, loss: 6.1741: 100%|██████████| 100/100 [00:01<00:00, 64.19it/s]\n",
      "epoch: 366, loss: 6.2515: 100%|██████████| 100/100 [00:01<00:00, 63.63it/s]\n",
      "epoch: 367, loss: 6.3212: 100%|██████████| 100/100 [00:01<00:00, 64.02it/s]\n",
      "epoch: 368, loss: 6.2012: 100%|██████████| 100/100 [00:01<00:00, 63.99it/s]\n",
      "epoch: 369, loss: 6.2587: 100%|██████████| 100/100 [00:01<00:00, 63.91it/s]\n",
      "epoch: 370, loss: 6.1472: 100%|██████████| 100/100 [00:01<00:00, 64.92it/s]\n",
      "epoch: 371, loss: 6.0410: 100%|██████████| 100/100 [00:01<00:00, 64.15it/s]\n",
      "epoch: 372, loss: 6.1774: 100%|██████████| 100/100 [00:01<00:00, 65.11it/s]\n",
      "epoch: 373, loss: 6.1999: 100%|██████████| 100/100 [00:01<00:00, 63.44it/s]\n",
      "epoch: 374, loss: 6.0957: 100%|██████████| 100/100 [00:01<00:00, 65.33it/s]\n",
      "epoch: 375, loss: 6.2470: 100%|██████████| 100/100 [00:01<00:00, 64.11it/s]\n",
      "epoch: 376, loss: 6.0992: 100%|██████████| 100/100 [00:01<00:00, 64.53it/s]\n",
      "epoch: 377, loss: 6.2441: 100%|██████████| 100/100 [00:01<00:00, 64.18it/s]\n",
      "epoch: 378, loss: 6.0546: 100%|██████████| 100/100 [00:01<00:00, 64.27it/s]\n",
      "epoch: 379, loss: 6.1632: 100%|██████████| 100/100 [00:01<00:00, 64.35it/s]\n",
      "epoch: 380, loss: 6.1906: 100%|██████████| 100/100 [00:01<00:00, 63.84it/s]\n",
      "epoch: 381, loss: 6.3360: 100%|██████████| 100/100 [00:01<00:00, 64.97it/s]\n",
      "epoch: 382, loss: 6.1488: 100%|██████████| 100/100 [00:01<00:00, 63.57it/s]\n",
      "epoch: 383, loss: 6.1063: 100%|██████████| 100/100 [00:01<00:00, 65.30it/s]\n",
      "epoch: 384, loss: 6.3452: 100%|██████████| 100/100 [00:01<00:00, 63.60it/s]\n",
      "epoch: 385, loss: 6.2946: 100%|██████████| 100/100 [00:01<00:00, 63.30it/s]\n",
      "epoch: 386, loss: 5.9342: 100%|██████████| 100/100 [00:01<00:00, 64.57it/s]\n",
      "epoch: 387, loss: 6.1545: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 388, loss: 5.9249: 100%|██████████| 100/100 [00:01<00:00, 63.34it/s]\n",
      "epoch: 389, loss: 6.1319: 100%|██████████| 100/100 [00:01<00:00, 65.11it/s]\n",
      "epoch: 390, loss: 6.0699: 100%|██████████| 100/100 [00:01<00:00, 63.80it/s]\n",
      "epoch: 391, loss: 6.2928: 100%|██████████| 100/100 [00:01<00:00, 64.74it/s]\n",
      "epoch: 392, loss: 6.0902: 100%|██████████| 100/100 [00:01<00:00, 63.91it/s]\n",
      "epoch: 393, loss: 6.1664: 100%|██████████| 100/100 [00:01<00:00, 64.09it/s]\n",
      "epoch: 394, loss: 6.2107: 100%|██████████| 100/100 [00:01<00:00, 64.16it/s]\n",
      "epoch: 395, loss: 6.2690: 100%|██████████| 100/100 [00:01<00:00, 64.27it/s]\n",
      "epoch: 396, loss: 6.1703: 100%|██████████| 100/100 [00:01<00:00, 64.52it/s]\n",
      "epoch: 397, loss: 6.2689: 100%|██████████| 100/100 [00:01<00:00, 63.96it/s]\n",
      "epoch: 398, loss: 6.2458: 100%|██████████| 100/100 [00:01<00:00, 65.01it/s]\n",
      "epoch: 399, loss: 6.1649: 100%|██████████| 100/100 [00:01<00:00, 63.81it/s]\n",
      "epoch: 400, loss: 6.2312: 100%|██████████| 100/100 [00:01<00:00, 64.72it/s]\n",
      "epoch: 401, loss: 6.1388: 100%|██████████| 100/100 [00:01<00:00, 63.97it/s]\n",
      "epoch: 402, loss: 6.1361: 100%|██████████| 100/100 [00:01<00:00, 64.68it/s]\n",
      "epoch: 403, loss: 6.1199: 100%|██████████| 100/100 [00:01<00:00, 63.43it/s]\n",
      "epoch: 404, loss: 6.3649: 100%|██████████| 100/100 [00:01<00:00, 64.79it/s]\n",
      "epoch: 405, loss: 6.2465: 100%|██████████| 100/100 [00:01<00:00, 63.60it/s]\n",
      "epoch: 406, loss: 6.4287: 100%|██████████| 100/100 [00:01<00:00, 64.90it/s]\n",
      "epoch: 407, loss: 6.1734: 100%|██████████| 100/100 [00:01<00:00, 64.28it/s]\n",
      "epoch: 408, loss: 6.3359: 100%|██████████| 100/100 [00:01<00:00, 64.26it/s]\n",
      "epoch: 409, loss: 6.1496: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 410, loss: 6.1845: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 411, loss: 6.2130: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 412, loss: 6.2096: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 413, loss: 6.1559: 100%|██████████| 100/100 [00:01<00:00, 65.06it/s]\n",
      "epoch: 414, loss: 6.1840: 100%|██████████| 100/100 [00:01<00:00, 63.44it/s]\n",
      "epoch: 415, loss: 6.2159: 100%|██████████| 100/100 [00:01<00:00, 64.62it/s]\n",
      "epoch: 416, loss: 6.1789: 100%|██████████| 100/100 [00:01<00:00, 63.61it/s]\n",
      "epoch: 417, loss: 6.2276: 100%|██████████| 100/100 [00:01<00:00, 63.86it/s]\n",
      "epoch: 418, loss: 6.1401: 100%|██████████| 100/100 [00:01<00:00, 63.95it/s]\n",
      "epoch: 419, loss: 5.9687: 100%|██████████| 100/100 [00:01<00:00, 63.65it/s]\n",
      "epoch: 420, loss: 6.2572: 100%|██████████| 100/100 [00:01<00:00, 64.63it/s]\n",
      "epoch: 421, loss: 6.1815: 100%|██████████| 100/100 [00:01<00:00, 63.73it/s]\n",
      "epoch: 422, loss: 6.2953: 100%|██████████| 100/100 [00:01<00:00, 64.60it/s]\n",
      "epoch: 423, loss: 6.2488: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 424, loss: 6.2460: 100%|██████████| 100/100 [00:01<00:00, 63.28it/s]\n",
      "epoch: 425, loss: 6.2638: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 426, loss: 6.0896: 100%|██████████| 100/100 [00:01<00:00, 64.69it/s]\n",
      "epoch: 427, loss: 6.1249: 100%|██████████| 100/100 [00:01<00:00, 64.22it/s]\n",
      "epoch: 428, loss: 5.8686: 100%|██████████| 100/100 [00:01<00:00, 64.27it/s]\n",
      "epoch: 429, loss: 6.3646: 100%|██████████| 100/100 [00:01<00:00, 63.89it/s]\n",
      "epoch: 430, loss: 6.2523: 100%|██████████| 100/100 [00:01<00:00, 64.05it/s]\n",
      "epoch: 431, loss: 6.2215: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 432, loss: 6.2501: 100%|██████████| 100/100 [00:01<00:00, 62.48it/s]\n",
      "epoch: 433, loss: 6.0923: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 434, loss: 6.1669: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 435, loss: 6.0336: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 436, loss: 6.1653: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 437, loss: 6.3299: 100%|██████████| 100/100 [00:01<00:00, 62.56it/s]\n",
      "epoch: 438, loss: 6.2535: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 439, loss: 6.3904: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 440, loss: 6.2627: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 441, loss: 6.1996: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 442, loss: 6.1694: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 443, loss: 6.3104: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 444, loss: 6.2011: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 445, loss: 6.0807: 100%|██████████| 100/100 [00:01<00:00, 62.92it/s]\n",
      "epoch: 446, loss: 6.0724: 100%|██████████| 100/100 [00:01<00:00, 62.37it/s]\n",
      "epoch: 447, loss: 6.2415: 100%|██████████| 100/100 [00:01<00:00, 62.38it/s]\n",
      "epoch: 448, loss: 6.3440: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 449, loss: 6.2990: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 450, loss: 6.2070: 100%|██████████| 100/100 [00:01<00:00, 64.04it/s]\n",
      "epoch: 451, loss: 6.1432: 100%|██████████| 100/100 [00:01<00:00, 65.27it/s]\n",
      "epoch: 452, loss: 6.1491: 100%|██████████| 100/100 [00:01<00:00, 64.48it/s]\n",
      "epoch: 453, loss: 6.1500: 100%|██████████| 100/100 [00:01<00:00, 64.82it/s]\n",
      "epoch: 454, loss: 6.0086: 100%|██████████| 100/100 [00:01<00:00, 64.86it/s]\n",
      "epoch: 455, loss: 6.1420: 100%|██████████| 100/100 [00:01<00:00, 64.44it/s]\n",
      "epoch: 456, loss: 6.2929: 100%|██████████| 100/100 [00:01<00:00, 64.74it/s]\n",
      "epoch: 457, loss: 6.2800: 100%|██████████| 100/100 [00:01<00:00, 64.23it/s]\n",
      "epoch: 458, loss: 6.1252: 100%|██████████| 100/100 [00:01<00:00, 65.12it/s]\n",
      "epoch: 459, loss: 5.9598: 100%|██████████| 100/100 [00:01<00:00, 63.84it/s]\n",
      "epoch: 460, loss: 6.1422: 100%|██████████| 100/100 [00:01<00:00, 64.89it/s]\n",
      "epoch: 461, loss: 6.4603: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 462, loss: 6.2875: 100%|██████████| 100/100 [00:01<00:00, 63.62it/s]\n",
      "epoch: 463, loss: 6.3983: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 464, loss: 6.3354: 100%|██████████| 100/100 [00:01<00:00, 64.36it/s]\n",
      "epoch: 465, loss: 6.1372: 100%|██████████| 100/100 [00:01<00:00, 64.07it/s]\n",
      "epoch: 466, loss: 6.1740: 100%|██████████| 100/100 [00:01<00:00, 64.12it/s]\n",
      "epoch: 467, loss: 6.2230: 100%|██████████| 100/100 [00:01<00:00, 64.80it/s]\n",
      "epoch: 468, loss: 6.1906: 100%|██████████| 100/100 [00:01<00:00, 64.11it/s]\n",
      "epoch: 469, loss: 6.1245: 100%|██████████| 100/100 [00:01<00:00, 64.95it/s]\n",
      "epoch: 470, loss: 6.1447: 100%|██████████| 100/100 [00:01<00:00, 63.80it/s]\n",
      "epoch: 471, loss: 6.1729: 100%|██████████| 100/100 [00:01<00:00, 65.13it/s]\n",
      "epoch: 472, loss: 6.1617: 100%|██████████| 100/100 [00:01<00:00, 63.87it/s]\n",
      "epoch: 473, loss: 5.9223: 100%|██████████| 100/100 [00:01<00:00, 64.94it/s]\n",
      "epoch: 474, loss: 6.2384: 100%|██████████| 100/100 [00:01<00:00, 63.68it/s]\n",
      "epoch: 475, loss: 6.3725: 100%|██████████| 100/100 [00:01<00:00, 64.66it/s]\n",
      "epoch: 476, loss: 6.0248: 100%|██████████| 100/100 [00:01<00:00, 64.35it/s]\n",
      "epoch: 477, loss: 6.3151: 100%|██████████| 100/100 [00:01<00:00, 64.18it/s]\n",
      "epoch: 478, loss: 6.1042: 100%|██████████| 100/100 [00:01<00:00, 64.66it/s]\n",
      "epoch: 479, loss: 6.2066: 100%|██████████| 100/100 [00:01<00:00, 64.14it/s]\n",
      "epoch: 480, loss: 6.2480: 100%|██████████| 100/100 [00:01<00:00, 65.17it/s]\n",
      "epoch: 481, loss: 6.3490: 100%|██████████| 100/100 [00:01<00:00, 63.55it/s]\n",
      "epoch: 482, loss: 6.1548: 100%|██████████| 100/100 [00:01<00:00, 64.89it/s]\n",
      "epoch: 483, loss: 6.1546: 100%|██████████| 100/100 [00:01<00:00, 64.45it/s]\n",
      "epoch: 484, loss: 6.2274: 100%|██████████| 100/100 [00:01<00:00, 65.35it/s]\n",
      "epoch: 485, loss: 6.0777: 100%|██████████| 100/100 [00:01<00:00, 67.98it/s]\n",
      "epoch: 486, loss: 6.1242: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 487, loss: 6.1559: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 488, loss: 6.0607: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 489, loss: 6.0842: 100%|██████████| 100/100 [00:01<00:00, 63.03it/s]\n",
      "epoch: 490, loss: 6.1438: 100%|██████████| 100/100 [00:01<00:00, 62.30it/s]\n",
      "epoch: 491, loss: 6.3079: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 492, loss: 6.1584: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 493, loss: 6.2152: 100%|██████████| 100/100 [00:01<00:00, 62.51it/s]\n",
      "epoch: 494, loss: 6.1986: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 495, loss: 6.0915: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 496, loss: 6.2186: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 497, loss: 6.0894: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 498, loss: 6.2621: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 499, loss: 6.1557: 100%|██████████| 100/100 [00:01<00:00, 62.14it/s]\n",
      "epoch: 500, loss: 6.1052: 100%|██████████| 100/100 [00:01<00:00, 61.25it/s]\n",
      "epoch: 501, loss: 6.1592: 100%|██████████| 100/100 [00:01<00:00, 61.58it/s]\n",
      "epoch: 502, loss: 6.2466: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 503, loss: 6.1702: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 504, loss: 6.3408: 100%|██████████| 100/100 [00:01<00:00, 63.57it/s]\n",
      "epoch: 505, loss: 6.2047: 100%|██████████| 100/100 [00:01<00:00, 64.67it/s]\n",
      "epoch: 506, loss: 5.9468: 100%|██████████| 100/100 [00:01<00:00, 64.48it/s]\n",
      "epoch: 507, loss: 6.0333: 100%|██████████| 100/100 [00:01<00:00, 65.04it/s]\n",
      "epoch: 508, loss: 6.2220: 100%|██████████| 100/100 [00:01<00:00, 64.09it/s]\n",
      "epoch: 509, loss: 6.0811: 100%|██████████| 100/100 [00:01<00:00, 65.25it/s]\n",
      "epoch: 510, loss: 6.2138: 100%|██████████| 100/100 [00:01<00:00, 63.59it/s]\n",
      "epoch: 511, loss: 6.2120: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 512, loss: 6.1456: 100%|██████████| 100/100 [00:01<00:00, 63.35it/s]\n",
      "epoch: 513, loss: 6.1677: 100%|██████████| 100/100 [00:01<00:00, 65.12it/s]\n",
      "epoch: 514, loss: 6.1971: 100%|██████████| 100/100 [00:01<00:00, 64.33it/s]\n",
      "epoch: 515, loss: 5.8829: 100%|██████████| 100/100 [00:01<00:00, 64.84it/s]\n",
      "epoch: 516, loss: 6.1618: 100%|██████████| 100/100 [00:01<00:00, 64.50it/s]\n",
      "epoch: 517, loss: 6.2440: 100%|██████████| 100/100 [00:01<00:00, 64.75it/s]\n",
      "epoch: 518, loss: 6.1979: 100%|██████████| 100/100 [00:01<00:00, 64.68it/s]\n",
      "epoch: 519, loss: 6.1622: 100%|██████████| 100/100 [00:01<00:00, 64.05it/s]\n",
      "epoch: 520, loss: 6.0941: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 521, loss: 6.1793: 100%|██████████| 100/100 [00:01<00:00, 64.01it/s]\n",
      "epoch: 522, loss: 6.0716: 100%|██████████| 100/100 [00:01<00:00, 65.18it/s]\n",
      "epoch: 523, loss: 6.0345: 100%|██████████| 100/100 [00:01<00:00, 64.11it/s]\n",
      "epoch: 524, loss: 6.5368: 100%|██████████| 100/100 [00:01<00:00, 65.39it/s]\n",
      "epoch: 525, loss: 6.1029: 100%|██████████| 100/100 [00:01<00:00, 63.73it/s]\n",
      "epoch: 526, loss: 6.3618: 100%|██████████| 100/100 [00:01<00:00, 65.03it/s]\n",
      "epoch: 527, loss: 6.1163: 100%|██████████| 100/100 [00:01<00:00, 64.59it/s]\n",
      "epoch: 528, loss: 6.3099: 100%|██████████| 100/100 [00:01<00:00, 64.80it/s]\n",
      "epoch: 529, loss: 6.2462: 100%|██████████| 100/100 [00:01<00:00, 64.58it/s]\n",
      "epoch: 530, loss: 6.2002: 100%|██████████| 100/100 [00:01<00:00, 64.38it/s]\n",
      "epoch: 531, loss: 6.2662: 100%|██████████| 100/100 [00:01<00:00, 65.28it/s]\n",
      "epoch: 532, loss: 6.0549: 100%|██████████| 100/100 [00:01<00:00, 63.77it/s]\n",
      "epoch: 533, loss: 6.3013: 100%|██████████| 100/100 [00:01<00:00, 64.87it/s]\n",
      "epoch: 534, loss: 6.3130: 100%|██████████| 100/100 [00:01<00:00, 63.99it/s]\n",
      "epoch: 535, loss: 6.2400: 100%|██████████| 100/100 [00:01<00:00, 65.18it/s]\n",
      "epoch: 536, loss: 6.0004: 100%|██████████| 100/100 [00:01<00:00, 63.72it/s]\n",
      "epoch: 537, loss: 5.9685: 100%|██████████| 100/100 [00:01<00:00, 65.33it/s]\n",
      "epoch: 538, loss: 6.1663: 100%|██████████| 100/100 [00:01<00:00, 63.10it/s]\n",
      "epoch: 539, loss: 6.1159: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 540, loss: 6.2646: 100%|██████████| 100/100 [00:01<00:00, 63.57it/s]\n",
      "epoch: 541, loss: 6.2721: 100%|██████████| 100/100 [00:01<00:00, 63.95it/s]\n",
      "epoch: 542, loss: 6.2254: 100%|██████████| 100/100 [00:01<00:00, 65.10it/s]\n",
      "epoch: 543, loss: 6.0675: 100%|██████████| 100/100 [00:01<00:00, 63.96it/s]\n",
      "epoch: 544, loss: 6.1223: 100%|██████████| 100/100 [00:01<00:00, 65.10it/s]\n",
      "epoch: 545, loss: 6.1811: 100%|██████████| 100/100 [00:01<00:00, 63.88it/s]\n",
      "epoch: 546, loss: 5.9877: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 547, loss: 5.9819: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 548, loss: 6.1080: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 549, loss: 6.0203: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 550, loss: 6.1569: 100%|██████████| 100/100 [00:01<00:00, 62.39it/s]\n",
      "epoch: 551, loss: 6.3158: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 552, loss: 6.1074: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 553, loss: 6.2110: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 554, loss: 6.0875: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 555, loss: 6.3488: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 556, loss: 6.2832: 100%|██████████| 100/100 [00:01<00:00, 62.48it/s]\n",
      "epoch: 557, loss: 6.1281: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 558, loss: 6.2600: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 559, loss: 6.2411: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 560, loss: 6.2012: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 561, loss: 6.1049: 100%|██████████| 100/100 [00:01<00:00, 63.59it/s]\n",
      "epoch: 562, loss: 6.0106: 100%|██████████| 100/100 [00:01<00:00, 65.18it/s]\n",
      "epoch: 563, loss: 6.1066: 100%|██████████| 100/100 [00:01<00:00, 63.84it/s]\n",
      "epoch: 564, loss: 6.3167: 100%|██████████| 100/100 [00:01<00:00, 64.92it/s]\n",
      "epoch: 565, loss: 6.0999: 100%|██████████| 100/100 [00:01<00:00, 64.22it/s]\n",
      "epoch: 566, loss: 6.2601: 100%|██████████| 100/100 [00:01<00:00, 64.67it/s]\n",
      "epoch: 567, loss: 5.9890: 100%|██████████| 100/100 [00:01<00:00, 64.29it/s]\n",
      "epoch: 568, loss: 6.1434: 100%|██████████| 100/100 [00:01<00:00, 64.20it/s]\n",
      "epoch: 569, loss: 5.9757: 100%|██████████| 100/100 [00:01<00:00, 64.76it/s]\n",
      "epoch: 570, loss: 6.1062: 100%|██████████| 100/100 [00:01<00:00, 63.91it/s]\n",
      "epoch: 571, loss: 6.3250: 100%|██████████| 100/100 [00:01<00:00, 65.15it/s]\n",
      "epoch: 572, loss: 6.2153: 100%|██████████| 100/100 [00:01<00:00, 64.03it/s]\n",
      "epoch: 573, loss: 6.0471: 100%|██████████| 100/100 [00:01<00:00, 64.86it/s]\n",
      "epoch: 574, loss: 6.2410: 100%|██████████| 100/100 [00:01<00:00, 64.18it/s]\n",
      "epoch: 575, loss: 6.1968: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 576, loss: 6.2546: 100%|██████████| 100/100 [00:01<00:00, 62.36it/s]\n",
      "epoch: 577, loss: 6.2932: 100%|██████████| 100/100 [00:01<00:00, 61.88it/s]\n",
      "epoch: 578, loss: 6.0131: 100%|██████████| 100/100 [00:01<00:00, 62.46it/s]\n",
      "epoch: 579, loss: 6.3153: 100%|██████████| 100/100 [00:01<00:00, 63.76it/s]\n",
      "epoch: 580, loss: 6.0554: 100%|██████████| 100/100 [00:01<00:00, 64.81it/s]\n",
      "epoch: 581, loss: 6.1896: 100%|██████████| 100/100 [00:01<00:00, 63.42it/s]\n",
      "epoch: 582, loss: 6.2845: 100%|██████████| 100/100 [00:01<00:00, 64.45it/s]\n",
      "epoch: 583, loss: 6.3643: 100%|██████████| 100/100 [00:01<00:00, 64.10it/s]\n",
      "epoch: 584, loss: 6.1436: 100%|██████████| 100/100 [00:01<00:00, 64.93it/s]\n",
      "epoch: 585, loss: 6.4695: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 586, loss: 6.0704: 100%|██████████| 100/100 [00:01<00:00, 64.94it/s]\n",
      "epoch: 587, loss: 6.2276: 100%|██████████| 100/100 [00:01<00:00, 63.73it/s]\n",
      "epoch: 588, loss: 6.2843: 100%|██████████| 100/100 [00:01<00:00, 63.87it/s]\n",
      "epoch: 589, loss: 6.1544: 100%|██████████| 100/100 [00:01<00:00, 63.78it/s]\n",
      "epoch: 590, loss: 6.3153: 100%|██████████| 100/100 [00:01<00:00, 64.76it/s]\n",
      "epoch: 591, loss: 6.2273: 100%|██████████| 100/100 [00:01<00:00, 64.96it/s]\n",
      "epoch: 592, loss: 6.2111: 100%|██████████| 100/100 [00:01<00:00, 63.23it/s]\n",
      "epoch: 593, loss: 6.1330: 100%|██████████| 100/100 [00:01<00:00, 64.85it/s]\n",
      "epoch: 594, loss: 6.1654: 100%|██████████| 100/100 [00:01<00:00, 63.68it/s]\n",
      "epoch: 595, loss: 6.2527: 100%|██████████| 100/100 [00:01<00:00, 65.05it/s]\n",
      "epoch: 596, loss: 6.1607: 100%|██████████| 100/100 [00:01<00:00, 63.12it/s]\n",
      "epoch: 597, loss: 6.2681: 100%|██████████| 100/100 [00:01<00:00, 64.32it/s]\n",
      "epoch: 598, loss: 6.2805: 100%|██████████| 100/100 [00:01<00:00, 63.93it/s]\n",
      "epoch: 599, loss: 6.2288: 100%|██████████| 100/100 [00:01<00:00, 64.01it/s]\n",
      "epoch: 600, loss: 6.2372: 100%|██████████| 100/100 [00:01<00:00, 63.74it/s]\n",
      "epoch: 601, loss: 5.9602: 100%|██████████| 100/100 [00:01<00:00, 63.84it/s]\n",
      "epoch: 602, loss: 6.2630: 100%|██████████| 100/100 [00:01<00:00, 64.65it/s]\n",
      "epoch: 603, loss: 6.2594: 100%|██████████| 100/100 [00:01<00:00, 62.31it/s]\n",
      "epoch: 604, loss: 6.2888: 100%|██████████| 100/100 [00:01<00:00, 62.37it/s]\n",
      "epoch: 605, loss: 6.0101: 100%|██████████| 100/100 [00:01<00:00, 62.17it/s]\n",
      "epoch: 606, loss: 6.1412: 100%|██████████| 100/100 [00:01<00:00, 62.37it/s]\n",
      "epoch: 607, loss: 6.2982: 100%|██████████| 100/100 [00:01<00:00, 62.43it/s]\n",
      "epoch: 608, loss: 6.3320: 100%|██████████| 100/100 [00:01<00:00, 62.40it/s]\n",
      "epoch: 609, loss: 5.8689: 100%|██████████| 100/100 [00:01<00:00, 62.47it/s]\n",
      "epoch: 610, loss: 6.0603: 100%|██████████| 100/100 [00:01<00:00, 62.15it/s]\n",
      "epoch: 611, loss: 6.2376: 100%|██████████| 100/100 [00:01<00:00, 62.46it/s]\n",
      "epoch: 612, loss: 6.3147: 100%|██████████| 100/100 [00:01<00:00, 62.40it/s]\n",
      "epoch: 613, loss: 6.0029: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 614, loss: 6.3583: 100%|██████████| 100/100 [00:01<00:00, 68.17it/s]\n",
      "epoch: 615, loss: 6.3434: 100%|██████████| 100/100 [00:01<00:00, 66.74it/s]\n",
      "epoch: 616, loss: 6.1705: 100%|██████████| 100/100 [00:01<00:00, 61.09it/s]\n",
      "epoch: 617, loss: 6.1221: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 618, loss: 6.1167: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 619, loss: 6.1238: 100%|██████████| 100/100 [00:01<00:00, 62.53it/s]\n",
      "epoch: 620, loss: 6.2055: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 621, loss: 6.1385: 100%|██████████| 100/100 [00:01<00:00, 62.48it/s]\n",
      "epoch: 622, loss: 6.1791: 100%|██████████| 100/100 [00:01<00:00, 62.42it/s]\n",
      "epoch: 623, loss: 6.2438: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 624, loss: 6.2570: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 625, loss: 6.2733: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 626, loss: 6.0843: 100%|██████████| 100/100 [00:01<00:00, 65.27it/s]\n",
      "epoch: 627, loss: 6.2004: 100%|██████████| 100/100 [00:01<00:00, 69.07it/s]\n",
      "epoch: 628, loss: 6.3095: 100%|██████████| 100/100 [00:01<00:00, 69.72it/s]\n",
      "epoch: 629, loss: 6.2299: 100%|██████████| 100/100 [00:01<00:00, 69.66it/s]\n",
      "epoch: 630, loss: 6.0673: 100%|██████████| 100/100 [00:01<00:00, 69.05it/s]\n",
      "epoch: 631, loss: 6.3738: 100%|██████████| 100/100 [00:01<00:00, 69.76it/s]\n",
      "epoch: 632, loss: 6.0494: 100%|██████████| 100/100 [00:01<00:00, 70.22it/s]\n",
      "epoch: 633, loss: 6.1516: 100%|██████████| 100/100 [00:01<00:00, 69.86it/s]\n",
      "epoch: 634, loss: 6.3333: 100%|██████████| 100/100 [00:01<00:00, 69.14it/s]\n",
      "epoch: 635, loss: 6.1879: 100%|██████████| 100/100 [00:01<00:00, 69.86it/s]\n",
      "epoch: 636, loss: 6.2248: 100%|██████████| 100/100 [00:01<00:00, 71.11it/s]\n",
      "epoch: 637, loss: 6.1168: 100%|██████████| 100/100 [00:01<00:00, 69.41it/s]\n",
      "epoch: 638, loss: 6.1859: 100%|██████████| 100/100 [00:01<00:00, 72.46it/s]\n",
      "epoch: 639, loss: 6.3507: 100%|██████████| 100/100 [00:01<00:00, 70.24it/s]\n",
      "epoch: 640, loss: 6.2069: 100%|██████████| 100/100 [00:01<00:00, 73.26it/s]\n",
      "epoch: 641, loss: 6.2300: 100%|██████████| 100/100 [00:01<00:00, 68.77it/s]\n",
      "epoch: 642, loss: 6.1203: 100%|██████████| 100/100 [00:01<00:00, 73.82it/s]\n",
      "epoch: 643, loss: 6.2911: 100%|██████████| 100/100 [00:01<00:00, 68.87it/s]\n",
      "epoch: 644, loss: 6.2436: 100%|██████████| 100/100 [00:01<00:00, 74.08it/s]\n",
      "epoch: 645, loss: 6.3144: 100%|██████████| 100/100 [00:01<00:00, 68.40it/s]\n",
      "epoch: 646, loss: 6.0967: 100%|██████████| 100/100 [00:01<00:00, 74.48it/s]\n",
      "epoch: 647, loss: 6.1813: 100%|██████████| 100/100 [00:01<00:00, 67.90it/s]\n",
      "epoch: 648, loss: 6.3786: 100%|██████████| 100/100 [00:01<00:00, 72.57it/s]\n",
      "epoch: 649, loss: 6.2456: 100%|██████████| 100/100 [00:01<00:00, 69.44it/s]\n",
      "epoch: 650, loss: 6.2221: 100%|██████████| 100/100 [00:01<00:00, 75.06it/s]\n",
      "epoch: 651, loss: 6.3232: 100%|██████████| 100/100 [00:01<00:00, 67.90it/s]\n",
      "epoch: 652, loss: 6.2622: 100%|██████████| 100/100 [00:01<00:00, 75.36it/s]\n",
      "epoch: 653, loss: 6.2182: 100%|██████████| 100/100 [00:01<00:00, 65.21it/s]\n",
      "epoch: 654, loss: 6.3916: 100%|██████████| 100/100 [00:01<00:00, 73.48it/s]\n",
      "epoch: 655, loss: 6.2737: 100%|██████████| 100/100 [00:01<00:00, 65.59it/s]\n",
      "epoch: 656, loss: 6.1705: 100%|██████████| 100/100 [00:01<00:00, 69.53it/s]\n",
      "epoch: 657, loss: 6.1378: 100%|██████████| 100/100 [00:01<00:00, 65.98it/s]\n",
      "epoch: 658, loss: 6.2640: 100%|██████████| 100/100 [00:01<00:00, 70.18it/s]\n",
      "epoch: 659, loss: 6.1450: 100%|██████████| 100/100 [00:01<00:00, 65.63it/s]\n",
      "epoch: 660, loss: 6.2297: 100%|██████████| 100/100 [00:01<00:00, 73.19it/s]\n",
      "epoch: 661, loss: 6.2031: 100%|██████████| 100/100 [00:01<00:00, 65.18it/s]\n",
      "epoch: 662, loss: 6.3809: 100%|██████████| 100/100 [00:01<00:00, 72.69it/s]\n",
      "epoch: 663, loss: 6.1742: 100%|██████████| 100/100 [00:01<00:00, 64.63it/s]\n",
      "epoch: 664, loss: 6.3142: 100%|██████████| 100/100 [00:01<00:00, 62.56it/s]\n",
      "epoch: 665, loss: 6.1954: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 666, loss: 6.3217: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 667, loss: 6.2988: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 668, loss: 6.2358: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 669, loss: 6.1817: 100%|██████████| 100/100 [00:01<00:00, 62.66it/s]\n",
      "epoch: 670, loss: 6.2068: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 671, loss: 6.2022: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 672, loss: 6.1159: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 673, loss: 6.0018: 100%|██████████| 100/100 [00:01<00:00, 62.39it/s]\n",
      "epoch: 674, loss: 6.2535: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 675, loss: 6.3338: 100%|██████████| 100/100 [00:01<00:00, 62.52it/s]\n",
      "epoch: 676, loss: 6.1344: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 677, loss: 6.1265: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 678, loss: 6.2799: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 679, loss: 6.1243: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 680, loss: 6.1623: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 681, loss: 6.1239: 100%|██████████| 100/100 [00:01<00:00, 62.44it/s]\n",
      "epoch: 682, loss: 6.0202: 100%|██████████| 100/100 [00:01<00:00, 61.92it/s]\n",
      "epoch: 683, loss: 6.1605: 100%|██████████| 100/100 [00:01<00:00, 63.55it/s]\n",
      "epoch: 684, loss: 6.0951: 100%|██████████| 100/100 [00:01<00:00, 65.00it/s]\n",
      "epoch: 685, loss: 6.3090: 100%|██████████| 100/100 [00:01<00:00, 63.73it/s]\n",
      "epoch: 686, loss: 6.2040: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 687, loss: 6.2757: 100%|██████████| 100/100 [00:01<00:00, 63.90it/s]\n",
      "epoch: 688, loss: 6.2862: 100%|██████████| 100/100 [00:01<00:00, 64.25it/s]\n",
      "epoch: 689, loss: 6.1905: 100%|██████████| 100/100 [00:01<00:00, 63.93it/s]\n",
      "epoch: 690, loss: 6.1722: 100%|██████████| 100/100 [00:01<00:00, 64.29it/s]\n",
      "epoch: 691, loss: 6.2990: 100%|██████████| 100/100 [00:01<00:00, 64.44it/s]\n",
      "epoch: 692, loss: 6.2637: 100%|██████████| 100/100 [00:01<00:00, 64.09it/s]\n",
      "epoch: 693, loss: 6.2732: 100%|██████████| 100/100 [00:01<00:00, 63.67it/s]\n",
      "epoch: 694, loss: 6.2045: 100%|██████████| 100/100 [00:01<00:00, 60.97it/s]\n",
      "epoch: 695, loss: 6.1855: 100%|██████████| 100/100 [00:01<00:00, 62.53it/s]\n",
      "epoch: 696, loss: 6.2069: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 697, loss: 6.2849: 100%|██████████| 100/100 [00:01<00:00, 61.17it/s]\n",
      "epoch: 698, loss: 6.2034: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 699, loss: 5.9671: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 700, loss: 6.1697: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 701, loss: 6.1768: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 702, loss: 6.2224: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 703, loss: 6.1541: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 704, loss: 6.1919: 100%|██████████| 100/100 [00:01<00:00, 62.56it/s]\n",
      "epoch: 705, loss: 6.2844: 100%|██████████| 100/100 [00:01<00:00, 62.50it/s]\n",
      "epoch: 706, loss: 6.1194: 100%|██████████| 100/100 [00:01<00:00, 64.16it/s]\n",
      "epoch: 707, loss: 6.2076: 100%|██████████| 100/100 [00:01<00:00, 64.14it/s]\n",
      "epoch: 708, loss: 6.1631: 100%|██████████| 100/100 [00:01<00:00, 64.98it/s]\n",
      "epoch: 709, loss: 6.2140: 100%|██████████| 100/100 [00:01<00:00, 63.53it/s]\n",
      "epoch: 710, loss: 6.2202: 100%|██████████| 100/100 [00:01<00:00, 65.24it/s]\n",
      "epoch: 711, loss: 5.9655: 100%|██████████| 100/100 [00:01<00:00, 63.40it/s]\n",
      "epoch: 712, loss: 6.0428: 100%|██████████| 100/100 [00:01<00:00, 64.99it/s]\n",
      "epoch: 713, loss: 6.2668: 100%|██████████| 100/100 [00:01<00:00, 63.26it/s]\n",
      "epoch: 714, loss: 6.0578: 100%|██████████| 100/100 [00:01<00:00, 64.66it/s]\n",
      "epoch: 715, loss: 6.3610: 100%|██████████| 100/100 [00:01<00:00, 64.28it/s]\n",
      "epoch: 716, loss: 6.1884: 100%|██████████| 100/100 [00:01<00:00, 63.91it/s]\n",
      "epoch: 717, loss: 6.1316: 100%|██████████| 100/100 [00:01<00:00, 64.03it/s]\n",
      "epoch: 718, loss: 6.1949: 100%|██████████| 100/100 [00:01<00:00, 64.27it/s]\n",
      "epoch: 719, loss: 6.2196: 100%|██████████| 100/100 [00:01<00:00, 64.46it/s]\n",
      "epoch: 720, loss: 6.1631: 100%|██████████| 100/100 [00:01<00:00, 64.14it/s]\n",
      "epoch: 721, loss: 6.1415: 100%|██████████| 100/100 [00:01<00:00, 65.02it/s]\n",
      "epoch: 722, loss: 6.3137: 100%|██████████| 100/100 [00:01<00:00, 63.64it/s]\n",
      "epoch: 723, loss: 6.1421: 100%|██████████| 100/100 [00:01<00:00, 65.12it/s]\n",
      "epoch: 724, loss: 6.2095: 100%|██████████| 100/100 [00:01<00:00, 63.64it/s]\n",
      "epoch: 725, loss: 6.2282: 100%|██████████| 100/100 [00:01<00:00, 64.86it/s]\n",
      "epoch: 726, loss: 6.0747: 100%|██████████| 100/100 [00:01<00:00, 64.16it/s]\n",
      "epoch: 727, loss: 6.3435: 100%|██████████| 100/100 [00:01<00:00, 65.24it/s]\n",
      "epoch: 728, loss: 6.2062: 100%|██████████| 100/100 [00:01<00:00, 63.36it/s]\n",
      "epoch: 729, loss: 6.1424: 100%|██████████| 100/100 [00:01<00:00, 65.22it/s]\n",
      "epoch: 730, loss: 6.0983: 100%|██████████| 100/100 [00:01<00:00, 63.57it/s]\n",
      "epoch: 731, loss: 6.1758: 100%|██████████| 100/100 [00:01<00:00, 67.04it/s]\n",
      "epoch: 732, loss: 6.1940: 100%|██████████| 100/100 [00:01<00:00, 77.56it/s]\n",
      "epoch: 733, loss: 6.0575: 100%|██████████| 100/100 [00:01<00:00, 77.25it/s]\n",
      "epoch: 734, loss: 6.3940: 100%|██████████| 100/100 [00:01<00:00, 77.26it/s]\n",
      "epoch: 735, loss: 6.1348: 100%|██████████| 100/100 [00:01<00:00, 65.65it/s]\n",
      "epoch: 736, loss: 5.9588: 100%|██████████| 100/100 [00:01<00:00, 64.12it/s]\n",
      "epoch: 737, loss: 6.1949: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 738, loss: 6.0929: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 739, loss: 6.3480: 100%|██████████| 100/100 [00:01<00:00, 62.53it/s]\n",
      "epoch: 740, loss: 6.4218: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 741, loss: 6.0173: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 742, loss: 6.3035: 100%|██████████| 100/100 [00:01<00:00, 62.66it/s]\n",
      "epoch: 743, loss: 6.1503: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 744, loss: 6.2524: 100%|██████████| 100/100 [00:01<00:00, 62.92it/s]\n",
      "epoch: 745, loss: 6.2704: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 746, loss: 6.3309: 100%|██████████| 100/100 [00:01<00:00, 62.81it/s]\n",
      "epoch: 747, loss: 6.0465: 100%|██████████| 100/100 [00:01<00:00, 62.59it/s]\n",
      "epoch: 748, loss: 6.2064: 100%|██████████| 100/100 [00:01<00:00, 63.07it/s]\n",
      "epoch: 749, loss: 6.3287: 100%|██████████| 100/100 [00:01<00:00, 62.49it/s]\n",
      "epoch: 750, loss: 6.0794: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 751, loss: 6.2707: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 752, loss: 6.2851: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 753, loss: 6.0967: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 754, loss: 6.3469: 100%|██████████| 100/100 [00:01<00:00, 62.97it/s]\n",
      "epoch: 755, loss: 6.2084: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 756, loss: 6.0254: 100%|██████████| 100/100 [00:01<00:00, 62.92it/s]\n",
      "epoch: 757, loss: 6.2950: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 758, loss: 6.1208: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 759, loss: 5.9820: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 760, loss: 6.3191: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 761, loss: 5.9569: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 762, loss: 6.0719: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 763, loss: 6.3203: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 764, loss: 6.1678: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 765, loss: 6.1588: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 766, loss: 6.2306: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 767, loss: 6.3128: 100%|██████████| 100/100 [00:01<00:00, 63.13it/s]\n",
      "epoch: 768, loss: 6.0712: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 769, loss: 6.1078: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 770, loss: 6.2193: 100%|██████████| 100/100 [00:01<00:00, 60.31it/s]\n",
      "epoch: 771, loss: 6.0732: 100%|██████████| 100/100 [00:01<00:00, 61.16it/s]\n",
      "epoch: 772, loss: 6.1248: 100%|██████████| 100/100 [00:01<00:00, 60.25it/s]\n",
      "epoch: 773, loss: 6.2719: 100%|██████████| 100/100 [00:01<00:00, 60.25it/s]\n",
      "epoch: 774, loss: 6.3700: 100%|██████████| 100/100 [00:01<00:00, 61.52it/s]\n",
      "epoch: 775, loss: 6.1496: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 776, loss: 6.1024: 100%|██████████| 100/100 [00:01<00:00, 62.39it/s]\n",
      "epoch: 777, loss: 6.1205: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 778, loss: 5.9793: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 779, loss: 6.2914: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 780, loss: 6.2585: 100%|██████████| 100/100 [00:01<00:00, 62.54it/s]\n",
      "epoch: 781, loss: 6.0852: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 782, loss: 6.3887: 100%|██████████| 100/100 [00:01<00:00, 62.59it/s]\n",
      "epoch: 783, loss: 6.2203: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 784, loss: 6.1143: 100%|██████████| 100/100 [00:01<00:00, 62.51it/s]\n",
      "epoch: 785, loss: 6.2352: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 786, loss: 5.9972: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 787, loss: 6.2093: 100%|██████████| 100/100 [00:01<00:00, 62.40it/s]\n",
      "epoch: 788, loss: 6.2078: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 789, loss: 6.0961: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 790, loss: 6.0210: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 791, loss: 6.3258: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 792, loss: 6.1634: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 793, loss: 6.1867: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 794, loss: 6.2392: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 795, loss: 6.0234: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 796, loss: 6.0730: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 797, loss: 6.2140: 100%|██████████| 100/100 [00:01<00:00, 62.39it/s]\n",
      "epoch: 798, loss: 6.0683: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 799, loss: 6.2677: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 800, loss: 6.0853: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 801, loss: 6.1921: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 802, loss: 6.1934: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 803, loss: 5.8152: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 804, loss: 5.9998: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 805, loss: 6.1976: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 806, loss: 6.1697: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 807, loss: 6.0605: 100%|██████████| 100/100 [00:01<00:00, 60.85it/s]\n",
      "epoch: 808, loss: 6.3324: 100%|██████████| 100/100 [00:01<00:00, 60.58it/s]\n",
      "epoch: 809, loss: 6.2288: 100%|██████████| 100/100 [00:01<00:00, 60.49it/s]\n",
      "epoch: 810, loss: 6.3113: 100%|██████████| 100/100 [00:01<00:00, 60.62it/s]\n",
      "epoch: 811, loss: 6.3684: 100%|██████████| 100/100 [00:01<00:00, 60.21it/s]\n",
      "epoch: 812, loss: 6.1598: 100%|██████████| 100/100 [00:01<00:00, 62.22it/s]\n",
      "epoch: 813, loss: 6.2376: 100%|██████████| 100/100 [00:01<00:00, 62.38it/s]\n",
      "epoch: 814, loss: 6.1079: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 815, loss: 6.1711: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 816, loss: 6.1504: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 817, loss: 6.1496: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 818, loss: 6.0334: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 819, loss: 6.2622: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 820, loss: 6.1083: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 821, loss: 6.3464: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 822, loss: 5.9990: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 823, loss: 6.2742: 100%|██████████| 100/100 [00:01<00:00, 62.40it/s]\n",
      "epoch: 824, loss: 6.2167: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 825, loss: 6.0833: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 826, loss: 6.2132: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 827, loss: 6.2670: 100%|██████████| 100/100 [00:01<00:00, 62.55it/s]\n",
      "epoch: 828, loss: 6.1510: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 829, loss: 6.1471: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 830, loss: 6.1939: 100%|██████████| 100/100 [00:01<00:00, 62.41it/s]\n",
      "epoch: 831, loss: 6.0627: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 832, loss: 6.0917: 100%|██████████| 100/100 [00:01<00:00, 62.66it/s]\n",
      "epoch: 833, loss: 6.0893: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 834, loss: 6.2815: 100%|██████████| 100/100 [00:01<00:00, 66.28it/s]\n",
      "epoch: 835, loss: 6.0482: 100%|██████████| 100/100 [00:01<00:00, 69.87it/s]\n",
      "epoch: 836, loss: 6.1739: 100%|██████████| 100/100 [00:01<00:00, 70.55it/s]\n",
      "epoch: 837, loss: 6.0307: 100%|██████████| 100/100 [00:01<00:00, 69.31it/s]\n",
      "epoch: 838, loss: 5.9743: 100%|██████████| 100/100 [00:01<00:00, 72.12it/s]\n",
      "epoch: 839, loss: 5.9478: 100%|██████████| 100/100 [00:01<00:00, 67.13it/s]\n",
      "epoch: 840, loss: 5.9076: 100%|██████████| 100/100 [00:01<00:00, 72.92it/s]\n",
      "epoch: 841, loss: 6.2118: 100%|██████████| 100/100 [00:01<00:00, 66.20it/s]\n",
      "epoch: 842, loss: 6.3143: 100%|██████████| 100/100 [00:01<00:00, 73.00it/s]\n",
      "epoch: 843, loss: 6.1552: 100%|██████████| 100/100 [00:01<00:00, 65.36it/s]\n",
      "epoch: 844, loss: 6.1517: 100%|██████████| 100/100 [00:01<00:00, 72.70it/s]\n",
      "epoch: 845, loss: 6.1625: 100%|██████████| 100/100 [00:01<00:00, 67.11it/s]\n",
      "epoch: 846, loss: 6.2297: 100%|██████████| 100/100 [00:01<00:00, 68.43it/s]\n",
      "epoch: 847, loss: 6.2233: 100%|██████████| 100/100 [00:01<00:00, 64.91it/s]\n",
      "epoch: 848, loss: 6.1710: 100%|██████████| 100/100 [00:01<00:00, 68.39it/s]\n",
      "epoch: 849, loss: 6.3389: 100%|██████████| 100/100 [00:01<00:00, 64.27it/s]\n",
      "epoch: 850, loss: 6.1259: 100%|██████████| 100/100 [00:01<00:00, 69.00it/s]\n",
      "epoch: 851, loss: 6.3533: 100%|██████████| 100/100 [00:01<00:00, 67.56it/s]\n",
      "epoch: 852, loss: 6.1136: 100%|██████████| 100/100 [00:01<00:00, 67.04it/s]\n",
      "epoch: 853, loss: 6.0199: 100%|██████████| 100/100 [00:01<00:00, 67.38it/s]\n",
      "epoch: 854, loss: 6.2079: 100%|██████████| 100/100 [00:01<00:00, 68.99it/s]\n",
      "epoch: 855, loss: 6.3820: 100%|██████████| 100/100 [00:01<00:00, 68.57it/s]\n",
      "epoch: 856, loss: 6.0000: 100%|██████████| 100/100 [00:01<00:00, 63.31it/s]\n",
      "epoch: 857, loss: 6.1298: 100%|██████████| 100/100 [00:01<00:00, 65.87it/s]\n",
      "epoch: 858, loss: 6.2328: 100%|██████████| 100/100 [00:01<00:00, 67.31it/s]\n",
      "epoch: 859, loss: 6.3859: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 860, loss: 6.1938: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 861, loss: 6.0937: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 862, loss: 6.2419: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 863, loss: 5.8929: 100%|██████████| 100/100 [00:01<00:00, 62.34it/s]\n",
      "epoch: 864, loss: 6.0853: 100%|██████████| 100/100 [00:01<00:00, 63.20it/s]\n",
      "epoch: 865, loss: 6.0255: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 866, loss: 6.3276: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 867, loss: 6.2216: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 868, loss: 6.1024: 100%|██████████| 100/100 [00:01<00:00, 63.15it/s]\n",
      "epoch: 869, loss: 6.1654: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 870, loss: 6.0650: 100%|██████████| 100/100 [00:01<00:00, 62.80it/s]\n",
      "epoch: 871, loss: 6.2266: 100%|██████████| 100/100 [00:01<00:00, 62.98it/s]\n",
      "epoch: 872, loss: 6.3391: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 873, loss: 5.9978: 100%|██████████| 100/100 [00:01<00:00, 63.04it/s]\n",
      "epoch: 874, loss: 6.2821: 100%|██████████| 100/100 [00:01<00:00, 63.08it/s]\n",
      "epoch: 875, loss: 6.1766: 100%|██████████| 100/100 [00:01<00:00, 62.90it/s]\n",
      "epoch: 876, loss: 6.0248: 100%|██████████| 100/100 [00:01<00:00, 63.10it/s]\n",
      "epoch: 877, loss: 6.2471: 100%|██████████| 100/100 [00:01<00:00, 62.70it/s]\n",
      "epoch: 878, loss: 6.1115: 100%|██████████| 100/100 [00:01<00:00, 63.03it/s]\n",
      "epoch: 879, loss: 5.9999: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 880, loss: 6.2524: 100%|██████████| 100/100 [00:01<00:00, 62.76it/s]\n",
      "epoch: 881, loss: 6.1603: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 882, loss: 6.2697: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 883, loss: 6.0783: 100%|██████████| 100/100 [00:01<00:00, 63.21it/s]\n",
      "epoch: 884, loss: 6.1023: 100%|██████████| 100/100 [00:01<00:00, 63.37it/s]\n",
      "epoch: 885, loss: 6.2488: 100%|██████████| 100/100 [00:01<00:00, 64.32it/s]\n",
      "epoch: 886, loss: 6.1812: 100%|██████████| 100/100 [00:01<00:00, 62.88it/s]\n",
      "epoch: 887, loss: 6.1823: 100%|██████████| 100/100 [00:01<00:00, 64.79it/s]\n",
      "epoch: 888, loss: 6.1268: 100%|██████████| 100/100 [00:01<00:00, 64.43it/s]\n",
      "epoch: 889, loss: 6.1445: 100%|██████████| 100/100 [00:01<00:00, 65.69it/s]\n",
      "epoch: 890, loss: 6.1118: 100%|██████████| 100/100 [00:01<00:00, 68.30it/s]\n",
      "epoch: 891, loss: 5.8297: 100%|██████████| 100/100 [00:01<00:00, 68.95it/s]\n",
      "epoch: 892, loss: 6.0843: 100%|██████████| 100/100 [00:01<00:00, 68.65it/s]\n",
      "epoch: 893, loss: 6.1699: 100%|██████████| 100/100 [00:01<00:00, 68.67it/s]\n",
      "epoch: 894, loss: 6.1365: 100%|██████████| 100/100 [00:01<00:00, 68.21it/s]\n",
      "epoch: 895, loss: 6.0944: 100%|██████████| 100/100 [00:01<00:00, 63.57it/s]\n",
      "epoch: 896, loss: 6.1265: 100%|██████████| 100/100 [00:01<00:00, 63.05it/s]\n",
      "epoch: 897, loss: 6.3089: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 898, loss: 6.0118: 100%|██████████| 100/100 [00:01<00:00, 63.00it/s]\n",
      "epoch: 899, loss: 6.2851: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 900, loss: 6.1585: 100%|██████████| 100/100 [00:01<00:00, 63.03it/s]\n",
      "epoch: 901, loss: 6.3968: 100%|██████████| 100/100 [00:01<00:00, 62.92it/s]\n",
      "epoch: 902, loss: 6.1242: 100%|██████████| 100/100 [00:01<00:00, 62.51it/s]\n",
      "epoch: 903, loss: 6.0494: 100%|██████████| 100/100 [00:01<00:00, 63.06it/s]\n",
      "epoch: 904, loss: 6.3759: 100%|██████████| 100/100 [00:01<00:00, 62.78it/s]\n",
      "epoch: 905, loss: 6.0046: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 906, loss: 6.1100: 100%|██████████| 100/100 [00:01<00:00, 62.72it/s]\n",
      "epoch: 907, loss: 6.3610: 100%|██████████| 100/100 [00:01<00:00, 63.13it/s]\n",
      "epoch: 908, loss: 6.1282: 100%|██████████| 100/100 [00:01<00:00, 63.11it/s]\n",
      "epoch: 909, loss: 6.1329: 100%|██████████| 100/100 [00:01<00:00, 62.58it/s]\n",
      "epoch: 910, loss: 6.1088: 100%|██████████| 100/100 [00:01<00:00, 62.85it/s]\n",
      "epoch: 911, loss: 6.1037: 100%|██████████| 100/100 [00:01<00:00, 62.42it/s]\n",
      "epoch: 912, loss: 6.2502: 100%|██████████| 100/100 [00:01<00:00, 62.97it/s]\n",
      "epoch: 913, loss: 6.2953: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 914, loss: 6.0021: 100%|██████████| 100/100 [00:01<00:00, 62.74it/s]\n",
      "epoch: 915, loss: 6.1866: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 916, loss: 6.1283: 100%|██████████| 100/100 [00:01<00:00, 62.96it/s]\n",
      "epoch: 917, loss: 5.9943: 100%|██████████| 100/100 [00:01<00:00, 63.03it/s]\n",
      "epoch: 918, loss: 6.1787: 100%|██████████| 100/100 [00:01<00:00, 62.84it/s]\n",
      "epoch: 919, loss: 6.1869: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 920, loss: 6.0722: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 921, loss: 6.2777: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 922, loss: 6.2228: 100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "epoch: 923, loss: 6.0576: 100%|██████████| 100/100 [00:01<00:00, 60.49it/s]\n",
      "epoch: 924, loss: 6.2672: 100%|██████████| 100/100 [00:01<00:00, 60.41it/s]\n",
      "epoch: 925, loss: 6.3161: 100%|██████████| 100/100 [00:01<00:00, 60.45it/s]\n",
      "epoch: 926, loss: 6.3079: 100%|██████████| 100/100 [00:01<00:00, 60.07it/s]\n",
      "epoch: 927, loss: 6.0319: 100%|██████████| 100/100 [00:01<00:00, 60.39it/s]\n",
      "epoch: 928, loss: 6.2423: 100%|██████████| 100/100 [00:01<00:00, 61.57it/s]\n",
      "epoch: 929, loss: 6.2368: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 930, loss: 6.2449: 100%|██████████| 100/100 [00:01<00:00, 62.93it/s]\n",
      "epoch: 931, loss: 6.1106: 100%|██████████| 100/100 [00:01<00:00, 62.57it/s]\n",
      "epoch: 932, loss: 6.0426: 100%|██████████| 100/100 [00:01<00:00, 63.09it/s]\n",
      "epoch: 933, loss: 6.2028: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 934, loss: 6.0354: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 935, loss: 6.1081: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 936, loss: 6.2609: 100%|██████████| 100/100 [00:01<00:00, 62.50it/s]\n",
      "epoch: 937, loss: 6.2358: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 938, loss: 6.0432: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 939, loss: 5.8940: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 940, loss: 6.2274: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 941, loss: 6.1209: 100%|██████████| 100/100 [00:01<00:00, 62.89it/s]\n",
      "epoch: 942, loss: 6.1525: 100%|██████████| 100/100 [00:01<00:00, 62.65it/s]\n",
      "epoch: 943, loss: 6.1604: 100%|██████████| 100/100 [00:01<00:00, 62.66it/s]\n",
      "epoch: 944, loss: 6.0901: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 945, loss: 6.1494: 100%|██████████| 100/100 [00:01<00:00, 62.29it/s]\n",
      "epoch: 946, loss: 6.0061: 100%|██████████| 100/100 [00:01<00:00, 62.77it/s]\n",
      "epoch: 947, loss: 6.0113: 100%|██████████| 100/100 [00:01<00:00, 62.46it/s]\n",
      "epoch: 948, loss: 6.1897: 100%|██████████| 100/100 [00:01<00:00, 62.79it/s]\n",
      "epoch: 949, loss: 6.0346: 100%|██████████| 100/100 [00:01<00:00, 62.48it/s]\n",
      "epoch: 950, loss: 6.2285: 100%|██████████| 100/100 [00:01<00:00, 62.27it/s]\n",
      "epoch: 951, loss: 6.1416: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 952, loss: 6.1944: 100%|██████████| 100/100 [00:01<00:00, 62.64it/s]\n",
      "epoch: 953, loss: 6.1579: 100%|██████████| 100/100 [00:01<00:00, 62.99it/s]\n",
      "epoch: 954, loss: 6.1422: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 955, loss: 6.1912: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 956, loss: 6.1625: 100%|██████████| 100/100 [00:01<00:00, 62.37it/s]\n",
      "epoch: 957, loss: 6.0395: 100%|██████████| 100/100 [00:01<00:00, 62.73it/s]\n",
      "epoch: 958, loss: 6.1680: 100%|██████████| 100/100 [00:01<00:00, 62.60it/s]\n",
      "epoch: 959, loss: 6.2744: 100%|██████████| 100/100 [00:01<00:00, 61.90it/s]\n",
      "epoch: 960, loss: 6.0946: 100%|██████████| 100/100 [00:01<00:00, 60.36it/s]\n",
      "epoch: 961, loss: 6.1942: 100%|██████████| 100/100 [00:01<00:00, 59.70it/s]\n",
      "epoch: 962, loss: 6.1310: 100%|██████████| 100/100 [00:01<00:00, 60.37it/s]\n",
      "epoch: 963, loss: 6.2405: 100%|██████████| 100/100 [00:01<00:00, 60.29it/s]\n",
      "epoch: 964, loss: 6.1577: 100%|██████████| 100/100 [00:01<00:00, 60.54it/s]\n",
      "epoch: 965, loss: 6.0656: 100%|██████████| 100/100 [00:01<00:00, 61.11it/s]\n",
      "epoch: 966, loss: 6.2613: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 967, loss: 6.1030: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 968, loss: 6.2144: 100%|██████████| 100/100 [00:01<00:00, 62.87it/s]\n",
      "epoch: 969, loss: 6.1826: 100%|██████████| 100/100 [00:01<00:00, 62.59it/s]\n",
      "epoch: 970, loss: 6.2222: 100%|██████████| 100/100 [00:01<00:00, 63.02it/s]\n",
      "epoch: 971, loss: 6.0980: 100%|██████████| 100/100 [00:01<00:00, 62.83it/s]\n",
      "epoch: 972, loss: 5.9252: 100%|██████████| 100/100 [00:01<00:00, 62.97it/s]\n",
      "epoch: 973, loss: 6.0719: 100%|██████████| 100/100 [00:01<00:00, 62.69it/s]\n",
      "epoch: 974, loss: 6.2385: 100%|██████████| 100/100 [00:01<00:00, 62.67it/s]\n",
      "epoch: 975, loss: 6.2494: 100%|██████████| 100/100 [00:01<00:00, 63.20it/s]\n",
      "epoch: 976, loss: 6.0382: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 977, loss: 6.3220: 100%|██████████| 100/100 [00:01<00:00, 63.01it/s]\n",
      "epoch: 978, loss: 6.2047: 100%|██████████| 100/100 [00:01<00:00, 62.38it/s]\n",
      "epoch: 979, loss: 6.0858: 100%|██████████| 100/100 [00:01<00:00, 62.91it/s]\n",
      "epoch: 980, loss: 6.1021: 100%|██████████| 100/100 [00:01<00:00, 62.63it/s]\n",
      "epoch: 981, loss: 6.2127: 100%|██████████| 100/100 [00:01<00:00, 62.68it/s]\n",
      "epoch: 982, loss: 6.1298: 100%|██████████| 100/100 [00:01<00:00, 62.61it/s]\n",
      "epoch: 983, loss: 6.2071: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 984, loss: 6.1930: 100%|██████████| 100/100 [00:01<00:00, 62.82it/s]\n",
      "epoch: 985, loss: 6.1304: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 986, loss: 6.0870: 100%|██████████| 100/100 [00:01<00:00, 62.75it/s]\n",
      "epoch: 987, loss: 6.2889: 100%|██████████| 100/100 [00:01<00:00, 62.62it/s]\n",
      "epoch: 988, loss: 6.1721: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 989, loss: 6.1276: 100%|██████████| 100/100 [00:01<00:00, 62.95it/s]\n",
      "epoch: 990, loss: 6.1466: 100%|██████████| 100/100 [00:01<00:00, 62.86it/s]\n",
      "epoch: 991, loss: 6.0517: 100%|██████████| 100/100 [00:01<00:00, 62.71it/s]\n",
      "epoch: 992, loss: 6.4530: 100%|██████████| 100/100 [00:01<00:00, 62.94it/s]\n",
      "epoch: 993, loss: 6.1943: 100%|██████████| 100/100 [00:01<00:00, 62.34it/s]\n",
      "epoch: 994, loss: 6.1733: 100%|██████████| 100/100 [00:01<00:00, 62.14it/s]\n",
      "epoch: 995, loss: 6.3083: 100%|██████████| 100/100 [00:01<00:00, 71.43it/s]\n",
      "epoch: 996, loss: 6.2160: 100%|██████████| 100/100 [00:01<00:00, 62.29it/s]\n",
      "epoch: 997, loss: 6.2623: 100%|██████████| 100/100 [00:01<00:00, 61.22it/s]\n",
      "epoch: 998, loss: 6.1498: 100%|██████████| 100/100 [00:01<00:00, 60.81it/s]\n",
      "epoch: 999, loss: 6.1578: 100%|██████████| 100/100 [00:01<00:00, 60.69it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "samples = float2bin(db.gen_batch(50000), bm)\n",
    "mean = np.mean(samples, axis=0)\n",
    "init_dist = torch.distributions.Bernoulli(probs=torch.from_numpy(mean).to(device) * (1. - 2 * 1e-2) + 1e-2)\n",
    "net = MLPScore(input_dim=32, hidden_dims=[256,256,256,1]).to(device)\n",
    "energy_func = EBM(net, torch.from_numpy(mean)).to(device)\n",
    "ema_energy_func = training_main_loop(db, bm, energy_func, device, algo='ed_grid_grad')\n",
    "plot_heat(ema_energy_func, bm, device)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ebm",
   "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.8.17"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
