{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "858d2263",
   "metadata": {},
   "source": [
    "# Random Seeds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8687dcbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "random_seed = 1999\n",
    "\n",
    "import random\n",
    "random.seed(random_seed)\n",
    "import numpy as np\n",
    "np.random.seed(random_seed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e4b18b75",
   "metadata": {},
   "source": [
    "# Train random forest "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "53216f27",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "f_names: ['Pregnancies', 'Glucose', 'BloodPressure', 'SkinThickness', 'Insulin', 'BMI', 'DiabetesPedigreeFunction', 'Age']\n",
      "f_types: [1, 1, 1, 1, 1, 1, 1, 1]\n",
      "c_names: ['Neg', 'Pos']\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append(\"../../../src/\")\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.datasets import load_iris\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "\n",
    "from uncertainpy.explanation.randomForest import MonteCarloSampler\n",
    "\n",
    "cont = MonteCarloSampler.type_cont\n",
    "cat =  MonteCarloSampler.type_cat\n",
    "\n",
    "\n",
    "# # load pima dataset\n",
    "filename = r\"../../../data/pima.csv\"\n",
    "dataset_df = pd.read_csv(filename, nrows=769)\n",
    "dateset_nd = dataset_df.values\n",
    "number_features = len(dataset_df.columns)-1\n",
    "X = dateset_nd[:,0:number_features]\n",
    "y = dateset_nd[:,number_features]\n",
    "f_names = list(dataset_df.columns[0:number_features])\n",
    "c_names = ['Neg','Pos']\n",
    "f_types = [cont] * 8\n",
    "\n",
    "# split the dataset\n",
    "X_train, X_test, y_train, y_test = train_test_split(X, y, random_state=0)\n",
    "\n",
    "# train a classifier\n",
    "rf = RandomForestClassifier()\n",
    "rf.fit(X_train, y_train)\n",
    "\n",
    "print(f\"f_names: {f_names}\")\n",
    "print(f\"f_types: {f_types}\")\n",
    "print(f\"c_names: {c_names}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b7cebc0c",
   "metadata": {},
   "source": [
    "# Run Sampling Algorithm to approximate delta-sufficient and delta-necessary reasons\n",
    "\n",
    "The current proof-of-concept algorithm works in two stages:\n",
    "- Stage 1: Estimate percentage of non-ambiguous inputs and determine all atomic almost necessary and sufficient reasons. The algorithm reports the remaining runtime and prints the results at termination.\n",
    "- Stage 2: Approximate all almost necessary and sufficient reasons of size 2. This stage can take a long time because all candidates are considered exhaustively. Results are reported continuously. The exhaustive search will be replaced with a more goal-oriented search (find promising short explanations) in future versions. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "03664366",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start Approximating Percentage of Nonambiguous Inputs and Atomic Queries\n",
      "  ... sampling in progress ... completed 671/50000 samples ... estimated time remaining: 368 seconds ...\n",
      "  ... sampling in progress ... completed 1334/50000 samples ... estimated time remaining: 365 seconds ...\n",
      "  ... sampling in progress ... completed 1953/50000 samples ... estimated time remaining: 369 seconds ...\n",
      "  ... sampling in progress ... completed 2672/50000 samples ... estimated time remaining: 354 seconds ...\n",
      "  ... sampling in progress ... completed 3333/50000 samples ... estimated time remaining: 350 seconds ...\n",
      "  ... sampling in progress ... completed 3967/50000 samples ... estimated time remaining: 348 seconds ...\n",
      "  ... sampling in progress ... completed 4605/50000 samples ... estimated time remaining: 345 seconds ...\n",
      "  ... sampling in progress ... completed 5214/50000 samples ... estimated time remaining: 343 seconds ...\n",
      "  ... sampling in progress ... completed 5895/50000 samples ... estimated time remaining: 336 seconds ...\n",
      "  ... sampling in progress ... completed 6577/50000 samples ... estimated time remaining: 330 seconds ...\n",
      "  ... sampling in progress ... completed 7272/50000 samples ... estimated time remaining: 323 seconds ...\n",
      "  ... sampling in progress ... completed 7924/50000 samples ... estimated time remaining: 318 seconds ...\n",
      "  ... sampling in progress ... completed 8627/50000 samples ... estimated time remaining: 312 seconds ...\n",
      "  ... sampling in progress ... completed 9281/50000 samples ... estimated time remaining: 307 seconds ...\n",
      "  ... sampling in progress ... completed 9955/50000 samples ... estimated time remaining: 301 seconds ...\n",
      "  ... sampling in progress ... completed 10618/50000 samples ... estimated time remaining: 296 seconds ...\n",
      "  ... sampling in progress ... completed 11318/50000 samples ... estimated time remaining: 290 seconds ...\n",
      "  ... sampling in progress ... completed 11996/50000 samples ... estimated time remaining: 285 seconds ...\n",
      "  ... sampling in progress ... completed 12684/50000 samples ... estimated time remaining: 279 seconds ...\n",
      "  ... sampling in progress ... completed 13314/50000 samples ... estimated time remaining: 275 seconds ...\n",
      "  ... sampling in progress ... completed 13928/50000 samples ... estimated time remaining: 272 seconds ...\n",
      "  ... sampling in progress ... completed 14583/50000 samples ... estimated time remaining: 267 seconds ...\n",
      "  ... sampling in progress ... completed 15256/50000 samples ... estimated time remaining: 262 seconds ...\n",
      "  ... sampling in progress ... completed 15868/50000 samples ... estimated time remaining: 258 seconds ...\n",
      "  ... sampling in progress ... completed 16509/50000 samples ... estimated time remaining: 253 seconds ...\n",
      "  ... sampling in progress ... completed 17241/50000 samples ... estimated time remaining: 247 seconds ...\n",
      "  ... sampling in progress ... completed 17911/50000 samples ... estimated time remaining: 242 seconds ...\n",
      "  ... sampling in progress ... completed 18599/50000 samples ... estimated time remaining: 236 seconds ...\n",
      "  ... sampling in progress ... completed 19268/50000 samples ... estimated time remaining: 231 seconds ...\n",
      "  ... sampling in progress ... completed 19958/50000 samples ... estimated time remaining: 225 seconds ...\n",
      "  ... sampling in progress ... completed 20697/50000 samples ... estimated time remaining: 219 seconds ...\n",
      "  ... sampling in progress ... completed 21360/50000 samples ... estimated time remaining: 214 seconds ...\n",
      "  ... sampling in progress ... completed 21995/50000 samples ... estimated time remaining: 210 seconds ...\n",
      "  ... sampling in progress ... completed 22662/50000 samples ... estimated time remaining: 205 seconds ...\n",
      "  ... sampling in progress ... completed 23374/50000 samples ... estimated time remaining: 199 seconds ...\n",
      "  ... sampling in progress ... completed 24076/50000 samples ... estimated time remaining: 193 seconds ...\n",
      "  ... sampling in progress ... completed 24743/50000 samples ... estimated time remaining: 188 seconds ...\n",
      "  ... sampling in progress ... completed 25512/50000 samples ... estimated time remaining: 182 seconds ...\n",
      "  ... sampling in progress ... completed 26160/50000 samples ... estimated time remaining: 177 seconds ...\n",
      "  ... sampling in progress ... completed 26842/50000 samples ... estimated time remaining: 172 seconds ...\n",
      "  ... sampling in progress ... completed 27503/50000 samples ... estimated time remaining: 167 seconds ...\n",
      "  ... sampling in progress ... completed 28244/50000 samples ... estimated time remaining: 161 seconds ...\n",
      "  ... sampling in progress ... completed 28976/50000 samples ... estimated time remaining: 156 seconds ...\n",
      "  ... sampling in progress ... completed 29666/50000 samples ... estimated time remaining: 150 seconds ...\n",
      "  ... sampling in progress ... completed 30365/50000 samples ... estimated time remaining: 145 seconds ...\n",
      "  ... sampling in progress ... completed 31131/50000 samples ... estimated time remaining: 139 seconds ...\n",
      "  ... sampling in progress ... completed 31862/50000 samples ... estimated time remaining: 133 seconds ...\n",
      "  ... sampling in progress ... completed 32547/50000 samples ... estimated time remaining: 128 seconds ...\n",
      "  ... sampling in progress ... completed 33276/50000 samples ... estimated time remaining: 123 seconds ...\n",
      "  ... sampling in progress ... completed 33928/50000 samples ... estimated time remaining: 118 seconds ...\n",
      "  ... sampling in progress ... completed 34654/50000 samples ... estimated time remaining: 113 seconds ...\n",
      "  ... sampling in progress ... completed 35340/50000 samples ... estimated time remaining: 107 seconds ...\n",
      "  ... sampling in progress ... completed 36050/50000 samples ... estimated time remaining: 102 seconds ...\n",
      "  ... sampling in progress ... completed 36727/50000 samples ... estimated time remaining: 97 seconds ...\n",
      "  ... sampling in progress ... completed 37407/50000 samples ... estimated time remaining: 92 seconds ...\n",
      "  ... sampling in progress ... completed 38067/50000 samples ... estimated time remaining: 87 seconds ...\n",
      "  ... sampling in progress ... completed 38735/50000 samples ... estimated time remaining: 82 seconds ...\n",
      "  ... sampling in progress ... completed 39431/50000 samples ... estimated time remaining: 77 seconds ...\n",
      "  ... sampling in progress ... completed 40143/50000 samples ... estimated time remaining: 72 seconds ...\n",
      "  ... sampling in progress ... completed 40770/50000 samples ... estimated time remaining: 67 seconds ...\n",
      "  ... sampling in progress ... completed 41456/50000 samples ... estimated time remaining: 62 seconds ...\n",
      "  ... sampling in progress ... completed 42146/50000 samples ... estimated time remaining: 57 seconds ...\n",
      "  ... sampling in progress ... completed 42821/50000 samples ... estimated time remaining: 52 seconds ...\n",
      "  ... sampling in progress ... completed 43593/50000 samples ... estimated time remaining: 47 seconds ...\n",
      "  ... sampling in progress ... completed 44283/50000 samples ... estimated time remaining: 41 seconds ...\n",
      "  ... sampling in progress ... completed 45031/50000 samples ... estimated time remaining: 36 seconds ...\n",
      "  ... sampling in progress ... completed 45684/50000 samples ... estimated time remaining: 31 seconds ...\n",
      "  ... sampling in progress ... completed 46352/50000 samples ... estimated time remaining: 26 seconds ...\n",
      "  ... sampling in progress ... completed 47067/50000 samples ... estimated time remaining: 21 seconds ...\n",
      "  ... sampling in progress ... completed 47778/50000 samples ... estimated time remaining: 16 seconds ...\n",
      "  ... sampling in progress ... completed 48449/50000 samples ... estimated time remaining: 11 seconds ...\n",
      "  ... sampling in progress ... completed 49113/50000 samples ... estimated time remaining: 6 seconds ...\n",
      "  ... sampling in progress ... completed 49804/50000 samples ... estimated time remaining: 1 seconds ...\n",
      "Sampling finished after 366.46081256866455 seconds.\n",
      "\n",
      "\n",
      "Estimates:\n",
      "\n",
      "  Percentage of nonambiguous input equivalence classes: 0.9798\n",
      "  Number of ambiguous input equivalence classess found: 1010\n",
      "\n",
      "Feature Pregnancies:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature Glucose:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "  P( Pos | 'Glucose'=(165.5, 166.0))=0.9408866995073891 based on 203 samples\n",
      "  P( Pos | 'Glucose'=(166.0, 166.5))=0.9243243243243243 based on 185 samples\n",
      "  P( Pos | 'Glucose'=(166.5, 167.0))=0.9483568075117371 based on 213 samples\n",
      "  P( Pos | 'Glucose'=(167.0, 168.0))=0.9032258064516129 based on 217 samples\n",
      "  P( Pos | 'Glucose'=(168.0, 168.5))=0.9342723004694836 based on 213 samples\n",
      "  P( Pos | 'Glucose'=(169.5, 170.5))=0.9162995594713657 based on 227 samples\n",
      "  P( Pos | 'Glucose'=(170.5, 171.0))=0.918552036199095 based on 221 samples\n",
      "  P( Pos | 'Glucose'=(171.0, 172.0))=0.9264705882352942 based on 204 samples\n",
      "  P( Pos | 'Glucose'=(172.0, 172.5))=0.921875 based on 192 samples\n",
      "  P( Pos | 'Glucose'=(172.5, 173.0))=0.9158415841584159 based on 202 samples\n",
      "  P( Pos | 'Glucose'=(173.0, 173.5))=0.9148936170212766 based on 235 samples\n",
      "  P( Pos | 'Glucose'=(173.5, 174.0))=0.9126637554585153 based on 229 samples\n",
      "  P( Pos | 'Glucose'=(174.0, 174.5))=0.9288888888888889 based on 225 samples\n",
      "  P( Pos | 'Glucose'=(174.5, 175.5))=0.9375 based on 208 samples\n",
      "  P( Pos | 'Glucose'=(175.5, 176.0))=0.9295774647887324 based on 213 samples\n",
      "  P( Pos | 'Glucose'=(176.0, 176.5))=0.9294605809128631 based on 241 samples\n",
      "  P( Pos | 'Glucose'=(176.5, 177.0))=0.9074889867841409 based on 227 samples\n",
      "  P( Pos | 'Glucose'=(177.0, 178.0))=0.9030837004405287 based on 227 samples\n",
      "  P( Pos | 'Glucose'=(178.0, 178.5))=0.9073170731707317 based on 205 samples\n",
      "  P( Pos | 'Glucose'=(178.5, 179.5))=0.9592760180995475 based on 221 samples\n",
      "  P( Pos | 'Glucose'=(179.5, 180.0))=0.9014778325123153 based on 203 samples\n",
      "  P( Pos | 'Glucose'=(180.0, 180.5))=0.9539170506912442 based on 217 samples\n",
      "  P( Pos | 'Glucose'=(180.5, 181.5))=0.9252336448598131 based on 214 samples\n",
      "  P( Pos | 'Glucose'=(183.5, 185.0))=0.9386792452830188 based on 212 samples\n",
      "  P( Pos | 'Glucose'=(185.0, 186.0))=0.9162790697674419 based on 215 samples\n",
      "  P( Pos | 'Glucose'=(186.0, 186.5))=0.926605504587156 based on 218 samples\n",
      "  P( Pos | 'Glucose'=(186.5, 187.0))=0.9068627450980392 based on 204 samples\n",
      "  P( Pos | 'Glucose'=(187.0, 187.5))=0.9380530973451328 based on 226 samples\n",
      "  P( Pos | 'Glucose'=(187.5, 188.5))=0.9120370370370371 based on 216 samples\n",
      "  P( Pos | 'Glucose'=(188.5, 189.0))=0.900398406374502 based on 251 samples\n",
      "  P( Pos | 'Glucose'=(189.5, 190.0))=0.9358288770053476 based on 187 samples\n",
      "  P( Pos | 'Glucose'=(190.0, 192.5))=0.9246861924686193 based on 239 samples\n",
      "  P( Pos | 'Glucose'=(192.5, 193.0))=0.9043478260869565 based on 230 samples\n",
      "  P( Pos | 'Glucose'=(193.0, 194.5))=0.9173553719008265 based on 242 samples\n",
      "  P( Pos | 'Glucose'=(194.5, 195.5))=0.9259259259259259 based on 243 samples\n",
      "  P( Pos | 'Glucose'=(196.5, inf))=0.9517543859649122 based on 228 samples\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature BloodPressure:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature SkinThickness:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature Insulin:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature BMI:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "  P( Neg | 'BMI'=(-inf, 9.100000381469727))=0.9166666666666666 based on 108 samples\n",
      "  P( Neg | 'BMI'=(14.949999809265137, 15.600000381469727))=0.9134615384615384 based on 104 samples\n",
      "  P( Pos | 'BMI'=(52.75, 53.25))=0.9012345679012346 based on 81 samples\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature DiabetesPedigreeFunction:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "  P( Pos | 'DiabetesPedigreeFunction'=(1.1410000324249268, 1.141999989748001))=0.9111111111111111 based on 45 samples\n",
      "  P( Pos | 'DiabetesPedigreeFunction'=(1.180999994277954, 1.1815000176429749))=0.9318181818181818 based on 44 samples\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature Age:\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Try to find pairwise delta-sufficient reasons.\n",
      "\n",
      "\n",
      " Scanning Feature Pregnancies\n",
      "\n",
      "\n",
      "  vs Feature Glucose\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(42.0, 47.0))=0.9696969696969697 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(47.0, 47.5))=0.9393939393939394 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(47.5, 48.5))=0.9489795918367347 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(48.5, 74.5))=0.9393939393939394 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(74.5, 75.5))=0.9292929292929293 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(75.5, 77.5))=0.9381443298969072 based on 97 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(77.5, 78.0))=0.9285714285714286 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(78.0, 78.5))=0.9693877551020408 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(78.5, 79.0))=0.9494949494949495 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(79.0, 79.5))=0.92 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(79.5, 80.0))=0.9591836734693877 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(80.0, 80.5))=0.9393939393939394 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(80.5, 81.0))=0.96 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(81.5, 82.0))=0.91 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(82.0, 82.5))=0.93 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(82.5, 83.0))=0.9494949494949495 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(83.0, 83.5))=0.9494949494949495 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(83.5, 84.0))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(84.0, 84.5))=0.93 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(84.5, 85.5))=0.9191919191919192 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(85.5, 86.0))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(86.0, 86.5))=0.9278350515463918 based on 97 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(86.5, 87.0))=0.94 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(87.0, 87.5))=0.97 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(87.5, 88.0))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(88.0, 89.0))=0.9278350515463918 based on 97 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(89.0, 89.5))=0.9285714285714286 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(89.5, 90.0))=0.9090909090909091 based on 99 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(90.0, 90.5))=0.9489795918367347 based on 98 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(91.5, 92.0))=0.9278350515463918 based on 97 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(92.0, 92.5))=0.93 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(98.0, 98.5))=0.9 based on 100 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(99.0, 99.5))=0.9175257731958762 based on 97 samples.\n",
      "\n",
      "   P( Neg | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(100.5, 101.0))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(168.5, 169.0))=0.9081632653061225 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(171.0, 172.0))=0.9387755102040817 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(172.0, 172.5))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(172.5, 173.0))=0.90625 based on 96 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(173.5, 174.0))=0.9292929292929293 based on 99 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(174.5, 175.5))=0.9484536082474226 based on 97 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(175.5, 176.0))=0.9693877551020408 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(176.5, 177.0))=0.9285714285714286 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(178.0, 178.5))=0.9387755102040817 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(180.5, 181.5))=0.9387755102040817 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(181.5, 182.0))=0.9081632653061225 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(182.0, 183.5))=0.9387755102040817 based on 98 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(186.5, 187.0))=0.9484536082474226 based on 97 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(187.0, 187.5))=0.9191919191919192 based on 99 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(189.0, 189.5))=0.9393939393939394 based on 99 samples.\n",
      "\n",
      "   P( Pos | 'Pregnancies'=(-inf, 0.5),  'Glucose'=(192.5, 193.0))=0.9387755102040817 based on 98 samples.\n",
      "\n",
      "\n",
      "  vs Feature BloodPressure\n",
      "\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[1;32m~\\AppData\\Local\\Temp/ipykernel_3040/2233314893.py\u001b[0m in \u001b[0;36m<module>\u001b[1;34m\u001b[0m\n\u001b[0;32m      1\u001b[0m \u001b[0mmcs\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mMonteCarloSampler\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mf_names\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mf_types\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mc_names\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mrf\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m----> 2\u001b[1;33m \u001b[0mmcs\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0msample\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;36m50000\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[1;32mC:\\Repositories\\Git\\Uncertainpy\\Uncertainpy\\examples\\explanations\\randomForests\\../../../src\\uncertainpy\\explanation\\randomForest.py\u001b[0m in \u001b[0;36msample\u001b[1;34m(self, no_samples, min_no_estimates)\u001b[0m\n\u001b[0;32m     34\u001b[0m         \u001b[0mmin_no_estimates\u001b[0m\u001b[1;33m:\u001b[0m \u001b[0mminimal\u001b[0m \u001b[0mnumber\u001b[0m \u001b[0mof\u001b[0m \u001b[0msamples\u001b[0m \u001b[0mrequired\u001b[0m \u001b[0mto\u001b[0m \u001b[0mestimate\u001b[0m \u001b[0ma\u001b[0m \u001b[0mprobability\u001b[0m \u001b[1;33m(\u001b[0m\u001b[1;32mnot\u001b[0m \u001b[0mimplemented\u001b[0m \u001b[0myet\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     35\u001b[0m         \"\"\"\n\u001b[1;32m---> 36\u001b[1;33m         \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0msampleAtomicAndAmbiguous\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mno_samples\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmin_no_estimates\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m     37\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     38\u001b[0m     \u001b[1;32mdef\u001b[0m \u001b[0mevaluateSample\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mx\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32mC:\\Repositories\\Git\\Uncertainpy\\Uncertainpy\\examples\\explanations\\randomForests\\../../../src\\uncertainpy\\explanation\\randomForest.py\u001b[0m in \u001b[0;36msampleAtomicAndAmbiguous\u001b[1;34m(self, no_samples, min_no_estimates)\u001b[0m\n\u001b[0;32m    128\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    129\u001b[0m         \u001b[1;31m#pairwise sampling\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 130\u001b[1;33m         \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0msamplePairwise\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    131\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    132\u001b[0m     \u001b[1;32mdef\u001b[0m \u001b[0msamplePairwise\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mdelta\u001b[0m \u001b[1;33m=\u001b[0m \u001b[1;36m0.9\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mno_pairwise_samples\u001b[0m\u001b[1;33m=\u001b[0m\u001b[1;36m100\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32mC:\\Repositories\\Git\\Uncertainpy\\Uncertainpy\\examples\\explanations\\randomForests\\../../../src\\uncertainpy\\explanation\\randomForest.py\u001b[0m in \u001b[0;36msamplePairwise\u001b[1;34m(self, delta, no_pairwise_samples)\u001b[0m\n\u001b[0;32m    177\u001b[0m                                     \u001b[0mx\u001b[0m\u001b[1;33m[\u001b[0m\u001b[0mf3\u001b[0m\u001b[1;33m]\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0meq\u001b[0m\u001b[1;33m[\u001b[0m\u001b[0mf3\u001b[0m\u001b[1;33m]\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mfeature_partitions\u001b[0m\u001b[1;33m[\u001b[0m\u001b[0mf3\u001b[0m\u001b[1;33m]\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mcreateSample\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    178\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 179\u001b[1;33m                             \u001b[0mambiguous\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmax_class\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mevaluateSample\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mx\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    180\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    181\u001b[0m                             \u001b[1;32mif\u001b[0m \u001b[1;32mnot\u001b[0m \u001b[0mambiguous\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32mC:\\Repositories\\Git\\Uncertainpy\\Uncertainpy\\examples\\explanations\\randomForests\\../../../src\\uncertainpy\\explanation\\randomForest.py\u001b[0m in \u001b[0;36mevaluateSample\u001b[1;34m(self, x)\u001b[0m\n\u001b[0;32m     44\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     45\u001b[0m         \u001b[1;31m#get class probabilities (relative frequency of votes)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m---> 46\u001b[1;33m         \u001b[0mclass_probs\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mrf\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mpredict_proba\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m[\u001b[0m\u001b[0mx\u001b[0m\u001b[1;33m]\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m[\u001b[0m\u001b[1;36m0\u001b[0m\u001b[1;33m]\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m     47\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     48\u001b[0m         \u001b[1;31m#determine if input is non-ambiguous and determine class with max number of votes\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\sklearn\\ensemble\\_forest.py\u001b[0m in \u001b[0;36mpredict_proba\u001b[1;34m(self, X)\u001b[0m\n\u001b[0;32m    681\u001b[0m                      for j in np.atleast_1d(self.n_classes_)]\n\u001b[0;32m    682\u001b[0m         \u001b[0mlock\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mthreading\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mLock\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 683\u001b[1;33m         Parallel(n_jobs=n_jobs, verbose=self.verbose,\n\u001b[0m\u001b[0;32m    684\u001b[0m                  \u001b[1;33m**\u001b[0m\u001b[0m_joblib_parallel_args\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mrequire\u001b[0m\u001b[1;33m=\u001b[0m\u001b[1;34m\"sharedmem\"\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    685\u001b[0m             delayed(_accumulate_prediction)(e.predict_proba, X, all_proba,\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\parallel.py\u001b[0m in \u001b[0;36m__call__\u001b[1;34m(self, iterable)\u001b[0m\n\u001b[0;32m   1042\u001b[0m                 \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_iterating\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_original_iterator\u001b[0m \u001b[1;32mis\u001b[0m \u001b[1;32mnot\u001b[0m \u001b[1;32mNone\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m   1043\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m-> 1044\u001b[1;33m             \u001b[1;32mwhile\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mdispatch_one_batch\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0miterator\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m   1045\u001b[0m                 \u001b[1;32mpass\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m   1046\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\parallel.py\u001b[0m in \u001b[0;36mdispatch_one_batch\u001b[1;34m(self, iterator)\u001b[0m\n\u001b[0;32m    857\u001b[0m                 \u001b[1;32mreturn\u001b[0m \u001b[1;32mFalse\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    858\u001b[0m             \u001b[1;32melse\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 859\u001b[1;33m                 \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_dispatch\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mtasks\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    860\u001b[0m                 \u001b[1;32mreturn\u001b[0m \u001b[1;32mTrue\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    861\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\parallel.py\u001b[0m in \u001b[0;36m_dispatch\u001b[1;34m(self, batch)\u001b[0m\n\u001b[0;32m    775\u001b[0m         \u001b[1;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_lock\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    776\u001b[0m             \u001b[0mjob_idx\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mlen\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_jobs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 777\u001b[1;33m             \u001b[0mjob\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_backend\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mapply_async\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mbatch\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mcallback\u001b[0m\u001b[1;33m=\u001b[0m\u001b[0mcb\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    778\u001b[0m             \u001b[1;31m# A job can complete so quickly than its callback is\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    779\u001b[0m             \u001b[1;31m# called before we get here, causing self._jobs to\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\_parallel_backends.py\u001b[0m in \u001b[0;36mapply_async\u001b[1;34m(self, func, callback)\u001b[0m\n\u001b[0;32m    206\u001b[0m     \u001b[1;32mdef\u001b[0m \u001b[0mapply_async\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mfunc\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mcallback\u001b[0m\u001b[1;33m=\u001b[0m\u001b[1;32mNone\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    207\u001b[0m         \u001b[1;34m\"\"\"Schedule a func to be run\"\"\"\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 208\u001b[1;33m         \u001b[0mresult\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mImmediateResult\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfunc\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    209\u001b[0m         \u001b[1;32mif\u001b[0m \u001b[0mcallback\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    210\u001b[0m             \u001b[0mcallback\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mresult\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\_parallel_backends.py\u001b[0m in \u001b[0;36m__init__\u001b[1;34m(self, batch)\u001b[0m\n\u001b[0;32m    570\u001b[0m         \u001b[1;31m# Don't delay the application, to avoid keeping the input\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    571\u001b[0m         \u001b[1;31m# arguments in memory\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 572\u001b[1;33m         \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mresults\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mbatch\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    573\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    574\u001b[0m     \u001b[1;32mdef\u001b[0m \u001b[0mget\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\parallel.py\u001b[0m in \u001b[0;36m__call__\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    260\u001b[0m         \u001b[1;31m# change the default number of processes to -1\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    261\u001b[0m         \u001b[1;32mwith\u001b[0m \u001b[0mparallel_backend\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_backend\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mn_jobs\u001b[0m\u001b[1;33m=\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_n_jobs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 262\u001b[1;33m             return [func(*args, **kwargs)\n\u001b[0m\u001b[0;32m    263\u001b[0m                     for func, args, kwargs in self.items]\n\u001b[0;32m    264\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\joblib\\parallel.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[1;34m(.0)\u001b[0m\n\u001b[0;32m    260\u001b[0m         \u001b[1;31m# change the default number of processes to -1\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    261\u001b[0m         \u001b[1;32mwith\u001b[0m \u001b[0mparallel_backend\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_backend\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mn_jobs\u001b[0m\u001b[1;33m=\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_n_jobs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 262\u001b[1;33m             return [func(*args, **kwargs)\n\u001b[0m\u001b[0;32m    263\u001b[0m                     for func, args, kwargs in self.items]\n\u001b[0;32m    264\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\sklearn\\utils\\fixes.py\u001b[0m in \u001b[0;36m__call__\u001b[1;34m(self, *args, **kwargs)\u001b[0m\n\u001b[0;32m    220\u001b[0m     \u001b[1;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;33m*\u001b[0m\u001b[0margs\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;33m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    221\u001b[0m         \u001b[1;32mwith\u001b[0m \u001b[0mconfig_context\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m**\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mconfig\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 222\u001b[1;33m             \u001b[1;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mfunction\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;33m*\u001b[0m\u001b[0margs\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;33m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\sklearn\\ensemble\\_forest.py\u001b[0m in \u001b[0;36m_accumulate_prediction\u001b[1;34m(predict, X, out, lock)\u001b[0m\n\u001b[0;32m    465\u001b[0m     \u001b[0mcomplains\u001b[0m \u001b[0mthat\u001b[0m \u001b[0mit\u001b[0m \u001b[0mcannot\u001b[0m \u001b[0mpickle\u001b[0m \u001b[0mit\u001b[0m \u001b[0mwhen\u001b[0m \u001b[0mplaced\u001b[0m \u001b[0mthere\u001b[0m\u001b[1;33m.\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    466\u001b[0m     \"\"\"\n\u001b[1;32m--> 467\u001b[1;33m     \u001b[0mprediction\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mpredict\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mX\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mcheck_input\u001b[0m\u001b[1;33m=\u001b[0m\u001b[1;32mFalse\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    468\u001b[0m     \u001b[1;32mwith\u001b[0m \u001b[0mlock\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    469\u001b[0m         \u001b[1;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mout\u001b[0m\u001b[1;33m)\u001b[0m \u001b[1;33m==\u001b[0m \u001b[1;36m1\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\Explainable ML\\lib\\site-packages\\sklearn\\tree\\_classes.py\u001b[0m in \u001b[0;36mpredict_proba\u001b[1;34m(self, X, check_input)\u001b[0m\n\u001b[0;32m    934\u001b[0m         \u001b[0mcheck_is_fitted\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    935\u001b[0m         \u001b[0mX\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0m_validate_X_predict\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mX\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mcheck_input\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 936\u001b[1;33m         \u001b[0mproba\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mtree_\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mpredict\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mX\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    937\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    938\u001b[0m         \u001b[1;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mn_outputs_\u001b[0m \u001b[1;33m==\u001b[0m \u001b[1;36m1\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "mcs = MonteCarloSampler(f_names, f_types, c_names, rf)\n",
    "mcs.sample(50000)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
