{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/i40/cribeiro/anaconda3/envs/subsel_torch/bin:/home/i40/cribeiro/anaconda3/condabin:/home/i40/cribeiro/.vscode-server/bin/8b3775030ed1a69b13e4f4c628c612102e30a681/bin/remote-cli:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/usr/local/cuda/bin:/home/i40/cribeiro/usr/local/texlive/2024/bin/x86_64-linux\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "\n",
    "os.environ[\"PATH\"] += os.pathsep + '/home/i40/cribeiro/usr/local/texlive/2024/bin/x86_64-linux'\n",
    "print(os.getenv(\"PATH\"))\n",
    "latex_preamble = \"\"\"\n",
    "\\\\usepackage[utf8]{inputenc}\n",
    "\\\\usepackage{microtype}\n",
    "\\\\usepackage{amsmath}\n",
    "\\\\renewcommand{\\\\rmdefault}{ptm}\n",
    "\\\\renewcommand{\\\\sfdefault}{phv}\n",
    "\"\"\"\n",
    "fs = 9\n",
    "column_width = 3.3249219444  # inch\n",
    "text_width = 7.02625  # inch\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"text.latex.preamble\": latex_preamble,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [],\n",
    "    \"font.sans-serif\": [],\n",
    "    \"font.monospace\": [],\n",
    "    \"font.size\": fs,\n",
    "    \"xtick.labelsize\": fs,\n",
    "    \"ytick.labelsize\": fs,\n",
    "    \"legend.fontsize\": fs,\n",
    "    \"savefig.bbox\": \"tight\",\n",
    "})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('experiments/Synthetic/table_result.csv',index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "df_grouped = df.groupby('frac').agg(['mean', 'std'])\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = df_grouped.index\n",
    "p1_mean = df_grouped['p1']['mean']\n",
    "p1_std = df_grouped['p1']['std']\n",
    "p2_mean = df_grouped['p2']['mean']\n",
    "p2_std = df_grouped['p2']['std']\n",
    "\n",
    "plt.figure(figsize=(8/4, 6/4))\n",
    "plt.axline((0, 0), linestyle = \"--\",slope=1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "plt.axline((0, 1), linestyle = \"--\",slope=-1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "\n",
    "plt.plot(x, p1_mean, label='Population 1', marker='o', linewidth = 2, color = '#845EC2')\n",
    "plt.fill_between(x, p1_mean - p1_std, p1_mean + p1_std, color='#845EC2', alpha=0.2)\n",
    "\n",
    "plt.plot(x, p2_mean, label='Population 2', marker='o', linewidth = 2, color = '#4E8397')\n",
    "plt.fill_between(x, p2_mean - p2_std, p2_mean + p2_std, color='#4E8397', alpha=0.2)\n",
    "\n",
    "\n",
    "#plt.title('V-GAN extracted probability')\n",
    "plt.xlabel('$F$')\n",
    "plt.ylabel('$\\\\hat{F}$')\n",
    "#plt.legend()\n",
    "\n",
    "plt.savefig(\"experiments/Synthetic/vgan_experiment.pdf\", dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('experiments/Synthetic/table_result_hics.csv',index_col=0)\n",
    "\n",
    "df_grouped = df.groupby('frac').agg(['mean', 'std'])\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = df_grouped.index\n",
    "p1_mean = df_grouped['p1']['mean']\n",
    "p1_std = df_grouped['p1']['std']\n",
    "p2_mean = df_grouped['p2']['mean']\n",
    "p2_std = df_grouped['p2']['std']\n",
    "\n",
    "plt.figure(figsize=(8/4, 6/4))\n",
    "plt.axline((0, 0), linestyle = \"--\",slope=1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "plt.axline((0, 1), linestyle = \"--\",slope=-1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "\n",
    "plt.plot(x, p1_mean, label='$S_1$', marker='o', linewidth = 2, color = '#845EC2')\n",
    "plt.fill_between(x, p1_mean - p1_std, p1_mean + p1_std, color='#845EC2', alpha=0.2)\n",
    "\n",
    "plt.plot(x, p2_mean, label='$S_2$', marker='o', linewidth = 2, color = '#4E8397')\n",
    "plt.fill_between(x, p2_mean - p2_std, p2_mean + p2_std, color='#4E8397', alpha=0.2)\n",
    "plt.legend()\n",
    "\n",
    "#plt.title('HiCS extracted probability')\n",
    "plt.xlabel('$F$')\n",
    "plt.ylabel('$\\\\hat{F}$')\n",
    "#plt.legend()\n",
    "\n",
    "xlim = plt.xlim()\n",
    "ylim = plt.ylim()\n",
    "plt.savefig(\"experiments/Synthetic/hics_experiment.pdf\", dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(8/4, 6/4))\n",
    "plt.axline((0, 0), linestyle = \"--\",slope=1, color = \"#845EC2\", linewidth = 1.5)\n",
    "plt.axline((0, 1), linestyle = \"--\",slope=-1, color = \"#4E8397\", linewidth = 1.5)\n",
    "\n",
    "\n",
    "\n",
    "#plt.title('V-GAN extracted probability')\n",
    "plt.xlabel('$F$')\n",
    "plt.ylabel('$\\\\hat{F}$')\n",
    "plt.legend([\"Population 1\",\"Population 2\"])\n",
    "plt.xlim(xlim)\n",
    "plt.ylim(ylim)\n",
    "plt.savefig(\"experiments/Synthetic/ideal_ss_experiment.pdf\", dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('experiments/Synthetic/table_result_gmd.csv',index_col=0)\n",
    "\n",
    "df_grouped = df.groupby('frac').agg(['mean', 'std'])\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = df_grouped.index\n",
    "p1_mean = df_grouped['p1']['mean']\n",
    "p1_std = df_grouped['p1']['std']\n",
    "p2_mean = df_grouped['p2']['mean']\n",
    "p2_std = df_grouped['p2']['std']\n",
    "\n",
    "plt.figure(figsize=(8/4, 6/4))\n",
    "plt.axline((0, 0), linestyle = \"--\",slope=1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "plt.axline((0, 1), linestyle = \"--\",slope=-1, color = \"#D5CABD\", linewidth = 1.5)\n",
    "\n",
    "plt.plot(x, p1_mean, label='Population 1', marker='o', linewidth = 2, color = '#845EC2')\n",
    "plt.fill_between(x, p1_mean - p1_std, p1_mean + p1_std, color='#845EC2', alpha=0.2)\n",
    "\n",
    "plt.plot(x, p2_mean, label='Population 2', marker='o', linewidth = 2, color = '#4E8397')\n",
    "plt.fill_between(x, p2_mean - p2_std, p2_mean + p2_std, color='#4E8397', alpha=0.2)\n",
    "\n",
    "\n",
    "#plt.title('HiCS extracted probability')\n",
    "plt.xlabel('$F$')\n",
    "plt.ylabel('$\\\\hat{F}$')\n",
    "#plt.legend()\n",
    "\n",
    "xlim = plt.xlim()\n",
    "ylim = plt.ylim()\n",
    "plt.savefig(\"experiments/Synthetic/gmd_experiment.pdf\", dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import pandas as pd\n",
    "from typing import Union\n",
    "import torch_two_sample as tts\n",
    "from sklearn.preprocessing import normalize\n",
    "import torch\n",
    "from src.models.Mmd_loss_constrained import MMDLossConstrained\n",
    "\n",
    "def check_if_myopic( x_data: np.array, bandwidth: Union[float, np.array] = 0.01, count=500) -> pd.DataFrame:\n",
    "        \"\"\"_summary_\n",
    "\n",
    "        Args:\n",
    "            x_data (np.array): Data to check the myopicity of.\n",
    "            bandwidth (float | np.array, optional): Bandwidth used in the GOF tests using the MMD. This method always runs\n",
    "            the recommended bandwidth alongside this optional one. Defaults to 0.01.\n",
    "            count (int, optional): Number of samples used to approximate the MMD. Defaults to 500.\n",
    "\n",
    "        Returns:\n",
    "            pd.DataFrame: DataFrame containing the p.value of the test with all the different bandwidths.\n",
    "        \"\"\"\n",
    "        assert count <= x_data.shape[0], \"Selected 'count' is greater than the number of samples in the dataset\"\n",
    "        results = []\n",
    "\n",
    "        x_data = normalize(x_data, axis=0)\n",
    "        x_sample = torch.Tensor(pd.DataFrame(\n",
    "            x_data).sample(count).to_numpy()).to('cuda')\n",
    "        x_sample2 = torch.Tensor(pd.DataFrame(\n",
    "            x_data).sample(count).to_numpy()).to('cuda')\n",
    "        u_subspaces = torch.BoolTensor(np.append(np.repeat([[True,True,False]],int(x_sample.shape[0]/2),axis=0),np.repeat([[False,True,False]],x_sample.shape[0]-int(x_sample.shape[0]/2),axis=0),axis=0)).to('cuda')\n",
    "        ux_sample = u_subspaces * \\\n",
    "            torch.Tensor(x_sample).to('cuda') + \\\n",
    "            torch.mean(x_sample2, dim=0)*(~u_subspaces)\n",
    "        \n",
    "        L2_distances = torch.cdist(x_sample,x_sample)**2\n",
    "        n_samples = L2_distances.shape[0]\n",
    "        bandwidth = L2_distances.data.sum() / (n_samples ** 2 - n_samples)\n",
    "        \n",
    "        bw = bandwidth.item()\n",
    "        mmd = tts.MMDStatistic(count, count)\n",
    "        _, distances = mmd(x_sample, ux_sample, alphas=[\n",
    "            bw], ret_matrix=True)\n",
    "        results.append(mmd.pval(distances))\n",
    "\n",
    "        return pd.DataFrame([results], columns=[bandwidth.item()], index=[\"p-val\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_926491/91756808.py:4: DeprecationWarning: This function is deprecated. Please call randint(10, 10000 + 1) instead\n",
      "  x_data = generate_data_3d(1,500,seed=np.random.random_integers(10,10000))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1.0000, 1.0000, 1.0000,  ..., 1.0000, 1.0000, 1.0000],\n",
      "        [1.0000, 1.0000, 1.0000,  ..., 1.0000, 1.0000, 1.0000],\n",
      "        [1.0000, 1.0000, 1.0000,  ..., 1.0000, 1.0000, 1.0000],\n",
      "        ...,\n",
      "        [1.0000, 1.0000, 1.0000,  ..., 1.0000, 0.9999, 1.0000],\n",
      "        [1.0000, 1.0000, 1.0000,  ..., 0.9999, 1.0000, 1.0000],\n",
      "        [1.0000, 1.0000, 1.0000,  ..., 1.0000, 1.0000, 1.0000]],\n",
      "       device='cuda:0')\n"
     ]
    },
    {
     "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>0.007986</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>p-val</th>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       0.007986\n",
       "p-val       1.0"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from src.modules.synthetic_module import generate_data_3d\n",
    "import numpy as np\n",
    "\n",
    "x_data = generate_data_3d(1,500,seed=np.random.random_integers(10,10000))\n",
    "check_if_myopic(x_data,count=500)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.0276e+08)"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_data_norm = normalize(x_data)\n",
    "L2_distances = torch.cdist(torch.Tensor(x_data),torch.Tensor(x_data))**2\n",
    "n_samples = L2_distances.shape[0]\n",
    "L2_distances.data.sum() / (n_samples ** 2 - n_samples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "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>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-14340.314828</td>\n",
       "      <td>46.322330</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-7769.253262</td>\n",
       "      <td>-0.675132</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1877.588437</td>\n",
       "      <td>-15.023298</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-23313.234446</td>\n",
       "      <td>12.355719</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>6488.080961</td>\n",
       "      <td>58.869162</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              0          1    2\n",
       "0 -14340.314828  46.322330  0.0\n",
       "1  -7769.253262  -0.675132  0.0\n",
       "2  -1877.588437 -15.023298  0.0\n",
       "3 -23313.234446  12.355719  0.0\n",
       "4   6488.080961  58.869162  0.0"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(x_data).head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from src.modules.synthetic_module import generate_data_3d\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "\n",
    "fig = plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "ax = fig.add_subplot(projection='3d')\n",
    "ax.set_box_aspect(aspect=None, zoom=0.9)\n",
    "x1, x2 = generate_data_3d(.5,100, give_pop=True)\n",
    "ax.view_init(elev=20, azim=70, roll=0)\n",
    "ax.scatter(pd.DataFrame(x1)[0],pd.DataFrame(x1)[1],pd.DataFrame(x1)[2], c = \"#845EC2\")\n",
    "ax.scatter(pd.DataFrame(x2)[0],pd.DataFrame(x2)[1],pd.DataFrame(x2)[2], c = \"#4E8397\")\n",
    "ax.set_xlabel('$\\\\mathbf{x}_1$', labelpad=-15)\n",
    "ax.set_ylabel('$\\\\mathbf{x}_2$',labelpad=-15)\n",
    "ax.axes.set_zlabel('$\\\\mathbf{x}_3$',labelpad=-15)\n",
    "ax.set_xticklabels([])\n",
    "ax.set_yticklabels([])\n",
    "ax.set_zticklabels([])\n",
    "\n",
    "\n",
    "plt.savefig(\"experiments/Synthetic/example1.png\",bbox_inches='tight', dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "x1, x2 = generate_data_3d(.5,1000, give_pop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.156033</td>\n",
       "      <td>-1.713702</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-0.333738</td>\n",
       "      <td>1.171051</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1.304851</td>\n",
       "      <td>-1.231909</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.089867</td>\n",
       "      <td>1.866642</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-0.693428</td>\n",
       "      <td>1.630036</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>495</th>\n",
       "      <td>0.542054</td>\n",
       "      <td>-0.725984</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>496</th>\n",
       "      <td>-1.595454</td>\n",
       "      <td>-0.003022</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>497</th>\n",
       "      <td>0.339185</td>\n",
       "      <td>-0.604244</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>498</th>\n",
       "      <td>-0.478850</td>\n",
       "      <td>-0.984367</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>499</th>\n",
       "      <td>-0.353393</td>\n",
       "      <td>0.878841</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>500 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           x1        x2  x3\n",
       "0    0.156033 -1.713702   0\n",
       "1   -0.333738  1.171051   0\n",
       "2   -1.304851 -1.231909   0\n",
       "3    0.089867  1.866642   0\n",
       "4   -0.693428  1.630036   0\n",
       "..        ...       ...  ..\n",
       "495  0.542054 -0.725984   0\n",
       "496 -1.595454 -0.003022   0\n",
       "497  0.339185 -0.604244   0\n",
       "498 -0.478850 -0.984367   0\n",
       "499 -0.353393  0.878841   0\n",
       "\n",
       "[500 rows x 3 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x1"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "subsel_torch",
   "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.12.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
