{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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,
   "metadata": {},
   "outputs": [],
   "source": [
    "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 kRing():\n",
    "    def __init__(self, n_nodes, k):\n",
    "        self.w = torch.zeros((n_nodes, n_nodes))\n",
    "\n",
    "        for i in range(n_nodes):\n",
    "            self.w[i,i] = 1/ (2*k + 1)\n",
    "            for j in range(k+1):\n",
    "                self.w[i, (i+j)%n_nodes] = 1 / (2*k + 1)\n",
    "                self.w[i, (i-j)%n_nodes] = 1 / (2*k + 1)\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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4\n",
    "alpha = 0 #0.1\n",
    "\n",
    "class SyntheticGraph():\n",
    "    def __init__(self, n, alpha):\n",
    "        ring = Line(n)\n",
    "        w = alpha*ring.w + (1 - alpha) * torch.ones((n, n)) / n #alpha*torch.eye(n) + (1 - alpha) * torch.ones((n, n)) / n\n",
    "        self.w = torch.block_diag(ring.w, w)\n",
    "\n",
    "        self.w[n-1, n-1] -= 0.1\n",
    "        self.w[n-1, n] += 0.1\n",
    "        self.w[n, n-1] += 0.1\n",
    "        self.w[n, n] -= 0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4\n",
    "alpha = 0 #0.1\n",
    "\n",
    "class SyntheticGraph():\n",
    "    def __init__(self, n, alpha):\n",
    "        ring = Ring(n)\n",
    "        w = alpha*Ring(n).w + (1 - alpha) * torch.ones((n, n)) / n #alpha*torch.eye(n) + (1 - alpha) * torch.ones((n, n)) / n\n",
    "        self.w = torch.block_diag(ring.w, w)\n",
    "\n",
    "        self.w[n-1, n-1] -= 10**(-3)\n",
    "        self.w[n-1, n] += 10**(-3)\n",
    "        self.w[n, n-1] += 10**(-3)\n",
    "        self.w[n, n] -= 10**(-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def calc_average_spectral_gap(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 calc_spectral_gap(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": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def max_eigenvalue_and_vector(matrix):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    return eigenvalues\n",
    "\n",
    "def generate_graph(matrix, b):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v**2 == sorted([v**2 for v in eigenvalues])[-1]:\n",
    "            new_eigenvalues.append(v)\n",
    "        elif v**2 == sorted([v**2 for v in eigenvalues])[-2] and counter:\n",
    "            new_eigenvalues.append(v)\n",
    "            counter = False\n",
    "        else:\n",
    "            new_eigenvalues.append(b)\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed\n",
    "\n",
    "\n",
    "def generate_graph2(matrix, spectral_gap, average_spectral_gap):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    \n",
    "    second_largest_eig = math.sqrt(spectral_gap / (1 + spectral_gap))\n",
    "    print(second_largest_eig)\n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v**2 == sorted([v**2 for v in eigenvalues])[-1]:\n",
    "            new_eigenvalues.append(v)\n",
    "        elif v**2 == sorted([v**2 for v in eigenvalues])[-2] and counter:\n",
    "            new_eigenvalues.append(second_largest_eig)\n",
    "            counter = False\n",
    "        else:\n",
    "            alpha = average_spectral_gap - second_largest_eig**2 / (1 - second_largest_eig**2) / len(eigenvalues)\n",
    "            new_eigenvalues.append(math.sqrt(len(eigenvalues) * alpha / (len(eigenvalues) * (1 + alpha) - 2)))\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_graph3(matrix, average_spectral_gap):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    n_nodes = len(eigenvalues)\n",
    "\n",
    "    spectral_gap = calc_spectral_gap(matrix)\n",
    "    \n",
    "    eig = (average_spectral_gap * n_nodes - spectral_gap) / ((1 + average_spectral_gap) * n_nodes - 2 - spectral_gap)\n",
    "    \n",
    "    if eig < 0 or eig >= 1 or average_spectral_gap > spectral_gap:\n",
    "        print(\"ERROR\")\n",
    "    eig = math.sqrt(eig)\n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v**2 == sorted([v**2 for v in eigenvalues])[-1]:\n",
    "            new_eigenvalues.append(v)\n",
    "        elif v**2 == sorted([v**2 for v in eigenvalues])[-2] and counter:\n",
    "            new_eigenvalues.append(v)\n",
    "            counter = False\n",
    "        else:\n",
    "            new_eigenvalues.append(eig)\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_graph4(matrix, average_spectral_gap):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    n_nodes = len(eigenvalues)\n",
    "\n",
    "    spectral_gap = calc_spectral_gap(matrix)\n",
    "    \n",
    "    eig = (average_spectral_gap * n_nodes - spectral_gap) / ((0.5 + average_spectral_gap) * n_nodes - 2 - spectral_gap)\n",
    "    \n",
    "    if eig < 0 or eig >= 1 or average_spectral_gap > spectral_gap:\n",
    "        print(\"ERROR\")\n",
    "    eig = math.sqrt(eig)\n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    counter2 = 0\n",
    "\n",
    "    for v in eigenvalues:\n",
    "        if v**2 == sorted([v**2 for v in eigenvalues])[-1]:\n",
    "            new_eigenvalues.append(v)\n",
    "        elif v**2 == sorted([v**2 for v in eigenvalues])[-2] and counter:\n",
    "            new_eigenvalues.append(v)\n",
    "            counter = False\n",
    "        elif counter2 < (0.5*n_nodes-2):\n",
    "            new_eigenvalues.append(eig)\n",
    "            counter2 += 1\n",
    "        else:\n",
    "            new_eigenvalues.append(0)\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8 (7.999998282508078+0j) (252.70514013340852+0j)\n",
      "27 (26.999998333718132+0j) (252.7051401342589+0j)\n",
      "64 (63.999998600330464+0j) (252.70514013587393+0j)\n",
      "125 (124.9999995214865+0j) (252.70514014062607+0j)\n",
      "216 (216.0000020102505+0j) (252.70514017810734+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [8, 27, 64, 125, 216]:\n",
    "    \n",
    "    w = generate_graph3(kRing(n, 3).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27 (26.999908842825253+0j) (2687.8882638857003+0j)\n",
      "64 (63.9999049644369+0j) (2687.888263829511+0j)\n",
      "125 (124.99988887237193+0j) (2687.8882637380025+0j)\n",
      "216 (215.99984242573333+0j) (2687.8882635517753+0j)\n",
      "1331 (1330.997091087128+0j) (2689.168189519813+0.11098325801791588j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [27, 64, 125, 216,1331]:\n",
    "    \n",
    "    w = generate_graph4(Line(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1, 8, 27, 64, 125, 216, 343, 512, 729, 1000, 1331]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[v**3 for v in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8 (7.999998282508078+0j) (252.70514013340852+0j)\n",
      "27 (26.999998333718132+0j) (252.7051401342589+0j)\n",
      "64 (63.999998600330464+0j) (252.70514013587393+0j)\n",
      "125 (124.9999995214865+0j) (252.70514014062607+0j)\n",
      "216 (216.0000020102505+0j) (252.70514017810734+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [8, 27, 64, 125, 216]:\n",
    "    \n",
    "    w = generate_graph3(kRing(n, 3).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8 (7.999901633333563+0j) (1519.181083401793+0j)\n",
      "27 (26.999901987110754+0j) (1519.181083424371+0j)\n",
      "64 (63.9999045303598+0j) (1519.1810834484884+0j)\n",
      "125 (124.99991407366156+0j) (1519.1810835080119+0j)\n",
      "216 (215.99994069005393+0j) (1519.1810836060206+0j)\n",
      "343 (343.0000026154366+0j) (1519.1810837584214+0j)\n",
      "512 (512.0001297931893+0j) (1519.1810840267904+0j)\n",
      "729 (729.0003680638142+0j) (1519.1810845381285+0j)\n",
      "1000 (1000.000784001519+0j) (1519.1810857891496+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [8, 27, 64, 125, 216, 343, 512, 729, 1000]:\n",
    "    \n",
    "    w = generate_graph3(Ring(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27 (26.99990896241896+0j) (2687.8882638198784+0j)\n",
      "64 (63.99990665234962+0j) (2687.8882637219485+0j)\n",
      "125 (124.99989711252414+0j) (2687.888263530905+0j)\n",
      "216 (215.9998696192651+0j) (2687.8882632034015+0j)\n",
      "343 (342.99980470380655+0j) (2687.888262726595+0j)\n",
      "512 (511.9996703522133+0j) (2687.888262011385+0j)\n",
      "729 (728.9994175140497+0j) (2687.888260876361+0j)\n",
      "1000 (999.9989749114451+0j) (2687.888259083119+0j)\n",
      "1331 (1330.9982431608346+0j) (2687.8882558939736+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [27, 64, 125, 216, 343, 512, 729, 1000, 1331]:\n",
    "    \n",
    "    w = generate_graph3(Line(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.125, 1, 3.375, 8, 15.625, 27]"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[v**3 for v in [0.5, 1, 1.5, 2, 2.5, 3]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 (0.9999999535234869+0j) (39.03912090771914+0j)\n",
      "3.375 (3.3749999567248565+0j) (39.0391209077227+0j)\n",
      "8 (7.999999971731609+0j) (39.039120907727145+0j)\n",
      "15.625 (15.625000021782476+0j) (39.03912090774014+0j)\n",
      "27 (27.000000155012664+0j) (39.039120907781964+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [1, 3.375, 8, 15.625, 27]:\n",
    "    \n",
    "    w = generate_graph3(Torus(8, 25).w_list[0], b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_graph2(matrix, inverse_p, average_spectral_gap):\n",
    "    \"\"\"\n",
    "    spectral_gap: (1 - p) / p\n",
    "    average_spectral_gap: 1/n \\sum (\\lambda_i^2) / (1 - \\lambda_i^2)\n",
    "    \"\"\"\n",
    "    \n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "\n",
    "    second_largest_eig = 1 - 1/inverse_p \n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v**2 == sorted([v**2 for v in eigenvalues])[-1]:\n",
    "            new_eigenvalues.append(v)\n",
    "        elif v**2 == sorted([v**2 for v in eigenvalues])[-2] and counter:\n",
    "            new_eigenvalues.append(second_largest_eig)\n",
    "            counter = False\n",
    "        else:\n",
    "            alpha = average_spectral_gap - second_largest_eig**2 / (1 - second_largest_eig**2) / len(eigenvalues)\n",
    "            new_eigenvalues.append(math.sqrt(len(eigenvalues) * alpha / (len(eigenvalues) * (1 + alpha) - 2)))\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100.00000852565222+0j) (100.50931779956618+0j)\n",
      "(100.000007160736+0j) (199.24997300185652+0j)\n",
      "(100.00000494439337+0j) (299.24944311572233+0j)\n",
      "(100.00000187664601+0j) (399.2487950838469+0j)\n",
      "(99.99999795749478+0j) (499.2479975556261+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "average_spectral_gap = 100\n",
    "\n",
    "for second_largest_eig in [200, 400, 600, 800, 1000]:\n",
    "    ring_w = Ring(n).w\n",
    "    w = generate_graph2(ring_w, second_largest_eig, average_spectral_gap)\n",
    "    \n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.set_default_dtype(torch.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100.00000241132012+0j) (100.50945847210727+0.00012453979200947288j)\n",
      "(100.00000148626708+0j) (199.2500736223308+0j)\n",
      "(99.99999996169065+0j) (299.2496697002856+0j)\n",
      "(99.99999783757299+0j) (399.249198068201+0j)\n",
      "(99.99999511389497+0j) (499.2486273748139+0j)\n",
      "(99.99999179070137+0j) (599.2479471802237+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "average_spectral_gap = 100\n",
    "\n",
    "for second_largest_eig in [200, 400, 600, 800, 1000, 1200]:\n",
    "    ring_w = Torus(8, 25).w_list[0]\n",
    "    w = generate_graph2(ring_w, second_largest_eig, average_spectral_gap)\n",
    "    \n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "以下の結果が良さそう？"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.3 (3.890367996430049+0j) (379.34449198448283+0j)\n",
      "0.97 (19.39550838022576+0j) (379.344491984001+0j)\n",
      "0.99 (52.0596683819025+0j) (379.3444919829731+0j)\n",
      "0.995 (101.05902802413273+0j) (379.34449198104585+0j)\n",
      "0.998 (248.05849626494376+0j) (379.34449196604515+0j)\n",
      "0.9976 (207.22527134065498+0j) (379.3444919727425+0j)\n"
     ]
    }
   ],
   "source": [
    "n=100\n",
    "\n",
    "for b in [0.3, 0.97, 0.99, 0.995, 0.998, 0.9976]:\n",
    "    \n",
    "    w = generate_graph(Ring(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.33333334, -0.33201784, -0.33201784, -0.32807648, -0.32807648, -0.32152483, -0.32152483, -0.31238878, -0.31238878, -0.30070436, -0.30070436, -0.28651768, -0.28651768, -0.2698847, -0.2698847, -0.25087112, -0.25087112, -0.22955196, -0.22955196, -0.20601134, -0.20601134, -0.18034217, -0.18034217, -0.15264575, -0.15264575, -0.12303141, -0.12303141, -0.091616, -0.091616, -0.058523502, -0.058523502, -0.023884531, -0.023884531, 0.012164217, 0.012164217, 0.049480475, 0.049480475, 0.08791697, 0.08791697, 0.127322, 0.127322, 0.16754007, 0.16754007, 0.20841247, 0.20841247, 0.24977785, 0.24977785, 0.291473, 0.291473, 0.33333334, 0.33333334, 0.3751937, 0.3751937, 0.41688883, 0.41688883, 0.45825422, 0.45825422, 0.4991266, 0.4991266, 0.53934467, 0.53934467, 0.5787497, 0.5787497, 0.6171862, 0.6171862, 0.65450245, 0.65450245, 0.6905512, 0.6905512, 0.72519016, 0.72519016, 0.75828266, 0.75828266, 0.7896981, 0.7896981, 0.81931245, 0.81931245, 0.8470088, 0.8470088, 0.87267804, 0.87267804, 0.89621866, 0.89621866, 0.9175378, 0.9175378, 0.9365514, 0.9365514, 0.95318437, 0.95318437, 0.96737105, 0.96737105, 0.97905546, 0.97905546, 0.98819155, 0.98819155, 0.99474317, 0.99474317, 0.9986845, 0.9986845, 1.0]\n"
     ]
    }
   ],
   "source": [
    "w = Ring(n).w\n",
    "print(sorted(max_eigenvalue_and_vector(w)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 (7.59590541706028+0j) (1519.1810834120558+0j)\n",
      "0.96 (19.23345656900544+0j) (1519.1810834151347+0j)\n",
      "0.98 (31.605905954324516+0j) (1519.1810834218054+0j)\n",
      "0.99 (56.35465130681528+0j) (1519.1810834531066+0j)\n",
      "0.991 (61.854526884718375+0j) (1519.1810834541327+0j)\n",
      "0.992 (68.72940279221561+0j) (1519.1810834602904+0j)\n",
      "0.993 (77.56856486815325+0j) (1519.1810834674743+0j)\n",
      "0.994 (89.35415620651378+0j) (1519.1810834803027+0j)\n",
      "0.995 (105.85403444608313+0j) (1519.1810834910784+0j)\n",
      "0.996 (130.6039150606092+0j) (1519.1810835146825+0j)\n",
      "0.997 (171.8538015184891+0j) (1519.1810835567596+0j)\n",
      "0.998 (254.3537078803787+0j) (1519.1810836480975+0j)\n",
      "0.999 (501.85374831130247+0j) (1519.1810840108833+0j)\n",
      "0.9991 (556.8537873418492+0j) (1519.1810841109445+0j)\n",
      "0.9992 (625.6038468423333+0j) (1519.1810842574444+0j)\n",
      "0.9993 (713.9967964598723+0j) (1519.181084497591+0j)\n",
      "0.9994 (831.8540885022959+0j) (1519.1810849004012+0j)\n",
      "0.9995 (996.8543440935075+0j) (1519.181085767598+0j)\n",
      "0.9996 (1244.3548250581985+0j) (1519.18108909322+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [0,0.96,0.98,0.99,0.991,0.992,0.993,0.994,0.995,0.996,0.997,0.998,0.999,0.9991,0.9992,0.9993,0.9994,0.9995,0.9996]:\n",
    "    \n",
    "    w = generate_graph(Ring(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.33333334, -0.3330044, -0.3330044, -0.33201784, -0.33201784, -0.33037466, -0.33037466, -0.32807648, -0.32807648, -0.32512558, -0.32512558, -0.32152483, -0.32152483, -0.31727785, -0.31727785, -0.31238878, -0.31238878, -0.30686247, -0.30686247, -0.30070436, -0.30070436, -0.29392052, -0.29392052, -0.28651768, -0.28651768, -0.2785031, -0.2785031, -0.2698847, -0.2698847, -0.26067102, -0.26067102, -0.25087112, -0.25087112, -0.2404947, -0.2404947, -0.22955196, -0.22955196, -0.21805373, -0.21805373, -0.20601134, -0.20601134, -0.19343668, -0.19343668, -0.18034217, -0.18034217, -0.16674072, -0.16674072, -0.15264575, -0.15264575, -0.1380712, -0.1380712, -0.12303141, -0.12303141, -0.10754125, -0.10754125, -0.091616, -0.091616, -0.07527137, -0.07527137, -0.058523502, -0.058523502, -0.04138892, -0.04138892, -0.023884531, -0.023884531, -0.0060276105, -0.0060276105, 0.012164217, 0.012164217, 0.030673001, 0.030673001, 0.049480475, 0.049480475, 0.06856807, 0.06856807, 0.08791697, 0.08791697, 0.107508056, 0.107508056, 0.127322, 0.127322, 0.14733927, 0.14733927, 0.16754007, 0.16754007, 0.1879045, 0.1879045, 0.20841247, 0.20841247, 0.22904369, 0.22904369, 0.24977785, 0.24977785, 0.27059448, 0.27059448, 0.291473, 0.291473, 0.31239283, 0.31239283, 0.33333334, 0.33333334, 0.35427386, 0.35427386, 0.3751937, 0.3751937, 0.3960722, 0.3960722, 0.41688883, 0.41688883, 0.437623, 0.437623, 0.45825422, 0.45825422, 0.47876218, 0.47876218, 0.4991266, 0.4991266, 0.5193274, 0.5193274, 0.53934467, 0.53934467, 0.5591586, 0.5591586, 0.5787497, 0.5787497, 0.59809864, 0.59809864, 0.6171862, 0.6171862, 0.63599366, 0.63599366, 0.65450245, 0.65450245, 0.6726943, 0.6726943, 0.6905512, 0.6905512, 0.7080556, 0.7080556, 0.72519016, 0.72519016, 0.74193805, 0.74193805, 0.75828266, 0.75828266, 0.77420795, 0.77420795, 0.7896981, 0.7896981, 0.80473787, 0.80473787, 0.81931245, 0.81931245, 0.8334074, 0.8334074, 0.8470088, 0.8470088, 0.86010337, 0.86010337, 0.87267804, 0.87267804, 0.8847204, 0.8847204, 0.89621866, 0.89621866, 0.90716136, 0.90716136, 0.9175378, 0.9175378, 0.9273377, 0.9273377, 0.9365514, 0.9365514, 0.9451698, 0.9451698, 0.95318437, 0.95318437, 0.9605872, 0.9605872, 0.96737105, 0.96737105, 0.97352916, 0.97352916, 0.97905546, 0.97905546, 0.98394454, 0.98394454, 0.98819155, 0.98819155, 0.99179226, 0.99179226, 0.99474317, 0.99474317, 0.99704134, 0.99704134, 0.9986845, 0.9986845, 0.99967104, 0.99967104, 1.0]\n"
     ]
    }
   ],
   "source": [
    "w = Ring(n).w\n",
    "print(sorted(max_eigenvalue_and_vector(w)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.33325067, -0.33300275, -0.33258954, -0.33201122, -0.33126792, -0.33035982, -0.32928714, -0.32805014, -0.32664913, -0.32508445, -0.32335654, -0.32146576, -0.31941262, -0.3171976, -0.31482127, -0.31228423, -0.3095871, -0.3067305, -0.3037152, -0.30054194, -0.2972115, -0.2937247, -0.2900824, -0.28628552, -0.28233498, -0.27823177, -0.2739769, -0.26957145, -0.2650165, -0.26031315, -0.25546262, -0.25046605, -0.24532475, -0.24003993, -0.23461294, -0.22904512, -0.22333784, -0.21749252, -0.21151061, -0.2053936, -0.19914299, -0.19276035, -0.18624724, -0.17960529, -0.17283615, -0.1659415, -0.15892303, -0.15178251, -0.14452168, -0.13714236, -0.12964638, -0.12203558, -0.11431187, -0.10647715, -0.09853337, -0.0904825, -0.08232654, -0.0740675, -0.06570744, -0.057248425, -0.048692558, -0.04004196, -0.03129877, -0.022465168, -0.013543334, -0.0045354837, 0.004556149, 0.013729309, 0.022981722, 0.032311097, 0.041715115, 0.051191445, 0.06073774, 0.07035163, 0.08003074, 0.08977266, 0.09957497, 0.109435245, 0.119351044, 0.1293199, 0.13933936, 0.14940691, 0.15952007, 0.16967635, 0.1798732, 0.1901081, 0.20037852, 0.2106819, 0.2210157, 0.23137736, 0.2417643, 0.25217396, 0.2626037, 0.27305102, 0.28351328, 0.2939879, 0.30447227, 0.3149638, 0.32545987, 0.33595788, 0.34645528, 0.3569494, 0.36743766, 0.3779175, 0.38838625, 0.39884135, 0.4092802, 0.41970024, 0.43009886, 0.44047347, 0.45082152, 0.46114042, 0.47142765, 0.48168063, 0.49189684, 0.5020737, 0.51220876, 0.5222994, 0.5323432, 0.5423377, 0.5522803, 0.56216866, 0.57200027, 0.5817727, 0.59148353, 0.6011303, 0.6107107, 0.6202223, 0.62966275, 0.63902974, 0.6483209, 0.657534, 0.6666667, 0.6666667, 0.6757167, 0.68468183, 0.6935598, 0.7023485, 0.7110457, 0.71964914, 0.72815686, 0.73656666, 0.74487644, 0.75308424, 0.7611879, 0.7691855, 0.77707493, 0.7848544, 0.7925219, 0.80007553, 0.8075134, 0.8148337, 0.8220346, 0.8291143, 0.8360711, 0.8429032, 0.84960896, 0.8561867, 0.8626348, 0.86895156, 0.8751356, 0.88118523, 0.887099, 0.8928755, 0.89851326, 0.90401083, 0.9093669, 0.9145801, 0.9196492, 0.9245729, 0.92934996, 0.9339793, 0.93845963, 0.9427899, 0.9469691, 0.9509961, 0.9548699, 0.9585896, 0.96215427, 0.965563, 0.96881497, 0.97190934, 0.97484535, 0.97762233, 0.9802395, 0.98269624, 0.98499197, 0.9871261, 0.98909813, 0.99090755, 0.9925539, 0.9940368, 0.99535584, 0.99651074, 0.99750113, 0.9983269, 0.99898773, 0.99948347, 0.99981403, 0.9999794]\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "w = Line(n).w\n",
    "print(sorted(max_eigenvalue_and_vector(w)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 (13.439441319412447+0j) (2687.8882638824894+0j)\n",
      "0.9 (17.659967614079328+0j) (2687.8882638744626+0j)\n",
      "0.99 (62.198182711705144+0j) (2687.8882637187376+0j)\n",
      "0.999 (507.69683043217555+0j) (2687.8882620290447+0j)\n",
      "0.9992 (631.4466735601029+0j) (2687.888261406146+0j)\n",
      "0.9994 (837.69636334906+0j) (2687.8882602197486+0j)\n",
      "0.9996 (1250.1955228692025+0j) (2687.888256813873+0j)\n",
      "0.9998 (2487.6910915034928+0j) (2687.8881558537087+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [0, 0.9,0.99,0.999,0.9992,0.9994,0.9996,0.9998]:\n",
    "    \n",
    "    w = generate_graph(Line(n).w, b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.59684587, -0.59684587, -0.5719106, -0.5719106, -0.5236068, -0.5236068, -0.4796886, -0.4796886, -0.4796886, -0.4796886, -0.4549696, -0.4549696, -0.4547533, -0.4547533, -0.4547533, -0.4547533, -0.40644953, -0.40644953, -0.40644953, -0.40644953, -0.3703117, -0.3703117, -0.3378123, -0.3378123, -0.3378123, -0.3378123, -0.27495253, -0.27495253, -0.25315443, -0.25315443, -0.25315443, -0.25315443, -0.19684589, -0.19684589, -0.19684589, -0.19684589, -0.1748838, -0.1748838, -0.1719106, -0.1719106, -0.1719106, -0.1719106, -0.15779524, -0.15779524, -0.15779524, -0.15779524, -0.1236068, -0.1236068, -0.1236068, -0.1236068, -0.0763932, -0.0763932, -0.057726506, -0.057726506, -0.057726506, -0.057726506, -0.054969598, -0.054969598, -0.054969598, -0.054969598, 0.014330719, 0.014330719, 0.029688284, 0.029688284, 0.029688284, 0.029688284, 0.040764086, 0.040764086, 0.040764086, 0.040764086, 0.08599684, 0.08599684, 0.08599684, 0.08599684, 0.091587454, 0.091587454, 0.11093212, 0.11093212, 0.11093212, 0.11093212, 0.12504748, 0.12504748, 0.12504748, 0.12504748, 0.13148801, 0.13148801, 0.13148801, 0.13148801, 0.15052268, 0.15052268, 0.15923592, 0.15923592, 0.15923592, 0.15923592, 0.18743327, 0.18743327, 0.2, 0.20315412, 0.20315412, 0.20874473, 0.20874473, 0.20874473, 0.20874473, 0.22511621, 0.22511621, 0.22511621, 0.22511621, 0.22787312, 0.22787312, 0.22787312, 0.22787312, 0.2280894, 0.2280894, 0.26767996, 0.26767996, 0.26767996, 0.26767996, 0.2763932, 0.2763932, 0.30459055, 0.30459055, 0.30459055, 0.30459055, 0.312531, 0.312531, 0.312531, 0.312531, 0.3171573, 0.3171573, 0.3236068, 0.3236068, 0.3236068, 0.3236068, 0.3450304, 0.3450304, 0.4078902, 0.4078902, 0.4078902, 0.4078902, 0.41433072, 0.41433072, 0.41433072, 0.41433072, 0.4296883, 0.4296883, 0.49158746, 0.49158746, 0.49158746, 0.49158746, 0.50795895, 0.50795895, 0.50795895, 0.50795895, 0.5250475, 0.5250475, 0.5505227, 0.5505227, 0.5505227, 0.5505227, 0.5874333, 0.5874333, 0.5874333, 0.5874333, 0.6, 0.6, 0.60644954, 0.60644954, 0.60644954, 0.60644954, 0.6251162, 0.6251162, 0.6971734, 0.6971734, 0.6971734, 0.6971734, 0.7236068, 0.7236068, 0.77443016, 0.77443016, 0.77443016, 0.77443016, 0.81433076, 0.81433076, 0.8333654, 0.8333654, 0.8333654, 0.8333654, 0.870276, 0.870276, 0.870276, 0.870276, 0.8828427, 0.8828427, 0.89158744, 0.89158744, 0.95052266, 0.95052266, 0.98743325, 0.98743325, 1.0]\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "w = Torus(8, 25).w_list[0]\n",
    "print(sorted(max_eigenvalue_and_vector(w)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 (0.1951956045386117+0j) (39.03912090772234+0j)\n",
      "0.9 (4.415721926286892+0j) (39.03912090772305+0j)\n",
      "0.92 (5.650508114066022+0j) (39.03912090772341+0j)\n",
      "0.94 (7.7103502610332555+0j) (39.03912090772679+0j)\n",
      "0.98 (24.205195767186037+0j) (39.0391209077663+0j)\n",
      "0.98 (24.205195767186037+0j) (39.0391209077663+0j)\n",
      "0.982 (26.95494353531783+0j) (39.039120907781964+0j)\n",
      "0.984 (30.392191827464977+0j) (39.03912090782148+0j)\n",
      "0.986 (34.811583508659766+0j) (39.03912090796511+0j)\n"
     ]
    }
   ],
   "source": [
    "n=200\n",
    "\n",
    "for b in [0,0.9,0.92,0.94,0.98,0.98,0.982,0.984,0.986]:\n",
    "    \n",
    "    w = generate_graph(Torus(8, 25).w_list[0], b)\n",
    "    #print(w)\n",
    "    #print(max_eigenvalue_and_vector(w))\n",
    "    print(b, calc_average_spectral_gap(w), calc_spectral_gap(w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f6770d00>]"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAARYAAAD4CAYAAAApdMkJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAmSklEQVR4nO3dfXybZ33v8c/Pj4mf5CR27NhO6iTNc+yE1qEUxiiHDkpglEJg7QqsUFYeTjs2zovTcTpaoHSsp7DTDUZZt/YERmiBdutpSwsBRlegLZDSNFbkPD80ke3YcRJJjuMHWb/zh6TEFbb1YEm3ZP3er1dekW7pvvW74+SbW9d13dclqooxxqRTkdMFGGNmHwsWY0zaWbAYY9LOgsUYk3YWLMaYtCtxuoBk1NXVaWtrq9NlGGOAF1988aSq1k/2Wl4FS2trKzt27HC6DGMMICJHp3rNvgoZY9LOgsUYk3YWLMaYtLNgMcaknQWLMSbt4gaLiDwoIn0i4p6w7U4R2SUiO0Vku4g0xeyzSUSCIrJlimNeJyKdkWP8SETqZn4qxphckcgVy1bgqpht96hqu6puBJ4Ebo++ICLFwN3A9skOJiIlwD8Ab1bVdmAXcHPSlRtjclbcYFHVZ4FTMdv8E55WAhPnXrgFeBTom+KQEvlVKSIC1ADdSdRsjMmAkeA4X3zCw8nBkRkfK+U2FhG5S0SOAdcTuWIRkWbgGuC+qfZT1THgE0An4UBZCzwwzefcJCI7RGRHf39/quUaY6YxNh7i5u++xIO/OsxzBwdmfLyUg0VVb1PVxcA2LnyVuRe4VVVDU+0nIqWEg+U1QBPhr0KfneZz7lfVDlXtqK+fdPSwMWYGxsZD/MVDL/ETzwm+ePU63rWhKf5OcaSjV2gb8N7I4w7gYRE5AmwBviEi7455/0YAVT2o4enrvg+8Pg11GGOSFBwP8Vff28nT7l4+9861fOjy1rQcN6V7hURkharujzy9GtgDoKpLJ7xnK/Ckqj4Ws7sXWCsi9araD/wR0JVKHcaY1I2HlM88sosnd/Xw2bev5sY/WBp/pwTFDRYReQi4AqgTkePAHcBmEVkFhICjwMcTOM5OVd2oqt0i8gXgWREZi+x/Q+qnYIxJViik3ProLv7jJS+fedsqPvam5Wk9vuTTZNodHR1qdzcbMzOhkHLbY5089Jtj/OWVK/jLK1emdBwReVFVOyZ7zUbeGlNAVJXbH3fz0G+OcfObL+ZTb1mRkc+xYDGmQKgqX3jCw3deeIWP/eEy/sdbVxIeSpZ+FizGFABV5W+f6mLrc0f4yBuW8tdvX52xUAELFmNmPVXlnh/v5V9+cZg/u/wiPvfONRkNFbBgMWbW+z8/3c83njnIn162hM+/a13GQwUsWIyZ1b72s/3848/28ycdi/nS1euzEipgwWLMrHXfMwf56k/28Z5Lmvnye9ooKspOqIAFizGz0r/+4hB3/2gP79rQxD1bNmQ1VMCCxZhZZ+uvDvOlH3bxjrZF/P37N1Cc5VABCxZjZpXvvHCUzz/h4W3rGrj32o2UFDvzT9yCxZhZ4uHfvMLfPObmyjUL+dp1l1DqUKiABYsxs8IjLx7ns//RyZtW1vNP119CWYmz/7QtWIzJc4+95OUzj7zMG5bX8c8fvJTykmKnS7JgMSafPbmrm09/fyevW7qAf/lQB3NKnQ8VsGAxJm/9yN3Dpx7eScdF83nghg7mluVGqIAFizF56SeeE9z83ZfYuLiWBz+8iYqylCaDzBgLFmPyzM/39PHJbS+yrtnF1g9voqo8t0IFLFiMySvP7uvnY995kVWN1Xz7I6+lek6p0yVNyoLFmDzx3IGT/Pm3d7C8vorv3HgZrrm5GSpgwWJMXvj1oQFu/NYOWhdUsu2jl1FbUeZ0SdPKvS9nxpjzRoLj/OsvDvO1/9xPy7wKtv35ZcyvzO1QAQsWY3KSqvKfe/r44pMejg4M8bZ1Ddz57vXUVZU7XVpCLFiMyTGH+gf54pMentnbz8ULq/i3G1/LG1fk1/LCFizG5IjBkSBf+8/9PPjLw8wpKeZv3rGGP3t9q6M3E6YqkZUQHwTeCfSp6vrItjsJL60aAvqAG1S1e8I+m4DngWtV9ZGY41UDv5iwqQX4jqr+5cxOxZj8pKo8ttPLl5/aQ19ghPdd2sL/vGo19dX58bVnMolcsWwFvg58e8K2e1T1cwAi8hfA7USWWRWRYuBuYPtkB1PVAJGF4SPvfxH49+RLNyb/ub0+7nh8Ny8ePc2GFhf//MFLec2SeU6XNWNxg0VVnxWR1pht/glPK4GJ67TeAjwKbIp3bBFZCSzk1Vcwxsx6A4MjfGX7Ph7+7SssqCzjf29pZ8slLVmfQjJTUm5jEZG7gA8BPuDNkW3NwDWR53GDBbgW+J5Os4C0iNwE3ASwZMmSVMs1JicEx0N854Wj/P1P9jE0Os5H3rCUT125gpocHUGbqpRbhVT1NlVdDGwDbo5svhe4VVVDCR7mWuChOJ9zv6p2qGpHfX1+tYwbM9HzBwd4xz/+ks8/4aG9pZanP/VGPvfOtbMuVCA9vULbgKeAO4AO4OHI2iV1wGYRCarqY7E7icgGoERVX0xDDcbkLO+Zc/ztU138cFcPLfPm8s0PXMrb1jVkbY0fJ6QULCKyQlX3R55eDewBUNWlE96zFXhyslCJuI44VyvG5LPhsXHuf/YQ33jmAKrwV1eu5GNvWpYzkzFlUiLdzQ8BVwB1InKc8JXJZhFZRbi7+SiRHqE4x9mpqhsnbHo/sDmFmo3JaarKds8JvvRDD8dOnWNzWyP/a/MaWuZVOF1a1iTSK3TdJJsfSGC/G2Keb4x5vizeMYzJNwf6AnzhCQ+/2H+SlQ1VfPejl/H6i+ucLivrbOStMWkQGB7jH366n63PHWFuWTF3/PFaPvC6i/Jy1Gw6WLAYMwOhkPLo745z94/2MnB2hD/pWMxn3raKBXlys2CmWLAYk6JQSPngg7/mVwcGeM2SWh68oYP2llqny8oJFizGpOjIwFl+dWCAm998MZ/+o5WzZtRsOhTmF0Bj0qCrJwDAVesbLVRiWLAYkyJPj4+SImFFQ5XTpeQcCxZjUuTp9nPxwqqcWNI011iwGJOirp4AaxfVOF1GTrJgMSYFp86O0usfZo0Fy6QsWIxJQVdPeEqitU0WLJOxYDEmBZ7ucLDYFcvkLFiMSUFXj5/Gmjl5scaPEyxYjEmBp8fPmkXVTpeRsyxYjEnSSHCcA32D1r4yDQsWY5K0/8QgwZBa+8o0LFiMSdL5HiELlilZsBiTJE+Pn7mlxVy0oNLpUnKWBYsxSfJ0+1m9qJpiu/FwShYsxiRBVenq8dvXoDgsWIxJgvfMOfzDQWu4jcOCxZgkROdgsa7m6VmwGJMET7cfEVjdaIPjpmPBYkwSunr8LF1QSUWZzeo6HQsWY5IQHspvX4PiiRssIvKgiPSJiHvCtjtFZJeI7BSR7SLSFLPPJhEJisiWKY5ZJiL3i8g+EdkjIu+d+akYk1mB4TFeOTVk7SsJSOSKZStwVcy2e1S1PbK64ZPA7dEXRKQYuBvYPs0xbwP6VHUlsBb4ryRqNsYRe3rDDbd282F8iSyx+qyItMZs8094WgnohOe3AI8Cm6Y57EeA1ZFjhYCTCdZbcL78dBfzKsr4+JuWO11KwYvOwbJ2kcvhSnJfym0sInKXiBwDridyxSIizcA1wH3T7FcbeXiniPxORH4gIg3TvP8mEdkhIjv6+/tTLTcvqSrf/fUrfO+3x5wuxRBuuJ1XUUpDTWGvcpiIlINFVW9T1cXANuDmyOZ7gVsjVyFTKQFagOdU9RLgeeAr03zO/araoaod9fX1qZabl46dOkdgOMjhk2fxnRtzupyC5+nxs7apBhEbyh9POnqFtgHRxtcO4GEROQJsAb4hIu+Oef8AMAT8e+T5D4BL0lDHrNPp9Z1/vHvCY5N9wfEQe3sDrGm0httEpBQsIrJiwtOrgT0AqrpUVVtVtRV4BPikqj42cV9VVeAJ4IrIprcAnlTqmO3c3b7zN7q9fNyCxUmHT55lJBiyHqEExW28FZGHCIdAnYgcB+4ANovIKiAEHAU+nsBxdkZ6kQBuBf5NRO4F+oEPp1L8bOf2+ljdWI1/eIxO7xmnyyloHpuVPymJ9ApdN8nmBxLY74aY5xsnPD4K/GH88gqXquL2+njr2kYGR4O8fOyM0yUVNE+Pn7LiIpbX23KqibCRtznKe+Ycp4fGWN/ior3ZxfHT5xgYHHG6rILV1RNgRUMVpcX2TyYR9qeUo9ze8KX3+qYa2lrC4yY6rQHXMZ5uG8qfDAuWHOX2hhtu1yyqoa05EizWgOuIvsAwJwdHbHKnJNgtmjnK3e1jxcIq5pQWM6e0mGX1ldYz5JDoHCx2xZI4u2LJQdGG2/XNF4aOtze7rGfIIReG8luwJMqCJQed8I9wcnCU9RO6NttbajnhH+GEf9jBygpTV4+f5tq5uCpKnS4lb1iw5KBoI2200RagPfJ4l30dyjqbgyV5Fiw5yO31USSv/k6/tqmGIoHO42ecK6wADY+Nc6h/kLU2VUJSLFhykNvrY3l91aumP6woK2FlQzW7rMs5q/b2BgipjbhNlgVLDnJ3v7rhNqqt2UXncR/h261MNlxYTtXmYEmGBUuO6QsMc8I/MmmwtLe4GDg7ivfMOQcqK0yeHj9V5SW0zJvrdCl5xYIlx+yeMOI2VntLLWAD5bKpq8fPmkXVFNlyqkmxYMkx0R6hdZNcsaxeVE1psVg7S5aEQkpXT8B6hFJgwZJj3F4fy+oqqSr//UHR5SXFrGqsZpf1DGXFsdNDDI4EbWBcCixYckzsiNtY7S217LIG3KyINtzaFUvyLFhyyMDgCN2+YdY3T/0Xub3ZRWA4yNGBoSxWVpg83X6KBFbZcqpJs2DJIe7IPSnTXbFER+O+bF+HMs7TE2BZffhGUJMcC5Yc4o423DZNHSwrG6opLymynqEs6OrxW/tKiixYcojb6+OiBRW45k59s1tpcRFrm2qsZyjDfENjeM+cs/aVFFmw5BB3t4/101ytRLU3u3B7fYyHrAE3U2zy7JmxYMkRZ4ZGOXbq3LTtK1FtLbUMjYZvjjOZcaFHyBpuU2HBkiN2n2+4jf8/5AabQiHjPD1+6qrKWVg9x+lS8pIFS46IjrhN5KvQsvoqKsqKbaBcBnm6/fY1aAYsWHKE2+ujuXYu8yrL4r63uEhY3+SyBtwMGQ2GONA3aF+DZiBusIjIgyLSJyLuCdvuFJFdIrJTRLaLSFPMPptEJCgiW6Y45jMisjey/04RWTjzU8lvbq/v/Gz8iWhvceHp9jM2HspgVYXpYP8go+Mh62qegUSuWLYCV8Vsu0dV2yOrGz4J3B59QUSKgbuB7XGOe72qboz86ku85NnHPzzGkYGhhNpXotpaXIwEQ+w7EchgZYXpwhwsFiypihssqvoscCpmm3/C00pgYr/nLcCjQEGHRTLOT5WQ1BVLLWBTKGSCp9tPeUkRS+sqnS4lb6XcxiIid4nIMeB6IlcsItIMXAPcl8Ah/m/ka9DnRGTKyS5E5CYR2SEiO/r7+1MtN6ft7o403CYRLK0LKqieU2LtLBnQ1etnVWM1JbacaspS/pNT1dtUdTGwDbg5svle4FZVjffF/3pVbQPeGPn1wWk+535V7VDVjvr6+lTLzWmdXh+LXHOoqypPeB8Rob3FZT1Daaaq4R4h+xo0I+mI5G3AeyOPO4CHReQIsAX4hoi8O3YHVfVGfg8A3wVem4Y68pbb65v2/qCptDXXsrc3wPDYeAaqKkwn/COcHhqzofwzlFKwiMiKCU+vBvYAqOpSVW1V1VbgEeCTqvpYzL4lIlIXeVwKvBNwU6AGR4IcOnk2qR6hqA0tLsbGlb291oCbLp6e8FdLG8MyM3HXbhaRh4ArgDoROQ7cAWwWkVVACDgKfDyB4+yM9CKVAz+OhEox8FPgX1I9gXzX1eNHNbERt7GiUyjs8vrYsLg2zZUVpuhyqqttDpYZiRssqnrdJJsfSGC/G2Keb4z8fha4NLHyZr9or04qVyzNtXOZX1nGrmNn4HUXpbmywtTVE2DJ/Aqq59hyqjNhzd4Oc3f7qK8uZ2FN8vekRBtwO61nKG08NgdLWliwOCzZEbex2ptd7DsR4NyoNeDO1NmRIEcGzlrDbRpYsDjo3Og4B/oGJ11DKFFtLbWE9MJYGJO6Pb0B1JZTTQsLFgd5evyENLmBcbHabQqFtLE5WNLHgsVBqYy4jdVQM4eGmnJrZ0kDT4+fmjklNNfacqozZcHioM7jPhZUlrHINbPJhNqaa23W/jQIL6dawzR3mJgEWbA4yN3tZ12za8Z/kdtbXBzqP0tgeCxNlRWe8ZCypydg7StpYsHikOGxcfafCNCWwsC4WNF2FrfXH+edZipHB85ybmzceoTSxILFIXt7AwRDmtBUlPFEu6vthsTUeWwOlrSyYHGIOw0Nt1ELqspprp1rUyjMgKfbT0mRsKKhyulSZgULFoe4vT5cc0tpmZeeHogNi1026dMMdPX4uXhhFeUltpxqOliwOMTt9dOWhobbqLbmWl45NcTps6NpOV6h8UR6hEx6WLA4YDQYYm9vgHVpaLiNijbg2niW5A0MjnDCP2LtK2lkweKAfScCjI6HZnSPUKxoW40FS/K6esLz2VhXc/pYsDjAncTiZIlyzS1laV0lLx87k7ZjFooLQ/ktWNLFgsUB7m4f1XNKuGhBRVqP29ZsUyikwtPjp7FmDvMTWCzOJMaCxQGdXj/rmtI/dLy9xUWPb5i+wHBajzvbhYfy242H6WTBkmVj4yG6evxpbV+Jiq415LarloQNj4WnrrD2lfSyYMmyA32DjAZDaRkYF2tdUw1FAi8fs2BJ1IG+QYIhtfaVNLNgybLzDbcZCJbK8hIuXlhl7SxJsKH8mWHBkmVur4/KsmKWLsjM8p1tzbXsOu5DVeO/2eDp9jO3tJiLMvTzKFQWLFnm7vazrslFUVFm5vxob3FxcnCEHp814Caiq8fP6kXVFGfo51GoLFiyaDwUXr4znSNuY9lUlYlTVRvKnyEWLFl0qH+Qc2PjGekRilqzqIaSIqHTeyZjnzFbeM+cIzActPaVDIgbLCLyoIj0iYh7wrY7RWSXiOwUke0i0hSzzyYRCYrIljjHfnzicWe7zgw23EbNKS1mZUO1XbEkILrqoXU1p18iVyxbgatitt2jqu2R1Q2fBG6PviAixcDdwPbpDioi7wEGkyk237m9fuaUFrG8PrNzfmxY7LIG3AR09QQQseVUMyFusKjqs8CpmG0T50CsBCb+Db4FeBTom+qYIlIFfBr4UjLF5ju318faRTUZbyhsa67Fd26MY6fOZfRz8p2nx8fSBZVUlMVdadgkKeU2FhG5S0SOAdcTuWIRkWbgGuC+OLvfCXwVGErgc24SkR0isqO/vz/Vch0XCim7u2e26mGiog24NnP/9KzhNnNSDhZVvU1VFwPbgJsjm+8FblXV0FT7ichGYLmq/keCn3O/qnaoakd9fX2q5Tru8MBZzo6Osy4LwbKyoZqy4iIbKDcN/3D4is7aVzIjHdeA24CngDuADuDhyM11dcBmEQmq6mMT3n850CEiRyKfv1BEnlHVK9JQS86KjrjNxhVLWUkRa5pqbHLtaeyJzMFiNx9mRkpXLCKyYsLTq4E9AKq6VFVbVbUVeAT4ZEyooKr3qWpT5D1/AOyb7aEC4WApKyni4oXZmay5vdmF2+snFLIG3Ml0nR/Kn/mgL0SJdDc/BDwPrBKR4yJyI/B3IuIWkV3AW4FPJXCcnTMtNp+5veHv86XF2Rk61NbiYnAkyKGTZ7PyefnG0+1nXkUpDTXlTpcyK8X9KqSq102y+YEE9rsh5vnGSd5zBFgf71j5TlVxd/t414am+G9Okw2RKRQ6vWeydpWUT7p6/azNwJw4JsxG3mbBK6eGCAwHs9K+ErW8vpK5pcU2hcIkguMh9vQGWNNoDbeZYsGSBdkYcRurpLiIdU011jM0icMnzzIaDFmPUAZZsGSB2+untFhY2ZDdHoj2llp2d/sIjk/Z+1+QPDZ5dsZZsGSB2+tjVWM1ZSXZ/eNub3ExPBZif19B3TkRl6fHT1lx5m+tKGQWLBkWbbjNZvtKVFt0ETO7IfFVPN1+VjRUZT3oC4n9yWbY8dPnODM0xro0riGUqKULKqkuL2GXTaHwKl02lD/jLFgybHd39kbcxioqEtY322LxE/UFhjk5OGpzsGSYBUuGdXp9lBQJqxy6Nb+9xUVXT4DRoDXgwoU5WOyKJbMsWDLM7fWzoqGaOaXFjnx+e0sto+PhRejNhHWaLVgyyoIlg1QVt9fHegfHS5yfA9faWYBwj1Bz7VxcFaVOlzKrWbBkUK9/mIGzo+d7Z5zQMm8u8ypK2WUjcAFruM0WC5YMijaaOtEjFCUitLXUsstG4DI8Ns6h/kHW2lQJGWfBkkHubj9F4vz3+fZmF/tOBBgeG3e0Dqft7Q0QUps8OxssWDLI7fVx8cIq5pY503Ab1dbiYjyk7O72x3/zLGZD+bPHgiWD3F5fVm88nMr5KRQKfEY5T7efqvISFs+rcLqUWc+CJUP6/MP0BUZY72D7SlRDTTn11eUF387S1eNndWN1xpa3NRdYsGSIOzri1sEeoSgRob3ZVdCLmIVCSleP39pXssSCJUM6j/uRHGi4jWprcXGwf5DBkaDTpTji2Okhzo6O58zPY7azYMkQd7ePZXWVVJbnxmJYG1pqUYXdBfp1yIbyZ5cFS4bkSsNtVLSWQv061NUT7vp36p6tQmPBkgEnB0fo8Q07ckfzVOqry2lyzSnYBlxPj59l9VWO3bNVaCxYMiC6OJmTI24n095SW7Bdzl09AWtfySILlgyIDkRb15xbf5HbWlwcGRjCNzTmdClZdWZoFO+Zc9a+kkUWLBnQedxH64IKaubk1h200TudC23m/uiIW+tqzp5EVkJ8UET6RMQ9YdudIrJLRHaKyHYRaYrZZ5OIBEVkyxTH/JGIvCwiu0XkmyIyq774urtzq+E2qr25Fii8KRS6bJ3mrEvkimUrcFXMtntUtT2yuuGTwO3RFyIhcTewfZpjvl9VNxBeBbEeeF8SNee0M0OjHD99LieDxVVRykULKgpuCgVPt5+6qnIWVs9xupSCETdYVPVZ4FTMtol3s1UCE1cevwV4FOib5pjR/UuAspj985rbGz61XOoRmqit2VVwX4XCc7DY1Uo2pdzGIiJ3icgx4HoiVywi0gxcA9yXwP4/Jhw+AeCRad53k4jsEJEd/f39qZabNdGh/Oty9Pv8hpZavGfOcXJwxOlSsmI0GGJ/X8DaV7Is5WBR1dtUdTGwDbg5svle4FZVjTtzs6q+DVgElAP/bZr33a+qHaraUV9fn2q5WdPp9bF4/lxqK8qcLmVSbQXWgHuwf5CxcbWu5ixLR6/QNuC9kccdwMMicgTYAnxDRN491Y6qOgz8P+DqNNSRE3Z7fTlxR/NU1je7EKFg2lmiQ/ktWLIrpWARkRUTnl4N7AFQ1aWq2qqqrYS/3nxSVR+L2bdKRBZFHpcA74jun+/8w2McGRjKyYbbqKryEpbXV9FZID1DXT1+ykuKWFpX6XQpBSXuHXIi8hBwBVAnIseBO4DNIrIKCAFHgY8ncJydkV6kSuBxESknHGw/B76Z6gnkkt2RhttcDhYIT1X5ywMnnS4jKzw9flY1VlNSbEO2silusKjqdZNsfiCB/W6Ieb4x8vsJYFNi5eWX6FB+J5f7SERbi4t/f8lLr2+YRtfs7YJVVTw9fq5a1+h0KQXHYjyN3N0+mlxzWFBV7nQp02qPTFW5a5bfN9TrH+bM0JgN5XeABUsadebYVAlTWbuohuIimfU9Q+cbbnP8CnI2smBJk8GRIIdPns2LYJlbVsyKhVW8PMvnZumK3CO02uZgyToLljTxdPtRzd0Rt7E2RKZQUJ01g55/j6fHz5L5FVTn2M2ghcCCJU3Oz8GSY1MlTKWtxcXpoTGOnz7ndCkZ09UTsKH8DrFgSRO310dDTf7c6HZ+sfhZ+nXo7EiQIwNnWbsoP64gZxsLljRxd+f2iNtYqxqrKS2WWTuFwp7eAKo2VYJTLFjSYGg0yIG+wbxouI0qLylmzaKa8wvXzzY2uZOzLFjSoKsnvNh4PgULRKZQOO4jFJp9DbhdPX5q5pTQXDvX6VIKkgVLGkQbbvOlRyiqvcVFINIWMdt4uv2sWVSDiC2n6oTcWE0rz7m9Puqqymioye0Rt7GiI3A7vT6W1Vc5W8wM+YbGeOHwAM8fDP/aeyLAR96w1OmyCpYFSxpER9zm2/+OKxZWUV5SxMvHfFy9sdnpcpIyOBLkt4dP8dzBkzx/aIDdkXFEc0qL2NQ6n3dtbOLaTYudLrNgWbDM0PDYOPv7BrlyTYPTpSStpLiIdU01eTGFwrnRcV48evp8kOw67mM8pJQVF/GaJbV86i0reP3yOjYsdlFeMqvmZs9LFiwztKc3wHhI867hNqq9pZbv/fYY4yGluCh3rrhGguPsfOUMzx0c4PlDA+x85Qyj4yFKioT2FhefeNNyLl++gEsvmmerG+YgC5YZOj9VQp6MuI3V3uJi63NHONg/yMoG58Z8jI2H2HXcxwuHwm0kO46eYngsRJGEe9s+/IZWLl++gE2t86kst7+2uc5+QjPk9vqYV1Gat92a0RG4Lx87k9VgGQ8pnm4/zx86yXMHB/jt4VOcHR0HwjcNXvfaJbx+eR2vXTof11y71yffWLDMUHRxsnxruI1aVldFZVkxnV4f7+vITGOnqtIfGGHviQB7egL85sgpfn1oAP9wEIDl9ZW855IWLl++gMuWzs/5+WxMfBYsMzASHGdvb4CPvnGZ06WkrKhIWN/sSts9Q4MjQfb2BtjbG2DfiQB7ev3s7Q1wesJ60UvmV7C5bRGXL1/A5csWsLAmP+6vMomzYJmB/SfCS0vk0z1Ck2lvcfGt548yGgxRVpLYmMnRYIhDJwfPh8je3gB7egN4z1y4W7qyrJiVjdVctb6RVQ3VrGysZnVjDfMrc3NpFJM+Fiwz0JmnI25jtbfUMho8zL4Tgd/r3QqFFO+Zc+HwOBEOj329AQ72DxKM3ApQUiQsr6/ikovm8aeXLWFVQzWrGqtprp1LUQ71NJnssWCZAbfXR82cEhbPz8+G26hoA+4vD5zEPzx24SrkRDhEoo2qAM21c1ndWM1b1ixkVWM4QJbVVSV8pWMKgwXLDLjzdMRtrCXzK3DNLeXvnr6wvFNtRSmrGqrZcmkLqxprWNVYzcqGKpuNzSTEgiVFY+MhunoD3PD6VqdLmTER4Svv28CRk2dZ1VjN6sZq6qvL8z4wjXMsWFK0/8Qgo8FQ3o64jfVHa/PvlgSTu+J+MRaRB0WkT0TcE7bdKSK7RGSniGwXkaaYfTaJSFBEtkxyvAoR+aGI7BGR3SLyd+k5lexyd+fH4mTGOCGRK5atwNeBb0/Ydo+qfg5ARP4CuJ3IMqsiUgzcDWyf5phfUdWfi0gZ8DMRebuqPp1C/SkZDylj4yGCIWUsGGIsFCI4Ht42Nq4EQyHGghqzfcLjkPJ0Zw9V5SW0LrA1gY2JlcgSq8+KSGvMNv+Ep5XAxCnIbgEeZYplVFV1iPB6zajqqIj8DmhJruypfeGJ3fzXvv5JgiIcCMHxEOmaMO2KVfXWnWrMJFJuYxGRu4APAT7gzZFtzcA1kedx12cWkVrgj4F/mOY9NwE3ASxZsiRuXYtcc1izqIay4iJKioSS4iLKisO/lxRLZPuEx5HXSouE0sjz0uKiC4+LiiiNvuf8a0JJURGLam3EqDGTkUQWrIpcsTypqusnee2zwBxVvUNEfgB8VVVfEJGtkX0emeKYJcATwI9V9d5Eiu3o6NAdO3Yk8lZjTIaJyIuq2jHZa+noFdoGPAXcAXQAD0e6KeuAzSISVNXHJtnvfmB/oqFijMkfKQWLiKxQ1f2Rp1cDewBUdemE92wlfMXy2CT7fwlwAR9N5fONMbktbrCIyEPAFUCdiBwnfGWyWURWASHgKJEeoTjH2amqG0WkBbiNcBj9LnJ183VV/deUz8IYk1MS6RW6bpLNDySw3w0xzzdGfj8OWFeKMbOY3TlmjEk7CxZjTNpZsBhj0s6CxRiTdgkNkMsVItJPuBcqnjrgZIbLySY7n9xWqOdzkarWT/ZCXgVLokRkx1QjAvORnU9us/P5ffZVyBiTdhYsxpi0m63Bcr/TBaSZnU9us/OJMSvbWIwxzpqtVyzGGAdZsBhj0i6vg0VErhKRvSJyQET+epLXy0Xke5HXfx07xWauSeB8Pi0inshE5j8TkYucqDNR8c5nwvveKyIqIjnbZZvIuYjI+yM/n90i8t1s15iMBP6uLRGRn4vIS5G/b5uT+gBVzctfQDFwEFgGlAEvA2tj3vNJ4JuRx9cC33O67hmez5uBisjjT+T7+UTeVw08C7wAdDhd9wx+NiuAl4B5kecLna57hudzP/CJyOO1wJFkPiOfr1heCxxQ1UOqOgo8THjSqYmuBr4VefwI8BbJ3VW44p6Pqv5cw5ORQ/gfYtomIc+ARH4+AHcSXtVhOJvFJSmRc/lz4J9U9TSAqvZlucZkJHI+CkTXtnEB3cl8QD4HSzNwbMLz45Ftk75HVYOEJ/5ekJXqkpfI+Ux0I5C1JVNSEPd8ROQSYLGq/jCbhaUgkZ/NSmCliPxKRF4QkauyVl3yEjmfzwMfiEzu9hTh1TcSZish5iER+QDh+YXf5HQtqRKRIuDvgRscLiVdSgh/HbqC8JXksyLSpqpnnCxqBq4DtqrqV0XkcuDfRGS9qoYS2Tmfr1i8wOIJz1si2yZ9T2RVABcwkJXqkpfI+SAiVxKe2vNdqjqSpdpSEe98qoH1wDMicgR4HfB4jjbgJvKzOQ48rqpjqnoY2Ec4aHJRIudzI/B9AFV9HphD+ObExDjdkDSDBqgS4BCwlAsNUOti3vPfeXXj7fedrnuG5/Mawo1uK5yuNx3nE/P+Z8jdxttEfjZXAd+KPK4j/FVjgdO1z+B8ngZuiDxeQ7iNRRL+DKdPcoZ/QJsJ/89wELgtsu2LhP83J5KyPwAOAL8Bljld8wzP56fACWBn5NfjTtc8k/OJeW/OBkuCPxsh/NXOA3QC1zpd8wzPZy3wq0jo7ATemszxbUi/MSbt8rmNxRiToyxYjDFpZ8FijEk7CxZjTNpZsBhj0s6CxRiTdhYsxpi0+/+xM5Vdan6DUQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 648x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "n = 100\n",
    "alpha_list = [0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8] #, 0.9, 1.0]\n",
    "\n",
    "for alpha in alpha_list:\n",
    "    ring = SyntheticGraph(100, alpha)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "#plt.plot(k_list, list_of_sing_1, label=f\"{k}\")\n",
    "plt.plot(alpha_list, list_of_sing_2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f66d8730>]"
      ]
     },
     "execution_count": 69,
     "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(alpha_list, list_of_sing_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4\n",
    "alpha = 0 #0.1\n",
    "\n",
    "class SyntheticGraph():\n",
    "    def __init__(self, n, alpha):\n",
    "        self.w = Line(2*n).w\n",
    "        self.w[n-1, n-1] = alpha\n",
    "        self.w[n-1, n] = 1 - alpha - 1/3\n",
    "        self.w[n, n-1] = 1 - alpha - 1/3\n",
    "        self.w[n, n] = alpha"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.6667, 0.3333, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000],\n",
       "        [0.3333, 0.3333, 0.3333, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000],\n",
       "        [0.0000, 0.3333, 0.3333, 0.3333, 0.0000, 0.0000, 0.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.3333, 0.5000, 0.1667, 0.0000, 0.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000, 0.1667, 0.5000, 0.3333, 0.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000, 0.0000, 0.3333, 0.3333, 0.3333, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.3333, 0.3333, 0.3333],\n",
       "        [0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.6667]])"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "SyntheticGraph(4, 1/2).w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f6300f10>]"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "n = 100\n",
    "alpha_list = [1/3 + 1/30*i for i in range(0, 10)] #, 0.9, 1.0]\n",
    "\n",
    "for alpha in alpha_list:\n",
    "    ring = SyntheticGraph(100, alpha)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "#plt.plot(k_list, list_of_sing_1, label=f\"{k}\")\n",
    "plt.plot(alpha_list, list_of_sing_2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f62e7730>]"
      ]
     },
     "execution_count": 94,
     "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(alpha_list, list_of_sing_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "metadata": {},
   "outputs": [],
   "source": [
    "def max_eigenvalue_and_vector(matrix):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    return eigenvalues\n",
    "\n",
    "def generate_graph(matrix,eig):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v < sorted(eigenvalues)[-2]:\n",
    "            new_eigenvalues.append(v)\n",
    "        else:\n",
    "            new_eigenvalues.append(eig)\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "False\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([[ 0.08879773,  0.1183114 , -0.13775413, -0.04224587,  0.03502193,\n",
       "         0.0645356 ,  0.03502192, -0.04224587, -0.13775413,  0.11831141],\n",
       "       [ 0.11831142,  0.08879773,  0.11831141, -0.13775413, -0.04224588,\n",
       "         0.03502193,  0.0645356 ,  0.03502193, -0.04224588, -0.13775413],\n",
       "       [-0.13775413,  0.11831141,  0.08879773,  0.11831142, -0.13775413,\n",
       "        -0.04224587,  0.03502193,  0.0645356 ,  0.03502194, -0.04224587],\n",
       "       [-0.04224587, -0.13775413,  0.11831141,  0.08879774,  0.11831141,\n",
       "        -0.13775413, -0.04224587,  0.03502193,  0.0645356 ,  0.03502193],\n",
       "       [ 0.03502193, -0.04224588, -0.13775413,  0.11831141,  0.08879773,\n",
       "         0.11831142, -0.13775413, -0.04224587,  0.03502193,  0.0645356 ],\n",
       "       [ 0.0645356 ,  0.03502192, -0.04224587, -0.13775413,  0.11831141,\n",
       "         0.08879773,  0.1183114 , -0.13775413, -0.04224587,  0.03502193],\n",
       "       [ 0.03502193,  0.0645356 ,  0.03502193, -0.04224588, -0.13775413,\n",
       "         0.11831142,  0.08879773,  0.11831141, -0.13775413, -0.04224588],\n",
       "       [-0.04224587,  0.03502193,  0.0645356 ,  0.03502194, -0.04224587,\n",
       "        -0.13775413,  0.11831141,  0.08879773,  0.11831142, -0.13775413],\n",
       "       [-0.13775413, -0.04224587,  0.03502193,  0.0645356 ,  0.03502193,\n",
       "        -0.04224587, -0.13775413,  0.11831141,  0.08879774,  0.11831141],\n",
       "       [ 0.11831142, -0.13775413, -0.04224587,  0.03502193,  0.0645356 ,\n",
       "         0.03502193, -0.04224588, -0.13775413,  0.11831141,  0.08879773]])"
      ]
     },
     "execution_count": 219,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ring = Ring(10)\n",
    "\n",
    "w = generate_graph(ring.w, 0.1)\n",
    "max_eigenvalue_and_vector(w)\n",
    "\n",
    "print((w >= 0).all())\n",
    "w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.28153561,  0.2279704 ,  0.13514289,  0.02851003, -0.05119807,\n",
       "        -0.0735356 , -0.02997041,  0.06285711,  0.16948997,  0.24919807],\n",
       "       [ 0.23858425,  0.21333925,  0.12824021,  0.04197241, -0.0225128 ,\n",
       "        -0.04058423, -0.00533926,  0.06975978,  0.15602759,  0.2205128 ],\n",
       "       [ 0.15231644,  0.13885405,  0.12016877,  0.0772174 ,  0.05258624,\n",
       "         0.04568357,  0.05914595,  0.08783123,  0.1207826 ,  0.14541376],\n",
       "       [ 0.04568357,  0.05914595,  0.08783123,  0.1307826 ,  0.14541376,\n",
       "         0.15231644,  0.13885405,  0.11016877,  0.0772174 ,  0.05258624],\n",
       "       [-0.04058423, -0.00533926,  0.06975978,  0.15602759,  0.2305128 ,\n",
       "         0.23858425,  0.20333925,  0.12824021,  0.04197241, -0.0225128 ],\n",
       "       [-0.0735356 , -0.02997041,  0.06285711,  0.16948997,  0.24919807,\n",
       "         0.28153561,  0.2279704 ,  0.13514289,  0.02851003, -0.05119807],\n",
       "       [-0.04058423, -0.00533926,  0.06975978,  0.15602759,  0.2205128 ,\n",
       "         0.23858425,  0.21333925,  0.12824021,  0.04197241, -0.0225128 ],\n",
       "       [ 0.04568357,  0.05914595,  0.08783123,  0.1207826 ,  0.14541376,\n",
       "         0.15231644,  0.13885405,  0.12016877,  0.0772174 ,  0.05258624],\n",
       "       [ 0.15231644,  0.13885405,  0.11016877,  0.0772174 ,  0.05258624,\n",
       "         0.04568357,  0.05914595,  0.08783123,  0.1307826 ,  0.14541376],\n",
       "       [ 0.23858425,  0.20333925,  0.12824021,  0.04197241, -0.0225128 ,\n",
       "        -0.04058423, -0.00533926,  0.06975978,  0.15602759,  0.2305128 ]])"
      ]
     },
     "execution_count": 198,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "metadata": {},
   "outputs": [],
   "source": [
    "def max_eigenvalue_and_vector(matrix):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    return eigenvalues\n",
    "\n",
    "def generate_graph(matrix,eig):\n",
    "    eigenvalues, eigenvectors = np.linalg.eig(matrix)\n",
    "    max_index = np.argmax(np.abs(eigenvalues))\n",
    "    max_eigenvalue = eigenvalues[max_index]\n",
    "    max_eigenvector = eigenvectors[:, max_index]\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    new_eigenvalues = []\n",
    "    counter = True\n",
    "    for v in eigenvalues:\n",
    "        if v == sorted(eigenvalues)[-2]:\n",
    "            new_eigenvalues.append(eig)\n",
    "        else:\n",
    "            new_eigenvalues.append(v)\n",
    "    eigenvalues = np.array(new_eigenvalues)\n",
    "    \n",
    "    #print(eigenvalues)\n",
    "    \n",
    "    D = np.diag(eigenvalues)\n",
    "    # Reconstruct the original matrix: A = V * D * V^{-1}\n",
    "    V_inv = np.linalg.inv(eigenvectors)\n",
    "    A_reconstructed = eigenvectors @ D @ V_inv\n",
    "    return A_reconstructed\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1.00000001 -0.33333335 -0.20601134 -0.20601134  0.127322    0.127322\n",
      "  0.53        0.52999998  0.53934467  0.53934467]\n",
      "False\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([[ 0.26479773,  0.27788686, -0.02117867,  0.02117867,  0.05544647,\n",
       "         0.06853561,  0.05544645,  0.02117866, -0.02117867,  0.27788687],\n",
       "       [ 0.27788689,  0.26479773,  0.27788687, -0.02117867,  0.02117865,\n",
       "         0.05544647,  0.0685356 ,  0.05544647,  0.02117866, -0.02117867],\n",
       "       [-0.02117866,  0.27788687,  0.26479772,  0.27788687, -0.02117867,\n",
       "         0.02117867,  0.05544647,  0.0685356 ,  0.05544648,  0.02117867],\n",
       "       [ 0.02117867, -0.02117867,  0.27788687,  0.26479773,  0.27788687,\n",
       "        -0.02117866,  0.02117867,  0.05544647,  0.0685356 ,  0.05544647],\n",
       "       [ 0.05544647,  0.02117866, -0.02117867,  0.27788687,  0.26479773,\n",
       "         0.27788689, -0.02117867,  0.02117867,  0.05544647,  0.0685356 ],\n",
       "       [ 0.06853561,  0.05544645,  0.02117866, -0.02117867,  0.27788687,\n",
       "         0.26479773,  0.27788686, -0.02117867,  0.02117867,  0.05544647],\n",
       "       [ 0.05544647,  0.0685356 ,  0.05544647,  0.02117866, -0.02117867,\n",
       "         0.27788689,  0.26479773,  0.27788687, -0.02117867,  0.02117865],\n",
       "       [ 0.02117867,  0.05544647,  0.0685356 ,  0.05544648,  0.02117867,\n",
       "        -0.02117866,  0.27788687,  0.26479772,  0.27788687, -0.02117867],\n",
       "       [-0.02117866,  0.02117867,  0.05544647,  0.0685356 ,  0.05544647,\n",
       "         0.02117867, -0.02117867,  0.27788687,  0.26479773,  0.27788687],\n",
       "       [ 0.27788689, -0.02117867,  0.02117867,  0.05544647,  0.0685356 ,\n",
       "         0.05544647,  0.02117866, -0.02117867,  0.27788687,  0.26479773]])"
      ]
     },
     "execution_count": 227,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ring = Ring(10)\n",
    "\n",
    "w = generate_graph(ring.w, 0.53)\n",
    "print(max_eigenvalue_and_vector(w))\n",
    "\n",
    "print((w >= 0).all())\n",
    "w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 260,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4\n",
    "alpha = 0 #0.1\n",
    "\n",
    "class SyntheticGraph():\n",
    "    def __init__(self, n, k, alpha):\n",
    "        w1 = torch.ones((int(n/k), int(n/k))) / (n/k)\n",
    "        #print(w1)\n",
    "        for j in range(k):\n",
    "            if j == 0:\n",
    "                self.w = w1\n",
    "            else:\n",
    "                self.w = torch.block_diag(self.w, w1)\n",
    "    \n",
    "        for j in range(1, k):\n",
    "            self.w[int(n*j/k)-1, int(n*j/k)-1] -= alpha\n",
    "            self.w[int(n*j/k)-1, int(n*j/k)] += alpha\n",
    "            self.w[int(n*j/k), int(n*j/k)-1] += alpha\n",
    "            self.w[int(n*j/k), int(n*j/k)] -= alpha\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1, 1]"
      ]
     },
     "execution_count": 257,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[1]*2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 267,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f2f1f3d0>]"
      ]
     },
     "execution_count": 267,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "n = 100\n",
    "alpha_list = [0.01, 0.05, 0.1, 0.2, 0.3, 0.4, 0.5] #, 0.9, 1.0]\n",
    "alpha = 0.01\n",
    "\n",
    "for k in [2, 10, 20, 50]:\n",
    "    ring = SyntheticGraph(100, k, alpha)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "#plt.plot(k_list, list_of_sing_1, label=f\"{k}\")\n",
    "plt.plot([2, 10, 20, 50], list_of_sing_2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 268,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7a78f23c5eb0>]"
      ]
     },
     "execution_count": 268,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "n = 100\n",
    "alpha_list = [0.01, 0.05, 0.1, 0.2, 0.3, 0.4, 0.5] #, 0.9, 1.0]\n",
    "alpha = 0.01\n",
    "\n",
    "for k in [2, 10, 20, 50]:\n",
    "    ring = SyntheticGraph(100, k, alpha)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "#plt.plot(k_list, list_of_sing_1, label=f\"{k}\")\n",
    "plt.plot([2, 10, 20, 50], list_of_sing_1)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "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": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def calc_average_spectral_gap(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 calc_spectral_gap(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": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams['mathtext.fontset'] = 'stix'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10] + list(range(100, 2100, 100))\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"o\", color=\"red\")\n",
    "plt.title(r\"$\\frac{1 - p}{p}$\", y=1.03, fontsize=20)\n",
    "plt.xlabel(\"# Nodes\", fontsize=20)\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 2)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "plt.plot(node_list, list_of_sing_2, marker=\"s\", color=\"blue\")\n",
    "plt.title(r\"$\\frac{1}{n} \\sum_{i=2}^n \\frac{\\lambda_i^2}{1 - \\lambda_i^2}$\", fontsize=20)\n",
    "plt.xlabel(\"#Nodes\", fontsize=20)\n",
    "\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "plt.savefig(\"pic/ring.pdf\", bbox_inches='tight', )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "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 648x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [n**2 for n in range(10, 50)]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Torus(int(math.sqrt(n)), int(math.sqrt(n)))\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w_list[0]))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"o\", color=\"red\")\n",
    "plt.title(r\"$\\frac{1 - p}{p}$\", y=1.03, fontsize=20)\n",
    "plt.xlabel(\"# Nodes\", fontsize=20)\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 2)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Torus(int(math.sqrt(n)), int(math.sqrt(n)))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w_list[0]))\n",
    "plt.plot(node_list, list_of_sing_2, marker=\"s\", color=\"blue\")\n",
    "plt.title(r\"$\\frac{1}{n} \\sum_{i=2}^n \\frac{\\lambda_i^2}{1 - \\lambda_i^2}$\", fontsize=20)\n",
    "plt.xlabel(\"#Nodes\", fontsize=20)\n",
    "\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "plt.savefig(\"pic/torus.pdf\", bbox_inches='tight', )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[3.194049687733592, 379.34114777770037, 1519.2007568358863, 3418.9842212943245, 6082.359509912191, 9499.372316884812]\n",
      "[0.7208310155244604, 126.04515524292489, 505.9921796983812, (1139.3163772036055+0j), 2025.9733939729485, (3165.9574565067383+0j)]\n",
      "[0.012500000188592821, (37.39486248185958+0j), (151.38055060665815+0j), (341.3630702606593+0j), 607.3405703837426, (949.2622968365214+0j)]\n",
      "[0.7455146357506042, 11.939509895373801, 24.43636435766939, 36.935917071750964, 49.45341246189491, 61.93986569383694]\n",
      "[0.16135140502164852, 3.856548569377502, 8.020105210299379, (12.186255277703866+0j), 16.35273243425866, (20.519633129715775+0j)]\n",
      "[0.01125000016973354, (1.0850033651684543+0j), (2.3319991486492957+0j), (3.581029575230379+0j), 4.830569611858074, (6.0800949408784275+0j)]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([-10.,   0.,  10.,  20.,  30.,  40.,  50.,  60.,  70.]),\n",
       " [Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, '')])"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10] + list(range(100, 600, 100))\n",
    "\n",
    "for k in [1, 2, 4]:\n",
    "    list_of_sing_1 = []\n",
    "\n",
    "    for n in node_list:\n",
    "        ring = kRing(n, k)\n",
    "        list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "\n",
    "    plt.plot(node_list, list_of_sing_1, label=f\"{k}\")\n",
    "    print(list_of_sing_1)\n",
    "plt.title(r\"$\\frac{1 - p}{p}$\", y=1.03, fontsize=20)\n",
    "plt.xlabel(\"# Nodes\", fontsize=20)\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 2)\n",
    "\n",
    "for k in [1, 2, 4]:\n",
    "    list_of_sing_1 = []\n",
    "\n",
    "    for n in node_list:\n",
    "        ring = kRing(n, k)\n",
    "        list_of_sing_1.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "    plt.plot(node_list, list_of_sing_1, label=f\"{k}\")\n",
    "    print(list_of_sing_1)\n",
    "\n",
    "plt.title(r\"$\\frac{1 - p}{p}$\", y=1.03, fontsize=20)\n",
    "plt.xlabel(\"# Nodes\", fontsize=20)\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "#plt.savefig(\"pic/ring.pdf\", bbox_inches='tight', )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f20f8352820>]"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(9, 4))\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "n = 500\n",
    "alpha_list = [0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9]\n",
    "\n",
    "for alpha in alpha_list:\n",
    "    ring = Ring(n)\n",
    "    w = alpha*ring.w + (1-alpha)*torch.ones((n,n))/n\n",
    "    list_of_sing_1.append(calc_spectral_gap(w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(w))\n",
    "\n",
    "#plt.plot(k_list, list_of_sing_1, label=f\"{k}\")\n",
    "plt.plot(alpha_list, list_of_sing_2, label=f\"{k}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f20f8337880>]"
      ]
     },
     "execution_count": 80,
     "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(alpha_list, list_of_sing_1, label=f\"{k}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1. , 1.1, 1.2]),\n",
       " [Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, ''),\n",
       "  Text(0, 0, '')])"
      ]
     },
     "execution_count": 56,
     "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_2, marker=\"s\", color=\"blue\")\n",
    "plt.title(r\"$\\frac{1}{n} \\sum_{i=2}^n \\frac{\\lambda_i^2}{1 - \\lambda_i^2}$\", fontsize=20)\n",
    "plt.xlabel(\"#Nodes\", fontsize=20)\n",
    "plt.xscale(\"log\")\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "\n",
    "#plt.savefig(\"pic/torus.pdf\", bbox_inches='tight', )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, '# Nodes')"
      ]
     },
     "execution_count": 21,
     "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": [
    "fig = plt.figure()\n",
    "\n",
    "list_of_sing_1 = []\n",
    "list_of_sing_2 = []\n",
    "\n",
    "node_list = [10] + list(range(100, 600, 100)) #[10] + list(range(100, 2100, 100))\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(calc_spectral_gap(ring.w))\n",
    "    list_of_sing_2.append(calc_average_spectral_gap(ring.w))\n",
    "\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"o\", color=\"red\")\n",
    "plt.plot(node_list, list_of_sing_2, marker=\"s\", color=\"blue\")\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",
    "\n",
    "#plt.savefig(\"pic/ring_spectral_gap.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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, 100, 200, 300, 400, 500, 600, 700, 800, 900, 1000]\n",
    "\n",
    "for n in node_list:\n",
    "    ring = Ring(n)\n",
    "    list_of_sing_1.append(calc_average_spectral_gap(ring.w))\n",
    "plt.plot(node_list, list_of_sing_1, marker=\"s\")\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,
   "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,
   "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": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAE3CAYAAAC6r7qRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAspklEQVR4nO3deXxU9b3/8deHhH0JhLCHkIi4IFsgBMW11lq1KmoXEa1LXWpbru1te++1t79fb2vXX5fb215sLVJrXUCttkqrFq1VxGJZQtjdIBAIiyyBsIZsn98f5xCHGMgkTDKTmffz8ZgHM2dO5nxOJnnzzXe+5/s1d0dERNq/DvEuQEREYkOBLiKSJBToIiJJQoEuIpIkFOgiIklCgS4ikiQU6CIiSUKBLiKSJNLjXYBIe2Nms4C9wDjgNGCmu38vnjWJgFroIi0xlqAxdCkwEfhSfMsRCaiFLtIMZpYGnAp8xN3rwse741yWCKAWukhznQ686+4HwsfjgBXxK0fkA2qhizTPWKA44nF+g8etyszOA24jaIy96+4/bKtjS+JTC12kecYCyyMe5zd43Krc/Q13v93dbwPOb6vjSvtgmj5XJPGY2RDgH8Bz7v7lRp6/Fejm7r9q69okcSnQRRKUmfUHNgA93b0uYvuXgDR3/2XcipOEpC4XkcS1H6gjGFUDgJldA3wdGGlm98epLklQCnSREzCz6WbmzbzNitHhvwt0AkYf3eDuz7p7nrvf7e4a/y7HUKCLnFhNPA5qZhOBjwK/JCLQRU5EfegiJ2BmXYAXgI8A+4CPuvvSVj5mR2AxcCdwCjDV3a9rzWNKclALXU5alN0QF8W7zpZw90rgKmAh0AuYZ2at3WL+T2Be+B/HCiJa6Gb2k1Y+trRjurBIYuGciPtdgb8D3wOej9i+tk0riiF3P2hmVwCvABOAl83sAnd/N9bHMrOzgOuASeGm94CBZtYdSAMyY31MSR7qcpGYMrMeBKMzbnP3h2PwemkEQ/SqTva1YlBLX+BVghZzGXC+u29sw+NfCIxyd41ukUapy0XalJl9xsxWmdkRM9tsZt83s/SI5x82s6Vmdo2ZrQEqgUlm9pqZPd3gtS4Ku3NGRWw7y8z+amblZnbQzN4Kx22fNHffDXwMeAfIBl4JLwBqK+OBojY8nrQzCnRpM2Z2KfAksAyYAvwvwZjqGQ12zQV+DPwQuJzg4ppo/RmoBW4Crg6P0TM8/tH/AC5q6Tm4+/sEo082EHxg+bfwAqC2MAZNBCYnoD50aUv3Aa+5+y3h47+aGcAPzex77l4Wbu8LXOLuy49+YbjfCZlZFpAHTHH3VeHmVyJ2cYKwP6l+RnffYmYXAwuAMwj61C9y9z0n87pRHPe21nx9af/UQpc2EfaFjwf+0OCpJwl+DiM/WN0SGebNUA5sBh4ws+sbtpzdfb67p7v7/Ba89jHCvvMHwodjCBa7EIkrBbq0lSygI/B+g+1HH2c2sq1ZwvlOLgW2Aw8B281sgZnlt+T1TsTMrgW+Ez78prs/GetjiDSXAl3ayi6gGmjY3zwg/Lc8YltjXSKVBJfBR+rTcCd3f9vdPwn0Bi4BugDPm1nMftbD7pY5BMMIf+buP4jy65o7hUDMb7H6HkhiUqBLm3D3WoIRGp9u8NRnCCagerOJlygj6K+OdNxuDnevdve/A/8NDCII+JNmZgXAs0Bn4CF3/3q0X+vuFu9bLL4Hkrj0oai0pf8iuNLyd8ATBOO5vws8GPGB6PH8CbjdzH5OcMHSR4DLIncwszHATwn65UsIWvD/Aaxw9/JwHPcrBJfvN7sf3czOAF4kGDXzDHBXc1+jLWhVo9SlFrq0GXd/CZgKFBAML/wK8DNgehRf+zzBJfGfIgj3YUDDhR+2E/S/f5MgeH8FvEUwfBHACLpJmt1SNbMc4CWCzwL+BkwL/+pIOFrVKHXpSlGRJphZP4IhiqcDiwha+Adb+Fq/JvgPZvDJdoFoVSNpSIEucgJm1pPgcv8JwBrgAncvP/FXnfD1LiC40nR7LPq0TasaSQQFusgJmNmjBFedNkepu+c28boeo0DvCuwAJhydLMyCVY1+DswDarUQRurQh6IiJzYo3gU0IXJVo3chWNWIYCSOpBi10EXi4HgtdDNbBuQ08iXz3P3GBvtOBGYSfEh70N2/3Rq1SvuhQBeJg5PtctGqRtIYDVsUaZ+0qpF8iAJdpAEzO8PMZrXwa4ea2SvhPOxrzOzHFjFVpJnNMrOy8H5ZS44TsarRt8NN9asamVkvtKpRylKXi0gMmdkgYIi7LzWzTsDLwC/d/Zk2Or5WNUphaqGLNGBmD5jZ1JZ8rbtvC7tBCJfNWwkMjWV9TdCqRilMwxZFPmwc8D+RG8xsHh/MDBnpVXf/18ZeJFyD9Bradq70MXwwT7ukGHW5iEQIp9ndDgyMvPKyBa/TGfgr8Bd3/1ms6hM5EbXQRY51GlDSMMyb00IPV2d6HChWmEtbUqCLHGscsLzhRnf/eDNe4zfAfuBrsSlJJDr6UFTkWONoJNCjZWbnArcTTBFcbGbLzeye2JQmcmLqQxcRSRJqoYuIJIm49aFnZWV5bm5uvA4vItIuFRUV7XL3fo09F7dAz83NZenSpfE6vIhIu2Rmpcd7Tl0uIiJJQoEuIpIkFOgiIklCgS4ikiQU6CIiSUKBLiLSBh6Yv56F63cds23h+l08MH99zI6hQBcRaQNjsjOYPru4PtQXrt/F9NnFjMnOiNkxNDmXiEgbmJibyZcvGcHtDy/lslEDmf/uTmZMy2fy8KyYHUOBLiLSCiqraynetJfFG8pZvHE3y0r3cri6FoA/FW/hnotPjWmYgwJdRCQm9ldWU1S6JwjwDeWsKNtLda1jBmcO7MX1E4fSu2tHHn5zIzefPYzHFm3i7OF91UIXEYm38oNVLNlYXh/ga7ZWUOeQ3sEYnZ3B587LY1JeJhOGZZLRtWN9n/mvbhzP5OFZnD28L9NnF8e020WBLiIShff3VbJoQzmLN+xm8YZy3n3/AACd0zuQn9Ob6RePYFJeJvk5venW6cPRurKs4pjwnjw8ixnT8llZVhGzQI/bfOgFBQWuyblEJBG5O5vLD7MoDO/FG8sp3X0IgB6d05kwrA+FeZlMystkdHYGndPT2qw2Myty94LGnlMLXURSnruzbseBsAUe3LbvqwSgT7eOTMzN5LNnD2NSXl/OHNST9LTEHPGtQBeRlFNb57y1bV99F8qSjXsoP1gFQP+enZl0St/6Fvip/XrQoYPFueLoKNBFJOlV1dSxasve+hZ40cY97D9SA0BOZjcuPqN/fYDnZHbDrH0EeEMKdBFJOoerainetKc+wJdt2sORmjoARvTvwdXjBlOYl0lhXiaDMrrGudrYUaCLSLu3r7Kaoo176rtQVpZVUFPndDAYObgXN04aRmFeJhNz+9C3R+d4l9tqFOgi0u7sPnCEJRvL61vga7ftwx06phljsntz5wWnUJiXyYRhfejVpWO8y20zCnQRSXjbKg6zeMMHAb5uRzAGvEvHDozP6cOXPzqCwrxM8of2oWunthtCmGgU6CKSUNyd0t2HPgjwjbvZXH4YgJ6d0ynI7cMnx2dTmJfJ6CEZdEpPzCGE8aBAF5G4qqtz3ttxgMUbdte3wHfsPwJAZvdOFOZmctvkPArzMjlzUC/S2skQwnhQoItIm6qprWPttn31LfAlG8vZe6gagIG9unDO8A/GgA/v16PdDiGMhyYD3cweAq4Edrj7qEaePwP4HTAe+Ka7/zTmVYpIu3WkppaVZRX1AV60sZyDVcE0srl9u3HpyAEU5vVlUl4m2X26KsBPQjQt9IeBGcAjx3m+HLgHuCY2JYlIe3aoqoZlpXvru1CKN++lKhwDfvqAnlwX9n8X5mUyoFeXOFebXJoMdHd/3cxyT/D8DmCHmX0iloWJSPtQcaiapaXl9S3w1Vs+GAM+akgGN599dAx4Jn26d4p3uUlNfegi0iw79x+pnwd80YZy3t4ejAHvlNaBsUMz+PyFp1CY15cJw/rQo7Mipi216XfbzO4C7gLIyclpy0OLSAtt2Xu4fg7wRRvKKdl5EICuHdOYMKwP/3rJaRTmZTJuaG+6dEzdMeCJoE0D3d1nAjMhmA+9LY8tIk1zdzbsOlg/heyiDeVs2RuOAe+STmFuJtcXDKUwL5NRQzLomKDTyKYq/T0kksLq6py3t+8/pgtl14FgDHhWj04U5mVy5/l5FOb15fSBPTUGPMFFM2xxDnARkGVmZcB/AR0B3P0BMxsILAV6AXVm9hVgpLvva62iRaRlqmvrWL2lor4FvmRjOfsqg2lkB2d04fwRWfUjUE7J6q4hhO1MNKNcbmji+e1AdswqEpGYqayuZfnmvfUBXlS6h8PVwRjwU7K6c8XoQfUBnt2nW5yrlZOlLheRJHLgSA3LSvfUB/jyzXupqq3DLBgD/pmCbArz+jIxrw/9e2oMeLJRoIskuAfmr2dMdsYxK8MvXL+LlWUVTJ04lCUb99SPQlm9dR+1dU5aB2PUkAxuPTeXwtxMCnL70LubxoAnOwW6SIIbk53B9NnFzJiWz6n9evDYolJ+M7+E/j0786MX3wagU3oHxg3tzRcvGk5hXibjc/rQXWPAU47ecZEEd9qAnlw6cgA3zVpEXTjYt3N6B3KzunP9xKEU5vVlTHaGxoCLAl0kEdXVOW+W7Gb2ok28tHY71bXO4N5d2Lq3ks8UZPODa0eTrjHg0oACXSSB7DpwhKeLynhi8SY27j5E724dufmcXM4c2JMfvPg291x8Ko8t2sQ1+eXH9KmLgAJdJO7cnTfX7+bxxZt4aU3QGi/My+Qrl5zGZaMGsmzTnvo+9MnDszh7eN9jHoscpUAXiZPdR1vjSzazYddBMrp25LNn5zJt0lBO7d+zfr+VZRXHhPfk4VnMmJbPyrIKBbocw9zjM6VKQUGBL126NC7HFokX96BvfM7izcxbvZ2q2joKczO5YdJQLh81SB9sSpPMrMjdCxp7Ti10kTZQfrCKZ4rKmLN4EyW7DtKrSzo3np3DtMIcRgzo2fQLiERBgS7SStydRRvKmb1oE38NW+MFw/ow/eJTuWK0WuMSewp0kRgrP1jFH5eVMXvxJkp2Bq3xaZNymDYph9PUGpdWpEAXiQF3Z/GGcmYv3sSLq4LW+IRhffjpp0/lE6MH0bWTWuPS+hToIidhz8EqnlkW9I2v33mQnmFrfGrhUM4Y2Cve5UmKUaCLNJO7s2TjHmYvKuWF1dupqqljfE5vfvKpMVw5ZrBa4xI3CnSRKO09VMUzy7YwZ/Em1u04QM/O6UydOJQbCnM4c5Ba4xJ/CnSRE3B3lpbuYfaiTTy/ahtVNXWMG9qbH39qDFeOGUS3TvoVksShn0aRRlQcqq7vG38vbI1fXxC0xkcOVmtcEpMCXSTk7hSV7mH24k08v3IbR2rqGDu0Nz/+5BiuHKvWuCQ+/YRKyqs4XM2flpUxZ/Fm3nl/Pz06p/PpgmxuKMzhrMEZ8S5PJGoKdElJ7s6yTXvDvvGtVFbXMTY7gx9dN5qrxg7Waj/SLumnVlJKxeFqni0ORqq8vX0/3Tulcd34bKYV5jBqiFrj0r41Gehm9hBwJbDD3Uc18rwBvwCuAA4Bt7r7slgXKtJS7k7x5qA1/peVQWt8THYGP7xuNFerNS5JJJqf5IeBGcAjx3n+cmBEeJsE/Dr8VySu9lUGrfHZiz5ojV+bn82Nk9Qal+TUZKC7++tmlnuCXaYAj3gwsfo/zay3mQ1y922xKlIkWu7O8s17mbN4E39esY3D1bWMGtKLH1w7mqvHDaaHWuOSxGLx0z0E2BzxuCzcpkCXNrOvsprnircwe/Fm3tq2j26d0rgmfzDTCocxOlutcUkNbdpcMbO7gLsAcnJy2vLQkoTcnRVlFcxZtIm5K7ZyuLqWswb34vvXjuLqsYPp2aVjvEsUaVOxCPQtwNCIx9nhtg9x95nATAiWoIvBsSUF7a+s5rnlW5m9aBNrw9b4lHGDmTYph9FDMgg+pxdJPbEI9LnAdDN7guDD0Ar1n0usuTurtlQwO2yNH6qq5cxBvfjuNaO4Zpxa4yIQ3bDFOcBFQJaZlQH/BXQEcPcHgBcIhiyuIxi2eFtrFSup58CRGp5bHoxUWbN1H107pnH12MHcMCmHsdlqjYtEimaUyw1NPO/Al2JWkQiwqqyC2YtLeW550Bo/Y2BPvjvlLKbkD6GXWuMijdIYLkkYB47UMHf5VmYvLmX1ln106diBq8YEfePjhvZWa1ykCQp0ibvVWyp4fNEm5i7fwsGwNX7flLO4Rq1xkWZRoEtcHDxSw9wVW5mzeBMryyro0rEDV4at8Xy1xkVaRIEubWr1lgrmLN7Ec8u3cuBIDacP6Ml3rg5a4xld1RoXORkKdGl1B4/U8OewNb6irILO6Udb40MZn9NHrXGRGFGgy0l5YP56xmRnMHl4Vv22het3sbKsgvNHZDFn8SaeLQ5a4yP69+C/rhrJdfnZZHRTa1wk1hToclLGZGcwfXYxM6blM3l4Fq++/T7TZxczMKMLP3rxbTqld+DK0YOYNimHCcPUGhdpTQp0OSmTh2cxY1o+X3hsGTmZ3Vi9pQIHzIxvXTmS68YPoXe3TvEuUyQlKNDlpJXuPsT+ympWbang9IE9+d41oyhQa1ykzXWIdwHSflVW13LvMyv5xh9X0aGDccd5eezcf4Tq2jqFuUgcqIUuLbJ172G+8FgRK8Ix5LNunsh5I7K4+Mz+x/Spi0jbUaBLsy1cv4vps4upqqnjuvFD+NSE7PrwPtqnvrKsQoEu0sYU6BI1d+fBBSX86MW3OaVfD37z2QkM79fjQ/tNHp6lMBeJAwW6ROXgkRr+/ZmVPL9yG5ePGshPPj1W63OKJBj9RkqTSnYe4O7Hili34wD3Xn4Gn7/gFH3oKZKAFOhyQi+vfZ+vPrmc9DTjkc9N4rwR6koRSVQKdGlUbZ3zi7+9yy//vo5RQ3rxwE0TyO7TLd5licgJKNDlQyoOVfPlJ4t57Z2dfGpCNt+7ZhRdOqbFuywRaYICXY6xdus+7n6siG0Vh/neNaO4cVKO+stF2gkFutR7bvkW/uOZlWR07ciTnz+H8Tl94l2SiDSDAl2orq3jBy+8xe/+sZHCvExmTMunf88u8S5LRJpJgZ7iduyvZPrjxSzeWM7nzs3jG1ecQcc0TfEj0h5F9ZtrZpeZ2Ttmts7M7m3k+WFm9oqZrTSz18wsO/alSqwVle7hqv99g5Vb9vKLqeP41lUjFeYi7ViTv71mlgbcD1wOjARuMLORDXb7KfCIu48B7gN+GOtCJXbcnUf/WcrUmW/SOT2NP33xXKaMGxLvskTkJEXT5VIIrHP3EgAzewKYAqyN2Gck8NXw/qvAszGsUWKosrqW//Psap4uKuOi0/vxi+vztRycSJKI5u/rIcDmiMdl4bZIK4DrwvvXAj3NrO/JlyexVLbnEJ96YCFPF5Vxz0dH8NAtExXmIkkkVh+Kfh2YYWa3Aq8DW4DahjuZ2V3AXQA5OTkxOrRE4433dvEvc5ZRU+vMurmAS0YOiHdJIhJj0QT6FmBoxOPscFs9d99K2EI3sx7AJ919b8MXcveZwEyAgoICb1nJ0hzuzgPzS/jJvLc5tX8PfvPZAvKyuse7LBFpBdEE+hJghJnlEQT5VGBa5A5mlgWUu3sd8A3goVgXKs134EgN//aHFby4ejufGDOIH39yDN015a1I0mryt9vda8xsOjAPSAMecvc1ZnYfsNTd5wIXAT80MyfocvlSK9YsUVi3I5jytmTnAb55xZnccX6eLuEXSXLmHp+ej4KCAl+6dGlcjp3s5q3ZzteeWkGn9A7MuCGfyadqyluRZGFmRe5e0Nhz+vs7idTWOf/98jvc/+p6xmZn8OubJjC4d9d4lyUibUSBniT2HKzinieKWfDeLqZOHMq3rz5LU96KpBgFehJYvaWCux8rYse+I/zwutHcUKghoSKpSIHezv1xWRnf+OMqMrt34qm7z2Hc0N7xLklE4kSB3k5V1dTx/efX8vs3Szn7lExmTBtPVo/O8S5LROJIgd4O7dhXyRcfX8bS0j3ceX4e/3HZGaRrlkSRlKdAb2eWbiznC48v40BlDf97Qz5XjR0c75JEJEEo0NsJd+eRN0v57l/Wkt2nK4/dPonTB/aMd1kikkAU6O3A4apavvmnVfyxeAsfPaM//339ODK6apZEETmWAj3BbS4/xOcfLeKt7fv410tO418uPpUOHXQJv4h8mAI9gc1/dyf3zCnG3fntLQVcfIamvBWR41OgJ6C6OufX89fz05fe4fQBPXngpgnkaspbEWmCAj3B7K+s5mtPreClte9z9djB/OiTo+nWSW+TiDRNSZFA3nt/P59/rIjS3Yf4v1eO5HPn5mrKWxGJmgI9Qby4ahtf/8MKunZK4/E7JnH2KVqSVUSaR4EeZzW1dfz0pXd5YP568nN686sbxzMoQ1PeikjzKdDjqPxgFffMKeaNdbu4cVIO37pqJJ3TNeWtiLSMAj1OVpUFU97uPHCEH39yDJ+ZOLTpLxIROQEFehz8YelmvvnsarK6d+Lpu89hTHbveJckIklAgd6GqmrquO8va3jsn5s499S+/HJqPn015a2IxIgCvY1sr6jkC48XUbxpL5+/8BT+7dLTNeWtiMSUAr0NLCrZzZdmF3Ooqob7p43nE2MGxbskEUlCUTURzewyM3vHzNaZ2b2NPJ9jZq+aWbGZrTSzK2Jfavvj7jz0xgamzVpEry7pPPelcxXmItJqmmyhm1kacD/wMaAMWGJmc919bcRu/wd4yt1/bWYjgReA3Faot904XFXLvX9cyXPLt/KxkQP42WfG0quLprwVkdYTTZdLIbDO3UsAzOwJYAoQGegO9ArvZwBbY1lkIntg/nrGZGcweXhW/bY/FZfxg+ffYtfBKr5+6Wl88SJNeSsirS+aLpchwOaIx2XhtkjfBm4yszKC1vm/xKS6dmBMdgbTZxezcP0uAH712jq++uQKDlXV8rtbJzL94hEKcxFpE7H6UPQG4GF3/5mZnQM8amaj3L0uciczuwu4CyAnJydGh46vycOzmDEtn+mzixnRvweLNpQzLLMbj94+iZy+3eJdnoikkGha6FuAyMsYs8NtkW4HngJw9zeBLkBWg31w95nuXuDuBf369WtZxQlo8vAsCob1YdGGck4f2JO/fuUChbmItLloAn0JMMLM8sysEzAVmNtgn03ARwHM7EyCQN8Zy0IT2cJ1u3jl7R1kduvIzv1HKN68J94liUgKajLQ3b0GmA7MA94iGM2yxszuM7Orw92+BtxpZiuAOcCt7u6tVXQiWbh+F59/rIjaOufey8+s73452qcuItJWoupDd/cXCD7sjNz2rYj7a4FzY1ta+7CyrIK8rO5s3VvJlPzBdE5PY8a0fFaWVRwz8kVEpLXp2vOTdPEZ/VlZVsGtk4fVT307eXgWd184PM6ViUiqUaCfpFkLSujSsQM3ThoW71JEJMUp0E/Cjv2VPFu8lU9PGEqf7p3iXY6IpDgF+kl4ZGEp1XV13H5eXrxLERFRoLfUoaoaHltUyqUjB5Cb1T3e5YiIKNBb6umiMvYequauC06JdykiIoACvUVq65zfvrGB/JzeTBiWGe9yREQABXqLvLx2O6W7D3Hn+Wqdi0jiUKC3wIMLNjA0sysfP2tgvEsREamnQG+motI9FJXu4fZz80jTtLgikkAU6M00a0EJvbqk8+mCoU3vLCLShhTozbBp9yHmrdnOTWcPo3tnra8tIolFgd4MD/1jA2kdjFsm58a7FBGRD1GgR2nvoSqeXLKZKeOGMKBXl3iXIyLyIQr0KD2+aBOHq2u543xd5i8iiUmBHoUjNbU8vHAj54/I4oyBveJdjohIoxToUZi7fCs79x/RZf4iktAU6E1wd2Yt2MAZA3ty3qlagUhEEpcCvQmvv7eLd97fzx3nn4KZLiQSkcSlQG/CrAUlDOjVmavHDo53KSIiJ6RAP4G1W/ex4L1d3DI5l07p+laJSGJTSp3ArDdK6NYpjRsLtV6oiCS+qALdzC4zs3fMbJ2Z3dvI8z83s+Xh7V0z2xvzStvY9opK/rxiK58pGEpGt47xLkdEpElNTkhiZmnA/cDHgDJgiZnNdfe1R/dx93+N2P9fgPxWqLVNPbxwI7V1rvVCRaTdiKaFXgisc/cSd68CngCmnGD/G4A5sSguXg4eqWH2olIuHzWIoZnd4l2OiEhUogn0IcDmiMdl4bYPMbNhQB7w95MvLX6eWrqZfZU1usxfRNqVWH8oOhV42t1rG3vSzO4ys6VmtnTnzp0xPnRs1NTW8ds3NlAwrA/5OX3iXY6ISNSiCfQtQORqDtnhtsZM5QTdLe4+090L3L2gX79+0VfZhuateZ+yPYe5U5f5i0g7E02gLwFGmFmemXUiCO25DXcyszOAPsCbsS2x7bg7MxeUkNu3G5ecOSDe5YiINEuTge7uNcB0YB7wFvCUu68xs/vM7OqIXacCT7i7t06prW9p6R5WbN7L7edpvVARaX+iWkfN3V8AXmiw7VsNHn87dmXFx4Ovl9CnW0c+NUHrhYpI+6MrRUMbdh3k5bfe56azh9G1U1q8yxERaTYFeui3b5TQsUMHbj4nN96liIi0iAIdKD9YxdNFZVybP4R+PTvHuxwRkRZRoAOP/bOUyuo6XUgkIu1aygd6ZXUtj7y5kY+c3o8RA3rGuxwRkRZL+UB/tngLuw5Ucef5upBIRNq3lA70ujpn1hsbGDmoF+cM7xvvckRETkpKB/r8d3eybscB7rpA64WKSPuX0oE+8/USBmV04RNjBsW7FBGRk5aygb56SwVvluzmtnNz6ZiWst8GEUkiKZtkDy4ooUfndKYW5sS7FBGRmEjJQN+69zB/WbmN6ycOpVcXrRcqIskhJQP94YUbAbjt3Ny41iEiEkspF+j7K6uZs2gTV4weRHYfrRcqIskj5QL9ySWb2X+khjt1mb+IJJmUCvTq2jp+94+NTMrLZEx273iXIyISUykV6C+s2saWvYd1mb+IJKWUCXR358EFJZzSrzsXn9E/3uWIiMRcygT6P0vKWb1lH3ecdwodtF6oiCShlAn0WQtK6Nu9E9eNHxLvUkREWkVKBPq6HQd45e0dfPacYXTpqPVCRSQ5pUSg//aNEjqnd+CzZw+LdykiIq0m6QN914EjPLNsC9eNz6ZvD60XKiLJK6pAN7PLzOwdM1tnZvceZ5/PmNlaM1tjZrNjW2bLPfpmKVU1Wi9URJJfelM7mFkacD/wMaAMWGJmc919bcQ+I4BvAOe6+x4zS4hxgZXVtTz6z1IuObM/w/v1iHc5IiKtKpoWeiGwzt1L3L0KeAKY0mCfO4H73X0PgLvviG2ZLfPMsjLKD2q9UBFJDdEE+hBgc8TjsnBbpNOA08zsH2b2TzO7LFYFtlRdnfPbBRsYk51BYV5mvMsREWl1sfpQNB0YAVwE3AA8aGa9G+5kZneZ2VIzW7pz584YHbpxr7y9g5JdB7njfK0XKiKpIZpA3wIMjXicHW6LVAbMdfdqd98AvEsQ8Mdw95nuXuDuBf369WtpzVF5cEEJQ3p35YpRA1v1OCIiiSKaQF8CjDCzPDPrBEwF5jbY51mC1jlmlkXQBVMSuzKbZ8XmvSzeUM5t5+aSrvVCRSRFNJl27l4DTAfmAW8BT7n7GjO7z8yuDnebB+w2s7XAq8C/ufvu1iq6KQ8uKKFn53Sunzi06Z1FRJJEk8MWAdz9BeCFBtu+FXHfga+Gt7jaXH6IF1dv547z8uip9UJFJIUkXX/E7/6xEQNu1XqhIpJikirQKw5X8+SSTVw1djCDMrrGuxwRkTaVVIE+Z/EmDlbV6jJ/EUlJSRPoVTV1PPyPjUwe3pezBmfEuxwRkTaXNIH+/KqtbN9XyZ0X6DJ/EUlNSRHo7s7M1zcwon8PLjqtdS9YEhFJVEkR6AvX7+atbfu44/w8XeYvIikrKQJ95uslZPXozJRxWi9URFJXuw/0d9/fz/x3d3KL1gsVkRTX7gN91oISunTswE1aL1REUly7DvQd+yt5tngrn54wlD7dO8W7HBGRuGrXgf7IwlKq6+q4/TxdSCQi0m4D/VBVDY8tKuXSkQPIzeoe73JEROKu3Qb600Vl7D1UrfVCRURC7TLQa+uc376xgXFDezNhWJ94lyMikhDaTaA/MH89C9fvAuDltdsp3X2IC0/rx29ej9vCSCIiCaXdBPqY7Aymzy5m4fpdPLhgA/16duLRN0sZk62JuEREIMoVixLB5OFZzJiWz92PFrGvsoZundKYdUsBk4dnxbs0EZGE0G5a6BCE+qVnDQDg5nOGKcxFRCK0q0BfuH4Xf397J/dcfCpPLS2r71MXEZF2FOgL1+9i+uxiZkzL56uXns6Mafn1feoiItKOAn1lWQUzpuXXd7Mc7VNfWVYR58pERBJDVIFuZpeZ2Ttmts7M7m3k+VvNbKeZLQ9vd8S60LsvHP6hPvPJw7O4+8LhsT6UiEi71OQoFzNLA+4HPgaUAUvMbK67r22w65PuPr0VahQRkShE00IvBNa5e4m7VwFPAFNatywREWmuaAJ9CLA54nFZuK2hT5rZSjN72syGxqQ6ERGJWqw+FP0zkOvuY4CXgd83tpOZ3WVmS81s6c6dO2N0aBERgegCfQsQ2eLODrfVc/fd7n4kfDgLmNDYC7n7THcvcPeCfv36taReERE5jmgu/V8CjDCzPIIgnwpMi9zBzAa5+7bw4dXAW029aFFR0S4zKw0fZgGpOqA8lc8dUvv8de6p62TO/7jrbTYZ6O5eY2bTgXlAGvCQu68xs/uApe4+F7jHzK4GaoBy4NYoXre+iW5mS929oMnTSEKpfO6Q2uevc0/Nc4fWO/+oJudy9xeAFxps+1bE/W8A34htaSIi0hzt5kpRERE5sUQJ9JnxLiCOUvncIbXPX+eeulrl/M3dW+N1RUSkjSVKC11ERE5SXAO9qUm/koWZbTSzVeHEZUvDbZlm9rKZvRf+2yfcbmb2y/B7stLMxse3+uYxs4fMbIeZrY7Y1uxzNbNbwv3fM7Nb4nEuzXWcc/+2mW2JmLjuiojnvhGe+ztm9vGI7e3y98LMhprZq2a21szWmNmXw+1J//6f4Nzb9v1397jcCIZArgdOAToBK4CR8aqnlc91I5DVYNuPgXvD+/cC/y+8fwXwImDA2cCieNffzHO9ABgPrG7puQKZQEn4b5/wfp94n1sLz/3bwNcb2Xdk+DPfGcgLfxfS2vPvBTAIGB/e7wm8G55n0r//Jzj3Nn3/49lCT/VJv6bwwRQJvweuidj+iAf+CfQ2s0FxqK9F3P11gmsRIjX3XD8OvOzu5e6+h2A6ictavfiTdJxzP54pwBPufsTdNwDrCH4n2u3vhbtvc/dl4f39BBcYDiEF3v8TnPvxtMr7H89Aj3bSr2TgwEtmVmRmd4XbBvgHV9duBwaE95Px+9Lcc02278H0sEvhoaPdDST5uZtZLpAPLCLF3v8G5w5t+P7rQ9G2cZ67jwcuB75kZhdEPunB32ApMdwolc419GtgODAO2Ab8LK7VtAEz6wE8A3zF3fdFPpfs738j596m7388A73JSb+ShbtvCf/dAfyJ4M+q9492pYT/7gh3T8bvS3PPNWm+B+7+vrvXunsd8CDBew9Jeu5m1pEg0B539z+Gm1Pi/W/s3Nv6/Y9noNdP+mVmnQgm/Zobx3pahZl1N7OeR+8DlwKrCc716Kf3twDPhffnAjeHIwDOBioi/lxtr5p7rvOAS82sT/gn6qXhtnanwecf1xK89xCc+1Qz62zBxHcjgMW0498LMzPgt8Bb7v7fEU8l/ft/vHNv8/c/zp8MX0HwafB64JvxrKUVz/EUgk+qVwBrjp4n0Bd4BXgP+BuQGW43giX/1gOrgIJ4n0Mzz3cOwZ+W1QT9f7e35FyBzxF8ULQOuC3e53US5/5oeG4rw1/MQRH7fzM893eAyyO2t8vfC+A8gu6UlcDy8HZFKrz/Jzj3Nn3/daWoiEiS0IeiIiJJQoEuIpIkFOgiIklCgS4ikiQU6CIiSUKBLu1COEvfV8L7XzGzv0bxNReZmZvZ7vAKvsjnpptZTIZ4xfK1RE6GAl3ai7EEY3shmCdjRTO+NhP4QqwLEkk0CnRJeOHVdv1oeaC/BnzVzLrEtjKRxKJAl/ZgLFDq7nvNrDNwJs0L9B8TtNLvONFOZpZlZr8Pu2gOmdlrZlbQYJ/OZjbDzPaaWbmZ/Rzo2MhrZZrZTDN738wqzWyhmU1qsM/t4YIIh81sl5nNN7OzmnFeIsdQoEvCCvu/nWARhGHh/UogHVgdPn9rFC+1GXgE+PdwAqXjeZZgLu6vA9cT/H68amanRuzzI4L/GL4L3AgMA77WoO7OBJe4XwL8G8H83zuBv5nZwHCfC4AHCC4Nv5zgUveFQEYU5yPSuHjPgaCbbse7EUw5Oo5gwqIfhff/B1gQ8VzmCb7+IoL5NUYRTGFaA9wePjedcDbX8PFl4b4XRmzrThDEvwkf9wUOA/8RsU8H4O0Gr3U7UAWMiNiWTjA3x0/Cx18HiuL9PdYtuW5qoUvCcvflBF0rI4C54eOBwKvuvjy8RbVCkLuvJ1j95V4zS2tkl0Jgh7vPj/iag8BfCCZeAhgNdOGD2QLxYFrU5zjWJUARsMHM0s0sPdw+HzjahbMcyDezn5vZBeHMeiInRYEuCcnM0sIgPAvoBqwMHxcCS8KgbO7P7w8IWurXN/Jc5Dzdkd4n6H+H4D8TGtmv4eMsgjUyqxvcbiOc69rd/xY+voDgQ9tdZnZ/OMWySIukN72LSFysJ+ifPmp/xP2j80N/h2AR3qi4+1oz+xPwn8BvGjy9DejfyJcN4IN1QreH//bn2LVDG35dObCUxodKHomo5/fA782sH3Ad8HOC82zeSu8iIQW6JKqrCFZE/z7B3OK/JujnngbcHO6ztQWv+32C7pBrG2xfBHzHzC7wYLFnzKwb8AmCVaYgmNe6kmDR3rfDfTrw4UV8XyFYlGGTB6tUnZC77wR+Y2bXEawGL9IiCnRJSO6+CiAcxvczd19qZncCf3X3pSfxusvM7EWCkSWR2+eZ2ULgSTO7F9hN8MFlV+An4T67zWwmQfDXECxYcidwzFWoBCNq7gZeM7OfAiUEH6gWAtvd/edm9h2CrpzXgF0EY+svRK1zOQnqQ5eEZWYjCfqjF4SbPkYwHPBkfe84268BXiYYSfMHghV1Lnb3dRH7/DvwEPAtghWKtgKRy63h7pXAR8LX+g7wEvALPlhmDIKROyMJhi7OI+ie+Xa4n0iLaMUiEZEkoRa6iEiSUKCLiCQJBbqISJJQoIuIJAkFuohIklCgi4gkCQW6iEiSUKCLiCQJBbqISJL4/ypmk0TjIAFkAAAAAElFTkSuQmCC\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,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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,
   "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,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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,
   "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,
   "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,
   "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,
   "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
