# import pickle

# path = "./data_census_onehot/transformed_columns.pk"
# with open(path, 'rb') as f:
#   encoder = pickle.load(f)

# path = "./data_census_onehot/missing_ratio-0.2_seed-1_max-min_norm.pk"
# with open(path, 'rb') as f:
#   contents = pickle.load(f)

# path = "./data_census_onehot/missing_ratio-0.2_seed-1.pk"
# with open(path, 'rb') as f:
#   content = pickle.load(f)


# from sdv.evaluation import evaluate
# try:
#     from sdgym.datasets import load_dataset
# except:
#     pass
# from sdgym.datasets import load_tables
# from sdgym.datasets import load_dataset

import pandas as pd
import numpy as np

import ipdb

path = './data_MIMIC4ED_onehot/used.csv'
data = pd.read_csv(path)
data.drop(columns='Unnamed: 0', axis=1,inplace=True)

# ipdb.set_trace()
data.replace(False, 0, inplace=True)
data.replace(True, 0, inplace=True)

#only for several case
# data.drop(columns='ed_los', axis=1,inplace=True)


new_data = pd.read_csv('./generated_MIMIC4ED/generated_samples_MIMIC4ED_0.2.csv')
# new_data.drop(columns='ed_los', axis=1,inplace=True)
# new_data = pd.read_csv('./generated_samples_MIMIC4ED_0.2.csv')

#eval 2
# ipdb.set_trace()
from sdmetrics import load_demo
from sdmetrics.reports.single_table import QualityReport

metadata = {
"fields": {'gender': {'type': 'categorical'},
 'age': {'type': 'numerical', 'subtype': 'integer'},
 'n_ed_30d': {'type': 'numerical', 'subtype': 'integer'},
 'n_ed_90d': {'type': 'numerical', 'subtype': 'integer'},
 'n_ed_365d': {'type': 'numerical', 'subtype': 'integer'},
 'n_hosp_30d': {'type': 'numerical', 'subtype': 'integer'},
 'n_hosp_90d': {'type': 'numerical', 'subtype': 'integer'},
 'n_hosp_365d': {'type': 'numerical', 'subtype': 'integer'},
 'n_icu_30d': {'type': 'numerical', 'subtype': 'integer'},
 'n_icu_90d': {'type': 'numerical', 'subtype': 'integer'},
 'n_icu_365d': {'type': 'numerical', 'subtype': 'integer'},
 'triage_temperature': {'type': 'numerical', 'subtype': 'integer'},
 'triage_heartrate': {'type': 'numerical', 'subtype': 'integer'},
 'triage_resprate': {'type': 'numerical', 'subtype': 'integer'},
 'triage_o2sat': {'type': 'numerical', 'subtype': 'integer'},
 'triage_sbp': {'type': 'numerical', 'subtype': 'integer'},
 'triage_dbp': {'type': 'numerical', 'subtype': 'integer'},
 'triage_pain': {'type': 'numerical', 'subtype': 'integer'},
 'triage_acuity': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_chest_pain': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_abdominal_pain': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_headache': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_shortness_of_breath': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_back_pain': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_cough': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_nausea_vomiting': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_fever_chills': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_syncope': {'type': 'numerical', 'subtype': 'integer'},
 'chiefcom_dizziness': {'type': 'numerical', 'subtype': 'integer'},
 'cci_MI': {'type': 'numerical', 'subtype': 'integer'},
 'cci_CHF': {'type': 'numerical', 'subtype': 'integer'},
 'cci_PVD': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Stroke': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Dementia': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Pulmonary': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Rheumatic': {'type': 'numerical', 'subtype': 'integer'},
 'cci_PUD': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Liver1': {'type': 'numerical', 'subtype': 'integer'},
 'cci_DM1': {'type': 'numerical', 'subtype': 'integer'},
 'cci_DM2': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Paralysis': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Renal': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Cancer1': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Liver2': {'type': 'numerical', 'subtype': 'integer'},
 'cci_Cancer2': {'type': 'numerical', 'subtype': 'integer'},
 'cci_HIV': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Arrhythmia': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Valvular': {'type': 'numerical', 'subtype': 'integer'},
 'eci_PHTN': {'type': 'numerical', 'subtype': 'integer'},
 'eci_HTN1': {'type': 'numerical', 'subtype': 'integer'},
 'eci_HTN2': {'type': 'numerical', 'subtype': 'integer'},
 'eci_NeuroOther': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Hypothyroid': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Lymphoma': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Coagulopathy': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Obesity': {'type': 'numerical', 'subtype': 'integer'},
 'eci_WeightLoss': {'type': 'numerical', 'subtype': 'integer'},
 'eci_FluidsLytes': {'type': 'numerical', 'subtype': 'integer'},
 'eci_BloodLoss': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Anemia': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Alcohol': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Drugs': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Psychoses': {'type': 'numerical', 'subtype': 'integer'},
 'eci_Depression': {'type': 'numerical', 'subtype': 'integer'},
 'ed_temperature_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_heartrate_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_resprate_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_o2sat_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_sbp_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_dbp_last': {'type': 'numerical', 'subtype': 'integer'},
 'ed_los': {'type': 'numerical', 'subtype': 'integer'},
 'n_med': {'type': 'numerical', 'subtype': 'integer'},
 'n_medrecon': {'type': 'numerical', 'subtype': 'integer'}}
}

my_report = QualityReport()
my_report.generate(data, new_data, metadata)

print(my_report.get_details('Column Shapes'))

# my_report.get_visualization(property_name='Column Pair Trends')