{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "h31guxNsHFMn"
      },
      "source": [
        "## utils "
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "id": "FRs5SnOLC1i5"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "import torch.nn.init as init\n",
        "from torch.autograd import Variable\n",
        "\n",
        "from torchvision import datasets, transforms\n",
        "\n",
        "from sklearn.decomposition import PCA\n",
        "from sklearn.preprocessing import StandardScaler\n",
        "\n",
        "from torchmetrics import Accuracy\n",
        "\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import matplotlib.ticker as mtick\n",
        "\n",
        "import random\n",
        "\n",
        "from PyQ.pyqtorch.core.circuit import QuantumCircuit\n",
        "from PyQ.pyqtorch.core.measurement import total_magnetization , total_magnetization_partial\n",
        "\n",
        "from PyQ.pyqtorch.core.operation import batchedRX, batchedRY, batchedRZ, batchedRZZ, batchedRYY, batchedRXX, hamiltonian_evolution, H, RX\n",
        "\n",
        "from PyQ.pyqtorch.core.utils import _apply_gate, _apply_batch_gate  \n",
        "\n",
        "from itertools import combinations \n",
        "import itertools\n",
        " \n",
        "from PyQ.pyqtorch.ansatz import AlternateLayerAnsatz \n",
        "from PyQ.pyqtorch.matrices_sparse import general_hamiltonian \n",
        "\n",
        "from PyQ.pyqtorch.ansatz import OneLayerRotation \n",
        "\n",
        "\n",
        "from sklearn.metrics import mean_squared_error as mse \n",
        "from sklearn.metrics import accuracy_score\n",
        "\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "4_1u7SORC1i_"
      },
      "outputs": [],
      "source": [
        "def get_circuit_spectrum_int(w_max): #distinct positive integer frequencies\n",
        "    \"\"\"Ham_list: a list of sublists, where sublist_i is the set of eigenvalues of H_i.\n",
        "    Careful with single rotation convention! (divide by 2 the eigenvalues)\"\"\"\n",
        "    #Ham_list = [list(set(v)) for v in eigenvalues]\n",
        "    omega=[]\n",
        "\n",
        "    \n",
        "    for i in range(len(w_max)-1):\n",
        "\n",
        "        x = np.arange(-w_max[i],w_max[i]+1,1)\n",
        "        omega.append(x)\n",
        "\n",
        "    x= np.arange(0,w_max[-1]+1,1)\n",
        "    omega.append(x)\n",
        "    omega=np.meshgrid(*omega)\n",
        "    omega_int=[]\n",
        "    for i in range(len(w_max)):\n",
        "        omega_int.append(omega[i].flatten())\n",
        "\n",
        "    full_spec=np.array(omega_int).T\n",
        "      \n",
        "    hyperplane_indices= np.argwhere(full_spec[:,-1]==0)\n",
        "    hyperplane_indices= hyperplane_indices[:hyperplane_indices.shape[0]//2]\n",
        "    hyperplane_indices = list(set([i for i in range(len(full_spec))]) - set(list(hyperplane_indices.flatten())))\n",
        "\n",
        "    return full_spec[hyperplane_indices]\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "def get_circuit_spectrum_unique_pos(eigenvalues): #unique positive frequencies\n",
        "    \"\"\"Ham_list: a list of sublists, where sublist_i is the set of eigenvalues of H_i.\n",
        "    Careful with single rotation convention! (divide by 2 the eigenvalues)\"\"\"\n",
        "    #Ham_list = [list(set(v)) for v in eigenvalues]\n",
        "    \n",
        "    def get_spectrum_1D_unique(l):  #unique positive and negative frequencies in 1D\n",
        "\n",
        "      all_sums = list(set([sum(e) for e in itertools.product(*l)]))\n",
        "      spectrum = list(set([abs(i[0]-i[1]) for i in itertools.combinations(all_sums, 2)]))\n",
        "      spectrum+= list(-np.array(spectrum))\n",
        "      return np.unique([0] + spectrum)\n",
        "\n",
        "    \n",
        "\n",
        "    spec=[]\n",
        "    w_max=[]\n",
        "    for i in range(len(eigenvalues)):\n",
        "        \n",
        "        spec.append(get_spectrum_1D_unique(eigenvalues[i]))\n",
        "        w_max.append(max(spec[i]))\n",
        "        print(w_max[i])\n",
        "\n",
        "   \n",
        "\n",
        "    spec[-1]=np.unique(np.abs(spec[-1]))\n",
        "\n",
        "\n",
        "    spectrum=np.meshgrid(*spec)\n",
        "    print(len(spectrum))\n",
        "    spec=[]\n",
        "    for i in range(len(spectrum)):\n",
        "        spec.append(spectrum[i].flatten())\n",
        "\n",
        "    full_spec=np.unique(np.array(spec),axis=1).T\n",
        "\n",
        "    hyperplane_indices= np.argwhere(full_spec[:,-1]==0)\n",
        "    hyperplane_indices= hyperplane_indices[:hyperplane_indices.shape[0]//2]\n",
        "    hyperplane_indices = list(set([i for i in range(len(full_spec))]) - set(list(hyperplane_indices.flatten())))\n",
        "\n",
        "    return full_spec[hyperplane_indices]\n",
        "    \n",
        "\n",
        "def gradient_descent(X, y, lr=.01, n_iter=200, reg=0):\n",
        "    w = np.zeros((X.shape[1], 1))\n",
        "    losses = []\n",
        "    for i in range(n_iter):\n",
        "        w -= lr * (np.dot(X.T, np.dot(X, w) - y) + reg * w)\n",
        "        losses.append(np.mean((np.dot(X, w) - y)**2))\n",
        "    return w, losses\n",
        "\n",
        "\n",
        "def sample_from_eigenvalues(eigenvalues, n_samples):\n",
        "    #Ham_list = [list(set(v)) for v in eigenvalues]\n",
        "    def sample(eigenvalues):\n",
        "        s=[]\n",
        "        n=len(eigenvalues)\n",
        "      \n",
        "        for i in range(n):\n",
        "            branch1 = sum([np.random.choice(l) for l in eigenvalues[i]])\n",
        "            \n",
        "            branch2 = sum([np.random.choice(l) for l in eigenvalues[i]])\n",
        "            s.append(branch1 - branch2)\n",
        "        return s\n",
        "    values = []\n",
        "    for _ in range(n_samples):\n",
        "        values.append(sample(eigenvalues))\n",
        "\n",
        "    \n",
        "    return values\n",
        "\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "id": "Fhj1BTa5RHza"
      },
      "outputs": [],
      "source": [
        "IMAT = torch.eye(2, dtype=torch.cdouble)\n",
        "XMAT = torch.tensor([[0, 1], [1, 0]], dtype=torch.cdouble)\n",
        "YMAT = torch.tensor([[0, -1j], [1j, 0]], dtype=torch.cdouble)\n",
        "ZMAT = torch.tensor([[1, 0], [0, -1]], dtype=torch.cdouble)\n",
        "\n",
        "def XX(N, i=0, j=0, device='cpu'):\n",
        "    if i == j:\n",
        "        return torch.ones(2**N).to(device)\n",
        "    op_list = [XMAT.to(device) if k in [i, j]\n",
        "               else IMAT.to(device) for k in range(N)]\n",
        "    operator = op_list[0]\n",
        "    for op in op_list[1::]:\n",
        "        operator = torch.kron(operator, op)\n",
        "    return operator    \n",
        "    \n",
        "def YY(N, i=0, j=0, device='cpu'):\n",
        "    if i == j:\n",
        "        return torch.ones(2**N).to(device)\n",
        "    op_list = [YMAT.to(device) if k in [i, j]\n",
        "               else IMAT.to(device) for k in range(N)]\n",
        "    operator = op_list[0]\n",
        "    for op in op_list[1::]:\n",
        "        operator = torch.kron(operator, op)\n",
        "    return operator\n",
        "    \n",
        "def ZZ(N, i=0, j=0, device='cpu'):\n",
        "    if i == j:\n",
        "        return torch.ones(2**N).to(device)\n",
        "\n",
        "    op_list = [ZMAT.to(device) if k in [i, j]\n",
        "               else IMAT.to(device) for k in range(N)]\n",
        "    operator = op_list[0]\n",
        "    for op in op_list[1::]:\n",
        "        operator = torch.kron(operator, op)\n",
        "\n",
        "    return operator\n",
        "\n",
        "    \n",
        "def general_hamiltonian(alpha, beta, gamma, device='cpu'):\n",
        "    #alpha, beta, gamma: matrices of parameters (e.g. alpha_ij)\n",
        "    #connectivity_graph: which qubits are connected\n",
        "    #no 1 body terms\n",
        "    \n",
        "    N = alpha.shape[0]\n",
        "    # construct the hamiltonian\n",
        "    H = torch.zeros((2**N,2**N), dtype=torch.cdouble).to(device)\n",
        "\n",
        "    for edge in combinations(range(N), 2):\n",
        "        H += alpha[edge[0], edge[1]] * XX(N, edge[0], edge[1], device) #alpha_ij * XX\n",
        "        H += beta[edge[0], edge[1]]  * YY(N, edge[0], edge[1], device) #beta_ij * YY\n",
        "        H += gamma[edge[0], edge[1]] * ZZ(N, edge[0], edge[1], device) #gamma_ij * ZZ\n",
        "\n",
        "    return H"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "dpjKy1HtKu5j"
      },
      "source": [
        "## Quantum model"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "3woU4sIARJvJ",
        "outputId": "3ef833b4-fec7-434c-9f61-79b60c134a46"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "<class 'torch.Tensor'>\n"
          ]
        }
      ],
      "source": [
        "n_qubits = 5\n",
        "d = 5\n",
        "\n",
        "#w_max_VQC= [5]*d\n",
        "\n",
        "hamiltonians = ['X', 'Y', 'Z', 'XX', 'YY', 'ZZ', 'XYZ']\n",
        "nb_ham=len(hamiltonians)\n",
        "# XYZ = X0X1 + Y1Y2 + Z0Z2\n",
        "locality = [1, 1, 1, 2, 2, 2, 3]\n",
        "\n",
        "\n",
        "dimension_multiplicity = np.zeros((nb_ham,d),dtype=\"int32\")#(nb_ham,d)\n",
        "dimension_multiplicity[0]=[5]*d #0:first hamiltonian type in hamiltonians list\n",
        "#dimension_multiplicity[0]=[1,2,4,3,0] #0:first hamiltonian type in hamiltonians list\n",
        "#dimension_multiplicity[6]=[0,0,0,0,1]\n",
        "\n",
        "multiplicity = np.sum(dimension_multiplicity,axis=1)\n",
        "\n",
        "\n",
        "hamiltonian_matrices = dict()\n",
        "\n",
        "IMAT = torch.eye(2, dtype=torch.cdouble)\n",
        "XMAT = torch.tensor([[0, 1], [1, 0]], dtype=torch.cdouble)\n",
        "YMAT = torch.tensor([[0, -1j], [1j, 0]], dtype=torch.cdouble)\n",
        "ZMAT = torch.tensor([[1, 0], [0, -1]], dtype=torch.cdouble)\n",
        "\n",
        "hamiltonian_matrices['XX'] = torch.kron(XMAT, XMAT)\n",
        "hamiltonian_matrices['YY'] = torch.kron(YMAT, YMAT)\n",
        "hamiltonian_matrices['ZZ'] = torch.kron(ZMAT, ZMAT)\n",
        "\n",
        "\n",
        "alpha = np.zeros((3, 3))\n",
        "alpha[0, 1] = 7    #H_XYZ =7 X_0 X_1 + 7 X_1 X_0 + 0.11 X_0 X_2 + 0.1 X_2 X_0 + 8 [ Y_1 Y_2 + Y_2 Y_1 + Z_0 Z_2 + Z_2 Z_0]\n",
        "alpha[1, 0] = 7\n",
        "alpha[0, 2] = 0.11\n",
        "alpha[2, 0] = 0.1\n",
        "\n",
        "beta = np.zeros((3, 3))\n",
        "beta[1, 2] = 8\n",
        "beta[2, 1] = 8\n",
        "\n",
        "gamma = np.zeros((3, 3))\n",
        "gamma[0, 2] = 8\n",
        "gamma[2, 0] = 8\n",
        "\n",
        "\n",
        "Ham = general_hamiltonian(alpha=alpha, beta=beta, gamma=gamma)\n",
        "print(type(Ham))\n",
        "hamiltonian_matrices['XYZ'] = Ham.clone()\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "eigenvalues_list = [[1/2, -1/2] for _ in range(3)] # Eigenvalues of pauli matrices\n",
        "eigenvalues_list += [[1/2, -1/2] for _ in range(3)] # Eigenvalues of XX, YY, ZZ\n",
        "eigenvalues_list.append(list(np.unique(np.round_(torch.linalg.eig(hamiltonian_matrices['XYZ'].real)[0].numpy().real, decimals=8)))) # Eigenvalues of XYZ\n",
        "\n",
        "all_eigenvalues_list = [[eigenvalues_list[i]  for i in range(nb_ham) for _ in range(dimension_multiplicity[i,j])] for j in range(d)]#(d,multiplicity)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "6RAPkDNGROn4"
      },
      "outputs": [],
      "source": [
        "# creating the quantum model \n",
        "\n",
        "np.random.seed(63) #fixed architecture of VQC\n",
        "#list of chosen hamiltonians with respective multiplicity \n",
        "ham_list = np.array([i for j in range(d)  for i in range(nb_ham) for _ in range(dimension_multiplicity[i,j])]) \n",
        "\n",
        "dim_list = np.array([i for i in range(d) for j in range(nb_ham) for _ in range(dimension_multiplicity[j,i])])\n",
        "\n",
        "coeff_list = np.array([1.]*ham_list.shape[0])\n",
        "'''\n",
        "coeff_list[0]=0.248\n",
        "coeff_list[10]=0.848\n",
        "coeff_list[18]=0.571\n",
        "'''\n",
        "\n",
        "\n",
        "\n",
        "locality_list = np.array([locality[i] for j in range(d) for i in range(nb_ham) for _ in range(dimension_multiplicity[i,j])]) #nb of qubits each gate will be applied on\n",
        "\n",
        "\n",
        "shuffle = np.random.permutation(len(ham_list))\n",
        "\n",
        "ham_list = ham_list[shuffle]\n",
        "locality_list = locality_list[shuffle]\n",
        "positions_list = [np.random.choice(n_qubits, size=l, replace=False) for l in locality_list] #on which qubits each gate is applied on \n",
        "dim_list = dim_list[shuffle]\n",
        "coeff_list = coeff_list[shuffle]\n",
        "\n",
        "ansatz_layers = np.random.randint(4,8, size=len(ham_list)) # number of repetitions of the one layer entangling ansatz after each hamiltonian encoding \n",
        "\n",
        "#get eigenvalues and V for each hamiltonian\n",
        "eigenvectors = dict()\n",
        "eigenvalues = dict()\n",
        "for ham in hamiltonians:\n",
        "    \n",
        "    try:\n",
        "        H = hamiltonian_matrices[ham]\n",
        "        Lambda, V = torch.linalg.eig(H)\n",
        "        eigenvectors[ham] = V.clone()\n",
        "        eigenvalues[ham] = Lambda.clone()\n",
        "    except KeyError:\n",
        "        pass\n",
        "\n",
        "#constructing random quantum circuit\n",
        "class Model(QuantumCircuit):\n",
        "\n",
        "    def __init__(self, n_qubits, ham_list, positions, ansatz_layers, dim_list,coeff_list):\n",
        "        super().__init__(n_qubits)\n",
        "        self.ham_list = ham_list\n",
        "        self.positions = positions\n",
        "        self.ansatz = nn.ModuleList([AlternateLayerAnsatz(n_qubits, l) for l in ansatz_layers])\n",
        "        self.dim_list= dim_list\n",
        "        self.coeffs = coeff_list\n",
        "    \n",
        "    def forward(self, x):\n",
        "        #batch_size = np.array(x[0].shape)[0] \n",
        "        batch_size=x.shape[1] #x(d,N)\n",
        "        state = self.uniform_state(batch_size)\n",
        "        for ham, pos, ansatz, d, c in zip( self.ham_list, self.positions, self.ansatz, self.dim_list, self.coeffs):\n",
        "            \n",
        "            #print(\"ham: \",ham)\n",
        "            #print(\"dimension: \",d)\n",
        "            if hamiltonians[ham]=='X':\n",
        "                state = batchedRX(c*x[d], state, pos, self.n_qubits)\n",
        "            elif hamiltonians[ham]=='Y':\n",
        "                state = batchedRY(c*x[d], state, pos, self.n_qubits)\n",
        "            elif hamiltonians[ham]=='Z':\n",
        "                state = batchedRZ(c*x[d], state, pos, self.n_qubits)\n",
        "            elif hamiltonians[ham]=='ZZ':\n",
        "                state = batchedRZZ(c*x[d], state, pos, self.n_qubits)\n",
        "            elif hamiltonians[ham]=='XX':\n",
        "                state = batchedRXX(c*x[d], state, pos, self.n_qubits)\n",
        "            elif hamiltonians[ham]=='YY':\n",
        "                state = batchedRYY(c*x[d], state, pos, self.n_qubits)\n",
        "            else:\n",
        "                \n",
        "                state = hamiltonian_evolution(hamiltonian_matrices[hamiltonians[ham]], state, c*x[d], pos, self.n_qubits, n_steps=20000)\n",
        "                #print(torch.sum(torch.abs(state.reshape((-1, batch_size)))**2, axis=0))\n",
        "                print('done')\n",
        "                # l, v = eigenvalues[hamiltonians[ham]].clone(), eigenvectors[hamiltonians[ham]].clone()\n",
        "                # mask = torch.eye(len(l)).unsqueeze(2).repeat(1, 1, batch_size)\n",
        "                # L = torch.diag(l).unsqueeze(2).repeat(1, 1, batch_size) * x.unsqueeze(0).unsqueeze(0).expand(len(l), len(l), -1)\n",
        "                # L = torch.exp(-x/2 * 1j * L) * mask\n",
        "\n",
        "                # U = torch.matmul(\n",
        "                #         torch.matmul(v, L).permute([2, 0, 1]),\n",
        "                #         torch.conj(v).T).permute([2, 0, 1])\n",
        "                # state = _apply_batch_gate(state, U, pos, self.n_qubits, batch_size)\n",
        "                \n",
        "            \n",
        "            state = ansatz(state)\n",
        "\n",
        "        return total_magnetization(state, self.n_qubits, batch_size) #measurment"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "GzUobMj3C1jM"
      },
      "source": [
        "## Fashion MNIST"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "id": "YWyW0M7SC1jN",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 423,
          "referenced_widgets": [
            "a40ab50ca6294004bc211b0578327a61",
            "e457e0907b0a477dbdd683f76e1779c2",
            "774204388f864a7eb46a015b2cef4de2",
            "82fe16c9783a415387ef28fabd8b06e1",
            "f7b6638219834666874efd944322e036",
            "6d4b7aa143944671aedf505746965bde",
            "f6bc9df0b2eb45f5bf89f7c726f02a2d",
            "23ae50719eec47a4a9843342586e98dd",
            "05845bd3756748bf89a9b61a58e840b3",
            "189a21fb261f405db4cd7440d083916a",
            "71bf95bfcbe445eab52835c1e2767528",
            "28ab3bae4a154d56bfd4da19c134ef42",
            "d7e841575bf946d0898ea02b22768d38",
            "a4bd8c6d50184268960076727ef65805",
            "efc69651089a4c07b0121c18fc5fb78d",
            "209fcac9204e4998b612acb1fc3695e8",
            "694dd2d3d7064b4ca07e2f556c9fa9d4",
            "fa3690fce9974251b28775c52d377118",
            "b7de33a3a89b437c997580a430c4c305",
            "c33af23fe189448282ce0e891bfabbf3",
            "a9cc10a880864a80b2fe5f6839d288ef",
            "cfa5d37a20c0491f9ab7a40b3144457e",
            "8982ebe70d9d4979a21dccc4c61e67ab",
            "420f67fad7104f65bb57b12c96d3a703",
            "5d82679ba8f2462ea687a0e32cc01386",
            "094d8ee6df044d218a6c1604297e6b39",
            "a97f6c8eedcd44d2900061178685a03e",
            "1c3ecd0476bf407885798bb5390e1172",
            "89d0ee6aaeda4c3689a84cc69eb2edef",
            "97d36a2cf6634abc87a830ddc0bd66be",
            "f42982d29e564bffa836de63e4983cd7",
            "3499c7e365f1454881dd2d7a72881678",
            "11e6e65bf750459c80a0eb86c07f9a86",
            "b4e9464208d0465caf05ae87578ce2cb",
            "ab48ab6f05e149119a6894ceca2c78fc",
            "451e067157264345986fbcb955e699c5",
            "67694e3b32894bdeb291c2f9a53d373a",
            "f59653d8ce67477386031cb02ce1ea26",
            "b179ce95ae66423294a4ad6348e1d3ea",
            "180115a17429439d95e1f2654f2548b7",
            "adf0af7761ed47429e81d21dfd761010",
            "45f990da3ea7402b9fc638cbde70503a",
            "23595d0d1ab643f2baec8d7b07f80ec7",
            "82c85b816db64feba14232582e8f14a7"
          ]
        },
        "outputId": "a02f3bdb-43d5-4bb9-e3c4-75e95a4c732e"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/train-images-idx3-ubyte.gz\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/train-images-idx3-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw/train-images-idx3-ubyte.gz\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "  0%|          | 0/26421880 [00:00<?, ?it/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "a40ab50ca6294004bc211b0578327a61"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting /root/.pytorch/F_MNIST_data/FashionMNIST/raw/train-images-idx3-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw\n",
            "\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/train-labels-idx1-ubyte.gz\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/train-labels-idx1-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw/train-labels-idx1-ubyte.gz\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "  0%|          | 0/29515 [00:00<?, ?it/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "28ab3bae4a154d56bfd4da19c134ef42"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting /root/.pytorch/F_MNIST_data/FashionMNIST/raw/train-labels-idx1-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw\n",
            "\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/t10k-images-idx3-ubyte.gz\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/t10k-images-idx3-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw/t10k-images-idx3-ubyte.gz\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "  0%|          | 0/4422102 [00:00<?, ?it/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "8982ebe70d9d4979a21dccc4c61e67ab"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting /root/.pytorch/F_MNIST_data/FashionMNIST/raw/t10k-images-idx3-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw\n",
            "\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/t10k-labels-idx1-ubyte.gz\n",
            "Downloading http://fashion-mnist.s3-website.eu-central-1.amazonaws.com/t10k-labels-idx1-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw/t10k-labels-idx1-ubyte.gz\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "  0%|          | 0/5148 [00:00<?, ?it/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "b4e9464208d0465caf05ae87578ce2cb"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting /root/.pytorch/F_MNIST_data/FashionMNIST/raw/t10k-labels-idx1-ubyte.gz to /root/.pytorch/F_MNIST_data/FashionMNIST/raw\n",
            "\n"
          ]
        }
      ],
      "source": [
        "from torch.utils.data.sampler import  SubsetRandomSampler  #for validation test\n",
        "np.random.seed(42)\n",
        "\n",
        "#Define a transform to convert to images to tensor and normalize\n",
        "transform = transforms.Compose([transforms.ToTensor(),\n",
        "                               ]) #mean and std have to be sequences (e.g., tuples), \n",
        "                                                                      # therefore we should add a comma after the values\n",
        "                          \n",
        "#Load the data: train and test sets\n",
        "trainset = datasets.FashionMNIST('~/.pytorch/F_MNIST_data', download=True, train=True, transform=transform)\n",
        "\n",
        "#selecting two classes\n",
        "idx = (trainset.targets==4) | (trainset.targets==3) \n",
        "trainset.targets = trainset.targets[idx]\n",
        "trainset.data = trainset.data[idx]\n",
        "\n",
        "#Preparing for validaion test\n",
        "indices = list(range(len(trainset)))\n",
        "np.random.shuffle(indices)\n",
        "#to get 20% of the train set\n",
        "split = int(np.floor(0.8 * len(trainset)))\n",
        "train_sample = SubsetRandomSampler(indices[:split])\n",
        "valid_sample = SubsetRandomSampler(indices[split:])\n",
        "\n",
        "#Data Loader\n",
        "trainloader = torch.utils.data.DataLoader(trainset, sampler=train_sample, batch_size=len(train_sample))\n",
        "validloader = torch.utils.data.DataLoader(trainset, sampler=valid_sample, batch_size=len(valid_sample))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "UU6X-UnvC1jP"
      },
      "source": [
        "\n",
        "PCA "
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "id": "gHPOJw_MC1jQ"
      },
      "outputs": [],
      "source": [
        "tensorInputTrain, tensorTargetTrain = next(iter(trainloader))\n",
        "tensorTargetTrain[tensorTargetTrain==3] = 1\n",
        "tensorTargetTrain[tensorTargetTrain==4] = 0\n",
        "\n",
        "\n",
        "#Flatten data\n",
        "numpyInputTrain = tensorInputTrain[:,0].reshape(-1, 784).numpy()\n",
        "\n",
        "#normalize data\n",
        "data_mean= np.mean(numpyInputTrain, axis =0)\n",
        "numpyInputTrain = numpyInputTrain - data_mean"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 12,
      "metadata": {
        "id": "fmoL2qhmC1jQ"
      },
      "outputs": [],
      "source": [
        "tensorInputValid, tensorTargetValid = next(iter(validloader))\n",
        "tensorTargetValid[tensorTargetValid==3] = 1\n",
        "tensorTargetValid[tensorTargetValid==4] = 0\n",
        "\n",
        "#flatten\n",
        "numpyInputValid = tensorInputValid[:,0].reshape(-1, 784).numpy()\n",
        "\n",
        "#normalize\n",
        "numpyInputValid = numpyInputValid - data_mean"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 13,
      "metadata": {
        "id": "6Bv5QtxnC1jR"
      },
      "outputs": [],
      "source": [
        "\n",
        "#truncate\n",
        "d_pca=5\n",
        "pca = PCA(n_components=d_pca)\n",
        "\n",
        "pca_train = pca.fit_transform(numpyInputTrain)\n",
        "pca_valid = pca.transform(numpyInputValid) "
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "max_val=np.maximum(np.max(pca_train, axis=0),np.min(-pca_train, axis=0))\n",
        "X_train_scaled=np.pi*pca_train*1./max_val\n",
        "X_test_scaled=np.pi*pca_valid*1./max_val "
      ],
      "metadata": {
        "id": "NUb-N7-lrJgx"
      },
      "execution_count": 26,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 27,
      "metadata": {
        "id": "m-IwlqdtC1jR"
      },
      "outputs": [],
      "source": [
        "tensor_pca_train= torch.from_numpy(X_train_scaled)\n",
        "tensor_pca_valid = torch.from_numpy(X_test_scaled)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "EuWlfJs4QB8Y"
      },
      "source": [
        "VQC training "
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 31,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "VH2sKC74QD8n",
        "outputId": "e0025eda-9902-4dd1-9069-1268790a7d4c"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 1 |  Loss 0.7388699508828015\n",
            "VQC accuracy score: 0.4541 | test score : 0.4504\n",
            "Epoch 2 |  Loss 0.5457132583624595\n",
            "VQC accuracy score: 0.7855 | test score : 0.7638\n",
            "Epoch 3 |  Loss 0.45559274257919774\n",
            "VQC accuracy score: 0.8759 | test score : 0.8604\n",
            "Epoch 4 |  Loss 0.40702288123634245\n",
            "VQC accuracy score: 0.8932 | test score : 0.8783\n",
            "Epoch 5 |  Loss 0.37731173745598123\n",
            "VQC accuracy score: 0.9040 | test score : 0.8825\n",
            "Epoch 6 |  Loss 0.3554469894655647\n",
            "VQC accuracy score: 0.9102 | test score : 0.8892\n",
            "Epoch 7 |  Loss 0.335974534253113\n",
            "VQC accuracy score: 0.9135 | test score : 0.8950\n",
            "Epoch 8 |  Loss 0.3176757875146016\n",
            "VQC accuracy score: 0.9170 | test score : 0.9033\n",
            "Epoch 9 |  Loss 0.300994659317671\n",
            "VQC accuracy score: 0.9214 | test score : 0.9087\n",
            "Epoch 10 |  Loss 0.28658190390828386\n",
            "VQC accuracy score: 0.9240 | test score : 0.9129\n",
            "Epoch 11 |  Loss 0.2746099744820766\n",
            "VQC accuracy score: 0.9277 | test score : 0.9150\n",
            "Epoch 12 |  Loss 0.2645213624509365\n",
            "VQC accuracy score: 0.9300 | test score : 0.9133\n",
            "Epoch 13 |  Loss 0.255511610482224\n",
            "VQC accuracy score: 0.9305 | test score : 0.9171\n",
            "Epoch 14 |  Loss 0.24714127556867477\n",
            "VQC accuracy score: 0.9318 | test score : 0.9154\n",
            "Epoch 15 |  Loss 0.2393907111609664\n",
            "VQC accuracy score: 0.9335 | test score : 0.9154\n",
            "Epoch 16 |  Loss 0.23233806652485678\n",
            "VQC accuracy score: 0.9334 | test score : 0.9154\n",
            "Epoch 17 |  Loss 0.22595010976688656\n",
            "VQC accuracy score: 0.9336 | test score : 0.9154\n",
            "Epoch 18 |  Loss 0.22014789702932097\n",
            "VQC accuracy score: 0.9336 | test score : 0.9171\n",
            "Epoch 19 |  Loss 0.21492956312959763\n",
            "VQC accuracy score: 0.9345 | test score : 0.9175\n",
            "Epoch 20 |  Loss 0.21031877113691305\n",
            "VQC accuracy score: 0.9350 | test score : 0.9192\n",
            "Epoch 21 |  Loss 0.20622902742119378\n",
            "VQC accuracy score: 0.9354 | test score : 0.9192\n",
            "Epoch 22 |  Loss 0.20248674189391708\n",
            "VQC accuracy score: 0.9356 | test score : 0.9208\n",
            "Epoch 23 |  Loss 0.19899115449156043\n",
            "VQC accuracy score: 0.9357 | test score : 0.9217\n",
            "Epoch 24 |  Loss 0.1957547771767325\n",
            "VQC accuracy score: 0.9365 | test score : 0.9225\n",
            "Epoch 25 |  Loss 0.19279427656362358\n",
            "VQC accuracy score: 0.9365 | test score : 0.9225\n",
            "Epoch 26 |  Loss 0.19006712956639357\n",
            "VQC accuracy score: 0.9371 | test score : 0.9208\n",
            "Epoch 27 |  Loss 0.1875171650844763\n",
            "VQC accuracy score: 0.9381 | test score : 0.9217\n",
            "Epoch 28 |  Loss 0.1851212739564914\n",
            "VQC accuracy score: 0.9383 | test score : 0.9221\n",
            "Epoch 29 |  Loss 0.18287412871097794\n",
            "VQC accuracy score: 0.9379 | test score : 0.9225\n",
            "Epoch 30 |  Loss 0.18076317069116812\n",
            "VQC accuracy score: 0.9384 | test score : 0.9233\n",
            "Epoch 31 |  Loss 0.17877428455365782\n",
            "VQC accuracy score: 0.9388 | test score : 0.9246\n",
            "Epoch 32 |  Loss 0.17690762406720847\n",
            "VQC accuracy score: 0.9391 | test score : 0.9242\n",
            "Epoch 33 |  Loss 0.17517159222911485\n",
            "VQC accuracy score: 0.9392 | test score : 0.9229\n",
            "Epoch 34 |  Loss 0.17357626734941062\n",
            "VQC accuracy score: 0.9394 | test score : 0.9221\n",
            "Epoch 35 |  Loss 0.17211657062907396\n",
            "VQC accuracy score: 0.9396 | test score : 0.9225\n",
            "Epoch 36 |  Loss 0.1707724217068379\n",
            "VQC accuracy score: 0.9394 | test score : 0.9225\n",
            "Epoch 37 |  Loss 0.1695232597885062\n",
            "VQC accuracy score: 0.9398 | test score : 0.9221\n",
            "Epoch 38 |  Loss 0.16836588328362842\n",
            "VQC accuracy score: 0.9399 | test score : 0.9233\n",
            "Epoch 39 |  Loss 0.16730032997674743\n",
            "VQC accuracy score: 0.9400 | test score : 0.9237\n",
            "Epoch 40 |  Loss 0.16631361448633905\n",
            "VQC accuracy score: 0.9402 | test score : 0.9242\n",
            "Epoch 41 |  Loss 0.16538140997270717\n",
            "VQC accuracy score: 0.9407 | test score : 0.9242\n",
            "Epoch 42 |  Loss 0.1644902482876773\n",
            "VQC accuracy score: 0.9405 | test score : 0.9237\n",
            "Epoch 43 |  Loss 0.16364427446557214\n",
            "VQC accuracy score: 0.9406 | test score : 0.9237\n",
            "Epoch 44 |  Loss 0.1628510329546386\n",
            "VQC accuracy score: 0.9407 | test score : 0.9233\n",
            "Epoch 45 |  Loss 0.1621092018189691\n",
            "VQC accuracy score: 0.9408 | test score : 0.9229\n",
            "Epoch 46 |  Loss 0.1614097733453413\n",
            "VQC accuracy score: 0.9411 | test score : 0.9229\n",
            "Epoch 47 |  Loss 0.16074485657066687\n",
            "VQC accuracy score: 0.9413 | test score : 0.9233\n",
            "Epoch 48 |  Loss 0.16011339737770983\n",
            "VQC accuracy score: 0.9413 | test score : 0.9233\n",
            "Epoch 49 |  Loss 0.15951804029291589\n",
            "VQC accuracy score: 0.9413 | test score : 0.9242\n",
            "Epoch 50 |  Loss 0.1589554174132866\n",
            "VQC accuracy score: 0.9417 | test score : 0.9246\n",
            "Epoch 51 |  Loss 0.15841950660998225\n",
            "VQC accuracy score: 0.9420 | test score : 0.9242\n",
            "Epoch 52 |  Loss 0.15790602407223348\n",
            "VQC accuracy score: 0.9418 | test score : 0.9237\n",
            "Epoch 53 |  Loss 0.1574169335665384\n",
            "VQC accuracy score: 0.9421 | test score : 0.9237\n",
            "Epoch 54 |  Loss 0.15695155548363043\n",
            "VQC accuracy score: 0.9421 | test score : 0.9237\n",
            "Epoch 55 |  Loss 0.1565045117242805\n",
            "VQC accuracy score: 0.9420 | test score : 0.9233\n",
            "Epoch 56 |  Loss 0.15607168378886485\n",
            "VQC accuracy score: 0.9419 | test score : 0.9233\n",
            "Epoch 57 |  Loss 0.1556538845569817\n",
            "VQC accuracy score: 0.9421 | test score : 0.9229\n",
            "Epoch 58 |  Loss 0.15525368061193576\n",
            "VQC accuracy score: 0.9422 | test score : 0.9233\n",
            "Epoch 59 |  Loss 0.15487131291280773\n",
            "VQC accuracy score: 0.9422 | test score : 0.9233\n",
            "Epoch 60 |  Loss 0.1545044211769284\n",
            "VQC accuracy score: 0.9420 | test score : 0.9233\n"
          ]
        }
      ],
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "model = Model(n_qubits, ham_list, positions_list, ansatz_layers,dim_list,coeff_list)\n",
        "\n",
        "\n",
        "optimizer = torch.optim.Adam(model.parameters(), lr=.01)\n",
        "criterion = nn.BCEWithLogitsLoss()\n",
        "m = nn.Sigmoid()\n",
        "accuracy = Accuracy()\n",
        "epochs = 60\n",
        "\n",
        "train_acc=[]\n",
        "test_acc=[]\n",
        "for epoch in range(epochs):\n",
        "      epoch_acc=0\n",
        "      epoch_test_acc=0\n",
        "      optimizer.zero_grad()\n",
        "      y_pred = model(tensor_pca_train.T) \n",
        "      y_pred_test = model(tensor_pca_valid.T)\n",
        "\n",
        "          \n",
        "      loss= criterion(y_pred,tensorTargetTrain.double())\n",
        "      loss_test = criterion(y_pred_test,tensorTargetValid.double())\n",
        "\n",
        "      \n",
        "      epoch_acc = accuracy(m(y_pred),tensorTargetTrain)\n",
        "      epoch_test_acc = accuracy(m(y_pred_test),tensorTargetValid)\n",
        "\n",
        "      \n",
        "      loss.backward()\n",
        "      optimizer.step()\n",
        "    \n",
        "      \n",
        "      print(f\"Epoch {epoch+1} |  Loss {loss}\")\n",
        "      train_acc.append(epoch_acc)\n",
        "      test_acc.append(epoch_test_acc)\n",
        "      print('VQC accuracy score: {0:0.4f} | test score : {1:0.4f}'. format(epoch_acc,epoch_test_acc))\n",
        "      \n",
        "\n",
        "\n",
        "    "
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 32,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 306
        },
        "id": "7mNjyw2Jfo1S",
        "outputId": "bca23db7-1ba9-4e14-d87b-b8162ba2afbe"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7fd1868d2f50>"
            ]
          },
          "metadata": {},
          "execution_count": 32
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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vfivpKSE7du3069fP/x+P6LddVUbMsYQCATYvHkzgCYPlRLSoqoqHDZkSSVhb93EsWPHDvr160dWVpYmDdXmRISsrCz69evHjh072jscpRKSHonDgJ/KuONUBYNB/H5t+1Dty+/3a1WpShlpkTiMMWRRidQzTpWeaaj2pn+DKpWkReIIh8N4JFxv4lBKKZW4NEkcIQBcmXrbWKWUaq60SBwmbO/11Bnv/icijT7efPPNJn32N998g4jwwgsvNL6wUiptpEd3XGPPONy+znfGsXz58sjrQCDA2LFjmT17NmeccUZk+vDhCd1dt44+fZdl21IAABzOSURBVPqwfPlyhg4d2vjCSqm0kR6Jwznj8HTCxDF69OjI69JSe1/1Aw44oNb0aKFQiFAoREZGRqOfnZmZWe/ndDaBQEB71ymVoLSoqsLYxJHh73xVVY2ZPHkyo0aN4rnnnmPEiBH4fD4++OADtm7dytSpUxk8eDB+v5+DDz6Y2bNnU1VVFVk3XlXVwIED+eUvf8mdd95JQUEB+fn5XHjhhezevbvBOFatWsWFF15I//79ycrKYsSIEdx1112Ew7VvGV9UVMRll11Gnz598Pl8DBkyhLvuuisyPxQK8bvf/Y6DDz6YzMxMCgoKmDx5cp34oi1evBgRiSTWN998ExFh6dKlnHXWWeTk5HDllVcCcPvtt3PUUUeRl5dH7969mThxIuvWratTnmeffZajjz4av99P9+7dOf3009mwYQMrV66MWz1YWlpKTk4Od999d4Pfk1KpIE3OOGxVVUYnPONIxDfffMOsWbOYO3cu++23H4MGDaKwsJBu3bpxxx13kJ+fz5o1a5g/fz47d+7kgQceaPDznnjiCQ499FAWLVrEpk2b+MUvfsGvfvUr7rvvvnrX2bx5M0OGDOGiiy6iS5cufPbZZ8ybN49AIMD1118P2KP+MWPGsGPHDubNm8fQoUNZt25drR33ZZddxpIlS5g1axYnn3wyu3bt4umnn27S9zJt2jSmTJnCNddcg89nh9zftGkTV155JQMGDKCkpIT777+f4447jrVr15KXlwfAI488wiWXXMKFF17InDlzMMawbNkydu7cyahRoxg9ejSLFy9mzJgxkW09+eSTBINBLr744ibFqlRHkhaJo+aMIzOrS0KL//qfK1i5paTxBVvB8L65zJs4okU/s6ioiNdff53DDz88Mq2goIA//OEPkffHH3882dnZTJ06lXvvvbfBqiyv18tzzz2Hx2P/fFauXMnjjz/eYOIYN24c48aNA+x1NSeccALl5eU8+OCDkcSxZMkSVqxYwSeffBKJdezYfTeLXLVqFX/+85+5++67ufrqqyPTL7jggmS+jojzzjuPm266qda0O++8M/I6FAoxfvx4evXqxfPPP88ll1xCOBzmuuuu4+yzz+Zvf/tbZNmzzjor8nratGlcc801LFiwgJwce7Dy0EMPMXHiRLp3796kWJXqSNKsqio9zzj69etXK2mA3XnfddddDB8+HL/fj9fr5aKLLqKyspKNGzc2+HmnnHJKJGmAbXxvbJDIiooK5s2bx4EHHkhmZiZer5cbbriB9evXU11dDcCyZcs44ogj6sRa41//+hdAraqp5ojuQFDj/fffZ/z48XTv3h2Px0NWVhalpaWsWbMGgNWrV7NlyxamTJlS7+fWJLInn3wSgK+++op33nmnwXWUSiXpccbh1KNLRmJtHC19xN/eevfuXWfaXXfdxcyZM7n22ms5+eSTyc/P58MPP+SKK66goqKiwc/r2rVrrfcZGRkYY6isrMTr9cZd59prr+VPf/oT8+bN48gjj6Rr1648//zz/OY3v6GiooKcnByKioro06dPvdstKioiOzu7xQYCjP1eNm7cyKmnnsrRRx/NAw88QN++fcnIyOCMM86IfCdFRUUADcbZpUsXzj//fB566CGmTJnC4sWL2W+//TjttNNaJG6l2ltaJA7jnHGQpleOxxvO4sknn+Tcc8/lt7/9bWTaypUrWy2GJ598kquuuopZs2ZFpr344ou1lunevXvchujo+WVlZZSUlNSbPHw+X60GfoDi4uK4y8Z+L6+88grl5eU8//zzZGfbg4zq6mp27dpVKwaArVu31hsnwKWXXsoJJ5zA2rVrWbJkCZdccglut7vBdZRKFWlRVSU1iSPO6LjpKhAIkJmZWWvaX//61zbbXigU4vHHH6+1zLhx4/j000/5/PPP435GTXvHkiVL6t1OQUEBX375Za1pr776asIxulyuWtVwTzzxRKQqDWDIkCH069ePhx9+uMHPOu644xgyZAhTp05l48aNLVa9plRHkBZnHJgwlWSQ6dIjvhrjx4/nnnvu4ZhjjuGAAw7gr3/9a4NH+y2xvYULF3LggQfSrVs3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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "font = {'size'   : 15}\n",
        "plt.rc('font', **font)\n",
        "\n",
        "plt.plot([i for i in range(0,epochs,1)],train_acc, label='Train accuracy')\n",
        "plt.plot([i for i in range(0,epochs,1)],test_acc, label='Test accuracy')\n",
        "\n",
        "\n",
        "plt.xlim(0)\n",
        "#plt.xlabel(\"nb samples D\")\n",
        "plt.xlabel(\"Epochs\")\n",
        "plt.ylabel(\"Accuracy\") \n",
        "\n",
        "plt.legend()\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ZPuGPzlgC1jU"
      },
      "source": [
        "SVM classifier"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 28,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "acicdK_wC1jU",
        "outputId": "ef88fc1d-58a1-4796-9a53-4497248e86a6"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Model accuracy score with default hyperparameters: 0.9398\n",
            "Model accuracy score with default hyperparameters: 0.9242\n"
          ]
        }
      ],
      "source": [
        "from sklearn.svm import SVC\n",
        "from sklearn.metrics import accuracy_score\n",
        "\n",
        "# instantiate classifier with default hyperparameters\n",
        "svc=SVC() \n",
        "\n",
        "\n",
        "# fit classifier to training set\n",
        "svc.fit(X_train_scaled,tensorTargetTrain.numpy())\n",
        "\n",
        "\n",
        "# make predictions on test set\n",
        "y_pred_train=svc.predict(X_train_scaled)\n",
        "y_pred_test=svc.predict(X_test_scaled) \n",
        "\n",
        "print('Model accuracy score with default hyperparameters: {0:0.4f}'. format(accuracy_score(tensorTargetTrain.numpy(), y_pred_train)))\n",
        "print('Model accuracy score with default hyperparameters: {0:0.4f}'. format(accuracy_score(tensorTargetValid.numpy(), y_pred_test)))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "pI8o4gGtC1jU"
      },
      "source": [
        "RFF tree sampling fitting"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#seed\n",
        "nb_seeds=10\n",
        "seeds=np.arange(0,nb_seeds,1)\n",
        "\n",
        "\n",
        "#reg \n",
        "l0 = 1e-8\n",
        "l = 100 * l0\n",
        "L_gate_per_feature = 5\n",
        "d=5\n",
        "N=len(train_sample)\n",
        "\n",
        "#train data\n",
        "data_target = np.array(tensorTargetTrain).reshape((-1,1)) #(N,1)\n",
        "data_target_test = np.array(tensorTargetValid).reshape((-1,1)) #(N,1)\n",
        "#X = [np.array(x) for x in X]\n",
        "data_points = X_train_scaled #(N,d)\n",
        "test =  X_test_scaled\n",
        "\n",
        "\n",
        "\n",
        "#freq_theoretical_VQC\n",
        "\n",
        "s=400\n",
        "sample_size=list(np.arange(0,s+1,10))\n",
        "sample_size[0]=1\n",
        "if sample_size[-1]!=s:\n",
        "    sample_size.append(s) \n",
        "\n",
        "\n",
        "\n",
        "#RFF training\n",
        "train_losses={k: [] for k in seeds}\n",
        "test_losses={k: [] for k in seeds}\n",
        "accuracy_train=[0]*len(sample_size)\n",
        "accuracy_test=[0]*len(sample_size)\n",
        "\n",
        "comp=-1\n",
        "for p_new in sample_size:\n",
        "    comp+=1\n",
        "    for seed in seeds:\n",
        "        #np.random.seed(seed) \n",
        "\n",
        "        \n",
        "        freq_samples= np.array(sample_from_eigenvalues(all_eigenvalues_list, p_new)).reshape((d,p_new)) #(d,p)\n",
        "        freq_samples = np.unique(freq_samples, axis=1)\n",
        "        p = freq_samples.shape[1]\n",
        "        \n",
        "        #RFF\n",
        "        dot_prod = np.matmul(data_points, freq_samples)\n",
        "        fourier_features = np.concatenate([np.cos(dot_prod), np.sin(dot_prod)], axis=1)/ np.sqrt(p) #(d,2p)\n",
        "\n",
        "        dot_prod_test = np.dot(test, freq_samples)\n",
        "        fourier_features_test = np.concatenate([np.cos(dot_prod_test), np.sin(dot_prod_test)], axis=1)/ np.sqrt(p) #(N,2p)\n",
        "\n",
        "\n",
        "        \n",
        "        criterion = nn.BCEWithLogitsLoss()\n",
        "        model=nn.Linear(2*p,1)\n",
        "        optimizer = torch.optim.Adam(model.parameters(), lr=.05)\n",
        "        m = nn.Sigmoid()\n",
        "        accuracy = Accuracy()\n",
        "\n",
        "        epoch_acc=0\n",
        "        epoch_test_acc=0\n",
        "        fourier_features= Variable(torch.from_numpy(fourier_features.astype('float32')))\n",
        "        fourier_features_test =  Variable(torch.from_numpy(fourier_features_test.astype('float32')))\n",
        "        epochs=2000\n",
        "        loss_test_stopping=[]\n",
        "        test_acc_single=[]\n",
        "        train_acc_single=[]\n",
        "        for epoch in range(epochs):\n",
        "              \n",
        "              optimizer.zero_grad()\n",
        "              y_pred = model(fourier_features)\n",
        "              y_pred_test = model(fourier_features_test)\n",
        "\n",
        "                  \n",
        "              loss= criterion(y_pred.double(),tensorTargetTrain.reshape((-1,1)).double())\n",
        "              loss_test = criterion(y_pred_test.double(),tensorTargetValid.reshape((-1,1)).double())\n",
        "\n",
        "              epoch_acc = accuracy(m(y_pred).reshape((-1,1)),tensorTargetTrain.reshape((-1,1)))\n",
        "              epoch_test_acc = accuracy(m(y_pred_test).reshape((-1,1)),tensorTargetValid.reshape((-1,1)))\n",
        "\n",
        "              test_acc_single.append(epoch_test_acc)\n",
        "              train_acc_single.append(epoch_acc)\n",
        "\n",
        "              #print('nb samples :{} | train acc: {} | test acc: {} | epoch {}'.format(p,epoch_acc,epoch_test_acc,epoch))\n",
        "              \n",
        "              \n",
        "              loss_test_stopping.append(loss_test.detach().numpy())\n",
        "              if epoch>200:\n",
        "                if ((loss_test_stopping[-1]>loss_test_stopping[-2]) & (loss_test_stopping[-2]>loss_test_stopping[-3])):\n",
        "                   epoch_acc = train_acc_single[-2]\n",
        "                   epoch_test_acc = test_acc_single[-2]\n",
        "                   break\n",
        "              \n",
        "              loss.backward()\n",
        "              optimizer.step()\n",
        "\n",
        "\n",
        "        accuracy_train[comp]+=epoch_acc/nb_seeds\n",
        "        accuracy_test[comp]+=epoch_test_acc/nb_seeds\n",
        "\n",
        "        train_losses[seed].append(epoch_acc)\n",
        "        test_losses[seed].append(epoch_test_acc)\n",
        "        \n",
        "    print('nb samples :{} | train acc: {} | test acc: {} | epoch {}'.format(p,accuracy_train[comp],accuracy_test[comp],epoch))\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "-mE1Seb9KSBN",
        "outputId": "260aadd3-4161-49d7-f5ec-91fdb5693199"
      },
      "execution_count": 36,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "nb samples :1 | train acc: 0.566572904586792 | test acc: 0.5605832934379578 | epoch 207\n",
            "nb samples :10 | train acc: 0.7169896364212036 | test acc: 0.7207916975021362 | epoch 203\n",
            "nb samples :19 | train acc: 0.7724166512489319 | test acc: 0.765083372592926 | epoch 201\n",
            "nb samples :30 | train acc: 0.85484379529953 | test acc: 0.8449583649635315 | epoch 1229\n",
            "nb samples :40 | train acc: 0.8816457986831665 | test acc: 0.8658333420753479 | epoch 1435\n",
            "nb samples :50 | train acc: 0.8819687366485596 | test acc: 0.8645416498184204 | epoch 437\n",
            "nb samples :60 | train acc: 0.9099999666213989 | test acc: 0.8946666717529297 | epoch 582\n",
            "nb samples :69 | train acc: 0.9225520491600037 | test acc: 0.9053750038146973 | epoch 1999\n",
            "nb samples :79 | train acc: 0.9211145639419556 | test acc: 0.9029583930969238 | epoch 1999\n",
            "nb samples :89 | train acc: 0.9307916164398193 | test acc: 0.9113749861717224 | epoch 1999\n",
            "nb samples :98 | train acc: 0.9362916946411133 | test acc: 0.9184166193008423 | epoch 777\n",
            "nb samples :107 | train acc: 0.9333645701408386 | test acc: 0.9147500395774841 | epoch 1999\n",
            "nb samples :118 | train acc: 0.938364565372467 | test acc: 0.9178749322891235 | epoch 1999\n",
            "nb samples :128 | train acc: 0.9384375214576721 | test acc: 0.9203749299049377 | epoch 1777\n",
            "nb samples :137 | train acc: 0.9393750429153442 | test acc: 0.9217500686645508 | epoch 1999\n",
            "nb samples :149 | train acc: 0.9415000081062317 | test acc: 0.9234583377838135 | epoch 1999\n",
            "nb samples :160 | train acc: 0.9422708749771118 | test acc: 0.9226667284965515 | epoch 1389\n",
            "nb samples :169 | train acc: 0.9425937533378601 | test acc: 0.9237499833106995 | epoch 716\n",
            "nb samples :176 | train acc: 0.9432291388511658 | test acc: 0.9227083325386047 | epoch 1897\n",
            "nb samples :187 | train acc: 0.9434896111488342 | test acc: 0.922374963760376 | epoch 727\n",
            "nb samples :196 | train acc: 0.9442812204360962 | test acc: 0.924583375453949 | epoch 1180\n",
            "nb samples :207 | train acc: 0.9443957805633545 | test acc: 0.921958327293396 | epoch 1195\n",
            "nb samples :217 | train acc: 0.9449478387832642 | test acc: 0.9240416288375854 | epoch 1899\n",
            "nb samples :223 | train acc: 0.9442916512489319 | test acc: 0.9222500324249268 | epoch 599\n",
            "nb samples :234 | train acc: 0.9439479112625122 | test acc: 0.9209166765213013 | epoch 621\n",
            "nb samples :248 | train acc: 0.9457499980926514 | test acc: 0.9219999313354492 | epoch 816\n",
            "nb samples :255 | train acc: 0.9453125 | test acc: 0.92249995470047 | epoch 482\n",
            "nb samples :269 | train acc: 0.9469895958900452 | test acc: 0.9243332743644714 | epoch 589\n",
            "nb samples :274 | train acc: 0.9458749890327454 | test acc: 0.9217916131019592 | epoch 695\n",
            "nb samples :285 | train acc: 0.9470104575157166 | test acc: 0.9227083325386047 | epoch 630\n",
            "nb samples :294 | train acc: 0.9458437561988831 | test acc: 0.9218333959579468 | epoch 562\n",
            "nb samples :299 | train acc: 0.9464375376701355 | test acc: 0.9213333129882812 | epoch 450\n",
            "nb samples :310 | train acc: 0.9459688067436218 | test acc: 0.9223333597183228 | epoch 368\n",
            "nb samples :323 | train acc: 0.9461145401000977 | test acc: 0.9221665859222412 | epoch 572\n",
            "nb samples :332 | train acc: 0.9462917447090149 | test acc: 0.9232083559036255 | epoch 427\n",
            "nb samples :343 | train acc: 0.9455417394638062 | test acc: 0.9201250076293945 | epoch 309\n",
            "nb samples :350 | train acc: 0.9465728998184204 | test acc: 0.9218333959579468 | epoch 330\n",
            "nb samples :361 | train acc: 0.9459375143051147 | test acc: 0.9225000143051147 | epoch 276\n",
            "nb samples :369 | train acc: 0.9471041560173035 | test acc: 0.9209166765213013 | epoch 278\n",
            "nb samples :375 | train acc: 0.9472708106040955 | test acc: 0.9245832562446594 | epoch 226\n",
            "nb samples :385 | train acc: 0.9470311999320984 | test acc: 0.922874927520752 | epoch 460\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "error2=np.array([train_losses[i] for i in train_losses.keys()])\n",
        "mean_error2 = np.mean(error2, axis=0)\n",
        "std_error2 = np.std(error2, axis=0)\n",
        "\n",
        "error_test2=np.array([test_losses[i] for i in test_losses.keys()])\n",
        "mean_error2_test = np.mean(error_test2, axis=0)\n",
        "std_error2_test = np.std(error_test2, axis=0)"
      ],
      "metadata": {
        "id": "nj3kUUAOUDBw"
      },
      "execution_count": 37,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "font = {'size'   : 18}\n",
        "p_omega = (11**5-1)/2+1\n",
        "plt.rc('font', **font)\n",
        "plt.figure(figsize=(10,6))\n",
        "plt.plot(np.array(sample_size)/p_omega,mean_error2,linestyle='dashed', marker='s',label='Train accuracy')\n",
        "plt.fill_between(np.array(sample_size)/p_omega, mean_error2-std_error2, mean_error2+std_error2, alpha=.2, linewidth=0) \n",
        "\n",
        "plt.plot(np.array(sample_size)/p_omega,mean_error2_test,linestyle='dashed', marker='s',label='Test accuracy')\n",
        "plt.fill_between(np.array(sample_size)/p_omega, mean_error2_test-std_error2_test, mean_error2_test+std_error2_test, alpha=.2, linewidth=0) \n",
        "\n",
        "plt.hlines(train_acc[-1],xmin=0,xmax=np.array(sample_size)[-1]/p_omega,linestyle='dashed',label=\"VQC train accuracy\",color='blue')\n",
        "plt.hlines(test_acc[-1],xmin=0,xmax=np.array(sample_size)[-1]/p_omega,linestyle='dashed',label=\"VQC test accuracy\",color='red')\n",
        "\n",
        "\n",
        "plt.xlim(0)\n",
        "#plt.xlabel(\"nb samples D\")\n",
        "plt.xlabel(\"Number of sampled frequencies (fraction of |\\u03A9|)\")\n",
        "plt.ylabel(\"Accuracy \") \n",
        "\n",
        "\n",
        "plt.legend()\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 421
        },
        "id": "edLoM4cBnGy8",
        "outputId": "5d284735-c77c-4db7-fc68-dd33962340ef"
      },
      "execution_count": 38,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7fd1868ceed0>"
            ]
          },
          "metadata": {},
          "execution_count": 38
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 720x432 with 1 Axes>"
            ],
            "image/png": "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gLfffpvPPvuMr776iq1bja98Lngf+XvqbAkPD+fatWssX74cgMjISJycnAgNDS3yWCGEEGWD9OAVcDY9hyO6No6+lv/o3oktUnzcDVYXVPi4G6yULv1WrFhB3bp1+eKLL8yGLfOCkn/Chg0bSEtL49NPP6Vbt25mecnJyTg5OZm+b9SoEQC//PILQUFBhZ4zf7m8r63x8vIC4MKFCxZ5x48fL/5NYHyWzs7ObNu2zSwIjIuLs1q/L774gv379xc5zNq2bVtatWpFZGQkI0aMYN26dfTt29dUdyGEEGVfifbgKaXslFLPK6XilFJXlFJ/KaXmKKWKvYxPKeWllHpTKfVH7jkSlVLblFL3F320pYupF3jS/lv87S2HEu/Ea8p+fOkh4l/rZfH58aWHbvu1/gn29vYopcx62a5fv2420f+fqANY9vR9+OGHJCQkmKUFBQXh4+PDnDlzOHv2rMW58s4RHByMwWBg+vTpXLp0qdBy9erVw8HBga+//tos/4cffmD37t03fB9KKbOeOq21xWIMMM6tA5gyZQpZWZb/YSj4LEaNGsXhw4d57rnnuHLliiyuEEKIcqake/DmAmOBDcAcoEnu962UUg9qrW2OpSml/IHtgDsQCRwBPIHmgOWM+WJwSDnOa46LOZHTgCzM39ZQnjc5vl2Cg4N58cUX6dGjB48//jiXLl1i9erVZqtq77QePXrg6upKaGgozz77LFWqVOH7779ny5YtBAQEmA2Vurq6EhkZSXBwMIGBgaZtUhITE4mJieGFF16gT58+1KpVi3nz5vHMM8/QrFkzwsLC8Pf35/Tp02zatIklS5bQsmVL3N3dGTp0KIsXL2bAgAF07dqVo0ePEhUVRfPmzdm/f3+x7yM4OJh169bRvXt3wsLCuHbtGhs3brTYTxCgXbt2TJ48mddff53WrVsTEhJC9erV+fPPP1m7di179+41m+c3aNAgJk2axMqVK6lXrx4PPPDArT10IYQQpUqJBXhKqbuB54D1Wut++dL/BN4BngRWF3GalRjvobnW2rL75SY0dzXugZfjVtVanW/HJcq1SZMmobUmMjKScePGUb16dUJCQhg2bBhNmzb9R+oQEBDAF198wZQpU5g1axb29vZ07NiRHTt28Oyzz1q8R7d379589913zJo1i8jISC5fvky1atW4//77adasmancmDFjCAgI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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# california housing dataset"
      ],
      "metadata": {
        "id": "0HdC6NSf-REu"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "from sklearn.datasets import fetch_california_housing\n",
        "from sklearn.model_selection import train_test_split\n",
        "from sklearn.preprocessing import MinMaxScaler\n",
        "\n",
        "\n",
        "california_housing = fetch_california_housing(as_frame=True)\n",
        "housing_data = california_housing.data\n",
        "housing_target = california_housing.target\n",
        "\n",
        "cols=housing_data.columns[:5]\n",
        "housing_data=housing_data[cols] \n",
        "\n",
        "X_train, X_test, y_train, y_test = train_test_split(housing_data, housing_target, test_size=0.33, random_state=40)\n",
        "\n",
        "N_train = 5000\n",
        "N_test = 1000\n",
        "\n",
        "X_train = np.array(X_train)[:N_train]\n",
        "X_test = np.array(X_test)[:N_test]\n",
        "\n",
        "y_train = np.array(y_train)[:N_train]\n",
        "y_test = np.array(y_test)[:N_test]\n",
        "\n",
        "scaler = MinMaxScaler(feature_range=(-1,1))\n",
        "scaler.fit(X_train)\n",
        "\n",
        "X_train_scaled = np.pi*scaler.transform(X_train)\n",
        "X_test_scaled = np.pi*scaler.transform(X_test)\n",
        "\n",
        "\n",
        "X_train_tensor = torch.from_numpy(X_train_scaled)\n",
        "y_train_tensor = torch.from_numpy(y_train)\n",
        "\n",
        "X_test_tensor = torch.from_numpy(X_test_scaled)  \n",
        "y_test_tensor = torch.from_numpy(y_test)"
      ],
      "metadata": {
        "id": "vOvSRXvN-Uem"
      },
      "execution_count": 39,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "np.random.seed(42)\n",
        "\n",
        "model = Model(n_qubits, ham_list, positions_list, ansatz_layers,dim_list,coeff_list)\n",
        "\n",
        "\n",
        "optimizer = torch.optim.Adam(model.parameters(), lr=.01)\n",
        "epochs = 100\n",
        "\n",
        "losses=[]\n",
        "losses_test=[]\n",
        "for epoch in range(epochs):\n",
        "    \n",
        "\n",
        "    optimizer.zero_grad()\n",
        "    y_pred = model(X_train_tensor.T)\n",
        "    y_pred_test = model(X_test_tensor.T)\n",
        "\n",
        "    criterion = nn.MSELoss()\n",
        "    loss= criterion(y_pred.double().reshape((-1,1)),y_train_tensor.reshape((-1,1)))\n",
        "    loss_test= criterion(y_pred_test.double().reshape((-1,1)),y_test_tensor.reshape((-1,1)))\n",
        "\n",
        "    loss.backward()\n",
        "    optimizer.step()\n",
        "    \n",
        "    print(f\"Epoch {epoch+1} | train Loss {loss} | test loss {loss_test}\")\n",
        "    losses.append(loss.detach().numpy())\n",
        "    losses_test.append(loss_test.detach().numpy())\n",
        "\n",
        "    "
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ie6p6pp__I_8",
        "outputId": "f9cac6fa-966a-4a1b-9e29-04d5f6ab373e"
      },
      "execution_count": 40,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch 1 | train Loss 5.720481817666423 | test loss 6.050103669806973\n",
            "Epoch 2 | train Loss 2.406171723092672 | test loss 2.697852876747339\n",
            "Epoch 3 | train Loss 1.839163418058374 | test loss 2.1206933257132037\n",
            "Epoch 4 | train Loss 1.6196504473028785 | test loss 1.9024798037193487\n",
            "Epoch 5 | train Loss 1.4454005753039159 | test loss 1.7197333285432816\n",
            "Epoch 6 | train Loss 1.3156415324405764 | test loss 1.5769824553804521\n",
            "Epoch 7 | train Loss 1.2568438806193554 | test loss 1.5076097266831634\n",
            "Epoch 8 | train Loss 1.1942338405242479 | test loss 1.4373032640257757\n",
            "Epoch 9 | train Loss 1.135311716022404 | test loss 1.3678920459909258\n",
            "Epoch 10 | train Loss 1.066873542087277 | test loss 1.2842609518240882\n",
            "Epoch 11 | train Loss 1.013392667246232 | test loss 1.2157191917089503\n",
            "Epoch 12 | train Loss 0.9679547845618397 | test loss 1.157595703387302\n",
            "Epoch 13 | train Loss 0.9327182819009598 | test loss 1.1090830189675458\n",
            "Epoch 14 | train Loss 0.8959102818578789 | test loss 1.0579700765750302\n",
            "Epoch 15 | train Loss 0.8603095549929861 | test loss 1.007821703657153\n",
            "Epoch 16 | train Loss 0.8427448628309883 | test loss 0.9772116773519887\n",
            "Epoch 17 | train Loss 0.8248284642494945 | test loss 0.950781865374075\n",
            "Epoch 18 | train Loss 0.8075148800034118 | test loss 0.9263110060451727\n",
            "Epoch 19 | train Loss 0.7853540680991368 | test loss 0.8949426190087976\n",
            "Epoch 20 | train Loss 0.76932573567534 | test loss 0.8702258152113388\n",
            "Epoch 21 | train Loss 0.7581753285119477 | test loss 0.8527477241552129\n",
            "Epoch 22 | train Loss 0.7482944720696117 | test loss 0.8377051439554506\n",
            "Epoch 23 | train Loss 0.7326173478000233 | test loss 0.816992732367243\n",
            "Epoch 24 | train Loss 0.7202090360227908 | test loss 0.7999219515369851\n",
            "Epoch 25 | train Loss 0.7112832851708465 | test loss 0.7884495044113901\n",
            "Epoch 26 | train Loss 0.7039763106163937 | test loss 0.7796796248630373\n",
            "Epoch 27 | train Loss 0.693220961301703 | test loss 0.7659440682563646\n",
            "Epoch 28 | train Loss 0.6839283638693056 | test loss 0.7539057217392708\n",
            "Epoch 29 | train Loss 0.677556443586985 | test loss 0.7462928765316079\n",
            "Epoch 30 | train Loss 0.672015605780683 | test loss 0.7395707880160094\n",
            "Epoch 31 | train Loss 0.664827209346397 | test loss 0.7305433975898116\n",
            "Epoch 32 | train Loss 0.6591916143888351 | test loss 0.7238841345677438\n",
            "Epoch 33 | train Loss 0.6546414240028959 | test loss 0.7199444046346958\n",
            "Epoch 34 | train Loss 0.649670153026238 | test loss 0.7145855323452945\n",
            "Epoch 35 | train Loss 0.6442170641592039 | test loss 0.7078495686022477\n",
            "Epoch 36 | train Loss 0.639612461051903 | test loss 0.7029964438139806\n",
            "Epoch 37 | train Loss 0.6363734518957339 | test loss 0.6989707507307862\n",
            "Epoch 38 | train Loss 0.6322464418305432 | test loss 0.6927930424394381\n",
            "Epoch 39 | train Loss 0.627815893309405 | test loss 0.6870874797364318\n",
            "Epoch 40 | train Loss 0.6246569773636935 | test loss 0.682849053943443\n",
            "Epoch 41 | train Loss 0.6218115590145047 | test loss 0.6776221210085192\n",
            "Epoch 42 | train Loss 0.6183695308962174 | test loss 0.6731706864711527\n",
            "Epoch 43 | train Loss 0.6154864137025372 | test loss 0.6695323129557604\n",
            "Epoch 44 | train Loss 0.6131212863972748 | test loss 0.6650007718028553\n",
            "Epoch 45 | train Loss 0.6104719353824423 | test loss 0.6614979123309755\n",
            "Epoch 46 | train Loss 0.6078483153641061 | test loss 0.6578737531792114\n",
            "Epoch 47 | train Loss 0.6059380110096861 | test loss 0.6546695629403804\n",
            "Epoch 48 | train Loss 0.6040928213885784 | test loss 0.653329546848275\n",
            "Epoch 49 | train Loss 0.6017770134062861 | test loss 0.6500797675847967\n",
            "Epoch 50 | train Loss 0.6000483118492729 | test loss 0.6485478725726276\n",
            "Epoch 51 | train Loss 0.5986717318450671 | test loss 0.647288079098202\n",
            "Epoch 52 | train Loss 0.5970513837430849 | test loss 0.6448702192788951\n",
            "Epoch 53 | train Loss 0.5955035687803177 | test loss 0.6435666377248608\n",
            "Epoch 54 | train Loss 0.5941822871594373 | test loss 0.6405271208604507\n",
            "Epoch 55 | train Loss 0.5927260786274452 | test loss 0.6397547713784578\n",
            "Epoch 56 | train Loss 0.5913946063436969 | test loss 0.6371730988536229\n",
            "Epoch 57 | train Loss 0.5902806018466423 | test loss 0.637120508268404\n",
            "Epoch 58 | train Loss 0.5891317667762419 | test loss 0.6345831706535788\n",
            "Epoch 59 | train Loss 0.5882335680865701 | test loss 0.6352505538090562\n",
            "Epoch 60 | train Loss 0.5879919399002042 | test loss 0.632391645593342\n",
            "Epoch 61 | train Loss 0.5888688952335293 | test loss 0.6365730345651689\n",
            "Epoch 62 | train Loss 0.5935740316791466 | test loss 0.6351290675604944\n",
            "Epoch 63 | train Loss 0.6041825876809905 | test loss 0.654468913291847\n",
            "Epoch 64 | train Loss 0.6256529478519649 | test loss 0.6627996136257637\n",
            "Epoch 65 | train Loss 0.6148066453493463 | test loss 0.6670147187751754\n",
            "Epoch 66 | train Loss 0.5900990711448885 | test loss 0.6318525373602963\n",
            "Epoch 67 | train Loss 0.5825583883604954 | test loss 0.6265254366846542\n",
            "Epoch 68 | train Loss 0.598927250427698 | test loss 0.6502272466127201\n",
            "Epoch 69 | train Loss 0.5938860098967116 | test loss 0.6351336749036223\n",
            "Epoch 70 | train Loss 0.5791601123918834 | test loss 0.6248919940407222\n",
            "Epoch 71 | train Loss 0.5929500756345721 | test loss 0.6435824517818786\n",
            "Epoch 72 | train Loss 0.5882586245680346 | test loss 0.6301436868644883\n",
            "Epoch 73 | train Loss 0.57835684823624 | test loss 0.6237234184318509\n",
            "Epoch 74 | train Loss 0.5902623727710176 | test loss 0.6416237642046492\n",
            "Epoch 75 | train Loss 0.581047753834758 | test loss 0.6248679294815426\n",
            "Epoch 76 | train Loss 0.5786381114938293 | test loss 0.6231909198884619\n",
            "Epoch 77 | train Loss 0.585504939115902 | test loss 0.6364075574157682\n",
            "Epoch 78 | train Loss 0.575495760747022 | test loss 0.6206496526959352\n",
            "Epoch 79 | train Loss 0.5783288222828784 | test loss 0.6216251378447266\n",
            "Epoch 80 | train Loss 0.5795270292365335 | test loss 0.6291873798303897\n",
            "Epoch 81 | train Loss 0.572579452085946 | test loss 0.618833239026319\n",
            "Epoch 82 | train Loss 0.5763502824135501 | test loss 0.619960718285866\n",
            "Epoch 83 | train Loss 0.5750164396736214 | test loss 0.6238519526199475\n",
            "Epoch 84 | train Loss 0.5706662386478585 | test loss 0.6168727745864592\n",
            "Epoch 85 | train Loss 0.5734760667805736 | test loss 0.6167315389672928\n",
            "Epoch 86 | train Loss 0.5723947618890015 | test loss 0.6203100739666495\n",
            "Epoch 87 | train Loss 0.5689257125818457 | test loss 0.6141432459432165\n",
            "Epoch 88 | train Loss 0.5701335733042796 | test loss 0.6138378434315531\n",
            "Epoch 89 | train Loss 0.5707259578434453 | test loss 0.6187036546957999\n",
            "Epoch 90 | train Loss 0.5681065121986267 | test loss 0.6124726042484703\n",
            "Epoch 91 | train Loss 0.5668208220232686 | test loss 0.6118502806646624\n",
            "Epoch 92 | train Loss 0.5680270427307603 | test loss 0.6153801876201006\n",
            "Epoch 93 | train Loss 0.5682272399293413 | test loss 0.6114945358277514\n",
            "Epoch 94 | train Loss 0.5661375760335629 | test loss 0.6129159050035896\n",
            "Epoch 95 | train Loss 0.5645916900375181 | test loss 0.6098616498789243\n",
            "Epoch 96 | train Loss 0.5647657871872278 | test loss 0.609077294050211\n",
            "Epoch 97 | train Loss 0.5654661542058742 | test loss 0.6129550210706646\n",
            "Epoch 98 | train Loss 0.5654601918115617 | test loss 0.6089192471168826\n",
            "Epoch 99 | train Loss 0.5643006310427112 | test loss 0.6116083116181701\n",
            "Epoch 100 | train Loss 0.5629213201811062 | test loss 0.6072376113302401\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "final_train_loss=losses[np.argmin(losses_test)]\n",
        "final_test_loss=losses_test[np.argmin(losses_test)]\n",
        "print(final_train_loss)\n",
        "print(final_test_loss)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "i46lmvglc6KU",
        "outputId": "241c71b3-fa64-4755-ffb8-e80274257959"
      },
      "execution_count": 41,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0.5629213201811062\n",
            "0.6072376113302401\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "font = {'size'   : 15}\n",
        "plt.rc('font', **font)\n",
        "plt.plot([i for i in range(0,epochs,1)],losses, label='Train MSE')\n",
        "plt.plot([i for i in range(0,epochs,1)],losses_test, label='Test MSE')\n",
        "\n",
        "plt.xlim(0)\n",
        "plt.xlabel(\"Epochs\")\n",
        "plt.ylabel(\"MSE Loss\") \n",
        "\n",
        "\n",
        "plt.legend()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 306
        },
        "id": "EJb-T2MoFGMx",
        "outputId": "445877cf-c9f1-4186-a67d-dc428bef7d2b"
      },
      "execution_count": 42,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7fd17d81fb10>"
            ]
          },
          "metadata": {},
          "execution_count": 42
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "tree sampling "
      ],
      "metadata": {
        "id": "hJNYcUXRNOL6"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "from sklearn.metrics import log_loss\n",
        "from sklearn.metrics import accuracy_score\n",
        "from sklearn.linear_model import LogisticRegression\n",
        "from sklearn.linear_model import LinearRegression\n",
        "from sklearn.metrics import mean_squared_error as mse\n",
        "from torch.autograd import Variable\n",
        "\n",
        "\n",
        "\n",
        "#seed\n",
        "nb_seeds=10\n",
        "seeds=np.arange(0,nb_seeds,1)\n",
        "\n",
        "\n",
        "#reg \n",
        "l0 = 1e-8\n",
        "l = 100 * l0\n",
        "L_gate_per_feature = 5\n",
        "d=5\n",
        "N=N_train\n",
        "\n",
        "#train data\n",
        "\n",
        "\n",
        "data_points = X_train_tensor#(N,d)\n",
        "test =  X_test_tensor\n",
        "\n",
        "\n",
        "\n",
        "#freq_theoretical_VQC\n",
        "\n",
        "s=200\n",
        "sample_size=list(np.arange(0,s+1,10))\n",
        "sample_size[0]=1\n",
        "if sample_size[-1]!=s:\n",
        "    sample_size.append(s) \n",
        "\n",
        "\n",
        "#RFF training\n",
        "train_losses = {k: [] for k in seeds}\n",
        "test_losses = {k: [] for k in seeds}\n",
        "\n",
        "train_loss=[0]*len(sample_size)\n",
        "test_loss=[0]*len(sample_size)\n",
        "\n",
        "comp=-1\n",
        "for p in sample_size:\n",
        "    comp+=1\n",
        "    for seed in seeds:\n",
        "\n",
        "        \n",
        "        freq_samples= np.array(sample_from_eigenvalues(all_eigenvalues_list, p)).reshape((d,p)) #(d,p)\n",
        "        #freq_samples = np.unique(freq_samples, axis=1)\n",
        "        #p = freq_samples.shape[1]\n",
        "        \n",
        "        reg_model = nn.Linear(2*p,1)\n",
        "        criterion = nn.MSELoss()\n",
        "        optimizer = torch.optim.Adam(reg_model.parameters(), lr=.05)\n",
        "        \n",
        "        #RFF\n",
        "        dot_prod = np.matmul(data_points, freq_samples)\n",
        "        fourier_features = np.concatenate([np.cos(dot_prod), np.sin(dot_prod)], axis=1)/ np.sqrt(p) #(N,2p)\n",
        "\n",
        "        dot_prod_test = np.dot(test, freq_samples)\n",
        "        fourier_features_test = np.concatenate([np.cos(dot_prod_test), np.sin(dot_prod_test)], axis=1)/ np.sqrt(p) #(N,2p)\n",
        "\n",
        "        loss_test_stopping=[]\n",
        "        if (True):\n",
        "         \n",
        "            \n",
        "            fourier_features= Variable(torch.from_numpy(fourier_features.astype('float32')))\n",
        "            fourier_features_test =  Variable(torch.from_numpy(fourier_features_test.astype('float32')))\n",
        "            epochs=2000\n",
        "            for epoch in range(epochs):\n",
        "                \n",
        "\n",
        "                optimizer.zero_grad()\n",
        "                pred_train = reg_model(fourier_features)\n",
        "                pred_test = reg_model(fourier_features_test)\n",
        "\n",
        "                \n",
        "                loss= criterion(pred_train.double(),y_train_tensor.reshape((-1,1)))\n",
        "                loss_test= criterion(pred_test.double(),y_test_tensor.reshape((-1,1)))\n",
        "\n",
        "                \n",
        "                loss_test_stopping.append(loss_test.detach().numpy())\n",
        "                if epoch>200:\n",
        "                  if ((loss_test_stopping[-1]>loss_test_stopping[-2]) & (loss_test_stopping[-2]>loss_test_stopping[-3])):\n",
        "                    break\n",
        "\n",
        "                loss.backward()\n",
        "                optimizer.step()\n",
        "\n",
        "\n",
        "\n",
        "        train_loss[comp]+=loss/nb_seeds\n",
        "        test_loss[comp]+=loss_test/nb_seeds\n",
        "\n",
        "        train_losses[seed].append(loss.detach().numpy())\n",
        "        test_losses[seed].append(loss_test.detach().numpy())\n",
        "\n",
        "        \n",
        "    print('nb samples : {} | train loss: {} | test loss: {} | epoch : {}'.format(p,train_loss[comp],test_loss[comp],epoch))\n",
        "  \n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "-OC9e6bwNFcA",
        "outputId": "b33d9893-87cf-4019-83c7-e723577c2364"
      },
      "execution_count": 43,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "nb samples : 1 | train loss: 1.2001848627372227 | test loss: 1.2616754637284724 | epoch : 245\n",
            "nb samples : 10 | train loss: 0.8596509390301174 | test loss: 0.9101002708542526 | epoch : 496\n",
            "nb samples : 20 | train loss: 0.6906267837802932 | test loss: 0.6965415780242094 | epoch : 1999\n",
            "nb samples : 30 | train loss: 0.6101720543058567 | test loss: 0.6143778703058234 | epoch : 533\n",
            "nb samples : 40 | train loss: 0.5870386892984703 | test loss: 0.6083515847580743 | epoch : 947\n",
            "nb samples : 50 | train loss: 0.5773948585922004 | test loss: 0.5926415750093005 | epoch : 672\n",
            "nb samples : 60 | train loss: 0.5773558015308042 | test loss: 0.5964884835159862 | epoch : 1878\n",
            "nb samples : 70 | train loss: 0.5523691928489061 | test loss: 0.5804338448656996 | epoch : 1690\n",
            "nb samples : 80 | train loss: 0.5508902551984562 | test loss: 0.5768488736153543 | epoch : 959\n",
            "nb samples : 90 | train loss: 0.540374548408146 | test loss: 0.5744664482348255 | epoch : 1999\n",
            "nb samples : 100 | train loss: 0.5423254747153798 | test loss: 0.5738209605126137 | epoch : 1806\n",
            "nb samples : 110 | train loss: 0.5325937018111432 | test loss: 0.5742118892593743 | epoch : 1650\n",
            "nb samples : 120 | train loss: 0.5256185180188394 | test loss: 0.5698376029516992 | epoch : 786\n",
            "nb samples : 130 | train loss: 0.5242280455845382 | test loss: 0.5722018378611351 | epoch : 686\n",
            "nb samples : 140 | train loss: 0.5207473011018725 | test loss: 0.5640280584681545 | epoch : 793\n",
            "nb samples : 150 | train loss: 0.5137127318258958 | test loss: 0.5713866983547811 | epoch : 1712\n",
            "nb samples : 160 | train loss: 0.5234176226793388 | test loss: 0.5679933271920645 | epoch : 1999\n",
            "nb samples : 170 | train loss: 0.5095995509700457 | test loss: 0.5682173784235348 | epoch : 1999\n",
            "nb samples : 180 | train loss: 0.5188207961059378 | test loss: 0.5817824744558888 | epoch : 623\n",
            "nb samples : 190 | train loss: 0.5143740443148284 | test loss: 0.5596896194521012 | epoch : 962\n",
            "nb samples : 200 | train loss: 0.5165107782619366 | test loss: 0.5654957545342286 | epoch : 890\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "error2=np.array([train_losses[i] for i in train_losses.keys()])\n",
        "mean_error2 = np.mean(error2, axis=0)\n",
        "std_error2 = np.std(error2, axis=0)\n",
        "\n",
        "error_test2=np.array([test_losses[i] for i in test_losses.keys()])\n",
        "mean_error2_test = np.mean(error_test2, axis=0)\n",
        "std_error2_test = np.std(error_test2, axis=0)"
      ],
      "metadata": {
        "id": "QrDrQUuCOsp2"
      },
      "execution_count": 44,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "font = {'size'   : 18}\n",
        "p_omega = (11**5-1)/2+1\n",
        "plt.rc('font', **font)\n",
        "plt.figure(figsize=(8,4))\n",
        "plt.plot(np.array(sample_size)/p_omega,mean_error2,linestyle='dashed', marker='s',label='Train MSE')\n",
        "plt.fill_between(np.array(sample_size)/p_omega, mean_error2-std_error2, mean_error2+std_error2, alpha=.2, linewidth=0) \n",
        "\n",
        "plt.plot(np.array(sample_size)/p_omega,mean_error2_test,linestyle='dashed', marker='s',label='Test MSE')\n",
        "plt.fill_between(np.array(sample_size)/p_omega, mean_error2_test-std_error2_test, mean_error2_test+std_error2_test, alpha=.2, linewidth=0) \n",
        "\n",
        "plt.hlines(final_train_loss,xmin=0,xmax=.0025,linestyle='dashed',label=\"VQC train MSE\",color='blue')\n",
        "plt.hlines(final_test_loss,xmin=0,xmax=.0025,linestyle='dashed',label=\"VQC test MSE\",color='red')\n",
        "\n",
        "plt.xlim(0)\n",
        "plt.xlabel(\"Number of sampled frequencies (fraction of |\\u03A9|)\")\n",
        "plt.ylabel(\"MSE Loss\") \n",
        "plt.legend()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 312
        },
        "id": "VQkP-VlyOzIO",
        "outputId": "4978b534-1b21-4149-d06f-027af587077f"
      },
      "execution_count": 47,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7fd17d407fd0>"
            ]
          },
          "metadata": {},
          "execution_count": 47
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 576x288 with 1 Axes>"
            ],
            "image/png": "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bt06li5dWulBxC+//EKJ7QwqlMViISEhga5d3XfBTkhIwGKxYLW6bsd06NAhunfvTnp6OuPHj2fatGkA/Pbbb2zdupWEhARuuukmlzaBgYH85z//8diHTp06VdC7OXf+BBAhQPFwtj/wX62L1jf+BEyrqI5VtU71ztaDaFPHTOSPi8mu38UtgADIzvMSQORmOJd/VuJ/0EKIi8fAgQNp2rQpK1as4Pnnn8dsNrtdk5CQADiDjULx8fEkJiYyadIk3nzzTUyms//rf/jhhxk2bBhPP/00MTExTJ48uejc4sWLiY+Pp1+/frz33nuEh4e7POu5555j9uzZaA/L3M9FTk4OAQEBLv30RWBg5e5DNGLECN566y1eeukll2ft3LmTH374gXHjxrFy5UqXNi+88AInT55k3bp1DBs2zO2ex48fdztmMpmYMGFCxb+BCubPFMZRoAOAUqo50A7nfhWF6gA1twSjMgBnP+jrBhloXstQrB5EB+/1IHK95EFou6zGEEJUGIPBwJQpUzh9+jQbNmxwO5+ens67775L+/bt6datGwAnT57khRdeoFmzZixcuNDtQzk4OJgVK1YQEhLCrFmzyMtzLkHPy8vjkUceITQ0lNWrV7sFDwBBQUE8++yz1KpVy2uf+/bty9KlSwFchuILh/kLpwdOnTpFXFwc9evXJyQkhCNHjgCwYMECBg4cSOPGjTGbzTRs2JAJEyaQlJTk9ixPORCFx37++WcGDx5MWFgY4eHhjBw50uOHd2liY2M5c+YM69a5brGUkJBAVFQUN954o1ubAwcOAHDttdd6vGeDBg386kN14k8A8T4wTSk1H3gHZ7Cwqdj59hTsklkjKYU2ukavXRqYyLdTZj0Iq81BvrflnFYJIIQQFSc2NhalVNFIQ3GrVq0iJyfHZfRh06ZNWK1WJk6ciMXiebFcvXr1GDZsGMeOHWPHjh0AbN++nePHjzNixAiioqLK3d9HHnmE3r17A5CYmFj06tOnj8t11113HceOHeOxxx7jmWeeITQ0FHB+g4+MjOS+++7j1VdfZfTo0bz33ntcddVVnD592qc+HD16lL59+9KsWTOef/55xo0bx9q1a5k0aZJf76Vz58506tSJxYsXFx2zWq289dZbTJgwgYCAALc20dHRALzxxht+jdQkJyd7fNlsXr6wVgF/xoeeBDoCd+EMHu7X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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [
        "diTXeFxzciHA"
      ],
      "machine_shape": "hm",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "a40ab50ca6294004bc211b0578327a61": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_e457e0907b0a477dbdd683f76e1779c2",
              "IPY_MODEL_774204388f864a7eb46a015b2cef4de2",
              "IPY_MODEL_82fe16c9783a415387ef28fabd8b06e1"
            ],
            "layout": "IPY_MODEL_f7b6638219834666874efd944322e036"
          }
        },
        "e457e0907b0a477dbdd683f76e1779c2": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_6d4b7aa143944671aedf505746965bde",
            "placeholder": "​",
            "style": "IPY_MODEL_f6bc9df0b2eb45f5bf89f7c726f02a2d",
            "value": "100%"
          }
        },
        "774204388f864a7eb46a015b2cef4de2": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_23ae50719eec47a4a9843342586e98dd",
            "max": 26421880,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_05845bd3756748bf89a9b61a58e840b3",
            "value": 26421880
          }
        },
        "82fe16c9783a415387ef28fabd8b06e1": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_189a21fb261f405db4cd7440d083916a",
            "placeholder": "​",
            "style": "IPY_MODEL_71bf95bfcbe445eab52835c1e2767528",
            "value": " 26421880/26421880 [00:14&lt;00:00, 5991448.58it/s]"
          }
        },
        "f7b6638219834666874efd944322e036": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "6d4b7aa143944671aedf505746965bde": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "f6bc9df0b2eb45f5bf89f7c726f02a2d": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "23ae50719eec47a4a9843342586e98dd": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "05845bd3756748bf89a9b61a58e840b3": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "189a21fb261f405db4cd7440d083916a": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "71bf95bfcbe445eab52835c1e2767528": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "28ab3bae4a154d56bfd4da19c134ef42": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_d7e841575bf946d0898ea02b22768d38",
              "IPY_MODEL_a4bd8c6d50184268960076727ef65805",
              "IPY_MODEL_efc69651089a4c07b0121c18fc5fb78d"
            ],
            "layout": "IPY_MODEL_209fcac9204e4998b612acb1fc3695e8"
          }
        },
        "d7e841575bf946d0898ea02b22768d38": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_694dd2d3d7064b4ca07e2f556c9fa9d4",
            "placeholder": "​",
            "style": "IPY_MODEL_fa3690fce9974251b28775c52d377118",
            "value": "100%"
          }
        },
        "a4bd8c6d50184268960076727ef65805": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_b7de33a3a89b437c997580a430c4c305",
            "max": 29515,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_c33af23fe189448282ce0e891bfabbf3",
            "value": 29515
          }
        },
        "efc69651089a4c07b0121c18fc5fb78d": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_a9cc10a880864a80b2fe5f6839d288ef",
            "placeholder": "​",
            "style": "IPY_MODEL_cfa5d37a20c0491f9ab7a40b3144457e",
            "value": " 29515/29515 [00:00&lt;00:00, 114397.16it/s]"
          }
        },
        "209fcac9204e4998b612acb1fc3695e8": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "694dd2d3d7064b4ca07e2f556c9fa9d4": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "fa3690fce9974251b28775c52d377118": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "b7de33a3a89b437c997580a430c4c305": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "c33af23fe189448282ce0e891bfabbf3": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "a9cc10a880864a80b2fe5f6839d288ef": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "cfa5d37a20c0491f9ab7a40b3144457e": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "8982ebe70d9d4979a21dccc4c61e67ab": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_420f67fad7104f65bb57b12c96d3a703",
              "IPY_MODEL_5d82679ba8f2462ea687a0e32cc01386",
              "IPY_MODEL_094d8ee6df044d218a6c1604297e6b39"
            ],
            "layout": "IPY_MODEL_a97f6c8eedcd44d2900061178685a03e"
          }
        },
        "420f67fad7104f65bb57b12c96d3a703": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_1c3ecd0476bf407885798bb5390e1172",
            "placeholder": "​",
            "style": "IPY_MODEL_89d0ee6aaeda4c3689a84cc69eb2edef",
            "value": "100%"
          }
        },
        "5d82679ba8f2462ea687a0e32cc01386": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_97d36a2cf6634abc87a830ddc0bd66be",
            "max": 4422102,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_f42982d29e564bffa836de63e4983cd7",
            "value": 4422102
          }
        },
        "094d8ee6df044d218a6c1604297e6b39": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_3499c7e365f1454881dd2d7a72881678",
            "placeholder": "​",
            "style": "IPY_MODEL_11e6e65bf750459c80a0eb86c07f9a86",
            "value": " 4422102/4422102 [00:02&lt;00:00, 3503609.67it/s]"
          }
        },
        "a97f6c8eedcd44d2900061178685a03e": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "1c3ecd0476bf407885798bb5390e1172": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "89d0ee6aaeda4c3689a84cc69eb2edef": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "97d36a2cf6634abc87a830ddc0bd66be": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "f42982d29e564bffa836de63e4983cd7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "3499c7e365f1454881dd2d7a72881678": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "11e6e65bf750459c80a0eb86c07f9a86": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "b4e9464208d0465caf05ae87578ce2cb": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_ab48ab6f05e149119a6894ceca2c78fc",
              "IPY_MODEL_451e067157264345986fbcb955e699c5",
              "IPY_MODEL_67694e3b32894bdeb291c2f9a53d373a"
            ],
            "layout": "IPY_MODEL_f59653d8ce67477386031cb02ce1ea26"
          }
        },
        "ab48ab6f05e149119a6894ceca2c78fc": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_b179ce95ae66423294a4ad6348e1d3ea",
            "placeholder": "​",
            "style": "IPY_MODEL_180115a17429439d95e1f2654f2548b7",
            "value": "100%"
          }
        },
        "451e067157264345986fbcb955e699c5": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_adf0af7761ed47429e81d21dfd761010",
            "max": 5148,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_45f990da3ea7402b9fc638cbde70503a",
            "value": 5148
          }
        },
        "67694e3b32894bdeb291c2f9a53d373a": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_23595d0d1ab643f2baec8d7b07f80ec7",
            "placeholder": "​",
            "style": "IPY_MODEL_82c85b816db64feba14232582e8f14a7",
            "value": " 5148/5148 [00:00&lt;00:00, 175705.53it/s]"
          }
        },
        "f59653d8ce67477386031cb02ce1ea26": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "b179ce95ae66423294a4ad6348e1d3ea": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "180115a17429439d95e1f2654f2548b7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "adf0af7761ed47429e81d21dfd761010": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "45f990da3ea7402b9fc638cbde70503a": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "23595d0d1ab643f2baec8d7b07f80ec7": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "82c85b816db64feba14232582e8f14a7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        }
      }
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}