{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "3dfb27e5",
   "metadata": {},
   "source": [
    "# Random Seeds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "555229a8",
   "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": "316769a0",
   "metadata": {},
   "source": [
    "# Train random forest on Iris dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "496485b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "RandomForestClassifier()"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.datasets import load_iris\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "\n",
    "iris = load_iris()\n",
    "X = iris.data\n",
    "y = iris.target\n",
    "X_train, X_test, y_train, y_test = train_test_split(X, y, random_state=random_seed)\n",
    "\n",
    "rf = RandomForestClassifier()\n",
    "rf.fit(X_train, y_train)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b2e6d557",
   "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": 8,
   "id": "947032c0",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start Approximating Percentage of Nonambiguous Inputs and Atomic Queries\n",
      "  ... sampling in progress ... completed 873/10000 samples ... estimated time remaining: 52 seconds ...\n",
      "  ... sampling in progress ... completed 1737/10000 samples ... estimated time remaining: 47 seconds ...\n",
      "  ... sampling in progress ... completed 2608/10000 samples ... estimated time remaining: 42 seconds ...\n",
      "  ... sampling in progress ... completed 3499/10000 samples ... estimated time remaining: 37 seconds ...\n",
      "  ... sampling in progress ... completed 4363/10000 samples ... estimated time remaining: 32 seconds ...\n",
      "  ... sampling in progress ... completed 5221/10000 samples ... estimated time remaining: 27 seconds ...\n",
      "  ... sampling in progress ... completed 6079/10000 samples ... estimated time remaining: 22 seconds ...\n",
      "  ... sampling in progress ... completed 6930/10000 samples ... estimated time remaining: 17 seconds ...\n",
      "  ... sampling in progress ... completed 7807/10000 samples ... estimated time remaining: 12 seconds ...\n",
      "  ... sampling in progress ... completed 8663/10000 samples ... estimated time remaining: 7 seconds ...\n",
      "  ... sampling in progress ... completed 9561/10000 samples ... estimated time remaining: 2 seconds ...\n",
      "Sampling finished after 57.66957664489746 seconds.\n",
      "\n",
      "\n",
      "Estimates:\n",
      "\n",
      "  Percentage of nonambiguous input equivalence classes: 0.98\n",
      "  Number of ambiguous input equivalence classess found: 200\n",
      "\n",
      "Feature sepal length (cm):\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature sepal width (cm):\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature petal length (cm):\n",
      "\n",
      "  Delta-sufficient Candidates\n",
      "  P( virginica | 'petal length (cm)'=(4.950000047683716, 5.0))=0.9869848156182213 based on 461 samples\n",
      "  P( virginica | 'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 407 samples\n",
      "  P( virginica | 'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 392 samples\n",
      "  P( virginica | 'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 414 samples\n",
      "  P( virginica | 'petal length (cm)'=(6.25, inf))=1.0 based on 446 samples\n",
      "\n",
      "  Delta-necessary Candidates\n",
      "\n",
      "Feature petal width (cm):\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 sepal length (cm)\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(-inf, 5.299999952316284),  'petal length (cm)'=(4.950000047683716, 5.0))=0.9183673469387755 based on 98 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(-inf, 5.299999952316284),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(-inf, 5.299999952316284),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(-inf, 5.299999952316284),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(-inf, 5.299999952316284),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.299999952316284, 5.450000047683716),  'petal length (cm)'=(4.950000047683716, 5.0))=0.9263157894736842 based on 95 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.299999952316284, 5.450000047683716),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.299999952316284, 5.450000047683716),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.299999952316284, 5.450000047683716),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.299999952316284, 5.450000047683716),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9479166666666666 based on 96 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(2.75, 2.8000000715255737))=0.9591836734693877 based on 98 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.9578947368421052 based on 95 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(3.199999988079071, 4.700000047683716))=1.0 based on 95 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(4.700000047683716, 4.75))=0.96875 based on 96 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.450000047683716, 5.5),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9010989010989011 based on 91 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(3.199999988079071, 4.700000047683716))=0.9263157894736842 based on 95 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 97 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.5, 5.549999952316284),  'petal width (cm)'=(2.75, inf))=0.9120879120879121 based on 91 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 99 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.549999952316284, 5.6499998569488525),  'petal width (cm)'=(2.75, inf))=0.9111111111111111 based on 90 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(2.75, 2.8000000715255737))=0.9230769230769231 based on 91 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.9010989010989011 based on 91 samples.\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   P( versicolor | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(3.199999988079071, 4.700000047683716))=0.9347826086956522 based on 92 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.6499998569488525, 5.75),  'petal width (cm)'=(2.75, inf))=0.945054945054945 based on 91 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 99 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.75, 5.900000095367432),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.900000095367432, 5.950000047683716),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(4.75, 4.799999952316284))=0.9 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(5.950000047683716, 6.049999952316284),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 96 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.049999952316284, 6.1499998569488525),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.1499998569488525, 6.150000095367432),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.150000095367432, 6.200000047683716),  'petal width (cm)'=(2.75, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=1.0 based on 99 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal width (cm)'=(1.699999988079071, 1.75))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.200000047683716, 6.25),  'petal width (cm)'=(2.75, inf))=1.0 based on 99 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(2.600000023841858, 2.649999976158142))=0.9130434782608695 based on 92 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal width (cm)'=(1.699999988079071, 1.75))=0.9230769230769231 based on 91 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.25, 6.400000095367432),  'petal width (cm)'=(2.75, inf))=0.9438202247191011 based on 89 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9111111111111111 based on 90 samples.\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.9473684210526315 based on 95 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.400000095367432, 6.550000190734863),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=0.9529411764705882 based on 85 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal width (cm)'=(1.5999999642372131, 1.649999976158142))=0.92 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(6.550000190734863, 6.6499998569488525),  'petal width (cm)'=(1.649999976158142, 1.699999988079071))=0.946236559139785 based on 93 samples.\n",
      "\n",
      "\n",
      "  vs Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(2.75, 2.8000000715255737))=0.9010989010989011 based on 91 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "   P( virginica | 'sepal length (cm)'=(7.6499998569488525, inf),  'petal width (cm)'=(1.699999988079071, 1.75))=0.9444444444444444 based on 90 samples.\n",
      "\n",
      "\n",
      " Scanning Feature sepal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(2.600000023841858, 2.649999976158142))=0.9010989010989011 based on 91 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(2.75, 2.8000000715255737))=0.9381443298969072 based on 97 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.945054945054945 based on 91 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(-inf, 2.25),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9042553191489362 based on 94 samples.\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   P( versicolor | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.90625 based on 96 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.25, 2.350000023841858),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9263157894736842 based on 95 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(2.75, 2.8000000715255737))=0.9130434782608695 based on 92 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.9239130434782609 based on 92 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.350000023841858, 2.399999976158142),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9010989010989011 based on 91 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.925531914893617 based on 94 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(3.199999988079071, 4.700000047683716))=0.925531914893617 based on 94 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.399999976158142, 2.5),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(2.649999976158142, 2.75))=0.90625 based on 96 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.5, 2.549999952316284),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(2.600000023841858, 2.649999976158142))=0.9157894736842105 based on 95 samples.\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(2.649999976158142, 2.75))=0.9080459770114943 based on 87 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.549999952316284, 2.600000023841858),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(2.8000000715255737, 3.199999988079071))=0.9058823529411765 based on 85 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.600000023841858, 2.649999976158142),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.649999976158142, 2.700000047683716),  'petal length (cm)'=(4.950000047683716, 5.0))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.649999976158142, 2.700000047683716),  'petal length (cm)'=(5.0, 5.1499998569488525))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.649999976158142, 2.700000047683716),  'petal length (cm)'=(5.1499998569488525, 5.200000047683716))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.649999976158142, 2.700000047683716),  'petal length (cm)'=(5.200000047683716, 5.25))=1.0 based on 100 samples.\n",
      "\n",
      "   P( virginica | 'sepal width (cm)'=(2.649999976158142, 2.700000047683716),  'petal length (cm)'=(6.25, inf))=1.0 based on 100 samples.\n",
      "\n",
      "\n",
      "  vs Feature petal width (cm)\n",
      "\n",
      "\n",
      "  vs Feature petal length (cm)\n",
      "\n",
      "   P( versicolor | 'sepal width (cm)'=(2.700000047683716, 2.75),  'petal length (cm)'=(2.600000023841858, 2.649999976158142))=0.9120879120879121 based on 91 samples.\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_26936/2035097066.py\u001b[0m in \u001b[0;36m<module>\u001b[1;34m\u001b[0m\n\u001b[0;32m     12\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     13\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---> 14\u001b[1;33m \u001b[0mmcs\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0msample\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;36m10000\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": [
    "import sys\n",
    "sys.path.append(\"../../../src/\")\n",
    " \n",
    "from uncertainpy.explanation.randomForest import MonteCarloSampler\n",
    "\n",
    "cont = MonteCarloSampler.type_cont\n",
    "cat =  MonteCarloSampler.type_cat\n",
    "\n",
    "f_names = iris.feature_names\n",
    "f_types = [cont,cont,cont,cont]\n",
    "c_names = iris.target_names\n",
    "\n",
    "mcs = MonteCarloSampler(f_names, f_types, c_names, rf)\n",
    "mcs.sample(10000)"
   ]
  }
 ],
 "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
}
