{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "import pandas as pd\n",
    "import d2l.torch as d2l\n",
    "from torch.utils.data import DataLoader, TensorDataset, random_split\n",
    "import networkx as nx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib_inline.backend_inline\n",
    "def use_svg_display():\n",
    "    matplotlib_inline.backend_inline.set_matplotlib_formats('svg')\n",
    "def set_figsize(figsize=(3.5, 2.5), fontsize=10):\n",
    "    use_svg_display()\n",
    "    plt.rcParams['figure.figsize'] = figsize\n",
    "    plt.rcParams['font.size'] = fontsize\n",
    "set_figsize()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "def save_variable(v,filename):\n",
    "    f=open(filename,'wb')\n",
    "    pickle.dump(v,f)\n",
    "    f.close()\n",
    "    return filename\n",
    "def load_variable(filename):\n",
    "    f=open(filename,'rb')\n",
    "    r=pickle.load(f)\n",
    "    f.close()\n",
    "    return r"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[1., 2., 3.],\n",
       "         [3., 4., 8.],\n",
       "         [6., 8., 5.]]),\n",
       " 3)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Target matrix f^*\n",
    "def synthetic_data(d, r):\n",
    "    # M = torch.rand(d, d)\n",
    "    np.random.seed(0)\n",
    "    # matrix_dxr = np.random.rand(d, r)\n",
    "    # matrix_rxd = np.random.rand(r, d)\n",
    "    # M = torch.tensor(np.dot(matrix_dxr, matrix_rxd), dtype=torch.float32)\n",
    "    M = torch.tensor([[1., 2, 3], [3, 4, 8], [6, 8, 5]])\n",
    "    # M = torch.tensor([[1., 2, 3, 3], [3, 4, 8, 4], [6, 8, 5, 3], [1, 2, 3, 4]])\n",
    "    return M\n",
    "M = synthetic_data(d=3, r=1)\n",
    "M, np.linalg.matrix_rank(M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def mod(ls, d):\n",
    "    ls_index = []\n",
    "    for item in ls:\n",
    "        i = item // d\n",
    "        j = item % d\n",
    "        ls_index.append((i, j))\n",
    "    return ls_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0, 0],\n",
       "         [0, 1],\n",
       "         [1, 0],\n",
       "         [2, 2]]),\n",
       " tensor([[1.],\n",
       "         [2.],\n",
       "         [3.],\n",
       "         [5.]]))"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import random\n",
    "d = 3\n",
    "def random_sample(M, num=5, d=d):\n",
    "    M_vec = M.reshape(-1, )\n",
    "    size = M_vec.shape\n",
    "    # random.seed(0)\n",
    "    ls = random.sample(list(range(size[0])), num)\n",
    "    train_features = mod(ls, d)\n",
    "    train_labels = M_vec[ls]\n",
    "    return torch.tensor(train_features), train_labels.reshape(-1, 1)\n",
    "ls_example1 = [0, 1, 3, 8]\n",
    "ls_example2 = [0, 1, 3, 4, 8]\n",
    "ls_example3 = [0, 1, 3, 4, 6, 8]\n",
    "\n",
    "ls_example0 = [0, 1, 5, 8]\n",
    "def fix_sample(M, ls, d=d):\n",
    "    '''\n",
    "    Sample from target matrix M\n",
    "    '''\n",
    "    M_vec = M.reshape(-1, )\n",
    "    size = M_vec.shape\n",
    "    # ls = [0, 1, 2] # Sample according to row-first order, 0, 3 represent positions (0, 0) and (1, 1) respectively\n",
    "    train_features = mod(ls, d)\n",
    "    train_labels = M_vec[ls]\n",
    "    return torch.tensor(train_features), train_labels.reshape(-1, 1)\n",
    "features_train, labels_train = fix_sample(M, ls_example1)\n",
    "# features_train, labels_train = random_sample(M)\n",
    "train_dataset = torch.utils.data.TensorDataset(features_train, labels_train)\n",
    "features_train, labels_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_observation_matrix(indices, elements, d):\n",
    "    # Initialize a dxd matrix filled with \"X\"\n",
    "    matrix = np.array([[None for _ in range(d)] for _ in range(d)])\n",
    "    \n",
    "    # Fill in the observed values\n",
    "    for index, element in zip(indices, elements):\n",
    "        x, y = index\n",
    "        matrix[x][y] = eval(f\"{element[0]:.4f}\")  \n",
    "\n",
    "    return matrix\n",
    "\n",
    "# observation_matrix = create_observation_matrix(features_train, labels_train, d=3)\n",
    "# observation_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Timer:\n",
    "    'Record multiple running times.'\n",
    "    def __init__(self):\n",
    "        self.times = []\n",
    "        self.start()\n",
    "\n",
    "    def start(self):\n",
    "        self.tik = time.time()\n",
    "\n",
    "    def stop(self):\n",
    "        self.times.append(time.time() - self.tik)\n",
    "        return self.times[-1]\n",
    "\n",
    "    def avg(self):\n",
    "        return sum(self.times) / len(self.times)\n",
    "\n",
    "    def sum(self):\n",
    "        return sum(self.times)\n",
    "    def cumsum(self):\n",
    "        return np.array(self.times).cumsum().tolist()\n",
    "class Accumulator:\n",
    "    'For accumulating sums over `n` variables.'\n",
    "    def __init__(self, n):\n",
    "        self.data = [0.0] * n\n",
    "\n",
    "    def add(self, *args):\n",
    "        self.data = [a + float(b) for a, b in zip(self.data, args)]\n",
    "\n",
    "    def reset(self):\n",
    "        self.data = [0.0] * len(self.data)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.data[idx]\n",
    "\n",
    "def create_observation_matrix(indices, elements, d):\n",
    "        matrix = np.array([[None for _ in range(d)] for _ in range(d)])\n",
    "        \n",
    "        for index, element in zip(indices, elements):\n",
    "            x, y = index\n",
    "            matrix[x][y] = eval(f\"{element[0]:.4f}\")  \n",
    "        return matrix\n",
    "    \n",
    "# def is_connected_with_networkx(indices, d):\n",
    "#         # Generate a dxd 0-1 matrix N\n",
    "#         N = np.zeros((d, d), dtype=int)\n",
    "#         for (x, y) in indices:\n",
    "#             N[x, y] = 1\n",
    "\n",
    "#         # Construct a large block matrix P\n",
    "#         P = np.block([[np.zeros_like(N), N], [N.T, np.zeros_like(N)]])\n",
    "\n",
    "#         # Create an undirected graph\n",
    "#         G = nx.Graph()\n",
    "\n",
    "#         # Add nodes\n",
    "#         G.add_nodes_from(range(len(P)))\n",
    "\n",
    "#         # Add edges\n",
    "#         for i in range(len(P)):\n",
    "#             for j in range(i+1, len(P)):\n",
    "#                 if P[i, j] == 1:\n",
    "#                     G.add_edge(i, j)\n",
    "#         G_line = nx.line_graph(G)\n",
    "#         # Use NetworkX's is_connected function to check connectivity\n",
    "#         return nx.is_connected(G_line)\n",
    "def is_complete_bipartite_component(G, component):\n",
    "    # NetworkX's function to check bipartiteness\n",
    "    if nx.is_bipartite(G.subgraph(component)):\n",
    "        # Get the two partitions of the bipartite graph\n",
    "        nodes_set = nx.bipartite.sets(G.subgraph(component))\n",
    "        # Check if it's a complete bipartite graph\n",
    "        for u in nodes_set[0]:\n",
    "            for v in nodes_set[1]:\n",
    "                if not G.has_edge(u, v):\n",
    "                    return False\n",
    "        return True\n",
    "    return False\n",
    "\n",
    "def are_all_components_complete_bipartite(G):\n",
    "    # Get all connected components\n",
    "    components = nx.connected_components(G)\n",
    "    # Check each connected component\n",
    "    for component in components:\n",
    "        # Ignore isolated vertices\n",
    "        if len(component) > 1:\n",
    "            if not is_complete_bipartite_component(G, component):\n",
    "                return False\n",
    "    return True\n",
    "def is_connected_with_networkx(indices, d):\n",
    "    # Generate a dxd 0-1 matrix N\n",
    "    N = np.zeros((d, d), dtype=int)\n",
    "    for (x, y) in indices:\n",
    "        N[x, y] = 1\n",
    "\n",
    "    # Construct a large block matrix P\n",
    "    P = np.block([[np.zeros_like(N), N], [N.T, np.zeros_like(N)]])\n",
    "\n",
    "    # Create an undirected graph\n",
    "    G = nx.Graph()\n",
    "\n",
    "    # Add nodes\n",
    "    G.add_nodes_from(range(len(P)))\n",
    "\n",
    "    # Add edges\n",
    "    for i in range(len(P)):\n",
    "        for j in range(i+1, len(P)):\n",
    "            if P[i, j] == 1:\n",
    "                G.add_edge(i, j)\n",
    "    G_line = nx.line_graph(G)\n",
    "    # Use NetworkX's is_connected function to check connectivity\n",
    "    if nx.is_connected(G_line):\n",
    "        return 1\n",
    "    else:\n",
    "        if are_all_components_complete_bipartite(G):\n",
    "            return 2\n",
    "        else:\n",
    "            return 0\n",
    "import cvxpy as cp\n",
    "def min_nuclear_norm(observation_matrix):\n",
    "    M = observation_matrix\n",
    "\n",
    "    # Create a variable matrix X with the same shape as M\n",
    "    X = cp.Variable(M.shape)\n",
    "\n",
    "    # Nuclear norm minimization objective\n",
    "    objective = cp.Minimize(cp.norm(X, 'nuc'))\n",
    "\n",
    "    # Constraints: known element positions should be equal to the original matrix\n",
    "    constraints = [X[i, j] == M[i, j] for i in range(M.shape[0]) for j in range(M.shape[1]) if M[i, j] is not None]\n",
    "\n",
    "    # Problem setup\n",
    "    prob = cp.Problem(objective, constraints)\n",
    "\n",
    "    # Solve the problem\n",
    "    prob.solve()\n",
    "    return X.value\n",
    "\n",
    "def compute_nuclear_norm(M):\n",
    "    return np.linalg.norm(M, ord='nuc')\n",
    "\n",
    "import tqdm\n",
    "def train(net, train_iter, num_epochs, lr, device, test_iter=None, stop=0.0):\n",
    "    print('training on', device)\n",
    "    net.to(device)\n",
    "    optimizer = torch.optim.SGD(net.parameters(), lr=lr)\n",
    "    timer, num_batches = Timer(), len(train_iter)\n",
    "    train_ls, test_ls = [], []\n",
    "    # train_accs, test_accs = [], []\n",
    "    # bar = tqdm.tqdm(total = num_epochs)\n",
    "    for epoch in tqdm.tqdm(range(1, num_epochs+1)):\n",
    "        metric = Accumulator(2)  \n",
    "        net.train()\n",
    "        for i, (X, y) in enumerate(train_iter):\n",
    "            timer.start()\n",
    "            optimizer.zero_grad()\n",
    "            X, y = X.to(device), y.to(device)\n",
    "            y_hat = net(X)\n",
    "            l = loss(y_hat[0], y)\n",
    "            l.backward()\n",
    "            optimizer.step()\n",
    "            with torch.no_grad():\n",
    "                metric.add(l * X.shape[0], X.shape[0])\n",
    "            timer.stop()\n",
    "            train_l = metric[0] / metric[1]\n",
    "            if (i + 1) % (num_batches // 1) == 0 or i == num_batches - 1:\n",
    "                # print(f'{i}, train_loss: {train_l}')\n",
    "                train_ls.append(train_l)\n",
    "        if train_ls[-1] <= stop:\n",
    "            break\n",
    "        net.eval()\n",
    "        metric2 = Accumulator(2)\n",
    "        if test_iter != None:\n",
    "            with torch.no_grad():\n",
    "                for (X_test,y_test) in test_iter:\n",
    "                    X_test, y_test = X_test.to(device), y_test.to(device)\n",
    "                    y_hat = net(X_test)\n",
    "                    l = loss(y_hat[0], y_test)\n",
    "                    metric2.add(l * X_test.shape[0], X_test.shape[0])\n",
    "                test_l = metric2[0] / metric2[1]\n",
    "                test_ls.append(test_l)\n",
    "        # bar.set_description('Epoch:')\n",
    "        # bar.update(1)\n",
    "    if test_iter != None:\n",
    "        print(f'train loss {train_l:.3f}', \n",
    "                f'test loss {test_l:.3f}')\n",
    "    else:\n",
    "        print(f'train loss {train_l:.3f}')\n",
    "    print(f'{metric[1] * num_epochs / timer.sum():.1f} examples/sec '\n",
    "        f'on {str(device)}')\n",
    "    return train_ls, test_ls\n",
    "\n",
    "def try_gpu(i=0):\n",
    "    'Return gpu(i) if exists, otherwise return cpu().'\n",
    "    if torch.cuda.device_count() >= i + 1:\n",
    "        return torch.device(f'cuda:{i}')\n",
    "    return torch.device('cpu')\n",
    "\n",
    "def num_matrix_rank(A, tol=1e-2):\n",
    "    'Compute the rank of a numerical matrix considering precision'\n",
    "    # Compute singular values\n",
    "    s = np.linalg.svd(A, compute_uv=False)\n",
    "    if tol is None:\n",
    "        # If tolerance is not specified, use machine precision multiplied by matrix size\n",
    "        tol = s.max() * max(A.shape) * np.finfo(np.float32).eps\n",
    "    # Compute numerical rank\n",
    "    return np.sum(s > tol)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "d = 3\n",
    "num_inputs, num_outputs, num_hiddens = d, d, d\n",
    "loss = nn.MSELoss()\n",
    "class NeuralNetwork(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(NeuralNetwork, self).__init__()\n",
    "        self.linear_stack = nn.Sequential(\n",
    "            nn.Linear(num_inputs, num_hiddens, bias=False),\n",
    "            nn.Linear(num_hiddens, num_outputs, bias=False)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        y = self.linear_stack(torch.eye(d, d))\n",
    "        return y[x.T.numpy().tolist()].reshape(-1, 1), y\n",
    "def init_weights(m, sigma=1e-25):\n",
    "    if type(m) == nn.Linear or type(m) == nn.Conv2d:\n",
    "        # nn.init.xavier_uniform_(m.weight)\n",
    "        nn.init.normal_(m.weight, 0, sigma)\n",
    "        if m.bias:\n",
    "            nn.init.normal_(m.bias, 0, sigma)\n",
    "# test_iter = torch.utils.data.DataLoader(test_dataset, batch_size, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_observation_matrix(indices, elements, d):\n",
    "        matrix = np.array([[None for _ in range(d)] for _ in range(d)])\n",
    "        \n",
    "        for index, element in zip(indices, elements):\n",
    "            x, y = index\n",
    "            matrix[x][y] = eval(f\"{element[0]:.4f}\") \n",
    "\n",
    "        return matrix\n",
    "    \n",
    "def is_complete_bipartite_component(G, component):\n",
    "\n",
    "    if nx.is_bipartite(G.subgraph(component)):\n",
    "\n",
    "        nodes_set = nx.bipartite.sets(G.subgraph(component))\n",
    "\n",
    "        for u in nodes_set[0]:\n",
    "            for v in nodes_set[1]:\n",
    "                if not G.has_edge(u, v):\n",
    "                    return False\n",
    "        return True\n",
    "    return False\n",
    "\n",
    "def are_all_components_complete_bipartite(G):\n",
    "\n",
    "    components = nx.connected_components(G)\n",
    "\n",
    "    for component in components:\n",
    "\n",
    "        if len(component) > 1:\n",
    "            if not is_complete_bipartite_component(G, component):\n",
    "                return False\n",
    "    return True\n",
    "def is_connected_with_networkx(indices, M, d):\n",
    "\n",
    "    N = np.zeros((d, d), dtype=int)\n",
    "    for (x, y) in indices:\n",
    "        if abs(M[x, y]) > 1e-5:\n",
    "            N[x, y] = 1\n",
    "\n",
    "\n",
    "    P = np.block([[np.zeros_like(N), N], [N.T, np.zeros_like(N)]])\n",
    "\n",
    "\n",
    "    G = nx.Graph()\n",
    "\n",
    "\n",
    "    G.add_nodes_from(range(len(P)))\n",
    "\n",
    "\n",
    "    for i in range(len(P)):\n",
    "        for j in range(i+1, len(P)):\n",
    "            if P[i, j] == 1:\n",
    "                G.add_edge(i, j)\n",
    "    G_line = nx.line_graph(G)\n",
    "\n",
    "    if nx.is_connected(G_line):\n",
    "        return 1\n",
    "    else:\n",
    "        if are_all_components_complete_bipartite(G):\n",
    "            return 2\n",
    "        else:\n",
    "            return 0\n",
    "def generated_graph(indices, M, d):\n",
    "\n",
    "    N = np.zeros((d, d), dtype=int)\n",
    "    for (x, y) in indices:\n",
    "        if abs(M[x, y]) > 1e-5:\n",
    "            N[x, y] = 1\n",
    "\n",
    "\n",
    "    P = np.block([[np.zeros_like(N), N], [N.T, np.zeros_like(N)]])\n",
    "\n",
    "\n",
    "    G = nx.Graph(P)\n",
    "    return G, P"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([], dtype=float64)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array([])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0, 0],\n",
       "         [0, 1],\n",
       "         [1, 0],\n",
       "         [2, 2]]),\n",
       " tensor([[1.],\n",
       "         [2.],\n",
       "         [3.],\n",
       "         [5.]]))"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# ls_example1 = [0, 1, 2, 4, 5, 6, 15]\n",
    "# ls_example0 = [0, 1, 5, 8]\n",
    "ls_example1 = [0, 1, 3, 8]\n",
    "ls_example2 = [0, 1, 3, 4, 8]\n",
    "ls_example3 = [0, 1, 3, 4, 6, 8]\n",
    "\n",
    "features_train, labels_train = fix_sample(M, ls_example1)\n",
    "# features_train, labels_train = random_sample(M)\n",
    "train_dataset = torch.utils.data.TensorDataset(features_train, labels_train)\n",
    "features_train, labels_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_connected_with_networkx(features_train, M, d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_bipartite_graph(G, P):\n",
    "\n",
    "    num_nodes = len(P)\n",
    "    top_nodes = list(range(num_nodes // 2))\n",
    "    bottom_nodes = list(range(num_nodes // 2, num_nodes))\n",
    "\n",
    "\n",
    "    pos = nx.bipartite_layout(G, top_nodes)\n",
    "\n",
    "\n",
    "    pos_adjust = {}\n",
    "    for node, coords in pos.items():\n",
    "        if node in top_nodes:\n",
    "            pos_adjust[node] = (coords[0], coords[1] + 0.1)\n",
    "        else:\n",
    "            pos_adjust[node] = (coords[0], coords[1] - 0.1)\n",
    "\n",
    "\n",
    "    nx.draw_networkx_nodes(G, pos_adjust, nodelist=top_nodes, node_color='r', node_size=500, alpha=0.5)\n",
    "    nx.draw_networkx_nodes(G, pos_adjust, nodelist=bottom_nodes, node_color='c', node_size=500, alpha=0.5)\n",
    "\n",
    "\n",
    "    nx.draw_networkx_edges(G, pos_adjust, width=2.0, alpha=0.5)\n",
    "\n",
    "\n",
    "    labels = {}\n",
    "    for node in G.nodes():\n",
    "        labels[node] = str(node+1)\n",
    "    nx.draw_networkx_labels(G, pos_adjust, labels, font_size=12)\n",
    "\n",
    "\n",
    "    plt.axis(\"off\")\n",
    "    plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"244.8pt\" height=\"172.8pt\" viewBox=\"0 0 244.8 172.8\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:57:58.892549</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 172.8 \n",
       "L 244.8 172.8 \n",
       "L 244.8 0 \n",
       "L 0 0 \n",
       "L 0 172.8 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"LineCollection_1\">\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#p3336e50b35)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 94.100535 \n",
       "\" clip-path=\"url(#p3336e50b35)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 78.699465 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#p3336e50b35)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 20.945455 \n",
       "L 217.606612 36.346524 \n",
       "\" clip-path=\"url(#p3336e50b35)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_1\">\n",
       "    <defs>\n",
       "     <path id=\"m043d51b88d\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <use xlink:href=\"#m043d51b88d\" x=\"27.193388\" y=\"136.453476\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m043d51b88d\" x=\"27.193388\" y=\"78.699465\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m043d51b88d\" x=\"27.193388\" y=\"20.945455\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_2\">\n",
       "    <defs>\n",
       "     <path id=\"m96fceb5866\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <use xlink:href=\"#m96fceb5866\" x=\"217.606612\" y=\"151.854545\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m96fceb5866\" x=\"217.606612\" y=\"94.100535\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m96fceb5866\" x=\"217.606612\" y=\"36.346524\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_1\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 1 -->\n",
       "     <g transform=\"translate(23.375888 139.764726) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_2\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 2 -->\n",
       "     <g transform=\"translate(23.375888 82.010715) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_3\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 3 -->\n",
       "     <g transform=\"translate(23.375888 24.256705) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-33\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_4\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 4 -->\n",
       "     <g transform=\"translate(213.789112 155.165795) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-34\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_5\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 5 -->\n",
       "     <g transform=\"translate(213.789112 97.411785) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_6\">\n",
       "    <g clip-path=\"url(#p3336e50b35)\">\n",
       "     <!-- 6 -->\n",
       "     <g transform=\"translate(213.789112 39.657774) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-36\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p3336e50b35\">\n",
       "   <rect x=\"7.2\" y=\"7.2\" width=\"230.4\" height=\"158.4\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "G, P = generated_graph(features_train, M, d)\n",
    "plot_bipartite_graph(G, P)\n",
    "\n",
    "plt.savefig('example1_disconnected.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10.000000033577884"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import networkx as nx\n",
    "import cvxpy as cp\n",
    "import time\n",
    "observation_matrix1 = create_observation_matrix(features_train, labels_train, d=d)\n",
    "min_nuclear_norm1 = compute_nuclear_norm(min_nuclear_norm(observation_matrix1))\n",
    "min_nuclear_norm1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 1/10000 [00:00<31:54,  5.22it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2678.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "16540.1 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2860.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "18034.8 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2882.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "18128.1 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2540.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "16106.9 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2713.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "17104.2 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2715.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "17118.0 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2931.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "18437.8 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2913.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "18448.7 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2938.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "18490.1 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:03<00:00, 2830.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "17794.5 examples/sec on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "nuclear_norm_trial = []\n",
    "eigenvalues_trial = []\n",
    "num_epochs = 1500\n",
    "batch_size, num_epochs, lr = 1024, 10000, 1e-1\n",
    "train_iter = torch.utils.data.DataLoader(train_dataset, batch_size, shuffle=True)\n",
    "def init_weights(m, sigma=1e-20):\n",
    "    if type(m) == nn.Linear or type(m) == nn.Conv2d:\n",
    "        # nn.init.xavier_uniform_(m.weight)\n",
    "        nn.init.normal_(m.weight, 0, sigma)\n",
    "        if m.bias:\n",
    "            nn.init.normal_(m.bias, 0, sigma)\n",
    "for i in range(10):\n",
    "    net = NeuralNetwork()\n",
    "    net.apply(init_weights)\n",
    "    train_ls, test_ls = train(net, train_iter, num_epochs, lr, try_gpu(), test_iter=None, stop=1e-15)\n",
    "    A = np.copy(list(net.parameters())[0].detach().T)\n",
    "    B = np.copy(list(net.parameters())[1].detach().T)\n",
    "    nuclear_norm_trial.append(compute_nuclear_norm(A @ B))\n",
    "    eigenvalues_trial.append(np.linalg.svd(A @ B, compute_uv=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"260.924859pt\" height=\"180.65625pt\" viewBox=\"0 0 260.924859 180.65625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:35.060555</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 180.65625 \n",
       "L 260.924859 180.65625 \n",
       "L 260.924859 0 \n",
       "L 0 0 \n",
       "L 0 180.65625 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "L 51.378125 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_1\">\n",
       "    <g id=\"xtick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"m9ed35de11e\" d=\"M 0 0 \n",
       "L 0 3.5 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"60.255398\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- 0 -->\n",
       "      <g transform=\"translate(57.074148 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"95.76804\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- 2000 -->\n",
       "      <g transform=\"translate(83.04304 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"131.280682\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- 4000 -->\n",
       "      <g transform=\"translate(118.555682 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-34\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_4\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"166.793324\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- 6000 -->\n",
       "      <g transform=\"translate(154.068324 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-36\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_5\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"202.305966\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_5\">\n",
       "      <!-- 8000 -->\n",
       "      <g transform=\"translate(189.580966 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \n",
       "Q 1584 2216 1326 1975 \n",
       "Q 1069 1734 1069 1313 \n",
       "Q 1069 891 1326 650 \n",
       "Q 1584 409 2034 409 \n",
       "Q 2484 409 2743 651 \n",
       "Q 3003 894 3003 1313 \n",
       "Q 3003 1734 2745 1975 \n",
       "Q 2488 2216 2034 2216 \n",
       "z\n",
       "M 1403 2484 \n",
       "Q 997 2584 770 2862 \n",
       "Q 544 3141 544 3541 \n",
       "Q 544 4100 942 4425 \n",
       "Q 1341 4750 2034 4750 \n",
       "Q 2731 4750 3128 4425 \n",
       "Q 3525 4100 3525 3541 \n",
       "Q 3525 3141 3298 2862 \n",
       "Q 3072 2584 2669 2484 \n",
       "Q 3125 2378 3379 2068 \n",
       "Q 3634 1759 3634 1313 \n",
       "Q 3634 634 3220 271 \n",
       "Q 2806 -91 2034 -91 \n",
       "Q 1263 -91 848 271 \n",
       "Q 434 634 434 1313 \n",
       "Q 434 1759 690 2068 \n",
       "Q 947 2378 1403 2484 \n",
       "z\n",
       "M 1172 3481 \n",
       "Q 1172 3119 1398 2916 \n",
       "Q 1625 2713 2034 2713 \n",
       "Q 2441 2713 2670 2916 \n",
       "Q 2900 3119 2900 3481 \n",
       "Q 2900 3844 2670 4047 \n",
       "Q 2441 4250 2034 4250 \n",
       "Q 1625 4250 1398 4047 \n",
       "Q 1172 3844 1172 3481 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-38\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_6\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m9ed35de11e\" x=\"237.818609\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_6\">\n",
       "      <!-- 10000 -->\n",
       "      <g transform=\"translate(221.912359 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"254.492188\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_7\">\n",
       "     <!-- xlabel -->\n",
       "     <g transform=\"translate(133.975781 171.376563) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-78\" d=\"M 3513 3500 \n",
       "L 2247 1797 \n",
       "L 3578 0 \n",
       "L 2900 0 \n",
       "L 1881 1375 \n",
       "L 863 0 \n",
       "L 184 0 \n",
       "L 1544 1831 \n",
       "L 300 3500 \n",
       "L 978 3500 \n",
       "L 1906 2253 \n",
       "L 2834 3500 \n",
       "L 3513 3500 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \n",
       "Q 3116 2381 2855 2742 \n",
       "Q 2594 3103 2138 3103 \n",
       "Q 1681 3103 1420 2742 \n",
       "Q 1159 2381 1159 1747 \n",
       "Q 1159 1113 1420 752 \n",
       "Q 1681 391 2138 391 \n",
       "Q 2594 391 2855 752 \n",
       "Q 3116 1113 3116 1747 \n",
       "z\n",
       "M 1159 2969 \n",
       "Q 1341 3281 1617 3432 \n",
       "Q 1894 3584 2278 3584 \n",
       "Q 2916 3584 3314 3078 \n",
       "Q 3713 2572 3713 1747 \n",
       "Q 3713 922 3314 415 \n",
       "Q 2916 -91 2278 -91 \n",
       "Q 1894 -91 1617 61 \n",
       "Q 1341 213 1159 525 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 4863 \n",
       "L 1159 4863 \n",
       "L 1159 2969 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <defs>\n",
       "       <path id=\"m0b5b756408\" d=\"M 0 0 \n",
       "L -3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0b5b756408\" x=\"51.378125\" y=\"114.434579\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- $\\mathdefault{10^{-9}}$ -->\n",
       "      <g transform=\"translate(20.878125 118.233798) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-2212\" d=\"M 678 2272 \n",
       "L 4684 2272 \n",
       "L 4684 1741 \n",
       "L 678 1741 \n",
       "L 678 2272 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-39\" d=\"M 703 97 \n",
       "L 703 672 \n",
       "Q 941 559 1184 500 \n",
       "Q 1428 441 1663 441 \n",
       "Q 2288 441 2617 861 \n",
       "Q 2947 1281 2994 2138 \n",
       "Q 2813 1869 2534 1725 \n",
       "Q 2256 1581 1919 1581 \n",
       "Q 1219 1581 811 2004 \n",
       "Q 403 2428 403 3163 \n",
       "Q 403 3881 828 4315 \n",
       "Q 1253 4750 1959 4750 \n",
       "Q 2769 4750 3195 4129 \n",
       "Q 3622 3509 3622 2328 \n",
       "Q 3622 1225 3098 567 \n",
       "Q 2575 -91 1691 -91 \n",
       "Q 1453 -91 1209 -44 \n",
       "Q 966 3 703 97 \n",
       "z\n",
       "M 1959 2075 \n",
       "Q 2384 2075 2632 2365 \n",
       "Q 2881 2656 2881 3163 \n",
       "Q 2881 3666 2632 3958 \n",
       "Q 2384 4250 1959 4250 \n",
       "Q 1534 4250 1286 3958 \n",
       "Q 1038 3666 1038 3163 \n",
       "Q 1038 2656 1286 2365 \n",
       "Q 1534 2075 1959 2075 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-39\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0b5b756408\" x=\"51.378125\" y=\"84.084016\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_9\">\n",
       "      <!-- $\\mathdefault{10^{-6}}$ -->\n",
       "      <g transform=\"translate(20.878125 87.883235) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_9\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0b5b756408\" x=\"51.378125\" y=\"53.733452\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_10\">\n",
       "      <!-- $\\mathdefault{10^{-3}}$ -->\n",
       "      <g transform=\"translate(20.878125 57.532671) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_10\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0b5b756408\" x=\"51.378125\" y=\"23.382889\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_11\">\n",
       "      <!-- $\\mathdefault{10^{0}}$ -->\n",
       "      <g transform=\"translate(26.778125 27.182107) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_12\">\n",
       "     <!-- ylabel -->\n",
       "     <g transform=\"translate(14.798438 90.202344) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-79\" d=\"M 2059 -325 \n",
       "Q 1816 -950 1584 -1140 \n",
       "Q 1353 -1331 966 -1331 \n",
       "L 506 -1331 \n",
       "L 506 -850 \n",
       "L 844 -850 \n",
       "Q 1081 -850 1212 -737 \n",
       "Q 1344 -625 1503 -206 \n",
       "L 1606 56 \n",
       "L 191 3500 \n",
       "L 800 3500 \n",
       "L 1894 763 \n",
       "L 2988 3500 \n",
       "L 3597 3500 \n",
       "L 2059 -325 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-79\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_11\">\n",
       "    <path d=\"M 60.255398 13.377273 \n",
       "L 63.771149 13.470775 \n",
       "L 63.842175 13.908641 \n",
       "L 63.948713 17.106802 \n",
       "L 64.090763 17.878582 \n",
       "L 65.564538 17.965552 \n",
       "L 65.653319 18.263435 \n",
       "L 65.742101 19.464596 \n",
       "L 66.452354 35.476641 \n",
       "L 67.056069 41.87558 \n",
       "L 67.943885 48.8126 \n",
       "L 69.328878 57.745723 \n",
       "L 71.850275 72.357592 \n",
       "L 79.663057 115.788013 \n",
       "L 82.290992 130.15411 \n",
       "L 82.628362 132.983728 \n",
       "L 82.646119 132.983728 \n",
       "L 82.841438 133.915223 \n",
       "L 82.859194 133.85644 \n",
       "L 82.894707 133.989492 \n",
       "L 82.93022 133.989492 \n",
       "L 85.504886 134.059599 \n",
       "L 85.646937 134.324266 \n",
       "L 93.104592 134.411735 \n",
       "L 93.122348 134.47551 \n",
       "L 93.21113 134.411735 \n",
       "L 100.722053 134.47551 \n",
       "L 100.846348 134.55389 \n",
       "L 108.304003 134.633694 \n",
       "L 108.428297 134.708668 \n",
       "L 118.869014 134.780137 \n",
       "L 118.993308 134.928317 \n",
       "L 131.014337 135.000114 \n",
       "L 131.156388 135.152551 \n",
       "L 141.739155 135.224595 \n",
       "L 141.756912 135.303248 \n",
       "L 141.774668 135.03052 \n",
       "L 141.827937 135.133422 \n",
       "L 146.213748 135.201624 \n",
       "L 146.338042 135.287045 \n",
       "L 153.795697 135.381497 \n",
       "L 153.937748 135.540402 \n",
       "L 163.153278 135.61528 \n",
       "L 163.171035 135.701318 \n",
       "L 163.259816 135.61528 \n",
       "L 168.977352 135.701318 \n",
       "L 169.101646 135.779014 \n",
       "L 176.541545 135.854018 \n",
       "L 176.665839 136.037724 \n",
       "L 176.790133 135.944911 \n",
       "L 184.105737 136.022827 \n",
       "L 184.230032 136.117318 \n",
       "L 184.336569 136.022827 \n",
       "L 184.460864 136.117318 \n",
       "L 184.585158 136.022827 \n",
       "L 184.709452 136.117318 \n",
       "L 184.833746 136.022827 \n",
       "L 184.922528 136.117318 \n",
       "L 184.940284 136.022827 \n",
       "L 191.705443 136.022827 \n",
       "L 191.794224 136.209451 \n",
       "L 191.811981 136.112979 \n",
       "L 199.269636 136.112979 \n",
       "L 199.376173 136.292248 \n",
       "L 199.500468 136.193961 \n",
       "L 199.624762 136.292248 \n",
       "L 199.749056 136.193961 \n",
       "L 199.87335 136.292248 \n",
       "L 199.979888 136.193961 \n",
       "L 200.104183 136.292248 \n",
       "L 200.228477 136.193961 \n",
       "L 200.352771 136.292248 \n",
       "L 200.477065 136.193961 \n",
       "L 200.565847 136.292248 \n",
       "L 200.583603 136.193961 \n",
       "L 206.887097 136.271964 \n",
       "L 207.011392 136.469725 \n",
       "L 221.997727 136.552829 \n",
       "L 222.015483 136.632651 \n",
       "L 222.033239 136.469725 \n",
       "L 222.104264 136.552829 \n",
       "L 229.686214 136.649771 \n",
       "L 229.810508 136.736385 \n",
       "L 237.285919 136.832399 \n",
       "L 237.410213 136.922727 \n",
       "L 237.800852 136.922727 \n",
       "L 237.800852 136.922727 \n",
       "\" clip-path=\"url(#pc1b144c406)\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 51.378125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 51.378125 7.2 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"legend_1\">\n",
       "    <g id=\"patch_7\">\n",
       "     <path d=\"M 183.492188 29.878125 \n",
       "L 239.678125 29.878125 \n",
       "Q 241.678125 29.878125 241.678125 27.878125 \n",
       "L 241.678125 14.2 \n",
       "Q 241.678125 12.2 239.678125 12.2 \n",
       "L 183.492188 12.2 \n",
       "Q 181.492188 12.2 181.492188 14.2 \n",
       "L 181.492188 27.878125 \n",
       "Q 181.492188 29.878125 183.492188 29.878125 \n",
       "z\n",
       "\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n",
       "    </g>\n",
       "    <g id=\"line2d_12\">\n",
       "     <path d=\"M 185.492188 20.298437 \n",
       "L 195.492188 20.298437 \n",
       "L 205.492188 20.298437 \n",
       "\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "    </g>\n",
       "    <g id=\"text_13\">\n",
       "     <!-- label -->\n",
       "     <g transform=\"translate(213.492188 23.798437) scale(0.1 -0.1)\">\n",
       "      <use xlink:href=\"#DejaVuSans-6c\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"27.783203\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"89.0625\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"152.539062\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"214.0625\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"pc1b144c406\">\n",
       "   <rect x=\"51.378125\" y=\"7.2\" width=\"195.3\" height=\"135.9\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_ls, linewidth=2, color='b', label='label')\n",
    "plt.xlabel('xlabel')\n",
    "plt.ylabel('ylabel')\n",
    "plt.legend()\n",
    "plt.yscale('log')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([12.071041,\n",
       "  12.07104,\n",
       "  12.071032,\n",
       "  12.071041,\n",
       "  12.071032,\n",
       "  12.071041,\n",
       "  12.0710335,\n",
       "  12.071049,\n",
       "  12.071039,\n",
       "  12.07104],\n",
       " [array([9.4173708e+00, 2.6536701e+00, 6.7452966e-08], dtype=float32),\n",
       "  array([7.0789990e+00, 4.9920411e+00, 1.6860493e-07], dtype=float32),\n",
       "  array([7.5618753e+00, 4.5091562e+00, 1.0120624e-07], dtype=float32),\n",
       "  array([7.8307266e+00, 4.2403140e+00, 1.0116384e-07], dtype=float32),\n",
       "  array([1.0976033e+01, 1.0949982e+00, 6.7482262e-08], dtype=float32),\n",
       "  array([9.8768921e+00, 2.1941490e+00, 1.3489314e-07], dtype=float32),\n",
       "  array([7.4647684e+00, 4.6062651e+00, 8.4317492e-08], dtype=float32),\n",
       "  array([1.1829492e+01, 2.4155699e-01, 8.4315225e-08], dtype=float32),\n",
       "  array([8.1739607e+00, 3.8970785e+00, 6.7556712e-08], dtype=float32),\n",
       "  array([9.0440216e+00, 3.0270185e+00, 8.4758490e-08], dtype=float32)])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nuclear_norm_trial, eigenvalues_trial"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0, 0],\n",
       "         [0, 1],\n",
       "         [1, 0],\n",
       "         [1, 1],\n",
       "         [2, 2]]),\n",
       " tensor([[1.],\n",
       "         [2.],\n",
       "         [3.],\n",
       "         [4.],\n",
       "         [5.]]))"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ls_example1 = [0, 1, 3, 8]\n",
    "ls_example2 = [0, 1, 3, 4, 8]\n",
    "ls_example3 = [0, 1, 3, 4, 6, 8]\n",
    "\n",
    "features_train, labels_train = fix_sample(M, ls_example2)\n",
    "# features_train, labels_train = random_sample(M)\n",
    "train_dataset = torch.utils.data.TensorDataset(features_train, labels_train)\n",
    "features_train, labels_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"244.8pt\" height=\"172.8pt\" viewBox=\"0 0 244.8 172.8\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:35.256581</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 172.8 \n",
       "L 244.8 172.8 \n",
       "L 244.8 0 \n",
       "L 0 0 \n",
       "L 0 172.8 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"LineCollection_1\">\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#p37f2560973)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 94.100535 \n",
       "\" clip-path=\"url(#p37f2560973)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 78.699465 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#p37f2560973)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 78.699465 \n",
       "L 217.606612 94.100535 \n",
       "\" clip-path=\"url(#p37f2560973)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 20.945455 \n",
       "L 217.606612 36.346524 \n",
       "\" clip-path=\"url(#p37f2560973)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_1\">\n",
       "    <defs>\n",
       "     <path id=\"mf9d8824ccb\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <use xlink:href=\"#mf9d8824ccb\" x=\"27.193388\" y=\"136.453476\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#mf9d8824ccb\" x=\"27.193388\" y=\"78.699465\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#mf9d8824ccb\" x=\"27.193388\" y=\"20.945455\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_2\">\n",
       "    <defs>\n",
       "     <path id=\"mc5319aa299\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <use xlink:href=\"#mc5319aa299\" x=\"217.606612\" y=\"151.854545\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#mc5319aa299\" x=\"217.606612\" y=\"94.100535\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#mc5319aa299\" x=\"217.606612\" y=\"36.346524\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_1\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 1 -->\n",
       "     <g transform=\"translate(23.375888 139.764726) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_2\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 2 -->\n",
       "     <g transform=\"translate(23.375888 82.010715) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_3\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 3 -->\n",
       "     <g transform=\"translate(23.375888 24.256705) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-33\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_4\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 4 -->\n",
       "     <g transform=\"translate(213.789112 155.165795) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-34\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_5\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 5 -->\n",
       "     <g transform=\"translate(213.789112 97.411785) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_6\">\n",
       "    <g clip-path=\"url(#p37f2560973)\">\n",
       "     <!-- 6 -->\n",
       "     <g transform=\"translate(213.789112 39.657774) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-36\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p37f2560973\">\n",
       "   <rect x=\"7.2\" y=\"7.2\" width=\"230.4\" height=\"158.4\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "G, P = generated_graph(features_train, M, d)\n",
    "plot_bipartite_graph(G, P)\n",
    "\n",
    "plt.savefig('example2_disconnected.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10.830951993578875"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import networkx as nx\n",
    "import cvxpy as cp\n",
    "import time\n",
    "observation_matrix2 = create_observation_matrix(features_train, labels_train, d=d)\n",
    "min_nuclear_norm2 = compute_nuclear_norm(min_nuclear_norm(observation_matrix2))\n",
    "min_nuclear_norm2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2458.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.027\n",
      "19485.9 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2771.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "22024.7 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2660.45it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "21226.6 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2528.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "20189.2 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2911.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "23149.7 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2852.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "22705.1 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2756.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "21937.1 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2867.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "22838.8 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2435.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "19395.4 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2800.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "22249.3 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:01<00:00, 2915.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "23218.6 examples/sec on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "nuclear_norm_trial2 = []\n",
    "eigenvalues_trial2 = []\n",
    "# num_epochs = 1500\n",
    "batch_size, num_epochs, lr = 1024, 3000, 1e-1\n",
    "train_iter = torch.utils.data.DataLoader(train_dataset, batch_size, shuffle=True)\n",
    "for i in range(11):\n",
    "    net = NeuralNetwork()\n",
    "    net.apply(lambda m: init_weights(m, sigma=1e-6))\n",
    "    train_ls, test_ls = train(net, train_iter, num_epochs, lr, try_gpu(), test_iter=None, stop=1e-15)\n",
    "    if train_ls[-1] <= 1e-7:\n",
    "        A = np.copy(list(net.parameters())[0].detach().T)\n",
    "        B = np.copy(list(net.parameters())[1].detach().T)\n",
    "        nuclear_norm_trial2.append(compute_nuclear_norm(A @ B))\n",
    "        eigenvalues_trial2.append(np.linalg.svd(A @ B, compute_uv=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"262.185054pt\" height=\"180.65625pt\" viewBox=\"0 0 262.185054 180.65625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:47.602633</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 180.65625 \n",
       "L 262.185054 180.65625 \n",
       "L 262.185054 0 \n",
       "L 0 0 \n",
       "L 0 180.65625 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 55.778125 143.1 \n",
       "L 251.078125 143.1 \n",
       "L 251.078125 7.2 \n",
       "L 55.778125 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_1\">\n",
       "    <g id=\"xtick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"m65ef8390fd\" d=\"M 0 0 \n",
       "L 0 3.5 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m65ef8390fd\" x=\"64.655398\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- 0 -->\n",
       "      <g transform=\"translate(61.474148 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m65ef8390fd\" x=\"123.85695\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- 1000 -->\n",
       "      <g transform=\"translate(111.13195 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m65ef8390fd\" x=\"183.058502\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- 2000 -->\n",
       "      <g transform=\"translate(170.333502 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_4\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m65ef8390fd\" x=\"242.260054\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- 3000 -->\n",
       "      <g transform=\"translate(229.535054 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-33\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_5\">\n",
       "     <!-- xlabel -->\n",
       "     <g transform=\"translate(138.375781 171.376563) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-78\" d=\"M 3513 3500 \n",
       "L 2247 1797 \n",
       "L 3578 0 \n",
       "L 2900 0 \n",
       "L 1881 1375 \n",
       "L 863 0 \n",
       "L 184 0 \n",
       "L 1544 1831 \n",
       "L 300 3500 \n",
       "L 978 3500 \n",
       "L 1906 2253 \n",
       "L 2834 3500 \n",
       "L 3513 3500 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \n",
       "Q 3116 2381 2855 2742 \n",
       "Q 2594 3103 2138 3103 \n",
       "Q 1681 3103 1420 2742 \n",
       "Q 1159 2381 1159 1747 \n",
       "Q 1159 1113 1420 752 \n",
       "Q 1681 391 2138 391 \n",
       "Q 2594 391 2855 752 \n",
       "Q 3116 1113 3116 1747 \n",
       "z\n",
       "M 1159 2969 \n",
       "Q 1341 3281 1617 3432 \n",
       "Q 1894 3584 2278 3584 \n",
       "Q 2916 3584 3314 3078 \n",
       "Q 3713 2572 3713 1747 \n",
       "Q 3713 922 3314 415 \n",
       "Q 2916 -91 2278 -91 \n",
       "Q 1894 -91 1617 61 \n",
       "Q 1341 213 1159 525 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 4863 \n",
       "L 1159 4863 \n",
       "L 1159 2969 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <defs>\n",
       "       <path id=\"m3642a8f14c\" d=\"M 0 0 \n",
       "L -3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m3642a8f14c\" x=\"55.778125\" y=\"122.756181\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_6\">\n",
       "      <!-- $\\mathdefault{10^{-11}}$ -->\n",
       "      <g transform=\"translate(20.878125 126.5554) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-2212\" d=\"M 678 2272 \n",
       "L 4684 2272 \n",
       "L 4684 1741 \n",
       "L 678 1741 \n",
       "L 678 2272 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 38.965625) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(186.855469 38.965625) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(231.391602 38.965625) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m3642a8f14c\" x=\"55.778125\" y=\"95.505452\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_7\">\n",
       "      <!-- $\\mathdefault{10^{-8}}$ -->\n",
       "      <g transform=\"translate(25.278125 99.304671) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \n",
       "Q 1584 2216 1326 1975 \n",
       "Q 1069 1734 1069 1313 \n",
       "Q 1069 891 1326 650 \n",
       "Q 1584 409 2034 409 \n",
       "Q 2484 409 2743 651 \n",
       "Q 3003 894 3003 1313 \n",
       "Q 3003 1734 2745 1975 \n",
       "Q 2488 2216 2034 2216 \n",
       "z\n",
       "M 1403 2484 \n",
       "Q 997 2584 770 2862 \n",
       "Q 544 3141 544 3541 \n",
       "Q 544 4100 942 4425 \n",
       "Q 1341 4750 2034 4750 \n",
       "Q 2731 4750 3128 4425 \n",
       "Q 3525 4100 3525 3541 \n",
       "Q 3525 3141 3298 2862 \n",
       "Q 3072 2584 2669 2484 \n",
       "Q 3125 2378 3379 2068 \n",
       "Q 3634 1759 3634 1313 \n",
       "Q 3634 634 3220 271 \n",
       "Q 2806 -91 2034 -91 \n",
       "Q 1263 -91 848 271 \n",
       "Q 434 634 434 1313 \n",
       "Q 434 1759 690 2068 \n",
       "Q 947 2378 1403 2484 \n",
       "z\n",
       "M 1172 3481 \n",
       "Q 1172 3119 1398 2916 \n",
       "Q 1625 2713 2034 2713 \n",
       "Q 2441 2713 2670 2916 \n",
       "Q 2900 3119 2900 3481 \n",
       "Q 2900 3844 2670 4047 \n",
       "Q 2441 4250 2034 4250 \n",
       "Q 1625 4250 1398 4047 \n",
       "Q 1172 3844 1172 3481 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-38\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m3642a8f14c\" x=\"55.778125\" y=\"68.254724\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- $\\mathdefault{10^{-5}}$ -->\n",
       "      <g transform=\"translate(25.278125 72.053942) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 38.965625) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(186.855469 38.965625) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m3642a8f14c\" x=\"55.778125\" y=\"41.003995\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_9\">\n",
       "      <!-- $\\mathdefault{10^{-2}}$ -->\n",
       "      <g transform=\"translate(25.278125 44.803214) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_5\">\n",
       "     <g id=\"line2d_9\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m3642a8f14c\" x=\"55.778125\" y=\"13.753266\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_10\">\n",
       "      <!-- $\\mathdefault{10^{1}}$ -->\n",
       "      <g transform=\"translate(31.178125 17.552485) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(128.203125 38.965625) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_11\">\n",
       "     <!-- ylabel -->\n",
       "     <g transform=\"translate(14.798437 90.202344) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-79\" d=\"M 2059 -325 \n",
       "Q 1816 -950 1584 -1140 \n",
       "Q 1353 -1331 966 -1331 \n",
       "L 506 -1331 \n",
       "L 506 -850 \n",
       "L 844 -850 \n",
       "Q 1081 -850 1212 -737 \n",
       "Q 1344 -625 1503 -206 \n",
       "L 1606 56 \n",
       "L 191 3500 \n",
       "L 800 3500 \n",
       "L 1894 763 \n",
       "L 2988 3500 \n",
       "L 3597 3500 \n",
       "L 2059 -325 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-79\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_10\">\n",
       "    <path d=\"M 64.655398 13.377273 \n",
       "L 68.444297 13.466208 \n",
       "L 68.621902 13.659301 \n",
       "L 68.799506 14.226247 \n",
       "L 69.036313 16.19593 \n",
       "L 69.33232 20.446378 \n",
       "L 69.569127 28.453538 \n",
       "L 69.865134 36.777701 \n",
       "L 70.042739 37.099655 \n",
       "L 70.693956 37.117024 \n",
       "L 116.397554 37.227348 \n",
       "L 118.765616 37.464805 \n",
       "L 120.245655 37.820726 \n",
       "L 121.370485 38.30347 \n",
       "L 122.376911 38.980825 \n",
       "L 123.264934 39.844973 \n",
       "L 124.152958 41.024201 \n",
       "L 125.100182 42.68369 \n",
       "L 126.106609 44.925363 \n",
       "L 127.29064 48.152687 \n",
       "L 128.770679 52.89874 \n",
       "L 130.842733 60.366543 \n",
       "L 134.631632 75.002015 \n",
       "L 148.307191 128.50187 \n",
       "L 148.366392 128.50187 \n",
       "L 148.6624 129.304746 \n",
       "L 148.721602 129.37615 \n",
       "L 148.899206 130.027535 \n",
       "L 149.313617 131.048408 \n",
       "L 149.372819 130.808168 \n",
       "L 149.43202 131.294456 \n",
       "L 149.491222 131.207538 \n",
       "L 149.550423 131.207538 \n",
       "L 150.20164 133.482629 \n",
       "L 150.260842 133.482629 \n",
       "L 150.379245 133.819706 \n",
       "L 150.438447 133.819706 \n",
       "L 150.55685 134.127761 \n",
       "L 150.734454 134.127761 \n",
       "L 150.852857 134.48378 \n",
       "L 151.208067 134.48378 \n",
       "L 151.267268 133.764531 \n",
       "L 151.385671 134.48378 \n",
       "L 151.800082 134.48378 \n",
       "L 151.918485 134.827035 \n",
       "L 152.688106 134.827035 \n",
       "L 152.806509 135.150777 \n",
       "L 152.86571 135.150777 \n",
       "L 152.924912 134.827035 \n",
       "L 153.043315 135.150777 \n",
       "L 153.102516 135.150777 \n",
       "L 153.161718 134.827035 \n",
       "L 153.22092 135.150777 \n",
       "L 153.280121 134.827035 \n",
       "L 153.398524 135.150777 \n",
       "L 153.457726 134.827035 \n",
       "L 153.576129 135.953964 \n",
       "L 153.63533 135.150777 \n",
       "L 153.753734 135.953964 \n",
       "L 153.99054 135.953964 \n",
       "L 154.049741 135.150777 \n",
       "L 154.168144 135.953964 \n",
       "L 154.227346 135.953964 \n",
       "L 154.286548 135.150777 \n",
       "L 154.404951 135.953964 \n",
       "L 154.464152 135.953964 \n",
       "L 154.523354 135.150777 \n",
       "L 154.641757 135.953964 \n",
       "L 154.700958 135.953964 \n",
       "L 154.76016 135.150777 \n",
       "L 154.878563 135.953964 \n",
       "L 154.937765 135.953964 \n",
       "L 155.056168 136.320425 \n",
       "L 155.174571 136.320425 \n",
       "L 155.233772 135.447124 \n",
       "L 155.352175 136.647844 \n",
       "L 155.52978 136.647844 \n",
       "L 155.648183 135.953964 \n",
       "L 155.825788 135.953964 \n",
       "L 155.944191 136.320425 \n",
       "L 157.246625 136.320425 \n",
       "L 157.365028 136.647844 \n",
       "L 162.101152 136.647844 \n",
       "L 162.160354 136.922727 \n",
       "L 162.219555 136.647844 \n",
       "L 162.278757 136.922727 \n",
       "L 162.337959 136.647844 \n",
       "L 162.39716 136.922727 \n",
       "L 162.456362 136.647844 \n",
       "L 162.515563 136.922727 \n",
       "L 162.574765 136.647844 \n",
       "L 162.633966 136.922727 \n",
       "L 162.693168 136.647844 \n",
       "L 162.752369 136.922727 \n",
       "L 162.811571 136.647844 \n",
       "L 162.870773 136.922727 \n",
       "L 162.929974 136.647844 \n",
       "L 162.989176 136.922727 \n",
       "L 163.048377 136.647844 \n",
       "L 163.107579 136.922727 \n",
       "L 163.16678 136.647844 \n",
       "L 163.225982 136.922727 \n",
       "L 163.285183 136.647844 \n",
       "L 163.344385 136.922727 \n",
       "L 163.403587 136.647844 \n",
       "L 163.462788 136.922727 \n",
       "L 163.52199 136.647844 \n",
       "L 163.581191 136.922727 \n",
       "L 163.640393 136.647844 \n",
       "L 163.699594 136.922727 \n",
       "L 163.758796 136.647844 \n",
       "L 163.817997 136.922727 \n",
       "L 163.877199 136.647844 \n",
       "L 163.9364 136.922727 \n",
       "L 163.995602 136.647844 \n",
       "L 164.054804 136.922727 \n",
       "L 164.114005 136.647844 \n",
       "L 164.173207 136.922727 \n",
       "L 164.232408 136.647844 \n",
       "L 164.29161 136.922727 \n",
       "L 164.350811 136.647844 \n",
       "L 164.410013 136.922727 \n",
       "L 164.469214 136.647844 \n",
       "L 164.528416 136.922727 \n",
       "L 164.587618 136.647844 \n",
       "L 164.646819 136.922727 \n",
       "L 164.706021 136.647844 \n",
       "L 164.765222 136.922727 \n",
       "L 164.824424 136.647844 \n",
       "L 164.883625 136.922727 \n",
       "L 164.942827 136.647844 \n",
       "L 165.002028 136.922727 \n",
       "L 165.06123 136.647844 \n",
       "L 165.120432 136.922727 \n",
       "L 165.179633 136.647844 \n",
       "L 165.238835 136.922727 \n",
       "L 165.298036 136.647844 \n",
       "L 165.357238 136.922727 \n",
       "L 165.416439 136.647844 \n",
       "L 165.475641 136.922727 \n",
       "L 165.534842 136.647844 \n",
       "L 165.594044 136.922727 \n",
       "L 165.653245 136.647844 \n",
       "L 165.712447 136.922727 \n",
       "L 165.771649 136.647844 \n",
       "L 165.83085 136.922727 \n",
       "L 165.890052 136.647844 \n",
       "L 165.949253 136.922727 \n",
       "L 166.008455 136.647844 \n",
       "L 166.067656 136.922727 \n",
       "L 166.126858 136.647844 \n",
       "L 166.186059 136.922727 \n",
       "L 166.245261 136.647844 \n",
       "L 166.304463 136.922727 \n",
       "L 166.363664 136.647844 \n",
       "L 166.422866 136.922727 \n",
       "L 166.482067 136.647844 \n",
       "L 166.541269 136.922727 \n",
       "L 166.60047 136.647844 \n",
       "L 166.659672 136.922727 \n",
       "L 166.718873 136.647844 \n",
       "L 166.778075 136.922727 \n",
       "L 166.837277 136.647844 \n",
       "L 166.896478 136.922727 \n",
       "L 166.95568 136.647844 \n",
       "L 167.014881 136.922727 \n",
       "L 167.074083 136.647844 \n",
       "L 167.133284 136.922727 \n",
       "L 167.192486 136.647844 \n",
       "L 167.251687 136.922727 \n",
       "L 167.310889 136.647844 \n",
       "L 167.370091 136.922727 \n",
       "L 167.429292 136.647844 \n",
       "L 167.488494 136.922727 \n",
       "L 167.547695 136.647844 \n",
       "L 167.606897 136.922727 \n",
       "L 167.666098 136.647844 \n",
       "L 167.7253 136.922727 \n",
       "L 167.784501 136.647844 \n",
       "L 167.843703 136.922727 \n",
       "L 167.902904 136.647844 \n",
       "L 167.962106 136.922727 \n",
       "L 168.021308 136.647844 \n",
       "L 168.080509 136.922727 \n",
       "L 168.139711 136.647844 \n",
       "L 168.198912 136.922727 \n",
       "L 168.258114 136.647844 \n",
       "L 168.317315 136.922727 \n",
       "L 168.376517 136.647844 \n",
       "L 168.435718 136.922727 \n",
       "L 168.49492 136.647844 \n",
       "L 168.554122 136.922727 \n",
       "L 168.613323 136.647844 \n",
       "L 168.672525 136.922727 \n",
       "L 168.731726 136.647844 \n",
       "L 168.790928 136.922727 \n",
       "L 168.850129 136.647844 \n",
       "L 168.909331 136.922727 \n",
       "L 168.968532 136.647844 \n",
       "L 169.027734 136.922727 \n",
       "L 169.086936 136.647844 \n",
       "L 169.146137 136.922727 \n",
       "L 169.205339 136.647844 \n",
       "L 169.26454 136.922727 \n",
       "L 169.323742 136.647844 \n",
       "L 169.382943 136.922727 \n",
       "L 169.442145 136.647844 \n",
       "L 169.501346 136.922727 \n",
       "L 169.560548 136.647844 \n",
       "L 169.619749 136.922727 \n",
       "L 169.678951 136.647844 \n",
       "L 169.738153 136.922727 \n",
       "L 169.797354 136.647844 \n",
       "L 169.856556 136.922727 \n",
       "L 169.915757 136.647844 \n",
       "L 169.974959 136.922727 \n",
       "L 170.03416 136.647844 \n",
       "L 170.093362 136.922727 \n",
       "L 170.152563 136.647844 \n",
       "L 170.211765 136.922727 \n",
       "L 170.270967 136.647844 \n",
       "L 170.330168 136.922727 \n",
       "L 170.38937 136.647844 \n",
       "L 170.448571 136.922727 \n",
       "L 170.507773 136.647844 \n",
       "L 170.566974 136.922727 \n",
       "L 170.626176 136.647844 \n",
       "L 170.685377 136.922727 \n",
       "L 170.744579 136.647844 \n",
       "L 170.803781 136.922727 \n",
       "L 170.862982 136.647844 \n",
       "L 170.922184 136.922727 \n",
       "L 170.981385 136.647844 \n",
       "L 171.040587 136.922727 \n",
       "L 171.099788 136.647844 \n",
       "L 171.15899 136.922727 \n",
       "L 171.218191 136.647844 \n",
       "L 171.277393 136.922727 \n",
       "L 171.336594 136.647844 \n",
       "L 171.395796 136.922727 \n",
       "L 171.454998 136.647844 \n",
       "L 171.514199 136.922727 \n",
       "L 171.573401 136.647844 \n",
       "L 171.632602 136.922727 \n",
       "L 171.691804 136.647844 \n",
       "L 171.751005 136.922727 \n",
       "L 171.810207 136.647844 \n",
       "L 171.869408 136.922727 \n",
       "L 171.92861 136.647844 \n",
       "L 171.987812 136.922727 \n",
       "L 172.047013 136.647844 \n",
       "L 172.106215 136.922727 \n",
       "L 172.165416 136.647844 \n",
       "L 172.224618 136.922727 \n",
       "L 172.283819 136.647844 \n",
       "L 172.343021 136.922727 \n",
       "L 172.402222 136.647844 \n",
       "L 172.461424 136.922727 \n",
       "L 172.520626 136.647844 \n",
       "L 172.579827 136.922727 \n",
       "L 172.639029 136.647844 \n",
       "L 172.69823 136.922727 \n",
       "L 172.757432 136.647844 \n",
       "L 172.816633 136.922727 \n",
       "L 172.875835 136.647844 \n",
       "L 172.935036 136.922727 \n",
       "L 172.994238 136.647844 \n",
       "L 173.053439 136.922727 \n",
       "L 173.112641 136.647844 \n",
       "L 173.171843 136.922727 \n",
       "L 173.231044 136.647844 \n",
       "L 173.290246 136.922727 \n",
       "L 173.349447 136.647844 \n",
       "L 173.408649 136.922727 \n",
       "L 173.46785 136.647844 \n",
       "L 173.527052 136.922727 \n",
       "L 173.586253 136.647844 \n",
       "L 173.645455 136.922727 \n",
       "L 173.704657 136.647844 \n",
       "L 173.763858 136.922727 \n",
       "L 173.82306 136.647844 \n",
       "L 173.882261 136.922727 \n",
       "L 173.941463 136.647844 \n",
       "L 174.000664 136.922727 \n",
       "L 174.059866 136.647844 \n",
       "L 174.119067 136.922727 \n",
       "L 174.178269 136.647844 \n",
       "L 174.237471 136.922727 \n",
       "L 174.296672 136.647844 \n",
       "L 174.355874 136.922727 \n",
       "L 174.415075 136.647844 \n",
       "L 174.474277 136.922727 \n",
       "L 174.533478 136.647844 \n",
       "L 174.59268 136.922727 \n",
       "L 174.651881 136.647844 \n",
       "L 174.711083 136.922727 \n",
       "L 174.770285 136.647844 \n",
       "L 174.829486 136.922727 \n",
       "L 174.888688 136.647844 \n",
       "L 174.947889 136.922727 \n",
       "L 175.007091 136.647844 \n",
       "L 175.066292 136.922727 \n",
       "L 175.125494 136.647844 \n",
       "L 175.184695 136.922727 \n",
       "L 175.243897 136.647844 \n",
       "L 175.303098 136.922727 \n",
       "L 175.3623 136.647844 \n",
       "L 175.421502 136.922727 \n",
       "L 175.480703 136.647844 \n",
       "L 175.539905 136.922727 \n",
       "L 175.599106 136.647844 \n",
       "L 175.658308 136.922727 \n",
       "L 175.717509 136.647844 \n",
       "L 175.776711 136.922727 \n",
       "L 175.835912 136.647844 \n",
       "L 175.895114 136.922727 \n",
       "L 175.954316 136.647844 \n",
       "L 176.013517 136.922727 \n",
       "L 176.072719 136.647844 \n",
       "L 176.13192 136.922727 \n",
       "L 176.191122 136.647844 \n",
       "L 176.250323 136.922727 \n",
       "L 176.309525 136.647844 \n",
       "L 176.368726 136.922727 \n",
       "L 176.427928 136.647844 \n",
       "L 176.48713 136.922727 \n",
       "L 176.546331 136.647844 \n",
       "L 176.605533 136.922727 \n",
       "L 176.664734 136.647844 \n",
       "L 176.723936 136.922727 \n",
       "L 176.783137 136.647844 \n",
       "L 176.842339 136.922727 \n",
       "L 176.90154 136.647844 \n",
       "L 176.960742 136.922727 \n",
       "L 177.019943 136.647844 \n",
       "L 177.079145 136.922727 \n",
       "L 177.138347 136.647844 \n",
       "L 177.197548 136.922727 \n",
       "L 177.25675 136.647844 \n",
       "L 177.315951 136.922727 \n",
       "L 177.375153 136.647844 \n",
       "L 177.434354 136.922727 \n",
       "L 177.493556 136.647844 \n",
       "L 177.552757 136.922727 \n",
       "L 177.611959 136.647844 \n",
       "L 177.671161 136.922727 \n",
       "L 177.730362 136.647844 \n",
       "L 177.789564 136.922727 \n",
       "L 177.848765 136.647844 \n",
       "L 177.907967 136.922727 \n",
       "L 177.967168 136.647844 \n",
       "L 178.02637 136.922727 \n",
       "L 178.085571 136.647844 \n",
       "L 178.144773 136.922727 \n",
       "L 178.203975 136.647844 \n",
       "L 178.263176 136.922727 \n",
       "L 178.322378 136.647844 \n",
       "L 178.381579 136.922727 \n",
       "L 178.440781 136.647844 \n",
       "L 178.499982 136.922727 \n",
       "L 178.559184 136.647844 \n",
       "L 178.618385 136.922727 \n",
       "L 178.677587 136.647844 \n",
       "L 178.736788 136.922727 \n",
       "L 178.79599 136.647844 \n",
       "L 178.855192 136.922727 \n",
       "L 178.914393 136.647844 \n",
       "L 178.973595 136.922727 \n",
       "L 179.032796 136.647844 \n",
       "L 179.091998 136.922727 \n",
       "L 179.151199 136.647844 \n",
       "L 179.210401 136.922727 \n",
       "L 179.269602 136.647844 \n",
       "L 179.328804 136.922727 \n",
       "L 179.388006 136.647844 \n",
       "L 179.447207 136.922727 \n",
       "L 179.506409 136.647844 \n",
       "L 179.56561 136.922727 \n",
       "L 179.624812 136.647844 \n",
       "L 179.684013 136.922727 \n",
       "L 179.743215 136.647844 \n",
       "L 179.802416 136.922727 \n",
       "L 179.861618 136.647844 \n",
       "L 179.92082 136.922727 \n",
       "L 179.980021 136.647844 \n",
       "L 180.039223 136.922727 \n",
       "L 180.098424 136.647844 \n",
       "L 180.157626 136.922727 \n",
       "L 180.216827 136.647844 \n",
       "L 180.276029 136.922727 \n",
       "L 180.33523 136.647844 \n",
       "L 180.394432 136.922727 \n",
       "L 180.453634 136.647844 \n",
       "L 180.512835 136.922727 \n",
       "L 180.572037 136.647844 \n",
       "L 180.631238 136.922727 \n",
       "L 180.69044 136.647844 \n",
       "L 180.749641 136.922727 \n",
       "L 180.808843 136.647844 \n",
       "L 180.868044 136.922727 \n",
       "L 180.927246 136.647844 \n",
       "L 180.986447 136.922727 \n",
       "L 181.045649 136.647844 \n",
       "L 181.104851 136.922727 \n",
       "L 181.164052 136.647844 \n",
       "L 181.223254 136.922727 \n",
       "L 181.282455 136.647844 \n",
       "L 181.341657 136.922727 \n",
       "L 181.400858 136.647844 \n",
       "L 181.46006 136.922727 \n",
       "L 181.519261 136.647844 \n",
       "L 181.578463 136.922727 \n",
       "L 181.637665 136.647844 \n",
       "L 181.696866 136.922727 \n",
       "L 181.756068 136.647844 \n",
       "L 181.815269 136.922727 \n",
       "L 181.874471 136.647844 \n",
       "L 181.933672 136.922727 \n",
       "L 181.992874 136.647844 \n",
       "L 182.052075 136.922727 \n",
       "L 182.111277 136.647844 \n",
       "L 182.170479 136.922727 \n",
       "L 182.22968 136.647844 \n",
       "L 182.288882 136.922727 \n",
       "L 182.348083 136.647844 \n",
       "L 182.407285 136.922727 \n",
       "L 182.466486 136.647844 \n",
       "L 182.525688 136.922727 \n",
       "L 182.584889 136.647844 \n",
       "L 182.644091 136.922727 \n",
       "L 182.703292 136.647844 \n",
       "L 182.762494 136.922727 \n",
       "L 182.821696 136.647844 \n",
       "L 182.880897 136.922727 \n",
       "L 182.940099 136.647844 \n",
       "L 182.9993 136.922727 \n",
       "L 183.058502 136.647844 \n",
       "L 183.117703 136.922727 \n",
       "L 183.176905 136.647844 \n",
       "L 183.236106 136.922727 \n",
       "L 183.295308 136.647844 \n",
       "L 183.35451 136.922727 \n",
       "L 183.413711 136.647844 \n",
       "L 183.472913 136.922727 \n",
       "L 183.532114 136.647844 \n",
       "L 183.591316 136.922727 \n",
       "L 183.650517 136.647844 \n",
       "L 183.709719 136.922727 \n",
       "L 183.76892 136.647844 \n",
       "L 183.828122 136.922727 \n",
       "L 183.887324 136.647844 \n",
       "L 183.946525 136.922727 \n",
       "L 184.005727 136.647844 \n",
       "L 184.064928 136.922727 \n",
       "L 184.12413 136.647844 \n",
       "L 184.183331 136.922727 \n",
       "L 184.242533 136.647844 \n",
       "L 184.301734 136.922727 \n",
       "L 184.360936 136.647844 \n",
       "L 184.420137 136.922727 \n",
       "L 184.479339 136.647844 \n",
       "L 184.538541 136.922727 \n",
       "L 184.597742 136.647844 \n",
       "L 184.656944 136.922727 \n",
       "L 184.716145 136.647844 \n",
       "L 184.775347 136.922727 \n",
       "L 184.834548 136.647844 \n",
       "L 184.89375 136.922727 \n",
       "L 184.952951 136.647844 \n",
       "L 185.012153 136.922727 \n",
       "L 185.071355 136.647844 \n",
       "L 185.130556 136.922727 \n",
       "L 185.189758 136.647844 \n",
       "L 185.248959 136.922727 \n",
       "L 185.308161 136.647844 \n",
       "L 185.367362 136.922727 \n",
       "L 185.426564 136.647844 \n",
       "L 185.485765 136.922727 \n",
       "L 185.544967 136.647844 \n",
       "L 185.604169 136.922727 \n",
       "L 185.66337 136.647844 \n",
       "L 185.722572 136.922727 \n",
       "L 185.781773 136.647844 \n",
       "L 185.840975 136.922727 \n",
       "L 185.900176 136.647844 \n",
       "L 185.959378 136.922727 \n",
       "L 186.018579 136.647844 \n",
       "L 186.077781 136.922727 \n",
       "L 186.136982 136.647844 \n",
       "L 186.196184 136.922727 \n",
       "L 186.255386 136.647844 \n",
       "L 186.314587 136.922727 \n",
       "L 186.373789 136.647844 \n",
       "L 186.43299 136.922727 \n",
       "L 186.492192 136.647844 \n",
       "L 186.551393 136.922727 \n",
       "L 186.610595 136.647844 \n",
       "L 186.669796 136.922727 \n",
       "L 186.728998 136.647844 \n",
       "L 186.7882 136.922727 \n",
       "L 186.847401 136.647844 \n",
       "L 186.906603 136.922727 \n",
       "L 186.965804 136.647844 \n",
       "L 187.025006 136.922727 \n",
       "L 187.084207 136.647844 \n",
       "L 187.143409 136.922727 \n",
       "L 187.20261 136.647844 \n",
       "L 187.261812 136.922727 \n",
       "L 187.321014 136.647844 \n",
       "L 187.380215 136.922727 \n",
       "L 187.439417 136.647844 \n",
       "L 187.498618 136.922727 \n",
       "L 187.55782 136.647844 \n",
       "L 187.617021 136.922727 \n",
       "L 187.676223 136.647844 \n",
       "L 187.735424 136.922727 \n",
       "L 187.794626 136.647844 \n",
       "L 187.853828 136.922727 \n",
       "L 187.913029 136.647844 \n",
       "L 187.972231 136.922727 \n",
       "L 188.031432 136.647844 \n",
       "L 188.090634 136.922727 \n",
       "L 188.149835 136.647844 \n",
       "L 188.209037 136.922727 \n",
       "L 188.268238 136.647844 \n",
       "L 188.32744 136.922727 \n",
       "L 188.386641 136.647844 \n",
       "L 188.445843 136.922727 \n",
       "L 188.505045 136.647844 \n",
       "L 188.564246 136.922727 \n",
       "L 188.623448 136.647844 \n",
       "L 188.682649 136.922727 \n",
       "L 188.741851 136.647844 \n",
       "L 188.801052 136.922727 \n",
       "L 188.860254 136.647844 \n",
       "L 188.919455 136.922727 \n",
       "L 188.978657 136.647844 \n",
       "L 189.037859 136.922727 \n",
       "L 189.09706 136.647844 \n",
       "L 189.156262 136.922727 \n",
       "L 189.215463 136.647844 \n",
       "L 189.274665 136.922727 \n",
       "L 189.333866 136.647844 \n",
       "L 189.393068 136.922727 \n",
       "L 189.452269 136.647844 \n",
       "L 189.511471 136.922727 \n",
       "L 189.570673 136.647844 \n",
       "L 189.629874 136.922727 \n",
       "L 189.689076 136.647844 \n",
       "L 189.748277 136.922727 \n",
       "L 189.807479 136.647844 \n",
       "L 189.86668 136.922727 \n",
       "L 189.925882 136.647844 \n",
       "L 189.985083 136.922727 \n",
       "L 190.044285 136.647844 \n",
       "L 190.103486 136.922727 \n",
       "L 190.162688 136.647844 \n",
       "L 190.22189 136.922727 \n",
       "L 190.281091 136.647844 \n",
       "L 190.340293 136.922727 \n",
       "L 190.399494 136.647844 \n",
       "L 190.458696 136.922727 \n",
       "L 190.517897 136.647844 \n",
       "L 190.577099 136.922727 \n",
       "L 190.6363 136.647844 \n",
       "L 190.695502 136.922727 \n",
       "L 190.754704 136.647844 \n",
       "L 190.813905 136.922727 \n",
       "L 190.873107 136.647844 \n",
       "L 190.932308 136.922727 \n",
       "L 190.99151 136.647844 \n",
       "L 191.050711 136.922727 \n",
       "L 191.109913 136.647844 \n",
       "L 191.169114 136.922727 \n",
       "L 191.228316 136.647844 \n",
       "L 191.287518 136.922727 \n",
       "L 191.346719 136.647844 \n",
       "L 191.405921 136.922727 \n",
       "L 191.465122 136.647844 \n",
       "L 191.524324 136.922727 \n",
       "L 191.583525 136.647844 \n",
       "L 191.642727 136.922727 \n",
       "L 191.701928 136.647844 \n",
       "L 191.76113 136.922727 \n",
       "L 191.820331 136.647844 \n",
       "L 191.879533 136.922727 \n",
       "L 191.938735 136.647844 \n",
       "L 191.997936 136.922727 \n",
       "L 192.057138 136.647844 \n",
       "L 192.116339 136.922727 \n",
       "L 192.175541 136.647844 \n",
       "L 192.234742 136.922727 \n",
       "L 192.293944 136.647844 \n",
       "L 192.353145 136.922727 \n",
       "L 192.412347 136.647844 \n",
       "L 192.471549 136.922727 \n",
       "L 192.53075 136.647844 \n",
       "L 192.589952 136.922727 \n",
       "L 192.649153 136.647844 \n",
       "L 192.708355 136.922727 \n",
       "L 192.767556 136.647844 \n",
       "L 192.826758 136.922727 \n",
       "L 192.885959 136.647844 \n",
       "L 192.945161 136.922727 \n",
       "L 193.004363 136.647844 \n",
       "L 193.063564 136.922727 \n",
       "L 193.122766 136.647844 \n",
       "L 193.181967 136.922727 \n",
       "L 193.241169 136.647844 \n",
       "L 193.30037 136.922727 \n",
       "L 193.359572 136.647844 \n",
       "L 193.418773 136.922727 \n",
       "L 193.477975 136.647844 \n",
       "L 193.537177 136.922727 \n",
       "L 193.596378 136.647844 \n",
       "L 193.65558 136.922727 \n",
       "L 193.714781 136.647844 \n",
       "L 193.773983 136.922727 \n",
       "L 193.833184 136.647844 \n",
       "L 193.892386 136.922727 \n",
       "L 193.951587 136.647844 \n",
       "L 194.010789 136.922727 \n",
       "L 194.06999 136.647844 \n",
       "L 194.129192 136.922727 \n",
       "L 194.188394 136.647844 \n",
       "L 194.247595 136.922727 \n",
       "L 194.306797 136.647844 \n",
       "L 194.365998 136.922727 \n",
       "L 194.4252 136.647844 \n",
       "L 194.484401 136.922727 \n",
       "L 194.543603 136.647844 \n",
       "L 194.602804 136.922727 \n",
       "L 194.662006 136.647844 \n",
       "L 194.721208 136.922727 \n",
       "L 194.780409 136.647844 \n",
       "L 194.839611 136.922727 \n",
       "L 194.898812 136.647844 \n",
       "L 194.958014 136.922727 \n",
       "L 195.017215 136.647844 \n",
       "L 195.076417 136.922727 \n",
       "L 195.135618 136.647844 \n",
       "L 195.19482 136.922727 \n",
       "L 195.254022 136.647844 \n",
       "L 195.313223 136.922727 \n",
       "L 195.372425 136.647844 \n",
       "L 195.431626 136.922727 \n",
       "L 195.490828 136.647844 \n",
       "L 195.550029 136.922727 \n",
       "L 195.609231 136.647844 \n",
       "L 195.668432 136.922727 \n",
       "L 195.727634 136.647844 \n",
       "L 195.786835 136.922727 \n",
       "L 195.846037 136.647844 \n",
       "L 195.905239 136.922727 \n",
       "L 195.96444 136.647844 \n",
       "L 196.023642 136.922727 \n",
       "L 196.082843 136.647844 \n",
       "L 196.142045 136.922727 \n",
       "L 196.201246 136.647844 \n",
       "L 196.260448 136.922727 \n",
       "L 196.319649 136.647844 \n",
       "L 196.378851 136.922727 \n",
       "L 196.438053 136.647844 \n",
       "L 196.497254 136.922727 \n",
       "L 196.556456 136.647844 \n",
       "L 196.615657 136.922727 \n",
       "L 196.674859 136.647844 \n",
       "L 196.73406 136.922727 \n",
       "L 196.793262 136.647844 \n",
       "L 196.852463 136.922727 \n",
       "L 196.911665 136.647844 \n",
       "L 196.970867 136.922727 \n",
       "L 197.030068 136.647844 \n",
       "L 197.08927 136.922727 \n",
       "L 197.148471 136.647844 \n",
       "L 197.207673 136.922727 \n",
       "L 197.266874 136.647844 \n",
       "L 197.326076 136.922727 \n",
       "L 197.385277 136.647844 \n",
       "L 197.444479 136.922727 \n",
       "L 197.50368 136.647844 \n",
       "L 197.562882 136.922727 \n",
       "L 197.622084 136.647844 \n",
       "L 197.681285 136.922727 \n",
       "L 197.740487 136.647844 \n",
       "L 197.799688 136.922727 \n",
       "L 197.85889 136.647844 \n",
       "L 197.918091 136.922727 \n",
       "L 197.977293 136.647844 \n",
       "L 198.036494 136.922727 \n",
       "L 198.095696 136.647844 \n",
       "L 198.154898 136.922727 \n",
       "L 198.214099 136.647844 \n",
       "L 198.273301 136.922727 \n",
       "L 198.332502 136.647844 \n",
       "L 198.391704 136.922727 \n",
       "L 198.450905 136.647844 \n",
       "L 198.510107 136.922727 \n",
       "L 198.569308 136.647844 \n",
       "L 198.62851 136.922727 \n",
       "L 198.687712 136.647844 \n",
       "L 198.746913 136.922727 \n",
       "L 198.806115 136.647844 \n",
       "L 198.865316 136.922727 \n",
       "L 198.924518 136.647844 \n",
       "L 198.983719 136.922727 \n",
       "L 199.042921 136.647844 \n",
       "L 199.102122 136.922727 \n",
       "L 199.161324 136.647844 \n",
       "L 199.220525 136.922727 \n",
       "L 199.279727 136.647844 \n",
       "L 199.338929 136.922727 \n",
       "L 199.39813 136.647844 \n",
       "L 199.457332 136.922727 \n",
       "L 199.516533 136.647844 \n",
       "L 199.575735 136.922727 \n",
       "L 199.634936 136.647844 \n",
       "L 199.694138 136.922727 \n",
       "L 199.753339 136.647844 \n",
       "L 199.812541 136.922727 \n",
       "L 199.871743 136.647844 \n",
       "L 199.930944 136.922727 \n",
       "L 199.990146 136.647844 \n",
       "L 200.049347 136.922727 \n",
       "L 200.108549 136.647844 \n",
       "L 200.16775 136.922727 \n",
       "L 200.226952 136.647844 \n",
       "L 200.286153 136.922727 \n",
       "L 200.345355 136.647844 \n",
       "L 200.404557 136.922727 \n",
       "L 200.463758 136.647844 \n",
       "L 200.52296 136.922727 \n",
       "L 200.582161 136.647844 \n",
       "L 200.641363 136.922727 \n",
       "L 200.700564 136.647844 \n",
       "L 200.759766 136.922727 \n",
       "L 200.818967 136.647844 \n",
       "L 200.878169 136.922727 \n",
       "L 200.937371 136.647844 \n",
       "L 200.996572 136.922727 \n",
       "L 201.055774 136.647844 \n",
       "L 201.114975 136.922727 \n",
       "L 201.174177 136.647844 \n",
       "L 201.233378 136.922727 \n",
       "L 201.29258 136.647844 \n",
       "L 201.351781 136.922727 \n",
       "L 201.410983 136.647844 \n",
       "L 201.470184 136.922727 \n",
       "L 201.529386 136.647844 \n",
       "L 201.588588 136.922727 \n",
       "L 201.647789 136.647844 \n",
       "L 201.706991 136.922727 \n",
       "L 201.766192 136.647844 \n",
       "L 201.825394 136.922727 \n",
       "L 201.884595 136.647844 \n",
       "L 201.943797 136.922727 \n",
       "L 202.002998 136.647844 \n",
       "L 202.0622 136.922727 \n",
       "L 202.121402 136.647844 \n",
       "L 202.180603 136.922727 \n",
       "L 202.239805 136.647844 \n",
       "L 202.299006 136.922727 \n",
       "L 202.358208 136.647844 \n",
       "L 202.417409 136.922727 \n",
       "L 202.476611 136.647844 \n",
       "L 202.535812 136.922727 \n",
       "L 202.595014 136.647844 \n",
       "L 202.654216 136.922727 \n",
       "L 202.713417 136.647844 \n",
       "L 202.772619 136.922727 \n",
       "L 202.83182 136.647844 \n",
       "L 202.891022 136.922727 \n",
       "L 202.950223 136.647844 \n",
       "L 203.009425 136.922727 \n",
       "L 203.068626 136.647844 \n",
       "L 203.127828 136.922727 \n",
       "L 203.187029 136.647844 \n",
       "L 203.246231 136.922727 \n",
       "L 203.305433 136.647844 \n",
       "L 203.364634 136.922727 \n",
       "L 203.423836 136.647844 \n",
       "L 203.483037 136.922727 \n",
       "L 203.542239 136.647844 \n",
       "L 203.60144 136.922727 \n",
       "L 203.660642 136.647844 \n",
       "L 203.719843 136.922727 \n",
       "L 203.779045 136.647844 \n",
       "L 203.838247 136.922727 \n",
       "L 203.897448 136.647844 \n",
       "L 203.95665 136.922727 \n",
       "L 204.015851 136.647844 \n",
       "L 204.075053 136.922727 \n",
       "L 204.134254 136.647844 \n",
       "L 204.193456 136.922727 \n",
       "L 204.252657 136.647844 \n",
       "L 204.311859 136.922727 \n",
       "L 204.371061 136.647844 \n",
       "L 204.430262 136.922727 \n",
       "L 204.489464 136.647844 \n",
       "L 204.548665 136.922727 \n",
       "L 204.607867 136.647844 \n",
       "L 204.667068 136.922727 \n",
       "L 204.72627 136.647844 \n",
       "L 204.785471 136.922727 \n",
       "L 204.844673 136.647844 \n",
       "L 204.903874 136.922727 \n",
       "L 204.963076 136.647844 \n",
       "L 205.022278 136.922727 \n",
       "L 205.081479 136.647844 \n",
       "L 205.140681 136.922727 \n",
       "L 205.199882 136.647844 \n",
       "L 205.259084 136.922727 \n",
       "L 205.318285 136.647844 \n",
       "L 205.377487 136.922727 \n",
       "L 205.436688 136.647844 \n",
       "L 205.49589 136.922727 \n",
       "L 205.555092 136.647844 \n",
       "L 205.614293 136.922727 \n",
       "L 205.673495 136.647844 \n",
       "L 205.732696 136.922727 \n",
       "L 205.791898 136.647844 \n",
       "L 205.851099 136.922727 \n",
       "L 205.910301 136.647844 \n",
       "L 205.969502 136.922727 \n",
       "L 206.028704 136.647844 \n",
       "L 206.087906 136.922727 \n",
       "L 206.147107 136.647844 \n",
       "L 206.206309 136.922727 \n",
       "L 206.26551 136.647844 \n",
       "L 206.324712 136.922727 \n",
       "L 206.383913 136.647844 \n",
       "L 206.443115 136.922727 \n",
       "L 206.502316 136.647844 \n",
       "L 206.561518 136.922727 \n",
       "L 206.62072 136.647844 \n",
       "L 206.679921 136.922727 \n",
       "L 206.739123 136.647844 \n",
       "L 206.798324 136.922727 \n",
       "L 206.857526 136.647844 \n",
       "L 206.916727 136.922727 \n",
       "L 206.975929 136.647844 \n",
       "L 207.03513 136.922727 \n",
       "L 207.094332 136.647844 \n",
       "L 207.153533 136.922727 \n",
       "L 207.212735 136.647844 \n",
       "L 207.271937 136.922727 \n",
       "L 207.331138 136.647844 \n",
       "L 207.39034 136.922727 \n",
       "L 207.449541 136.647844 \n",
       "L 207.508743 136.922727 \n",
       "L 207.567944 136.647844 \n",
       "L 207.627146 136.922727 \n",
       "L 207.686347 136.647844 \n",
       "L 207.745549 136.922727 \n",
       "L 207.804751 136.647844 \n",
       "L 207.863952 136.922727 \n",
       "L 207.923154 136.647844 \n",
       "L 207.982355 136.922727 \n",
       "L 208.041557 136.647844 \n",
       "L 208.100758 136.922727 \n",
       "L 208.15996 136.647844 \n",
       "L 208.219161 136.922727 \n",
       "L 208.278363 136.647844 \n",
       "L 208.337565 136.922727 \n",
       "L 208.396766 136.647844 \n",
       "L 208.455968 136.922727 \n",
       "L 208.515169 136.647844 \n",
       "L 208.574371 136.922727 \n",
       "L 208.633572 136.647844 \n",
       "L 208.692774 136.922727 \n",
       "L 208.751975 136.647844 \n",
       "L 208.811177 136.922727 \n",
       "L 208.870378 136.647844 \n",
       "L 208.92958 136.922727 \n",
       "L 208.988782 136.647844 \n",
       "L 209.047983 136.922727 \n",
       "L 209.107185 136.647844 \n",
       "L 209.166386 136.922727 \n",
       "L 209.225588 136.647844 \n",
       "L 209.284789 136.922727 \n",
       "L 209.343991 136.647844 \n",
       "L 209.403192 136.922727 \n",
       "L 209.462394 136.647844 \n",
       "L 209.521596 136.922727 \n",
       "L 209.580797 136.647844 \n",
       "L 209.639999 136.922727 \n",
       "L 209.6992 136.647844 \n",
       "L 209.758402 136.922727 \n",
       "L 209.817603 136.647844 \n",
       "L 209.876805 136.922727 \n",
       "L 209.936006 136.647844 \n",
       "L 209.995208 136.922727 \n",
       "L 210.05441 136.647844 \n",
       "L 210.113611 136.922727 \n",
       "L 210.172813 136.647844 \n",
       "L 210.232014 136.922727 \n",
       "L 210.291216 136.647844 \n",
       "L 210.350417 136.922727 \n",
       "L 210.409619 136.647844 \n",
       "L 210.46882 136.922727 \n",
       "L 210.528022 136.647844 \n",
       "L 210.587223 136.922727 \n",
       "L 210.646425 136.647844 \n",
       "L 210.705627 136.922727 \n",
       "L 210.764828 136.647844 \n",
       "L 210.82403 136.922727 \n",
       "L 210.883231 136.647844 \n",
       "L 210.942433 136.922727 \n",
       "L 211.001634 136.647844 \n",
       "L 211.060836 136.922727 \n",
       "L 211.120037 136.647844 \n",
       "L 211.179239 136.922727 \n",
       "L 211.238441 136.647844 \n",
       "L 211.297642 136.922727 \n",
       "L 211.356844 136.647844 \n",
       "L 211.416045 136.922727 \n",
       "L 211.475247 136.647844 \n",
       "L 211.534448 136.922727 \n",
       "L 211.59365 136.647844 \n",
       "L 211.652851 136.922727 \n",
       "L 211.712053 136.647844 \n",
       "L 211.771255 136.922727 \n",
       "L 211.830456 136.647844 \n",
       "L 211.889658 136.922727 \n",
       "L 211.948859 136.647844 \n",
       "L 212.008061 136.922727 \n",
       "L 212.067262 136.647844 \n",
       "L 212.126464 136.922727 \n",
       "L 212.185665 136.647844 \n",
       "L 212.244867 136.922727 \n",
       "L 212.304068 136.647844 \n",
       "L 212.36327 136.922727 \n",
       "L 212.422472 136.647844 \n",
       "L 212.481673 136.922727 \n",
       "L 212.540875 136.647844 \n",
       "L 212.600076 136.922727 \n",
       "L 212.659278 136.647844 \n",
       "L 212.718479 136.922727 \n",
       "L 212.777681 136.647844 \n",
       "L 212.836882 136.922727 \n",
       "L 212.896084 136.647844 \n",
       "L 212.955286 136.922727 \n",
       "L 213.014487 136.647844 \n",
       "L 213.073689 136.922727 \n",
       "L 213.13289 136.647844 \n",
       "L 213.192092 136.922727 \n",
       "L 213.251293 136.647844 \n",
       "L 213.310495 136.922727 \n",
       "L 213.369696 136.647844 \n",
       "L 213.428898 136.922727 \n",
       "L 213.4881 136.647844 \n",
       "L 213.547301 136.922727 \n",
       "L 213.606503 136.647844 \n",
       "L 213.665704 136.922727 \n",
       "L 213.724906 136.647844 \n",
       "L 213.784107 136.922727 \n",
       "L 213.843309 136.647844 \n",
       "L 213.90251 136.922727 \n",
       "L 213.961712 136.647844 \n",
       "L 214.020914 136.922727 \n",
       "L 214.080115 136.647844 \n",
       "L 214.139317 136.922727 \n",
       "L 214.198518 136.647844 \n",
       "L 214.25772 136.922727 \n",
       "L 214.316921 136.647844 \n",
       "L 214.376123 136.922727 \n",
       "L 214.435324 136.647844 \n",
       "L 214.494526 136.922727 \n",
       "L 214.553727 136.647844 \n",
       "L 214.612929 136.922727 \n",
       "L 214.672131 136.647844 \n",
       "L 214.731332 136.922727 \n",
       "L 214.790534 136.647844 \n",
       "L 214.849735 136.922727 \n",
       "L 214.908937 136.647844 \n",
       "L 214.968138 136.922727 \n",
       "L 215.02734 136.647844 \n",
       "L 215.086541 136.922727 \n",
       "L 215.145743 136.647844 \n",
       "L 215.204945 136.922727 \n",
       "L 215.264146 136.647844 \n",
       "L 215.323348 136.922727 \n",
       "L 215.382549 136.647844 \n",
       "L 215.441751 136.922727 \n",
       "L 215.500952 136.647844 \n",
       "L 215.560154 136.922727 \n",
       "L 215.619355 136.647844 \n",
       "L 215.678557 136.922727 \n",
       "L 215.737759 136.647844 \n",
       "L 215.79696 136.922727 \n",
       "L 215.856162 136.647844 \n",
       "L 215.915363 136.922727 \n",
       "L 215.974565 136.647844 \n",
       "L 216.033766 136.922727 \n",
       "L 216.092968 136.647844 \n",
       "L 216.152169 136.922727 \n",
       "L 216.211371 136.647844 \n",
       "L 216.270572 136.922727 \n",
       "L 216.329774 136.647844 \n",
       "L 216.388976 136.922727 \n",
       "L 216.448177 136.647844 \n",
       "L 216.507379 136.922727 \n",
       "L 216.56658 136.647844 \n",
       "L 216.625782 136.922727 \n",
       "L 216.684983 136.647844 \n",
       "L 216.744185 136.922727 \n",
       "L 216.803386 136.647844 \n",
       "L 216.862588 136.922727 \n",
       "L 216.92179 136.647844 \n",
       "L 216.980991 136.922727 \n",
       "L 217.040193 136.647844 \n",
       "L 217.099394 136.922727 \n",
       "L 217.158596 136.647844 \n",
       "L 217.217797 136.922727 \n",
       "L 217.276999 136.647844 \n",
       "L 217.3362 136.922727 \n",
       "L 217.395402 136.647844 \n",
       "L 217.454604 136.922727 \n",
       "L 217.513805 136.647844 \n",
       "L 217.573007 136.922727 \n",
       "L 217.632208 136.647844 \n",
       "L 217.69141 136.922727 \n",
       "L 217.750611 136.647844 \n",
       "L 217.809813 136.922727 \n",
       "L 217.869014 136.647844 \n",
       "L 217.928216 136.922727 \n",
       "L 217.987417 136.647844 \n",
       "L 218.046619 136.922727 \n",
       "L 218.105821 136.647844 \n",
       "L 218.165022 136.922727 \n",
       "L 218.224224 136.647844 \n",
       "L 218.283425 136.922727 \n",
       "L 218.342627 136.647844 \n",
       "L 218.401828 136.922727 \n",
       "L 218.46103 136.647844 \n",
       "L 218.520231 136.922727 \n",
       "L 218.579433 136.647844 \n",
       "L 218.638635 136.922727 \n",
       "L 218.697836 136.647844 \n",
       "L 218.757038 136.922727 \n",
       "L 218.816239 136.647844 \n",
       "L 218.875441 136.922727 \n",
       "L 218.934642 136.647844 \n",
       "L 218.993844 136.922727 \n",
       "L 219.053045 136.647844 \n",
       "L 219.112247 136.922727 \n",
       "L 219.171449 136.647844 \n",
       "L 219.23065 136.922727 \n",
       "L 219.289852 136.647844 \n",
       "L 219.349053 136.922727 \n",
       "L 219.408255 136.647844 \n",
       "L 219.467456 136.922727 \n",
       "L 219.526658 136.647844 \n",
       "L 219.585859 136.922727 \n",
       "L 219.645061 136.647844 \n",
       "L 219.704263 136.922727 \n",
       "L 219.763464 136.647844 \n",
       "L 219.822666 136.922727 \n",
       "L 219.881867 136.647844 \n",
       "L 219.941069 136.922727 \n",
       "L 220.00027 136.647844 \n",
       "L 220.059472 136.922727 \n",
       "L 220.118673 136.647844 \n",
       "L 220.177875 136.922727 \n",
       "L 220.237076 136.647844 \n",
       "L 220.296278 136.922727 \n",
       "L 220.35548 136.647844 \n",
       "L 220.414681 136.922727 \n",
       "L 220.473883 136.647844 \n",
       "L 220.533084 136.922727 \n",
       "L 220.592286 136.647844 \n",
       "L 220.651487 136.922727 \n",
       "L 220.710689 136.647844 \n",
       "L 220.76989 136.922727 \n",
       "L 220.829092 136.647844 \n",
       "L 220.888294 136.922727 \n",
       "L 220.947495 136.647844 \n",
       "L 221.006697 136.922727 \n",
       "L 221.065898 136.647844 \n",
       "L 221.1251 136.922727 \n",
       "L 221.184301 136.647844 \n",
       "L 221.243503 136.922727 \n",
       "L 221.302704 136.647844 \n",
       "L 221.361906 136.922727 \n",
       "L 221.421108 136.647844 \n",
       "L 221.480309 136.922727 \n",
       "L 221.539511 136.647844 \n",
       "L 221.598712 136.922727 \n",
       "L 221.657914 136.647844 \n",
       "L 221.717115 136.922727 \n",
       "L 221.776317 136.647844 \n",
       "L 221.835518 136.922727 \n",
       "L 221.89472 136.647844 \n",
       "L 221.953921 136.922727 \n",
       "L 222.013123 136.647844 \n",
       "L 222.072325 136.922727 \n",
       "L 222.131526 136.647844 \n",
       "L 222.190728 136.922727 \n",
       "L 222.249929 136.647844 \n",
       "L 222.309131 136.922727 \n",
       "L 222.368332 136.647844 \n",
       "L 222.427534 136.922727 \n",
       "L 222.486735 136.647844 \n",
       "L 222.545937 136.922727 \n",
       "L 222.605139 136.647844 \n",
       "L 222.66434 136.922727 \n",
       "L 222.723542 136.647844 \n",
       "L 222.782743 136.922727 \n",
       "L 222.841945 136.647844 \n",
       "L 222.901146 136.922727 \n",
       "L 222.960348 136.647844 \n",
       "L 223.019549 136.922727 \n",
       "L 223.078751 136.647844 \n",
       "L 223.137953 136.922727 \n",
       "L 223.197154 136.647844 \n",
       "L 223.256356 136.922727 \n",
       "L 223.315557 136.647844 \n",
       "L 223.374759 136.922727 \n",
       "L 223.43396 136.647844 \n",
       "L 223.493162 136.922727 \n",
       "L 223.552363 136.647844 \n",
       "L 223.611565 136.922727 \n",
       "L 223.670766 136.647844 \n",
       "L 223.729968 136.922727 \n",
       "L 223.78917 136.647844 \n",
       "L 223.848371 136.922727 \n",
       "L 223.907573 136.647844 \n",
       "L 223.966774 136.922727 \n",
       "L 224.025976 136.647844 \n",
       "L 224.085177 136.922727 \n",
       "L 224.144379 136.647844 \n",
       "L 224.20358 136.922727 \n",
       "L 224.262782 136.647844 \n",
       "L 224.321984 136.922727 \n",
       "L 224.381185 136.647844 \n",
       "L 224.440387 136.922727 \n",
       "L 224.499588 136.647844 \n",
       "L 224.55879 136.922727 \n",
       "L 224.617991 136.647844 \n",
       "L 224.677193 136.922727 \n",
       "L 224.736394 136.647844 \n",
       "L 224.795596 136.922727 \n",
       "L 224.854798 136.647844 \n",
       "L 224.913999 136.922727 \n",
       "L 224.973201 136.647844 \n",
       "L 225.032402 136.922727 \n",
       "L 225.091604 136.647844 \n",
       "L 225.150805 136.922727 \n",
       "L 225.210007 136.647844 \n",
       "L 225.269208 136.922727 \n",
       "L 225.32841 136.647844 \n",
       "L 225.387611 136.922727 \n",
       "L 225.446813 136.647844 \n",
       "L 225.506015 136.922727 \n",
       "L 225.565216 136.647844 \n",
       "L 225.624418 136.922727 \n",
       "L 225.683619 136.647844 \n",
       "L 225.742821 136.922727 \n",
       "L 225.802022 136.647844 \n",
       "L 225.861224 136.922727 \n",
       "L 225.920425 136.647844 \n",
       "L 225.979627 136.922727 \n",
       "L 226.038829 136.647844 \n",
       "L 226.09803 136.922727 \n",
       "L 226.157232 136.647844 \n",
       "L 226.216433 136.922727 \n",
       "L 226.275635 136.647844 \n",
       "L 226.334836 136.922727 \n",
       "L 226.394038 136.647844 \n",
       "L 226.453239 136.922727 \n",
       "L 226.512441 136.647844 \n",
       "L 226.571643 136.922727 \n",
       "L 226.630844 136.647844 \n",
       "L 226.690046 136.922727 \n",
       "L 226.749247 136.647844 \n",
       "L 226.808449 136.922727 \n",
       "L 226.86765 136.647844 \n",
       "L 226.926852 136.922727 \n",
       "L 226.986053 136.647844 \n",
       "L 227.045255 136.922727 \n",
       "L 227.104457 136.647844 \n",
       "L 227.163658 136.922727 \n",
       "L 227.22286 136.647844 \n",
       "L 227.282061 136.922727 \n",
       "L 227.341263 136.647844 \n",
       "L 227.400464 136.922727 \n",
       "L 227.459666 136.647844 \n",
       "L 227.518867 136.922727 \n",
       "L 227.578069 136.647844 \n",
       "L 227.63727 136.922727 \n",
       "L 227.696472 136.647844 \n",
       "L 227.755674 136.922727 \n",
       "L 227.814875 136.647844 \n",
       "L 227.874077 136.922727 \n",
       "L 227.933278 136.647844 \n",
       "L 227.99248 136.922727 \n",
       "L 228.051681 136.647844 \n",
       "L 228.110883 136.922727 \n",
       "L 228.170084 136.647844 \n",
       "L 228.229286 136.922727 \n",
       "L 228.288488 136.647844 \n",
       "L 228.347689 136.922727 \n",
       "L 228.406891 136.647844 \n",
       "L 228.466092 136.922727 \n",
       "L 228.525294 136.647844 \n",
       "L 228.584495 136.922727 \n",
       "L 228.643697 136.647844 \n",
       "L 228.702898 136.922727 \n",
       "L 228.7621 136.647844 \n",
       "L 228.821302 136.922727 \n",
       "L 228.880503 136.647844 \n",
       "L 228.939705 136.922727 \n",
       "L 228.998906 136.647844 \n",
       "L 229.058108 136.922727 \n",
       "L 229.117309 136.647844 \n",
       "L 229.176511 136.922727 \n",
       "L 229.235712 136.647844 \n",
       "L 229.294914 136.922727 \n",
       "L 229.354115 136.647844 \n",
       "L 229.413317 136.922727 \n",
       "L 229.472519 136.647844 \n",
       "L 229.53172 136.922727 \n",
       "L 229.590922 136.647844 \n",
       "L 229.650123 136.922727 \n",
       "L 229.709325 136.647844 \n",
       "L 229.768526 136.922727 \n",
       "L 229.827728 136.647844 \n",
       "L 229.886929 136.922727 \n",
       "L 229.946131 136.647844 \n",
       "L 230.005333 136.922727 \n",
       "L 230.064534 136.647844 \n",
       "L 230.123736 136.922727 \n",
       "L 230.182937 136.647844 \n",
       "L 230.242139 136.922727 \n",
       "L 230.30134 136.647844 \n",
       "L 230.360542 136.922727 \n",
       "L 230.419743 136.647844 \n",
       "L 230.478945 136.922727 \n",
       "L 230.538147 136.647844 \n",
       "L 230.597348 136.922727 \n",
       "L 230.65655 136.647844 \n",
       "L 230.715751 136.922727 \n",
       "L 230.774953 136.647844 \n",
       "L 230.834154 136.922727 \n",
       "L 230.893356 136.647844 \n",
       "L 230.952557 136.922727 \n",
       "L 231.011759 136.647844 \n",
       "L 231.07096 136.922727 \n",
       "L 231.130162 136.647844 \n",
       "L 231.189364 136.922727 \n",
       "L 231.248565 136.647844 \n",
       "L 231.307767 136.922727 \n",
       "L 231.366968 136.647844 \n",
       "L 231.42617 136.922727 \n",
       "L 231.485371 136.647844 \n",
       "L 231.544573 136.922727 \n",
       "L 231.603774 136.647844 \n",
       "L 231.662976 136.922727 \n",
       "L 231.722178 136.647844 \n",
       "L 231.781379 136.922727 \n",
       "L 231.840581 136.647844 \n",
       "L 231.899782 136.922727 \n",
       "L 231.958984 136.647844 \n",
       "L 232.018185 136.922727 \n",
       "L 232.077387 136.647844 \n",
       "L 232.136588 136.922727 \n",
       "L 232.19579 136.647844 \n",
       "L 232.254992 136.922727 \n",
       "L 232.314193 136.647844 \n",
       "L 232.373395 136.922727 \n",
       "L 232.432596 136.647844 \n",
       "L 232.491798 136.922727 \n",
       "L 232.550999 136.647844 \n",
       "L 232.610201 136.922727 \n",
       "L 232.669402 136.647844 \n",
       "L 232.728604 136.922727 \n",
       "L 232.787805 136.647844 \n",
       "L 232.847007 136.922727 \n",
       "L 232.906209 136.647844 \n",
       "L 232.96541 136.922727 \n",
       "L 233.024612 136.647844 \n",
       "L 233.083813 136.922727 \n",
       "L 233.143015 136.647844 \n",
       "L 233.202216 136.922727 \n",
       "L 233.261418 136.647844 \n",
       "L 233.320619 136.922727 \n",
       "L 233.379821 136.647844 \n",
       "L 233.439023 136.922727 \n",
       "L 233.498224 136.647844 \n",
       "L 233.557426 136.922727 \n",
       "L 233.616627 136.647844 \n",
       "L 233.675829 136.922727 \n",
       "L 233.73503 136.647844 \n",
       "L 233.794232 136.922727 \n",
       "L 233.853433 136.647844 \n",
       "L 233.912635 136.922727 \n",
       "L 233.971837 136.647844 \n",
       "L 234.031038 136.922727 \n",
       "L 234.09024 136.647844 \n",
       "L 234.149441 136.922727 \n",
       "L 234.208643 136.647844 \n",
       "L 234.267844 136.922727 \n",
       "L 234.327046 136.647844 \n",
       "L 234.386247 136.922727 \n",
       "L 234.445449 136.647844 \n",
       "L 234.504651 136.922727 \n",
       "L 234.563852 136.647844 \n",
       "L 234.623054 136.922727 \n",
       "L 234.682255 136.647844 \n",
       "L 234.741457 136.922727 \n",
       "L 234.800658 136.647844 \n",
       "L 234.85986 136.922727 \n",
       "L 234.919061 136.647844 \n",
       "L 234.978263 136.922727 \n",
       "L 235.037464 136.647844 \n",
       "L 235.096666 136.922727 \n",
       "L 235.155868 136.647844 \n",
       "L 235.215069 136.922727 \n",
       "L 235.274271 136.647844 \n",
       "L 235.333472 136.922727 \n",
       "L 235.392674 136.647844 \n",
       "L 235.451875 136.922727 \n",
       "L 235.511077 136.647844 \n",
       "L 235.570278 136.922727 \n",
       "L 235.62948 136.647844 \n",
       "L 235.688682 136.922727 \n",
       "L 235.747883 136.647844 \n",
       "L 235.807085 136.922727 \n",
       "L 235.866286 136.647844 \n",
       "L 235.925488 136.922727 \n",
       "L 235.984689 136.647844 \n",
       "L 236.043891 136.922727 \n",
       "L 236.103092 136.647844 \n",
       "L 236.162294 136.922727 \n",
       "L 236.221496 136.647844 \n",
       "L 236.280697 136.922727 \n",
       "L 236.339899 136.647844 \n",
       "L 236.3991 136.922727 \n",
       "L 236.458302 136.647844 \n",
       "L 236.517503 136.922727 \n",
       "L 236.576705 136.647844 \n",
       "L 236.635906 136.922727 \n",
       "L 236.695108 136.647844 \n",
       "L 236.754309 136.922727 \n",
       "L 236.813511 136.647844 \n",
       "L 236.872713 136.922727 \n",
       "L 236.931914 136.647844 \n",
       "L 236.991116 136.922727 \n",
       "L 237.050317 136.647844 \n",
       "L 237.109519 136.922727 \n",
       "L 237.16872 136.647844 \n",
       "L 237.227922 136.922727 \n",
       "L 237.287123 136.647844 \n",
       "L 237.346325 136.922727 \n",
       "L 237.405527 136.647844 \n",
       "L 237.464728 136.922727 \n",
       "L 237.52393 136.647844 \n",
       "L 237.583131 136.922727 \n",
       "L 237.642333 136.647844 \n",
       "L 237.701534 136.922727 \n",
       "L 237.760736 136.647844 \n",
       "L 237.819937 136.922727 \n",
       "L 237.879139 136.647844 \n",
       "L 237.938341 136.922727 \n",
       "L 237.997542 136.647844 \n",
       "L 238.056744 136.922727 \n",
       "L 238.115945 136.647844 \n",
       "L 238.175147 136.922727 \n",
       "L 238.234348 136.647844 \n",
       "L 238.29355 136.922727 \n",
       "L 238.352751 136.647844 \n",
       "L 238.411953 136.922727 \n",
       "L 238.471154 136.647844 \n",
       "L 238.530356 136.922727 \n",
       "L 238.589558 136.647844 \n",
       "L 238.648759 136.922727 \n",
       "L 238.707961 136.647844 \n",
       "L 238.767162 136.922727 \n",
       "L 238.826364 136.647844 \n",
       "L 238.885565 136.922727 \n",
       "L 238.944767 136.647844 \n",
       "L 239.003968 136.922727 \n",
       "L 239.06317 136.647844 \n",
       "L 239.122372 136.922727 \n",
       "L 239.181573 136.647844 \n",
       "L 239.240775 136.922727 \n",
       "L 239.299976 136.647844 \n",
       "L 239.359178 136.922727 \n",
       "L 239.418379 136.647844 \n",
       "L 239.477581 136.922727 \n",
       "L 239.536782 136.647844 \n",
       "L 239.595984 136.922727 \n",
       "L 239.655186 136.647844 \n",
       "L 239.714387 136.922727 \n",
       "L 239.773589 136.647844 \n",
       "L 239.83279 136.922727 \n",
       "L 239.891992 136.647844 \n",
       "L 239.951193 136.922727 \n",
       "L 240.010395 136.647844 \n",
       "L 240.069596 136.922727 \n",
       "L 240.128798 136.647844 \n",
       "L 240.188 136.922727 \n",
       "L 240.247201 136.647844 \n",
       "L 240.306403 136.922727 \n",
       "L 240.365604 136.647844 \n",
       "L 240.424806 136.922727 \n",
       "L 240.484007 136.647844 \n",
       "L 240.543209 136.922727 \n",
       "L 240.60241 136.647844 \n",
       "L 240.661612 136.922727 \n",
       "L 240.720813 136.647844 \n",
       "L 240.780015 136.922727 \n",
       "L 240.839217 136.647844 \n",
       "L 240.898418 136.922727 \n",
       "L 240.95762 136.647844 \n",
       "L 241.016821 136.922727 \n",
       "L 241.076023 136.647844 \n",
       "L 241.135224 136.922727 \n",
       "L 241.194426 136.647844 \n",
       "L 241.253627 136.922727 \n",
       "L 241.312829 136.647844 \n",
       "L 241.372031 136.922727 \n",
       "L 241.431232 136.647844 \n",
       "L 241.490434 136.922727 \n",
       "L 241.549635 136.647844 \n",
       "L 241.608837 136.922727 \n",
       "L 241.668038 136.647844 \n",
       "L 241.72724 136.922727 \n",
       "L 241.786441 136.647844 \n",
       "L 241.845643 136.922727 \n",
       "L 241.904845 136.647844 \n",
       "L 241.964046 136.922727 \n",
       "L 242.023248 136.647844 \n",
       "L 242.082449 136.922727 \n",
       "L 242.141651 136.647844 \n",
       "L 242.200852 136.922727 \n",
       "L 242.200852 136.922727 \n",
       "\" clip-path=\"url(#pd2e42147dc)\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 55.778125 143.1 \n",
       "L 55.778125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 251.078125 143.1 \n",
       "L 251.078125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 55.778125 143.1 \n",
       "L 251.078125 143.1 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 55.778125 7.2 \n",
       "L 251.078125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"legend_1\">\n",
       "    <g id=\"patch_7\">\n",
       "     <path d=\"M 187.892188 29.878125 \n",
       "L 244.078125 29.878125 \n",
       "Q 246.078125 29.878125 246.078125 27.878125 \n",
       "L 246.078125 14.2 \n",
       "Q 246.078125 12.2 244.078125 12.2 \n",
       "L 187.892188 12.2 \n",
       "Q 185.892188 12.2 185.892188 14.2 \n",
       "L 185.892188 27.878125 \n",
       "Q 185.892188 29.878125 187.892188 29.878125 \n",
       "z\n",
       "\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n",
       "    </g>\n",
       "    <g id=\"line2d_11\">\n",
       "     <path d=\"M 189.892188 20.298437 \n",
       "L 199.892188 20.298437 \n",
       "L 209.892188 20.298437 \n",
       "\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "    </g>\n",
       "    <g id=\"text_12\">\n",
       "     <!-- label -->\n",
       "     <g transform=\"translate(217.892188 23.798437) scale(0.1 -0.1)\">\n",
       "      <use xlink:href=\"#DejaVuSans-6c\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"27.783203\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"89.0625\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"152.539062\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"214.0625\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"pd2e42147dc\">\n",
       "   <rect x=\"55.778125\" y=\"7.2\" width=\"195.3\" height=\"135.9\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_ls, linewidth=2, color='b', label='label')\n",
    "plt.xlabel('xlabel')\n",
    "plt.ylabel('ylabel')\n",
    "plt.legend()\n",
    "plt.yscale('log')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([10.83095,\n",
       "  10.83095,\n",
       "  10.83095,\n",
       "  10.83095,\n",
       "  10.830951,\n",
       "  10.83095,\n",
       "  10.830951,\n",
       "  10.83095,\n",
       "  10.830951,\n",
       "  10.830951],\n",
       " [array([5.6455812 , 5.1659336 , 0.01943537], dtype=float32),\n",
       "  array([6.5447245, 3.956146 , 0.3300794], dtype=float32),\n",
       "  array([5.94069   , 4.653659  , 0.23660086], dtype=float32),\n",
       "  array([10.042866 ,  0.6481522,  0.139932 ], dtype=float32),\n",
       "  array([6.7195668e+00, 4.1105928e+00, 7.9026277e-04], dtype=float32),\n",
       "  array([5.6683345 , 4.818117  , 0.34449804], dtype=float32),\n",
       "  array([5.523049  , 5.276799  , 0.03110229], dtype=float32),\n",
       "  array([5.6854506 , 5.073045  , 0.07245461], dtype=float32),\n",
       "  array([7.780718  , 2.6860924 , 0.36414033], dtype=float32),\n",
       "  array([7.3429003 , 3.4179845 , 0.07006525], dtype=float32)])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nuclear_norm_trial2, eigenvalues_trial2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0, 0],\n",
       "         [0, 1],\n",
       "         [1, 0],\n",
       "         [1, 1],\n",
       "         [2, 0],\n",
       "         [2, 2]]),\n",
       " tensor([[1.],\n",
       "         [2.],\n",
       "         [3.],\n",
       "         [4.],\n",
       "         [6.],\n",
       "         [5.]]))"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ls_example1 = [0, 1, 3, 8]\n",
    "ls_example2 = [0, 1, 3, 4, 8]\n",
    "ls_example3 = [0, 1, 3, 4, 6, 8]\n",
    "\n",
    "features_train, labels_train = fix_sample(M, ls_example3)\n",
    "# features_train, labels_train = random_sample(M)\n",
    "train_dataset = torch.utils.data.TensorDataset(features_train, labels_train)\n",
    "features_train, labels_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"244.8pt\" height=\"172.8pt\" viewBox=\"0 0 244.8 172.8\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:47.935155</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 172.8 \n",
       "L 244.8 172.8 \n",
       "L 244.8 0 \n",
       "L 0 0 \n",
       "L 0 172.8 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"LineCollection_1\">\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 136.453476 \n",
       "L 217.606612 94.100535 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 78.699465 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 78.699465 \n",
       "L 217.606612 94.100535 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 20.945455 \n",
       "L 217.606612 151.854545 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "    <path d=\"M 27.193388 20.945455 \n",
       "L 217.606612 36.346524 \n",
       "\" clip-path=\"url(#pe273391c30)\" style=\"fill: none; stroke: #000000; stroke-opacity: 0.5; stroke-width: 2\"/>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_1\">\n",
       "    <defs>\n",
       "     <path id=\"m882b7e861c\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <use xlink:href=\"#m882b7e861c\" x=\"27.193388\" y=\"136.453476\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m882b7e861c\" x=\"27.193388\" y=\"78.699465\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m882b7e861c\" x=\"27.193388\" y=\"20.945455\" style=\"fill: #ff0000; fill-opacity: 0.5; stroke: #ff0000; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"PathCollection_2\">\n",
       "    <defs>\n",
       "     <path id=\"m0bd2f0ad18\" d=\"M 0 11.18034 \n",
       "C 2.965061 11.18034 5.80908 10.002309 7.905694 7.905694 \n",
       "C 10.002309 5.80908 11.18034 2.965061 11.18034 0 \n",
       "C 11.18034 -2.965061 10.002309 -5.80908 7.905694 -7.905694 \n",
       "C 5.80908 -10.002309 2.965061 -11.18034 0 -11.18034 \n",
       "C -2.965061 -11.18034 -5.80908 -10.002309 -7.905694 -7.905694 \n",
       "C -10.002309 -5.80908 -11.18034 -2.965061 -11.18034 0 \n",
       "C -11.18034 2.965061 -10.002309 5.80908 -7.905694 7.905694 \n",
       "C -5.80908 10.002309 -2.965061 11.18034 0 11.18034 \n",
       "z\n",
       "\" style=\"stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <use xlink:href=\"#m0bd2f0ad18\" x=\"217.606612\" y=\"151.854545\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m0bd2f0ad18\" x=\"217.606612\" y=\"94.100535\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "     <use xlink:href=\"#m0bd2f0ad18\" x=\"217.606612\" y=\"36.346524\" style=\"fill: #00bfbf; fill-opacity: 0.5; stroke: #00bfbf; stroke-opacity: 0.5\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_1\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 1 -->\n",
       "     <g transform=\"translate(23.375888 139.764726) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_2\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 2 -->\n",
       "     <g transform=\"translate(23.375888 82.010715) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_3\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 3 -->\n",
       "     <g transform=\"translate(23.375888 24.256705) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-33\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_4\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 4 -->\n",
       "     <g transform=\"translate(213.789112 155.165795) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-34\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_5\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 5 -->\n",
       "     <g transform=\"translate(213.789112 97.411785) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_6\">\n",
       "    <g clip-path=\"url(#pe273391c30)\">\n",
       "     <!-- 6 -->\n",
       "     <g transform=\"translate(213.789112 39.657774) scale(0.12 -0.12)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-36\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"pe273391c30\">\n",
       "   <rect x=\"7.2\" y=\"7.2\" width=\"230.4\" height=\"158.4\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "G, P = generated_graph(features_train, M, d)\n",
    "plot_bipartite_graph(G, P)\n",
    "\n",
    "plt.savefig('example3_connected.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "12.322608447914273"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import networkx as nx\n",
    "import cvxpy as cp\n",
    "import time\n",
    "observation_matrix3 = create_observation_matrix(features_train, labels_train, d=d)\n",
    "min_nuclear_norm3 = compute_nuclear_norm(min_nuclear_norm(observation_matrix3))\n",
    "min_nuclear_norm3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2389.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "23130.2 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2865.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "27673.5 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2433.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "23368.6 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2733.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "26439.8 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2797.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "26822.0 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2916.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "28200.3 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2886.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "27875.9 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2712.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "26192.2 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2717.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "26256.7 examples/sec on cpu\n",
      "training on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 2856.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train loss 0.000\n",
      "27591.2 examples/sec on cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "nuclear_norm_trial3 = []\n",
    "eigenvalues_trial3 = []\n",
    "# num_epochs = 1500\n",
    "batch_size, num_epochs, lr = 1024, 2000, 1e-1\n",
    "train_iter = torch.utils.data.DataLoader(train_dataset, batch_size, shuffle=True)\n",
    "for i in range(10):\n",
    "    net = NeuralNetwork()\n",
    "    net.apply(lambda m: init_weights(m, sigma=1e-35))\n",
    "    train_ls, test_ls = train(net, train_iter, num_epochs, lr, try_gpu(), test_iter=None, stop=1e-15)\n",
    "    if train_ls[-1] <= 1e-7:\n",
    "        A = np.copy(list(net.parameters())[0].detach().T)\n",
    "        B = np.copy(list(net.parameters())[1].detach().T)\n",
    "        nuclear_norm_trial3.append(compute_nuclear_norm(A @ B))\n",
    "        eigenvalues_trial3.append(np.linalg.svd(A @ B, compute_uv=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"257.814669pt\" height=\"180.65625pt\" viewBox=\"0 0 257.814669 180.65625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:55.732817</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 180.65625 \n",
       "L 257.814669 180.65625 \n",
       "L 257.814669 0 \n",
       "L 0 0 \n",
       "L 0 180.65625 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "L 51.378125 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_1\">\n",
       "    <g id=\"xtick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"m70d9d31124\" d=\"M 0 0 \n",
       "L 0 3.5 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m70d9d31124\" x=\"60.255398\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- 0 -->\n",
       "      <g transform=\"translate(57.074148 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m70d9d31124\" x=\"104.663966\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- 500 -->\n",
       "      <g transform=\"translate(95.120216 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m70d9d31124\" x=\"149.072534\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- 1000 -->\n",
       "      <g transform=\"translate(136.347534 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_4\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m70d9d31124\" x=\"193.481101\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- 1500 -->\n",
       "      <g transform=\"translate(180.756101 157.698438) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_5\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m70d9d31124\" x=\"237.889669\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_5\">\n",
       "      <!-- 2000 -->\n",
       "      <g transform=\"translate(225.164669 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"190.869141\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_6\">\n",
       "     <!-- xlabel -->\n",
       "     <g transform=\"translate(133.975781 171.376563) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-78\" d=\"M 3513 3500 \n",
       "L 2247 1797 \n",
       "L 3578 0 \n",
       "L 2900 0 \n",
       "L 1881 1375 \n",
       "L 863 0 \n",
       "L 184 0 \n",
       "L 1544 1831 \n",
       "L 300 3500 \n",
       "L 978 3500 \n",
       "L 1906 2253 \n",
       "L 2834 3500 \n",
       "L 3513 3500 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \n",
       "Q 3116 2381 2855 2742 \n",
       "Q 2594 3103 2138 3103 \n",
       "Q 1681 3103 1420 2742 \n",
       "Q 1159 2381 1159 1747 \n",
       "Q 1159 1113 1420 752 \n",
       "Q 1681 391 2138 391 \n",
       "Q 2594 391 2855 752 \n",
       "Q 3116 1113 3116 1747 \n",
       "z\n",
       "M 1159 2969 \n",
       "Q 1341 3281 1617 3432 \n",
       "Q 1894 3584 2278 3584 \n",
       "Q 2916 3584 3314 3078 \n",
       "Q 3713 2572 3713 1747 \n",
       "Q 3713 922 3314 415 \n",
       "Q 2916 -91 2278 -91 \n",
       "Q 1894 -91 1617 61 \n",
       "Q 1341 213 1159 525 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 4863 \n",
       "L 1159 4863 \n",
       "L 1159 2969 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <defs>\n",
       "       <path id=\"m1677785e09\" d=\"M 0 0 \n",
       "L -3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m1677785e09\" x=\"51.378125\" y=\"121.793116\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_7\">\n",
       "      <!-- $\\mathdefault{10^{-9}}$ -->\n",
       "      <g transform=\"translate(20.878125 125.592335) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-2212\" d=\"M 678 2272 \n",
       "L 4684 2272 \n",
       "L 4684 1741 \n",
       "L 678 1741 \n",
       "L 678 2272 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-39\" d=\"M 703 97 \n",
       "L 703 672 \n",
       "Q 941 559 1184 500 \n",
       "Q 1428 441 1663 441 \n",
       "Q 2288 441 2617 861 \n",
       "Q 2947 1281 2994 2138 \n",
       "Q 2813 1869 2534 1725 \n",
       "Q 2256 1581 1919 1581 \n",
       "Q 1219 1581 811 2004 \n",
       "Q 403 2428 403 3163 \n",
       "Q 403 3881 828 4315 \n",
       "Q 1253 4750 1959 4750 \n",
       "Q 2769 4750 3195 4129 \n",
       "Q 3622 3509 3622 2328 \n",
       "Q 3622 1225 3098 567 \n",
       "Q 2575 -91 1691 -91 \n",
       "Q 1453 -91 1209 -44 \n",
       "Q 966 3 703 97 \n",
       "z\n",
       "M 1959 2075 \n",
       "Q 2384 2075 2632 2365 \n",
       "Q 2881 2656 2881 3163 \n",
       "Q 2881 3666 2632 3958 \n",
       "Q 2384 4250 1959 4250 \n",
       "Q 1534 4250 1286 3958 \n",
       "Q 1038 3666 1038 3163 \n",
       "Q 1038 2656 1286 2365 \n",
       "Q 1534 2075 1959 2075 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-39\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m1677785e09\" x=\"51.378125\" y=\"89.846251\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- $\\mathdefault{10^{-6}}$ -->\n",
       "      <g transform=\"translate(20.878125 93.645469) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m1677785e09\" x=\"51.378125\" y=\"57.899385\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_9\">\n",
       "      <!-- $\\mathdefault{10^{-3}}$ -->\n",
       "      <g transform=\"translate(20.878125 61.698604) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_9\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m1677785e09\" x=\"51.378125\" y=\"25.952519\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_10\">\n",
       "      <!-- $\\mathdefault{10^{0}}$ -->\n",
       "      <g transform=\"translate(26.778125 29.751738) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_11\">\n",
       "     <!-- ylabel -->\n",
       "     <g transform=\"translate(14.798438 90.202344) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-79\" d=\"M 2059 -325 \n",
       "Q 1816 -950 1584 -1140 \n",
       "Q 1353 -1331 966 -1331 \n",
       "L 506 -1331 \n",
       "L 506 -850 \n",
       "L 844 -850 \n",
       "Q 1081 -850 1212 -737 \n",
       "Q 1344 -625 1503 -206 \n",
       "L 1606 56 \n",
       "L 191 3500 \n",
       "L 800 3500 \n",
       "L 1894 763 \n",
       "L 2988 3500 \n",
       "L 3597 3500 \n",
       "L 2059 -325 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-79\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"59.179688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"86.962891\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"148.242188\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"211.71875\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"273.242188\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_10\">\n",
       "    <path d=\"M 60.255398 13.377273 \n",
       "L 89.298601 13.457285 \n",
       "L 89.565053 13.723117 \n",
       "L 89.742687 14.278951 \n",
       "L 89.920321 15.628843 \n",
       "L 90.186773 20.213278 \n",
       "L 90.542041 25.716796 \n",
       "L 91.252578 33.217275 \n",
       "L 91.785481 36.151519 \n",
       "L 92.496018 38.830854 \n",
       "L 93.206555 40.69291 \n",
       "L 93.828275 41.77402 \n",
       "L 94.449995 42.470331 \n",
       "L 95.160532 42.946518 \n",
       "L 96.048703 43.258067 \n",
       "L 97.292143 43.439565 \n",
       "L 99.690206 43.523859 \n",
       "L 111.591702 43.536811 \n",
       "L 185.309925 43.649707 \n",
       "L 189.48433 43.885401 \n",
       "L 192.148844 44.244849 \n",
       "L 194.191639 44.741417 \n",
       "L 195.879164 45.381995 \n",
       "L 197.389055 46.202072 \n",
       "L 198.721313 47.171663 \n",
       "L 200.05357 48.413593 \n",
       "L 201.385827 49.956752 \n",
       "L 202.806901 51.947342 \n",
       "L 204.405609 54.596609 \n",
       "L 206.181952 57.988315 \n",
       "L 208.40238 62.745206 \n",
       "L 211.333346 69.602852 \n",
       "L 215.86302 80.842631 \n",
       "L 226.787527 108.784619 \n",
       "L 233.359995 125.704794 \n",
       "L 234.336984 128.165991 \n",
       "L 235.580424 131.372341 \n",
       "L 236.02451 132.432469 \n",
       "L 237.623218 136.592773 \n",
       "L 237.800852 136.922727 \n",
       "L 237.800852 136.922727 \n",
       "\" clip-path=\"url(#p2e1750ac46)\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 51.378125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 51.378125 7.2 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"legend_1\">\n",
       "    <g id=\"patch_7\">\n",
       "     <path d=\"M 183.492188 29.878125 \n",
       "L 239.678125 29.878125 \n",
       "Q 241.678125 29.878125 241.678125 27.878125 \n",
       "L 241.678125 14.2 \n",
       "Q 241.678125 12.2 239.678125 12.2 \n",
       "L 183.492188 12.2 \n",
       "Q 181.492188 12.2 181.492188 14.2 \n",
       "L 181.492188 27.878125 \n",
       "Q 181.492188 29.878125 183.492188 29.878125 \n",
       "z\n",
       "\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n",
       "    </g>\n",
       "    <g id=\"line2d_11\">\n",
       "     <path d=\"M 185.492188 20.298437 \n",
       "L 195.492188 20.298437 \n",
       "L 205.492188 20.298437 \n",
       "\" style=\"fill: none; stroke: #0000ff; stroke-width: 2; stroke-linecap: square\"/>\n",
       "    </g>\n",
       "    <g id=\"text_12\">\n",
       "     <!-- label -->\n",
       "     <g transform=\"translate(213.492188 23.798437) scale(0.1 -0.1)\">\n",
       "      <use xlink:href=\"#DejaVuSans-6c\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"27.783203\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-62\" x=\"89.0625\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"152.539062\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"214.0625\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p2e1750ac46\">\n",
       "   <rect x=\"51.378125\" y=\"7.2\" width=\"195.3\" height=\"135.9\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_ls, linewidth=2, color='b', label='label')\n",
    "plt.xlabel('xlabel')\n",
    "plt.ylabel('ylabel')\n",
    "plt.legend()\n",
    "plt.yscale('log')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([13.413452,\n",
       "  13.413421,\n",
       "  13.413371,\n",
       "  13.413429,\n",
       "  13.413257,\n",
       "  13.41321,\n",
       "  13.413439,\n",
       "  13.4134445,\n",
       "  13.413445],\n",
       " [array([1.30474911e+01, 3.65960747e-01, 1.13765154e-07], dtype=float32),\n",
       "  array([1.3047490e+01, 3.6593059e-01, 1.3085271e-07], dtype=float32),\n",
       "  array([1.3047494e+01, 3.6587688e-01, 1.5154342e-07], dtype=float32),\n",
       "  array([1.3047495e+01, 3.6593461e-01, 3.8150816e-08], dtype=float32),\n",
       "  array([1.3047492e+01, 3.6576506e-01, 1.3941775e-07], dtype=float32),\n",
       "  array([1.3047494e+01, 3.6571628e-01, 2.7428959e-07], dtype=float32),\n",
       "  array([1.3047492e+01, 3.6594665e-01, 1.5131288e-08], dtype=float32),\n",
       "  array([1.3047493e+01, 3.6595109e-01, 2.2113481e-08], dtype=float32),\n",
       "  array([1.3047494e+01, 3.6595148e-01, 1.0349615e-07], dtype=float32)])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nuclear_norm_trial3, eigenvalues_trial3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'eigenvalues_trial3.pkl'"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "save_variable(nuclear_norm_trial, 'nuclear_norm_trial.pkl')\n",
    "save_variable(nuclear_norm_trial2, 'nuclear_norm_trial2.pkl')\n",
    "save_variable(nuclear_norm_trial3, 'nuclear_norm_trial3.pkl')\n",
    "save_variable(eigenvalues_trial, 'eigenvalues_trial.pkl')\n",
    "save_variable(eigenvalues_trial2, 'eigenvalues_trial2.pkl')\n",
    "save_variable(eigenvalues_trial3, 'eigenvalues_trial3.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "eigenvalues_trial = load_variable('eigenvalues_trial.pkl')\n",
    "eigenvalues_trial2 = load_variable('eigenvalues_trial2.pkl')\n",
    "eigenvalues_trial3 = load_variable('eigenvalues_trial3.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"252.64375pt\" height=\"166.978125pt\" viewBox=\"0 0 252.64375 166.978125\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T20:58:56.014328</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 166.978125 \n",
       "L 252.64375 166.978125 \n",
       "L 252.64375 0 \n",
       "L 0 0 \n",
       "L 0 166.978125 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 50.14375 143.1 \n",
       "L 245.44375 143.1 \n",
       "L 245.44375 7.2 \n",
       "L 50.14375 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 59.021023 143.1 \n",
       "L 94.530114 143.1 \n",
       "L 94.530114 26.624748 \n",
       "L 59.021023 26.624748 \n",
       "z\n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: #0000ff; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 130.039205 143.1 \n",
       "L 165.548295 143.1 \n",
       "L 165.548295 38.590555 \n",
       "L 130.039205 38.590555 \n",
       "z\n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: #008000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 201.057386 143.1 \n",
       "L 236.566477 143.1 \n",
       "L 236.566477 13.67225 \n",
       "L 201.057386 13.67225 \n",
       "z\n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: #ff0000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_1\">\n",
       "    <g id=\"xtick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"mf73a98c6a1\" d=\"M 0 0 \n",
       "L 0 3.5 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#mf73a98c6a1\" x=\"76.775568\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- $M_1$ -->\n",
       "      <g transform=\"translate(70.075568 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-Oblique-4d\" d=\"M 1081 4666 \n",
       "L 2028 4666 \n",
       "L 2572 1522 \n",
       "L 4378 4666 \n",
       "L 5350 4666 \n",
       "L 4441 0 \n",
       "L 3828 0 \n",
       "L 4622 4091 \n",
       "L 2791 897 \n",
       "L 2175 897 \n",
       "L 1581 4103 \n",
       "L 788 0 \n",
       "L 172 0 \n",
       "L 1081 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mf73a98c6a1\" x=\"147.79375\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- $M_2$ -->\n",
       "      <g transform=\"translate(141.09375 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mf73a98c6a1\" x=\"218.811932\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- $M_3$ -->\n",
       "      <g transform=\"translate(212.111932 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <defs>\n",
       "       <path id=\"m26988187bf\" d=\"M 0 0 \n",
       "L -3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- 0.0 -->\n",
       "      <g transform=\"translate(27.240625 146.899219) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-2e\" d=\"M 684 794 \n",
       "L 1344 794 \n",
       "L 1344 0 \n",
       "L 684 0 \n",
       "L 684 794 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"95.410156\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"118.977128\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_5\">\n",
       "      <!-- 2.5 -->\n",
       "      <g transform=\"translate(27.240625 122.776347) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" x=\"95.410156\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"94.854256\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_6\">\n",
       "      <!-- 5.0 -->\n",
       "      <g transform=\"translate(27.240625 98.653475) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"95.410156\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"70.731385\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_7\">\n",
       "      <!-- 7.5 -->\n",
       "      <g transform=\"translate(27.240625 74.530603) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-37\" d=\"M 525 4666 \n",
       "L 3525 4666 \n",
       "L 3525 4397 \n",
       "L 1831 0 \n",
       "L 1172 0 \n",
       "L 2766 4134 \n",
       "L 525 4134 \n",
       "L 525 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-37\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" x=\"95.410156\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_5\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"46.608513\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- 10.0 -->\n",
       "      <g transform=\"translate(20.878125 50.407732) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" x=\"159.033203\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_6\">\n",
       "     <g id=\"line2d_9\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m26988187bf\" x=\"50.14375\" y=\"22.485641\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_9\">\n",
       "      <!-- 12.5 -->\n",
       "      <g transform=\"translate(20.878125 26.28486) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" x=\"63.623047\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" x=\"127.246094\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" x=\"159.033203\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_10\">\n",
       "     <!-- Nuclear Norm -->\n",
       "     <g transform=\"translate(14.798437 109.621094) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-4e\" d=\"M 628 4666 \n",
       "L 1478 4666 \n",
       "L 3547 763 \n",
       "L 3547 4666 \n",
       "L 4159 4666 \n",
       "L 4159 0 \n",
       "L 3309 0 \n",
       "L 1241 3903 \n",
       "L 1241 0 \n",
       "L 628 0 \n",
       "L 628 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-75\" d=\"M 544 1381 \n",
       "L 544 3500 \n",
       "L 1119 3500 \n",
       "L 1119 1403 \n",
       "Q 1119 906 1312 657 \n",
       "Q 1506 409 1894 409 \n",
       "Q 2359 409 2629 706 \n",
       "Q 2900 1003 2900 1516 \n",
       "L 2900 3500 \n",
       "L 3475 3500 \n",
       "L 3475 0 \n",
       "L 2900 0 \n",
       "L 2900 538 \n",
       "Q 2691 219 2414 64 \n",
       "Q 2138 -91 1772 -91 \n",
       "Q 1169 -91 856 284 \n",
       "Q 544 659 544 1381 \n",
       "z\n",
       "M 1991 3584 \n",
       "L 1991 3584 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \n",
       "L 3122 2828 \n",
       "Q 2878 2963 2633 3030 \n",
       "Q 2388 3097 2138 3097 \n",
       "Q 1578 3097 1268 2742 \n",
       "Q 959 2388 959 1747 \n",
       "Q 959 1106 1268 751 \n",
       "Q 1578 397 2138 397 \n",
       "Q 2388 397 2633 464 \n",
       "Q 2878 531 3122 666 \n",
       "L 3122 134 \n",
       "Q 2881 22 2623 -34 \n",
       "Q 2366 -91 2075 -91 \n",
       "Q 1284 -91 818 406 \n",
       "Q 353 903 353 1747 \n",
       "Q 353 2603 823 3093 \n",
       "Q 1294 3584 2113 3584 \n",
       "Q 2378 3584 2631 3529 \n",
       "Q 2884 3475 3122 3366 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-72\" d=\"M 2631 2963 \n",
       "Q 2534 3019 2420 3045 \n",
       "Q 2306 3072 2169 3072 \n",
       "Q 1681 3072 1420 2755 \n",
       "Q 1159 2438 1159 1844 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1341 3275 1631 3429 \n",
       "Q 1922 3584 2338 3584 \n",
       "Q 2397 3584 2469 3576 \n",
       "Q 2541 3569 2628 3553 \n",
       "L 2631 2963 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6f\" d=\"M 1959 3097 \n",
       "Q 1497 3097 1228 2736 \n",
       "Q 959 2375 959 1747 \n",
       "Q 959 1119 1226 758 \n",
       "Q 1494 397 1959 397 \n",
       "Q 2419 397 2687 759 \n",
       "Q 2956 1122 2956 1747 \n",
       "Q 2956 2369 2687 2733 \n",
       "Q 2419 3097 1959 3097 \n",
       "z\n",
       "M 1959 3584 \n",
       "Q 2709 3584 3137 3096 \n",
       "Q 3566 2609 3566 1747 \n",
       "Q 3566 888 3137 398 \n",
       "Q 2709 -91 1959 -91 \n",
       "Q 1206 -91 779 398 \n",
       "Q 353 888 353 1747 \n",
       "Q 353 2609 779 3096 \n",
       "Q 1206 3584 1959 3584 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6d\" d=\"M 3328 2828 \n",
       "Q 3544 3216 3844 3400 \n",
       "Q 4144 3584 4550 3584 \n",
       "Q 5097 3584 5394 3201 \n",
       "Q 5691 2819 5691 2113 \n",
       "L 5691 0 \n",
       "L 5113 0 \n",
       "L 5113 2094 \n",
       "Q 5113 2597 4934 2840 \n",
       "Q 4756 3084 4391 3084 \n",
       "Q 3944 3084 3684 2787 \n",
       "Q 3425 2491 3425 1978 \n",
       "L 3425 0 \n",
       "L 2847 0 \n",
       "L 2847 2094 \n",
       "Q 2847 2600 2669 2842 \n",
       "Q 2491 3084 2119 3084 \n",
       "Q 1678 3084 1418 2786 \n",
       "Q 1159 2488 1159 1978 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1356 3278 1631 3431 \n",
       "Q 1906 3584 2284 3584 \n",
       "Q 2666 3584 2933 3390 \n",
       "Q 3200 3197 3328 2828 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-4e\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-75\" x=\"74.804688\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-63\" x=\"138.183594\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"193.164062\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"220.947266\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"282.470703\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-72\" x=\"343.75\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-20\" x=\"384.863281\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-4e\" x=\"416.650391\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6f\" x=\"491.455078\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-72\" x=\"552.636719\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6d\" x=\"592\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_1\">\n",
       "    <path d=\"M 76.775568 26.624796 \n",
       "L 76.775568 26.624699 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_10\">\n",
       "    <defs>\n",
       "     <path id=\"m633a259748\" d=\"M 10 0 \n",
       "L -10 -0 \n",
       "\" style=\"stroke: #000000\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"76.775568\" y=\"26.624796\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_11\">\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"76.775568\" y=\"26.624699\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_2\">\n",
       "    <path d=\"M 59.021023 46.608513 \n",
       "L 94.530114 46.608513 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #0000ff; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_3\">\n",
       "    <path d=\"M 130.039205 38.590533 \n",
       "L 165.548295 38.590533 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_4\">\n",
       "    <path d=\"M 147.79375 38.590561 \n",
       "L 147.79375 38.590549 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_12\">\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"147.79375\" y=\"38.590561\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_13\">\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"147.79375\" y=\"38.590549\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_5\">\n",
       "    <path d=\"M 218.811932 13.673071 \n",
       "L 218.811932 13.671429 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_14\">\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"218.811932\" y=\"13.673071\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_15\">\n",
       "    <g clip-path=\"url(#p3f559bc907)\">\n",
       "     <use xlink:href=\"#m633a259748\" x=\"218.811932\" y=\"13.671429\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_6\">\n",
       "    <path d=\"M 201.057386 24.197319 \n",
       "L 236.566477 24.197319 \n",
       "\" clip-path=\"url(#p3f559bc907)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #ff0000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 50.14375 143.1 \n",
       "L 50.14375 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_7\">\n",
       "    <path d=\"M 245.44375 143.1 \n",
       "L 245.44375 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_8\">\n",
       "    <path d=\"M 50.14375 143.1 \n",
       "L 245.44375 143.1 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_9\">\n",
       "    <path d=\"M 50.14375 7.2 \n",
       "L 245.44375 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p3f559bc907\">\n",
       "   <rect x=\"50.14375\" y=\"7.2\" width=\"195.3\" height=\"135.9\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_figsize((3.5, 2.5), 10)\n",
    "edgecolor='k'\n",
    "linewidth=1\n",
    "x_ls = [0, 0.5, 1]\n",
    "\n",
    "data = np.array(nuclear_norm_trial)\n",
    "bar_width = 0.25\n",
    "plt.bar(x_ls[0], np.mean(data), bar_width, yerr=np.std(data), capsize=10, color='b', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.hlines(min_nuclear_norm1, x_ls[0]-bar_width/2, x_ls[0]+bar_width/2, colors='b', linestyles='dashed')\n",
    "\n",
    "data = np.array(nuclear_norm_trial2)\n",
    "plt.hlines(min_nuclear_norm2, x_ls[1]-bar_width/2, x_ls[1]+bar_width/2, colors='g', linestyles='dashed')\n",
    "plt.bar(x_ls[1], np.mean(data), bar_width, yerr=np.std(data), capsize=10, color='g', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "\n",
    "\n",
    "\n",
    "data = np.array(nuclear_norm_trial3)\n",
    "plt.bar(x_ls[2], np.mean(data), bar_width, yerr=np.std(data), capsize=10, color='r', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.hlines(min_nuclear_norm3, x_ls[2]-bar_width/2, x_ls[2]+bar_width/2, colors='r', linestyles='dashed')\n",
    "\n",
    "\n",
    "# plt.xlabel('Experiment')\n",
    "plt.ylabel('Nuclear Norm')\n",
    "# plt.title('Experimental Results')\n",
    "# plt.xlim(-0.4, 2.4)\n",
    "plt.xticks(x_ls, ['$M_1$', '$M_2$', '$M_3$'])\n",
    "\n",
    "# plt.xticks([0, 1, 2], ['Disconnected', 'Disconnected\\n(complete bipartite)', 'Connected'])\n",
    "plt.savefig('examples_nuclear_norm2.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[9.4173708e+00, 2.6536701e+00, 6.7452966e-08],\n",
       "       [7.0789990e+00, 4.9920411e+00, 1.6860493e-07],\n",
       "       [7.5618753e+00, 4.5091562e+00, 1.0120624e-07],\n",
       "       [7.8307266e+00, 4.2403140e+00, 1.0116384e-07],\n",
       "       [1.0976033e+01, 1.0949982e+00, 6.7482262e-08],\n",
       "       [9.8768921e+00, 2.1941490e+00, 1.3489314e-07],\n",
       "       [7.4647684e+00, 4.6062651e+00, 8.4317492e-08],\n",
       "       [1.1829492e+01, 2.4155699e-01, 8.4315225e-08],\n",
       "       [8.1739607e+00, 3.8970785e+00, 6.7556712e-08],\n",
       "       [9.0440216e+00, 3.0270185e+00, 8.4758490e-08]], dtype=float32)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(eigenvalues_trial)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"253.878125pt\" height=\"166.978125pt\" viewBox=\"0 0 253.878125 166.978125\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2024-05-22T21:00:36.113709</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.7.3, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 166.978125 \n",
       "L 253.878125 166.978125 \n",
       "L 253.878125 0 \n",
       "L 0 0 \n",
       "L 0 166.978125 \n",
       "z\n",
       "\" style=\"fill: none\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "L 51.378125 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 60.255398 13230.412633 \n",
       "L 76.395894 13230.412633 \n",
       "L 76.395894 25.015653 \n",
       "L 60.255398 25.015653 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #0000ff; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 76.395894 13230.412633 \n",
       "L 92.536389 13230.412633 \n",
       "L 92.536389 30.990981 \n",
       "L 76.395894 30.990981 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #0000ff; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 92.536389 13230.412633 \n",
       "L 108.676885 13230.412633 \n",
       "L 108.676885 130.130595 \n",
       "L 92.536389 130.130595 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #0000ff; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 124.817381 13230.412633 \n",
       "L 140.957877 13230.412633 \n",
       "L 140.957877 26.667953 \n",
       "L 124.817381 26.667953 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #008000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_7\">\n",
       "    <path d=\"M 140.957877 13230.412633 \n",
       "L 157.098373 13230.412633 \n",
       "L 157.098373 29.642046 \n",
       "L 140.957877 29.642046 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #008000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_8\">\n",
       "    <path d=\"M 157.098373 13230.412633 \n",
       "L 173.238869 13230.412633 \n",
       "L 173.238869 48.024597 \n",
       "L 157.098373 48.024597 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #008000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_9\">\n",
       "    <path d=\"M 189.379365 13230.412633 \n",
       "L 205.519861 13230.412633 \n",
       "L 205.519861 22.840169 \n",
       "L 189.379365 22.840169 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #ff0000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_10\">\n",
       "    <path d=\"M 205.519861 13230.412633 \n",
       "L 221.660356 13230.412633 \n",
       "L 221.660356 43.317768 \n",
       "L 205.519861 43.317768 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #ff0000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_11\">\n",
       "    <path d=\"M 221.660356 13230.412633 \n",
       "L 237.800852 13230.412633 \n",
       "L 237.800852 129.368236 \n",
       "L 221.660356 129.368236 \n",
       "z\n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: #ff0000; opacity: 0.3; stroke: #000000; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_1\">\n",
       "    <g id=\"xtick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"mc1ca3b54c7\" d=\"M 0 0 \n",
       "L 0 3.5 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#mc1ca3b54c7\" x=\"84.466142\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- $M_1$ -->\n",
       "      <g transform=\"translate(77.766142 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-Oblique-4d\" d=\"M 1081 4666 \n",
       "L 2028 4666 \n",
       "L 2572 1522 \n",
       "L 4378 4666 \n",
       "L 5350 4666 \n",
       "L 4441 0 \n",
       "L 3828 0 \n",
       "L 4622 4091 \n",
       "L 2791 897 \n",
       "L 2175 897 \n",
       "L 1581 4103 \n",
       "L 788 0 \n",
       "L 172 0 \n",
       "L 1081 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mc1ca3b54c7\" x=\"149.028125\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- $M_2$ -->\n",
       "      <g transform=\"translate(142.328125 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"xtick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mc1ca3b54c7\" x=\"213.590108\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- $M_3$ -->\n",
       "      <g transform=\"translate(206.890108 157.698438) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-Oblique-4d\" transform=\"translate(0 0.09375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(86.279297 -16.3125) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <defs>\n",
       "       <path id=\"mac6240d495\" d=\"M 0 0 \n",
       "L -3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"143.1\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- $\\mathdefault{10^{-8}}$ -->\n",
       "      <g transform=\"translate(20.878125 146.899219) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-2212\" d=\"M 678 2272 \n",
       "L 4684 2272 \n",
       "L 4684 1741 \n",
       "L 678 1741 \n",
       "L 678 2272 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \n",
       "Q 1584 2216 1326 1975 \n",
       "Q 1069 1734 1069 1313 \n",
       "Q 1069 891 1326 650 \n",
       "Q 1584 409 2034 409 \n",
       "Q 2484 409 2743 651 \n",
       "Q 3003 894 3003 1313 \n",
       "Q 3003 1734 2745 1975 \n",
       "Q 2488 2216 2034 2216 \n",
       "z\n",
       "M 1403 2484 \n",
       "Q 997 2584 770 2862 \n",
       "Q 544 3141 544 3541 \n",
       "Q 544 4100 942 4425 \n",
       "Q 1341 4750 2034 4750 \n",
       "Q 2731 4750 3128 4425 \n",
       "Q 3525 4100 3525 3541 \n",
       "Q 3525 3141 3298 2862 \n",
       "Q 3072 2584 2669 2484 \n",
       "Q 3125 2378 3379 2068 \n",
       "Q 3634 1759 3634 1313 \n",
       "Q 3634 634 3220 271 \n",
       "Q 2806 -91 2034 -91 \n",
       "Q 1263 -91 848 271 \n",
       "Q 434 634 434 1313 \n",
       "Q 434 1759 690 2068 \n",
       "Q 947 2378 1403 2484 \n",
       "z\n",
       "M 1172 3481 \n",
       "Q 1172 3119 1398 2916 \n",
       "Q 1625 2713 2034 2713 \n",
       "Q 2441 2713 2670 2916 \n",
       "Q 2900 3119 2900 3481 \n",
       "Q 2900 3844 2670 4047 \n",
       "Q 2441 4250 2034 4250 \n",
       "Q 1625 4250 1398 4047 \n",
       "Q 1172 3844 1172 3481 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-38\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"116.714289\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_5\">\n",
       "      <!-- $\\mathdefault{10^{-6}}$ -->\n",
       "      <g transform=\"translate(20.878125 120.513508) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"90.328578\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_6\">\n",
       "      <!-- $\\mathdefault{10^{-4}}$ -->\n",
       "      <g transform=\"translate(20.878125 94.127797) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.684375)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 38.965625) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-34\" transform=\"translate(186.855469 38.965625) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"63.942867\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_7\">\n",
       "      <!-- $\\mathdefault{10^{-2}}$ -->\n",
       "      <g transform=\"translate(20.878125 67.742086) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(186.855469 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_5\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"37.557156\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- $\\mathdefault{10^{0}}$ -->\n",
       "      <g transform=\"translate(26.778125 41.356375) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_6\">\n",
       "     <g id=\"line2d_9\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#mac6240d495\" x=\"51.378125\" y=\"11.171445\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_9\">\n",
       "      <!-- $\\mathdefault{10^{2}}$ -->\n",
       "      <g transform=\"translate(26.778125 14.970664) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(0 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0.765625)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(128.203125 39.046875) scale(0.7)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_10\">\n",
       "     <!-- Singular Values -->\n",
       "     <g transform=\"translate(14.798438 113.658594) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-53\" d=\"M 3425 4513 \n",
       "L 3425 3897 \n",
       "Q 3066 4069 2747 4153 \n",
       "Q 2428 4238 2131 4238 \n",
       "Q 1616 4238 1336 4038 \n",
       "Q 1056 3838 1056 3469 \n",
       "Q 1056 3159 1242 3001 \n",
       "Q 1428 2844 1947 2747 \n",
       "L 2328 2669 \n",
       "Q 3034 2534 3370 2195 \n",
       "Q 3706 1856 3706 1288 \n",
       "Q 3706 609 3251 259 \n",
       "Q 2797 -91 1919 -91 \n",
       "Q 1588 -91 1214 -16 \n",
       "Q 841 59 441 206 \n",
       "L 441 856 \n",
       "Q 825 641 1194 531 \n",
       "Q 1563 422 1919 422 \n",
       "Q 2459 422 2753 634 \n",
       "Q 3047 847 3047 1241 \n",
       "Q 3047 1584 2836 1778 \n",
       "Q 2625 1972 2144 2069 \n",
       "L 1759 2144 \n",
       "Q 1053 2284 737 2584 \n",
       "Q 422 2884 422 3419 \n",
       "Q 422 4038 858 4394 \n",
       "Q 1294 4750 2059 4750 \n",
       "Q 2388 4750 2728 4690 \n",
       "Q 3069 4631 3425 4513 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-69\" d=\"M 603 3500 \n",
       "L 1178 3500 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 3500 \n",
       "z\n",
       "M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 4134 \n",
       "L 603 4134 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6e\" d=\"M 3513 2113 \n",
       "L 3513 0 \n",
       "L 2938 0 \n",
       "L 2938 2094 \n",
       "Q 2938 2591 2744 2837 \n",
       "Q 2550 3084 2163 3084 \n",
       "Q 1697 3084 1428 2787 \n",
       "Q 1159 2491 1159 1978 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1366 3272 1645 3428 \n",
       "Q 1925 3584 2291 3584 \n",
       "Q 2894 3584 3203 3211 \n",
       "Q 3513 2838 3513 2113 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-67\" d=\"M 2906 1791 \n",
       "Q 2906 2416 2648 2759 \n",
       "Q 2391 3103 1925 3103 \n",
       "Q 1463 3103 1205 2759 \n",
       "Q 947 2416 947 1791 \n",
       "Q 947 1169 1205 825 \n",
       "Q 1463 481 1925 481 \n",
       "Q 2391 481 2648 825 \n",
       "Q 2906 1169 2906 1791 \n",
       "z\n",
       "M 3481 434 \n",
       "Q 3481 -459 3084 -895 \n",
       "Q 2688 -1331 1869 -1331 \n",
       "Q 1566 -1331 1297 -1286 \n",
       "Q 1028 -1241 775 -1147 \n",
       "L 775 -588 \n",
       "Q 1028 -725 1275 -790 \n",
       "Q 1522 -856 1778 -856 \n",
       "Q 2344 -856 2625 -561 \n",
       "Q 2906 -266 2906 331 \n",
       "L 2906 616 \n",
       "Q 2728 306 2450 153 \n",
       "Q 2172 0 1784 0 \n",
       "Q 1141 0 747 490 \n",
       "Q 353 981 353 1791 \n",
       "Q 353 2603 747 3093 \n",
       "Q 1141 3584 1784 3584 \n",
       "Q 2172 3584 2450 3431 \n",
       "Q 2728 3278 2906 2969 \n",
       "L 2906 3500 \n",
       "L 3481 3500 \n",
       "L 3481 434 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-75\" d=\"M 544 1381 \n",
       "L 544 3500 \n",
       "L 1119 3500 \n",
       "L 1119 1403 \n",
       "Q 1119 906 1312 657 \n",
       "Q 1506 409 1894 409 \n",
       "Q 2359 409 2629 706 \n",
       "Q 2900 1003 2900 1516 \n",
       "L 2900 3500 \n",
       "L 3475 3500 \n",
       "L 3475 0 \n",
       "L 2900 0 \n",
       "L 2900 538 \n",
       "Q 2691 219 2414 64 \n",
       "Q 2138 -91 1772 -91 \n",
       "Q 1169 -91 856 284 \n",
       "Q 544 659 544 1381 \n",
       "z\n",
       "M 1991 3584 \n",
       "L 1991 3584 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-72\" d=\"M 2631 2963 \n",
       "Q 2534 3019 2420 3045 \n",
       "Q 2306 3072 2169 3072 \n",
       "Q 1681 3072 1420 2755 \n",
       "Q 1159 2438 1159 1844 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1341 3275 1631 3429 \n",
       "Q 1922 3584 2338 3584 \n",
       "Q 2397 3584 2469 3576 \n",
       "Q 2541 3569 2628 3553 \n",
       "L 2631 2963 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-56\" d=\"M 1831 0 \n",
       "L 50 4666 \n",
       "L 709 4666 \n",
       "L 2188 738 \n",
       "L 3669 4666 \n",
       "L 4325 4666 \n",
       "L 2547 0 \n",
       "L 1831 0 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \n",
       "L 2834 2853 \n",
       "Q 2591 2978 2328 3040 \n",
       "Q 2066 3103 1784 3103 \n",
       "Q 1356 3103 1142 2972 \n",
       "Q 928 2841 928 2578 \n",
       "Q 928 2378 1081 2264 \n",
       "Q 1234 2150 1697 2047 \n",
       "L 1894 2003 \n",
       "Q 2506 1872 2764 1633 \n",
       "Q 3022 1394 3022 966 \n",
       "Q 3022 478 2636 193 \n",
       "Q 2250 -91 1575 -91 \n",
       "Q 1294 -91 989 -36 \n",
       "Q 684 19 347 128 \n",
       "L 347 722 \n",
       "Q 666 556 975 473 \n",
       "Q 1284 391 1588 391 \n",
       "Q 1994 391 2212 530 \n",
       "Q 2431 669 2431 922 \n",
       "Q 2431 1156 2273 1281 \n",
       "Q 2116 1406 1581 1522 \n",
       "L 1381 1569 \n",
       "Q 847 1681 609 1914 \n",
       "Q 372 2147 372 2553 \n",
       "Q 372 3047 722 3315 \n",
       "Q 1072 3584 1716 3584 \n",
       "Q 2034 3584 2315 3537 \n",
       "Q 2597 3491 2834 3397 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-53\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-69\" x=\"63.476562\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6e\" x=\"91.259766\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-67\" x=\"154.638672\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-75\" x=\"218.115234\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"281.494141\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"309.277344\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-72\" x=\"370.556641\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-20\" x=\"411.669922\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-56\" x=\"443.457031\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" x=\"504.115234\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6c\" x=\"565.394531\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-75\" x=\"593.177734\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" x=\"656.556641\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-73\" x=\"718.080078\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_1\">\n",
       "    <path d=\"M 68.325646 26.081778 \n",
       "L 68.325646 24.117128 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_10\">\n",
       "    <defs>\n",
       "     <path id=\"m7a85d46a8b\" d=\"M 5 0 \n",
       "L -5 -0 \n",
       "\" style=\"stroke: #000000\"/>\n",
       "    </defs>\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"68.325646\" y=\"26.081778\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_11\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"68.325646\" y=\"24.117128\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_2\">\n",
       "    <path d=\"M 84.466142 34.757083 \n",
       "L 84.466142 28.73795 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_12\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"84.466142\" y=\"34.757083\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_13\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"84.466142\" y=\"28.73795\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_3\">\n",
       "    <path d=\"M 100.606637 132.369033 \n",
       "L 100.606637 128.525125 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_14\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"100.606637\" y=\"132.369033\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_15\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"100.606637\" y=\"128.525125\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_4\">\n",
       "    <path d=\"M 92.536389 143.1 \n",
       "L 92.536389 31.262564 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #0000ff; stroke-width: 3\"/>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_5\">\n",
       "    <path d=\"M 132.887629 27.948369 \n",
       "L 132.887629 25.622062 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_16\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"132.887629\" y=\"27.948369\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_17\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"132.887629\" y=\"25.622062\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_6\">\n",
       "    <path d=\"M 149.028125 32.041321 \n",
       "L 149.028125 27.95606 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_18\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"149.028125\" y=\"32.041321\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_19\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"149.028125\" y=\"27.95606\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_7\">\n",
       "    <path d=\"M 165.168621 59.00854 \n",
       "L 165.168621 44.490676 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_20\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"165.168621\" y=\"59.00854\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_21\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"165.168621\" y=\"44.490676\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_8\">\n",
       "    <path d=\"M 173.238869 143.1 \n",
       "L 173.238869 47.072456 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #008000; stroke-width: 3\"/>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_9\">\n",
       "    <path d=\"M 197.449613 22.840169 \n",
       "L 197.449613 22.840168 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_22\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"197.449613\" y=\"22.840169\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_23\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"197.449613\" y=\"22.840168\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_10\">\n",
       "    <path d=\"M 213.590108 43.319102 \n",
       "L 213.590108 43.316435 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_24\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"213.590108\" y=\"43.319102\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_25\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"213.590108\" y=\"43.316435\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_11\">\n",
       "    <path d=\"M 229.730604 136.108551 \n",
       "L 229.730604 126.356287 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #000000; stroke-width: 1.5\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_26\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"229.730604\" y=\"136.108551\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"line2d_27\">\n",
       "    <g clip-path=\"url(#p3b0220f402)\">\n",
       "     <use xlink:href=\"#m7a85d46a8b\" x=\"229.730604\" y=\"126.356287\" style=\"stroke: #000000\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_12\">\n",
       "    <path d=\"M 221.660356 143.1 \n",
       "L 221.660356 42.807121 \n",
       "\" clip-path=\"url(#p3b0220f402)\" style=\"fill: none; stroke: #ff0000; stroke-width: 3\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_12\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 51.378125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_13\">\n",
       "    <path d=\"M 246.678125 143.1 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_14\">\n",
       "    <path d=\"M 51.378125 143.1 \n",
       "L 246.678125 143.1 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_15\">\n",
       "    <path d=\"M 51.378125 7.2 \n",
       "L 246.678125 7.2 \n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "   <g id=\"text_11\">\n",
       "    <!-- GT:1 -->\n",
       "    <g transform=\"translate(65.333394 18.313168) scale(0.1 -0.1)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-47\" d=\"M 3809 666 \n",
       "L 3809 1919 \n",
       "L 2778 1919 \n",
       "L 2778 2438 \n",
       "L 4434 2438 \n",
       "L 4434 434 \n",
       "Q 4069 175 3628 42 \n",
       "Q 3188 -91 2688 -91 \n",
       "Q 1594 -91 976 548 \n",
       "Q 359 1188 359 2328 \n",
       "Q 359 3472 976 4111 \n",
       "Q 1594 4750 2688 4750 \n",
       "Q 3144 4750 3555 4637 \n",
       "Q 3966 4525 4313 4306 \n",
       "L 4313 3634 \n",
       "Q 3963 3931 3569 4081 \n",
       "Q 3175 4231 2741 4231 \n",
       "Q 1884 4231 1454 3753 \n",
       "Q 1025 3275 1025 2328 \n",
       "Q 1025 1384 1454 906 \n",
       "Q 1884 428 2741 428 \n",
       "Q 3075 428 3337 486 \n",
       "Q 3600 544 3809 666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-54\" d=\"M -19 4666 \n",
       "L 3928 4666 \n",
       "L 3928 4134 \n",
       "L 2272 4134 \n",
       "L 2272 0 \n",
       "L 1638 0 \n",
       "L 1638 4134 \n",
       "L -19 4134 \n",
       "L -19 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-3a\" d=\"M 750 794 \n",
       "L 1409 794 \n",
       "L 1409 0 \n",
       "L 750 0 \n",
       "L 750 794 \n",
       "z\n",
       "M 750 3309 \n",
       "L 1409 3309 \n",
       "L 1409 2516 \n",
       "L 750 2516 \n",
       "L 750 3309 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-47\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-54\" x=\"73.865234\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" x=\"123.949219\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-31\" x=\"157.640625\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_12\">\n",
       "    <!-- GT:2 -->\n",
       "    <g transform=\"translate(137.965625 18.313168) scale(0.1 -0.1)\">\n",
       "     <use xlink:href=\"#DejaVuSans-47\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-54\" x=\"73.865234\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" x=\"123.949219\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-32\" x=\"157.640625\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_13\">\n",
       "    <!-- GT:2 -->\n",
       "    <g transform=\"translate(202.527608 18.313168) scale(0.1 -0.1)\">\n",
       "     <use xlink:href=\"#DejaVuSans-47\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-54\" x=\"73.865234\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" x=\"123.949219\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-32\" x=\"157.640625\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p3b0220f402\">\n",
       "   <rect x=\"51.378125\" y=\"7.2\" width=\"195.3\" height=\"135.9\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 252x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_figsize((3.5, 2.5), 10)\n",
    "edgecolor='k'\n",
    "linewidth=1\n",
    "\n",
    "data = np.array(eigenvalues_trial)\n",
    "bar_width = 0.25\n",
    "plt.bar(0-bar_width, np.mean(data[:, 0]), bar_width, yerr=np.std(data[:, 0]), capsize=5, color='b', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(0, np.mean(data[:, 1]), bar_width, yerr=np.std(data[:, 1]), capsize=5, color='b', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(0+bar_width, np.mean(data[:, 2]), bar_width, yerr=np.std(data[:, 2]), capsize=5, color='b', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.vlines(bar_width/2, 1e-8, 0.3*1e1, colors='b', linestyles='-', linewidth=3)\n",
    "plt.text(-bar_width/2, 0.2*1e2, 'GT:1', ha='center', va='bottom', fontsize=10)\n",
    "\n",
    "\n",
    "\n",
    "data = np.array(eigenvalues_trial2)\n",
    "plt.bar(1-bar_width, np.mean(data[:, 0]), bar_width, yerr=np.std(data[:, 0]), capsize=5, color='g', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(1, np.mean(data[:, 1]), bar_width, yerr=np.std(data[:, 1]), capsize=5, color='g', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(1+bar_width, np.mean(data[:, 2]), bar_width, yerr=np.std(data[:, 2]), capsize=5, color='g', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.vlines(1+3*bar_width/2, 1e-8, 1.9*1e-1, colors='g', linestyles='-', linewidth=3)\n",
    "plt.text(1+0*bar_width/2, 0.2*1e2, 'GT:2', ha='center', va='bottom', fontsize=10)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "data = np.array(eigenvalues_trial3)\n",
    "plt.bar(2-bar_width, np.mean(data[:, 0]), bar_width, yerr=np.std(data[:, 0]), capsize=5, color='r', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(2, np.mean(data[:, 1]), bar_width, yerr=np.std(data[:, 1]), capsize=5, color='r', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.bar(2+bar_width, np.mean(data[:, 2]), bar_width, yerr=np.std(data[:, 2]), capsize=5, color='r', alpha=0.3, edgecolor=edgecolor, linewidth=linewidth)\n",
    "plt.vlines(2+bar_width/2, 1e-8, 4*1e-1, colors='r', linestyles='-', linewidth=3)\n",
    "plt.text(2+0*bar_width/2, 0.2*1e2, 'GT:2', ha='center', va='bottom', fontsize=10)\n",
    "\n",
    "\n",
    "plt.ylabel('Singular Values')\n",
    "# plt.title('Experimental Results')\n",
    "# plt.xlim(-0.4, 2.4)\n",
    "plt.xticks([0, 1, 2], ['$M_1$', '$M_2$', '$M_3$'])\n",
    "plt.yscale('log')\n",
    "plt.ylim(1e-8, 2*1e2)\n",
    "plt.savefig('examples_eigenvalues2.pdf', bbox_inches='tight')\n",
    "# plt.savefig('name.svg', bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
