{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "understood-channel",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import minimize\n",
    "from sklearn.metrics import log_loss\n",
    "\n",
    "\n",
    "def not_that_deep(X, y, sigma=10., loss=\"mse\", seed=0):\n",
    "    '''\n",
    "    X: input data\n",
    "    y: labels\n",
    "    sigma: sigma value for bump activation\n",
    "    loss: mse or bce (binary cross entropy, equiv to log loss)\n",
    "    seed: random seed\n",
    "    '''\n",
    "    \n",
    "    # x = [1, x_1, x_2]\n",
    "\n",
    "    X_ = np.vstack((X.shape[0] * [1], X.T)).T\n",
    "    \n",
    "    np.random.seed(seed)\n",
    "    beta = np.random.randn(X_.shape[1])\n",
    "\n",
    "    def xorloss(beta):\n",
    "        y_pred = np.exp(-0.5 * np.square(X_.dot(beta) / sigma)) \n",
    "\n",
    "        # without smoothing\n",
    "        # tildy = X_.dot(beta) != 0\n",
    "        \n",
    "        if loss == \"mse\":\n",
    "            return np.linalg.norm(y - y_pred) ** 2\n",
    "        elif loss == \"bce\":\n",
    "            return log_loss(y, y_pred)\n",
    "\n",
    "    res = minimize(xorloss, beta, method=\"BFGS\")\n",
    "\n",
    "    return res.x\n",
    "\n",
    "\n",
    "def decision(w, b, x_0):\n",
    "    \"\"\"\n",
    "    The hyperplane is H = {x: <w, x> + b = 0}.\n",
    "    This function return x[1] given x[0] for x in H\n",
    "    \"\"\"\n",
    "    return - (x_0 * w[0] + b) / w[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "refined-publication",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Betas = [ 44.56763053 -45.00623116 -44.78855279]\n"
     ]
    },
    {
     "data": {
      "image/png": "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AePHj/c4lYgEggpKQkZiYiIjR46kW7duAOzZswddkEQkfKmgJGRER0fzwAMPUKFCBTIzM2ndujV//vOf+f573V5MJBypoCQkRUVF0bNnT+bOnUtCQgITJ07U3pRImFFBSUiKjIxkwIABrF69mvr169OzZ086duzId99953U0EfETFZSEtNq1a/PZZ5/x0ksvsXDhQhITE3n55ZfJycnxOpqIFJEKSkJeREQEffv2Zc2aNTRr1oy77rqL9u3bs2XLFq+jiUgRqKAkbNSqVYt58+Yxfvx4UlNTWbx4sdeRRKQILFjfWE5KSnKpqalex5AQtWvXLuLi4jAz3nrrLRITE6lbt67XsUSkAGa2wjmXlH+59qAkLJ199tmYGZmZmfTr149HH33U60gicor8ckddkWBVqlQpli9f/tsp6N9++y0HDx4kISHB42QicjLag5Kwd84553DuuecC8Le//Y3GjRszdOhQsrKyPE4mIieigpISZcyYMVx33XUMGjSIZs2asWrVKq8jichxqKCkRImLi2PatGm8/fbb7Nixg6ZNmzJ48GAyMzO9jiYi+aigpETq0qULGRkZ9OjRg6effpomTZqQkpLidSwRyUMFJSVWpUqVmDx5Mu+//z779u2jRYsWDB482OtYIuKjgpIS75prriE9PZ1evXpRpkwZr+OIiI9fCsrMOpjZejPbZGaPHGfMDWaWYWbpZvZvf2xXxF8qVKjAK6+8wsMPPwzAO++8w/3338/hw4c9TiZSchX5c1BmFgmMAf4H2AakmNls51xGnjG1gUeBVs65vWZ2dlG3K1IczAyAtLQ0Fi9eTFSUPioo4hV/7EE1AzY557Y4544C04DkfGNuB8Y45/YCOOd2+WG7IsXmySefZNGiRURHR7N3714eeughDhw44HUskRLFHwVVDdia5/k237K86gB1zGyxmS01sw4FvZCZ3WFmqWaWunv3bj9EEzl9sbGxAMydO5eRI0eSmJjInDlzPE4lUnIE6iSJKKA20AboAbxiZmfmH+ScG++cS3LOJcXFxQUomsiJdevWjSVLllCmTBk6dOhA79692bdvn9exRMKePwpqO3BenufVfcvy2gbMds5lOee+BjaQW1giIaFFixasXLmSRx99lEmTJpGQkMD777/vdSyRsOaPgkoBaptZLTOLAboDs/ONeZfcvSfMrDK5h/x0NzkJ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+lGlShW6dOlCjx492L17t9eRJESooESkWDVu3JiUlBSGDBnCW2+9RUJCAtOnTydYb5YqwUMFJSLFLjo6mkGDBvHll19So0YNunXrRteuXdm5c6fX0SSIqaBEJGASExP54osveO655/jwww+Jj49n6tSpXseSIKWCEpGAioqK4qGHHmLVqlVcdNFFpKSkeB1JgpROMxcRT1x00UUsXLiQrKwsAJYsWcK6devo1asXZuZxOgkG2oMSEc9ERkYSGxsLwOuvv87TTz/NoUOHPE4lwUIFJSJBYfz48SxcuJCyZcty5MgRJk2apDv4lnB+KSgz62Bm681sk5k9UsD6/maWYWarzexTM6vhj+2KSPiIiIjgvPPOA2Dq1KncdttttG3blk2bNnmcTLxS5IIys0hgDHA1EA/0MLP4fMNWAknOuQbATODvRd2uiISv3r1789prr5GWlkaDBg0YPXo02dnZXseSAPPHHlQzYJNzbotz7igwDUjOO8A5N9859+uB5aVAdT9sV0TClJnRq1cv0tPTadeuHf379+eyyy7jq6++8jqaBJA/CqoasDXP822+ZcfTG/iooBVmdoeZpZpZqi6HIiLVqlVj9uzZTJ06lfXr19OoUSOeffZZjh075nU0CYCAniRhZjcDScCIgtY758Y755Kcc0lxcXGBjCYiQcrMuOmmm8jIyKBTp048+uijtGjRgv3793sdTYqZPwpqO3BenufVfct+x8zaAwOBzs65TD9sV0RKkCpVqjBz5kxmzJhBkyZNKF++PICu6RfG/FFQKUBtM6tlZjFAd2B23gFm1hh4mdxy2uWHbYpICXX99dfz8ssvY2Zs2LCBli1bsm7dOq9jSTEockE5544BfYE5wDpgunMu3cyGmFln37ARQDlghpmtMrPZx3k5EZFC27lzJwcOHODMM8/0OooUAwvW3eOkpCSXmprqdQwRCXI5OTlERESQk5PDnXfeSe/evWnRooXXseQUmNkK51xS/uW6koSIhLSIiNwfY1u3bmXOnDm0atWKBx98UJdMCgMqKBEJCzVq1GDt2rXccccd/OMf/6Bhw4YsXLjQ61hSBCooEQkb5cuXZ+zYsXz66adkZ2fTunVr7r33Xg4ePOh1NDkNKigRCTtXXHEFa9as4b777mPMmDHUr1+fTz/91OtYcopUUCISlsqWLcsLL7zAggULiImJoX379sydO9frWHIKVFAiEtYuvfRSVq1axQsvvEC7du0A2LVLH8cMBSooEQl7pUuX5r777iMyMpLdu3eTkJDA8OHDvY4lJ6GCEpESpXz58vTp04fOnXOvI/DrLecl+ER5HUBEJJBKlSrFkCFDfnt+2223kZ2dzUsvvYQuUh1ctAclIiWWc4569erx9ttvEx8fz5tvvqmLzwYRFZSIlFhmxuOPP86XX35JrVq16N69O127dmXnzp1eRxNUUCIiJCYmsmTJEp577jk+/PBD4uPjmTx5svamPKaCEhEBoqKieOihh0hLS6NevXrceuutdOrUiW3btnkdrcRSQYmI5FG3bl0WLFjA888/z/z583nxxRe9jlRi6XYbIiLHsXnzZqpWrUrZsmX58ssvqVSpEjVr1vQ6Vtg53u02dJq5iMhxXHjhhUDu2X633347WVlZpKWlYWYeJysZVFAiIidhZrzzzjvs2rULM+Pw4cNs376dP/3pT15HC2t6D0pEpBDOP/98kpJyj0I988wzNGjQgFGjRpGdne1xsvClghIROUV333037du3Z8CAAVx66aWsW7fO60hhSQUlInKKzj33XGbNmsUbb7zBhg0baNSoEcOHD+fYsWNeRwsrKigRkdNgZtx4441kZGTQuXNnHnvsMZo3b87q1au9jhY2VFAiIkVQpUoVZsyYwYwZM9i2bRtNmjThySefJCcnx+toIU8FJSLiB9dffz3p6el069aN9PR0IiL047Wo/HKauZl1AF4AIoFXnXPP5ltfCpgMNAF+Aro5577xx7bDlXOOr/ccYstPvxAZYdSJK0e1CqW9jiUiJ1C5cmWmTp362z2m1q9fz6RJkxg8eDCxsbEA7EpbxJaPJ5N1+CDVL+1MjbbXExGpT/wUpMgVb2aRwBjgaiAe6GFm8fmG9Qb2Ouf+BIwGnivqdsPd0m/3krp1H7t/OcrOA5ks/mYPGTt/9jqWiBRCdHQ0AO+99x4vv/wy+/btA+Dref8hZfR97EpbyN4NK8l44++kPn+/h0mDmz/2QZsBm5xzW5xzR4FpQHK+McnAJN/jmUA700exj+tg5jG27jtEdp7LUGXnONbuPMAxHdcWCRkPPvgg69ato2rVqhw7mslzgx7m0KFfflufnXmY3WuWsP+79R6mDF7+KKhqwNY8z7f5lhU4xjl3DNgPnJX/hczsDjNLNbPU3bt3+yFaaNp/JIuIAvrbDA4d1YcCRULJ2WefDcB/53zIy8u2ct9HX7N216Hf1ltEJAe2bvQqXlALqnfxnHPjnXNJzrmkknzr5Qqx0b/be/qVc1AmJtKDRCJSVO2v7sSwq+sAMPDT73g5dSeHs3JwOdmUP6+Ox+mCkz8KajtwXp7n1X3LChxjZlFABXJPlpAClCsVRY2KZYiM+P+9qMgII/Gc8kTpzCCRkBQRFU33B57kn50v4tq6Fflo4z7u++gbvo6tQfnzVVAF8cepIylAbTOrRW4RdQduzDdmNnAr8AVwPfBfF6z3+QgSzc+vyNnlSrFlzy9EmVFbZ/GJhLxa/9ODclVrUO3jyXT4agsj567l3pdnkZZ9OyNHjqRChQpeRwwqfrkflJl1BJ4n9zTz151zz5jZECDVOTfbzGKBKUBjYA/Q3Tm35USvqftBiUi4O3z4ME8++SQjR47knHPOYcGCBVxwwQVexwq4490PSjcsFBHxWEpKCuPGjWP8+PFERkaSk5NToj7oe7yCKjl/AyIiQapp06a89tprREZG8sMPP9CgQQPmz5/vdSzPqaBERILI/v37OeOMM6hatarXUTynghIRCSJ16tRhyZIl1KtXD4C+ffsybdo0gvXtmOKkghIRCTK/Xmjn4MGDpKSk0KNHD7p06cKOHTs8ThZYKigRkSBVrlw5Fi9ezIgRI5gzZw7x8fFMmjSpxOxNqaBERIJYVFQUDz74IGlpaSQmJnLbbbdxzTXXsHXr1pP/zyFOBSUiEgLq1KnD559/zosvvsjnn39OQkIC48ePD+u9KRWUiEiIiIiI4N5772XNmjU0bdqUO++8k7Fjx3odq9iooEREQswFF1zAJ598wqRJk7jtttsA2LZtW9jdZl4FJSISgsyMv/zlL5QpU4bDhw/Tpk0bevbs6XUsv9J9hkVEQlxsbCyDBg2iZs2aAGRmZhIVFUVkZGjfnkd7UCIiIc7MuPXWW7n88ssBePzxx2nVqhUZGRkeJysaFZSISJhp0qQJmzZtonHjxgwbNoysrCyvI50WFZSISJjp3r076enpJCcnM3DgQFq0aEFaWprXsU6ZCkpEJAxVqVKF6dOnM3PmTLZt20ZSUhJPPPEER48e9TpaoamgRETCWNeuXcnIyKB79+4MGTKEJk2aECr32lNBiYiEubPOOospU6bw3nvvsWfPHkaNGuV1pELRaeYiIiVEp06dSE9PJzs7G4D169fz008/0bJlS4+TFUwFJSJSgpx55pm/PR40aBCfffYZ33zzDWXKlPEu1HHoEJ+ISAn12muv8d5771GmTBmys7NJSUnxOtLvqKBEREqoM844g+bNmwMwYcIEmjVrxj333MOBAwc8TpZLBSUiIvTo0YN+/foxduxYEhMTmTt3rteRVFAiIgJly5Zl9OjRLFq0iNKlS3PVVVfx17/+lX379nmWSQUlIiK/admyJatWreLhhx9mwoQJJCYm8v7773uSpUgFZWaVzGyemW30/bdiAWMamdkXZpZuZqvNrFtRtikiIsUrNjaWZ599lqVLl1KxYkWuvfZabrnlFn755ZeA5ijqHtQjwKfOudrAp77n+R0C/uKcSwA6AM+b2ZlF3K6IiBSzpk2bsmLFCgYPHsz27dspXbp0QLdf1IJKBib5Hk8C/px/gHNug3Nuo+/x98AuIK6I2xURkQCIiYnhqaeeYt68eURERLBz50569+7Nrl27in3bRS2oKs65Hb7HO4EqJxpsZs2AGGDzcdbfYWapZpa6e/fuIkYTERF/+fXmh1988QUzZ85kz549xb5Nc86deIDZJ0DVAlYNBCY5587MM3avc+4P70P51p0DfAbc6pxberJgSUlJLlQuaCgiUpLs37+fChUq+O31zGyFcy4p//KTXurIOdf+BC/6g5md45zb4SugAvf5zKw88AEwsDDlJCIiwcuf5XQiRT3ENxu41ff4VmBW/gFmFgO8A0x2zs0s4vZERKSEKGpBPQv8j5ltBNr7nmNmSWb2qm/MDUBr4DYzW+X706iI2xURkTB30vegvKL3oERESobjvQelK0mIiEhQUkGJiEhQUkGJiEhQUkGJiEhQUkGJiEhQUkGJiEhQUkGJiEhQCtrPQZnZbuBbP7xUZeBHP7yOlzSH4BAOc4DwmIfmEBz8NYcazrk/3OUiaAvKX8wstaAPgIUSzSE4hMMcIDzmoTkEh+Kegw7xiYhIUFJBiYhIUCoJBTXe6wB+oDkEh3CYA4THPDSH4FCscwj796BERCQ0lYQ9KBERCUEqKBERCUphV1BmVsnM5pnZRt9/KxYwppGZfWFm6Wa22sy6eZE1PzPrYGbrzWyTmT1SwPpSZvamb/0yM6vpQcwTKsQc+ptZhu/v/VMzq+FFzhM52RzyjOtqZs7Mgu5U4cLMwcxu8H0t0s3s34HOWBiF+Pd0vpnNN7OVvn9THb3IeTxm9rqZ7TKztcdZb2b2om9+q83s4kBnPJlCzOEmX/Y1ZrbEzBr6bePOubD6A/wdeMT3+BHguQLG1AFq+x6fC+wAzvQ4dySwGbgAiAHSgPh8Y+4Gxvkedwfe9Prv+zTm0BYo43vcJxTn4Bt3BrAAWAokeZ37NL4OtYGVQEXf87O9zn2a8xgP9PE9jge+8Tp3vnytgYuBtcdZ3xH4CDCgBbDM68ynMYeWef4dXe3POYTdHhSQDEzyPZ4E/Dn/AOfcBufcRt/j74FdwB8+xRxgzYBNzrktzrmjwDRy55JX3rnNBNqZmQUw48mcdA7OufnOuUO+p0uB6gHOeDKF+ToAPA08BxwJZLhCKswcbgfGOOf2AjjndgU4Y2EUZh4OKO97XAH4PoD5Tso5twDYc4IhycBkl2spcKaZnROYdIVzsjk455b8+u8IP39Ph2NBVXHO7fA93glUOdFgM2tG7m9nm4s72ElUA7bmeb7Nt6zAMc65Y8B+4KyApCucwswhr97k/vYYTE46B99hmPOccx8EMtgpKMzXoQ5Qx8wWm9lSM+sQsHSFV5h5PAncbGbbgA+BewMTzW9O9Xsm2Pn1ezrKXy8USGb2CVC1gFUD8z5xzjkzO+559L7fVKYAtzrncvybUk7EzG4GkoDLvc5yKswsAhgF3OZxlKKKIvcwXxtyf+NdYGb1nXP7vAx1GnoAE51z/zCzS4ApZpao7+fAM7O25BbUpf56zZAsKOdc++OtM7MfzOwc59wOXwEVeOjCzMoDHwADfbvWXtsOnJfneXXfsoLGbDOzKHIPafwUmHiFUpg5YGbtyf1l4nLnXGaAshXWyeZwBpAIfOY7uloVmG1mnZ1zqQFLeWKF+TpsI/e9gizgazPbQG5hpQQmYqEUZh69gQ4AzrkvzCyW3AuYBuMhy4IU6nsm2JlZA+BV4GrnnN9+JoXjIb7ZwK2+x7cCs/IPMLMY4B1yj/3ODGC2E0kBaptZLV++7uTOJa+8c7se+K/zvTMZJE46BzNrDLwMdA7S9z1OOAfn3H7nXGXnXE3nXE1yj7kHUzlB4f4tvUvu3hNmVpncQ35bApixMAozj++AdgBmVg+IBXYHNGXRzAb+4jubrwWwP89bFCHBzM4H3gZucc5t8OuLe32GiL//kPuezKfARuAToJJveRLwqu/xzUAWsCrPn0ZBkL0jsIHc98MG+pYNIfcHIOR+880ANgHLgQu8znwac/gE+CHP3/tsrzOf6hzyjf2MIDuLr5BfByP3UGUGsAbo7nXm05xHPLCY3DP8VgFXep05X/7/kHuWcBa5e629gbuAu/J8Hcb45rcmSP8tnWwOrwJ783xPp/pr27rUkYiIBKVwPMQnIiJhQAUlIiJBSQUlIiJBSQUlIiJBSQUlIiJBSQUlIiJBSQUlIiJB6f8A8RxOJgbLbIcAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = np.array([[0, 0], [0, 1], [1, 0], [1, 1]], dtype=np.float32)\n",
    "y = np.array([0, 1, 1, 0], dtype=np.float32)\n",
    "\n",
    "plt.scatter(X[:, 0], X[:, 1], c=y, s=30, cmap=plt.cm.Paired)\n",
    "plt.grid(None)\n",
    "\n",
    "x_range = [-0.2, 1.2]\n",
    "beta = not_that_deep(X, y, sigma=10., loss=\"mse\", seed=2023)\n",
    "print(f\"Betas = {beta}\")\n",
    "dec_x = [decision(beta[1:], beta[0], x_) for x_ in x_range]\n",
    "plt.plot(x_range, dec_x, c=\"k\", linestyle=\"-.\")\n",
    "plt.grid(None)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "weird-spoke",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Betas = [ 53.10898041 -53.10745961 -53.10953304]\n"
     ]
    },
    {
     "data": {
      "image/png": "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ZedvpjyOneC5kiykJkk458Y555Kdc8nVq1f3Oo5nqpybjMv5/2+gloo2ysZFU6l6DcpU/0Ovi0gYiI+NpkKpP77X5JyjZnnd6LQgwSqo7cBZeZZr+9dJAWJKlSb57pFElypNdHxZLvXVYmiXRFrdM4qtW7dy+eWXs2HDBq9jisgpale/CqViooiJMmKijGiDNnWrEBcTUscKISNYV5KYBQw0s2lAa2C/c27HSf6fEi2hxcVcMno+u9csJiomlupN2hEdG8fSOXNYtGgRzZo146mnnuJvf/sb0dHRXscVkUKoEB/LX5LOYOcvRziWk3vkpHI6PgvEB0PN7G2gA1AN+BEYBsQCOOfG+qeZ/53cmX6HgH7OudQTvWZycrJLTT3hJiXWDz/8wG233cZHH31E69atGT9+PImJiV7HEhE5LWa2zDmX/If1oXrlAhXUiTnnePvtt7nrrrs4ePAgjz/+OPfff/9vF6YVEQkXxysoHVuGKTPj2muvJSMjg+7du/PII4/QunVr0tLSvI4mIhIQKqgwl5CQwPTp05k5cybbtm2jXbt27N17oo+kiYiEBxVUhOjZsycZGRn885//pEqVKgB8++23HqcSETl9KqgIUrVqVbp37w7AJ598QoMGDZg3b57HqURETo8KKkK1a9eOIUOG0L59ewAOHjzocSIRkVOjgopQlSpV4oknniAuLo79+/fj8/m49957OXTokNfRREQKRQVVAkRHR3PFFVcwcuRImjZtyldffeV1JBGRk1JBlQDlypVj9OjRfPHFFzjn6NChA3feeScHDhzwOpqIyHGpoEqQDh06sGrVKgYNGsSYMWNo0qQJc+fO9TqWiEiBVFAlTNmyZRk5ciQLFy4kPj6eSy65hAEDBrB//36vo4mI/I4KqoRq27YtK1eu5MEHH2TChAksX77c60giIr+jgirB4uPjee6559i0aRMdO3YEYMaMGboShYiEBBWUULduXQB+/PFHbrjhBp588kmPE4mIBO9+UBIGEhISWLJkCfXr1wdg3bp1VK5cmRo1anicTERKIh1Bye80b96cihUr4pzjxhtvxOfzMW3aNEL1tiwiErlUUFIgM2PChAmcc8459OnThx49erBjh26CLCLBo4KS40pMTGTRokW8+OKLzJ49m8TERCZOnKijKREJChWUnFB0dDSDBw9m1apVNGnShH79+tG1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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(X[:, 0], X[:, 1], c=y, s=30, cmap=plt.cm.Paired)\n",
    "plt.grid(None)\n",
    "\n",
    "x_range = [-0.2, 1.2]\n",
    "beta = not_that_deep(X, y, sigma=10., loss=\"bce\", seed=2023)\n",
    "print(f\"Betas = {beta}\")\n",
    "dec_x = [decision(beta[1:], beta[0], x_) for x_ in x_range]\n",
    "plt.plot(x_range, dec_x, c=\"k\", linestyle=\"-.\")\n",
    "plt.grid(None)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
