datasets_ohe_vectors = {
    "compas": [[1,2,3,4,5], [9,10,11,12]],
    "adult": [[3,4,5,6,7,8]],# [11,12,13,14,15], [16, 17, 18]],
    "adult_larger":[[0,1,2], [5,6,7,8,9,10], [12,13,14], [15,16,17,18,19], [20,21,22,23,24,25], [26,27,28,29,30], [31,32,33,34,35,36], [37,38,39,40]],
    "default_credit":[[0,1,2,3], [5,6,7]],
    "default_credit_numerical":[[15,16,17,18],[19,20,21]],
    "default_credit_numerical_2":[[0,1,2,3], [5,6,7]],
    "fico": [ # New entry for FICO
        [0, 1, 2],    # ExternalRiskEstimate bins
        [3, 4, 5],    # MSinceOldestTradeOpen bins
        [6, 7],       # NumSatisfactoryTrades bins
        [8, 9],       # NumTrades90Ever2DerogPubRec bins
        [10, 11, 12], # MSinceMostRecentDelq bins
        [13, 14, 15], # MaxDelqEver bins
        [16, 17],     # NumTotalTrades bins
        [18, 19, 20], # NumTradesOpeninLast12M bins
        [21, 22, 23], # NumInqLast6M bins
        [24, 25],     # NetFractionRevolvingBurden bins
        [26, 27, 28]  # NumRevolvingTradesWBalance bins
    ],
    "bank-marketing": [ # New entry for Bank Marketing
        [1, 2, 3],       # age (e.g., age_lt26, age_26-61, age_ge61)
        [4, 5, 6],       # job (e.g., job_blue-collar, job_management-services, job_other)
        [9, 10, 11],     # duration (e.g., duration_lt121, duration_121-600, duration_ge600)
        [12, 13, 14],    # campaign (e.g., campaign_lt2, campaign_2-6, campaign_ge6)
        [15, 16, 17],    # pdays (e.g., pdays_lt31, pdays_31-181, pdays_ge181)
        [18, 19, 20],    # previous (e.g., previous_0-1, previous_1-6, previous_ge6)
        [21, 22, 23, 24],# education (e.g., education_tertiary, education_secondary, education_unknown, education_primary)
        [28, 29, 30],    # contact (e.g., contact_unknown, contact_cellular, contact_telephone)
        [31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42], # month (e.g., month_may, ..., month_sep)
        [43, 44, 45, 46] # poutcome (e.g., poutcome_unknown, poutcome_failure, poutcome_other, poutcome_success)
    ],
    "diabetes": [ # New entry for Diabetes (readmitted is label, indices shifted)
        [1, 2, 3, 4],                   # age (was 2-5)
        [13, 14, 15, 16, 17],           # race (was 14-18)
        [18, 19, 20, 21],               # max_glu_serum (was 19-22)
        [22, 23, 24, 25],               # A1Cresult (was 23-26)
        [26, 27, 28, 29],               # metformin (was 27-30)
        [30, 31, 32, 33],               # repaglinide (was 31-34)
        [34, 35, 36, 37],               # nateglinide (was 35-38)
        [38, 39, 40],                   # chlorpropamide (was 39-41)
        [41, 42, 43, 44],               # glimepiride (was 42-45)
        [46, 47, 48, 49],               # glipizide (was 47-50)
        [50, 51, 52, 53],               # glyburide (was 51-54)
        [55, 56, 57, 58],               # pioglitazone (was 56-59)
        [59, 60, 61, 62],               # rosiglitazone (was 60-63)
        [63, 64, 65, 66],               # acarbose (was 64-67)
        [67, 68, 69, 70],               # miglitol (was 68-71)
        [72, 73, 74],                   # tolazamide (was 73-75)
        [75, 76, 77, 78],               # insulin (was 76-79)
        [79, 80, 81],                   # glyburide-metformin (was 80-82)
    ]
}
predictions = {
    "compas":"recidivate-within-two-years:1",
    "adult":"income", "adult_larger":"income", 
    "default_credit":"DEFAULT_PAYMENT",
    "default_credit_numerical":"DEFAULT_PAYMENT",
    "default_credit_numerical_2":"DEFAULT_PAYMENT",
    "fico": "RiskPerformance:Bad",
    "bank-marketing": "class:yes",
    "diabetes": "readmitted:<30"
}

# Below: for ordinal and numerical attributes support
# Each element in the list is the index of an ordinal (integer attribute whose values can be sorted) feature, then the lower and upper bounds on values of such feature
datasets_ordinal_attrs = {"compas": [],
                     "adult": [],
                     "adult_larger": [],
                     "default_credit": [],
                     "default_credit_numerical": [[1, 21, 79]],
                     "default_credit_numerical_2": [[4,-1,-1]],
                     "fico": []}

# Each element in the list is the index of a numerical (continuous) feature, then the lower and upper bounds on values of such feature
datasets_numerical_attrs = {"compas": [],
                     "adult": [],
                     "fico": [],
                     "adult_larger": [],
                     "default_credit": [],
                     "default_credit_numerical": [[0, 10000, 1000000], [2, -165580, 964511], [3, -69777, 983931], [4, -157264, 1664089], [5, -170000, 891586], [6, -81334, 927171], [7, -339603, 961664], [8, 0, 873552], [9, 0, 1684259], [10, 0, 896040], [11, 0, 621000], [12, 0, 426529], [13, 0, 528666]],
                     "default_credit_numerical_2":[]}
