{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "48761a06-f564-4757-a481-87ed259a71fc",
   "metadata": {},
   "source": [
    "# Debugging the Data of a Soccer XG model\n",
    "\n",
    "The task is to predict the probabiliy a shot resulting in a goal given:\n",
    " - x-coordinate of shot\n",
    " - y-coordinate of shot\n",
    " - bodypart=foot\n",
    " - bodypart=head\n",
    " - bodypart=other\n",
    " - prev_action=shot."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20f18abf-fb41-4f86-8fb8-3b2f041dbfd4",
   "metadata": {},
   "source": [
    "## Preliminaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cca1befc-0edf-4486-93f9-753c0ea499e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "eda4d05a-75d9-4e21-aa54-7fa3245f19c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import joblib\n",
    "import veritas\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.patches import Rectangle\n",
    "import xg_penalty_example_util as matplotsoccer\n",
    "from IPython.core.display import HTML\n",
    "\n",
    "columns = [\"x\", \"y\", \"foot\", \"head\", \"other\", \"prev_action\"]\n",
    "icolumns = { k: i for i, k in enumerate(columns) }\n",
    "field = matplotsoccer.spadl_config\n",
    "\n",
    "pb_x1 = field[\"origin_x\"] + field[\"length\"] - field[\"penalty_box_length\"]\n",
    "pb_x2 = field[\"origin_x\"] + field[\"length\"]\n",
    "pb_y1 = (field[\"origin_y\"] + field[\"width\"]) / 2 - field[\"penalty_box_width\"] / 2\n",
    "pb_y2 = (field[\"origin_y\"] + field[\"width\"]) / 2 + field[\"penalty_box_width\"] / 2\n",
    "\n",
    "def minmax_normalize(x):\n",
    "    m, M = min(x), max(x)\n",
    "    return (np.array(x)-m) / (M-m)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bbdcf322-1cd2-4337-821d-cf15e668a449",
   "metadata": {},
   "source": [
    "## Load a pre-trained model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ce40c931-5aaa-4b26-b9e0-28fc7b1b6285",
   "metadata": {},
   "outputs": [],
   "source": [
    "at_orig = veritas.AddTree.read(\"models/xgb2-xy-basic.json.gz\", compressed=True)\n",
    "splits = {columns[k]: v for k, v in at_orig.get_splits().items()}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4b6db09-0d81-4e3c-8bc9-85b0eeb25a10",
   "metadata": {},
   "source": [
    "## Add two additional trees to the ensemble that penalize the output\n",
    "\n",
    "... when ...\n",
    "\n",
    "1. the *bodypart* feature with possible values *foot*, *head*, *other* has no option or multiple options selected (one-hot encoding)\n",
    "2. the action happens inside of the penalty box"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9d8f5154-44f4-403d-9b79-6dabc2ec5c26",
   "metadata": {},
   "outputs": [],
   "source": [
    "# One-hot constraint penalty tree\n",
    "at = at_orig.copy()\n",
    "t = at.add_tree()\n",
    "t.split(t[\"\"], icolumns[\"foot\"], 1.0)\n",
    "for p in [\"l\", \"r\"]:\n",
    "    t.split(t[p], icolumns[\"head\"], 1.0)\n",
    "for p in [\"ll\", \"lr\", \"rl\"]:\n",
    "    t.split(t[p], icolumns[\"other\"], 1.0)\n",
    "for p in [\"lll\", \"lrr\", \"rlr\", \"rr\"]:\n",
    "    t.set_leaf_value(t[p], 0, -1000.0)\n",
    "\n",
    "# In penalty box penalty tree\n",
    "t = at.add_tree()\n",
    "t.split(t[\"\"], icolumns[\"y\"], pb_y1)\n",
    "t.split(t[\"r\"], icolumns[\"y\"], pb_y2)\n",
    "t.split(t[\"rl\"], icolumns[\"x\"], pb_x1)\n",
    "t.set_leaf_value(t[\"rlr\"], 0, -2000.0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "057b1af9-7297-4460-819b-ee81bebfa697",
   "metadata": {},
   "source": [
    "## Test the one-hot encoding penalty tree\n",
    "\n",
    "Take a example with no value for *bodypart*."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cb8cd9ca-6f12-4760-b14e-bc015de7b494",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Invalid one-hot encoding: [-1003.37304335]\n",
      "  Valid one-hot encoding: [-3.36736452]\n"
     ]
    }
   ],
   "source": [
    "#                                     v  v  v\n",
    "test_example = np.array([100.0, 10.2, 0, 0, 0, 0])\n",
    "print(\"Invalid one-hot encoding:\", at.eval(test_example)[0])\n",
    "\n",
    "test_example[icolumns[\"foot\"]] = 1.0\n",
    "print(\"  Valid one-hot encoding:\", at.eval(test_example)[0])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7b7e1a5c-bb07-477b-8b1a-78b2a8a44d0f",
   "metadata": {},
   "source": [
    "## Test the penalty box penalty tree\n",
    "\n",
    "Evaluate the tree for a grid of points covering the full soccer field."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0fb1e7e0-9b55-4ea1-9d23-fc69c838ed42",
   "metadata": {
    "editable": true,
    "slideshow": {
     "slide_type": ""
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Node(id=0, split=[F1 < 13.85], sz=7, left=1, right=2)\n",
      "├─ Leaf(id=1, sz=1, value=[0])\n",
      "├─ Node(id=2, split=[F1 < 54.15], sz=5, left=3, right=4)\n",
      "│  ├─ Node(id=3, split=[F0 < 88.5], sz=3, left=5, right=6)\n",
      "│  │  ├─ Leaf(id=5, sz=1, value=[0])\n",
      "│  │  └─ Leaf(id=6, sz=1, value=[-2000])\n",
      "│  └─ Leaf(id=4, sz=1, value=[0])\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAf4AAAEVCAYAAAAB7IdkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA03UlEQVR4nO3dfViUZaI/8O8zAzOANPjC8FKSgprkK4pJsG1hS4177NdynY2fa9ee1DXbdXM3ha2LzAXL43HNfDvlxnZ8rdZf6NrltqvHRNRztqRcRSoNLfMFQwcxjVEUBmae3x+3PDKC8Dw6w8zDfD9dzxXzzM1wOzDznft+7hdJlmUZREREFBQM/q4AERERdR0GPxERURBh8BMREQURBj8REVEQYfATEREFEQY/ERFREGHwExERBREGPxERURBh8BMREQWRELUFJUnyZT2IiKgb4aKwgUt18AMAnhoFhBp9VBUiHWlyAW8fFF/zdUF0XevXBgUkbcEfauQbHNGN+LogIh3hNX4iIqIgwuAnIiJqx8qVK9G/f3+EhYUhLS0N+/bt83eVvILBT0REdIPi4mLk5uaisLAQ5eXlGDlyJGw2G86dO+fvqt02Bj8REdENli5diunTp2Pq1KkYMmQIioqKEBERgTVr1vi7ardN2+A+IiKiANHQ0ACn06m6vCzLbaamm81mmM1mj3NOpxMHDhzAiy++qJwzGAzIyspCWVnZ7VU6ADD4iYhIdxoaGhDexwJcaVL9PZGRkbh8+bLHucLCQsybN8/j3Pnz5+FyuRAbG+txPjY2FkeOHLnlOgcKBj8REemO0+kUof/UKMCkYjqt04XLbx/E6dOnYbFYlNM3tvaDAYOfiIh0SwoLgWTqPMpkgwQZgMVi8Qj+9kRHR8NoNKKmpsbjfE1NDeLi4m6nugGBg/uIiEi3JEmCZFBxaFh23mQyITU1FaWlpco5t9uN0tJSpKen++Kf0aXY4iciIt1qCfZOqSnTSm5uLiZPnowxY8Zg7NixWL58Oerr6zF16tRbrGngYPATEZFuSZLK1rzGjeYmTpyI2tpaFBQUwG63IyUlBdu3b28z4E+PGPxERKRbvmrxA8DMmTMxc+bMW6hVYGPwExGRbvky+LsrBj8REekWg187Bj8REekWg187Bj8REekWg187Bj8REekWg187Bj8REemWwWCAZOx8LTrZwPXqWjD4iYhIt9ji147BT0REusXg147BT0REusXg147BT0REusXg147BT0REuiUZoDL4fV8XvWDwExGRfqls8cts8SsY/EREpFtqu/pV9QoECQY/ERHpFoNfOwY/ERHpliRJkCQVwa+iTLBg8BMRkW5JksoWP4NfweAnIiLdYle/dgx+IiLSLQa/dgx+IiLSLYNBHJ0X9HlVdINPBRER6ZZRklQfvnDy5ElMmzYNiYmJCA8Px4ABA1BYWAin0+lRpmUQYuvjk08+8XisTZs2ITk5GWFhYRg+fDi2bdvmkzqzxU9ERLplMhpgULEtr1tFmVtx5MgRuN1u/OlPf8LAgQNx6NAhTJ8+HfX19Xjttdc8yu7cuRNDhw5Vbvfp00f5eu/evZg0aRIWLlyIxx57DBs2bEB2djbKy8sxbNgwr9aZwU9ERLplMACqMt1H/dvjx4/H+PHjldtJSUk4evQo3nzzzTbB36dPH8TFxbX7OCtWrMD48ePx/PPPAwDmz5+PkpISvPHGGygqKvJqndnVT0REuqW1q9/hcHgcjY2NXq9TXV0devfu3eb8448/jpiYGDzwwAP44IMPPO4rKytDVlaWxzmbzYaysjKv14/BT0REuqU1+BMSEhAVFaUcCxcu9Gp9jh07htdffx2//OUvlXORkZFYsmQJNm3ahK1bt+KBBx5Adna2R/jb7XbExsZ6PFZsbCzsdrtX6wewq5+IiHTMaJBg1LAt7+nTp2GxWJTTZrO53eL5+flYtGhRhw9ZWVmJ5ORk5XZ1dTXGjx+PnJwcTJ8+XTkfHR2N3Nxc5fZ9992HM2fOYPHixXj88cc7r7uXMfiJiEi3jACMGgbsWywWj+C/mby8PEyZMqXDMklJScrXZ86cwbhx45CRkYG33nqr08dPS0tDSUmJcjsuLg41NTUeZWpqam46JuB2MPiJiEi3tLb41bJarbBararKVldXY9y4cUhNTcXatWthULGwQEVFBeLj45Xb6enpKC0txaxZs5RzJSUlSE9P11RvNRj8RESkWwaVc/RlH83jr66uRmZmJvr164fXXnsNtbW1yn0trfX169fDZDJh1KhRAID3338fa9aswapVq5Syzz33HB566CEsWbIEEyZMwHvvvYf9+/er6j3QisFPRES6pbbFL/toyd6SkhIcO3YMx44dQ9++fT1/piwrX8+fPx+nTp1CSEgIkpOTUVxcjCeeeEK5PyMjAxs2bMDcuXMxZ84cDBo0CFu2bPH6HH4AkOTWNeuooCQB08YAoUavV4JId5pcwOr94mu+Loiuu/baUBktt8zhcCAqKgo/WPcEQiJCOy3ffKUJH0/5C+rq6lRd4+/O2OInIiLd8neLX48Y/EREpFtq1+H31TV+PWLwExGRbhklqAz+LqiMTjD4iYhIt9Su1e/mOrUKBj8REemW2q5+N7v6FdqC39nso2oEIFkGmt3i67AQ8bGSiEgNtxtouPZ+GWIAgil0ujgnTEYDQlU0+SUfbcurR9qC/50K39Qi0D01Cogw+bsWRKQXDc3A2wf9XYugYGRXv2bs6iciIt0yQmVXP4Ko16UT2oJ/0ojgafk2ua5/Yg/hR0Ui0qDVe8YfkQRzEO2A7kAzZuNkl/08g8p5/C7O41doC/5QY3CuUBZM1+eI6Pa1es8ww4CwIAr+xi7+t6od3KemTLBgVz8REemW2mv8HNt3HYOfiIh0iy1+7Rj8RESkW2LlPnXlSGDwExGRbhkkCQYVrXk1ZYIFg5+IiHTLoLLFz0H91zH4iYhItwySulBn8F/H4CciIt3iNX7tGPxERKRbBoMEg4rmvJoywYLBT0REusUWv3Zc0oCIiHSr5Rq/msNX+vfvD0mSPI4//OEPHmU+//xz/PCHP0RYWBgSEhLw6quvtnmcTZs2ITk5GWFhYRg+fDi2bdvmk/oy+ImISLdaWvxqDl965ZVXcPbsWeX4zW9+o9zncDjw6KOPol+/fjhw4AAWL16MefPm4a233lLK7N27F5MmTcK0adNw8OBBZGdnIzs7G4cOHfJ6XdnVT0REuhUiSQhVs0mPj+fx33HHHYiLi2v3vj//+c9wOp1Ys2YNTCYThg4dioqKCixduhTPPPMMAGDFihUYP348nn/+eQDA/PnzUVJSgjfeeANFRUVerStb/EREpFtau/odDofH0djY6JV6/OEPf0CfPn0watQoLF68GM3Nzcp9ZWVlePDBB2EyXd/d1maz4ejRo7h48aJSJisry+MxbTYbysrKvFK/1tjiJyIi3dK6Vn9CQoLH+cLCQsybN++26vDb3/4Wo0ePRu/evbF37168+OKLOHv2LJYuXQoAsNvtSExM9Pie2NhY5b5evXrBbrcr51qXsdvtt1W39jD4iYhIt7Qu4HP69GlYLBblvNlsbrd8fn4+Fi1a1OFjVlZWIjk5Gbm5ucq5ESNGwGQy4Ze//CUWLlx408f3JwY/ERHpltbpfBaLxSP4byYvLw9TpkzpsExSUlK759PS0tDc3IyTJ09i8ODBiIuLQ01NjUeZltst4wJuVuZm4wZuB4OfiIh0y2AQh5pyWlitVlit1luqU0VFBQwGA2JiYgAA6enpeOmll9DU1ITQ0FAAQElJCQYPHoxevXopZUpLSzFr1izlcUpKSpCenn5LdegIB/cREZFutVzjV3P4QllZGZYvX47PPvsMx48fx5///GfMnj0bP//5z5VQf/LJJ2EymTBt2jQcPnwYxcXFWLFihcclgueeew7bt2/HkiVLcOTIEcybNw/79+/HzJkzvV5ntviJiEi3JJXX+H01m89sNuO9997DvHnz0NjYiMTERMyePdsj1KOiorBjxw48++yzSE1NRXR0NAoKCpSpfACQkZGBDRs2YO7cuZgzZw4GDRqELVu2YNiwYV6vM4OfiIh0y99L9o4ePRqffPJJp+VGjBiBf/zjHx2WycnJQU5OjreqdlMMfiIi0i1uy6sdg5+IiHRL6zx+YvATEZGOscWvHYOfiIh0y9/X+PWIwU9ERLplkCQYVHTjqykTLBj8RESkWwaVLX529V/H4CciIt0KMRgQomJZPjVlggWDn4iIdMsAlV39YJO/BYOfiIh0S1zj77w1z2v81zH4iYhItzi4TzsGPxER6RaDXzsGPxER6RaDXzsGPxER6Zbh2n9qypHA4CciIt2SVLb4Jbb4FQx+IiLSLXb1a8fgJyIi3TJIBpXT+djV34LBT0REusUWv3bagt/ZDIQab/+nyjLQ7BZfh4UAXEqRiKjLueHGJYj3YhMkSF5Y3a4Brtt+DC0Y/NppC/73vvB+DZ4aBUSYvP+4RN5S7wRq68Vxvl7cbvngCgAbvwBCDOKwmIHoHoD12mFmpxoFrktw49c47u9q3BYGv3ZsahPd6MIVYP+3wH8fBd4uB945CGz/CjhcA7hlICYSuMtyvXxiL3G7TwRwpQk4UA38/Qiw9gCwoQIo+Rr47Kz4wEBEXtVyjV/N4Qt79uyBJEntHv/85z8BACdPnmz3/k8++cTjsTZt2oTk5GSEhYVh+PDh2LZtm0/qrK05kjMMsITd/k9tcgFvH7xWA372oADgcgMnLopwP3tJtNRjegDJVtFyj+4BRJqAllZDkws4fE58fV9fz0tgbhmoa/DsJfjnt8AnVUBib2BoDHCn5fpjEfmJqVXX/h+RBLMX2oK1cCIfVbf9OGoZIKnagMdXm/RkZGTg7NmzHud+//vfo7S0FGPGjPE4v3PnTgwdOlS53adPH+XrvXv3YtKkSVi4cCEee+wxbNiwAdnZ2SgvL8ewYcO8WmdtwR9i8M41/tb45kf+dLkR+PIcUFkLXG0C4u8AHhkI9O8FGG/xTdAgAb3CxXFPtDjnbAa+Oi8+LPztCNAzDBgaK+7n5QDyk9bX9M0wIMwLwe+NDw9aGA0GhBg6zyWjj8aSmUwmxMXFKbebmprw17/+Fb/5zW/arB3Qp08fj7KtrVixAuPHj8fzzz8PAJg/fz5KSkrwxhtvoKioyKt15jsOBafGZqCsCjhaKz7Q3mMVLfHeEb75eaYQYFicCPuzl0TPQlkV8OlpYNSdQEr8rX/QIApiWq/xOxwOj/Nmsxlms9lr9fnggw/w3XffYerUqW3ue/zxx9HQ0IB77rkHL7zwAh5//HHlvrKyMuTm5nqUt9ls2LJli9fq1oLBT8Gn6nvgf44DTW4gvZ/ozjd5uSfrZiRJdPPfaRHX/D+3i/EEJy4A4waIcQJEpJrW4E9ISPA4X1hYiHnz5nmtPqtXr4bNZkPfvn2Vc5GRkViyZAl+8IMfwGAwYPPmzcjOzsaWLVuU8Lfb7YiNjfV4rNjYWNjtdq/VrQWDn4JHYzOw91orPyEKeCgRiPTeJ33NepiA9LuBAb2B3ceBzYeA1LvY+ifSQOsCPqdPn4bFcn1w7s1a+/n5+Vi0aFGHj1lZWYnk5GTl9rfffosPP/wQGzdu9CgXHR3t0Zq/7777cObMGSxevNij1d9VGPxqnHEA/Xr5uxZ0O1q38h9KFK38QBlfEhMJPDEM2F/N1n93Icv+rkHQ0Nrit1gsHsF/M3l5eZgyZUqHZZKSkjxur127Fn369FEV5mlpaSgpKVFux8XFoaamxqNMTU3NTccE3A4GvxrbvwIy+gHDvf8LIB+TZeDgGWDft4HRyr8ZowFISxBTA3cfB94/BGQNFLMASF/cMvDxKX/XImj4alS/1WqF1WpVXV6WZaxduxZPPfUUQkNDOy1fUVGB+Ph45XZ6ejpKS0sxa9Ys5VxJSQnS09M11VsNBr8aQ2PFC9npAkbfGTgtReqYLAOfnBZz6MfcJbrRA/13FxMJ/HQYsOsYsONr0fJvmRlAgc/lBkq/Eb021CUMUNni99F0vha7du3CiRMn8PTTT7e5b/369TCZTBg1ahQA4P3338eaNWuwatUqpcxzzz2Hhx56CEuWLMGECRPw3nvvYf/+/Xjrrbe8XlcGvxppCUB4qJiL3eQStwM9QIKdLAP/OCmm6v1AZ701IQYgaxDwPyeAXd+IVQKHxPi7VtSZZrf4sPZtHfCjAcDOb/xdo6AQKJv0rF69GhkZGR7X/FubP38+Tp06hZCQECQnJ6O4uBhPPPGEcn9GRgY2bNiAuXPnYs6cORg0aBC2bNni9Tn8AINfvdS7gFCDGBwGAPff7d/60M21tPS/PCe69u/VYWgaJCAzUXwI+N8T4m9vEFv+AcstAx9+JaZq/ngwEBfp7xoFjUBZsnfDhg03vW/y5MmYPHlyp4+Rk5ODnJwcb1arXQx+LUbEAzLE/Oue4WKAGAWeg2dE935GP32GfgtJAh7oJ3qZdh8XUw45yDQw7T0FVDuAfxkM9I0SvzPqEpJkgKSiNa+mTLDgM6HViDgR+P97Qny6p8BS9b0YyJd6l/hd6Z0kAZlJwN09gZ3HAEejv2tENzpcAxyqEZeU+kb5uzZBR4JB1X8S407BZ0IrSQJ+2B+IjRRde1ea/F0jatHYLK6L97WIwXzdhUECHk4SS/v+z3FOFQsk9kti4O+wWDEImLpcS4tfzUECn4lbYTQAjw4SX3900q9VoVbKqsSa+A8ldb/Bl6YQ8e+qdoixC+R/zW5gz3EgOkJcViK/ENf41ezO183eE24Dg/9WhYcCD/QHjl8QB/lX1ffAkVqxBO8dAThP3xsSosSYhU+q2OUfCA58K34PmUmiV4b8QlJm8nd+kMBn4nYM6C12cfvHSaCh2d+1CV6tu/jv7eYDLtMT2OUfCGrrgYqzYiyJrzZ2IlXUtfbVTfkLFnwmbkfL9f5mlxhJTv7xSTfu4r9R6y7/Snb5+4UsA2WnxMyelPjOy5NPGaUQ1QcJDP7b1cMkpvkdsovd1qhrXXaKLv4xfbtvF/+NEqKAgX2A8jNi/jh1rWoHcOaSWMiLmyn5HQf3aaftmXC7fVQNnRsRJ94APvf+9onUicpz4rnv7l38NxoRJz70nP7e3zUJPuXVgLUH0K+nv2sSkNzo2pxQN5lP/EeCtmfCyeBvlzlETOX5skZ0OVPXcLlF8N8TLbrAg0lMpAifQzWdlyXvOXdZtPa5Z8dN1Xdx8LPFrx2fCW8ZGiO2fD1+0d81CR4nL4p1FIJ1/vTQWOB0HVDX4O+aBI+jtUCPUK6gGEA4uE87bc+EkZ9wbyrSDNxlAb4+7++aBI/D54C4O4J33/oBvQGzkfP6u4rLDXxzQeyZwOl7NxXq413wbiSm6hlVHAz+FtqeCXZtdWxQtBj4c5lzrH3u4lXgjEP0tASrUCMw2CoGNzbzMpzPna4T03a5TXKHpK4OfpWtfXb1X8dnwpuSeoleEXb3+97xC2LTmqTe/q6JfyVbxToGZxz+rkn39813QO9wztsPMFzARzs+E95kChGDrs7yTdjnauvF4LZgn07VK1x8AKqt93dNur+zl7gJTwDiNX7t+Ex4W/wdYuMOrqrmWy3BH+wkSTwPDH7futQopk/G3+HvmtANOKpfOz4T3hZ3B3C1GajjdX6fudokFkuKZvADEM/DeQa/T9mvbcEdx+APNJzHrx2fCW+LjRT/r73s33p0Zy2tW7b4BWsP0Rq9yi2ifaa2HrCYxeZcFFDY4teOz4S3mUPEFKtLbPH7TG29uK5tCZIlejvT8gGI3f2+c6kRsIT5uxbUDl7j147PhC9EmkULjHyj5fo+p5cKFjMH+PnaZScQafJ3LagdgTCqf8GCBcjIyEBERAR69uzZbpmqqipMmDABERERiImJwfPPP4/mZs+VXvfs2YPRo0fDbDZj4MCBWLduXZvHWblyJfr374+wsDCkpaVh3759muvL4PeFSBOD35euOINnQx41JEk8H+zq953LjfybC1AGSVLZ4vddQ8HpdCInJwczZsxo936Xy4UJEybA6XRi7969WL9+PdatW4eCggKlzIkTJzBhwgSMGzcOFRUVmDVrFp5++ml8+OGHSpni4mLk5uaisLAQ5eXlGDlyJGw2G86d07aIV/cIfrcstmbd+Dmw+zjQ5PJvfSJMIpzIN1yy/6fxOVv9je3/1v+zOIwSF/HxFbcsBuxG+Pf6/nk0YTG+xRycwi5879e6BJJAaPG//PLLmD17NoYPH97u/Tt27MCXX36Jd999FykpKfjxj3+M+fPnY+XKlXA6RVYUFRUhMTERS5Yswb333ouZM2fiiSeewLJly5THWbp0KaZPn46pU6diyJAhKCoqQkREBNasWaOpvt0j+L+wAxVngQtXga9qxYcAfzJK3C7Vl5rdQIif/3Rb/419ZhfLB/tTiEEsKUve1/Ja9vOS5ctwBp/jCk6hEatxDpW44tf6BAqjIUT1AQAOh8PjaGz0/XissrIyDB8+HLGx1/cVsdlscDgcOHz4sFImKyvL4/tsNhvKysoAiF6FAwcOeJQxGAzIyspSyqjVPYL/4lUoq0TKEB8A/MnA4Pcpt+z/v9zWf2MSxN+gPxkk0RNC3tfSm+PnMSVn4PTY964a7FUEAElWfwBAQkICoqKilGPhwoU+r6PdbvcIfQDKbbvd3mEZh8OBq1ev4vz583C5XO2WaXkMtfz99ukdd/cUgd/yuvT3zllumZt4+JIxAEKu9V7sMsTfoD+5ZP/3gnRXLa9lP3+YH4UekCDetEMgYQi4dDAAQHarPwCcPn0adXV1yvHiiy+2+7D5+fmQJKnD48iRI135L/Wa7rGJeVJvYPw9YoOc6Aj/b6IRCF3R3ZnR4P/r2SnxQPkZ8bVtkOcHAX9odvu9K7rbMkiiUeHnv7kZiEMSvsf3cOEHuAN3grMMAHiEeqflAFgsFlgslk6L5+XlYcqUKR2WSUpKUlNDxMXFtRl9X1NTo9zX8v+Wc63LWCwWhIeHw2g0wmg0tlum5THU6h7BDwD9e4kjEFx2Aj34ovSZkAAI/tbdvoGwfnuz2/8DHrsrSRKv53r/dq2HwoDHEOSbUrVHY/CrZbVaYbVab7FSntLT07FgwQKcO3cOMTFiR9GSkhJYLBYMGTJEKbNt2zaP7yspKUF6ejoAwGQyITU1FaWlpcjOzgYAuN1ulJaWYubMmZrqw3cKX7jcKObyk29YzMD3fr6mHkhcbsDRwAVmfIlTdAOXLKvs6vfdpZqqqipUVFSgqqoKLpcLFRUVqKiowOXLYgXXRx99FEOGDMG//du/4bPPPsOHH36IuXPn4tlnn4XZLLLiV7/6FY4fP44XXngBR44cwR//+Eds3LgRs2fPVn5Obm4u/uu//gvr169HZWUlZsyYgfr6ekydOlVTfbtPiz9QyDIX+/A1aw+xLa+LrVwAYmChS+YSxr4UaeZqnIHK7RaHmnI+UlBQgPXr1yu3R40aBQDYvXs3MjMzYTQa8fe//x0zZsxAeno6evTogcmTJ+OVV15RvicxMRFbt27F7NmzsWLFCvTt2xerVq2CzWZTykycOBG1tbUoKCiA3W5HSkoKtm/f3mbAX2cY/N5W7xTdrlxO1nesPUTQXbzKjXoAsWKfBDG+hXzDYhZjiGTZ76P76QY+6urXYt26de2ustdav3792nTl3ygzMxMHDx7ssMzMmTM1d+3fiM0lb7Nf25ynZbMe8r6WsOeOdEJtPdAzHAg1+rsm3VdspFgZ0cFWf8DROKqfGPzeZ78kWgcR7Or3mVAj0CuMa9O3OF/Pbn5fa9mOt2V7XgocDH7NGPzedvYSEN/5VBG6TdE9GPyAGOfw3RVe8vA1cwjQO1y8vimwtFzjV3MQAAa/d11uFG/Cd93h75p0f7GRwPkrQEOQb0xTc1mMd4hh8PvcnRag6nu/L+RDN2CLXzMGvzd9/Z2YYx4o6wl0ZwP6iP8fPe/fevjbl+eAqDCOKekKg6KBK03AGYe/a0KtMfg10xb8/t6BLJDJMvDVeRH6Jk6W8LnwUGBAb+BwTfD+XV5ximmNQ2M40rwrxPQQ43e+DvIPm52Q0cWvRwa/ZtqC39/rowey766I6WWD+vi7JsFjaKwYZf1tnb9r4h+VtWI52cHeWV2MOiFJYjnw4xf8v/V3AGvq4uCXZTdk2aXiYPC3YFe/t3xuF4v2BMLyrcEiNhLoEyFa/cHGLQOV54CBfcTAM+oag61inY4jtf6uCbVwNwMuFYe72d81DRjagt/EzwntcjSI7r+R8VxJritJkmj1n/o++FZVO3VRrBA5VNuKXXSb7jCLa/0VZ8WMCmqjR1e3J9nVr5m235CBodau/dXimnMyu1y73KA+Yl7/Z2f9XZOuI8vi3xvTg/P3/WH0nWJ8xZfn/F2TgGRg8Ac8JvntOndZDOobfRdXTvOHUCOQehdwqCZ45lgfqhErRKYl+LsmwalnOHCPFThQLVbzI/9i8GvG4L8dLjew57hYI31IjL9rE7yGx4nr/XuOd/9BV3UNwKenRRf/XRxP4jdpfUXPy95T/q4JcQEfzRj8t6P8DPB9A5CZJEZXk38YJGBcklhA6Z/f+rs2viPL4sNNeChwP1v7fhVhAjL6ibU7Tl30d22CG1v8mjH4b1VtPXDwDJASz+VSA0HPcGBsgphd0V27/FsuZ2Qm8bJSILgnGkiIAv73BLv8/YnBrxmD/1bUO4HtX4mpZKl3+bs21KKly3/3N92vy9+ji597QQQESQIeShTrm+z4mqP8/UWWVQY/16FpweDXqtkNfPiV+COy3cPpe4Gkpcv/ShNQcqz7vBFfbQL++ygQwS7+gBNpFu8DNZeBf5xkuPgDr/FrxtTSwi2L1uR3V4Dx94gFeyiw9AwHbIPEan67j+t/Q5XGZmDrEaDRBUxIZhd/IIq/A3gwUSzqUxFE00oDBbv6NeOSX2q53EDpN8CJC0DWQCCGm6IErISewI8GADuPiU2THkzU5+DLxmbR0nc0Aj8ZIjbjocCUbBULeX16WnzYHM6FlbqM2lBn8CsY/Go0u0Xr8ds64NFBQGJvf9eIOjOgj/iwtvvaFL+HB+jrsszVJtHSdzSKln6fCH/XiDpzX1/xN/bPb8WHNuoaarvx2dWv0NE7oR9t/0psxfnjexj6enKPVXxQO3FR/A718mZc1wD89Uugvkm09Lnlrj5Ikhjsm363mF1CXcMtqz98ZMGCBcjIyEBERAR69uzZ5v7PPvsMkyZNQkJCAsLDw3HvvfdixYoVHmX27NkDSZLaHHa759/SypUr0b9/f4SFhSEtLQ379u3TXF8GvxqORuCxZNGFTPqS2Bv4l8Fi8FXx54E951qWRWBs+kK8SWUPYUtfj0bGi8tL1DVklQP7fNjV73Q6kZOTgxkzZrR7/4EDBxATE4N3330Xhw8fxksvvYQXX3wRb7zxRpuyR48exdmzZ5UjJub64nDFxcXIzc1FYWEhysvLMXLkSNhsNpw7p235aHb1q5F9LxAV7u9a0K3qGwX83xFivvV/fyXmX/+gX2DtalfXIBbnOXsJGBYrluPlQD79GtRH/L2R7wVAV//LL78MAFi3bl279//iF7/wuJ2UlISysjK8//77mDlzpsd9MTEx7fYaAMDSpUsxffp0TJ06FQBQVFSErVu3Ys2aNcjPz1ddX7b41Yjg6H3dizSJSzWZScDJi6L1fzIAWv+tW/n1TuDxe4EH+jP0idRqdqk/ADgcDo+jsdE/O3vW1dWhd++2l45TUlIQHx+PRx55BB9//LFy3ul04sCBA8jKylLOGQwGZGVloaysTNPPZvBT8JAkMfr6/44Qqy1u/0qsyXDW0fXzr90ycPwCsOVLsd57shXIGQ7cycV5iDRxyyrn8YvXeEJCAqKiopRj4cKFXV7lvXv3ori4GM8884xyLj4+HkVFRdi8eTM2b96MhIQEZGZmory8HABw/vx5uFwuxMZ6zhiJjY1tMw6gMwHU10nURVpa/1+dF/st/LUS6B0uVsUbFA2YfNjarncClefElq5XmsTAvf9zL1fjI7pVagfuXStz+vRpWCzXX29ms7nd4vn5+Vi0aFGHD1lZWYnk5GT1dQVw6NAh/OQnP0FhYSEeffRR5fzgwYMxePBg5XZGRga++eYbLFu2DO+8846mn9EZBj8FJ0kCBlvF9f5vHcDhGuCjk8AnVWI2wL1WoHeEd+b/u9yA/RJw+Jy4vGCQxAeMoTHc54Hodmm8xm+xWDyC/2by8vIwZcqUDsskJSWpqaHiyy+/xI9+9CM888wzmDt3bqflx44di48++ggAEB0dDaPRiJqaGo8yNTU1iIuL01QPbcHf7PbOGuitH4NLXJI/SZLYaCUhSuzuV1krWuOHa8TiP9E9AGurIyqs4w8DLrdY2fF8vdjIqbYeuHBVtDZ6hompXvdEB9bAQgpaMq6//zbCO4PfvPU4qmls8atltVphtVpvsVJtHT58GA8//DAmT56MBQsWqPqeiooKxMfHAwBMJhNSU1NRWlqK7OxsAIDb7UZpaWmbAYKd0fbus+mQpuKqNLsBjp2jQBBpFouwjL5TtNBbgvvUReCLa9fQQgzAHSbA0Gp4zAeV4k2l2Q1cahRfSxA9BtE9xPX7mEjxwUHS4QqC1G05WwX/r3HcjzW5DQEwqr+qqgoXLlxAVVUVXC4XKioqAAADBw5EZGQkDh06hIcffhg2mw25ubnKNXmj0ah8uFi+fDkSExMxdOhQNDQ0YNWqVdi1axd27Nih/Jzc3FxMnjwZY8aMwdixY7F8+XLU19cro/zVYrOD6EZGA3BXlDhaNDZfb8VfaQKcLtGyB4Be4UCo4dqHAjNgjRTz70M4dpbI52SVwe/DefwFBQVYv369cnvUqFEAgN27dyMzMxN/+ctfUFtbi3fffRfvvvuuUq5fv344efIkADFqPy8vD9XV1YiIiMCIESOwc+dOjBs3Tik/ceJE1NbWoqCgAHa7HSkpKdi+fXubAX+dkWRZXV+7JEnAz4YDPdofCKGJfK11BABhIZ6tp0DR5AJW7xdfTxvD6VXkiX8f1JFWfx+rMRBhATqByg03Ll3rmjdBgoTb75GqQxNycQoqo+WWORwOREVF4eLO52BRkUuO+kb0ylqBuro6Vdf4uzNtLX5TiPfe4Ni9T0TkVwYYEOXlDyWN6OIPwQHQ1a837OonIiL9YvBrxuAnIiL98tGo/u6MwU9ERPrFFr9mDH4iItKvliV71ZQjAAx+IiLSM3b1a8bgJyIi/WJXv2YMfiIi0i/X9S13Oy1HABj8RESkZ2zxa8bgJyIi/WLwa8bgJyIi/eLgPs0Y/EREpF9s8WvG4CciIt2SXTJkV+eteTVlggWDn4iI9Itd/Zox+ImISL9csjjUlCMADH4iItIxWZYhq2jNyzKDvwWDn4iI9MsFlS1+n9dENxj8RESkXy63ONSUIwAMfiIi0jHZrbKrn4P7FAZ/V4CIiOiWtQzuU3P4yIIFC5CRkYGIiAj07Nmz3TKSJLU53nvvPY8ye/bswejRo2E2mzFw4ECsW7euzeOsXLkS/fv3R1hYGNLS0rBv3z7N9WXwExGRfrVM51Nz+IjT6UROTg5mzJjRYbm1a9fi7NmzypGdna3cd+LECUyYMAHjxo1DRUUFZs2ahaeffhoffvihUqa4uBi5ubkoLCxEeXk5Ro4cCZvNhnPnzmmqL7v6iYhItwJhAZ+XX34ZANptobfWs2dPxMXFtXtfUVEREhMTsWTJEgDAvffei48++gjLli2DzWYDACxduhTTp0/H1KlTle/ZunUr1qxZg/z8fNX1ZYufiIj0S3ZfX7a3o0MWg/scDofH0djY2GVVffbZZxEdHY2xY8dizZo1HlMMy8rKkJWV5VHeZrOhrKwMgOhVOHDggEcZg8GArKwspYxaDH4iItItucmt+gCAhIQEREVFKcfChQu7pJ6vvPIKNm7ciJKSEvz0pz/Fr3/9a7z++uvK/Xa7HbGxsR7fExsbC4fDgatXr+L8+fNwuVztlrHb7Zrqwq5+IiLSL40r950+fRoWi0U5bTab2y2en5+PRYsWdfiQlZWVSE5OVlXN3//+98rXo0aNQn19PRYvXozf/va3qr7fmxj8RESkXxqD32KxeAT/zeTl5WHKlCkdlklKSlJTw3alpaVh/vz5aGxshNlsRlxcHGpqajzK1NTUwGKxIDw8HEajEUajsd0yNxs3cDMMfiIi0i1fzeO3Wq2wWq23Wq1OVVRUoFevXkqPQ3p6OrZt2+ZRpqSkBOnp6QAAk8mE1NRUlJaWKrMB3G43SktLMXPmTE0/m8FPRET6FQAr91VVVeHChQuoqqqCy+VCRUUFAGDgwIGIjIzE3/72N9TU1OD+++9HWFgYSkpK8B//8R/43e9+pzzGr371K7zxxht44YUX8Itf/AK7du3Cxo0bsXXrVqVMbm4uJk+ejDFjxmDs2LFYvnw56uvrlVH+ajH4iYhItwJhk56CggKsX79euT1q1CgAwO7du5GZmYnQ0FCsXLkSs2fPhizLGDhwoDI1r0ViYiK2bt2K2bNnY8WKFejbty9WrVqlTOUDgIkTJ6K2thYFBQWw2+1ISUnB9u3b2wz464wkq3w2JEkCnhoFRJg0/QDdanIBq/eLr6eNAUKN/q0PBRb+fVBHWv19rMZAhAXRBKo6NOPXOO7z3fAcDgeioqJgf/4RWMyhnZdvbELc4hLU1dWpusbfnbHFT0RE+qV2VT6u1a9g8BMRkW7JLnWr8sncllfB4CciIv1ii18zBj8REelXAIzq1xsGPxER6Zav5vF3Zwx+IiLSL7fKlfsY/AoGPxER6RZb/Nox+ImISLdkl6xyVD+Dv4W24G9yiSMYtP53+nghCiLqZlq9ZzQiuAaVdfW/19Xkhkvq/Ge6moLr99ARbcH//z73UTUCXLMbCJIFC4nIC5qvh8yvcdyPFen+2NWvHbv6iYhIt2S3G7K789a8mjLBQlvw/1sKYAqSzwqyfP1Te1iQ/JuJyDvCQsTeJgAQYgAkyb/16UrOZuCdiq77eSqv8asa+R8ktCWaKSS4NiNh9z4R3QqDIXg2NPOzQNidT2/YlCUiIt2SXTJkA0f1a8HgJyIi3eLgPu0Y/EREpFtutwy3ilBXUyZYMPiJiEi3ZBdUdvV3QWV0gsFPRES6xa5+7Rj8RESkWwx+7Qz+rgAREdGtalmrX83hKwsWLEBGRgYiIiLQs2fPNvevW7cOkiS1e5w7dw4AsGfPnnbvt9vtHo+1cuVK9O/fH2FhYUhLS8O+ffs015fBT0REuiXLbmX1vg4P2Xcr9zmdTuTk5GDGjBnt3j9x4kScPXvW47DZbHjooYcQExPjUfbo0aMe5VrfX1xcjNzcXBQWFqK8vBwjR46EzWZTPjyoxa5+IiLSLdklQ5b8O4//5ZdfBiBa9u0JDw9HeHi4cru2tha7du3C6tWr25SNiYlpt9cAAJYuXYrp06dj6tSpAICioiJs3boVa9asQX5+vur6ssVPRES61XKNX80BAA6Hw+NobGzs8jq//fbbiIiIwBNPPNHmvpSUFMTHx+ORRx7Bxx9/rJx3Op04cOAAsrKylHMGgwFZWVkoKyvT9PMZ/EREpFuuJrfqAwASEhIQFRWlHAsXLuzyOq9evRpPPvmkRy9AfHw8ioqKsHnzZmzevBkJCQnIzMxEeXk5AOD8+fNwuVyIjY31eKzY2Ng24wA6w65+IiLSLa2j+k+fPg2LxaKcN5vN7ZbPz8/HokWLOnzMyspKJCcna6gtUFZWhsrKSrzzzjse5wcPHozBgwcrtzMyMvDNN99g2bJlbcreLgY/ERHpltZr/BaLxSP4byYvLw9TpkzpsExSUpKqOra2atUqpKSkIDU1tdOyY8eOxUcffQQAiI6OhtFoRE1NjUeZmpoaxMXFaaoDg5+IiPRL5e580Lg7n9VqhdVqvcVKte/y5cvYuHGj6ssLFRUViI+PBwCYTCakpqaitLQU2dnZAAC3243S0lLMnDlTUz0Y/EREpFuyW2WL34cL+FRVVeHChQuoqqqCy+VCRUUFAGDgwIGIjIxUyhUXF6O5uRk///nP2zzG8uXLkZiYiKFDh6KhoQGrVq3Crl27sGPHDqVMbm4uJk+ejDFjxmDs2LFYvnw56uvrlVH+ajH4iYhIt2SXDBn+nc5XUFCA9evXK7dHjRoFANi9ezcyMzOV86tXr8a//uu/tjtdz+l0Ii8vD9XV1YiIiMCIESOwc+dOjBs3TikzceJE1NbWoqCgAHa7HSkpKdi+fXubAX+dkWRZXf+HJEnAtDFAqFHTDyDqlppcwOr94mu+Loiuu/baUBktt8zhcCAqKgr7hg1EpLHz199llwtjDx1DXV2dqmv83Rlb/EREpFtuN+CW1JUjgcFPRES6xeDXjsFPRES6xeDXjsFPRES65ZbFoaYcCQx+IiLSLbb4tWPwExGRbrlldaHOFv91DH4iItIt2Q2oaczLbPErGPxERKRbbpXBz67+6xj8RESkW83NQLOKDeabGfwKBj8REekWW/zaMfiJiEi3GPzaMfiJiEi3ZFlWtS+Ar/cO0BMGPxER6RZb/Nox+ImISLcY/Nox+ImISLe4gI92DH4iItItWeWSvbzEfx2Dn4iIdEv1Wv0MfgWDn4iIdIvBrx2Dn4iIdIvBr52KhQ6JiIgCk1tWf/jCyZMnMW3aNCQmJiI8PBwDBgxAYWEhnE6nR7nPP/8cP/zhDxEWFoaEhAS8+uqrbR5r06ZNSE5ORlhYGIYPH45t27Z53C/LMgoKChAfH4/w8HBkZWXh66+/1lxnBj8REemW263+8IUjR47A7XbjT3/6Ew4fPoxly5ahqKgIc+bMUco4HA48+uij6NevHw4cOIDFixdj3rx5eOutt5Qye/fuxaRJkzBt2jQcPHgQ2dnZyM7OxqFDh5Qyr776Kv7zP/8TRUVF+PTTT9GjRw/YbDY0NDRoqrMkq1zOSJIkYNoYINSo6QcQdUtNLmD1fvE1XxdE1117bfh6pTyHw4GoqCisNQ5AhNT56++K7MJU1zeoq6uDxWLxad0WL16MN998E8ePHwcAvPnmm3jppZdgt9thMpkAAPn5+diyZQuOHDkCAJg4cSLq6+vx97//XXmc+++/HykpKSgqKoIsy7jzzjuRl5eH3/3udwCAuro6xMbGYt26dfjZz36mun5s8RMRkW75u8Xfnrq6OvTu3Vu5XVZWhgcffFAJfQCw2Ww4evQoLl68qJTJysryeBybzYaysjIAwIkTJ2C32z3KREVFIS0tTSmjFgf3ERGRbtXLblXX769eW9/P4XB4nDebzTCbzV6rz7Fjx/D666/jtddeU87Z7XYkJiZ6lIuNjVXu69WrF+x2u3KudRm73a6Ua/197ZVRi8FPRES6YzKZEBcXh9/aT6j+nsjISCQkJHicKywsxLx589qUzc/Px6JFizp8vMrKSiQnJyu3q6urMX78eOTk5GD69Omq69XVGPxERKQ7YWFhOHHiRJvR8x2RZVmMV2vlZq39vLw8TJkypcPHS0pKUr4+c+YMxo0bh4yMDI9BewAQFxeHmpoaj3Mtt+Pi4jos0/r+lnPx8fEeZVJSUjqs540Y/EREpEthYWEICwvzyWNbrVZYrVZVZaurqzFu3DikpqZi7dq1MBg8h8+lp6fjpZdeQlNTE0JDQwEAJSUlGDx4MHr16qWUKS0txaxZs5TvKykpQXp6OgAgMTERcXFxKC0tVYLe4XDg008/xYwZMzT92zi4j4iI6BZVV1cjMzMTd999N1577TXU1tbCbrd7XHd/8sknYTKZMG3aNBw+fBjFxcVYsWIFcnNzlTLPPfcctm/fjiVLluDIkSOYN28e9u/fj5kzZwIQM+tmzZqFf//3f8cHH3yAL774Ak899RTuvPNOZGdna6ozW/xERES3qKSkBMeOHcOxY8fQt29fj/tapjRGRUVhx44dePbZZ5Gamoro6GgUFBTgmWeeUcpmZGRgw4YNmDt3LubMmYNBgwZhy5YtGDZsmFLmhRdeQH19PZ555hl8//33eOCBB7B9+3bNvR6cx090KziPn6h9XTSPn26dthZ/k8tH1SDSmdavBb4uiK7j6yHgaWvxExERqcAWf+BS3eLnL5GIiEj/OKqfiIgoiDD4iYiIggiDn4iIKIgw+ImIiIIIg5+IiCiIMPiJiIiCCIOfiIgoiDD4iYiIggiDn4iIKIj8f1j7827pUPifAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.axis(\"off\")\n",
    "matplotsoccer.field(ax)\n",
    "\n",
    "at_test_pb = veritas.AddTree(1, veritas.AddTreeType.REGR)\n",
    "at_test_pb.add_tree(at[len(at)-1])\n",
    "\n",
    "print(at_test_pb[0])\n",
    "\n",
    "XY = np.array([[x, y] for x in np.linspace(field[\"origin_x\"], field[\"length\"], 200)\n",
    "                      for y in np.linspace(field[\"origin_y\"], field[\"width\"], 200)])\n",
    "X = np.hstack((XY, np.ones((XY.shape[0], 1)), np.zeros((XY.shape[0], 3)))) # append foot, head, other, prev_actio\n",
    "penalties = at_test_pb.eval(X)\n",
    "#penalties = at.eval(X)\n",
    "\n",
    "im = ax.imshow(penalties.reshape((200, 200)).T,\n",
    "          cmap=\"RdYlGn\",\n",
    "          extent=(field[\"origin_x\"], field[\"length\"],\n",
    "                  field[\"origin_y\"], field[\"width\"]))\n",
    "fig.colorbar(im, ax=ax, shrink=0.65)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15e03d45-3dbe-417b-8980-aeabbe521536",
   "metadata": {},
   "source": [
    "## Use Veritas to find the most promising positions to shoot from outside of the penalty box"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ce4e288c-b19e-4723-82cc-958b03a66c1c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solving time: 0.02s\n",
      "Number of solutions 959\n"
     ]
    }
   ],
   "source": [
    "config = veritas.Config(veritas.HeuristicType.MAX_OUTPUT)\n",
    "config.stop_when_optimal = False\n",
    "config.ignore_state_when_worse_than = -2.5\n",
    "\n",
    "prune_box = {\n",
    "    icolumns[\"x\"]: veritas.Interval(field[\"origin_x\"], field[\"length\"]),\n",
    "    icolumns[\"y\"]: veritas.Interval(field[\"origin_y\"], field[\"width\"])\n",
    "}\n",
    "\n",
    "search = config.get_search(at, prune_box)\n",
    "\n",
    "while search.num_solutions() < 1000:\n",
    "    if search.steps(100) != veritas.StopReason.NONE:\n",
    "        break\n",
    "\n",
    "print(f\"Solving time: {search.time_since_start():.2f}s\")\n",
    "print(\"Number of solutions\", search.num_solutions())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bdf6a0f1-84e7-42d4-b2d8-37d2108e8cfa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f//9nHzyyc0uw+wiFgb2IQcffDCnnXYaixcvbnYpZhcZGRnhda97Hd/73vf4zne+w3ve855ml/RHe8973sN3vvMdbrnlFl7/+tczMjLS7JLMLrJ48WJOO+00Dj744GaXYnYRCwP7kFtuuYUjjjiC17zmNSxdurTZ5ZgXqV6v84Y3vIEHHniAu+66ize+8Y3NLulPdvbZZ3PXXXdx//3388Y3vtF6CPYBjz32GKeffjrz5s3jlltuaXY5ZhexMLAPaW9v584772TWrFmceuqpPPPMM80uyfyZVJV3vvOd/PKXv+S2227jpJNOanZJf7aTTjqJW2+9lV/84he8853vZAwvetrynn76aU499VT2228/7rzzzr36cpX501gY2MeMHz+eH/3oR4wbN47XvOY1DA0NNbsk82e44oor+MY3vsENN9ywT1yXPeWUU7jhhhv4xje+wb/8y780uxzzZxgcHOQv//IvGT9+PHfddRddXV3NLsnsQhYG9kGTJ0/mjjvuYPPmzbzrXe+yT2JjzDe/+U3++Z//mSuuuILzzjuv2eXsMueddx6XX345H//4x/nWt77V7HLMn0BVede73sXmzZu5/fbbbTfXfZCFgX3U3Llz+a//+i++/e1vc+211za7HPNHWrFiBe985zu54IIL+OhHP9rscna5j33sY1xwwQX89V//NStXrmx2OeaP9OUvf5nvfOc7fO1rX7PNqfZRFgb2Yeeccw7vf//7+eAHP8jDDz/c7HLMH+Hiiy9m4sSJXHvttWN605PfR0S49tprmTBhAhdffHGzyzF/hPsX/w+XXPJ3vOu9x/DaM4/C+5Saf5IR/wsafk2zyzO7iIWBfdxnPvMZDj30UP72b//WFn/Zy91+++3cdtttXHPNNfv0wKz29nauueYabr31Vu64445ml2NeQNzYzLvfcwkHHjaeD3/65WyRL9Gn1zDEzQzzM7bwjWaXaHYRCwP7uHw+z5e+9CUWL17Mdddd1+xyzO9RrVa56KKLOPXUUzn77LObXc5ud8455/DqV7+aiy66yDY22kulvsK1X3sHS36zmSu/cBr5QgFcREM3kWo/qgme6rb7K2kTqzUvloWBFnDCCSfw1re+lQ9/+MMMDAw0uxzzPK6++mrWrl3LF77whX3y8sDvEhG+8IUvsGbNGq6++upml2Oex7r+b3L5x+/mjW89nGNPmAkCICApqimeGGR7b6OqhYGxzMJAi7j66qupVqtcdtllzS7F/I5nn32Wq666ir//+7/nkEMOaXY5e8yhhx7Khz70Ia666ipb434vo+q58rL/olZN+Oin/gJUyJoLBU2y/6OgO156tB6esczCQIuYPn06H/7wh7n22mvZsGFDs8sxO7j44ouZPHnyPjl74A/52Mc+xqRJk2ww4V5mw4YNXPf/FvG+f1zAlKmj41c0BRTRBAFEFee392IJ++44l1ZgYaCFvP/97yefz3PNNdc0uxQzatmyZXz/+9/nyiuvpK2trdnl7HFtbW1ceeWVfP/73+epp55qdjlm1DXX/BuFQpH3vPetoyHAA4L4mA4/jw45iaIcTptsXxBLxJqTsWyvPnveezZt2sSmTZsol8uMjIw858+O9zUvbNy4cbz73e/mK1/5CuVyudnlGOCGG25g3LhxnHvuuc0upWnOOeccxo0bxw033NDsUgxQLpf5yle+wrvf/R72m/C35N2hOM3jNEdRTqY9927ag7MYH7yTjuCUZpfbdDu2Pc/XRpXL5W3t2N7cTu3VYaC3t5cpU6YwZcoUOjo6aG9v3+nP/Pnzt913y5YtTax07Hjve9/L8PAwN954Y7NLaXlpmnLDDTfw5je/mUKh0OxymqZYLHL++edz/fXXk6Y2CK3ZbrjhBsrlMu973/sQcYTMBIkQ6aDNvawlBrj+KXZse+bPn/+cdqqjo2NbO9bb29vESl/YXh0GzK6333778frXv56vfe1rzS6l5f3sZz9j7dq1XHjhhc0upekuvPBC1q5dy89//vNml9Ly/vu//5szzjiD2bNn4zWmzhN4ifGUqfN0s8szu8leHQZKpdK2r3t6eiiXyzv9WbRo0bZ/LxaLzShxTDr//PN58MEHWbVqVbNLaWnXX389hxxyCAsWLGh2KU133HHHcfDBB3P99dc3u5SWtnLlSh588EHOP/98AJQd1xJQUvqbV9xease2Z9GiRc9pp3p6erb9+45t2t5mrw4DO3ZHtbW1PefPji+sdV398V73uteRy+W4+eabm11KyxocHOTmm2/mwgsvtJ9dst/fCy+8kJtuusl22myim2++mXw+z+te9zoAhDw59sNpDkc7BQ5rcoV7nx1/f0ul0vO2Vc93373NXh0GzO7R2dnJ6aefzk033dTsUlrWd77zHer1Om9729uaXcpe421vexu1Wo3vfOc7zS6lZd10002cfvrpdHR0AODEMV7OpUvOZLy8iYIc3uQKze5iYaBFnX322dxzzz1s2rSp2aW0pFtuuYWTTjqJGTNmNLuUvcbMmTM5+eSTueWWW5pdSkvq6enh3nvvfc5y2E6KFOUo8rJ/cwoze4SFgRZ18snZ/OD777+/yZW0piVLlrBw4cJml7HXOe6441iyZEmzy2hJW98Ltr43mNZiYaBFzZo1iylTpuw0CNPsGX19faxbt44jjzyy2aXsdY488kjWrl1rU4WbYNGiRUydOpWZM2c2uxTTBBYGWpSIsGDBAh544IFml9JyHn30UQALA89j62uy9TUye84DDzzAggUL9upBbmb3sTDQwo477jgWL168V6+KtS969NFHKRQKHHTQQc0uZa9z8MEHk8/nLQzsYd57Fi9ezHHHHfecf4vTXgaS/2Ew/RbeV5/nu82+wMJAC3vJS17C4OAg69ata3YpLWXJkiUcccQRhGHY7FL2OmEYcsQRR9i4gT1s3bp1DA0NcdRRR+10u6rS7z9LjUVU9R76039vUoVmd7Mw0MK2Xhu0MLBnPfroo3aJ4AUceeSR1jOwh61duxbIxhLtyPtBPMPb/h6zHlXrSdwXWRhoYVuntVkY2HOSJOHxxx+3MPACjjzySJYuXWr7FOxBW98Dfneqq/cyumshgIImgI0p2BdZGGhhEydOJJfLWRjYgzZv3kytVmPu3LnNLmWvdeCBB1Kr1WwNjD1o3bp15PN5JkyYsNPtLohBfRYCNMXpzk2Gqu7JMs1uZBct96D169fz7LPPMm/ePLq6uppdDiLC9OnTLQzsQbVaDdh71ijf8c18b3lj37rWe71eb3IlY5tqSsI6ICBkGiK//7Pf+vXrmT59+nNmEqReURRGfzY8CXWeoNFYQs3fTbm+fUCh10GgjV1hYGCApUuXMmfOHKZPn75LjmlemPUM7CF33303c+bM4cQTT+Swww7bazYJ6uzspFKpNLuMlrE1DOTz+SZXkjX+733ve7f9/X3ve99eEQi2vjZbXyvz56nqQ5T9TxnxP6HBUy9435GRETo7O59z+5bkX9CwHQ2KqMuhYZF+/1+MBPfjwzwadmy7b63+/V1S96pVqzj00EM58cQTmTt3LnffffcuOa55YRYG9pAPfvCDxHEMZF3FV111VZMrykRRtK0us/tt/bRbKBSaXAk8/PDD3Hjjjdv+fsMNN/DII480r6BRW18b6xl4cVI2AuCpk2jvC943jmOiKNr5Nu3DRwGIAwQkRHFZTwEhv5sbk2TXLGB21VVX0dub1dtoNPjgBz+4S45rXpiFgT2kv79/23x+VWVgYKC5BY1yztk6A3vQ1kFxzjX/V+/5fgb3hp/Lra+NDSB8cSLmIuQI6CQns1/wvqr63EsEbAZGW/yt/yYCWwOBC8BvD2xhumtWjRwYGNjWQ+W9p7/ftk3eE5r/jtQi3vSmNyEiBEGA9/45m4E0y/N9IjC7z9Yu8L3hU+8xxxzDtGnTtv192rRpHH300U2sKLP1tdkbLqWMZXk5jA73Otrd64j+QBgIw5AkSXa+jcnZ4EH86P/ZNnYgG1ToCZOBbfeXP/AYf6yzzz4b7z1BEADZe6fZ/WwA4R7yr//6r3R3d/PYY4/xl3/5l5x77rnNLgnI3ngtDOw5e1MXeGdnJz/60Y+YP38+AD/60Y+e97rxnrY3XUoZy0SEgK4/6r65XO45YzRCmYDzipLiASQEPKKKAKIJoR/Zfv/cMbuk7nPPPZevf/3r/PCHP2T+/Plccsklu+S45oVZGNhDgiDgH/7hH5pdxnNs2LCBqVOnNruMlrG3DY474IADnvfrZtqbBlnuCzwNlBhHCfk9awRMmTKFjRs3Puf2MA2ouwSkCM6N9gjUkKQKOoJLts8mcG6/XVbzW97yFt7ylrfssuOZP8zCQAurVCoMDAw8Z6ERs/uMHz8ewObQv4Ctr83eMP12rEsYoMy9KFUKHEGRQ5/3fjNmzKC/v59qtbptaidAKnVwbSAB2fgBh0qID4uIdzSicdvuq371bn42ZneyMQMtbP369cBzVx0zu097ezsHHHCALbf7Ah599FHmzJlDe3t7s0sZ8xI2krIZT4M6z/ze+219D9j6nrDt+4Pi6GwCJVt50Gd/dzlUCqRh17b7ptrY9U/A7DEWBlrY71uC1Oxetvb+C7O9G3adgC4cHYASMeX33u/3LU3uNDc6oUCzZYk1RbbOMHBZKNjKB80fb2L+fBYGWthTTz2Fc+45m5OY3cvCwAuzMLDrREylg5Pp5GRKvPT33m/27Nk451i2bNlOtxfT7tGliLfOKAhQlWzqnyZsm3oIqF11HtMsDLSwBx54gPnz5+81S+O2iqOOOoqenh56enqaXcpep6enh02bNj1nK13z5wsZT8Q05AUa61KpxLx581i0aOeFgwpyMMSD2ZRCCbMrBapIMozTnWfEqD69O8o3e4iFgRa2aNEiFixY0OwyWs7WT72PPfZYkyvZ+2ztMbGegT1vwYIFzwkDNTcMua7RaYUALhszIBGaNpB0+1LmotacjGV29lpUuVzm8ccftzDQBHPmzKFUKrFkyZJml7LXWbJkCaVSiTlz5jS7lJazYMECli5dSrlc3nZbwrM7XgnIiKBhEXElAr99imygk/ZQpWZ3sDDQohYtWoT33sJAEwRBwLx58/aKfQD2NkuWLGH+/Pl7xXLNrea4447De79T70CkJYQEtAFpBUjJrhU4dHQBoq0Um00wltlvXIu69dZbmT59OvPmzWt2KS3ppJNO4gc/+AGNhr2BblWv17nzzjt55Stf2exSWtK8efOYPn06t91227bbCv4QgsYWJBnOtiXw2cBB0QTxjZ3GDQT1Zc9zVDNWWBhoQd57br75Zt74xjfaJ7Amefvb305fXx933HFHs0vZa9xxxx1s2bKFd7zjHc0upSU553jDG97ATTfdhPceVU+Ve0mj8WjYhboiuBAQXFrDaRXx28NsWL6Z52xlaMaMvbol2HFv9ZGRkef8qVQqz3tf88IWLVrE2rVrOeecc5pdSss64ogjOOaYY7juuuuaXcpe47rrruPYY4/l8MMPb3YpLeucc85h7dq1LF68GPAk9JJdFsguDWRbGTvQBk6VMN6+o6D4MpA873H3ZTu2PZVK5Xnbque7795mr54YumNjP2XK718wA6Barb7gv5vtbrrpJiZPnswJJ5zQ7FJa2oUXXsjf/d3f0dPT8wd/vvd1PT093HnnnXz+859vdikt7cQTT2TSpEl897vf5bjjjiNf20gczc62LN62CqEi6gl8lWCHjYpIslkGrWbHtucPjcGqVCp77cqae3XPgNn16vU6N9xwA+eee+62LUJNc5x//vkEQcA3vvGNZpfSdF//+tcJgoDzzz+/2aW0tCAIOO+887jxxhup1+uU4hK56nKyT/wK4kEVxbOtp2Ar97LmFG12ib06DHR3d29bnGV4eJhyubzTnx3naU+YMKGJlY4d3/72t9m0aRPve9/7ml1Ky5s4cSJnnHFGy18qUFWuu+46zjzzTPs93gu8973vpaenh+985zu4aD+itDK66BDb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rng = np.random.default_rng(6)\n",
    "\n",
    "best_positions = []\n",
    "for i in range(search.num_solutions()):\n",
    "    sol = search.get_solution(i)\n",
    "    box = sol.box()\n",
    "\n",
    "    x = box.get(icolumns[\"x\"], prune_box[icolumns[\"x\"]])\n",
    "    y = box.get(icolumns[\"y\"], prune_box[icolumns[\"y\"]])\n",
    "\n",
    "    x = x.lo + rng.random() * (x.hi - x.lo)\n",
    "    y = y.lo + rng.random() * (y.hi - y.lo)\n",
    "\n",
    "    #x = x.hi\n",
    "    #y = y.hi\n",
    "\n",
    "    best_positions.append((x, y, sol.output))\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.invert_yaxis()\n",
    "ax.axis(\"off\")\n",
    "matplotsoccer.field(ax)\n",
    "ax.scatter([p[0] for p in best_positions],\n",
    "           [p[1] for p in best_positions],\n",
    "           s=10 + 50*minmax_normalize([p[2] for p in best_positions]), marker=\".\",\n",
    "           c=[p[2] for p in best_positions], cmap=\"Wistia\",\n",
    "           alpha=0.5 + 0.5*minmax_normalize([p[2] for p in best_positions]))\n",
    "\n",
    "#fig, ax = plt.subplots()\n",
    "#ax.hist(1.0 / (1.0 + np.exp([-p[2] for p in best_positions])))\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "76e37785-28eb-43d1-9948-a62c5f67bf1a",
   "metadata": {},
   "source": [
    "## The most likely states"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "90f514b0-c308-4511-bebb-bc142e603417",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<b>1st best solution</b>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  x             : Interval(103.469,105)\n",
      "  y             : Interval(54.3575,68)\n",
      "  foot          : Interval(>=1)\n",
      "  head          : Interval(<1)\n",
      "  other         : Interval(<1)\n",
      "  prev_action   : Interval(<1)\n",
      "  output        : -1.3139, -1.3139\n",
      "  output prob   : 21.2%\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q4YoJSXlop/34vF41LJlS7Vs2VLDhw/XnDlzlJeXp6VLl2rJkiWaO3euBg0apCeeeEJdu3at5n8RUP2Cb9NjY2Or5Zjh9XrPefmRhmfHARFsz549SktLU0pKirZu3ap58+Zpz549mjVrllJTU6v1CbBRUVFKTU3VrFmz9O2332revHn65JNPlJKSosGDB+vbb7+ttr8LQGgRA0AEKi8vV1ZWltq3b68NGzZoyZIl+uKLLzR69GjVq1evxv/+evXqafTo0dq5c6eWLFmi9evXq127dsrKylJ5eXmN//0AqhcxAESYnTt3KjU1VVlZWRo3bpx27typESNGOHlSX3R0tEaMGKGdO3dq7NixysrKUmpqqnbu3BnyLQAuHjEARJCcnBzdcMMNKi8vV35+vv74xz9WPSHKpfj4eM2YMUP5+fk6efKkbrjhBi1ZssT1LAAXiBioRXbt2uV6AmqI3+9Xenq6Ro4cqbS0NG3ZskVdunRxPesnunTpon/84x8aNGiQHnjgAaWnp0f0iVhwftzm1B7EQC3Su3dvbdq0yfUMVLOKigoNGzZM8+bN0/z587Vo0aKwfslrXFycFi9erPnz5+uFF17Q8OHDVVFR4XoWqtmmTZvUu3dv1zNQTYiBWqRt27bq16+f8vPzXU9BNSktLdUdd9yhN998U8uWLdMjjzzietIFe+SRR7Rs2TKtXLlSd955p0pLS11PQjXJz89Xv3791LZtW9dTUE2IgVpk5cqV6tixo2699Vbt2LHD9RxcooqKCt19993avHmz1q5dq3vuucf1pJ9t0KBBWrt2rTZt2qR77rmHewhqge3bt6t///7q1KmTVq5c6XoOqgkxUIvExcVpzZo1at68ufr27at//etfrifhIgUCAT344IP66KOPtHr1avXq1cv1pIvWq1cvrVq1Sh9++KEefPBBRfBJT8376quv1LdvX11zzTVas2ZNWD9chZ+HGKhlrrzySq1bt04NGjTQrbfequPHj7uehIuQlZWlV199VTk5ObXicdk+ffooJydHr776qv7v//7P9RxchGPHjum2227TlVdeqbVr1+qKK65wPQnViBiohRITE5Wbm6uDBw/qoYce4jexCPPaa6/pD3/4g7KysjRkyBDXc6rNkCFDNHXqVD3zzDN6/fXXXc/BzxAIBPTQQw/p4MGDevvtt3k311qIGKilWrdu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jx49XE8xbdSoUfrd734nn8/3P3++azufz6c1a9Zozpw5rqeY1rNnTzVq1EhvvPGGunXr5npORAg+9vyv52CVlZWF7Zk1w/qeAVS/iooK5eTkaPDgwVVvEQo3hg4dqujoaL366quupzj3yiuvKDo6WkOHDnU9xbTo6GgNGTJES5YsCYt31kTohHUMJCQkVJ2c5cSJEyopKTnrI/h12ldddZXDpZFj6dKlOnDggB599FHXU8xr2LChBgwYYP6hgkAgoEWLFmngwIFcj8PAmDFj5PP5tGzZMtdTIkLwz+z27dt/cpw6ceJE1XEsISHB4dLzC+sYiIqKUmJiohITExUXF6fY2NiffAR/Lc4vEAho5syZ6tevn9q3b+96DnTmoYJt27Zp69atrqc48+mnn2r79u0aNWqU6ymQ1KFDB/Xr108zZ84M68e4w0Xwsedcx6i4uLiq41g4H6fCdxmq3TvvvKOCggJNnDjR9RT8qH///mrWrJmmTp3qeoozmZmZatasmfr37+96Cn70+9//Xp9++qnWrl3regpChBgw4vTp03rqqafUvXt39erVy/Uc/Oiyyy7T888/rzfffFNr1qxxPSfkcnNztWrVKs2cOVN16oT185lN6d27t1JTUzVp0iSdPn3a9RyEADFgxF//+ldt3bpVs2fPlsfjcT0HQYYMGaI+ffooPT1d5eXlrueETHl5udLT0/XrX/9agwcPdj0HQTwej2bPnq2tW7fqxRdfdD0HIUAMGHD48GE99dRTGjVqFC8XCkMej0cvvPCC9uzZo+eee871nJCZMWOG9u7dqxdeeIFADUOpqakaOXKkJk2apMOHD7uegxpGDBgwefJk/fDDD3r22WddT8F/0b59e2VkZGj69OnavXu36zk17ptvvlF2drYyMjLUrl0713PwXzz77LP6/vvvNXnyZNdTUMOIgVrunXfe0fz58zV16lTzJ7YJd5MnT1bDhg01fvx411Nq3Pjx45WQkKCnn37a9RScR+PGjZWVlaX58+fzZMJajhioxQoLC3X//ffr9ttv17hx41zPwf8QFxen2bNna9WqVXrjjTdcz6kxb7zxhlavXq3Zs2eH7dnY8G/jxo3TbbfdphEjRqioqMj1HNQQYqCWOnXqlIYNG6a6detq8eLFYf36VvxbWlqa0tLSNHLkyFp57oFPPvlEI0eO1ODBgzVo0CDX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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<b>2nd best solution</b>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  x             : Interval(102.944,103.469)\n",
      "  y             : Interval(54.3575,68)\n",
      "  foot          : Interval(>=1)\n",
      "  head          : Interval(<1)\n",
      "  other         : Interval(<1)\n",
      "  prev_action   : Interval(<1)\n",
      "  output        : -1.3264, -1.3264\n",
      "  output prob   : 21.0%\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgMAAAGFCAYAAABg2vAPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAheklEQVR4nO3de3CU9d2G8XsTNLBJQCUkAQEFBDkFOqOEUKECFfAEjhIQEIU6Y0WEFCNOEcUCeTEWBaYg0KFVIYyOgoCgoULH48gpoWIArWhFkATcEM5JSBR23z8w6VIpVUj2t5vv9ZnJNGq63GSy+1zZw7OeQCAQEAAAMCvK9QAAAOAWMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGAcMQAAgHHEAAAAxhEDAAAYRwwAAGBcPdcDLobf71dJSYkkyev1yuPxOF4ERJZAIKDy8nJJXIeACxF8HUpISFBUVGT+jh3RMVBSUqKkpCTXMwAAkM/nU2JiousZFyQyEwYAANSYiL5nwOv1Vn/u8/kUGxvrcA0QecrKyqrvXeM6BPx8wdeh4GNSpInoGAh+fDM2NpYbMuAicB0CLk4kP+eGhwkAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMIwYAADCOGAAAwDhiAAAA44gBAACMq+d6wMXw+/3Vn5eWljpc4k4gEFB5ebkkKSEhQVFR9B2A0PD7/SopKZEkeb1eeTwex4tCL/jYE3xMijQRHQNVP4SSlJyc7HBJePD5fEpMTHQ9A4ARJSUlSkpKcj0jbJSUlCg+Pt71jAvCr5EAABgX0fcMeL3e6s93795t8rfisrKy6jIP/n4AQG0Lvs3x+XyKjY11uMaN4uJitW7dWlJk3wZHdAwEPz4VGxtr8gcxmMXH6wC4w22wzvo7R/JtMA8TAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGEcMAABgHDEAAIBxxAAAAMYRAwAAGFfP9YCL4ff7qz8vLS1VbGzsRV9mIBBQeXm5JCkhIUFRUfQSANQFfr9fJSUlkiSv1yuPx3PRl1laWnrW5UeqiI6BQ4cOVX/epk2bGr98n8+nxMTEGr9cINRKSkq0efNm5efna+/evSosLFRhYaEOHjxY/TUtW7ZUkyZN1Lx5czVv3lxXXXWVunXrprS0NCUkJDhcD9SMkpISJSUl1drlHzp0SMnJybV2+bUpomMAwLmdPn1aH330kZYtW6a///3v+vLLLyVJTZo00TXXXKMWLVqoa9euatiwoaZOnSpJysjI0PHjx1VYWKgvvvhCa9eu1fTp0yVJbdu2Vb9+/TR06FD17NlT0dHRrv5qAGqBJxAIBFyPuFC7d++uvkdg586duvrqqy/6MsvKyqrL8cSJE4qLi7voy6xNZWVl1Rtr6qESRK6vvvpK8+bN02uvvaZvv/1WLVq00KBBg/TLX/5SPXr00NVXX33WXaPn+/kJBALas2ePNm3apI0bN2rNmjXat2+fkpOTdffdd2v8+PG1co8cIkek3f6UlpYqPj5e0pl7fmti7549e9S5c2dJZ65/rVu3vujLdCGi7xkIvlHzer01/oNYE48nAaGQn5+vZ599VitWrFDjxo01cuRIDR06VKmpqRf8vBePx6NWrVqpVatWGjFihObOnau8vDwtW7ZMS5cu1bx58zR48GA99thj6tatWw3/jYCaF3ybHhsbWyPHDK/Xe87LjzQ8Ow6IYHv37lV6erpSU1O1bds2zZ8/X3v37tXs2bOVlpZWo0+AjYqKUlpammbPnq1vvvlG8+fP18cff6zU1FQNGTJE33zzTY39WQBCixgAIlBFRYWysrLUoUMHbdy4UUuXLtXnn3+uMWPGqEGDBrX+5zdo0EBjxozRrl27tHTpUm3YsEHt27dXVlaWKioqav3PB1CziAEgwuzatUtpaWnKysrS+PHjtWvXLo0cOdLJk/qio6M1cuRI7dq1S+PGjVNWVpbS0tK0a9eukG8BcOGIASCC5OTk6LrrrlNFRYXy8/P1xz/+sfoJUS7Fx8dr5syZys/P18mTJ3Xddddp6dKlrmcB+ImIgTpk9+7drieglvj9fmVkZGjUqFFKT0/X1q1b1bVrV9ezfqRr1676xz/+ocGDB+u+++5TRkZGRJ+IBefHbU7dQQzUIX369NHmzZtdz0ANq6ys1PDhwzV//nwtWLBAixcvDuuXvMbFxWnJkiVasGCBnn/+eY0YMUKVlZWuZ6GGbd68WX369HE9AzWEGKhD2rVrp/79+ys/P9/1FNSQsrIy3XbbbXrjjTe0fPlyPfTQQ64n/WQPPfSQli9frlWrVun2229XWVmZ60moIfn5+erfv7/atWvnegpqCDFQh6xatUqdOnXSzTffrJ07d7qeg4tUWVmpO++8U1u2bNG6det01113uZ70sw0ePFjr1q3T5s2bddddd3EPQR2wY8cODRgwQJ07d9aqVatcz0ENIQbqkLi4OK1du1YtWrRQv3799K9//cv1JFygQCCg+++/Xx9++KHWrFmj3r17u550wXr37q3Vq1frgw8+0P33368IPumpeV9++aX69eunq666SmvXrg3rh6vw8xADdczll1+u9evXq1GjRrr55pt1/Phx15NwAbKysvTKK68oJyenTjwu27dvX+Xk5OiVV17R//3f/7megwtw7Ngx3XLLLbr88su1bt06XXbZZa4noQYRA3VQYmKicnNzdfDgQT3wwAP8JhZhXn31Vf3hD39QVlaWhg4d6npOjRk6dKimT5+up556Sq+99prrOfgZAoGAHnjgAR08eFBvvfUW7+ZaBxEDdVSbNm30wgsvaNmyZVq4cKHrOfiJvv76a91///0aOXKknnjiCddzatyTTz6pkSNH6je/+Y327Nnjeg5+ogULFmj58uV68cUXeXOqOooYqMPS09M1btw4PfLII9q2bZvrOfgJJkyYoMaNG2vhwoUR/aYn/43H49HChQt1xRVXaMKECa7n4CfYtm2bMjMzNX78eA0ePNj1HNQSYqCOe+6559S+fXs9+OCDnPwlzL311ltas2aN5syZU6efmBUXF6c5c+Zo9erVys3NdT0H5+H3+/Xb3/5WHTp00LPPPut6DmoRMVDHxcTEaP78+crPz9fixYtdz8F/cfLkSWVkZKhfv34mfvtKT0/XTTfdpIyMDN7YKIy99NJL2rp1q+bPn6+YmBjXc1CLiAEDevbsqXvuuUeTJk3S0aNHXc/BOcycOVOFhYWaN29enXx44D95PB7NmzdP+/bt08yZM13PwTkcPXpUjz/+uEaOHKkbbrjB9RzUMmLAiJkzZ+rkyZOaNm2a6yn4D7t371Z2drYmTpyoa6+91vWckGnfvr0effRRZWdnc477MDR16lSdPHmSWDOCGDCiWbNmmjRpkhYuXKgDBw64noMgEyZMUGJiYp189cD/8uSTT6pJkyY8mTDMHDhwQAsXLtSkSZPUtGlT13MQAsSAIePGjVNMTIzmzJnjegp+sGvXLr355puaMWOGYmNjXc8JudjYWM2YMUNvvvmmvvjiC9dz8IPZs2erfv36GjdunOspCJGwjgG/36/i4mIVFxertLRUZWVlP/oI/lqcX6NGjTRmzBgtWrRIpaWlrudAUk5Ojho1aqQhQ4a4nuJMenq6GjVqpJycHNdTIKm0tFSLFi3SmDFj1KhRI9dzwl7wsedcx6jS0tLq41g4H6fCOgZKSkqUlJSkpKQkxcfHKy4u7qyPlJSU6q89fPiww6WRY+zYsTpx4oSWLl3qeop5p0+fVk5OjoYPH6769eu7nuNMgwYNNGzYMC1ZskSnT592Pce8nJwclZaW6uGHH3Y9JSIEH3tSUlJ+dJyKj4+vPo6VlJQ4XHp+YR0DqHlXXXWVbr/9dr344ouup5j37rvvqrCwUKNHj3Y9xbnRo0ersLBQ7733nusp5r300ksaOHCgWrZs6XoKQiisY8Dr9VZ/7vP5VFpaetZHXl5e9X9v0KCBi4kRadiwYdq6dav27t3reoppS5Ys0bXXXqvU1FTXU5zr3r272rVrpyVLlrieYtqePXu0detWDRs2zPWUiBF87MnLy/vRccrn81X/9+BjWrgJ6xgIfr11bGzsjz6Cv7EWXptdU2677TZdeumlWrlypespZh07dkwrV67U6NGj+dnVmevv6NGjtWLFCt5p06GVK1cqJiZGt912m+spESP4+uv1es95rDrX14absI4B1I6GDRtqwIABWrFihespZi1fvlyVlZW69957XU8JG/fee68qKiq0fPly11PMWrFihQYMGKD4+HjXUxBixIBRgwcP1oYNG1RcXOx6ikmrVq1S7969deWVV7qeEjaaN2+uPn36aNWqVa6nmOTz+bRx40YTp8PGjxEDRvXp00eStHnzZsdLbCooKFBaWprrGWGne/fuKigocD3DpKrbgqrbBthCDBjVokULJSUlnfUkTITGoUOHVFRUpC5durieEna6dOmiwsJCXirsQF5enpKTk9W8eXPXU+AAMWCUx+NRamqqtmzZ4nqKOdu3b5ckYuAcqr4nVd8jhM6WLVuUmpoa1k9yQ+0hBgzr3r278vPzw/qsWHXR9u3bVb9+fbVt29b1lLDTrl07xcTEEAMh5vf7lZ+fr+7du7ueAkeIAcN+8Ytf6NixYyoqKnI9xZSCggJ16tRJ9erVcz0l7NSrV0+dOnXieQMhVlRUpOPHj6tr166up8ARYsCwqscGiYHQ2r59Ow8RnEeXLl24ZyDECgsLJZ15LhFsIgYMq3pZGzEQOqdOndKnn35KDJxHly5dtHPnTt6nIISqbgN4qatdxIBhjRs31qWXXkoMhNDBgwdVUVGhNm3auJ4Stq655hpVVFRwDowQKioqUkxMjK644grXU+AIMRBC+/fv10cffaSjR4+6niLpzCsKmjVrRgyEUEVFhaTwOUd5IBA45+cuVZ3rvbKy0vESO/bv369mzZqFzSsJjh49qo8++kj79+93PcUMYiBE3n//fbVu3Vq9evVShw4dwuZNgho2bKjy8nLXM8yoioGYmBjHS84c/MeOHVv9zw8//HBYBEHV96bqe4XaV1ZWpoYNG7qeIUnau3ev2rdvr169eqlNmzZ6//33XU8ygRgIkUceeUTff/+9pDN3FWdnZztedMYll1xSvQu1r+q33fr16zteIm3btk1Lly6t/uecnBx98skn7gb9oOp7wz0DofP999/rkksucT1D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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<b>3rd best solution</b>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  x             : Interval(103.469,105)\n",
      "  y             : Interval(54.3575,68)\n",
      "  foot          : Interval(>=1)\n",
      "  head          : Interval(<1)\n",
      "  other         : Interval(<1)\n",
      "  prev_action   : Interval(>=1)\n",
      "  output        : -1.4250, -1.4250\n",
      "  output prob   : 19.4%\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q4YoJSXlop/34vF41LJlS7Vs2VLDhw/XnDlzlJeXp6VLl2rJkiWaO3euBg0apCeeeEJdu3at5n8RUP2Cb9NjY2Or5Zjh9XrPefmRhmfHARFsz549SktLU0pKirZu3ap58+Zpz549mjVrllJTU6v1CbBRUVFKTU3VrFmz9O2332revHn65JNPlJKSosGDB+vbb7+ttr8LQGgRA0AEKi8vV1ZWltq3b68NGzZoyZIl+uKLLzR69GjVq1evxv/+evXqafTo0dq5c6eWLFmi9evXq127dsrKylJ5eXmN//0AqhcxAESYnTt3KjU1VVlZWRo3bpx27typESNGOHlSX3R0tEaMGKGdO3dq7NixysrKUmpqqnbu3BnyLQAuHjEARJCcnBzdcMMNKi8vV35+vv74xz9WPSHKpfj4eM2YMUP5+fk6efKkbrjhBi1ZssT1LAAXiBioRXbt2uV6AmqI3+9Xenq6Ro4cqbS0NG3ZskVdunRxPesnunTpon/84x8aNGiQHnjgAaWnp0f0iVhwftzm1B7EQC3Su3dvbdq0yfUMVLOKigoNGzZM8+bN0/z587Vo0aKwfslrXFycFi9erPnz5+uFF17Q8OHDVVFR4XoWqtmmTZvUu3dv1zNQTYiBWqRt27bq16+f8vPzXU9BNSktLdUdd9yhN998U8uWLdMjjzzietIFe+SRR7Rs2TKtXLlSd955p0pLS11PQjXJz89Xv3791LZtW9dTUE2IgVpk5cqV6tixo2699Vbt2LHD9RxcooqKCt19993avHmz1q5dq3vuucf1pJ9t0KBBWrt2rTZt2qR77rmHewhqge3bt6t///7q1KmTVq5c6XoOqgkxUIvExcVpzZo1at68ufr27at//etfrifhIgUCAT344IP66KOPtHr1avXq1cv1pIvWq1cvrVq1Sh9++KEefPBBRfBJT8376quv1LdvX11zzTVas2ZNWD9chZ+HGKhlrrzySq1bt04NGjTQrbfequPHj7uehIuQlZWlV199VTk5ObXicdk+ffooJydHr776qv7v//7P9RxchGPHjum2227TlVdeqbVr1+qKK65wPQnViBiohRITE5Wbm6uDBw/qoYce4jexCPPaa6/pD3/4g7KysjRkyBDXc6rNkCFDNHXqVD3zzDN6/fXXXc/BzxAIBPTQQw/p4MGDevvtt3k311qIGKilWrdu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jx49XE8xbdSoUfrd734nn8/3P3++azufz6c1a9Zozpw5rqeY1rNnTzVq1EhvvPGGunXr5npORAg+9vyv52CVlZWF7Zk1w/qeAVS/iooK5eTkaPDgwVVvEQo3hg4dqujoaL366quupzj3yiuvKDo6WkOHDnU9xbTo6GgNGTJES5YsCYt31kTohHUMJCQkVJ2c5cSJEyopKTnrI/h12ldddZXDpZFj6dKlOnDggB599FHXU8xr2LChBgwYYP6hgkAgoEWLFmngwIFcj8PAmDFj5PP5tGzZMtdTIkLwz+z27dt/cpw6ceJE1XEsISHB4dLzC+sYiIqKUmJiohITExUXF6fY2NiffAR/Lc4vEAho5syZ6tevn9q3b+96DnTmoYJt27Zp69atrqc48+mnn2r79u0aNWqU6ymQ1KFDB/Xr108zZ84M68e4w0Xwsedcx6i4uLiq41g4H6fCdxmq3TvvvKOCggJNnDjR9RT8qH///mrWrJmmTp3qeoozmZmZatasmfr37+96Cn70+9//Xp9++qnWrl3regpChBgw4vTp03rqqafUvXt39erVy/Uc/Oiyyy7T888/rzfffFNr1qxxPSfkcnNztWrVKs2cOVN16oT185lN6d27t1JTUzVp0iSdPn3a9RyEADFgxF//+ldt3bpVs2fPlsfjcT0HQYYMGaI+ffooPT1d5eXlrueETHl5udLT0/XrX/9agwcPdj0HQTwej2bPnq2tW7fqxRdfdD0HIUAMGHD48GE99dRTGjVqFC8XCkMej0cvvPCC9uzZo+eee871nJCZMWOG9u7dqxdeeIFADUOpqakaOXKkJk2apMOHD7uegxpGDBgwefJk/fDDD3r22WddT8F/0b59e2VkZGj69OnavXu36zk17ptvvlF2drYyMjLUrl0713PwXzz77LP6/vvvNXnyZNdTUMOIgVrunXfe0fz58zV16lTzJ7YJd5MnT1bDhg01fvx411Nq3Pjx45WQkKCnn37a9RScR+PGjZWVlaX58+fzZMJajhioxQoLC3X//ffr9ttv17hx41zPwf8QFxen2bNna9WqVXrjjTdcz6kxb7zxhlavXq3Zs2eH7dnY8G/jxo3TbbfdphEjRqioqMj1HNQQYqCWOnXqlIYNG6a6detq8eLFYf36VvxbWlqa0tLSNHLkyFp57oFPPvlEI0eO1ODBgzVo0CDX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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<b>4th best solution</b>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  x             : Interval(102.944,103.469)\n",
      "  y             : Interval(54.3575,68)\n",
      "  foot          : Interval(>=1)\n",
      "  head          : Interval(<1)\n",
      "  other         : Interval(<1)\n",
      "  prev_action   : Interval(>=1)\n",
      "  output        : -1.4376, -1.4376\n",
      "  output prob   : 19.2%\n"
     ]
    },
    {
     "data": {
      "image/png": "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VKmpqRf8vBePx6NWrVqpVatWGjFihObOnau8vDwtW7ZMS5cu1bx58zR48GA99thj6tatWw3/jYCaF3ybHhsbWyPHDK/Xe87LjzQ8Ow6IYHv37lV6erpSU1O1bds2zZ8/X3v37tXs2bOVlpZWo0+AjYqKUlpammbPnq1vvvlG8+fP18cff6zU1FQNGTJE33zzTY39WQBCixgAIlBFRYWysrLUoUMHbdy4UUuXLtXnn3+uMWPGqEGDBrX+5zdo0EBjxozRrl27tHTpUm3YsEHt27dXVlaWKioqav3PB1CziAEgwuzatUtpaWnKysrS+PHjtWvXLo0cOdLJk/qio6M1cuRI7dq1S+PGjVNWVpbS0tK0a9eukG8BcOGIASCC5OTk6LrrrlNFRYXy8/P1xz/+sfoJUS7Fx8dr5syZys/P18mTJ3Xddddp6dKlrmcB+ImIgTpk9+7drieglvj9fmVkZGjUqFFKT0/X1q1b1bVrV9ezfqRr1676xz/+ocGDB+u+++5TRkZGRJ+IBefHbU7dQQzUIX369NHmzZtdz0ANq6ys1PDhwzV//nwtWLBAixcvDuuXvMbFxWnJkiVasGCBnn/+eY0YMUKVlZWuZ6GGbd68WX369HE9AzWEGKhD2rVrp/79+ys/P9/1FNSQsrIy3XbbbXrjjTe0fPlyPfTQQ64n/WQPPfSQli9frlWrVun2229XWVmZ60moIfn5+erfv7/atWvnegpqCDFQh6xatUqdOnXSzTffrJ07d7qeg4tUWVmpO++8U1u2bNG6det01113uZ70sw0ePFjr1q3T5s2bddddd3EPQR2wY8cODRgwQJ07d9aqVatcz0ENIQbqkLi4OK1du1YtWrRQv3799K9//cv1JFygQCCg+++/Xx9++KHWrFmj3r17u550wXr37q3Vq1frgw8+0P33368IPumpeV9++aX69eunq666SmvXrg3rh6vw8xADdczll1+u9evXq1GjRrr55pt1/Phx15NwAbKysvTKK68oJyenTjwu27dvX+Xk5OiVV17R//3f/7megwtw7Ngx3XLLLbr88su1bt06XXbZZa4noQYRA3VQYmKicnNzdfDgQT3wwAP8JhZhXn31Vf3hD39QVlaWhg4d6npOjRk6dKimT5+up556Sq+99prrOfgZAoGAHnjgAR08eFBvvfUW7+ZaBxEDdVSbNm30wgsvaNmyZVq4cKHrOfiJvv76a91///0aOXKknnjiCddzatyTTz6pkSNH6je/+Y327Nnjeg5+ogULFmj58uV68cUXeXOqOooYqMPS09M1btw4PfLII9q2bZvrOfgJJkyYoMaNG2vhwoUR/aYn/43H49HChQt1xRVXaMKECa7n4CfYtm2bMjMzNX78eA0ePNj1HNQSYqCOe+6559S+fXs9+OCDnPwlzL311ltas2aN5syZU6efmBUXF6c5c+Zo9erVys3NdT0H5+H3+/Xb3/5WHTp00LPPPut6DmoRMVDHxcTEaP78+crPz9fixYtdz8F/cfLkSWVkZKhfv34mfvtKT0/XTTfdpIyMDN7YKIy99NJL2rp1q+bPn6+YmBjXc1CLiAEDevbsqXvuuUeTJk3S0aNHXc/BOcycOVOFhYWaN29enXx44D95PB7NmzdP+/bt08yZM13PwTkcPXpUjz/+uEaOHKkbbrjB9RzUMmLAiJkzZ+rkyZOaNm2a6yn4D7t371Z2drYmTpyoa6+91vWckGnfvr0effRRZWdnc477MDR16lSdPHmSWDOCGDCiWbNmmjRpkhYuXKgDBw64noMgEyZMUGJiYp189cD/8uSTT6pJkyY8mTDMHDhwQAsXLtSkSZPUtGlT13MQAsSAIePGjVNMTIzmzJnjegp+sGvXLr355puaMWOGYmNjXc8JudjYWM2YMUNvvvmmvvjiC9dz8IPZs2erfv36GjdunOspCJGwjgG/36/i4mIVFxertLRUZWVlP/oI/lqcX6NGjTRmzBgtWrRIpaWlrudAUk5Ojho1aqQhQ4a4nuJMenq6GjVqpJycHNdTIKm0tFSLFi3SmDFj1KhRI9dzwl7wsedcx6jS0tLq41g4H6fCOgZKSkqUlJSkpKQkxcfHKy4u7qyPlJSU6q89fPiww6WRY+zYsTpx4oSWLl3qeop5p0+fVk5OjoYPH6769eu7nuNMgwYNNGzYMC1ZskSnT592Pce8nJwclZaW6uGHH3Y9JSIEH3tSUlJ+dJyKj4+vPo6VlJQ4XHp+YR0DqHlXXXWVbr/9dr344ouup5j37rvvqrCwUKNHj3Y9xbnRo0ersLBQ7733nusp5r300ksaOHCgWrZs6XoKQiisY8Dr9VZ/7vP5VFpaetZHXl5e9X9v0KCBi4kRadiwYdq6dav27t3reoppS5Ys0bXXXqvU1FTXU5zr3r272rVrpyVLlrieYtqePXu0detWDRs2zPWUiBF87MnLy/vRccrn81X/9+BjWrgJ6xgIfr11bGzsjz6Cv7EWXptdU2677TZdeumlWrlypespZh07dkwrV67U6NGj+dnVmevv6NGjtWLFCt5p06GVK1cqJiZGt912m+spESP4+uv1es95rDrX14absI4B1I6GDRtqwIABWrFihespZi1fvlyVlZW69957XU8JG/fee68qKiq0fPly11PMWrFihQYMGKD4+HjXUxBixIBRgwcP1oYNG1RcXOx6ikmrVq1S7969deWVV7qeEjaaN2+uPn36aNWqVa6nmOTz+bRx40YTp8PGjxEDRvXp00eStHnzZsdLbCooKFBaWprrGWGne/fuKigocD3DpKrbgqrbBthCDBjVokULJSUlnfUkTITGoUOHVFRUpC5durieEna6dOmiwsJCXirsQF5enpKTk9W8eXPXU+AAMWCUx+NRamqqtmzZ4nqKOdu3b5ckYuAcqr4nVd8jhM6WLVuUmpoa1k9yQ+0hBgzr3r278vPzw/qsWHXR9u3bVb9+fbVt29b1lLDTrl07xcTEEAMh5vf7lZ+fr+7du7ueAkeIAcN+8Ytf6NixYyoqKnI9xZSCggJ16tRJ9erVcz0l7NSrV0+dOnXieQMhVlRUpOPHj6tr166up8ARYsCwqscGiYHQ2r59Ow8RnEeXLl24ZyDECgsLJZ15LhFsIgYMq3pZGzEQOqdOndKnn35KDJxHly5dtHPnTt6nIISqbgN4qatdxIBhjRs31qWXXkoMhNDBgwdVUVGhNm3auJ4Stq655hpVVFRwDowQKioqUkxMjK644grXU+AIMRBC+/fv10cffaSjR4+6niLpzCsKmjVrRgyEUEVFhaTwOUd5IBA45+cuVZ3rvbKy0vESO/bv369mzZqFzSsJjh49qo8++kj79+93PcUMYiBE3n//fbVu3Vq9evVShw4dwuZNgho2bKjy8nLXM8yoioGYmBjHS84c/MeOHVv9zw8//HBYBEHV96bqe4XaV1ZWpoYNG7qeIUnau3ev2rdvr169eqlNmzZ6//33XU8ygRgIkUceeUTff/+9pDN3FWdnZztedMYll1xSvQu1r+q33fr16zteIm3btk1Lly6t/uecnBx98skn7gb9oOp7wz0DofP999/rkksucT1D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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "numbers = [\"1st\", \"2nd\", \"3rd\", \"4th\"]\n",
    "\n",
    "for i, num in enumerate(numbers):\n",
    "    fig, ax = plt.subplots()\n",
    "    ax.invert_yaxis()\n",
    "    ax.axis(\"off\")\n",
    "    matplotsoccer.field(ax)\n",
    "\n",
    "    sol = search.get_solution(i)\n",
    "    box = sol.box()\n",
    "    x = box.get(icolumns[\"x\"], prune_box[icolumns[\"x\"]])\n",
    "    y = box.get(icolumns[\"y\"], prune_box[icolumns[\"y\"]])\n",
    "    \n",
    "    ex = veritas.get_closest_example(sol, np.zeros(len(columns)), eps=1e-3)\n",
    "    \n",
    "    display(HTML(f\"<b>{num} best solution</b>\"))\n",
    "    for k, v in box.items():\n",
    "        print(f\"  {columns[k]:14s}: {v}\")\n",
    "    print(f\"  output        : {at.eval(ex)[0,0]:.4f}, {sol.output:.4f}\")\n",
    "    print(f\"  output prob   : {100.0 / (1.0 + np.exp(-sol.output)):.1f}%\")\n",
    "    \n",
    "    r = Rectangle((x.lo, y.lo), x.hi-x.lo, y.hi-y.lo, fc=\"orange\")\n",
    "    ax.add_patch(r)\n",
    "    \n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "040065b1-ffba-4cc8-b465-d5063d933356",
   "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
}
