{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"main.ipynb","provenance":[],"collapsed_sections":[],"toc_visible":true,"mount_file_id":"1PMhHOhurp7SMF1d4NjofxvSdjmWwsjZJ","authorship_tag":"ABX9TyNij/WKK/ZmlAlaAttdican"},"kernelspec":{"name":"python3","display_name":"Python 3"},"accelerator":"GPU"},"cells":[{"cell_type":"code","metadata":{"id":"xdaLwwWgWnqa","executionInfo":{"status":"ok","timestamp":1601627828444,"user_tz":240,"elapsed":906,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}}},"source":["import os\n","os.chdir('/content/drive/My Drive/GCNGAN/GraphCGAN')"],"execution_count":1,"outputs":[]},{"cell_type":"code","metadata":{"id":"jQz6IWmRW7OP","executionInfo":{"status":"ok","timestamp":1601627829465,"user_tz":240,"elapsed":1897,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"b14d0c45-9a4a-4eee-fe32-b22a464cf246","colab":{"base_uri":"https://localhost:8080/","height":34}},"source":["%tensorflow_version 1.x"],"execution_count":2,"outputs":[{"output_type":"stream","text":["TensorFlow 1.x selected.\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"cm20AjqnYDUp"},"source":["# Overview\n","\n","+ Read data \n","  + read and combine\n","+ Apply GNN\n","+ Update Generated nodes"]},{"cell_type":"markdown","metadata":{"id":"OClwhvn38v9E"},"source":["## Explanation 1 (Karate CLUB)"]},{"cell_type":"code","metadata":{"id":"rvMVUqmT8yfL","executionInfo":{"status":"ok","timestamp":1601627843343,"user_tz":240,"elapsed":15770,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}}},"source":["import os\n","#from gan_function import *\n","from util_function.utils import combine_nodes\n","from util_function.metrics import *\n","from util_function.preprocess import *\n","from GNN_Model.model_toy import GCN_Model\n","from GNN_Model.trainer import GCN_Trainer\n","from Generator.model_toy import GraphCGAN_Generator\n","from Generator.trainer import GraphCGAN_Trainer\n","from sklearn.cluster import KMeans\n","from collections import Counter\n","from sklearn.cluster import SpectralClustering\n","import tensorflow as tf\n","import os\n","import time\n","import numpy as np\n","from sklearn.cluster import AgglomerativeClustering\n","from sklearn.metrics.cluster import normalized_mutual_info_score\n","from sklearn.decomposition import PCA\n","import pickle\n"],"execution_count":3,"outputs":[]},{"cell_type":"code","metadata":{"id":"f1d4DlZ8AwzS","executionInfo":{"status":"ok","timestamp":1601627843349,"user_tz":240,"elapsed":15773,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}}},"source":["import networkx as nx\n","import matplotlib.pyplot as plt\n","\n","%matplotlib inline\n","from matplotlib.colors import ListedColormap\n","from matplotlib.markers import MarkerStyle, CARETDOWNBASE\n","import matplotlib.pyplot as plt\n","import numpy as np\n","from sklearn.decomposition import PCA\n","from sklearn.manifold import TSNE\n","\n","def plot(feature_space):\n","  pca = PCA(n_components=3)\n","  pca.fit(feature_space)\n","  feature_space = pca.transform(feature_space)\n","  # feature_space = TSNE(n_components=2, perplexity = 10).fit_transform(feature_space)\n","  categories = np.array(partition_value + [-1] * B) + 1\n","  sizes = np.hstack((np.ones_like(partition_value) * 100, np.ones(B) * 20 ))\n","  colormap = ListedColormap(['k', 'b', 'g', 'c', 'm']) # \n","  scatter = plt.scatter(feature_space[:,0], feature_space[:,1], s=sizes , c=categories, cmap = colormap)\n","  plt.legend(handles=scatter.legend_elements()[0], labels=[\"fake node\", \"group 1\",\"group 2\",\"group 3\",\"group 4\"])\n","  plt.show()\n","\n","\n"],"execution_count":4,"outputs":[]},{"cell_type":"code","metadata":{"id":"TKHhcPhnCmla","executionInfo":{"status":"ok","timestamp":1601627843833,"user_tz":240,"elapsed":16241,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"2caf518b-4c19-4312-af60-19087c9a008e","colab":{"base_uri":"https://localhost:8080/","height":319}},"source":["# load the graph\n","G = nx.karate_club_graph()\n","\n","# visualize the graph\n","nx.draw(G, with_labels = True)\n","\n","existed_edge_list = list(G.edges())"],"execution_count":5,"outputs":[{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"d-YESXjeHnPk","executionInfo":{"status":"ok","timestamp":1601627843834,"user_tz":240,"elapsed":11467,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}}},"source":["## covert Karate graph into adj + attr with format\n","import community as community_louvain\n","from sklearn.model_selection import train_test_split\n","\n","B = 3\n","adj = nx.adjacency_matrix(G)\n","N = adj.shape[0]\n","### build community label\n","features = sp.coo_matrix(np.hstack((np.eye((N)), np.zeros((N, B)))))\n","partition = community_louvain.best_partition(G)\n","partition_value = list(partition.values())\n","n_values = np.max(partition_value) + 1\n","y_val = y_test = y_train = np.eye(n_values)[partition_value]\n","train_unmask_idx, val_test_unmask_idx = train_test_split(range(N), \n","                                                         train_size = 0.4, \n","                                                         test_size = 0.6)\n","val_unmask_idx, test_unmask_idx = train_test_split(val_test_unmask_idx, \n","                                                   train_size = 0.5, \n","                                                   test_size = 0.5)\n","train_mask = np.array([False for _ in range(N)])\n","val_mask = np.array([False for _ in range(N)])\n","test_mask = np.array([False for _ in range(N)])\n","train_mask[train_unmask_idx] = True\n","val_mask[val_unmask_idx] = True\n","test_mask[test_unmask_idx] = True\n","\n","N = adj.shape[0]\n","d = features.shape[1]\n","M = y_train.shape[1]\n"],"execution_count":6,"outputs":[]},{"cell_type":"code","metadata":{"id":"0K0yt4_dTJJa","executionInfo":{"status":"ok","timestamp":1601627854756,"user_tz":240,"elapsed":19197,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"0a1ddcd6-6bcd-4479-b3d9-4c33e1585d18","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["\n","#################\n","## build model ##\n","#################\n","tf.reset_default_graph()\n","gcn_model = GCN_Model(N, d, M, model_name = \"GCN\", batch_size = B, hidden_layer = 8)\n","gcn_model_attr = GCN_Model(N, d, M, model_name = \"GCN_attr\", batch_size = B, hidden_layer = 8)\n","cgan_model = GraphCGAN_Generator(N, d, M, gcn_model_attr, gcn_model, batch_size = B)\n","####################\n","## define session ##\n","####################\n","config = tf.ConfigProto()\n","config.gpu_options.allow_growth = True\n","sess = tf.Session(config=config)\n","sess.run(tf.global_variables_initializer())\n","###################\n","## build trainer ##\n","###################\n","gcn_trainer = GCN_Trainer(gcn_model)\n","gcn_trainer_attr = GCN_Trainer(gcn_model_attr)\n","cgan_trainer = GraphCGAN_Trainer(cgan_model)\n","##########################\n","## initialize fake node ##\n","##########################\n","generated_features = np.zeros((B, d))\n","generated_adj = np.zeros((B, N))\n","###############################\n","## obtain dense adj and attr ##\n","###############################\n","features_dense = preprocess_features_dense(features) \n","adj_dense = preprocess_adj_dence(adj)\n"],"execution_count":7,"outputs":[{"output_type":"stream","text":["WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:30: The name tf.sparse_placeholder is deprecated. Please use tf.compat.v1.sparse_placeholder instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:32: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:34: The name tf.placeholder_with_default is deprecated. Please use tf.compat.v1.placeholder_with_default instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:49: The name tf.variable_scope is deprecated. Please use tf.compat.v1.variable_scope instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:49: The name tf.AUTO_REUSE is deprecated. Please use tf.compat.v1.AUTO_REUSE instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:51: The name tf.get_variable is deprecated. Please use tf.compat.v1.get_variable instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:44: The name tf.random_uniform is deprecated. Please use tf.random.uniform instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:13: The name tf.sparse_retain is deprecated. Please use tf.sparse.retain instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:22: The name tf.sparse_tensor_dense_matmul is deprecated. Please use tf.sparse.sparse_dense_matmul instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:64: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:91: The name tf.get_collection is deprecated. Please use tf.compat.v1.get_collection instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:91: The name tf.GraphKeys is deprecated. Please use tf.compat.v1.GraphKeys instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/metrics.py:6: softmax_cross_entropy_with_logits (from tensorflow.python.ops.nn_ops) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","\n","Future major versions of TensorFlow will allow gradients to flow\n","into the labels input on backprop by default.\n","\n","See `tf.nn.softmax_cross_entropy_with_logits_v2`.\n","\n","WARNING:tensorflow:\n","The TensorFlow contrib module will not be included in TensorFlow 2.0.\n","For more information, please see:\n","  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md\n","  * https://github.com/tensorflow/addons\n","  * https://github.com/tensorflow/io (for I/O related ops)\n","If you depend on functionality not listed there, please file an issue.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:105: The name tf.log is deprecated. Please use tf.math.log instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model_toy.py:115: The name tf.train.AdamOptimizer is deprecated. Please use tf.compat.v1.train.AdamOptimizer instead.\n","\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/ops/math_grad.py:1424: where (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Use tf.where in 2.0, which has the same broadcast rule as np.where\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/Generator/generator_utils_toy.py:49: dense (from tensorflow.python.layers.core) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Use keras.layers.Dense instead.\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/layers/core.py:187: Layer.apply (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use `layer.__call__` method instead.\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/Generator/generator_utils_toy.py:15: calling reduce_sum_v1 (from tensorflow.python.ops.math_ops) with keep_dims is deprecated and will be removed in a future version.\n","Instructions for updating:\n","keep_dims is deprecated, use keepdims instead\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"2pg6LgrATLsL","executionInfo":{"status":"ok","timestamp":1601627863574,"user_tz":240,"elapsed":8568,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"afcd56f8-0099-4850-e597-67de7af34c42","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["val_traj = []\n","test_traj = []\n","test_traj_attr = []\n","for _ in range(15):\n","  ###########################################\n","  ## combine fake nodes to original graph ###\n","  ###########################################\n","  enlarged_adj, enlarged_features, enlarged_y_train, enlarged_y_val, enlarged_y_test, enlarged_train_mask, enlarged_val_mask, enlarged_test_mask = \\\n","                    combine_nodes(adj, features, y_train, y_val, y_test, \\\n","                                  train_mask, val_mask, test_mask, \\\n","                                  generated_adj, generated_features)\n","  enlarged_features_sp = preprocess_features(enlarged_features) ## sparse normalized feature\n","  enlarged_adj_sp = preprocess_adj(enlarged_adj) ## sparse normalized adjancency matrix\n","\n","  ###############\n","  ## train gnn ##\n","  ###############\n","\n","  val_cost, val_acc = gcn_trainer.fit(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_train, enlarged_train_mask,enlarged_y_val, enlarged_val_mask,\\\n","                  epoch_num = 5, print_every = 10)\n","  test_cost, test_acc, pred_result, feature_space = gcn_trainer.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_test, enlarged_test_mask)\n","  #plot(feature_space)\n","  val_traj.append(val_acc)\n","  test_traj.append(test_acc)\n","  ##############################\n","  ## train gnn with attr only ##\n","  ##############################\n","\n","  enlarged_y_attr_hat = np.eye(M)[np.argmax(pred_result, 1)]\n","  enlarged_train_attr_mask = np.array([True] * N + [False] * B)\n","  enlarged_adj_attr = sp.coo_matrix(np.eye(N + B))\n","  enlarged_adj_attr_sp = preprocess_adj(enlarged_adj_attr)\n","\n","  val_cost_attr, val_acc_attr = gcn_trainer_attr.fit(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_attr_hat, enlarged_train_attr_mask,\\\n","                       epoch_num = 21)\n","  _, _, _, feature_space_attr = gcn_trainer_attr.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_test, enlarged_test_mask)\n","  #####################\n","  ## train generator ##\n","  #####################\n","  generated_features, generated_adj = cgan_trainer.fit(sess, adj_dense, features_dense,\\\n","                                                       epoch_num = 10)\n","  generated_features = np.hstack((np.zeros((B,N)), np.eye((B))))\n"],"execution_count":8,"outputs":[{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.69329 D_loss= 0.00000 train_acc= 0.07692 val_loss= 1.63547 val_acc= 0.10000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.57506 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.56087 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.52375 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.49915 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.48604 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.43670 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.36578 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.37357 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.28918 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.31100 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.14181 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.25375 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.28418 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.20399 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.16397 D_loss= 0.00000 train_acc= 0.46154 val_loss= 1.14568 val_acc= 0.50000\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.11691 D_loss= 0.00000 train_acc= 0.53846 val_loss= 1.08723 val_acc= 0.60000\n","Optimization Finished!\n","Test accuracy: 0.45454547\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.95073 D_loss= 0.00000 train_acc= 0.69231 val_loss= 1.02129 val_acc= 0.60000\n","Optimization Finished!\n","Test accuracy: 0.6363636\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.99507 D_loss= 0.00000 train_acc= 0.69231 val_loss= 0.95095 val_acc= 0.60000\n","Optimization Finished!\n","Test accuracy: 0.6363636\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.090909086\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.72949 D_loss= 0.00000 train_acc= 0.69231 val_loss= 0.87671 val_acc= 0.60000\n","Optimization Finished!\n","Test accuracy: 0.90909094\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.6363636\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.81775 D_loss= 0.00000 train_acc= 0.76923 val_loss= 0.79984 val_acc= 0.80000\n","Optimization Finished!\n","Test accuracy: 0.90909094\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.7272727\n","========================================Run cGan========================================\n","========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.61263 D_loss= 0.00000 train_acc= 0.76923 val_loss= 0.72786 val_acc= 0.80000\n","Optimization Finished!\n","Test accuracy: 0.90909094\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.7272727\n","========================================Run cGan========================================\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"8t7zB4Ovbp-c"},"source":["### Plot"]},{"cell_type":"code","metadata":{"id":"LA0D4GsGcMj5","executionInfo":{"status":"ok","timestamp":1601627863574,"user_tz":240,"elapsed":8558,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"fac14796-aec4-48c5-eb1b-135998c863c6","colab":{"base_uri":"https://localhost:8080/","height":34}},"source":["import matplotlib.pyplot as plt\n","\n","\n","thresh_hold = 0.02\n","generated_edges = generated_adj > thresh_hold\n","\n","generated_edge_list = []\n","used_nodes = set()\n","\n","for i in range(B):\n","  for j in range(N):\n","    if generated_edges[i][j]:\n","      used_nodes.add(i + N)\n","      generated_edge_list.append((i + N, j))\n","used_nodes = list(used_nodes)\n","G.add_edges_from(generated_edge_list)\n","G.add_nodes_from([i + N for i in range(B)])\n","used_nodes"],"execution_count":9,"outputs":[{"output_type":"execute_result","data":{"text/plain":["[34, 35, 36]"]},"metadata":{"tags":[]},"execution_count":9}]},{"cell_type":"code","metadata":{"id":"kgJ5ckgtbrBm","executionInfo":{"status":"ok","timestamp":1601627865061,"user_tz":240,"elapsed":10036,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"ea3bc761-4dc2-47dc-d618-f517d43152b8","colab":{"base_uri":"https://localhost:8080/","height":248}},"source":["draw_fake = True\n","partition_dict = dict()\n","\n","for i in range(N):\n","  if partition[i] in partition_dict:\n","    partition_dict[partition[i]].append(i)\n","  else:\n","    partition_dict[partition[i]] = [i]\n","partition_dict\n","\n","pos=nx.spring_layout(G) \n","\n","# nodes\n","\n","cluster_list = []\n","color_list = ['b', 'g', 'c', 'm', 'y','r', 'k', 'w']\n","for k in partition_dict.keys():\n","  cluster = nx.draw_networkx_nodes(G,pos,\n","                         nodelist=partition_dict[k],\n","                          node_color=color_list[k],\n","                          node_size=300,\n","                          alpha=0.8)\n","  cluster_list.append(cluster)\n","if draw_fake:\n","  cluster = nx.draw_networkx_nodes(G,pos,\n","                         nodelist=used_nodes,\n","                         node_color= 'k',\n","                         node_size=100,\n","                         alpha=0.8)\n","  cluster_list.append(cluster)\n","labels = {}    \n","labels[0] = \"coach\"\n","labels[33] = \"instructor\"\n","#Now only add labels to the nodes you require (the hubs in my case)\n","nx.draw_networkx_labels(G, pos,labels,font_size=11,font_color='r')\n","\n","# edges\n","nx.draw_networkx_edges(G, pos, edgelist = existed_edge_list, width=1.0,alpha=1, edge_color='k')\n","nx.draw_networkx_edges(G, pos, edgelist = generated_edge_list, width=0.7, style = 'dotted', alpha=0.5, edge_color='k')\n","#plt.legend(handles=cluster_list, bbox_to_anchor=(1.05, 1), loc='bottom left', labels=[\"group 1\",\"group 2\",\"group 3\",\"group 4\", \"fake node\"])\n","\n","#plt.savefig('karate.eps', format='eps')\n","plt.savefig('karate.png', dpi=500)\n","#plt.savefig('karate.svg', format='svg')\n","plt.show() "],"execution_count":10,"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAV0AAADnCAYAAAC9roUQAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOydeXwTdf7/nzNJmjZpm7bpQU/a0hZBQEQQQUEOT7SICgseeIG7rMfyEw8QXL4qyMqq6y7r8V0FjxUPFkQRFBQQkeOLIjcU2mLvA9om6ZU0TTIzvz/SxpYeFGgrrPN8PPJomZl8ZqY0r77nfQqKoqCioqKi0j2Iv/YFqKioqPyWUEVXRUVFpRtRRVdFRUWlG1FFV0VFRaUbUUVXRUVFpRvRtrczPDxcSUxM7KZLUVFRUfnvYM+ePRWKokS0tq9d0U1MTOSnn37qmqtSUVHpFtxWN5a1FhxZDjxVHrQmLYY0A+bxZnShul/78v4rEQQhv6197YquiorKhYs9w07p0lIs6ywoUkM+vgjIgAD5L+RjvtlM9PRojH2Nv+al/qZQRVdF5b+QslVl5M7NRZEUNMEaBI3Q4hhFUqhYU4FlnYWkRUlEToz8Fa70t4cquioq/2WUrSojZ3YOolFE46dp8zhBI6AN1SK7ZHJm5wCowtsNqNkLKir/Rdgz7OTOzUU0ioh+Hft4i34iolEkd24u9gx7F1+himrpqqj8inR2kKt0aanXpdCOhdsaop+Ix+6hdFkpKa+knPF5VTqOKroqKr8CXRHkclvdWNZZ0ASfmeA2ognWYFlroeczPdWshi5EdS+oqHQzZavKODzhMBVrKhCNItpQrfdlavgaokU0ilSsqeDwhMOUrSrr0LqWtV4Bby1o1hEEjYAiK1jWWs7q/SodQ7V0VVS6ka4McjmyHO3u97g9KCjodO1Yscrp11E5N1TRVVHpJs42yAWQOzcXY19ju64GT5XH9+zqdrlxOBw4HA7sDjsOhwOPx4NGo6F3Wm/8A/zbOGHDOipdhiq6KirdRFcEuRRFIS8vj71791K1t4rQ4lCseVYADAYDRoMRc5gZFJAVGZPJREFBAWm901o/mQxakyoLXYn601VR6QY6K8jlnuxm/8/72bt3r+8VGBjIoEGDuCHqBoJNwfSI7OFzIciSzPGfj6PVaumV1AtBELBYLNhsNkJDQ1ueSABDmuFcblXlNKiiq6LSDZxxkEuBOmedz0XgcDgQ7AJf3vQlrlEuBg0axFNPPcWll15KZKTX1+u2utl7xV5E0etj8Lg9ZB/Pxmg0kpCQ4Fs6ISGB3JxcTCaT71jwVqgJooA53dx5N67SAlV0VVS6gdMFp2RZxmq1egXW7qDOWYefzg+D0YDBYCAkJAS9S8+CuxaQvDC51TV0YTrMN5upWFOBbJDJys7CHGYmOia62XGBgYEEBgVyovQEMbExvu1StUT4hHA1XayLUUVXRaUbaBrkOhVFUTh69CiKohAZGUlYWBgGg6GZFdq4xumCXNHToyn5tITcY7lExUQREdFqd0Hi4uLIOJKBOdyMXq9HdskIGoHoadGtHq/Seah5uioq3YDWpPUWPrTCyZMn0Wl1eDwewsPDCQwMbCG4QIeCXHsq9vCS7SVizbGYTW27CXQ6HVE9oigsLER2ych2maRFSWq3sW5AFV0VlW6greBUvbOekydOkpiUSGBgIDabre1FThPkWrNmDRMnTmTm6pkMeG0AilPBY/P8UvF2CpHhkYh2kVpLLcmLk9VmN92EKroqKt2AOd3srfg6RQDz8vOIjonGz8+P8PBwKioqWn3/6YJc77zzDjNmzOCrr77immuuIXJiJP0+70f4hHBku4yn0oPH5nVPeGwePJUelDqF0PRQntM+hynd1On3rNI6quiqqHQDjUEuqVrybSsvLwcFX/aByWTC6XRS76xv8X6pWsKc3rIJjqIoLF68mAULFrB161YGDx7s22fsayTllRQG/TCIxPmJRN4RSdgNYUTeEUni/EQG7RrEtauvxXSJib///e9ddOcqp6IG0lRUuono6dFY1lmQXTIePJSUlNC7d2/ffkEQMJvNVFRUEBsX69veVpBLlmWeeOIJNm7cyI4dO4iJiaE1dKE6etzTo83revXVVxk6dCh33303sbGxbR6n0jmolq6KSjdh7GskaVESsl2mKLeIqMgo/P2bl+OGh4djsVhQFK8boq0gl9vt5t577+XHH3/k+++/b1NwO0KvXr2YMWMGTz755FmvodJxVNFVUelGIidGUnRTEbjArDe38PH6+/uj1+upslV5g2BOpUWQy263c8stt1BZWck333zTemXZGfL000+zfft2vv/++3NeS6V9VNFVUelGysrKeHjFwyQuTyTi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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"A-KJ70Rpw4-b"},"source":[""],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"KDVECJZZzt4q"},"source":["\n","## Explanation 2 (MNIST)\n","\n","[ref: tutoroial for mnist](https://github.com/ianlewis/tensorflow-examples/blob/master/notebooks/TensorFlow%20MNIST%20tutorial.ipynb)"]},{"cell_type":"code","metadata":{"id":"1EYaA6xv5QH4","executionInfo":{"status":"ok","timestamp":1601186165295,"user_tz":240,"elapsed":3724,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"61099387-accd-4fa0-e2f9-5ee4c34628d2","colab":{"base_uri":"https://localhost:8080/","height":35}},"source":["import tensorflow as tf\n","tf.__version__"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"},"text/plain":["'1.15.2'"]},"metadata":{"tags":[]},"execution_count":3}]},{"cell_type":"code","metadata":{"id":"UaElU59vTHY9","executionInfo":{"status":"ok","timestamp":1601186165798,"user_tz":240,"elapsed":4177,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"bed4cc4d-cee7-4389-cae8-6f38abfd198d","colab":{"base_uri":"https://localhost:8080/","height":411}},"source":["\n","# import matplotlib\n","import matplotlib.pyplot as plt\n","%matplotlib inline\n","\n","# import MNIST data\n","from tensorflow.examples.tutorials.mnist import input_data\n","mnist = input_data.read_data_sets(\"MNIST_data/\", one_hot=True)"],"execution_count":null,"outputs":[{"output_type":"stream","text":["WARNING:tensorflow:From <ipython-input-4-794654c077d0>:8: read_data_sets (from tensorflow.contrib.learn.python.learn.datasets.mnist) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use alternatives such as official/mnist/dataset.py from tensorflow/models.\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/contrib/learn/python/learn/datasets/mnist.py:260: maybe_download (from tensorflow.contrib.learn.python.learn.datasets.base) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please write your own downloading logic.\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/contrib/learn/python/learn/datasets/mnist.py:262: extract_images (from tensorflow.contrib.learn.python.learn.datasets.mnist) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use tf.data to implement this functionality.\n","Extracting MNIST_data/train-images-idx3-ubyte.gz\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/contrib/learn/python/learn/datasets/mnist.py:267: extract_labels (from tensorflow.contrib.learn.python.learn.datasets.mnist) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use tf.data to implement this functionality.\n","Extracting MNIST_data/train-labels-idx1-ubyte.gz\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/contrib/learn/python/learn/datasets/mnist.py:110: dense_to_one_hot (from tensorflow.contrib.learn.python.learn.datasets.mnist) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use tf.one_hot on tensors.\n","Extracting MNIST_data/t10k-images-idx3-ubyte.gz\n","Extracting MNIST_data/t10k-labels-idx1-ubyte.gz\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/contrib/learn/python/learn/datasets/mnist.py:290: DataSet.__init__ (from tensorflow.contrib.learn.python.learn.datasets.mnist) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use alternatives such as official/mnist/dataset.py from tensorflow/models.\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"JFS06mk9hFnl"},"source":["import os\n","#from gan_function import *\n","from util_function.utils import combine_nodes\n","from util_function.metrics import *\n","from util_function.preprocess import *\n","from GNN_Model.model import GCN_Model\n","from GNN_Model.trainer import GCN_Trainer\n","from Generator.model_toy_mnist import GraphCGAN_Generator\n","from Generator.trainer import GraphCGAN_Trainer\n","from sklearn.cluster import KMeans\n","from collections import Counter\n","from sklearn.cluster import SpectralClustering\n","import tensorflow as tf\n","import os\n","import time\n","import numpy as np\n","from sklearn.cluster import AgglomerativeClustering\n","from sklearn.metrics.cluster import normalized_mutual_info_score\n","from sklearn.decomposition import PCA\n","import pickle\n","\n","from sklearn.model_selection import train_test_split\n","\n","adj = sp.coo_matrix(np.eye((mnist.test.images.shape[0])))\n","features = sp.coo_matrix(mnist.test.images)\n","y_train = y_val = y_test = mnist.test.labels\n","N = adj.shape[0]\n","d = features.shape[1]\n","M = y_train.shape[1]\n","train_unmask_idx, val_test_unmask_idx = train_test_split(range(N), \n","                                                         train_size = 0.8, \n","                                                         test_size = 0.2)\n","val_unmask_idx, test_unmask_idx = train_test_split(val_test_unmask_idx, \n","                                                   train_size = 0.5, \n","                                                   test_size = 0.5)\n","train_mask = np.array([False for _ in range(N)])\n","val_mask = np.array([False for _ in range(N)])\n","test_mask = np.array([False for _ in range(N)])\n","train_mask[train_unmask_idx] = True\n","val_mask[val_unmask_idx] = True\n","test_mask[test_unmask_idx] = True\n","\n","\n","\n","\n"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"cV71NDGXz0bR"},"source":["B = 100\n","#################\n","## build model ##\n","#################\n","tf.reset_default_graph()\n","gcn_model = GCN_Model(N, d, M, model_name = \"GCN\", batch_size = B)\n","gcn_model_attr = GCN_Model(N, d, M, model_name = \"GCN_attr\", batch_size = B)\n","cgan_model = GraphCGAN_Generator(N, d, M, gcn_model_attr, gcn_model, batch_size = B)\n","####################\n","## define session ##\n","####################\n","config = tf.ConfigProto()\n","config.gpu_options.allow_growth = True\n","sess = tf.Session(config=config)\n","sess.run(tf.global_variables_initializer())\n","###################\n","## build trainer ##\n","###################\n","gcn_trainer = GCN_Trainer(gcn_model)\n","gcn_trainer_attr = GCN_Trainer(gcn_model_attr)\n","cgan_trainer = GraphCGAN_Trainer(cgan_model)\n","##########################\n","## initialize fake node ##\n","##########################\n","generated_features = np.zeros((B, d))\n","generated_adj = np.zeros((B, N))\n","###############################\n","## obtain dense adj and attr ##\n","###############################\n","features_dense = features.toarray()\n","adj_dense = preprocess_adj_dence(adj)\n"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"71EIe9O7lvOs","executionInfo":{"status":"ok","timestamp":1601186647683,"user_tz":240,"elapsed":77517,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"62ed47d5-7add-4afb-af8f-5ccea96199cb","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["val_traj = []\n","test_traj = []\n","test_traj_attr = []\n","for _ in range(20):\n","  ###########################################\n","  ## combine fake nodes to original graph ###\n","  ###########################################\n","  enlarged_adj, enlarged_features, enlarged_y_train, enlarged_y_val, enlarged_y_test, enlarged_train_mask, enlarged_val_mask, enlarged_test_mask = \\\n","                    combine_nodes(adj, features, y_train, y_val, y_test, \\\n","                                  train_mask, val_mask, test_mask, \\\n","                                  generated_adj, generated_features)\n","  enlarged_features_sp = sparse_to_tuple(enlarged_features) ## sparse normalized feature\n","  enlarged_adj_sp = preprocess_adj(enlarged_adj) ## sparse normalized adjancency matrix\n","\n","  ###############\n","  ## train gnn ##\n","  ###############\n","\n","  val_cost, val_acc = gcn_trainer.fit(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_train, enlarged_train_mask,enlarged_y_val, enlarged_val_mask,\\\n","                  epoch_num = 1, print_every = 10)\n","  test_cost, test_acc, pred_result, feature_space = gcn_trainer.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_test, enlarged_test_mask)\n","\n","  val_traj.append(val_acc)\n","  test_traj.append(test_acc)\n","  ##############################\n","  ## train gnn with attr only ##\n","  ##############################\n","\n","  enlarged_y_attr_hat = np.eye(M)[np.argmax(pred_result, 1)]\n","  enlarged_train_attr_mask = np.array([True] * N + [False] * B)\n","  enlarged_adj_attr = sp.coo_matrix(np.eye(N + B))\n","  enlarged_adj_attr_sp = preprocess_adj(enlarged_adj_attr)\n","\n","  val_cost_attr, val_acc_attr = gcn_trainer_attr.fit(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_attr_hat, enlarged_train_attr_mask,\\\n","                       epoch_num = 11)\n","  _, _, _, feature_space_attr = gcn_trainer_attr.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_test, enlarged_test_mask)\n","  #####################\n","  ## train generator ##\n","  #####################\n","  generated_features, generated_adj = cgan_trainer.fit(sess, adj_dense, features_dense,\\\n","                                                       epoch_num = 5)\n","  generated_adj = np.zeros((B, N))\n","\n","\n","  sample_img = generated_features[0].reshape(28, 28)\n","  # plot the image\n","  plt.imshow(sample_img).set_cmap('Greys')\n","  plt.show()\n"],"execution_count":null,"outputs":[{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 2.77200 D_loss= 0.00000 train_acc= 0.10163 val_loss= 2.01344 val_acc= 0.30500\n","Optimization Finished!\n","Test accuracy: 0.31899998\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.33800003\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 2.29597 D_loss= 0.00000 train_acc= 0.20700 val_loss= 1.56020 val_acc= 0.60700\n","Optimization Finished!\n","Test accuracy: 0.597\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.536\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.92226 D_loss= 0.00000 train_acc= 0.35275 val_loss= 1.29550 val_acc= 0.69000\n","Optimization Finished!\n","Test accuracy: 0.64400005\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.62799996\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.67989 D_loss= 0.00000 train_acc= 0.44788 val_loss= 1.11876 val_acc= 0.70000\n","Optimization Finished!\n","Test accuracy: 0.67300004\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.68299997\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.53831 D_loss= 0.00000 train_acc= 0.49287 val_loss= 0.98002 val_acc= 0.72400\n","Optimization Finished!\n","Test accuracy: 0.7110001\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.7070001\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.41762 D_loss= 0.00000 train_acc= 0.52875 val_loss= 0.87018 val_acc= 0.77000\n","Optimization Finished!\n","Test accuracy: 0.752\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.749\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.34257 D_loss= 0.00000 train_acc= 0.55088 val_loss= 0.78684 val_acc= 0.79000\n","Optimization Finished!\n","Test accuracy: 0.785\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.786\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.28450 D_loss= 0.00000 train_acc= 0.58013 val_loss= 0.72318 val_acc= 0.80600\n","Optimization Finished!\n","Test accuracy: 0.80599993\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.81000006\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.19007 D_loss= 0.00000 train_acc= 0.60563 val_loss= 0.67506 val_acc= 0.81100\n","Optimization Finished!\n","Test accuracy: 0.816\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.816\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.15960 D_loss= 0.00000 train_acc= 0.61000 val_loss= 0.63704 val_acc= 0.81900\n","Optimization Finished!\n","Test accuracy: 0.821\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.82900006\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.12063 D_loss= 0.00000 train_acc= 0.63063 val_loss= 0.60560 val_acc= 0.83000\n","Optimization Finished!\n","Test accuracy: 0.832\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.83800006\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.09728 D_loss= 0.00000 train_acc= 0.64400 val_loss= 0.57927 val_acc= 0.83700\n","Optimization Finished!\n","Test accuracy: 0.84099996\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.848\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAASc0lEQVR4nO3dfWwVdboH8O8DipCWKNCKCGhlQyREuex6FHAN9kowSEBcQV1MRI1cTERiReNFr2YxeiORC7ga3YhLA1yVdYX1+hJYl8XVuokWDoq8SBAuKZHKSwkgVF5bnvtHB2+BM8+czsyZOfD7fpKmp/OcmXk89suczu/M/ERVQUTnvnZpN0BEyWDYiRzBsBM5gmEncgTDTuSI85LcWVlZmVZUVCS5y9js2bPHt9atWzdzXRGJu528/fTTT2a9pKSkoPtvbGz0rZWWlhZ031E0NTWZ9fPOixaduro639pll11mrtuunf8xuq6uDnv27Mn5CxepYxEZAeD3ANoD+KOqzrCeX1FRgWw2G2WXqamurvatTZgwwVw36i9GFF9++aVZHzx4cEH3X1NT41sbOnRopG03Nzeb9fbt24fetvWPOwB07drVrFuBBID777/ft/byyy+b63bu3Nm3lslk/Hsyt2oQkfYAXgVwC4D+AMaLSP+w2yOiworyN/t1ALao6lZVPQbgTwDGxNMWEcUtSth7Avi+1c/bvWWnEJFJIpIVkWxDQ0OE3RFRFAU/G6+qc1U1o6qZ8vLyQu+OiHxECXs9gN6tfu7lLSOiIhQl7KsA9BWRK0SkA4DfAvggnraIKG4S5ao3ERkJ4CW0DL1Vq+p/Ws/PZDJqDb299NJL5v6qqqpCdNli7969Zn3t2rVmvbKyMvS+i1ltba1ZHzRoUEKdnF2ChubKysoKtu+jR4/61q6//nqsXr06/nF2VV0KYGmUbRBRMvhxWSJHMOxEjmDYiRzBsBM5gmEncgTDTuSISOPsbRU0zn7kyBFz/Y4dO/rWZs+eba47depUuzmic0Amk0E2m805zs4jO5EjGHYiRzDsRI5g2IkcwbATOYJhJ3JEorc9PXz4sHkp6f79+831rbuRcmjt3PPFF1+Y9SFDhpj1Qt7G+vPPPzfrx44dM+urVq3yrfXsecbd3U5xzz33mHU/PLITOYJhJ3IEw07kCIadyBEMO5EjGHYiRzDsRI5IdJy9U6dOGDBggG99+/btCXZDQPBMqA899JBZHz16tFkfNWpUm3s6KWgcPWhGYOt3LaqgW2x36NDBrA8bNizOdvLCIzuRIxh2Ikcw7ESOYNiJHMGwEzmCYSdyBMNO5IhEx9mD9OrVK+0WitIrr7xi1qdMmeJbO3HihLluXV2dWbeuuwaAq666yqwXUnl5uVm3PrfRuXPnSNs+fvy4WQ8aZ4/Cmi66qanJtxYp7CJSB+AggGYATaqaibI9IiqcOI7s/6qq9sz0RJQ6/s1O5IioYVcAfxOR1SIyKdcTRGSSiGRFJNvQ0BBxd0QUVtSw36CqvwJwC4DJInLGHSFVda6qZlQ1E3TSg4gKJ1LYVbXe+74bwHsAroujKSKKX+iwi0iJiHQ++RjAzQDWx9UYEcUrytn47gDeE5GT23lbVf8apZko48lp2rZtm1m//PLLzfqmTZvM+qFDh9rc00lVVVVmvbq62qxb915PW9Drap0jivonZUlJSaT1oygrK/OtnXeef6RDh11VtwL4l7DrE1GyOPRG5AiGncgRDDuRIxh2Ikcw7ESOEFVNbGeZTEaDbv/roqD/B97wpq/a2lrfWtAtj4M8+OCDZn3WrFlm3RoK6tixo7nuJ598YtbffPNNs96tWzff2syZM811g1iXkgL2f3dUmzdv9q3dfvvtWLduXc5fGB7ZiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMYdiJHJHor6cbGRtTU1PjWhw4940Y354T6+nqzvmzZMrM+ceJEs26NpQfdnjtomuzXX3/drB88eNCsB31GwBJ0eW3Q5bmFnBa5kOPoQfr27etbu+CCC3xrPLITOYJhJ3IEw07kCIadyBEMO5EjGHYiRzDsRI7g9exngRkzZpj1adOm+daWLFlirjt27NhQPZ0NPvroI99a//79zXX79OkTdzuJyGQyyGazvJ6dyGUMO5EjGHYiRzDsRI5g2IkcwbATOYJhJ3JEehflUt6scXQAeOutt3xraY8XW5/jOHz4sLnu448/HnrbAPDMM8/41i699FJz3aheffVVsz558uSC7j+XwCO7iFSLyG4RWd9qWVcRWS4im73vXQrbJhFFlc/b+PkARpy2bBqAFaraF8AK72ciKmKBYVfVGgB7T1s8BsAC7/ECALfF3BcRxSzsCbruqrrDe7wTQHe/J4rIJBHJiki2oaEh5O6IKKrIZ+O15SyJ75kSVZ2rqhlVzZSXl0fdHRGFFDbsu0SkBwB433fH1xIRFULYsH8A4F7v8b0A3o+nHSIqlMDr2UVkEYBKAGUAdgH4HYD/AfBnAJcB2AbgTlU9/STeGdK8nj1oTPfjjz8266NGjfKtBd1D/OGHHzbrn332mVlft26dWbcsXrzYrI8bNy70tvPx6KOP+tbmzJlT0H2vXLnSt7Znzx5z3ZEjR8bdTiKs69kDP1SjquN9SoW7Az8RxY4flyVyBMNO5AiGncgRDDuRIxh2Ikc4c4lrp06dzHrQ1MS33Rb+4/9Bt4IuLS0164sWLTLr48f7DZjYU/gm4cCBA6HXfeyxx8z6vn37zHplZaVvbcKECWFaOqvxyE7kCIadyBEMO5EjGHYiRzDsRI5g2IkcwbATOSLRcXZVxbFjx3zrHTp0SLCbUy1btqxg2w4aR1+4cKFZjzImPHr06NDrAkBtba1ZHzRokFm/8cYbQ+971qxZZn316tVm/Zprrgm97zQFXZa8Zs0a31p9fb1vjUd2Ikcw7ESOYNiJHMGwEzmCYSdyBMNO5AiGncgRgbeSjlO/fv30jTfe8K3/8MMP5vp33XVX3C39LOia86Bpk9MU5XbN33zzjVk/cuSIWb/wwgvNer9+/cx6Wo4ePWrW074PQFjWraR5ZCdyBMNO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHJHoOHuaUzZHJZJz6BJAy3X6lrvvvtusv/3222Y9aKy7Y8eOZt1y/vnnm/Xjx4+b9cGDB5v1a6+91rd2xRVXmOtOnTrVrAexruX/8MMPI227WEUaZxeRahHZLSLrWy2bLiL1IrLG+zo7J7Mmckg+b+PnAxiRY/kcVR3ofS2Nty0iiltg2FW1BsDeBHohogKKcoLuYRFZ673N7+L3JBGZJCJZEck2NDRE2B0RRRE27H8A8AsAAwHsAOB7Z0BVnauqGVXNlJeXh9wdEUUVKuyquktVm1X1BIA3AFwXb1tEFLdQYReRHq1+/A2A9X7PJaLiEHjfeBFZBKASQJmIbAfwOwCVIjIQgAKoA/BgPjtrbGxETU2Nb/27774z17/11lt9axdffHE+LYQW5fMIU6ZMMetff/21Wb/66qtD73vAgAFmPeh69ueff96sW/8/gWhzAUyfPt2sDx8+3Kyfq2PpYQWGXVXH51g8rwC9EFEB8eOyRI5g2IkcwbATOYJhJ3IEw07kiESnbAaAdu38/32ZOHGiue6mTZt8a926dTPXbd++vd1YAQ0ZMsSsb9myxawfOHDArHft2tW3tnbtWnPdzZs3m/Wnn37arBfShg0bzHox3967GPHITuQIhp3IEQw7kSMYdiJHMOxEjmDYiRzBsBM5IvFx9hMnToRe98orr4yxk+IR9JpY4+gAsGLFCt/asGHDzHX79u1r1oO88847Zj3KNNvvvvuuWf/000/NemVlZeh9n4t4ZCdyBMNO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHJHoOHtpaSmGDh2a5C5/NmHCBLO+cOHChDo506FDhyKtHzSWXkhB4+jdu3f3rW3cuNFcd+XKlWZ9xIhc842SHx7ZiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMYdiJHJH49e1rSHEcPsn37drM+cODAhDo50759+8x6p06dzPquXbtC7zvqOPqTTz7pW3vhhRcibftsFHhkF5HeIvIPEflWRDaIyCPe8q4islxENnvfuxS+XSIKK5+38U0AHlPV/gAGA5gsIv0BTAOwQlX7Aljh/UxERSow7Kq6Q1W/8h4fBLARQE8AYwAs8J62AMBthWqSiKJr0wk6EakA8EsAtQC6q+oOr7QTQM4PQYvIJBHJiki2oaEhQqtEFEXeYReRUgBLAFSp6ikzDaqqAtBc66nqXFXNqGqmvLw8UrNEFF5eYReR89ES9LdU9S/e4l0i0sOr9wCwuzAtElEcAofeREQAzAOwUVVntyp9AOBeADO87+/ns8Pm5mbfWprTKhfS2LFjzfqSJUsS6qTtunSJNsgyf/5831rPnj3NdYcPHx5p34888ohvraamxlw3rUuxCymfcfZfA7gHwDoRWeMtewotIf+ziDwAYBuAOwvTIhHFITDsqvpPAOJTTu+uCUTUJvy4LJEjGHYiRzDsRI5g2IkcwbATOSLxS1ytsfSgKXrvuOOOuNvJmzU9cNDUwFVVVfE2E6PnnnvOrAfdpvqSSy4x6/fdd19bW4qN1VtQ3+ciHtmJHMGwEzmCYSdyBMNO5AiGncgRDDuRIxh2IkcU1a2k0xxHD2KNpW/YsMFct7S0NOZu4nPzzTeb9aDx6KBr0q2psl977TVz3aDXbf/+/Wb9oosuMuuu4ZGdyBEMO5EjGHYiRzDsRI5g2IkcwbATOYJhJ3JEUY2zB9m5c6dvLc3rkysqKsx6SUlJpO0vXrzYrI8bNy70tpcuXWrWn3322dDbBuypsn/88cdI216+fLlZL+bPbVhmzpxp1q17BDQ1NfnWeGQncgTDTuQIhp3IEQw7kSMYdiJHMOxEjmDYiRwhqmo/QaQ3gIUAugNQAHNV9fciMh3AvwFo8J76lKqag7aZTEaz2WzoZl988UXf2hNPPBF6u0Rnk9mzZ/vW5syZg++//z7nrMv5fKimCcBjqvqViHQGsFpETn6aYY6q/lebuyWixOUzP/sOADu8xwdFZCMA+/YkRFR02vQ3u4hUAPglgFpv0cMislZEqkWki886k0QkKyLZhoaGXE8hogTkHXYRKQWwBECVqh4A8AcAvwAwEC1H/lm51lPVuaqaUdVMeXl5DC0TURh5hV1EzkdL0N9S1b8AgKruUtVmVT0B4A0A1xWuTSKKKjDsIiIA5gHYqKqzWy3v0eppvwGwPv72iCgu+ZyN/zWAewCsE5E13rKnAIwXkYFoGY6rA/BgPjtsbm72rVnTOQMcXjvXWJcsA9EvW66vr/etBd0CO8i8efPM+gMPPBB621u3bjXr1i2227XzP37nczb+nwByjdvZF0ITUVHhJ+iIHMGwEzmCYSdyBMNO5AiGncgRDDuRIwIvcY1T1Etco9i2bZtZt8YnAaB3795xtkNFbvr06Wa9T58+Zv2mm24y67169WprS3nJZDLIZrM5L3HlkZ3IEQw7kSMYdiJHMOxEjmDYiRzBsBM5gmEnckSi4+wi0gCg9YB3GYA9iTXQNsXaW7H2BbC3sOLs7XJVzXn/t0TDfsbORbKqmkmtAUOx9lasfQHsLaykeuPbeCJHMOxEjkg77HNT3r+lWHsr1r4A9hZWIr2l+jc7ESUn7SM7ESWEYSdyRCphF5ERIrJJRLaIyLQ0evAjInUisk5E1ohIOhff/38v1SKyW0TWt1rWVUSWi8hm73vOOfZS6m26iNR7r90aERmZUm+9ReQfIvKtiGwQkUe85am+dkZfibxuif/NLiLtAXwHYDiA7QBWARivqt8m2ogPEakDkFHV1D+AISJDATQCWKiqV3nLXgSwV1VneP9QdlHVfy+S3qYDaEx7Gm9vtqIeracZB3AbgPuQ4mtn9HUnEnjd0jiyXwdgi6puVdVjAP4EYEwKfRQ9Va0BsPe0xWMALPAeL0DLL0vifHorCqq6Q1W/8h4fBHBymvFUXzujr0SkEfaeAL5v9fN2FNd87wrgbyKyWkQmpd1MDt1VdYf3eCeA7mk2k0PgNN5JOm2a8aJ57cJMfx4VT9Cd6QZV/RWAWwBM9t6uFiVt+RusmMZO85rGOyk5phn/WZqvXdjpz6NKI+z1AFrfvbGXt6woqGq99303gPdQfFNR7zo5g673fXfK/fysmKbxzjXNOIrgtUtz+vM0wr4KQF8RuUJEOgD4LYAPUujjDCJS4p04gYiUALgZxTcV9QcA7vUe3wvg/RR7OUWxTOPtN804Un7tUp/+XFUT/wIwEi1n5P8XwH+k0YNPX30AfON9bUi7NwCL0PK27jhazm08AKAbgBUANgP4O4CuRdTbfwNYB2AtWoLVI6XebkDLW/S1ANZ4XyPTfu2MvhJ53fhxWSJH8AQdkSMYdiJHMOxEjmDYiRzBsBM5gmEncgTDTuSI/wPmUqF62xkJngAAAABJRU5ErkJggg==\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.06209 D_loss= 0.00000 train_acc= 0.65413 val_loss= 0.55906 val_acc= 0.84000\n","Optimization Finished!\n","Test accuracy: 0.847\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.85\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.04753 D_loss= 0.00000 train_acc= 0.65513 val_loss= 0.54293 val_acc= 0.84400\n","Optimization Finished!\n","Test accuracy: 0.845\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.85599995\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.02973 D_loss= 0.00000 train_acc= 0.67100 val_loss= 0.52837 val_acc= 0.84800\n","Optimization Finished!\n","Test accuracy: 0.852\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.859\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.01223 D_loss= 0.00000 train_acc= 0.67062 val_loss= 0.51375 val_acc= 0.85300\n","Optimization Finished!\n","Test accuracy: 0.86099994\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.865\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.00080 D_loss= 0.00000 train_acc= 0.67275 val_loss= 0.50041 val_acc= 0.85800\n","Optimization Finished!\n","Test accuracy: 0.86600006\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.868\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.97749 D_loss= 0.00000 train_acc= 0.68913 val_loss= 0.48898 val_acc= 0.85900\n","Optimization Finished!\n","Test accuracy: 0.869\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.8680001\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.95473 D_loss= 0.00000 train_acc= 0.69113 val_loss= 0.47972 val_acc= 0.86200\n","Optimization Finished!\n","Test accuracy: 0.87200004\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.87\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.94721 D_loss= 0.00000 train_acc= 0.69437 val_loss= 0.47190 val_acc= 0.86600\n","Optimization Finished!\n","Test accuracy: 0.87200004\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.86700004\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"code","metadata":{"id":"xAiNqaTP52mz","executionInfo":{"status":"ok","timestamp":1601186651594,"user_tz":240,"elapsed":3892,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"cb75992e-b0ec-4008-c36f-cf134f3b6d16","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["for i in range(20):\n","  sample_img = generated_features[i].reshape(28, 28)\n","  # plot the image\n","  plt.imshow(sample_img).set_cmap('Greys')\n","  plt.show()"],"execution_count":null,"outputs":[{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAASX0lEQVR4nO3dbWwWZboH8P9Fy/saoBRKgYYiEIkctJBHOeFNjTkrEBJYowgmiJEc1gDJLuHDQY/J8sFEcnJ2cePLJuyRyCqCxMVAiC+rzUYsJMgjooL0HOUtvBRaQBAULC3X+dDBFOhc087MMzNw/39J03auzszFwJ95+twzc4uqgohufZ3SboCIksGwEzmCYSdyBMNO5AiGncgRxUnurLS0VCsrK5PcZWwuXLjgW+vevbu5blFRUdzttNtPP/1k1oN6F5FI+//55599a127do207UJqamoy68XF0aJTX1/vWystLTXX7dTJ/xx96NAhnDp1qs2/tEgdi8gUAH8GUATgf1R1hfXzlZWVyOfzUXaZmpqaGt/a6NGjzXV79eoVdzvtFnS8g3qPGsiDBw/61oYOHRpp24V05swZs15SUhJp+y+//LJvbf78+ea61n/QuVzOtxb6ZbyIFAF4BcBUAHcCmCMid4bdHhEVVpTf2e8F8J2qHlDVRgDrAcyIpy0iiluUsA8CcKTV90e9ZdcQkQUikheRfENDQ4TdEVEUBX83XlVXqWpOVXP9+vUr9O6IyEeUsB8DUNHq+8HeMiLKoChh3wlghIgMFZEuAGYD2BxPW0QUt9BDb6raJCKLAXyIlqG31aq6N0oz27dvN+vjx48Pve3z58+b9WPH7BclEydODL3vNFlDMQBQW1tr1keOHBlp/1keXrMEDa1dvHjRrAddv7B48eIO93TVuXPnfGvNzc2+tUjj7Kr6HoD3omyDiJLBy2WJHMGwEzmCYSdyBMNO5AiGncgRDDuRIxK9nz1IlHH0Dz74wKxPmTLFrEcdT75ZufrnjipoHL2QrFumrWcn8MxO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHJHo0FtjYyOOHDniW79y5Yq5/pAhQ3xrQUNrdPPZtWuXWR87dmxCndzIehQ0EPwIb+vW4lGjRpnrVlRUmHU/PLMTOYJhJ3IEw07kCIadyBEMO5EjGHYiRzDsRI5IdJy9S5cu5hjhiRMnEuyG2uOll14y60GP2B4zZkzofQeNo0e9rTmKbt26mfX+/fub9TSmLueZncgRDDuRIxh2Ikcw7ESOYNiJHMGwEzmCYSdyRKYeJT1gwIC0W8ikLVu2mPXp06eH3vbJkyfNetB9242NjaH3HVXQdNSHDx/2rf3www/muqNHjzbrTU1NZr2Qgp774CdS2EXkEIDzAJoBNKmqffSJKDVxnNkfUNVTMWyHiAqIv7MTOSJq2BXAP0TkcxFZ0NYPiMgCEcmLSL6hoSHi7ogorKhhn6iqYwFMBbBIRCZf/wOqukpVc6qa69evX8TdEVFYkcKuqse8z/UA3gVwbxxNEVH8QoddRHqKyG1XvwbwawB74mqMiOIV5d34MgDvisjV7bylqvYNxgHef/99sz516tQom8+sffv2mfXi4vB/TWvXrjXr27dvN+uvvPJK6H0XWmlpqVm3xsKDxtGDlJSURFo/ik6dwp2jQ/8rUtUDAO4Ouz4RJYtDb0SOYNiJHMGwEzmCYSdyBMNO5AhR1cR2lsvlNJ/PJ7a/m8XFixfNevfu3c36jh07fGvjxo0L1dNVy5cvN+tPPPGEWR80aJBvrWvXrua6NTU1Zr2urs6sW1ds3n///ea6QX788Uez3rNnz0jbtzQ3N/vWxo0bh3w+L23VeGYncgTDTuQIhp3IEQw7kSMYdiJHMOxEjmDYiRyR6KOkm5qacPr0ad963759E+wmOUGPa37nnXfM+qJFi8y6NZbu3YLsK+g6i6Bx9qCx7ijXcQSt++ijj5r1hQsX+taijrMXchw9SFFRUaj1eGYncgTDTuQIhp3IEQw7kSMYdiJHMOxEjmDYiRyR6Dh7cXHxLTuWbikrKzPrQePob7zxhlmfO3eub+2tt94y142qvLy8YNueNGlSpPWXLl0aUye3Bp7ZiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMYdiJHJDrOTuFY4+gAcODAAd+a9dz2rAu6RmDw4MFmffLkyXG20yFBzzAIuvaiEALP7CKyWkTqRWRPq2UlIvKRiHzrfe5T2DaJKKr2vIx/HcCU65YtA1CtqiMAVHvfE1GGBYZdVbcCOHPd4hkA1nhfrwEwM+a+iChmYd+gK1PVqw8fOwHA9xcQEVkgInkRyTc0NITcHRFFFfndeG15KqDvkwFVdZWq5lQ1Z020R0SFFTbsJ0WkHAC8z/XxtUREhRA27JsBzPO+ngdgUzztEFGhBI6zi8g6APcDKBWRowD+AGAFgA0iMh/AYQCzCtlkHM6ePWvWv/jiC7NuPWc86Nnsb7/9tlkPGk/etMn+v/T222/3rR09etRct9Bef/1139qTTz5prvv4449H2vfu3bt9a8OGDTPXve222yLtO41x9CCBYVfVOT6lB2PuhYgKiJfLEjmCYSdyBMNO5AiGncgRDDuRI5y5xbV3795mfc2aNWb9gQceCL3v6dOnm/XHHnvMrFtDSABQVVXlW+vfv7+5bqENHz489Lq7du0y601NTWa9S5cuvrWoQ2tpamxs9K1Z01zzzE7kCIadyBEMO5EjGHYiRzDsRI5g2IkcwbATOSLxcfbm5mbfWlFRUYKdXMu6FTOqnj17mvWdO3ea9XvuuSf0vkeOHBl6XSD49toZM2aY9draWt/axIkTzXXHjh1r1oOOm3X9QZZt3brVrF+5csW3duHCBd8az+xEjmDYiRzBsBM5gmEncgTDTuQIhp3IEQw7kSPEuv81bnfddZdu3rzZt37mzPVTyl0raNw1io0bN5r1hx9+uGD7juqTTz7xrd13333musePHzfrQVMPjx492qwXF2fzkQnWPeGAfS98luVyOeTz+Tafbc4zO5EjGHYiRzDsRI5g2IkcwbATOYJhJ3IEw07kiETH2XO5nObz+cT2F6ennnrKt7Z69Wpz3ZUrV5r1JUuWhOopDgsXLjTrr776qlkP+rNb4/iDBw821w2a0jnIsmXLfGsrVqyItO2sijTOLiKrRaReRPa0WrZcRI6JyG7vY1qcDRNR/NrzMv51AFPaWL5SVau8j/fibYuI4hYYdlXdCsC+jpWIMi/KG3SLReQr72V+H78fEpEFIpIXkXxDQ0OE3RFRFGHD/hcAwwBUAagD8Ee/H1TVVaqaU9Vcv379Qu6OiKIKFXZVPamqzap6BcBfAdwbb1tEFLdQYReR8lbf/gbAHr+fJaJsCBxnF5F1AO4HUArgJIA/eN9XAVAAhwD8VlXrgnY2atQoXb9+vW/deuY1AFRWVvrWysvLfWtpC3qvImie8T59fN8SAQB069bNt7Zt2zZz3aBn2lvbBqI/l96yZcsWs37HHXeY9REjRsTZzk3BGmcPfLKAqs5pY/FrkbsiokTxclkiRzDsRI5g2IkcwbATOYJhJ3JEos/5LS4uRt++fX3rQY8lPnXqVNwtJSLNKwcnTJhg1tsx9BpnOx3y8ccfm/UoU1m7iGd2Ikcw7ESOYNiJHMGwEzmCYSdyBMNO5AiGncgRiY6zX758GfX19b71gQMHmuuXlpbG3VImXLp0yawH3WZaW1vrWwu6BTXqOPqnn35q1idNmhR62y+++KJZ37lzp1kvKysLve9bEc/sRI5g2IkcwbATOYJhJ3IEw07kCIadyBEMO5EjEh1n79GjB6qqqpLc5S9eeOEFs/7MM88k1MmNgu7TD5rauJCPcw4SNI4+a9Ys39qbb75prnv69GmzzvvZO4ZndiJHMOxEjmDYiRzBsBM5gmEncgTDTuQIhp3IEYmOs6cpzXH0IPv37zfrQePshXT48GGzbs0DAAAbNmwIve+o03A/99xzvrXnn38+0rZvRoFndhGpEJF/isg3IrJXRH7nLS8RkY9E5Fvvsz2JOBGlqj0v45sALFXVOwH8K4BFInIngGUAqlV1BIBq73siyqjAsKtqnaru8r4+D2AfgEEAZgBY4/3YGgAzC9UkEUXXoTfoRKQSwBgAOwCUqWqdVzoBoM0HfonIAhHJi0i+oaEhQqtEFEW7wy4ivwLwdwC/V9UfWte0ZXbANmcIVNVVqppT1VyaExwSua5dYReRzmgJ+lpV3egtPiki5V69HID/Y2OJKHWBQ2/S8qzh1wDsU9U/tSptBjAPwArv86aCdHgLWLJkiVlfuXJlQp103JAhQ8z65cuXzfr69et9axUVFea6QdNNB8nlcr61L7/80lz37rvvjrTvLGrPOPsEAHMBfC0iu71lz6Il5BtEZD6AwwD8b1wmotQFhl1VawD4zSTwYLztEFGh8HJZIkcw7ESOYNiJHMGwEzmCYSdyRKZucbWmHgbSfWRydXW1b+3BB+1BiZkzs3vbwIcffmjWu3btataHDx9u1mfPnt3hnuKS5eOeBp7ZiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMYdiJHZGqcPc1x9CDWWHrQ45Z79eoVdzvXaGpq8q0VF9t/xUFPDxo4cKBZHzBggFlft26db23atGnmukHH7fjx42bd6j3oPvzOnTub9ZsRz+xEjmDYiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMyNc4e5OzZs7613r17J9jJtbp162bWq6qqIm3/4MGDZn3o0KG+taAptz777DOz/vTTT5v1II888ohv7dKlS5G2ff78+dDrZnkcvaamxqxbz8NvmZypbTyzEzmCYSdyBMNO5AiGncgRDDuRIxh2Ikcw7ESOEGtcDgBEpALA3wCUAVAAq1T1zyKyHMC/A7g6kPusqr5nbSuXy2k+nw/drPWM84ceeij0dm92hbz+YP/+/WZ92LBhkbaflubmZrNeVFSUUCcdt23bNt/a/PnzUVtb2+asy+25qKYJwFJV3SUitwH4XEQ+8morVfW/O9wtESWuPfOz1wGo874+LyL7AAwqdGNEFK8O/c4uIpUAxgDY4S1aLCJfichqEenjs84CEcmLSD7o0k0iKpx2h11EfgXg7wB+r6o/APgLgGEAqtBy5v9jW+up6ipVzalqLuh5Z0RUOO0Ku4h0RkvQ16rqRgBQ1ZOq2qyqVwD8FcC9hWuTiKIKDLuICIDXAOxT1T+1Wl7e6sd+A2BP/O0RUVza8278BABzAXwtIru9Zc8CmCMiVWgZjjsE4LcF6bAVl4fXLIW8vbeQQ2vWkCEQ/c+1d+9e39qoUaMibXv79u1mffz48aG3HXRcevTo4Vvr1Mn//N2ed+NrALQ1bmeOqRNRtvAKOiJHMOxEjmDYiRzBsBM5gmEncgTDTuSITD1K2pp6GAieftjy/fffm/XGxkazXlZWFnrf1LZCP/47ylh6dXW1WS8pKTHr586dM+vWdNRBx2XMmDG+NXMM3twqEd0yGHYiRzDsRI5g2IkcwbATOYJhJ3IEw07kiMBHSce6M5EGAIdbLSoFcCqxBjomq71ltS+AvYUVZ29DVLXN578lGvYbdi6SV1X/yaZTlNXestoXwN7CSqo3vowncgTDTuSItMO+KuX9W7LaW1b7AthbWIn0lurv7ESUnLTP7ESUEIadyBGphF1EpojI/4rIdyKyLI0e/IjIIRH5WkR2i0j4+aXj6WW1iNSLyJ5Wy0pE5CMR+db73OYceyn1tlxEjnnHbreITEuptwoR+aeIfCMie0Xkd97yVI+d0Vcixy3x39lFpAjA/wH4NwBHAewEMEdVv0m0ER8icghATlVTvwBDRCYDuADgb6r6L96y/wJwRlVXeP9R9lHV/8hIb8sBXEh7Gm9vtqLy1tOMA5gJ4EmkeOyMvmYhgeOWxpn9XgDfqeoBVW0EsB7AjBT6yDxV3QrgzHWLZwBY4329Bi3/WBLn01smqGqdqu7yvj4P4Oo046keO6OvRKQR9kEAjrT6/iiyNd+7AviHiHwuIgvSbqYNZapa5319AkDWnpcVOI13kq6bZjwzxy7M9OdR8Q26G01U1bEApgJY5L1czSRt+R0sS2On7ZrGOyltTDP+izSPXdjpz6NKI+zHAFS0+n6wtywTVPWY97kewLvI3lTUJ6/OoOt9rk+5n19kaRrvtqYZRwaOXZrTn6cR9p0ARojIUBHpAmA2gM0p9HEDEenpvXECEekJ4NfI3lTUmwHM876eB2BTir1cIyvTePtNM46Uj13q05+rauIfAKah5R35/QD+M40efPq6HcCX3sfetHsDsA4tL+suo+W9jfkA+gKoBvAtgI8BlGSotzcAfA3gK7QEqzyl3iai5SX6VwB2ex/T0j52Rl+JHDdeLkvkCL5BR+QIhp3IEQw7kSMYdiJHMOxEjmDYiRzBsBM54v8Bofxscs2ApjMAAAAASUVORK5CYII=\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAASVElEQVR4nO3dfWwVdboH8O/TQuWlIC+tFREu7wQ0WHBAtIhdNxeBRGFjkAWzUVHZRDS7ujEXvcb1D28kN9fdu0HdBAQBg8Ii6wsGbpZr1hRIJBywCIIXBAGBAuUlUKK1Fp77RwdTtfPMYeacmaO/7ydpejrP+Z15PPjtnJ7fmfmJqoKIfv6K0m6AiJLBsBM5gmEncgTDTuQIhp3IEe2S3FlZWZn269cvyV3mzNmzZwNrpaWl5tji4uJct5O18+fPm/Ww3uNqbGwMrHXo0CGv+46jubnZrLdrFy86p06dCqx169bNHGv9/3TgwAGcPHlS2qrF6lhEJgL4C4BiAK+q6jzr/v369UMmk4mzy9SsW7cusFZVVWWO7dq1a67bydqmTZvM+s0332zWi4rivfjbvXt3YG3YsGGxHjuf6uvrzXp5eXmsx1+yZElgberUqeZY65eB53mBtcj/kiJSDOBlAJMADAcwQ0SGR308IsqvOL+2xwD4XFX3q2oTgBUApuSmLSLKtThh7w3gy1Y/H/a3fY+IzBaRjIhkwl4aEVH+5P3deFVdoKqeqnpx/84houjihP0IgD6tfr7W30ZEBShO2LcAGCwi/UWkBMCvAbyXm7aIKNckzllvIjIZwH+jZeptsar+h3V/z/PUmnqrqakx9zd+/PgIXbaw5nsB4LPPPjPrlZWVkfddyMKm5sKmFV319ddfm/WOHTumsu+qqips27Yt9/PsqroWwNo4j0FEyeDHZYkcwbATOYJhJ3IEw07kCIadyBEMO5EjEj2fPcyoUaMij924caNZHzdunFn/uc6jh+E8ejT5nEePs2/rlGQe2YkcwbATOYJhJ3IEw07kCIadyBEMO5EjEp16a2pqwqFDhwLrYZc9Hj48+HqWY8eOjdwXFaZ8nvIc1549e8y6SJtnmX7HOtV76NCh5tioU9Q8shM5gmEncgTDTuQIhp3IEQw7kSMYdiJHMOxEjkh0nr2kpAR9+/YNrB87dizyY8ddQpfaNm+euTAvRo4cadbvuOOOyPsOm0ffsmWLWR89enTkfYepqKgw61deeaVZHzx4cC7byQqP7ESOYNiJHMGwEzmCYSdyBMNO5AiGncgRDDuRIwpqcvrqq69Ou4WCtHLlSrM+ffr0yI/95ZdfmvWDBw+a9dtuuy3yvuMKm6s+evRoYO3kyZPm2BEjRpj10tJSs55PTU1NgTVrCfZYYReRAwAaAFwA0KyqXpzHI6L8ycWR/Reqav+aJKLU8W92IkfEDbsC+IeIbBWR2W3dQURmi0hGRDL19fUxd0dEUcUN+zhVHQVgEoA5IvKjMxdUdYGqeqrqlZeXx9wdEUUVK+yqesT/fgLA2wDG5KIpIsq9yGEXkc4i0uXSbQATAOzMVWNElFtx3o2vAPC2f33sdgDeUNX/sQaoqjlH+NZbb5k7nDlz5uV3mYDDhw+b9Wuvvdash12D/Iorrrjsni5ZtmyZWX/99dfN+vr16yPvO9+6detm1r/99tvAWtg8epji4uJY4+MoKSkJrFnXq48cdlXdD+CGqOOJKFmceiNyBMNO5AiGncgRDDuRIxh2IkeIdUpcrnmep9ZSta5qbGw06x06dDDrtbW1gbXKyspIPV3y/PPPm/W77rrLrF9//fWBtaIi+1hj/XcB4dOC1imwU6dONceGaWhoMOtdunSJ9fiWs2fPBtaqq6vx8ccftzn/xiM7kSMYdiJHMOxEjmDYiRzBsBM5gmEncgTDTuSIRC8l3dTUZF66uE+fPgl2k5wjR46Y9UWLFpn1Z5991qxbc+nWKY+AfelhAHjmmWfM+r59+8x6c3NzYM06VRMA6urqzPqTTz5p1h944IHAWtx59nzOo4exloO2Tr3lkZ3IEQw7kSMYdiJHMOxEjmDYiRzBsBM5gmEncgTPZ/8JmDdvnlmfO3duYG3+/Pnm2MceeyxSTz8F+/fvD6wNGDAgwU6S43keMpkMz2cnchnDTuQIhp3IEQw7kSMYdiJHMOxEjmDYiRyR6PnsFI01jw4Au3fvDqyVlZXlup3EvPrqq2Y9bK789ttvz2U7l8Wa4wfSmecPPbKLyGIROSEiO1tt6yEi60Vkr/+9e37bJKK4snkZvwTAxB9smwvgA1UdDOAD/2ciKmChYVfVGgCnf7B5CoCl/u2lAOJd44eI8i7qG3QVqnrpAmHHAFQE3VFEZotIRkQy9fX1EXdHRHHFfjdeW86kCTybRlUXqKqnql55eXnc3RFRRFHDflxEegGA//1E7loionyIGvb3ANzn374PwLu5aYeI8iV0nl1E3gRQDaBMRA4D+COAeQD+JiIPAjgI4J58NpkL586dM+vbt28367feemvkfYedU15TU2PWV61aZdaHDRsWWDt8+LA5Nt8WL14cWJs1a5Y59qGHHoq1761btwbWhg4dao4tLS2Nte9CPF8+NOyqOiOg9Msc90JEecSPyxI5gmEncgTDTuQIhp3IEQw7kSOcOcW1a9euZn3ZsmVmPc7UW9jlmsPqYZff9jwvsNazZ09zbL4NGjQo8thNmzaZ9YsXL5r13r17B9biTq2l6cKFC5HG8chO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHMGwEznCmXn2MAsXLkxt3zt27DDr1jx6mFGjRkUeCwBvvPGGWZ85c2asx7dUVVWZ9Z07d5r1QjzNNBu1tbVmfd++fYG1M2fOBNZ4ZCdyBMNO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHCEtC7ok47rrrtMVK1YE1hsaGszxt9xyS65b+s7atWvN+uTJk/O277g2bNgQWAs7D99a7hkAGhsbzfoNN9xg1ouKeDxJkud5yGQy0laN/xJEjmDYiRzBsBM5gmEncgTDTuQIhp3IEQw7kSMSnWf3PE/DroFeqO69997A2vLly82xTz31lFl/4YUXIvWUC3fffbdZX716tVl/8cUXzfrJkycDa1dddZU59vHHHzfrYaZPnx5YW7lyZazHLlSx5tlFZLGInBCRna22PSciR0Sk1v8q3E+cEBGA7F7GLwEwsY3tf1bVSv/L/vgZEaUuNOyqWgPgdAK9EFEexXmD7lER+cR/md896E4iMltEMiKSqa+vj7E7Ioojatj/CmAggEoAdQAC36VR1QWq6qmqV15eHnF3RBRXpLCr6nFVvaCqFwEsBDAmt20RUa5FCruI9Gr1468A2Nf0JaLUhc6zi8ibAKoBlAE4DuCP/s+VABTAAQC/VdW6sJ2NGDFC16xZE1j/4osvzPFDhgwJrF1zzTVhu0/N6dP2+5th64yXlZVF3veSJUvM+pgx9ouyb775xqyPHDnyclvK2vz588163759zfqUKVNy2c5PgjXPHrpIhKrOaGPzothdEVGi+HFZIkcw7ESOYNiJHMGwEzmCYSdyRKJLNl+8eNG8NHF1dbU5fteuXYG1Qp5669Gjh1kPm95qbm426+3aBf8z3n///Xl77Hzbtm2bWZ80aVJCnfw88MhO5AiGncgRDDuRIxh2Ikcw7ESOYNiJHMGwEzki0UnUoqIidOrUKfL44cOH57CbwvHVV1+Z9e7dA6/6BQDYvn17YC1sSeW48+irVq0y69OmTYv82K+99ppZ//DDD836oEGDIu/754hHdiJHMOxEjmDYiRzBsBM5gmEncgTDTuQIhp3IEYnOs5eUlKR23vmjjz5q1l966aWEOvkxa1ljIHyePWwuPZ/C5tHHjh0bWNuwYYM5tqmpyayHXf+Avo9HdiJHMOxEjmDYiRzBsBM5gmEncgTDTuQIhp3IEYlfFLy4uDjpXQJIdx49zJkzZ9JuIdCePXvMeq9evcz6Rx99FHnf7du3jzwWAObMmRNYe/nll2M99k9R6JFdRPqIyD9FZJeIfCoiv/O39xCR9SKy1/9uf/KDiFKVzcv4ZgB/UNXhAMYCmCMiwwHMBfCBqg4G8IH/MxEVqNCwq2qdqm7zbzcA2A2gN4ApAJb6d1sKYGq+miSi+C7rDToR6QdgJIDNACpUtc4vHQNQETBmtohkRCRTX18fo1UiiiPrsItIKYDVAH6vquda11RVAWhb41R1gap6quqVl5fHapaIossq7CLSHi1BX66qf/c3HxeRXn69F4AT+WmRiHIhdOpNRATAIgC7VfVPrUrvAbgPwDz/+7vZ7PDChQuBtbSm5fLt4YcfNusLFy5MqJPLN2TIELPe8qIumDXF5XmeOXb06NFmvajIPlbdeOONgbWNGzeaY8eNG2fWf4qymWevAvAbADtEpNbf9jRaQv43EXkQwEEA9+SnRSLKhdCwq+pGABJQ/mVu2yGifOHHZYkcwbATOYJhJ3IEw07kCIadyBEFdYprTU2NOXb8+PG5bidra9asCazdeeed5thCnrNdt26dWQ9b0nngwIFm3TrNNN9mzZqV2r4LEY/sRI5g2IkcwbATOYJhJ3IEw07kCIadyBEMO5EjEp9nt6Q5jx7Gmkvfv3+/ObZ///65bidnOnbsaNbDri40YMAAs/7KK68E1iZMmGCOHTRokFlvbGw06x06dDDrruGRncgRDDuRIxh2Ikcw7ESOYNiJHMGwEzmCYSdyREHNs4dpaGgIrHXp0iXBTr6vU6dOZj3u5wf27dtn1q1zysPmouvq6sx6dXW1WQ/zyCOPBNasNQSysX37drN+0003xXr8tLzzzjtmfeLEiYE16zr+PLITOYJhJ3IEw07kCIadyBEMO5EjGHYiRzDsRI6QsPW1RaQPgGUAKgAogAWq+hcReQ7AwwDq/bs+raprrcfyPE8zmUzkZletWhVYmzZtWuTHpWBNTU1mvaSkJKFO6BJrDYMnnngCe/fubXPV5Ww+VNMM4A+quk1EugDYKiLr/dqfVfW/LrtbIkpcNuuz1wGo8283iMhuAL3z3RgR5dZl/c0uIv0AjASw2d/0qIh8IiKLRaR7wJjZIpIRkUx9fX1bdyGiBGQddhEpBbAawO9V9RyAvwIYCKASLUf+F9sap6oLVNVTVS/semZElD9ZhV1E2qMl6MtV9e8AoKrHVfWCql4EsBDAmPy1SURxhYZdRATAIgC7VfVPrbb3anW3XwHYmfv2iChXsnk3vgrAbwDsEJFaf9vTAGaISCVapuMOAPhtNju0pvpafq8E4/Ra8vI5tXbq1Cmz3rNnz1iPv3fv3sDa4MGDYz325s2bzXqc02sPHTpk1q0/h60ltrN5N34jgLZSaM6pE1Fh4SfoiBzBsBM5gmEncgTDTuQIhp3IEQw7kSMSv5R02Fx6vhw9etSst2/f3qzzo765F3cePUycufT333/frHfv3uapIN+J8xmCvn37mmOteufOnQNrPLITOYJhJ3IEw07kCIadyBEMO5EjGHYiRzDsRI4IvZR0TncmUg/gYKtNZQBOJtbA5SnU3gq1L4C9RZXL3v5FVdv8UEiiYf/RzkUyquql1oChUHsr1L4A9hZVUr3xZTyRIxh2IkekHfYFKe/fUqi9FWpfAHuLKpHeUv2bnYiSk/aRnYgSwrATOSKVsIvIRBH5PxH5XETmptFDEBE5ICI7RKRWRKKvL52bXhaLyAkR2dlqWw8RWS8ie/3v9onVyfb2nIgc8Z+7WhGZnFJvfUTknyKyS0Q+FZHf+dtTfe6MvhJ53hL/m11EigHsAfCvAA4D2AJghqruSrSRACJyAICnqql/AENExgM4D2CZql7vb/tPAKdVdZ7/i7K7qv5bgfT2HIDzaS/j7a9W1Kv1MuMApgK4Hyk+d0Zf9yCB5y2NI/sYAJ+r6n5VbQKwAsCUFPooeKpaA+D0DzZPAbDUv70ULf+zJC6gt4KgqnWqus2/3QDg0jLjqT53Rl+JSCPsvQF82ernwyis9d4VwD9EZKuIzE67mTZUqGqdf/sYgIo0m2lD6DLeSfrBMuMF89xFWf48Lr5B92PjVHUUgEkA5vgvVwuStvwNVkhzp1kt452UNpYZ/06az13U5c/jSiPsRwD0afXztf62gqCqR/zvJwC8jcJbivr4pRV0/e8nUu7nO4W0jHdby4yjAJ67NJc/TyPsWwAMFpH+IlIC4NcA3kuhjx8Rkc7+GycQkc4AJqDwlqJ+D8B9/u37ALybYi/fUyjLeActM46Un7vUlz9X1cS/AExGyzvy+wD8exo9BPQ1AMB2/+vTtHsD8CZaXtZ9i5b3Nh4E0BPABwD2AvhfAD0KqLfXAewA8AlagtUrpd7GoeUl+icAav2vyWk/d0ZfiTxv/LgskSP4Bh2RIxh2Ikcw7ESOYNiJHMGwEzmCYSdyBMNO5Ij/B187bsTsoCFWAAAAAElFTkSuQmCC\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAScUlEQVR4nO3dfWwVZb4H8O+P0lJCCaBtCgJSIEUkgl08lou8BIS7ognCihqIWbkJscZg3JWNL/H+sf6JelezJjckBQ11sxeCoAESAbGB4EYEjoTb8qKgiAHEUlQE5KUUfvePDt4ind+czpwzc+rz/SSk7fl2Zh6PfJn2PGfmEVUFEf32dUt6AEQUD5adyBEsO5EjWHYiR7DsRI7oHufBSktLtaKiIs5DZs3PP//smxUXF5vbFhQUZHs4GTtz5oyZ9+rVy8yjjv3ChQu+Wc+ePSPtO5cuX75s5t2729URETNvbm72zcrKysxtLUeOHMGpU6c6PHiksovIDAB/B1AAYJmqLra+v6KiAul0OsohE7Njxw7f7LbbbjO37du3b7aHk7GPPvrIzFOplJlHHXtjY6NvNnr06Ej7zqVvv/3WzIMKWVhYaOa1tbW+2YIFC8xtrX+Arf+foX+MF5ECAP8N4H4AowDME5FRYfdHRLkV5Xf2agBfquphVW0BsBLArOwMi4iyLUrZBwI42u7rY95j1xGRGhFJi0ja+j2FiHIr56/Gq2qtqqZUNRXlhQciiiZK2Y8DGNzu60HeY0SUh6KUfReAShEZKiJFAOYCWJedYRFRtoWeelPVVhF5GsAmtE29va2q+6IMZuvWrWY+ZcqU0Pu+ePGimTc0NJj5uHHjQh87SdOnTzfzr7/+2syjTr3l8/Sa5ZZbbjFz6/0DQPDUW01NTafHlMmxr1696ptFmmdX1Q8AfBBlH0QUD75dlsgRLDuRI1h2Ikew7ESOYNmJHMGyEzki1uvZg0SZR9+4caOZz5gxw8yrq6tDH7srGzp0aNJD6JKSvBbfOna3bv7nb57ZiRzBshM5gmUncgTLTuQIlp3IESw7kSNinXq7fPkympqafPPDhw+b248fP943C5pao65n27ZtZj558mQzb2lp8c2KiopCjema48ft+7ScP3/ezK2711rTZwAwadIkM/fdb6itiKjLYdmJHMGyEzmCZSdyBMtO5AiWncgRLDuRI2KdZy8sLER5eblv3traGuNoKBNvvPGGmd95551mfu+994Y+dtA8en19vZlPmzYt9LGD9OnTx8wHDrxhJbTrVFZWZnM4GeGZncgRLDuRI1h2Ikew7ESOYNmJHMGyEzmCZSdyRF7dSjpobtJVr7zyipm/8MILvtnZs2fNbYPyffvsVbirqqrMPJfGjh1r5l999ZVv1qtXL3Pb/v37m/mlS5fMvKSkxMyTEKnsInIEwFkAVwC0qmoqG4MiouzLxpl9qqqeysJ+iCiH+Ds7kSOill0BfCgin4lITUffICI1IpIWkXRzc3PEwxFRWFHLPlFVxwK4H8BCEbnhygVVrVXVlKqmysrKIh6OiMKKVHZVPe59PAngfQBuro5I1AWELruI9BKR3tc+B/B7AHuzNTAiyq4or8aXA3hfRK7t539U1Vw3WVXNe3lv2rTJPODMmTM7P8oYBM259ujRw8yt+WAg+Jpxy/Lly828sbHRzJctWxb62LnWr18/M+/e3f+vd+/evSMd++abbzbzc+fOmXkS8/Chy66qhwGE/1tIRLHi1BuRI1h2Ikew7ESOYNmJHMGyEzlCVDW2g6VSKU2n07EdzxWff/65bzZ06FBz26BpwVdffdXMg6ZDreMXFxeb227ZssXM9+/fb+bWJdOzZ882t81nV65c8c3GjRuHdDotHWU8sxM5gmUncgTLTuQIlp3IESw7kSNYdiJHsOxEjoj1VtItLS04duyYbz5o0KAYRxOfgwcPmvnmzZvNfOHChWY+cuRI38y7BNlX0Pssnn/+eTM/ffq0mQfNpVuKiorMPOh5efLJJ32zrjzPXlBQEGo7ntmJHMGyEzmCZSdyBMtO5AiWncgRLDuRI1h2IkfEOs9eVFT0m51Lt4wYMSJS/vrrr5v5okWLfLO1a9ea20bVt2/fnO17woQJkbZ/9tlnfbOot//uinhmJ3IEy07kCJadyBEsO5EjWHYiR7DsRI5g2YkcEes8O4VjzaMDQENDg2/WrVvX/fe8rq7OzIcPH27mEydOzOZwOuXAgQNmfvvtt8c0kv8X+DdBRN4WkZMisrfdYzeJyGYROeR9tBfKJqLEZfLP/nIAM3712IsA6lW1EkC99zUR5bHAsqvqNgA//OrhWQCu/YxVB6Dr3uOHyBFhf6ErV9UT3uffASj3+0YRqRGRtIikm5ubQx6OiKKK/OqNtt2x0Peuhapaq6opVU2VlZVFPRwRhRS27E0iMgAAvI8nszckIsqFsGVfB2C+9/l8ALm9jpKIIgucZxeRFQCmACgVkWMA/gpgMYBVIrIAwDcAHs3lILPh3LlzZr5r1y4znzp1auhjL1261Mzfe+89M9+wYYOZjxkzxjf7/vvvzW1zbeXKlb7Z3LlzzW3nz59v5kE+/fRT36yiosLctn///pGOncQ8epDAsqvqPJ9oWpbHQkQ51HXfXkVEncKyEzmCZSdyBMtO5AiWncgRzlziWlJSYuabNm0y8yhTb0888USkfOfOnWZeXV3tm916663mtrk2YMCA0NuuX7/ezIOWdO7Xz/9izKhTa0lqbW31zawluHlmJ3IEy07kCJadyBEsO5EjWHYiR7DsRI5g2YkcEes8u6ri8uXLvnlhYWGMo7ne4sWLEzv29u3bzXz8+PGh9x10u+UgQZffPvTQQ2Y+ePDg0MeeOXOmmUd5/0E+27Jli5lfvHjRNztz5oxvxjM7kSNYdiJHsOxEjmDZiRzBshM5gmUncgTLTuQIsa5/zbYxY8bounXrfHNrjtDbPttD+sWKFSvMfN48v5vsJq++vt43mzbNvgnwF198YeZ9+vQx86D7BATlSQlaiqyrrl6USqWQTqelo4xndiJHsOxEjmDZiRzBshM5gmUncgTLTuQIlp3IEbHOs9911126Y8cO37x79/y9jb21fHBdXZ257XPPPWfmr732WqgxZcOcOXPMfM2aNWYe9N/+448/+mZBc9mPPfaYmQd5+OGHfbPVq1dH2ne+ijTPLiJvi8hJEdnb7rGXReS4iOzx/jyQzQETUfZl8mP8cgAzOnj8DVWt8v58kN1hEVG2BZZdVbcB+CGGsRBRDkV5ge5pEWnwfsz3XVRLRGpEJC0i6VOnTkU4HBFFEbbsSwAMB1AF4ASAv/l9o6rWqmpKVVOlpaUhD0dEUYUqu6o2qeoVVb0KYCmArnkbTyKHhCq7iLRfh/cPAPb6fS8R5YfAeXYRWQFgCoBSAE0A/up9XQVAARwB8KSqngg62OjRo3Xt2rW++eHDh83tKysrfbMhQ4YEHT4xTU1NZm7dBxwIvvd6t27+/2a/88475rYPPvigmR87dszM77jjDjOPYtmyZWY+adIkMx82bJhvluQaBblkzbMHvotFVTu6a8NbkUdFRLHi22WJHMGyEzmCZSdyBMtO5AiWncgRsV9TKtLhrAAAYPr06ea2Bw8ezPZwYlFeXm7mFy5cMPMrV66YuTX19vjjj5vbXrp0ycxzObUW5MMPPzTzcePGmflvdXotLJ7ZiRzBshM5gmUncgTLTuQIlp3IESw7kSNYdiJHxDrPrqqB87qWESNGZHE0+ePkyZNmHnT57u7du32zsWPHmtv26NHDzINYy0UDwUtGW1atWmXm1vLfADB69OjQx/4t4pmdyBEsO5EjWHYiR7DsRI5g2YkcwbITOYJlJ3JErPPsxcXFGDlyZJyH/MVTTz1l5kuWLIlpJDf66aefIm0fNJeeS0Hz6NayycuXLze3DboFd9BtsOl6PLMTOYJlJ3IEy07kCJadyBEsO5EjWHYiR7DsRI6I/b7xSUlyHj3I6dOnkx6Cr507d5p50HLSq1evDn3skpKS0NsCwDPPPOObvfnmm5H23RUFntlFZLCIbBGR/SKyT0T+5D1+k4hsFpFD3sd+uR8uEYWVyY/xrQD+oqqjAPwbgIUiMgrAiwDqVbUSQL33NRHlqcCyq+oJVd3tfX4WwAEAAwHMAlDnfVsdgNm5GiQRRdepF+hEpALA7wDsAFCuqie86DsAHS5oJiI1IpIWkXRzc3OEoRJRFBmXXURKAKwB8GdVPdM+U1UFoB1tp6q1qppS1VRZWVmkwRJReBmVXUQK0Vb0f6rqe97DTSIywMsHALBvkUpEiQqcepO2NZbfAnBAVV9vF60DMB/AYu/j2kwOaC0/XFBQkMkuupyamhozr62tjWkknVddXW3mQbcG37Ztm28WtBT11KlTzTyIdfntu+++a277yCOPRDp2Pspknn0CgD8CaBSRPd5jL6Gt5KtEZAGAbwA8mpshElE2BJZdVf8FQHzi8CsAEFGs+HZZIkew7ESOYNmJHMGyEzmCZSdyROyXuFpz6R9//LG57aRJk7I9nIxt3brVN5syZYq5bT7P2X7yySdmHjSPPmrUKDOfPHlyp8eULbNmzUrs2PmIZ3YiR7DsRI5g2YkcwbITOYJlJ3IEy07kCJadyBF5dSvpJOfRg1hz6UePHjW3TfIOPW03EfJXWFho5kHLQRcXF5v5xo0bfbOg5bsrKirM/OLFi2YeNDbX8MxO5AiWncgRLDuRI1h2Ikew7ESOYNmJHMGyEzkir+bZg1jXVvfo0SPGkVwvaK66qqoq0v4PHjxo5iNGjPDNzp8/b27b2Nho5nfffbeZB5kxY4Zv1tLSEmnf27dvN/Oo951PinWvfcD+f3L16lXfjGd2Ikew7ESOYNmJHMGyEzmCZSdyBMtO5AiWncgREnS9s4gMBvAOgHIACqBWVf8uIi8DeAJAs/etL6nqB9a+UqmUptPp0INds2aNbzZnzpzQ++3qrOu6o17TfeHCBTPv2bNnpP1T561fv943W7RoEQ4dOtThqsuZvKmmFcBfVHW3iPQG8JmIbPayN1T1vzo9WiKKXSbrs58AcML7/KyIHAAwMNcDI6Ls6tTv7CJSAeB3AHZ4Dz0tIg0i8raI9PPZpkZE0iKSbm5u7uhbiCgGGZddREoArAHwZ1U9A2AJgOEAqtB25v9bR9upaq2qplQ1leS92Ihcl1HZRaQQbUX/p6q+BwCq2qSqV1T1KoClAKpzN0wiiiqw7CIiAN4CcEBVX2/3+IB23/YHAHuzPzwiypZMXo2fAOCPABpFZI/32EsA5olIFdqm444AeDInI2zH5ek1Sy5vmZzLqbVTp06ZeWlpaaT9f/PNN77ZkCFDIu1706ZNZn7fffeF3nfQdGdYmbwa/y8AHc3bmXPqRJRf+A46Ikew7ESOYNmJHMGyEzmCZSdyBMtO5IjAS1yzKegS19bWVnP77t3D3/n67NmzZh70vv1hw4aFPjZ1PRs2bDDzoPcf3HPPPWZeVFTU6TFlIpVKIZ1Od3iJK8/sRI5g2YkcwbITOYJlJ3IEy07kCJadyBEsO5EjYp1nF5FmAO0vMi4FYF/UnJx8HVu+jgvg2MLK5tiGqGqH93+Ltew3HFwkraqpxAZgyNex5eu4AI4trLjGxh/jiRzBshM5Iumy1yZ8fEu+ji1fxwVwbGHFMrZEf2cnovgkfWYnopiw7ESOSKTsIjJDRL4QkS9F5MUkxuBHRI6ISKOI7BGR8OtLZ2csb4vISRHZ2+6xm0Rks4gc8j52uMZeQmN7WUSOe8/dHhF5IKGxDRaRLSKyX0T2icifvMcTfe6MccXyvMX+O7uIFAA4CODfARwDsAvAPFXdH+tAfIjIEQApVU38DRgiMhnAOQDvqOod3mOvAvhBVRd7/1D2U9UX8mRsLwM4l/Qy3t5qRQPaLzMOYDaA/0CCz50xrkcRw/OWxJm9GsCXqnpYVVsArAQwK4Fx5D1V3Qbgh189PAtAnfd5Hdr+ssTOZ2x5QVVPqOpu7/OzAK4tM57oc2eMKxZJlH0ggKPtvj6G/FrvXQF8KCKfiUhN0oPpQLmqnvA+/w5AeZKD6UDgMt5x+tUy43nz3IVZ/jwqvkB3o4mqOhbA/QAWej+u5iVt+x0sn+ZOM1rGOy4dLDP+iySfu7DLn0eVRNmPAxjc7utB3mN5QVWPex9PAngf+bcUddO1FXS9jycTHs8v8mkZ746WGUcePHdJLn+eRNl3AagUkaEiUgRgLoB1CYzjBiLSy3vhBCLSC8DvkX9LUa8DMN/7fD6AtQmO5Tr5soy33zLjSPi5S3z5c1WN/Q+AB9D2ivxXAP4ziTH4jGsYgP/1/uxLemwAVqDtx7rLaHttYwGAmwHUAzgE4CMAN+XR2P4BoBFAA9qKNSChsU1E24/oDQD2eH8eSPq5M8YVy/PGt8sSOYIv0BE5gmUncgTLTuQIlp3IESw7kSNYdiJHsOxEjvg/9CZ4c215vKMAAAAASUVORK5CYII=\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"markdown","metadata":{"id":"TUkbp1qQLAoR"},"source":["## Main (benchmark datasets)"]},{"cell_type":"markdown","metadata":{"id":"20NZp7WQ8pXw"},"source":["### Build graph"]},{"cell_type":"code","metadata":{"id":"liyqpNhy8qTG"},"source":["import os\n","#from gan_function import *\n","from util_function.utils import combine_nodes\n","from util_function.preprocess import *\n","from GNN_Model.model import GCN_Model\n","from GNN_Model.trainer import GCN_Trainer\n","from Generator.model import GraphCGAN_Generator\n","from Generator.trainer import GraphCGAN_Trainer\n","from sklearn.cluster import KMeans\n","from collections import Counter\n","from sklearn.cluster import SpectralClustering\n","import tensorflow as tf\n","import os\n","import time\n","import numpy as np\n","from sklearn.cluster import AgglomerativeClustering\n","from sklearn.metrics.cluster import normalized_mutual_info_score\n","from sklearn.decomposition import PCA\n","import pickle\n","\n","name = \"citeseer\"\n","adj, features, y_train, y_val, y_test, train_mask, val_mask, test_mask = load_data(name)\n","\n","B = 500\n","N = adj.shape[0]\n","d = features.shape[1]\n","M = y_train.shape[1]"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"1PsrQZ_0960u","executionInfo":{"status":"ok","timestamp":1599857832111,"user_tz":240,"elapsed":28315,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"fcf70b92-b5c0-44e5-c7ed-33f48a96c456","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["\n","#################\n","## build model ##\n","#################\n","tf.reset_default_graph()\n","gcn_model = GCN_Model(N, d, M, model_name = \"GCN\", batch_size = B)\n","gcn_model_attr = GCN_Model(N, d, M, model_name = \"GCN_attr\", batch_size = B)\n","cgan_model = GraphCGAN_Generator(N, d, M, gcn_model_attr, gcn_model, batch_size = B)\n","####################\n","## define session ##\n","####################\n","config = tf.ConfigProto()\n","config.gpu_options.allow_growth = True\n","sess = tf.Session(config=config)\n","sess.run(tf.global_variables_initializer())\n","###################\n","## build trainer ##\n","###################\n","gcn_trainer = GCN_Trainer(gcn_model)\n","gcn_trainer_attr = GCN_Trainer(gcn_model_attr)\n","cgan_trainer = GraphCGAN_Trainer(cgan_model)\n","##########################\n","## initialize fake node ##\n","##########################\n","generated_features = np.zeros((B, d))\n","generated_adj = np.zeros((B, N))\n","###############################\n","## obtain dense adj and attr ##\n","###############################\n","features_dense = preprocess_features_dense(features) \n","adj_dense = preprocess_adj_dence(adj)\n"],"execution_count":null,"outputs":[{"output_type":"stream","text":["WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:30: The name tf.sparse_placeholder is deprecated. Please use tf.compat.v1.sparse_placeholder instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:32: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:34: The name tf.placeholder_with_default is deprecated. Please use tf.compat.v1.placeholder_with_default instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:49: The name tf.variable_scope is deprecated. Please use tf.compat.v1.variable_scope instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:49: The name tf.AUTO_REUSE is deprecated. Please use tf.compat.v1.AUTO_REUSE instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:51: The name tf.get_variable is deprecated. Please use tf.compat.v1.get_variable instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:44: The name tf.random_uniform is deprecated. Please use tf.random.uniform instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:13: The name tf.sparse_retain is deprecated. Please use tf.sparse.retain instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/gnn_utils.py:22: The name tf.sparse_tensor_dense_matmul is deprecated. Please use tf.sparse.sparse_dense_matmul instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:64: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:86: The name tf.get_collection is deprecated. Please use tf.compat.v1.get_collection instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:86: The name tf.GraphKeys is deprecated. Please use tf.compat.v1.GraphKeys instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/metrics.py:6: softmax_cross_entropy_with_logits (from tensorflow.python.ops.nn_ops) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","\n","Future major versions of TensorFlow will allow gradients to flow\n","into the labels input on backprop by default.\n","\n","See `tf.nn.softmax_cross_entropy_with_logits_v2`.\n","\n","WARNING:tensorflow:\n","The TensorFlow contrib module will not be included in TensorFlow 2.0.\n","For more information, please see:\n","  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md\n","  * https://github.com/tensorflow/addons\n","  * https://github.com/tensorflow/io (for I/O related ops)\n","If you depend on functionality not listed there, please file an issue.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:100: The name tf.log is deprecated. Please use tf.math.log instead.\n","\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/GNN_Model/model.py:110: The name tf.train.AdamOptimizer is deprecated. Please use tf.compat.v1.train.AdamOptimizer instead.\n","\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/ops/math_grad.py:1424: where (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Use tf.where in 2.0, which has the same broadcast rule as np.where\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/Generator/generator_utils.py:49: dense (from tensorflow.python.layers.core) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Use keras.layers.Dense instead.\n","WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/layers/core.py:187: Layer.apply (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n","Instructions for updating:\n","Please use `layer.__call__` method instead.\n","WARNING:tensorflow:From /content/drive/My Drive/GCNGAN/GraphCGAN/Generator/generator_utils.py:15: calling reduce_sum_v1 (from tensorflow.python.ops.math_ops) with keep_dims is deprecated and will be removed in a future version.\n","Instructions for updating:\n","keep_dims is deprecated, use keepdims instead\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:120: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"}]},{"cell_type":"markdown","metadata":{"id":"V3sz6ZyY8nEM"},"source":["### Train"]},{"cell_type":"code","metadata":{"id":"gM0at432LFcK","executionInfo":{"status":"ok","timestamp":1599857852001,"user_tz":240,"elapsed":45290,"user":{"displayName":"Sheng Zhang","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GhraDPO3yxolOf82I55EVZaIAfn4g1oUU6mSS7k=s64","userId":"16336041814041002028"}},"outputId":"569d76e6-b759-4ddc-9bb3-18aa2ceaf4af","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["val_traj = []\n","test_traj = []\n","test_traj_attr = []\n","for _ in range(10):\n","  ###########################################\n","  ## combine fake nodes to original graph ###\n","  ###########################################\n","  enlarged_adj, enlarged_features, enlarged_y_train, enlarged_y_val, enlarged_y_test, enlarged_train_mask, enlarged_val_mask, enlarged_test_mask = \\\n","                    combine_nodes(adj, features, y_train, y_val, y_test, \\\n","                                  train_mask, val_mask, test_mask, \\\n","                                  generated_adj, generated_features)\n","  enlarged_features_sp = preprocess_features(enlarged_features) ## sparse normalized feature\n","  enlarged_adj_sp = preprocess_adj(enlarged_adj) ## sparse normalized adjancency matrix\n","\n","  ###############\n","  ## train gnn ##\n","  ###############\n","\n","  val_cost, val_acc = gcn_trainer.fit(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_train, enlarged_train_mask,enlarged_y_val, enlarged_val_mask,\\\n","                  epoch_num = 11, print_every = 10)\n","  test_cost, test_acc, pred_result, feature_space = gcn_trainer.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_sp, enlarged_y_test, enlarged_test_mask)\n","\n","  val_traj.append(val_acc)\n","  test_traj.append(test_acc)\n","  ##############################\n","  ## train gnn with attr only ##\n","  ##############################\n","\n","  enlarged_y_attr_hat = np.eye(M)[np.argmax(pred_result, 1)]\n","  enlarged_train_attr_mask = np.array([True] * N + [False] * B)\n","  enlarged_adj_attr = sp.coo_matrix(np.eye(N + B))\n","  enlarged_adj_attr_sp = preprocess_adj(enlarged_adj_attr)\n","\n","  val_cost_attr, val_acc_attr = gcn_trainer_attr.fit(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_attr_hat, enlarged_train_attr_mask,\\\n","                       epoch_num = 21)\n","  _, _, _, feature_space_attr = gcn_trainer_attr.evaluate_on_test(sess, enlarged_features_sp, enlarged_adj_attr_sp, enlarged_y_test, enlarged_test_mask)\n","  #####################\n","  ## train generator ##\n","  #####################\n","  generated_features, generated_adj = cgan_trainer.fit(sess, adj_dense, features_dense,\\\n","                                                       epoch_num = 5)\n"],"execution_count":null,"outputs":[{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.95333 D_loss= 0.00000 train_acc= 0.17500 val_loss= 1.94280 val_acc= 0.35000\n","Epoch: 0011 train_loss= 1.84174 D_loss= 0.00000 train_acc= 0.65833 val_loss= 1.89997 val_acc= 0.51200\n","Optimization Finished!\n","Test accuracy: 0.52\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.18100001\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.82984 D_loss= 0.00000 train_acc= 0.66667 val_loss= 1.89731 val_acc= 0.56000\n","Epoch: 0011 train_loss= 1.70707 D_loss= 0.00000 train_acc= 0.80833 val_loss= 1.86289 val_acc= 0.67400\n","Optimization Finished!\n","Test accuracy: 0.655\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.291\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.70476 D_loss= 0.00000 train_acc= 0.73333 val_loss= 1.85738 val_acc= 0.68200\n","Epoch: 0011 train_loss= 1.55929 D_loss= 0.00000 train_acc= 0.86667 val_loss= 1.82290 val_acc= 0.67200\n","Optimization Finished!\n","Test accuracy: 0.644\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.514\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.54712 D_loss= 0.00000 train_acc= 0.82500 val_loss= 1.82039 val_acc= 0.66200\n","Epoch: 0011 train_loss= 1.41081 D_loss= 0.00000 train_acc= 0.90833 val_loss= 1.77338 val_acc= 0.68800\n","Optimization Finished!\n","Test accuracy: 0.674\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.487\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.37237 D_loss= 0.00000 train_acc= 0.89167 val_loss= 1.76807 val_acc= 0.68400\n","Epoch: 0011 train_loss= 1.31198 D_loss= 0.00000 train_acc= 0.86667 val_loss= 1.72421 val_acc= 0.71400\n","Optimization Finished!\n","Test accuracy: 0.70500004\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.689\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.28648 D_loss= 0.00000 train_acc= 0.90833 val_loss= 1.71888 val_acc= 0.71600\n","Epoch: 0011 train_loss= 1.18226 D_loss= 0.00000 train_acc= 0.90833 val_loss= 1.67280 val_acc= 0.72000\n","Optimization Finished!\n","Test accuracy: 0.6980001\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.723\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.16020 D_loss= 0.00000 train_acc= 0.91667 val_loss= 1.66948 val_acc= 0.72200\n","Epoch: 0011 train_loss= 1.05905 D_loss= 0.00000 train_acc= 0.93333 val_loss= 1.61913 val_acc= 0.72000\n","Optimization Finished!\n","Test accuracy: 0.71099997\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.73300004\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.05289 D_loss= 0.00000 train_acc= 0.95833 val_loss= 1.61691 val_acc= 0.71600\n","Epoch: 0011 train_loss= 0.99366 D_loss= 0.00000 train_acc= 0.92500 val_loss= 1.57093 val_acc= 0.71200\n","Optimization Finished!\n","Test accuracy: 0.709\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.734\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 1.00373 D_loss= 0.00000 train_acc= 0.92500 val_loss= 1.56731 val_acc= 0.71800\n","Epoch: 0011 train_loss= 0.94690 D_loss= 0.00000 train_acc= 0.93333 val_loss= 1.52440 val_acc= 0.71600\n","Optimization Finished!\n","Test accuracy: 0.7070001\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.743\n","========================================Run cGan========================================\n"],"name":"stdout"},{"output_type":"stream","text":["/content/drive/My Drive/GCNGAN/GraphCGAN/util_function/preprocess.py:130: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n"],"name":"stderr"},{"output_type":"stream","text":["========================================Run gcn========================================\n","Epoch: 0001 train_loss= 0.94391 D_loss= 0.00000 train_acc= 0.93333 val_loss= 1.51711 val_acc= 0.72200\n","Epoch: 0011 train_loss= 0.87530 D_loss= 0.00000 train_acc= 0.96667 val_loss= 1.49563 val_acc= 0.70600\n","Optimization Finished!\n","Test accuracy: 0.698\n","========================================Run gcn========================================\n","Optimization Finished!\n","Test accuracy: 0.73099995\n","========================================Run cGan========================================\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"uZebLrwRMpwE"},"source":[""],"execution_count":null,"outputs":[]}]}