{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import random\n",
    "import warnings\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "cmap = 'Blues'\n",
    "warnings.filterwarnings('ignore')\n",
    "sys.path.insert(0, '../GRAPH_Framework-main')\n",
    "from tasks.experiment import ModelTest"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_excel(\"../Source_Data/default of credit card clients.xls\", sheet_name='Data', skiprows=1).reset_index()\n",
    "df['EDUCATION'] = df['EDUCATION'].apply(lambda x: 0 if x in [1, 2, 0] else 1)\n",
    "df = df.iloc[:, 2:]\n",
    "\n",
    "columns_name = df.columns.to_list()[5:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sex_values = df['SEX'].unique()\n",
    "education_values = df['EDUCATION'].unique()\n",
    "marriage_values = [1, 2]\n",
    "\n",
    "# Dictionary to hold the sub-datasets\n",
    "D_lt = []\n",
    "\n",
    "# Iterate through each combination and create a subset\n",
    "for sex in sex_values:\n",
    "    for education in education_values:\n",
    "        for marriage in marriage_values:\n",
    "            # Create a key for the dictionary\n",
    "            key = f\"SEX_{sex}_EDU_{education}_MARR_{marriage}\"\n",
    "\n",
    "            # Create a subset DataFrame\n",
    "            subset = df[(df['SEX'] == sex) & (df['EDUCATION'] == education) & (df['MARRIAGE'] == marriage)]\n",
    "            D_lt.append(np.array(subset[columns_name]))\n",
    "\n",
    "D = np.concatenate(D_lt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    print(D_lt[i].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "parameters = {'max_iter':1000, 'step_size':1e-4, 'tau':0.01, 'lam':1e-1, 'lamm':1e-1, 'rhom':1, 'tol':1e-5}\n",
    "covariance_test = ModelTest(model_type='Covariance',showfig=False)\n",
    "covariance_test.group_graph(D,D_lt,parameters)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "covariance_test.runtime(1,D,D_lt,parameters)\n",
    "covariance_test.summary()\n",
    "covariance_test.plot()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Graph_Learning",
   "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.11.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
