{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "5fG7YlZk38Hk"
   },
   "outputs": [],
   "source": [
    "from typing import Tuple, Optional, Union, Callable\n",
    "from typing_extensions import Literal\n",
    "import math\n",
    "\n",
    "import numpy as np\n",
    "from scipy.stats import ortho_group  # type: ignore\n",
    "\n",
    "Transform = Literal[\"cosine\", \"polynomial\"]\n",
    "\n",
    "Dataset = Tuple[np.ndarray, np.ndarray]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "!pip3 install pyscnn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ifpo8q3B1tlM"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from scnn.private.utils.data import gen_classification_data, gen_regression_data\n",
    "\n",
    "\n",
    "from scnn.models import ConvexGatedReLU, ConvexReLU\n",
    "from scnn.solvers import RFISTA, AL, LeastSquaresSolver, CVXPYSolver, ApproximateConeDecomposition\n",
    "from scnn.regularizers import NeuronGL1, L2, L1, FeatureGL1\n",
    "from scnn.metrics import Metrics\n",
    "from scnn.activations import sample_gate_vectors\n",
    "from scnn.optimize import optimize_model, optimize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "HFmj3toLxZym"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torchvision\n",
    "from torch import nn, optim\n",
    "import torch.nn.functional as F\n",
    "from torchvision import datasets, transforms\n",
    "from torch.autograd import Variable\n",
    "from torch.utils.data.sampler import Sampler\n",
    "import matplotlib.pyplot as plt\n",
    "import random\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "!nvidia-smi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "DQ97qiMG26ra",
    "outputId": "2f61d2ca-08c2-4e65-e713-719a9f131710"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n"
     ]
    }
   ],
   "source": [
    "device = torch.device('cuda:1' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(torch.cuda.get_device_name(device))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "# Manually compute output from non-convex weights for sanity check:\n",
    "def gated_relu_prediction(X, gates, W1, W2):\n",
    "    \"\"\"\n",
    "    Compute the prediction of a Gated ReLU network.\n",
    "\n",
    "    Args:\n",
    "    - X: Input tensor of shape (N, D), where N is the number of samples and D is the number of features.\n",
    "    - gates: Gate vectors tensor of shape (D, P), where P is the number of neurons in the hidden layer.\n",
    "    - W1: First layer weights of shape (P, D).\n",
    "    - W2: Second layer weights of shape (C, P), where C is the output dimension.\n",
    "\n",
    "    Returns:\n",
    "    - Output predictions of shape (N, C).\n",
    "    \"\"\"\n",
    "    # Step 1: Compute the intermediate activations (X * W1^T)\n",
    "    intermediate_activations = torch.mm(X, W1.T)  # Shape: (N, P)\n",
    "\n",
    "    # Step 2: Compute the gates activation (should be on X against the gates, then determine the gating on neurons)\n",
    "    gate_activations = torch.mm(X, gates) > 0  # Shape: (N, P)\n",
    "\n",
    "    # Step 3: Apply gating to intermediate activations\n",
    "    gated_activations = intermediate_activations * gate_activations.float()  # Element-wise multiplication\n",
    "\n",
    "    # Step 4: Compute the final output using W2\n",
    "    output = torch.mm(gated_activations, W2.T)  # Shape: (N, C)\n",
    "\n",
    "    return gated_activations, output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def count_effective_entries(W1, sparse_W2, p, hidden_dim):\n",
    "    \"\"\"\n",
    "    Calculate the number of contributing elements in W1 given W1 and sparse_W2.\n",
    "\n",
    "    Args:\n",
    "    - W1 (torch.Tensor): First layer weights of shape (P, D).\n",
    "    - sparse_W2 (torch.Tensor): Sparse second layer weights of shape (C, P).\n",
    "    - p (int): Number of smaller matrices concatenated in W1 and sparse_W2.\n",
    "    - hidden_dim (int): Hidden dimension of the smaller matrices.\n",
    "\n",
    "    Returns:\n",
    "    - int: Number of contributing elements in W1.\n",
    "    \"\"\"\n",
    "\n",
    "    num_contributing_elements = 0\n",
    "    \n",
    "    for i in range(p):\n",
    "        # Extract the i-th smaller matrices from W1 and sparse_W2\n",
    "        W1_i = W1[i * hidden_dim: (i + 1) * hidden_dim]\n",
    "        sparse_W2_i = sparse_W2[:, i * hidden_dim: (i + 1) * hidden_dim]\n",
    "\n",
    "        # Find the non-zero indices in the i-th smaller matrix of sparse_W2\n",
    "        non_zero_indices_W2 = sparse_W2_i.nonzero(as_tuple=False)\n",
    "\n",
    "        # Find the unique column indices (corresponding to elements in W1_i)\n",
    "        unique_indices_W2 = non_zero_indices_W2[:, 1].unique()\n",
    "\n",
    "        # Extract relevant columns in W1_i\n",
    "        contributing_W1_i = W1_i[unique_indices_W2]\n",
    "\n",
    "        # Count the non-zero elements in the extracted relevant columns\n",
    "        num_contributing_elements += contributing_W1_i.nonzero(as_tuple=False).size(0)\n",
    "\n",
    "    return num_contributing_elements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "N4UwG3fbIdmw",
    "outputId": "036bb96d-1545-454a-d98a-4d90d650fd42"
   },
   "outputs": [],
   "source": [
    "import torchvision.models as models\n",
    "\n",
    "# Put your Full-Fine-Tuned ResNet18 checkpoint here.\n",
    "# Due to the size limit on the supplementary material, we are not able to provide the checkpoint here.\n",
    "# But we will provide the checkpoint on our github repository once the review period is over.\n",
    "\n",
    "checkpoint = torch.load('./fft_testloss_0.562552809715271_testacc_81.0')\n",
    "orig_model = torchvision.models.resnet18(pretrained=True).to(device)\n",
    "orig_model.fc = nn.Linear(512, 2).to(device)\n",
    "orig_model.load_state_dict(checkpoint['model_state_dict'])\n",
    "orig_model.eval()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Create Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "wFNwjxyx1GYB",
    "outputId": "81856595-75d9-4344-ffc6-f1b16d9878ff"
   },
   "outputs": [],
   "source": [
    "!unzip ./TinyImageNet2Classes.zip -d ./data/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test  train  val\n"
     ]
    }
   ],
   "source": [
    "!ls ./data/TinyImageNet2Classes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "PUXYwua428If"
   },
   "outputs": [],
   "source": [
    "data_dir = \"./data/TinyImageNet2Classes\"\n",
    "num_workers = {\"train\": 4, \"val\": 1, \"test\": 1}\n",
    "data_transforms = {\n",
    "    \"train\": transforms.Compose(\n",
    "        [\n",
    "            transforms.Resize(32),\n",
    "            transforms.RandomRotation(20),\n",
    "            transforms.RandomHorizontalFlip(0.5),\n",
    "            transforms.ToTensor(),\n",
    "            # transforms.Normalize([0.4802, 0.4481, 0.3975], [0.2302, 0.2265, 0.2262]),\n",
    "            transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),\n",
    "        ]\n",
    "    ),\n",
    "    \"val\": transforms.Compose(\n",
    "        [\n",
    "            transforms.Resize(32),\n",
    "            transforms.ToTensor(),\n",
    "            # transforms.Normalize([0.4802, 0.4481, 0.3975], [0.2302, 0.2265, 0.2262]),\n",
    "            transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),\n",
    "        ]\n",
    "    ),\n",
    "    \"test\": transforms.Compose(\n",
    "        [\n",
    "            transforms.Resize(32),\n",
    "            transforms.ToTensor(),\n",
    "            # transforms.Normalize([0.4802, 0.4481, 0.3975], [0.2302, 0.2265, 0.2262]),\n",
    "            transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),\n",
    "        ]\n",
    "    ),\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "uOWCRoq5V1T8"
   },
   "outputs": [],
   "source": [
    "train_dataset = datasets.ImageFolder(os.path.join(data_dir, \"train\"), data_transforms[\"train\"])\n",
    "val_dataset = datasets.ImageFolder(os.path.join(data_dir, \"val\"), data_transforms[\"val\"])\n",
    "test_dataset = datasets.ImageFolder(os.path.join(data_dir, \"test\"), data_transforms[\"test\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "xFrpm42RYDMH"
   },
   "outputs": [],
   "source": [
    "num_classes = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "-CZuuR2DLQsn"
   },
   "outputs": [],
   "source": [
    "merged_test_dataset = torch.utils.data.ConcatDataset([val_dataset, test_dataset])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "J3817JAOLTG0"
   },
   "outputs": [],
   "source": [
    "batch_size = 256\n",
    "epochs = 100\n",
    "test_stats_epochs = 5\n",
    "lr = 0.001\n",
    "gamma = 0.7\n",
    "log_interval = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "v8X8J7bmFZ55"
   },
   "outputs": [],
   "source": [
    "train_loader = torch.utils.data.DataLoader(train_dataset, batch_size = batch_size, num_workers = 2, pin_memory = True, shuffle=True)\n",
    "validation_loader = torch.utils.data.DataLoader(train_dataset, batch_size = batch_size, num_workers = 2, pin_memory = True, shuffle = False)\n",
    "test_loader = torch.utils.data.DataLoader(merged_test_dataset, batch_size = batch_size, num_workers = 1, pin_memory = True, shuffle = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "__3GkWOXn8z3"
   },
   "outputs": [],
   "source": [
    "class_names = ('German shepherd',\n",
    "               'Tabby cat')\n",
    "\n",
    "num_classes = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "xmtYWBFIIdm1",
    "outputId": "d6298e52-c4ea-47f2-f329-2cf846245e7d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Input image shape torch.Size([256, 3, 32, 32])\n",
      "Layer1 Input torch.Size([256, 64, 8, 8])\n",
      "Layer2 Input torch.Size([256, 64, 8, 8])\n",
      "Layer3 Input torch.Size([256, 128, 4, 4])\n",
      "Layer3 Output torch.Size([256, 256, 2, 2])\n",
      "Layer4 Output torch.Size([256, 512, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "def inspect_shapes(model, x):\n",
    "        print(\"Input image shape\", x.shape)\n",
    "        out = model.conv1(x)\n",
    "        out = model.bn1(out)\n",
    "        out = model.relu(out)\n",
    "        out = model.maxpool(out)\n",
    "        print(\"Layer1 Input\", out.shape)\n",
    "        out = model.layer1(out)\n",
    "        print(\"Layer2 Input\", out.shape)\n",
    "        out = model.layer2(out)\n",
    "        print(\"Layer3 Input\", out.shape)\n",
    "        out = model.layer3(out)\n",
    "        print(\"Layer3 Output\", out.shape)\n",
    "        out = model.layer4(out)\n",
    "        print(\"Layer4 Output\", out.shape)\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for data in validation_loader:\n",
    "\n",
    "        images, labels = data\n",
    "        images, labels = images.to(device), labels.to(device)\n",
    "\n",
    "        inspect_shapes(orig_model, images)\n",
    "\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "922JhWo5IdnB",
    "outputId": "7ef04087-74a5-49e5-af77-7e610594d752"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch.utils.hooks.RemovableHandle at 0x7f14ac257b50>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "activation = {}\n",
    "def get_activation(name):\n",
    "    def hook(model, input, output):\n",
    "        activation[name] = output.to(device)\n",
    "    return hook\n",
    "\n",
    "orig_model.maxpool.register_forward_hook(get_activation('layer0'))\n",
    "orig_model.layer1.register_forward_hook(get_activation('layer1'))\n",
    "orig_model.layer2.register_forward_hook(get_activation('layer2'))\n",
    "orig_model.layer3.register_forward_hook(get_activation('layer3'))\n",
    "orig_model.layer4.register_forward_hook(get_activation('layer4'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Hai6rBHJ-j33"
   },
   "outputs": [],
   "source": [
    "import copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "2N1z9U2H79RB"
   },
   "outputs": [],
   "source": [
    "X_train = []\n",
    "y_train = []\n",
    "\n",
    "for batch_idx, (data, target) in enumerate(train_loader):\n",
    "    data, target = data.to(device), target.to(device)\n",
    "\n",
    "    _ = orig_model(data.to(device))\n",
    "\n",
    "    x = activation[\"layer3\"].detach()\n",
    "    y = 2*target - 1\n",
    "\n",
    "    if batch_idx == 0:\n",
    "        X_train = copy.deepcopy(x)\n",
    "        y_train = copy.deepcopy(y)\n",
    "\n",
    "    else:\n",
    "        X_train = torch.cat((X_train, x), 0)\n",
    "        y_train = torch.cat((y_train, y), 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "r6PTVXZ6_C9s"
   },
   "outputs": [],
   "source": [
    "X_test = []\n",
    "y_test = []\n",
    "\n",
    "for batch_idx, (data, target) in enumerate(test_loader):\n",
    "    data, target = data.to(device), target.to(device)\n",
    "\n",
    "    _ = orig_model(data.to(device))\n",
    "\n",
    "    x = activation[\"layer3\"].detach()\n",
    "    y = 2*target - 1\n",
    "\n",
    "    if batch_idx == 0:\n",
    "        X_test = copy.deepcopy(x)\n",
    "        y_test = copy.deepcopy(y)\n",
    "\n",
    "    else:\n",
    "        X_test = torch.cat((X_test, x), 0)\n",
    "        y_test = torch.cat((y_test, y), 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "TfHibCsF80ik",
    "outputId": "e3c36d8f-5a76-4569-f516-a1f7a343bf86"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1000, 256, 2, 2])\n",
      "torch.Size([1000])\n",
      "torch.Size([100, 256, 2, 2])\n",
      "torch.Size([100])\n"
     ]
    }
   ],
   "source": [
    "print(X_train.shape)\n",
    "print(y_train.shape)\n",
    "print(X_test.shape)\n",
    "print(y_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "rlDkR8kv_4jR"
   },
   "outputs": [],
   "source": [
    "X_train_SCNN = torch.reshape(X_train, (len(X_train), -1))\n",
    "y_train_SCNN = torch.reshape(y_train, (len(y_train), -1))\n",
    "X_test_SCNN = torch.reshape(X_test, (len(X_test), -1))\n",
    "y_test_SCNN = torch.reshape(y_test, (len(y_test), -1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "IL72ACAw_7op",
    "outputId": "eda77b2d-e090-40d5-bcbe-0069031f6ec8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1000, 256, 2, 2])\n",
      "torch.Size([1000, 1024])\n"
     ]
    }
   ],
   "source": [
    "print(X_train.shape)\n",
    "print(X_train_SCNN.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "a5YEfc5hR2IZ",
    "outputId": "31fbd25c-bd98-4954-c3d7-7a9fe5aac6c5"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True\n"
     ]
    }
   ],
   "source": [
    "print(torch.equal(torch.reshape(X_train_SCNN, X_train.shape), X_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "W4GWdwkLAWZd",
    "outputId": "eafedf56-1c94-4a01-addb-aeadc699fa78"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1000, 1024])\n",
      "torch.Size([1000, 1])\n",
      "torch.Size([100, 1024])\n",
      "torch.Size([100, 1])\n"
     ]
    }
   ],
   "source": [
    "print(X_train_SCNN.shape)\n",
    "print(y_train_SCNN.shape)\n",
    "print(X_test_SCNN.shape)\n",
    "print(y_test_SCNN.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn import preprocessing\n",
    "scaler = preprocessing.StandardScaler().fit(X_train_SCNN.cpu().numpy())\n",
    "X_train_SCNN = torch.from_numpy(scaler.transform(X_train_SCNN.cpu().numpy())).to(device)\n",
    "X_test_SCNN =  torch.from_numpy(scaler.transform(X_test_SCNN.cpu().numpy())).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "def accuracy(logits, y):\n",
    "    return np.sum((np.sign(logits) == y)) / len(y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Different Convex Optimization Routine Runs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Running R-FISTA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "id": "6t-D4VPF-pbm"
   },
   "outputs": [],
   "source": [
    "# lam = 5e-4\n",
    "lam = 1e-4\n",
    "max_neurons = 50\n",
    "G = sample_gate_vectors(123, X_train_SCNN.shape[-1], max_neurons)\n",
    "metrics = Metrics(metric_freq=25, model_loss=True, train_accuracy=True, train_mse=True, test_mse=True, test_accuracy=True, neuron_sparsity=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "id": "qa36vU5HIgmj"
   },
   "outputs": [],
   "source": [
    "# Instantiate convex model and other options.\n",
    "model = ConvexGatedReLU(G, c=y_train_SCNN.shape[-1])\n",
    "solver = RFISTA(model)\n",
    "regularizer = L1(lam)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 191,
     "referenced_widgets": [
      "f74d01cb96c54da6bd8475d8cfee0d1f",
      "7a44fb277f314c61a3c8ccb0ef9ce302",
      "a2414210eabc4c24a8c41856a1635975",
      "1bb01749d62849a78aec02198c4bb3d3",
      "d88e29cb4fce4f60bc7ccdf25fc8e207",
      "e6c26b488f184ca981f9a240bb38ed5a",
      "ba11766b65be480196f8ae3e06a762b6",
      "9292d0a5da4d4a8e86a230796281277b",
      "0456cd6949c848009d9d9beddb5e387f",
      "845e490060da4382899500d2aea2f340",
      "92351eda4dfd4583aeecb0d45c175e8e"
     ]
    },
    "id": "xcwR0mY4EPvr",
    "outputId": "377e41ce-5b9a-4e3d-b336-cadefb763005"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2014954388141632, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|▏                                                                                                                                            | 10/10000 [00:00<01:40, 99.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.2014954388141632, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▋                                                                                                                                           | 47/10000 [00:00<01:25, 116.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07149340212345123, Train Set grad_norm: 9.718941146275029e-05, Train Set base_objective: 0.07149340212345123, Train Set accuracy: 1.0, Train Set squared_error: 0.014640643261373043, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 492.88861083984375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|█                                                                                                                                           | 72/10000 [00:00<01:23, 119.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0581183135509491, Train Set grad_norm: 7.5833195296581835e-06, Train Set base_objective: 0.0581183135509491, Train Set accuracy: 1.0, Train Set squared_error: 0.010168191976845264, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 514.3170166015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|█                                                                                                                                           | 72/10000 [00:00<01:23, 119.11it/s]INFO:scnn:Termination criterion satisfied at iteration 77/10000. Exiting optimization loop.\n",
      "fista:   1%|█                                                                                                                                           | 77/10000 [00:00<01:25, 116.20it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05373897776007652, Train Set grad_norm: 9.68731342254614e-07, Train Set base_objective: 0.05373897776007652, Train Set accuracy: 1.0, Train Set squared_error: 0.009679777547717094, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 523.9263305664062, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0539410226047039, Train Set grad_norm: 1.5252988987413119e-06, Train Set base_objective: 0.0539410226047039, Train Set accuracy: 1.0, Train Set squared_error: 0.009765961207449436, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 522.7802734375, group_sparsity: 0.0, \n"
     ]
    }
   ],
   "source": [
    "grelu_model, grelu_metrics = optimize_model(\n",
    "    model,\n",
    "    solver,\n",
    "    metrics,\n",
    "    X_train_SCNN.cpu().numpy(),\n",
    "    y_train_SCNN.cpu().numpy(),\n",
    "    X_test_SCNN.cpu().numpy(),\n",
    "    y_test_SCNN.cpu().numpy(),\n",
    "    regularizer=regularizer,\n",
    "    verbose=True,\n",
    "    device='cuda',\n",
    "    # return_convex=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Z19_h-eIJKSd",
    "outputId": "a3174cb1-16c2-4f27-a4f4-c43dad6768e6"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter Shape:  (50, 1024)\n",
      "#Non-zero entries:  5087\n",
      "Total number of parameters:  51200\n",
      "\n",
      "\n",
      "Parameter Shape:  (1, 50)\n",
      "#Non-zero entries:  50\n",
      "Total number of parameters:  50\n",
      "\n",
      "\n",
      "0.32783474028110504\n"
     ]
    }
   ],
   "source": [
    "for p in grelu_model.get_parameters():\n",
    "    print(\"Parameter Shape: \", p.shape)\n",
    "    print(\"#Non-zero entries: \", np.count_nonzero(p))\n",
    "    print(\"Total number of parameters: \", np.size(p))\n",
    "    print(\"\\n\")\n",
    "\n",
    "print(grelu_metrics.time[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100, 1)\n",
      "0.76\n"
     ]
    }
   ],
   "source": [
    "output = grelu_model(X_test_SCNN.cpu().numpy())\n",
    "print(output.shape)\n",
    "print(accuracy(grelu_model(X_test_SCNN.cpu().numpy()), y_test_SCNN.cpu().numpy()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.06887987 0.08263207 0.08563996 0.08840759 0.09116394 0.09438964\n",
      " 0.09716244 0.09990224 0.1027632  0.1080031  0.11087567 0.11400902\n",
      " 0.1167825  0.11955282 0.12232688 0.12521036 0.12796065 0.13072017\n",
      " 0.13591903 0.13865909 0.14150767 0.14424345 0.14708535 0.15037264\n",
      " 0.15349148 0.15639109 0.1616773  0.16756915 0.17034138 0.1731529\n",
      " 0.17592726 0.17867826 0.18155684 0.18431903 0.18707163 0.18983841\n",
      " 0.19296521 0.19585402 0.19859823 0.20439873 0.20797117 0.21070161\n",
      " 0.21356914 0.21631336 0.21904976 0.22180197 0.22453161 0.22740674\n",
      " 0.23052882 0.23327554 0.2360521  0.24137385 0.24427879 0.24703817\n",
      " 0.24980275 0.2574487  0.26031715 0.26306293 0.26580379 0.2686726\n",
      " 0.27182148 0.27458165 0.27731904 0.28006602 0.28298842 0.28574058\n",
      " 0.2885084  0.29126593 0.29400209 0.29686365 0.30157677 0.30642387\n",
      " 0.30925054 0.31235336 0.31511159 0.31841726 0.32384274 0.32663463\n",
      " 0.32783474]\n",
      "79\n",
      "0\n"
     ]
    }
   ],
   "source": [
    "print(grelu_metrics.time)\n",
    "print(len(grelu_metrics.time))\n",
    "print(np.argmin(grelu_metrics.test_mse))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Running Approximate Cone Decomposition"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2014954388141632, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|▏                                                                                                                                             | 9/10000 [00:00<01:57, 85.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.2014954388141632, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▋                                                                                                                                           | 46/10000 [00:00<01:29, 111.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07149340212345123, Train Set grad_norm: 9.718941146275029e-05, Train Set base_objective: 0.07149340212345123, Train Set accuracy: 1.0, Train Set squared_error: 0.014640643261373043, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 492.88861083984375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▉                                                                                                                                           | 70/10000 [00:00<01:27, 112.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0581183135509491, Train Set grad_norm: 7.5833195296581835e-06, Train Set base_objective: 0.0581183135509491, Train Set accuracy: 1.0, Train Set squared_error: 0.010168191976845264, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 514.3170166015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▉                                                                                                                                           | 70/10000 [00:00<01:27, 112.93it/s]INFO:scnn:Termination criterion satisfied at iteration 77/10000. Exiting optimization loop.\n",
      "fista:   1%|█                                                                                                                                           | 77/10000 [00:00<01:30, 109.62it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 53.77751922607422, Train Set grad_norm: 1077.8941650390625, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0539410226047039, Train Set grad_norm: 1.5252988987413119e-06, Train Set base_objective: 0.0539410226047039, Train Set accuracy: 1.0, Train Set squared_error: 0.009765961207449436, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 522.7802734375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▎                                                                                                                                | 28/10000 [00:00<00:36, 272.16it/s]INFO:scnn:Termination criterion satisfied at iteration 50/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▋                                                                                                                                | 50/10000 [00:00<00:34, 289.26it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0859185550771144e-08, Train Set grad_norm: 7.369351656683065e-11, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 53.77751922607422, Train Set grad_norm: 1077.8941650390625, \n",
      "Train Set objective: 0.04470585286617279, Train Set grad_norm: 0.02009955421090126, \n",
      "Train Set objective: 1.0859185550771144e-08, Train Set grad_norm: 7.369351656683065e-11, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5621762275695801, Train Set grad_norm: 0.0011748853139579296, Train Set base_objective: 0.5621762275695801, Train Set accuracy: 1.0, Train Set squared_error: 0.009679777547717094, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 480.8888854980469, group_sparsity: 0.0, \n"
     ]
    }
   ],
   "source": [
    "model = ConvexGatedReLU(G) # start with a Gated ReLU model; a ReLU model will be output.\n",
    "solver = ApproximateConeDecomposition(model)\n",
    "cd_model, cd_metrics = optimize_model(\n",
    "    model,\n",
    "    solver,\n",
    "    metrics,\n",
    "    X_train_SCNN.cpu().numpy(),\n",
    "    y_train_SCNN.cpu().numpy(),\n",
    "    X_test_SCNN.cpu().numpy(),\n",
    "    y_test_SCNN.cpu().numpy(),\n",
    "    regularizer=regularizer,\n",
    "    verbose=True,\n",
    "    device='cuda',\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter Shape:  (100, 1024)\n",
      "#Non-zero entries:  102400\n",
      "Total number of parameters:  102400\n",
      "\n",
      "\n",
      "Parameter Shape:  (1, 100)\n",
      "#Non-zero entries:  100\n",
      "Total number of parameters:  100\n",
      "\n",
      "\n",
      "0.45165572687983513\n"
     ]
    }
   ],
   "source": [
    "for p in cd_model.get_parameters():\n",
    "    print(\"Parameter Shape: \", p.shape)\n",
    "    print(\"#Non-zero entries: \", np.count_nonzero(p))\n",
    "    print(\"Total number of parameters: \", np.size(p))\n",
    "    print(\"\\n\")\n",
    "\n",
    "print(cd_metrics.time[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.76\n"
     ]
    }
   ],
   "source": [
    "print(accuracy(cd_model(X_test_SCNN.cpu().numpy()), y_test_SCNN.cpu().numpy()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.15987232327461243, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                                                                                           | 7/10000 [00:00<02:32, 65.60it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 8/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                                                                                           | 8/10000 [00:00<02:30, 66.56it/s]\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:00<20:55,  7.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.15987232327461243, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:00<20:55,  7.96it/s]\n",
      "Inner al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48877957463264465, Train Set grad_norm: 0.0009836016688495874, Train Set base_objective: 0.47993236780166626, Train Set accuracy: 0.8980000615119934, Train Set squared_error: 0.9397047758102417, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 1.114677906036377, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                                                                                           | 5/10000 [00:00<02:57, 56.32it/s]\n",
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:00<20:55,  7.96it/s]\n",
      "Inner al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                                                                                           | 7/10000 [00:00<02:27, 67.96it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4935469329357147, Train Set grad_norm: 0.0008085654699243605, Train Set base_objective: 0.487579882144928, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.960101842880249, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.7924304008483887, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▏                                                                                                                                         | 16/10000 [00:00<02:06, 79.22it/s]\u001b[A\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:00<20:55,  7.96it/s]\n",
      "Inner al:   0%|▎                                                                                                                                         | 25/10000 [00:00<02:02, 81.11it/s]\u001b[A\n",
      "Inner al:   0%|▍                                                                                                                                         | 34/10000 [00:00<02:06, 78.95it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.492770791053772, Train Set grad_norm: 1.772471659933217e-05, Train Set base_objective: 0.48594599962234497, Train Set accuracy: 0.9170000553131104, Train Set squared_error: 0.950568437576294, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.9371516108512878, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:00<20:55,  7.96it/s]\n",
      "Inner al:   0%|▌                                                                                                                                         | 43/10000 [00:00<02:01, 81.69it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                                                                                         | 52/10000 [00:00<02:04, 79.66it/s]\u001b[A\n",
      "Inner al:   1%|▊                                                                                                                                         | 61/10000 [00:00<02:02, 80.91it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.492571085691452, Train Set grad_norm: 5.145647719473345e-06, Train Set base_objective: 0.4858567416667938, Train Set accuracy: 0.9180000424385071, Train Set squared_error: 0.9481340646743774, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.9721773862838745, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:01<20:55,  7.96it/s]\n",
      "Inner al:   1%|▉                                                                                                                                         | 70/10000 [00:00<02:01, 81.50it/s]\u001b[A\n",
      "Inner al:   1%|█                                                                                                                                         | 79/10000 [00:00<02:05, 79.26it/s]\u001b[A\n",
      "Inner al:   1%|█▏                                                                                                                                        | 88/10000 [00:01<02:02, 80.79it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4923783540725708, Train Set grad_norm: 2.5757772164070047e-06, Train Set base_objective: 0.48573410511016846, Train Set accuracy: 0.9140000343322754, Train Set squared_error: 0.9450759291648865, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 1.0340396165847778, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:01<20:55,  7.96it/s]\n",
      "Inner al:   1%|█▎                                                                                                                                        | 97/10000 [00:01<01:59, 82.57it/s]\u001b[A\n",
      "Inner al:   1%|█▍                                                                                                                                       | 106/10000 [00:01<02:03, 80.02it/s]\u001b[A\n",
      "Inner al:   1%|█▌                                                                                                                                       | 115/10000 [00:01<02:02, 80.63it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4921908974647522, Train Set grad_norm: 4.564343271340476e-06, Train Set base_objective: 0.4856034815311432, Train Set accuracy: 0.9130000472068787, Train Set squared_error: 0.9409582018852234, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 1.1706267595291138, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                           | 1/10000 [00:01<20:55,  7.96it/s]\n",
      "Inner al:   1%|█▋                                                                                                                                       | 124/10000 [00:01<02:03, 79.78it/s]\u001b[A\n",
      "Inner al:   1%|█▊                                                                                                                                       | 132/10000 [00:01<02:04, 79.43it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 133/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|█▊                                                                                                                                       | 133/10000 [00:01<02:04, 79.52it/s]\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:01<1:54:46,  1.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49201223254203796, Train Set grad_norm: 1.0737385309766978e-06, Train Set base_objective: 0.48552367091178894, Train Set accuracy: 0.906000018119812, Train Set squared_error: 0.9362917542457581, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 1.384926438331604, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:01<1:54:46,  1.45it/s]\n",
      "Inner al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49196022748947144, Train Set grad_norm: 8.898999226403248e-07, Train Set base_objective: 0.4854918122291565, Train Set accuracy: 0.9040000438690186, Train Set squared_error: 0.9346422553062439, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 1.4713388681411743, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                                                                                           | 6/10000 [00:00<02:48, 59.31it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                                                                                         | 15/10000 [00:00<02:18, 71.99it/s]\u001b[A\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:02<1:54:46,  1.45it/s]\n",
      "Inner al:   0%|▎                                                                                                                                         | 24/10000 [00:00<02:09, 76.74it/s]\u001b[A\n",
      "Inner al:   0%|▍                                                                                                                                         | 33/10000 [00:00<02:08, 77.81it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5053049921989441, Train Set grad_norm: 2.3615317331859842e-05, Train Set base_objective: 0.4981110095977783, Train Set accuracy: 0.878000020980835, Train Set squared_error: 0.9742273688316345, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.1292988061904907, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:02<1:54:46,  1.45it/s]\n",
      "Inner al:   0%|▌                                                                                                                                         | 42/10000 [00:00<02:03, 80.64it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                                                                                         | 51/10000 [00:00<02:08, 77.55it/s]\u001b[A\n",
      "Inner al:   1%|▊                                                                                                                                         | 60/10000 [00:00<02:05, 78.98it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5052164196968079, Train Set grad_norm: 2.1519317670026794e-06, Train Set base_objective: 0.4979797303676605, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9735009670257568, Test Set nc_accuracy: 0.6499999761581421, Test Set nc_squared_error: 1.1469107866287231, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:02<1:54:46,  1.45it/s]\n",
      "Inner al:   1%|▉                                                                                                                                         | 69/10000 [00:00<02:03, 80.20it/s]\u001b[A\n",
      "Inner al:   1%|█                                                                                                                                         | 78/10000 [00:00<02:01, 81.35it/s]\u001b[A\n",
      "Inner al:   1%|█▏                                                                                                                                        | 87/10000 [00:01<02:00, 82.04it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5051212906837463, Train Set grad_norm: 1.5505453347941511e-06, Train Set base_objective: 0.49791765213012695, Train Set accuracy: 0.8950000405311584, Train Set squared_error: 0.9713685512542725, Test Set nc_accuracy: 0.6299999952316284, Test Set nc_squared_error: 1.2246150970458984, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 3/10000 [00:03<1:54:46,  1.45it/s]\n",
      "Inner al:   1%|█▎                                                                                                                                        | 96/10000 [00:01<02:00, 82.12it/s]\u001b[A\n",
      "Inner al:   1%|█▍                                                                                                                                       | 105/10000 [00:01<02:02, 80.46it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 111/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|█▌                                                                                                                                       | 111/10000 [00:01<02:04, 79.34it/s]\n",
      "Outer al:   0%|                                                                                                                                         | 4/10000 [00:03<2:36:05,  1.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5049920082092285, Train Set grad_norm: 2.039468199654948e-06, Train Set base_objective: 0.49784529209136963, Train Set accuracy: 0.8960000276565552, Train Set squared_error: 0.9680566787719727, Test Set nc_accuracy: 0.6299999952316284, Test Set nc_squared_error: 1.3801281452178955, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                                                                                            \u001b[A\n",
      "Outer al:   0%|                                                                                                                                         | 4/10000 [00:03<2:36:05,  1.07it/s]\n",
      "Inner al:   0%|                                                                                                                                                   | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5049319863319397, Train Set grad_norm: 9.957291240425548e-07, Train Set base_objective: 0.4978198707103729, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9663909077644348, Test Set nc_accuracy: 0.6299999952316284, Test Set nc_squared_error: 1.4702900648117065, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                                                                                           | 7/10000 [00:00<02:30, 66.61it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                                                                                         | 16/10000 [00:00<02:11, 75.91it/s]\u001b[AINFO:scnn:*Outer* termination criterion satisfied at iteration 4/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|▎                                                                                                                                         | 22/10000 [00:00<02:12, 75.17it/s]\n",
      "Outer al:   0%|                                                                                                                                         | 5/10000 [00:03<2:00:03,  1.39it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5056141018867493, Train Set grad_norm: 9.934421996149467e-07, Train Set base_objective: 0.4984374940395355, Train Set accuracy: 0.8910000324249268, Train Set squared_error: 0.9687387943267822, Test Set nc_accuracy: 0.6499999761581421, Test Set nc_squared_error: 1.513813853263855, group_sparsity: 0.0, \n"
     ]
    }
   ],
   "source": [
    "model = ConvexReLU(G)\n",
    "solver = AL(model)\n",
    "regularizer = L1(1.25*1e-3)\n",
    "relu_model, relu_metrics = optimize_model(\n",
    "    model,\n",
    "    solver,\n",
    "    metrics,\n",
    "    X_train_SCNN.cpu().numpy(),\n",
    "    y_train_SCNN.cpu().numpy(),\n",
    "    X_test_SCNN.cpu().numpy(),\n",
    "    y_test_SCNN.cpu().numpy(),\n",
    "    regularizer,\n",
    "    verbose=True,\n",
    "    device='cuda',\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter Shape:  (100, 1024)\n",
      "#Non-zero entries:  6664\n",
      "Total number of parameters:  102400\n",
      "\n",
      "\n",
      "Parameter Shape:  (1, 100)\n",
      "#Non-zero entries:  100\n",
      "Total number of parameters:  100\n",
      "\n",
      "\n",
      "2.0726881958544254\n"
     ]
    }
   ],
   "source": [
    "for p in relu_model.get_parameters():\n",
    "    print(\"Parameter Shape: \", p.shape)\n",
    "    print(\"#Non-zero entries: \", np.count_nonzero(p))\n",
    "    print(\"Total number of parameters: \", np.size(p))\n",
    "    print(\"\\n\")\n",
    "\n",
    "print(relu_metrics.time[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.65\n"
     ]
    }
   ],
   "source": [
    "print(accuracy(relu_model(X_test_SCNN.cpu().numpy()), y_test_SCNN.cpu().numpy()))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Running Ridge Regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "htCj6X13-LNY",
    "outputId": "2f62df8c-9c98-444d-b3f7-0be209288b56"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.21726402640342712, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016318881233531635, Train Set grad_norm: 6.779492646290767e-15, Train Set base_objective: 0.016318881233531635, Train Set accuracy: 1.0, Train Set squared_error: 0.0026688329597689053, Test Set nc_accuracy: 0.74, Test Set nc_squared_error: 525.4070218961914, group_sparsity: 0.0, \n"
     ]
    }
   ],
   "source": [
    "# Super-fast least-squares solver.\n",
    "model = ConvexGatedReLU(G)\n",
    "solver = LeastSquaresSolver(model, tol=1e-8)\n",
    "regularizer = L2(0.001)\n",
    "lstsq_model, lstsq_metrics = optimize_model(\n",
    "    model,\n",
    "    solver,\n",
    "    metrics,\n",
    "    X_train_SCNN.cpu().numpy(),\n",
    "    y_train_SCNN.cpu().numpy(),\n",
    "    X_test_SCNN.cpu().numpy(),\n",
    "    y_test_SCNN.cpu().numpy(),\n",
    "    regularizer,\n",
    "    verbose=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter Shape:  (50, 1024)\n",
      "#Non-zero entries:  51200\n",
      "Total number of parameters:  51200\n",
      "\n",
      "\n",
      "Parameter Shape:  (1, 50)\n",
      "#Non-zero entries:  50\n",
      "Total number of parameters:  50\n",
      "\n",
      "\n",
      "0.3366099074482918\n"
     ]
    }
   ],
   "source": [
    "for p in lstsq_model.get_parameters():\n",
    "    print(\"Parameter Shape: \", p.shape)\n",
    "    print(\"#Non-zero entries: \", np.count_nonzero(p))\n",
    "    print(\"Total number of parameters: \", np.size(p))\n",
    "    print(\"\\n\")\n",
    "\n",
    "print(lstsq_metrics.time[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "HLVbFkLhcWeM",
    "outputId": "dffdb57e-3dfe-45c2-f25d-e9af66e4fcc7"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.74\n"
     ]
    }
   ],
   "source": [
    "print(accuracy(lstsq_model(X_test_SCNN.cpu().numpy()), y_test_SCNN.cpu().numpy()))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Running Nonconvex Distillation using Adam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {
    "id": "JzGrNfIaygpl"
   },
   "outputs": [],
   "source": [
    "class nonconvex_distil_model(nn.Module):\n",
    "    def __init__(self, hidden_units=100):\n",
    "        super().__init__()\n",
    "        self.fc1 = torch.nn.Linear(in_features=X_train_SCNN.shape[-1], out_features=hidden_units, bias=False)\n",
    "        self.fc2 = torch.nn.Linear(in_features=hidden_units, out_features=y_train_SCNN.shape[-1], bias=False)\n",
    "        self.relu = torch.nn.ReLU()\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        x = self.relu(x)\n",
    "        x = self.fc2(x)\n",
    "\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6150\n",
      "Parameter containing:\n",
      "tensor([[-0.0157,  0.0060,  0.0301,  ...,  0.0029,  0.0113,  0.0062],\n",
      "        [-0.0293, -0.0069, -0.0268,  ...,  0.0251, -0.0058, -0.0076],\n",
      "        [-0.0074,  0.0132,  0.0001,  ...,  0.0027, -0.0132, -0.0249],\n",
      "        [-0.0176,  0.0263,  0.0311,  ...,  0.0086, -0.0137, -0.0098],\n",
      "        [-0.0197,  0.0019, -0.0202,  ...,  0.0100, -0.0183, -0.0311],\n",
      "        [-0.0096,  0.0034,  0.0289,  ...,  0.0096, -0.0281,  0.0223]],\n",
      "       device='cuda:2', requires_grad=True)\n",
      "Parameter containing:\n",
      "tensor([[ 0.2032,  0.3813, -0.3044, -0.2713, -0.1252, -0.0235]],\n",
      "       device='cuda:2', requires_grad=True)\n"
     ]
    }
   ],
   "source": [
    "# create model\n",
    "hidden_units = 6\n",
    "\n",
    "distil_model = nonconvex_distil_model(hidden_units).to(device)\n",
    "\n",
    "print(sum(p.numel() for p in distil_model.parameters() if p.requires_grad))\n",
    "\n",
    "for p in distil_model.parameters():\n",
    "    if p.requires_grad:\n",
    "        print(p)\n",
    "\n",
    "optimizer = optim.Adam(distil_model.parameters(), lr=1e-3, weight_decay=1e-3)\n",
    "loss_function = nn.MSELoss()\n",
    "\n",
    "time_budget = 2\n",
    "\n",
    "num_epochs = 10000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch.autograd.grad_mode.set_grad_enabled at 0x7f13a2419ca0>"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.set_grad_enabled(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_105108/2103497848.py:2: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
      "/tmp/ipykernel_105108/2103497848.py:3: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n"
     ]
    }
   ],
   "source": [
    "# Ensure input tensors are of type torch.Tensor and on the correct device\n",
    "X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
    "y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch:  1 , time elapse:  0.0024776458740234375\n",
      "epoch:  251 , time elapse:  0.0006287097930908203\n",
      "epoch:  501 , time elapse:  0.0006246566772460938\n",
      "epoch:  751 , time elapse:  0.0008175373077392578\n",
      "epoch:  1001 , time elapse:  0.0006229877471923828\n",
      "epoch:  1251 , time elapse:  0.0006318092346191406\n",
      "epoch:  1501 , time elapse:  0.0008778572082519531\n",
      "epoch:  1751 , time elapse:  0.0006279945373535156\n",
      "epoch:  2001 , time elapse:  0.0005993843078613281\n",
      "epoch:  2251 , time elapse:  0.0006148815155029297\n",
      "epoch:  2501 , time elapse:  0.0008115768432617188\n",
      "epoch:  2751 , time elapse:  0.0008130073547363281\n"
     ]
    }
   ],
   "source": [
    "import time\n",
    "# Start the timer\n",
    "total_time = 0\n",
    "\n",
    "# Training loop\n",
    "# for epoch in range(num_epochs):\n",
    "epoch = 0\n",
    "time_list = []\n",
    "acc_list = []\n",
    "\n",
    "while total_time < time_budget:\n",
    "    start_time = time.time()\n",
    "    optimizer.zero_grad()\n",
    "    output = distil_model(X_train_SCNN_nn)\n",
    "    loss = loss_function(output, y_train_SCNN_nn)\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    # Check if the time budget has been exceeded\n",
    "    time_elapse = time.time() - start_time\n",
    "    total_time += time_elapse\n",
    "    if epoch%250 == 0:\n",
    "        print(\"epoch: \", epoch+1, \", time elapse: \", time_elapse)\n",
    "        time_list.append(total_time)\n",
    "        acc_list.append(accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy()))\n",
    "    epoch+= 1\n",
    "    \n",
    "# Continue with further code, such as evaluation or saving the model\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.57, 0.64, 0.64, 0.64, 0.63, 0.63, 0.64, 0.63, 0.64, 0.64, 0.6, 0.6]"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.61\n"
     ]
    }
   ],
   "source": [
    "print(accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [],
   "source": [
    "def accuracy(logits, y):\n",
    "    return np.sum((np.sign(logits) == y)) / len(y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Multiple Seed Runs Comparing All the Methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.19959428906440735, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running for seed: 6607 (Run 1/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.19959428906440735, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 38/10000 [00:00<01:20, 123.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.070895254611969, Train Set grad_norm: 0.0001620620023459196, Train Set base_objective: 0.070895254611969, Train Set accuracy: 1.0, Train Set squared_error: 0.013941111974418163, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 461.0105285644531, group_sparsity: 0.0, \n",
      "Train Set objective: 0.05775531381368637, Train Set grad_norm: 2.9076360078761354e-05, Train Set base_objective: 0.05775531381368637, Train Set accuracy: 1.0, Train Set squared_error: 0.010249179787933826, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 484.09429931640625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 77/10000 [00:00<01:18, 125.94it/s]INFO:scnn:Termination criterion satisfied at iteration 83/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 83/10000 [00:00<01:19, 124.36it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05158650502562523, Train Set grad_norm: 8.704322453922941e-07, Train Set base_objective: 0.05158650502562523, Train Set accuracy: 1.0, Train Set squared_error: 0.008281121030449867, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 515.0731811523438, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05296747758984566, Train Set grad_norm: 1.9560053260647692e-05, Train Set base_objective: 0.05296747758984566, Train Set accuracy: 1.0, Train Set squared_error: 0.009052916429936886, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 508.2727966308594, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.19959428906440735, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 12/10000 [00:00<01:27, 114.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.19959428906440735, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Train Set objective: 0.070895254611969, Train Set grad_norm: 0.0001620620023459196, Train Set base_objective: 0.070895254611969, Train Set accuracy: 1.0, Train Set squared_error: 0.013941111974418163, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 461.0105285644531, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                                                                              "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05775531381368637, Train Set grad_norm: 2.9076360078761354e-05, Train Set base_objective: 0.05775531381368637, Train Set accuracy: 1.0, Train Set squared_error: 0.010249179787933826, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 484.09429931640625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 79/10000 [00:00<01:19, 124.04it/s]INFO:scnn:Termination criterion satisfied at iteration 83/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 83/10000 [00:00<01:19, 124.39it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 58.435028076171875, Train Set grad_norm: 1136.022705078125, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05296747758984566, Train Set grad_norm: 1.9560053260647692e-05, Train Set base_objective: 0.05296747758984566, Train Set accuracy: 1.0, Train Set squared_error: 0.009052916429936886, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 508.2727966308594, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 27/10000 [00:00<00:37, 265.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 58.435028076171875, Train Set grad_norm: 1136.022705078125, \n",
      "Train Set objective: 0.03983873128890991, Train Set grad_norm: 0.018749931827187538, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Termination criterion satisfied at iteration 44/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 44/10000 [00:00<00:36, 276.54it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0778372860897889e-08, Train Set grad_norm: 5.397271518603475e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5609105229377747, Train Set grad_norm: 0.0011627719504758716, Train Set base_objective: 0.5609105229377747, Train Set accuracy: 1.0, Train Set squared_error: 0.008281120099127293, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 567.9109497070312, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.15793979167938232, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:38, 62.86it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:29, 66.76it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:43,  7.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.15793979167938232, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:43,  7.02it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48875492811203003, Train Set grad_norm: 0.0008004494593478739, Train Set base_objective: 0.4797534942626953, Train Set accuracy: 0.893000066280365, Train Set squared_error: 0.9392727017402649, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.1058038473129272, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:49, 59.03it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:43,  7.02it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:16, 73.09it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.493622362613678, Train Set grad_norm: 0.0008914698264561594, Train Set base_objective: 0.48752468824386597, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9597655534744263, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.7755677700042725, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:43,  7.02it/s]\n",
      "Inner al:   0%|▏                                                                           | 18/10000 [00:00<01:56, 86.04it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 27/10000 [00:00<01:56, 85.84it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 36/10000 [00:00<01:55, 86.43it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4928448498249054, Train Set grad_norm: 1.6880710973055102e-05, Train Set base_objective: 0.48610538244247437, Train Set accuracy: 0.9180000424385071, Train Set squared_error: 0.9513562917709351, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.8728726506233215, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:43,  7.02it/s]\n",
      "Inner al:   0%|▎                                                                           | 45/10000 [00:00<01:57, 84.92it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 54/10000 [00:00<01:56, 85.26it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 63/10000 [00:00<01:55, 86.13it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49269020557403564, Train Set grad_norm: 2.841964260369423e-06, Train Set base_objective: 0.4860159158706665, Train Set accuracy: 0.9140000343322754, Train Set squared_error: 0.948040246963501, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.9906904101371765, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   1%|▌                                                                           | 72/10000 [00:00<01:54, 87.04it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 73/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▌                                                                           | 73/10000 [00:00<01:56, 85.41it/s]\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:04:55,  2.57it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:04:55,  2.57it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.60it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4926322102546692, Train Set grad_norm: 8.88200588633481e-07, Train Set base_objective: 0.48598265647888184, Train Set accuracy: 0.9140000343322754, Train Set squared_error: 0.9451058506965637, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 1.129326581954956, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:04:55,  2.57it/s]\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:14, 74.41it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 26/10000 [00:00<02:06, 78.85it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 35/10000 [00:00<02:03, 80.58it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5063945055007935, Train Set grad_norm: 3.728518640855327e-05, Train Set base_objective: 0.49894028902053833, Train Set accuracy: 0.8690000176429749, Train Set squared_error: 0.9837004542350769, Test Set nc_accuracy: 0.5899999737739563, Test Set nc_squared_error: 0.9129164814949036, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:04:55,  2.57it/s]\n",
      "Inner al:   0%|▎                                                                           | 44/10000 [00:00<02:01, 81.62it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 53/10000 [00:00<02:06, 78.89it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 62/10000 [00:00<02:03, 80.42it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5062879920005798, Train Set grad_norm: 6.685721473331796e-06, Train Set base_objective: 0.49880293011665344, Train Set accuracy: 0.8660000562667847, Train Set squared_error: 0.9828324317932129, Test Set nc_accuracy: 0.6200000047683716, Test Set nc_squared_error: 0.9441920518875122, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   1%|▌                                                                           | 71/10000 [00:00<02:02, 81.25it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 73/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▌                                                                           | 73/10000 [00:00<02:04, 79.58it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<1:35:42,  1.74it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<1:35:42,  1.74it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.63it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5062348246574402, Train Set grad_norm: 9.24485675568576e-07, Train Set base_objective: 0.49876245856285095, Train Set accuracy: 0.8700000643730164, Train Set squared_error: 0.980150043964386, Test Set nc_accuracy: 0.5899999737739563, Test Set nc_squared_error: 1.0042920112609863, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:10, 76.70it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 17/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:13, 74.53it/s]\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:02<1:16:58,  2.16it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:02<1:16:58,  2.16it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:29, 67.06it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 15/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 15/10000 [00:00<02:13, 74.98it/s]\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:02<1:03:19,  2.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5072029232978821, Train Set grad_norm: 9.511539929007995e-07, Train Set base_objective: 0.4995266795158386, Train Set accuracy: 0.8330000638961792, Train Set squared_error: 0.9827091693878174, Test Set nc_accuracy: 0.5799999833106995, Test Set nc_squared_error: 1.0222797393798828, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:02<1:03:19,  2.63it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:27, 67.83it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 11/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 11/10000 [00:00<02:15, 73.98it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:02<51:37,  3.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507458508014679, Train Set grad_norm: 9.619732281862525e-07, Train Set base_objective: 0.49969857931137085, Train Set accuracy: 0.8070000410079956, Train Set squared_error: 0.983002781867981, Test Set nc_accuracy: 0.5899999737739563, Test Set nc_squared_error: 1.0289429426193237, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:02<51:37,  3.23it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5075689554214478, Train Set grad_norm: 9.954779898180277e-07, Train Set base_objective: 0.4997482895851135, Train Set accuracy: 0.7920000553131104, Train Set squared_error: 0.983021080493927, Test Set nc_accuracy: 0.5799999833106995, Test Set nc_squared_error: 1.0308047533035278, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:23, 69.47it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 11/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 11/10000 [00:00<02:17, 72.65it/s]\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:02<43:45,  3.81it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:02<43:45,  3.81it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5076355338096619, Train Set grad_norm: 9.45264105212118e-07, Train Set base_objective: 0.4997810125350952, Train Set accuracy: 0.784000039100647, Train Set squared_error: 0.9829512238502502, Test Set nc_accuracy: 0.5699999928474426, Test Set nc_squared_error: 1.0315821170806885, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 8/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 4/10000 [00:00<02:55, 57.09it/s]\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:02<52:45,  3.16it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5076762437820435, Train Set grad_norm: 9.86536747404898e-07, Train Set base_objective: 0.4997902512550354, Train Set accuracy: 0.7820000648498535, Train Set squared_error: 0.9829158186912537, Test Set nc_accuracy: 0.5699999928474426, Test Set nc_squared_error: 1.0319318771362305, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.21525819599628448, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.015923968209515586, Train Set grad_norm: 2.116479326662369e-15, Train Set base_objective: 0.015923968209515586, Train Set accuracy: 1.0, Train Set squared_error: 0.002501262096941535, Test Set nc_accuracy: 0.74, Test Set nc_squared_error: 482.43516643134797, group_sparsity: 0.0, \n",
      "/tmp/ipykernel_105108/3404535369.py:121: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
      "/tmp/ipykernel_105108/3404535369.py:122: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0015687942504882812\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005941390991210938\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0005450248718261719\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0005736351013183594\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0005753040313720703\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0005695819854736328\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0006368160247802734\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0006279945373535156\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0008461475372314453\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006363391876220703\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0006306171417236328\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0008459091186523438\n",
      "Full-Batch Final Test Accuracy: 0.75\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0013689994812011719\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_105108/3404535369.py:162: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
      "/tmp/ipykernel_105108/3404535369.py:163: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mini-Batch Epoch: 251, Time Elapsed: 0.000659942626953125\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006241798400878906\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006680488586425781\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006732940673828125\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007014274597167969\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0007035732269287109\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0006821155548095703\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006227493286132812\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006651878356933594\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0006659030914306641\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.000690460205078125\n",
      "Mini-Batch Final Test Accuracy: 0.68\n",
      "Running for seed: 2362 (Run 2/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.21119612455368042, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 11/10000 [00:00<01:33, 106.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.21119612455368042, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 38/10000 [00:00<01:24, 117.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07059848308563232, Train Set grad_norm: 0.00013852721895091236, Train Set base_objective: 0.07059848308563232, Train Set accuracy: 1.0, Train Set squared_error: 0.014042549766600132, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 478.2254943847656, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▍                                                                             | 63/10000 [00:00<01:26, 115.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05694396793842316, Train Set grad_norm: 1.3219023458077572e-05, Train Set base_objective: 0.05694396793842316, Train Set accuracy: 1.0, Train Set squared_error: 0.009253324940800667, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 473.0049133300781, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 75/10000 [00:00<01:25, 116.07it/s]INFO:scnn:Termination criterion satisfied at iteration 82/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 82/10000 [00:00<01:25, 115.76it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05017348378896713, Train Set grad_norm: 8.218854077313154e-07, Train Set base_objective: 0.05017348378896713, Train Set accuracy: 1.0, Train Set squared_error: 0.007949890568852425, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 505.4102478027344, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.21119612455368042, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05136982351541519, Train Set grad_norm: 1.3050501365796663e-05, Train Set base_objective: 0.05136982351541519, Train Set accuracy: 1.0, Train Set squared_error: 0.008534763008356094, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 494.39544677734375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.21119612455368042, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 46/10000 [00:00<01:27, 114.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07059848308563232, Train Set grad_norm: 0.00013852721895091236, Train Set base_objective: 0.07059848308563232, Train Set accuracy: 1.0, Train Set squared_error: 0.014042549766600132, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 478.2254943847656, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:26, 115.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05694396793842316, Train Set grad_norm: 1.3219023458077572e-05, Train Set base_objective: 0.05694396793842316, Train Set accuracy: 1.0, Train Set squared_error: 0.009253324940800667, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 473.0049133300781, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:26, 115.27it/s]INFO:scnn:Termination criterion satisfied at iteration 82/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 82/10000 [00:00<01:27, 112.84it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 68.6668701171875, Train Set grad_norm: 1232.5, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05136982351541519, Train Set grad_norm: 1.3050501365796663e-05, Train Set base_objective: 0.05136982351541519, Train Set accuracy: 1.0, Train Set squared_error: 0.008534763008356094, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 494.39544677734375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 27/10000 [00:00<00:37, 266.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 68.6668701171875, Train Set grad_norm: 1232.5, \n",
      "Train Set objective: 0.03975633159279823, Train Set grad_norm: 0.017103662714362144, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Termination criterion satisfied at iteration 45/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 45/10000 [00:00<00:35, 284.39it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.2068637644802038e-08, Train Set grad_norm: 6.310341832405086e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.6252778172492981, Train Set grad_norm: 0.0011721255723387003, Train Set base_objective: 0.6252778172492981, Train Set accuracy: 1.0, Train Set squared_error: 0.007949890568852425, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 489.7906494140625, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.17169249057769775, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:47, 59.80it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:30, 66.42it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:52,  6.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.17169249057769775, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:52,  6.98it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4883374869823456, Train Set grad_norm: 0.0007893242873251438, Train Set base_objective: 0.47892192006111145, Train Set accuracy: 0.89000004529953, Train Set squared_error: 0.9375391006469727, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.073926329612732, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:52, 57.83it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:52,  6.98it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:32, 65.46it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4934213161468506, Train Set grad_norm: 0.0008892449550330639, Train Set base_objective: 0.4870736598968506, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.9590085744857788, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.765084981918335, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:52,  6.98it/s]\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:03, 81.16it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 26/10000 [00:00<02:05, 79.55it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 35/10000 [00:00<02:01, 81.82it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4928314685821533, Train Set grad_norm: 1.4026481949258596e-05, Train Set base_objective: 0.485910028219223, Train Set accuracy: 0.909000039100647, Train Set squared_error: 0.952677309513092, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.8123605251312256, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 43/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:01, 81.80it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<44:45,  3.72it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<44:45,  3.72it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:36, 63.76it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4927997291088104, Train Set grad_norm: 9.982493338611675e-07, Train Set base_objective: 0.4860684275627136, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9529403448104858, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.834542989730835, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:14, 74.15it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<44:45,  3.72it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:04, 80.12it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:07, 78.00it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 41/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 41/10000 [00:00<02:07, 78.37it/s]\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<59:49,  2.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.506709098815918, Train Set grad_norm: 1.67516409419477e-05, Train Set base_objective: 0.49906808137893677, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9933163523674011, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.8751422166824341, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<59:49,  2.79it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:27, 67.72it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 14/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 14/10000 [00:00<02:13, 74.97it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<50:42,  3.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5066686272621155, Train Set grad_norm: 8.140785894283908e-07, Train Set base_objective: 0.49901410937309265, Train Set accuracy: 0.9120000600814819, Train Set squared_error: 0.9940897822380066, Test Set nc_accuracy: 0.6699999570846558, Test Set nc_squared_error: 0.8864961266517639, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<50:42,  3.29it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5076896548271179, Train Set grad_norm: 9.923326160787838e-07, Train Set base_objective: 0.49985843896865845, Train Set accuracy: 0.8850000500679016, Train Set squared_error: 0.997442901134491, Test Set nc_accuracy: 0.6100000143051147, Test Set nc_squared_error: 0.9305760860443115, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:29, 66.98it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 13/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 13/10000 [00:00<02:16, 72.99it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<44:18,  3.76it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<44:18,  3.76it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5078990459442139, Train Set grad_norm: 7.274204563145759e-07, Train Set base_objective: 0.49998974800109863, Train Set accuracy: 0.8390000462532043, Train Set squared_error: 0.9982650876045227, Test Set nc_accuracy: 0.6200000047683716, Test Set nc_squared_error: 0.9426727890968323, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 4/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 4/10000 [00:00<03:00, 55.42it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<44:18,  3.76it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 6/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:32, 65.45it/s]\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:01<30:08,  5.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5079858899116516, Train Set grad_norm: 9.019867661663739e-07, Train Set base_objective: 0.50001060962677, Train Set accuracy: 0.8260000348091125, Train Set squared_error: 0.9983750581741333, Test Set nc_accuracy: 0.6100000143051147, Test Set nc_squared_error: 0.9441223740577698, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:01<30:08,  5.53it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5080543160438538, Train Set grad_norm: 9.328303463007614e-07, Train Set base_objective: 0.5000295639038086, Train Set accuracy: 0.7970000505447388, Train Set squared_error: 0.9985024929046631, Test Set nc_accuracy: 0.6399999856948853, Test Set nc_squared_error: 0.9459724426269531, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 8/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 4/10000 [00:00<03:03, 54.46it/s]\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:01<35:46,  4.66it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5081031918525696, Train Set grad_norm: 9.447753654967528e-07, Train Set base_objective: 0.5000407695770264, Train Set accuracy: 0.7600000500679016, Train Set squared_error: 0.9985974431037903, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 0.9476541876792908, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22729317843914032, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016532258131993514, Train Set grad_norm: 1.7669642576138518e-15, Train Set base_objective: 0.016532258131993514, Train Set accuracy: 1.0, Train Set squared_error: 0.0027053629228456218, Test Set nc_accuracy: 0.7, Test Set nc_squared_error: 513.2512580496814, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0015325546264648438\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0006494522094726562\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0006303787231445312\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0006504058837890625\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006432533264160156\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0008351802825927734\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0005991458892822266\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0005872249603271484\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0005848407745361328\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0005855560302734375\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0006475448608398438\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0006432533264160156\n",
      "Full-Batch Final Test Accuracy: 0.72\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0010454654693603516\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0007028579711914062\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006940364837646484\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0005941390991210938\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0008027553558349609\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007386207580566406\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0008058547973632812\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0007448196411132812\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.000751495361328125\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0007359981536865234\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0007441043853759766\n",
      "Mini-Batch Final Test Accuracy: 0.64\n",
      "Running for seed: 4219 (Run 3/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20520912110805511, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                               | 10/10000 [00:00<01:45, 95.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20520912110805511, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 48/10000 [00:00<01:24, 117.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0697571337223053, Train Set grad_norm: 0.00016054791922215372, Train Set base_objective: 0.0697571337223053, Train Set accuracy: 1.0, Train Set squared_error: 0.015234973281621933, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 473.00006103515625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▍                                                                             | 61/10000 [00:00<01:24, 117.51it/s]INFO:scnn:Termination criterion satisfied at iteration 70/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 70/10000 [00:00<01:25, 116.77it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05218939483165741, Train Set grad_norm: 9.485769965067448e-07, Train Set base_objective: 0.05218939483165741, Train Set accuracy: 1.0, Train Set squared_error: 0.008917327970266342, Test Set nc_accuracy: 0.6699999570846558, Test Set nc_squared_error: 480.6612243652344, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.056713443249464035, Train Set grad_norm: 4.9247511924477294e-05, Train Set base_objective: 0.056713443249464035, Train Set accuracy: 1.0, Train Set squared_error: 0.008726326748728752, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 486.0397033691406, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20520912110805511, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 11/10000 [00:00<01:34, 105.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20520912110805511, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 39/10000 [00:00<01:17, 128.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0697571337223053, Train Set grad_norm: 0.00016054791922215372, Train Set base_objective: 0.0697571337223053, Train Set accuracy: 1.0, Train Set squared_error: 0.015234973281621933, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 473.00006103515625, group_sparsity: 0.0, \n",
      "Train Set objective: 0.056713443249464035, Train Set grad_norm: 4.9247511924477294e-05, Train Set base_objective: 0.056713443249464035, Train Set accuracy: 1.0, Train Set squared_error: 0.008726326748728752, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 486.0397033691406, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 67/10000 [00:00<01:15, 131.37it/s]INFO:scnn:Termination criterion satisfied at iteration 70/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 70/10000 [00:00<01:17, 128.63it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 56.60333251953125, Train Set grad_norm: 1097.5958251953125, \n",
      "quadratic_decomp:   0%|▏                                                                  | 29/10000 [00:00<00:35, 284.28it/s]INFO:scnn:Termination criterion satisfied at iteration 49/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 49/10000 [00:00<00:32, 304.38it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0885509382774217e-08, Train Set grad_norm: 4.457969063342837e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5671226382255554, Train Set grad_norm: 0.0011772842844948173, Train Set base_objective: 0.5671226382255554, Train Set accuracy: 1.0, Train Set squared_error: 0.008917327970266342, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 488.1677551269531, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 56.60333251953125, Train Set grad_norm: 1097.5958251953125, \n",
      "Train Set objective: 0.0911722332239151, Train Set grad_norm: 0.03336486965417862, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.16467377543449402, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:35, 64.42it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:25, 68.54it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<22:43,  7.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.16467377543449402, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<22:43,  7.33it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48857834935188293, Train Set grad_norm: 0.0007799002924002707, Train Set base_objective: 0.4793843924999237, Train Set accuracy: 0.893000066280365, Train Set squared_error: 0.9384803771972656, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 1.043804407119751, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:40, 62.23it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<22:43,  7.33it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:25, 68.48it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49354931712150574, Train Set grad_norm: 0.0008563562296330929, Train Set base_objective: 0.487343966960907, Train Set accuracy: 0.9070000648498535, Train Set squared_error: 0.9594373106956482, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.7348765134811401, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<22:43,  7.33it/s]\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:00, 82.96it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 26/10000 [00:00<02:03, 80.61it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 35/10000 [00:00<02:00, 82.73it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49290919303894043, Train Set grad_norm: 1.218253601109609e-05, Train Set base_objective: 0.48609596490859985, Train Set accuracy: 0.9150000214576721, Train Set squared_error: 0.9525001049041748, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.7705885171890259, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▎                                                                           | 44/10000 [00:00<01:57, 84.89it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 44/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 44/10000 [00:00<02:00, 82.29it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<44:34,  3.74it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<44:34,  3.74it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.78it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49288517236709595, Train Set grad_norm: 9.714385669212788e-07, Train Set base_objective: 0.48620739579200745, Train Set accuracy: 0.9160000681877136, Train Set squared_error: 0.9524560570716858, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.7806158065795898, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:13, 74.93it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<44:34,  3.74it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:04, 79.92it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:03, 80.43it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5066726207733154, Train Set grad_norm: 2.995656723214779e-05, Train Set base_objective: 0.49915793538093567, Train Set accuracy: 0.9190000295639038, Train Set squared_error: 0.9937448501586914, Test Set nc_accuracy: 0.6699999570846558, Test Set nc_squared_error: 0.8742526173591614, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:03, 80.87it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 44/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 44/10000 [00:00<02:06, 78.83it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:01:40,  2.70it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:01:40,  2.70it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:32, 65.53it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5066273212432861, Train Set grad_norm: 7.972549269652518e-07, Train Set base_objective: 0.49902981519699097, Train Set accuracy: 0.9290000200271606, Train Set squared_error: 0.9942032694816589, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.8824502229690552, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:07, 78.10it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 18/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 18/10000 [00:00<02:11, 76.02it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<54:36,  3.05it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<54:36,  3.05it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:32, 65.46it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5076450705528259, Train Set grad_norm: 9.337223900729441e-07, Train Set base_objective: 0.49986571073532104, Train Set accuracy: 0.9070000648498535, Train Set squared_error: 0.99776291847229, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 0.9366263151168823, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:11, 75.84it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 17/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:17, 72.59it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<49:59,  3.33it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<49:59,  3.33it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:30, 66.34it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 7/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:36, 63.85it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<40:24,  4.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507858395576477, Train Set grad_norm: 9.61901150731137e-07, Train Set base_objective: 0.5000040531158447, Train Set accuracy: 0.8860000371932983, Train Set squared_error: 0.9988852739334106, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 0.9562295079231262, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<40:24,  4.12it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507938802242279, Train Set grad_norm: 9.787573844732833e-07, Train Set base_objective: 0.5000340342521667, Train Set accuracy: 0.8670000433921814, Train Set squared_error: 0.999219536781311, Test Set nc_accuracy: 0.6499999761581421, Test Set nc_squared_error: 0.962306559085846, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 7/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:44, 60.57it/s]\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:02<42:21,  3.93it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.507988452911377, Train Set grad_norm: 9.013058388518402e-07, Train Set base_objective: 0.5000477433204651, Train Set accuracy: 0.8370000123977661, Train Set squared_error: 0.9994750022888184, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9676032066345215, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22108271718025208, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016071728160733673, Train Set grad_norm: 2.343783961143755e-15, Train Set base_objective: 0.016071728160733673, Train Set accuracy: 1.0, Train Set squared_error: 0.0025709425708899973, Test Set nc_accuracy: 0.69, Test Set nc_squared_error: 498.34156904115196, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0015571117401123047\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005400180816650391\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0005688667297363281\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0006518363952636719\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006499290466308594\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0008382797241210938\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0006473064422607422\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0008449554443359375\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0008380413055419922\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006449222564697266\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.000835418701171875\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0006501674652099609\n",
      "Full-Batch Final Test Accuracy: 0.74\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.001047372817993164\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.00067901611328125\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006763935089111328\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0007615089416503906\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0007505416870117188\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007467269897460938\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0007572174072265625\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0007474422454833984\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006966590881347656\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006871223449707031\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0006866455078125\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0007574558258056641\n",
      "Mini-Batch Final Test Accuracy: 0.69\n",
      "Running for seed: 2939 (Run 4/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20451661944389343, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 11/10000 [00:00<01:38, 100.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20451661944389343, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▍                                                                             | 50/10000 [00:00<01:19, 124.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07094241678714752, Train Set grad_norm: 0.0001034191227518022, Train Set base_objective: 0.07094241678714752, Train Set accuracy: 1.0, Train Set squared_error: 0.02374044619500637, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 511.52593994140625, group_sparsity: 0.0, \n",
      "Train Set objective: 0.05727163702249527, Train Set grad_norm: 5.014151975046843e-05, Train Set base_objective: 0.05727163702249527, Train Set accuracy: 1.0, Train Set squared_error: 0.010916103608906269, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 522.0259399414062, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 76/10000 [00:00<01:18, 126.88it/s]INFO:scnn:Termination criterion satisfied at iteration 76/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 76/10000 [00:00<01:20, 123.39it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.050528090447187424, Train Set grad_norm: 8.308694532388472e-07, Train Set base_objective: 0.050528090447187424, Train Set accuracy: 1.0, Train Set squared_error: 0.008314070291817188, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 539.7457885742188, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20451661944389343, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.050729867070913315, Train Set grad_norm: 1.138457491833833e-06, Train Set base_objective: 0.050729867070913315, Train Set accuracy: 1.0, Train Set squared_error: 0.008133307099342346, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 538.1843872070312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20451661944389343, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 40/10000 [00:00<01:19, 125.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07094241678714752, Train Set grad_norm: 0.0001034191227518022, Train Set base_objective: 0.07094241678714752, Train Set accuracy: 1.0, Train Set squared_error: 0.02374044619500637, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 511.52593994140625, group_sparsity: 0.0, \n",
      "Train Set objective: 0.05727163702249527, Train Set grad_norm: 5.014151975046843e-05, Train Set base_objective: 0.05727163702249527, Train Set accuracy: 1.0, Train Set squared_error: 0.010916103608906269, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 522.0259399414062, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 66/10000 [00:00<01:18, 126.27it/s]INFO:scnn:Termination criterion satisfied at iteration 76/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 76/10000 [00:00<01:19, 124.95it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 60.667633056640625, Train Set grad_norm: 1135.12109375, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.050729867070913315, Train Set grad_norm: 1.138457491833833e-06, Train Set base_objective: 0.050729867070913315, Train Set accuracy: 1.0, Train Set squared_error: 0.008133307099342346, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 538.1843872070312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 27/10000 [00:00<00:37, 266.65it/s]INFO:scnn:Termination criterion satisfied at iteration 46/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 46/10000 [00:00<00:34, 285.56it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0919878334902933e-08, Train Set grad_norm: 3.380642293882019e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5666196942329407, Train Set grad_norm: 0.0011759611079469323, Train Set base_objective: 0.5666196942329407, Train Set accuracy: 1.0, Train Set squared_error: 0.008314070291817188, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 517.363037109375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 60.667633056640625, Train Set grad_norm: 1135.12109375, \n",
      "Train Set objective: 0.05167480930685997, Train Set grad_norm: 0.025530610233545303, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.16392295062541962, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:23, 69.56it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:17, 72.58it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:33,  7.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.16392295062541962, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:33,  7.73it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48833292722702026, Train Set grad_norm: 0.0008367107948288321, Train Set base_objective: 0.47902557253837585, Train Set accuracy: 0.8920000195503235, Train Set squared_error: 0.9372621178627014, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.0814658403396606, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:50, 58.68it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:33,  7.73it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:32, 65.61it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4933745861053467, Train Set grad_norm: 0.0009649748681113124, Train Set base_objective: 0.48700740933418274, Train Set accuracy: 0.9100000262260437, Train Set squared_error: 0.9583030939102173, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.7559863328933716, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:33,  7.73it/s]\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:00, 82.69it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 26/10000 [00:00<02:02, 81.34it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 36/10000 [00:00<01:57, 84.93it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49267610907554626, Train Set grad_norm: 1.8394730432191864e-05, Train Set base_objective: 0.48561978340148926, Train Set accuracy: 0.9150000214576721, Train Set squared_error: 0.9505881667137146, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.8061906099319458, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 43/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<01:58, 84.14it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<43:12,  3.86it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<43:12,  3.86it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:29, 66.98it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4926479160785675, Train Set grad_norm: 9.223304004990496e-07, Train Set base_objective: 0.4858551323413849, Train Set accuracy: 0.9150000214576721, Train Set squared_error: 0.9514447450637817, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.8025962710380554, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<43:12,  3.86it/s]\n",
      "Inner al:   0%|▏                                                                           | 17/10000 [00:00<02:03, 80.69it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 26/10000 [00:00<01:59, 83.81it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 36/10000 [00:00<01:54, 86.91it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 38/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 38/10000 [00:00<01:58, 84.06it/s]\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<54:42,  3.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5067335367202759, Train Set grad_norm: 7.937413101899438e-06, Train Set base_objective: 0.4989944398403168, Train Set accuracy: 0.9200000166893005, Train Set squared_error: 0.9933678507804871, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.8734491467475891, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<54:42,  3.05it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5067174434661865, Train Set grad_norm: 7.983400678313046e-07, Train Set base_objective: 0.49892157316207886, Train Set accuracy: 0.9150000214576721, Train Set squared_error: 0.9936416149139404, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.8789460062980652, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:23, 69.40it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 14/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 14/10000 [00:00<02:07, 78.52it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<46:51,  3.56it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<46:51,  3.56it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507832407951355, Train Set grad_norm: 8.872362400325073e-07, Train Set base_objective: 0.4998112916946411, Train Set accuracy: 0.9130000472068787, Train Set squared_error: 0.9972690939903259, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.9297108054161072, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:24, 69.06it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 14/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 14/10000 [00:00<02:04, 80.52it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<41:28,  4.02it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<41:28,  4.02it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5081053376197815, Train Set grad_norm: 9.091753554457682e-07, Train Set base_objective: 0.49996984004974365, Train Set accuracy: 0.9040000438690186, Train Set squared_error: 0.9982932806015015, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9470098614692688, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:13, 74.58it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 12/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 12/10000 [00:00<02:06, 78.67it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<36:45,  4.53it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<36:45,  4.53it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5082272887229919, Train Set grad_norm: 8.052875841713103e-07, Train Set base_objective: 0.5000362396240234, Train Set accuracy: 0.8840000629425049, Train Set squared_error: 0.9988932609558105, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.9574508666992188, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 7/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 3/10000 [00:00<03:08, 52.90it/s]\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:01<37:11,  4.48it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5082864761352539, Train Set grad_norm: 8.654996577206475e-07, Train Set base_objective: 0.5000413656234741, Train Set accuracy: 0.878000020980835, Train Set squared_error: 0.9989892244338989, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.9591695070266724, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22034943103790283, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.015808295631682737, Train Set grad_norm: 2.000273741305331e-15, Train Set base_objective: 0.015808295631682737, Train Set accuracy: 1.0, Train Set squared_error: 0.0025273830875978034, Test Set nc_accuracy: 0.7, Test Set nc_squared_error: 555.1268753198583, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0013408660888671875\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0008413791656494141\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0008378028869628906\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0008580684661865234\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006539821624755859\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0006492137908935547\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0009214878082275391\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0007944107055664062\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0008091926574707031\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0007984638214111328\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0007894039154052734\n",
      "Full-Batch Final Test Accuracy: 0.73\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.000820159912109375\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0006701946258544922\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006966590881347656\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006055831909179688\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006055831909179688\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0005972385406494141\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0005857944488525391\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0005958080291748047\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006012916564941406\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0005915164947509766\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0005924701690673828\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0005846023559570312\n",
      "Mini-Batch Epoch: 3001, Time Elapsed: 0.0005867481231689453\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20184805989265442, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mini-Batch Final Test Accuracy: 0.66\n",
      "Running for seed: 1422 (Run 5/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20184805989265442, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 38/10000 [00:00<01:21, 122.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07254574447870255, Train Set grad_norm: 0.00015728079597465694, Train Set base_objective: 0.07254574447870255, Train Set accuracy: 1.0, Train Set squared_error: 0.01344000268727541, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 469.0827941894531, group_sparsity: 0.0, \n",
      "Train Set objective: 0.05864778906106949, Train Set grad_norm: 6.064603803679347e-05, Train Set base_objective: 0.05864778906106949, Train Set accuracy: 1.0, Train Set squared_error: 0.009231542237102985, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 505.88397216796875, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 77/10000 [00:00<01:19, 124.78it/s]INFO:scnn:Termination criterion satisfied at iteration 84/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 84/10000 [00:00<01:20, 123.61it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05223928019404411, Train Set grad_norm: 8.989983371066046e-07, Train Set base_objective: 0.05223928019404411, Train Set accuracy: 1.0, Train Set squared_error: 0.008867564611136913, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 512.9351806640625, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20184805989265442, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05334683135151863, Train Set grad_norm: 1.2410591807565652e-06, Train Set base_objective: 0.05334683135151863, Train Set accuracy: 1.0, Train Set squared_error: 0.009645241312682629, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 506.32366943359375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20184805989265442, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 38/10000 [00:00<01:20, 123.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07254574447870255, Train Set grad_norm: 0.00015728079597465694, Train Set base_objective: 0.07254574447870255, Train Set accuracy: 1.0, Train Set squared_error: 0.01344000268727541, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 469.0827941894531, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▍                                                                             | 64/10000 [00:00<01:19, 124.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05864778906106949, Train Set grad_norm: 6.064603803679347e-05, Train Set base_objective: 0.05864778906106949, Train Set accuracy: 1.0, Train Set squared_error: 0.009231542237102985, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 505.88397216796875, group_sparsity: 0.0, \n",
      "Train Set objective: 0.05334683135151863, Train Set grad_norm: 1.2410591807565652e-06, Train Set base_objective: 0.05334683135151863, Train Set accuracy: 1.0, Train Set squared_error: 0.009645241312682629, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 506.32366943359375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 77/10000 [00:00<01:18, 126.09it/s]INFO:scnn:Termination criterion satisfied at iteration 84/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 84/10000 [00:00<01:19, 124.49it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 53.26537322998047, Train Set grad_norm: 1020.7044677734375, \n",
      "quadratic_decomp:   0%|▏                                                                  | 28/10000 [00:00<00:36, 273.42it/s]INFO:scnn:Termination criterion satisfied at iteration 45/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 45/10000 [00:00<00:35, 277.61it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0404078487624702e-08, Train Set grad_norm: 2.985608288375019e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5406128764152527, Train Set grad_norm: 0.0011672147084027529, Train Set base_objective: 0.5406128764152527, Train Set accuracy: 1.0, Train Set squared_error: 0.008867565542459488, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 491.5836181640625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 53.26537322998047, Train Set grad_norm: 1020.7044677734375, \n",
      "Train Set objective: 0.053952544927597046, Train Set grad_norm: 0.021042797714471817, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.16102725267410278, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "                                                                                                                              \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:47, 59.59it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 8/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:37, 63.57it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:59,  7.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.16102725267410278, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:59,  7.58it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4890523850917816, Train Set grad_norm: 0.0008595969993621111, Train Set base_objective: 0.4802320897579193, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9412564039230347, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 1.0329713821411133, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:58, 56.13it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:59,  7.58it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49379536509513855, Train Set grad_norm: 0.000754759821575135, Train Set base_objective: 0.4879434406757355, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9617313742637634, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.7712327241897583, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:35, 64.33it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:08, 77.90it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:59,  7.58it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:04, 80.14it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:03, 80.68it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49320805072784424, Train Set grad_norm: 1.1551042916835286e-05, Train Set base_objective: 0.48667141795158386, Train Set accuracy: 0.9160000681877136, Train Set squared_error: 0.9548996686935425, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.8274234533309937, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:02, 81.02it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 46/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 46/10000 [00:00<02:05, 79.59it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<47:40,  3.49it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<47:40,  3.49it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:38, 62.89it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4931846857070923, Train Set grad_norm: 9.910993412631797e-07, Train Set base_objective: 0.4867992103099823, Train Set accuracy: 0.9160000681877136, Train Set squared_error: 0.9552052021026611, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.8532539010047913, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 15/10000 [00:00<02:18, 72.20it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<47:40,  3.49it/s]\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:07, 78.43it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 32/10000 [00:00<02:07, 78.14it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 41/10000 [00:00<02:05, 79.51it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5063794255256653, Train Set grad_norm: 2.0951314581907354e-05, Train Set base_objective: 0.4992366135120392, Train Set accuracy: 0.9010000228881836, Train Set squared_error: 0.9947481751441956, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.8991170525550842, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 45/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 45/10000 [00:00<02:08, 77.68it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:04:58,  2.56it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:04:58,  2.56it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.78it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 13/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 13/10000 [00:00<02:17, 72.77it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<53:42,  3.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5063382983207703, Train Set grad_norm: 9.128983151640568e-07, Train Set base_objective: 0.49908438324928284, Train Set accuracy: 0.9190000295639038, Train Set squared_error: 0.9948780536651611, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.90727698802948, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<53:42,  3.10it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5072973370552063, Train Set grad_norm: 9.52935124587384e-07, Train Set base_objective: 0.4998948872089386, Train Set accuracy: 0.8790000677108765, Train Set squared_error: 0.9983617067337036, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.950372576713562, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:33, 64.92it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:09, 76.90it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 16/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:15, 73.89it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<48:26,  3.44it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<48:26,  3.44it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:33, 64.95it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 7/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:38, 62.90it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<39:26,  4.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5074690580368042, Train Set grad_norm: 9.392322226631222e-07, Train Set base_objective: 0.4999890923500061, Train Set accuracy: 0.8570000529289246, Train Set squared_error: 0.999131441116333, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.9613880515098572, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<39:26,  4.22it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5075505375862122, Train Set grad_norm: 9.9203441550344e-07, Train Set base_objective: 0.5000158548355103, Train Set accuracy: 0.8210000395774841, Train Set squared_error: 0.9993926286697388, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9653998613357544, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:52, 57.87it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:02<39:26,  4.22it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 3/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 3/10000 [00:00<03:26, 48.36it/s]\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:02<27:08,  6.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5076038241386414, Train Set grad_norm: 8.863611924425641e-07, Train Set base_objective: 0.5000295042991638, Train Set accuracy: 0.8060000538825989, Train Set squared_error: 0.9995823502540588, Test Set nc_accuracy: 0.6499999761581421, Test Set nc_squared_error: 0.9684690833091736, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:02<27:08,  6.14it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5076425671577454, Train Set grad_norm: 9.663923492553295e-07, Train Set base_objective: 0.5000318288803101, Train Set accuracy: 0.7850000262260437, Train Set squared_error: 0.9996677041053772, Test Set nc_accuracy: 0.6200000047683716, Test Set nc_squared_error: 0.969745934009552, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 9/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 2/10000 [00:00<04:11, 39.68it/s]\n",
      "Outer al:   0%|                                                                            | 10/10000 [00:02<35:44,  4.66it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5076762437820435, Train Set grad_norm: 8.934291599871358e-07, Train Set base_objective: 0.5000293254852295, Train Set accuracy: 0.7730000615119934, Train Set squared_error: 0.9997100234031677, Test Set nc_accuracy: 0.6200000047683716, Test Set nc_squared_error: 0.9702978134155273, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2175784409046173, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.015927636184571367, Train Set grad_norm: 3.0521682852063656e-15, Train Set base_objective: 0.015927636184571367, Train Set accuracy: 1.0, Train Set squared_error: 0.0025133158526448695, Test Set nc_accuracy: 0.66, Test Set nc_squared_error: 479.25706529290903, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0015666484832763672\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0006258487701416016\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0006425380706787109\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0008540153503417969\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006506443023681641\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0008625984191894531\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0006444454193115234\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0006511211395263672\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0006718635559082031\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006647109985351562\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.000637054443359375\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0006368160247802734\n",
      "Full-Batch Final Test Accuracy: 0.74\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0010263919830322266\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0006656646728515625\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.00066375732421875\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0008082389831542969\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006120204925537109\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0006008148193359375\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006036758422851562\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0005993843078613281\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0008008480072021484\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0007293224334716797\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0007271766662597656\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0007367134094238281\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.206933856010437, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mini-Batch Final Test Accuracy: 0.67\n",
      "Running for seed: 3644 (Run 6/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.206933856010437, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 47/10000 [00:00<01:26, 115.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06933389604091644, Train Set grad_norm: 0.0001613129279576242, Train Set base_objective: 0.06933389604091644, Train Set accuracy: 1.0, Train Set squared_error: 0.016245055943727493, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 512.5302734375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:25, 116.12it/s]INFO:scnn:Termination criterion satisfied at iteration 71/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:27, 113.12it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05130351334810257, Train Set grad_norm: 9.942773431248497e-07, Train Set base_objective: 0.05130351334810257, Train Set accuracy: 1.0, Train Set squared_error: 0.008385210298001766, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 522.23876953125, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05657944455742836, Train Set grad_norm: 4.270811041351408e-05, Train Set base_objective: 0.05657944455742836, Train Set accuracy: 1.0, Train Set squared_error: 0.009019729681313038, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 524.9945068359375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.206933856010437, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 11/10000 [00:00<01:34, 106.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.206933856010437, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 47/10000 [00:00<01:26, 114.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06933389604091644, Train Set grad_norm: 0.0001613129279576242, Train Set base_objective: 0.06933389604091644, Train Set accuracy: 1.0, Train Set squared_error: 0.016245055943727493, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 512.5302734375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:25, 115.49it/s]INFO:scnn:Termination criterion satisfied at iteration 71/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:27, 113.88it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 60.512577056884766, Train Set grad_norm: 1144.3306884765625, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05657944455742836, Train Set grad_norm: 4.270811041351408e-05, Train Set base_objective: 0.05657944455742836, Train Set accuracy: 1.0, Train Set squared_error: 0.009019729681313038, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 524.9945068359375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|                                                                             | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 60.512577056884766, Train Set grad_norm: 1144.3306884765625, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 26/10000 [00:00<00:39, 255.08it/s]INFO:scnn:Termination criterion satisfied at iteration 44/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 44/10000 [00:00<00:35, 277.23it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.1250394393869101e-08, Train Set grad_norm: 1.7197574961325124e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5858965516090393, Train Set grad_norm: 0.001172609394416213, Train Set base_objective: 0.5858965516090393, Train Set accuracy: 1.0, Train Set squared_error: 0.008385210298001766, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 523.5857543945312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.032170504331588745, Train Set grad_norm: 0.017329465597867966, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.1666879951953888, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:31, 65.80it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 8/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:31, 66.07it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:03,  7.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.1666879951953888, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:03,  7.91it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48864972591400146, Train Set grad_norm: 0.0008932863129302859, Train Set base_objective: 0.4795764684677124, Train Set accuracy: 0.8870000243186951, Train Set squared_error: 0.9392987489700317, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.0723490715026855, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:48, 59.24it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:03,  7.91it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:28, 67.24it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4935542047023773, Train Set grad_norm: 0.0007897834293544292, Train Set base_objective: 0.48746436834335327, Train Set accuracy: 0.9030000567436218, Train Set squared_error: 0.9602186679840088, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.7704711556434631, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:04, 80.36it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:03,  7.91it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:01, 82.25it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<01:59, 83.72it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 37/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 37/10000 [00:00<02:03, 80.67it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<39:42,  4.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.492963582277298, Train Set grad_norm: 1.2214516573294532e-05, Train Set base_objective: 0.4861651062965393, Train Set accuracy: 0.9100000262260437, Train Set squared_error: 0.953421413898468, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.8328654766082764, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<39:42,  4.20it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4929482340812683, Train Set grad_norm: 9.408378218722646e-07, Train Set base_objective: 0.4863581359386444, Train Set accuracy: 0.909000039100647, Train Set squared_error: 0.9543836116790771, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.8273184895515442, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:30, 66.54it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:11, 76.10it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<39:42,  4.20it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:04, 80.02it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:04, 80.13it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5065736770629883, Train Set grad_norm: 3.978371387347579e-05, Train Set base_objective: 0.49921607971191406, Train Set accuracy: 0.9100000262260437, Train Set squared_error: 0.9952808618545532, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9139294028282166, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:02, 81.61it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 43/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:05, 79.20it/s]\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<57:37,  2.89it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<57:37,  2.89it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:35, 64.45it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 11/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 11/10000 [00:00<02:22, 69.89it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<47:35,  3.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5065422654151917, Train Set grad_norm: 7.688277037232183e-07, Train Set base_objective: 0.4990653693675995, Train Set accuracy: 0.9200000166893005, Train Set squared_error: 0.9951245188713074, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.9094027280807495, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<47:35,  3.50it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5075106620788574, Train Set grad_norm: 8.669121598359197e-07, Train Set base_objective: 0.4998664855957031, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9983243942260742, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9550088047981262, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:30, 66.19it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 10/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 10/10000 [00:00<02:23, 69.71it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<40:21,  4.13it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<40:21,  4.13it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5077133774757385, Train Set grad_norm: 9.465808261666098e-07, Train Set base_objective: 0.49999600648880005, Train Set accuracy: 0.8510000109672546, Train Set squared_error: 0.9992187023162842, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 0.9697015285491943, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Outer* termination criterion satisfied at iteration 6/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:48, 59.41it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<38:55,  4.28it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5077871680259705, Train Set grad_norm: 6.917342716405983e-07, Train Set base_objective: 0.5000375509262085, Train Set accuracy: 0.7260000109672546, Train Set squared_error: 0.9996830821037292, Test Set nc_accuracy: 0.5600000023841858, Test Set nc_squared_error: 0.9788001775741577, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22286513447761536, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016220882075028115, Train Set grad_norm: 2.1205117419514217e-15, Train Set base_objective: 0.016220882075028115, Train Set accuracy: 1.0, Train Set squared_error: 0.0026258878221760637, Test Set nc_accuracy: 0.7, Test Set nc_squared_error: 545.5533512566424, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.001543283462524414\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005536079406738281\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0005500316619873047\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0005500316619873047\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006036758422851562\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0006210803985595703\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0009965896606445312\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0013790130615234375\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0006258487701416016\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006511211395263672\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0006470680236816406\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0006508827209472656\n",
      "Full-Batch Final Test Accuracy: 0.73\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0009293556213378906\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0007648468017578125\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006823539733886719\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006902217864990234\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.00069427490234375\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0006918907165527344\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006878376007080078\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0007877349853515625\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006973743438720703\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006952285766601562\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0005776882171630859\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0006871223449707031\n",
      "Mini-Batch Final Test Accuracy: 0.68\n",
      "Running for seed: 6358 (Run 7/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20512910187244415, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                                | 9/10000 [00:00<01:51, 89.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20512910187244415, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 45/10000 [00:00<01:28, 112.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0704505667090416, Train Set grad_norm: 0.00017044793639797717, Train Set base_objective: 0.0704505667090416, Train Set accuracy: 1.0, Train Set squared_error: 0.014631250873208046, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 489.81842041015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 69/10000 [00:00<01:26, 115.02it/s]INFO:scnn:Termination criterion satisfied at iteration 72/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 72/10000 [00:00<01:28, 111.58it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05227842926979065, Train Set grad_norm: 9.374903697789705e-07, Train Set base_objective: 0.05227842926979065, Train Set accuracy: 1.0, Train Set squared_error: 0.008975867182016373, Test Set nc_accuracy: 0.7799999713897705, Test Set nc_squared_error: 546.2379760742188, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05637793987989426, Train Set grad_norm: 3.7269659515004605e-05, Train Set base_objective: 0.05637793987989426, Train Set accuracy: 1.0, Train Set squared_error: 0.00966273806989193, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 517.498291015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20512910187244415, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                               | 10/10000 [00:00<01:48, 91.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20512910187244415, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 46/10000 [00:00<01:26, 114.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0704505667090416, Train Set grad_norm: 0.00017044793639797717, Train Set base_objective: 0.0704505667090416, Train Set accuracy: 1.0, Train Set squared_error: 0.014631250873208046, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 489.81842041015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 70/10000 [00:00<01:25, 116.01it/s]INFO:scnn:Termination criterion satisfied at iteration 72/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 72/10000 [00:00<01:27, 113.15it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 56.33021545410156, Train Set grad_norm: 1126.036865234375, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05637793987989426, Train Set grad_norm: 3.7269659515004605e-05, Train Set base_objective: 0.05637793987989426, Train Set accuracy: 1.0, Train Set squared_error: 0.00966273806989193, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 517.498291015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|                                                                             | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 56.33021545410156, Train Set grad_norm: 1126.036865234375, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 27/10000 [00:00<00:37, 262.84it/s]INFO:scnn:Termination criterion satisfied at iteration 46/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 46/10000 [00:00<00:35, 282.18it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0451763010621562e-08, Train Set grad_norm: 9.133229589286529e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5427002906799316, Train Set grad_norm: 0.0011761647183448076, Train Set base_objective: 0.5427002906799316, Train Set accuracy: 1.0, Train Set squared_error: 0.008975867182016373, Test Set nc_accuracy: 0.7699999809265137, Test Set nc_squared_error: 533.0408325195312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06615665555000305, Train Set grad_norm: 0.029816577211022377, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.1646762490272522, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "                                                                                                                              \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:35, 64.29it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:28, 67.33it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:06,  7.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.1646762490272522, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:06,  7.21it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48838087916374207, Train Set grad_norm: 0.0008364147506654263, Train Set base_objective: 0.4791020154953003, Train Set accuracy: 0.89000004529953, Train Set squared_error: 0.9377952218055725, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.0827147960662842, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:48, 59.16it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:06,  7.21it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:49, 59.00it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49339285492897034, Train Set grad_norm: 0.0009236527257598937, Train Set base_objective: 0.4870891273021698, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.9587113261222839, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.7681155204772949, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 15/10000 [00:00<02:10, 76.36it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:06,  7.21it/s]\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:06, 79.07it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 33/10000 [00:00<02:04, 79.91it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4926024079322815, Train Set grad_norm: 2.1236568500171416e-05, Train Set base_objective: 0.4856647849082947, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9505475163459778, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.8703210949897766, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:06,  7.21it/s]\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<01:57, 84.90it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 52/10000 [00:00<02:00, 82.63it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 61/10000 [00:00<01:57, 84.34it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4924454391002655, Train Set grad_norm: 4.850492587138433e-06, Train Set base_objective: 0.4855305552482605, Train Set accuracy: 0.9130000472068787, Train Set squared_error: 0.9472727179527283, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 1.031569004058838, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:01<23:06,  7.21it/s]\n",
      "Inner al:   1%|▌                                                                           | 71/10000 [00:00<01:54, 86.92it/s]\u001b[A\n",
      "Inner al:   1%|▌                                                                           | 80/10000 [00:00<01:55, 85.92it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                           | 89/10000 [00:01<01:54, 86.34it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49234986305236816, Train Set grad_norm: 1.531494376649789e-06, Train Set base_objective: 0.48550817370414734, Train Set accuracy: 0.9130000472068787, Train Set squared_error: 0.9453988075256348, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 1.2003765106201172, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 97/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▋                                                                           | 97/10000 [00:01<01:58, 83.51it/s]\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:23:37,  1.99it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:23:37,  1.99it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:29, 66.72it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4922810196876526, Train Set grad_norm: 8.983810175777762e-07, Train Set base_objective: 0.48549792170524597, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.943444013595581, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 1.3556842803955078, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:08, 77.58it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:23:37,  1.99it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:00, 82.84it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:05, 79.61it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5063601732254028, Train Set grad_norm: 2.7954538381891325e-05, Train Set base_objective: 0.49854904413223267, Train Set accuracy: 0.8910000324249268, Train Set squared_error: 0.982279360294342, Test Set nc_accuracy: 0.6699999570846558, Test Set nc_squared_error: 1.0411972999572754, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:23:37,  1.99it/s]\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:01, 81.89it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 52/10000 [00:00<02:03, 80.68it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 61/10000 [00:00<02:02, 80.94it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5062444806098938, Train Set grad_norm: 2.4076662157312967e-06, Train Set base_objective: 0.4985361397266388, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9836938977241516, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.0528517961502075, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:23:37,  1.99it/s]\n",
      "Inner al:   1%|▌                                                                           | 70/10000 [00:00<01:59, 83.19it/s]\u001b[A\n",
      "Inner al:   1%|▌                                                                           | 79/10000 [00:00<02:02, 80.88it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                           | 88/10000 [00:01<02:02, 81.05it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5061514973640442, Train Set grad_norm: 1.9138069546897896e-06, Train Set base_objective: 0.4985167384147644, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9825556874275208, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.1414066553115845, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:23:37,  1.99it/s]\n",
      "Inner al:   1%|▋                                                                           | 97/10000 [00:01<01:59, 83.00it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 100/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▊                                                                          | 100/10000 [00:01<02:02, 80.69it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<2:06:31,  1.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5060563087463379, Train Set grad_norm: 9.849920843407745e-07, Train Set base_objective: 0.4984728991985321, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9798652529716492, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.3006621599197388, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<2:06:31,  1.32it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:24, 69.11it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5060563087463379, Train Set grad_norm: 9.849920843407745e-07, Train Set base_objective: 0.4984728991985321, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9798652529716492, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.3006621599197388, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:07, 78.30it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 24/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:06, 78.87it/s]\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:02<1:41:50,  1.64it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:02<1:41:50,  1.64it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:16, 73.24it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 11/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 11/10000 [00:00<02:13, 74.69it/s]\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:03<1:17:23,  2.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5069349408149719, Train Set grad_norm: 9.333438129033311e-07, Train Set base_objective: 0.4992252290248871, Train Set accuracy: 0.8820000290870667, Train Set squared_error: 0.9827274680137634, Test Set nc_accuracy: 0.6399999856948853, Test Set nc_squared_error: 1.3357681035995483, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:03<1:17:23,  2.15it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507085919380188, Train Set grad_norm: 9.980631148209795e-07, Train Set base_objective: 0.49930351972579956, Train Set accuracy: 0.8630000352859497, Train Set squared_error: 0.9829137325286865, Test Set nc_accuracy: 0.6100000143051147, Test Set nc_squared_error: 1.3453832864761353, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:32, 65.32it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:09, 76.87it/s]\u001b[AINFO:scnn:*Outer* termination criterion satisfied at iteration 6/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:15, 73.78it/s]\n",
      "Outer al:   0%|                                                                           | 7/10000 [00:03<1:19:18,  2.10it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5071607232093811, Train Set grad_norm: 9.581646054357407e-07, Train Set base_objective: 0.49933621287345886, Train Set accuracy: 0.8500000238418579, Train Set squared_error: 0.9829215407371521, Test Set nc_accuracy: 0.5899999737739563, Test Set nc_squared_error: 1.3530739545822144, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22099259495735168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.015840183001729447, Train Set grad_norm: 2.2679375871298664e-15, Train Set base_objective: 0.015840183001729447, Train Set accuracy: 1.0, Train Set squared_error: 0.0024932234328643938, Test Set nc_accuracy: 0.73, Test Set nc_squared_error: 518.1631797544798, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.001344442367553711\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005643367767333984\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0005633831024169922\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0008533000946044922\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006351470947265625\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0006287097930908203\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0006525516510009766\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.00070953369140625\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0007877349853515625\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006034374237060547\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0009162425994873047\n",
      "Full-Batch Final Test Accuracy: 0.73\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0008339881896972656\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.00067138671875\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006115436553955078\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006170272827148438\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006668567657470703\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0006690025329589844\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006668567657470703\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0006754398345947266\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006237030029296875\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006670951843261719\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.00066375732421875\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0007467269897460938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.19967971742153168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mini-Batch Final Test Accuracy: 0.68\n",
      "Running for seed: 6778 (Run 8/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.19967971742153168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▍                                                                             | 49/10000 [00:00<01:23, 118.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07036399096250534, Train Set grad_norm: 0.00012457281991373748, Train Set base_objective: 0.07036399096250534, Train Set accuracy: 1.0, Train Set squared_error: 0.013629206456243992, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 496.6712341308594, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 74/10000 [00:00<01:22, 119.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.057261452078819275, Train Set grad_norm: 3.4100390621460974e-05, Train Set base_objective: 0.057261452078819275, Train Set accuracy: 1.0, Train Set squared_error: 0.008179879747331142, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 518.478515625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 74/10000 [00:00<01:22, 119.73it/s]INFO:scnn:Termination criterion satisfied at iteration 81/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 81/10000 [00:00<01:24, 117.62it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.05045274645090103, Train Set grad_norm: 9.64743890108366e-07, Train Set base_objective: 0.05045274645090103, Train Set accuracy: 1.0, Train Set squared_error: 0.007635010872036219, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 531.6658325195312, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.19967971742153168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.051377732306718826, Train Set grad_norm: 1.0296964319422841e-05, Train Set base_objective: 0.051377732306718826, Train Set accuracy: 1.0, Train Set squared_error: 0.008067372255027294, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 527.135986328125, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.19967971742153168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 47/10000 [00:00<01:27, 113.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.07036399096250534, Train Set grad_norm: 0.00012457281991373748, Train Set base_objective: 0.07036399096250534, Train Set accuracy: 1.0, Train Set squared_error: 0.013629206456243992, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 496.6712341308594, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 72/10000 [00:00<01:25, 116.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.057261452078819275, Train Set grad_norm: 3.4100390621460974e-05, Train Set base_objective: 0.057261452078819275, Train Set accuracy: 1.0, Train Set squared_error: 0.008179879747331142, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 518.478515625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 72/10000 [00:00<01:25, 116.64it/s]INFO:scnn:Termination criterion satisfied at iteration 81/10000. Exiting optimization loop.\n",
      "fista:   1%|▋                                                                             | 81/10000 [00:00<01:26, 114.63it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 65.50991821289062, Train Set grad_norm: 1230.89306640625, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.051377732306718826, Train Set grad_norm: 1.0296964319422841e-05, Train Set base_objective: 0.051377732306718826, Train Set accuracy: 1.0, Train Set squared_error: 0.008067372255027294, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 527.135986328125, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 28/10000 [00:00<00:36, 273.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 65.50991821289062, Train Set grad_norm: 1230.89306640625, \n",
      "Train Set objective: 0.1022011935710907, Train Set grad_norm: 0.040084391832351685, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 28/10000 [00:00<00:36, 273.31it/s]INFO:scnn:Termination criterion satisfied at iteration 55/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   1%|▎                                                                  | 55/10000 [00:00<00:34, 285.72it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.238018665361551e-08, Train Set grad_norm: 6.45357517425893e-11, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 2.9424974457015196e-08, Train Set grad_norm: 1.7335491264702796e-08, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.6425557136535645, Train Set grad_norm: 0.0011679099407047033, Train Set base_objective: 0.6425557136535645, Train Set accuracy: 1.0, Train Set squared_error: 0.007635010406374931, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 459.50128173828125, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.15865108370780945, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.15865108370780945, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.71it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 8/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 8/10000 [00:00<02:32, 65.33it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:16,  7.83it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:16,  7.83it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.48921796679496765, Train Set grad_norm: 0.0008418099605478346, Train Set base_objective: 0.48051995038986206, Train Set accuracy: 0.89000004529953, Train Set squared_error: 0.9420850276947021, Test Set nc_accuracy: 0.7599999904632568, Test Set nc_squared_error: 0.9533700346946716, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<02:56, 56.53it/s]\n",
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:16,  7.83it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:46, 59.88it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4938918352127075, Train Set grad_norm: 0.0007405871292576194, Train Set base_objective: 0.48811525106430054, Train Set accuracy: 0.9030000567436218, Train Set squared_error: 0.9623172879219055, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.7259596586227417, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 15/10000 [00:00<02:12, 75.51it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<21:16,  7.83it/s]\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:05, 79.63it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 32/10000 [00:00<02:05, 79.49it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 34/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:08, 77.78it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<38:44,  4.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49337708950042725, Train Set grad_norm: 1.3586665772891138e-05, Train Set base_objective: 0.4870070219039917, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.956564724445343, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.729033350944519, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<38:44,  4.30it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4933711290359497, Train Set grad_norm: 9.01211592463369e-07, Train Set base_objective: 0.4870775640010834, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.9568590521812439, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.7275436520576477, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:33, 64.98it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:10, 76.75it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<38:44,  4.30it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:03, 80.67it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 31/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 31/10000 [00:00<02:08, 77.69it/s]\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<48:42,  3.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5062747597694397, Train Set grad_norm: 1.1178879503859207e-05, Train Set base_objective: 0.49936556816101074, Train Set accuracy: 0.9080000519752502, Train Set squared_error: 0.9968103766441345, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.9364602565765381, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 4/10000 [00:01<48:42,  3.42it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:28, 67.21it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5062642097473145, Train Set grad_norm: 7.165893407545809e-07, Train Set base_objective: 0.49928757548332214, Train Set accuracy: 0.9140000343322754, Train Set squared_error: 0.9964884519577026, Test Set nc_accuracy: 0.7699999809265137, Test Set nc_squared_error: 0.9307685494422913, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:33, 65.28it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<40:34,  4.11it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<40:34,  4.11it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5070016980171204, Train Set grad_norm: 9.939121810020879e-07, Train Set base_objective: 0.49988630414009094, Train Set accuracy: 0.9220000505447388, Train Set squared_error: 0.9988788366317749, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.9666279554367065, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:31, 66.13it/s]\u001b[AINFO:scnn:*Outer* termination criterion satisfied at iteration 5/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                            | 10/10000 [00:00<02:23, 69.60it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<37:57,  4.39it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5071550607681274, Train Set grad_norm: 7.92531920978945e-07, Train Set base_objective: 0.4999893605709076, Train Set accuracy: 0.9030000567436218, Train Set squared_error: 0.9995208978652954, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.9763926267623901, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2153010368347168, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016209638279634144, Train Set grad_norm: 2.441025329965756e-15, Train Set base_objective: 0.016209638279634144, Train Set accuracy: 1.0, Train Set squared_error: 0.0026135707588516082, Test Set nc_accuracy: 0.72, Test Set nc_squared_error: 532.2937013597796, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0013318061828613281\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005702972412109375\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0009591579437255859\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0006437301635742188\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0008387565612792969\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0008449554443359375\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0008475780487060547\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0007104873657226562\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0005891323089599609\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0005910396575927734\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0006272792816162109\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0009093284606933594\n",
      "Full-Batch Final Test Accuracy: 0.74\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.00089263916015625\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0006861686706542969\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006833076477050781\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006024837493896484\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006334781646728516\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007343292236328125\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006682872772216797\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0006821155548095703\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006201267242431641\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0007436275482177734\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0006616115570068359\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0006659030914306641\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20636320114135742, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mini-Batch Final Test Accuracy: 0.67\n",
      "Running for seed: 7820 (Run 9/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|                                                                                        | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20636320114135742, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▍                                                                             | 49/10000 [00:00<01:23, 119.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06967421621084213, Train Set grad_norm: 0.00015556201105937362, Train Set base_objective: 0.06967421621084213, Train Set accuracy: 1.0, Train Set squared_error: 0.01485845074057579, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 518.3123168945312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▍                                                                             | 61/10000 [00:00<01:23, 119.46it/s]INFO:scnn:Termination criterion satisfied at iteration 71/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:24, 118.01it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.051728371530771255, Train Set grad_norm: 8.747246056373115e-07, Train Set base_objective: 0.051728371530771255, Train Set accuracy: 1.0, Train Set squared_error: 0.008283176459372044, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 568.492431640625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0569632388651371, Train Set grad_norm: 4.1214774682885036e-05, Train Set base_objective: 0.0569632388651371, Train Set accuracy: 1.0, Train Set squared_error: 0.00904484000056982, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 554.6556396484375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.20636320114135742, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                               | 10/10000 [00:00<01:40, 99.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.20636320114135742, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 47/10000 [00:00<01:27, 113.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06967421621084213, Train Set grad_norm: 0.00015556201105937362, Train Set base_objective: 0.06967421621084213, Train Set accuracy: 1.0, Train Set squared_error: 0.01485845074057579, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 518.3123168945312, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:27, 113.22it/s]INFO:scnn:Termination criterion satisfied at iteration 71/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:28, 112.16it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 59.54255676269531, Train Set grad_norm: 1081.7291259765625, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.0569632388651371, Train Set grad_norm: 4.1214774682885036e-05, Train Set base_objective: 0.0569632388651371, Train Set accuracy: 1.0, Train Set squared_error: 0.00904484000056982, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 554.6556396484375, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|                                                                             | 0/10000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 59.54255676269531, Train Set grad_norm: 1081.7291259765625, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "quadratic_decomp:   0%|▏                                                                  | 27/10000 [00:00<00:37, 265.53it/s]INFO:scnn:Termination criterion satisfied at iteration 43/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 43/10000 [00:00<00:35, 281.64it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0660680338503425e-08, Train Set grad_norm: 2.073863650253749e-12, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5567927360534668, Train Set grad_norm: 0.0011756037129089236, Train Set base_objective: 0.5567927360534668, Train Set accuracy: 1.0, Train Set squared_error: 0.008283176459372044, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 547.5748291015625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.045903902500867844, Train Set grad_norm: 0.020241057500243187, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.16580244898796082, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.53it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:28, 67.22it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:55,  6.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.16580244898796082, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<23:55,  6.97it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4884680509567261, Train Set grad_norm: 0.0007930266438052058, Train Set base_objective: 0.47921594977378845, Train Set accuracy: 0.893000066280365, Train Set squared_error: 0.9379898905754089, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 1.0638031959533691, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<03:07, 53.20it/s]\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<19:43,  8.45it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<19:43,  8.45it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49348241090774536, Train Set grad_norm: 0.0008863087277859449, Train Set base_objective: 0.4872060716152191, Train Set accuracy: 0.9050000309944153, Train Set squared_error: 0.9590084552764893, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.7604027986526489, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:35, 64.33it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:10, 76.24it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<19:43,  8.45it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:05, 79.27it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 33/10000 [00:00<02:08, 77.79it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4928774833679199, Train Set grad_norm: 1.5504130715271458e-05, Train Set base_objective: 0.48602673411369324, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9523338079452515, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.7981324791908264, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|▎                                                                           | 42/10000 [00:00<02:05, 79.25it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 46/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 46/10000 [00:00<02:07, 78.02it/s]\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<56:03,  2.97it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:00<56:03,  2.97it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:51, 58.23it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4928448796272278, Train Set grad_norm: 9.880222933134064e-07, Train Set base_objective: 0.4861612319946289, Train Set accuracy: 0.9120000600814819, Train Set squared_error: 0.9522292613983154, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.7989010214805603, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 15/10000 [00:00<02:19, 71.40it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 3/10000 [00:01<56:03,  2.97it/s]\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:09, 77.11it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 32/10000 [00:00<02:08, 77.46it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 40/10000 [00:00<02:07, 78.11it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5066566467285156, Train Set grad_norm: 2.7325098926667124e-05, Train Set base_objective: 0.49915510416030884, Train Set accuracy: 0.9070000648498535, Train Set squared_error: 0.9938278794288635, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.881956934928894, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 43/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:10, 76.10it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:11:34,  2.33it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:01<1:11:34,  2.33it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:30, 66.43it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 11/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 11/10000 [00:00<02:20, 71.34it/s]\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<55:27,  3.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5066210031509399, Train Set grad_norm: 9.840417760642595e-07, Train Set base_objective: 0.49900850653648376, Train Set accuracy: 0.9230000376701355, Train Set squared_error: 0.9938549995422363, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.8846251964569092, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 5/10000 [00:01<55:27,  3.00it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507649838924408, Train Set grad_norm: 8.081691476036212e-07, Train Set base_objective: 0.4998648166656494, Train Set accuracy: 0.8920000195503235, Train Set squared_error: 0.9971970915794373, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9351333975791931, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:30, 66.48it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 10/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 10/10000 [00:00<02:23, 69.67it/s]\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<45:12,  3.68it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 6/10000 [00:01<45:12,  3.68it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5078601241111755, Train Set grad_norm: 9.851709137365106e-07, Train Set base_objective: 0.4999951422214508, Train Set accuracy: 0.8710000514984131, Train Set squared_error: 0.9979134202003479, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9498631358146667, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:34, 64.61it/s]\u001b[AINFO:scnn:*Outer* termination criterion satisfied at iteration 6/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:30, 66.40it/s]\n",
      "Outer al:   0%|                                                                             | 7/10000 [00:01<44:28,  3.74it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5079467296600342, Train Set grad_norm: 9.532780040899524e-07, Train Set base_objective: 0.5000429153442383, Train Set accuracy: 0.831000030040741, Train Set squared_error: 0.9982715845108032, Test Set nc_accuracy: 0.6499999761581421, Test Set nc_squared_error: 0.9592610597610474, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.22229033708572388, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.01617964141348025, Train Set grad_norm: 2.1507170063001494e-15, Train Set base_objective: 0.01617964141348025, Train Set accuracy: 1.0, Train Set squared_error: 0.002566592274064959, Test Set nc_accuracy: 0.7, Test Set nc_squared_error: 536.9392793942504, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.0015497207641601562\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005946159362792969\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0006344318389892578\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0008118152618408203\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006392002105712891\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.00084686279296875\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0008091926574707031\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0006010532379150391\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.000797271728515625\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0007917881011962891\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.0006067752838134766\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0007944107055664062\n",
      "Full-Batch Final Test Accuracy: 0.74\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0010793209075927734\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0006062984466552734\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006630420684814453\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006968975067138672\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.0006837844848632812\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007636547088623047\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006628036499023438\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0007860660552978516\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006744861602783203\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006895065307617188\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0006616115570068359\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0007197856903076172\n",
      "Mini-Batch Final Test Accuracy: 0.68\n",
      "Running for seed: 9496 (Run 10/10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2087039351463318, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                               | 10/10000 [00:00<01:44, 95.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.2087039351463318, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 46/10000 [00:00<01:27, 113.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06946728378534317, Train Set grad_norm: 0.00012078761938028038, Train Set base_objective: 0.06946728378534317, Train Set accuracy: 1.0, Train Set squared_error: 0.014203587546944618, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 572.9508666992188, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 70/10000 [00:00<01:28, 112.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05618627369403839, Train Set grad_norm: 1.2774808055837639e-05, Train Set base_objective: 0.05618627369403839, Train Set accuracy: 1.0, Train Set squared_error: 0.01052863709628582, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 564.5533447265625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Termination criterion satisfied at iteration 74/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 74/10000 [00:00<01:29, 110.94it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.051733944565057755, Train Set grad_norm: 9.299170642407262e-07, Train Set base_objective: 0.051733944565057755, Train Set accuracy: 1.0, Train Set squared_error: 0.008641133084893227, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 590.9371948242188, group_sparsity: 0.0, \n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2087039351463318, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "fista:   0%|                                                                              | 11/10000 [00:00<01:36, 103.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.2087039351463318, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   0%|▎                                                                             | 47/10000 [00:00<01:28, 112.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.06946728378534317, Train Set grad_norm: 0.00012078761938028038, Train Set base_objective: 0.06946728378534317, Train Set accuracy: 1.0, Train Set squared_error: 0.014203587546944618, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 572.9508666992188, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "fista:   1%|▌                                                                             | 71/10000 [00:00<01:28, 112.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.05618627369403839, Train Set grad_norm: 1.2774808055837639e-05, Train Set base_objective: 0.05618627369403839, Train Set accuracy: 1.0, Train Set squared_error: 0.01052863709628582, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 564.5533447265625, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Termination criterion satisfied at iteration 74/10000. Exiting optimization loop.\n",
      "fista:   1%|▌                                                                             | 74/10000 [00:00<01:28, 111.59it/s]\n",
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 59.47425079345703, Train Set grad_norm: 1132.058837890625, \n",
      "quadratic_decomp:   0%|▏                                                                  | 26/10000 [00:00<00:38, 257.18it/s]INFO:scnn:Termination criterion satisfied at iteration 45/10000. Exiting optimization loop.\n",
      "quadratic_decomp:   0%|▎                                                                  | 45/10000 [00:00<00:35, 279.67it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 1.0921671567132307e-08, Train Set grad_norm: 3.5438419559996603e-11, \n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.5679903626441956, Train Set grad_norm: 0.0011715978616848588, Train Set base_objective: 0.5679903626441956, Train Set accuracy: 1.0, Train Set squared_error: 0.008641133084893227, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 507.87725830078125, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 59.47425079345703, Train Set grad_norm: 1132.058837890625, \n",
      "Train Set objective: 0.053256161510944366, Train Set grad_norm: 0.022972431033849716, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Optimization Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.16867515444755554, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:51, 58.15it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 9/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 9/10000 [00:00<02:35, 64.22it/s]\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<24:43,  6.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5, Train Set grad_norm: 0.16867515444755554, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 1/10000 [00:00<24:43,  6.74it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4882667064666748, Train Set grad_norm: 0.0008229288505390286, Train Set base_objective: 0.4788700342178345, Train Set accuracy: 0.8910000324249268, Train Set squared_error: 0.9369505047798157, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 1.0784876346588135, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 5/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 5/10000 [00:00<03:06, 53.58it/s]\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<20:02,  8.32it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<20:02,  8.32it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.4933464825153351, Train Set grad_norm: 0.000911173818167299, Train Set base_objective: 0.4869786202907562, Train Set accuracy: 0.9070000648498535, Train Set squared_error: 0.9582544565200806, Test Set nc_accuracy: 0.75, Test Set nc_squared_error: 0.7686620950698853, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:38, 63.20it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:09, 76.95it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<20:02,  8.32it/s]\n",
      "Inner al:   0%|▏                                                                           | 24/10000 [00:00<02:08, 77.59it/s]\u001b[A\n",
      "Inner al:   0%|▏                                                                           | 32/10000 [00:00<02:08, 77.35it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 41/10000 [00:00<02:06, 78.97it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49261167645454407, Train Set grad_norm: 2.265305920445826e-05, Train Set base_objective: 0.48557576537132263, Train Set accuracy: 0.9130000472068787, Train Set squared_error: 0.9500886797904968, Test Set nc_accuracy: 0.7299999594688416, Test Set nc_squared_error: 0.8340170979499817, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:00<20:02,  8.32it/s]\n",
      "Inner al:   0%|▍                                                                           | 50/10000 [00:00<02:01, 81.63it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 59/10000 [00:00<02:05, 78.96it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49244827032089233, Train Set grad_norm: 4.159551281190943e-06, Train Set base_objective: 0.4856571853160858, Train Set accuracy: 0.9120000600814819, Train Set squared_error: 0.9486494660377502, Test Set nc_accuracy: 0.7199999690055847, Test Set nc_squared_error: 0.8836374282836914, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:01<20:02,  8.32it/s]\n",
      "Inner al:   1%|▌                                                                           | 68/10000 [00:00<02:03, 80.28it/s]\u001b[A\n",
      "Inner al:   1%|▌                                                                           | 77/10000 [00:00<02:05, 79.04it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                           | 86/10000 [00:01<02:02, 80.73it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49230337142944336, Train Set grad_norm: 3.6838928281213157e-06, Train Set base_objective: 0.4854913055896759, Train Set accuracy: 0.9100000262260437, Train Set squared_error: 0.9452120065689087, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 0.9859203696250916, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 2/10000 [00:01<20:02,  8.32it/s]\n",
      "Inner al:   1%|▋                                                                           | 95/10000 [00:01<02:01, 81.76it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 103/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▊                                                                          | 103/10000 [00:01<02:04, 79.74it/s]\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:49:42,  1.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49217137694358826, Train Set grad_norm: 1.0902838312176755e-06, Train Set base_objective: 0.48539048433303833, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9410123825073242, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.1653205156326294, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:49:42,  1.52it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:36, 63.86it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.49215835332870483, Train Set grad_norm: 9.473425848227635e-07, Train Set base_objective: 0.48538243770599365, Train Set accuracy: 0.9110000729560852, Train Set squared_error: 0.9405394792556763, Test Set nc_accuracy: 0.7400000095367432, Test Set nc_squared_error: 1.1901501417160034, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:15, 73.48it/s]\u001b[A\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:01<1:49:42,  1.52it/s]\n",
      "Inner al:   0%|▏                                                                           | 25/10000 [00:00<02:04, 79.81it/s]\u001b[A\n",
      "Inner al:   0%|▎                                                                           | 34/10000 [00:00<02:07, 77.98it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5061849355697632, Train Set grad_norm: 2.6726407668320462e-05, Train Set base_objective: 0.4984601140022278, Train Set accuracy: 0.8910000324249268, Train Set squared_error: 0.9801788330078125, Test Set nc_accuracy: 0.7099999785423279, Test Set nc_squared_error: 0.9254958629608154, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:49:42,  1.52it/s]\n",
      "Inner al:   0%|▎                                                                           | 43/10000 [00:00<02:03, 80.66it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 52/10000 [00:00<02:07, 77.90it/s]\u001b[A\n",
      "Inner al:   1%|▍                                                                           | 61/10000 [00:00<02:04, 79.78it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5060716271400452, Train Set grad_norm: 2.667869921424426e-06, Train Set base_objective: 0.49842625856399536, Train Set accuracy: 0.893000066280365, Train Set squared_error: 0.9804867506027222, Test Set nc_accuracy: 0.699999988079071, Test Set nc_squared_error: 0.9496061205863953, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:49:42,  1.52it/s]\n",
      "Inner al:   1%|▌                                                                           | 70/10000 [00:00<02:01, 81.49it/s]\u001b[A\n",
      "Inner al:   1%|▌                                                                           | 79/10000 [00:01<02:06, 78.52it/s]\u001b[A\n",
      "Inner al:   1%|▋                                                                           | 88/10000 [00:01<02:01, 81.37it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5059770345687866, Train Set grad_norm: 2.0983634385629557e-06, Train Set base_objective: 0.4983733594417572, Train Set accuracy: 0.8920000195503235, Train Set squared_error: 0.9784945249557495, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 0.9981528520584106, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 3/10000 [00:02<1:49:42,  1.52it/s]\n",
      "Inner al:   1%|▋                                                                           | 97/10000 [00:01<02:01, 81.23it/s]\u001b[A\n",
      "Inner al:   1%|▊                                                                          | 106/10000 [00:01<02:04, 79.39it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 113/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   1%|▊                                                                          | 113/10000 [00:01<02:04, 79.48it/s]\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<2:40:21,  1.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5058807730674744, Train Set grad_norm: 1.0735004707385087e-06, Train Set base_objective: 0.4983294606208801, Train Set accuracy: 0.8960000276565552, Train Set squared_error: 0.9757671356201172, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 1.0804545879364014, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 4/10000 [00:02<2:40:21,  1.04it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5058272480964661, Train Set grad_norm: 9.899130191115546e-07, Train Set base_objective: 0.49830734729766846, Train Set accuracy: 0.8940000534057617, Train Set squared_error: 0.9740563035011292, Test Set nc_accuracy: 0.6899999976158142, Test Set nc_squared_error: 1.1498037576675415, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:27, 67.56it/s]\u001b[A\n",
      "Inner al:   0%|                                                                            | 16/10000 [00:00<02:10, 76.34it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 21/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|▏                                                                           | 21/10000 [00:00<02:10, 76.60it/s]\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:03<1:59:26,  1.39it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 5/10000 [00:03<1:59:26,  1.39it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:29, 66.78it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 14/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 14/10000 [00:00<02:13, 74.53it/s]\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:03<1:29:50,  1.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.506659746170044, Train Set grad_norm: 9.697034784039715e-07, Train Set base_objective: 0.4990095794200897, Train Set accuracy: 0.8640000224113464, Train Set squared_error: 0.9768310189247131, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 1.1791690587997437, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 6/10000 [00:03<1:29:50,  1.85it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5068163275718689, Train Set grad_norm: 9.74116687757487e-07, Train Set base_objective: 0.49908247590065, Train Set accuracy: 0.8470000624656677, Train Set squared_error: 0.9770041704177856, Test Set nc_accuracy: 0.6800000071525574, Test Set nc_squared_error: 1.1879746913909912, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:27, 67.81it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 12/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                            | 12/10000 [00:00<02:16, 73.09it/s]\n",
      "Outer al:   0%|                                                                           | 7/10000 [00:03<1:09:46,  2.39it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                           | 7/10000 [00:03<1:09:46,  2.39it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5069065093994141, Train Set grad_norm: 9.773528972800705e-07, Train Set base_objective: 0.4991208016872406, Train Set accuracy: 0.7970000505447388, Train Set squared_error: 0.977112352848053, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.1947286128997803, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:31, 65.86it/s]\u001b[AINFO:scnn:*Inner* termination criterion satisfied at iteration 7/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 7/10000 [00:00<02:37, 63.48it/s]\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:03<53:46,  3.10it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 8/10000 [00:03<53:46,  3.10it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[A"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.5069597363471985, Train Set grad_norm: 9.898582220557728e-07, Train Set base_objective: 0.49913108348846436, Train Set accuracy: 0.784000039100647, Train Set squared_error: 0.9771068692207336, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.19754159450531, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:*Inner* termination criterion satisfied at iteration 6/10000. Exiting *inner* optimization loop.\n",
      "Inner al:   0%|                                                                             | 6/10000 [00:00<02:41, 61.97it/s]\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:03<42:20,  3.93it/s]\n",
      "                                                                                                                              \u001b[A\n",
      "Outer al:   0%|                                                                             | 9/10000 [00:03<42:20,  3.93it/s]\n",
      "Inner al:   0%|                                                                                     | 0/10000 [00:00<?, ?it/s]\u001b[AINFO:scnn:*Outer* termination criterion satisfied at iteration 9/10000. Exiting *outer* optimization loop.\n",
      "Inner al:   0%|                                                                             | 4/10000 [00:00<02:57, 56.40it/s]\n",
      "Outer al:   0%|                                                                          | 10/10000 [00:03<1:05:18,  2.55it/s]\n",
      "INFO:scnn:Post-Optimization Metrics: Train Set objective: 0.507032036781311, Train Set grad_norm: 9.97187726170523e-07, Train Set base_objective: 0.49913865327835083, Train Set accuracy: 0.7520000338554382, Train Set squared_error: 0.97701096534729, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.202799916267395, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Set objective: 0.507000207901001, Train Set grad_norm: 9.742102520249318e-07, Train Set base_objective: 0.4991386830806732, Train Set accuracy: 0.7560000419616699, Train Set squared_error: 0.9770618081092834, Test Set nc_accuracy: 0.6599999666213989, Test Set nc_squared_error: 1.2010070085525513, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:scnn:Pre-Training Metrics: Train Set objective: 0.5, Train Set grad_norm: 0.2247084528207779, Train Set base_objective: 0.5, Train Set accuracy: 0.0, Train Set squared_error: 1.0, Test Set nc_accuracy: 0.0, Test Set nc_squared_error: 1.0, group_sparsity: 1.0, \n",
      "INFO:scnn:Post-Training Metrics: Train Set objective: 0.016179612224522084, Train Set grad_norm: 2.5432330495141575e-15, Train Set base_objective: 0.016179612224522084, Train Set accuracy: 1.0, Train Set squared_error: 0.0025786465572739245, Test Set nc_accuracy: 0.71, Test Set nc_squared_error: 575.1643135795002, group_sparsity: 0.0, \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Full-Batch Epoch: 1, Time Elapsed: 0.001352548599243164\n",
      "Full-Batch Epoch: 251, Time Elapsed: 0.0005533695220947266\n",
      "Full-Batch Epoch: 501, Time Elapsed: 0.0006024837493896484\n",
      "Full-Batch Epoch: 751, Time Elapsed: 0.0006077289581298828\n",
      "Full-Batch Epoch: 1001, Time Elapsed: 0.0006246566772460938\n",
      "Full-Batch Epoch: 1251, Time Elapsed: 0.0005996227264404297\n",
      "Full-Batch Epoch: 1501, Time Elapsed: 0.0006229877471923828\n",
      "Full-Batch Epoch: 1751, Time Elapsed: 0.0007977485656738281\n",
      "Full-Batch Epoch: 2001, Time Elapsed: 0.0006394386291503906\n",
      "Full-Batch Epoch: 2251, Time Elapsed: 0.0006220340728759766\n",
      "Full-Batch Epoch: 2501, Time Elapsed: 0.000720977783203125\n",
      "Full-Batch Epoch: 2751, Time Elapsed: 0.0006144046783447266\n",
      "Full-Batch Final Test Accuracy: 0.74\n",
      "Mini-Batch Epoch: 1, Time Elapsed: 0.0011241436004638672\n",
      "Mini-Batch Epoch: 251, Time Elapsed: 0.0006814002990722656\n",
      "Mini-Batch Epoch: 501, Time Elapsed: 0.0006213188171386719\n",
      "Mini-Batch Epoch: 751, Time Elapsed: 0.0006952285766601562\n",
      "Mini-Batch Epoch: 1001, Time Elapsed: 0.00069427490234375\n",
      "Mini-Batch Epoch: 1251, Time Elapsed: 0.0007007122039794922\n",
      "Mini-Batch Epoch: 1501, Time Elapsed: 0.0006873607635498047\n",
      "Mini-Batch Epoch: 1751, Time Elapsed: 0.0006825923919677734\n",
      "Mini-Batch Epoch: 2001, Time Elapsed: 0.0006284713745117188\n",
      "Mini-Batch Epoch: 2251, Time Elapsed: 0.0006611347198486328\n",
      "Mini-Batch Epoch: 2501, Time Elapsed: 0.0006830692291259766\n",
      "Mini-Batch Epoch: 2751, Time Elapsed: 0.0006659030914306641\n",
      "Mini-Batch Final Test Accuracy: 0.68\n",
      "All seeds completed and metrics saved.\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import pickle\n",
    "import time\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "\n",
    "# Set the number of seeds to run\n",
    "num_seeds = 10\n",
    "seeds = np.random.randint(0, 10000, size=num_seeds)\n",
    "\n",
    "# Initialize a dictionary to store the metrics for each seed\n",
    "all_metrics = {}\n",
    "\n",
    "# Loop over each seed\n",
    "for seed_idx, seed in enumerate(seeds):\n",
    "    print(f\"Running for seed: {seed} (Run {seed_idx+1}/{num_seeds})\")\n",
    "\n",
    "    # Set the random seed for reproducibility\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "\n",
    "    ### Convex Model Experiments ###\n",
    "\n",
    "    lam = 1e-4\n",
    "    max_neurons = 50\n",
    "    G = sample_gate_vectors(seed, X_train_SCNN.shape[-1], max_neurons)\n",
    "    metrics = Metrics(metric_freq=25, model_loss=True, train_accuracy=True, train_mse=True, test_mse=True, test_accuracy=True, neuron_sparsity=True)\n",
    "\n",
    "    # First model: Convex Gated ReLU\n",
    "    model = ConvexGatedReLU(G, c=y_train_SCNN.shape[-1])\n",
    "    solver = RFISTA(model)\n",
    "    regularizer = L1(lam)\n",
    "\n",
    "    grelu_model, grelu_metrics = optimize_model(\n",
    "        model,\n",
    "        solver,\n",
    "        metrics,\n",
    "        X_train_SCNN.cpu().numpy(),\n",
    "        y_train_SCNN.cpu().numpy(),\n",
    "        X_test_SCNN.cpu().numpy(),\n",
    "        y_test_SCNN.cpu().numpy(),\n",
    "        regularizer=regularizer,\n",
    "        verbose=True,\n",
    "        device='cuda',\n",
    "    )\n",
    "\n",
    "    # Second model: Approximate Cone Decomposition\n",
    "    model = ConvexGatedReLU(G)\n",
    "    solver = ApproximateConeDecomposition(model)\n",
    "    cd_model, cd_metrics = optimize_model(\n",
    "        model,\n",
    "        solver,\n",
    "        metrics,\n",
    "        X_train_SCNN.cpu().numpy(),\n",
    "        y_train_SCNN.cpu().numpy(),\n",
    "        X_test_SCNN.cpu().numpy(),\n",
    "        y_test_SCNN.cpu().numpy(),\n",
    "        regularizer=regularizer,\n",
    "        verbose=True,\n",
    "        device='cuda',\n",
    "    )\n",
    "\n",
    "    # Third model: Convex ReLU with AL\n",
    "    model = ConvexReLU(G)\n",
    "    solver = AL(model)\n",
    "    regularizer = L1(1.25 * 1e-3)\n",
    "    relu_model, relu_metrics = optimize_model(\n",
    "        model,\n",
    "        solver,\n",
    "        metrics,\n",
    "        X_train_SCNN.cpu().numpy(),\n",
    "        y_train_SCNN.cpu().numpy(),\n",
    "        X_test_SCNN.cpu().numpy(),\n",
    "        y_test_SCNN.cpu().numpy(),\n",
    "        regularizer,\n",
    "        verbose=True,\n",
    "        device='cuda',\n",
    "    )\n",
    "\n",
    "    # Fourth model: Least-Squares Solver\n",
    "    model = ConvexGatedReLU(G)\n",
    "    solver = LeastSquaresSolver(model, tol=1e-8)\n",
    "    regularizer = L2(0.001)\n",
    "    lstsq_model, lstsq_metrics = optimize_model(\n",
    "        model,\n",
    "        solver,\n",
    "        metrics,\n",
    "        X_train_SCNN.cpu().numpy(),\n",
    "        y_train_SCNN.cpu().numpy(),\n",
    "        X_test_SCNN.cpu().numpy(),\n",
    "        y_test_SCNN.cpu().numpy(),\n",
    "        regularizer,\n",
    "        verbose=True,\n",
    "    )\n",
    "\n",
    "    ### Nonconvex Distillation Model Experiments ###\n",
    "\n",
    "    # Define nonconvex distillation model class\n",
    "    class nonconvex_distil_model(nn.Module):\n",
    "        def __init__(self, hidden_units=100):\n",
    "            super().__init__()\n",
    "            self.fc1 = torch.nn.Linear(in_features=X_train_SCNN.shape[-1], out_features=hidden_units, bias=False)\n",
    "            self.fc2 = torch.nn.Linear(in_features=hidden_units, out_features=y_train_SCNN.shape[-1], bias=False)\n",
    "            self.relu = torch.nn.ReLU()\n",
    "    \n",
    "        def forward(self, x):\n",
    "            x = self.fc1(x)\n",
    "            x = self.relu(x)\n",
    "            x = self.fc2(x)\n",
    "            return x\n",
    "\n",
    "    # Full-batch Adam nonconvex distillation model\n",
    "    def run_full_batch_adam():\n",
    "        hidden_units = 6\n",
    "        distil_model = nonconvex_distil_model(hidden_units).to(device)\n",
    "        optimizer = torch.optim.Adam(distil_model.parameters(), lr=1e-2, weight_decay=1e-3)\n",
    "        loss_function = torch.nn.MSELoss()\n",
    "\n",
    "        torch.set_grad_enabled(True)\n",
    "\n",
    "        X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
    "        y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n",
    "\n",
    "        total_time = 0\n",
    "        time_budget = 2  # Time budget in seconds\n",
    "        epoch = 0\n",
    "        time_list = []\n",
    "        acc_list = []\n",
    "\n",
    "        # Full-batch training loop\n",
    "        while total_time < time_budget:\n",
    "            start_time = time.time()\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            output = distil_model(X_train_SCNN_nn)\n",
    "            loss = loss_function(output, y_train_SCNN_nn)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            time_elapse = time.time() - start_time\n",
    "            total_time += time_elapse\n",
    "\n",
    "            if epoch % 250 == 0:\n",
    "                print(f\"Full-Batch Epoch: {epoch+1}, Time Elapsed: {time_elapse}\")\n",
    "                time_list.append(total_time)\n",
    "                acc_list.append(accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy()))\n",
    "            epoch += 1\n",
    "\n",
    "        final_accuracy = accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy())\n",
    "        print(f\"Full-Batch Final Test Accuracy: {final_accuracy}\")\n",
    "        return time_list, acc_list, final_accuracy\n",
    "\n",
    "    # Mini-batch Adam nonconvex distillation model (batch size 64)\n",
    "    def run_batch_adam(batch_size=128):\n",
    "        hidden_units = 6\n",
    "        distil_model = nonconvex_distil_model(hidden_units).to(device)\n",
    "        optimizer = torch.optim.Adam(distil_model.parameters(), lr=1e-3, weight_decay=1e-3)\n",
    "        loss_function = torch.nn.MSELoss()\n",
    "\n",
    "        torch.set_grad_enabled(True)\n",
    "\n",
    "        X_train_SCNN_nn = torch.tensor(X_train_SCNN, dtype=torch.float32).to(device)\n",
    "        y_train_SCNN_nn = torch.tensor(y_train_SCNN, dtype=torch.float32).to(device)\n",
    "\n",
    "        # Create DataLoader for batching\n",
    "        train_dataset = TensorDataset(X_train_SCNN_nn, y_train_SCNN_nn)\n",
    "        train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "        total_time = 0\n",
    "        time_budget = 2  # Time budget in seconds\n",
    "        epoch = 0\n",
    "        time_list = []\n",
    "        acc_list = []\n",
    "\n",
    "        # Mini-batch training loop\n",
    "        while total_time < time_budget:\n",
    "            for batch_X, batch_y in train_loader:\n",
    "                start_time = time.time()\n",
    "\n",
    "                optimizer.zero_grad()\n",
    "                output = distil_model(batch_X)\n",
    "                loss = loss_function(output, batch_y)\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "\n",
    "                time_elapse = time.time() - start_time\n",
    "                total_time += time_elapse\n",
    "\n",
    "                if epoch % 250 == 0:\n",
    "                    print(f\"Mini-Batch Epoch: {epoch+1}, Time Elapsed: {time_elapse}\")\n",
    "                    time_list.append(total_time)\n",
    "                    acc_list.append(accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy()))\n",
    "                epoch += 1\n",
    "\n",
    "                if total_time >= time_budget:\n",
    "                    break\n",
    "\n",
    "        final_accuracy = accuracy(distil_model(X_test_SCNN).detach().cpu().numpy(), y_test_SCNN.cpu().numpy())\n",
    "        print(f\"Mini-Batch Final Test Accuracy: {final_accuracy}\")\n",
    "        return time_list, acc_list, final_accuracy\n",
    "\n",
    "    # Run both full-batch and mini-batch versions\n",
    "    full_batch_time_list, full_batch_acc_list, full_batch_final_acc = run_full_batch_adam()\n",
    "    batch_time_list, batch_acc_list, batch_final_acc = run_batch_adam(batch_size=64)\n",
    "\n",
    "    # Store metrics for this seed (including time and accuracy lists for both full-batch and mini-batch)\n",
    "    all_metrics[seed] = {\n",
    "        \"relu_metrics\": relu_metrics,\n",
    "        \"grelu_metrics\": grelu_metrics,\n",
    "        \"cd_metrics\": cd_metrics,\n",
    "        \"lstsq_metrics\": lstsq_metrics,\n",
    "        \"full_batch_adam_metrics\": [full_batch_time_list, full_batch_acc_list],  # Full-batch Adam\n",
    "        \"mini_batch_adam_metrics\": [batch_time_list, batch_acc_list],  # Mini-batch Adam with batch size 64\n",
    "    }\n",
    "\n",
    "# After all seeds are done, save all metrics to a file\n",
    "with open('./combined_metrics_multiple_seeds.pickle', 'wb') as handle:\n",
    "    pickle.dump(all_metrics, handle)\n",
    "\n",
    "print(\"All seeds completed and metrics saved.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "with open('./combined_metrics_multiple_seeds.pickle', 'rb') as handle:\n",
    "    all_metrics = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['relu_metrics', 'grelu_metrics', 'cd_metrics', 'lstsq_metrics', 'full_batch_adam_metrics', 'mini_batch_adam_metrics'])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_metrics[6607].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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87nPfQ7DMIjFYpx33nmUlJRQUlLCV7/6VYQQg85znxtE3zUd7tPHf/7zHz72sY8xffr0wjW84ooryGazhTIXXHABP//5zwv72H4bQ/kgv/nmm5x88slEo1HC4TDHH388L7300oAyfcf8/PPPc+WVV1JRUUEoFOIjH/kIHR0dw122HfKBD3wAgPXr1w9Y/uCDD7JkyRICgQDl5eV88pOfpLm5eUCZ7f1k++jvp7hp0yYqKioAuO666wrno+8cDOVH23fP/OUvf2HhwoWFe72vHfRnNG0C4JZbbmG//fYjGAxSUlLCwQcfzB/+8Icdnp+mpiZOP/10QqEQlZWVXHHFFYPa7PbH3Mcf//hHlixZQiQSIRqNsmjRIn76058C7vX82Mc+BsCxxx47aBh7uHO7I4ZrK6O5bxzH4dprr6W2tpZgMMixxx7LihUrdsmved9996W8vHzQ/TXa/vCJJ57gyCOPpLi4mHA4zLx58/jmN79Z+H20/V0fL7/8MsuWLaOoqIhgMMjRRx/N888/X/h9R31RbW3tqF6GEokEAFVVVQOW19TUABSML0NxzDHHcP755wNwyCGHoCjKgPM/mrbZ56awfv16PvjBDxKJRPjEJz6xw3rviO3v876+84c//CF33nkns2fPxufzccghh/Dqq68Wyt1zzz0oisKbb745aJs33HADmqYNOob+zJgxgw996EM8++yzHHzwwQQCARYtWlRoL3/+859ZtGhR4fmy/X7eeecdLrjgAmbNmoXf76e6uppPf/rTQ7q79O3D7/cze/Zs7rjjjmHnSvzud78rXIvS0lLOOeccGhsbB5Q55phjWLhwIStWrODYY48lGAxSV1fHTTfdNGh7o2kXiqKQTqf5zW9+U7g/94Z5B3u+meS/gE996lN885vf5PHHH+czn/nMoN8rKiq49957+d73vkcqleLGG28E3AfBvffeyxVXXEF9fT1f/vKXC+Udx+G0007jueee47Of/Sz77rsv7777Lj/5yU9Ys2bNIF+ip59+mgceeIDLLruM8vJyZsyYQVtbG+973/sK4qGiooJHHnmEiy66iEQiMWgy4P/7f/8PVVW56qqriMfj3HTTTXziE5/g5ZdfBuBb3/oW8XicpqYmfvKTnwCM6Pf1yCOPYNs255133rBlzjvvPJ555hkeffRRLr744sLyf/3rX9x///1cfvnl+Hw+brvtNpYtW8Yrr7zCwoULOeOMM1izZg333XcfP/nJTwoWzj5hNRxf/OIXqa6u5rrrruOll17izjvvpLi4mBdeeIHp06dzww038M9//pMf/OAHLFy4cNi6913T/pimyRVXXDHAkvfggw+SyWT4whe+QFlZGa+88gq33HILTU1NPPjgg4BrlW1paeGJJ54YtM2hWL58OR/4wAeIRqN89atfxePxcMcdd3DMMcfwr3/9i8MOO2zQMZeUlHDNNdewadMmbr75Zi677DLuv//+He5rKPoe/CUlJYVlv/71r7nwwgs55JBDuPHGG2lra+OnP/0pzz//PG+++eaYrFoVFRX84he/4Atf+AIf+chHOOOMMwDYf//9R1zvueee489//jOXXHIJkUiEn/3sZ3z0ox9ly5YtlJWVAYy6Tfzyl7/k8ssv58wzz+RLX/oSuVyOd955h5dffplzzz132Dpks1mOP/54tmzZwuWXX05tbS333nsvTz/99A6P+4knnuDjH/84xx9/PN///vcBWLlyJc8//zxf+tKXOOqoo7j88sv52c9+xje/+U323XdfgML3eDOa++Yb3/gGN910E6eeeipLly7l7bffZunSpeRyuZ3ebzwep6enh9mzZxeWjbY/XL58OR/60IfYf//9uf766/H5fKxbt26AoO1jR/0duP3qySefzJIlS7jmmmtQVZV77rmH4447jv/85z8ceuihO90Xbc9RRx2Fqqp86Utf4kc/+hH19fW88847fO973+P0009n/vz5w677rW99i3nz5nHnnXdy/fXXM3PmzML5G0vbtCyLpUuXcuSRR/LDH/6QYDA4pmMYC3/4wx9IJpN87nOfQ1EUbrrpJs444ww2bNiAx+PhzDPP5NJLL+X3v//9IMv573//e4455hjq6upG3Me6des499xz+dznPscnP/lJfvjDH3Lqqady++23881vfpNLLrkEgBtvvJGzzjqL1atXo6quXfKJJ55gw4YNXHjhhVRXV7N8+XLuvPNOli9fzksvvVQQv2+++SbLli2jpqaG6667Dtu2uf7664e8/t/73vf49re/zVlnncXFF19MR0cHt9xyC0cdddSga9HT08OyZcs444wzOOuss/jTn/7E1772NRYtWsTJJ58MjL5d3HvvvVx88cUceuihfPaznwUY0L72WCbbx0OyzQf51VdfHbZMUVGROPDAAwt/D+Xrd/TRR4v99ttv0LoNDQ3ilFNOGbDs3nvvFaqqiv/85z8Dlt9+++0CEM8//3xhGSBUVRXLly8fUPaiiy4SNTU1orOzc8Dyc845RxQVFYlMJiOE2OYfue+++w7wYfzpT38qAPHuu+8Wlo3FB/l//ud/BCDefPPNYcu88cYbAhBXXnnlgOMBxGuvvVZYtnnzZuH3+8VHPvKRwrKR/P4aGhoG+Fv1XcOlS5cKx3EKyw8//HChKIr4/Oc/X1hmWZaor68XRx999IBtMoxPbB+XXHKJ0DRNPP3004Vlfee4PzfeeKNQFEVs3ry5sGwkH+Tt93v66acLr9cr1q9fX1jW0tIiIpGIOOqoowYd8wknnDDgmK+44gqhaZqIxWLDHosQ2+7h1atXi46ODrFp0ybxq1/9SgQCAVFRUSHS6bQQwvWlraysFAsXLhzgG/yPf/xDAOLqq68uLDv66KMHnVchXB/C/vfVSD7IQ7UtQHi9XrFu3brCsrffflsA4pZbbiksG22b+PCHPzxkW90RN998swDEAw88UFiWTqfFnDlzBvkOb3/MX/rSl0Q0GhWWZQ27/ZF8kLc/t6P1QR6urezovmltbRW6rovTTz99wPauvfZaAYzK3xEQF110kejo6BDt7e3itddeE8uWLROA+MEPflAoN9r+8Cc/+YkAREdHx7D7HG1/5ziO2GeffQb1GZlMRsycOVOceOKJhWUj9UX92VH/edddd4ni4uJCH9h3HkczB2Go59RY2ub5558vAPH1r399h/vanpH6r+3v8777sqysTHR3dxeW//WvfxWA+Pvf/15Y9vGPf1zU1tYO8L/ue2b0v6+H8kFuaGgQgHjhhRcKyx577DEBiEAgMKD/veOOOwa1q6H67vvuu08A4t///ndh2amnniqCwaBobm4uLFu7dq3QdX3AOdm0aZPQNE1873vfG7DNd999V+i6PmB537yd3/72t4Vl+XxeVFdXi49+9KOFZWPRCXujD7J0sdhDCIfDo45mMRoefPBB9t13X+bPn09nZ2fhc9xxxwHwzDPPDCh/9NFHD/BjFkLw0EMPceqppyKEGLCNpUuXEo/HeeONNwZs48ILLxxg/ewbSt+wYcNOHUPf+YhEIsOW6futb3ixj8MPP5wlS5YU/p4+fTof/vCHeeyxx7Bte6fqA3DRRRcNGPY67LDDEEJw0UUXFZZpmsbBBx88puP+7W9/y2233cZNN93EscceW1jef1g0nU7T2dnJ+9//foQQQw4d7gjbtnn88cc5/fTTmTVrVmF5TU0N5557Ls8999ygc/nZz352wDF/4AMfwLZtNm/ePKp9zps3j4qKCmbMmMGnP/1p5syZwyOPPFKwLr322mu0t7dzySWXDPCXPuWUU5g/f/5ui0hwwgknDLCK7L///kSj0cJ1HEubKC4upqmpacCQ72j45z//SU1NDWeeeWZhWTAYLFhtRqK4uJh0Os0TTzwxpn1OFDu6b5566iksyypY4fr44he/OKb93H333VRUVFBZWcnBBx/MU089xVe/+lWuvPLKQpnR9od9Fri//vWvOI4z4n531N+99dZbrF27lnPPPZeurq7CPtPpNMcffzz//ve/d7iPsVJXV8ehhx7KzTffzP/93/9x5ZVX8vvf/56vf/3rO7W9nWmbX/jCF3a6/mPh7LPPHjAKNdTz5rzzzqOlpWXA8+73v/89gUCAj370ozvcx4IFCzj88MMLf/eNrh133HFMnz590PL+++7fd+dyOTo7O3nf+94HUOgnbNvmySef5PTTT6e2trZQfs6cOQUrbx9//vOfcRyHs846a8A9XF1dzT777DPomR4Ohwf4dHu9Xg499NABdRyrTtjbkC4WewipVIrKyspx297atWtZuXLlsMN0fRMy+pg5c+aAvzs6OojFYtx5553ceeedo9pG/w4Dtg2h9/T0jKnuffSJ35FeHIYT0fvss8+gsnPnziWTydDR0UF1dfVO1Wn7YywqKgJg2rRpg5aP9rjfeustPv/5z/Pxj398wEMdYMuWLVx99dX87W9/G7S9eDw+1urT0dFBJpNh3rx5g37bd999cRyHxsZG9ttvv8LyXb2uDz30ENFolI6ODn72s5+xcePGAQ+PPsE0VJ3mz5/Pc889N6r97CrbHye4x9p3nGNpE1/72td48sknOfTQQ5kzZw4nnXQS5557LkccccSIddi8eTNz5swZ5Hs41LnZnksuuYQHHniAk08+mbq6Ok466STOOussli1btsN1J4Id3Td9133OnDkDypWWlg4QPjviwx/+MJdddhmGYfDqq69yww03kMlkCkPdMPr+8Oyzz+auu+7i4osv5utf/zrHH388Z5xxBmeeeeaA7Y3m+NauXQtQ8O0ding8PqZj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IpEglUpx0UUX0d3dPWGdL33pSzQ3N5NMJnn3u989ZafF73znO6xevZpIJMIxxxzDN77xjarGOsJPfvITTjjhBBYsmFwX0dTUNOEzsK9Anur5xsbG0b9HhO/49dLpoCPoscceS1tbG//zP/9T03iPFqoWyONdLEJCpsL1JWW3glT8CQJ5wJnawSITl1haFFXZ/8dQApHQ4i1kOvwaLN5GUixqsXgTAqzEgdebZYrF4rSPfS/S+1u3XC5XtW4t9Pf386tf/YoPfvCDo9GoEVpaWrj00ku57bbbJlw3/uVf/oW1a9fw+OMP8Q//8HfYdiBERsTx1q07ufjid3Deeefzpz/9ife///0TRLbvC6SYPJYtWzbzy1/+gh/c9BN+eNNt/P7xR/jnG7487vWWuOqqq/n9I49y1x13o2kqb3nLhQgxxc7mKDfccAOnnHIKTz31FB/84Ae58sorWb9+PRBYY51zzjkkk0kefvhhfve735FIJHjDG96A40xuuw3wb//2b5x22mm8973vpbOzk87OThYtWlT1eDZv3sztt9/OHXfcwR133MGDDz7Il770pdHnr7/+er7//e9z44038txzz3H11VfzV3/1Vzz44INAIOgvvPBC3vzmN/P000/znve8h7//+7+v6tjNzc2cc845fO973wOgVCpx2223ccUVV0xYTwjBeeedR39/Pw8++CC/+c1v2LJlCxdffPHoOj/5yU/47Gc/y3XXXccf/vAHWltbJ4nfH/3oR3z605/mi1/8Ii+88ALXXXcd11577ejxq+Hhhx/mlFNOqXr92eTUU0/l4YcfPizHPtKpOiw3n04mIYcGxwuahIA/ISo8UBmJII94IAefpXTcJ6LtP69z5AIbOliETIszXHRXDaMWbzU6WOgH9uqebfaNFI3njW98I3feeefo301NTZRKpSnXPfPMM3nggQdG/25vb6e3t3fSerUEQTZu3IiUctruqatXr2ZgYICenp7RtLyzzjqDv/mbDwGCSmUP27YF+bum2QQofOc7t7Bq1Ur+5V9uAGDVqlU8++yzfPGLX0QIie/JKf/NQgi+9pVvYmpBM5BLL72U+x+4b/T5Cy+4cHQ9RVG4+eabaWpu4vnnn+e4446r+jV/4xvfmNAM6/3vfz833HBD1dvXyh133DHhM3Duuefy05/+dMp13/jGN/LBD34QgI9//OP8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YuzYsdx6660888wz3H333Q1G92qTkJDAyJEj+etf/xos+KpJSUlJk9bTED179sRms3H48GG6desW8hMuR7Yx/u///o/vvvuOzMzMiObu3r07Doej3gLG5tjHhqjvHOjWrVtE2xUEgcGDB/PUU0+xfft2rFZr8O5GbaxWK4qi1LuWs7mv/fr1C6YONUTPnj2D59x3333HggUL+Prrr/n222+ZNWsWAFu3bmXFihXk5eWxbt06Zs+ezdGjRwH94uiRRx7h+++/58SJE6xfv56srCw++OADQP8/vGbNGm644Qb27NnDxx9/zKZNm/j22285deoURUVFXH311cydO5d7772X2bNnh4hjgF27dtGuXTuSkpLO6JicjxgKxaBRgh7INVA1tYbFWwoFhVUFeiYsZhNWU8PRDkHQsFnOT4FiUBdN01BVPUrsdv9IYdHXlJXtwO3eg6KE3lqzWlOIrconjh+MzZaIKEYjihFGwGS/nidcWziHo6QybcORALYIUzIUCawRjj3PUWQ9cgzUiQqrqkZ5oR9VUTGJJqITbJjqXBToBXkmk4DYhMgxwKeffkpxcTETJ06sEynOzMwkOzubyZMnA3D48GGmTZvGPffcw7Zt23j99deZP39+yGsiGVMTp9PJlClTmD59OgkJCXTo0IF58+bh8XiYOHFicNxjjz1GaWkpr732Gi6Xi88++4wJEybw6aefArBw4UI++uijBl0t/vrXvzJ48GAyMjJ4+umn6d27N7Is89VXX7Fo0SL27NkT8XoaIjo6mocffpiHHnoIVVUZMmQIpaWlbNiwgZiYGO666656X+v3+zl+/HiIzdvzzz/PjTfeyJ133okoio3ObbfbeeSRR5gxYwZWq5XBgwdz8uRJdu/ezcSJE5tlHxuivnMgku1u2bKFNWvWMGLECFJSUtiyZQsnT56kR48eYbfVqVMntmzZQn5+Pi6Xq47F29nc15EjRzJz5kyKi4uJj4+nsLCQrKwsJkyYQO/evYmOjiYvL4958+YxZswYAP7zn/9w6623BotCq9a7YcMGMjMzsdvt2O12hg0bxtatW+nTpw9paWlBMd+vXz/y8/MZN24cBw8epLi4mNzcXAYPHozdbmfNmjVs3ryZgQMHAnrKxIABA5gzZw59+/alW7dujBs3rs6+5OTkMGLEiDM6HucrhkA2aJQKv4ys+UK+XMuk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T0+na9euvPPOOy29lIseQ7kYBHH7Ky3eavgan/JWNghx6NX6VRHkBJeKQ2zYvzagaFjNhkA2CIPsjdjAIuhgYXFCVFJkr1EksNiDAlxTNdzFfo4f0qPGNkd11Fj3NT7F6jd381Nl1Lj75SkMn9iTpHbVAirg16PGZuvFHTWuTVVEsHXr1vTt25dHH32Un3/+mZMnTwKwevVqhgwZQlxcHImJidx4440cOHAg+Prx48ezbt06Xn311WAkOj8/H1VVmTdvHt26dcNms9GhQweeffbZkG2rqsqMGTNISEigdevW/OUvfwk+9+GHH9KrVy8cDgeJiYlcd911VFRUBJ+vilrn5+eHRMGrfoYOHRqyneeff57OnTvjcDjo06cPH374YfD5uXPn0r59e/7+97+TkZFB586dGTFiBF27dg1Zr9vt5o477mDx4sVhxXM43G4377//PlOmTGHUqFEsXbq0zpiKigruvPNOXC4XqampYW/RN/Y+DB06lPvvv58HH3yQ+Ph4WrVqxeLFi6moqOCPf/wj0dHRdOvWjc8//7zB9X722WfYbDauvPJKAEpKSsjJyWHu3Llce+21dOzYkYyMDGbOnMnvfve7iI7Bxcbo0aN57733WnoZFz2GcjEAIKCoeAMBVKRaHshVHfQqLd7KqlIsNGxiwwVQkqzisokXdXTNoB585RHbr1U3CGmCg4UsgT0OAL9X5tQv5RT8VIYiV0aNK4VtWaGXdf/Yy9ZV+UhemdhkB78ddyl9r+sQjCyrqkZFqUTArxDX2kmrsxw11jQNRfG0yI+mRXrVEh63280777xDt27dSExMBHTxNm3aNPLy8lizZg0mk4mbb74ZVdWLfV999VUGDRrEpEmTgpHo9u3bM3PmTF544QWeeOIJvv/+e/7xj3/QqlWrkO0tW7YMp9PJli1bmDdvHk8//TRfffUVx44d4/bbb2fChAns2bOHtWvXcsstt4Tdv/bt2we3e+zYMbZv305iYiJXX311cMzzzz/P8uXLeeONN9i9ezcPPfQQY8eOZd26dQB88sknDBw4kKysLFJSUujXrx+LFy+us617772XUaNGcd1110V8TFesWMGll15KWloaY8eOZcmSJXX2Y/r06axbt46PP/6YL7/8krVr17Jt27aQMY29D1XHMykpidzcXO6//36mTJlCVlYWV111Fdu2bWPEiBGMGzcOj8dT73pzcnIYMGBA8G+Xy4XL5WLlypX4/f56X2dQTUZGBrm5ucbxamEMewEDQG8x7ZG8gIJZqM7bPFVDIKuqxslKgZwQQ4P5xwABVcVlM04xg1poGvhLm95iOtL8YwBNRREdlBd4KD3pRQmoOKItwQI7RVb5YeMxfth8HFXREM0mev4mlUsub4Wphme33xNA8ik442zEJUdhd0WQEnKGqKqXtet6nfXthGPoNd8hNnJnqDaffvopLpeen11RUUFqaiqffvopJpN+HDMzM0PGL1myhOTkZL7//nvS09OJjY3FarUSFRVF69b6hXh5eTmvvvoqCxcu5K677gKga9euDBkyJGSu3r178+STTwLQvXt3Fi5cyJo1a0hMTESWZW655RY6dtTTcnr1Cn9MRVEMbtfn83HTTTcxaNCgYDTa7/fz3HPP8e9//5tBgwYB0KVLF9avX8///M//cM0113Dw4EEWLVrEtGnTmDVrFlu3buWBBx7AarUG1//ee++xbds2tm7d2qTjm52dzdixYwE9naW0tJR169YFI9xut5vs7Gzeeecdhg0bBuhCt127diHzNPY+APTp04fHH38cIHiBkpSUxKRJkwCYPXs2ixYtYufOncEIcW1++ukn2rRpE/zbbDazdOlSJk2axBtvvEH//v255ppruO2225qUZnIx0aZNGyRJ4vjx48Hz1+DcY0SQDQA92uuVJRDkWhZvlU1C7K0pqlBRVDCLkOA0NWrxJgB2iyGQDWoh+5pWoHcaAtnrgYKjGoW/uIO+xlXiuCC/jC/f2s33G46hKhqtu8QwctJlXHplalAcKwGV8mIfmiaQ3D6alA7R50QcX4hce+217Nixgx07dpCbm8vIkSO54YYb+OknPfK/b98+br/9drp06UJMTEywcOvw4cP1zrlnzx78fn9Q8NVHbYGVmppKQUEBffr0YdiwYfTq1YusrCwWL15McXFxo/syYcIEysvL+cc//hEU+Pv378fj8TB8+PBgNNTlcrF8+fJgioKqqvTv35/nnnuOfv368ac//SkoCAF+/vlnpk6dyv/+7/9it0fe2XHv3r3k5uZy++23A7rYvPXWW8nOzg6OOXDgAJIkccUVVwQfS0hIIC0tLWSuSN6HmsdTFEUSExNDLiyqIvgFBQX1rtnr9dbZx8zMTI4ePconn3zC9ddfz9q1a+nfv3/Y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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pickle\n",
    "from scipy.interpolate import interp1d\n",
    "\n",
    "fft_acc = .81\n",
    "# Function to interpolate the data\n",
    "def interpolate_data(time_list, acc_list, num_points=100):\n",
    "    # Find common time range for interpolation\n",
    "    min_time = max([min(times) for times in time_list])\n",
    "    max_time = min([max(times) for times in time_list])\n",
    "    \n",
    "    # Create a common time range\n",
    "    common_time = np.logspace(np.log10(min_time), np.log10(max_time), num_points)\n",
    "    \n",
    "    # Interpolate accuracy values to this common time range\n",
    "    interpolated_acc = []\n",
    "    for i in range(len(time_list)):\n",
    "        interp_func = interp1d(time_list[i], acc_list[i], kind='linear', bounds_error=False, fill_value=\"extrapolate\")\n",
    "        interpolated_acc.append(interp_func(common_time))\n",
    "    \n",
    "    return common_time, np.array(interpolated_acc)\n",
    "\n",
    "# Function to extract and interpolate seed data\n",
    "def extract_and_interpolate_data(all_metrics, key, num_points=100):\n",
    "    time_list_all = []\n",
    "    acc_list_all = []\n",
    "    \n",
    "    for seed in all_metrics:\n",
    "        if key in all_metrics[seed]:\n",
    "            time_data = all_metrics[seed][key].time\n",
    "            acc_data = all_metrics[seed][key].test_accuracy\n",
    "            if len(time_data) > 0 and len(acc_data) > 0:\n",
    "                time_list_all.append(time_data)\n",
    "                acc_list_all.append(acc_data)\n",
    "\n",
    "    if len(time_list_all) == 0 or len(acc_list_all) == 0:\n",
    "        print(f\"Warning: No valid data found for {key}\")\n",
    "        return None, None\n",
    "\n",
    "    # Interpolate data\n",
    "    return interpolate_data(time_list_all, acc_list_all, num_points)\n",
    "\n",
    "# Extract and interpolate time and accuracy data for each method\n",
    "relu_time, relu_acc = extract_and_interpolate_data(all_metrics, 'relu_metrics')\n",
    "grelu_time, grelu_acc = extract_and_interpolate_data(all_metrics, 'grelu_metrics')\n",
    "cd_time, cd_acc = extract_and_interpolate_data(all_metrics, 'cd_metrics')\n",
    "lstsq_time, lstsq_acc = extract_and_interpolate_data(all_metrics, 'lstsq_metrics')\n",
    "\n",
    "# For adam_metrics, handle them separately\n",
    "full_batch_adam_time_all = []\n",
    "full_batch_adam_acc_all = []\n",
    "for seed in all_metrics:\n",
    "    if 'full_batch_adam_metrics' in all_metrics[seed]:\n",
    "        full_batch_adam_time_all.append(all_metrics[seed]['full_batch_adam_metrics'][0])  # time_list\n",
    "        full_batch_adam_acc_all.append(all_metrics[seed]['full_batch_adam_metrics'][1])    # acc_list\n",
    "\n",
    "full_batch_adam_time, full_batch_adam_acc = interpolate_data(full_batch_adam_time_all, full_batch_adam_acc_all)\n",
    "\n",
    "mini_batch_adam_time_all = []\n",
    "mini_batch_adam_acc_all = []\n",
    "for seed in all_metrics:\n",
    "    if 'mini_batch_adam_metrics' in all_metrics[seed]:\n",
    "        mini_batch_adam_time_all.append(all_metrics[seed]['mini_batch_adam_metrics'][0])  # time_list\n",
    "        mini_batch_adam_acc_all.append(all_metrics[seed]['mini_batch_adam_metrics'][1])    # acc_list\n",
    "\n",
    "mini_batch_adam_time, mini_batch_adam_acc = interpolate_data(mini_batch_adam_time_all, mini_batch_adam_acc_all)\n",
    "\n",
    "# Helper function to plot mean and shaded area for standard deviation\n",
    "def plot_with_error_bars(time_all, acc_all, label, color):\n",
    "    if time_all is None or acc_all is None:\n",
    "        print(f\"Skipping {label} due to missing data.\")\n",
    "        return\n",
    "    \n",
    "    mean_acc = np.mean(acc_all, axis=0)\n",
    "    std_acc = np.std(acc_all, axis=0)\n",
    "    \n",
    "    plt.plot(time_all, mean_acc, label=label, color=color)\n",
    "    plt.fill_between(time_all, mean_acc - std_acc, mean_acc + std_acc, color=color, alpha=0.2)\n",
    "\n",
    "# Plot setup\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.title('Different Optimization Routines distilling Resnet18 for TinyImagenet')\n",
    "\n",
    "plt.axhline(y=fft_acc,  linestyle='--', c='black', label='Original Full Fine-tuned Model (FFT)')\n",
    "\n",
    "# Plot each method with mean and standard deviation\n",
    "if relu_time is not None and relu_acc is not None:\n",
    "    plot_with_error_bars(relu_time, relu_acc, \"Augmented Lagrangian (AL) for ($\\mathsf{S}_\\mathrm{convex}$)\", \"#ff7f0e\")\n",
    "if grelu_time is not None and grelu_acc is not None:\n",
    "    plot_with_error_bars(grelu_time, grelu_acc, \"RFISTA ($\\mathsf{S}_\\mathrm{convex}$)\", \"#1f77b4\")\n",
    "if cd_time is not None and cd_acc is not None:\n",
    "    plot_with_error_bars(cd_time, cd_acc, \"Approx. Cone Decomposition ($\\mathsf{S}_\\mathrm{convex}$)\", \"#2ca02c\")\n",
    "# if lstsq_time is not None and lstsq_acc is not None:\n",
    "#     plot_with_error_bars(lstsq_time, lstsq_acc, \"Ridge Regression for ReLU NN\", \"#d62728\")\n",
    "if full_batch_adam_time is not None and full_batch_adam_acc is not None:\n",
    "    plot_with_error_bars(full_batch_adam_time, full_batch_adam_acc, \"Full-batch Adam ($\\mathsf{S}_\\mathrm{non-convex}$)\", \"tab:purple\")\n",
    "if mini_batch_adam_time is not None and mini_batch_adam_acc is not None:\n",
    "    plot_with_error_bars(mini_batch_adam_time, mini_batch_adam_acc, \"Batchsize64 Adam ($\\mathsf{S}_\\mathrm{non-convex}$)\", \"tab:olive\")\n",
    "\n",
    "# Axis settings\n",
    "plt.xscale(\"log\")\n",
    "plt.xlim([5e-3, 1])\n",
    "plt.ylim([0.5, 0.82])\n",
    "plt.xlabel(\"Time (seconds)\")\n",
    "plt.ylabel(\"Test Accuracy\")\n",
    "plt.legend()\n",
    "\n",
    "# Save the figure (optional)\n",
    "plt.savefig('./tinyimagenet_binary_with_errorbars.pdf')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "81"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fft_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "machine_shape": "hm",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "0456cd6949c848009d9d9beddb5e387f": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "ProgressStyleModel",
     "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": ""
     }
    },
    "1bb01749d62849a78aec02198c4bb3d3": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "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_845e490060da4382899500d2aea2f340",
      "placeholder": "​",
      "style": "IPY_MODEL_92351eda4dfd4583aeecb0d45c175e8e",
      "value": " 97/10000 [05:58&lt;10:09:13,  3.69s/it]"
     }
    },
    "7a44fb277f314c61a3c8ccb0ef9ce302": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "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_e6c26b488f184ca981f9a240bb38ed5a",
      "placeholder": "​",
      "style": "IPY_MODEL_ba11766b65be480196f8ae3e06a762b6",
      "value": "fista:   1%"
     }
    },
    "845e490060da4382899500d2aea2f340": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "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
     }
    },
    "92351eda4dfd4583aeecb0d45c175e8e": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "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": ""
     }
    },
    "9292d0a5da4d4a8e86a230796281277b": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "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
     }
    },
    "a2414210eabc4c24a8c41856a1635975": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "FloatProgressModel",
     "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": "danger",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_9292d0a5da4d4a8e86a230796281277b",
      "max": 10000,
      "min": 0,
      "orientation": "horizontal",
      "style": "IPY_MODEL_0456cd6949c848009d9d9beddb5e387f",
      "value": 97
     }
    },
    "ba11766b65be480196f8ae3e06a762b6": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "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": ""
     }
    },
    "d88e29cb4fce4f60bc7ccdf25fc8e207": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "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
     }
    },
    "e6c26b488f184ca981f9a240bb38ed5a": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "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
     }
    },
    "f74d01cb96c54da6bd8475d8cfee0d1f": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HBoxModel",
     "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_7a44fb277f314c61a3c8ccb0ef9ce302",
       "IPY_MODEL_a2414210eabc4c24a8c41856a1635975",
       "IPY_MODEL_1bb01749d62849a78aec02198c4bb3d3"
      ],
      "layout": "IPY_MODEL_d88e29cb4fce4f60bc7ccdf25fc8e207"
     }
    }
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
