{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.model_selection import train_test_split\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sigmoid(x):\n",
    "    return 1 / (1 + np.exp(-x))\n",
    "def prob_func_x4(a,b,c):\n",
    "    prob1 = abs(a/100) + 0.1*(b==0) + 0.1*(b==2) * np.sqrt(abs(c)) \n",
    "    prob2 = 0.3*(b==1) + 0.4*(b==3) + c/10\n",
    "    prob3 = a/100*c/10 + 0.1\n",
    "    return np.array([prob1, prob2, prob3])/ sum([prob1, prob2, prob3])\n",
    "SCM = {0:{'input':[], 'func':None}, 1:{'input':[], 'func':None}, 2:{'input':[], 'func':None},\\\n",
    "     3:{'input':[2], 'func':lambda a: (a-3)**2}, 4:{'input':[0,1,3], 'func':prob_func_x4}}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(0)\n",
    "n_data = 8000\n",
    "x0 = np.random.normal(50, 15, n_data)\n",
    "x1 = np.argmax(np.random.multinomial(1, [0.3, 0.2, 0.25, 0.25], n_data), axis=1)\n",
    "x2 = np.random.normal(2, 1, n_data)\n",
    "u0 = np.sqrt(np.abs(x2)) + np.random.normal(2, 1, n_data)\n",
    "u1 = np.random.normal(0,0.3,(n_data,3))\n",
    "I = np.random.choice([0,1], n_data)\n",
    "x3= SCM[3]['func'](x2) + u0 + np.random.normal(-3, 0.5, n_data)*I + np.random.normal(3.5, 0.5, n_data)*(1-I)\n",
    "x4_prob = np.array([SCM[4]['func'](x_0, x_1, x_3) + u_1 for x_0, x_1, x_3, u_1 in zip(x0, x1, x3, u1)])\n",
    "x4 = np.argmax(x4_prob, axis=1)\n",
    "y= (sigmoid( x0*x1/16 + 5 - 2*(x4==1) - 4*(x4==2) + 1*(x4==0) - 1.5*x3) + np.random.normal(-0.05, 0.1, n_data) >= 0.5).astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f6059bc9df0>"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x2,x3, alpha=0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.493625"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "cols = ['x' + str(i) for i in range(5)] + ['y']\n",
    "data_arrs = [x0, x1, x2, x3, x4, y]\n",
    "graph_data = pd.DataFrame({col: arr for col, arr in zip(cols, data_arrs)})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "train, test = train_test_split(graph_data, test_size=0.2, random_state=0)\n",
    "train.to_csv('./sim_cat_data_train.csv', index=False)\n",
    "valid, test = train_test_split(test, test_size=0.5, random_state=0)\n",
    "valid.to_csv('./sim_cat_data_valid.csv', index=False)\n",
    "test.to_csv('./sim_cat_data_test.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>76.460785</td>\n",
       "      <td>0</td>\n",
       "      <td>2.773568</td>\n",
       "      <td>-0.561858</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>56.002358</td>\n",
       "      <td>3</td>\n",
       "      <td>0.969247</td>\n",
       "      <td>11.380219</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>64.681070</td>\n",
       "      <td>2</td>\n",
       "      <td>2.598390</td>\n",
       "      <td>1.394030</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>83.613398</td>\n",
       "      <td>2</td>\n",
       "      <td>2.954977</td>\n",
       "      <td>2.134189</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>78.013370</td>\n",
       "      <td>3</td>\n",
       "      <td>2.586707</td>\n",
       "      <td>2.005600</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7995</th>\n",
       "      <td>40.350995</td>\n",
       "      <td>3</td>\n",
       "      <td>2.105134</td>\n",
       "      <td>11.020088</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7996</th>\n",
       "      <td>37.565284</td>\n",
       "      <td>0</td>\n",
       "      <td>2.207423</td>\n",
       "      <td>0.246881</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7997</th>\n",
       "      <td>46.958981</td>\n",
       "      <td>1</td>\n",
       "      <td>0.587161</td>\n",
       "      <td>12.331826</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7998</th>\n",
       "      <td>46.132003</td>\n",
       "      <td>3</td>\n",
       "      <td>1.552049</td>\n",
       "      <td>1.684485</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7999</th>\n",
       "      <td>51.062218</td>\n",
       "      <td>0</td>\n",
       "      <td>1.844469</td>\n",
       "      <td>1.950420</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8000 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             x0  x1        x2         x3  x4  y\n",
       "0     76.460785   0  2.773568  -0.561858   0  1\n",
       "1     56.002358   3  0.969247  11.380219   1  0\n",
       "2     64.681070   2  2.598390   1.394030   0  1\n",
       "3     83.613398   2  2.954977   2.134189   0  1\n",
       "4     78.013370   3  2.586707   2.005600   0  1\n",
       "...         ...  ..       ...        ...  .. ..\n",
       "7995  40.350995   3  2.105134  11.020088   1  0\n",
       "7996  37.565284   0  2.207423   0.246881   0  1\n",
       "7997  46.958981   1  0.587161  12.331826   1  0\n",
       "7998  46.132003   3  1.552049   1.684485   0  1\n",
       "7999  51.062218   0  1.844469   1.950420   1  0\n",
       "\n",
       "[8000 rows x 6 columns]"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "graph_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import StandardScaler, OneHotEncoder\n",
    "from sklearn.compose import ColumnTransformer\n",
    "from sklearn.pipeline import Pipeline\n",
    "\n",
    "categorical = ['x1', 'x4']\n",
    "numerical = list(train.drop('y', axis=1).columns.difference(categorical))\n",
    "\n",
    "numeric_transformer = Pipeline(steps=[\n",
    "    ('scaler', StandardScaler())])\n",
    "categorical_transformer = Pipeline(steps=[\n",
    "    ('onehot', OneHotEncoder(handle_unknown='error'))])\n",
    "\n",
    "transformations = ColumnTransformer(\n",
    "    transformers=[\n",
    "        ('num', numeric_transformer, numerical),\n",
    "        ('cat', categorical_transformer, categorical)])\n",
    "\n",
    "transformations.fit(train.drop('y', axis=1))\n",
    "all_onehot_norm = transformations.transform(graph_data.drop('y', axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.41586305, -1.03423785,  1.42475202,  0.        ,  0.        ,\n",
       "        0.        ,  1.        ,  0.        ,  1.        ,  0.        ])"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_onehot_norm[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 1, 2])"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(graph_data['x4'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "onehot_columns = []\n",
    "for col in numerical:\n",
    "    onehot_columns.append(col)\n",
    "for col in categorical:\n",
    "    n_class = len(np.unique(train[col]))\n",
    "    onehot_columns.extend([col + '_' + str(i) for i in range(n_class)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['x0', 'x2', 'x3', 'x1_0', 'x1_1', 'x1_2', 'x1_3', 'x4_0', 'x4_1', 'x4_2']"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "onehot_columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_all_onehot_norm = pd.DataFrame(all_onehot_norm, columns=onehot_columns)\n",
    "df_all_onehot_norm['y'] = graph_data['y']\n",
    "df_all_onehot_norm.to_csv('sim_all_onehot_norm.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.7 ('base': conda)",
   "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.9.7"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "13f752eec1c22bf877ed13574aae0c5036489a901cc325afaf3d1c548bba661a"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
