{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating data with TabEBM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "notebookRunGroups": {
     "groupValue": "1"
    }
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "notebookRunGroups": {
     "groupValue": "1"
    }
   },
   "outputs": [],
   "source": [
    "from TabEBM import TabEBM\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_two_blobs_at_distance(num_samples=200, blob1_num_samples=None, blob2_num_samples=None, distance=1.0, random_state=42):\n",
    "\t\"\"\"\n",
    "\tCreate two Gaussian blobs at distance D from the center\n",
    "\t\"\"\"\n",
    "\tif num_samples!=None:\n",
    "\t\tnp.random.seed(random_state)\n",
    "\t\tX1 = np.random.randn(num_samples//2, 2) # class 1\n",
    "\t\tX2 = np.random.randn(num_samples//2, 2) # class 2\n",
    "\telse:\n",
    "\t\tX1 = np.random.randn(blob1_num_samples, 2) # class 1\n",
    "\t\tX2 = np.random.randn(blob2_num_samples, 2) # class 2\n",
    "\n",
    "\tX1[:,0] -= distance/2\n",
    "\tX2[:,0] += distance/2\n",
    "\n",
    "\tX = np.concatenate([X1, X2], axis=0)\n",
    "\ty = np.concatenate([np.zeros(len(X1)), np.ones(len(X2))], axis=0)\n",
    "\n",
    "\treturn X, y"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data Generation using TabEBM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6y1UVVXhySefxBNPPIE333xT9na3b9+OefPmYcGCBaisrMSUKVPwy1/+sttzLly4gJtvvhkbN27Enj17MGPGDMycORMnTpwAALzzzjsYMGAAnnnmGdTX16O+vh6AtEr9mDFj8N5772Hfvn3453/+Z/zoRz/C559/HrA8lZWVmDp1KkpLS7F161Z8+umnmDlzZq8bkHpdunQJy5YtwxdffIF3330Xx44dw5w5c3x/X7p0KaqqqvDXv/4VBw4cwEsvvYS+ffsCAP7rv/4L69evx5tvvomDBw/i9ddfR3FxsexjR0QGpcmNcCKk1f3UTp0SYsMGId59V/p96lTUbxlUeXm5SExMFE6n03cPsoSEBPH2228LIaR7pTkcDrFly5Zur5s3b564++67A77v/Pnzxe23395tO8HuX3b33XeLm2++udtjd911V7f7qflz9dVXixUrVvj+P3DgQPHcc88FfY0QQtxyyy3i5z//edDy3HDDDQH/3vN+aj3t2LFDABDnz58XQggxc+ZMMXfuXL/PffDBB8V3vvMd4fF4Qpa7Jzn7y/upESlL7v3U4r6n5nIBVVWAEEB+vvS7qkr9HtuUKVNQWVmJ7du3o7y8HHPnzsXtt98OADh8+DDa2trw3e9+FykpKb6f3/3udzhy5IjvPVauXIkxY8YgJycHKSkpeOWVV3w9KDkOHDiA6667rttj48eP7/b/CxcuYNGiRRg+fDgyMjKQkpKCAwcOhNxOZ2cnli1bhhEjRiArKwspKSn44IMPgr7O21OTa9euXZg5cyaKioqQmpqKSZMmAYBvGw888ADeeOMNjB49Go899hi2bNnie+2cOXNQWVmJYcOG4aGHHsKGDRtkb5eIjCvug5rbDbS1AZmZQEKC9LutTXpcTU6nE0OGDMGoUaPw29/+Ftu3b8err74KQAokAPDee++hsrLS91NVVeWbV3vjjTewaNEizJs3Dxs2bEBlZSXmzp2Ljo4ORcu5aNEirF27Fr/61a/wf//3f6isrMSIESNCbufZZ5/FCy+8gMcffxwff/wxKisrMX369KCvs9vtssvlcrkwffp0pKWl4fXXX8eOHTuwdu1aAPBt46abbvLN99XV1WHq1KlYtGgRAODb3/42ampqsGzZMly8eBHf//73cccdd8jePhEZUx+9C6A3mw1wOIDmZimgNTdL/9fyZsUJCQl44oknsHDhQtxzzz0oLS2F1WrFiRMnfL2Pnj777DOUlZXhpz/9qe+xrr04OYYPH47t27d3e2zbtm29tjNnzhzcdtttAKSAe+zYsW7PSU5O7jXv9dlnn2HWrFn44Q9/CECaAzx06BBKS0sDlmfkyJHYuHEjnn766ZBlr66uRmNjI37961+jsLAQALBz585ez8vJyUF5eTnKy8sxceJEPProo1i+fDkAIC0tDXfddRfuuusu3HHHHZgxYwaampqQlZUVcvtEZEyq9tReeukljBw5EmlpaUhLS8P48ePx17/+Vc1Nhs3pBEpLAYsFqKuTfpeWSo9r6c4770RiYiJWrlyJ1NRULFq0CI888ghee+01HDlyBLt378aKFSvw2muvAQCGDh2KnTt34oMPPsChQ4ewdOlS7NixI6xtPvTQQ3j//fexfPlyfPXVV3jxxRfx/vvvd3vO0KFD8c4776CyshJffPEF7rnnHng8nm7PKS4uxubNm1FbW4uzZ8/6Xvfhhx9iy5YtOHDgAO6//36cPn06aHmWLFmCHTt24Kc//Sn27t2L6upqvPTSS7737KqoqAjJyclYsWIFjh49ivXr12PZsmXdnvPkk09i3bp1OHz4MPbv348///nPGD58OADgP//zP/GHP/wB1dXVOHToEN566y30798/4IXnHR0dvh5zR0cHamtrUVlZicOHDwfdJyLSmJoTe+vXrxfvvfeeOHTokDh48KB44oknRFJSkti3b5+s12uVKCKEEBcuCHH2rPRbbYESOCoqKkROTo64cOGC8Hg84vnnnxfDhg0TSUlJIicnR0yfPl1s2rRJCCElk8yZM0ekp6eLjIwM8cADD4jFixeLUaNGhdxOV6+++qoYMGCAsNvtYubMmWL58uXdEkVqamrElClThN1uF4WFheLFF1/slbCxdetWMXLkSF/SixBCNDY2ilmzZomUlBSRm5srfvGLX4h77703ZHk++eQTUVZWJqxWq8jIyBDTp08Xzc3NQojeiSJr1qwRxcXFwmq1ivHjx4v169cLAGLPnj1CCCGWLVsmhg8fLux2u8jKyhKzZs0SR48eFUII8corr4jRo0cLp9Mp0tLSxNSpU8Xu3bsDlqumpkYA6PUzadIkv89nogiRsuQmiliEEELLIJqVlYVnn30W8+bNC/nc1tZWpKeno6WlBWlpad3+5na7UVNTg5KS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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X, y = create_two_blobs_at_distance(num_samples=None, blob1_num_samples=150, blob2_num_samples=150, distance=2, random_state=40)\n",
    "# ==== scatter the points ====\n",
    "fig, ax = plt.subplots(1, 1, figsize=(5, 5))\n",
    "ax.scatter(X[y == 0][:, 0], X[y == 0][:, 1], c='red', label='Real data class 0', alpha=0.2, s=10)\n",
    "ax.scatter(X[y == 1][:, 0], X[y == 1][:, 1], c='blue', label='Real data class 1', alpha=0.2, s=10)\n",
    "ax.set_title('Real data')\n",
    "ax.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model that can be used for inference only\n",
      "Using a Transformer with 25.82 M parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 42\n",
      "Global seed set to 42\n",
      "Global seed set to 42\n",
      "Global seed set to 42\n"
     ]
    }
   ],
   "source": [
    "tabebm = TabEBM()\n",
    "augmented_data = tabebm.generate(\n",
    "    X, y, num_samples = 50,\n",
    "    sgld_steps = 200\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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xkYoFAq1iu7o0aMWt83S/Y0bN05rdqBSpRYUFAAADh8+jLKyMjzzzDNa66nUYKZQOSB89913aGpq0rvOoEGD0K5dO6xevVq97MSJEzh+/DieeOKJFutPmDBBS8XXt29fNDY24sKFCybbY+4+duzYgevXr2PUqFHq+3f16lV4enrirrvuwq5du8w+loqmpiZs3rwZQ4cOVdtkNdFsjy5bt26Fl5cXJk2apF7m6emJ5557rsW6vr6+6v9rampw9epV3H333QBg9jOluY+KigpcvXoV/fr1Q0FBASoqKszaByEsJNQIs1m6dCl27NiBDRs24L777sPVq1chlUrVv587dw6MMcyZMwfh4eFaf3PnzgUAlJWVAeAd3eLFi9GpUydIpVK0adMG4eHhOH78uFWdh6X7i42N1fquUqGWl5cDgLqT79Spk9Z63t7eSExMNNmeRx99FL1798ZTTz2Ftm3b4rHHHsO6deu0BJyHhwcef/xxbN68GdXV1QCA1atXQyaTYeTIkRa32RxM7ePPP/8EANxzzz0t7uH27dvV988Srly5gsrKStx6660Wb3vhwgVERUXB399fa3lSUlKLda9du4YXXngBbdu2ha+vL8LDw5GQkAAAZj9T+/btw6BBgyCXyxEcHIzw8HC1HZSEmmtANjXCbO688071SHvYsGHo06cPRo8ejTNnzsDf31/dYU+fPh1paWl699GxY0cAwDvvvIM5c+bgySefxPz58xEaGgoPDw9MnTrV4MzGGJbuT9OGpQljzOJj68PX1xd79+7Frl278MMPP+DHH3/EN998g3vuuQfbt29XH3/s2LFYuHAhNm/ejFGjRmHNmjV44IEH9M4G7dFmU/tQXatVq1YhMjKyxXpiddMHgEceeQQ5OTmYMWMGbrvtNvUzOXjwYLOeqfz8fAwcOBBdunTBBx98gJiYGPj4+GDr1q1YvHixVc8l4XzE+4QSokblnTdgwAB8/PHHmDlzpnoG4+3tjUGDBhndfsOGDRgwYAA+//xzreXXr19XG+8twd77i4uLA8BnLvfcc496eX19PQoLC9G9e3eT+/Dw8MDAgQMxcOBAfPDBB3jnnXfw6quvYteuXerrc+utt+If//gHVq9ejfbt26OoqAhLliyxuL0qjKnyzKFDhw4AgIiICJP30NxjhYeHIzAwECdOnLC4PXFxcdi5cyeqqqq0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bNu2DU8++aTWfrp166b1PSoqyqRKDeCqyYCAAL3bnTt3DtXV1bj33nvh7++v/vvyyy+Rn59v9jnm5ubC09MT/fr1M2v9U6dOwcvLCz169FAv69KlSwsniJ9//hkDBw5EdHQ0AgICMGbMGCgUClRXVxvd/5EjRzB06FDExsYiICBA3a6ioiK7tL+xsRHz589HSkoKQkND4e/vj59++km9/+7du2PgwIFISUnByJEj8Z///IdXI/f0RGi7dsh8/HGkDRuGoY89hg//8x+UmnEfCYJoSasXajExwKpV2stWreLLHYlMJsO9996LOXPmICcnB5mZmZg7d67697Fjx6KgoAD79+/HV199hYSEBPTt21drH97e3lrfJRIJmpqaTB7b2HYq+9QPP/yA3Nxc9V9eXp7armYOvr6+Zq9rLufPn8cDDzyAbt264dtvv8WRI0ewdOlSANxxwhBKpRJpaWkIDAzE6tWrcejQIWzatMnodpa2f+HChfjwww/xyiuvYNeuXcjNzUVaWpp6/56entixYwe2bduG5ORkLFmyBElJSSgsLAR8fLBi5Urs/9//kNqnD7759lt07twZBw4csKgNBEGQUMPFi8CYMdrLxozhy51JcnIylBoBMGFhYRg2bBhWrFiB7OxsjBs3zuJ9ent7o9FMF3HNdkilUhQVFaFjx45afzF/S3qfvz3zjO07JSUFTU1N2LNnj1nH7dKlCxoaGnDkyBH1sjNnzmiFDRw5cgRNTU14//33cffdd6Nz584oKSnR2o+Pj0+Ldp0+fRoKhQLvvvsu+vbtiy5dupic0Vra/n379iE9PR1PPPEEunfvjsTERJw9e1ZrHYlEgt69e2PevHk4duwYfHx81MIVnp74R8+emPXqq8jJycGtt96KNWvWmHVsMaNU8mrVFNtFOItWL9SmTm1WOe7b16yKtHMMsRqFQoF77rkHX331FY4fP47CwkKsX78e7733HtLT07XWfeqpp7By5UqcOnUKGRkZFh8rPj4eO3fuxKVLl7iqywwCAgIwffp0TJs2DStXrkR+fj6OHj2KJUuWYOXKlQCAuLg4SCQSfP/997hy5Yp6dqd77IyMDDz55JPYvHkzCgsLsXv3bqxbt07vcZOSkjB48GBMnDgRBw8exJEjR/DUU09pzZg6duyI+vp6LFmyBAUFBVi1ahU+/fTTFsetqqrCzp07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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ==== Scatter the real points ====\n",
    "fig, ax = plt.subplots(1, 1, figsize=(5, 5))\n",
    "ax.scatter(X[y == 0][:, 0], X[y == 0][:, 1], c='red', label='Real data class 0', alpha=0.2, s=10)\n",
    "ax.scatter(X[y == 1][:, 0], X[y == 1][:, 1], c='blue', label='Real data class 1', alpha=0.2, s=10)\n",
    "\n",
    "# ==== Scatter the generated points ====\n",
    "ax.scatter(augmented_data['class_0'][:, 0], augmented_data['class_0'][:, 1], c='red', s=15, marker='x', label='Synthetic data class 0')\n",
    "ax.scatter(augmented_data['class_1'][:, 0], augmented_data['class_1'][:, 1], c='blue', s=15, marker='x', label='Synthetic data class 1')\n",
    "\n",
    "ax.set_title('Real and synthetic data')\n",
    "ax.legend()\n",
    "plt.show()"
   ]
  }
 ],
 "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.10.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
