{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ae102ebc",
   "metadata": {},
   "source": [
    "This notebook runs the integrated gradient calculations for the model using angle encoding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b4c78c00",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle as pkl\n",
    "\n",
    "from os import listdir, mkdir\n",
    "from os.path import isdir\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from qiskit import QuantumCircuit\n",
    "from qiskit.quantum_info import Statevector, DensityMatrix, state_fidelity, partial_trace, Pauli, Operator\n",
    "\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.preprocessing import MinMaxScaler, StandardScaler\n",
    "from sklearn.metrics import log_loss, accuracy_score\n",
    "\n",
    "\n",
    "from sklearn.datasets import load_digits\n",
    "\n",
    "from data_utils import return_scaled_data, return_unscaled_data, generate_bars_and_stripes\n",
    "from model_utils import *\n",
    "from integrated_grads_utils import  integrated_grad,  native_integrated_grad"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "19ad0996",
   "metadata": {},
   "source": [
    "## Bars and Stripes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "91b28d33",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"bars\"\n",
    "dir_name = f\"trained_qml_circuits/angle/{dataset}\"\n",
    "encoding_scaler = \"angle\"\n",
    "activation_func = \"tanh\"\n",
    "num_qubits = 8\n",
    "num_layers = 8\n",
    "\n",
    "imageHeight, imageWidth = 4, 4\n",
    "\n",
    "numSamplesPerExp = 8\n",
    "\n",
    "baselineImage = np.zeros(imageHeight*imageWidth)\n",
    "baselineImage[0] = 1.0\n",
    "baselineImage = baselineImage / np.linalg.norm(baselineImage)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "427fe549",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['batchedbars_angletanh_qml_class01_results']"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "experimentFolders = [c for c in listdir(dir_name) if (encoding_scaler in c and activation_func in c)]\n",
    "experimentFolders"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c0521ee1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# samples chosen to remove redundant data points\n",
    "sampleIndices = [0, 1, 3, 6, 7, 9, 10, 11]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "aa1605b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "batchedbars_angletanh_qml_class01_results     NISTresult_8_layer_8_trial5.npy\n",
      "128\n",
      "Train accuracy:  0.9583333333333334\n",
      "Test accuracy:  0.95\n",
      "Sample : 0\n",
      "Sample : 1\n",
      "Sample : 2\n",
      "Sample : 3\n",
      "Sample : 4\n",
      "Sample : 5\n",
      "Sample : 6\n",
      "Sample : 7\n"
     ]
    },
    {
     "data": {
      "image/png": "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i1P8b4jTb+np6YiKitJUdr3nZ3Z9Ztd7fmZn9u2dmP3yF+G2xHQni8UirVq1Sp6+9Nhjj8nTnZqnDz344IPSs88+azfdydPTU1q6dKl07NgxaeHChdc03WnWrFnyaOEdO3bYTV+qqalpaXP5a1i0aJG0ZcsW6dSpU1Jqaqp03333SV5eXvJ0LS1l13t+Ztdndr3nZ3Zmv9DJ2Zu5dTEiLFu2TJ7vLOZgi+lP+/bta/m7W265RXrooYfs2n/22WdSv3795PYDBgyQvv7663Y/t6jVHD3ElCZnr2Hu3LktrzciIkKer52Wlqa57HrPz+z6zK73/MzO7FAhu2D41wshIiIiUoXbjhkhIiIifWAxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqmIxQkRERKpiMUJERESqYjFCREREqvKEBthsNuTm5sLf3x8GgwFaJ0kSKisrER0dDQ8PD11lV5Jfz9m7Yn49Zxe43+uz7/WcXVF+SQNycnIk8VK72kPk0mt2V/LrOXtXzq/n7K7k13P2rpxfz9nhQn5NnBkRVaJwEybDEyZoXRMakYKNLbk6Ivu6k+noLHf3G9gh+btav7e377PTeiHAT/vfqFZU2dBzWFaX2e87Kr8W+r2jjvlrya/0NXXW/tIZ+707c7Xv21WMLF++HK+99hry8vIwePBgLFu2DKNGjXLafu3atXj++eeRlZWFvn37YsmSJZg8ebLLz9d8ukp0jqdB3Q7KkTKRjZNoQB38EIh4DEWg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",
      "text/plain": [
       "<Figure size 640x480 with 24 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for ef in experimentFolders:\n",
    "\n",
    "    files = listdir(f\"{dir_name}/{ef}\")\n",
    "\n",
    "    print(ef, \"   \", files[0])\n",
    "    # print(files[0])\n",
    " \n",
    "    index = ef.find(\"class\")\n",
    "    if index != -1:\n",
    "        class0, class1 = int(ef[index + len(\"class\")]) , int(ef[index + len(\"class\") + 1])\n",
    "        # print(\"Class0 : \", class0)\n",
    "        # print(\"Class1 : \", class1)\n",
    "    else:\n",
    "        print(\"Substring not found.\") \n",
    "    \n",
    "\n",
    "    \n",
    "    config = {\"dataset\" : dataset, \"classes\":[class0, class1], \"num_qubits\" : num_qubits, \"measured_qubit\" : 0, \"num_layers\" : num_layers , \"encoding_scaler\" : encoding_scaler, \"encoding_order\":\"C\", \"activation\": activation_func}\n",
    "    \n",
    "    opt_params = np.load(f\"{dir_name}/{ef}/{files[0]}\")\n",
    "    \n",
    "    print(len(opt_params))\n",
    "\n",
    "    scaled_train_data, scaled_test_data, train_labels, test_labels = return_scaled_data(config)\n",
    "    _, unscaled_test_data, _, _ = return_unscaled_data(config)\n",
    "    _, unscaled_test_data2, _, _ = return_unscaled_data(config)\n",
    "\n",
    "    # opt_loss = classifier_loss_angle(opt_params, scaled_train_data, num_qubits, num_layers, train_labels, config)\n",
    "  \n",
    "\n",
    "    print(\"Train accuracy: \", classifier_accuracy_angles(opt_params, scaled_train_data, num_qubits, num_layers, train_labels, config))\n",
    "    print(\"Test accuracy: \", classifier_accuracy_angles(opt_params, scaled_test_data, num_qubits, num_layers, test_labels, config))\n",
    "\n",
    "    # circuit_func = lambda x : classifierCircuit_withoutInit(opt_params, num_qubits, num_layers)\n",
    "    model_func = lambda x : classifier_forward_angles(x, opt_params, num_qubits, num_layers, config)\n",
    "\n",
    "    fig, axes = plt.subplots(3, numSamplesPerExp)\n",
    "\n",
    "    ig_arrays =  np.zeros((numSamplesPerExp, imageWidth, imageHeight))\n",
    "    image_arrays =  np.zeros((numSamplesPerExp, imageWidth, imageHeight))\n",
    "    \n",
    "    for idx, sample_idx in enumerate(sampleIndices):\n",
    "        print(f\"Sample : {idx}\")\n",
    "        # ig = native_integrated_grad(scaled_test_data[idx], baselineImage, circuit_func, 500, num_qubits, config)[0:(imageHeight*imageWidth)] \n",
    "        ig = integrated_grad(scaled_test_data[sample_idx], baselineImage, model_func, 500)\n",
    "        \n",
    "        ig_arrays[idx, :] = np.reshape(ig, (imageWidth, imageHeight))\n",
    "        image_arrays[idx, :] = np.reshape(unscaled_test_data[sample_idx, :], (imageWidth, imageHeight))\n",
    "        \n",
    "        axes[0,idx].imshow(np.reshape(unscaled_test_data[sample_idx, :], (imageWidth, imageHeight)))\n",
    "        axes[1,idx].imshow(np.reshape(ig, (imageWidth, imageHeight)))\n",
    "        axes[2,idx].imshow(np.reshape(unscaled_test_data2[sample_idx,:], (imageWidth, imageHeight)))\n",
    "    \n",
    "    if not isdir(f\"paper_data/{dataset}/{ef}/\"):\n",
    "        mkdir(f\"paper_data/{dataset}/{ef}/\")\n",
    "        \n",
    "    np.save(f\"paper_data/{dataset}/{ef}/{files[0][:-4]}_attributions.npy\", ig_arrays)\n",
    "    np.save(f\"paper_data/{dataset}/{ef}/{files[0][:-4]}_raw_images.npy\", image_arrays)\n",
    "\n",
    "    # print(classifier_forward_angles(inputs, params, numQubits, numLayers, config))\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "703f176e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "qiskit_env",
   "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.12.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
