{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d7b39ed3-e6cd-47c6-afc4-48ba02c179a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import os, time\n",
    "import numpy as np\n",
    "import trace_util\n",
    "import matplotlib.pyplot as plt\n",
    "import xgboost as xgb\n",
    "import veritas # pip install dtai-veritas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3f8c384f-193c-4726-9b9e-ac67bdceda29",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams.update({'font.size': 12})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7df3998b-4b1c-4fd6-b078-357fb962aa5b",
   "metadata": {},
   "outputs": [],
   "source": [
    "xtrain, ytrain_mc = trace_util.load_trace_file(\"Trace_TRAIN.txt\")\n",
    "xtest, ytest_mc = trace_util.load_trace_file(\"Trace_TEST.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5513f3e1-b137-483e-a299-0e0b4b289f44",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9h07diwOHjwo3j948CCCgoIwZMiQdvtZH6eusZ+4B/YTabGfuAf2E2mxn7gP9hVbbh/0lJWVISEhod1267bS0lJnN4k6sGrVKpSUlODWW28FYP7cAHT62dXW1kKr1Yr7xsXFQSaTtdsP4GfcE+wn7oH9RFrsJ+6B/URa7Cfug33FltsHPS0tLVAqle22+/v7i4+TtPLz8/HQQw9h/PjxuOeeewC0fi49+ez4GduPf0PXx34iPf4NXR/7ifT4N3QP7CvtuX3QExAQIEalbWk0GvFxkk55eTlmzZqFsLAwrFmzBgqFAkDr59KTz46fsf34N3Rt7CeugX9D18Z+4hr4N3R97Csdc/ugJyEhQRyua8u6LTEx0dlNIguVSoWrr74a9fX1+PHHH20+C+vwaGefXWRkpHiFISEhAeXl5RAEod1+AD/jnmA/cV3sJ66D/cR1sZ+4DvYT18a+0jm3D3pyc3NRUFAAtVpts3337t3i4+R8Go0G11xzDQoKCrB27VoMHTrU5vGkpCTExMRg37597Z67Z88em88tNzcXzc3NOH78uM1+/Ix7jv3ENbGfuBb2E9fEfuJa2E9cF/tKN6QrHOcYu3btalcvXqPRCIMGDRLGjRsnYcu8l8FgEK699lrBx8dHWLduXaf7Pfjgg0JAQIBNecv169cLAIR3331X3FZUVNRprfikpCS3rBXvbOwnrof9xPWwn7ge9hPXw37imthXuuf2QY8gCMKcOXMEHx8f4emnnxaWLl0qTJgwQfDx8RF++eUXqZvmlR577DEBgHDNNdcIK1eubPdjdf78eSEqKkoYOHCg8Pe//1147bXXhIiICCE7O1vQaDQ2r/n0008LAIQHHnhAeO+998RVgVetWuXsX89tsZ+4FvYT18R+4lrYT1wT+4nrYV/pnkcEPS0tLcJTTz0lxMfHC0qlUhgzZozw448/St0srzV58mQBQKc/bR09elSYPn26EBgYKISHhwtz584VysvL272m0WgUXnvtNSE1NVXw8/MThg0bJnz88cfO+pU8AvuJa2E/cU3sJ66F/cQ1sZ+4HvaV7skE4YIZSkRERERERB7E7QsZEBERERERdYVBDxEREREReTQGPURERERE5NEY9BARERERkUdj0ENERERERB6NQQ8REREREXk0Bj1EREREROTRGPQQEREREZFHY9BDREREREQejUEPERERERF5NAY9RERERETk0Rj0EBERERGRR/t/Na4atQH6iWoAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x200 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 4, figsize=(10, 2))\n",
    "\n",
    "axs[0].plot(xtrain[np.argmax(ytrain_mc==0),:])\n",
    "axs[1].plot(xtrain[np.argmax(ytrain_mc==1),:])\n",
    "axs[2].plot(xtrain[np.argmax(ytrain_mc==2),:])\n",
    "axs[3].plot(xtrain[np.argmax(ytrain_mc==3),:])\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "131c219e-204e-45fe-8fb5-e9cfe43214d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# binary classification for simplicity\n",
    "ytrain, ytest = ytrain_mc==1, ytest_mc==1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9c593a4a-78ad-418a-9ce0-92e456753458",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0]\ttrain-error:0.21000\ttest-error:0.29000\n",
      "[1]\ttrain-error:0.21000\ttest-error:0.29000\n",
      "[2]\ttrain-error:0.21000\ttest-error:0.29000\n",
      "[3]\ttrain-error:0.21000\ttest-error:0.29000\n",
      "[4]\ttrain-error:0.00000\ttest-error:0.08000\n",
      "[5]\ttrain-error:0.00000\ttest-error:0.08000\n",
      "[6]\ttrain-error:0.00000\ttest-error:0.08000\n",
      "[7]\ttrain-error:0.00000\ttest-error:0.08000\n",
      "[8]\ttrain-error:0.01000\ttest-error:0.09000\n",
      "[9]\ttrain-error:0.01000\ttest-error:0.05000\n",
      "[10]\ttrain-error:0.01000\ttest-error:0.07000\n",
      "[11]\ttrain-error:0.01000\ttest-error:0.04000\n",
      "[12]\ttrain-error:0.01000\ttest-error:0.04000\n",
      "[13]\ttrain-error:0.01000\ttest-error:0.04000\n",
      "[14]\ttrain-error:0.01000\ttest-error:0.04000\n",
      "[15]\ttrain-error:0.01000\ttest-error:0.04000\n",
      "[16]\ttrain-error:0.00000\ttest-error:0.04000\n",
      "[17]\ttrain-error:0.00000\ttest-error:0.04000\n",
      "[18]\ttrain-error:0.00000\ttest-error:0.04000\n",
      "[19]\ttrain-error:0.00000\ttest-error:0.04000\n",
      "[20]\ttrain-error:0.00000\ttest-error:0.03000\n",
      "[21]\ttrain-error:0.00000\ttest-error:0.03000\n",
      "[22]\ttrain-error:0.00000\ttest-error:0.03000\n",
      "[23]\ttrain-error:0.00000\ttest-error:0.03000\n",
      "[24]\ttrain-error:0.00000\ttest-error:0.03000\n"
     ]
    }
   ],
   "source": [
    "params = {\n",
    "    #\"num_class\": 4,\n",
    "    #\"objective\": \"multi:softmax\",\n",
    "    #\"eval_metric\": \"merror\",\n",
    "    \n",
    "    \"objective\": \"binary:logistic\",\n",
    "    \"eval_metric\": \"error\",\n",
    "    \n",
    "    \"tree_method\": \"hist\",\n",
    "    \"seed\": 135,\n",
    "    \"max_depth\": 3,\n",
    "    \"learning_rate\": 0.2,\n",
    "    \"colsample_bynode\": 0.2,\n",
    "    \"subsample\": 0.2\n",
    "}\n",
    "num_trees = 25\n",
    "\n",
    "dtrain = xgb.DMatrix(xtrain, ytrain)\n",
    "dtest = xgb.DMatrix(xtest, ytest)\n",
    "model = xgb.train(params, dtrain, num_boost_round=num_trees,\n",
    "                  evals=[(dtrain, \"train\"), (dtest, \"test\")])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7ee413ce-44cb-4746-ac97-49fd467cc2cb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "| XGBOOST's base_score\n",
      "|   base_score diff std      2.0072345340244863e-08 OK\n",
      "|   base_score reported      0.23866731\n",
      "|   versus manually detected -0.8379497682042419\n",
      "|   abs err                  1.076617078204242\n",
      "|   rel err                  4.510953252057192\n",
      "|   (!) base_score NOT THE SAME with relative tolerance 0.00025\n",
      "\n"
     ]
    }
   ],
   "source": [
    "at = veritas.get_addtree(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c3dd1ca3-14c3-4d57-9507-743646337be5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Node(id=0, split=[F9 < 0.601209], sz=3, left=1, right=2)\n",
      "├─ Leaf(id=1, sz=1, value=[-0.184564])\n",
      "└─ Leaf(id=2, sz=1, value=[0.245714])\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(at[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ac9192c2-d5d2-457f-a3cf-529cfe868a29",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OK, model outputs are the same\n",
      "test_conversion: no problems detected (rel_tol 0.00025)\n",
      "Conversion OK? True\n"
     ]
    }
   ],
   "source": [
    "# Check whether output of xgboost and corresponding AddTree match\n",
    "err = np.max(np.abs(at.eval(xtest).ravel() - model.predict(dtest, output_margin=True)))\n",
    "if err < 1e-5:\n",
    "    print(\"OK, model outputs are the same\")\n",
    "else:\n",
    "    print(\"WARNING, model outputs not the same\")\n",
    "\n",
    "# This is also implemented in Veritas:\n",
    "is_conversion_ok = veritas.test_conversion(at, xtest, model.predict(dtest), silent=False)\n",
    "print(\"Conversion OK?\", is_conversion_ok)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d9269844-4511-47db-b97d-82bfa3288c04",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "StopReason.OPTIMAL\n",
      "found an adversarial example for `base_example` with raw output 1.342 in 0.1ms\n",
      " - F0   Interval(>=0.663867)   base value= 0.5792, in? 0\n",
      " - F3   Interval(>=0.660472)   base value= 0.5170, in? 0\n",
      " - F5   Interval(>=0.653347)   base value= 0.5537, in? 0\n",
      " - F7   Interval(>=0.696791)   base value= 0.5965, in? 0\n",
      " - F9   Interval(>=0.601209)   base value= 0.5037, in? 0\n",
      " - F16  Interval(>=0.658673)   base value= 0.5811, in? 0\n",
      " - F18  Interval(>=0.692481)   base value= 0.6242, in? 0\n",
      " - F21  Interval(>=0.62866)    base value= 0.5810, in? 0\n",
      " - F23  Interval(>=0.629155)   base value= 0.5257, in? 0\n",
      " - F47  Interval(>=0.645616)   base value= 2.2385, in? 1\n"
     ]
    }
   ],
   "source": [
    "# FROM CLASS 0 -> CLASS 1\n",
    "base_example = xtest[ytest_mc==0, :][16,:]\n",
    "eps = 0.3\n",
    "\n",
    "config = veritas.Config(veritas.HeuristicType.MAX_OUTPUT)\n",
    "config.ignore_state_when_worse_than = 0.0\n",
    "prune_box = [veritas.Interval(x-eps, x+eps) for x in base_example]\n",
    "search = config.get_search(at)\n",
    "\n",
    "tstart = time.time()\n",
    "while search.num_solutions() == 0:\n",
    "    pass\n",
    "    print(search.steps(100))\n",
    "tstop = time.time()\n",
    "    \n",
    "sol = search.get_solution(0) # best solution is at index 0\n",
    "adv_example = veritas.get_closest_example(sol, base_example, eps=1e-4)\n",
    "\n",
    "print(f\"found an adversarial example for `base_example` with raw output {sol.output:.3f} in {(tstop-tstart)*1000:.1f}ms\")\n",
    "for feat_id, ival in sol.box().items():\n",
    "    x = base_example[feat_id]\n",
    "    print(\" - F{:<3d} {:<22s} base value={:7.4f}, in? {:d}\".format(feat_id, repr(ival), x, ival.contains(x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e73d7982-2744-4d18-80f0-e21378f2caaf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "           base       adv\n",
      "xgb proba [0.05540035 0.79280543]\n",
      " at proba [0.05540035 0.79280545]\n",
      " at raw   [-2.83617529  1.34191966]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1400x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(14, 4))\n",
    "axs[0].plot(base_example)\n",
    "axs[1].plot(adv_example)\n",
    "axs[0].plot(np.nonzero(adv_example!=base_example)[0], base_example[adv_example!=base_example], \".\", ms=4)\n",
    "axs[1].plot(np.nonzero(adv_example!=base_example)[0], adv_example[adv_example!=base_example], \".\", ms=4)\n",
    "axs[2].plot(adv_example-base_example, color=\"red\")\n",
    "\n",
    "# Just to be sure, evaluate two example in the original xgboost model\n",
    "base_and_adv = np.vstack((base_example, adv_example))\n",
    "ypred = model.predict(xgb.DMatrix(base_and_adv))\n",
    "print(\"           base       adv\")\n",
    "print(\"xgb proba\", ypred)\n",
    "print(\" at proba\", at.predict(base_and_adv).ravel())\n",
    "print(\" at raw  \", at.eval(base_and_adv).ravel())\n",
    "\n",
    "axs[0].set_title(f\"original example\\np(y=1)={ypred[0]:.3f}\")\n",
    "axs[1].set_title(f\"adversarial example\\np(y=1)={ypred[1]:.3f}\")\n",
    "axs[2].set_title(\"difference\\nadv. example - orig. example\")\n",
    "\n",
    "for ax in axs:\n",
    "    ax.set_xlabel(\"time\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57017226-40b7-4c07-b7e8-492ec346d59c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
