{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 194,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os.path as osp\n",
    "import os\n",
    "import time\n",
    "import multiprocessing\n",
    "import pickle\n",
    "import math\n",
    "\n",
    "import torch\n",
    "from torch_geometric.data import InMemoryDataset, download_url, Data\n",
    "import torch.nn.functional as F\n",
    "import torch_geometric.transforms as T\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "from numpy.linalg import inv, pinv\n",
    "from torch_geometric.utils import to_undirected, to_dense_adj\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "class Games(torch.utils.data.Dataset):\n",
    "    def __init__(self, root, n_graphs, n_games=200, n_nodes=50, m=2, p=0.2, target_spectral_radius=0.9, homophilous_marginal_benefits=True, marginal_benefits_noise_variance=0.1, graph_type=\"barabasi_albert\", game_type=\"linear_quadratic\", regenerate_data=True, transform=None):\n",
    "        super(Games, self).__init__()\n",
    "\n",
    "        self.n_graphs = n_graphs\n",
    "        self.n_games = n_games\n",
    "        self.n_nodes = n_nodes\n",
    "        self.m = m\n",
    "        self.p = p\n",
    "        self.target_spectral_radius = target_spectral_radius\n",
    "        self.homophilous_marginal_benefits = homophilous_marginal_benefits\n",
    "        self.marginal_benefits_noise_variance = marginal_benefits_noise_variance\n",
    "        self.graph_type = graph_type\n",
    "        self.game_type = game_type\n",
    "\n",
    "        start = time.time()\n",
    "        print(\"Generating graphs\")\n",
    "\n",
    "        self.data_list = []\n",
    "        for j in range(self.n_graphs):\n",
    "            data = self.generate_network_game(self.n_nodes, self.m, self.n_games, self.target_spectral_radius, self.homophilous_marginal_benefits)\n",
    "            self.data_list.append(data)\n",
    "        # with multiprocessing.Pool(processes=10) as pool:\n",
    "        #     self.data_list = pool.starmap(self.generate_network_game, [(self.n_nodes, self.m, self.n_games, self.target_spectral_radius, self.homophilous_marginal_benefits) for _ in range(self.n_graphs)])\n",
    "\n",
    "        print(f\"Finished generating graphs. It took {time.time() - start}s\")\n",
    "\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.data_list[idx]\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data_list)\n",
    "\n",
    "    def get_graph(self, graph_type):\n",
    "        if graph_type == \"barabasi_albert\":\n",
    "            return nx.barabasi_albert_graph(self.n_nodes, self.m)\n",
    "        elif graph_type == \"erdos_renyi\":\n",
    "            return nx.erdos_renyi_graph(self.n_nodes, self.p, directed=False)\n",
    "        elif graph_type == \"watts_strogatz\":\n",
    "            k = math.floor(np.log2(self.n_nodes))\n",
    "            return nx.watts_strogatz_graph(self.n_nodes, k=k, p=self.p)\n",
    "\n",
    "    def generate_network_game(self, n_nodes, m, n_games, target_spectral_radius, homophilous_marginal_benefits, one_cost_all_games=True):\n",
    "        # Adjacency matrix and laplacian are symmetric\n",
    "        G = self.get_graph(self.graph_type)\n",
    "        L = nx.laplacian_matrix(G).todense()\n",
    "        adj = nx.adjacency_matrix(G).todense()\n",
    "        #D = np.diag(np.asarray(np.sum(adj, axis=1)).flatten())\n",
    "        #adj = inv(np.sqrt(D)) @ adj @ inv(np.sqrt(D))\n",
    "        spectral_radius = max([abs(i) for i in np.linalg.eigvals(adj)])\n",
    "        beta = (self.target_spectral_radius / spectral_radius)\n",
    "\n",
    "        spectral_radius_of_betaG = beta * spectral_radius\n",
    "        assert abs(spectral_radius_of_betaG) <= 1, f\"spectral_radius_of_betaG: {spectral_radius_of_betaG} is outside the [-1, 1] range\"\n",
    "\n",
    "        benefit_covariance = pinv(L) if homophilous_marginal_benefits else np.eye(self.n_nodes)\n",
    "        marginal_benefits_noise = np.random.multivariate_normal(mean = np.zeros(self.n_nodes), cov = self.marginal_benefits_noise_variance * np.eye(self.n_nodes), size = n_games).T\n",
    "        marginal_benefits = np.random.multivariate_normal(mean = np.zeros(self.n_nodes), cov = benefit_covariance, size = n_games).T + marginal_benefits_noise\n",
    "\n",
    "        if self.game_type == \"variable_cost\":\n",
    "            # costs = [np.diag(np.ones(n_nodes) / 2) for _ in range(n_games)] ### This is equivalent to linear quadratic, used as a sanity check\n",
    "            #costs = [np.eye(n_nodes)*0.5]*n_games #[np.diag(np.random.rand(n_nodes))]*n_games # [np.diag(np.random.rand(n_nodes)) for _ in range(n_games)]\n",
    "            cost_covariance = pinv(L)*0.1\n",
    "            min_C = 0.1\n",
    "            delta_C = 0.8\n",
    "            if one_cost_all_games:\n",
    "                cost_c_graph = np.random.multivariate_normal(mean = np.ones(self.n_nodes)*0.5, cov = cost_covariance)\n",
    "                #cost_c_graph[cost_c_graph < 0] = 1e-10  # c needs to be positive in order to have nash equilibrium (actions need to correspond to max of utility function)\n",
    "                #print(cost_c_graph)\n",
    "                min_cost_c_graph = np.min(cost_c_graph)\n",
    "                cost_c_graph = delta_C*(cost_c_graph - min_cost_c_graph) / np.max(cost_c_graph - min_cost_c_graph) + min_C\n",
    "                costs = [np.diag(cost_c_graph)]*n_games\n",
    "            else:\n",
    "                costs = []\n",
    "                for _ in range(n_games):\n",
    "                    cost_c_graph = np.random.multivariate_normal(mean=np.ones(self.n_nodes) * 0.5, cov=cost_covariance)\n",
    "                    min_cost_c_graph = np.min(cost_c_graph)\n",
    "                    cost_c_graph = delta_C*(cost_c_graph - min_cost_c_graph) / np.max(cost_c_graph - min_cost_c_graph) + min_C\n",
    "                    #cost_c_graph[cost_c_graph < 0] = 1e-10  # c needs to be positive in order to have nash equilibrium (actions need to correspond to max of utility function)\n",
    "                    costs.append(np.diag(cost_c_graph))\n",
    "\n",
    "            # sanity check\n",
    "            \"\"\"for i, cost in enumerate(costs):\n",
    "                x1 = np.squeeze(np.asarray(inv((2 * cost - beta * adj)) @ marginal_benefits[:, i]))\n",
    "\n",
    "                C_minus_one_half = np.sqrt(inv(cost))\n",
    "                D = inv(np.eye(adj.shape[0]) - beta/2 * np.dot(C_minus_one_half, adj) @ C_minus_one_half)\n",
    "                x2 = 0.5 * C_minus_one_half @ D @ C_minus_one_half @ marginal_benefits[:, i]\n",
    "\n",
    "                assert np.linalg.norm(x2 - x1) < 1e-5\n",
    "            \"\"\"\n",
    "\n",
    "\n",
    "            actions = [np.squeeze(np.asarray(inv(2 * cost - beta * adj) @ marginal_benefits[:, i])) for i, cost in enumerate(costs)]\n",
    "            actions = np.stack(actions, axis=1)\n",
    "\n",
    "            actions_no_C = [np.squeeze(np.asarray(inv(np.identity(self.n_nodes) - beta * adj) @ marginal_benefits[:, i])) for i, cost in enumerate(costs)]\n",
    "            actions_no_C = np.stack(actions_no_C, axis=1)\n",
    "        elif self.game_type == \"linear_quadratic\":\n",
    "            actions = np.matmul(inv(np.identity(self.n_nodes) - beta * adj), marginal_benefits)\n",
    "        else:\n",
    "            raise NotImplementedError(f\"Game type {self.game_type} not implemented\")\n",
    "\n",
    "        edges = np.array(G.edges())\n",
    "        np.random.shuffle(edges)\n",
    "        edge_index = torch.from_numpy(edges).long().T\n",
    "        edge_index = to_undirected(edge_index, self.n_nodes)\n",
    "        x = torch.from_numpy(actions).float()\n",
    "        x_no_c = torch.from_numpy(actions_no_C).float()\n",
    "        b = torch.from_numpy(marginal_benefits).float()\n",
    "        adj = torch.FloatTensor(adj)\n",
    "\n",
    "        return {\"x\": x, \"edge_index\": edge_index, \"b\": b, \"spectral_radius\": spectral_radius, \"beta\": beta, \"adj\": adj,\n",
    "                \"x_no_c\": x_no_c, \"marginal_benefits\": marginal_benefits, \"costs\": costs}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating graphs\n",
      "Finished generating graphs. It took 1.2947957515716553s\n"
     ]
    }
   ],
   "source": [
    "dataset = Games(\"\", n_graphs=100, n_nodes=20, m=1, n_games=50,\n",
    "                    target_spectral_radius=0.5, homophilous_marginal_benefits=False,\n",
    "                    marginal_benefits_noise_variance=0.01, game_type=\"variable_cost\", transform=T.NormalizeFeatures(),\n",
    "                    regenerate_data=True, graph_type=\"barabasi_albert\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2530.3804\n"
     ]
    }
   ],
   "source": [
    "max_values = []\n",
    "for i in range(len(dataset)):\n",
    "    max_values.append(np.max(np.abs(dataset[i]['x'].numpy())))\n",
    "    \n",
    "print(np.max(max_values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 212,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.1622776601683795\n",
      "857.536863078931\n",
      "4179.017459605199\n",
      "[-9.21050136e-01  9.21050136e-01 -4.76919142e-01  4.76919142e-01\n",
      " -3.29562662e-01  3.29562662e-01 -1.80926020e-01 -1.71705231e-01\n",
      " -1.63286682e-01 -1.16589768e-01 -5.80766671e-02  1.80926020e-01\n",
      "  1.71705231e-01  1.63286682e-01  1.16589768e-01  5.80766671e-02\n",
      "  2.24625389e-17 -8.88329126e-19 -8.88329126e-19  7.78686311e-18]\n"
     ]
    }
   ],
   "source": [
    "max_eigenvalues_C_minus_one_half = []\n",
    "max_eigenvalues_D = []\n",
    "max_eigenvalues_T_ = []\n",
    "max_eigenvalues_all = []\n",
    "for i in range(len(dataset)):\n",
    "    C_minus_one_half = np.sqrt(inv(dataset[i]['costs'][0]))\n",
    "    T_ = C_minus_one_half @ dataset[i]['adj'].numpy() @ C_minus_one_half\n",
    "    T_ = (T_ + T_.T) / 2\n",
    "    D = inv(np.eye(20) - dataset[i]['beta']/2 * T_)\n",
    "    \n",
    "    max_eigenvalues_C_minus_one_half.append(np.max(np.abs(np.linalg.eigvals(C_minus_one_half))))\n",
    "    max_eigenvalues_D.append(np.max(np.abs(np.linalg.eigvals(D))))\n",
    "    max_eigenvalues_T_.append(np.real(np.linalg.eigvals(T_)))\n",
    "    max_eigenvalues_all.append(np.max(np.abs(np.linalg.eigvals(C_minus_one_half @ D @ C_minus_one_half))))\n",
    "    \n",
    "print(np.max(max_eigenvalues_C_minus_one_half))\n",
    "print(np.max(max_eigenvalues_D))\n",
    "print(np.max(max_eigenvalues_all))\n",
    "\n",
    "idx_max_i = np.where(np.asarray(max_eigenvalues_D) == np.max(max_eigenvalues_D))[0][0]\n",
    "print(max_eigenvalues_T_[idx_max_i]*dataset[i]['beta']/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 206,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "39"
      ]
     },
     "execution_count": 190,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx_max_i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 8.38024309, -6.38024309,  6.50761834,  5.25338802,  4.50718464,\n",
       "       -4.50761834, -3.25338802, -2.50718464,  1.        ,  1.        ,\n",
       "        1.        ,  1.        ,  1.        ,  1.        ,  1.        ,\n",
       "        1.        ,  1.        ,  1.        ,  1.        ,  1.        ])"
      ]
     },
     "execution_count": 186,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.linalg.eigvals(np.eye(20) - T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.]])"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "D_ = C_minus_one_half @ dataset[0]['adj'].numpy() @ C_minus_one_half\n",
    "D_ - D_.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "C_minus_one_half = np.sqrt(inv(dataset[0]['costs'][0]))\n",
    "D = inv(np.eye(20) - dataset[0]['beta']/2 * C_minus_one_half @ dataset[0]['adj'].numpy() @ C_minus_one_half)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.127621\n"
     ]
    }
   ],
   "source": [
    "max_values = []\n",
    "for i in range(len(dataset)):\n",
    "    max_values.append(np.max(np.abs(dataset[i]['x_no_c'].numpy())))\n",
    "    \n",
    "print(np.max(max_values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7f947b59bcc0>"
      ]
     },
     "execution_count": 170,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh0AAADvCAYAAABWpWbcAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAAgAElEQVR4nO3de5Cdd33f8c/3nL3ftCutbrZuNpaN5cQ2iWIglJZragiNaZNpAkmGtJlxkoYMmdKhJkwnzUymk95CmGkmgwIudCAJTAKFUAIxLoGmSYxlMOC7ZWFZkldarXalve+5ffvHHpe1Yz3fn3bPec7q8fs1c0Y653z3Ob/n9zzn2d8+l89j7i4AAIB2K3W6AQAA4KWBQQcAAMgFgw4AAJALBh0AACAXDDoAAEAuGHQAAIBcMOgAAAAvysxGzexPzewxM3vUzF69kel1taphAACgcD4k6Uvu/lNm1iNpYCMTM8LBAAAohn/8+kE/P11Pqn3gOytfdvfbL/W+mW2R9KCka71FgwX2dAAAUBBT03Xd9+U9SbXdu596uZkdXfPSEXc/sub5NZLOSfrvZnaLpAckvcfdF9bbPgYdAAAUhqvujdTiKXc/nPF+l6QfkvRr7n6fmX1I0l2S/t16W8eJpAAAFIRLasiTHglOSTrl7vc1n/+pVgch68aeDgAACsLlqnraOR3htNzPmNlJM7vB3R+X9EZJj2xkmgw6AAAokMS9GKl+TdInm1euHJf0LzYysY4dXjGz283scTM7ZmZ3daodRWNmd5vZpJk9tOa1rWZ2j5k92fx3rJNtvJKZ2V4z+6qZPWJmD5vZe5qv08ctZGZ9ZvYNM/t2s59/q/n6NWZ2X3O78anmhhAbYGZlM/uWmX2h+Zw+voK5pLo86ZE0PfcH3f2wu9/s7m9395mNtK8jgw4zK0v6fUlvkXRI0jvM7FAn2lJAH5P0wkug7pJ0r7sflHRv8znWpybpve5+SNKrJP1qc92lj1trRdIb3P0WSbdKut3MXiXpP0r6oLtfJ2lG0i92sI1F8R5Jj655Th9f4Vp4TkfLdWpPx22Sjrn7cXevSPoTSXd0qC2F4u5flzT9gpfvkPTx5v8/LuntuTaqQNx9wt2/2fz/nFY31leLPm4pXzXffNrdfLikN2j1ZDaJft4wM9sj6cclfaT53EQfX9FcUt096dEJnRp0XC3p5Jrnp5qvoT12uvtE8/9nJO3sZGOKwswOSHqFpPtEH7dcc7f/g5ImJd0j6SlJF9y91ixhu7FxvyfpfZKeu8Zym+jjK14j8dEJXDL7EtNMlSOGdoPMbEjSn0n6dXefXfsefdwa7l5391sl7dHq3tGXd7hJhWJmb5M06e4PdLotaB1PPJ8j9ZyOVuvU1SunJe1d83xP8zW0x1kz2+3uE2a2W6t/OWKdzKxbqwOOT7r7Z5ov08dt4u4XzOyrkl4tadTMupp/ibPd2JjXSPoJM3urpD5JI1q9zwZ9fAVzl6qb+E+eTu3puF/SweZZ0j2SfkbS5zvUlpeCz0t6V/P/75L0uQ625YrWPOb9UUmPuvvvrnmLPm4hM9tuZqPN//dLerNWz5/5qqSfapbRzxvg7u939z3ufkCr2+D/7e4/K/r4CmeqJz46oSODjuYI+t2SvqzVDcmn3f3hTrSlaMzsjyX9raQbzOyUmf2ipN+R9GYze1LSm5rPsT6vkfTzkt5gZg82H28VfdxquyV91cy+o9U/Uu5x9y9I+reS/rWZHdPq+Qcf7WAbi4o+voK5pIanPTqBu8wCAFAQP3Bzj3/6f21Pqr1p37MPBPdeaTkSSQEAKIjVcLDOHDpJwaADAIACaTiDDgAA0Gbs6QAAALlwmape7nQzLqmj4WBmdmcnP/+lgn5uP/q4/ejjfNDPV7bn9nRwyeyLY+XOB/3cfvRx+9HH+aCfr2imupeSHp3A4RUAAArCJTU6vj/h0nIddJSHB71r++j3n49vUe+1Vz8/KKSRsMunFGeLWCXu9JSBXnkprqkPJLSnO769ji1kH4dLOSHZe/9+W8rbRtV7zZ7vv2EtymapJzQoZQ9ewjJP6b/urnpYU63Fxzo9oT3lF3xW9/YRDRzc/fyOvRh/vep9YUnSvHs1e2Xu6auG06isdIc1pUpYokZPvH519cTLqr7w/P7r2jKmvqv2Pm/iNhBPp1GNl7nF3aOuobio3og3Ko3lhOPtPfEyLyVsBxsp6/LC89vcPTymgZ3P7+eesZXMaSwt9YSfk7IB6+qthTW15fh7ZSn9N5+wrIbj9Suar+q5C6rPLuR6LKOwJ5Ka2e1azeovS/qIu2emMHZtH9VVv/2rmdNsrMRfyFLCBqvrmXhrXhuMv7RjD8UL7/zhuD3944thjT0wkvm+JyytpWuzNw6SVE74QqZkxjXm419SSviFWZqNZ6xnz0JYs2t0NqyZmMnuY0mqLMXzNToWt0d/sTUsuXh93NHlXfHItzbZn/n+vhvPhNN45sn4xrj9p+Lv5+L++BfH9r0zYc3cfXHAUdcrLoQ1C88OhzW9Z+P52vqjcR9eWMheDpJUeTJeB7UvXuZ9/fEIcHGhN6wZ/kbc5n0/eTzz/e8+ui+chlXiben4y6bDmvOPbwtryrvj/hv428GwpvIP421KLRjUnvqNPwin0Uru1rFDJynW3TIzK0v6fUlvkXRI0jvM7FCrGgYAAC5fQ5b06ISN7Om4TdIxdz8uSWb2J5LukPRIKxoGAAAuj8tUSdkt3iEbadnVkk6ueX5K0itfWNS8/OpOafUcDgAA0B4v+RNJ3f2IpCOS/v5JowAAoKXqBY1BPy1p75rne5qvAQCADnCZ6gXd03G/pINmdo1WBxs/I+mdLWkVAABYl8Ymvnpl3YMOd6+Z2bslfVmrl8ze7e4PZ/5QpaTSqexLWbuvnY8/+4mhuIEH40sa7dRAWLN4+1w8nYn40qvlhfg6dj+YfQlcKSH3ofts/DnVnfGldqWZ+LLRnqV4F17v+bjNcwfjSyyXz8eX9Z2sxJ/l5+JLCLU17p+ZU/H5SX07EzISdsWXUlfn4mXavTN7Os+ciS/fLY0mXIJpCVkeg3GeRcrlsNWR+HLrl43Fl94+fCbeXmxLuBz23APxJcW1/cthjQ8kXLJ+MV7m9Z74e7Nr/GJYc2Eo/m6dW8zexvVNxN+9ypZ4vqeeitfTnrn4F+rKaMLl/AkH+y0h06ga5Iak5P600moMegEHHZLk7l+U9MUWtQUAAGzAZr/h2+a9rgYAAFwWdxUzHAwAAGw2acFglxMOZmZlM/uWmX1ho61jTwcAAAXhasuejvdIelRSQoZ/NvZ0AABQIHWVkh4pzGyPpB+X9JFWtI09HQAAFITL1EgPBxs3s6Nrnh9pBnqu9XuS3icpvnNiAgYdAAAUyGVcMjvl7ocv9aaZvU3SpLs/YGava0XbGHQAAFAQLb5k9jWSfsLM3iqpT9KImX3C3X9uvRPMddDRN1jRwVeeyKw5MT0WTmdpNA6Z2fL1OBCo6y1TYU3tL8bDmpWDcXsaC3FX7/5a9uh08rZwErJr4lC03oTAm56xOLSq8u14Wc0digOnVItH5TfecCqseezE7rAmZaejTcfBTH174hC7JYvD57pPxDX918UBdcuLQZtTgpCC4D5JKnfFE7LZeDr1Q3H/lY/FoXtPnIlDxrrH4sCuZ8/E67IlBH8NPBgHbdVeGS/Plcl4vQiXuaSLR+Pz/hb3JYTzPRb088GlcBoprkoIM5uciffy9z4RrzspN2Kt1+Nt09i27HX5XFc9/qAWcrUukdTd3y/p/ZLU3NPxbzYy4JDY0wEAQKHUL+Ny2Lwx6AAAoCDcrS33XnH3v5L0VxudDoMOAAAKZDMnkjLoAACgIFy6rLTRvDHoAACgMIw9HQAAoP1c4i6zAACg/S4zkTR3DDoAACiQxia+rVqug46VhR499Tf7M2sq2+Igld7z8a6jpR1xe2qPbgtr+lLS5rethCX9T8ShQedekR28NHbD+XAaU2cSbgJYj0fB9eFqWGO9cVDU1p2zYc3sI/FyeGIiXqBei+fLR+IgpHJfXFM7Fq8Ygxfi9lSH4z5cPhsHHZXnsjcyI8fDSWj6lfEy73smDqRKOZy8ciEOEBs5F/ff4rXxhw39dRy0VXvzhbAmJSiqVI2/58szCSFso3GoXjkhdGrh+ng6g4/Hy3ThZdnrRvfJeJ5qu+O2/PTeB8KaD06+Mazx3fG6vBJnCUoJ6+muA9lhb+WEMMZWcpfq7OkAAAB54PAKAABou9VzOji8AgAAckAMOgAAaDuXqdbgklkAAJADEkkBAEDbcfUKAADIDSeSAgCAtiORdI1SRRp4NrszDnzgG+F0nvjDHwlr9u8/F9ZM3B+nw4x/Jw6ZObmzN6wZfbIR1rzhrv+b+f7NA8+E03h4756w5pP3vDasaSwmnIjUE4fe9HXHQVvbPrcY1hz7pbg9fafikKPffucnwprPnb81rHnyzw+FNZWEYLndf7sc1px/b9w/2wcXMt9/YnxXOI0fvv7psOab5exwP0na89l4WT3703FQlJfjzdM7b7o/rPnaJ340rDn77dGwpjocf4eXbojX966ZeL7ueu2fhzX/5VP/LKz55Z+8J6z58FwctvWJN3048/13ffZfhdM4/mMfDWt+61z8vfKFuP/Ki/Ff+sPXxYFwK/dvDWtmd2Vv/ztxqINzOgAAQNu5CAcDAAB5cC6ZBQAAOXBxeAUAAOSEwysAAKDtOKcDAADkhkEHAABoO3I6AABAPlyqbeJEUnOPA55apffaq/3q/xCEyJzuD6fj3XGbSzvi0CWf6AtrrBqPGOsDcWhQ146l+LOODWZPYzFuS9dtM2HN/Fw83yknPzeW4jHrwPe6w5rFl8VBUarGXyLrj4OZymfjILfe8/HMV4fidbB7IZ7O8ni87pQS1sHu2eyaxf1x3yhuinpm4kvxqiMJ34ft8fehuhiHvXX3x+F91cV4HbT5eF3u3zMX1iyfiBPhGn0JHZ0iYTvYdT6er0ZCyJ92rGRPYzleL0qzcVtKlXhdb+yJt+3lk/E2rrqlHtZYI25PeSF723TqQx/UyqmTue16GLlhp7/yw+9Mqv3K63/vAXc/3OYmPQ97OgAAKJDCHl4xs6clzUmqS6rlPWICAADf18pzOsxsr6T/IWmnVi+MOeLuH9rINFuxp+P17j7VgukAAIAN8tbt6ahJeq+7f9PMhiU9YGb3uPsj650gh1cAACiQViWSuvuEpInm/+fM7FFJV0ta96Bjo6e4uqS/NLMHzOzOFyswszvN7KiZHa3PZd8JEwAArJ/76jkdKQ9J48/9fm4+XvT3uCSZ2QFJr5B030bat9E9Hf/A3U+b2Q5J95jZY+7+9bUF7n5E0hFp9eqVDX4eAAC4JFO9kbw/YSrlXEwzG5L0Z5J+3d1nN9K6De3pcPfTzX8nJX1W0m0bmR4AANgYd0t6pDCzbq0OOD7p7p/ZaNvWPegws8HmiSUys0FJPybpoY02CAAArM9z915JPLySycxM0kclPeruv9uK9m3k8MpOSZ9dbZO6JP2Ru38p8yeqJdmpIPwrITfHE1pdW4gDgTQaByZZSujNcsKI8Xh28JckVceyZ76yKw6z6VmJ57uxkjBPvfFnlebj6aSEX6UEfw2ciBf64sH4s2pb4zCp2pYWnYQ1kxDMlLCa9sxsvD1Wj6fh5fjoZ2VbwnqxFC/PxqmBsMb6EwLYtsQhY333x9+9uYPxtmDxXDwdSwkurMT9k/JHqGXndUmSytfOhzWNSryelruyl3v5XBzG1UjYbvu+eHmWot8hkrb84PmwZvbb28Ka6t64k+sefInzDgf11fM6WuQ1kn5e0nfN7MHma7/h7l9c7wTXPehw9+OSblnvzwMAgNZr4dUrf62kfOp0XDILAEBBuFqa09FyDDoAACgM7jILAABy0ki4UV2nMOgAAKAg3Dm8AgAAcsLhFQAAkIsWXjLbcgw6AAAoEA6vPMekem/2EKx3Ok5SWdlVCWtK03HqkiXkVtW3xqFB9TgXR/VaQvpbFBpUi/tmbHgxrJl5Ig45quxIWGkH4qCoFIPb4zYv1obiCSUsz5Q+7J6JQ89qV8WhQeXlhKC2+KO0sj1hxoIS74qnMXQsbu/yePwnVG1bHMBmS/GMd21dDmuWJhLWiwPxemoD8fc8RWm+J6ypJ/RP6WK8LEo74/6pnYj7pzEc94/Xs+fL+uL1whI2F/WLcf/1JISiXXwoDv5KCZlM4X3Bd6uU724HV3rEeSewpwMAgALZxEdXGHQAAFAYLjmXzAIAgDxweAUAAOSCq1cAAEDbce8VAACQD5fEoAMAAOSBwysAACAfDDqe+7SGytuzA20q2+LdQgPf7Q9r6r1xcxo3zcfTWYjDagZGl8KaxQtxmwefyg5MCvJ5JElLj+4IayqH4nCiweNxONHQ6Thwam5vHMa14HFY2fiBmbBmeiaeTiMhHKx8Xbxe1BLWC0vImxo8Ha/vy69eCGsqM9kJdaWFOIxr5Yfj+R74uzhsajbOZdKO++L5nj40ENa8/NUnwpqLK3F6X7Ue98/yvdvDmpVtCVv7qXjd6dofL4vK2bh/uhICuYZ3z4Y1+0ezv38TH7k2nMbMTXFbek7Fv5KWr0oIe9uSECD5bLxeDAzFSWRLU8PZBfW8D3UYl8wCAIAccJdZAACQGw6vAACAfLCnAwAA5IE9HQAAIBcMOgAAQNtxwzcAAJAb9nQAAIBccMnsqlLJ1T+QHbYydz4OeFq8MQ5s6T4ZB/BUz8aBXUPPJIQGbY+DtLQ9DuSavyY7TcoSQmYaPXH4lVXjmuWb48AzKe6/xQPxfNty3Mfnp+NQKl+Kp6M4z0wrCcFfIw/E6XMXD8XpYMu1eJmW6/Hy6h9fzHy/8r0gwEhS3zfiPq6MhCXqfzrhu/fTU/GEvhunjD320N6wZnhvHH61tJTQ5kNx4FT5YrxJ3XXTZFgzcW5LWOP9cUhWtS9e4S+cj5f7hclg/XltQhJed9yW6nj8fehL2LbX5uLgr1rCNlnL8ba9sSWY93L+ux1sE+/piLdmAADgyuCX8UhgZreb2eNmdszM7tpo8xh0AABQGLZ6eCXlEU3JrCzp9yW9RdIhSe8ws0MbaR2DDgAAiqR1ezpuk3TM3Y+7e0XSn0i6YyNNY9ABAECRNBIfsaslnVzz/FTztXXj6hUAAIrCdTlXr4yb2dE1z4+4+5HWN+r7GHQAAFAgl3H1ypS7H854/7SktZeI7Wm+tm4cXgEAoEhad07H/ZIOmtk1ZtYj6WckfX4jTct1T4dLqtWCLIWEDIme4ThDwi2+lru0En/W/HUJ15/3xtfLl7riA2g9z2S3uTKacBAuYbda13w83/VqnEOxvCNuT3k2XsXqY/H18r19cU09oY/9dJwt4gnrxex1CctzOs4Nqe6NM2dqswnr8ljQnoQ/fZZ2hSWqDyasgylZKMe2hjW+J+6b0tl4PZ2fjzMbfDruY0uIgakPxduCiUd2hDWNgYROLMXLtO9UnDPhCfNlwWytbI/nu39bdpaMJC2ei3OaKtG6LsnH4kyVrol43amNJvw+Op/dgZaQxbNZuXvNzN4t6cuSypLudveHNzJNDq8AAFAgrQwHc/cvSvpiq6bHoAMAgCLZxDHo4b4jM7vbzCbN7KE1r201s3vM7Mnmv2PtbSYAAAi5WnnJbMulnEj6MUm3v+C1uyTd6+4HJd3bfA4AADrMPO3RCeGgw92/Lmn6BS/fIenjzf9/XNLbW9wuAACwHi2890qrrfecjp3uPtH8/xlJOy9VaGZ3SrpTkrrG4zsnAgCADSjyXWbdPXPM5O5H3P2wux8ubxnY6McBAIBLSD20smkPr1zCWTPbLUnNfydb1yQAALBuLbrLbDus9/DK5yW9S9LvNP/9XMoPebWs5bPZ4S/lpbgjGheGwpr6/uWwppwQJlW/EAfIpCy8xlwc0tMoZw89G/1xAM9KX2tChcqzcWLQyPUzYc3F4wkXNtXisW/tZBwa5DviMKnGYEKQ23Lcnr6puKZ6YxyGVJqIg6tK1YSNw1R2/3QnBBQ1bpyPa07HeytT+rhrPA5vqs7HgV0918yFNf298WfNXIg/yxP+NOyZSgjDiz9Kg0/H01m5OV6/upbj7c7yrfF0Gmey19OUAKyV4yNhTW+c+6jKgYTQuGBbKkmNnrjG+uJ1uTqUvS3wTuR+b+LDK+GabWZ/LOl1Wr0xzClJv6nVwcanzewXJZ2Q9M/b2UgAAJDGOnQ5bIpw0OHu77jEW29scVsAAMBGdPB8jRQkkgIAUCQMOgAAQC4YdAAAgDxs5sMrnTivFgAAvASxpwMAgCLZxHs6GHQAAFAUfoVfMttS5vIgkKtUTQjX6YuHcd29tXg6x+OQMe2ohiU2HwdppRzIqmzPDqIpJ3xOfTgOs7Fq3JhGf9zH9a9uC2v8urg9SbdYThi5ez2er67ROCiqlhAUtbQvoZ8TQs+6F+NQpepo3EGllezpVIYS2nuuP6zxlPWrkhCcthCHViklFO1bceDUzI6E/ou/5pLi9lR2xhPq/168fi3uifvZL8bTmb8+Xt9Lk3FAXe++7OC4pdl4GoOPx+1duCbebmsx/h3RqMTLygfi9aL7TNzm6miwrDpxggV7OgAAQLuZNveJpAw6AAAoEgYdAACg7UgkBQAAuWHQAQAA8sDVKwAAIB/s6QAAAG3nYtABAADywYmka5Wze2NgIg51md8f92j12cG4KQnHvUoX4i5KOX42cN3FsGbx2JbM9+tbEoK26gmBSkNxgFHfYBwqNNeI+7h7fCmu+VYc0rZ4dTzvY9vmwprpU6NhjTUS+rA7YVnMxgFYjTh7KAz+kqT61uxQpa33xW2ZvjWep+5z8ffh0GuOhzXfeehAWNN7Lg7Dq4y1KvgrNnL9TFgzcz5el5f2xQ0qD8c19YSQrJuuOx3WTPzRgbBmbmf2sugdWgmnUX71QlgzkBDwV1mJ1+X6VG9Y0zcR99/K1oSNe3dQk7A5aTkGHQAAIA+beU8Hd5kFAKBIPPGxQWb2n83sMTP7jpl91szCXckMOgAAKAjz9EcL3CPpB9z9ZklPSHp/9AMMOgAAKJKc9nS4+1+6+3MnlP2dpD3Rz3BOBwAABXIZezHGzezomudH3P3IOj/2X0r6VFTEoAMAgCJJH3RMufvhrAIz+4qkXS/y1gfc/XPNmg9Iqkn6ZPSBDDoAACiSFl694u5vynrfzH5B0tskvdHdw09m0AEAQFHkeJdZM7td0vsk/SN3X0z5mXwHHS6pln3u6sWXZ4ccSZINxTW+EM9aeSkOH2qMJLQnYTpzzw6HNd2V7BQZOx/PU/d8nESzckMcPFR7Mm6v7VkOa6pn+8Oayv6EPq7E5zxPn46Dv7ouxstK++JAs/pMHD7UNR+3uTYUhw91zcXTaSxkz1fpn5wPp6GJ7HA6SWr0xFuzk7PxdLwUT6fWF9d07YsDp2on4sCulACx2bmBsMYS5ss9IextNk6NKyWE/D3y7f1hjW6J18Hex7ODAKsH4++MPx4vh/q18Tal9ExfWGMJ607Kuty1FC8rXw7CymodSAfLL6fjv0nqlXSPmUnS37n7L2f9AHs6AAAokLzuMuvu113uzzDoAACgQDZzIimDDgAAioK7zAIAgNww6AAAAO1m4vAKAADIC4MOAACQB4szujqGQQcAAEXh+V0yux6bbtDRPxE3qXpjJazxxdYEM/WcCYJfJDXiHB/VhuphjQdNLq/EITO1m+KwpMbFhGCruLmys/F0GsMpE4pLemfi5bm8JyE0bl/CunM2IXworEjbw2lBIJyUtgEpB+v71Kk4OG3we/F3b3k8nqvpyZGwRl3xdGx/HHBYORMHdvVdiPu4MhZ3cmMqXt8H9s6FNYsJK08p4btV74nb3J3wYdWEea9en70sUr4PlZ3x97PnePzdq47E604p4XvVSPntlzBj4ba93IG9Dpt3R8fmG3QAAID128wnkoZ/PprZ3WY2aWYPrXnt35vZaTN7sPl4a3ubCQAAknjiowPifdbSxyTd/iKvf9Ddb20+vtjaZgEAgMvWvOFbyqMTwkGHu39d0nQObQEAABt1he/puJR3m9l3modfxi5VZGZ3mtlRMztan49PcgQAAOvzXDjYFbun4xL+QNLLJN0qaULSf71UobsfcffD7n64PJR9e2QAALAx1vCkRyesa9Dh7mfdve7uDUl/KOm21jYLAABcttRDK1fSng4z273m6T+V9NClagEAQH6skfbohDCnw8z+WNLrJI2b2SlJvynpdWZ2q1bHSk9L+qWUDyutmIaeyv7IpVuXwunUl+J4EetuTYBMSqCNEhbe6K6E0KCZS54as9qW8YSgrak4XEe9cYNTgshSQtGSgnEa8Wd13zoT1iyfGQ5rxu7pD2sWd8XtWboqXhbde+fDmurxuM290wnr6Suz16/aVDzf1eGE70zK12G5HNZ4Kf6sWjVhOoPxcrAfipdD10Nb4s9KaHP56/F0dOtKXJNwwH3gyfgLWL0lnndbjgMQ63PZNT2T8Ta5K2F7UX9ZvP23yXgb130g4bv39FBLpmNPZk/H6inRaS22iXM6wjXF3d/xIi9/tA1tAQAAG7SZw8FIJAUAoChcEjd8AwAAeeCGbwAAoO2ey+nYrBh0AABQFO4cXgEAAPlgTwcAAMgHgw4AAJAH9nQ0lUZqGnrD2cyavnocCDRjA2GNX4xnrXtffAO6xmT8WaWxOOxn9nujYU05yJCxlMCugYTgr7m4j5d3JIRfXYwDbfueSUgESsjOqYzGy7NnbDmsmb4lXp5dcY6bvC/u5+XTcfjQQELw19LOhCCtC0FgUn+8POt98fIcPBnXzCasO7YUr4PdJ3rDmsqeSljTVY6X1eLV8XQGnorX5eVtCVv7uYRt03zcz9Wb4+1X7VwcCpcSsDayMzska1bxum61hADsqXiZlxIyEpdn4+n07o+Dv5an4yAyG8levzxe1VvLJXXoviopNnKXWQAAsMnkHYNuZu81Mzez8aiWwysAABRJjlevmNleST8m6ZmUevZ0AABQIOZpjxb5oKT3KfH0VfZ0AABQFJd32/pxMzu65vkRdz+S+sNmdoek0+7+bbO0G9sx6B21ZeQAAATtSURBVAAAoCBWE0mTRx1T7n44c3pmX5G060Xe+oCk39DqoZVkDDoAACiSFp4k6u5verHXzewHJV0j6bm9HHskfdPMbnP3M5eaHoMOAAAK5DL2dKybu39X0o7//5lmT0s67O5TWT/HoAMAgKJw39Q5HbkPOtyzTzY5Px2HzHgl4aKb0VpqkzL1nYmTXRpTCWFlXRtfCUaeiue70RXXvOpnvxXWfONjrwhravFsJwVb1bdWw5q+R4bj9gwm9HE5rml0J0zmQvzV8e74s6rDCcFfI3EaUs9kdnu6FuKTvBaviZfDwp6Ek8XqcU3K96r2A3F40y/ceDSs+dyJHwxres7GC73nVdNhjf3N1rBm8JYLYc32Q3Hw12wlDsCaOhF/SXueTdjG3baY+X5XQhhjoyde18vL8bozdCheDvMPxcuhshjPdzkhkLG+NfhdU8p/ANCJRFJ3P5BSx54OAACKhLvMAgCAtvPWpo22GoMOAACKhD0dAAAgF5t3zMGgAwCAIsnjktn1YtABAEBRuKQ6gw4AANBmJmdPBwAAyAmDjlW1almTk1sya4ZHs0NoJKlWjwOw/MHsz5GkRldPWFPZGl971BiKw5tSApN2fS17vs68PiHwLGFdu/f/3BIXXRNPaPBgHHJUfzYO9eoZqsTT6YvDm+pbEvqnO16evcMrYc3Sxb6wpjwTf70q2+J156oDmanCkqSpczsz39/2uolwGosnxsOalKCj7uF4eS7tjz/KJvvDmo8tvTqe0FIcAtV/w1xYc+H0SFhjN8brTulr28KaEyNxTeOGODytvjtuz+KOeHtqs9nru6d89xJy5awWL6v6vXHf2PaEDeGWOAyvvhK3py/YXlgHwsEYdAAAgPZztfSGb63GoAMAgALhnA4AAJAPBh0AAKDt3KXG5j2+wqADAIAi2bxjDgYdAAAUCed0AACAfDDoAAAAbeeSGgw6JEmVp09PnXjX+0+seWlcUpx89BLxTFTwR+ueNP3cfm3r43C9SHCsBdPYBFiP80E/t1ZCFF4rOXs6nuPu29c+N7Oj7n44zza8FNHP7Ucftx99nA/6uQAYdAAAgLZzSfXNe/kKgw4AAArDJWfQcSlHOvz5LxX0c/vRx+1HH+eDfr7ScXjlxbk7K3cO6Of2o4/bjz7OB/18hePqFQAAkBv2dAAAgFww6AAAAG3nLtXrnW7FJZU63QAAANBC7mmPFjCzXzOzx8zsYTP7T1E9ezoAACiSnA6vmNnrJd0h6RZ3XzGzHdHPMOgAAKAwPM+rV35F0u+4+4okuftk9AMcXgEAoChccm8kPSSNm9nRNY87L/PTrpf0WjO7z8y+ZmY/Ev0AezoAACiS9D0dU9F9dszsK5J2vchbH9DqGGKrpFdJ+hFJnzaza90vfXyHQQcAAEXSwnM63P1Nl3rPzH5F0meag4xvmFlDq3cpPnepn+HwCgAARfHcJbMpj437n5JeL0lmdr2kHklTWT/Ang4AAArEG7nd8O1uSXeb2UOSKpLelXVoRWLQAQBAgbQugyP8JPeKpJ+7nJ9h0AEAQFFwwzcAAJAbz+3wymVj0AEAQEG4JGdPBwAAaDt39nQAAIB8+Ca+y6wFV7cAAIArhJl9SasBXSmm3P32drbnhRh0AACAXJBICgAAcsGgAwAA5IJBBwAAyAWDDgAAkAsGHQAAIBf/Dyp3Z+gvKMZGAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.matshow(dataset[0]['x'])\n",
    "plt.colorbar()\n",
    "\n",
    "plt.figure()\n",
    "plt.matshow(dataset[0]['x_no_c'])\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 2.56099676e+00,  2.16987824e+00,  1.99864675e+00,  1.94513302e+00,\n",
       "        1.89239634e+00,  1.84826667e+00,  1.45625639e+00,  1.13591779e+00,\n",
       "        1.06365492e+00, -4.30000689e-02,  2.35813769e-03,  7.89828047e-01,\n",
       "        6.69295808e-01,  6.10055980e-01,  5.27275062e-01,  5.09437911e-01,\n",
       "        1.58673122e-01,  3.59067586e-01,  2.63910305e-01,  2.75283015e-01])"
      ]
     },
     "execution_count": 116,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#np.linalg.eigvals(inv(np.identity(20) - dataset[0]['beta'] * dataset[0]['adj'].numpy()))\n",
    "np.linalg.eigvals(2 * dataset[0]['costs'][0] - dataset[0]['beta'] * dataset[0]['adj'].numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {},
   "outputs": [],
   "source": [
    "x2 = []\n",
    "for i in range(dataset[0]['marginal_benefits'].shape[1]):\n",
    "    C_minus_one_half = np.sqrt(inv(dataset[0]['costs'][0]))\n",
    "    D = inv(np.eye(20) - dataset[0]['beta']/2 * C_minus_one_half @ dataset[0]['adj'].numpy() @ C_minus_one_half)\n",
    "    x2_ = 0.5 * C_minus_one_half @ D @ C_minus_one_half @ dataset[0]['marginal_benefits'][:, i]\n",
    "    x2.append(x2_)\n",
    "    \n",
    "x2 = np.stack(x2, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10.85126640314371"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max(x2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 3.91733501e-09, -1.26528354e-08, -7.84386689e-09,  2.26188235e-11,\n",
       "        2.20340668e-09,  9.83926176e-08, -1.51229084e-08, -2.85176551e-08,\n",
       "        3.61765728e-10,  4.66469641e-10, -1.37117330e-08,  7.54568130e-09,\n",
       "        7.36570008e-09,  6.80659221e-09, -5.07725140e-09, -3.36481332e-09,\n",
       "       -4.97028272e-08, -5.01385533e-09, -2.42665112e-08,  4.24737943e-07])"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x2 - dataset[0]['x'].numpy()[:, 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7f9478804358>"
      ]
     },
     "execution_count": 160,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.matshow(x2 - dataset[0]['x'].numpy())\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.96485797, 1.48779702, 1.12465071, 0.90022367, 0.67066501,\n",
       "       0.75308843, 1.        , 1.        , 1.        , 1.        ,\n",
       "       1.        , 1.        , 1.        , 1.        , 1.        ,\n",
       "       1.        , 1.        , 1.        , 1.        , 1.        ])"
      ]
     },
     "execution_count": 161,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.linalg.eigvals(D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sigmoid(x):\n",
    "    sig = 1 / (1 + np.exp(-x))\n",
    "    return sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7f9478d98e48>"
      ]
     },
     "execution_count": 163,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.matshow(dataset[0]['x'])\n",
    "plt.colorbar()\n",
    "\n",
    "plt.figure()\n",
    "plt.matshow(dataset[0]['x_no_c'])\n",
    "plt.colorbar()"
   ]
  },
  {
   "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.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
