{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7bf16f80-4925-4ea9-acd7-462afb5aae6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7bc9ea85-7e0f-45cb-a5aa-72359534ede0",
   "metadata": {},
   "source": [
    "# Unexpected Examples, e.g., Adversarial Examples\n",
    "\n",
    "Tree ensembles can behave erratically for unexpected examples.\n",
    "\n",
    "Tree ensembles are susceptible to evasion attacks. An evasion attack constructs an adversarial example specifically designed to fool the ensemble to make the wrong prediction."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cfb52829-2685-41c2-b268-3c69368fd714",
   "metadata": {},
   "source": [
    "## Preliminaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7616d694-6a34-4a0f-8b3e-054bc1069ce9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "from sklearn import datasets\n",
    "from sklearn.model_selection import train_test_split\n",
    "import numpy as np\n",
    "\n",
    "import veritas\n",
    "import xgboost as xgb\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import accuracy_score"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f045e3fb-30cf-45d5-85f3-e925479799a6",
   "metadata": {},
   "source": [
    "## The MNIST dataset of handwritten digits\n",
    "\n",
    "We use the [MNIST dataset](http://yann.lecun.com/exdb/mnist/)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e16c9219-649f-429d-8f5e-f1d5e7f06aee",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_mc, y_mc = datasets.fetch_openml(data_id=554, return_X_y=True, as_frame=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d0b9d431-662e-44d4-ad02-9074eaad0862",
   "metadata": {},
   "source": [
    "We construct a binary classification task by contrasting 2 and 8."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0eb8d5d4-a25a-4bb8-86a3-08dfc50e4dcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "class0, class1 = '2', '8'\n",
    "mask = (y_mc == class0) | (y_mc == class1)\n",
    "X = X_mc[mask, :].astype(veritas.FloatT)\n",
    "yn = y_mc[mask]\n",
    "y = yn == class1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "da55d069-9cb7-4a08-91d7-e797acfa7d63",
   "metadata": {},
   "source": [
    "Use a train and test set."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "414168ba-5ceb-4388-8ba1-c75c025746b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "xtrain, xtest, ytrain, ytest, ytrain_n, ytest_n = train_test_split(X, y, yn, test_size=0.2, shuffle=True, random_state=13)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a6192bd-375f-428d-b94f-37cd77a4b241",
   "metadata": {},
   "source": [
    "## Train the classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0686c394-8a18-4c7f-91a6-7a768732d955",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "XGB trained in 0.623908281326294 seconds\n"
     ]
    }
   ],
   "source": [
    "params = {\n",
    "    \"n_estimators\": 20,\n",
    "    \"eval_metric\": \"error\",\n",
    "    \n",
    "    \"tree_method\": \"hist\",\n",
    "    \"seed\": 135,\n",
    "    \"max_depth\": 4,\n",
    "    \"learning_rate\": 0.4\n",
    "}\n",
    "model = xgb.XGBClassifier(**params)\n",
    "\n",
    "t = time.time()\n",
    "model.fit(X, y)\n",
    "print(f\"XGB trained in {time.time()-t} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "41e806a9-5015-40dd-9bf3-9ee5f56bd796",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train acc: 0.996, test acc: 0.995 wrt true labels\n"
     ]
    }
   ],
   "source": [
    "ytrain_pred = model.predict(xtrain)\n",
    "ytest_pred = model.predict(xtest)\n",
    "acc_train = accuracy_score(ytrain, ytrain_pred)\n",
    "acc_test = accuracy_score(ytest, ytest_pred)\n",
    "\n",
    "print(f\"Train acc: {acc_train:.3f}, test acc: {acc_test:.3f} wrt true labels\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3271f1f8-695d-4b83-bab2-6760e3558bd5",
   "metadata": {},
   "source": [
    "# Generate adversarial examples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b7ce0ec8-69a9-4188-a697-212828123232",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# FROM CLASS 0 -> CLASS 1\n",
    "number_of_adv_examples = 6\n",
    "\n",
    "rng = np.random.default_rng(seed=159)\n",
    "subset = rng.choice(range(xtest.shape[0]), number_of_adv_examples)\n",
    "\n",
    "eps = 50\n",
    "\n",
    "def noticks(ax):\n",
    "    for x in ax:\n",
    "        x.set_xticks([])\n",
    "        x.set_yticks([])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "84380740-f95d-4110-a679-c66e886dfdff",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "| XGBOOST's base_score\n",
      "|   base_score diff std      8.999774135166457e-08 OK\n",
      "|   base_score reported      0.4940285\n",
      "|   versus manually detected -0.023887091157375834\n",
      "|   abs err                  0.5179155911573758\n",
      "|   rel err                  1.048351646023207\n",
      "|   (!) base_score NOT THE SAME with relative tolerance 0.0002\n",
      "\n"
     ]
    }
   ],
   "source": [
    "at = veritas.get_addtree(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "142b4cf5-131c-4fc7-b991-a6bb7efa219c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "true_label=2, objective=MAX_OUTPUT done in 0.36ms\n",
      "    RAW:  -4.2180 -> 6.7231\n",
      "          -4.2180 -> 6.7231\n",
      "    PROB: 0.0145 -> 0.9988\n",
      "          0.0145 -> 0.9988\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "true_label=8, objective=MIN_OUTPUT done in 0.44ms\n",
      "    RAW:  4.9177 -> -1.8366\n",
      "          4.9177 -> -1.8366\n",
      "    PROB: 0.9927 -> 0.1375\n",
      "          0.9927 -> 0.1375\n"
     ]
    },
    {
     "data": {
      "image/png": "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Ai1btrSrXym3bt06ANAco+fbb7/Fa6+9hj179qg/Q735XNcrYs7O1dUVUVFRePfdd3Hu3Dn13+Wbb77Btm3bHNZPYGAgBg4ciOXLl+Opp55C27Zt7b5/8eLFKpP+qKgomEwmLFiwAJGRkXBzc6v2Oa43cuRIpKamYu7cuVi8eLHd90QEiqJgxIgRmDVrFubOnYu1a9faffaKCC5fvmx3KxZqOA5Nis6cOYPhw4cjOjoa+/btw9q1a/HII4+gd+/eapvf/e53WLNmDb799lvdjPnxxx/HjBkzAECz1QCU/bVQ/heDUQEBAXjiiSewYsUKDBo0CCNGjEB+fj6WLl2KwsJCzJo1y679Tz/9hK+//lpTaKunbdu2mv85a2rPnj2YN28ehgwZgjZt2mD//v1YtWoVoqOjNZdZx8bGIiQkBN27d0deXh7eeOMNfP/99/jggw/g6+urtjt48CAiIyORmJiIOXPmACi7V8ayZcsQExODzp07Iz8/H9u2bcP27dvx4IMPqlthv2W1WvHMM8/g2WeftftlNGrUKMycORMBAQH44YcfkJGR0SifAVYTnM+199prr+HKlSvIysoCAGzZsgU//vgjgLLCdbPZjIKCAnTo0AEPP/wwevToAW9vb2RkZGDVqlUwm814/vnn7c550003YcCAAZpk1Gq1YsOGDejbt6/dfaMqMnXqVDz88MO444471NioUaPwu9/9Tt2y3rJlC95///3a/Aiahblz52Lr1q245557MHnyZJSWliIlJQU9evTA119/7bB+UlNT0b9/f/Ts2RMTJ05E586dkZOTg3379uHHH3/EV199VenxJpMJaWlpGDt2LG677TaMHj0aAQEBOHfuHD744APcfffdeO2116o1psjISIwdOxZLlizBqVOnEB0dDZvNhr179yIyMhIJCQkIDw/HSy+9hFmzZuHs2bOIiYmBr68vzpw5g82bN+OPf/yj+jlBDcwRhUnlhWfHjx+XUaNGia+vr7Ru3VoSEhLUu8mWKy4uFn9/f93iVJGyoj1XV1fp0qWLI4amslgskpKSIrfccov4+PiIj4+PREZG6hZRpqWlNchjEU6fPi1DhgwRf39/8fDwkG7duklSUpIUFxdr2r788svSrVs38fT0lNatW8vw4cPlyJEjmnblBYuJiYlq7NChQ/LQQw9Jx44dxcPDQ7y9veW2226ThQsXisVi0R1bamqqtG/fXq5evWoXt1gsMm3aNPH395fQ0FB58803a/UzaAw4nx0nNDS0wuLS8sdrFBcXy9NPPy29evUSk8kkbm5uEhoaKhMmTLB7BEc5ADJgwABNfOvWrQLA0GX8H3zwgfj4+EhWVpbme0lJSRISEiJt27aVl19+ubpvudnavXu3REREiLu7u3Tu3FmWLVumKUqu7SX5IiLfffedPP744xIcHCxubm7Srl07GTZsmHrLEpH/FlofOnRId6y7du2SqKgoMZvN4unpKeHh4TJu3Di74vy4uDjx9vbWHKt3l+7S0lJ55ZVXpFu3buLu7i4BAQEydOhQOXz4sF27TZs2Sf/+/cXb21u8vb2lW7duEh8fLydPntQdZ2NUWFgoubm5Fb6u/4x0Ng5Nii5evGio/bx58yQsLMzu/hHlLl68KC1atNDcG6I+3XLLLer9S6j54XwmItIqLCyU4EDXSq+kCw4OdurEqEHuZT916lQUFBTgrbfe0nxv9erVsFqtGDt2bAOMDNi6dStOnTql2YIgqgjnMxE1ByUlJcj+yYozh0Px87dhmteZw6HIzs5GSUlJQw+1xur0kvyK+Pj44KeffrKL7dy5E8ePH8f8+fMRExNjd6v1+hQdHW3oEmmicpzPRNScePkIvHy0V59a6uGK1LrWIEmRnnnz5uGzzz7D3XffrV7lQ+SsOJ+JqKmyiFU3AbKIrQFG41iKSBNI7YiIiKhO5eXlwWw244cTITD5aqtv8vJtCO2WhdzcXJhMpgYYYe01mpUiIiIiavxKYYOlgrizY1JEREREhllFYNXZZNKLORtDSZHNZkNWVhZ8fX01d0Emqg4RQX5+PkJCQiq9Q3dd4VwmR+FcpqakOvPZAoEFOjVFOjFnYygpysrKQocOHep6LNSMnD9/Hu3bt6/3fjmXydE4l6kpMTKfrVL20os7O0NJUfljI86fP++0xVPUOOTl5aFDhw52jyKpT5zL5CiNZS63n/scXDw9G2QM1HTYiorwY+JLhuZzKRRYoF2dLNWJORtDSVH50qzJZOIvEnKIhlru51wmR2vouezi6cmkiBzGyHy2iAKLaNvpxZwNC62JiIjIMCsUWHVWhfRizoZJERERERlmERdYdJ4SZmkuNUVEREREAGCFC6zQJkXWBhiLozEpIiIiIsNKK1gpKuVKERERETUnFnGFRVx14s6/VsSkiIiIiAxjoTURERERKlspaoDBOBiTIiIiIjLMVkGhta25POaDiIiICAAs0qKClSJunxEREVEzYhUFVp0ESC/mbJgUERERkWFcKSIiIiICYIELSvSSItYUERERUXNigwtsuoXW2pizYVJEREREhlnEFS10t8+4UkRERETNiFVcYNV5zIdezNkwKSIiIiLDuFJEREREBKBUWsAi2vSBD4Qljf/85z+aWFJSkm7bjz/+WBObNWuWJjZ9+nRNrE2bNtUfHDV7hYWFunEvLy9NjHOZGjPvTrm68atnzfU8kuanKT/7zPk3AImIiKjeWMRFff6Z/at6KUVSUhJuv/12+Pr6IjAwEDExMTh58qRdm6KiIsTHx6NNmzbw8fHByJEjkZOT48i3Y4dJERERERlmE5cKX9Wxe/duxMfHY//+/di+fTssFguGDBmCq1evqm2mTp2KLVu24J///Cd2796NrKwsjBgxwtFvScXtMyIiIjKs9NeVIW3cVq3zbN261e7r1atXIzAwEIcPH8a9996L3NxcrFy5EuvWrcN9990HAFi1ahVuuukm7N+/H3379q35m6gAV4qIiIjIsPJL8vVeAJCXl2f3Ki4uNnTe3NyyOjE/Pz8AwOHDh2GxWDB48GC1Tbdu3dCxY0fs27fPwe+qDFeKDCgoKNCNjxw5UhPbs2ePJlZUVKR7vKJoi9L++te/amI7d+7UxN577z3dcwYFBenGiQDAarXqxqOiojQxzmVqzFhQ3XAs4goX3Uvyy1aKOnToYBdPTEzEnDlzKj2nzWbDM888g7vvvhs333wzACA7Oxvu7u5o1aqVXdugoCBkZ2fX/A1UgkkRERERGVYqrnCtZPvs/PnzMJlMatzDw6PKc8bHx+Po0aP45JNPHDfQGmBSRERERIZZRYFVdC7J/zVmMpnskqKqJCQk4P3338eePXvQvn17NR4cHIySkhJcuXLFbrUoJycHwcHBNX8DlWBNERERERlmtbmiVOdltWlXjyojIkhISMDmzZuxc+dOhIWF2X0/IiICbm5u2LFjhxo7efIkzp07h379+jnkvVyPK0VERERkmKNu3hgfH49169bhvffeg6+vr1onZDab4eXlBbPZjAkTJmDatGnw8/ODyWTCU089hX79+tXJlWcAkyIiIiKqhlKbC1x0VoVKbfoXclQkLS0NADBw4EC7+KpVqzBu3DgAwKJFi+Di4oKRI0eiuLgYUVFRWLp0aY3GbQSTouuUXxL4W2PGjNFtu337dkPnjIuL041ff+dOADhw4IAmdvDgQU3s3LlzuufkFTtUjnOZiOqCRVyg6Nyosbp3tBYDD5D19PREamoqUlNTq3XummJSRERERIZVdPfq6t7RujFiUkRERESGWeGCUp0EyNoErt1iUkRERESG2USBTeeSfL2Ys2FSRERERIaV2lyh6BZaV++S/MaISdF1Zs6cqYld/9C6cm5ubprYkiVLNLFJkybpHv/aa69pYnrFqXoWLVqkG1+3bp2h46np41wmorpggwKbzuX3ejFnw6SIiIiIDCu1uUCxaeuHSnVizoZJERERERnGpIiIiIgIgEB/q6zquw41fkyKiIiIyLBSmwvAlSLndvnyZU0sISFBE6uoEFXP9OnTNbGKClEdzWw210s/1PhwLhNRQ+Il+UREREQArBXUFFm5UkRERETNSam4ADp3tNa7y7WzYVJEREREhokoEJ2tMr2Ys2FSRERERIZx+4yIiIgIZStCekXVXClqhPSuzAGA8ePHa2JbtmypVV8hISG1Oj4zM7PGxz7xxBO16psaP85lImqMrFAAnQTIysd8EBERUXPCmiIiIiIiAFabAth0Vop0Ys6GSREREREZZqug0NrGQmsiIiJqTmyiQOEdrZ3D7t27deO1LUQ16qefftLENm3apNt24cKFdT0ccmKcy8aI6D+GUlGc/wOamhdpUcFcLm1cc9lmAxSdrTKbrQEG42BNLikiIiKiusNCayIiIiJw+4yIiIiojE2B6F1pxqvPiIiIqDkRKXvpxZ0dkyIDYmNjdePfffedJjZ48GBNLCMjQ/f42hSCpqen68b17kzs5+eniXl5edW4b3JenMtEjVdjK6iuiNhcIDqX3+vFnA2TIiIiIjKMK0VEREREAKSCmiLdOiMnw6SIiIiIqqcJrArpYVJEREREhnGlqJnbuHFjQw9BY8mSJYbj77zzjiYWExPj6CGRE+BcJqJaE6XspRd3ckyKiIiIyDiB/vZZE9hSY1JEREREhnH7jIiIiAjgShERERERACg2BYrOqpBezNkwKSIiIiLjbIr+c86YFDU+PXr00I136NBBEzt//nxdD6dSd911lyY2bNgwTez48eOa2Nq1a+tkTNR4ONNcHjt2rCZ20003aWKc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",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "true_label=8, objective=MIN_OUTPUT done in 0.38ms\n",
      "    RAW:  6.0362 -> -2.8642\n",
      "          6.0362 -> -2.8642\n",
      "    PROB: 0.9976 -> 0.0540\n",
      "          0.9976 -> 0.0540\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "true_label=2, objective=MAX_OUTPUT done in 0.35ms\n",
      "    RAW:  -4.8124 -> 6.4438\n",
      "          -4.8124 -> 6.4438\n",
      "    PROB: 0.0081 -> 0.9984\n",
      "          0.0081 -> 0.9984\n"
     ]
    },
    {
     "data": {
      "image/png": "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LDwml1FJCo/VOKoYubw8MokOERERlR1ndIiIiMh1mX/d1OJOiIkOERERacZLV0REROSydGaBzqzMatRizoCJDhEREWnHBQOd065duxSxH374QRHr1auXItahQ4eH0ieiB8GxTEQVicXIRERE5LKY6BAREZHLYjEyERERuS6xMXvDRIeIiIgqPZGiTS3uhB7pRMfT01MRmzZtWgX05OH6+OOPFbGbN2+qto2KilLEevbs6fA+kWNxLCtxLBM9HKzRISIiIpfFRIeIiIhcFhMdIiIicllcGZmIiIhcF1dGrjzUCjhr1qypeX+TyaSIXb16VfP+q1evVsTy8vI07btixQrNfQoPD1fEPDzU/+lHjx6t6fzkXLSO5ZycHNX9fX19FTGOZXJm9/q1VY37bTlezj159HBGh4iIiFxWZVsw0K2iO0BERESVR3Exstpmjy+//BK9evVCZGQkdDodtm/fbvW+iOD1119HtWrV4OPjg/j4eFy6dMnu/jLRISIiIu1MYnuzw7179/D4448jNTVV9f2FCxfinXfewYoVK3D8+HH4+fkhISFB82XxYrx0RURERJrpYOPSlZ3H6d69O7p37676nojg7bffxmuvvYbnnnsOAPD3v/8d4eHh2L59OwYOHKj5PJzRISIiIs2Ki5HVNke5cuUKMjMzER8fb4kFBgaibdu2OHr0qF3HemRmdMLCwhQxtbs6GjdurIh16NBB9ZiFhYWK2J49ex6gd/8TFBSkiLVtq7y74JlnnlHdPzExURHr2LGjIhYQEGB/58gpcCxb41h+NPHuqgpUyu3l2dnZVmFvb294e3vbdYrMzEwAyjstw8PDLe9pxRkdIiIi0kxnEpsbAERHRyMwMNCyJScnV2h/H5kZHSIiIio7nQh0Kk8qL46lp6fDYDBY4vbO5gBAREQEACArKwvVqlWzxLOystCsWTO7jsUZHSIiItLOLLY3AAaDwWp7kESndu3aiIiIwP79+y2x7OxsHD9+HHFxcXYdizM6REREpJmjVka+e/cuLl++bHl95coVnD59GsHBwahRowbGjx+PuXPnIiYmBrVr18aMGTMQGRmJ3r1723WeRybRUSvC/OabbxQxtfv5t27dqnrMqKgoRWzMmDGa+zRixAhFLDAwUBGLjo7WfExyfRzLRFSRHPX08q+//hqdO3e2vJ44cSKAohsR1q1bh6lTp+LevXv485//jNu3b6NDhw7YvXs39Hq9Xed5ZBIdIiIicoDfXKZSxO3QqVMniEqtTzGdToc5c+Zgzpw59vbQChMdIiIi0qy0YmRnw0SHiIiItDPbeNwDn15ORERElR1ndCqRevXqKWJLlizRFCNyJhzLRFRuzKJeecwZHSIiIqrsdCaBTuUZEDo7n15eXpjoEBERkXYiRZta3Akx0SEiIiLtzDYW0jHbuZBOOWGiQ0RERNqZAehsxJ0QEx0iIiLSTGc2Q6cyo6PjjA4RERFVeiYzVKdvTEx0iIiIqNKzUYyscieWM2CiQ0RERNqZzICwGJmIiIhckdhIdNRiToCJDhEREWnHGR0iIiJyWVwwkIiIiFyWWaB61xWfdUVERESVnskEiEkZN6vEnAATHSIiItLOFS9dya+dz87OfqidIddXPIakgv5DcCyTozjLWC6E0VmXL6FKpBBGANrGs5hMEJUZHanMMzo5OTkAgOjo6IfaGXp05OTkIDAwsELOC3Ask+NU9Fj+CjvL/dzkujSNZxH1epzKPKMTGRmJ9PR0BAQEQKdTe5IXkTYigpycHERGRlbI+TmWyVE4lsmV2DWeTSZApzJ7o1a34wQ0JTpubm6Iiop62H2hR0RFfPstxrFMjsSxTK5E63gWkwmikuioXc5yBm4V3QEiIiKqRIqLkdW2B5CamopatWpBr9ejbdu2+Ne//uXQ7jLRISIiIu1M5qLLV4rN/pWRN23ahIkTJ2LmzJk4efIkHn/8cSQkJODatWsO6y4THSIiItJMzGJzs9df//pXjBgxAkOHDkXDhg2xYsUK+Pr64v3333dYf5noEBERkWZiMtnc7FFQUIC0tDTEx8dbYm5uboiPj8fRo0cd1l8uGEhERESaFUq+6kM9i9fiuX+dMm9vb3h7eyva37hxAyaTCeHh4Vbx8PBwXLhwwWH9ZaJDREREpfLy8kJERAS+yrS9dpO/v79inbKZM2di1qxZD7l3tjHRISIiolLp9XpcuXIFBQUFNtuIiGJdJ7XZHAAICQmBu7s7srKyrOJZWVmIiIgoe4d/xUSHiIiINNHr9dDr9Q45lpeXF1q2bIn9+/ejd+/eAACz2Yz9+/dj9OjRDjkHwESHiIiIKsjEiRORmJiIVq1aoU2bNnj77bdx7949DB061GHnYKJDREREFeL555/H9evX8frrryMzMxPNmjXD7t27FQXKZaGTinr0LhEREdFDxnV0iIiIyGUx0SEiIiKXxUSHiIiIXBYTHSIiInJZTHSIiIjIZTHRISIiIpfFRIeIiIhcFhMdIiIicllMdIiIiMhlMdEhIiIil8VEh4iIiFwWEx0iIiJyWf8ffdySmsqSaLsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "true_label=2, objective=MAX_OUTPUT done in 0.34ms\n",
      "    RAW:  -3.3363 -> 7.3444\n",
      "          -3.3363 -> 7.3444\n",
      "    PROB: 0.0343 -> 0.9994\n",
      "          0.0343 -> 0.9994\n"
     ]
    },
    {
     "data": {
      "image/png": "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ouIRleMPQUFB8PLysh6xsbGql8jJycHx48fRp08fa0yv16NPnz44cuRIaba+QFVmTRERERGVnBSw+yw/lpSUBE9PT2vc1dVV9To3btyA2WyGv7+/Tdzf3x9nz561Y4u1qzJJ0fr16zXFXn/9dUXs7bffLlHdnTp1KtH569atU8QGDhyoWtbX17dEdVHFkZSUpBovSV/+85//rHpNd3d3TW1iX6ZH8V2PVarxJ/8+6ZGv+Xijy6rxH/5d/5GvSRqJLu9QiwPw9PS0SYocSZVJioiIiMgOHpous4kXg4+PDwwGA1JTU23iqampCAgIeOTmlQTXFBEREZFmRS201srFxQWhoaH49ttvrTGLxYJvv/0WYWFh9m62JhwpIiIiIu3sNFIEAK+99hpGjhyJDh064PHHH8e7776Lu3fvYvTo0SVt5SNhUkRERESa6Sw66FRGhdRiRRkyZAjS0tIwZ84cpKSkoF27dti7d69i8XVZYVJERERE2ll06s85e8Rnn02YMAETJkwoYaPso9IlRadOnVKN79q1SxETldtvLl26VBHLyclRveY777yjqU2zZs1SjavVr+bnn39WxG7evKlaljt2Ko/bt2+rxtmXydGUZJdZQbjLrBzZcfqsoql0SRERERGVIssfh1rcwTEpIiIiIu2KuE+RI2NSRERERJrpLHmHWtzR8T5FRERERKiEI0Vr165Vjd+4cUMR0+m0DfW99957qvHMzExFTO3eCnFxcarnq9WvtU1U+ZV3X16xYoUixr5MjqjJiB8VsQt/aV8OLakcdFLAlnxOnxEREVGVwoXWRERERIBO8g61uKNjUkRERETacaSIiIiIiCNFDuWLL77QXDYwMFARe+yxxxSxL7/8UvX8jRs3KmI7d+5UxAq6i7BWjRs3VsQ8PT1LdE2q+NiXieyDi6rtzM6P+ahIKl1SRERERKWnMt+niEkRERERaVfA9BmffUZERERVCxdaExEREXGhNREREVEegfpUGZOiimfKlCmq8ddff10Ri4qK0lQuMjJS9ZqnT59WxDIyMopoYfHt2LFDEatdu7bd66HyY7Eox53Zl8kROTmbFbFck6EcWkKlhSNFREREREDeiJDa+iEmRURERFSVcEs+ERERETh9RkRERJSHW/Idh4+Pj+ay33zzjabYmTNnStSm4hg8eLAiFhISUmb1U/nQ6/WKGPsy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",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "true_label=2, objective=MAX_OUTPUT done in 0.55ms\n",
      "    RAW:  -4.2530 -> 7.6476\n",
      "          -4.2530 -> 7.6476\n",
      "    PROB: 0.0140 -> 0.9995\n",
      "          0.0140 -> 0.9995\n"
     ]
    },
    {
     "data": {
      "image/png": "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msc8ffq0KjZv3jxVLC0tTXP/3r17q2Jdu3bVbEtkw1wmoprk7JGilStXYvHixcjKysI999yD5ORk3H///VXr5B3iA2GJiIhIP8H/1hXdut1BUbR582ZMnToVSUlJ+O6773DPPfcgPj4eV65ccWaPdWNRRERERLrZLsnX2gAgPz/fbisuLnZ4rHfeeQfjx4/H2LFj0bFjR6xevRoNGzbEBx984KJPY49FEREREelmmz7T2gAgMjISgYGByrZw4ULN45SUlODw4cPo16+fEjMajejXrx8OHDjgio+iUm/WFBEREZETVHBJfmZmJgICApRwgwYNNA9z9epVWCwWhIWF2cXDwsJw4sQJJ3W2cupNUfTCCy+oYoWFhapYSkqK7mO2b99eFdN6dMhTTz2luf+XX36pir377ruq2PTp03X3ieo+5jIR1aSKFloHBATYFUXupN4URUREROQETrp5Y5MmTWAymZCdnW0Xz87ORnh4+B13ryq4poiIiIh0q2ihtV5eXl6IjY3Frl27lJjVasWuXbvQo0cPJ/daH44UERERkW7OvE/R1KlTMXr0aHTt2hX3338/3n33Xdy4cQNjx46tekfvAIsiIiIi0s+Jzz57/PHHkZOTgzfeeANZWVno0qULdu7cqVp87Sp1rii6fv26Zlzrngdbt251+vm3b9+uinXv3l2z7YULF1SxtWvXqmITJ05UxXx8fO6gd+ROmMtqRUVFqpi3t7fu/Ylqi5uRpapYw0z3+JNs+GXTit+JiRMnav5uqAnu8RMgIiKiWsHR+qHKrimqjVgUERERkX58ICwRERHRLwuttUaKWBQRERFRfcLpMzeitTgUgOaNoB544IEqneudd95RxbQWvGrd7RcAcnNzVbHHHntMFcvIyFDF4uLi9HSR3BhzWY2LqqmucJdF1Zo4fUZERETEkSIiIiKiMhwpIiIiIuJIEREREREAwGAVGKzqYSGtmLthUURERES6OfPZZ7VNnSuKevbsqRnPyspSxU6fPq2KXbt2TRXbsmWL5jE//vhjVezTTz9VxXr16qW5v5aOHTuqYtu2bVPFePVZ3ffEE09oxseNG6eKVTWXFy9erIoxl8lZmi/crxm/8Jrzf/Yfv6DO5cdWT3f6eeozTp8RERERAVxoTURERARwpIiIiIhIURfWD2lhUURERES68eozN9KuXTvN+Pz581Wx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",
      "text/plain": [
       "<Figure size 700x210 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "for i in subset:\n",
    "    base_example = xtest[i, :]\n",
    "    true_label = ytest_n[i]\n",
    "\n",
    "    heur = veritas.HeuristicType.MAX_OUTPUT if true_label == class0 \\\n",
    "           else veritas.HeuristicType.MIN_OUTPUT\n",
    "\n",
    "    config = veritas.Config(heur)\n",
    "    config.ignore_state_when_worse_than = 0.0\n",
    "\n",
    "    prune_box = [veritas.Interval(max(0.0, x-eps), min(255, x+eps)) for x in base_example]\n",
    "    search = config.get_search(at, prune_box)\n",
    "\n",
    "    tstart = time.time()\n",
    "    while search.num_solutions() == 0:\n",
    "        if search.steps(100) == veritas.StopReason.NO_MORE_OPEN:\n",
    "            break\n",
    "    tstop = time.time()\n",
    "\n",
    "    print(f\"true_label={true_label}, objective={str(heur)[14:]}\",\n",
    "          f\"done in {1000*(tstop-tstart):.2f}ms\")\n",
    "\n",
    "    if search.num_solutions() > 0:\n",
    "        sol = search.get_solution(0)\n",
    "        adv_example = veritas.get_closest_example(sol, base_example, eps=1e-3)\n",
    "\n",
    "        # raw scores\n",
    "        base_pred_at = at.eval(np.atleast_2d(base_example))[0,0]\n",
    "        base_pred = model.predict(np.atleast_2d(base_example), output_margin=True)[0]\n",
    "        adv_pred = model.predict(np.atleast_2d(adv_example), output_margin=True)[0]\n",
    "        adv_pred_at = at.eval(np.atleast_2d(adv_example))[0,0]\n",
    "\n",
    "        print(f\"    RAW:  {base_pred_at:.4f} -> {adv_pred_at:.4f}\")\n",
    "        print(f\"          {base_pred:.4f} -> {adv_pred:.4f}\")\n",
    "        \n",
    "        # probabilities\n",
    "        base_prob_at = at.predict(np.atleast_2d(base_example))[0,0]\n",
    "        base_prob = model.predict_proba(np.atleast_2d(base_example))[0,1]\n",
    "        adv_prob = model.predict_proba(np.atleast_2d(adv_example))[0,1]\n",
    "        adv_prob_at = at.predict(np.atleast_2d(adv_example))[0,0]\n",
    "        \n",
    "        print(f\"    PROB: {base_prob_at:.4f} -> {adv_prob_at:.4f}\")\n",
    "        print(f\"          {base_prob:.4f} -> {adv_prob:.4f}\")\n",
    "\n",
    "        fig, ax = plt.subplots(1, 3, figsize=(7, 2.1), width_ratios=[1, 1, 1.25])\n",
    "        noticks(ax)\n",
    "        \n",
    "        ax[0].imshow((base_example).reshape((28,28)), cmap=\"binary\")\n",
    "        ax[0].set_title(f\"p(y={class1}) = {base_prob*100:.1f}%\")\n",
    "        ax[1].imshow((adv_example).reshape((28,28)), cmap=\"binary\")\n",
    "        ax[1].set_title(f\"p(y={class1}) = {adv_prob*100:.1f}%\")\n",
    "        imdiff = ax[2].imshow((adv_example-base_example).reshape((28,28)))\n",
    "        ax[2].set_title(f\"difference\")\n",
    "        fig.colorbar(imdiff, cax=None)\n",
    "        plt.show()\n",
    "    else:\n",
    "        print(\"no adversarial examples found for\", i)\n",
    "    print()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f41242e-022d-46e3-9a0f-92a5e520c10b",
   "metadata": {},
   "source": [
    "## An alternative verification question:\n",
    "\n",
    "Can an image that only has a narrow non-black band in the middle ever get the negative class?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "cfb95593-2d09-42a9-861f-3374685f1384",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Veritas generated an example in 0.47ms, stop_reason=StopReason.NONE\n",
      "AddTreeType.CLF_SOFTMAX\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q7h48SIWLFiAAQMGKLPctfbss89aNLuaiLTH2kFUelW++SjIvHnzcOLECXTs2LHY2dVERPlYO4gsoxMRsXUSREREVHVU+TkfREREpC02H0RERKQpu5vzkZeXhzt37sDDw4N/kZPIRuS/j4cODAyEg0PF+B2FtYPItkpUN8rrHt4VK1ZISEiI6PV6adOmjcVP+UtISCjy4SkMBkO7SEhIKK8SUaDS1g0R1g4Gw17CkrpRLs3H1q1bxcXFRdatWyc///yzjBkzRry8vCQ5ObnY96amptr8wDEYjCeR/zhnLZSlboiwdjAY9hKW1I1yaT7atGkj4eHhyuvc3FwJDAyUqKioYt9rNBptfuAYDMaTMBqN5VEiClSWuiHC2sFg2EtYUjesfjE3Ozsbp0+fVv6iIAA4ODggLCwMcXFxZuOzsrJgMplUQURVS0nrBsDaQVSRWb35SElJQW5uLvz8/FTL/fz8kJSUZDY+KioKBoNBieDgYGunRER2rqR1A2DtIKrIbD6NfcaMGTAajUokJCTYOiUiqgBYO4gqLqvfaluzZk04OjoiOTlZtTw5ORn+/v5m4/V6PfR6vbXTIKIKpKR1A2DtIKrIrH7mw8XFBa1atcLBgweVZXl5eTh48CDat29v7d0RUSXAukFUxZR6anoRtm7dKnq9XjZs2CAXL16UsWPHipeXlyQlJRX7Xs5YZzDsJ7S826UsdUOEtYPBsJewpG6UyxNOX375Zdy7dw+zZs1CUlISWrZsif3795tNJiMiyse6QVR12N1ftTWZTDAYDLZOg4gAGI1GeHp62joNi7B2ENkHS+qGze92ISIioqqFzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpis0HERERaYrNBxEREWmKzQcRERFpyurNx5w5c6DT6VTRuHFja++GiCoR1g2iqsWpPDbatGlTHDhw4P/fiVO57IaIKhHWDaKqo1y+3U5OTvD39y+PTRNRJcW6QVR1lMucj2vXriEw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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "blackband = np.zeros(28*28)\n",
    "blackband[0:28*12] = 255.0\n",
    "blackband[28*16:] = 255.0\n",
    "\n",
    "anything = veritas.Interval(0.0, 255.0)\n",
    "black = veritas.Interval.constant(255.0)\n",
    "\n",
    "config = veritas.Config(veritas.HeuristicType.MAX_OUTPUT)\n",
    "config.ignore_state_when_worse_than = 0.0\n",
    "\n",
    "prune_box = [black if x>0 else anything for x in blackband]\n",
    "search = config.get_search(at, prune_box)\n",
    "\n",
    "tstart = time.time()\n",
    "while search.num_solutions() == 0:\n",
    "    stop_reason = search.steps(100)\n",
    "    if stop_reason == veritas.StopReason.NO_MORE_OPEN:\n",
    "        break\n",
    "tstop = time.time()\n",
    "\n",
    "print(f\"Veritas generated an example in {1000*(tstop-tstart):.2f}ms, stop_reason={stop_reason}\")\n",
    "\n",
    "sol = search.get_solution(0)\n",
    "generated = veritas.get_closest_example(sol, blackband, eps=1e-3)\n",
    "\n",
    "print(at.get_type())\n",
    "\n",
    "prob_blackband = at.predict(blackband)[0,0]\n",
    "prob_generated = at.predict(generated)[0,0]\n",
    "\n",
    "fig, ax = plt.subplots(1, 2)\n",
    "ax[0].imshow(blackband.reshape((28, 28)), cmap=\"binary\")\n",
    "ax[0].set_title(f\"p(y=1) = {prob_blackband:.8f}%\")\n",
    "ax[1].imshow(generated.reshape((28, 28)), cmap=\"binary\")\n",
    "ax[1].set_title(f\"p(y=1) = {prob_generated:.8f}%\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "996ed1f2-9f66-4164-af63-c26d2d47cbef",
   "metadata": {},
   "source": [
    "\n",
    "## Another alternative\n",
    "\n",
    "Can we find a positive example with non-white pixels only in the top 10 rows of pixels?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "76be0d94-492d-447e-aa95-583ebc337775",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Veritas generated an example in 0.08ms, stop_reason=StopReason.OPTIMAL\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "We proved that no such example exists!\n"
     ]
    }
   ],
   "source": [
    "allwhite = np.zeros(28*28)\n",
    "whiteband = np.zeros(28*28)\n",
    "whiteband[0:28*10] = 255.0\n",
    "\n",
    "anything = veritas.Interval(0.0, 255.0)\n",
    "white = veritas.Interval.constant(0.0)\n",
    "\n",
    "config = veritas.Config(veritas.HeuristicType.MAX_OUTPUT)\n",
    "#config.ignore_state_when_worse_than = 0.0\n",
    "\n",
    "prune_box = [anything if x>0 else white for x in whiteband]\n",
    "search = config.get_search(at, prune_box)\n",
    "\n",
    "tstart = time.time()\n",
    "while search.num_solutions() == 0:\n",
    "    stop_reason = search.steps(100)\n",
    "    if stop_reason == veritas.StopReason.NO_MORE_OPEN:\n",
    "        break\n",
    "tstop = time.time()\n",
    "\n",
    "print(f\"Veritas generated an example in {1000*(tstop-tstart):.2f}ms,\",\n",
    "      f\"stop_reason={stop_reason}\")\n",
    "\n",
    "if search.num_solutions() > 0:\n",
    "    sol = search.get_solution(0)\n",
    "    generated = veritas.get_closest_example(sol, allwhite, eps=1e-3)\n",
    "    \n",
    "    prob_whiteband = at.predict(whiteband)[0,0]\n",
    "    prob_generated = at.predict(generated)[0,0]\n",
    "    \n",
    "    fig, ax = plt.subplots(1, 2)\n",
    "    ax[0].imshow(whiteband.reshape((28, 28)), cmap=\"binary\")\n",
    "    ax[0].set_title(f\"p(y=1) = {prob_whiteband*100:.1f}%\")\n",
    "    ax[1].imshow(generated.reshape((28, 28)), cmap=\"binary\")\n",
    "    ax[1].set_title(f\"p(y=1) = {prob_generated*100:.1f}%\")\n",
    "    plt.show()\n",
    "    \n",
    "if search.num_solutions() == 0 or stop_reason == veritas.StopReason.OPTIMAL \\\n",
    "        and prob_generated < 0.5:\n",
    "    print(\"We proved that no such example exists!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f966c8f6-d517-4ec3-aeb3-18c3cfa5258e",
   "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
}
