{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "SP0HeaeCOooo"
      },
      "outputs": [],
      "source": [
        "'''Shallow neural networks trained on the ECG5000 Data Set (Jupyter notebook version)'''\n",
        "import numpy as np\n",
        "from sklearn.model_selection import train_test_split\n",
        "\n",
        "# read and process data\n",
        "def get_data(RANDOM_SEED=22):\n",
        "    np.random.seed(RANDOM_SEED)\n",
        "\n",
        "    train_data = np.genfromtxt('ECG5000_TRAIN.txt')\n",
        "    test_data = np.genfromtxt('ECG5000_TEST.txt')\n",
        "    wdata = np.vstack([train_data, test_data])\n",
        "\n",
        "    for i in range(wdata.shape[0]):\n",
        "        if wdata[i,0] > 1.0:\n",
        "            wdata[i,0] = 1.0\n",
        "        else:\n",
        "            wdata[i,0] = 0.0\n",
        "\n",
        "    np.random.shuffle(wdata)\n",
        "\n",
        "    normal_data = wdata[wdata[:,0]==0.0,:]\n",
        "    abnormal_data = wdata[wdata[:,0]==1.0,:]\n",
        "\n",
        "    data = wdata[:,1:]\n",
        "    labels = wdata[:,0]\n",
        "   \n",
        "    train_data, test_data, train_labels, test_labels = train_test_split(data, labels, test_size=0.9, random_state=RANDOM_SEED)\n",
        "\n",
        "    min_val = np.min(train_data)\n",
        "    max_val = np.max(train_data)\n",
        "    X_train = (train_data-min_val)/(max_val-min_val)\n",
        "    X_test = (test_data-min_val)/(max_val-min_val)\n",
        "    y_train = train_labels\n",
        "    y_test = test_labels\n",
        "\n",
        "    print('training input data shape: ', X_train.shape)\n",
        "    print('testing input data shape: ', X_test.shape)\n",
        "\n",
        "    #normal_train_data = train_data[y_train==True]\n",
        "    #normal_test_data = test_data[y_test==True]\n",
        "    #abnormal_train_data = X_train[y_train==False]\n",
        "    #abnormal_test_data = X_test[y_test==False]\n",
        "    #print(normal_train_data.shape)\n",
        "    #print(abnormal_train_data.shape)\n",
        "\n",
        "    return X_train, y_train, X_test, y_test\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "3czg2xFcRVbk"
      },
      "outputs": [],
      "source": [
        "# helper functions for implementing the perturbations used in MPGD (see Section 3 of the paper for full details)\n",
        "import numpy as np\n",
        "import torch\n",
        "from scipy.optimize import fsolve\n",
        "from scipy.special import gamma as Gamma\n",
        "\n",
        "# define the Thaler map\n",
        "def Thaler_map(x, gamma):\n",
        "  return ((x**(1-gamma) + (1+x)**(1-gamma) - 1)**(1/(1-gamma))) % 1\n",
        "\n",
        "# define the chi_j \n",
        "def chi_func(x, x_star, p, seed):\n",
        "  np.random.seed(seed)\n",
        "  if x <= x_star:\n",
        "    return 1.0\n",
        "  else: \n",
        "    return 2*np.random.binomial(1,p,1)[0] - 1\n",
        "\n",
        "# define v\n",
        "def v_func(x, x_star, eta, gamma):\n",
        "  alpha = 1/gamma\n",
        "  if x <= x_star:\n",
        "    return eta * ((1-2**(gamma-1))**(-gamma)) * ( (alpha**alpha)*(1-gamma)*Gamma(1-alpha)*np.cos(alpha*np.pi/2)/(2**(1-gamma)-1) )**(-gamma)\n",
        "  else:\n",
        "    return (eta * ((1-2**(gamma-1))**(-gamma)) * ( (alpha**alpha)*(1-gamma)*Gamma(1-alpha)*np.cos(alpha*np.pi/2)/(2**(1-gamma)-1) )**(-gamma))/(1-2**(1-gamma))\n",
        "\n",
        "# define the observables v^{(k)} \n",
        "def obs_v(x_0, p, T, gamma, eta=1.0, seed=1234):\n",
        "  y = x_0\n",
        "  def func(x, gamma=gamma):\n",
        "   return x**(1-gamma) + (1+x)**(1-gamma) - 2\n",
        "  x_star =  fsolve(func, (0.01))[0]\n",
        "  chi_i = chi_func(x=x_0, x_star=x_star, p=p, seed=seed) \n",
        "  v_0 = chi_i * v_func(y, x_star=x_star, eta=eta, gamma=gamma)\n",
        "  v_list = []\n",
        "  v_list.append(v_0)\n",
        "\n",
        "  for i in range(T):\n",
        "    y = Thaler_map(y, gamma=gamma)\n",
        "    chi_i = chi_i * chi_func(x=y, x_star=x_star, p=p, seed=seed)\n",
        "    v_new = v_func(x = y, x_star=x_star, eta=eta, gamma=gamma)\n",
        "    v = chi_i * v_new\n",
        "    v_list.append(v)\n",
        "  return v_list\n",
        "\n",
        "# define initial conditions following Gottwald-Melbourne (2021)\n",
        "def init_data(gamma, seed=1234):\n",
        "  np.random.seed(seed)\n",
        "  x = np.random.uniform()\n",
        "  for i in range(10000):\n",
        "    x = Thaler_map(x, gamma=gamma)\n",
        "  x_0 = x\n",
        "  return x_0\n",
        "\n",
        "# construct higher dimensional versions of the v^{(k)} (to be compatible with the shape of the parameters)\n",
        "def obs_v_dim(p, T, gamma, param, eta=1.0, seed=1234):\n",
        "  dim = torch.numel(param)\n",
        "  obs_vec = torch.zeros((dim,T+1))\n",
        "  for i in range(dim):\n",
        "    x0 = init_data(gamma,i+seed) \n",
        "    obs_vec[i, :] = torch.tensor(obs_v(x0, p, T, gamma, eta=eta, seed=i+seed))\n",
        "  if len(param.size()) == 1:\n",
        "    return obs_vec.view(T+1, param.shape[0]) \n",
        "  elif len(param.size()) == 2:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1])\n",
        "  elif len(param.size()) == 3:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2])\n",
        "  elif len(param.size()) == 4:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2], param.shape[3])\n",
        "  elif len(param.size()) == 5:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2], param.shape[3], param.shape[4])\n",
        "  else:\n",
        "    print('invalid shape!')\n",
        "\n",
        "# construct higher dimensional versions of the observables for the MPGD variant (see Eq. (11) in the paper)\n",
        "def diff_obs_v_dim(p, T, gamma, param, eta=1.0, seed=1234):\n",
        "  dim = torch.numel(param)\n",
        "  obs_vec = torch.zeros((dim,T+1))\n",
        "  for i in range(dim):\n",
        "    x0 = init_data(gamma,i+seed) \n",
        "    x00 = init_data(gamma,i+100*seed) \n",
        "    obs_vec[i, :] = torch.tensor( np.array(obs_v(x0, p, T, gamma, eta=eta, seed=i+seed)) - np.array(obs_v(x00, p, T, gamma, eta=eta, seed=i+seed)) )\n",
        "  if len(param.size()) == 1:\n",
        "    return obs_vec.view(T+1, param.shape[0]) \n",
        "  elif len(param.size()) == 2:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1])\n",
        "  elif len(param.size()) == 3:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2])\n",
        "  elif len(param.size()) == 4:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2], param.shape[3])\n",
        "  elif len(param.size()) == 5:\n",
        "    return obs_vec.view(T+1, param.shape[0], param.shape[1], param.shape[2], param.shape[3], param.shape[4])\n",
        "  else:\n",
        "    print('invalid shape!')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BHl8sTVEebcl",
        "outputId": "2985ad5d-9d1c-456d-f1bf-77e96a1a5f19"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "training input data shape:  (500, 140)\n",
            "testing input data shape:  (4500, 140)\n",
            "batch size:  500\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.optim as optim\n",
        "from torch.autograd import Variable\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "%matplotlib inline\n",
        "from sklearn.metrics import accuracy_score\n",
        "import statistics\n",
        "\n",
        "# get and process data\n",
        "X_train, y_train, X_test, y_test = get_data()\n",
        "\n",
        "BATCH_SIZE = X_train.shape[0] #equal training set size for full batch GD\n",
        "print('batch size: ', BATCH_SIZE)\n",
        "\n",
        "dataset = torch.utils.data.TensorDataset(torch.tensor(X_train, dtype=torch.float),\n",
        "                                         torch.tensor(y_train, dtype=torch.float).reshape(-1,1))\n",
        "train_loader = torch.utils.data.DataLoader(dataset, batch_size=BATCH_SIZE)\n",
        "test_target = torch.tensor(y_test, dtype=torch.float).reshape(-1,1)\n",
        "\n",
        "# define the neural network model\n",
        "class Net(nn.Module):\n",
        "    def __init__(self):\n",
        "        super(Net, self).__init__()\n",
        "        self.fc1 = nn.Linear(140, 32)  # input layer\n",
        "        self.fc2 = nn.Linear(32, 32) # hidden layer \n",
        "        self.last = nn.Linear(32, 1)  # ouput layer\n",
        "        self.layers = [self.fc1, self.fc2]\n",
        "\n",
        "    def forward(self, x):\n",
        "        for i, layer in enumerate(self.layers):\n",
        "            x = layer(x)\n",
        "            x = torch.sigmoid(x)\n",
        "        x = torch.sigmoid(self.last(x))\n",
        "        return x.view(-1)\n",
        "\n",
        "# implement various GD schemes: vanilla GD (baseline), GD with Gaussian perturbations, MPGD, MPGD variant Eq. (11) in the paper\n",
        "def train(X_train, y_train, X_test, y_test, option=0, start_perturb=0, perturb_level=[0.0,0.0], beta=0.5, gamma=0.65, epochs=1000, lr=0.01, mom=0.0, seed=1):\n",
        "    np.random.seed(seed)\n",
        "    torch.manual_seed(seed)\n",
        "    torch.cuda.manual_seed(seed)\n",
        "    torch.cuda.manual_seed_all(seed)\n",
        "    torch.backends.cudnn.deterministic = True\n",
        "    torch.backends.cudnn.benchmark = False\n",
        "    torch.set_default_tensor_type(torch.DoubleTensor)\n",
        "\n",
        "    if torch.cuda.device_count() > 0:\n",
        "      device = torch.device('cuda')\n",
        "      print(\"Connected to a GPU\")\n",
        "    else:\n",
        "      print(\"Using the CPU\")\n",
        "      device = torch.device('cpu')\n",
        "\n",
        "    net = Net().to(device)\n",
        "\n",
        "    optimizer = optim.SGD(net.parameters(), lr=lr, momentum=mom) \n",
        "\n",
        "    criterion = nn.BCELoss().to(device) \n",
        "\n",
        "    gamma = gamma #gamma is in (1/2,1)\n",
        "    beta = beta #beta is in [-1,1]\n",
        "    p = 0.5*(1+beta)\n",
        "    \n",
        "    total_params = sum(p.numel() for p in net.parameters())\n",
        "    print('Number of trainable parameters: ', total_params)\n",
        "\n",
        "    count = 0\n",
        "    loss_list = []\n",
        "    train_loss_hist = []\n",
        "    test_loss_hist = []\n",
        "    test_acc_hist = []\n",
        "    train_acc_hist = []\n",
        "\n",
        "    for epoch in range(epochs):\n",
        "        net.train()\n",
        "        inputs = Variable(torch.from_numpy(X_train)).to(device) \n",
        "        targets = Variable(torch.from_numpy(y_train)).to(device)\n",
        "        outputs = net(inputs) \n",
        "\n",
        "        if epoch >= start_perturb and epoch < 500: #stop injecting perturbations after 500 epochs\n",
        "          # simulate perturbations\n",
        "          if option == 1 and epoch == start_perturb:\n",
        "            p_vec_list = []\n",
        "            for param in net.parameters():\n",
        "              p_vec = obs_v_dim(p, epochs, gamma, param.data, seed=123456+seed)\n",
        "              p_vec_list.append(p_vec)\n",
        "          if option == 3 and epoch == start_perturb:\n",
        "            p_vec_list = []\n",
        "            for param in net.parameters():\n",
        "              diff_p_vec = diff_obs_v_dim(p, epochs, gamma, param.data, seed=123456+seed)\n",
        "              p_vec_list.append(diff_p_vec)\n",
        "\n",
        "          # adding the perturbations/regularization to GD (for option > 0)\n",
        "          reg = 0.0\n",
        "          if option == 0: #baseline\n",
        "            loss = criterion(outputs, targets)\n",
        "          elif option == 1 or option == 3: #inject our perturbations (different for all parameters in all layers)\n",
        "            param_count = 0\n",
        "            for param in net.parameters():\n",
        "              if param.requires_grad:\n",
        "                p_perturb = p_vec_list[param_count]\n",
        "                reg += (perturb_level[0] * (p_perturb[count].to(device) * param).sum() + perturb_level[1] * (p_perturb[count].to(device) * param * param).sum()/2) \n",
        "                param_count += 1\n",
        "            loss = criterion(outputs, targets) + (lr**gamma) * reg / lr\n",
        "          elif option == 2: #replace the perturbations with uncorrelated Gaussians instead for all parameters\n",
        "            param_count = 0\n",
        "            for param in net.parameters():\n",
        "              if param.requires_grad:\n",
        "                reg += perturb_level[0] * torch.matmul(torch.randn(param.shape).to(device), param.T).sum() + perturb_level[1] * (torch.randn(param.shape).to(device) * param * param).sum()/2\n",
        "                param_count += 1\n",
        "            loss = criterion(outputs, targets) + reg\n",
        "          else:\n",
        "            print('invalid option!')\n",
        "\n",
        "          count += 1\n",
        "\n",
        "        else:\n",
        "          loss = criterion(outputs, targets)\n",
        "          \n",
        "        # collecting performance data at each epoch\n",
        "        loss_list.append(criterion(outputs, targets).cpu().detach().numpy())\n",
        "        \n",
        "        loss.backward()        \n",
        "        optimizer.step()\n",
        "        optimizer.zero_grad()\n",
        "            \n",
        "        # evaluate\n",
        "        net.eval()\n",
        "        y_pred = net(Variable(torch.from_numpy(X_test).to(device)) ) \n",
        "        y_pred_train = net(Variable(torch.from_numpy(X_train)).to(device) )\n",
        "        test_target = Variable(torch.from_numpy(y_test).to(device) )\n",
        "        test_loss = criterion(y_pred, test_target) #the orignal test loss (without the perturbations)\n",
        "        \n",
        "        y_pred = y_pred.cpu().detach().numpy()\n",
        "        y_pred[y_pred>=0.5] = 1.0\n",
        "        y_pred[y_pred<0.5] = 0.0\n",
        "        \n",
        "        y_pred_train = y_pred_train.cpu().detach().numpy()\n",
        "        y_pred_train[y_pred_train>=0.5] = 1.0\n",
        "        y_pred_train[y_pred_train<0.5] = 0.0\n",
        "\n",
        "        train_loss_hist.append(loss.cpu().detach().numpy())\n",
        "        test_loss_hist.append(test_loss.cpu().detach().numpy())\n",
        "        test_acc_hist.append(accuracy_score(y_test, y_pred))\n",
        "        train_acc_hist.append(accuracy_score(y_train, y_pred_train))\n",
        "\n",
        "    return net, train_loss_hist, test_loss_hist, test_acc_hist, train_acc_hist\n",
        "\n",
        "# run the experiments \n",
        "def run_exp(option=0, lr=0.01, epochs=1000, start_perturb=0, gamma=0.6, beta=0.5, sigma=0.0, mu=0.0, n_run=5):\n",
        "    list0 = []\n",
        "    diff0 = []\n",
        "    listacc = []\n",
        "    for i in range(n_run):\n",
        "        net0, train_loss_hist0, test_loss_hist0, test_acc_hist0, train_acc_hist0 = train(X_train, y_train, X_test, y_test, start_perturb=start_perturb, gamma=gamma, beta=beta, perturb_level=[sigma, mu], epochs=epochs, option=option, lr=lr, mom=0.0, seed=1+i)\n",
        "        listacc.append(test_acc_hist0)\n",
        "        list0.append(test_acc_hist0[-1]) \n",
        "        diff0.append(train_acc_hist0[-1]-test_acc_hist0[-1])\n",
        "    print('===========> Option: ', option)\n",
        "    if option == 1 or option == 3:\n",
        "        print('gamma: ', gamma, ', beta: ', beta, ', mu: ', mu, ', sigma: ', sigma)\n",
        "    elif option == 2:\n",
        "        print('sigma: ', sigma, ', mu: ', mu)\n",
        "    print('test accs: ', list0)\n",
        "    print('acc gaps: ', diff0)\n",
        "    mean_acc = np.array(np.mean(listacc, axis=0))\n",
        "    print('Average test acc: ',  statistics.mean(list0) )\n",
        "    print('Average acc gap: ',  statistics.mean(diff0) )\n",
        "    print('Std dev of test acc: ', statistics.stdev(list0))\n",
        "    print('Std dev of acc gap: ', statistics.stdev(diff0))\n",
        "    print('Maximum test acc: ', max(list0))\n",
        "    print('Minimum test acc: ', min(list0))\n",
        "    print('Maximum acc gap: ', max(diff0))\n",
        "    print('Minimum acc gap: ', min(diff0))\n",
        "    print('--------------------------------------')\n",
        "    return mean_acc"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "N6M9lgcSenq4",
        "outputId": "fec01e42-4afe-4de3-bda8-f7b8b5e7d88e"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "=============== Using lr of  0.05  and run for  1000  epochs ============== \n",
            "==== baseline (vanilla GD) ===== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  0\n",
            "test accs:  [0.5837777777777777, 0.5837777777777777, 0.5837777777777777, 0.5837777777777777, 0.5837777777777777]\n",
            "acc gaps:  [0.00022222222222223476, 0.00022222222222223476, 0.00022222222222223476, 0.00022222222222223476, 0.00022222222222223476]\n",
            "Average test acc:  0.5837777777777777\n",
            "Average acc gap:  0.00022222222222223476\n",
            "Std dev of test acc:  0.0\n",
            "Std dev of acc gap:  0.0\n",
            "Maximum test acc:  0.5837777777777777\n",
            "Minimum test acc:  0.5837777777777777\n",
            "Maximum acc gap:  0.00022222222222223476\n",
            "Minimum acc gap:  0.00022222222222223476\n",
            "--------------------------------------\n",
            "==== GD with Gaussian perturbations ===== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n"
          ]
        },
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:110: UserWarning: The use of `x.T` on tensors of dimension other than 2 to reverse their shape is deprecated and it will throw an error in a future release. Consider `x.mT` to transpose batches of matricesor `x.permute(*torch.arange(x.ndim - 1, -1, -1))` to reverse the dimensions of a tensor. (Triggered internally at  ../aten/src/ATen/native/TensorShape.cpp:2318.)\n"
          ]
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  2\n",
            "sigma:  0.2 , mu:  0.2\n",
            "test accs:  [0.5837777777777777, 0.5837777777777777, 0.5837777777777777, 0.5837777777777777, 0.9491111111111111]\n",
            "acc gaps:  [0.00022222222222223476, 0.00022222222222223476, 0.00022222222222223476, 0.00022222222222223476, 0.012888888888888839]\n",
            "Average test acc:  0.6568444444444445\n",
            "Average acc gap:  0.0027555555555555554\n",
            "Std dev of test acc:  0.16338203355598466\n",
            "Std dev of acc gap:  0.005664705542999439\n",
            "Maximum test acc:  0.9491111111111111\n",
            "Minimum test acc:  0.5837777777777777\n",
            "Maximum acc gap:  0.012888888888888839\n",
            "Minimum acc gap:  0.00022222222222223476\n",
            "--------------------------------------\n"
          ]
        }
      ],
      "source": [
        "########################################## main ###########################################\n",
        "\n",
        "lr = 0.05\n",
        "epochs = 1000\n",
        "n_run = 5\n",
        "\n",
        "print('=============== Using lr of ', lr, ' and run for ', epochs, ' epochs ============== ')\n",
        "\n",
        "# baseline\n",
        "print('==== baseline (vanilla GD) ===== ')\n",
        "mean_acc_baseline = run_exp(option=0, lr=lr, epochs=epochs, start_perturb=0, n_run=n_run)\n",
        "\n",
        "\n",
        "# GD with the perturbations replaced with uncorrelated Gaussian vectors\n",
        "print('==== GD with Gaussian perturbations ===== ')\n",
        "sigma = 0.2\n",
        "mu = 0.2\n",
        "mean_acc_gaussian = run_exp(option=2, lr=lr, epochs=epochs, start_perturb=0, sigma=sigma, mu=mu, n_run=n_run)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "OXcOtYkBO3aN",
        "outputId": "ccb68c29-3f2a-4a82-efc4-7337b362483f"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "==================== MPGD with beta = 0.0 ================== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  1\n",
            "gamma:  0.55 , beta:  0.0 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.934, 0.9533333333333334, 0.9337777777777778, 0.9315555555555556, 0.9211111111111111]\n",
            "acc gaps:  [0.0020000000000000018, 0.012666666666666604, 0.004222222222222127, 0.004444444444444473, -0.0031111111111110645]\n",
            "Average test acc:  0.9347555555555556\n",
            "Average acc gap:  0.004044444444444429\n",
            "Std dev of test acc:  0.011651948387912133\n",
            "Std dev of acc gap:  0.005699036089171446\n",
            "Maximum test acc:  0.9533333333333334\n",
            "Minimum test acc:  0.9211111111111111\n",
            "Maximum acc gap:  0.012666666666666604\n",
            "Minimum acc gap:  -0.0031111111111110645\n",
            "--------------------------------------\n",
            "==== Another MPGD variant ===== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.55 , beta:  0.0 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.8448888888888889, 0.9453333333333334, 0.9562222222222222, 0.9424444444444444, 0.7437777777777778]\n",
            "acc gaps:  [-0.014888888888888951, 0.0086666666666666, 0.009777777777777774, 0.013555555555555543, 0.01622222222222225]\n",
            "Average test acc:  0.8865333333333333\n",
            "Average acc gap:  0.006666666666666643\n",
            "Std dev of test acc:  0.09158799317501809\n",
            "Std dev of acc gap:  0.012420612099984135\n",
            "Maximum test acc:  0.9562222222222222\n",
            "Minimum test acc:  0.7437777777777778\n",
            "Maximum acc gap:  0.01622222222222225\n",
            "Minimum acc gap:  -0.014888888888888951\n",
            "--------------------------------------\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 576x360 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.6 , beta:  0.0 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9526666666666667, 0.9126666666666666, 0.9426666666666667, 0.9293333333333333, 0.7884444444444444]\n",
            "acc gaps:  [0.01533333333333331, 0.009333333333333416, -0.0006666666666667043, 0.00666666666666671, 0.003555555555555645]\n",
            "Average test acc:  0.9051555555555555\n",
            "Average acc gap:  0.006844444444444475\n",
            "Std dev of test acc:  0.06694560164974929\n",
            "Std dev of acc gap:  0.006031604008353022\n",
            "Maximum test acc:  0.9526666666666667\n",
            "Minimum test acc:  0.7884444444444444\n",
            "Maximum acc gap:  0.01533333333333331\n",
            "Minimum acc gap:  -0.0006666666666667043\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.65 , beta:  0.0 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.8504444444444444, 0.9253333333333333, 0.9608888888888889, 0.9446666666666667, 0.9046666666666666]\n",
            "acc gaps:  [-0.008444444444444477, -0.0033333333333332993, 0.0011111111111110628, 0.005333333333333301, 0.007333333333333414]\n",
            "Average test acc:  0.9172\n",
            "Average acc gap:  0.00040000000000000034\n",
            "Std dev of test acc:  0.04284470954274833\n",
            "Std dev of acc gap:  0.006424105836804792\n",
            "Maximum test acc:  0.9608888888888889\n",
            "Minimum test acc:  0.8504444444444444\n",
            "Maximum acc gap:  0.007333333333333414\n",
            "Minimum acc gap:  -0.008444444444444477\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.7 , beta:  0.0 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.926, 0.9337777777777778, 0.9273333333333333, 0.5837777777777777, 0.9048888888888889]\n",
            "acc gaps:  [0.0119999999999999, -0.001777777777777767, 0.010666666666666602, 0.00022222222222223476, 0.007111111111111179]\n",
            "Average test acc:  0.8551555555555556\n",
            "Average acc gap:  0.005644444444444429\n",
            "Std dev of test acc:  0.15209316508047802\n",
            "Std dev of acc gap:  0.006169618912936495\n",
            "Maximum test acc:  0.9337777777777778\n",
            "Minimum test acc:  0.5837777777777777\n",
            "Maximum acc gap:  0.0119999999999999\n",
            "Minimum acc gap:  -0.001777777777777767\n",
            "--------------------------------------\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "array([0.51675556, 0.51675556, 0.44973333, 0.48324444, 0.48324444,\n",
              "       0.51675556, 0.48324444, 0.48324444, 0.48324444, 0.51653333,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.42844444, 0.48693333, 0.51675556, 0.48324444, 0.48328889,\n",
              "       0.48324444, 0.44413333, 0.48324444, 0.51982222, 0.51675556,\n",
              "       0.53253333, 0.48324444, 0.51675556, 0.51675556, 0.55026667,\n",
              "       0.5804    , 0.48324444, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.4496    , 0.48337778, 0.48742222, 0.5004    , 0.578     ,\n",
              "       0.55026667, 0.51675556, 0.52111111, 0.49528889, 0.51777778,\n",
              "       0.44973333, 0.48324444, 0.48324444, 0.49506667, 0.48582222,\n",
              "       0.48902222, 0.44942222, 0.41617778, 0.44973333, 0.47155556,\n",
              "       0.492     , 0.43844444, 0.53426667, 0.48213333, 0.48324444,\n",
              "       0.53493333, 0.48333333, 0.45284444, 0.44973333, 0.44973333,\n",
              "       0.45613333, 0.53542222, 0.4496    , 0.46995556, 0.46302222,\n",
              "       0.45644444, 0.53515556, 0.48804444, 0.44951111, 0.41626667,\n",
              "       0.44977778, 0.48337778, 0.48311111, 0.48324444, 0.48497778,\n",
              "       0.48328889, 0.48324444, 0.48306667, 0.42568889, 0.48106667,\n",
              "       0.466     , 0.48693333, 0.50435556, 0.54097778, 0.48306667,\n",
              "       0.48888889, 0.49924444, 0.51693333, 0.48133333, 0.58782222,\n",
              "       0.61382222, 0.61764444, 0.55973333, 0.43755556, 0.54066667,\n",
              "       0.41404444, 0.45333333, 0.48324444, 0.48577778, 0.60324444,\n",
              "       0.62204444, 0.52471111, 0.50182222, 0.44955556, 0.45542222,\n",
              "       0.48315556, 0.47875556, 0.49955556, 0.48915556, 0.53688889,\n",
              "       0.51675556, 0.52128889, 0.48391111, 0.56502222, 0.55057778,\n",
              "       0.596     , 0.58413333, 0.53573333, 0.51751111, 0.5848    ,\n",
              "       0.55168889, 0.50391111, 0.51671111, 0.48662222, 0.48333333,\n",
              "       0.48324444, 0.51666667, 0.51675556, 0.51675556, 0.51497778,\n",
              "       0.4692    , 0.58262222, 0.58377778, 0.49431111, 0.57853333,\n",
              "       0.55017778, 0.60982222, 0.5504    , 0.49435556, 0.51671111,\n",
              "       0.51671111, 0.48115556, 0.49973333, 0.54817778, 0.48324444,\n",
              "       0.45204444, 0.46324444, 0.47044444, 0.48333333, 0.45004444,\n",
              "       0.44977778, 0.44844444, 0.49364444, 0.50053333, 0.44728889,\n",
              "       0.42057778, 0.50448889, 0.47595556, 0.51817778, 0.41964444,\n",
              "       0.49462222, 0.53497778, 0.55048889, 0.55026667, 0.55031111,\n",
              "       0.57848889, 0.53964444, 0.51671111, 0.5168    , 0.48324444,\n",
              "       0.48324444, 0.48484444, 0.57435556, 0.48982222, 0.42462222,\n",
              "       0.39742222, 0.45377778, 0.48328889, 0.51502222, 0.48324444,\n",
              "       0.48324444, 0.48324444, 0.48337778, 0.44973333, 0.44973333,\n",
              "       0.44133333, 0.4516    , 0.48315556, 0.43733333, 0.5172    ,\n",
              "       0.4808    , 0.51848889, 0.51675556, 0.484     , 0.48315556,\n",
              "       0.48324444, 0.40213333, 0.48853333, 0.51422222, 0.4832    ,\n",
              "       0.51675556, 0.55013333, 0.54195556, 0.50462222, 0.55248889,\n",
              "       0.61448889, 0.51675556, 0.55026667, 0.55026667, 0.51675556,\n",
              "       0.60502222, 0.51688889, 0.51684444, 0.51715556, 0.60404444,\n",
              "       0.51675556, 0.50528889, 0.55022222, 0.55026667, 0.51333333,\n",
              "       0.51431111, 0.50595556, 0.51675556, 0.54848889, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.55026667, 0.57995556,\n",
              "       0.62293333, 0.49595556, 0.5836    , 0.49751111, 0.58524444,\n",
              "       0.65657778, 0.59475556, 0.6008    , 0.58071111, 0.56706667,\n",
              "       0.55822222, 0.5844    , 0.63955556, 0.60404444, 0.53115556,\n",
              "       0.5308    , 0.55026667, 0.55128889, 0.55026667, 0.55026667,\n",
              "       0.55026667, 0.55026667, 0.58306667, 0.58315556, 0.58364444,\n",
              "       0.58315556, 0.58244444, 0.5836    , 0.58311111, 0.58262222,\n",
              "       0.5528    , 0.56013333, 0.64564444, 0.64248889, 0.58875556,\n",
              "       0.58564444, 0.58653333, 0.58377778, 0.59795556, 0.5668    ,\n",
              "       0.58475556, 0.62257778, 0.62666667, 0.58391111, 0.58408889,\n",
              "       0.58408889, 0.58395556, 0.58377778, 0.58377778, 0.58377778,\n",
              "       0.55026667, 0.54386667, 0.61968889, 0.63244444, 0.62675556,\n",
              "       0.58884444, 0.55026667, 0.55022222, 0.56284444, 0.60226667,\n",
              "       0.54977778, 0.55404444, 0.58422222, 0.58053333, 0.57377778,\n",
              "       0.58431111, 0.58573333, 0.58737778, 0.58404444, 0.58391111,\n",
              "       0.58413333, 0.54777778, 0.58386667, 0.51671111, 0.59764444,\n",
              "       0.51671111, 0.55026667, 0.55026667, 0.46724444, 0.53977778,\n",
              "       0.55715556, 0.58933333, 0.58928889, 0.58377778, 0.58377778,\n",
              "       0.58377778, 0.58377778, 0.584     , 0.58395556, 0.59768889,\n",
              "       0.5488    , 0.57315556, 0.49226667, 0.52426667, 0.5212    ,\n",
              "       0.52817778, 0.50977778, 0.51786667, 0.51666667, 0.52044444,\n",
              "       0.51666667, 0.54222222, 0.51315556, 0.55626667, 0.55035556,\n",
              "       0.55026667, 0.55026667, 0.55088889, 0.58426667, 0.58395556,\n",
              "       0.54893333, 0.55      , 0.55004444, 0.55026667, 0.58382222,\n",
              "       0.58382222, 0.58377778, 0.54164444, 0.53484444, 0.55026667,\n",
              "       0.55031111, 0.55026667, 0.55026667, 0.55035556, 0.55026667,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55026667, 0.55026667,\n",
              "       0.55022222, 0.55026667, 0.55026667, 0.55026667, 0.55026667,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55026667, 0.55026667,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55026667, 0.58382222,\n",
              "       0.58373333, 0.55026667, 0.57506667, 0.55662222, 0.52933333,\n",
              "       0.58377778, 0.58377778, 0.58377778, 0.58377778, 0.58377778,\n",
              "       0.58377778, 0.58377778, 0.58377778, 0.58377778, 0.58377778,\n",
              "       0.58377778, 0.58377778, 0.58377778, 0.58377778, 0.58377778,\n",
              "       0.58377778, 0.58395556, 0.55026667, 0.55026667, 0.55026667,\n",
              "       0.65044444, 0.58511111, 0.55026667, 0.55      , 0.55031111,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55017778, 0.55026667,\n",
              "       0.6344    , 0.64675556, 0.56026667, 0.5932    , 0.56884444,\n",
              "       0.6144    , 0.57671111, 0.55111111, 0.55266667, 0.54977778,\n",
              "       0.55      , 0.54951111, 0.58368889, 0.58337778, 0.58382222,\n",
              "       0.53426667, 0.57595556, 0.54191111, 0.50391111, 0.48222222,\n",
              "       0.48337778, 0.52106667, 0.51702222, 0.48333333, 0.48355556,\n",
              "       0.48435556, 0.48391111, 0.48315556, 0.4832    , 0.48311111,\n",
              "       0.45928889, 0.42248889, 0.42702222, 0.43093333, 0.42844444,\n",
              "       0.48382222, 0.4852    , 0.48413333, 0.47524444, 0.52128889,\n",
              "       0.47946667, 0.5172    , 0.51724444, 0.51662222, 0.52      ,\n",
              "       0.55022222, 0.5444    , 0.46208889, 0.5156    , 0.52071111,\n",
              "       0.51657778, 0.48311111, 0.50671111, 0.48311111, 0.5836    ,\n",
              "       0.56115556, 0.51693333, 0.51791111, 0.52568889, 0.58515556,\n",
              "       0.58822222, 0.6036    , 0.58675556, 0.55022222, 0.5592    ,\n",
              "       0.63235556, 0.62706667, 0.60533333, 0.56924444, 0.5672    ,\n",
              "       0.55      , 0.51693333, 0.51671111, 0.516     , 0.514     ,\n",
              "       0.51377778, 0.546     , 0.55057778, 0.55026667, 0.55044444,\n",
              "       0.57724444, 0.56835556, 0.52088889, 0.528     , 0.5504    ,\n",
              "       0.5504    , 0.55048889, 0.55048889, 0.55062222, 0.55071111,\n",
              "       0.55071111, 0.55071111, 0.55071111, 0.55075556, 0.55075556,\n",
              "       0.5508    , 0.55084444, 0.55088889, 0.55093333, 0.55093333,\n",
              "       0.55093333, 0.55093333, 0.55093333, 0.55088889, 0.55084444,\n",
              "       0.55088889, 0.55088889, 0.55084444, 0.55084444, 0.55084444,\n",
              "       0.55088889, 0.55093333, 0.55093333, 0.55088889, 0.55088889,\n",
              "       0.55088889, 0.55088889, 0.55088889, 0.55088889, 0.55093333,\n",
              "       0.55093333, 0.55097778, 0.55102222, 0.55115556, 0.55173333,\n",
              "       0.55302222, 0.55542222, 0.55848889, 0.56262222, 0.56808889,\n",
              "       0.57168889, 0.57417778, 0.57662222, 0.57893333, 0.58057778,\n",
              "       0.58222222, 0.58395556, 0.58546667, 0.58697778, 0.58875556,\n",
              "       0.59035556, 0.61711111, 0.68488889, 0.68822222, 0.68648889,\n",
              "       0.6852    , 0.68395556, 0.68151111, 0.68102222, 0.68048889,\n",
              "       0.67946667, 0.67862222, 0.67795556, 0.67706667, 0.67657778,\n",
              "       0.67617778, 0.6756    , 0.67506667, 0.67484444, 0.67502222,\n",
              "       0.67502222, 0.67533333, 0.67551111, 0.67577778, 0.67591111,\n",
              "       0.67622222, 0.67657778, 0.67688889, 0.67751111, 0.67822222,\n",
              "       0.6788    , 0.67915556, 0.68      , 0.68057778, 0.68137778,\n",
              "       0.68222222, 0.68311111, 0.68426667, 0.68573333, 0.68977778,\n",
              "       0.6976    , 0.7064    , 0.71595556, 0.72342222, 0.73084444,\n",
              "       0.73582222, 0.73964444, 0.74324444, 0.74644444, 0.7492    ,\n",
              "       0.75124444, 0.75431111, 0.75644444, 0.75893333, 0.7612    ,\n",
              "       0.76342222, 0.76617778, 0.76853333, 0.76991111, 0.772     ,\n",
              "       0.77377778, 0.77515556, 0.77671111, 0.77773333, 0.77871111,\n",
              "       0.77995556, 0.78111111, 0.78217778, 0.7836    , 0.78466667,\n",
              "       0.78613333, 0.7872    , 0.78844444, 0.78955556, 0.79057778,\n",
              "       0.7916    , 0.79213333, 0.79328889, 0.79404444, 0.79475556,\n",
              "       0.79591111, 0.79662222, 0.79737778, 0.79817778, 0.79888889,\n",
              "       0.79964444, 0.8004    , 0.80102222, 0.80173333, 0.80266667,\n",
              "       0.80328889, 0.804     , 0.80493333, 0.8056    , 0.80635556,\n",
              "       0.80688889, 0.80751111, 0.80844444, 0.80902222, 0.80968889,\n",
              "       0.8104    , 0.81088889, 0.81151111, 0.81168889, 0.81235556,\n",
              "       0.8128    , 0.81337778, 0.81413333, 0.81502222, 0.8156    ,\n",
              "       0.81613333, 0.8168    , 0.8172    , 0.81751111, 0.81786667,\n",
              "       0.81831111, 0.81875556, 0.81911111, 0.81946667, 0.81977778,\n",
              "       0.82062222, 0.82115556, 0.8216    , 0.822     , 0.82231111,\n",
              "       0.82275556, 0.82328889, 0.82355556, 0.82391111, 0.82435556,\n",
              "       0.8248    , 0.82528889, 0.82546667, 0.82586667, 0.8264    ,\n",
              "       0.82666667, 0.82724444, 0.82786667, 0.82826667, 0.8284    ,\n",
              "       0.8288    , 0.82915556, 0.82968889, 0.82986667, 0.83022222,\n",
              "       0.83075556, 0.83106667, 0.8316    , 0.83204444, 0.83244444,\n",
              "       0.83275556, 0.83351111, 0.83364444, 0.83413333, 0.83448889,\n",
              "       0.83502222, 0.83546667, 0.83591111, 0.83622222, 0.83631111,\n",
              "       0.83662222, 0.83675556, 0.83702222, 0.83737778, 0.83777778,\n",
              "       0.83826667, 0.83817778, 0.83831111, 0.83857778, 0.83902222,\n",
              "       0.83946667, 0.83986667, 0.84022222, 0.84044444, 0.84048889,\n",
              "       0.84057778, 0.84084444, 0.84088889, 0.84111111, 0.84133333,\n",
              "       0.84137778, 0.84164444, 0.84186667, 0.84208889, 0.84213333,\n",
              "       0.84226667, 0.8424    , 0.84253333, 0.84253333, 0.84257778,\n",
              "       0.84271111, 0.84284444, 0.84302222, 0.84311111, 0.84328889,\n",
              "       0.84328889, 0.84328889, 0.84342222, 0.84351111, 0.84351111,\n",
              "       0.84364444, 0.84373333, 0.84377778, 0.84404444, 0.84431111,\n",
              "       0.84448889, 0.84462222, 0.8448    , 0.84484444, 0.84484444,\n",
              "       0.84502222, 0.84506667, 0.84506667, 0.84511111, 0.84524444,\n",
              "       0.84551111, 0.84555556, 0.84564444, 0.84573333, 0.84577778,\n",
              "       0.84582222, 0.84595556, 0.84608889, 0.84613333, 0.84622222,\n",
              "       0.84626667, 0.8464    , 0.8464    , 0.8464    , 0.84635556,\n",
              "       0.84644444, 0.84648889, 0.84657778, 0.84666667, 0.84662222,\n",
              "       0.84675556, 0.84684444, 0.84684444, 0.84693333, 0.84697778,\n",
              "       0.84706667, 0.84711111, 0.8472    , 0.84715556, 0.84733333,\n",
              "       0.84742222, 0.84755556, 0.84768889, 0.84782222, 0.84782222,\n",
              "       0.84786667, 0.84786667, 0.84782222, 0.84791111, 0.84804444,\n",
              "       0.84813333, 0.84826667, 0.84822222, 0.84826667, 0.84831111,\n",
              "       0.84835556, 0.84831111, 0.84826667, 0.84826667, 0.84831111,\n",
              "       0.84826667, 0.8484    , 0.84835556, 0.84844444, 0.84848889,\n",
              "       0.84866667, 0.84884444, 0.84884444, 0.84893333, 0.84888889,\n",
              "       0.84888889, 0.84888889, 0.84906667, 0.84915556, 0.84915556,\n",
              "       0.84928889, 0.84937778, 0.84946667, 0.84955556, 0.84955556,\n",
              "       0.8496    , 0.84968889, 0.84982222, 0.84977778, 0.84982222,\n",
              "       0.84973333, 0.84968889, 0.84964444, 0.84973333, 0.84986667,\n",
              "       0.84991111, 0.85008889, 0.85013333, 0.85008889, 0.85008889,\n",
              "       0.85013333, 0.85017778, 0.85008889, 0.85008889, 0.85013333,\n",
              "       0.85017778, 0.85026667, 0.85031111, 0.8504    , 0.85044444,\n",
              "       0.85053333, 0.85062222, 0.85066667, 0.85071111, 0.8508    ,\n",
              "       0.85088889, 0.85102222, 0.85097778, 0.85106667, 0.85115556,\n",
              "       0.85124444, 0.85142222, 0.85146667, 0.85164444, 0.85168889,\n",
              "       0.85173333, 0.85177778, 0.85182222, 0.85186667, 0.85195556,\n",
              "       0.85204444, 0.85204444, 0.85213333, 0.85217778, 0.85231111,\n",
              "       0.85213333, 0.85208889, 0.85208889, 0.85217778, 0.85217778,\n",
              "       0.85222222, 0.85222222, 0.85222222, 0.85222222, 0.85222222,\n",
              "       0.85235556, 0.85244444, 0.85262222, 0.85257778, 0.85262222,\n",
              "       0.85262222, 0.85266667, 0.85266667, 0.85266667, 0.85262222,\n",
              "       0.8528    , 0.85293333, 0.85293333, 0.85293333, 0.85288889,\n",
              "       0.85288889, 0.85288889, 0.85293333, 0.85293333, 0.85297778,\n",
              "       0.85302222, 0.85302222, 0.85297778, 0.85302222, 0.85311111,\n",
              "       0.85315556, 0.85315556, 0.8532    , 0.8532    , 0.85315556,\n",
              "       0.85315556, 0.8532    , 0.85324444, 0.85337778, 0.85337778,\n",
              "       0.85337778, 0.85337778, 0.85346667, 0.85346667, 0.85351111,\n",
              "       0.85351111, 0.85355556, 0.8536    , 0.85364444, 0.85364444,\n",
              "       0.85364444, 0.85382222, 0.85377778, 0.85377778, 0.85377778,\n",
              "       0.85386667, 0.85386667, 0.85386667, 0.85395556, 0.85395556,\n",
              "       0.854     , 0.854     , 0.85404444, 0.85404444, 0.85404444,\n",
              "       0.85408889, 0.85408889, 0.85413333, 0.85413333, 0.85413333,\n",
              "       0.85417778, 0.85431111, 0.85426667, 0.85426667, 0.85426667,\n",
              "       0.85431111, 0.85435556, 0.8544    , 0.85453333, 0.85466667,\n",
              "       0.85466667, 0.85466667, 0.85475556, 0.85475556, 0.8548    ,\n",
              "       0.85475556, 0.85475556, 0.8548    , 0.8548    , 0.8548    ,\n",
              "       0.8548    , 0.85484444, 0.8548    , 0.85488889, 0.85488889,\n",
              "       0.85488889, 0.85493333, 0.85506667, 0.85506667, 0.85506667,\n",
              "       0.85506667, 0.85506667, 0.85506667, 0.85515556, 0.85515556])"
            ]
          },
          "execution_count": 27,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "# MPGD with beta = 0.0\n",
        "print('==================== MPGD with beta = 0.0 ================== ')\n",
        "sigma = 0.2\n",
        "mu = 0.2\n",
        "beta = 0.0\n",
        "mean_acc_mpgd = run_exp(option=1, lr=lr, epochs=epochs, start_perturb=0, gamma=0.55, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "\n",
        "# MPGD with perturbations of the form v(y1)-v(y2), where v is the observable and y1 and y2 are independent Thaler iterates\n",
        "print('==== Another MPGD variant ===== ')\n",
        "sigma = 0.2\n",
        "mu = 0.2\n",
        "beta = 0.0\n",
        "mean_acc_mpgd_variant = run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.55, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "\n",
        "# plotting the test accuracy results\n",
        "plt.rcParams[\"figure.figsize\"] = (8,5)\n",
        "plt.rc('font', size=13)\n",
        "plt.rc('axes', titlesize=10) \n",
        "plt.rc('axes', labelsize=20) \n",
        "plt.rc('xtick', labelsize=20) \n",
        "plt.rc('ytick', labelsize=20) \n",
        "plt.rc('legend', fontsize=15) \n",
        "\n",
        "plt.plot(mean_acc_baseline, '-o')\n",
        "plt.plot(mean_acc_gaussian, '--y')\n",
        "plt.plot(mean_acc_mpgd, '-r')\n",
        "plt.plot(mean_acc_mpgd_variant, '-c')\n",
        "plt.legend(['baseline', 'Gaussian', 'MPGD', 'MPGD variant'])\n",
        "plt.show()\n",
        "\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.60, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.65, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.70, beta=beta, sigma=sigma, mu=mu, n_run=n_run)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "WUtF5pugbv5N",
        "outputId": "820c9144-62ae-4b2b-da9b-e235e8a4dfa7"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "==================== MPGD with beta = 0.5 ================== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  1\n",
            "gamma:  0.55 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9437777777777778, 0.9397777777777778, 0.9471111111111111, 0.9484444444444444, 0.632]\n",
            "acc gaps:  [0.012222222222222134, 0.004222222222222127, 0.010888888888888837, 0.013555555555555543, -0.0020000000000000018]\n",
            "Average test acc:  0.8822222222222222\n",
            "Average acc gap:  0.007777777777777728\n",
            "Std dev of test acc:  0.13991858302792812\n",
            "Std dev of acc gap:  0.006539528430916506\n",
            "Maximum test acc:  0.9484444444444444\n",
            "Minimum test acc:  0.632\n",
            "Maximum acc gap:  0.013555555555555543\n",
            "Minimum acc gap:  -0.0020000000000000018\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  1\n",
            "gamma:  0.6 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9271111111111111, 0.9486666666666667, 0.9466666666666667, 0.9371111111111111, 0.954]\n",
            "acc gaps:  [0.012888888888888839, 0.01533333333333331, 0.011333333333333306, 0.020888888888888846, 0.014000000000000012]\n",
            "Average test acc:  0.942711111111111\n",
            "Average acc gap:  0.014888888888888863\n",
            "Std dev of test acc:  0.010645117120939452\n",
            "Std dev of acc gap:  0.0036616126785075677\n",
            "Maximum test acc:  0.954\n",
            "Minimum test acc:  0.9271111111111111\n",
            "Maximum acc gap:  0.020888888888888846\n",
            "Minimum acc gap:  0.011333333333333306\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  1\n",
            "gamma:  0.65 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9531111111111111, 0.9355555555555556, 0.9328888888888889, 0.952, 0.958]\n",
            "acc gaps:  [0.020888888888888846, -0.005555555555555536, 0.013111111111111073, 0.014000000000000012, 0.006000000000000005]\n",
            "Average test acc:  0.9463111111111111\n",
            "Average acc gap:  0.00968888888888888\n",
            "Std dev of test acc:  0.011303446431711326\n",
            "Std dev of acc gap:  0.01002170484005761\n",
            "Maximum test acc:  0.958\n",
            "Minimum test acc:  0.9328888888888889\n",
            "Maximum acc gap:  0.020888888888888846\n",
            "Minimum acc gap:  -0.005555555555555536\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  1\n",
            "gamma:  0.7 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.8884444444444445, 0.7548888888888889, 0.9106666666666666, 0.9211111111111111, 0.8204444444444444]\n",
            "acc gaps:  [-0.0344444444444445, 0.013111111111111073, -0.0006666666666665932, 0.002888888888888941, 0.03355555555555556]\n",
            "Average test acc:  0.8591111111111112\n",
            "Average acc gap:  0.0028888888888888966\n",
            "Std dev of test acc:  0.07021360706646503\n",
            "Std dev of acc gap:  0.024755595451793126\n",
            "Maximum test acc:  0.9211111111111111\n",
            "Minimum test acc:  0.7548888888888889\n",
            "Maximum acc gap:  0.03355555555555556\n",
            "Minimum acc gap:  -0.0344444444444445\n",
            "--------------------------------------\n",
            "==== Another MPGD variant ===== \n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.55 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9437777777777778, 0.8982222222222223, 0.9275555555555556, 0.9571111111111111, 0.93]\n",
            "acc gaps:  [0.004222222222222127, 0.011777777777777776, 0.0004444444444444695, 0.000888888888888828, -0.006000000000000005]\n",
            "Average test acc:  0.9313333333333333\n",
            "Average acc gap:  0.002266666666666639\n",
            "Std dev of test acc:  0.021975856561347915\n",
            "Std dev of acc gap:  0.006477692013916719\n",
            "Maximum test acc:  0.9571111111111111\n",
            "Minimum test acc:  0.8982222222222223\n",
            "Maximum acc gap:  0.011777777777777776\n",
            "Minimum acc gap:  -0.006000000000000005\n",
            "--------------------------------------\n"
          ]
        },
        {
          "data": {
            "image/png": "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65kyZQrJycksWbKEjz/+mJl2/7BmzJjB119/TUBAgM32tm3bWvoEmDx5MlOnTmXcuHG8/PLLzJ8/vx6v2j1kWUaWZSIjIxEVEGvmSFkZl+/dy6tduricrna2qopSg4HgBljmdWN+PhMPH6aDnx/br7iCWG/y4NPS4N574fLL4YMPwFuGFwQChCfvFUybNo3Vq1dbvDBFUVi9ejXTprm3YN9AU2gxPT0dgCVLljB48GAHgTczceJEYmNja+13zJgxTJkyhbffftvlPgkJCcTExDiE9b/99lskSeL48eMA/Pe//2XEiBG0adOG1q1bc8011zhEL2bOnMmgQYNYt24dl112Gf7+/uzevdtpuP7JJ5+kb9++BAcH065dO+644w7Onj1r01+nTp147LHHSExMpF27drRu3Zpp06ZZvPZt27YxceJEADp37owkSXTq1KnW96UpklFRAcC2WiISt//+e72e16gofJidza1HjtA3KIg9Awd6l8Dn5qqLzsgyfP45hLqq7C0QNE2EyHsBt956Kzk5OezYsQOA7du3c+7cOW699Va3jjeLe0xMDAaDgZSUFMaOHVsvto0ZM4acnBzLOey5/fbbycnJ4ccff7TZvmrVKgYOHEi3bt0sNt5111188cUXfPbZZ7Rv356rr76atLQ0h2uZN28eTz31FBs2bKBz585Oz5ubm8vTTz/Nt99+y5IlS0hLS2P06NEONxurV69my5YtvPfee7z22mt88803PP300wBceeWVLFq0CICvvvqKlJQU1q5dW+f3qClg/qEba1l1cm9JSb2ds8Rg4ObDh7n3zz8ZHBLCxn79vKs2fXW1Wqo2K0udKtfLvraXQND0EeF6LyAsLIxx48aRlJTE1VdfTVJSEuPGjSO0Bq/CYDAAkJaWxgMPPEBISAjXXXcd+fn5VFZW0t6uTriiKMhWiVdardatrOd2pmVBc3JynHq5vXv3pl+/fqxatYprrrkGgMrKSpKTk3nuuecs+z3//POWv41GI2PGjGHPnj188sknNm35+fls3ryZAQMG1GjXRx99ZPlblmXi4+Np164dO3bsYOTIkZY2Hx8f1q1bh84Uov79999JSkpi+fLltGrVip49ewJwxRVXeK0XD6AxfZa1pUkGabX1cr6zlZVcf/AgR8rKeLNbN/4ZF+c9WfSgrip3992wYwd8+inEx3vaIoHg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",
            "text/plain": [
              "<Figure size 576x360 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.6 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.948, 0.876, 0.9333333333333333, 0.9284444444444444, 0.9026666666666666]\n",
            "acc gaps:  [-0.008000000000000007, 0.0020000000000000018, 0.006666666666666599, -0.0004444444444443585, -0.004666666666666597]\n",
            "Average test acc:  0.9176888888888889\n",
            "Average acc gap:  -0.0008888888888888725\n",
            "Std dev of test acc:  0.028472902430899203\n",
            "Std dev of acc gap:  0.0057111543448428136\n",
            "Maximum test acc:  0.948\n",
            "Minimum test acc:  0.876\n",
            "Maximum acc gap:  0.006666666666666599\n",
            "Minimum acc gap:  -0.008000000000000007\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.65 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.9684444444444444, 0.9195555555555556, 0.9357777777777778, 0.4162222222222222, 0.9533333333333334]\n",
            "acc gaps:  [0.011555555555555541, -0.0015555555555555323, 0.010222222222222133, -0.00022222222222223476, 0.004666666666666597]\n",
            "Average test acc:  0.8386666666666667\n",
            "Average acc gap:  0.004933333333333301\n",
            "Std dev of test acc:  0.2368668428348888\n",
            "Std dev of acc gap:  0.0059283791218464905\n",
            "Maximum test acc:  0.9684444444444444\n",
            "Minimum test acc:  0.4162222222222222\n",
            "Maximum acc gap:  0.011555555555555541\n",
            "Minimum acc gap:  -0.0015555555555555323\n",
            "--------------------------------------\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "Connected to a GPU\n",
            "Number of trainable parameters:  5601\n",
            "===========> Option:  3\n",
            "gamma:  0.7 , beta:  0.5 , mu:  0.2 , sigma:  0.2\n",
            "test accs:  [0.5837777777777777, 0.7677777777777778, 0.4162222222222222, 0.4162222222222222, 0.5837777777777777]\n",
            "acc gaps:  [0.00022222222222223476, -0.007777777777777772, -0.00022222222222223476, -0.00022222222222223476, 0.00022222222222223476]\n",
            "Average test acc:  0.5535555555555556\n",
            "Average acc gap:  -0.0015555555555555544\n",
            "Std dev of test acc:  0.1461495935803576\n",
            "Std dev of acc gap:  0.0034854193647462475\n",
            "Maximum test acc:  0.7677777777777778\n",
            "Minimum test acc:  0.4162222222222222\n",
            "Maximum acc gap:  0.00022222222222223476\n",
            "Minimum acc gap:  -0.007777777777777772\n",
            "--------------------------------------\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "array([0.55026667, 0.51675556, 0.55026667, 0.51675556, 0.48324444,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.48324444, 0.44973333, 0.44973333, 0.44973333, 0.48346667,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.48324444, 0.43773333, 0.44973333, 0.49204444, 0.50764444,\n",
              "       0.5536    , 0.58377778, 0.58377778, 0.58377778, 0.58377778,\n",
              "       0.58377778, 0.60484444, 0.55026667, 0.51675556, 0.48342222,\n",
              "       0.5152    , 0.5168    , 0.51724444, 0.62084444, 0.51613333,\n",
              "       0.51675556, 0.51675556, 0.5156    , 0.548     , 0.58377778,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55026667, 0.58946667,\n",
              "       0.58386667, 0.55226667, 0.55026667, 0.51928889, 0.61511111,\n",
              "       0.51675556, 0.55044444, 0.5504    , 0.58377778, 0.58391111,\n",
              "       0.55084444, 0.65635556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.48324444, 0.48324444, 0.53315556,\n",
              "       0.54831111, 0.53266667, 0.51675556, 0.54502222, 0.58377778,\n",
              "       0.58537778, 0.52102222, 0.51662222, 0.51675556, 0.5168    ,\n",
              "       0.51675556, 0.51675556, 0.51648889, 0.53035556, 0.51675556,\n",
              "       0.55035556, 0.48382222, 0.43048889, 0.40177778, 0.48311111,\n",
              "       0.48324444, 0.50368889, 0.44964444, 0.48324444, 0.49728889,\n",
              "       0.5196    , 0.48137778, 0.52662222, 0.54057778, 0.5176    ,\n",
              "       0.48342222, 0.47942222, 0.42351111, 0.51955556, 0.51533333,\n",
              "       0.51093333, 0.48151111, 0.48324444, 0.51257778, 0.48324444,\n",
              "       0.42986667, 0.51137778, 0.51991111, 0.51115556, 0.47977778,\n",
              "       0.44862222, 0.46582222, 0.44875556, 0.4756    , 0.47368889,\n",
              "       0.43515556, 0.44755556, 0.48324444, 0.47266667, 0.53937778,\n",
              "       0.5244    , 0.4516    , 0.44973333, 0.46271111, 0.56635556,\n",
              "       0.47675556, 0.5128    , 0.51693333, 0.51737778, 0.48324444,\n",
              "       0.48324444, 0.51173333, 0.4388    , 0.42426667, 0.51671111,\n",
              "       0.51675556, 0.51675556, 0.51697778, 0.56031111, 0.51888889,\n",
              "       0.51577778, 0.44973333, 0.48266667, 0.48324444, 0.48324444,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48324444, 0.44617778,\n",
              "       0.438     , 0.49831111, 0.48346667, 0.48324444, 0.48506667,\n",
              "       0.48346667, 0.46231111, 0.44973333, 0.44973333, 0.47942222,\n",
              "       0.44973333, 0.53471111, 0.48324444, 0.57515556, 0.54991111,\n",
              "       0.51675556, 0.45186667, 0.5168    , 0.51395556, 0.51697778,\n",
              "       0.38346667, 0.44973333, 0.42084444, 0.43168889, 0.48324444,\n",
              "       0.48346667, 0.48324444, 0.48324444, 0.47613333, 0.5168    ,\n",
              "       0.51671111, 0.51657778, 0.51804444, 0.48337778, 0.56528889,\n",
              "       0.48337778, 0.49133333, 0.53382222, 0.47973333, 0.41617778,\n",
              "       0.41617778, 0.50595556, 0.43875556, 0.5052    , 0.51715556,\n",
              "       0.44742222, 0.5392    , 0.60897778, 0.55031111, 0.5384    ,\n",
              "       0.55133333, 0.49906667, 0.53915556, 0.48262222, 0.48275556,\n",
              "       0.5216    , 0.58182222, 0.53395556, 0.56937778, 0.52004444,\n",
              "       0.56204444, 0.58773333, 0.53777778, 0.55057778, 0.57426667,\n",
              "       0.49511111, 0.51528889, 0.5212    , 0.52235556, 0.52413333,\n",
              "       0.54893333, 0.54404444, 0.51751111, 0.56911111, 0.60368889,\n",
              "       0.56937778, 0.57311111, 0.604     , 0.58017778, 0.58395556,\n",
              "       0.61066667, 0.58586667, 0.60902222, 0.63484444, 0.56382222,\n",
              "       0.58582222, 0.522     , 0.56608889, 0.52577778, 0.54444444,\n",
              "       0.56964444, 0.5468    , 0.58333333, 0.60226667, 0.5456    ,\n",
              "       0.61928889, 0.60706667, 0.58115556, 0.67053333, 0.55195556,\n",
              "       0.56706667, 0.56071111, 0.57426667, 0.58111111, 0.54315556,\n",
              "       0.54755556, 0.5228    , 0.53115556, 0.51675556, 0.51675556,\n",
              "       0.51684444, 0.5168    , 0.51671111, 0.51675556, 0.51675556,\n",
              "       0.51662222, 0.55244444, 0.51462222, 0.54293333, 0.51675556,\n",
              "       0.5372    , 0.54871111, 0.51675556, 0.51675556, 0.57768889,\n",
              "       0.52368889, 0.51675556, 0.58008889, 0.51777778, 0.59986667,\n",
              "       0.54684444, 0.51675556, 0.51675556, 0.55088889, 0.55026667,\n",
              "       0.55026667, 0.55017778, 0.54511111, 0.51671111, 0.52026667,\n",
              "       0.52551111, 0.43937778, 0.49417778, 0.49915556, 0.46671111,\n",
              "       0.4868    , 0.48688889, 0.48475556, 0.48768889, 0.48751111,\n",
              "       0.47133333, 0.53564444, 0.54524444, 0.49675556, 0.51884444,\n",
              "       0.48422222, 0.5896    , 0.53431111, 0.44697778, 0.50617778,\n",
              "       0.4368    , 0.5492    , 0.55293333, 0.6572    , 0.52453333,\n",
              "       0.53795556, 0.51577778, 0.51968889, 0.51266667, 0.51666667,\n",
              "       0.48866667, 0.55035556, 0.54391111, 0.55617778, 0.59968889,\n",
              "       0.57124444, 0.60724444, 0.63586667, 0.59462222, 0.61102222,\n",
              "       0.61226667, 0.55982222, 0.57284444, 0.55026667, 0.48182222,\n",
              "       0.55026667, 0.55026667, 0.55026667, 0.55022222, 0.53724444,\n",
              "       0.56577778, 0.53093333, 0.51253333, 0.60222222, 0.48106667,\n",
              "       0.43115556, 0.51275556, 0.49293333, 0.48257778, 0.48311111,\n",
              "       0.48142222, 0.51675556, 0.49417778, 0.55324444, 0.52644444,\n",
              "       0.49506667, 0.50471111, 0.49231111, 0.49337778, 0.49133333,\n",
              "       0.49782222, 0.49742222, 0.53595556, 0.51137778, 0.51444444,\n",
              "       0.41724444, 0.51293333, 0.51568889, 0.458     , 0.49453333,\n",
              "       0.4596    , 0.4964    , 0.54764444, 0.4828    , 0.48346667,\n",
              "       0.49275556, 0.51062222, 0.48395556, 0.48155556, 0.4668    ,\n",
              "       0.52577778, 0.51093333, 0.51      , 0.48133333, 0.45862222,\n",
              "       0.4496    , 0.48093333, 0.43355556, 0.44684444, 0.44066667,\n",
              "       0.46404444, 0.48266667, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.46311111, 0.48324444, 0.48324444, 0.48324444, 0.48324444,\n",
              "       0.48324444, 0.48533333, 0.4656    , 0.4716    , 0.48324444,\n",
              "       0.48328889, 0.48302222, 0.45666667, 0.45804444, 0.48324444,\n",
              "       0.4608    , 0.43533333, 0.48737778, 0.43955556, 0.45257778,\n",
              "       0.4832    , 0.48324444, 0.48324444, 0.48404444, 0.51564444,\n",
              "       0.48324444, 0.47697778, 0.50177778, 0.50106667, 0.51657778,\n",
              "       0.53351111, 0.48306667, 0.48324444, 0.48315556, 0.46786667,\n",
              "       0.57346667, 0.51688889, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51608889, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.5168    , 0.48324444,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48324444, 0.48346667,\n",
              "       0.48324444, 0.48324444, 0.48324444, 0.48351111, 0.48324444,\n",
              "       0.48448889, 0.44968889, 0.41662222, 0.41071111, 0.47946667,\n",
              "       0.47782222, 0.45604444, 0.42293333, 0.51702222, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.51675556, 0.51675556,\n",
              "       0.51675556, 0.51675556, 0.51675556, 0.5168    , 0.5168    ,\n",
              "       0.5168    , 0.5168    , 0.5168    , 0.5168    , 0.5168    ,\n",
              "       0.5168    , 0.5168    , 0.5168    , 0.5168    , 0.5168    ,\n",
              "       0.5168    , 0.5168    , 0.5168    , 0.5168    , 0.5168    ,\n",
              "       0.51684444, 0.51684444, 0.51684444, 0.51684444, 0.51684444,\n",
              "       0.51684444, 0.51684444, 0.51684444, 0.51684444, 0.51684444,\n",
              "       0.51684444, 0.51684444, 0.51684444, 0.51684444, 0.51684444,\n",
              "       0.51684444, 0.51684444, 0.51688889, 0.51688889, 0.51688889,\n",
              "       0.51688889, 0.51688889, 0.51688889, 0.51688889, 0.51688889,\n",
              "       0.51688889, 0.51688889, 0.51688889, 0.51688889, 0.51688889,\n",
              "       0.51688889, 0.51688889, 0.51688889, 0.51688889, 0.51688889,\n",
              "       0.51688889, 0.51688889, 0.51688889, 0.51688889, 0.51688889,\n",
              "       0.51693333, 0.51693333, 0.51693333, 0.51697778, 0.51697778,\n",
              "       0.51697778, 0.51697778, 0.51697778, 0.51697778, 0.51697778,\n",
              "       0.51697778, 0.51697778, 0.51697778, 0.51697778, 0.51697778,\n",
              "       0.51697778, 0.51702222, 0.51702222, 0.51702222, 0.51702222,\n",
              "       0.51702222, 0.51702222, 0.51715556, 0.51724444, 0.51733333,\n",
              "       0.51742222, 0.5176    , 0.51773333, 0.51791111, 0.51804444,\n",
              "       0.51826667, 0.51853333, 0.51884444, 0.51893333, 0.51906667,\n",
              "       0.5192    , 0.51924444, 0.51955556, 0.51991111, 0.52026667,\n",
              "       0.52048889, 0.5208    , 0.52106667, 0.52151111, 0.52195556,\n",
              "       0.52235556, 0.52284444, 0.52311111, 0.52351111, 0.52386667,\n",
              "       0.5244    , 0.52462222, 0.52493333, 0.52533333, 0.52555556,\n",
              "       0.52582222, 0.52608889, 0.52648889, 0.52684444, 0.52742222,\n",
              "       0.52782222, 0.52808889, 0.52857778, 0.52888889, 0.52928889,\n",
              "       0.52977778, 0.53004444, 0.5304    , 0.53106667, 0.5316    ,\n",
              "       0.532     , 0.53248889, 0.53306667, 0.53368889, 0.53404444,\n",
              "       0.53448889, 0.53502222, 0.53542222, 0.53582222, 0.53608889,\n",
              "       0.53666667, 0.53728889, 0.53751111, 0.53813333, 0.53862222,\n",
              "       0.53915556, 0.53973333, 0.54026667, 0.54088889, 0.54137778,\n",
              "       0.54204444, 0.54271111, 0.54337778, 0.54404444, 0.54453333,\n",
              "       0.54511111, 0.54568889, 0.54617778, 0.54693333, 0.54773333,\n",
              "       0.54857778, 0.54897778, 0.54955556, 0.55026667, 0.55088889,\n",
              "       0.55151111, 0.55182222, 0.5524    , 0.5528    , 0.55355556])"
            ]
          },
          "execution_count": 6,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "# MPGD with beta = 0.5\n",
        "print('==================== MPGD with beta = 0.5 ================== ')\n",
        "sigma = 0.2\n",
        "mu = 0.2\n",
        "beta = 0.5\n",
        "mean_acc_mpgd_beta05 = run_exp(option=1, lr=lr, epochs=epochs, start_perturb=0, gamma=0.55, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=1, lr=lr, epochs=epochs, start_perturb=0, gamma=0.60, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=1, lr=lr, epochs=epochs, start_perturb=0, gamma=0.65, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=1, lr=lr, epochs=epochs, start_perturb=0, gamma=0.70, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "\n",
        "# MPGD with perturbations of the form v(y1)-v(y2), where v is the observable and y1 and y2 are independent Thaler iterates\n",
        "print('==== Another MPGD variant ===== ')\n",
        "sigma = 0.2\n",
        "mu = 0.2\n",
        "beta = 0.5\n",
        "mean_acc_mpgd_variant_beta05 = run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.55, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "\n",
        "# plotting the test accuracy results\n",
        "plt.rcParams[\"figure.figsize\"] = (8,5)\n",
        "plt.rc('font', size=13)\n",
        "plt.rc('axes', titlesize=10) \n",
        "plt.rc('axes', labelsize=20) \n",
        "plt.rc('xtick', labelsize=20) \n",
        "plt.rc('ytick', labelsize=20) \n",
        "plt.rc('legend', fontsize=15) \n",
        "\n",
        "plt.plot(mean_acc_baseline, '-o')\n",
        "plt.plot(mean_acc_gaussian, '--y')\n",
        "plt.plot(mean_acc_mpgd_beta05, '-r')\n",
        "plt.plot(mean_acc_mpgd_variant_beta05, '-c')\n",
        "plt.legend(['baseline', 'Gaussian', 'MPGD', 'MPGD variant'])\n",
        "plt.show()\n",
        "\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.60, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.65, beta=beta, sigma=sigma, mu=mu, n_run=n_run)\n",
        "run_exp(option=3, lr=lr, epochs=epochs, start_perturb=0, gamma=0.70, beta=beta, sigma=sigma, mu=mu, n_run=n_run)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "gjlzLRq92WPh"
      },
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "collapsed_sections": [],
      "name": "ecg_classification_mlps.ipynb",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
