{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/lee4094/miniconda3/envs/stable-low-order/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from CPC import CPC\n",
    "import pyAgrum as gum\n",
    "from algorithms_for_missingness_experiment import pc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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>sampid</th>\n",
       "      <th>w1_D_wordrec_flag</th>\n",
       "      <th>w1_D_wordrec_use</th>\n",
       "      <th>w1_D_wordrecvalid</th>\n",
       "      <th>w1_D_wordrecvalidtype</th>\n",
       "      <th>w1_D_bc</th>\n",
       "      <th>w1_D_cact</th>\n",
       "      <th>w1_D_cesd_p</th>\n",
       "      <th>w1_D_dr</th>\n",
       "      <th>w1_D_dw</th>\n",
       "      <th>...</th>\n",
       "      <th>w3_RF_item2_flag</th>\n",
       "      <th>w3_RF_item2_use</th>\n",
       "      <th>w3_RF_item2_valid</th>\n",
       "      <th>w3_RF_item2_validtype</th>\n",
       "      <th>w3_RF_item3_flag</th>\n",
       "      <th>w3_RF_item3_use</th>\n",
       "      <th>w3_RF_item3_valid</th>\n",
       "      <th>w3_RF_item3_validtype</th>\n",
       "      <th>w3_RF_pscore</th>\n",
       "      <th>w3_RF_wscore</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>7000030010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.333333</td>\n",
       "      <td>496.80</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>7000030020</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>25.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>20.555556</td>\n",
       "      <td>495.15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>7000040010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>7000050010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>36.111111</td>\n",
       "      <td>502.75</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>7000050020</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>20.555556</td>\n",
       "      <td>495.15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>7000070010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7000080010</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>12.5</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.333333</td>\n",
       "      <td>496.80</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7000080020</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>7.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>20.000000</td>\n",
       "      <td>494.80</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>7000110010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>62.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>13.888889</td>\n",
       "      <td>490.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>7000140010</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>25.000000</td>\n",
       "      <td>497.71</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10 rows × 260 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       sampid  w1_D_wordrec_flag  w1_D_wordrec_use  w1_D_wordrecvalid  \\\n",
       "0  7000030010                  0                 1                  1   \n",
       "1  7000030020                  0                 1                  1   \n",
       "2  7000040010                  0                 1                  1   \n",
       "3  7000050010                  0                 1                  1   \n",
       "4  7000050020                  0                 1                  1   \n",
       "5  7000070010                  0                 1                  1   \n",
       "6  7000080010                  7                 0                  0   \n",
       "7  7000080020                  0                 1                  1   \n",
       "8  7000110010                  0                 1                  1   \n",
       "9  7000140010                  0                 1                  1   \n",
       "\n",
       "   w1_D_wordrecvalidtype  w1_D_bc  w1_D_cact  w1_D_cesd_p  w1_D_dr  w1_D_dw  \\\n",
       "0                    NaN        0          1          0.0      3.0        1   \n",
       "1                    NaN        1          1         25.0      3.0        1   \n",
       "2                    NaN        1          0         50.0      4.0        1   \n",
       "3                    NaN        1          1          0.0      6.0        1   \n",
       "4                    NaN        1          1          0.0      5.0        1   \n",
       "5                    NaN        1          1          0.0      6.0        1   \n",
       "6                    1.0        1          1         12.5      NaN        1   \n",
       "7                    NaN        1          1          0.0      7.0        1   \n",
       "8                    NaN        1          1         62.5      1.0        1   \n",
       "9                    NaN        1          1          0.0      6.0        1   \n",
       "\n",
       "   ...  w3_RF_item2_flag  w3_RF_item2_use  w3_RF_item2_valid  \\\n",
       "0  ...               0.0              1.0                1.0   \n",
       "1  ...               0.0              1.0                1.0   \n",
       "2  ...               NaN              NaN                NaN   \n",
       "3  ...               0.0              1.0                1.0   \n",
       "4  ...               0.0              1.0                1.0   \n",
       "5  ...               NaN              NaN                NaN   \n",
       "6  ...               0.0              1.0                1.0   \n",
       "7  ...               0.0              1.0                1.0   \n",
       "8  ...               0.0              1.0                1.0   \n",
       "9  ...               0.0              1.0                1.0   \n",
       "\n",
       "   w3_RF_item2_validtype  w3_RF_item3_flag  w3_RF_item3_use  \\\n",
       "0                    NaN               0.0              1.0   \n",
       "1                    NaN               0.0              1.0   \n",
       "2                    NaN               NaN              NaN   \n",
       "3                    NaN               0.0              1.0   \n",
       "4                    NaN               0.0              1.0   \n",
       "5                    NaN               NaN              NaN   \n",
       "6                    NaN               0.0              1.0   \n",
       "7                    NaN               0.0              1.0   \n",
       "8                    NaN               0.0              1.0   \n",
       "9                    NaN               0.0              1.0   \n",
       "\n",
       "   w3_RF_item3_valid  w3_RF_item3_validtype  w3_RF_pscore  w3_RF_wscore  \n",
       "0                1.0                    NaN     23.333333        496.80  \n",
       "1                1.0                    NaN     20.555556        495.15  \n",
       "2                NaN                    NaN           NaN           NaN  \n",
       "3                1.0                    NaN     36.111111        502.75  \n",
       "4                1.0                    NaN     20.555556        495.15  \n",
       "5                NaN                    NaN           NaN           NaN  \n",
       "6                1.0                    NaN     23.333333        496.80  \n",
       "7                1.0                    NaN     20.000000        494.80  \n",
       "8                1.0                    NaN     13.888889        490.25  \n",
       "9                1.0                    NaN     25.000000        497.71  \n",
       "\n",
       "[10 rows x 260 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Read the TSV file into a DataFrame\n",
    "df = pd.read_csv(\"36053-0002-Data.tsv\", sep='\\t', na_values=[' '], keep_default_na=True)\n",
    "df.head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "columns = ['w1_D_bc', 'w1_D_dr','w1_D_ir', \n",
    "           'w1_D_cact', 'w1_D_ms', 'w1_D_pres', 'w1_D_rm', 'w1_D_scis', 'w1_D_vp','w1_D_dy', 'w1_D_dw', \n",
    "           'w2_D_bc', 'w2_D_dr', 'w2_D_ir', 'w2_D_num', 'w2_D_s7']\n",
    "df_filtered = df[columns]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['w1_D_dr', 'w1_D_ir', 'w1_D_scis', 'w2_D_bc', 'w2_D_dr', 'w2_D_ir',\n",
      "       'w2_D_num', 'w2_D_s7'],\n",
      "      dtype='object')\n"
     ]
    }
   ],
   "source": [
    "missing_values_count = df_filtered.isnull().sum()\n",
    "\n",
    "# Display the count of missing values\n",
    "print(df_filtered.columns[missing_values_count > 0])\n",
    "columns_that_have_missing_data = df_filtered.columns[missing_values_count > 0]\n",
    "cpc_I_set = [col for col in df_filtered.columns if col not in columns_that_have_missing_data]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['w1_D_dr', 'w1_D_ir', 'w1_D_scis', 'w2_D_bc', 'w2_D_dr', 'w2_D_ir',\n",
       "       'w2_D_num', 'w2_D_s7'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "columns_that_have_missing_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['w1_D_bc', 'w1_D_dr', 'w1_D_ir', 'w1_D_cact', 'w1_D_ms', 'w1_D_pres', 'w1_D_rm', 'w1_D_scis', 'w1_D_vp', 'w1_D_dy', 'w1_D_dw', 'w2_D_bc', 'w2_D_dr', 'w2_D_ir', 'w2_D_num', 'w2_D_s7']\n",
      "w1_D_cact --> w1_D_dr\n",
      "w1_D_cact --> w1_D_ir\n"
     ]
    }
   ],
   "source": [
    "import itertools\n",
    "from utils import visualize_graph, visualize_graph_color\n",
    "\n",
    "\n",
    "# test-wise deletion chisq approach\n",
    "n = len(df_filtered.columns)\n",
    "alpha =0.05\n",
    "tester = 'td-chisq'\n",
    "data = df_filtered\n",
    "D,_ = CPC(data.to_numpy(),tester,I=[] ,n=len(df_filtered.columns),variables_cannot_be_tested= columns_that_have_missing_data, data_names=df_filtered.columns.tolist(),alpha=alpha,       \n",
    "          path_sep_set_enforced=False, traverse_subset_and_skip = True, k =2)\n",
    "cpc_adj = D.graph\n",
    "visualize_graph_color(D, name= 'mv_CPC_aging_p{}'.format(alpha), nodes_to_green=['w1_D_bc', 'w1_D_ms']) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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>w1_D_bc</th>\n",
       "      <th>w1_D_dr</th>\n",
       "      <th>w1_D_ir</th>\n",
       "      <th>w1_D_cact</th>\n",
       "      <th>w1_D_ms</th>\n",
       "      <th>w1_D_pres</th>\n",
       "      <th>w1_D_rm</th>\n",
       "      <th>w1_D_scis</th>\n",
       "      <th>w1_D_vp</th>\n",
       "      <th>w1_D_dy</th>\n",
       "      <th>w1_D_dw</th>\n",
       "      <th>w2_D_bc</th>\n",
       "      <th>w2_D_dr</th>\n",
       "      <th>w2_D_ir</th>\n",
       "      <th>w2_D_num</th>\n",
       "      <th>w2_D_s7</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>7.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>3.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>1</td>\n",
       "      <td>13</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>4.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>0</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>6.0</td>\n",
       "      <td>8.0</td>\n",
       "      <td>1</td>\n",
       "      <td>13</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>5.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>1</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   w1_D_bc  w1_D_dr  w1_D_ir  w1_D_cact  w1_D_ms  w1_D_pres  w1_D_rm  \\\n",
       "0        0      3.0      4.0          1       10          1        1   \n",
       "1        1      3.0      5.0          1       13          1        2   \n",
       "2        1      4.0      6.0          0       12          1        3   \n",
       "3        1      6.0      8.0          1       13          1        3   \n",
       "4        1      5.0      5.0          1       12          1        3   \n",
       "\n",
       "   w1_D_scis  w1_D_vp  w1_D_dy  w1_D_dw  w2_D_bc  w2_D_dr  w2_D_ir  w2_D_num  \\\n",
       "0        1.0        1        1        1      1.0      4.0      7.0       2.0   \n",
       "1        1.0        0        1        1      1.0      0.0      3.0       1.0   \n",
       "2        1.0        0        1        1      NaN      NaN      NaN       NaN   \n",
       "3        1.0        0        1        1      0.0      4.0      5.0       3.0   \n",
       "4        1.0        1        1        1      1.0      5.0      6.0       1.0   \n",
       "\n",
       "   w2_D_s7  \n",
       "0      2.0  \n",
       "1      5.0  \n",
       "2      NaN  \n",
       "3      5.0  \n",
       "4      5.0  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_filtered.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "from kPC import kPC\n",
    "kD,_ = kPC(data.to_numpy(),\n",
    "                     tester,\n",
    "                     k=1,\n",
    "                     n=len(list(data.columns)),\n",
    "                     alpha=0.05, \n",
    "                     mark_essential_edges = False, \n",
    "                     fastAdjSearch=False, \n",
    "                     stable =False,\n",
    "                     node_names=df_filtered.columns.tolist())\n",
    "kpc_adj = D.graph\n",
    "visualize_graph_color(kD, name= 'mv_KPC_aging_p{}'.format(alpha), nodes_to_red=['w2_D_dr', 'w1_D_dr'], nodes_to_green=['w1_D_bc', 'w1_D_ms']) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Depth=7, working on node 15: 100%|██████████| 16/16 [00:00<00:00, 1532.13it/s]\n"
     ]
    }
   ],
   "source": [
    "pcalg = pc(data.to_numpy(),alpha=alpha,indep_test=tester, mvpc=True, node_names=df_filtered.columns.tolist())\n",
    "pc_adj = pcalg.G.graph\n",
    "visualize_graph_color(pcalg.G, name= 'mv_aging_pc_output_p{}'.format(alpha), nodes_to_red=['w2_D_s7','w1_D_ms', 'w2_D_dr', 'w1_D_dr'], nodes_to_green=['w1_D_bc', 'w1_D_ms']) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('tigramite') "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# PCMCI\n",
    "import itertools\n",
    "from utils import visualize_graph, visualize_graph_color\n",
    "from tigramite.tigramite.pcmci import PCMCI\n",
    "# from tigramite.tigramite.rpcmci import RPCMCI\n",
    "# from tigramite.tigramite.independence_tests.cmisymb import CMIsymb\n",
    "from tigramite.tigramite.independence_tests.gsquared import Gsquared\n",
    "\n",
    "from tigramite.tigramite import plotting as tp\n",
    "from tigramite.tigramite.data_processing import DataFrame\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline  \n",
    "\n",
    "# # test-wise deletion chisq approach\n",
    "# n = len(df_filtered.columns)\n",
    "# alpha =0.05\n",
    "# tester = 'td-chisq'\n",
    "# data = df_filtered\n",
    "# D,_ = CPC(data.to_numpy(),tester,I=[] ,n=len(df_filtered.columns),variables_cannot_be_tested= columns_that_have_missing_data, data_names=df_filtered.columns.tolist(),alpha=alpha,       \n",
    "#           path_sep_set_enforced=False, traverse_subset_and_skip = True, k =2)\n",
    "# cpc_adj = D.graph\n",
    "# visualize_graph_color(D, name= 'mv_CPC_aging_p{}'.format(alpha), nodes_to_green=['w1_D_bc', 'w1_D_ms']) \n",
    "\n",
    "df_filtered_cleaned = df_filtered.dropna().astype(int)  # Drop NaN values\n",
    "df_tigramite = DataFrame(df_filtered_cleaned.to_numpy(), var_names=df_filtered_cleaned.columns.tolist())\n",
    "pcmci = PCMCI(dataframe=df_tigramite, \n",
    "              cond_ind_test=Gsquared())\n",
    "results = pcmci.run_pcmci(tau_min=1, tau_max=2, pc_alpha=0.05, alpha_level=0.01)\n",
    "tp.plot_graph(val_matrix=results['val_matrix'],\n",
    "              graph=results['graph'], var_names=df_filtered.columns,\n",
    "              node_aspect=0.3, node_size=0.2, arrow_linewidth=3.0, show_colorbar=False,\n",
    "              show_autodependency_lags=False, curved_radius=0.01\n",
    ")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['w1_D_bc', 'w1_D_dr', 'w1_D_ir', 'w1_D_cact', 'w1_D_ms', 'w1_D_pres',\n",
       "       'w1_D_rm', 'w1_D_scis', 'w1_D_vp', 'w1_D_dy', 'w1_D_dw', 'w2_D_bc',\n",
       "       'w2_D_dr', 'w2_D_ir', 'w2_D_num', 'w2_D_s7'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_filtered_cleaned.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "w1_D_dr\n",
      "w1_D_cact\n",
      "w1_D_pres\n",
      "w1_D_scis\n",
      "w1_D_vp\n",
      "w2_D_num\n"
     ]
    }
   ],
   "source": [
    "from causallearn.graph.GeneralGraph import GeneralGraph\n",
    "from causallearn.graph.GraphNode import GraphNode\n",
    "# Manually plot a better graph\n",
    "nodes = []\n",
    "node_name_map = {}\n",
    "alpha = 0.05\n",
    "for colname in df_filtered_cleaned.columns:\n",
    "    tmp = GraphNode(colname)\n",
    "    nodes.append(tmp)\n",
    "    node_name_map[colname] = tmp\n",
    "\n",
    "D = GeneralGraph(nodes)\n",
    "\n",
    "for col1 in df_filtered_cleaned.columns:\n",
    "    for col2 in df_filtered_cleaned.columns:\n",
    "        if ((col1 == 'w1_D_pres' and col2 =='w1_D_vp') or\n",
    "        (col1 == 'w1_D_vp' and col2 =='w1_D_ir') or \n",
    "        (col1 == 'w1_D_scis' and col2 =='w1_D_bc') or\n",
    "        (col1 == 'w1_D_cact' and col2 =='w2_D_num') or\n",
    "        (col1 == 'w1_D_dr' and col2 =='w2_D_num') or \n",
    "        (col1 == 'w2_D_num' and col2 =='w2_D_dr')):\n",
    "            print(col1)\n",
    "            node1 = node_name_map[col1]\n",
    "            node2= node_name_map[col2]\n",
    "            D.add_directed_edge(node1, node2)\n",
    "\n",
    "\n",
    "visualize_graph_color(D, name= 'PCMCI_output_p{}'.format(alpha), nodes_to_red=[], nodes_to_green=['w1_D_bc', 'w1_D_ms']) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py312",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
