{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "\n",
    "subspace_num = [1, 2, 4, 8, 16, 32, 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_legend_name = [\"Harmonica (2 order)\", \"Harmonica (3 order)\", \"LIME\", \"SHAP\", \"Integrated Gradients\", \"Integrated Hessians\", \"Shapley Taylor Index (2 order)\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "L2_inconsistency = np.zeros((len(method_legend_name),7))\n",
    "L1_inconsistency = np.zeros((len(method_legend_name),7))\n",
    "L0_inconsistency = np.zeros((len(method_legend_name),7))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 & 0.0100 & 0.0365 & 0.0554 \\\\ \\hline \n",
      "2 & 0.0157 & 0.0470 & 0.0999 \\\\ \\hline \n",
      "4 & 0.0296 & 0.0538 & 0.1339 \\\\ \\hline \n",
      "8 & 0.0585 & 0.0542 & 0.1300 \\\\ \\hline \n",
      "16 & 0.1201 & 0.0558 & 0.1287 \\\\ \\hline \n",
      "32 & 0.2038 & 0.0575 & 0.1294 \\\\ \\hline \n",
      "64 & 0.2139 & 0.0577 & 0.1294 \\\\ \\hline \n"
     ]
    }
   ],
   "source": [
    "for mm in range(7):\n",
    "    print(2**mm, end=\" & \")\n",
    "    print(\"%.4f\" % L2_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][mm], end=\" & \")\n",
    "    print(\"%.4f\" % L1_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][mm], end=\" & \")\n",
    "    print(\"%.4f\" % L0_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][mm], end=\" \\\\\\\\ \\hline \\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Harmonica 2 order\n",
      "subspace 1\n",
      "L2 0.0007\n",
      "L1 0.0192\n",
      "L0 0.004\n",
      "subspace 2\n",
      "L2 0.0007\n",
      "L1 0.0193\n",
      "L0 0.0035\n",
      "subspace 4\n",
      "L2 0.0011\n",
      "L1 0.0228\n",
      "L0 0.014\n",
      "subspace 8\n",
      "L2 0.0022\n",
      "L1 0.0298\n",
      "L0 0.0433\n",
      "subspace 16\n",
      "L2 0.0028\n",
      "L1 0.0329\n",
      "L0 0.0573\n",
      "subspace 32\n",
      "L2 0.0029\n",
      "L1 0.0334\n",
      "L0 0.0595\n",
      "subspace infinity\n",
      "L2 0.0029\n",
      "L1 0.0334\n",
      "L0 0.0596\n"
     ]
    }
   ],
   "source": [
    "print(\"Harmonica 2 order\")\n",
    "degree = 2\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_4000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_5500_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_7000_8500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_8500_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_10000_11250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_11250_12500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_12500_13750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_13750_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_15000_16250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_16250_17500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_17500_18750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_18750_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_20000_21250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_21250_22500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_22500_23750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_lasso_output_subspace{each_subspace_num}_seed123_23750_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_4000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_5500_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_7000_8500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_8500_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_10000_11250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_11250_12500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_12500_13750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_13750_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_15000_16250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_16250_17500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_17500_18750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_18750_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_20000_21250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_21250_22500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_22500_23750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica2degree/harmonica2degree_final_model_output_subspace{each_subspace_num}_seed123_23750_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"Harmonica (2 order)\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"Harmonica (2 order)\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"Harmonica (2 order)\")][idx] = L0_norm / len(final_lasso_output)\n",
    "\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Harmonica 3 order\n",
      "subspace 1\n",
      "L2 0.0005\n",
      "L1 0.0149\n",
      "L0 0.0027\n",
      "subspace 2\n",
      "L2 0.0005\n",
      "L1 0.0157\n",
      "L0 0.0022\n",
      "subspace 4\n",
      "L2 0.0008\n",
      "L1 0.0195\n",
      "L0 0.0098\n",
      "subspace 8\n",
      "L2 0.0018\n",
      "L1 0.0265\n",
      "L0 0.0367\n",
      "subspace 16\n",
      "L2 0.0024\n",
      "L1 0.0296\n",
      "L0 0.0505\n",
      "subspace 32\n",
      "L2 0.0025\n",
      "L1 0.0301\n",
      "L0 0.0527\n",
      "subspace infinity\n",
      "L2 0.0025\n",
      "L1 0.0301\n",
      "L0 0.0528\n"
     ]
    }
   ],
   "source": [
    "print(\"Harmonica 3 order\")\n",
    "degree = 3\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_6000_6500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_6500_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_7000_7500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_7500_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_10000_11000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_11000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_12000_13000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_13000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_14000_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_15000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_16000_17000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_17000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_18000_19000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_19000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_20000_21250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_21250_22500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_22500_23750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_lasso_output_subspace{each_subspace_num}_seed123_23750_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_6000_6500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_6500_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_7000_7500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_7500_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_10000_11000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_11000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_12000_13000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_13000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_14000_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_15000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_16000_17000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_17000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_18000_19000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_19000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_20000_21250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_21250_22500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_22500_23750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./harmonica3degree/harmonica3degree_final_model_output_subspace{each_subspace_num}_seed123_23750_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"Harmonica (3 order)\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"Harmonica (3 order)\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"Harmonica (3 order)\")][idx] = L0_norm / len(final_lasso_output)\n",
    "\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "KernelSHAP\n",
      "subspace 1\n",
      "L2 0.0091\n",
      "L1 0.065\n",
      "L0 0.2266\n",
      "subspace 2\n",
      "L2 0.0149\n",
      "L1 0.0903\n",
      "L0 0.3589\n",
      "subspace 4\n",
      "L2 0.0223\n",
      "L1 0.1162\n",
      "L0 0.4891\n",
      "subspace 8\n",
      "L2 0.0284\n",
      "L1 0.1341\n",
      "L0 0.561\n",
      "subspace 16\n",
      "L2 0.0306\n",
      "L1 0.1402\n",
      "L0 0.5817\n",
      "subspace 32\n",
      "L2 0.031\n",
      "L1 0.1411\n",
      "L0 0.5842\n",
      "subspace infinity\n",
      "L2 0.031\n",
      "L1 0.1411\n",
      "L0 0.5843\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nKernelSHAP\")\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_2000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_4000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_6000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_8000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_18000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_20000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_22000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_lasso_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_2000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_4000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_6000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_8000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_18000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_20000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_22000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ks/ks_final_model_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "    _baseline = 0.\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model + _baseline) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model + _baseline)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model + _baseline) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"SHAP\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"SHAP\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"SHAP\")][idx] = L0_norm / len(final_lasso_output)\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "LIME\n",
      "subspace 1\n",
      "L2 0.0063\n",
      "L1 0.0525\n",
      "L0 0.1175\n",
      "subspace 2\n",
      "L2 0.0071\n",
      "L1 0.0546\n",
      "L0 0.1358\n",
      "subspace 4\n",
      "L2 0.0082\n",
      "L1 0.0583\n",
      "L0 0.1606\n",
      "subspace 8\n",
      "L2 0.0096\n",
      "L1 0.064\n",
      "L0 0.1903\n",
      "subspace 16\n",
      "L2 0.0102\n",
      "L1 0.0664\n",
      "L0 0.2017\n",
      "subspace 32\n",
      "L2 0.0103\n",
      "L1 0.0667\n",
      "L0 0.2033\n",
      "subspace infinity\n",
      "L2 0.0103\n",
      "L1 0.0667\n",
      "L0 0.2033\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nLIME\")\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_18000_19750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_19750_21500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_21500_23250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_lasso_output_subspace{each_subspace_num}_seed123_23250_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_18000_19750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_19750_21500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_21500_23250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./lime/lime_final_model_output_subspace{each_subspace_num}_seed123_23250_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"LIME\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"LIME\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"LIME\")][idx] = L0_norm / len(final_lasso_output)\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "IG\n",
      "subspace 1\n",
      "L2 0.0189\n",
      "L1 0.081\n",
      "L0 0.2702\n",
      "subspace 2\n",
      "L2 0.0301\n",
      "L1 0.1169\n",
      "L0 0.4102\n",
      "subspace 4\n",
      "L2 0.0419\n",
      "L1 0.1494\n",
      "L0 0.5333\n",
      "subspace 8\n",
      "L2 0.0485\n",
      "L1 0.1657\n",
      "L0 0.5885\n",
      "subspace 16\n",
      "L2 0.0502\n",
      "L1 0.1697\n",
      "L0 0.6004\n",
      "subspace 32\n",
      "L2 0.0504\n",
      "L1 0.1702\n",
      "L0 0.6014\n",
      "subspace infinity\n",
      "L2 0.0504\n",
      "L1 0.1702\n",
      "L0 0.6015\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nIG\")\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_18000_19750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_19750_21500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_21500_23250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_lasso_output_subspace{each_subspace_num}_seed123_23250_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_4000_4500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_4500_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_5000_5500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_5500_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_18000_19750.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_19750_21500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_21500_23250.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ig/ig_final_model_output_subspace{each_subspace_num}_seed123_23250_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "    _baseline = 0.\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"Integrated Gradients\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"Integrated Gradients\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"Integrated Gradients\")][idx] = L0_norm / len(final_lasso_output)\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "IH\n",
      "subspace 1\n",
      "L2 0.0174\n",
      "L1 0.0635\n",
      "L0 0.1929\n",
      "subspace 2\n",
      "L2 0.0293\n",
      "L1 0.0997\n",
      "L0 0.3125\n",
      "subspace 4\n",
      "L2 0.0442\n",
      "L1 0.1415\n",
      "L0 0.4501\n",
      "subspace 8\n",
      "L2 0.0552\n",
      "L1 0.1702\n",
      "L0 0.5423\n",
      "subspace 16\n",
      "L2 0.0589\n",
      "L1 0.1795\n",
      "L0 0.5702\n",
      "subspace 32\n",
      "L2 0.0595\n",
      "L1 0.1807\n",
      "L0 0.5739\n",
      "subspace infinity\n",
      "L2 0.0595\n",
      "L1 0.1807\n",
      "L0 0.5738\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nIH\")\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_2000_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_3000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_4000_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_5000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_10000_11000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_11000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_12000_13000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_13000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_14000_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_15000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_16000_17000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_17000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_18000_19000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_19000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_20000_21000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_21000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_22000_23000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_23000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_lasso_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_2000_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_3000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_4000_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_5000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_6000_7000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_7000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_8000_9000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_9000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_10000_11000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_11000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_12000_13000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_13000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_14000_15000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_15000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_16000_17000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_17000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_18000_19000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_19000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_20000_21000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_21000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_22000_23000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_23000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./ih/ih_final_model_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "\n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "    _baseline = 0.\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model + _baseline) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model + _baseline)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model + _baseline) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"Integrated Hessians\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"Integrated Hessians\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"Integrated Hessians\")][idx] = L0_norm / len(final_lasso_output)\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Shapley Taylor\n",
      "subspace 1\n",
      "L2 0.01\n",
      "L1 0.0365\n",
      "L0 0.0554\n",
      "subspace 2\n",
      "L2 0.0157\n",
      "L1 0.047\n",
      "L0 0.0999\n",
      "subspace 4\n",
      "L2 0.0296\n",
      "L1 0.0538\n",
      "L0 0.1339\n",
      "subspace 8\n",
      "L2 0.0585\n",
      "L1 0.0542\n",
      "L0 0.13\n",
      "subspace 16\n",
      "L2 0.1201\n",
      "L1 0.0558\n",
      "L0 0.1287\n",
      "subspace 32\n",
      "L2 0.2038\n",
      "L1 0.0575\n",
      "L0 0.1294\n",
      "subspace infinity\n",
      "L2 0.2139\n",
      "L1 0.0577\n",
      "L0 0.1294\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nShapley Taylor\")\n",
    "idx = 0\n",
    "\n",
    "for each_subspace_num in subspace_num:\n",
    "    final_lasso_output = np.concatenate([\n",
    "                                        np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         # np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_2000_3000.npy\", allow_pickle=True),\n",
    "                                         # np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_3000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_4000_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_5000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_6000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_8000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_18000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_20000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_22000_23000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_23000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_lasso_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    final_model_output = np.concatenate([\n",
    "                                        np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_0_500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_500_1000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_1000_1500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_1500_2000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_2000_2500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_2500_3000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_3000_3500.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_3500_4000.npy\", allow_pickle=True),\n",
    "                                         # np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_2000_3000.npy\", allow_pickle=True),\n",
    "                                         # np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_3000_4000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_4000_5000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_5000_6000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_6000_8000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_8000_10000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_10000_12000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_12000_14000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_14000_16000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_16000_18000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_18000_20000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_20000_22000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_22000_23000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_23000_24000.npy\", allow_pickle=True),\n",
    "                                         np.load(f\"./shaptaylor/shaptaylor_final_model_output_subspace{each_subspace_num}_seed123_24000_25000.npy\", allow_pickle=True),\n",
    "                                         ], axis = 0)\n",
    "    \n",
    "    L0_norm = 0\n",
    "    L1_norm = 0\n",
    "    L2_norm = 0\n",
    "    _baseline = 0.\n",
    "\n",
    "    for _lasso, _model in zip(final_lasso_output, final_model_output):\n",
    "        assert _lasso.shape[0] == _model.shape[0]\n",
    "        L2_norm += np.sum(np.abs(_lasso - _model + _baseline) ** 2) / _lasso.shape[0]\n",
    "        L1_norm += np.sum(np.abs(_lasso - _model + _baseline)) / _lasso.shape[0]\n",
    "        L0_norm += np.sum(np.abs(_lasso - _model + _baseline) >= 0.1) / _lasso.shape[0]\n",
    "\n",
    "    if (each_subspace_num == 0):\n",
    "        print(f\"subspace infinity\")\n",
    "    else:\n",
    "        print(f\"subspace {each_subspace_num}\")\n",
    "    print(\"L2\", np.round(L2_norm / len(final_lasso_output), 4))\n",
    "    print(\"L1\", np.round(L1_norm / len(final_lasso_output), 4))\n",
    "    print(\"L0\", np.round(L0_norm / len(final_lasso_output), 4))\n",
    "\n",
    "    L2_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][idx] = L2_norm / len(final_lasso_output)\n",
    "    L1_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][idx] = L1_norm / len(final_lasso_output)\n",
    "    L0_inconsistency[method_legend_name.index(\"Shapley Taylor Index (2 order)\")][idx] = L0_norm / len(final_lasso_output)\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/hehaowei/.conda/envs/gdn_battery/lib/python3.6/site-packages/ipykernel_launcher.py:16: UserWarning: Attempted to set non-positive bottom ylim on a log-scaled axis.\n",
      "Invalid limit will be ignored.\n",
      "  app.launch_new_instance()\n"
     ]
    },
    {
     "data": {
      "image/png": "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Fi5cSEFBQfhceXk569evJyUlhYiICEaNGoU/qDH6tLOJjollR5ELaysfMTYT8RF2om0mrGYjZqPupWcyGHjl2af46MMPKCop48NZ7zJsYAZIyWXnjoXCLRD0EtRs3PXQ0yz+7VdkwENufhEr125g3NgxLPhjFc8/MwOApFatOO+Ci8Bk0j3pLJHgk2CyHfCZAYwdO5a4uDgAjj/+eLZu3VrjcxgyZAjPPPMMd911FyNHjmTs2LG1PjPFsUl9LKh04EAJcaKADocljULRQFTNnms0GmtVGFJK7r33Xq688sp636NqfqgdO3Zw2223sXTpUjp27MjixYuZNGlSjddVrlktXboUs7n6msrKlavQpCSr0Em5J4BEIkJhf3qmRmMy7nUbHzBgAEuXhvbPBAPcc/PV3HPFeDLPnIK/MAvhStHlNAVABsESycxn/ktJSQl//PEHNquVaddeh8cYBXHtQ4v4B19DONgz2/fZu93uGtsNHTqUv/76ix9++IF3332Xxx9/nF9//fWg91ccO9Qn3QYcONDtIKD00EVRKBqfmJgYysrKwsdnnXUWL730Unh6yev1smqV7qQ6atQo3nlHT5pYWlrKl1/WnqfT4XBgsVhITU1F0zReeeWVavd0uVxhJRkdHc2JJ57I448/Dugv/E1bt/PXhm3I2NZUON388usvJEdbWPvr9zjKSomLsFRTTgA33HAD8+fP591Xn4WC9YAkGNMWr6sCNL/uzi2E7oqd3B3i0yl1emjdujU2ewTZObnVxnTSSSfx5ptvAlBUVMQXX3xR41gP9Mzq8+y3b99OTEwMEydOZObMmSxfvhztKEipoWg4DmhBCSFuAm6qcmqGEOLBGprGAYlADfE4FIrmw7Rp07jjjjt46qmnePrpp7n00kspLCxk5MiRgG7dXH/99fTr14/777+fK664gh49etC6dWsyMzOrTWVVpU+fPlx44YVkZGSQlJTE6aefzs8//wzo04OTJ0+mT58+xMfHs3jxYmbNmsUtt95Kz169CWqSiMhIHprxIv37pPLOu+9x520385QQjBgxgvbt2+9/Q7+HNKubnz95hXsef577HnmapORWWAwa544bzcA+PfQoCFAtnPXNN9/MhRdeSO/evWnbti0nn3xyuO6+++7jyiuvpEePHqSmpjJixIgax3qgZ3Ygzj33XN555x369+/PxIkT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/PnzefbZZxFCEBMTw8UXX8z8+fPDubEmTZoUntpbsGABU6ZMwWw2YzabueSSS/j1118BmDNnDsuWLWPgQD2bTyAQIDZ2b+S1cE6wKqSmprJ7924Uh49SULWgQh1Vx24xhvdw2S2HEGZIauBz7fW087lCa0g2XSGZrLpSqnR8OAR69+5N7969ueGGG8jIyGDhwoXhiNmVOYoq11oCgQC//PILL7/8MosXLyY5OZn333+f1157rX7DkpJx48aF03Lsy4033shLL70EwDXXXFPntZ5//etfpKam8tZbb2EymRgzZkw459KwYcMIBoP89ttvvPXWWyxdurReMgP1dn6oKcdTTVRuj5BSkpSUFF5f25fc3FwqKioQQuBwOIiJidmvjd1ur5ZnqpLnn3+e999/n59++omIiEML2lvX8Uspuffee7nyyivr3I/H48Futx+SXIrqtIR8UE2ClHKulHJa1W9Linqgzx/r5bJsyF0DRZuhPFc/H5W814khMlH3orNEHpJyys7OZsmSJeHj3bt3U1BQcFBPqtLSUmJjY0lMTMTr9fLGG29Uq9+6dWs4L9P7779Pnz599nuRjhkzhm+//Za///47fK6qwpgyZQqzZ8/mo48+4qqrrqrzmEpLS2nXrh0mk4m1a9eG5ajkpptuYuLEiQwbNox27drtd/2QIUNYtWoVGzbonqRvv/02AwYMaNAstgfKXdW9e3ciIiJ49913w+03bNiAw+HA5/Nx0UUX8eSTTzJ9+nQmTpxYo8Lr3r07OTk5eL3e8LlXX32V1157jR9++CFsHdfEKaecwv/+9z+klJSXl/Phhx9y6qmn1tj2pJNO4t133yUQCOB2u3n//ffDdWeddRYvvfQSJSV6XGqv1xvOF1Yb69evp1+/fgdso6gbyoJqTNyluhvzvuWjERkKthr2tKuAxK66hWQ0gz1Bt5AsUWBs2D+7QCDAAw88wI4dO7Db7WiaxsMPP8yAAQMOeN24ceN477336NatG0lJSYwYMaJagr4+ffrw+uuvc9111xEREVGjldS1a1fee+89pk6ditvtxufzccIJJzB48GBAz/M0btw43G43ycnJdR7Tvffey6WXXsr//vc/unXrVm0KEfQptxtuuIHrr7++xuuTk5N59913mTRpEoFAgOTkZN577706378uWK3WWnNXmUwm5s6dy6233spTTz1F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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np \n",
    "import pandas as pd \n",
    "import seaborn as sns \n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "index = [\"1\",\"2\",\"4\",\"8\",\"16\",\"32\",\"∞\"] \n",
    "df_L2 = pd.DataFrame(L2_inconsistency.T, index, [\"Harmonica (2 order)\", \"Harmonica (3 order)\", \"LIME\", \"SHAP\", \"Integrated Gradients\", \"Integrated Hessians\", \"Shapley Taylor Index (2 order)\"]) \n",
    "\n",
    "ax_L2 = sns.lineplot(data=df_L2, marker='X') \n",
    "# ax_L2.set(xlabel='subspace radius', ylabel='Inconsistency') \n",
    "plt.xlabel('Subspace radius', fontsize=17)\n",
    "plt.ylabel('Interpretation error', fontsize=17)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "ax_L2.set(yscale='log')\n",
    "ax_L2.set(ylim=[0,1])\n",
    "ax_L2.legend(fontsize=11)\n",
    "fig_L2 = ax_L2.get_figure() \n",
    "plt.tight_layout()\n",
    "fig_L2.savefig(\"interpretation-error-imdb-plot-l2.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "# print(L2_inconsistency)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import numpy as np \n",
    "# import pandas as pd \n",
    "# import seaborn as sns \n",
    "# from copy import deepcopy\n",
    "\n",
    "# index = [\"1\",\"2\",\"4\",\"8\",\"16\",\"32\",\"∞\"] \n",
    "# df_L2 = pd.DataFrame(deepcopy(L2_inconsistency.T), index, [\"Harmonica (2 order)\", \"Harmonica (3 order)\", \"LIME\", \"SHAP\", \"Integrated Gradients\", \"Integrated Hessians\", \"Shapley Taylor Interaction Index\"]) \n",
    "# print(df_L2)\n",
    "# df_L2[\"LIME\"] = df_L2[\"LIME\"] / df_L2[\"Harmonica (2 order)\"]\n",
    "# df_L2[\"SHAP\"] = df_L2[\"SHAP\"] / df_L2[\"Harmonica (2 order)\"]\n",
    "# df_L2[\"Integrated Gradients\"] = df_L2[\"Integrated Gradients\"] / df_L2[\"Harmonica (2 order)\"]\n",
    "# df_L2[\"Integrated Hessians\"] = df_L2[\"Integrated Hessians\"] / df_L2[\"Harmonica (2 order)\"]\n",
    "# df_L2[\"Shapley Taylor Interaction Index\"] = df_L2[\"Shapley Taylor Interaction Index\"] / df_L2[\"Harmonica (2 order)\"]\n",
    "# del df_L2[\"Harmonica (2 order)\"]\n",
    "# del df_L2[\"Harmonica (3 order)\"]\n",
    "# print(df_L2)\n",
    "# ax_L2 = sns.lineplot(data=df_L2, marker='X') \n",
    "# ax_L2.set(xlabel='Subspace radius', ylabel='L2 norm ratio to Harmonica (2 order)') \n",
    "# # ax_L2.set(yscale='log')\n",
    "# # ax_L2.set(ylim=[0,1])\n",
    "# fig_L2 = ax_L2.get_figure() \n",
    "# fig_L2.savefig(\"inconsistency-har2nd-ratio-imdb-plot-l2.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/hehaowei/.conda/envs/gdn_battery/lib/python3.6/site-packages/ipykernel_launcher.py:15: UserWarning: Attempted to set non-positive bottom ylim on a log-scaled axis.\n",
      "Invalid limit will be ignored.\n",
      "  from ipykernel import kernelapp as app\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAagAAAEYCAYAAAAJeGK1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACEZElEQVR4nOydd3xVRfbAv/Nqeg8EQglNOgQIdZEiiFjAAiqCBRt2VxRXd9eC/kRdFVh7XRQV+y4IdpGO0nuXEiCEhPT6+p3fH/flkYQEkvBCCvP9fC5v7szcuWduePe8mTlzjpBSolAoFApFfcNQ1wIoFAqFQlERSkEpFAqFol6iFJRCoVAo6iVKQSkUCoWiXqIUlEKhUCjqJUpBKRQKhaJeohSUQqFQKOol55WCEkJ0E0JsEkL8KYRYKIQIrWuZFAqFQlEx55WCAt4BnpBSdgD2AH+rY3kUCoVCUQn1XkEJIdoLId4VQmwTQniEEMsqqddFCPGbEKJYCJEqhHhWCGEsVd4UaCOl/MGb9R9gXO33QKFQKBQ1wVTXAlSBrsBlwBrAXFEFIUQksBjYBVwJtANmoivgJ7zVWgAppS47ArSsHZEVCoVCcbY0BAW1SEr5LYAQ4hsgpoI6dwOBwDVSynzgVyFEGDBdCPGSN0+cM4kVCoVCcdbU+yk+KaVWhWqXAj97FVEJX6ArraHe8xT0UVQJrSg7olIoFApFPaIhjKCqQidgSekMKeURIUSxt2yRlDJNCJEshLjMuw51O/C/ihoTQkwBpgAEBwf36dSpU+1Kr1AoFOcxGzduzJRSxpbPbywKKhLIrSA/x1tWwj3AXCHEq8BeYFJFjUkp3wPeA0hKSpIbNmzwq7AKhUKhOIkQ4nBF+Y1FQVUJKeU2oFddy6FQKBSKM1Pv16CqSA4QXkF+pLdMoVAoFA2MxqKg9qCvNfkQQrQEgrxlCoVCoWhgNBYF9SNwSTnXRdcDNmB5TRoUQowRQryXl5fnD/kUCoVCUU3q/RqUECIIfaMuQDwQJoQY7z3/QUpZjO7C6EHgf0KIfwFtgenArHKm51VGSrkIWJSUlHRn+TJN08jMzCQ3NxePx1OT5hWK84qAgABatGiB2VzhXnuFokLqvYICmgBfl8srOW8DJEspc4QQI4A3gEXoFn2z0ZWU30lJSUEIQUJCAmazGSHUHmCFojKklGRlZZGSkkKbNm3qWhxFA6LeKygpZTJV8AIhpdwFXFTrAgFFRUV07NgRg6GxzJAqFLWHEILo6GgyMjLqWhRFA0O9YWuIUk4KRdVRswyKmqDesgqFQqGolygFVQkNzYovISGBHTt2lMlLSkpi2bJldSPQGUhMTMRms/mtvS1btnDllVcCsG/fPoYPH06nTp3o1q0bt956q1/vVcLkyZN54403qn1dRkYG/fv3x+12+10mhaIxoRRUJUgpF0kpp4SHV7T/t/Fyrl6aW7ZsITAw0G/t/f3vf+fxxx8HwGKxMGvWLPbs2cO2bdsoLi7mlVdeOav2/fVc3G43sbGxDBw4kE8++cQvbSoUjZV6byTREHhm0U52pdbImv2MdGkextNjup51O5999hmvvvoqTqcTgFdeeYURI0YA+uhrwoQJLFmyhO7du9OyZUv27NlDfn4++/bto0+fPjz++OM88sgjHD58mGuuuYaXX34ZgP3793PXXXeRkZGByWTi+eefZ/To0YC+7jBjxgzmz59PVlYWL7/8MuPGjfOVFRQUEBISwu7du/nrX/9KWloaUkqmTZvGLbfcwsyZM/niiy9wu90EBATw9ttvk5iYeErfjhw5wt69exk4cKCvPwkJCYC+VtivXz92795d4XM5k/xPP/0033//PaNHj+buu+/m5ptv5vjx4yQkJJRZh8zPz+fhhx9m27Zt2O12hg8fzqxZszAajQwbNozExETWrFlDVFQUP/zwAzfccAMPP/wwt95661n+ZRWKxotSUI2I8ePHExAQ4Dvft2+fL33JJZdwww03IIRg7969jBgxgpSUk9FG8vPzWbduHQDTp09n48aNbNiwgZCQEHr37s3jjz/Ojz/+iNvtpk2bNkyZMoUOHTowadIkpkyZwu23386uXbsYMmQIu3fvJjZWd0wcFhbG+vXrWb16Ndddd51PQZXgdru58sormTFjBtdeey0AWVlZANx888088sgjACxevJi7776bNWvWnNLv5cuX069fvwqfic1mY86cObzwwgsVlp9J/sDAQNavXw/AuHHjGDJkCE8//TQHDx6kZ8+ePmX28MMPM3ToUD744AM0TWPSpEnMmTOHO+/Ut9EdPHiQVatWYTLpX7k+ffqwZcsWioqKCA4OrlA2heJ8RykoP+CPEY4/+Oabb+jWrZvvPCkpyZc+cOAAN9xwA8eOHcNsNpOWlkZa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goKCGDZsGADXXXcdU6ZMqVKfX3zxRb744guysrL48ssvGTRoEKArwxI8Hg+PPvoov//+O1JK0tLS2LJlC6NHjy7T35iYGK655poK73O6ZwZwySWXEBERAUD//v05cOBAhe0MGDCA2bNn8+ijjzJ06FAuueSSKvVToThfqI6CGg28JqV8pLaEUfiP0hF0jUZjpQpDSskTTzzBbbfdVu17lI4RdfjwYaZOncr69etp06YNv//+OxMnTqzwOk3TEEKwfv16zGZzmbJt206N6CLEKTPJAPTq1Yv169f7zh9//HEef/xxkpKScDqdFco5a9YscnJyWLt2LQEBAUyZMgW7vXoeus70zMo/e5vNVmG9gQMHsnnzZn799Vc++eQTXnzxRVatWlUtWRSKxkx1jCScwP7aEkRxbggLCyMvL893PnbsWN566y3f9JLD4WDr1q2Avpb18cd60MTc3Fy+/fbbStvNz8/HYrEQFxeHpmm88847Ze5ZXFzsU5KhoaFceOGFvPjii746R48eJS0tjY4dO2Kz2XzxqL755htyc3MrvOd9993H4sWL+eSTT3x5Ho+nQgOJEnJzc2nWrBkBAQEcO3asTJ8uuugiPvzwQwCysrKYP39+hW2c7pmdjvLP/tChQ4SFhTFhwgRmzZrFxo0b0TTtjO0oFOcL1VFQ3wCX1ZYg9Q0hxBghxHulXyiNgSlTpvDss8+SmJjI4sWLuemmm5g0aRJDhw6lR48e9OnTh9WrVwPw1FNPceLECTp16sTVV19NUlJSmams0nTv3p1rr72WLl260L9//zLBEqOiopg0aRLdu3f3TbvNmzePXbt20b17d7p37871119Pbm4uVquVzz//nHvvvZcePXqwbNkyWrVqVeE9mzdvzooVK5g/fz4JCQkkJSVx4YUXcvXVV/um38rz4IMPsnr1arp168btt9/OiBEjfGVPPvkkOTk5dOrUiXHjxjFkyJAK2zjdMzsdV199NevXrycxMZEXX3yRZcuW0bt3bxITE7n00kt55513MBiUYa1CUUJ14kF1BD4F9gFvA4eBUzabSClT/SlgXXM+x4NyuVx4PB4CAgLIz89n8ODBzJo1i5EjR9a1aIoGyPnyvVFUn8riQVVnDWo3upVeH2DCaeopK75GQk5ODpdeeikejwe73c7EiROVclKcU+xFhQQEh5ySbsg0tj7VZn+q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+OKLL7j44osrrHvRRRfxySef4Ha7sdlsZdbzThcvrDJ2795Nz549T1tHoagK1flG9gNekFLmCiFKvhkGACnlSiHEf4D/AxZXo82uwGXAGqBCJ1BCiEhvm7uAK4F26FF9DcAT1bhXo8XtdvP0009z+PBhAgMD0TSN5557royhhMetUZzvwF6kvwiL8x1cPGIU8xd9zQUXXEBMTAxDhgwps0DevXt3PvjgA+655x6CgoJ8oyRDKWesHTp0YO7cudx2223Y7XZsxUX07dWLgYP+gtkaQOtOXbj0ssuw2+00b1F1K7wnnniCm266if988AEd2rRhcL9+uI4fx3nkCNaEBCaMG8eD06Zxz513AroPNWurVmAQGENDaRIayieffMLEiRNxu93Exsby6aeflrlHaZPsmmxmtVqtlcauMplMLFq0iIceeoiXX34Zj8dD06ZN+eqrr3jqqadITEz0Tf8tWbKEJ554okwAR9BHUMOHD2fZsmVccsklFBQUcM8999C6dWufsrFaraxde6r3sSeffJL777/fF2/rpptuYvTo0RX2Y8qUKWzbto3OnTsTExND3759SU9P911XWbywiigx2ujWrVu1nqVCUSEVLUxVdACFwB3edACgAdeWKr8DKKxqe95rDKXS3wDLKqjzdyAHCCuV9zeguFzeJiCzgmNeBW3KqspYVSOJ+ojH7ZGapsnifIdMT86T6cl5Miu1UBbl2aXb5TnttUuXLpXl++5xu09JF+fnyeP798n8LH2h3F5cJJ12u9Q0TUoppcvlkp07d5br1q2rmszFxdKVkSHd+bqBguPwYVm8fbu07d4tHYcPS1dWlpRSypUrV8quXbv67tNYWb16tbzyyivrWowq8/jjj8sPPvigwrKG8r1RnHvwg5HEEaC19+1uF0IcBQYBJXbEiUBexZdWjJRSq0K1S4GfpZSlYwl/AfwLGAos8rbVuzr3bqyU+LVzOzzknigmomkQ5gAjweFWrMFn9m9XGR63C0dRESZrAEKA02YjMCwcS0AgIZFRBIToe4esgSfXRBYuXMgDDzzA1VdfTd++fU9pU2qavgG2uBhDYCDG0FDcGRl48vMxRUdjDA3B1KSJ7gTVcjJY4O23386vv/7Kxx9/XG/cGtUWgwYN4oorrqCoqIjgSrxS1yfi4+O59dZbz1xRoagC1XEW+wYwVErZ3Xs+A30k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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np \n",
    "import pandas as pd \n",
    "import seaborn as sns \n",
    "\n",
    "index = [\"1\",\"2\",\"4\",\"8\",\"16\",\"32\",\"∞\"] \n",
    "df_L1 = pd.DataFrame(L1_inconsistency.T, index, [\"Harmonica (2 order)\", \"Harmonica (3 order)\", \"LIME\", \"SHAP\", \"Integrated Gradients\", \"Integrated Hessians\", \"Shapley Taylor Index (2 order)\"]) \n",
    "\n",
    "ax_L1 = sns.lineplot(data=df_L1, marker='X') \n",
    "# ax_L1.set(xlabel='subspace radius', ylabel='Inconsistency') \n",
    "plt.xlabel('Subspace radius', fontsize=17)\n",
    "plt.ylabel('Interpretation error', fontsize=17)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "ax_L1.set(yscale='log')\n",
    "ax_L1.set(ylim=[0,1])\n",
    "ax_L1.legend(fontsize=11)\n",
    "fig_L1 = ax_L1.get_figure() \n",
    "plt.tight_layout()\n",
    "fig_L1.savefig(\"interpretation-error-imdb-plot-l1.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/hehaowei/.conda/envs/gdn_battery/lib/python3.6/site-packages/ipykernel_launcher.py:17: UserWarning: Attempted to set non-positive bottom ylim on a log-scaled axis.\n",
      "Invalid limit will be ignored.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np \n",
    "import pandas as pd \n",
    "import seaborn as sns \n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "index = [\"1\",\"2\",\"4\",\"8\",\"16\",\"32\",\"∞\"]\n",
    "df_L0 = pd.DataFrame(L0_inconsistency.T, index, [\"Harmonica (2 order)\", \"Harmonica (3 order)\", \"LIME\", \"SHAP\", \"Integrated Gradients\", \"Integrated Hessians\", \"Shapley Taylor Index (2 order)\"]) \n",
    "\n",
    "ax_L0 = sns.lineplot(data=df_L0, marker='X') \n",
    "# ax_L0.set(xlabel='subspace radius', ylabel='Inconsistency') \n",
    "plt.xlabel('Subspace radius', fontsize=17)\n",
    "plt.ylabel('Interpretation error', fontsize=17)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "ax_L0.set(yscale='log')\n",
    "ax_L0.set(ylim=[0,1])\n",
    "ax_L0.legend(fontsize=11)\n",
    "fig_L0 = ax_L0.get_figure() \n",
    "plt.tight_layout()\n",
    "fig_L0.savefig(\"interpretation-error-imdb-plot-l0.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.6.13"
  },
  "vscode": {
   "interpreter": {
    "hash": "b8f076930f2ec5764706603fffbaf6bf97f1b4e883c91bf6d505c138de291d16"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
