{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "1. Scaled heatmap for quail, run on "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "from sklearn.datasets import make_classification\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import accuracy_score, classification_report, roc_auc_score\n",
    "\n",
    "def generate_classification_task(data_size):\n",
    "    n_samples = data_size # 100000\n",
    "    n_features = 7\n",
    "    n_informative = 7 # relevant features to explain target\n",
    "    n_redundant = 0 # linear combinations of informative\n",
    "    n_repeated = 0 # random copies of informative and redundant\n",
    "    n_useless = n_features - n_informative - n_redundant - n_repeated # noise\n",
    "\n",
    "    n_classes = 10\n",
    "    seed = 42\n",
    "\n",
    "    # define feature names\n",
    "    def feature_names (n_items, prefix = 'feature'):\n",
    "        names = []\n",
    "        for i in range(n_items):\n",
    "            names.append(prefix + '_' + str(i))\n",
    "        return names\n",
    "\n",
    "    inf_features = feature_names(n_informative, 'inf')\n",
    "    red_features = feature_names(n_redundant, 'red')\n",
    "    rep_features = feature_names(n_repeated, 'rep')\n",
    "    useless_features = feature_names(n_useless, 'noise')\n",
    "\n",
    "    feature_names = inf_features + red_features + rep_features + useless_features\n",
    "\n",
    "    X, y = make_classification(n_samples=n_samples, \n",
    "                        n_features=n_features, \n",
    "                        n_informative=n_informative, \n",
    "                        n_redundant=n_redundant, \n",
    "                        n_repeated=n_repeated, \n",
    "                        n_classes=n_classes, \n",
    "                        n_clusters_per_class=2, \n",
    "                        weights=None, \n",
    "                        flip_y=0.03, \n",
    "                        class_sep=5.0, \n",
    "                        hypercube=True, \n",
    "                        shift=15.0, # 20\n",
    "                        scale=0.5, # 2.0\n",
    "                        shuffle=False, \n",
    "                        random_state=seed)\n",
    "\n",
    "    Z=np.zeros((X.shape[0], X.shape[1]+1))\n",
    "    Z[:,:-1]=X\n",
    "    Z[:,-1]=y\n",
    "\n",
    "    columns = feature_names + ['class']\n",
    "    df = pd.DataFrame(Z, columns=columns)\n",
    "\n",
    "    df = df.astype('int32')\n",
    "    return df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(3200, 7)\n",
      "(3200, 1)\n",
      "[7 7 4 ... 4 3 6]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.62      0.54      0.58        74\n",
      "           1       0.69      0.97      0.81        79\n",
      "           2       0.94      0.39      0.55        77\n",
      "           3       0.67      0.25      0.36        81\n",
      "           4       0.96      0.94      0.95        87\n",
      "           5       0.96      0.51      0.66        87\n",
      "           6       0.64      0.95      0.77        88\n",
      "           7       0.55      0.82      0.66        72\n",
      "           8       0.47      0.97      0.64        71\n",
      "           9       0.45      0.25      0.32        84\n",
      "\n",
      "    accuracy                           0.66       800\n",
      "   macro avg       0.70      0.66      0.63       800\n",
      "weighted avg       0.70      0.66      0.63       800\n",
      "\n",
      "0.6575\n",
      "Finished eps split 0.1\n",
      "(3200, 7)\n",
      "(3200, 1)\n",
      "[7 7 4 ... 4 3 6]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.57      0.51      0.54        74\n",
      "           1       0.64      0.52      0.57        79\n",
      "           2       0.70      0.42      0.52        77\n",
      "           3       0.80      0.54      0.65        81\n",
      "           4       0.71      0.90      0.79        87\n",
      "           5       0.92      0.40      0.56        87\n",
      "           6       0.65      0.83      0.73        88\n",
      "           7       0.47      0.89      0.62        72\n",
      "           8       0.65      0.55      0.60        71\n",
      "           9       0.62      0.82      0.71        84\n",
      "\n",
      "    accuracy                           0.64       800\n",
      "   macro avg       0.67      0.64      0.63       800\n",
      "weighted avg       0.68      0.64      0.63       800\n",
      "\n",
      "0.64125\n",
      "Finished eps split 0.3\n",
      "(3200, 7)\n",
      "(3200, 1)\n",
      "[7 7 4 ... 4 3 6]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.91      0.41      0.56        74\n",
      "           1       0.69      0.97      0.81        79\n",
      "           2       0.84      0.42      0.56        77\n",
      "           3       0.98      0.58      0.73        81\n",
      "           4       0.93      0.93      0.93        87\n",
      "           5       0.95      0.22      0.36        87\n",
      "           6       0.68      0.94      0.79        88\n",
      "           7       0.55      0.85      0.67        72\n",
      "           8       0.59      0.93      0.73        71\n",
      "           9       0.59      0.83      0.69        84\n",
      "\n",
      "    accuracy                           0.71       800\n",
      "   macro avg       0.77      0.71      0.68       800\n",
      "weighted avg       0.78      0.71      0.68       800\n",
      "\n",
      "0.7075\n",
      "Finished eps split 0.5\n",
      "(3200, 7)\n",
      "(3200, 1)\n",
      "[7 7 4 ... 4 3 6]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.94      0.64      0.76        74\n",
      "           1       0.75      0.97      0.85        79\n",
      "           2       0.78      0.42      0.54        77\n",
      "           3       0.97      0.75      0.85        81\n",
      "           4       0.94      0.90      0.92        87\n",
      "           5       0.97      0.82      0.89        87\n",
      "           6       0.70      0.93      0.80        88\n",
      "           7       0.54      0.86      0.67        72\n",
      "           8       0.72      0.90      0.80        71\n",
      "           9       0.63      0.50      0.56        84\n",
      "\n",
      "    accuracy                           0.77       800\n",
      "   macro avg       0.79      0.77      0.76       800\n",
      "weighted avg       0.80      0.77      0.77       800\n",
      "\n",
      "0.77\n",
      "Finished eps split 0.7\n",
      "(3200, 7)\n",
      "(3200, 1)\n",
      "[7 7 4 ... 4 3 6]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.97      0.46      0.62        74\n",
      "           1       0.59      0.89      0.71        79\n",
      "           2       0.69      0.71      0.70        77\n",
      "           3       0.96      0.57      0.71        81\n",
      "           4       0.94      0.68      0.79        87\n",
      "           5       0.56      0.40      0.47        87\n",
      "           6       0.66      0.94      0.78        88\n",
      "           7       0.38      0.33      0.35        72\n",
      "           8       0.55      0.96      0.70        71\n",
      "           9       0.41      0.39      0.40        84\n",
      "\n",
      "    accuracy                           0.63       800\n",
      "   macro avg       0.67      0.63      0.62       800\n",
      "weighted avg       0.67      0.63      0.63       800\n",
      "\n",
      "0.63375\n",
      "Finished eps split 0.9\n",
      "(9600, 7)\n",
      "(9600, 1)\n",
      "[3 7 2 ... 0 8 0]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.89      0.67      0.77       246\n",
      "           1       0.53      0.99      0.69       244\n",
      "           2       0.72      0.54      0.62       241\n",
      "           3       0.95      0.50      0.65       235\n",
      "           4       0.96      0.84      0.90       261\n",
      "           6       0.70      0.99      0.82       246\n",
      "           7       0.61      0.86      0.72       255\n",
      "           8       0.60      0.91      0.73       203\n",
      "           9       0.60      0.56      0.58       227\n",
      "\n",
      "   micro avg       0.69      0.76      0.72      2158\n",
      "   macro avg       0.73      0.76      0.72      2158\n",
      "weighted avg       0.73      0.76      0.72      2158\n",
      "\n",
      "0.6870833333333334\n",
      "Epoch 1, Loss G: -0.0581, Loss D: 0.1550\n",
      "epsilon is 0.21130224162476505, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0659, Loss D: 0.1317\n",
      "epsilon is 0.2711099360113021, alpha is 63.0\n",
      "Finished eps split 0.1\n",
      "(9600, 7)\n",
      "(9600, 1)\n",
      "[3 7 2 ... 0 8 0]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.71      0.63      0.67       246\n",
      "           1       0.79      0.99      0.88       244\n",
      "           2       0.83      0.51      0.64       241\n",
      "           3       0.94      0.35      0.51       235\n",
      "           4       0.97      0.88      0.92       261\n",
      "           5       0.97      0.59      0.74       242\n",
      "           6       0.71      0.98      0.83       246\n",
      "           7       0.62      0.89      0.74       255\n",
      "           8       0.71      0.93      0.81       203\n",
      "           9       0.63      0.81      0.71       227\n",
      "\n",
      "    accuracy                           0.76      2400\n",
      "   macro avg       0.79      0.76      0.74      2400\n",
      "weighted avg       0.79      0.76      0.74      2400\n",
      "\n",
      "0.75625\n",
      "Epoch 1, Loss G: -0.0483, Loss D: 0.1637\n",
      "epsilon is 0.21130224162476505, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0622, Loss D: 0.0935\n",
      "epsilon is 0.2711099360113021, alpha is 63.0\n",
      "Finished eps split 0.3\n",
      "(9600, 7)\n",
      "(9600, 1)\n",
      "[3 7 2 ... 0 8 0]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.79      0.60      0.68       246\n",
      "           1       0.68      0.98      0.80       244\n",
      "           2       0.78      0.58      0.67       241\n",
      "           3       0.90      0.44      0.59       235\n",
      "           4       0.93      0.90      0.92       261\n",
      "           5       0.96      0.72      0.83       242\n",
      "           6       0.72      0.98      0.83       246\n",
      "           7       0.67      0.86      0.75       255\n",
      "           8       0.85      0.92      0.89       203\n",
      "           9       0.60      0.66      0.63       227\n",
      "\n",
      "    accuracy                           0.77      2400\n",
      "   macro avg       0.79      0.77      0.76      2400\n",
      "weighted avg       0.79      0.77      0.76      2400\n",
      "\n",
      "0.76625\n",
      "Epoch 1, Loss G: -0.0572, Loss D: 0.1635\n",
      "epsilon is 0.21130224162476505, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0728, Loss D: 0.0889\n",
      "epsilon is 0.2711099360113021, alpha is 63.0\n",
      "Finished eps split 0.5\n",
      "(9600, 7)\n",
      "(9600, 1)\n",
      "[3 7 2 ... 0 8 0]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.88      0.72      0.79       246\n",
      "           1       0.70      0.99      0.82       244\n",
      "           2       0.73      0.62      0.67       241\n",
      "           3       0.92      0.82      0.86       235\n",
      "           4       0.96      0.97      0.97       261\n",
      "           5       0.92      0.75      0.83       242\n",
      "           6       0.87      0.67      0.75       246\n",
      "           7       0.69      0.80      0.75       255\n",
      "           8       0.66      0.87      0.75       203\n",
      "           9       0.64      0.64      0.64       227\n",
      "\n",
      "    accuracy                           0.79      2400\n",
      "   macro avg       0.80      0.79      0.78      2400\n",
      "weighted avg       0.80      0.79      0.79      2400\n",
      "\n",
      "0.78625\n",
      "Epoch 1, Loss G: -0.0644, Loss D: 0.1807\n",
      "epsilon is 0.21130224162476505, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0659, Loss D: 0.0813\n",
      "epsilon is 0.2711099360113021, alpha is 63.0\n",
      "Finished eps split 0.7\n",
      "(9600, 7)\n",
      "(9600, 1)\n",
      "[3 7 2 ... 0 8 0]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.72      0.75      0.73       246\n",
      "           1       0.74      0.96      0.84       244\n",
      "           2       0.78      0.56      0.66       241\n",
      "           3       0.92      0.24      0.38       235\n",
      "           4       0.94      0.96      0.95       261\n",
      "           5       0.97      0.58      0.72       242\n",
      "           6       0.68      0.99      0.81       246\n",
      "           7       0.69      0.84      0.76       255\n",
      "           8       0.76      0.90      0.82       203\n",
      "           9       0.72      0.87      0.79       227\n",
      "\n",
      "    accuracy                           0.77      2400\n",
      "   macro avg       0.79      0.77      0.75      2400\n",
      "weighted avg       0.79      0.77      0.75      2400\n",
      "\n",
      "0.7670833333333333\n",
      "Epoch 1, Loss G: -0.0585, Loss D: 0.1647\n",
      "epsilon is 0.21130224162476505, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0788, Loss D: 0.1207\n",
      "epsilon is 0.2711099360113021, alpha is 63.0\n",
      "Finished eps split 0.9\n",
      "(16000, 7)\n",
      "(16000, 1)\n",
      "[5 4 9 ... 2 4 9]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.80      0.60      0.68       413\n",
      "           1       0.76      0.97      0.85       407\n",
      "           2       0.77      0.67      0.72       403\n",
      "           3       0.97      0.48      0.64       380\n",
      "           4       0.98      0.97      0.97       380\n",
      "           5       0.97      0.80      0.88       407\n",
      "           6       0.70      0.98      0.82       383\n",
      "           7       0.73      0.89      0.80       386\n",
      "           8       0.87      0.87      0.87       415\n",
      "           9       0.67      0.79      0.72       426\n",
      "\n",
      "    accuracy                           0.80      4000\n",
      "   macro avg       0.82      0.80      0.80      4000\n",
      "weighted avg       0.82      0.80      0.79      4000\n",
      "\n",
      "0.8\n",
      "Epoch 1, Loss G: -0.0117, Loss D: 0.2001\n",
      "epsilon is 0.19402621812102808, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0262, Loss D: -0.0358\n",
      "epsilon is 0.22831876603986057, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0689, Loss D: -0.2592\n",
      "epsilon is 0.2626113139586931, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.0992, Loss D: -0.3015\n",
      "epsilon is 0.2969038618775256, alpha is 63.0\n",
      "Finished eps split 0.1\n",
      "(16000, 7)\n",
      "(16000, 1)\n",
      "[5 4 9 ... 2 4 9]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.74      0.61      0.67       413\n",
      "           1       0.87      0.91      0.89       407\n",
      "           2       0.85      0.62      0.72       403\n",
      "           3       0.88      0.35      0.50       380\n",
      "           4       0.97      0.92      0.95       380\n",
      "           5       0.96      0.91      0.93       407\n",
      "           6       0.67      0.97      0.79       383\n",
      "           7       0.65      0.91      0.75       386\n",
      "           8       0.89      0.92      0.90       415\n",
      "           9       0.70      0.85      0.77       426\n",
      "\n",
      "    accuracy                           0.80      4000\n",
      "   macro avg       0.82      0.80      0.79      4000\n",
      "weighted avg       0.82      0.80      0.79      4000\n",
      "\n",
      "0.798\n",
      "Epoch 1, Loss G: -0.0193, Loss D: 0.1798\n",
      "epsilon is 0.19402621812102808, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0337, Loss D: -0.0655\n",
      "epsilon is 0.22831876603986057, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0832, Loss D: -0.2899\n",
      "epsilon is 0.2626113139586931, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.1054, Loss D: -0.4321\n",
      "epsilon is 0.2969038618775256, alpha is 63.0\n",
      "Finished eps split 0.3\n",
      "(16000, 7)\n",
      "(16000, 1)\n",
      "[5 4 9 ... 2 4 9]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.77      0.67      0.72       413\n",
      "           1       0.76      0.97      0.85       407\n",
      "           2       0.79      0.62      0.69       403\n",
      "           3       0.93      0.36      0.51       380\n",
      "           4       0.87      0.82      0.84       380\n",
      "           5       0.96      0.70      0.81       407\n",
      "           6       0.67      0.97      0.79       383\n",
      "           7       0.63      0.82      0.71       386\n",
      "           8       0.77      0.91      0.83       415\n",
      "           9       0.70      0.75      0.73       426\n",
      "\n",
      "    accuracy                           0.76      4000\n",
      "   macro avg       0.78      0.76      0.75      4000\n",
      "weighted avg       0.78      0.76      0.75      4000\n",
      "\n",
      "0.7595\n",
      "Epoch 1, Loss G: -0.0165, Loss D: 0.1652\n",
      "epsilon is 0.19402621812102808, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0426, Loss D: -0.0666\n",
      "epsilon is 0.22831876603986057, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0877, Loss D: -0.3584\n",
      "epsilon is 0.2626113139586931, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.1101, Loss D: -0.4591\n",
      "epsilon is 0.2969038618775256, alpha is 63.0\n",
      "Finished eps split 0.5\n",
      "(16000, 7)\n",
      "(16000, 1)\n",
      "[5 4 9 ... 2 4 9]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.66      0.54      0.59       413\n",
      "           1       0.79      0.93      0.85       407\n",
      "           2       0.86      0.64      0.73       403\n",
      "           3       0.54      0.22      0.31       380\n",
      "           4       0.96      0.94      0.95       380\n",
      "           5       0.97      0.89      0.93       407\n",
      "           6       0.64      0.98      0.78       383\n",
      "           7       0.69      0.87      0.77       386\n",
      "           8       0.84      0.95      0.89       415\n",
      "           9       0.65      0.70      0.68       426\n",
      "\n",
      "    accuracy                           0.77      4000\n",
      "   macro avg       0.76      0.76      0.75      4000\n",
      "weighted avg       0.76      0.77      0.75      4000\n",
      "\n",
      "0.765\n",
      "Epoch 1, Loss G: -0.0203, Loss D: 0.1975\n",
      "epsilon is 0.19402621812102808, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0252, Loss D: -0.0909\n",
      "epsilon is 0.22831876603986057, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0829, Loss D: -0.2415\n",
      "epsilon is 0.2626113139586931, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.1073, Loss D: -0.3717\n",
      "epsilon is 0.2969038618775256, alpha is 63.0\n",
      "Finished eps split 0.7\n",
      "(16000, 7)\n",
      "(16000, 1)\n",
      "[5 4 9 ... 2 4 9]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.73      0.82      0.77       413\n",
      "           1       0.96      0.90      0.93       407\n",
      "           2       0.87      0.62      0.72       403\n",
      "           3       0.67      0.18      0.28       380\n",
      "           4       0.98      0.93      0.95       380\n",
      "           5       0.97      0.88      0.92       407\n",
      "           6       0.65      0.98      0.78       383\n",
      "           7       0.68      0.95      0.79       386\n",
      "           8       0.88      0.93      0.90       415\n",
      "           9       0.86      0.96      0.91       426\n",
      "\n",
      "    accuracy                           0.82      4000\n",
      "   macro avg       0.82      0.81      0.80      4000\n",
      "weighted avg       0.83      0.82      0.80      4000\n",
      "\n",
      "0.81725\n",
      "Epoch 1, Loss G: -0.0148, Loss D: 0.1836\n",
      "epsilon is 0.19402621812102808, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0253, Loss D: -0.0931\n",
      "epsilon is 0.22831876603986057, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0763, Loss D: -0.3750\n",
      "epsilon is 0.2626113139586931, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.1077, Loss D: -0.4711\n",
      "epsilon is 0.2969038618775256, alpha is 63.0\n",
      "Finished eps split 0.9\n",
      "(22400, 7)\n",
      "(22400, 1)\n",
      "[1 6 7 ... 0 2 1]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.64      0.76      0.70       582\n",
      "           1       0.75      0.97      0.84       576\n",
      "           2       0.75      0.62      0.68       567\n",
      "           3       0.93      0.16      0.27       543\n",
      "           4       0.97      0.95      0.96       540\n",
      "           5       0.96      0.83      0.89       557\n",
      "           6       0.68      0.95      0.79       541\n",
      "           7       0.66      0.74      0.70       601\n",
      "           8       0.87      0.92      0.90       565\n",
      "           9       0.65      0.70      0.67       528\n",
      "\n",
      "    accuracy                           0.76      5600\n",
      "   macro avg       0.79      0.76      0.74      5600\n",
      "weighted avg       0.79      0.76      0.74      5600\n",
      "\n",
      "0.7616071428571428\n",
      "Epoch 1, Loss G: -0.0226, Loss D: 0.0949\n",
      "epsilon is 0.18919643774096742, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0508, Loss D: -0.2693\n",
      "epsilon is 0.21323223372133257, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0938, Loss D: -0.5288\n",
      "epsilon is 0.23726802970169772, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.2196, Loss D: -0.1381\n",
      "epsilon is 0.2613038256820629, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.2589, Loss D: -0.2928\n",
      "epsilon is 0.285339621662428, alpha is 63.0\n",
      "Finished eps split 0.1\n",
      "(22400, 7)\n",
      "(22400, 1)\n",
      "[1 6 7 ... 0 2 1]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.65      0.69      0.67       582\n",
      "           1       0.79      0.97      0.87       576\n",
      "           2       0.69      0.66      0.67       567\n",
      "           3       0.94      0.17      0.30       543\n",
      "           4       0.98      0.87      0.92       540\n",
      "           5       0.95      0.71      0.81       557\n",
      "           6       0.66      0.96      0.78       541\n",
      "           7       0.64      0.71      0.67       601\n",
      "           8       0.75      0.84      0.79       565\n",
      "           9       0.61      0.75      0.67       528\n",
      "\n",
      "    accuracy                           0.73      5600\n",
      "   macro avg       0.77      0.73      0.72      5600\n",
      "weighted avg       0.76      0.73      0.72      5600\n",
      "\n",
      "0.7335714285714285\n",
      "Epoch 1, Loss G: -0.0250, Loss D: 0.0960\n",
      "epsilon is 0.18919643774096742, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0526, Loss D: -0.2270\n",
      "epsilon is 0.21323223372133257, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.1196, Loss D: -0.4449\n",
      "epsilon is 0.23726802970169772, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.2046, Loss D: -0.5482\n",
      "epsilon is 0.2613038256820629, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.2981, Loss D: -0.3661\n",
      "epsilon is 0.285339621662428, alpha is 63.0\n",
      "Finished eps split 0.3\n",
      "(22400, 7)\n",
      "(22400, 1)\n",
      "[1 6 7 ... 0 2 1]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.68      0.88      0.77       582\n",
      "           1       0.72      0.96      0.82       576\n",
      "           2       0.78      0.57      0.66       567\n",
      "           3       0.93      0.16      0.28       543\n",
      "           4       0.98      0.95      0.96       540\n",
      "           5       0.96      0.82      0.88       557\n",
      "           6       0.67      0.96      0.79       541\n",
      "           7       0.66      0.84      0.74       601\n",
      "           8       0.85      0.90      0.87       565\n",
      "           9       0.78      0.65      0.71       528\n",
      "\n",
      "    accuracy                           0.77      5600\n",
      "   macro avg       0.80      0.77      0.75      5600\n",
      "weighted avg       0.80      0.77      0.75      5600\n",
      "\n",
      "0.7708928571428572\n",
      "Epoch 1, Loss G: -0.0098, Loss D: 0.0891\n",
      "epsilon is 0.18919643774096742, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0510, Loss D: -0.2250\n",
      "epsilon is 0.21323223372133257, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.1036, Loss D: -0.3491\n",
      "epsilon is 0.23726802970169772, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.1877, Loss D: -0.2801\n",
      "epsilon is 0.2613038256820629, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.2685, Loss D: -0.2902\n",
      "epsilon is 0.285339621662428, alpha is 63.0\n",
      "Finished eps split 0.5\n",
      "(22400, 7)\n",
      "(22400, 1)\n",
      "[1 6 7 ... 0 2 1]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.70      0.71      0.70       582\n",
      "           1       0.76      0.97      0.85       576\n",
      "           2       0.73      0.55      0.63       567\n",
      "           3       0.97      0.31      0.47       543\n",
      "           4       0.97      0.92      0.95       540\n",
      "           5       0.96      0.71      0.81       557\n",
      "           6       0.69      0.95      0.80       541\n",
      "           7       0.62      0.75      0.68       601\n",
      "           8       0.77      0.90      0.83       565\n",
      "           9       0.62      0.73      0.67       528\n",
      "\n",
      "    accuracy                           0.75      5600\n",
      "   macro avg       0.78      0.75      0.74      5600\n",
      "weighted avg       0.78      0.75      0.74      5600\n",
      "\n",
      "0.7496428571428572\n",
      "Epoch 1, Loss G: -0.0324, Loss D: 0.1006\n",
      "epsilon is 0.18919643774096742, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0652, Loss D: -0.2675\n",
      "epsilon is 0.21323223372133257, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0857, Loss D: -0.6628\n",
      "epsilon is 0.23726802970169772, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.2361, Loss D: -0.2717\n",
      "epsilon is 0.2613038256820629, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.2725, Loss D: -0.5948\n",
      "epsilon is 0.285339621662428, alpha is 63.0\n",
      "Finished eps split 0.7\n",
      "(22400, 7)\n",
      "(22400, 1)\n",
      "[1 6 7 ... 0 2 1]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.69      0.74      0.71       582\n",
      "           1       0.74      0.96      0.84       576\n",
      "           2       0.76      0.53      0.62       567\n",
      "           3       0.89      0.25      0.40       543\n",
      "           4       0.97      0.86      0.92       540\n",
      "           5       0.96      0.84      0.90       557\n",
      "           6       0.68      0.96      0.80       541\n",
      "           7       0.60      0.84      0.70       601\n",
      "           8       0.89      0.90      0.89       565\n",
      "           9       0.68      0.72      0.70       528\n",
      "\n",
      "    accuracy                           0.76      5600\n",
      "   macro avg       0.79      0.76      0.75      5600\n",
      "weighted avg       0.79      0.76      0.75      5600\n",
      "\n",
      "0.7608928571428571\n",
      "Epoch 1, Loss G: -0.0259, Loss D: 0.1151\n",
      "epsilon is 0.18919643774096742, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.0511, Loss D: -0.2015\n",
      "epsilon is 0.21323223372133257, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.0901, Loss D: -0.3187\n",
      "epsilon is 0.23726802970169772, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.2028, Loss D: -0.1931\n",
      "epsilon is 0.2613038256820629, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.2295, Loss D: -0.2475\n",
      "epsilon is 0.285339621662428, alpha is 63.0\n",
      "Finished eps split 0.9\n",
      "(28800, 7)\n",
      "(28800, 1)\n",
      "[8 0 2 ... 7 9 3]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.79      0.67      0.73       747\n",
      "           1       0.78      0.97      0.86       730\n",
      "           2       0.64      0.58      0.61       692\n",
      "           3       0.98      0.34      0.50       698\n",
      "           4       0.97      0.86      0.91       745\n",
      "           5       0.92      0.61      0.73       694\n",
      "           6       0.66      0.98      0.79       732\n",
      "           7       0.63      0.86      0.73       702\n",
      "           8       0.67      0.70      0.69       714\n",
      "           9       0.66      0.79      0.72       746\n",
      "\n",
      "    accuracy                           0.74      7200\n",
      "   macro avg       0.77      0.74      0.73      7200\n",
      "weighted avg       0.77      0.74      0.73      7200\n",
      "\n",
      "0.7381944444444445\n",
      "Epoch 1, Loss G: -0.1083, Loss D: 0.0282\n",
      "epsilon is 0.18771568419633322, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.1893, Loss D: -0.1392\n",
      "epsilon is 0.20621726811140442, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.2633, Loss D: -0.2916\n",
      "epsilon is 0.22471885202647562, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.3686, Loss D: -0.0260\n",
      "epsilon is 0.2432204359415468, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.4697, Loss D: -0.1051\n",
      "epsilon is 0.26172201985661797, alpha is 63.0\n",
      "Epoch 6, Loss G: -0.5882, Loss D: 0.0728\n",
      "epsilon is 0.2802236037716892, alpha is 63.0\n",
      "Epoch 7, Loss G: -0.7430, Loss D: -0.2550\n",
      "epsilon is 0.2987251876867604, alpha is 63.0\n",
      "Finished eps split 0.1\n",
      "(28800, 7)\n",
      "(28800, 1)\n",
      "[8 0 2 ... 7 9 3]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.70      0.66      0.68       747\n",
      "           1       0.82      0.97      0.89       730\n",
      "           2       0.75      0.60      0.67       692\n",
      "           3       0.86      0.43      0.57       698\n",
      "           4       0.98      0.95      0.96       745\n",
      "           5       0.96      0.66      0.78       694\n",
      "           6       0.75      0.89      0.82       732\n",
      "           7       0.69      0.87      0.77       702\n",
      "           8       0.73      0.85      0.78       714\n",
      "           9       0.67      0.85      0.75       746\n",
      "\n",
      "    accuracy                           0.78      7200\n",
      "   macro avg       0.79      0.77      0.77      7200\n",
      "weighted avg       0.79      0.78      0.77      7200\n",
      "\n",
      "0.775\n",
      "Epoch 1, Loss G: -0.1141, Loss D: 0.0078\n",
      "epsilon is 0.18771568419633322, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.1972, Loss D: -0.1513\n",
      "epsilon is 0.20621726811140442, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.2887, Loss D: -0.6775\n",
      "epsilon is 0.22471885202647562, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.4683, Loss D: -0.5860\n",
      "epsilon is 0.2432204359415468, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.5911, Loss D: -0.5891\n",
      "epsilon is 0.26172201985661797, alpha is 63.0\n",
      "Epoch 6, Loss G: -0.8430, Loss D: -0.3259\n",
      "epsilon is 0.2802236037716892, alpha is 63.0\n",
      "Epoch 7, Loss G: -1.0582, Loss D: -1.9126\n",
      "epsilon is 0.2987251876867604, alpha is 63.0\n",
      "Finished eps split 0.3\n",
      "(28800, 7)\n",
      "(28800, 1)\n",
      "[8 0 2 ... 7 9 3]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.78      0.74      0.76       747\n",
      "           1       0.66      0.97      0.78       730\n",
      "           2       0.71      0.67      0.69       692\n",
      "           3       0.98      0.30      0.46       698\n",
      "           4       0.97      0.94      0.95       745\n",
      "           5       0.97      0.52      0.68       694\n",
      "           6       0.66      0.98      0.78       732\n",
      "           7       0.71      0.82      0.76       702\n",
      "           8       0.69      0.84      0.76       714\n",
      "           9       0.67      0.62      0.64       746\n",
      "\n",
      "    accuracy                           0.74      7200\n",
      "   macro avg       0.78      0.74      0.73      7200\n",
      "weighted avg       0.78      0.74      0.73      7200\n",
      "\n",
      "0.7420833333333333\n",
      "Epoch 1, Loss G: -0.1103, Loss D: 0.0459\n",
      "epsilon is 0.18771568419633322, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.1810, Loss D: -0.1545\n",
      "epsilon is 0.20621726811140442, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.2720, Loss D: -0.1677\n",
      "epsilon is 0.22471885202647562, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.3536, Loss D: -0.0401\n",
      "epsilon is 0.2432204359415468, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.4753, Loss D: -0.0887\n",
      "epsilon is 0.26172201985661797, alpha is 63.0\n",
      "Epoch 6, Loss G: -0.5741, Loss D: 0.0954\n",
      "epsilon is 0.2802236037716892, alpha is 63.0\n",
      "Epoch 7, Loss G: -0.7300, Loss D: -0.0859\n",
      "epsilon is 0.2987251876867604, alpha is 63.0\n",
      "Finished eps split 0.5\n",
      "(28800, 7)\n",
      "(28800, 1)\n",
      "[8 0 2 ... 7 9 3]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.64      0.65      0.65       747\n",
      "           1       0.82      0.97      0.89       730\n",
      "           2       0.68      0.56      0.61       692\n",
      "           3       0.93      0.11      0.19       698\n",
      "           4       0.98      0.91      0.95       745\n",
      "           5       0.97      0.77      0.86       694\n",
      "           6       0.65      0.98      0.78       732\n",
      "           7       0.65      0.89      0.75       702\n",
      "           8       0.81      0.80      0.81       714\n",
      "           9       0.68      0.86      0.76       746\n",
      "\n",
      "    accuracy                           0.75      7200\n",
      "   macro avg       0.78      0.75      0.72      7200\n",
      "weighted avg       0.78      0.75      0.73      7200\n",
      "\n",
      "0.7525\n",
      "Epoch 1, Loss G: -0.1238, Loss D: -0.0178\n",
      "epsilon is 0.18771568419633322, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.1966, Loss D: -0.1018\n",
      "epsilon is 0.20621726811140442, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.2863, Loss D: -0.2637\n",
      "epsilon is 0.22471885202647562, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.3894, Loss D: -0.1967\n",
      "epsilon is 0.2432204359415468, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.5331, Loss D: -0.3187\n",
      "epsilon is 0.26172201985661797, alpha is 63.0\n",
      "Epoch 6, Loss G: -0.6938, Loss D: -0.0346\n",
      "epsilon is 0.2802236037716892, alpha is 63.0\n",
      "Epoch 7, Loss G: -0.7829, Loss D: -0.9422\n",
      "epsilon is 0.2987251876867604, alpha is 63.0\n",
      "Finished eps split 0.7\n",
      "(28800, 7)\n",
      "(28800, 1)\n",
      "[8 0 2 ... 7 9 3]\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.70      0.77      0.73       747\n",
      "           1       0.71      0.97      0.82       730\n",
      "           2       0.72      0.60      0.66       692\n",
      "           3       0.99      0.17      0.30       698\n",
      "           4       0.98      0.94      0.96       745\n",
      "           5       0.97      0.71      0.82       694\n",
      "           6       0.65      0.98      0.78       732\n",
      "           7       0.68      0.87      0.76       702\n",
      "           8       0.79      0.84      0.81       714\n",
      "           9       0.70      0.66      0.68       746\n",
      "\n",
      "    accuracy                           0.75      7200\n",
      "   macro avg       0.79      0.75      0.73      7200\n",
      "weighted avg       0.79      0.75      0.73      7200\n",
      "\n",
      "0.75375\n",
      "Epoch 1, Loss G: -0.0997, Loss D: 0.0397\n",
      "epsilon is 0.18771568419633322, alpha is 63.0\n",
      "Epoch 2, Loss G: -0.1754, Loss D: -0.1050\n",
      "epsilon is 0.20621726811140442, alpha is 63.0\n",
      "Epoch 3, Loss G: -0.2560, Loss D: -0.3200\n",
      "epsilon is 0.22471885202647562, alpha is 63.0\n",
      "Epoch 4, Loss G: -0.3670, Loss D: -0.0577\n",
      "epsilon is 0.2432204359415468, alpha is 63.0\n",
      "Epoch 5, Loss G: -0.4354, Loss D: -0.1295\n",
      "epsilon is 0.26172201985661797, alpha is 63.0\n",
      "Epoch 6, Loss G: -0.5961, Loss D: -0.0887\n",
      "epsilon is 0.2802236037716892, alpha is 63.0\n",
      "Epoch 7, Loss G: -0.7029, Loss D: -0.2554\n",
      "epsilon is 0.2987251876867604, alpha is 63.0\n",
      "Finished eps split 0.9\n",
      "[[-0.18418271213507909, -0.12176331698327159, -0.21576642359557474, -0.31643248601591456, -0.13685016372116376], [0.03259373080657224, -0.1207268837910419, -0.08876767779508798, -0.08233032296830767, -0.0975970186849715], [-0.07275372504458533, -0.15912902371311766, -0.1320986769863428, -0.14816777799574732, -0.128138730783387], [0.0535487067153847, 0.01657969841427709, -0.03852143544400821, -0.06909018784933496, 0.012063437049894654], [-0.03770070174013218, -0.09029367675690336, -0.10629876791337556, -0.08370581025912671, -0.11848010787112861]]\n",
      "CPU times: user 3h 19min 47s, sys: 2h 3min 5s, total: 5h 22min 52s\n",
      "Wall time: 1h 44min 31s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "seed = 42\n",
    "\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import f1_score\n",
    "\n",
    "from synthesizers.mwem import MWEMSynthesizer # current mwem.py taken from WN Github\n",
    "from synthesizers.quail import QUAILSynthesizer\n",
    "from diffprivlib.models import GaussianNB as DPNB\n",
    "\n",
    "from synthesizers.pytorch.pytorch_synthesizer import PytorchDPSynthesizer\n",
    "from synthesizers.preprocessors.preprocessing import GeneralTransformer\n",
    "from synthesizers.pytorch.nn.dpctgan import DPCTGAN\n",
    "\n",
    "data_sizes = [5000,15000,25000,35000,45000]\n",
    "splits = [0.1,0.3,0.5,0.7,0.9]\n",
    "confidence_interval = 1\n",
    "matrix = [[None for i in range(len(splits))] for i in range(len(data_sizes))]\n",
    "\n",
    "def feature_names (n_items, prefix = 'feature'):\n",
    "    names = []\n",
    "    for i in range(n_items):\n",
    "        names.append(prefix + '_' + str(i))\n",
    "    return names\n",
    "\n",
    "feature_names = feature_names(7, 'inf')\n",
    "\n",
    "for i, d_s in enumerate(data_sizes):\n",
    "    df = generate_classification_task(d_s)\n",
    "    # Ground truth accuracy\n",
    "    X_train, X_test, y_train, y_test = train_test_split(df.drop(['class'],axis=1), df['class'], test_size=0.2, stratify = df['class'], random_state = seed) \n",
    "    clf = DPNB()\n",
    "    clf.fit(X_train, y_train)\n",
    "    y_pred = clf.predict(X_test)\n",
    "    f1 = f1_score(y_test, y_pred, average='macro')\n",
    "    # print(classification_report(y_test, y_pred))\n",
    "    \n",
    "    # Quail comps\n",
    "    Xy_train = pd.concat([X_train, y_train], axis = 1)\n",
    "    for j, eps_split in enumerate(splits):\n",
    "        runs = []\n",
    "        for k in range(confidence_interval):\n",
    "#             synth = QUAILSynthesizer(3.0, MWEMSynthesizer, {\n",
    "#                 'Q_count':600,\n",
    "#                 'iterations':40,\n",
    "#                 'mult_weights_iterations':30,\n",
    "#                 'split_factor':2,\n",
    "#                 'max_bin_count':500\n",
    "#             }, DPNB, {}, 'class', eps_split=eps_split)\n",
    "\n",
    "#             synth.fit(Xy_train)\n",
    "\n",
    "            synth = QUAILSynthesizer(3.0, PytorchDPSynthesizer, {\n",
    "                'preprocessor': None,\n",
    "                'gan': DPCTGAN(loss='wasserstein', batch_size=500, pack=2, sigma=5.0)}, DPNB, {}, 'class')\n",
    "\n",
    "            synth.fit(Xy_train, categorical_columns=['class'], ordinal_columns=feature_names)\n",
    "\n",
    "            sample_size = Xy_train.shape[0]\n",
    "            synthetic = synth.sample(int(sample_size))\n",
    "            synth_df = pd.DataFrame(synthetic, columns=Xy_train.columns)\n",
    "\n",
    "            X_train_dp = synth_df.drop('class', axis = 1)\n",
    "            y_train_dp = synth_df['class']\n",
    "\n",
    "            clf = RandomForestClassifier(random_state=seed)\n",
    "            clf.fit(X_train_dp, y_train_dp)\n",
    "\n",
    "            y_pred = clf.predict(X_test)\n",
    "            f1_synth = f1_score(y_test, y_pred, average='macro')\n",
    "            runs.append(f1_synth)\n",
    "        # store the delta\n",
    "        matrix[i][j] = f1 - np.mean(np.array(runs))\n",
    "        print(\"Finished eps split \" + str(eps_split))\n",
    "        \n",
    "print(matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "import mlflow\n",
    "from mlflow.tracking.artifact_utils import _download_artifact_from_uri\n",
    "from azureml.core import Workspace, Experiment\n",
    "\n",
    "quail_exp = Experiment(Workspace.from_config(), \"quail_evals_v2_higheps_4\")\n",
    "\n",
    "for i,r in enumerate(quail_exp.get_runs()):\n",
    "    if r.get_status() in ['Completed']:\n",
    "        r.download_file(\"matrix.json\", 'matrices_10/matrix_4_' + str(i) + '.json')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "import glob\n",
    "import json\n",
    "\n",
    "ds = []\n",
    "for file in glob.glob(\"matrices_10/*.json\"):\n",
    "    with open(file, \"r\") as read_json:\n",
    "        mat = json.load(read_json)\n",
    "        for k,v in mat.items():\n",
    "            ds.append(v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0.02417143  0.01913571  0.02752857  0.02019286  0.01940714]\n",
      " [ 0.02235     0.01933214  0.02820357  0.02058571  0.02621429]\n",
      " [ 0.00043571 -0.00272619 -0.00037381 -0.00510952  0.00584286]\n",
      " [ 0.004575    0.00418036  0.01465893  0.00750357  0.00665357]\n",
      " [ 0.01625571  0.00667143  0.01227286  0.00631143  0.00490857]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "combined = {}\n",
    "for res in ds:\n",
    "    for k,v in res.items():\n",
    "        if k not in combined:\n",
    "            combined[k] = np.array(v)\n",
    "        else:\n",
    "            combined[k] = combined[k] + np.array(v)\n",
    "\n",
    "data_sizes = [10000,20000,30000,40000,50000]\n",
    "splits = [0.1,0.3,0.5,0.7,0.9]\n",
    "\n",
    "first = 1\n",
    "for k,v in combined.items():\n",
    "    if first == 5:\n",
    "        final_mat = v / float(len(ds))\n",
    "        print(final_mat)\n",
    "        m_df = pd.DataFrame(final_mat, columns=splits, index=data_sizes)\n",
    "        heatmap = sns.heatmap(m_df, annot=True, vmax=0.05, vmin=-0.02, cmap='coolwarm', cbar_kws={'label': 'delta\\n(f1 score, vanilla - quail)'})\n",
    "        heatmap.set_title('Varying QUAIL ϵ-split across datasizes\\n with categorical data: ' + k, fontdict={'fontsize':18}, pad=16);\n",
    "        plt.xlabel('Epsilon Splits')\n",
    "        plt.ylabel('Data Sizes')\n",
    "    first += 1"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
