{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b4e40426",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "590c74b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "class DynamicGraph():\n",
    "    def __init__(self, w_list):\n",
    "        \"\"\"\n",
    "        Parameter\n",
    "        --------\n",
    "        w_list (list of torch.tensor):\n",
    "            list of mixing matrix\n",
    "        \"\"\"\n",
    "        self.w_list = w_list\n",
    "        self.n_nodes = w_list[0].size()[0]\n",
    "        self.length = len(w_list)\n",
    "        self.itr = 0\n",
    "        \n",
    "    def get_in_neighbors(self, i):\n",
    "        \"\"\"\n",
    "        Parameter\n",
    "        ----------\n",
    "        i (int):\n",
    "            a node index\n",
    "        Return\n",
    "        ----------\n",
    "            dictionary of (neighbors's index: weight of the edge (i,j))\n",
    "        \"\"\"\n",
    "        w = self.w_list[self.itr%self.length]        \n",
    "\n",
    "        return {idx.item(): w[idx, i].item() for idx in torch.nonzero(w[:,i])}\n",
    "\n",
    "    def get_out_neighbors(self, i):\n",
    "        \"\"\"\n",
    "        Parameter\n",
    "        ----------\n",
    "        i (int):\n",
    "            a node index\n",
    "        Return\n",
    "        ----------\n",
    "            dictionary of (neighbors's index: weight of the edge (i,j))\n",
    "        \"\"\"\n",
    "        w = self.w_list[self.itr%self.length]        \n",
    "        \n",
    "        return {idx.item(): w[i,idx].item() for idx in torch.nonzero(w[i])}\n",
    "\n",
    "    \n",
    "    def get_neighbors(self, i):\n",
    "        in_neighbors = self.get_in_neighbors(i)\n",
    "        out_neighbors = self.get_out_neighbors(i)\n",
    "        self.itr += 1\n",
    "        return in_neighbors, out_neighbors\n",
    "        \n",
    "    \n",
    "    def get_w(self):\n",
    "        w = self.w_list[self.itr%self.length]        \n",
    "        self.itr += 1\n",
    "        return w\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a96a2e8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "class Ring():\n",
    "    def __init__(self, n_nodes):\n",
    "        self.w = torch.zeros((n_nodes, n_nodes))\n",
    "\n",
    "        for i in range(n_nodes):\n",
    "            self.w[i,i] = 1/3\n",
    "            self.w[i, (i+1)%n_nodes] = 1/3\n",
    "            self.w[i, (i-1)%n_nodes] = 1/3\n",
    "\n",
    "class DoubleRing():\n",
    "    def __init__(self, n_nodes):\n",
    "        self.w = torch.zeros((n_nodes, n_nodes))\n",
    "\n",
    "        for i in range(n_nodes):\n",
    "            self.w[i,i] = 1/5\n",
    "            self.w[i, (i+1)%n_nodes] = 1/5\n",
    "            self.w[i, (i-1)%n_nodes] = 1/5\n",
    "            self.w[i, (i+2)%n_nodes] = 1/5\n",
    "            self.w[i, (i-2)%n_nodes] = 1/5\n",
    "\n",
    "            \n",
    "class Torus(DynamicGraph):\n",
    "    def __init__(self, p, q):\n",
    "        self.n_nodes = p * q\n",
    "        self.p = p\n",
    "        self.q = q\n",
    "\n",
    "        if p <=2 or q<=2:\n",
    "            print(\"ERROR\")\n",
    "        \n",
    "        w = torch.zeros((self.n_nodes, self.n_nodes))\n",
    "\n",
    "        node_list_list = self.split_nodes()\n",
    "        \n",
    "        for sub_node_list in node_list_list:\n",
    "            for i in range(len(sub_node_list)):\n",
    "                i_idx = sub_node_list[i]\n",
    "                j_idx = sub_node_list[(i+1) % len(sub_node_list)]\n",
    "                w[i_idx, j_idx] = 1/5\n",
    "                w[j_idx, i_idx] = 1/5\n",
    "                w[i_idx, i_idx] = 1/5\n",
    "                w[j_idx, j_idx] = 1/5\n",
    "                \n",
    "\n",
    "        node_list_list2 = self.split_nodes2()\n",
    "        \n",
    "        for sub_node_list in node_list_list2:\n",
    "            for i in range(len(sub_node_list)):\n",
    "                i_idx = sub_node_list[i]\n",
    "                j_idx = sub_node_list[(i+1) % len(sub_node_list)]\n",
    "                w[i_idx, j_idx] = 1/5\n",
    "                w[j_idx, i_idx] = 1/5\n",
    "                w[i_idx, i_idx] = 1/5\n",
    "                w[j_idx, j_idx] = 1/5\n",
    "                \n",
    "\n",
    "        super().__init__([w])\n",
    "\n",
    "    def split_nodes(self):\n",
    "        node_list = list(range(self.n_nodes))\n",
    "        node_list_list = [node_list[i*self.q:(i+1)*self.q] for i in range(self.p)]\n",
    "        return node_list_list\n",
    "\n",
    "    \n",
    "    def split_nodes2(self):\n",
    "        node_list_list = self.split_nodes()\n",
    "        node_list_list2 = [[] for _ in range(self.q)]\n",
    "\n",
    "        for i in range(self.q):\n",
    "            for j in range(self.p):\n",
    "                node_list_list2[i].append(node_list_list[j][i])\n",
    "\n",
    "\n",
    "        return node_list_list2\n",
    "        \n",
    "class ExponentialGraph(DynamicGraph):\n",
    "    def __init__(self, n_nodes):\n",
    "        w = torch.zeros((n_nodes, n_nodes))\n",
    "\n",
    "        n_neighbors = int(math.log2(n_nodes-1))\n",
    "        for i in range(n_nodes):\n",
    "            w[i,i] = 1 / (math.ceil(math.log2(n_nodes)) + 1)\n",
    "            \n",
    "            for j in range(n_neighbors+1):\n",
    "                w[i, (i+2**j)%n_nodes] = 1 / (math.ceil(math.log2(n_nodes)) + 1)\n",
    "\n",
    "        super().__init__([w])\n",
    "        \n",
    "class Line():\n",
    "    def __init__(self, n_nodes):\n",
    "        self.w = torch.zeros((n_nodes, n_nodes))\n",
    "\n",
    "        for i in range(n_nodes):\n",
    "            if i == 0:\n",
    "                self.w[0,0] = 2/3\n",
    "                self.w[0,1] = 1/3\n",
    "            elif i == n_nodes - 1:\n",
    "                self.w[n_nodes-1, n_nodes-1] = 2/3\n",
    "            else:\n",
    "                self.w[i,i] = 1/3\n",
    "                self.w[i, (i+1)] = 1/3\n",
    "                self.w[i, (i-1)] = 1/3\n",
    "\n",
    "class FC():\n",
    "    def __init__(self, n_nodes):\n",
    "        self.w = torch.ones((n_nodes, n_nodes)) / n_nodes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1c76a518",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def max_singular_value(matrix):\n",
    "    singular_values = np.linalg.eig(matrix)[0] \n",
    "    #singular_values = np.linalg.svd(matrix, compute_uv=False)\n",
    "    \n",
    "    if len(singular_values) <= 4:\n",
    "        print(sorted(singular_values))\n",
    "    else:\n",
    "        print(sorted(singular_values)[:5], \" ... \", sorted(singular_values)[-3:])\n",
    "        \n",
    "    return sorted(singular_values)[-2]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ec9134e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "39ac13a4",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.33333334, -0.20601134, -0.20601134, 0.127322, 0.127322]  ...  [0.87267804, 0.87267804, 1.0]\n",
      "[-0.33333334, -0.32807648, -0.32807648, -0.31238878, -0.31238878]  ...  [0.99474317, 0.99474317, 1.0]\n",
      "[-0.33333334, -0.33201784, -0.33201784, -0.32807648, -0.32807648]  ...  [0.9986845, 0.9986845, 1.0]\n",
      "[-0.33333334, -0.3332807, -0.3332807, -0.3331228, -0.3331228]  ...  [0.99994737, 0.99994737, 1.0]\n",
      "[-0.33333334, -0.33332017, -0.33332017, -0.3332807, -0.3332807]  ...  [0.9999869, 0.9999869, 1.0]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fe2b41da760>]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing = []\n",
    "\n",
    "for n in [10, 50, 100, 500, 1000]:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing.append(max_singular_value(ring.w))\n",
    "    \n",
    "plt.plot(list_of_sing)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "95cb3c3c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.127322, 0.6666667, 0.87267804]\n",
      "[-0.2972115, -0.19276035, -0.03129877, 0.16967635, 0.38838625]  ...  [0.7848544, 0.9196492, 0.99090755]\n",
      "[-0.33199114, -0.32796988, -0.3212858, -0.31196582, -0.30004743]  ...  [0.99162596, 0.9969813, 0.99966437]\n",
      "[-0.33300108, -0.33200458, -0.33034486, -0.32802358, -0.32504305]  ...  [0.9979242, 0.9992525, 0.999917]\n",
      "[-0.33332017, -0.3332806, -0.33321467, -0.33312237, -0.33300373]  ...  [0.9999176, 0.9999704, 0.9999967]\n",
      "[-0.33333004, -0.33332017, -0.33330372, -0.33328065, -0.33325103]  ...  [0.99997944, 0.9999926, 0.9999992]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fe2b40ea190>]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing = []\n",
    "\n",
    "for n in [3, 10, 50, 100, 500, 1000]:\n",
    "    line = Line(n)\n",
    "    list_of_sing.append(max_singular_value(line.w))\n",
    "    \n",
    "plt.plot(list_of_sing)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "38e86165",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-7.187524e-17, 1.8488927e-32, 1.0]\n",
      "[0.0, 0.0, 0.0, 0.0, 0.0]  ...  [0.0, 0.0, 1.0]\n",
      "[(-3.1720658e-19+0j), (-2.1158768e-32+0j), (-5.3905094e-35+0j), (-3.8252637e-36+0j), 0j]  ...  [0j, (3.046486e-34+0j), (1+0j)]\n",
      "[(-9.035851e-31+0j), (-1.6476359e-31+0j), (-3.1654743e-32+0j), (-1.1521034e-34+0j), (-6.289794e-37+0j)]  ...  [(6.178611e-18-2.1363779e-17j), (6.178611e-18+2.1363779e-17j), (1+0j)]\n",
      "[(-8.091567e-17+0j), (-8.140404e-20+0j), (-5.5956757e-21+0j), (-1.6230865e-27+0j), (-5.088248e-29+0j)]  ...  [(9.1330414e-17+0j), (5.370916e-16+0j), (1+0j)]\n",
      "[(-6.9520323e-20+0j), (-2.3167327e-20+0j), (-1.6207987e-28+0j), (-3.6408577e-29+0j), (-2.2967863e-29+0j)]  ...  [(3.2415916e-18+4.2959936e-17j), (8.712455e-16+0j), (1+0j)]\n",
      "[3.4184043884735275e-64, 0.0, (9.281076981831698e-68+0j), (-4.1823581658429186e-34+2.6399696416884864e-34j), (2.884673594783922e-31+0j), (7.590687037245557e-31+0j)]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWoAAAEDCAYAAAAcI05xAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAZtklEQVR4nO3deZhU9Z3v8fe3F/Ydmn1pdsSFrV2CGwIaE43RjHGJy5jHBFwBM7ne5GbyJJO5mZk7mQTUuKHRXBUl7tfRRAUBxRjRbjbZ7GanWZt9aZpe6nv/6MaQDtLVUKfOqarP63n6SVdX9alPEfrjl9/vVB9zd0REJLqywg4gIiInpqIWEYk4FbWISMSpqEVEIk5FLSIScSpqEZGIC6yozewpM9thZssSdLy3zWyvmb1Z7+tmZr80s2IzW2lmkxLxfCIiURHkRP174PIEHu9XwC3H+fptQC9giLufBsxM4HOKiIQusKJ29w+A3cd+zcz6103GRWY238yGNOJ47wEHjnPXncAv3D1W97gdp5JbRCRqkr1GPR24191HAT8EHknAMfsD15tZoZn9ycwGJuCYIiKRkZOsJzKzVsBo4CUzO/rlpnX3fQv4xXG+bbO7f7WBQzcFKty9oO44TwEXJia1iEj4klbU1E7ve919eP073P1V4NWTPG7pMd/7GvD0SR5HRCSSkrb04e77gXVm9m344myNYQk49OvAJXWfXwwUJ+CYIiKRYUH99jwzewEYA3QCtgM/A+YAjwLdgFxgprsfb8njeMebDwwBWgG7gNvd/R0zawfMAHoDB4E73H1JQl+MiEiIAitqERFJDL0zUUQk4gLZTOzUqZPn5+cHcWgRkbRUVFS0093zjndfIEWdn59PYWFhEIcWEUlLZrbhy+7T0oeISMSpqEVEIk5FLSIScSpqEZGIU1GLiEScilpEJOJU1CIiEaeiFhFJgE/X7+bJ+WsJ4tdyqKhFRE7R1n2HufO5ImYs2Eh5ZU3Cj6+iFhE5BRVVNdzxbBGHK2uYfssoWjZN/Bu+k3nhABGRtOLu/PPry1hSuo/HbxnFwC6tA3keTdQiIifpmb9s4OWiUiaNG8hXT+8a2POoqEVETsLHa3fxizdXMP60zkwZF+w1tVXUIiKNtHnvYe6esZA+HVsw9frhZGVZw990ClTUIiKNUFFVw8RnC6msjvHErQW0bpYb+HNqM1FEJE7uzo9f/Yxlm/fz5K0F9M9rlZTn1UQtIhKnp/68ntcWbeYHlw5i/NAuSXteFbWISBw+Wr2Tf/vjSr56ehfuuWRAUp9bRS0i0oBNu8u5+/mF9OvUkl9fF/zmYX0qahGREzhcWcPEZ4uojjnTby2gVQDvPGyINhNFRL6Eu/M/X1nKym37eeq2s+nbqWUoOeKaqM3sPjNbbmbLzOwFM2sWdDARkbA9MX8tbyzZwg8vG8wlgzuHlqPBojazHsAkoMDdzwCygRuCDiYiEqb5JWX8x59W8fUzu3LXmP6hZol3jToHaG5mOUALYEtwkUREwrVxVzn3PL+IgZ1b86trh2GW3M3D+hosanffDPwXsBHYCuxz93frP87MJphZoZkVlpWVJT6piEgSlFdWM+HZQgCm3xrMry1trHiWPtoD3wT6At2BlmZ2c/3Huft0dy9w94K8vLzEJxURCZi78z9eXkrx9gM8eOMI+nQMZ/OwvniWPsYD69y9zN2rgFeB0cHGEhFJvsfeX8tbS7dy/+VDuHhQdAbOeIp6I3CembWw2oWaccDKYGOJiCTXvM938J/vrOLKs7ox8aJ+Ycf5G/GsUS8AXgYWAp/Vfc/0gHOJiCTN+p2HmPTCIoZ0bcN/XntW6JuH9cW1Su7uPwN+FnAWEZGkO3ikdvMwK8uYfssoWjQJf/OwPr2FXEQylrvzwxeXsHrHQR7+zkh6dWgRdqTjUlGLSMZ6eO5q3l6+jf/19dM4f0CnsON8KRW1iGSkOau28+tZxVw9vDu3X9A37DgnpKIWkYyzpuwgk19YzNBubfj3b0Vv87A+FbWIZJQDFVVMeKaQ3JwsHr9lFM2bZIcdqUHR294UEQlILOb84MUlrN9VznO3n0vP9tHcPKxPE7WIZIwH55Qwa8V2/vmK0/hK/45hx4mbilpEMsKsFduZNruEfxjZk9tG54cdp1FU1CKS9lbvOMh9f1jMWT3b8strzoj85mF9KmoRSWv76zYPm+Vm8djNo2iWG/3Nw/q0mSgiaSsWc+6buZiNu8t5/vvn0b1d87AjnRRN1CKStqbNLua9VTv42TeGck7fDmHHOWkqahFJS28v28qDc1ZzXUFPbj6vT9hxTomKWkTSTvH2A/zgxSUM79WOX3wz9TYP61NRi0ha2Vdeu3nYsmlOym4e1qeiFpG0URNzJs1cxOa9h3n0ppF0bdss7EgJobM+RCRt/Prdz3m/uIx/u+ZMCvJTd/OwPk3UIpIW3lq6lUfmreHGc3rznXN7hx0noVTUIpLyVm7dzw9fWsKoPu35+VVDw46TcCpqEUlpe8srmfBsIW2a5/DoTSNpmpP6m4f1aY1aRFJWdU2Me19YxPZ9R5g58Tw6t0mPzcP6VNQikrJ+9c7nzC/Zyf/5hzMZ2bt92HECo6UPEUlJbyzZwuMfrOWW8/pw/dnptXlYn4paRFLO8i37uP/lJZyd356fXpl+m4f1qahFJKXsPlTJhGeKaNe8CY/cNIomOelfY1qjFpGUUV0T457nF1J28AgvTfwKea2bhh0pKdL/P0Uikjb+/U+r+GjNLn559RkM69Uu7DhJo6IWkZTw2qJSfvfhOm4bnc+3C3qFHSepVNQiEnnLNu/jR698xrl9O/CTK04LO07SqahFJNJ2HjzChGcK6dSqKY/cNJLc7MyrLW0mikhkVdXEuHvGQnYdquSVO0fTsVVmbB7Wp6IWkcj65VsrWbBuN1OvH8YZPdqGHSc0mfdvCBFJCS8VbuL3H63n9gv6cs2InmHHCZWKWkQiZ8mmvfzk9WWM7t+RH39tSNhxQqeiFpFIKTtwhInPFpHXqim//c5IcjJw87A+rVGLSGRUVse4a0YRew/Xbh52aNkk7EiRoKIWkcj41zdX8On6PTx44whO7565m4f1xfVvCjNrZ2Yvm9kqM1tpZl8JOpiIZJY/fLqRZz/ewMSL+nHVsO5hx4mUeCfqB4C33f1aM2sCtAgwk4hkmIUb9/DT15dz4cBO3H+5Ng/ra7CozawtcBFwG4C7VwKVwcYSkUyxY38FdzxbRNe2zXjoxhFkZ1nYkSInnqWPvkAZ8LSZLTKzJ82sZf0HmdkEMys0s8KysrKEBxWR9HOkuoY7niviQEU1028dRbsW2jw8nniKOgcYCTzq7iOAQ8CP6j/I3ae7e4G7F+Tl5SU4poiko5+/sYKFG/fyX98expCubcKOE1nxFHUpUOruC+puv0xtcYuInLQZCzbwwicbuWtMf644q1vYcSKtwaJ2923AJjMbXPelccCKQFOJSForXL+bn7+xnDGD8/inywY3/A0ZLt6zPu4FZtSd8bEW+G5wkUQknW3bV8GdMxbSo11zHrhem4fxiKuo3X0xUBBsFBFJd0c3D8uPVDPje+fStkVu2JFSgt6ZKCJJ4e789PVlLN60l8duHsWgLq3DjpQy9NtORCQpnvt4Ay8WljJp7AAuP6Nr2HFSiopaRAK3YO0u/uW/VzBuSGemjB8UdpyUo6IWkUBt2XuYu59fSO+OLZh6w3CytHnYaFqjFpHAVFTVbh5WVMWYOaGANs20eXgyVNQiEgh35yevLWNp6T6euLWAAZ1bhR0pZWnpQ0QC8fuP1vPKwlKmjB/IpUO7hB0npamoRSThCtfv5n+/tZJLh3Zh0tiBYcdJeSpqEUkod+df31pJ1zbN+M11w7R5mAAqahFJqHmfl7Fk017uGTuA1to8TAgVtYgkjLszdXYxPds359pRPcOOkzZU1CKSMO+t3MHS0n1MGjuQ3GzVS6LoT1JEEuLoNN27QwuuGdkj7DhpRUUtIgnx7ortLN+yn0njNE0nmv40ReSUxWLOtNkl9O3UkquHdw87TtpRUYvIKXt3xTZWbt3PvWMHkKNpOuH0JyoipyQWc6bOKqFfXkuuGqZpOggqahE5JX9ato3Ptx9g8riBmqYDoj9VETlpNTFn2uxiBnRuxZVnaZoOiopaRE7aW59tpWTHQSaPG6iL1AZIRS0iJ6Um5jwwu5hBXVpxxZndwo6T1lTUInJS/nvJFtaUHWLyuEH6xUsBU1GLSKNV18R48L0ShnRtzdd0odrAqahFpNHeWLKFtTsPMWX8QE3TSaCiFpFGOTpND+3WhsuGappOBhW1iDTKa4s2s35XuabpJFJRi0jcqmpiPDRnNWf0aKPrICaRilpE4vbqwlI27i7nvvGDMNM0nSwqahGJS2V17TQ9rGdbxg7pHHacjKKiFpG4vFxUSumew0zRNJ10KmoRaVBldYyH565meK92jBmcF3acjKOiFpEGvVi4ic17D3PfpZqmw6CiFpETOlJdw8NzVzOqT3suGtgp7DgZSUUtIif0h083sXVfhc70CJGKWkS+VEVV7TR9dn57zh/QMew4GUtFLSJf6oVPNrJ9/xGtTYcs7qI2s2wzW2RmbwYZSESioaKqhkfmreHcvh0Y3V9r02FqzEQ9GVgZVBARiZYZCzZSdqB2mpZwxVXUZtYTuAJ4Mtg4IhIFhytreHTeGkb378h5/bQ2HbZ4J+ppwP1A7MseYGYTzKzQzArLysoSkU1EQvLcxxvYeVDTdFQ0WNRmdiWww92LTvQ4d5/u7gXuXpCXp3cuiaSq8spqHnt/DRcM6MTZ+R3CjiPEN1GfD1xlZuuBmcBYM3su0FQiEppn/rKBXYcque/SgWFHkToNFrW7/9jde7p7PnADMMfdbw48mYgk3cEj1Tz+/houGpTHqD6apqNC51GLyBf+70fr2VNexX3jNU1HSU5jHuzu84B5gSQRkVAdqKjiiflruWRwHiN6tw87jhxDE7WIALXT9N7yKqaM15keUaOiFhH2V1Qx/YO1jD+tM8N6tQs7jtSjohYRnv5wPfsrqjVNR5SKWiTD7TtcxZMfruXSoV04o0fbsOPIcaioRTLc7z5cx4GKaqboTI/IUlGLZLC95ZU8/eE6Lj+9K6d31zQdVSpqkQz25Px1HDhSzWRN05GmohbJUHsOVfL0n9dxxZndOK1bm7DjyAmoqEUy1BPz11JeVaNpOgWoqEUy0K6DR/j9R+u58qzuDOrSOuw40gAVtUgGmj5/LYerapg8bkDYUSQOKmqRDLPz4BGe+WgDVw3rzoDOmqZTgYpaJMM8/v4ajlTXMGmc1qZThYpaJIPsOFDBsx9v4OrhPeif1yrsOBInFbVIBnls3lqqapx7NU2nFBW1SIbYsb+CGQs2cM2IHvTt1DLsONIIKmqRDPHIvDVUx5x7x+pMj1SjohbJANv2VfD8Jxu5dmRP+nTUNJ1qVNQiGeCReauJxZx7NE2nJBW1SJrbsvcwMz/ZxLcLetKrQ4uw48hJUFGLpLmH567Gce6+RNN0qlJRi6Sx0j3lvFi4iesKetGzvabpVKWiFkljD89dg2GaplOcilokTW3aXc5LhZu44ZxedG/XPOw4cgpU1CJp6rdzVpOVZdw1RtN0qlNRi6ShDbsO8fLCUr5zTm+6tm0Wdhw5RSpqkTT00JzV5GQZd47pH3YUSQAVtUiaWbfzEK8t2sxN5/ahSxtN0+lARS2SZh56r4TcbOOOMf3CjiIJoqIWSSNryg7y+uLN3HJeHzq31jSdLlTUImnkofdKaJqTzcSLtTadTlTUImli9Y4D/L8lW7h1dB86tWoadhxJIBW1SJp44L3VNM/NZuJFmqbTjYpaJA0Ubz/Am0u38I+j8+nQsknYcSTBVNQiaeCB2SW0yM1mwoU60yMdqahFUtyqbft567OtfPf8vrTXNJ2WGixqM+tlZnPNbIWZLTezyckIJiLxmTarhNZNc/jehX3DjiIBiWeirgb+yd2HAucBd5vZ0GBjiUg8lm/Zx9vLt/HdC/rSroWm6XTVYFG7+1Z3X1j3+QFgJdAj6GAi0rAHZpfQulkOt1+gaTqdNWqN2szygRHAgkDSiEjclm3ex7srtvO9C/rRtnlu2HEkQHEXtZm1Al4Bprj7/uPcP8HMCs2ssKysLJEZReQ4ps0upk2zHL57QX7YUSRgcRW1meVSW9Iz3P3V4z3G3ae7e4G7F+Tl5SUyo4jUs7R0L7NX7uD7F/ajTTNN0+kunrM+DPgdsNLdfxN8JBFpyNRZxbRrkctt5+eHHUWSIJ6J+nzgFmCsmS2u+/h6wLlE5Ess2riHuZ+X8f0L+9Fa03RGyGnoAe7+IWBJyCIicZg6u4T2LXL5x9H5YUeRJNE7E0VSSNGGPXxQXMbEi/vTqmmDc5akCRW1SAqZNruYji2bcOtX+oQdRZJIRS2SIj5dv5v5JTu54+L+tGiiaTqTqKhFUsTUWcV0atWUm8/TNJ1pVNQiKeDjtbv4aM0u7ri4H82bZIcdR5JMRS2SAqbOKiavtabpTKWiFom4j9bsZMG63dw1pj/NcjVNZyIVtUiEuTvTZpXQpU1Tbjynd9hxJCQqapEI+/PqXXyyfjd3XzJA03QGU1GLRJS7M3V2Md3aNuP6s3uFHUdCpKIWiagPSnZStGEPd10ygKY5mqYzmYpaJILcnamziunRrjnXFfQMO46ETEUtEkHzistYvGkvd2uaFlTUIpFzdJru2b45147SNC0qapHImbNqB0tL93Hv2AE0ydGPqKioRSLl6JkevTu04FsjNU1LLRW1SITMWrGdZZv3c+/YAeRm68dTaulvgkhEuDvTZpeQ37EF14zoEXYciRAVtUhEvLN8Oyu27ufesQPJ0TQtx9DfBpEIiMWcabOL6depJd8c3j3sOBIxKmqRCHh7+TZWbTvApHGapuXv6W+ESMiOTtP981ryjWGapuXvqahFQvbWZ1sp3n6QyeMHkZ1lYceRCFJRi4SoJuY88F4JAzu34oozu4UdRyJKRS0SojeXbmH1joNM0TQtJ6CiFgnJ0Wl6SNfWfO2MrmHHkQhTUYuE5I0lm1lbdojJ4waSpWlaTkBFLRKC6poYD8wu4bRubfjq6Zqm5cRU1CIheH3xFtbvKmfKeE3T0jAVtUiSVdXEePC9Ek7v3obLhnYJO46kABW1SJK9tnAzG3eXc9/4QZhpmpaGqahFkqiqJsaDc0o4q2dbxp3WOew4kiJU1CJJ9HJRKaV7DmualkZRUYskSWV1jN/OWc3wXu0YMzgv7DiSQlTUIknyUtEmNu89zJTxAzVNS6OoqEWS4Eh1Db+ds5qRvdtx8SBN09I4KmqRJHjx001s3VfBfZdqbVoaLyeeB5nZ5cADQDbwpLv/R6CpRFJETcypqolRWROjuqbu8+oYVTUxqupuH6mO8fDcNRT0ac8FAzqFHVlSUINFbWbZwMPApUAp8KmZveHuK4IOJ5nH3amuK7+jRVdVE6Oq2qk8+nndR2X1Mfcf+9iaGJU1TlV1vds1MaqqY1TH6o51TKH+zbGPea4vyvfY56n+6+2Yx//afnPdME3TclLimajPAVa7+1oAM5sJfBNIeFF/46EPqaiqSfRhJWKc2t918TcFWf3X20HJzTZys7O++GiSbeTmZJGTVfv1JjlH7zNa5+bQ5Ohjc2q/lpuVRW5O3WOPOU5ujn1xOye7/v21z9G9bXMGd20d2GuT9BZPUfcANh1zuxQ4t/6DzGwCMAGgd+/eJxWmf17LQH9QJTr+rjCPFmLWMZ8fe1/d147ezqkrwWMLs0lO/SL+a3HmZpumWUlZca1Rx8PdpwPTAQoKChrxD8K/mnbDiETFERFJG/Gc9bEZ6HXM7Z51XxMRkSSIp6g/BQaaWV8zawLcALwRbCwRETmqwaUPd682s3uAd6g9Pe8pd18eeDIREQHiXKN29z8Cfww4i4iIHIfemSgiEnEqahGRiFNRi4hEnIpaRCTizP2k3pty4oOalQEbTvLbOwE7ExgnFeg1p79Me72g19xYfdz9uL8DN5CiPhVmVujuBWHnSCa95vSXaa8X9JoTSUsfIiIRp6IWEYm4KBb19LADhECvOf1l2usFveaEidwatYiI/K0oTtQiInIMFbWISMRFpqjN7HIz+9zMVpvZj8LOkwxm9pSZ7TCzZWFnSQYz62Vmc81shZktN7PJYWcKmpk1M7NPzGxJ3Wv+l7AzJYuZZZvZIjN7M+wsyWBm683sMzNbbGaFCT12FNao6y6gW8wxF9AFbkz3C+ia2UXAQeAZdz8j7DxBM7NuQDd3X2hmrYEi4Op0/v/Zaq//1dLdD5pZLvAhMNndPw45WuDM7AdAAdDG3a8MO0/QzGw9UODuCX+TT1Qm6i8uoOvulcDRC+imNXf/ANgddo5kcfet7r6w7vMDwEpqr8mZtrzWwbqbuXUf4U9HATOznsAVwJNhZ0kHUSnq411AN61/gDOdmeUDI4AFIUcJXN0SwGJgBzDL3dP+NQPTgPuBTLpatQPvmllR3cW+EyYqRS0ZxMxaAa8AU9x9f9h5gubuNe4+nNrrjZ5jZmm9zGVmVwI73L0o7CxJdoG7jwS+Btxdt7SZEFEpal1AN0PUrdO+Asxw91fDzpNM7r4XmAtcHnKUoJ0PXFW3ZjsTGGtmz4UbKXjuvrnuf3cAr1G7pJsQUSlqXUA3A9RtrP0OWOnuvwk7TzKYWZ6Ztav7vDm1G+arQg0VMHf/sbv3dPd8an+W57j7zSHHCpSZtazbIMfMWgKXAQk7mysSRe3u1cDRC+iuBF7MhAvomtkLwF+AwWZWama3h50pYOcDt1A7YS2u+/h62KEC1g2Ya2ZLqR1IZrl7RpyulmG6AB+a2RLgE+Atd387UQePxOl5IiLy5SIxUYuIyJdTUYuIRJyKWkQk4lTUIiIRp6IWEYk4FbWISMSpqEVEIu7/A2Wr9ZW2IuQkAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing = []\n",
    "\n",
    "for n in [3, 10, 50, 100, 500, 1000]:\n",
    "    line = FC(n)\n",
    "    list_of_sing.append(max_singular_value(line.w))\n",
    "    \n",
    "plt.plot(list_of_sing)\n",
    "print([x**2 for x in list_of_sing])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "feb4044f",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def avg_eigen_value(matrix):\n",
    "    singular_values = np.linalg.eig(matrix)[0] \n",
    "    return sum([x**2 for x in singular_values]) / len(singular_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "92988304",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.3333333517914371, 0.33333335194419816, 0.3333333528721419, 0.3333333519277418, 0.3333333525294497]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing = []\n",
    "\n",
    "for n in [10, 50, 100, 500, 1000]:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing.append(avg_eigen_value(ring.w))\n",
    "    \n",
    "plt.plot(list_of_sing)\n",
    "print(list_of_sing)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "fbb7cad9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.35555557399262444, 0.3377777998848531, 0.33555557587508617, 0.33377779864375506, 0.33355557620457377]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing = []\n",
    "\n",
    "for n in [10, 50, 100, 500, 1000]:\n",
    "    line = Line(n)\n",
    "    list_of_sing.append(avg_eigen_value(line.w))\n",
    "    \n",
    "plt.plot(list_of_sing)\n",
    "print(list_of_sing)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "22bc07a2",
   "metadata": {},
   "source": [
    "# 仮に理論がうまく行ったときどの程度改善するのか？\n",
    "$ \\frac{1}{p} := (\\frac{1}{1 - \\lambda_{max}^2})$ vs $\\frac{1}{n} \\sum \\frac{1}{1 - \\lambda_i^2}$\n",
    "\n",
    "下の実験だと、ringのとき、$O(n^2)$ が $O(n)$ になるぐらいか？"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7b21c082",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def test1(matrix):\n",
    "    singular_values = np.linalg.eig(matrix)[0] \n",
    "    #singular_values = np.linalg.svd(matrix, compute_uv=False)\n",
    "    \n",
    "    \"\"\"\n",
    "    if len(singular_values) <= 4:\n",
    "        print(sorted(singular_values))\n",
    "    else:\n",
    "        print(sorted(singular_values)[:5], \" ... \", sorted(singular_values)[-3:])\n",
    "    \"\"\" \n",
    "    return sum(v**2 / (1 - v**2) for v in sorted(singular_values)[:-1]) / len(singular_values)\n",
    "\n",
    "def test2(matrix):\n",
    "    singular_values = np.linalg.eig(matrix)[0] \n",
    "    #singular_values = np.linalg.svd(matrix, compute_uv=False)\n",
    "    \n",
    "    \"\"\"\n",
    "    if len(singular_values) <= 4:\n",
    "        print(sorted(singular_values))\n",
    "    else:\n",
    "        print(sorted(singular_values)[:5], \" ... \", sorted(singular_values)[-3:])\n",
    "    \"\"\" \n",
    "    return max([v**2 / (1 - v**2) for v in sorted(singular_values)[:-1]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20ed1e59",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "83800368",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10, 50, 100, 500, 1000]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(test2(ring.w))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"o\")\n",
    "plt.title(r\"Ring: $\\frac{1 - p}{p}$\", fontsize=15)\n",
    "plt.xlabel(\"# Nodes\", fontsize=15)\n",
    "plt.savefig(\"pic/ring_spectral_gap.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "c7661b7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10, 50, 100, 500, 1000]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(test1(ring.w))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"x\")\n",
    "plt.title(r\"Ring: $\\sum_{i=2}^n \\frac{\\lambda_i^2}{1 - \\lambda_i^2}$\", fontsize=15)\n",
    "plt.xlabel(\"# Nodes\", fontsize=15)\n",
    "plt.savefig(\"pic/ring_average_spectral_gap.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "60236d23",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/yuki/.pyenv/versions/3.8.5/envs/base/lib/python3.8/site-packages/matplotlib/cbook/__init__.py:1333: ComplexWarning: Casting complex values to real discards the imaginary part\n",
      "  return np.asarray(x, float)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "#node_list = [10, 50, 100, 500, 1000]\n",
    "node_list = []\n",
    "for n in [10, 20, 30, 40, 50]:\n",
    "    ring = Torus(n, n)\n",
    "    node_list.append(n**2)\n",
    "    list_of_sing_1.append(test2(ring.w_list[0]))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"o\")\n",
    "plt.title(r\"Torus: $\\frac{1 - p}{p}$\", fontsize=15)\n",
    "plt.xlabel(\"# Nodes\", fontsize=15)\n",
    "plt.savefig(\"pic/torus_spectral_gap.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "bab60733",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/yuki/.pyenv/versions/3.8.5/envs/base/lib/python3.8/site-packages/matplotlib/cbook/__init__.py:1333: ComplexWarning: Casting complex values to real discards the imaginary part\n",
      "  return np.asarray(x, float)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "#node_list = [10, 50, 100, 500, 1000]\n",
    "node_list = []\n",
    "for n in [10, 20, 30, 40, 50]:\n",
    "    ring = Torus(n, n)\n",
    "    node_list.append(n**2)\n",
    "    list_of_sing_1.append(test1(ring.w_list[0]))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"x\")\n",
    "plt.title(r\"Torus: $\\sum_{i=2}^n \\frac{\\lambda_i^2}{1 - \\lambda_i^2}$\", fontsize=15)\n",
    "plt.xlabel(\"# Nodes\", fontsize=15)\n",
    "plt.savefig(\"pic/torus_average_spectral_gap.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "941d45bb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "c32ceb7d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.7455146357506042, 5.695539019685898, 11.939509895373801, 61.93986569383694, 124.70957130958041]\n",
      "[4.1940496877335915, 95.36498504461855, 380.34114777770037, 9500.372316884812, 38130.286365275504]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10, 50, 100, 500, 1000]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(test1(ring.w))\n",
    "    list_of_sing_2.append(test2(ring.w))\n",
    "    \n",
    "plt.plot(node_list, list_of_sing_1)\n",
    "plt.plot(node_list, list_of_sing_2)\n",
    "print(list_of_sing_1)\n",
    "print(list_of_sing_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9774463e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x76e1f87cd3d0>]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(node_list, list_of_sing_1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea8a81f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "7318975e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.10317460675300313, 0.20182293930298068, (0.26909093464887973+0j), 0.48459392095625775, 0.7077701349535744, (0.8837772202552264+6.162975822039155e-37j), (1.1587612271245014+0j)]\n",
      "[1.1904761972340867, 1.5625000698491975, (2.0991065314922452+0j), 5.605167664517947, 16.67519773781609, (40.03913028130084+0j), (158.77427190007478+0j)]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [3**2, 4**2, 5**2, 3**4, 4**4, 5**4, 50**2]\n",
    "\n",
    "for n in [3, 4, 5, 9, 16, 25, 50]:\n",
    "    ring = Torus(n, n)\n",
    "    list_of_sing_1.append(test1(ring.w_list[0]))\n",
    "    list_of_sing_2.append(test2(ring.w_list[0]))\n",
    "    \n",
    "plt.plot(node_list, list_of_sing_1)\n",
    "plt.plot(node_list, list_of_sing_2)\n",
    "print(list_of_sing_1)\n",
    "print(list_of_sing_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "e0714ff0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x76e1f81fae50>]"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(node_list, list_of_sing_1, marker=\"o\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "87f8b6bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[(0.03725481998510861+0j), (0.008553142553996666+0j), (0.013176780845039695+0j), (0.005376060424563524+0j), (0.005861022899890268+0j)]\n",
      "[(1.5625000698491975+0j), (2.0416667680773535+0j), (2.2857142857142856+0j), (2.777777924949749+0j), (3.0250008113684714+0j)]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10, 50, 100, 500, 1000]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = ExponentialGraph(n)\n",
    "    list_of_sing_1.append(test1(ring.w_list[0]))\n",
    "    list_of_sing_2.append(test2(ring.w_list[0]))\n",
    "    \n",
    "plt.plot(node_list, list_of_sing_1)\n",
    "plt.plot(node_list, list_of_sing_2)\n",
    "print(list_of_sing_1)\n",
    "print(list_of_sing_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "0d3f5baf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x76e1f83f6eb0>]"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(node_list, list_of_sing_1, marker=\"o\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7516683f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
