{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3f80e3a6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_32940\\273441208.py:10: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# !pip install deeprobust\n",
    "# !conda install pytorch torchvision torchaudio -c pytorch\n",
    "import torch\n",
    "# print(torch.__version__)\n",
    "# !pip install torch-scatter torch-sparse -f https://data.pyg.org/whl/torch-{torch.__version__}.html\n",
    "# !pip install torch-geometric\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "\n",
    "import random\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c287cb5c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_32940\\4057615484.py:25: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC'"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import collections\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "from torch import Tensor\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import networkx as nx\n",
    "from networkx.algorithms import community\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "data_dir = \"./data\"\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "\n",
    "import numpy\n",
    "import torch\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "\n",
    "from random import sample\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "import random\n",
    "\n",
    "from scipy.sparse import csr_matrix\n",
    "from scipy.sparse import csgraph\n",
    "from scipy.sparse.linalg import inv\n",
    "\n",
    "import os\n",
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3669a0f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Cora'"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset = os.path.join(os.getcwd(),'Cora')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "067c3d06",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset: Cora\n",
      "num_nodes: 2708\n",
      "num_edges: 10556\n",
      "num_classes: 7\n",
      "num_features: 1433\n"
     ]
    }
   ],
   "source": [
    "import os.path as osp\n",
    "import torch\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import torch_geometric.transforms as T\n",
    "\n",
    "def get_planetoid_dataset(name, normalize_features=False, transform=None, split=\"public\"):\n",
    "    path = osp.join(osp.dirname(osp.realpath(os.getcwd())), '..', 'data', name)\n",
    "    if split == 'complete':\n",
    "        dataset = Planetoid(path, name)\n",
    "        dataset[0].train_mask.fill_(False)\n",
    "        dataset[0].train_mask[:dataset[0].num_nodes - 1000] = 1\n",
    "        dataset[0].val_mask.fill_(False)\n",
    "        dataset[0].val_mask[dataset[0].num_nodes - 1000:dataset[0].num_nodes - 500] = 1\n",
    "        dataset[0].test_mask.fill_(False)\n",
    "        dataset[0].test_mask[dataset[0].num_nodes - 500:] = 1\n",
    "    else:\n",
    "        dataset = Planetoid(path, name, split=split)\n",
    "    if transform is not None and normalize_features:\n",
    "        dataset.transform = T.Compose([T.NormalizeFeatures(), transform])\n",
    "    elif normalize_features:\n",
    "        dataset.transform = T.NormalizeFeatures()\n",
    "    elif transform is not None:\n",
    "        dataset.transform = transform\n",
    "    return dataset\n",
    "\n",
    "\n",
    "if __name__ == '__main__':\n",
    "#     lst_names = ['Cora', 'CiteSeer', 'PubMed']\n",
    "    lst_names = ['Cora']\n",
    "    for name in lst_names:\n",
    "        dataset = get_planetoid_dataset(name)\n",
    "        print(f\"dataset: {name}\")\n",
    "        print(f\"num_nodes: {dataset[0]['x'].shape[0]}\")\n",
    "        print(f\"num_edges: {dataset[0]['edge_index'].shape[1]}\")\n",
    "        print(f\"num_classes: {dataset.num_classes}\")\n",
    "        print(f\"num_features: {dataset.num_node_features}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7f8577f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data(x=[2708, 1433], edge_index=[2, 10556], y=[2708], train_mask=[2708], val_mask=[2708], test_mask=[2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "# from torch_geometric.datasets import Planetoid\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # dataset = NELL(root='/nell')\n",
    "\n",
    "\n",
    "# dataset= Planetoid(root=dataset, name='Cora')\n",
    "print(dataset[0])\n",
    "adj = to_dense_adj(dataset[0].edge_index).cuda()\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "475846d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2708, 1433])"
      ]
     },
     "execution_count": 160,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "a0757b15",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "def get_laplacian(adj):\n",
    "    b=torch.ones(adj.shape[0]).cuda()\n",
    "    return torch.diag(adj@b)-adj\n",
    "\n",
    "theta = get_laplacian(adj)\n",
    "print(theta.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "cad0c60b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda', index=0)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "114a42e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7 2708\n"
     ]
    }
   ],
   "source": [
    "features = torch.Tensor(X).cuda()\n",
    "NO_OF_NODES = X.shape[0]\n",
    "print(NO_OF_CLASSES,NO_OF_NODES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "2ba32732",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda', index=0)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "b33c30e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def convertScipyToTensor(coo):\n",
    "  try:\n",
    "    coo = coo.tocoo()\n",
    "  except:\n",
    "    coo = coo\n",
    "  values = coo.data\n",
    "  indices = np.vstack((coo.row, coo.col))\n",
    "\n",
    "  i = torch.LongTensor(indices)\n",
    "  v = torch.FloatTensor(values)\n",
    "  shape = coo.shape\n",
    "\n",
    "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "b7f9d72b",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.sparse import random\n",
    "from scipy.sparse.linalg import norm\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "p = X.shape[0]\n",
    "k = int(p*0.01)\n",
    "n = X.shape[1]\n",
    "lambda_param = 100\n",
    "beta_param = 50\n",
    "gamma_param = 100\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "#X_tilde = random(k, n, density=0.25, random_state=1, data_rvs=temp2.rvs)   #NOT needed 21\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 364,
   "id": "1f724733",
   "metadata": {},
   "outputs": [],
   "source": [
    "def experiment_K_component(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X):\n",
    "      p = X.shape[0]\n",
    "      k = int(p*1)\n",
    "      n = X.shape[1]\n",
    "      ones = csr_matrix(np.ones((k,k)))\n",
    "      ones = convertScipyToTensor(ones).cuda()\n",
    "      ones = ones.to_dense()\n",
    "      \n",
    "      try:\n",
    "        C = convertScipyToTensor(C)\n",
    "        C = C.to_dense()\n",
    "      except:\n",
    "        C=C\n",
    "      try:\n",
    "        theta = convertScipyToTensor(theta)\n",
    "      except:\n",
    "        theta = theta\n",
    "      try:\n",
    "        X = convertScipyToTensor(X)\n",
    "        X = X.to_dense()\n",
    "      except:\n",
    "        X = X\n",
    "      if(torch.cuda.is_available()):\n",
    "        print(\"yes\")\n",
    "        C = C.cuda()\n",
    "        theta = theta.cuda()\n",
    "        X = X.cuda()\n",
    "        ones = ones.cuda()\n",
    "      def bracket_term2fun(C,CT,theta:\n",
    "          lamb,U=torch.linalg.eig(CT@theta@C)\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          lambda_matrix= torch.diag(lamb,0).cuda()   ## Making 1D array into diagonal square matrix  \n",
    "          return U@lambda_matrix@UT\n",
    "\n",
    "      def update_C(C):\n",
    "          thetaC = theta@C\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          t1 = alpha_param*(C@ones)\n",
    "          bracket_term1 = (thetaC@CT@thetaC)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta)\n",
    "          bracket_term = bracket_term1 - bracket_term2\n",
    "          t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          grad_fc= t1+t2\n",
    "          C_new=C-gamma_param*grad_fc\n",
    "          C_new[C_new<thresh] = thresh\n",
    "          for i in range(len(C_new)):\n",
    "              C_new[i] = C_new[i]/torch.linalg.norm(C_new[i],1)\n",
    "          return C_new,bracket_term # bracket term (CT*theta*C - U*lambda*UT)\n",
    "            \n",
    "      def update_U(C,theta):\n",
    "          CT= torch.transpose(C,0,1)\n",
    "          lamb,U=torch.linalg.eig(CT@theta@C)  #U lena ahi\n",
    "          return U \n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "\n",
    "\n",
    "      # K is the number of smallest eigenvalues of the Laplacian matrix that are being ignored while updating the eigenvalues.\n",
    "      def laplacian_lambda_update(lb, ub, beta, U, Lw, k):\n",
    "        q = Lw.size(1) - k\n",
    "        UT= torch.transpose(U,0,1)\n",
    "        UT = UT.type(torch.float64)\n",
    "        d = torch.diag(UT @ Lw @ U)\n",
    "        # unconstrained solution as initial point\n",
    "        lambda_ = 0.5 * (d + torch.sqrt(d.pow(2) + 4 / beta))\n",
    "        lambda_,indices = torch.sort(lambda_, dim=- 1, descending=True)\n",
    "        print(lambda_)\n",
    "        eps = 10\n",
    "        condition = torch.tensor([(lambda_[q] - ub) <= eps,\n",
    "                                  (lambda_[0] - lb) >= -eps,\n",
    "                                  (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps]).all()\n",
    "        if condition:\n",
    "            return lambda_\n",
    "        else:\n",
    "            greater_ub = lambda_ > ub\n",
    "            lesser_lb = lambda_ < lb\n",
    "            lambda_[greater_ub] = ub\n",
    "            lambda_[lesser_lb] = lb\n",
    "            condition = torch.tensor([(lambda_[q] - ub) <= eps,\n",
    "                                  (lambda_[0] - lb) >= -eps,\n",
    "                                  (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps]).all()\n",
    "            if condition:\n",
    "                return lambda_\n",
    "            else:\n",
    "                print(lambda_)\n",
    "                raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "            \n",
    "\n",
    "      for i in tqdm(range(2000)): #update C only 21\n",
    "         C, bracket_term = update_C(C)\n",
    "         U  = update_U(C,theta).double()\n",
    "         CT = torch.transpose(C,0,1)\n",
    "         Lw = (CT @theta @C).double()\n",
    "         k_ = 7   #%notebookNumber of classes\n",
    "         lambda_ = laplacian_lambda_update(0, 5, 0.5, U, Lw , k_)\n",
    "         lambda_ =  torch.diag(lambda_,0).cuda()\n",
    "            \n",
    "      return lambda_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 365,
   "id": "5ac900a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accuracy(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "#         device = torch.device('cpu')\n",
    "        device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "        device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        model=Net().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        try:\n",
    "          X=np.array(features.todense())\n",
    "        except:\n",
    "          X = np.array(features)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        Wc=sparse.csr_matrix(adj)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 368,
   "id": "77c22626",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n",
      "SVD DID NOT CONVERGE\n",
      "Average accuracy = nan +/- nan\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for lambda_param in [100,10,1,0.1,0.01]:\n",
    "  for beta_param in [ 100,10,1,0.1,0.01]:\n",
    "      for gamma_param in [100,10,1,0.1,0.01]:\n",
    "\n",
    "        av = []\n",
    "        avg_accuracy_all=[]\n",
    "\n",
    "        for _ in range(1):\n",
    "\n",
    "          X_tilde = random(k, n, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "          C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "          try:\n",
    "\n",
    "              C_0 = experiment_K_component(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X)\n",
    "              L = theta\n",
    "#               C_0 = C_0.cpu().detach().numpy()\n",
    "#               X_t_0 = X_t_0.cpu().detach().numpy()     #See X_t_0 from copy 21\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_t_0 = C_0.T\n",
    "              try:\n",
    "                L = L.cpu().detach().numpy()\n",
    "              except:\n",
    "                L = L\n",
    "              \n",
    "              acc = get_accuracy(C_0,L,X_t_0)\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                    highest_accuracy=acc\n",
    "              print(\"Accuracy = \" + str(acc) + \" \" + str(lambda_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "          except:\n",
    "              print(\"SVD DID NOT CONVERGE\")\n",
    "\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 361,
   "id": "26e1e00f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "yes\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|▋                                                                              | 16/2000 [00:00<00:12, 153.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.9205, 1.4715, 1.0850], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9206, 1.4716, 1.0862], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9206, 1.4717, 1.0874], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9207, 1.4718, 1.0886], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9208, 1.4719, 1.0898], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9209, 1.4720, 1.0910], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9210, 1.4720, 1.0921], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9210, 1.4721, 1.0933], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9211, 1.4722, 1.0945], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9212, 1.4723, 1.0956], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9212, 1.4724, 1.0968], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9213, 1.4725, 1.0980], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9214, 1.4726, 1.0991], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9215, 1.4726, 1.1003], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9215, 1.4727, 1.1015], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9216, 1.4728, 1.1026], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9216, 1.4729, 1.1038], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9217, 1.4730, 1.1049], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9218, 1.4731, 1.1061], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9218, 1.4732, 1.1072], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9219, 1.4733, 1.1083], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9219, 1.4734, 1.1095], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9220, 1.4734, 1.1106], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9220, 1.4735, 1.1118], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9221, 1.4736, 1.1129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9222, 1.4737, 1.1140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9222, 1.4738, 1.1152], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9223, 1.4739, 1.1163], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9223, 1.4740, 1.1174], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9223, 1.4741, 1.1185], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9224, 1.4742, 1.1196], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9224, 1.4743, 1.1208], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9225, 1.4744, 1.1219], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|██▏                                                                            | 54/2000 [00:00<00:10, 178.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.9225, 1.4745, 1.1230], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9226, 1.4746, 1.1241], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9226, 1.4747, 1.1252], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9226, 1.4748, 1.1263], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4749, 1.1274], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4750, 1.1285], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4751, 1.1296], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4752, 1.1307], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4753, 1.1318], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4754, 1.1329], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4755, 1.1340], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4756, 1.1351], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4757, 1.1361], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4758, 1.1372], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4759, 1.1383], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4760, 1.1394], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4761, 1.1405], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4762, 1.1415], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4764, 1.1426], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4765, 1.1437], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4766, 1.1447], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4767, 1.1458], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4768, 1.1469], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4769, 1.1479], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4770, 1.1490], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4771, 1.1501], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4773, 1.1511], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4774, 1.1522], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4775, 1.1532], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4776, 1.1543], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4777, 1.1553], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4778, 1.1564], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4780, 1.1574], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4781, 1.1584], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4782, 1.1595], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4783, 1.1605], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9231, 1.4784, 1.1616], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4786, 1.1626], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4787, 1.1636], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4788, 1.1646], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|███▉                                                                           | 99/2000 [00:00<00:09, 207.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.9230, 1.4789, 1.1657], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4791, 1.1667], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9230, 1.4792, 1.1677], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4793, 1.1687], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4794, 1.1698], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4796, 1.1708], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4797, 1.1718], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9229, 1.4798, 1.1728], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4800, 1.1738], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4801, 1.1748], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9228, 1.4802, 1.1758], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4804, 1.1768], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4805, 1.1778], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9227, 1.4806, 1.1788], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9226, 1.4808, 1.1798], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9226, 1.4809, 1.1808], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9225, 1.4811, 1.1818], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9225, 1.4812, 1.1828], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9225, 1.4813, 1.1838], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9224, 1.4815, 1.1848], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9224, 1.4816, 1.1858], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9223, 1.4818, 1.1868], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9223, 1.4819, 1.1878], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9222, 1.4821, 1.1888], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9222, 1.4822, 1.1897], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9221, 1.4824, 1.1907], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9220, 1.4825, 1.1917], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9220, 1.4827, 1.1927], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9219, 1.4828, 1.1936], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9219, 1.4830, 1.1946], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9218, 1.4831, 1.1956], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9217, 1.4833, 1.1965], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9217, 1.4834, 1.1975], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9216, 1.4836, 1.1985], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9215, 1.4837, 1.1994], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9215, 1.4839, 1.2004], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9214, 1.4841, 1.2013], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9213, 1.4842, 1.2023], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9212, 1.4844, 1.2033], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9211, 1.4846, 1.2042], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9211, 1.4847, 1.2052], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9210, 1.4849, 1.2061], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9209, 1.4851, 1.2070], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9208, 1.4852, 1.2080], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9207, 1.4854, 1.2089], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9206, 1.4856, 1.2099], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9205, 1.4857, 1.2108], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9204, 1.4859, 1.2118], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9203, 1.4861, 1.2127], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9202, 1.4863, 1.2136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9201, 1.4864, 1.2145], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9200, 1.4866, 1.2155], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|█████▉                                                                        | 152/2000 [00:00<00:07, 233.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.9199, 1.4868, 1.2164], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9198, 1.4870, 1.2173], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9197, 1.4872, 1.2183], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9196, 1.4873, 1.2192], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9195, 1.4875, 1.2201], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9194, 1.4877, 1.2210], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9193, 1.4879, 1.2219], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9192, 1.4881, 1.2228], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9190, 1.4883, 1.2238], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9189, 1.4885, 1.2247], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9188, 1.4887, 1.2256], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9187, 1.4889, 1.2265], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9185, 1.4891, 1.2274], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9184, 1.4893, 1.2283], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9183, 1.4895, 1.2292], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9182, 1.4897, 1.2301], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9180, 1.4899, 1.2310], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9179, 1.4901, 1.2319], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9177, 1.4903, 1.2328], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9176, 1.4905, 1.2337], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9175, 1.4907, 1.2345], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9173, 1.4909, 1.2354], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9172, 1.4911, 1.2363], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9170, 1.4913, 1.2372], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9169, 1.4916, 1.2381], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9167, 1.4918, 1.2390], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9166, 1.4920, 1.2398], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9164, 1.4922, 1.2407], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9162, 1.4924, 1.2416], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9161, 1.4927, 1.2424], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9159, 1.4929, 1.2433], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9157, 1.4931, 1.2442], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9156, 1.4933, 1.2450], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9154, 1.4936, 1.2459], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9152, 1.4938, 1.2468], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9151, 1.4940, 1.2476], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9149, 1.4943, 1.2485], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9147, 1.4945, 1.2493], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9145, 1.4948, 1.2502], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9143, 1.4950, 1.2510], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9141, 1.4952, 1.2519], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9139, 1.4955, 1.2527], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9138, 1.4957, 1.2536], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9136, 1.4960, 1.2544], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9134, 1.4962, 1.2553], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9132, 1.4965, 1.2561], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9130, 1.4968, 1.2569], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9128, 1.4970, 1.2578], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9126, 1.4973, 1.2586], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9123, 1.4975, 1.2594], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9121, 1.4978, 1.2603], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9119, 1.4981, 1.2611], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9117, 1.4983, 1.2619], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████                                                                     | 232/2000 [00:01<00:07, 250.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.9115, 1.4986, 1.2627], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9113, 1.4989, 1.2635], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9110, 1.4992, 1.2644], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9108, 1.4994, 1.2652], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9106, 1.4997, 1.2660], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9104, 1.5000, 1.2668], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9101, 1.5003, 1.2676], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9099, 1.5006, 1.2684], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9096, 1.5009, 1.2692], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9094, 1.5012, 1.2700], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9092, 1.5015, 1.2708], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9089, 1.5017, 1.2716], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9087, 1.5020, 1.2724], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9084, 1.5024, 1.2732], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9082, 1.5027, 1.2740], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9079, 1.5030, 1.2748], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9076, 1.5033, 1.2756], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9074, 1.5036, 1.2763], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9071, 1.5039, 1.2771], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9068, 1.5042, 1.2779], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9066, 1.5045, 1.2787], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9063, 1.5049, 1.2794], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9060, 1.5052, 1.2802], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9057, 1.5055, 1.2810], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9054, 1.5058, 1.2817], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9052, 1.5062, 1.2825], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9049, 1.5065, 1.2833], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9046, 1.5068, 1.2840], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9043, 1.5072, 1.2848], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9040, 1.5075, 1.2855], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9037, 1.5079, 1.2863], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9034, 1.5082, 1.2870], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9031, 1.5086, 1.2878], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9028, 1.5089, 1.2885], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9024, 1.5093, 1.2893], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9021, 1.5097, 1.2900], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9018, 1.5100, 1.2908], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9015, 1.5104, 1.2915], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9012, 1.5108, 1.2922], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9008, 1.5111, 1.2930], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9005, 1.5115, 1.2937], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.9002, 1.5119, 1.2944], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8998, 1.5123, 1.2951], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8995, 1.5127, 1.2959], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8991, 1.5131, 1.2966], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8988, 1.5135, 1.2973], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8984, 1.5139, 1.2980], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8981, 1.5143, 1.2987], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8977, 1.5147, 1.2994], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8974, 1.5151, 1.3001], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8970, 1.5155, 1.3008], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8966, 1.5159, 1.3015], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8963, 1.5163, 1.3022], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8959, 1.5167, 1.3029], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 13%|██████████                                                                    | 258/2000 [00:01<00:06, 250.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.8955, 1.5172, 1.3036], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8951, 1.5176, 1.3043], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8947, 1.5180, 1.3050], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8943, 1.5185, 1.3057], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8940, 1.5189, 1.3063], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8936, 1.5193, 1.3070], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8932, 1.5198, 1.3077], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8927, 1.5202, 1.3084], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8923, 1.5207, 1.3090], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8919, 1.5211, 1.3097], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8915, 1.5216, 1.3104], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8911, 1.5221, 1.3110], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8907, 1.5225, 1.3117], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8902, 1.5230, 1.3124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8898, 1.5235, 1.3130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8894, 1.5240, 1.3137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8889, 1.5245, 1.3143], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8885, 1.5250, 1.3149], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8880, 1.5255, 1.3156], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8876, 1.5260, 1.3162], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8871, 1.5265, 1.3169], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8867, 1.5270, 1.3175], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8862, 1.5275, 1.3181], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8857, 1.5280, 1.3188], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8853, 1.5285, 1.3194], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8848, 1.5290, 1.3200], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8843, 1.5296, 1.3206], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8838, 1.5301, 1.3212], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8833, 1.5306, 1.3219], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8828, 1.5312, 1.3225], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8823, 1.5317, 1.3231], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8818, 1.5323, 1.3237], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8813, 1.5329, 1.3243], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8808, 1.5334, 1.3249], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8803, 1.5340, 1.3255], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8798, 1.5346, 1.3261], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8793, 1.5351, 1.3267], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8787, 1.5357, 1.3273], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8782, 1.5363, 1.3278], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8776, 1.5369, 1.3284], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8771, 1.5375, 1.3290], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8765, 1.5381, 1.3296], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8760, 1.5387, 1.3302], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8754, 1.5393, 1.3307], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8749, 1.5399, 1.3313], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8743, 1.5406, 1.3319], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8737, 1.5412, 1.3324], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8731, 1.5418, 1.3330], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8725, 1.5425, 1.3335], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8720, 1.5431, 1.3341], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8714, 1.5438, 1.3346], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|████████████                                                                  | 310/2000 [00:01<00:06, 252.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.8708, 1.5444, 1.3352], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8701, 1.5451, 1.3357], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8695, 1.5458, 1.3363], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8689, 1.5464, 1.3368], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8683, 1.5471, 1.3373], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8677, 1.5478, 1.3379], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8670, 1.5485, 1.3384], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8664, 1.5492, 1.3389], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8657, 1.5499, 1.3395], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8651, 1.5506, 1.3400], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8644, 1.5513, 1.3405], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8637, 1.5521, 1.3410], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8631, 1.5528, 1.3415], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8624, 1.5535, 1.3420], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8617, 1.5543, 1.3425], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8610, 1.5550, 1.3430], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8603, 1.5558, 1.3435], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8596, 1.5565, 1.3440], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8589, 1.5573, 1.3445], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8582, 1.5581, 1.3450], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8574, 1.5589, 1.3455], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8567, 1.5597, 1.3460], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8559, 1.5605, 1.3465], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8552, 1.5613, 1.3470], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8544, 1.5621, 1.3474], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8537, 1.5629, 1.3479], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8529, 1.5638, 1.3484], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8521, 1.5646, 1.3488], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8513, 1.5655, 1.3493], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8505, 1.5663, 1.3498], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8497, 1.5672, 1.3502], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8489, 1.5680, 1.3507], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8481, 1.5689, 1.3511], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8473, 1.5698, 1.3516], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8464, 1.5707, 1.3520], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8456, 1.5716, 1.3525], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8447, 1.5725, 1.3529], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8438, 1.5735, 1.3534], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8430, 1.5744, 1.3538], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8421, 1.5754, 1.3542], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8412, 1.5763, 1.3547], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8403, 1.5773, 1.3551], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8394, 1.5783, 1.3555], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8384, 1.5792, 1.3559], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8375, 1.5802, 1.3564], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8366, 1.5812, 1.3568], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8356, 1.5823, 1.3572], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8346, 1.5833, 1.3576], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8336, 1.5843, 1.3580], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8327, 1.5854, 1.3584], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8316, 1.5865, 1.3588], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8306, 1.5875, 1.3592], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8296, 1.5886, 1.3596], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|███████████████▏                                                              | 390/2000 [00:01<00:06, 258.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.8286, 1.5897, 1.3600], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8275, 1.5909, 1.3604], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8264, 1.5920, 1.3608], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8253, 1.5931, 1.3612], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8242, 1.5943, 1.3616], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8231, 1.5955, 1.3619], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8220, 1.5967, 1.3623], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8208, 1.5979, 1.3627], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8197, 1.5991, 1.3631], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8185, 1.6003, 1.3634], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8173, 1.6016, 1.3638], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8161, 1.6029, 1.3642], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8149, 1.6042, 1.3645], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8136, 1.6055, 1.3649], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8123, 1.6068, 1.3652], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8110, 1.6081, 1.3656], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8097, 1.6095, 1.3660], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8084, 1.6109, 1.3663], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8070, 1.6123, 1.3666], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8056, 1.6138, 1.3670], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8042, 1.6152, 1.3673], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8028, 1.6167, 1.3677], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.8013, 1.6183, 1.3680], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7998, 1.6198, 1.3683], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7983, 1.6214, 1.3687], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7967, 1.6230, 1.3690], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7952, 1.6246, 1.3693], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7935, 1.6263, 1.3697], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7919, 1.6280, 1.3700], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7902, 1.6298, 1.3703], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7884, 1.6316, 1.3706], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7866, 1.6334, 1.3709], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7848, 1.6353, 1.3713], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7829, 1.6373, 1.3716], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7809, 1.6393, 1.3719], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7789, 1.6414, 1.3722], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7768, 1.6435, 1.3725], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7747, 1.6457, 1.3728], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7724, 1.6480, 1.3731], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7701, 1.6504, 1.3734], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7677, 1.6528, 1.3737], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7651, 1.6554, 1.3740], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7624, 1.6582, 1.3743], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7596, 1.6611, 1.3746], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7566, 1.6641, 1.3748], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7533, 1.6674, 1.3751], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7498, 1.6710, 1.3754], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7459, 1.6749, 1.3757], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7415, 1.6793, 1.3760], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7364, 1.6845, 1.3763], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7300, 1.6910, 1.3765], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7197, 1.7013, 1.3768], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7105, 1.7105, 1.3771], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7104, 1.7104, 1.3773], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|█████████████████▎                                                            | 443/2000 [00:01<00:06, 258.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7104, 1.7104, 1.3776], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7103, 1.7103, 1.3779], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7103, 1.7103, 1.3781], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.3784], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.3787], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3789], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3792], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3794], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3797], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3799], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3802], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3804], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3807], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3809], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3812], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3814], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3816], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3819], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3821], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3823], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3826], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3828], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3830], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3833], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3835], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3837], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3839], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3841], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3844], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3846], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3848], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3850], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3852], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3854], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3856], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3858], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3861], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3863], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3865], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3867], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.3869], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3871], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3873], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3875], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3877], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3879], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.3880], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3882], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3884], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3886], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.3888], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3890], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3892], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|███████████████████▎                                                          | 495/2000 [00:02<00:05, 258.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7100, 1.7100, 1.3894], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.3895], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3897], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3899], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.3901], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.3902], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.3904], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.3906], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7103, 1.7103, 1.3908], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7103, 1.7103, 1.3909], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7103, 1.7103, 1.3911], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7104, 1.7104, 1.3913], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7104, 1.7104, 1.3914], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7104, 1.7104, 1.3916], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7105, 1.7105, 1.3918], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7105, 1.7105, 1.3919], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7106, 1.7106, 1.3921], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7106, 1.7106, 1.3923], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7106, 1.7106, 1.3924], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7107, 1.7107, 1.3926], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7107, 1.7107, 1.3928], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7108, 1.7108, 1.3929], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7108, 1.7108, 1.3931], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7109, 1.7109, 1.3932], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7109, 1.7109, 1.3934], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7109, 1.7109, 1.3935], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7110, 1.7110, 1.3937], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7110, 1.7110, 1.3938], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7111, 1.7111, 1.3940], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7111, 1.7111, 1.3941], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7112, 1.7112, 1.3943], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7112, 1.7112, 1.3944], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7113, 1.7113, 1.3946], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7113, 1.7113, 1.3947], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7114, 1.7114, 1.3949], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7114, 1.7114, 1.3950], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7115, 1.7115, 1.3951], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7115, 1.7115, 1.3953], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7116, 1.7116, 1.3954], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7116, 1.7116, 1.3956], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7117, 1.7117, 1.3957], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7117, 1.7117, 1.3958], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7118, 1.7118, 1.3960], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7118, 1.7118, 1.3961], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7119, 1.7119, 1.3962], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7119, 1.7119, 1.3964], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7120, 1.7120, 1.3965], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7120, 1.7120, 1.3966], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7121, 1.7121, 1.3968], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7121, 1.7121, 1.3969], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7122, 1.7122, 1.3970], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7122, 1.7122, 1.3972], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|█████████████████████▎                                                        | 547/2000 [00:02<00:05, 257.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7123, 1.7123, 1.3973], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7124, 1.7124, 1.3974], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7124, 1.7124, 1.3975], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7125, 1.7125, 1.3977], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7125, 1.7125, 1.3978], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7126, 1.7126, 1.3979], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7126, 1.7126, 1.3980], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7127, 1.7127, 1.3981], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7127, 1.7127, 1.3983], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7128, 1.7128, 1.3984], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7128, 1.7128, 1.3985], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7129, 1.7129, 1.3986], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7129, 1.7129, 1.3987], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7130, 1.7130, 1.3989], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7130, 1.7130, 1.3990], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7131, 1.7131, 1.3991], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7131, 1.7131, 1.3992], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7132, 1.7132, 1.3993], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7132, 1.7132, 1.3994], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7133, 1.7133, 1.3995], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7133, 1.7133, 1.3996], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7134, 1.7134, 1.3997], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7135, 1.7135, 1.3999], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7135, 1.7135, 1.4000], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7136, 1.7136, 1.4001], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7136, 1.7136, 1.4002], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7137, 1.7137, 1.4003], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7137, 1.7137, 1.4004], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7138, 1.7138, 1.4005], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7138, 1.7138, 1.4006], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7139, 1.7139, 1.4007], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7139, 1.7139, 1.4008], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7140, 1.7140, 1.4009], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7140, 1.7140, 1.4010], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7140, 1.7140, 1.4011], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7141, 1.7141, 1.4012], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7141, 1.7141, 1.4013], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7142, 1.7142, 1.4014], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7142, 1.7142, 1.4015], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7143, 1.7143, 1.4016], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7143, 1.7143, 1.4017], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7144, 1.7144, 1.4018], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7144, 1.7144, 1.4019], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7145, 1.7145, 1.4020], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7145, 1.7145, 1.4021], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7146, 1.7146, 1.4022], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7146, 1.7146, 1.4023], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7146, 1.7146, 1.4023], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7147, 1.7147, 1.4024], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7147, 1.7147, 1.4025], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7148, 1.7148, 1.4026], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7148, 1.7148, 1.4027], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 29%|██████████████████████▎                                                       | 573/2000 [00:02<00:05, 254.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7149, 1.7149, 1.4028], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7149, 1.7149, 1.4029], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7149, 1.7149, 1.4030], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7150, 1.7150, 1.4031], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7150, 1.7150, 1.4031], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7150, 1.7150, 1.4032], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7151, 1.7151, 1.4033], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7151, 1.7151, 1.4034], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4035], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4036], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4037], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7153, 1.7153, 1.4037], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7153, 1.7153, 1.4038], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7153, 1.7153, 1.4039], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4040], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4041], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4041], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4042], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4043], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4044], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4044], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4045], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4046], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4047], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4048], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4048], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4049], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4050], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4051], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4051], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4052], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4053], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4053], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4054], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4055], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4056], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4056], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4057], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4058], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4058], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4059], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4060], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4060], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4061], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4062], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4062], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4063], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4064], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4064], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|█████████████████████████▍                                                    | 652/2000 [00:02<00:05, 255.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7161, 1.7161, 1.4065], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4065], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4066], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4067], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4067], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4068], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4069], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4069], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4070], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4070], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4071], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4072], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4072], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4073], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4073], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4074], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4074], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4075], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4076], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4076], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4077], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4077], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7161, 1.7161, 1.4078], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4078], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4079], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4079], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4080], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4081], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4081], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7160, 1.7160, 1.4082], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4082], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4083], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4083], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7159, 1.7159, 1.4084], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4084], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4085], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4085], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4086], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7158, 1.7158, 1.4086], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4087], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4087], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7157, 1.7157, 1.4088], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4088], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4089], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7156, 1.7156, 1.4089], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4090], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4090], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7155, 1.7155, 1.4090], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4091], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4091], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7154, 1.7154, 1.4092], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7153, 1.7153, 1.4092], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7153, 1.7153, 1.4093], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4093], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4094], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7152, 1.7152, 1.4094], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███████████████████████████▍                                                  | 704/2000 [00:02<00:05, 253.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7151, 1.7151, 1.4095], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7151, 1.7151, 1.4095], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7150, 1.7150, 1.4095], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7150, 1.7150, 1.4096], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7149, 1.7149, 1.4096], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7149, 1.7149, 1.4097], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7148, 1.7148, 1.4097], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7148, 1.7148, 1.4098], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7147, 1.7147, 1.4098], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7147, 1.7147, 1.4098], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7146, 1.7146, 1.4099], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7145, 1.7145, 1.4099], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7145, 1.7145, 1.4100], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7144, 1.7144, 1.4100], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7144, 1.7144, 1.4100], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7143, 1.7143, 1.4101], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7143, 1.7143, 1.4101], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7142, 1.7142, 1.4102], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7141, 1.7141, 1.4102], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7141, 1.7141, 1.4102], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7140, 1.7140, 1.4103], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7139, 1.7139, 1.4103], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7139, 1.7139, 1.4103], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7138, 1.7138, 1.4104], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7137, 1.7137, 1.4104], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7137, 1.7137, 1.4105], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7136, 1.7136, 1.4105], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7135, 1.7135, 1.4105], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7134, 1.7134, 1.4106], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7134, 1.7134, 1.4106], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7133, 1.7133, 1.4106], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7132, 1.7132, 1.4107], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7131, 1.7131, 1.4107], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7130, 1.7130, 1.4107], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7130, 1.7130, 1.4108], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7129, 1.7129, 1.4108], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7128, 1.7128, 1.4108], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7127, 1.7127, 1.4109], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7126, 1.7126, 1.4109], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7125, 1.7125, 1.4110], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7125, 1.7125, 1.4110], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7124, 1.7124, 1.4110], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7123, 1.7123, 1.4111], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7122, 1.7122, 1.4111], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7121, 1.7121, 1.4111], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7120, 1.7120, 1.4111], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7119, 1.7119, 1.4112], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7118, 1.7118, 1.4112], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7117, 1.7117, 1.4112], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7116, 1.7116, 1.4113], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7115, 1.7115, 1.4113], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7114, 1.7114, 1.4113], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|█████████████████████████████▍                                                | 756/2000 [00:03<00:04, 252.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7113, 1.7113, 1.4114], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7112, 1.7112, 1.4114], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7111, 1.7111, 1.4114], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7110, 1.7110, 1.4115], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7109, 1.7109, 1.4115], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7108, 1.7108, 1.4115], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7107, 1.7107, 1.4115], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7106, 1.7106, 1.4116], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7105, 1.7105, 1.4116], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7104, 1.7104, 1.4116], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7102, 1.7102, 1.4117], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7101, 1.7101, 1.4117], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7100, 1.7100, 1.4117], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7099, 1.7099, 1.4117], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7098, 1.7098, 1.4118], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7097, 1.7097, 1.4118], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7095, 1.7095, 1.4118], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7094, 1.7094, 1.4119], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7093, 1.7093, 1.4119], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7092, 1.7092, 1.4119], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7091, 1.7091, 1.4119], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7089, 1.7089, 1.4120], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7088, 1.7088, 1.4120], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7087, 1.7087, 1.4120], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7085, 1.7085, 1.4120], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7084, 1.7084, 1.4121], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7083, 1.7083, 1.4121], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7082, 1.7082, 1.4121], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7080, 1.7080, 1.4121], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7079, 1.7079, 1.4122], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7077, 1.7077, 1.4122], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7076, 1.7076, 1.4122], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7075, 1.7075, 1.4122], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7073, 1.7073, 1.4123], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7072, 1.7072, 1.4123], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7071, 1.7071, 1.4123], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7069, 1.7069, 1.4123], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7068, 1.7068, 1.4124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7066, 1.7066, 1.4124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7065, 1.7065, 1.4124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7063, 1.7063, 1.4124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7062, 1.7062, 1.4124], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7060, 1.7060, 1.4125], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7059, 1.7059, 1.4125], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7057, 1.7057, 1.4125], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7056, 1.7056, 1.4125], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7054, 1.7054, 1.4126], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7053, 1.7053, 1.4126], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7051, 1.7051, 1.4126], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7049, 1.7049, 1.4126], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7048, 1.7048, 1.4126], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7046, 1.7046, 1.4127], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|██████████████████████████████▍                                               | 782/2000 [00:03<00:04, 250.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.7045, 1.7045, 1.4127], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7043, 1.7043, 1.4127], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7041, 1.7041, 1.4127], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7040, 1.7040, 1.4127], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7038, 1.7038, 1.4128], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7036, 1.7036, 1.4128], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7035, 1.7035, 1.4128], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7033, 1.7033, 1.4128], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7031, 1.7031, 1.4128], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7030, 1.7030, 1.4129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7028, 1.7028, 1.4129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7026, 1.7026, 1.4129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7024, 1.7024, 1.4129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7022, 1.7022, 1.4129], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7021, 1.7021, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7019, 1.7019, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7017, 1.7017, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7015, 1.7015, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7013, 1.7013, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7012, 1.7012, 1.4130], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7010, 1.7010, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7008, 1.7008, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7006, 1.7006, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7004, 1.7004, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7002, 1.7002, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.7000, 1.7000, 1.4131], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6998, 1.6998, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6996, 1.6996, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6994, 1.6994, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6992, 1.6992, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6990, 1.6990, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6988, 1.6988, 1.4132], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6986, 1.6986, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6984, 1.6984, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6982, 1.6982, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6980, 1.6980, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6978, 1.6978, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6976, 1.6976, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6974, 1.6974, 1.4133], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6972, 1.6972, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6970, 1.6970, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6968, 1.6968, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6966, 1.6966, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6964, 1.6964, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6961, 1.6961, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6959, 1.6959, 1.4134], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6957, 1.6957, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6955, 1.6955, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6953, 1.6953, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6950, 1.6950, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6948, 1.6948, 1.4135], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████████████████████████████████▌                                             | 834/2000 [00:03<00:04, 248.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6946, 1.6946, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6944, 1.6944, 1.4135], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6941, 1.6941, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6939, 1.6939, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6937, 1.6937, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6935, 1.6935, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6932, 1.6932, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6930, 1.6930, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6928, 1.6928, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6925, 1.6925, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6923, 1.6923, 1.4136], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6921, 1.6921, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6918, 1.6918, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6916, 1.6916, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6913, 1.6913, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6911, 1.6911, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6908, 1.6908, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6906, 1.6906, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6904, 1.6904, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6901, 1.6901, 1.4137], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6899, 1.6899, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6896, 1.6896, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6894, 1.6894, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6891, 1.6891, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6888, 1.6888, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6886, 1.6886, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6883, 1.6883, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6881, 1.6881, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6878, 1.6878, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6876, 1.6876, 1.4138], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6873, 1.6873, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6870, 1.6870, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6868, 1.6868, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6865, 1.6865, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6862, 1.6862, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6860, 1.6860, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6857, 1.6857, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6854, 1.6854, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6852, 1.6852, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6849, 1.6849, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6846, 1.6846, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6843, 1.6843, 1.4139], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6841, 1.6841, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6838, 1.6838, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6835, 1.6835, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6832, 1.6832, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6829, 1.6829, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6827, 1.6827, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6824, 1.6824, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6821, 1.6821, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6818, 1.6818, 1.4140], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|██████████████████████████████████▌                                           | 885/2000 [00:03<00:04, 248.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6815, 1.6815, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6812, 1.6812, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6809, 1.6809, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6806, 1.6806, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6803, 1.6803, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6801, 1.6801, 1.4140], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6798, 1.6798, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6795, 1.6795, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6792, 1.6792, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6789, 1.6789, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6786, 1.6786, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6783, 1.6783, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6780, 1.6780, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6776, 1.6776, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6773, 1.6773, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6770, 1.6770, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6767, 1.6767, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6764, 1.6764, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6761, 1.6761, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6758, 1.6758, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6755, 1.6755, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6752, 1.6752, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6748, 1.6748, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6745, 1.6745, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6742, 1.6742, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6739, 1.6739, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6736, 1.6736, 1.4141], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6732, 1.6732, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6729, 1.6729, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6726, 1.6726, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6723, 1.6723, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6719, 1.6719, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6716, 1.6716, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6713, 1.6713, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6709, 1.6709, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6706, 1.6706, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6703, 1.6703, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6699, 1.6699, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6696, 1.6696, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6692, 1.6692, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6689, 1.6689, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6686, 1.6686, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6682, 1.6682, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6679, 1.6679, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6675, 1.6675, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6672, 1.6672, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6668, 1.6668, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6665, 1.6665, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6661, 1.6661, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████████████████████████████████████▍                                         | 934/2000 [00:03<00:04, 235.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6658, 1.6658, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6654, 1.6654, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6651, 1.6651, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6647, 1.6647, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6643, 1.6643, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6640, 1.6640, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6636, 1.6636, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6633, 1.6633, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6629, 1.6629, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6625, 1.6625, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6622, 1.6622, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6618, 1.6618, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6614, 1.6614, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|██████████████████████████████████████▍                                       | 985/2000 [00:04<00:04, 240.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|███████████████████████████████████████▊                                     | 1035/2000 [00:04<00:03, 242.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|██████████████████████████████████████████▊                                  | 1111/2000 [00:04<00:03, 246.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|████████████████████████████████████████████▋                                | 1162/2000 [00:04<00:03, 247.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████████████████████████████████████████████▋                              | 1212/2000 [00:04<00:03, 247.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|████████████████████████████████████████████████▋                            | 1263/2000 [00:05<00:02, 247.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████████████████████████████████████████████████▌                          | 1313/2000 [00:05<00:02, 245.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|████████████████████████████████████████████████████▍                        | 1363/2000 [00:05<00:02, 244.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|██████████████████████████████████████████████████████▍                      | 1413/2000 [00:05<00:02, 244.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|████████████████████████████████████████████████████████▎                    | 1463/2000 [00:05<00:02, 244.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████▎                  | 1513/2000 [00:06<00:01, 244.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 77%|███████████████████████████████████████████████████████████▏                 | 1538/2000 [00:06<00:01, 242.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|█████████████████████████████████████████████████████████████▏               | 1588/2000 [00:06<00:01, 242.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|███████████████████████████████████████████████████████████████              | 1639/2000 [00:06<00:01, 243.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|█████████████████████████████████████████████████████████████████            | 1689/2000 [00:06<00:01, 242.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|██████████████████████████████████████████████████████████████████▉          | 1739/2000 [00:07<00:01, 237.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████████████████████████████████████████████████████████████████▋        | 1785/2000 [00:07<00:01, 204.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|██████████████████████████████████████████████████████████████████████▎      | 1827/2000 [00:07<00:00, 198.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|████████████████████████████████████████████████████████████████████████▎    | 1879/2000 [00:07<00:00, 227.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|██████████████████████████████████████████████████████████████████████████▍  | 1935/2000 [00:08<00:00, 251.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████| 2000/2000 [00:08<00:00, 242.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n",
      "tensor([1.6612, 1.6612, 1.4142], device='cuda:0', dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "ansc= experiment(0.01,0.01,0.01,0.1,A,B,D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 362,
   "id": "b3c56a3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.6612, 0.0000, 0.0000],\n",
       "        [0.0000, 1.6612, 0.0000],\n",
       "        [0.0000, 0.0000, 1.4142]], device='cuda:0', dtype=torch.float64)"
      ]
     },
     "execution_count": 362,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Lambda_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "id": "d2acbb5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import cvxpy as cp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "c1f54c2a",
   "metadata": {},
   "outputs": [],
   "source": [
    " def bracket_term2fun(C,CT,theta):\n",
    "          lamb,U=torch.linalg.eig(CT@theta@C)\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          f=np.pad(l, (0, l.shape[0]-u.shape[0]), 'constant')  #padding zeros to reshape size\n",
    "          t = torch.from_numpy(f)       ## Converting numpy array into pytorch tensor\n",
    "          lambda_matrix= torch.diag(t,0).cuda()   ## Making 1D array into diagonal square matrix \n",
    "          return U@lambda_matrix@UT\n",
    " def update(C,theta,alpha_param,beta_param):\n",
    "          global L\n",
    "          ones = csr_matrix(np.ones((3,3)))\n",
    "          ones = convertScipyToTensor(ones).cuda()\n",
    "          ones = ones.to_dense()  \n",
    "          thetaC = theta@C\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          t1 = alpha_param*(C@ones)\n",
    "          bracket_term1 = (thetaC@CT@thetaC)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta)\n",
    "          bracket_term = bracket_term1 - bracket_term2\n",
    "          t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          return t1+t2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "67079295",
   "metadata": {},
   "outputs": [],
   "source": [
    "ttt=update(A,B,0.1,10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "92033699",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 46.4997, -40.4700,  -8.6379],\n",
       "        [-34.8556,  62.6103,   9.7361],\n",
       "        [-40.1891,  81.0733,   8.8863]], device='cuda:0')"
      ]
     },
     "execution_count": 169,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ttt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "fc52f17b",
   "metadata": {},
   "outputs": [],
   "source": [
    "ones = csr_matrix(np.ones((3,3)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 369,
   "id": "0470baae",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = torch.randn(3,3).cuda()\n",
    "B= torch.randn(3,3).cuda()\n",
    "D=  torch.randn(3,3).cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 372,
   "id": "658405b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 2.7703+0.0896j, -1.2379-0.6084j,  2.7563-0.0326j],\n",
       "        [-1.2379-0.6084j, -1.1773-0.0972j, -1.1248+0.3554j],\n",
       "        [ 2.7563-0.0326j, -1.1248+0.3554j,  2.0460+0.0076j]], device='cuda:0')"
      ]
     },
     "execution_count": 372,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "anu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "f406b80c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-0.7743,  0.1154,  1.3749],\n",
       "        [-0.2375,  0.3584, -0.8537],\n",
       "        [-0.2295,  1.4149, -1.4513]])"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "B"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 371,
   "id": "c849142f",
   "metadata": {},
   "outputs": [],
   "source": [
    "anu=bracket_term2fun(A,torch.transpose(A,0,1),B)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "31af5cbd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "l.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "52bfb1f8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "ae6ee61b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 5.8207+0.0000j,  0.0000+0.0000j,  0.0000+0.0000j],\n",
       "        [ 0.0000+0.0000j, -1.0909+0.9081j,  0.0000+0.0000j],\n",
       "        [ 0.0000+0.0000j,  0.0000+0.0000j, -1.0909-0.9081j]])"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.diag(l,0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "28aea8bb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-0.5389-1.7827j, -0.5042+1.8526j,  1.2691-0.1850j],\n",
       "        [-0.5042+1.8526j,  1.5902-0.1390j, -2.0782-1.9672j],\n",
       "        [ 1.2691-0.1850j, -2.0782-1.9672j,  0.5408+1.5923j]])"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "anu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "3725ce0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 5.8207+0.0000j, -1.0909+0.9081j, -1.0909-0.9081j])"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "l"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "caa4c852",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "764fbe00",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 5.8207073+0.j       , -1.0909152+0.9081454j,\n",
       "       -1.0909152-0.9081454j], dtype=complex64)"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "73a47ce7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "3a48c4ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 5.8207+0.0000j, -1.0909+0.9081j, -1.0909-0.9081j])"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 263,
   "id": "2b276a10",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([10])\n",
      "torch.Size([100, 100])\n",
      "torch.Size([100, 10])\n"
     ]
    },
    {
     "ename": "IndexError",
     "evalue": "index 90 is out of bounds for dimension 0 with size 10",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[1;32mIn [263], line 42\u001b[0m\n\u001b[0;32m     39\u001b[0m Lw \u001b[38;5;241m=\u001b[39m Lw_cpu\u001b[38;5;241m.\u001b[39mto(device)\n\u001b[0;32m     41\u001b[0m \u001b[38;5;66;03m# call function on GPU\u001b[39;00m\n\u001b[1;32m---> 42\u001b[0m lambda_ \u001b[38;5;241m=\u001b[39m \u001b[43mlaplacian_lambda_update\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mU\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mLw\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mk\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     44\u001b[0m \u001b[38;5;66;03m# transfer output to CPU and print\u001b[39;00m\n\u001b[0;32m     45\u001b[0m lambda_cpu \u001b[38;5;241m=\u001b[39m lambda_\u001b[38;5;241m.\u001b[39mcpu()\n",
      "Cell \u001b[1;32mIn [263], line 12\u001b[0m, in \u001b[0;36mlaplacian_lambda_update\u001b[1;34m(lb, ub, beta, U, Lw, k)\u001b[0m\n\u001b[0;32m     10\u001b[0m \u001b[38;5;28mprint\u001b[39m(U\u001b[38;5;241m.\u001b[39mshape)\n\u001b[0;32m     11\u001b[0m eps \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1e-9\u001b[39m\n\u001b[1;32m---> 12\u001b[0m condition \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mtensor([(\u001b[43mlambda_\u001b[49m\u001b[43m[\u001b[49m\u001b[43mq\u001b[49m\u001b[43m]\u001b[49m \u001b[38;5;241m-\u001b[39m ub) \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m eps,\n\u001b[0;32m     13\u001b[0m                           (lambda_[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;241m-\u001b[39m lb) \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m-\u001b[39meps,\n\u001b[0;32m     14\u001b[0m                           (lambda_[\u001b[38;5;241m1\u001b[39m:q] \u001b[38;5;241m-\u001b[39m lambda_[\u001b[38;5;241m0\u001b[39m:(q\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)]) \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m-\u001b[39meps])\u001b[38;5;241m.\u001b[39mall()\n\u001b[0;32m     15\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m condition:\n\u001b[0;32m     16\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m lambda_\n",
      "\u001b[1;31mIndexError\u001b[0m: index 90 is out of bounds for dimension 0 with size 10"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def laplacian_lambda_update(lb, ub, beta, U, Lw, k):\n",
    "    q = Lw.size(1) - k\n",
    "    d = torch.diag(U.t() @ Lw @ U)\n",
    "    # unconstrained solution as initial point\n",
    "    lambda_ = 0.5 * (d + torch.sqrt(d.pow(2) + 4 / beta))\n",
    "    print(d.shape)\n",
    "    print(Lw.shape)\n",
    "    print(U.shape)\n",
    "    eps = 1e-9\n",
    "    condition = torch.tensor([(lambda_[q] - ub) <= eps,\n",
    "                              (lambda_[0] - lb) >= -eps,\n",
    "                              (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps]).all()\n",
    "    if condition:\n",
    "        return lambda_\n",
    "    else:\n",
    "        greater_ub = lambda_ > ub\n",
    "        lesser_lb = lambda_ < lb\n",
    "        lambda_[greater_ub] = ub\n",
    "        lambda_[lesser_lb] = lb\n",
    "    condition = torch.tensor([(lambda_[q] - ub) <= eps,\n",
    "                              (lambda_[0] - lb) >= -eps,\n",
    "                              (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps]).all()\n",
    "    if condition:\n",
    "        return lambda_\n",
    "    else:\n",
    "        print(lambda_)\n",
    "        raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "\n",
    "# create sample input matrices on CPU\n",
    "k = 10\n",
    "U_cpu = torch.randn(100, k)\n",
    "Lw_cpu = torch.randn(100, 100)\n",
    "\n",
    "# transfer input matrices to GPU\n",
    "device = torch.device('cuda')\n",
    "U = U_cpu.to(device)\n",
    "Lw = Lw_cpu.to(device)\n",
    "\n",
    "# call function on GPU\n",
    "lambda_ = laplacian_lambda_update(0, 1.5, 0.5, U, Lw, k)\n",
    "\n",
    "# transfer output to CPU and print\n",
    "lambda_cpu = lambda_.cpu()\n",
    "print(lambda_cpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "930fa365",
   "metadata": {},
   "outputs": [],
   "source": [
    "def loss_fn(lambda_matrix):\n",
    "#           obj = -(cp.log_det(lambda_matrix))\n",
    "#           return obj\n",
    "\n",
    "#       def regularizer(bracket_term):\n",
    "#           return cp.square(cp.norm(bracket_term))\n",
    "         \n",
    "\n",
    "#       def objective_fn(lambda_matrix,bracket_term):\n",
    "#           return loss_fn(lambda_matrix) + 0.01/2 * regularizer(bracket_term)\n",
    "# #       constraints = []  \n",
    "# #       beta=0.01\n",
    "# #       problem = cp.Problem(cp.Minimize(objective_fn(lambda_matrix.cpu().numpy(),bracket_term.cpu().numpy())),constraints)\n",
    "# #       result = problem.solve(solver=cp.SCS) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 309,
   "id": "ee668c9f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Complex tensor:\n",
      "tensor([[[-0.3832,  0.1960],\n",
      "         [ 0.3439, -2.5746],\n",
      "         [ 0.9823,  0.7276]],\n",
      "\n",
      "        [[ 1.5499, -0.5122],\n",
      "         [ 0.1271,  0.5082],\n",
      "         [ 0.7633,  0.0393]],\n",
      "\n",
      "        [[-0.3770,  0.2081],\n",
      "         [-1.3294, -0.3335],\n",
      "         [-1.1066, -1.0647]]])\n",
      "Real tensor:\n",
      "tensor([[-0.3832,  0.1960,  0.3439, -2.5746,  0.9823,  0.7276],\n",
      "        [ 1.5499, -0.5122,  0.1271,  0.5082,  0.7633,  0.0393],\n",
      "        [-0.3770,  0.2081, -1.3294, -0.3335, -1.1066, -1.0647]])\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "# create a complex tensor of size 3x3\n",
    "c = torch.randn(3, 3, 2)\n",
    "print(\"Complex tensor:\")\n",
    "print(c)\n",
    "\n",
    "# extract the real and imaginary components of the complex tensor\n",
    "real_part = c[..., 0]\n",
    "imag_part = c[..., 1]\n",
    "\n",
    "# stack the real and imaginary components together to form a real tensor\n",
    "r = torch.stack((real_part, imag_part), dim=-1)\n",
    "r = r.reshape(3, 6)\n",
    "print(\"Real tensor:\")\n",
    "print(r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c3738c5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
