{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "NeurIPS_2021_Correlation_input_norm_excessive_risk_individual_level.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BphQprZKdl8v",
        "outputId": "a8a8d110-75a5-4b9b-e282-e2c9313092de"
      },
      "source": [
        "from google.colab import drive\n",
        "drive.mount('/content/drive')\n",
        "!git clone https://github.com/timgianitsos/pytorch-dp /content/pytorch-dp/\n",
        "%cd /content/pytorch-dp\n",
        "import sys, os\n",
        "sys.path.append(\"/content/drive/MyDrive/research/fair_dpsgd/final_codes/\")\n",
        "!pip install pyhessian\n",
        "from pyhessian import hessian \n",
        "from utils import *\n",
        "from network import * \n",
        "from classifier import *\n",
        "from matplotlib import pyplot as plt\n",
        "from sklearn.linear_model import LogisticRegression\n",
        "from sklearn.metrics import accuracy_score\n",
        "from torch import autograd\n",
        "from scipy.linalg import eig\n",
        "from numpy import linalg as LA\n",
        "import copy, warnings\n",
        "warnings.filterwarnings(\"ignore\", category=FutureWarning)\n",
        "from sklearn.preprocessing import StandardScaler"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "Drive already mounted at /content/drive; to attempt to forcibly remount, call drive.mount(\"/content/drive\", force_remount=True).\n",
            "fatal: destination path '/content/pytorch-dp' already exists and is not an empty directory.\n",
            "/content/pytorch-dp\n",
            "Requirement already satisfied: pyhessian in /usr/local/lib/python3.7/dist-packages (0.1)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from pyhessian) (1.19.5)\n",
            "Requirement already satisfied: torch in /usr/local/lib/python3.7/dist-packages (from pyhessian) (1.8.1+cu101)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch->pyhessian) (3.7.4.3)\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "jKkqV9KUd0VM"
      },
      "source": [
        "%cd /content/drive/My Drive/research/fair_dpsgd/data\n",
        "DATA_PATH = '/content/drive/My Drive/research/fair_dpsgd/data/'\n",
        "C = 0.1\n",
        "sigma = 1.0\n",
        "model_dict = {}\n",
        "import copy\n",
        "for data in  ['bank', 'abalone', 'stroke', 'churn', 'credit_card']:\n",
        "    model_dict[data] = {}\n",
        "    if data =='bank':\n",
        "        pd00 = pd.read_csv(DATA_PATH + 'formated_bank.csv')\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'age', 'is_train', 'y'] ]\n",
        "\n",
        "    elif data =='income':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_income.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'age', 'race', 'is_train', 'y'] ]\n",
        "    elif data =='abalone':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_abalone.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'is_train', 'y']]\n",
        "    elif data =='parkinsons':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_parkinsons.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z','is_train', 'y']]\n",
        "    elif data == 'wine':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_wine.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'is_train', 'y']]\n",
        "    elif data =='stroke':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_stroke.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'is_train', 'y']]\n",
        "    elif data == 'credit_card':\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_credit_card.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'is_train', 'y']]\n",
        "    else:\n",
        "        pd00 = pd.read_csv(DATA_PATH + \"formated_churn.csv\")\n",
        "        features = [x for x in pd00.columns if x not in ['label', 'z', 'is_train', 'y']]\n",
        "    \n",
        "    x_train = pd00[pd00['is_train'] == 1][features].values\n",
        "    y_train = pd00[pd00['is_train'] == 1]['y'].values\n",
        "    a_train = pd00[pd00['is_train'] == 1]['z'].values\n",
        "    ######\n",
        "    x_test = pd00[pd00['is_train'] == 0][features].values\n",
        "    y_test = pd00[pd00['is_train'] == 0]['y'].values\n",
        "    a_test = pd00[pd00['is_train'] == 0]['z'].values\n",
        "\n",
        "    train_tensor = TensorDataset(torch.Tensor(x_train), torch.Tensor(np.c_[y_train, a_train]))\n",
        "    train_loader = DataLoader(dataset=train_tensor, batch_size=32, shuffle=True)\n",
        "    x_test = torch.Tensor(x_test)\n",
        "    a_test = torch.Tensor(a_test)\n",
        "    y_test = torch.Tensor(y_test).reshape(-1, 1)\n",
        "    model_dict[data]['input_norm'] = np.linalg.norm(x_test, axis =1)\n",
        "    \n",
        "    # first train a non-private model by setting DP = False\n",
        "    options = {'DP': False, 'model': 'MLP', 'epochs': 200, 'add_noise': False, 'num_z': 2, 'C': None, 'sigma': None, 'write_logs':True,\n",
        "            'activation': 'tanh', 'n_layers': 2,\n",
        "            'bs': 32, 'num_feats': len(features), 'lr': 1e-4,\n",
        "            'cuda': False, 'init_model': None, 'width': int(len(features) / 2),  'random_state_1':0, 'random_state_2':0}\n",
        "\n",
        "    clf_model = CLF(train_loader, x_test, y_test, a_test)\n",
        "    clf_model.fit(options)\n",
        "    model_dict[data]['non_priv_model'] = copy.deepcopy(clf_model)\n",
        "    model_dict[data]['priv_model'] = []\n",
        "\n",
        "    # now run DP model, to compute excessive risk we run 10 random seeds to compute the expected private loss. Then based on expected private loss we subtract with the non-private loss\n",
        "    options['DP'] = True\n",
        "    options['C'] = C\n",
        "    options['sigma'] = sigma\n",
        "\n",
        "    for seed in range(10):\n",
        "      options['random_state_2'] = seed # random state for private noise\n",
        "      priv_model =  CLF(train_loader, x_test, y_test, a_test)\n",
        "      priv_model.fit(options)\n",
        "      model_dict[data]['priv_model'].append(priv_model)\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 370
        },
        "id": "_WwlKpbpj_Nf",
        "outputId": "99dcc3e9-2bfa-4298-e7a1-fe4c363e836a"
      },
      "source": [
        "\n",
        "%cd /content/drive/My Drive/research/fair_dpsgd/privacy/tensorflow_privacy/privacy/analysis/\n",
        "SAVE_PATH = '/content/drive/My Drive/research/fair_dpsgd/figures/misc/'\n",
        "import sys \n",
        "from rdp_accountant import *\n",
        "orders = range(2,64)\n",
        "\n",
        "data_list = ['bank', 'abalone', 'stroke']\n",
        "name_list = ['Bank', 'Abalone', 'Stroke']\n",
        "N = len(data_list)\n",
        "fig, axes = plt.subplots(nrows=1, ncols=N, sharex = True, sharey=True, figsize=(N*4, 4))\n",
        "for i in range(N):\n",
        "  ax = axes[i]\n",
        "  data = data_list[i]\n",
        "  pd00 = pd.read_csv(DATA_PATH + \"formated_{}.csv\".format(data))\n",
        "  n_train = len(pd00[pd00['is_train']==1])\n",
        "  sampling_rate = 32/n_train\n",
        "  ax.tick_params(axis='both', which='major', labelsize=25)\n",
        "  ax.set_title(name_list[i], fontsize = 30)\n",
        "  eps_list = []\n",
        "  corr_list = []\n",
        "  org_loss = model_dict[data]['non_priv_model'].logs['ind_loss'][-1]\n",
        "  ax.set_xlabel(r'$\\epsilon$', fontsize = 30)\n",
        "  if i ==0:\n",
        "    ax.set_ylabel('Correlation', fontsize= 20)\n",
        "  for epoch in range(200):\n",
        "        rdp = compute_rdp(sampling_rate, sigma, epoch/sampling_rate, orders)\n",
        "        eps, _, opt_order = get_privacy_spent(orders, rdp, target_eps=None, target_delta= 1e-4)\n",
        "        if eps<5.0:\n",
        "          eps_list.append(eps)\n",
        "          exp_priv_loss = np.mean(  [model_dict[data]['priv_model'][seed].logs['ind_loss'][epoch] for seed in range(10)], axis =0)\n",
        "          excessive_risk = exp_priv_loss- org_loss\n",
        "          corr_ = spearmanr(excessive_risk, model_dict[data]['input_norm'])[0]\n",
        "          corr_list.append(corr_)\n",
        "  \n",
        "  ax.plot(eps_list, corr_list, 'o', markersize = 10)\n",
        "  ax.grid()\n",
        "\n",
        "plt.subplots_adjust(bottom=0.1, right=1.2, top=0.9)\n",
        "plt.savefig(SAVE_PATH + \"corr_input_norm_vs_excessive_risk.pdf\", dpi=1200, bbox_inches = \"tight\")\n",
        "plt.show()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "/content/drive/My Drive/research/fair_dpsgd/privacy/tensorflow_privacy/privacy/analysis\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 864x288 with 3 Axes>"
            ]
          },
          "metadata": {
            "tags": [],
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "MAWihngVGUJF"
      },
      "source": [
        ""
      ],
      "execution_count": null,
      "outputs": []
    }
  ]
}