{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "device = \"cpu\"\n",
    "from copy import deepcopy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_seed():\n",
    "    random.seed(42)\n",
    "    np.random.seed(42)\n",
    "    torch.manual_seed(42)\n",
    "    torch.cuda.manual_seed_all(42)  # If using CUDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def lin_y(X: np.array, w: np.array, var: float):\n",
    "    if len(w.shape) == 1:\n",
    "        w = w.reshape(-1, 1)\n",
    "    assert X.shape[1] == len(w), \"Input array must be of same shape as the weight vector\"\n",
    "    result = X @ w\n",
    "    exog = np.random.randn(len(X)) * np.sqrt(var)\n",
    "    return [result.reshape(-1, 1), exog.reshape(-1, 1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class LinearModel(nn.Module):\n",
    "    def __init__(self, num_params):\n",
    "        super(LinearModel, self).__init__()\n",
    "        self.num_params = num_params\n",
    "\n",
    "    def fit(self, X, y):\n",
    "        self.w = np.linalg.inv(X.T @ X) @ X.T @ y\n",
    "\n",
    "    def predict(self, X):\n",
    "        yhat = X @ self.w\n",
    "        yhat = yhat.reshape(-1, 1)\n",
    "        return yhat\n",
    "\n",
    "    def forward(self, X):\n",
    "        return self.predict(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "Gauss = np.random.normal\n",
    "variances = [5]\n",
    "trn_sizes = [50]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Generate the datasets such that the last three features are correlated with the first three features dependoing on the $\\rho$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_ndim = {}\n",
    "set_seed()\n",
    "\n",
    "def generate_data(num_samples, ndim, corr):\n",
    "    base_X = Gauss(0, 1, (num_samples, 3))\n",
    "    X = [base_X]\n",
    "    num_rpt = ndim // 3\n",
    "    for i in range(num_rpt - 1):\n",
    "        X.append(base_X + Gauss(0, corr, (num_samples, 3)))\n",
    "    X = np.concatenate(X, axis=1)\n",
    "    assert X.shape == (num_samples, ndim), f\"Shape of X is {X.shape}\"\n",
    "    return X\n",
    "\n",
    "\n",
    "ndim = 6\n",
    "w = Gauss(0, 1, (ndim, 1))\n",
    "# w[3:] = 0\n",
    "\n",
    "corrs =  [0.01, 0.05, 0.1, 0.5, 1]\n",
    "\n",
    "for corr in corrs:\n",
    "    results = {}\n",
    "    # Sample the w for linear function\n",
    "    for var in  variances:\n",
    "        results[var] = {}\n",
    "        # %% Generate the same Val and Tst set for a fixed value of variance.\n",
    "        XVal, XTst = generate_data(100, ndim, corr), generate_data(100, ndim, corr)\n",
    "        XFix = np.copy(XTst)\n",
    "\n",
    "        # Generate the superset of all the training samples at once.\n",
    "        AllXTrn = generate_data(1000, ndim, corr)\n",
    "\n",
    "        # Inject root cause into the Testcases\n",
    "        for i in range(len(XFix)):\n",
    "            XTst[i, np.random.choice(3)] = np.random.uniform(3, 10) # This is the root cause\n",
    "\n",
    "        y_dict = {\n",
    "            \"Val\": {\n",
    "                \"lin\": lin_y(XVal, w, var),\n",
    "            },\n",
    "            \"Tst\": {\n",
    "                \"lin\": lin_y(XTst, w, var),\n",
    "            },\n",
    "            \"Fix\": {\n",
    "                \"lin\": lin_y(XFix, w, var),\n",
    "            },\n",
    "            \"AllTrn\": {\n",
    "                \"lin\": lin_y(AllXTrn, w, var),\n",
    "            }\n",
    "        }\n",
    "\n",
    "        # For the fix use the same exogenous variable as the test\n",
    "        y_dict[\"Fix\"][\"lin\"][1] = np.copy(y_dict[\"Tst\"][\"lin\"][1])\n",
    "\n",
    "        for size in trn_sizes:\n",
    "            results[var][size] = {}\n",
    "\n",
    "            error_keys = [\"lin_val_error\", \"lin_tst_error\", \"lin_int_error\", \"lin_cf_error\"]\n",
    "            for key in error_keys:\n",
    "                results[var][size][key] = []\n",
    "\n",
    "            for run in [1, 2, 3, 4, 5]:\n",
    "                # Take the first size samples for training\n",
    "                XTrn = AllXTrn[:size]\n",
    "                try:\n",
    "                    del y_dict[\"Trn\"]\n",
    "                except:\n",
    "                    pass\n",
    "                y_dict[\"Trn\"] = {\n",
    "                    \"lin\": [y_dict[\"AllTrn\"][\"lin\"][0][:size], y_dict[\"AllTrn\"][\"lin\"][1][:size]],\n",
    "                }\n",
    "\n",
    "                # %% Fit the Models\n",
    "                lin_model = LinearModel(ndim)\n",
    "\n",
    "                lin_model.fit(XTrn, y_dict[\"Trn\"][\"lin\"][0] + y_dict[\"Trn\"][\"lin\"][1])\n",
    "                \n",
    "                # print(f\"Var: {var}, size: {size}, ndim: {ndim}\\t wstatr: {w.squeeze()} \\t wfit: {lin_model.w.squeeze()}\")\n",
    "\n",
    "                # %% Val Errors\n",
    "                lin_val = lin_model.predict(XVal)\n",
    "                lin_val_res = (y_dict[\"Val\"][\"lin\"][0] + y_dict[\"Val\"][\"lin\"][1] - lin_val).reshape(-1, 1)\n",
    "                lin_val_error = np.mean((y_dict[\"Val\"][\"lin\"][0] - lin_val)**2) # Just assess the f_4 prediction accuracies and not the X_4 on val data that has all usual parents.\n",
    "                results[var][size][\"lin_val_error\"].append(lin_val_error)\n",
    "\n",
    "                # %% Tst Errors\n",
    "                lin_tst = lin_model.predict(XTst)\n",
    "                lin_tst_res = (y_dict[\"Tst\"][\"lin\"][0] + y_dict[\"Tst\"][\"lin\"][1] - lin_tst).reshape(-1, 1)\n",
    "\n",
    "                # Just assess the f_4 prediction accuracies and not the X_4 on test data that has an abnormal a.k.a OOD parent.\n",
    "                lin_tst_error = np.mean((y_dict[\"Tst\"][\"lin\"][0] - lin_tst)**2)\n",
    "                results[var][size][\"lin_tst_error\"].append(lin_tst_error)\n",
    "\n",
    "                # %% Int Error\n",
    "                lin_int = lin_model.predict(XFix)\n",
    "                lin_int = (lin_int + np.mean(lin_val_res.squeeze())).reshape(-1, 1)\n",
    "                lin_int_error = np.mean((y_dict[\"Fix\"][\"lin\"][0] + y_dict[\"Fix\"][\"lin\"][1] - lin_int)**2) # Assess the error between the true CD XFix_4 and the int estimate\n",
    "                results[var][size][\"lin_int_error\"].append(lin_int_error)\n",
    "\n",
    "                # %% CF Error\n",
    "                lin_cf = lin_model.predict(XFix)\n",
    "                lin_cf = lin_cf + lin_tst_res\n",
    "                lin_cf_error = np.mean((y_dict[\"Fix\"][\"lin\"][0] + y_dict[\"Fix\"][\"lin\"][1] - lin_cf)**2)\n",
    "                results[var][size][\"lin_cf_error\"].append(lin_cf_error)\n",
    "\n",
    "            for key in error_keys:\n",
    "                results[var][size][key] = np.mean(results[var][size][key])\n",
    "\n",
    "    results_ndim[corr] = deepcopy(results)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "cols = ['lin_val_error',  'lin_tst_error', 'lin_int_error', 'lin_cf_error']\n",
    "dfs = {}\n",
    "\n",
    "for corr in results_ndim.keys():\n",
    "    dfs[corr] = {}\n",
    "    results = results_ndim[corr]\n",
    "    for var in results.keys():\n",
    "        df = {}\n",
    "        for col in cols:\n",
    "            df[col] = []\n",
    "            for size in trn_sizes:\n",
    "                df[col].append(results[var][size][col])\n",
    "        df = pd.DataFrame(df)\n",
    "        df.index = trn_sizes\n",
    "        dfs[corr][var] = df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2000x500 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "var_dict = {\n",
    "    0.5: \"Low\",\n",
    "    1: \"Medium\",\n",
    "    2: \"High\",\n",
    "    5: \"Very High\"\n",
    "}\n",
    "title_size = 18\n",
    "label_size = 16\n",
    "tick_size = 14\n",
    "\n",
    "sns.set_theme(style=\"whitegrid\")\n",
    "sns.set_context(\"paper\", font_scale=1.5)\n",
    "fig, ax = plt.subplots(1, 5, figsize=(20, 5))\n",
    "\n",
    "for corr_idx, corr in enumerate(dfs.keys()):        \n",
    "    df = dfs[corr][var]\n",
    "    lin_bars = [\"lin_val_error\", \"lin_tst_error\", \"lin_cf_error\", \"lin_int_error\"]\n",
    "\n",
    "    lin_bars_name = [\"Validation\", \"Test\", \"Counterfactual\",  \"Intervention\"]\n",
    "\n",
    "    # bar_colors =  ['#1b9e77', '#fdaa48','#6890F0', 'r']\n",
    "    bar_colors = ['#555555', '#aaaaaa', '#6890F0', 'r']\n",
    "\n",
    "    bar_line_width = 1\n",
    "    bar_width = 0.75\n",
    "\n",
    "    df[lin_bars].plot(kind='bar', ax=ax[corr_idx], color=bar_colors, linewidth=bar_line_width, width=bar_width, edgecolor='black')\n",
    "    ax[corr_idx].set_title(r'$\\rho={}$'.format(round(corr, 2)), fontsize=title_size)\n",
    "    ax[corr_idx].set_xlabel(\"Training Data Size\", fontsize=label_size)\n",
    "    ax[corr_idx].set_ylabel(\"Error (Log Scale)\", fontsize=label_size)\n",
    "    ax[corr_idx].set_yscale('log')\n",
    "    ax[corr_idx].set_xticklabels(trn_sizes, rotation=0, fontsize=tick_size)\n",
    "    ax[corr_idx].legend().set_visible(False)\n",
    "    ax[corr_idx].grid(True, which='both', linestyle='--', lw=0.3)\n",
    "plt.tight_layout()\n",
    "# plt.show()\n",
    "plt.savefig(\"corr_1000.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "petshop",
   "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.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
