{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6af3f4f0-48a7-4ce8-874b-12d3097a0f94",
   "metadata": {
    "pycharm": {
     "is_executing": true
    }
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import math \n",
    "import scipy\n",
    "import sys  \n",
    "\n",
    "\n",
    "def inference_via_confidence(confidence_mtx1, confidence_mtx2, label_vec1, label_vec2):\n",
    "    \n",
    "    #----------------First step: obtain confidence lists for both training dataset and test dataset--------------\n",
    "    confidence1 = []\n",
    "    confidence2 = []\n",
    "    acc1 = 0\n",
    "    acc2 = 0\n",
    "    for num in range(confidence_mtx1.shape[0]):\n",
    "        confidence1.append(confidence_mtx1[num,label_vec1[num]])\n",
    "        if np.argmax(confidence_mtx1[num,:]) == label_vec1[num]:\n",
    "            acc1 += 1\n",
    "            \n",
    "    for num in range(confidence_mtx2.shape[0]):\n",
    "        confidence2.append(confidence_mtx2[num,label_vec2[num]])\n",
    "        if np.argmax(confidence_mtx2[num,:]) == label_vec2[num]:\n",
    "            acc2 += 1\n",
    "    confidence1 = np.array(confidence1)\n",
    "    confidence2 = np.array(confidence2)\n",
    "    \n",
    "    print('model accuracy for training and test-', (acc1/confidence_mtx1.shape[0], acc2/confidence_mtx2.shape[0]) )\n",
    "    \n",
    "    \n",
    "    #sort_confidence = np.sort(confidence1)\n",
    "    sort_confidence = np.sort(np.concatenate((confidence1, confidence2)))\n",
    "    max_accuracy = 0.5\n",
    "    best_precision = 0.5\n",
    "    best_recall = 0.5\n",
    "    for num in range(len(sort_confidence)):\n",
    "        delta = sort_confidence[num]\n",
    "        ratio1 = np.sum(confidence1>=delta)/confidence_mtx1.shape[0]\n",
    "        ratio2 = np.sum(confidence2>=delta)/confidence_mtx2.shape[0]\n",
    "        accuracy_now = 0.5*(ratio1+1-ratio2)\n",
    "        if accuracy_now > max_accuracy:\n",
    "            max_accuracy = accuracy_now\n",
    "            best_precision = ratio1/(ratio1+ratio2)\n",
    "            best_recall = ratio1\n",
    "    print('membership inference accuracy is:', max_accuracy)\n",
    "    return max_accuracy\n",
    "\n",
    "\n",
    "def inference_attack_from_npz_file(file_path, verification_file=False):\n",
    "    if verification_file == False:\n",
    "        output_data = np.load( file_path )\n",
    "        output_train_adversarial = output_data['output_train_adversarial']\n",
    "        output_test_adversarial = output_data['output_test_adversarial']\n",
    "        train_label = output_data['train_label']\n",
    "        test_label = output_data['test_label']\n",
    "        inference_via_confidence(output_train_adversarial, output_test_adversarial, train_label, test_label)\n",
    "        print()\n",
    "\n",
    "file_path = 'counterfactual_adversarial_example.npz'\n",
    "inference_attack_from_npz_file(file_path, verification_file=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
