{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>User ID</th>\n",
       "      <th>Gender</th>\n",
       "      <th>Age</th>\n",
       "      <th>EstimatedSalary</th>\n",
       "      <th>Purchased</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>15624510</td>\n",
       "      <td>Male</td>\n",
       "      <td>19</td>\n",
       "      <td>19000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>15810944</td>\n",
       "      <td>Male</td>\n",
       "      <td>35</td>\n",
       "      <td>20000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>15668575</td>\n",
       "      <td>Female</td>\n",
       "      <td>26</td>\n",
       "      <td>43000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>15603246</td>\n",
       "      <td>Female</td>\n",
       "      <td>27</td>\n",
       "      <td>57000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>15804002</td>\n",
       "      <td>Male</td>\n",
       "      <td>19</td>\n",
       "      <td>76000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>395</th>\n",
       "      <td>15691863</td>\n",
       "      <td>Female</td>\n",
       "      <td>46</td>\n",
       "      <td>41000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>396</th>\n",
       "      <td>15706071</td>\n",
       "      <td>Male</td>\n",
       "      <td>51</td>\n",
       "      <td>23000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>397</th>\n",
       "      <td>15654296</td>\n",
       "      <td>Female</td>\n",
       "      <td>50</td>\n",
       "      <td>20000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>398</th>\n",
       "      <td>15755018</td>\n",
       "      <td>Male</td>\n",
       "      <td>36</td>\n",
       "      <td>33000</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>399</th>\n",
       "      <td>15594041</td>\n",
       "      <td>Female</td>\n",
       "      <td>49</td>\n",
       "      <td>36000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>400 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      User ID  Gender  Age  EstimatedSalary  Purchased\n",
       "0    15624510    Male   19            19000          0\n",
       "1    15810944    Male   35            20000          0\n",
       "2    15668575  Female   26            43000          0\n",
       "3    15603246  Female   27            57000          0\n",
       "4    15804002    Male   19            76000          0\n",
       "..        ...     ...  ...              ...        ...\n",
       "395  15691863  Female   46            41000          1\n",
       "396  15706071    Male   51            23000          1\n",
       "397  15654296  Female   50            20000          1\n",
       "398  15755018    Male   36            33000          0\n",
       "399  15594041  Female   49            36000          1\n",
       "\n",
       "[400 rows x 5 columns]"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "import pandas as pd\n",
    "import csv\n",
    "import sys\n",
    "import numpy as np\n",
    "count=0 \n",
    "data=pd.read_csv('Social_Network_Ads.csv')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data.isnull().sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data.Gender[data.Gender=='Male']=1\n",
    "data.Gender[data.Gender=='Female']=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "x=data.iloc[:,1:-1].values\n",
    "y=data.iloc[:,-1].values\n",
    "print(x[:10])\n",
    "print(y[:10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(280, 3)\n",
      "(120, 3)\n",
      "(280,)\n",
      "(120,)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "x_train,x_test,y_train,y_test=train_test_split(x,y,test_size=0.3,random_state=1)\n",
    "print(x_train.shape)\n",
    "print(x_test.shape)\n",
    "print(y_train.shape)\n",
    "print(y_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(280, 3)\n",
      "(120, 3)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.preprocessing import StandardScaler\n",
    "sc=StandardScaler()\n",
    "x_train=sc.fit_transform(x_train)\n",
    "x_test=sc.fit_transform(x_test)\n",
    "print(x_train.shape)\n",
    "print(x_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>#sk-container-id-1 {color: black;background-color: white;}#sk-container-id-1 pre{padding: 0;}#sk-container-id-1 div.sk-toggleable {background-color: white;}#sk-container-id-1 label.sk-toggleable__label {cursor: pointer;display: block;width: 100%;margin-bottom: 0;padding: 0.3em;box-sizing: border-box;text-align: center;}#sk-container-id-1 label.sk-toggleable__label-arrow:before {content: \"▸\";float: left;margin-right: 0.25em;color: #696969;}#sk-container-id-1 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-container-id-1 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-container-id-1 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-container-id-1 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-container-id-1 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-container-id-1 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: \"▾\";}#sk-container-id-1 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 input.sk-hidden--visually {border: 0;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;}#sk-container-id-1 div.sk-estimator {font-family: monospace;background-color: #f0f8ff;border: 1px dotted black;border-radius: 0.25em;box-sizing: border-box;margin-bottom: 0.5em;}#sk-container-id-1 div.sk-estimator:hover {background-color: #d4ebff;}#sk-container-id-1 div.sk-parallel-item::after {content: \"\";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-container-id-1 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 div.sk-serial::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: 0;}#sk-container-id-1 div.sk-serial {display: flex;flex-direction: column;align-items: center;background-color: white;padding-right: 0.2em;padding-left: 0.2em;position: relative;}#sk-container-id-1 div.sk-item {position: relative;z-index: 1;}#sk-container-id-1 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;position: relative;}#sk-container-id-1 div.sk-item::before, #sk-container-id-1 div.sk-parallel-item::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: -1;}#sk-container-id-1 div.sk-parallel-item {display: flex;flex-direction: column;z-index: 1;position: relative;background-color: white;}#sk-container-id-1 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-container-id-1 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-container-id-1 div.sk-parallel-item:only-child::after {width: 0;}#sk-container-id-1 div.sk-dashed-wrapped {border: 1px dashed gray;margin: 0 0.4em 0.5em 0.4em;box-sizing: border-box;padding-bottom: 0.4em;background-color: white;}#sk-container-id-1 div.sk-label label {font-family: monospace;font-weight: bold;display: inline-block;line-height: 1.2em;}#sk-container-id-1 div.sk-label-container {text-align: center;}#sk-container-id-1 div.sk-container {/* jupyter's `normalize.less` sets `[hidden] { display: none; }` but bootstrap.min.css set `[hidden] { display: none !important; }` so we also need the `!important` here to be able to override the default hidden behavior on the sphinx rendered scikit-learn.org. See: https://github.com/scikit-learn/scikit-learn/issues/21755 */display: inline-block !important;position: relative;}#sk-container-id-1 div.sk-text-repr-fallback {display: none;}</style><div id=\"sk-container-id-1\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>LogisticRegression(random_state=0)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-1\" type=\"checkbox\" checked><label for=\"sk-estimator-id-1\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">LogisticRegression</label><div class=\"sk-toggleable__content\"><pre>LogisticRegression(random_state=0)</pre></div></div></div></div></div>"
      ],
      "text/plain": [
       "LogisticRegression(random_state=0)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LogisticRegression\n",
    "lr=LogisticRegression(random_state=0)\n",
    "lr.fit(x_train,y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred=lr.predict(x_test)\n",
    "y_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "predicted_Test= lr.predict(x_test)\n",
    "predicted_Train=lr.predict(x_train) \n",
    "\n",
    "predicted_Final=np.concatenate((predicted_Test,predicted_Train),axis=0)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "data['predicted_Output']=predicted_Final"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "#CODE TO FIND ACTUAL OUTPUT\n",
    "\n",
    "from scipy.spatial.distance import euclidean\n",
    "distance_sn=[]\n",
    "euclidean_distance_value_sn=[]\n",
    "\n",
    "\n",
    "for i in range(0, len(data)):\n",
    "    # Get the Euclidean distance between the first row and the current row\n",
    "    distance_i_sn = euclidean(x[0, :-1], x[i, :-1])\n",
    "    \n",
    "    # Add the Euclidean distance to the list of Euclidean distances\n",
    "    euclidean_distance_value_sn.append(np.sqrt(distance_i_sn))\n",
    "\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "Actual_Output=[]\n",
    "for i in range(len(data)):\n",
    "    if(euclidean_distance_value_sn[i] <np.ceil(np.average(euclidean_distance_value_sn))):   \n",
    "        Actual_Output.append(0)\n",
    "    else:\n",
    "        Actual_Output.append(1)\n",
    "#Actual_Output=data['Purchased']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data['Actual_Output']=Actual_Output\n",
    "data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of women (D) in the predicted output is  61\n",
      "count of men (ND) in the predicted output is  51\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in actual output\n",
    "count_P_D=0\n",
    "count_P_ND=0\n",
    "for i in range(0,len(data)):\n",
    "    if((data.predicted_Output[i]==1) and (data.Gender[i]==0)):\n",
    "        count_P_D+=1\n",
    "    elif((data.predicted_Output[i]==1) and (data.Gender[i]==1)):\n",
    "        count_P_ND+=1\n",
    "    \n",
    "\n",
    "\n",
    "print(\"count of women (D) in the predicted output is \",count_P_D)\n",
    "print(\"count of men (ND) in the predicted output is \",count_P_ND)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of women (D) in the actual output is  66\n",
      "count of men (ND) in the actual output is  46\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in expected output\n",
    "count_A_D=0\n",
    "count_A_ND=0\n",
    "for i in range(0,len(data)):\n",
    "    if((data.Actual_Output[i]==1) and (data.Gender[i]==0)):\n",
    "        count_A_D+=1\n",
    "    elif((data.Actual_Output[i]==1) and (data.Gender[i]==1)):\n",
    "        count_A_ND+=1\n",
    "    \n",
    "\n",
    "\n",
    "print(\"count of women (D) in the actual output is \",count_A_D)\n",
    "print(\"count of men (ND) in the actual output is \",count_A_ND)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "count_of_female=(data['Gender']==0).sum()\n",
    "count_of_male=(data['Gender']==1).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias for FEMALE -0.024509803921568627\n"
     ]
    }
   ],
   "source": [
    "deg_of_bias_female=((count_P_D-count_A_D)/count_of_female)\n",
    "print(\"degree of bias for FEMALE\",deg_of_bias_female)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias for male 0.025510204081632654\n"
     ]
    }
   ],
   "source": [
    "deg_of_bias_male=((count_P_ND-count_A_ND)/count_of_male)\n",
    "print(\"degree of bias for male\",deg_of_bias_male)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping does not exist\n",
      "242\n",
      "158\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "\n",
    "\n",
    "count_both_same=0\n",
    "count_both_diff=0\n",
    "for i in range(len(data)):\n",
    "    if((data.predicted_Output[i]==data.Actual_Output[i])):\n",
    "        flag=1\n",
    "        count_both_same=count_both_same+1\n",
    "    else:\n",
    "        flag=0\n",
    "        count_both_diff=count_both_diff+1\n",
    "\n",
    "if(flag==1):\n",
    "    print(\"one-one mapping exists\")\n",
    "else:\n",
    "    print(\"one-one mapping does not exist\")\n",
    "\n",
    "        \n",
    "        \n",
    "print(count_both_same)\n",
    "print(count_both_diff)\n",
    "    \n",
    "    \n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping does not exist\n"
     ]
    }
   ],
   "source": [
    "\n",
    "if(np.logical_and(data.predicted_Output.all(),data.Actual_Output.all())):\n",
    "    flag=1\n",
    "               \n",
    "else:\n",
    "    flag=0\n",
    "if(flag==1):\n",
    "    print(\"one-one mapping exists\")\n",
    "else:\n",
    "    print(\"one-one mapping does not exist\")   \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.605\n"
     ]
    }
   ],
   "source": [
    "#THEOREM2 ---- ACCURACY OF MODEL\n",
    "Accuracy=count_both_same/len (data)\n",
    "print(\"new model accuracy is\",Accuracy)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.605\n"
     ]
    }
   ],
   "source": [
    "#original formula for accuracy\n",
    "from sklearn.metrics import accuracy_score\n",
    "print(accuracy_score(data.predicted_Output,data.Actual_Output))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.605\n",
      "         50 function calls (48 primitive calls) in 0.001 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.001    0.001 1912836126.py:3(my_method)\n",
      "        1    0.000    0.000    0.001    0.001 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.000    0.000 frame.py:1498(__len__)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        1    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "      7/5    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.print}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    Accuracy=count_both_same/len (data)\n",
    "    print(\"new model accuracy is\",Accuracy)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.605\n",
      "         918 function calls (910 primitive calls) in 0.003 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.003    0.003 3857534796.py:3(my_method)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(average)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(reshape)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(union1d)\n",
      "        5    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unique)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "        4    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.003    0.003 <string>:1(<module>)\n",
      "        4    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "        2    0.000    0.000    0.000    0.000 _array_api.py:83(unique_values)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "       10    0.000    0.000    0.000    0.000 _base.py:1301(isspmatrix)\n",
      "        1    0.000    0.000    0.000    0.000 _classification.py:137(_weighted_sum)\n",
      "        1    0.000    0.000    0.002    0.002 _classification.py:146(accuracy_score)\n",
      "        1    0.000    0.000    0.002    0.002 _classification.py:59(_check_targets)\n",
      "        8    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "        8    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "        7    0.000    0.000    0.000    0.000 _param_validation.py:103(make_constraint)\n",
      "        1    0.000    0.000    0.003    0.003 _param_validation.py:169(wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:179(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:185(<dictcomp>)\n",
      "       10    0.000    0.000    0.000    0.000 _param_validation.py:226(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _param_validation.py:258(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:262(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:272(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:28(validate_parameter_constraints)\n",
      "        3    0.000    0.000    0.000    0.000 _param_validation.py:471(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:530(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:538(is_satisfied_by)\n",
      "        2    0.000    0.000    0.000    0.000 _param_validation.py:547(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 _param_validation.py:74(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:138(unique)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:323(_unique1d)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:898(union1d)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:391(_average_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:396(average)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        7    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "        3    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3075(_bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "       18    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       16    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        2    0.000    0.000    0.000    0.000 multiclass.py:126(is_multilabel)\n",
      "        2    0.000    0.000    0.000    0.000 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:257(_is_arraylike)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:262(_is_arraylike_not_scalar)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:629(check_array)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.any}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.003    0.003 {built-in method builtins.exec}\n",
      "       25    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       65    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "      119    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    18/12    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     10/8    0.000    0.000    0.001    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method sys.getrecursionlimit}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__contains__' of 'frozenset' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'append' of 'list' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        9    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'insert' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'isidentifier' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'items' of 'mappingproxy' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'mean' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pop' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'pop' of 'set' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'values' of 'mappingproxy' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "\tprint(accuracy_score(data.predicted_Output,data.Actual_Output))\n",
    "\tpass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAcUAAAHqCAYAAAB1O1VnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAA9hAAAPYQGoP6dpAABAmUlEQVR4nO3dd3gVVf7H8c+kJ6QHiNTQpKr0JiqoKNhQQUUBqa6KWFFUFAnFXetaUH5WQFyliywoygqChSYoIGBAYUMLJCIhuSGE1PP7g8ldQgrJTW4ukPfrefJwM3POzPdeIJ/MzJkzljHGCAAAyMvTBQAAcLYgFAEAsBGKAADYCEUAAGyEIgAANkIRAAAboQgAgI1QBADARigCAGAjFIHTbN26VXfccYdq1aolHx8fWZalNm3aeKyeVatWybIsWZblsRpQtD179jj/bvbs2ePpclABCEW4RW5urubNm6fBgweradOmCg8Pl5+fn2rWrKnLLrtMY8eO1bZt2zxdZiHx8fHq1q2b5s+fr8TERIWFhSk6OlrVq1f3dGnnpPzAsCxLLVq0OGP7DRs2FOgzdOjQCq1n8+bNmjBhgt54440K3S7OHz6eLgDnn3Xr1mnIkCH6/fffnct8fX0VEhKiI0eOaPXq1Vq9erVefPFF9e3bV7Nnz5afn58HK/6f9957T2lpaWrSpIlWrVqlOnXqeLokBQUFqVmzZp4uo9x27NihtWvXqmvXrsW2mT59ultr2Lx5syZOnKiYmBg9+uij5d6er6+v8+/G19e33NuD53GkiAq1ZMkS9ejRQ7///ruioqL0wgsv6Pfff1dWVpaOHDmirKwsbdiwQU8//bRCQ0O1cOFCHT9+3NNlO23dulWSdPPNN58VgShJnTp10o4dO7Rjxw5Pl+KyBg0aSJJmzJhRbJsTJ05ozpw5sixLMTExlVRZ+dSpU8f5d3O2/HtB+RCKqDB//PGHBg0apMzMTLVs2VKbN2/W008/rQsvvNDZxtvbWx06dNALL7yg+Ph43XzzzR6suLD8gA4ODvZwJeeXwYMHy7IszZ07t9hfghYuXKiUlBR1797dGaJAZSMUUWHGjRsnh8OhgIAAff7556pbt26J7SMjI7Vo0SKFhYUVWpeYmKgxY8aoVatWqlatmqpVq6ZWrVrpySefVFJSUpHbO33QQ1JSkh555BE1bNhQAQEBio6O1p133lnkEVeDBg1kWZZWrVolSZo4cWKBa1v5yydMmCDLstSjR49i39eZBsasX79eAwcOdNZVrVo1xcTEqHv37po8ebIOHDhQpu154vMqq4YNG6p79+5yOBz67LPPimyTf+p02LBhJW7r+PHjmj17tgYPHqw2bdqoRo0a8vf3V+3atXXLLbfoq6++KrKfZVnObe/du7fA369lWZowYYKz7dChQ53XNI0x+vDDD3XZZZcpKipKlmXpo48+klT8QJsjR46obt26sixLt9xyS5H15OTkqFu3brIsS5dccolOnDhR4vtGJTFABUhMTDReXl5GkhkxYkS5trVq1SoTHh5uJBlJplq1aqZatWrO7yMiIswPP/xQqF98fLyzzRdffGFq1qxpJJmgoCDj7+/vXBcaGmo2b95coG+HDh1MdHS08fX1de4zOjra+bV69WpjjDGxsbFGkunevXux9a9cudK5r9N99NFHxrIs53p/f38TGhrq/F6SmTFjRqm356nPq7ROfU8zZ840ksyVV15ZqN2ePXuMZVkmJCTEpKenm+7duxtJZsiQIYXazpgxw7ldy7JMWFiYCQoKKvAZPv7444X6RUdHOz9rLy+vAn+/0dHR5pVXXnG2HTJkiJFkBg8ebPr16+fsExERYby8vJx/R6d+hvHx8QX2t2rVKuf/ibfffrtQPc8++6yRZAIDA8327dvL9sHCbQhFVIjZs2cX+AHrqn379jl/wLds2dL8+OOPznXff/+9adasmZFkIiMjzYEDBwr0PfUHVEREhOnWrZvZsGGDMcaY7Oxs880335hatWoZSebyyy8vcv/5P4xjY2OLXF+eUExPTzchISFGkhk0aJDZtWuXc92xY8fMxo0bzZgxY8yXX35Zqu2dDZ/XmZwaivnv37Is89///rdAuwkTJhhJ5p577jHGmBJDcdGiReaJJ54wP/74o0lPT3cuP3jwoJk4caLzF5t///vfhfrmB2pMTEyJdeeHYnBwsPHx8TGvvvqqSU1NNcYYk5aWZg4ePGiMKTkUjTHmueeeM5JMQECA+fXXX53LV65c6QzMd999t8RaULkIRVSIcePGOX84JCQkuLyd+++/3/lD+tChQ4XW79+/3/nb/qhRowqsO/UHVPPmzc3x48cL9V+8eLGzzf79+wutd2corl+/3nkkl52dXWz/0m7PGM9/Xmdy+tHvPffcYySZ8ePHO9vk5eWZBg0aGEnOI/KSQvFMXnnlFSPJXH311YXWlTUUJZkpU6YU2+5MoZiTk2O6devm/KXl+PHj5q+//jJ16tQxkkzfvn3L+vbgZlxTRIU4cuSI83VkZKRL2zDGaN68eZKk+++/XxdccEGhNnXr1tX9998vSZozZ06x23r88ccVGBhYaPl1113nvP0jf6RpZQkPD5ck50jc8joXP6/hw4dLkmbOnCljjCRp5cqV2rNnj5o1a6ZLL7203Pu44YYbJElr165Vbm5uubYVERGh++67z+X+3t7emjVrliIiIvTbb7/pkUce0fDhw5WQkKB69erpww8/LFd9qHiEIs4a8fHxSk5OliT17Nmz2HbXXHONpJNBHB8fX2Sbzp07F7ncx8dHNWrUkCTnvipL48aN1bx5c2VnZ6tz58566aWXtHnzZpd/cJ+Ln1fXrl3VvHlz7d27VytWrJBU+gE2p0pKSlJsbKy6du2qqKgo58xDlmWpZcuWkk4OyDl69Gi56u3YsWO576GtX7++PvjgA0nSBx98oMWLF8vb21uffPKJIiIiyrVtVDxCERUiKirK+drVH55//vmn83VJ93ydOqr11D6nCgkJKba/j8/JOSuys7PLWmK5eHt7a86cOWrYsKH27t2rp59+Wm3btlVoaKiuueYavfPOO2W6Z/Nc/bzyw2/GjBlyOBxauHChvL29NXjw4FL1X7t2rZo3b65JkyZp3bp1Sk5OVmBgoGrWrFlo9qH09PRy1VqzZs1y9c/Xr18/9evXz/n9E088oSuuuKJCto2KRSiiQrRq1cr5etOmTR6s5OzWunVr7dixQ5999pnuvfdeXXTRRcrIyNDy5cv1wAMPqHnz5pV+Wrey3X333fL29tbnn3+ud999VxkZGerdu7dq1ap1xr45OTm66667lJKSojZt2mjp0qVyOBxKS0tTUlKSEhMTtW7dOmf7/FO0rvL29i5X/3x79uzR8uXLnd+vXr263Kd24R6EIirElVdeKS+vk/+cPv/8c5e2cepv5affq3eqU9dV1G/ypZV/1FTSPWWpqaklbsPPz099+/bVe++9p61bt+rw4cN69913FRkZqf3792vIkCGlquVc+LyKUqtWLfXu3VsZGRl67rnnJJX+1OnatWu1d+9eeXt764svvtB1111X6Cg3MTGxwmsuj/wgT01NVdOmTeXv768ff/xRkydP9nRpKAKhiAoRHR3tPD00a9asAvOenkn+b/MNGzZ0DtLJv95UlPzfuKOiotSwYUNXS3ZJ/jWg/fv3F9tm/fr1ZdpmVFSU7rvvPr300kuSTh5pl2YgzrnweRUnf8BNVlaWqlevrj59+pSqX/7nXqNGjWJPGZ96RHa6/F/cynsEWRaxsbFat26dgoKCtGjRIuff8/PPP68ff/yx0upA6RCKqDDPP/+8goODlZGRob59+yohIaHE9kePHlW/fv2cR1aWZal///6STk7MXdRv/AcPHtR7770nSbrrrrsq+B2cWevWrZ11FBV+f/75p3NQxekyMzNL3Papoz/zf3iX5Fz4vIpz0003acyYMXr88cf1xhtvlHoy7fzZj5KSkoqcqefAgQOaMmVKsf1DQ0MlSSkpKWUv2gUrV67Uiy++KEl6/fXX1aJFCz3yyCO64YYblJubq4EDB5Z7MBAqFqGICtO0aVP961//kp+fn7Zv3642bdropZde0q5du5xtcnNztWnTJo0fP16NGjXSwoULC2zjmWeeUXh4uJKTk9WzZ0+tWbPGuW716tXq2bOnUlJSFBkZqaeffrrS3lu+Sy+91DlZ9ZAhQ7Rx40YZY5SXl6dVq1apR48eysvLK7LvnDlz1K1bN7333nv673//61yem5urZcuWOd9P165dSz0q8Wz/vIrj6+url19+Wa+++qoGDhxY6n6XXXaZqlWrJmOM7rjjDucZifzPsEePHiVOh3fRRRdJkhwOh/N2Fnc5cuSI7r77buXl5alv37669957netmzJihWrVqad++ffrb3/7m1jpQRp67RRLnqx9//NE0adKkwLRbfn5+JjIy0jmLh+wpuu666y6TlZVVoP+qVatMWFhYsdOWhYeHm++//77Qfs90I3W+mJiYIqdTM+bMN+8bY8zXX3/tnDVF9rRoAQEBRpK58MILC8zuc6pTpyeTPcVbVFRUgc+kdu3aJi4urkC/0kzz5qnP60zyt1/WviXdvP/OO+8U+ByDg4Odn3/16tULTDhQ1Pu6+uqrnetDQkJMTEyMiYmJMa+//rqzTf7N+2eaPKCkz7BPnz5GkqlXr55JTk4u1Pebb75xTvn3/vvvl+JTQWXgSBEVrlu3btqxY4dmz56tgQMHqkmTJgoICFBaWpoiIyN12WWX6dlnn1VcXJxmzZpV6NRZ9+7dFRcXp8cff1wtWrRQXl6ejDFq0aKFnnjiCcXFxenyyy/30LuTevXqpR9++EE33nijIiIilJubq3r16unpp5/Wzz//XORN9JLUp08fffzxxxo2bJhat26tsLAwpaamKiQkRJ06ddLkyZO1fft2NW/evEz1nO2fV0W7//779eWXX6pHjx4KDg5WTk6O6tSpo4ceekhbtmzRxRdfXGL/BQsW6LHHHlPTpk2VnZ2tvXv3au/evRV6SnXq1KlavHixvLy8ir0fsWfPnhozZowk6dFHH1VcXFyF7R+us4ypxCvOAACcxThSBADARigCAGAjFAEAsBGKAADYCEUAAGyEIgAANkIRAAAboQgAgI1QhNtNnTpVDRo0UEBAgDp37qyffvrJ0yUBleL777/XTTfdpNq1a8uyLC1atMjTJeEMCEW41dy5czV69GjFxsbql19+UevWrdWrV69inwAPnE/S09PVunVrTZ061dOloJSY5g1u1blzZ3Xs2FFvv/22JCkvL0/16tXTQw89dFY9tQFwN8uy9Pnnn+uWW27xdCkoAUeKcJusrCz9/PPP6tmzp3OZl5eXevbsqbVr13qwMgAoGqEIt/nrr7+Um5ur6OjoAsujo6OLfCAuAHgaoQgAgI1QhNtUr15d3t7eSkpKKrA8KSmp2GcOAoAnEYpwGz8/P7Vv314rVqxwLsvLy9OKFSvUtWtXD1YGAEXz8XQBOL+NHj1aQ4YMUYcOHdSpUye98cYbSk9P17BhwzxdGuB2x44d065du5zfx8fHa/PmzYqMjFT9+vU9WBmKwy0ZcLu3335br7zyihITE9WmTRtNmTJFnTt39nRZgNutWrVKV155ZaHlQ4YM0UcffVT5BeGMCEUAAGxcUwQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIt8vMzNSECROUmZnp6VIAj+D/wLmDm/fhdg6HQ2FhYUpNTVVoaKinywEqHf8Hzh0cKQIAYCMUAQCwVYmnZOTl5engwYMKCQmRZVmeLqfKcTgcBf4Eqhr+D3iWMUZpaWmqXbu2vLxKPhasEtcUDxw4oHr16nm6DACAB+3fv19169YtsU2VOFIMCQmRJM1c8I2Cgqp5uBqg8nVofaGnSwA8Ji0tTZc0b+TMgpJUiVDMP2UaFFRNQdWCPVwNUPkY8QioVJfPGGgDAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwObj6QJwdvoz6ZDWfL9cW35er/jdv+vo0SPy9fHVBbXrqn3ny3TzbQMVGVWj2P7Z2dn69/x/adWKr3QoYZ+8vX1Ur35D9bzuFvW+qZ8syyq2ryM1RZ/P+1jrV69S4qED8vLyVu269XXFlb10822D5Ovn5463DJRaVIh/qdsu/uobdbvsikLLN/y0Xu9OnaJ1a9co+chfCg+PULv2HXTP/Q/oyqt6VmS5KAPLGGM8XYS7ORwOhYWFaf7SNQqqFuzpcs56h/9M1LA7eunUfxpB1YJ14kSG8nJzJUnBIaF6ZtJrat2uU6H+x9OPaexj92jXzt8kSf4BAcrNzVVOdrYkqVPXKzTu+Tfk7VP4d7L/7tqp2CcfUPKRw5KkwMAg5Zk8ZZ44IUlq2Lip/vH6hwoNC6/Q93y+69KumadLOK+0aFy/xPVpaQ5lZGTIz89P23/fo8ioqALr33ztVU2eME7GGFmWpbDwcKU5HMq1/3899sRTGhc7yW31VzUOh0MN69RQamqqQkNDS2zL6VMUkh98HbteobETX9WcL37U/KVrtHDZT5r40lRF16qjY2kOPT/uUSUf+atQ/ymvTNSunb8pJDRMsS+8pc++Xq+Fy37SY2Mny8/PXz+t/V6fzPi/Qv0yjh/XpLEPKfnIYdWt30CvTP1YC75ep8++Xq+/v/a+qteIVvzu3/XK5Kfd/hkAJYnbva/Er8ZNLpQkXdv7+kKB+NWXSzQp9lkZYzRo8DDF7d6n3fsStXt/ksaOi5VlWXr91Zf02fy5nnhrVR6hiEKCQ0I15cN5mvDi27qsx7UKCTn5m5Wvr686dLlcE1/6P/n5+et4+jF9vWR+gb67f4/TDyuXSZIefXqSOl3aXZZlydvbWz1736yh9z0iSfr3/E+UcvRIgb7/WbpQh/9MlJe3t56d/IZaXtRGkmRZltq076Ixz70gSfplwxpt2rDWnR8B4LKtv27Rtq2/SpLuHDCo0PqX/jFZktSxUxe9OfVd1ahRU5IUEhKiJ556RncNHCxJmhQ7Tjk5OZVUNfIRiiikWnCIGjUp/nRbvZiGatbyEknSH/Yp0nyrViyVJNWt30Bdul1ZqG/vm25TteAQZWae0JrvVxRYt3H9j5Kkdh26qn6DRoX6XtS6g5o0aylJWrFsSRneEVB55sz6lySpRo2auqbXdQXWJSYe0tZft0iS7h/1UJH9H3jo5C+OB/bv0+ofv3djpSgKoQiXhIaFSZLy8vIKLP910wZJUtsOlxbZz98/QK0ubitJ2vLLTwXW/Zl4SJJUp36DYvdbt35DSdKmnzlSxNknJydHn807edqz3x395XPadfMD+/c7Xze5sGmR22jUuIm8vE7+aF717Yoi28B9CEWUWW5Ojn7bulmSFNOwiXO5MUYH9sXbyxsX279eg5Pr9u/dXWB5/ojUvNy8Qn3y5V/vTEk+IkdqSplrB9xp+X++1uHDf0qS7hxwd6H1p466zh9Uc7q8vDznILedcb8V2Qbuc06F4tSpU9WgQQMFBASoc+fO+umnn87cCRXui0VzdDT5L3l5ealn7z7O5cfTj+lERoYklXi7RlT1k+tOH6RTM7qWJGnfaWF5qn17/rcuf4QqcLaY/enJU6cXXXyJLr6kdaH1devVc77euSOuyG38vnOHMxQTkxLdUCVKcs6E4ty5czV69GjFxsbql19+UevWrdWrVy/9+eefni6tSonf/btmvj9FknTjrXeqfoP/HRGeOJHhfO3nH1DsNvztdRkZxwssb9vx5CnXX3/5qdC1SknauO4H7fnvH87vM44fL9QG8JSjycn6z9cnr6kXNcBGkqKjL1Criy6WJP3fW28UuvwgSVNef9X5+lhamhsqRUnOmVB87bXX9Le//U3Dhg1Ty5Yt9e677yooKEjTp0/3dGlVRvKRw5r87CPKzDyhJs1aath9j1Xo9nvdcKuiqteUMUbPP/uI1v7wrU5kHNfx4+latXyp/vmPZwtco7G8ip8AAKhsny2Yq6ysLPn4+Oi2/ncV2+6Jp56RdHKU6pCB/bUj7jdlZ2dr/769enrMY1q0cIF8fX0lyXltEZXnnJjRJisrSz///LPGjh3rXObl5aWePXtq7drCAy4yMzOVmZnp/N7hcFRKneezNEeqxj1+n5IOJah23RhNeHGq/PwLzuoREBDofJ2VeaLYbWXa6wIDgwosD6oWrOf+/qZin3pAfx1O0vPjHi2wPjQsXAOHPaCZH5w8Ug0ODinPWwIq1JxZn0iSel7Ty3mbRVH63NJXTz3znF76x2Qt/WKxln6xuMD6q6+5Vv7+AVr6xWKFMUlFpTsnfg3566+/lJubq+jo6ALLo6OjlZhY+Jz7Cy+8oLCwMOdXvVPO46Ps0o+l6bkn7tfe+F2qEV1Lf3/tfUVERhVqF1QtWAGBJ4OxpOt9R/46uS4yqnqhdRc2b6V3Zi7SXUPuU7OWF6tGdC01aHSh+vQboLemzVeEfa3Sx8dH0RfUqYi3B5Tbzh1x2vTzRklS/4GFB9ic7smx4/T18u/U/65Bata8herWq69Lu12uf775tuYs+LdSU1IkSY2aNCl5Q6hw58SRYlmNHTtWo0ePdn7vcDgIRhedyDiu2KdG6Y+d2xURWV1/f+1954CY01mWpXr1G+mPndu1N774wTL77cEy9WKKHqEaFh6hQcNHadDwUYXW7f795OCERhc2Zw5UnDXyB9hERESq93U3lKpPx85d1LFzl0LLc3NztX371pNtOnWuuCJRKudEKFavXl3e3t5KSkoqsDwpKUkXXHBBofb+/v7y9y/9hL0oWmbmCU0c+5Ditm1WaFi4/v7a+6pTN6bEPpe07ag/dm7Xpo1F30eYlZmp7Vs3SZLatC/bf/js7Gyt+X65JKlHz+vL1Bdwl9zcXM2fO1uS1Pf2O+RXzl/WVnyzTClHj8rPz099bu5bESWiDM6J06d+fn5q3769Vqz4342seXl5WrFihbp27erBys5f2dnZ+vu4x/Trpg2qFhyiya++W+CexOJ0v/rkDB4H9sXrpzXfFVr/9RefKf1Ymvz9A9T18qvKVNOsGf+nI3/9qYjI6urZ++Yy9QXc5buVK5R46KCkou9NLAtHaqpix50cOzFw8FBVr1H8rU1wj3MiFCVp9OjR+uCDDzRz5kzFxcVp5MiRSk9P17Bhwzxd2nknNzdXr0x+Sj//tFqBQdU06eX/U5OmLUvVt3HTFrr8yl6SpNdffE4b1v3g3OaKrxfro/fekCTdfPsghUcUvi45f9Z0rf5+udIcqc5lB/bF642XYjXv02ny8vbWw2NiVY1BNjhL5A+wada8hdq173DG9n/+maQJzz2jzZt+0Qn76S/Z2dn6ZtlXuu6aHvp95w41atxY4yf+3a11o2jnxOlTSerfv78OHz6s8ePHKzExUW3atNHXX39daPANyi9u2yat/u7kacrcnBxNPm0U6Klq1LhAb7w/u8Cyh8fE6tDB/dq18zdNeGqU/AMClJeXp+ysLEknHx01aNgDRW7v5/U/6qP3Tg5YCAgMlDHG+diowMAgPTQmVp0u7V7etwhUCIfD4Rw9Wty9iac7kZGht974p95645/Ox0YdS0tzTv590cWXaPaCRWd8xBHc45wJRUl68MEH9eCDD3q6jPNeXt7/nqOYlZWprOTMYtv6+RW+dhtULVivTv2XFs3/l76zHzLs6+unxk2an/Ehwzf1G6CIyOr6Y+f2k7PmWF6KadhY7Ttfpj79BqpGzcLXkAFP+ffCBcrIyJCXl5duv3NAqfpEVa+hp58drx++W6Vdu/5wPmC4RatWurXv7Ro4eGihOVNReXjIMFAF8JBhVGU8ZBgAABcQigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAG6EIAICNUAQAwEYoAgBgIxQBALARigAA2AhFAABshCIAADZCEQAAm1tD8ejRo0pNTXXnLgAAqDAuh+LBgwf18ccf6+uvvy60bvv27erQoYOqV6+uyMhIXX755fr999/LVSgAAO7mcihOnz5dw4YN06pVqwosz8jI0PXXX69NmzbJGCNjjFavXq2ePXvK4XCUt14AANzG5VBcvny5JKl///4F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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#CREATE CONFUSION MATRIX\n",
    "# Calculate the confusion matrix\n",
    "from sklearn.metrics import confusion_matrix\n",
    "conf_matrix = confusion_matrix(y_true=data.Actual_Output, y_pred=data.predicted_Output)\n",
    "#\n",
    "# Print the confusion matrix using Matplotlib\n",
    "#\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "ax.matshow(conf_matrix, cmap=plt.cm.Blues, alpha=0.3)\n",
    "for i in range(conf_matrix.shape[0]):\n",
    "    for j in range(conf_matrix.shape[1]):\n",
    "        ax.text(x=j, y=i,s=conf_matrix[i, j], va='center', ha='center', size='xx-large')\n",
    " \n",
    "plt.xlabel('Predictions', fontsize=18)\n",
    "plt.ylabel('Actuals', fontsize=18)\n",
    "plt.title('Confusion Matrix', fontsize=18)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "TP=0\n",
    "FN=0\n",
    "TN=0\n",
    "FP=0\n",
    "for i in range(len(data)):\n",
    "    if((data.Actual_Output[i]==1) and (data.predicted_Output[i]==1)):\n",
    "        TP=TP+1\n",
    "    if((data.Actual_Output[i]==0) and (data.predicted_Output[i]==0)):\n",
    "        TN=TN+1\n",
    "    if((data.Actual_Output[i]==1) and (data.predicted_Output[i]==0)):\n",
    "        FN=FN+1\n",
    "    if((data.Actual_Output[i]==0) and (data.predicted_Output[i]==1)):\n",
    "        FP=FP+1\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "39\n",
      "40\n"
     ]
    }
   ],
   "source": [
    "FP_women_count=0\n",
    "FP_men_count=0\n",
    "for i in range(len(data)):\n",
    "    if((data.Actual_Output.iloc[i]==0) and (data.predicted_Output.iloc[i]==1)):\n",
    "        if(data.Gender.iloc[i] ==1):\n",
    "            FP_men_count=FP_men_count+1\n",
    "    if((data.Actual_Output.iloc[i]==0) and (data.predicted_Output.iloc[i]==1)):\n",
    "        if(data.Gender.iloc[i] ==0):\n",
    "            FP_women_count=FP_women_count+1\n",
    "print(FP_men_count)\n",
    "print(FP_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "34\n",
      "45\n"
     ]
    }
   ],
   "source": [
    "FN_women_count=0\n",
    "FN_men_count=0\n",
    "for i in range(len(data)):\n",
    "    if((data.Actual_Output.iloc[i]==1) and (data.predicted_Output.iloc[i]==0)):\n",
    "        if(data.Gender.iloc[i] ==1):\n",
    "            FN_men_count=FN_men_count+1\n",
    "    if((data.Actual_Output.iloc[i]==1) and (data.predicted_Output.iloc[i]==0)):\n",
    "        if(data.Gender.iloc[i] ==0):\n",
    "            FN_women_count=FN_women_count+1\n",
    "print(FN_men_count)\n",
    "print(FN_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "123\n",
      "119\n"
     ]
    }
   ],
   "source": [
    "TP_women_count=0\n",
    "TP_men_count=0\n",
    "for i in range(len(data)):\n",
    "    if(((data.Actual_Output.iloc[i]==1) and (data.predicted_Output.iloc[i]==1)) or((data.Actual_Output.iloc[i]==0) and (data.predicted_Output.iloc[i]==0))):\n",
    "        if(data.Gender.iloc[i] ==1):\n",
    "            TP_men_count=TP_men_count+1\n",
    "    if(((data.Actual_Output.iloc[i]==1) and (data.predicted_Output.iloc[i]==1)) or((data.Actual_Output.iloc[i]==0) and (data.predicted_Output.iloc[i]==0))):\n",
    "        if(data.Gender.iloc[i] ==0):\n",
    "            TP_women_count=TP_women_count+1\n",
    "print(TP_men_count)\n",
    "print(TP_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from matplotlib_venn import venn2\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = data.predicted_Output\n",
    "list2 = data.Actual_Output\n",
    "\n",
    "        \n",
    "# Create sets from the binary data lists\n",
    "set1 = set([i for i, x in enumerate(list1)if x==1] )\n",
    "set2 = set([i for i, x in enumerate(list2)if x==1])\n",
    "\n",
    "set1_zeros = set([i for i, x in enumerate(list1) if x == 0])\n",
    "set2_zeros = set([i for i, x in enumerate(list2) if x == 0])\n",
    "# Create a Venn diagram to visualize the overlap between the two sets\n",
    "fig, ax = plt.subplots(figsize=(5,4))\n",
    "venn = venn2([set1,set2],ax=ax )\n",
    "venn.get_patch_by_id('10').set_color('darkblue')\n",
    "venn.get_patch_by_id('01').set_color('darkblue')\n",
    "venn.get_patch_by_id('11').set_color('green')\n",
    "# Add labels to the diagram\n",
    "venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(FP))\n",
    "venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(FN))\n",
    "venn.get_label_by_id('11').set_text('A & P\\n' + str(TP+TN))\n",
    "\n",
    "\n",
    "# Show the Venn diagram\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from matplotlib_venn import venn2, venn2_circles\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = data.predicted_Output\n",
    "list2 = data.Actual_Output\n",
    "#Age = dataf1.Age  # Assuming 'Age' is the column containing age information\n",
    "\n",
    "# Create sets from the binary data lists\n",
    "set1 = set([i for i, x in enumerate(list1) if x == 1])\n",
    "set2 = set([i for i, x in enumerate(list2) if x == 1])\n",
    "set1_zeros = set([i for i, x in enumerate(list1) if x == 0])\n",
    "set2_zeros = set([i for i, x in enumerate(list2) if x == 0])\n",
    "\n",
    "# Calculate the number of males and females in FP and FN zones\n",
    "\n",
    "\n",
    "# Create a Venn diagram to visualize the overlap between the two sets\n",
    "fig, ax = plt.subplots(figsize=(6, 6))\n",
    "\n",
    "# Outer Venn diagram\n",
    "venn = venn2([set1, set2], ax=ax)\n",
    "for patch in venn.patches:\n",
    "    patch.set_edgecolor('black')\n",
    "    patch.set_linewidth(2) \n",
    "venn.get_patch_by_id('10').set_facecolor('white')\n",
    "venn.get_patch_by_id('01').set_facecolor('white')\n",
    "venn.get_patch_by_id('11').set_facecolor('grey')\n",
    "\n",
    "# Add labels to the outer diagram\n",
    "venn.get_label_by_id('10').set_text('FP\\n' + str(FP))\n",
    "venn.get_label_by_id('01').set_text('FN\\n' + str(FN))\n",
    "venn.get_label_by_id('11').set_text('TP+TN\\n' + str(TP + TN))\n",
    "fp_center_x, fp_center_y = venn.set_labels[0].get_position()\n",
    "ax.add_patch(plt.Circle((fp_center_x - 0.2, fp_center_y + 0.7), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fp_center_x - 0.3, fp_center_y + 0.8, 'Female: ' + str(FP_women_count), fontsize=12, color='black')\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.5, fn_center_y + 0.2), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.58, fn_center_y + 0.08, 'Male: ' + str(FP_men_count), fontsize=12, color='black')\n",
    "\n",
    "# Draw circles for old and young in FN zone\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.6, 'Female: ' + str(FN_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.3, 'Male: ' + str(FN_men_count), fontsize=12, color='black')\n",
    "\n",
    "# Draw circles for old and young in Correct Prediction zone\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.2, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.27, fn_center_y + 0.6, 'Female: ' + str(TP_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.2, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.27, fn_center_y + 0.3, 'Male: ' + str(TP_men_count), fontsize=12, color='black')\n",
    "\n",
    "#plt.title(\"Venn diagram with subsets of OLD and YOUNG in FP and FN zones\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         214031 function calls (208032 primitive calls) in 0.427 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.427    0.427 887624253.py:5(my_method)\n",
      "      184    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(all)\n",
      "      710    0.001    0.000    0.009    0.000 <__array_function__ internals>:177(amax)\n",
      "      714    0.001    0.000    0.010    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(any)\n",
      "      840    0.001    0.000    0.010    0.000 <__array_function__ internals>:177(around)\n",
      "       22    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(broadcast_arrays)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(can_cast)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(clip)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(column_stack)\n",
      "       44    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(cumsum)\n",
      "       16    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(diff)\n",
      "      232    0.001    0.000    0.002    0.000 <__array_function__ internals>:177(dot)\n",
      "        5    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(empty_like)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(in1d)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(inv)\n",
      "       84    0.000    0.000    0.012    0.000 <__array_function__ internals>:177(isclose)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(isin)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(min_scalar_type)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(nan_to_num)\n",
      "       12    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "      168    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(nonzero)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ones_like)\n",
      "      168    0.000    0.000    0.004    0.000 <__array_function__ internals>:177(ptp)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ravel_multi_index)\n",
      "      234    0.001    0.000    0.005    0.000 <__array_function__ internals>:177(reshape)\n",
      "       84    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(result_type)\n",
      "      840    0.001    0.000    0.014    0.000 <__array_function__ internals>:177(round_)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(union1d)\n",
      "       15    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(unique)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unravel_index)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(zeros_like)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:778(__contains__)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:794(values)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:812(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 <frozen _collections_abc>:815(__len__)\n",
      "       40    0.000    0.000    0.000    0.000 <frozen _collections_abc>:878(__iter__)\n",
      "      392    0.000    0.000    0.001    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       82    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen genericpath>:121(_splitext)\n",
      "       23    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "       39    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:405(parent)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen ntpath>:231(splitext)\n",
      "       82    0.000    0.000    0.000    0.000 <string>:1(<lambda>)\n",
      "        1    0.000    0.000    0.427    0.427 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.013    0.013 Image.py:2346(save)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:2875(_check_size)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2896(new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2973(frombuffer)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:321(preinit)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:417(_getencoder)\n",
      "        3    0.000    0.000    0.000    0.000 Image.py:512(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 Image.py:539(size)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:543(_new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:603(_copy)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:609(_ensure_mutable)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:835(load)\n",
      "        1    0.000    0.000    0.012    0.012 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.012    0.012 ImageFile.py:527(_encode_tile)\n",
      "        1    0.000    0.000    0.000    0.000 ImageFile.py:75(_tilesort)\n",
      "        5    0.000    0.000    0.000    0.000 PngImagePlugin.py:1078(putchunk)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1092(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1096(write)\n",
      "        1    0.000    0.000    0.012    0.012 PngImagePlugin.py:1242(_save)\n",
      "       10    0.000    0.000    0.000    0.000 PngImagePlugin.py:154(_crc32)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:282(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:285(add)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:328(add_text)\n",
      "     1263    0.002    0.000    0.002    0.000 __init__.py:101(check_in_list)\n",
      "       13    0.000    0.000    0.000    0.000 __init__.py:106(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:109(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:112(__eq__)\n",
      "       27    0.000    0.000    0.000    0.000 __init__.py:115(__hash__)\n",
      "       16    0.000    0.000    0.000    0.000 __init__.py:119(_weak_or_strong_ref)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1286(is_interactive)\n",
      "      212    0.001    0.000    0.001    0.000 __init__.py:1314(is_math_text)\n",
      "      172    0.000    0.000    0.001    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       66    0.001    0.000    0.001    0.000 __init__.py:134(check_shape)\n",
      "        1    0.000    0.000    0.002    0.002 __init__.py:1456(inner)\n",
      "      198    0.000    0.000    0.000    0.000 __init__.py:154(<genexpr>)\n",
      "       22    0.000    0.000    0.000    0.000 __init__.py:1623(<lambda>)\n",
      "      344    0.001    0.000    0.002    0.000 __init__.py:163(match)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:1675(_safe_first_finite)\n",
      "        6    0.000    0.000    0.000    0.000 __init__.py:1685(safe_isfinite)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:1715(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1718(sanitize_sequence)\n",
      "      278    0.003    0.000    0.004    0.000 __init__.py:1726(normalize_kwargs)\n",
      "       19    0.000    0.000    0.000    0.000 __init__.py:175(check_getitem)\n",
      "      278    0.002    0.000    0.002    0.000 __init__.py:1765(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:183(dumps)\n",
      "      158    0.000    0.000    0.000    0.000 __init__.py:1834(_str_equal)\n",
      "       25    0.000    0.000    0.000    0.000 __init__.py:1845(_str_lower_equal)\n",
      "      102    0.000    0.000    0.000    0.000 __init__.py:190(__init__)\n",
      "      998    0.004    0.000    0.006    0.000 __init__.py:1994(_setattr_cm)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2039(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2051(add)\n",
      "       16    0.000    0.000    0.000    0.000 __init__.py:221(connect)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:2290(_unpack_to_numpy)\n",
      "       11    0.000    0.000    0.000    0.000 __init__.py:235(_connect_picklable)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:265(disconnect)\n",
      "      344    0.001    0.000    0.001    0.000 __init__.py:272(_compile)\n",
      "  582/580    0.002    0.000    0.003    0.000 __init__.py:291(process)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:313(blocked)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:318(wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:53(__get__)\n",
      "       14    0.000    0.000    0.001    0.000 __init__.py:550(_get_data_path)\n",
      "      211    0.001    0.000    0.001    0.000 __init__.py:65(check_isinstance)\n",
      "     2756    0.002    0.000    0.004    0.000 __init__.py:691(_get)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:708(safe_masked_invalid)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:73(get_projection_class)\n",
      "     2756    0.004    0.000    0.007    0.000 __init__.py:742(__getitem__)\n",
      "      148    0.000    0.000    0.000    0.000 __init__.py:80(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:825(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:826(<dictcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 __init__.py:828(__contains__)\n",
      "     1510    0.002    0.000    0.003    0.000 __init__.py:831(clean)\n",
      "     1510    0.001    0.000    0.001    0.000 __init__.py:834(<listcomp>)\n",
      "     1508    0.004    0.000    0.009    0.000 __init__.py:880(get_siblings)\n",
      "     1508    0.001    0.000    0.001    0.000 __init__.py:884(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:98(get_projection_class)\n",
      "        4    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "       15    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:83(unique_values)\n",
      "       15    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "        1    0.000    0.000    0.001    0.001 _axes.py:104(set_title)\n",
      "        1    0.000    0.000    0.002    0.002 _axes.py:5459(imshow)\n",
      "        4    0.000    0.000    0.002    0.001 _axes.py:626(text)\n",
      "        1    0.000    0.000    0.005    0.005 _axes.py:7937(matshow)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1025(get_yaxis_text1_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:105(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1051(get_yaxis_text2_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1077(_update_transScale)\n",
      "      6/5    0.000    0.000    0.001    0.000 _base.py:1082(get_position)\n",
      "        6    0.000    0.000    0.001    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1179(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1189(_gen_axes_patch)\n",
      "        6    0.000    0.000    0.000    0.000 _base.py:119(get_shape)\n",
      "        1    0.000    0.000    0.002    0.002 _base.py:1206(_gen_axes_spines)\n",
      "        1    0.000    0.000    0.002    0.002 _base.py:1221(<dictcomp>)\n",
      "        1    0.000    0.000    0.029    0.029 _base.py:1262(__clear)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1287(_process_toarray_args)\n",
      "       18    0.000    0.000    0.000    0.000 _base.py:1301(isspmatrix)\n",
      "        1    0.000    0.000    0.030    0.030 _base.py:1388(clear)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1522(_set_title_offset_trans)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1608(get_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1616(set_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1702(set_adjustable)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1766(set_box_aspect)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1803(get_anchor)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:1862(get_data_ratio)\n",
      "        5    0.000    0.000    0.002    0.000 _base.py:1876(apply_aspect)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:222(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2278(add_image)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2312(_add_text)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:235(set_prop_cycle)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:2446(_unit_change_handler)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2485(update_datalim)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2510(_process_unit_info)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2569(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:291(nnz)\n",
      "        4    0.001    0.000    0.175    0.044 _base.py:2939(_update_title_position)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:2994(<genexpr>)\n",
      "        2    0.000    0.000    0.184    0.092 _base.py:3001(draw)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3123(set_axisbelow)\n",
      "        2    0.000    0.000    0.012    0.006 _base.py:3157(grid)\n",
      "        2    0.000    0.000    0.002    0.001 _base.py:3316(tick_params)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3405(set_axis_on)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3423(set_xlabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3488(get_xbound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3536(get_xlim)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3575(set_xlim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3672(set_ylabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3737(get_ybound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3785(get_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3807(set_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3971(set_navigate)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3987(set_navigate_mode)\n",
      "        7    0.000    0.000    0.000    0.000 _base.py:4273(get_children)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4299(get_default_bbox_extra_artists)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:4328(<listcomp>)\n",
      "        2    0.000    0.000    0.143    0.072 _base.py:4331(get_tightbbox)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:4416(<listcomp>)\n",
      "       49    0.000    0.000    0.000    0.000 _base.py:564(_axis_map)\n",
      "       49    0.000    0.000    0.000    0.000 _base.py:567(<dictcomp>)\n",
      "        1    0.000    0.000    0.046    0.046 _base.py:574(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:652(<dictcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:73(wrapper)\n",
      "        1    0.000    0.000    0.001    0.001 _base.py:790(set_subplotspec)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:799(get_window_extent)\n",
      "        1    0.000    0.000    0.011    0.011 _base.py:818(_init_axis)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:827(set_figure)\n",
      "      732    0.002    0.000    0.018    0.000 _base.py:841(_unstale_viewLim)\n",
      "      732    0.004    0.000    0.015    0.000 _base.py:844(<dictcomp>)\n",
      "     2928    0.001    0.000    0.001    0.000 _base.py:845(<genexpr>)\n",
      "      730    0.001    0.000    0.019    0.000 _base.py:855(viewLim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:881(_set_lim_and_transforms)\n",
      "    47/25    0.000    0.000    0.000    0.000 _base.py:917(get_xaxis_transform)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:945(get_xaxis_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:971(get_xaxis_text2_transform)\n",
      "    47/25    0.000    0.000    0.000    0.000 _base.py:997(get_yaxis_transform)\n",
      "       14    0.000    0.000    0.000    0.000 _binary.py:101(o32be)\n",
      "        1    0.000    0.000    0.003    0.003 _classification.py:232(confusion_matrix)\n",
      "        1    0.000    0.000    0.002    0.002 _classification.py:59(_check_targets)\n",
      "       15    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "       15    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:127(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _coo.py:240(getnnz)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:266(_check)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:320(toarray)\n",
      "        1    0.000    0.000    0.000    0.000 _data.py:20(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _data.py:23(_get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:103(_clip_dep_is_byte_swapped)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:108(_clip_dep_invoke_with_casting)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:127(_clip)\n",
      "      168    0.001    0.000    0.002    0.000 _methods.py:281(_ptp)\n",
      "     1374    0.001    0.000    0.006    0.000 _methods.py:39(_amax)\n",
      "      536    0.001    0.000    0.005    0.000 _methods.py:43(_amin)\n",
      "      168    0.000    0.000    0.002    0.000 _methods.py:47(_sum)\n",
      "       89    0.000    0.000    0.001    0.000 _methods.py:55(_any)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:93(_clip_dep_is_scalar_nan)\n",
      "        3    0.000    0.000    0.000    0.000 _pylab_helpers.py:100(get_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:147(get_index_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.001    0.001 _tight_bbox.py:8(adjust_bbox)\n",
      "      174    0.001    0.000    0.001    0.000 _ufunc_config.py:132(geterr)\n",
      "      174    0.001    0.000    0.002    0.000 _ufunc_config.py:33(seterr)\n",
      "       87    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       87    0.000    0.000    0.001    0.000 _ufunc_config.py:430(__enter__)\n",
      "       87    0.000    0.000    0.001    0.000 _ufunc_config.py:435(__exit__)\n",
      "      168    0.000    0.000    0.001    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 _util.py:5(is_path)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       15    0.000    0.000    0.001    0.000 arraysetops.py:138(unique)\n",
      "       15    0.000    0.000    0.001    0.000 arraysetops.py:323(_unique1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:373(intersect1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:519(_in1d_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:524(in1d)\n",
      "        9    0.000    0.000    0.000    0.000 arraysetops.py:630(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:761(_isin_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:766(isin)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:898(union1d)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:1007(set_alpha)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1025(_set_alpha_for_array)\n",
      "     1294    0.002    0.000    0.007    0.000 artist.py:103(_stale_axes_callback)\n",
      "      114    0.000    0.000    0.001    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       26    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "       82    0.000    0.000    0.000    0.000 artist.py:1132(sticky_edges)\n",
      "       20    0.000    0.000    0.000    0.000 artist.py:1159(update_from)\n",
      "      312    0.003    0.000    0.016    0.000 artist.py:1180(_update_props)\n",
      "       34    0.000    0.000    0.003    0.000 artist.py:1205(update)\n",
      "      278    0.000    0.000    0.014    0.000 artist.py:1216(_internal_update)\n",
      "      244    0.000    0.000    0.016    0.000 artist.py:1227(set)\n",
      "       50    0.000    0.000    0.005    0.000 artist.py:1233(_cm_set)\n",
      "       25    0.000    0.000    0.000    0.000 artist.py:1238(<dictcomp>)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:1375(get_mouseover)\n",
      "        4    0.000    0.000    0.036    0.009 artist.py:1408(_get_tightbbox_for_layout_only)\n",
      "      244    0.000    0.000    0.016    0.000 artist.py:147(<lambda>)\n",
      "       82    0.001    0.000    0.002    0.000 artist.py:180(__init__)\n",
      "      278    0.000    0.000    0.002    0.000 artist.py:271(convert_xunits)\n",
      "      276    0.000    0.000    0.001    0.000 artist.py:283(convert_yunits)\n",
      "     4199    0.001    0.000    0.001    0.000 artist.py:295(axes)\n",
      "      107    0.000    0.000    0.000    0.000 artist.py:300(axes)\n",
      "7598/5140    0.008    0.000    0.014    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.036    0.001 artist.py:352(get_tightbbox)\n",
      "      571    0.001    0.000    0.004    0.000 artist.py:417(pchanged)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:430(is_transform_set)\n",
      "       99    0.000    0.000    0.001    0.000 artist.py:438(set_transform)\n",
      "      286    0.000    0.000    0.001    0.000 artist.py:451(get_transform)\n",
      "    100/2    0.001    0.000    0.186    0.093 artist.py:54(draw_wrapper)\n",
      "       14    0.000    0.000    0.000    0.000 artist.py:604(get_url)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:608(set_url)\n",
      "       64    0.000    0.000    0.000    0.000 artist.py:618(get_gid)\n",
      "       12    0.000    0.000    0.000    0.000 artist.py:632(get_snap)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:671(get_sketch_params)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:730(get_path_effects)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:733(get_figure)\n",
      "       81    0.000    0.000    0.001    0.000 artist.py:737(set_figure)\n",
      "        6    0.000    0.000    0.000    0.000 artist.py:761(set_clip_box)\n",
      "       19    0.000    0.000    0.004    0.000 artist.py:778(set_clip_path)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:840(get_alpha)\n",
      "      762    0.000    0.000    0.000    0.000 artist.py:847(get_visible)\n",
      "     7600    0.002    0.000    0.002    0.000 artist.py:851(get_animated)\n",
      "       32    0.000    0.000    0.000    0.000 artist.py:855(get_in_layout)\n",
      "       30    0.000    0.000    0.000    0.000 artist.py:866(_fully_clipped_to_axes)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:890(get_clip_on)\n",
      "       47    0.000    0.000    0.000    0.000 artist.py:894(get_clip_box)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\n",
      "       48    0.000    0.000    0.001    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.187    0.093 artist.py:93(draw_wrapper)\n",
      "      200    0.000    0.000    0.000    0.000 artist.py:939(get_rasterized)\n",
      "      200    0.000    0.000    0.000    0.000 artist.py:966(get_agg_filter)\n",
      "       11    0.000    0.000    0.000    0.000 axis.py:1012(_translate_tick_params)\n",
      "       11    0.000    0.000    0.000    0.000 axis.py:1060(<dictcomp>)\n",
      "        2    0.000    0.000    0.007    0.004 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:1157(_set_lim)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1175(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1232(_set_artist_props)\n",
      "       84    0.005    0.000    0.166    0.002 axis.py:1252(_update_ticks)\n",
      "       48    0.000    0.000    0.046    0.001 axis.py:1295(_get_ticklabel_bboxes)\n",
      "       48    0.000    0.000    0.015    0.000 axis.py:1299(<listcomp>)\n",
      "       48    0.000    0.000    0.031    0.001 axis.py:1301(<listcomp>)\n",
      "       20    0.001    0.000    0.201    0.010 axis.py:1304(get_tightbbox)\n",
      "       40    0.000    0.000    0.002    0.000 axis.py:1329(<genexpr>)\n",
      "       20    0.000    0.000    0.000    0.000 axis.py:1348(<listcomp>)\n",
      "        4    0.000    0.000    0.052    0.013 axis.py:1363(draw)\n",
      "       84    0.000    0.000    0.022    0.000 axis.py:1477(get_majorticklocs)\n",
      "       84    0.002    0.000    0.040    0.000 axis.py:1481(get_minorticklocs)\n",
      "       10    0.000    0.000    0.027    0.003 axis.py:1539(_get_tick)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:154(<dictcomp>)\n",
      "        4    0.000    0.000    0.005    0.001 axis.py:1560(_copy_tick_props)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1574(get_major_locator)\n",
      "       84    0.000    0.000    0.018    0.000 axis.py:1590(get_major_ticks)\n",
      "       84    0.000    0.000    0.000    0.000 axis.py:1603(get_minor_ticks)\n",
      "        4    0.000    0.000    0.012    0.003 axis.py:1616(grid)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1647(<dictcomp>)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:1658(update_units)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:1719(_have_units_and_converter)\n",
      "      118    0.000    0.000    0.001    0.000 axis.py:1725(convert_units)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:1742(set_units)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1775(set_label_text)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1796(set_major_formatter)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1822(set_minor_formatter)\n",
      "       28    0.000    0.000    0.001    0.000 axis.py:1836(_set_formatter)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:1862(set_major_locator)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1878(set_minor_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1894(set_pickradius)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:196(_set_labelrotation)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:208(_apply_tickdir)\n",
      "       24    0.000    0.000    0.067    0.003 axis.py:2083(_get_tick_boxes_siblings)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2091(<listcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2145(_get_ticks_position)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2161(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2167(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2173(<genexpr>)\n",
      "      672    0.001    0.000    0.022    0.000 axis.py:2208(getter)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2212(setter)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:223(get_tick_padding)\n",
      "        1    0.000    0.000    0.003    0.003 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.002    0.000 axis.py:2241(_init)\n",
      "       16    0.000    0.000    0.083    0.005 axis.py:2298(_update_label_position)\n",
      "       16    0.000    0.000    0.004    0.000 axis.py:2338(_update_offset_text_position)\n",
      "        6    0.000    0.000    0.002    0.000 axis.py:237(set_clip_path)\n",
      "        2    0.000    0.000    0.001    0.001 axis.py:2385(set_ticks_position)\n",
      "        1    0.000    0.000    0.001    0.001 axis.py:2425(tick_top)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2449(get_ticks_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2462(get_minpos)\n",
      "        1    0.000    0.000    0.003    0.003 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2500(_init)\n",
      "        8    0.000    0.000    0.042    0.005 axis.py:2559(_update_label_position)\n",
      "        8    0.000    0.000    0.001    0.000 axis.py:2598(_update_offset_text_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2721(get_minpos)\n",
      "      336    0.000    0.000    0.000    0.000 axis.py:289(get_loc)\n",
      "        8    0.000    0.000    0.013    0.002 axis.py:293(draw)\n",
      "      336    0.001    0.000    0.003    0.000 axis.py:305(set_label1)\n",
      "      336    0.000    0.000    0.003    0.000 axis.py:318(set_label2)\n",
      "       50    0.000    0.000    0.000    0.000 axis.py:342(_set_artist_props)\n",
      "       23    0.000    0.000    0.004    0.000 axis.py:351(_apply_params)\n",
      "      115    0.000    0.000    0.000    0.000 axis.py:359(<genexpr>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:376(<dictcomp>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:389(<dictcomp>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:394(<dictcomp>)\n",
      "        5    0.000    0.000    0.014    0.003 axis.py:416(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:438(_get_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:441(_get_text2_transform)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:444(_apply_tickdir)\n",
      "      221    0.001    0.000    0.008    0.000 axis.py:455(update_position)\n",
      "        5    0.000    0.000    0.013    0.003 axis.py:477(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:499(_get_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:502(_get_text2_transform)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:505(_apply_tickdir)\n",
      "      125    0.001    0.000    0.005    0.000 axis.py:516(update_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:543(__init__)\n",
      "      256    0.000    0.000    0.000    0.000 axis.py:549(locator)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:553(locator)\n",
      "      418    0.000    0.000    0.000    0.000 axis.py:560(formatter)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:564(formatter)\n",
      "       10    0.001    0.000    0.021    0.002 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.015    0.004 axis.py:583(__get__)\n",
      "        2    0.000    0.000    0.005    0.003 axis.py:643(__init__)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:701(isDefault_majfmt)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:709(isDefault_minloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:717(isDefault_minfmt)\n",
      "       84    0.000    0.000    0.000    0.000 axis.py:727(get_remove_overlapping_locs)\n",
      "      432    0.000    0.000    0.002    0.000 axis.py:758(get_transform)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_scale)\n",
      "       14    0.000    0.000    0.007    0.001 axis.py:765(_set_scale)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:821(limit_range_for_scale)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:824(_get_autoscale_on)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:828(_set_autoscale_on)\n",
      "       12    0.000    0.000    0.014    0.001 axis.py:855(clear)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:893(reset_ticks)\n",
      "       11    0.000    0.000    0.015    0.001 axis.py:913(set_tick_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:100(_update_methods)\n",
      "        6    0.000    0.000    0.001    0.000 backend_agg.py:109(draw_path)\n",
      "       11    0.000    0.000    0.005    0.000 backend_agg.py:200(draw_text)\n",
      "       22    0.000    0.000    0.008    0.000 backend_agg.py:221(get_text_width_height_descent)\n",
      "       22    0.000    0.000    0.000    0.000 backend_agg.py:259(get_canvas_width_height)\n",
      "       33    0.000    0.000    0.004    0.000 backend_agg.py:263(_prepare_font)\n",
      "       24    0.000    0.000    0.000    0.000 backend_agg.py:273(points_to_pixels)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:277(buffer_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:286(clear)\n",
      "        4    0.000    0.000    0.000    0.000 backend_agg.py:289(option_image_nocomposite)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:297(option_scale_image)\n",
      "        2    0.000    0.000    0.081    0.040 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.001    0.001 backend_agg.py:405(get_renderer)\n",
      "       33    0.000    0.000    0.000    0.000 backend_agg.py:43(get_hinting_flag)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:435(buffer_rgba)\n",
      "        2    0.000    0.000    0.093    0.047 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.093    0.047 backend_agg.py:462(print_png)\n",
      "        2    0.001    0.000    0.001    0.000 backend_agg.py:78(__init__)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1002(set_snap)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1017(get_hatch)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1021(get_hatch_path)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1028(get_hatch_color)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1036(get_hatch_linewidth)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1040(get_sketch_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1252(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1257(_process)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1284(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 backend_bases.py:1571(_get_renderer)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1581(Done)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1584(_draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1642(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1671(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 backend_bases.py:1693(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:172(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1727(new_manager)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1748(is_saving)\n",
      "       31    0.000    0.000    0.000    0.000 backend_bases.py:179(open_group)\n",
      "       31    0.000    0.000    0.000    0.000 backend_bases.py:186(close_group)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2053(draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2174(_switch_canvas_and_return_print_method)\n",
      "        2    0.000    0.000    0.093    0.047 backend_bases.py:2228(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2229(<dictcomp>)\n",
      "        1    0.000    0.000    0.362    0.362 backend_bases.py:2237(print_figure)\n",
      "        3    0.000    0.000    0.000    0.000 backend_bases.py:2411(mpl_connect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2474(mpl_disconnect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2809(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2840(notify_axes_change)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2846(create_with_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2921(destroy)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2937(set_window_title)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3572(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3577(draw_if_interactive)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:447(get_image_magnification)\n",
      "       22    0.000    0.000    0.000    0.000 backend_bases.py:661(flipy)\n",
      "       48    0.000    0.000    0.002    0.000 backend_bases.py:679(new_gc)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:735(_draw_disabled)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:743(<dictcomp>)\n",
      "       86    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       48    0.001    0.000    0.002    0.000 backend_bases.py:756(__init__)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:797(restore)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:824(get_clip_path)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:839(get_dashes)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:876(get_snap)\n",
      "       36    0.000    0.000    0.000    0.000 backend_bases.py:887(set_alpha)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:904(set_antialiased)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:909(set_capstyle)\n",
      "       10    0.000    0.000    0.000    0.000 backend_bases.py:920(set_clip_rectangle)\n",
      "       48    0.000    0.000    0.001    0.000 backend_bases.py:924(set_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:929(set_dashes)\n",
      "       82    0.000    0.000    0.000    0.000 backend_bases.py:959(set_foreground)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:979(set_joinstyle)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:990(set_linewidth)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:994(set_url)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:998(set_gid)\n",
      "        1    0.000    0.000    0.002    0.002 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.367    0.367 backend_inline.py:72(show)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:382(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:405(_scale_norm)\n",
      "        2    0.000    0.000    0.004    0.002 cm.py:427(to_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:520(get_array)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:575(set_cmap)\n",
      "       26    0.000    0.000    0.000    0.000 cm.py:589(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:593(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:622(set_norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:649(autoscale_None)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:660(changed)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:699(_ensure_cmap)\n",
      "        1    0.000    0.000    0.000    0.000 colors.py:1213(__init__)\n",
      "       15    0.000    0.000    0.000    0.000 colors.py:1241(vmin)\n",
      "        5    0.000    0.000    0.000    0.000 colors.py:1245(vmin)\n",
      "       13    0.000    0.000    0.000    0.000 colors.py:1252(vmax)\n",
      "        5    0.000    0.000    0.000    0.000 colors.py:1256(vmax)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:1263(clip)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:1273(_changed)\n",
      "        6    0.000    0.000    0.001    0.000 colors.py:1280(process_value)\n",
      "        2    0.000    0.000    0.001    0.001 colors.py:1315(__call__)\n",
      "        3    0.000    0.000    0.000    0.000 colors.py:1382(autoscale_None)\n",
      "       12    0.000    0.000    0.000    0.000 colors.py:203(_sanitize_extrema)\n",
      "      349    0.001    0.000    0.003    0.000 colors.py:213(_is_nth_color)\n",
      "       99    0.000    0.000    0.002    0.000 colors.py:218(is_color_like)\n",
      "       10    0.000    0.000    0.000    0.000 colors.py:231(_has_alpha_channel)\n",
      "       99    0.000    0.000    0.002    0.000 colors.py:237(_check_color_like)\n",
      "      250    0.001    0.000    0.003    0.000 colors.py:265(to_rgba)\n",
      "        2    0.001    0.000    0.004    0.002 colors.py:683(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      612    0.002    0.000    0.002    0.000 contextlib.py:104(__init__)\n",
      "  612/587    0.001    0.000    0.008    0.000 contextlib.py:132(__enter__)\n",
      "  612/587    0.001    0.000    0.006    0.000 contextlib.py:141(__exit__)\n",
      "      612    0.001    0.000    0.003    0.000 contextlib.py:287(helper)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:450(_create_exit_wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:460(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:490(enter_context)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:522(_push_cm_exit)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:527(_push_exit_callback)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:543(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:546(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:751(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:754(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:757(__exit__)\n",
      "     1038    0.000    0.000    0.000    0.000 copy.py:107(_copy_immutable)\n",
      "   748/12    0.002    0.000    0.004    0.000 copy.py:128(deepcopy)\n",
      "      584    0.000    0.000    0.000    0.000 copy.py:182(_deepcopy_atomic)\n",
      "    48/12    0.001    0.000    0.004    0.000 copy.py:227(_deepcopy_dict)\n",
      "       12    0.000    0.000    0.000    0.000 copy.py:237(_deepcopy_method)\n",
      "      128    0.000    0.000    0.000    0.000 copy.py:243(_keep_alive)\n",
      "      479    0.002    0.000    0.005    0.000 copy.py:259(_reconstruct)\n",
      "      144    0.000    0.000    0.000    0.000 copy.py:264(<genexpr>)\n",
      "     1577    0.005    0.000    0.010    0.000 copy.py:66(copy)\n",
      "      455    0.001    0.000    0.001    0.000 copyreg.py:104(__newobj__)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1283(_replace_dtype_fields_recursive)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1315(_replace_dtype_fields)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1329(make_mask_descr)\n",
      "       33    0.000    0.000    0.000    0.000 core.py:1362(getmask)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:1545(_shrink_mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1555(make_mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1644(make_mask_none)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:1816(_check_mask_axis)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1828(masked_where)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:199(_recursive_fill_value)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:220(_get_dtype_of)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:2332(masked_invalid)\n",
      "       12    0.000    0.000    0.001    0.000 core.py:2808(__new__)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:285(_extremum_fill_value)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:287(_scalar_fill_value)\n",
      "       21    0.000    0.000    0.000    0.000 core.py:2940(_update_from)\n",
      "       21    0.000    0.000    0.001    0.000 core.py:2966(__array_finalize__)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:299(minimum_fill_value)\n",
      "        8    0.000    0.000    0.000    0.000 core.py:3205(__getitem__)\n",
      "        4    0.000    0.000    0.000    0.000 core.py:3222(_scalar_heuristic)\n",
      "       61    0.000    0.000    0.000    0.000 core.py:3401(dtype)\n",
      "       28    0.000    0.000    0.000    0.000 core.py:3417(shape)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3429(__setmask__)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:350(maximum_fill_value)\n",
      "        4    0.000    0.000    0.000    0.000 core.py:3500(mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3510(mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3640(shrink_mask)\n",
      "       20    0.000    0.000    0.000    0.000 core.py:3676(_get_data)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:3770(filled)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:5731(min)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:5830(max)\n",
      "       11    0.000    0.000    0.000    0.000 core.py:587(filled)\n",
      "        8    0.000    0.000    0.001    0.000 core.py:6625(array)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:6642(is_masked)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:8025(asarray)\n",
      "       12    0.000    0.000    0.000    0.000 cycler.py:165(keys)\n",
      "      110    0.000    0.000    0.000    0.000 cycler.py:239(__iter__)\n",
      "       10    0.000    0.000    0.000    0.000 cycler.py:364(by_key)\n",
      "       10    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "       12    0.000    0.000    0.001    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.365    0.030 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       33    0.000    0.000    0.001    0.000 deprecation.py:289(wrapper)\n",
      "      7/5    0.000    0.000    0.002    0.000 deprecation.py:379(wrapper)\n",
      "       12    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    76/68    0.000    0.000    0.026    0.000 deprecation.py:443(wrapper)\n",
      "       10    0.000    0.000    0.000    0.000 dir2.py:54(get_real_method)\n",
      "        1    0.000    0.000    0.367    0.367 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.002    0.002 display_functions.py:45(publish_display_data)\n",
      "        1    0.000    0.000    0.000    0.000 displaypub.py:43(_validate_data)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:105(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:183(encode)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:205(iterencode)\n",
      "      284    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1232(__reduce_ex__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1243(name)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:192(__get__)\n",
      "      284    0.000    0.000    0.001    0.000 enum.py:691(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:101(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:131(update)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1474(add_gridspec)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1598(sca)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:1604(gca)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:161(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1650(_process_projection_requirements)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1686(get_default_bbox_extra_artists)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1687(<listcomp>)\n",
      "        1    0.000    0.000    0.158    0.158 figure.py:1694(get_tightbbox)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1745(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.000 figure.py:191(_get_draw_artists)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:203(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:204(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2105(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2353(__repr__)\n",
      "        1    0.000    0.000    0.002    0.002 figure.py:2360(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2553(_check_layout_engines_compat)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:2572(set_layout_engine)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:259(get_children)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:2638(get_layout_engine)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2645(_repr_html_)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:2696(axes)\n",
      "      808    0.000    0.000    0.000    0.000 figure.py:2718(_get_dpi)\n",
      "      360    0.000    0.000    0.000    0.000 figure.py:2721(_set_dpi)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:2875(set_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3096(clear)\n",
      "        2    0.000    0.000    0.186    0.093 figure.py:3105(draw)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3199(add_axobserver)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3203(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:402(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:406(get_facecolor)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:434(set_edgecolor)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:444(set_facecolor)\n",
      "     1164    0.001    0.000    0.002    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.046    0.046 figure.py:618(add_subplot)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:68(__init__)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:72(as_list)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:747(_add_axes_internal)\n",
      "        1    0.000    0.000    0.047    0.047 figure.py:760(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:80(bubble)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:86(add)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:91(current)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:933(clear)\n",
      "       42    0.000    0.000    0.000    0.000 font_manager.py:1061(get_default_size)\n",
      "       47    0.001    0.000    0.003    0.000 font_manager.py:1200(findfont)\n",
      "      282    0.000    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       33    0.000    0.000    0.003    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       33    0.000    0.000    0.001    0.000 font_manager.py:1490(get_font)\n",
      "       66    0.000    0.000    0.000    0.000 font_manager.py:1515(<genexpr>)\n",
      "       67    0.001    0.000    0.003    0.000 font_manager.py:588(__init__)\n",
      "       88    0.000    0.000    0.002    0.000 font_manager.py:608(_from_any)\n",
      "     1057    0.005    0.000    0.008    0.000 font_manager.py:631(__hash__)\n",
      "      345    0.000    0.000    0.006    0.000 font_manager.py:642(__eq__)\n",
      "     1090    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "     1090    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "      100    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:729(set_style)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       70    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "      111    0.000    0.000    0.001    0.000 font_manager.py:807(set_size)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:857(get_math_fontfamily)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:865(set_math_fontfamily)\n",
      "      418    0.001    0.000    0.009    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.364    0.030 formatters.py:217(catch_format_error)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:271(_get_type)\n",
      "        9    0.000    0.000    0.363    0.040 formatters.py:328(__call__)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:356(_check_return)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:371(lookup)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:394(lookup_by_type)\n",
      "       40    0.000    0.000    0.000    0.000 formatters.py:550(_in_deferred_types)\n",
      "        1    0.000    0.000    0.001    0.001 formatters.py:693(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:828(_check_return)\n",
      "        1    0.000    0.000    0.365    0.365 formatters.py:88(format)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:905(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:942(_check_return)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:951(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:1888(_nonzero_dispatcher)\n",
      "      168    0.000    0.000    0.001    0.000 fromnumeric.py:1892(nonzero)\n",
      "      234    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "      234    0.000    0.000    0.004    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2107(_clip_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2111(clip)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 fromnumeric.py:2333(any)\n",
      "      184    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "      184    0.000    0.000    0.003    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:2600(_ptp_dispatcher)\n",
      "      168    0.001    0.000    0.003    0.000 fromnumeric.py:2604(ptp)\n",
      "      710    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "      710    0.001    0.000    0.007    0.000 fromnumeric.py:2703(amax)\n",
      "      714    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "      714    0.001    0.000    0.008    0.000 fromnumeric.py:2829(amin)\n",
      "       12    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "       12    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "     1680    0.001    0.000    0.001    0.000 fromnumeric.py:3241(_around_dispatcher)\n",
      "      840    0.001    0.000    0.007    0.000 fromnumeric.py:3245(around)\n",
      "      840    0.001    0.000    0.011    0.000 fromnumeric.py:3754(round_)\n",
      "      234    0.001    0.000    0.003    0.000 fromnumeric.py:38(_wrapit)\n",
      "     1246    0.002    0.000    0.011    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "     1632    0.005    0.000    0.016    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "     1632    0.002    0.000    0.002    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       16    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       16    0.000    0.000    0.000    0.000 function_base.py:1320(diff)\n",
      "     1364    0.001    0.000    0.002    0.000 function_base.py:346(iterable)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:35(update_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:65(wraps)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "      172    0.001    0.000    0.001    0.000 getlimits.py:476(__new__)\n",
      "      172    0.003    0.000    0.003    0.000 getlimits.py:558(smallest_normal)\n",
      "      172    0.000    0.000    0.004    0.000 getlimits.py:581(tiny)\n",
      "       13    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:101(set_width_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:123(set_height_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:145(get_grid_positions)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:191(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:199(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:228(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 gridspec.py:232(_normalize)\n",
      "        1    0.000    0.000    0.046    0.046 gridspec.py:265(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:329(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:33(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:413(get_subplot_params)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:430(<dictcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:546(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:556(_from_subplot_args)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:604(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:608(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:612(get_gridspec)\n",
      "        1    0.000    0.000    0.001    0.001 gridspec.py:653(get_position)\n",
      "        3    0.000    0.000    0.000    0.000 gridspec.py:75(get_geometry)\n",
      "        6    0.000    0.000    0.000    0.000 hatch.py:182(_validate_hatch_pattern)\n",
      "        4    0.000    0.000    0.000    0.000 hmac.py:117(update)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:122(copy)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:139(_current)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:161(hexdigest)\n",
      "        3    0.000    0.000    0.000    0.000 image.py:1004(get_extent)\n",
      "      4/2    0.000    0.000    0.184    0.092 image.py:113(_draw_list_compositing_images)\n",
      "       10    0.000    0.000    0.000    0.000 image.py:123(<genexpr>)\n",
      "        1    0.000    0.000    0.013    0.013 image.py:1567(imsave)\n",
      "        4    0.000    0.000    0.010    0.003 image.py:160(_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:247(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:287(get_size)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:294(set_alpha)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:308(_get_scalar_alpha)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:321(changed)\n",
      "        2    0.001    0.001    0.018    0.009 image.py:328(_make_image)\n",
      "        2    0.000    0.000    0.021    0.010 image.py:617(draw)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:685(set_data)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:745(get_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:756(set_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:778(set_interpolation_stage)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:802(set_resample)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:816(get_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:820(set_filternorm)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:833(get_filternorm)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:837(set_filterrad)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:852(get_filterrad)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:905(__init__)\n",
      "        2    0.000    0.000    0.018    0.009 image.py:940(make_image)\n",
      "        1    0.000    0.000    0.001    0.001 image.py:956(set_extent)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2037(_signature_bound_method)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "      2/1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "       74    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "      163    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2836(args)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2859(kwargs)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "       10    0.000    0.000    0.000    0.000 inspect.py:292(isclass)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "       54    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3039(replace)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:3075(_bind)\n",
      "       16    0.000    0.000    0.001    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        5    0.000    0.000    0.001    0.000 iostream.py:203(schedule)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:215(send_multipart)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:287(send_multipart)\n",
      "        2    0.000    0.000    0.001    0.001 iostream.py:480(flush)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:107(json_default)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:38(_ensure_tzinfo)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:52(encode_images)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:77(json_clean)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:112(_makearray)\n",
      "        6    0.000    0.000    0.000    0.000 linalg.py:117(isComplexType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:130(_realType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:136(_commonType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 linalg.py:469(inv)\n",
      "       10    0.000    0.000    0.002    0.000 lines.py:1026(get_path)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1040(set_antialiased)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1052(set_color)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1064(set_drawstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1099(set_gapcolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1122(set_linewidth)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1137(set_linestyle)\n",
      "       20    0.000    0.000    0.001    0.000 lines.py:1182(set_marker)\n",
      "       90    0.000    0.000    0.001    0.000 lines.py:1196(_set_markercolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1210(set_markeredgecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1220(set_markerfacecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1230(set_markerfacecoloralt)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1240(set_markeredgewidth)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1255(set_markersize)\n",
      "      723    0.002    0.000    0.005    0.000 lines.py:1269(set_xdata)\n",
      "      435    0.001    0.000    0.003    0.000 lines.py:1290(set_ydata)\n",
      "       12    0.000    0.000    0.005    0.000 lines.py:1335(update_from)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       30    0.001    0.000    0.010    0.000 lines.py:272(__init__)\n",
      "       36    0.000    0.000    0.000    0.000 lines.py:33(_get_dash_pattern)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:538(set_markevery)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:597(get_markevery)\n",
      "       77    0.000    0.000    0.000    0.000 lines.py:63(_scale_dashes)\n",
      "       60    0.000    0.000    0.001    0.000 lines.py:635(set_data)\n",
      "       22    0.001    0.000    0.003    0.000 lines.py:654(recache)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:697(_transform_path)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:712(_get_transformed_path)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:718(set_transform)\n",
      "       24    0.001    0.000    0.006    0.000 lines.py:729(draw)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:893(get_drawstyle)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:933(get_markeredgecolor)\n",
      "       24    0.000    0.000    0.000    0.000 lines.py:959(_get_markerfacecolor)\n",
      "       18    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       16    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       62    0.000    0.000    0.007    0.000 markers.py:228(__init__)\n",
      "      112    0.000    0.000    0.001    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:293(__bool__)\n",
      "       44    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       62    0.000    0.000    0.000    0.000 markers.py:302(_set_fillstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:318(get_joinstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:321(get_capstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:324(get_marker)\n",
      "       62    0.000    0.000    0.006    0.000 markers.py:327(_set_marker)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:369(get_path)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:378(get_transform)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:388(get_alt_path)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:407(get_snap_threshold)\n",
      "       30    0.000    0.000    0.000    0.000 markers.py:482(_set_nothing)\n",
      "        5    0.000    0.000    0.000    0.000 markers.py:791(_set_tickleft)\n",
      "        5    0.000    0.000    0.000    0.000 markers.py:797(_set_tickright)\n",
      "        5    0.000    0.000    0.000    0.000 markers.py:805(_set_tickup)\n",
      "        5    0.000    0.000    0.000    0.000 markers.py:811(_set_tickdown)\n",
      "        4    0.000    0.000    0.000    0.000 mathtext.py:196(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:1029(unravel_index)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "       44    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:502(can_cast)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:617(min_scalar_type)\n",
      "       84    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "      232    0.000    0.000    0.000    0.000 multiarray.py:740(dot)\n",
      "        5    0.000    0.000    0.000    0.000 multiarray.py:84(empty_like)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:968(ravel_multi_index)\n",
      "        6    0.000    0.000    0.000    0.000 multiclass.py:114(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 multiclass.py:116(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 multiclass.py:126(is_multilabel)\n",
      "        4    0.000    0.000    0.001    0.000 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.000    0.000 multiclass.py:23(_unique_multiclass)\n",
      "        1    0.000    0.000    0.001    0.001 multiclass.py:44(unique_labels)\n",
      "        3    0.000    0.000    0.000    0.000 multiclass.py:81(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:150(ones)\n",
      "        6    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:215(_ones_like_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:219(ones_like)\n",
      "       84    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "       84    0.001    0.000    0.012    0.000 numeric.py:2278(isclose)\n",
      "       84    0.003    0.000    0.007    0.000 numeric.py:2359(within_tol)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:73(_zeros_like_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:77(zeros_like)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:228(obj2sctype)\n",
      "       12    0.000    0.000    0.000    0.000 numerictypes.py:282(issubclass_)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:356(issubdtype)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:433(__getitem__)\n",
      "       70    0.000    0.000    0.005    0.000 patches.py:262(get_transform)\n",
      "       44    0.000    0.000    0.000    0.000 patches.py:273(get_patch_transform)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:288(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:292(get_facecolor)\n",
      "        7    0.000    0.000    0.000    0.000 patches.py:304(set_antialiased)\n",
      "       19    0.000    0.000    0.000    0.000 patches.py:317(_set_edgecolor)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:332(set_edgecolor)\n",
      "       19    0.000    0.000    0.001    0.000 patches.py:343(_set_facecolor)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:350(set_facecolor)\n",
      "       11    0.000    0.000    0.000    0.000 patches.py:384(set_linewidth)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:399(set_linestyle)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:434(set_fill)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:456(set_capstyle)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:476(set_joinstyle)\n",
      "        6    0.000    0.000    0.002    0.000 patches.py:48(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "       12    0.000    0.000    0.002    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "       12    0.000    0.000    0.004    0.000 patches.py:582(draw)\n",
      "       39    0.000    0.000    0.008    0.000 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.001    0.000 patches.py:689(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 patches.py:730(get_path)\n",
      "       28    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       26    0.000    0.000    0.004    0.000 patches.py:742(get_patch_transform)\n",
      "       52    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:768(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:855(set_bounds)\n",
      "       26    0.000    0.000    0.001    0.000 patches.py:876(get_bbox)\n",
      "       68    0.000    0.000    0.000    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       66    0.000    0.000    0.001    0.000 path.py:202(_update_values)\n",
      "      240    0.000    0.000    0.000    0.000 path.py:211(vertices)\n",
      "      159    0.000    0.000    0.000    0.000 path.py:225(codes)\n",
      "       19    0.000    0.000    0.000    0.000 path.py:244(simplify_threshold)\n",
      "       19    0.000    0.000    0.000    0.000 path.py:256(should_simplify)\n",
      "       12    0.000    0.000    0.001    0.000 path.py:281(__deepcopy__)\n",
      "       39    0.001    0.000    0.006    0.000 path.py:603(get_extents)\n",
      "        7    0.000    0.000    0.000    0.000 path.py:730(unit_rectangle)\n",
      "       66    0.000    0.000    0.002    0.000 path.py:99(__init__)\n",
      "       28    0.000    0.000    0.000    0.000 pathlib.py:147(splitroot)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:484(_parse_args)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:504(_from_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:523(_format_parsed_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:536(__str__)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:56(parse_parts)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:868(__new__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:118(_safe_getattr)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:184(group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:201(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:232(text)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:280(begin_group)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:304(end_group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:313(flush)\n",
      "       12    0.000    0.000    0.000    0.000 pretty.py:321(_get_mro)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:355(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:372(pretty)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:417(_in_deferred_types)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:482(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:490(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:495(enq)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:512(remove)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:775(_repr_pprint)\n",
      "        1    0.000    0.000    0.363    0.363 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.049    0.049 pyplot.py:1328(subplots)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        5    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:2280(gca)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:3055(title)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3062(xlabel)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3070(ylabel)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:358(_warn_if_gui_out_of_main_thread)\n",
      "        1    0.000    0.000    0.002    0.002 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.367    0.367 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.002    0.002 pyplot.py:690(figure)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:866(gcf)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:887(get_fignums)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:926(close)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:140(validate_bool)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:152(validate_axisbelow)\n",
      "       14    0.000    0.000    0.007    0.001 scale.py:103(set_default_locators_and_formatters)\n",
      "      516    0.001    0.000    0.002    0.000 scale.py:115(get_transform)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:704(scale_factory)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:96(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:198(utcnow)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:272(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:279(extract_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:598(msg_id)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:643(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:647(msg)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:673(sign)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:688(serialize)\n",
      "        1    0.000    0.000    0.001    0.001 session.py:752(send)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:852(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 session.py:92(json_packer)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 shape_base.py:612(column_stack)\n",
      "        5    0.001    0.000    0.001    0.000 socket.py:613(send)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:135(get_patch_transform)\n",
      "       36    0.001    0.000    0.080    0.002 spines.py:142(get_window_extent)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:199(get_path)\n",
      "    44/40    0.000    0.000    0.000    0.000 spines.py:202(_ensure_position_is_set)\n",
      "        4    0.000    0.000    0.005    0.001 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.004    0.001 spines.py:221(clear)\n",
      "       44    0.001    0.000    0.002    0.000 spines.py:227(_adjust_location)\n",
      "        8    0.000    0.000    0.002    0.000 spines.py:285(draw)\n",
      "        4    0.000    0.000    0.000    0.000 spines.py:292(set_position)\n",
      "    44/40    0.000    0.000    0.001    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.002    0.000 spines.py:35(__init__)\n",
      "        4    0.000    0.000    0.002    0.001 spines.py:425(linear_spine)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:538(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:541(from_dict)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:551(__getattr__)\n",
      "       64    0.000    0.000    0.000    0.000 spines.py:558(__getitem__)\n",
      "        8    0.000    0.000    0.000    0.000 spines.py:584(__iter__)\n",
      "        7    0.000    0.000    0.000    0.000 spines.py:587(__len__)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:416(_broadcast_shape)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:476(_broadcast_arrays_dispatcher)\n",
      "       22    0.000    0.000    0.001    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       66    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "      110    0.000    0.000    0.000    0.000 text.py:1000(set_horizontalalignment)\n",
      "       22    0.000    0.000    0.008    0.000 text.py:101(_get_text_metrics_with_cache_impl)\n",
      "       55    0.000    0.000    0.001    0.000 text.py:1030(set_linespacing)\n",
      "       44    0.000    0.000    0.001    0.000 text.py:1098(set_fontsize)\n",
      "        3    0.000    0.000    0.000    0.000 text.py:1150(set_fontweight)\n",
      "       84    0.000    0.000    0.001    0.000 text.py:1184(set_position)\n",
      "      575    0.001    0.000    0.002    0.000 text.py:1195(set_x)\n",
      "      385    0.000    0.000    0.001    0.000 text.py:1206(set_y)\n",
      "       62    0.000    0.000    0.001    0.000 text.py:1217(set_rotation)\n",
      "      109    0.000    0.000    0.001    0.000 text.py:1249(set_verticalalignment)\n",
      "      798    0.001    0.000    0.001    0.000 text.py:1265(set_text)\n",
      "      182    0.001    0.000    0.002    0.000 text.py:1283(_preprocess_math)\n",
      "       55    0.000    0.000    0.004    0.000 text.py:1307(set_fontproperties)\n",
      "       31    0.000    0.000    0.009    0.000 text.py:132(__init__)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "      364    0.000    0.000    0.000    0.000 text.py:1335(get_usetex)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:1351(get_parse_math)\n",
      "       55    0.001    0.000    0.008    0.000 text.py:185(_reset_visual_defaults)\n",
      "       34    0.000    0.000    0.003    0.000 text.py:221(update)\n",
      "       40    0.000    0.000    0.002    0.000 text.py:270(_get_xy_display)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:277(_get_multialignment)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:315(get_rotation)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:323(get_transform_rotates_text)\n",
      "       62    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:344(get_rotation_mode)\n",
      "        8    0.000    0.000    0.000    0.000 text.py:348(update_from)\n",
      "      160    0.010    0.000    0.058    0.000 text.py:363(_get_layout)\n",
      "      124    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        6    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        4    0.000    0.000    0.001    0.000 text.py:596(set_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       38    0.001    0.000    0.023    0.001 text.py:738(draw)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:808(get_color)\n",
      "      178    0.001    0.000    0.002    0.000 text.py:893(get_unitless_position)\n",
      "       84    0.000    0.000    0.000    0.000 text.py:901(get_position)\n",
      "      428    0.000    0.000    0.000    0.000 text.py:907(get_text)\n",
      "      178    0.004    0.000    0.074    0.000 text.py:918(get_window_extent)\n",
      "      320    0.002    0.000    0.025    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       69    0.000    0.000    0.002    0.000 text.py:985(set_color)\n",
      "        2    0.000    0.000    0.000    0.000 textpath.py:26(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        4    0.000    0.000    0.000    0.000 threading.py:1161(ident)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:1446(current_thread)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:236(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:264(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:267(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:273(_release_save)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:276(_acquire_restore)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:279(_is_owned)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:288(wait)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:555(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.001    0.000 threading.py:604(wait)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1633(raise_if_exceeds)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1651(nonsingular)\n",
      "       84    0.000    0.000    0.000    0.000 ticker.py:1755(__call__)\n",
      "       84    0.000    0.000    0.000    0.000 ticker.py:1758(tick_values)\n",
      "      168    0.001    0.000    0.001    0.000 ticker.py:1899(scale_range)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1917(__init__)\n",
      "       58    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "      336    0.000    0.000    0.000    0.000 ticker.py:1932(closeto)\n",
      "      168    0.000    0.000    0.001    0.000 ticker.py:1942(le)\n",
      "      168    0.000    0.000    0.001    0.000 ticker.py:1949(ge)\n",
      "       16    0.000    0.000    0.003    0.000 ticker.py:1969(__init__)\n",
      "       16    0.000    0.000    0.002    0.000 ticker.py:2010(_validate_steps)\n",
      "       16    0.000    0.000    0.001    0.000 ticker.py:2025(_staircase)\n",
      "       16    0.000    0.000    0.002    0.000 ticker.py:2031(set_params)\n",
      "      168    0.014    0.000    0.025    0.000 ticker.py:2074(_raw_ticks)\n",
      "      168    0.001    0.000    0.041    0.000 ticker.py:2134(__call__)\n",
      "      168    0.001    0.000    0.034    0.000 ticker.py:2138(tick_values)\n",
      "      168    0.001    0.000    0.031    0.000 ticker.py:215(format_ticks)\n",
      "      168    0.001    0.000    0.005    0.000 ticker.py:218(<listcomp>)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:238(set_locs)\n",
      "      360    0.001    0.000    0.002    0.000 ticker.py:247(fix_minus)\n",
      "       28    0.000    0.000    0.000    0.000 ticker.py:259(_set_locator)\n",
      "       14    0.000    0.000    0.002    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:427(__init__)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:454(set_useOffset)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:500(set_useLocale)\n",
      "      336    0.001    0.000    0.003    0.000 ticker.py:516(_format_maybe_minus_and_locale)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:533(set_useMathText)\n",
      "      336    0.001    0.000    0.004    0.000 ticker.py:568(__call__)\n",
      "       24    0.000    0.000    0.000    0.000 ticker.py:668(get_offset)\n",
      "      168    0.001    0.000    0.049    0.000 ticker.py:696(set_locs)\n",
      "      168    0.004    0.000    0.013    0.000 ticker.py:705(_compute_offset)\n",
      "      168    0.003    0.000    0.010    0.000 ticker.py:744(_set_order_of_magnitude)\n",
      "      168    0.007    0.000    0.025    0.000 ticker.py:778(_set_format)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "     2254    0.001    0.000    0.001    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:1057(set)\n",
      "       26    0.000    0.000    0.000    0.000 transforms.py:1087(__init__)\n",
      "     1964    0.002    0.000    0.002    0.000 transforms.py:110(__init__)\n",
      "       53    0.000    0.000    0.001    0.000 transforms.py:1109(get_points)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:131(__getstate__)\n",
      "      131    0.000    0.000    0.001    0.000 transforms.py:1335(__add__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:134(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:136(__setstate__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:141(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1463(__array__)\n",
      "      160    0.001    0.000    0.009    0.000 transforms.py:1467(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1568(get_matrix)\n",
      "      425    0.001    0.000    0.003    0.000 transforms.py:157(invalidate)\n",
      "       39    0.000    0.000    0.003    0.000 transforms.py:1588(transform_path)\n",
      "       39    0.000    0.000    0.002    0.000 transforms.py:1597(transform_path_affine)\n",
      "       56    0.000    0.000    0.001    0.000 transforms.py:1607(transform_path_non_affine)\n",
      "  661/425    0.002    0.000    0.002    0.000 transforms.py:167(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1696(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1714(set)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1751(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1752(<lambda>)\n",
      "      214    0.000    0.000    0.000    0.000 transforms.py:1753(<lambda>)\n",
      "     1202    0.002    0.000    0.003    0.000 transforms.py:1764(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:1768(__array__)\n",
      "       11    0.000    0.000    0.001    0.000 transforms.py:1772(__eq__)\n",
      "      561    0.001    0.000    0.005    0.000 transforms.py:1777(transform)\n",
      "       39    0.000    0.000    0.002    0.000 transforms.py:1794(transform_path_affine)\n",
      "      309    0.000    0.000    0.000    0.000 transforms.py:1803(get_affine)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:1827(frozen)\n",
      "       30    0.000    0.000    0.000    0.000 transforms.py:1831(is_separable)\n",
      "      600    0.002    0.000    0.004    0.000 transforms.py:1843(transform_affine)\n",
      "       13    0.000    0.000    0.001    0.000 transforms.py:1864(inverted)\n",
      "      478    0.002    0.000    0.004    0.000 transforms.py:1881(__init__)\n",
      "      783    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      210    0.001    0.000    0.001    0.000 transforms.py:194(set_children)\n",
      "      186    0.001    0.000    0.003    0.000 transforms.py:1978(rotate)\n",
      "      186    0.001    0.000    0.004    0.000 transforms.py:2001(rotate_deg)\n",
      "       58    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       93    0.001    0.000    0.001    0.000 transforms.py:2046(scale)\n",
      "      143    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "      682    0.001    0.000    0.001    0.000 transforms.py:2126(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2190(__init__)\n",
      "      104    0.000    0.000    0.001    0.000 transforms.py:2214(<lambda>)\n",
      "       68    0.000    0.000    0.000    0.000 transforms.py:2222(transform_non_affine)\n",
      "      160    0.000    0.000    0.001    0.000 transforms.py:2254(get_affine)\n",
      "       29    0.000    0.000    0.001    0.000 transforms.py:2281(__init__)\n",
      "       77    0.000    0.000    0.001    0.000 transforms.py:2307(get_matrix)\n",
      "       31    0.000    0.000    0.001    0.000 transforms.py:2323(blended_transform_factory)\n",
      "       87    0.000    0.000    0.001    0.000 transforms.py:2347(__init__)\n",
      "   138/74    0.000    0.000    0.001    0.000 transforms.py:2376(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2391(__eq__)\n",
      "  469/257    0.001    0.000    0.001    0.000 transforms.py:2405(<lambda>)\n",
      "      160    0.000    0.000    0.007    0.000 transforms.py:2413(transform_affine)\n",
      "      160    0.000    0.000    0.001    0.000 transforms.py:2417(transform_non_affine)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:2426(transform_path_non_affine)\n",
      "  232/171    0.002    0.000    0.007    0.000 transforms.py:2436(get_affine)\n",
      "       49    0.000    0.000    0.001    0.000 transforms.py:246(frozen)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:250(__array__)\n",
      "      131    0.000    0.000    0.001    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       55    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "  113/111    0.000    0.000    0.000    0.000 transforms.py:2597(get_matrix)\n",
      "       74    0.000    0.000    0.000    0.000 transforms.py:263(y0)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:2639(__init__)\n",
      "       32    0.000    0.000    0.000    0.000 transforms.py:2651(get_matrix)\n",
      "       22    0.000    0.000    0.000    0.000 transforms.py:2673(__init__)\n",
      "      136    0.000    0.000    0.000    0.000 transforms.py:2683(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:273(x1)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2736(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2751(_revalidate)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2764(get_transformed_points_and_affine)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2791(get_affine)\n",
      "      172    0.003    0.000    0.008    0.000 transforms.py:2822(nonsingular)\n",
      "       40    0.000    0.000    0.000    0.000 transforms.py:283(y1)\n",
      "      336    0.002    0.000    0.002    0.000 transforms.py:2902(_interval_contains_close)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:293(p0)\n",
      "      243    0.001    0.000    0.005    0.000 transforms.py:313(xmin)\n",
      "      267    0.001    0.000    0.004    0.000 transforms.py:318(ymin)\n",
      "      243    0.001    0.000    0.003    0.000 transforms.py:323(xmax)\n",
      "      263    0.001    0.000    0.004    0.000 transforms.py:328(ymax)\n",
      "      463    0.001    0.000    0.001    0.000 transforms.py:343(intervalx)\n",
      "      263    0.001    0.000    0.001    0.000 transforms.py:352(intervaly)\n",
      "      161    0.000    0.000    0.000    0.000 transforms.py:361(width)\n",
      "      105    0.000    0.000    0.000    0.000 transforms.py:367(height)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:373(size)\n",
      "       23    0.000    0.000    0.000    0.000 transforms.py:379(bounds)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:385(extents)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:474(transformed)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:493(anchored)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:534(shrunk_to_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:619(padded)\n",
      "      138    0.002    0.000    0.003    0.000 transforms.py:624(translated)\n",
      "       99    0.001    0.000    0.023    0.000 transforms.py:649(union)\n",
      "       99    0.000    0.000    0.005    0.000 transforms.py:654(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:655(<listcomp>)\n",
      "       99    0.000    0.000    0.003    0.000 transforms.py:656(<listcomp>)\n",
      "       99    0.000    0.000    0.003    0.000 transforms.py:657(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.000 transforms.py:660(intersection)\n",
      "      604    0.004    0.000    0.007    0.000 transforms.py:754(__init__)\n",
      "       49    0.000    0.000    0.001    0.000 transforms.py:784(frozen)\n",
      "       26    0.000    0.000    0.001    0.000 transforms.py:790(unit)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:795(null)\n",
      "      205    0.000    0.000    0.008    0.000 transforms.py:800(from_bounds)\n",
      "      232    0.001    0.000    0.009    0.000 transforms.py:809(from_extents)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:856(update_from_path)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:932(update_from_data_xy)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:958(x0)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:963(y0)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:968(x1)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:973(y1)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:988(intervalx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:993(intervaly)\n",
      "        1    0.000    0.000    0.000    0.000 type_check.py:400(_nan_to_num_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 type_check.py:404(nan_to_num)\n",
      "        1    0.000    0.000    0.000    0.000 tz.py:74(utcoffset)\n",
      "     12/6    0.000    0.000    0.000    0.000 units.py:164(get_converter)\n",
      "      118    0.000    0.000    0.001    0.000 units.py:56(_is_natively_supported)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "        5    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:629(check_array)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       16    0.000    0.000    0.000    0.000 weakref.py:46(__new__)\n",
      "        2    0.000    0.000    0.000    0.000 weakref.py:68(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 widgets.py:38(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 zmqshell.py:63(_flush_streams)\n",
      "        1    0.000    0.000    0.000    0.000 zmqshell.py:73(_hooks)\n",
      "        1    0.000    0.000    0.002    0.002 zmqshell.py:80(publish)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.fill}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.map_buffer}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.zip_encoder}\n",
      "      623    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEFC799F90}\n",
      "      392    0.000    0.000    0.001    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       82    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _struct.pack}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method _thread.allocate_lock}\n",
      "       35    0.000    0.000    0.000    0.000 {built-in method _thread.get_ident}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method binascii.b2a_base64}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.__build_class__}\n",
      "     1698    0.001    0.000    0.001    0.000 {built-in method builtins.abs}\n",
      "       64    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "     2294    0.002    0.000    0.004    0.000 {built-in method builtins.any}\n",
      "      574    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "      318    0.000    0.000    0.000    0.000 {built-in method builtins.delattr}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.dir}\n",
      "      336    0.000    0.000    0.000    0.000 {built-in method builtins.divmod}\n",
      "        1    0.000    0.000    0.427    0.427 {built-in method builtins.exec}\n",
      "     7596    0.005    0.000    0.025    0.000 {built-in method builtins.getattr}\n",
      "      886    0.000    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "1780/1090    0.001    0.000    0.006    0.000 {built-in method builtins.hash}\n",
      "     1718    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     6515    0.002    0.000    0.003    0.000 {built-in method builtins.isinstance}\n",
      "      603    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "     1476    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "2523/2516    0.001    0.000    0.001    0.000 {built-in method builtins.len}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.locals}\n",
      "     1061    0.001    0.000    0.001    0.000 {built-in method builtins.max}\n",
      "       27    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "1418/1318    0.002    0.000    0.012    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.repr}\n",
      "       22    0.000    0.000    0.000    0.000 {built-in method builtins.round}\n",
      "      809    0.001    0.000    0.001    0.000 {built-in method builtins.setattr}\n",
      "      430    0.002    0.000    0.002    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sum}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method from_iterable}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method math.ceil}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "      336    0.000    0.000    0.000    0.000 {built-in method math.floor}\n",
      "      504    0.001    0.000    0.001    0.000 {built-in method math.log10}\n",
      "      208    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "        4    0.010    0.002    0.010    0.003 {built-in method matplotlib._image.resample}\n",
      "      600    0.002    0.000    0.002    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "       29    0.000    0.000    0.000    0.000 {built-in method nt.fspath}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "      169    0.001    0.000    0.001    0.000 {built-in method numpy.arange}\n",
      "      931    0.003    0.000    0.003    0.000 {built-in method numpy.array}\n",
      "     1198    0.001    0.000    0.001    0.000 {built-in method numpy.asanyarray}\n",
      "1756/1750    0.003    0.000    0.003    0.000 {built-in method numpy.asarray}\n",
      "4458/3299    0.008    0.000    0.057    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       16    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "      348    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.promote_types}\n",
      "      174    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method scipy.sparse._sparsetools.coo_todense}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method sys.exc_info}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method sys.getrecursionlimit}\n",
      "      112    0.000    0.000    0.000    0.000 {built-in method sys.intern}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method utcnow}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method zlib.crc32}\n",
      "     2762    0.001    0.000    0.001    0.000 {function RcParams.__getitem__ at 0x0000026B81E739C0}\n",
      "        3    0.000    0.000    0.000    0.000 {method '__array_prepare__' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__contains__' of 'frozenset' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method '__deepcopy__' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__enter__' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.lock' objects}\n",
      "      455    0.001    0.000    0.001    0.000 {method '__reduce_ex__' of 'object' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'add' of 'set' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "       89    0.000    0.000    0.001    0.000 {method 'any' of 'numpy.ndarray' objects}\n",
      "        9    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "     1988    0.001    0.000    0.001    0.000 {method 'append' of 'list' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.generic' objects}\n",
      "       32    0.001    0.000    0.001    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'cleanup' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.OrderedDict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       33    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'clip' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of '_hashlib.HMAC' objects}\n",
      "       19    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "      160    0.000    0.000    0.000    0.000 {method 'copy' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'copy' of 'numpy.generic' objects}\n",
      "     1209    0.003    0.000    0.003    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      424    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.002    0.002    0.002    0.002 {method 'draw_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'draw_markers' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.001    0.000    0.001    0.000 {method 'draw_path' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       11    0.001    0.000    0.001    0.000 {method 'draw_text_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        1    0.012    0.012    0.012    0.012 {method 'encode' of 'ImagingEncoder' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {method 'encode' of 'str' objects}\n",
      "       51    0.000    0.000    0.000    0.000 {method 'extend' of 'list' objects}\n",
      "       21    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'flush' of '_io.BytesIO' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'format' of 'str' objects}\n",
      "     6360    0.002    0.000    0.002    0.000 {method 'get' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'get' of 'mappingproxy' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'get_bitmap_offset' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       33    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       22    0.000    0.000    0.000    0.000 {method 'get_width_height' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.StringIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'hexdigest' of '_hashlib.HMAC' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'insert' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'isidentifier' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'islower' of 'bytes' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'isoformat' of 'datetime.datetime' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.ndarray' objects}\n",
      "     5968    0.001    0.000    0.001    0.000 {method 'items' of 'dict' objects}\n",
      "       36    0.000    0.000    0.000    0.000 {method 'items' of 'mappingproxy' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'join' of 'bytes' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'join' of 'str' objects}\n",
      "       39    0.000    0.000    0.000    0.000 {method 'lower' of 'str' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'lstrip' of 'str' objects}\n",
      "      344    0.000    0.000    0.000    0.000 {method 'match' of 're.Pattern' objects}\n",
      "     1374    0.001    0.000    0.008    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "      536    0.001    0.000    0.006    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'move_to_end' of 'collections.OrderedDict' objects}\n",
      "      168    0.000    0.000    0.000    0.000 {method 'nonzero' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pixel_access' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.OrderedDict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.deque' objects}\n",
      "      417    0.000    0.000    0.000    0.000 {method 'pop' of 'dict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'list' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pop' of 'set' objects}\n",
      "       45    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "     4136    0.021    0.000    0.021    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'release' of '_thread.lock' objects}\n",
      "       32    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'replace' of 'datetime.datetime' objects}\n",
      "      572    0.000    0.000    0.000    0.000 {method 'replace' of 'str' objects}\n",
      "       84    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "      555    0.001    0.000    0.001    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'reverse' of 'list' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rfind' of 'str' objects}\n",
      "      840    0.005    0.000    0.005    0.000 {method 'round' of 'numpy.ndarray' objects}\n",
      "       39    0.000    0.000    0.000    0.000 {method 'rpartition' of 'str' objects}\n",
      "       84    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       33    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       33    0.007    0.000    0.007    0.000 {method 'set_text' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       33    0.000    0.000    0.000    0.000 {method 'setdefault' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'setimage' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'sort' of 'list' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "      188    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'splitlines' of 'str' objects}\n",
      "       59    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "      168    0.000    0.000    0.002    0.000 {method 'sum' of 'numpy.ndarray' objects}\n",
      "        2    0.002    0.001    0.002    0.001 {method 'take' of 'numpy.ndarray' objects}\n",
      "      186    0.000    0.000    0.000    0.000 {method 'tolist' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'update' of '_hashlib.HMAC' objects}\n",
      "      573    0.001    0.000    0.001    0.000 {method 'update' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'upper' of 'str' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'values' of 'collections.OrderedDict' objects}\n",
      "     1261    0.000    0.000    0.000    0.000 {method 'values' of 'dict' objects}\n",
      "       17    0.000    0.000    0.000    0.000 {method 'values' of 'mappingproxy' objects}\n",
      "    27/21    0.000    0.000    0.000    0.000 {method 'view' of 'numpy.generic' objects}\n",
      "    37/35    0.000    0.000    0.000    0.000 {method 'view' of 'numpy.ndarray' objects}\n",
      "       16    0.000    0.000    0.000    0.000 {method 'write' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "#NUMBER OF FUNCTION CALLS NEEDED FOR CONFUSION MATRIX...NORMAL ONE ALREADY AVAILALBLE\n",
    "\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "        #CREATE CONFUSION MATRIX\n",
    "    # Calculate the confusion matrix\n",
    "    from sklearn.metrics import confusion_matrix\n",
    "    conf_matrix = confusion_matrix(y_true=data.Actual_Output, y_pred=data.predicted_Output)\n",
    "    #\n",
    "    # Print the confusion matrix using Matplotlib\n",
    "    #\n",
    "    fig, ax = plt.subplots(figsize=(4, 7))\n",
    "    ax.matshow(conf_matrix, cmap=plt.cm.Blues, alpha=0.3)\n",
    "    for i in range(conf_matrix.shape[0]):\n",
    "        for j in range(conf_matrix.shape[1]):\n",
    "            ax.text(x=j, y=i,s=conf_matrix[i, j], va='center', ha='center', size='xx-large')\n",
    "    \n",
    "    plt.xlabel('Predictions', fontsize=18)\n",
    "    plt.ylabel('Actuals', fontsize=18)\n",
    "    plt.title('Confusion Matrix', fontsize=18)\n",
    "    plt.show()\n",
    "    \n",
    "    pass\n",
    "\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         72488 function calls (70451 primitive calls) in 0.178 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.000    0.000 4147517468.py:17(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 4147517468.py:18(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 4147517468.py:20(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 4147517468.py:21(<listcomp>)\n",
      "        1    0.000    0.000    0.178    0.178 4147517468.py:5(my_method)\n",
      "       88    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(all)\n",
      "       92    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(amax)\n",
      "       86    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(any)\n",
      "       64    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(append)\n",
      "      128    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(atleast_1d)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(atleast_2d)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(broadcast_arrays)\n",
      "        8    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(column_stack)\n",
      "      220    0.001    0.000    0.003    0.000 <__array_function__ internals>:177(concatenate)\n",
      "      137    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(cumsum)\n",
      "       64    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(diag)\n",
      "       14    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(diff)\n",
      "      103    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(dot)\n",
      "       64    0.000    0.000    0.008    0.000 <__array_function__ internals>:177(eigvals)\n",
      "       67    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(empty_like)\n",
      "       64    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(full_like)\n",
      "       64    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(hstack)\n",
      "       32    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(imag)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(in1d)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(inv)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(isin)\n",
      "       32    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(isreal)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(linspace)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(mean)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "       64    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(nonzero)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(norm)\n",
      "      128    0.001    0.000    0.002    0.000 <__array_function__ internals>:177(ravel)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ravel_multi_index)\n",
      "       32    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(real)\n",
      "       76    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(reshape)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "       64    0.000    0.000    0.019    0.000 <__array_function__ internals>:177(roots)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(sum)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unique)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unravel_index)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(vstack)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(zeros_like)\n",
      "       12    0.000    0.000    0.000    0.000 <frozen _collections_abc>:778(__contains__)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen _collections_abc>:794(values)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen _collections_abc>:812(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 <frozen _collections_abc>:815(__len__)\n",
      "       65    0.000    0.000    0.000    0.000 <frozen _collections_abc>:878(__iter__)\n",
      "      298    0.000    0.000    0.001    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       50    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen genericpath>:121(_splitext)\n",
      "       15    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        3    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:405(parent)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen ntpath>:231(splitext)\n",
      "       61    0.000    0.000    0.000    0.000 <string>:1(<lambda>)\n",
      "        1    0.000    0.000    0.178    0.178 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.011    0.011 Image.py:2346(save)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:2875(_check_size)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2896(new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2973(frombuffer)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:321(preinit)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:417(_getencoder)\n",
      "        3    0.000    0.000    0.000    0.000 Image.py:512(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 Image.py:539(size)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:543(_new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:603(_copy)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:609(_ensure_mutable)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:835(load)\n",
      "        1    0.000    0.000    0.011    0.011 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.011    0.011 ImageFile.py:527(_encode_tile)\n",
      "        1    0.000    0.000    0.000    0.000 ImageFile.py:75(_tilesort)\n",
      "        5    0.000    0.000    0.000    0.000 PngImagePlugin.py:1078(putchunk)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1092(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1096(write)\n",
      "        1    0.000    0.000    0.011    0.011 PngImagePlugin.py:1242(_save)\n",
      "       10    0.000    0.000    0.000    0.000 PngImagePlugin.py:154(_crc32)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:282(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:285(add)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:328(add_text)\n",
      "      928    0.001    0.000    0.002    0.000 __init__.py:101(check_in_list)\n",
      "       13    0.000    0.000    0.000    0.000 __init__.py:106(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:109(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:112(__eq__)\n",
      "       27    0.000    0.000    0.000    0.000 __init__.py:115(__hash__)\n",
      "       15    0.000    0.000    0.000    0.000 __init__.py:119(_weak_or_strong_ref)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1286(is_interactive)\n",
      "       74    0.000    0.000    0.000    0.000 __init__.py:1314(is_math_text)\n",
      "       40    0.000    0.000    0.000    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       27    0.000    0.000    0.000    0.000 __init__.py:134(check_shape)\n",
      "       79    0.000    0.000    0.000    0.000 __init__.py:154(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 __init__.py:1623(<lambda>)\n",
      "      257    0.001    0.000    0.002    0.000 __init__.py:163(match)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:1675(_safe_first_finite)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:1685(safe_isfinite)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:1715(<genexpr>)\n",
      "      179    0.002    0.000    0.003    0.000 __init__.py:1726(normalize_kwargs)\n",
      "       18    0.000    0.000    0.000    0.000 __init__.py:175(check_getitem)\n",
      "      179    0.001    0.000    0.001    0.000 __init__.py:1765(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:183(dumps)\n",
      "      116    0.000    0.000    0.000    0.000 __init__.py:1834(_str_equal)\n",
      "       79    0.000    0.000    0.000    0.000 __init__.py:190(__init__)\n",
      "      478    0.002    0.000    0.002    0.000 __init__.py:1994(_setattr_cm)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2039(__init__)\n",
      "       15    0.000    0.000    0.000    0.000 __init__.py:221(connect)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:2290(_unpack_to_numpy)\n",
      "       11    0.000    0.000    0.000    0.000 __init__.py:235(_connect_picklable)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:254(method)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:265(disconnect)\n",
      "      257    0.000    0.000    0.001    0.000 __init__.py:272(_compile)\n",
      "      397    0.001    0.000    0.002    0.000 __init__.py:291(process)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:318(wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:53(__get__)\n",
      "       14    0.000    0.000    0.001    0.000 __init__.py:550(_get_data_path)\n",
      "      165    0.001    0.000    0.001    0.000 __init__.py:65(check_isinstance)\n",
      "     1732    0.001    0.000    0.002    0.000 __init__.py:691(_get)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:73(get_projection_class)\n",
      "     1732    0.002    0.000    0.004    0.000 __init__.py:742(__getitem__)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:80(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:825(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:826(<dictcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 __init__.py:828(__contains__)\n",
      "       56    0.000    0.000    0.000    0.000 __init__.py:831(clean)\n",
      "       56    0.000    0.000    0.000    0.000 __init__.py:834(<listcomp>)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:880(get_siblings)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:884(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:98(get_projection_class)\n",
      "        9    0.000    0.000    0.000    0.000 _arc.py:153(angle_as_point)\n",
      "        3    0.000    0.000    0.000    0.000 _arc.py:168(start_point)\n",
      "        6    0.000    0.000    0.000    0.000 _arc.py:188(mid_point)\n",
      "        8    0.000    0.000    0.000    0.000 _arc.py:25(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 _arc.py:44(length_degrees)\n",
      "        5    0.000    0.000    0.004    0.001 _axes.py:626(text)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:1025(get_yaxis_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:1051(get_yaxis_text2_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1077(_update_transScale)\n",
      "      6/5    0.000    0.000    0.000    0.000 _base.py:1082(get_position)\n",
      "        6    0.000    0.000    0.000    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "       11    0.000    0.000    0.000    0.000 _base.py:1179(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1189(_gen_axes_patch)\n",
      "        1    0.000    0.000    0.003    0.003 _base.py:1206(_gen_axes_spines)\n",
      "        1    0.000    0.000    0.003    0.003 _base.py:1221(<dictcomp>)\n",
      "        1    0.000    0.000    0.035    0.035 _base.py:1262(__clear)\n",
      "        1    0.000    0.000    0.035    0.035 _base.py:1388(clear)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1522(_set_title_offset_trans)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1608(get_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1616(set_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1702(set_adjustable)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1766(set_box_aspect)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1803(get_anchor)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:1862(get_data_ratio)\n",
      "        5    0.000    0.000    0.002    0.000 _base.py:1876(apply_aspect)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:222(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2312(_add_text)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:235(set_prop_cycle)\n",
      "        3    0.000    0.000    0.042    0.014 _base.py:2371(add_patch)\n",
      "        3    0.001    0.000    0.040    0.013 _base.py:2384(_update_patch_limits)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:2446(_unit_change_handler)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:2485(update_datalim)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2510(_process_unit_info)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2569(<listcomp>)\n",
      "        4    0.000    0.000    0.005    0.001 _base.py:2939(_update_title_position)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:2994(<genexpr>)\n",
      "        2    0.000    0.000    0.027    0.013 _base.py:3001(draw)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3123(set_axisbelow)\n",
      "        2    0.000    0.000    0.015    0.007 _base.py:3157(grid)\n",
      "        2    0.000    0.000    0.001    0.001 _base.py:3316(tick_params)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3396(set_axis_off)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3405(set_axis_on)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3488(get_xbound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3536(get_xlim)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3575(set_xlim)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3737(get_ybound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3785(get_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3807(set_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3971(set_navigate)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3987(set_navigate_mode)\n",
      "        7    0.000    0.000    0.000    0.000 _base.py:4273(get_children)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4299(get_default_bbox_extra_artists)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4328(<listcomp>)\n",
      "        2    0.000    0.000    0.017    0.008 _base.py:4331(get_tightbbox)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:4416(<listcomp>)\n",
      "       28    0.000    0.000    0.000    0.000 _base.py:564(_axis_map)\n",
      "       28    0.000    0.000    0.000    0.000 _base.py:567(<dictcomp>)\n",
      "        1    0.000    0.000    0.052    0.052 _base.py:574(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:652(<dictcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:73(wrapper)\n",
      "        1    0.000    0.000    0.001    0.001 _base.py:790(set_subplotspec)\n",
      "       14    0.000    0.000    0.000    0.000 _base.py:799(get_window_extent)\n",
      "        1    0.000    0.000    0.011    0.011 _base.py:818(_init_axis)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:827(set_figure)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:841(_unstale_viewLim)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:844(<dictcomp>)\n",
      "       64    0.000    0.000    0.000    0.000 _base.py:845(<genexpr>)\n",
      "       14    0.000    0.000    0.000    0.000 _base.py:855(viewLim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:881(_set_lim_and_transforms)\n",
      "    29/15    0.000    0.000    0.000    0.000 _base.py:917(get_xaxis_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:945(get_xaxis_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:971(get_xaxis_text2_transform)\n",
      "    29/15    0.000    0.000    0.000    0.000 _base.py:997(get_yaxis_transform)\n",
      "       14    0.000    0.000    0.000    0.000 _binary.py:101(o32be)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:100(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:101(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:102(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:20(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _common.py:27(get_patch_by_id)\n",
      "        3    0.000    0.000    0.000    0.000 _common.py:33(get_label_by_id)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:70(mix_colors)\n",
      "        1    0.000    0.000    0.001    0.001 _common.py:92(prepare_venn_axes)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:99(<listcomp>)\n",
      "        1    0.000    0.000    0.001    0.001 _math.py:100(find_distance_by_area)\n",
      "        9    0.000    0.000    0.001    0.000 _math.py:126(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _math.py:129(circle_circle_intersection)\n",
      "        8    0.000    0.000    0.000    0.000 _math.py:175(vector_angle_in_degrees)\n",
      "        1    0.000    0.000    0.000    0.000 _math.py:199(normalize_by_center_of_mass)\n",
      "        9    0.000    0.000    0.001    0.000 _math.py:44(circle_intersection_area)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "       55    0.000    0.000    0.000    0.000 _methods.py:39(_amax)\n",
      "       55    0.000    0.000    0.001    0.000 _methods.py:43(_amin)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:55(_any)\n",
      "       65    0.000    0.000    0.001    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        2    0.000    0.000    0.000    0.000 _region.py:126(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _region.py:132(subtract_and_intersect_circle)\n",
      "        4    0.000    0.000    0.000    0.000 _region.py:230(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _region.py:459(label_position)\n",
      "        3    0.000    0.000    0.000    0.000 _region.py:461(<listcomp>)\n",
      "        3    0.000    0.000    0.003    0.001 _region.py:482(make_patch)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.001    0.001 _tight_bbox.py:8(adjust_bbox)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 _util.py:5(is_path)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:104(compute_venn2_colors)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:113(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:117(compute_venn2_subsets)\n",
      "        1    0.000    0.000    0.054    0.054 _venn2.py:183(venn2)\n",
      "        1    0.000    0.000    0.003    0.003 _venn2.py:239(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:246(<listcomp>)\n",
      "        1    0.000    0.000    0.003    0.003 _venn2.py:247(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:251(<listcomp>)\n",
      "        1    0.000    0.000    0.002    0.002 _venn2.py:254(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:29(compute_venn2_areas)\n",
      "        1    0.000    0.000    0.001    0.001 _venn2.py:57(solve_venn2_circles)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:89(compute_venn2_regions)\n",
      "        1    0.000    0.000    0.001    0.001 _zeros_py.py:658(brentq)\n",
      "        1    0.000    0.000    0.000    0.000 _zeros_py.py:70(results_c)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:138(unique)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:323(_unique1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:373(intersect1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:519(_in1d_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:524(in1d)\n",
      "        9    0.000    0.000    0.000    0.000 arraysetops.py:630(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:761(_isin_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:766(isin)\n",
      "        9    0.000    0.000    0.000    0.000 artist.py:1007(set_alpha)\n",
      "      239    0.000    0.000    0.001    0.000 artist.py:103(_stale_axes_callback)\n",
      "       71    0.000    0.000    0.001    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       18    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "      199    0.002    0.000    0.011    0.000 artist.py:1180(_update_props)\n",
      "       24    0.000    0.000    0.002    0.000 artist.py:1205(update)\n",
      "      175    0.000    0.000    0.010    0.000 artist.py:1216(_internal_update)\n",
      "      155    0.000    0.000    0.012    0.000 artist.py:1227(set)\n",
      "       26    0.000    0.000    0.003    0.000 artist.py:1233(_cm_set)\n",
      "       13    0.000    0.000    0.000    0.000 artist.py:1238(<dictcomp>)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:1375(get_mouseover)\n",
      "      155    0.000    0.000    0.012    0.000 artist.py:147(<lambda>)\n",
      "       61    0.001    0.000    0.002    0.000 artist.py:180(__init__)\n",
      "      107    0.000    0.000    0.001    0.000 artist.py:271(convert_xunits)\n",
      "      107    0.000    0.000    0.001    0.000 artist.py:283(convert_yunits)\n",
      "      898    0.000    0.000    0.000    0.000 artist.py:295(axes)\n",
      "       84    0.000    0.000    0.000    0.000 artist.py:300(axes)\n",
      "2098/1747    0.003    0.000    0.004    0.000 artist.py:319(stale)\n",
      "       18    0.000    0.000    0.013    0.001 artist.py:352(get_tightbbox)\n",
      "      390    0.001    0.000    0.003    0.000 artist.py:417(pchanged)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:430(is_transform_set)\n",
      "       79    0.000    0.000    0.001    0.000 artist.py:438(set_transform)\n",
      "       79    0.000    0.000    0.000    0.000 artist.py:451(get_transform)\n",
      "     28/2    0.000    0.000    0.029    0.014 artist.py:54(draw_wrapper)\n",
      "       22    0.000    0.000    0.000    0.000 artist.py:618(get_gid)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:632(get_snap)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:671(get_sketch_params)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:730(get_path_effects)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:733(get_figure)\n",
      "       60    0.000    0.000    0.001    0.000 artist.py:737(set_figure)\n",
      "        3    0.000    0.000    0.000    0.000 artist.py:761(set_clip_box)\n",
      "       22    0.000    0.000    0.006    0.000 artist.py:778(set_clip_path)\n",
      "       10    0.000    0.000    0.000    0.000 artist.py:840(get_alpha)\n",
      "      198    0.000    0.000    0.000    0.000 artist.py:847(get_visible)\n",
      "     2100    0.001    0.000    0.001    0.000 artist.py:851(get_animated)\n",
      "       29    0.000    0.000    0.000    0.000 artist.py:855(get_in_layout)\n",
      "       27    0.000    0.000    0.001    0.000 artist.py:866(_fully_clipped_to_axes)\n",
      "       42    0.000    0.000    0.000    0.000 artist.py:890(get_clip_on)\n",
      "       30    0.000    0.000    0.000    0.000 artist.py:894(get_clip_box)\n",
      "       33    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\n",
      "       18    0.000    0.000    0.000    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.029    0.014 artist.py:93(draw_wrapper)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:939(get_rasterized)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:966(get_agg_filter)\n",
      "        8    0.000    0.000    0.000    0.000 axis.py:1012(_translate_tick_params)\n",
      "        8    0.000    0.000    0.000    0.000 axis.py:1060(<dictcomp>)\n",
      "        2    0.000    0.000    0.008    0.004 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:1157(_set_lim)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1175(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1232(_set_artist_props)\n",
      "        6    0.000    0.000    0.018    0.003 axis.py:1539(_get_tick)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:154(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1574(get_major_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1590(get_major_ticks)\n",
      "        4    0.000    0.000    0.015    0.004 axis.py:1616(grid)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1647(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1658(update_units)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1719(_have_units_and_converter)\n",
      "       96    0.000    0.000    0.001    0.000 axis.py:1725(convert_units)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:1742(set_units)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1796(set_major_formatter)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1822(set_minor_formatter)\n",
      "       28    0.000    0.000    0.001    0.000 axis.py:1836(_set_formatter)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:1862(set_major_locator)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1878(set_minor_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1894(set_pickradius)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:196(_set_labelrotation)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2014(_set_tick_locations)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2022(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2041(set_ticks)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:208(_apply_tickdir)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2145(_get_ticks_position)\n",
      "       36    0.000    0.000    0.000    0.000 axis.py:2161(<genexpr>)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2182(get_label_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2212(setter)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:223(get_tick_padding)\n",
      "        1    0.000    0.000    0.002    0.002 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2241(_init)\n",
      "        6    0.000    0.000    0.003    0.000 axis.py:237(set_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2449(get_ticks_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2462(get_minpos)\n",
      "        1    0.000    0.000    0.002    0.002 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2500(_init)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2721(get_minpos)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:342(_set_artist_props)\n",
      "       14    0.000    0.000    0.003    0.000 axis.py:351(_apply_params)\n",
      "       70    0.000    0.000    0.000    0.000 axis.py:359(<genexpr>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:376(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:389(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:394(<dictcomp>)\n",
      "        3    0.000    0.000    0.008    0.003 axis.py:416(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:438(_get_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:441(_get_text2_transform)\n",
      "        3    0.000    0.000    0.001    0.000 axis.py:444(_apply_tickdir)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:455(update_position)\n",
      "        3    0.000    0.000    0.009    0.003 axis.py:477(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:499(_get_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:502(_get_text2_transform)\n",
      "        3    0.000    0.000    0.001    0.000 axis.py:505(_apply_tickdir)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:516(update_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:543(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:549(locator)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:553(locator)\n",
      "       58    0.000    0.000    0.000    0.000 axis.py:560(formatter)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:564(formatter)\n",
      "        6    0.000    0.000    0.014    0.002 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.018    0.005 axis.py:583(__get__)\n",
      "        2    0.000    0.000    0.004    0.002 axis.py:643(__init__)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:701(isDefault_majfmt)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:709(isDefault_minloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:717(isDefault_minfmt)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:758(get_transform)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_scale)\n",
      "       14    0.000    0.000    0.008    0.001 axis.py:765(_set_scale)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:821(limit_range_for_scale)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:828(_set_autoscale_on)\n",
      "       12    0.000    0.000    0.017    0.001 axis.py:855(clear)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:893(reset_ticks)\n",
      "        8    0.000    0.000    0.016    0.002 axis.py:913(set_tick_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:100(_update_methods)\n",
      "        4    0.000    0.000    0.002    0.001 backend_agg.py:109(draw_path)\n",
      "        8    0.000    0.000    0.005    0.001 backend_agg.py:200(draw_text)\n",
      "       18    0.000    0.000    0.006    0.000 backend_agg.py:221(get_text_width_height_descent)\n",
      "       10    0.000    0.000    0.000    0.000 backend_agg.py:259(get_canvas_width_height)\n",
      "       26    0.000    0.000    0.003    0.000 backend_agg.py:263(_prepare_font)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:277(buffer_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:286(clear)\n",
      "        4    0.000    0.000    0.000    0.000 backend_agg.py:289(option_image_nocomposite)\n",
      "        2    0.000    0.000    0.019    0.009 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.001    0.000 backend_agg.py:405(get_renderer)\n",
      "       26    0.000    0.000    0.000    0.000 backend_agg.py:43(get_hinting_flag)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:435(buffer_rgba)\n",
      "        2    0.000    0.000    0.030    0.015 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.030    0.015 backend_agg.py:462(print_png)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:78(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:1002(set_snap)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1017(get_hatch)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1021(get_hatch_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1028(get_hatch_color)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1036(get_hatch_linewidth)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1040(get_sketch_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1252(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1257(_process)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1284(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 backend_bases.py:1571(_get_renderer)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1581(Done)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1584(_draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1642(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1671(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 backend_bases.py:1693(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:172(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1727(new_manager)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1748(is_saving)\n",
      "       11    0.000    0.000    0.000    0.000 backend_bases.py:179(open_group)\n",
      "       11    0.000    0.000    0.000    0.000 backend_bases.py:186(close_group)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2053(draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2174(_switch_canvas_and_return_print_method)\n",
      "        2    0.000    0.000    0.030    0.015 backend_bases.py:2228(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2229(<dictcomp>)\n",
      "        1    0.000    0.000    0.067    0.067 backend_bases.py:2237(print_figure)\n",
      "        3    0.000    0.000    0.000    0.000 backend_bases.py:2411(mpl_connect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2474(mpl_disconnect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2809(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2840(notify_axes_change)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2846(create_with_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2921(destroy)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2937(set_window_title)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3572(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3577(draw_if_interactive)\n",
      "       16    0.000    0.000    0.000    0.000 backend_bases.py:661(flipy)\n",
      "       18    0.000    0.000    0.001    0.000 backend_bases.py:679(new_gc)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:735(_draw_disabled)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:743(<dictcomp>)\n",
      "       34    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       18    0.000    0.000    0.001    0.000 backend_bases.py:756(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:797(restore)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:824(get_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:839(get_dashes)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:876(get_snap)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:887(set_alpha)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:904(set_antialiased)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:909(set_capstyle)\n",
      "       16    0.000    0.000    0.000    0.000 backend_bases.py:920(set_clip_rectangle)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:924(set_clip_path)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:929(set_dashes)\n",
      "       36    0.000    0.000    0.000    0.000 backend_bases.py:959(set_foreground)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:979(set_joinstyle)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:990(set_linewidth)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:994(set_url)\n",
      "        1    0.000    0.000    0.001    0.001 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.070    0.070 backend_inline.py:72(show)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:742(__iter__)\n",
      "       35    0.001    0.000    0.002    0.000 bezier.py:191(__init__)\n",
      "       35    0.000    0.000    0.000    0.000 bezier.py:195(<listcomp>)\n",
      "       35    0.001    0.000    0.002    0.000 bezier.py:200(__call__)\n",
      "       32    0.000    0.000    0.000    0.000 bezier.py:224(control_points)\n",
      "       67    0.000    0.000    0.000    0.000 bezier.py:234(degree)\n",
      "       32    0.002    0.000    0.007    0.000 bezier.py:239(polynomial_coefficients)\n",
      "       35    0.002    0.000    0.031    0.001 bezier.py:275(axis_aligned_extrema)\n",
      "      268    0.001    0.000    0.002    0.000 colors.py:213(_is_nth_color)\n",
      "       80    0.000    0.000    0.002    0.000 colors.py:218(is_color_like)\n",
      "        6    0.000    0.000    0.000    0.000 colors.py:231(_has_alpha_channel)\n",
      "       80    0.000    0.000    0.002    0.000 colors.py:237(_check_color_like)\n",
      "      188    0.001    0.000    0.003    0.000 colors.py:265(to_rgba)\n",
      "        6    0.000    0.000    0.000    0.000 colors.py:307(_to_rgba_no_colorcycle)\n",
      "       24    0.000    0.000    0.000    0.000 colors.py:384(<genexpr>)\n",
      "       30    0.000    0.000    0.000    0.000 colors.py:394(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:494(to_rgb)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      257    0.001    0.000    0.001    0.000 contextlib.py:104(__init__)\n",
      "  257/244    0.000    0.000    0.004    0.000 contextlib.py:132(__enter__)\n",
      "  257/244    0.001    0.000    0.003    0.000 contextlib.py:141(__exit__)\n",
      "      257    0.000    0.000    0.001    0.000 contextlib.py:287(helper)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:450(_create_exit_wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:460(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:490(enter_context)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:522(_push_cm_exit)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:527(_push_exit_callback)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:543(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:546(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:751(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:754(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:757(__exit__)\n",
      "       18    0.000    0.000    0.000    0.000 copy.py:107(_copy_immutable)\n",
      "      142    0.001    0.000    0.001    0.000 copy.py:259(_reconstruct)\n",
      "      232    0.001    0.000    0.004    0.000 copy.py:66(copy)\n",
      "      142    0.000    0.000    0.000    0.000 copyreg.py:104(__newobj__)\n",
      "       12    0.000    0.000    0.000    0.000 core.py:587(filled)\n",
      "       18    0.000    0.000    0.000    0.000 cycler.py:165(keys)\n",
      "      176    0.000    0.000    0.000    0.000 cycler.py:239(__iter__)\n",
      "       16    0.000    0.000    0.001    0.000 cycler.py:364(by_key)\n",
      "       16    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "       12    0.000    0.000    0.001    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.068    0.006 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       26    0.000    0.000    0.001    0.000 deprecation.py:289(wrapper)\n",
      "    31/17    0.000    0.000    0.003    0.000 deprecation.py:379(wrapper)\n",
      "       84    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    59/51    0.000    0.000    0.021    0.000 deprecation.py:443(wrapper)\n",
      "       10    0.000    0.000    0.000    0.000 dir2.py:54(get_real_method)\n",
      "        1    0.000    0.000    0.070    0.070 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.002    0.002 display_functions.py:45(publish_display_data)\n",
      "        1    0.000    0.000    0.000    0.000 displaypub.py:43(_validate_data)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:105(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:183(encode)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:205(iterencode)\n",
      "      150    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "      150    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:101(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:131(update)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1474(add_gridspec)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1598(sca)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:161(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1650(_process_projection_requirements)\n",
      "        1    0.000    0.000    0.001    0.001 figure.py:1686(get_default_bbox_extra_artists)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1687(<listcomp>)\n",
      "        1    0.000    0.000    0.023    0.023 figure.py:1694(get_tightbbox)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1745(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.000 figure.py:191(_get_draw_artists)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:203(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:204(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2105(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2353(__repr__)\n",
      "        1    0.000    0.000    0.001    0.001 figure.py:2360(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2553(_check_layout_engines_compat)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:2572(set_layout_engine)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:259(get_children)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:2638(get_layout_engine)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2645(_repr_html_)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:2696(axes)\n",
      "      143    0.000    0.000    0.000    0.000 figure.py:2718(_get_dpi)\n",
      "       70    0.000    0.000    0.000    0.000 figure.py:2721(_set_dpi)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:2875(set_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3096(clear)\n",
      "        2    0.000    0.000    0.029    0.014 figure.py:3105(draw)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3199(add_axobserver)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3203(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:402(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:406(get_facecolor)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:434(set_edgecolor)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:444(set_facecolor)\n",
      "      112    0.000    0.000    0.000    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.052    0.052 figure.py:618(add_subplot)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:68(__init__)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:72(as_list)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:747(_add_axes_internal)\n",
      "        1    0.000    0.000    0.052    0.052 figure.py:760(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:80(bubble)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:86(add)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:933(clear)\n",
      "       31    0.000    0.000    0.000    0.000 font_manager.py:1061(get_default_size)\n",
      "       40    0.001    0.000    0.002    0.000 font_manager.py:1200(findfont)\n",
      "      240    0.000    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       26    0.000    0.000    0.002    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       26    0.000    0.000    0.000    0.000 font_manager.py:1490(get_font)\n",
      "       52    0.000    0.000    0.000    0.000 font_manager.py:1515(<genexpr>)\n",
      "       60    0.001    0.000    0.003    0.000 font_manager.py:588(__init__)\n",
      "       74    0.000    0.000    0.002    0.000 font_manager.py:608(_from_any)\n",
      "      279    0.002    0.000    0.003    0.000 font_manager.py:631(__hash__)\n",
      "       87    0.000    0.000    0.002    0.000 font_manager.py:642(__eq__)\n",
      "      305    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "      305    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "       86    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:729(set_style)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       62    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "       90    0.000    0.000    0.001    0.000 font_manager.py:807(set_size)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "      279    0.000    0.000    0.000    0.000 font_manager.py:857(get_math_fontfamily)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:865(set_math_fontfamily)\n",
      "      141    0.000    0.000    0.004    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.068    0.006 formatters.py:217(catch_format_error)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:271(_get_type)\n",
      "        9    0.000    0.000    0.067    0.007 formatters.py:328(__call__)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:356(_check_return)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:371(lookup)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:394(lookup_by_type)\n",
      "       40    0.000    0.000    0.000    0.000 formatters.py:550(_in_deferred_types)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:693(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:828(_check_return)\n",
      "        1    0.000    0.000    0.068    0.068 formatters.py:88(format)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:905(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:942(_check_return)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:951(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "      128    0.000    0.000    0.000    0.000 fromnumeric.py:1777(_ravel_dispatcher)\n",
      "      128    0.000    0.000    0.001    0.000 fromnumeric.py:1781(ravel)\n",
      "       64    0.000    0.000    0.000    0.000 fromnumeric.py:1888(_nonzero_dispatcher)\n",
      "       64    0.000    0.000    0.000    0.000 fromnumeric.py:1892(nonzero)\n",
      "       76    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "       76    0.000    0.000    0.002    0.000 fromnumeric.py:198(reshape)\n",
      "        3    0.000    0.000    0.000    0.000 fromnumeric.py:2183(_sum_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 fromnumeric.py:2188(sum)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 fromnumeric.py:2333(any)\n",
      "       88    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "       88    0.000    0.000    0.002    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "       92    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "       92    0.000    0.000    0.001    0.000 fromnumeric.py:2703(amax)\n",
      "       86    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "       86    0.000    0.000    0.001    0.000 fromnumeric.py:2829(amin)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:3340(_mean_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:3345(mean)\n",
      "       78    0.001    0.000    0.001    0.000 fromnumeric.py:38(_wrapit)\n",
      "      142    0.001    0.000    0.002    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "      293    0.001    0.000    0.004    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "      293    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       14    0.000    0.000    0.000    0.000 function_base.py:1320(diff)\n",
      "        6    0.000    0.000    0.000    0.000 function_base.py:18(_linspace_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 function_base.py:23(linspace)\n",
      "       64    0.000    0.000    0.005    0.000 function_base.py:2301(__call__)\n",
      "       64    0.001    0.000    0.003    0.000 function_base.py:2331(_get_ufunc_and_otypes)\n",
      "       64    0.000    0.000    0.000    0.000 function_base.py:2361(<listcomp>)\n",
      "      192    0.000    0.000    0.000    0.000 function_base.py:2362(<genexpr>)\n",
      "       64    0.001    0.000    0.001    0.000 function_base.py:2366(<listcomp>)\n",
      "       64    0.000    0.000    0.000    0.000 function_base.py:2390(<listcomp>)\n",
      "       64    0.001    0.000    0.005    0.000 function_base.py:2400(_vectorize_call)\n",
      "       64    0.000    0.000    0.001    0.000 function_base.py:2410(<listcomp>)\n",
      "      245    0.000    0.000    0.001    0.000 function_base.py:346(iterable)\n",
      "       64    0.000    0.000    0.000    0.000 function_base.py:5440(_append_dispatcher)\n",
      "       64    0.000    0.000    0.002    0.000 function_base.py:5444(append)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:35(update_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:65(wraps)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:476(__new__)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:558(smallest_normal)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:581(tiny)\n",
      "        9    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        6    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:101(set_width_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:123(set_height_ratios)\n",
      "        1    0.000    0.000    0.001    0.001 gridspec.py:145(get_grid_positions)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:191(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:199(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:228(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 gridspec.py:232(_normalize)\n",
      "        1    0.000    0.000    0.052    0.052 gridspec.py:265(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:329(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:33(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:413(get_subplot_params)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:430(<dictcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:546(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:556(_from_subplot_args)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:604(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:608(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:612(get_gridspec)\n",
      "        1    0.000    0.000    0.001    0.001 gridspec.py:653(get_position)\n",
      "        3    0.000    0.000    0.000    0.000 gridspec.py:75(get_geometry)\n",
      "        9    0.000    0.000    0.000    0.000 hatch.py:182(_validate_hatch_pattern)\n",
      "        4    0.000    0.000    0.000    0.000 hmac.py:117(update)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:122(copy)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:139(_current)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:161(hexdigest)\n",
      "      4/2    0.000    0.000    0.027    0.013 image.py:113(_draw_list_compositing_images)\n",
      "       28    0.000    0.000    0.000    0.000 image.py:123(<genexpr>)\n",
      "        1    0.000    0.000    0.011    0.011 image.py:1567(imsave)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2037(_signature_bound_method)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "      2/1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "      170    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "      307    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "       40    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2836(args)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2859(kwargs)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "       10    0.000    0.000    0.000    0.000 inspect.py:292(isclass)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "       78    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3039(replace)\n",
      "       40    0.001    0.000    0.001    0.000 inspect.py:3075(_bind)\n",
      "       40    0.000    0.000    0.001    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:215(send_multipart)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:287(send_multipart)\n",
      "        2    0.000    0.000    0.001    0.001 iostream.py:480(flush)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:107(json_default)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:38(_ensure_tzinfo)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:52(encode_images)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:77(json_clean)\n",
      "       65    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "       65    0.000    0.000    0.000    0.000 linalg.py:112(_makearray)\n",
      "      198    0.000    0.000    0.000    0.000 linalg.py:117(isComplexType)\n",
      "      129    0.000    0.000    0.000    0.000 linalg.py:130(_realType)\n",
      "       65    0.000    0.000    0.001    0.000 linalg.py:136(_commonType)\n",
      "       65    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "       65    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "       64    0.000    0.000    0.001    0.000 linalg.py:192(_assert_finite)\n",
      "        4    0.000    0.000    0.000    0.000 linalg.py:2338(_norm_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 linalg.py:2342(norm)\n",
      "       65    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 linalg.py:469(inv)\n",
      "       64    0.003    0.000    0.007    0.000 linalg.py:969(eigvals)\n",
      "        6    0.000    0.000    0.002    0.000 lines.py:1026(get_path)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1040(set_antialiased)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1052(set_color)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1064(set_drawstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1099(set_gapcolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1122(set_linewidth)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1137(set_linestyle)\n",
      "       12    0.000    0.000    0.001    0.000 lines.py:1182(set_marker)\n",
      "       54    0.000    0.000    0.000    0.000 lines.py:1196(_set_markercolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1210(set_markeredgecolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1220(set_markerfacecolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1230(set_markerfacecoloralt)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1240(set_markeredgewidth)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1255(set_markersize)\n",
      "       45    0.000    0.000    0.000    0.000 lines.py:1269(set_xdata)\n",
      "       45    0.000    0.000    0.000    0.000 lines.py:1290(set_ydata)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       18    0.001    0.000    0.006    0.000 lines.py:272(__init__)\n",
      "       27    0.000    0.000    0.000    0.000 lines.py:33(_get_dash_pattern)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:538(set_markevery)\n",
      "       59    0.000    0.000    0.000    0.000 lines.py:63(_scale_dashes)\n",
      "       36    0.000    0.000    0.001    0.000 lines.py:635(set_data)\n",
      "        6    0.000    0.000    0.002    0.000 lines.py:654(recache)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:718(set_transform)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       30    0.000    0.000    0.002    0.000 markers.py:228(__init__)\n",
      "       60    0.000    0.000    0.001    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       30    0.000    0.000    0.000    0.000 markers.py:302(_set_fillstyle)\n",
      "       30    0.000    0.000    0.001    0.000 markers.py:327(_set_marker)\n",
      "       18    0.000    0.000    0.000    0.000 markers.py:482(_set_nothing)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:791(_set_tickleft)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:797(_set_tickright)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:805(_set_tickup)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:811(_set_tickdown)\n",
      "        4    0.000    0.000    0.000    0.000 mathtext.py:196(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:1029(unravel_index)\n",
      "      137    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "      220    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "      103    0.000    0.000    0.000    0.000 multiarray.py:740(dot)\n",
      "       67    0.000    0.000    0.000    0.000 multiarray.py:84(empty_like)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:968(ravel_multi_index)\n",
      "       64    0.000    0.000    0.001    0.000 numeric.py:150(ones)\n",
      "       10    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        6    0.000    0.000    0.000    0.000 numeric.py:290(full)\n",
      "       64    0.000    0.000    0.000    0.000 numeric.py:354(_full_like_dispatcher)\n",
      "       64    0.000    0.000    0.001    0.000 numeric.py:358(full_like)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:73(_zeros_like_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:77(zeros_like)\n",
      "       36    0.000    0.000    0.005    0.000 patches.py:262(get_transform)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:273(get_patch_transform)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:288(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:292(get_facecolor)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:304(set_antialiased)\n",
      "       34    0.000    0.000    0.001    0.000 patches.py:317(_set_edgecolor)\n",
      "       22    0.000    0.000    0.000    0.000 patches.py:332(set_edgecolor)\n",
      "       34    0.000    0.000    0.002    0.000 patches.py:343(_set_facecolor)\n",
      "       22    0.000    0.000    0.001    0.000 patches.py:350(set_facecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:361(set_color)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:377(set_alpha)\n",
      "       14    0.000    0.000    0.000    0.000 patches.py:384(set_linewidth)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:399(set_linestyle)\n",
      "        9    0.000    0.000    0.001    0.000 patches.py:434(set_fill)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:456(set_capstyle)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:476(set_joinstyle)\n",
      "        9    0.000    0.000    0.003    0.000 patches.py:48(__init__)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "        8    0.000    0.000    0.003    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "        8    0.000    0.000    0.004    0.001 patches.py:582(draw)\n",
      "        3    0.000    0.000    0.003    0.001 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.001    0.000 patches.py:689(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 patches.py:730(get_path)\n",
      "       29    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       27    0.000    0.000    0.004    0.000 patches.py:742(get_patch_transform)\n",
      "       54    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:768(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:855(set_bounds)\n",
      "       27    0.000    0.000    0.002    0.000 patches.py:876(get_bbox)\n",
      "        3    0.000    0.000    0.001    0.000 patches.py:943(__init__)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:955(get_path)\n",
      "        3    0.000    0.000    0.000    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       25    0.000    0.000    0.000    0.000 path.py:202(_update_values)\n",
      "       35    0.000    0.000    0.000    0.000 path.py:211(vertices)\n",
      "       25    0.000    0.000    0.000    0.000 path.py:225(codes)\n",
      "       10    0.000    0.000    0.000    0.000 path.py:244(simplify_threshold)\n",
      "       10    0.000    0.000    0.000    0.000 path.py:256(should_simplify)\n",
      "        3    0.000    0.000    0.000    0.000 path.py:350(__len__)\n",
      "       38    0.001    0.000    0.003    0.000 path.py:353(iter_segments)\n",
      "       38    0.001    0.000    0.005    0.000 path.py:419(iter_bezier)\n",
      "        3    0.000    0.000    0.000    0.000 path.py:466(cleaned)\n",
      "        3    0.000    0.000    0.002    0.001 path.py:603(get_extents)\n",
      "        5    0.000    0.000    0.000    0.000 path.py:730(unit_rectangle)\n",
      "        6    0.001    0.000    0.001    0.000 path.py:924(arc)\n",
      "       25    0.000    0.000    0.001    0.000 path.py:99(__init__)\n",
      "       28    0.000    0.000    0.000    0.000 pathlib.py:147(splitroot)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:484(_parse_args)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:504(_from_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:523(_format_parsed_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:536(__str__)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:56(parse_parts)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:868(__new__)\n",
      "       64    0.000    0.000    0.000    0.000 polynomial.py:167(_roots_dispatcher)\n",
      "       64    0.003    0.000    0.018    0.000 polynomial.py:171(roots)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:118(_safe_getattr)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:184(group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:201(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:232(text)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:280(begin_group)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:304(end_group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:313(flush)\n",
      "       12    0.000    0.000    0.000    0.000 pretty.py:321(_get_mro)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:355(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:372(pretty)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:417(_in_deferred_types)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:482(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:490(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:495(enq)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:512(remove)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:775(_repr_pprint)\n",
      "        1    0.000    0.000    0.067    0.067 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.053    0.053 pyplot.py:1328(subplots)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        5    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:358(_warn_if_gui_out_of_main_thread)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.070    0.070 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:690(figure)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:887(get_fignums)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:926(close)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:140(validate_bool)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:152(validate_axisbelow)\n",
      "       14    0.000    0.000    0.008    0.001 scale.py:103(set_default_locators_and_formatters)\n",
      "       12    0.000    0.000    0.000    0.000 scale.py:115(get_transform)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:704(scale_factory)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:96(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:198(utcnow)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:272(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:279(extract_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:598(msg_id)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:643(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:647(msg)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:673(sign)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:688(serialize)\n",
      "        1    0.000    0.000    0.001    0.001 session.py:752(send)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:852(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 session.py:92(json_packer)\n",
      "      128    0.000    0.000    0.000    0.000 shape_base.py:19(_atleast_1d_dispatcher)\n",
      "       75    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "       67    0.000    0.000    0.000    0.000 shape_base.py:218(_vhstack_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:223(vstack)\n",
      "      128    0.001    0.000    0.001    0.000 shape_base.py:23(atleast_1d)\n",
      "       64    0.000    0.000    0.002    0.000 shape_base.py:299(hstack)\n",
      "        8    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "        8    0.000    0.000    0.000    0.000 shape_base.py:612(column_stack)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:77(_atleast_2d_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:81(atleast_2d)\n",
      "        5    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "    28/24    0.000    0.000    0.000    0.000 spines.py:202(_ensure_position_is_set)\n",
      "        4    0.000    0.000    0.006    0.002 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.006    0.001 spines.py:221(clear)\n",
      "        4    0.000    0.000    0.000    0.000 spines.py:292(set_position)\n",
      "    28/24    0.000    0.000    0.000    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.002    0.001 spines.py:35(__init__)\n",
      "        4    0.000    0.000    0.003    0.001 spines.py:425(linear_spine)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:538(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:541(from_dict)\n",
      "       28    0.000    0.000    0.000    0.000 spines.py:551(__getattr__)\n",
      "       64    0.000    0.000    0.000    0.000 spines.py:558(__getitem__)\n",
      "       13    0.000    0.000    0.000    0.000 spines.py:584(__iter__)\n",
      "        7    0.000    0.000    0.000    0.000 spines.py:587(__len__)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:416(_broadcast_shape)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:476(_broadcast_arrays_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       18    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "       94    0.000    0.000    0.001    0.000 text.py:1000(set_horizontalalignment)\n",
      "       18    0.000    0.000    0.006    0.000 text.py:101(_get_text_metrics_with_cache_impl)\n",
      "       48    0.000    0.000    0.001    0.000 text.py:1030(set_linespacing)\n",
      "       30    0.000    0.000    0.001    0.000 text.py:1098(set_fontsize)\n",
      "        2    0.000    0.000    0.000    0.000 text.py:1150(set_fontweight)\n",
      "       24    0.000    0.000    0.001    0.000 text.py:1184(set_position)\n",
      "       70    0.000    0.000    0.001    0.000 text.py:1195(set_x)\n",
      "       70    0.000    0.000    0.000    0.000 text.py:1206(set_y)\n",
      "       55    0.000    0.000    0.001    0.000 text.py:1217(set_rotation)\n",
      "       93    0.000    0.000    0.001    0.000 text.py:1249(set_verticalalignment)\n",
      "       71    0.000    0.000    0.000    0.000 text.py:1265(set_text)\n",
      "       56    0.000    0.000    0.001    0.000 text.py:1283(_preprocess_math)\n",
      "       48    0.000    0.000    0.004    0.000 text.py:1307(set_fontproperties)\n",
      "       24    0.000    0.000    0.008    0.000 text.py:132(__init__)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "       97    0.000    0.000    0.000    0.000 text.py:1335(get_usetex)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "       56    0.000    0.000    0.000    0.000 text.py:1351(get_parse_math)\n",
      "       48    0.001    0.000    0.008    0.000 text.py:185(_reset_visual_defaults)\n",
      "       24    0.000    0.000    0.003    0.000 text.py:221(update)\n",
      "       18    0.000    0.000    0.002    0.000 text.py:270(_get_xy_display)\n",
      "       25    0.000    0.000    0.000    0.000 text.py:277(_get_multialignment)\n",
      "       35    0.000    0.000    0.000    0.000 text.py:315(get_rotation)\n",
      "       35    0.000    0.000    0.000    0.000 text.py:323(get_transform_rotates_text)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "       25    0.000    0.000    0.000    0.000 text.py:344(get_rotation_mode)\n",
      "       25    0.002    0.000    0.017    0.001 text.py:363(_get_layout)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:432(<listcomp>)\n",
      "       15    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       13    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        3    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        5    0.000    0.000    0.002    0.000 text.py:596(set_clip_path)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       16    0.001    0.000    0.020    0.001 text.py:738(draw)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:808(get_color)\n",
      "       33    0.000    0.000    0.001    0.000 text.py:893(get_unitless_position)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:901(get_position)\n",
      "      106    0.000    0.000    0.000    0.000 text.py:907(get_text)\n",
      "       33    0.001    0.000    0.014    0.000 text.py:918(get_window_extent)\n",
      "       65    0.000    0.000    0.010    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       62    0.000    0.000    0.002    0.000 text.py:985(set_color)\n",
      "        2    0.000    0.000    0.000    0.000 textpath.py:26(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        4    0.000    0.000    0.000    0.000 threading.py:1161(ident)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:1446(current_thread)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:236(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:264(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:267(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:273(_release_save)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:276(_acquire_restore)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:279(_is_owned)\n",
      "        2    0.000    0.000    0.001    0.000 threading.py:288(wait)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:555(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.001    0.000 threading.py:604(wait)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1651(nonsingular)\n",
      "        2    0.000    0.000    0.000    0.000 ticker.py:1716(__init__)\n",
      "       58    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:1969(__init__)\n",
      "       14    0.000    0.000    0.002    0.000 ticker.py:2010(_validate_steps)\n",
      "       14    0.000    0.000    0.001    0.000 ticker.py:2025(_staircase)\n",
      "       14    0.000    0.000    0.002    0.000 ticker.py:2031(set_params)\n",
      "       28    0.000    0.000    0.000    0.000 ticker.py:259(_set_locator)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:427(__init__)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:454(set_useOffset)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:500(set_useLocale)\n",
      "       14    0.000    0.000    0.003    0.000 ticker.py:533(set_useMathText)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "      306    0.000    0.000    0.000    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:1057(set)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:1087(__init__)\n",
      "      625    0.001    0.000    0.001    0.000 transforms.py:110(__init__)\n",
      "       55    0.000    0.000    0.001    0.000 transforms.py:1109(get_points)\n",
      "       86    0.000    0.000    0.001    0.000 transforms.py:1335(__add__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:1350(_iter_break_from_left_to_right)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:1362(depth)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1376(contains_branch)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1395(contains_branch_seperately)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1413(__sub__)\n",
      "       49    0.000    0.000    0.004    0.000 transforms.py:1467(transform)\n",
      "      189    0.000    0.000    0.001    0.000 transforms.py:157(invalidate)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1588(transform_path)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1597(transform_path_affine)\n",
      "  413/189    0.001    0.000    0.001    0.000 transforms.py:167(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1696(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:1705(__eq__)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1714(set)\n",
      "        8    0.000    0.000    0.000    0.000 transforms.py:1751(<lambda>)\n",
      "        8    0.000    0.000    0.000    0.000 transforms.py:1752(<lambda>)\n",
      "       41    0.000    0.000    0.000    0.000 transforms.py:1753(<lambda>)\n",
      "      332    0.001    0.000    0.001    0.000 transforms.py:1764(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1768(__array__)\n",
      "    13/12    0.000    0.000    0.000    0.000 transforms.py:1772(__eq__)\n",
      "      112    0.000    0.000    0.001    0.000 transforms.py:1777(transform)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1794(transform_path_affine)\n",
      "      162    0.000    0.000    0.000    0.000 transforms.py:1803(get_affine)\n",
      "       30    0.000    0.000    0.000    0.000 transforms.py:1831(is_separable)\n",
      "      115    0.000    0.000    0.001    0.000 transforms.py:1843(transform_affine)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:1864(inverted)\n",
      "      169    0.001    0.000    0.002    0.000 transforms.py:1881(__init__)\n",
      "      165    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      181    0.001    0.000    0.001    0.000 transforms.py:194(set_children)\n",
      "       52    0.000    0.000    0.001    0.000 transforms.py:1978(rotate)\n",
      "       52    0.000    0.000    0.001    0.000 transforms.py:2001(rotate_deg)\n",
      "       54    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       68    0.000    0.000    0.001    0.000 transforms.py:2046(scale)\n",
      "       90    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       51    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:2126(transform)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:2162(__eq__)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2190(__init__)\n",
      "       29    0.000    0.000    0.001    0.000 transforms.py:2281(__init__)\n",
      "       38    0.000    0.000    0.000    0.000 transforms.py:2307(get_matrix)\n",
      "       31    0.000    0.000    0.001    0.000 transforms.py:2323(blended_transform_factory)\n",
      "       77    0.000    0.000    0.001    0.000 transforms.py:2347(__init__)\n",
      "   144/80    0.000    0.000    0.001    0.000 transforms.py:2376(_invalidate_internal)\n",
      "     12/6    0.000    0.000    0.000    0.000 transforms.py:2391(__eq__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2398(_iter_break_from_left_to_right)\n",
      "     12/6    0.000    0.000    0.000    0.000 transforms.py:2404(<lambda>)\n",
      "       79    0.000    0.000    0.000    0.000 transforms.py:2405(<lambda>)\n",
      "       49    0.000    0.000    0.003    0.000 transforms.py:2413(transform_affine)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:2417(transform_non_affine)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:2426(transform_path_non_affine)\n",
      "   102/60    0.001    0.000    0.003    0.000 transforms.py:2436(get_affine)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:246(frozen)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:250(__array__)\n",
      "       86    0.000    0.000    0.001    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       29    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "       78    0.000    0.000    0.000    0.000 transforms.py:2597(get_matrix)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:263(y0)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:2639(__init__)\n",
      "       31    0.000    0.000    0.000    0.000 transforms.py:2651(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:2673(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:2683(get_matrix)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:2822(nonsingular)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:293(p0)\n",
      "       22    0.000    0.000    0.000    0.000 transforms.py:313(xmin)\n",
      "       34    0.000    0.000    0.001    0.000 transforms.py:318(ymin)\n",
      "       22    0.000    0.000    0.000    0.000 transforms.py:323(xmax)\n",
      "       34    0.000    0.000    0.001    0.000 transforms.py:328(ymax)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:343(intervalx)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:352(intervaly)\n",
      "       55    0.000    0.000    0.000    0.000 transforms.py:361(width)\n",
      "       33    0.000    0.000    0.000    0.000 transforms.py:367(height)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:373(size)\n",
      "       23    0.000    0.000    0.000    0.000 transforms.py:379(bounds)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:385(extents)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:474(transformed)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:493(anchored)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:534(shrunk_to_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:619(padded)\n",
      "       15    0.000    0.000    0.000    0.000 transforms.py:624(translated)\n",
      "        3    0.000    0.000    0.002    0.001 transforms.py:649(union)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:654(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:655(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:656(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:657(<listcomp>)\n",
      "      156    0.001    0.000    0.003    0.000 transforms.py:754(__init__)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:784(frozen)\n",
      "       29    0.000    0.000    0.001    0.000 transforms.py:790(unit)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:795(null)\n",
      "       48    0.000    0.000    0.002    0.000 transforms.py:800(from_bounds)\n",
      "       76    0.000    0.000    0.003    0.000 transforms.py:809(from_extents)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:856(update_from_path)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:932(update_from_data_xy)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:988(intervalx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:993(intervaly)\n",
      "       64    0.000    0.000    0.000    0.000 twodim_base.py:236(_diag_dispatcher)\n",
      "       64    0.001    0.000    0.001    0.000 twodim_base.py:240(diag)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:117(_real_dispatcher)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:121(real)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:163(_imag_dispatcher)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:167(imag)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:206(_is_type_dispatcher)\n",
      "       32    0.000    0.000    0.000    0.000 type_check.py:247(isreal)\n",
      "        1    0.000    0.000    0.000    0.000 tz.py:74(utcoffset)\n",
      "     10/6    0.000    0.000    0.000    0.000 units.py:164(get_converter)\n",
      "       96    0.000    0.000    0.001    0.000 units.py:56(_is_natively_supported)\n",
      "       15    0.000    0.000    0.000    0.000 weakref.py:46(__new__)\n",
      "        2    0.000    0.000    0.000    0.000 widgets.py:38(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 zmqshell.py:63(_flush_streams)\n",
      "        1    0.000    0.000    0.000    0.000 zmqshell.py:73(_hooks)\n",
      "        1    0.000    0.000    0.002    0.002 zmqshell.py:80(publish)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.fill}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.map_buffer}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.zip_encoder}\n",
      "      223    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEFC799F90}\n",
      "      298    0.000    0.000    0.001    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       50    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _struct.pack}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _thread.allocate_lock}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method _thread.get_ident}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method binascii.b2a_base64}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.__build_class__}\n",
      "       95    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "      191    0.000    0.000    0.001    0.000 {built-in method builtins.any}\n",
      "      436    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "      205    0.000    0.000    0.000    0.000 {built-in method builtins.delattr}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.dir}\n",
      "        1    0.000    0.000    0.178    0.178 {built-in method builtins.exec}\n",
      "     2267    0.002    0.000    0.002    0.000 {built-in method builtins.getattr}\n",
      "      384    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "  486/312    0.000    0.000    0.002    0.000 {built-in method builtins.hash}\n",
      "      646    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     4139    0.002    0.000    0.003    0.000 {built-in method builtins.isinstance}\n",
      "      507    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "      344    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "  932/922    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.locals}\n",
      "      196    0.000    0.000    0.000    0.000 {built-in method builtins.max}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "  904/852    0.001    0.000    0.006    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.repr}\n",
      "       16    0.000    0.000    0.000    0.000 {built-in method builtins.round}\n",
      "      362    0.000    0.000    0.000    0.000 {built-in method builtins.setattr}\n",
      "        9    0.000    0.000    0.000    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sum}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "      393    0.000    0.000    0.000    0.000 {built-in method math.factorial}\n",
      "       68    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "      115    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.cleanup_path}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "       29    0.000    0.000    0.000    0.000 {built-in method nt.fspath}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "      139    0.001    0.000    0.001    0.000 {built-in method numpy.arange}\n",
      "      300    0.001    0.000    0.001    0.000 {built-in method numpy.array}\n",
      "      801    0.001    0.000    0.001    0.000 {built-in method numpy.asanyarray}\n",
      "      703    0.002    0.000    0.002    0.000 {built-in method numpy.asarray}\n",
      " 1779/792    0.007    0.000    0.033    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "       83    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       64    0.001    0.000    0.001    0.000 {built-in method numpy.frompyfunc}\n",
      "      135    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method scipy.optimize._zeros._brentq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method sys.exc_info}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method sys.getrecursionlimit}\n",
      "      112    0.000    0.000    0.000    0.000 {built-in method sys.intern}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method utcnow}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method zlib.crc32}\n",
      "     1732    0.001    0.000    0.001    0.000 {function RcParams.__getitem__ at 0x0000026B81E739C0}\n",
      "        1    0.000    0.000    0.000    0.000 {method '__array_prepare__' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__contains__' of 'frozenset' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__enter__' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.lock' objects}\n",
      "      142    0.001    0.000    0.001    0.000 {method '__reduce_ex__' of 'object' objects}\n",
      "       15    0.001    0.000    0.001    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'add' of 'set' objects}\n",
      "       65    0.000    0.000    0.001    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'any' of 'numpy.ndarray' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "     1427    0.000    0.000    0.000    0.000 {method 'append' of 'list' objects}\n",
      "       77    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'cleanup' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.OrderedDict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       26    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of '_hashlib.HMAC' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "       72    0.000    0.000    0.000    0.000 {method 'copy' of 'list' objects}\n",
      "      352    0.001    0.000    0.001    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      148    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'dot' of 'numpy.ndarray' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        4    0.002    0.001    0.002    0.001 {method 'draw_path' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'draw_text_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        1    0.011    0.011    0.011    0.011 {method 'encode' of 'ImagingEncoder' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {method 'encode' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'extend' of 'list' objects}\n",
      "       24    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'flush' of '_io.BytesIO' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'format' of 'str' objects}\n",
      "     1441    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'get' of 'mappingproxy' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'get_bitmap_offset' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       26    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'get_width_height' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.StringIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'hexdigest' of '_hashlib.HMAC' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'isidentifier' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'islower' of 'bytes' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'isoformat' of 'datetime.datetime' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.ndarray' objects}\n",
      "     3035    0.001    0.000    0.001    0.000 {method 'items' of 'dict' objects}\n",
      "       36    0.000    0.000    0.000    0.000 {method 'items' of 'mappingproxy' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'join' of 'bytes' objects}\n",
      "       82    0.000    0.000    0.000    0.000 {method 'join' of 'str' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'lower' of 'str' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'lstrip' of 'str' objects}\n",
      "      257    0.001    0.000    0.001    0.000 {method 'match' of 're.Pattern' objects}\n",
      "       55    0.000    0.000    0.000    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "       55    0.000    0.000    0.001    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'move_to_end' of 'collections.OrderedDict' objects}\n",
      "       64    0.000    0.000    0.000    0.000 {method 'nonzero' of 'numpy.ndarray' objects}\n",
      "       70    0.001    0.000    0.001    0.000 {method 'outer' of 'numpy.ufunc' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pixel_access' of 'ImagingCore' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.deque' objects}\n",
      "      302    0.000    0.000    0.000    0.000 {method 'pop' of 'dict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'list' objects}\n",
      "      150    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "      473    0.004    0.000    0.004    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'release' of '_thread.lock' objects}\n",
      "       46    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'replace' of 'datetime.datetime' objects}\n",
      "       86    0.000    0.000    0.000    0.000 {method 'replace' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "      179    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'reverse' of 'list' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rfind' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rpartition' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       26    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       26    0.005    0.000    0.005    0.000 {method 'set_text' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       31    0.000    0.000    0.000    0.000 {method 'setdefault' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'setimage' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'sort' of 'list' objects}\n",
      "        9    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "       53    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'splitlines' of 'str' objects}\n",
      "       58    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "       52    0.000    0.000    0.000    0.000 {method 'tolist' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'update' of '_hashlib.HMAC' objects}\n",
      "      160    0.000    0.000    0.000    0.000 {method 'update' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'upper' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'values' of 'collections.OrderedDict' objects}\n",
      "      307    0.000    0.000    0.000    0.000 {method 'values' of 'dict' objects}\n",
      "       41    0.000    0.000    0.000    0.000 {method 'values' of 'mappingproxy' objects}\n",
      "       16    0.000    0.000    0.000    0.000 {method 'write' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "#NUMBER OF FUNCTION CALLS NEEDED FOR SPIDER DIAGRAM...NEW ONE\n",
    "\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    from matplotlib_venn import venn2\n",
    "    import matplotlib.pyplot as plt\n",
    "    import matplotlib.transforms as transforms\n",
    "\n",
    "\n",
    "    # Define two sets of binary data\n",
    "    list1 = data.predicted_Output\n",
    "    list2 = data.Actual_Output\n",
    "\n",
    "            \n",
    "    # Create sets from the binary data lists\n",
    "    set1 = set([i for i, x in enumerate(list1)if x==1] )\n",
    "    set2 = set([i for i, x in enumerate(list2)if x==1])\n",
    "\n",
    "    set1_zeros = set([i for i, x in enumerate(list1) if x == 0])\n",
    "    set2_zeros = set([i for i, x in enumerate(list2) if x == 0])\n",
    "\n",
    "    \n",
    "    # Create a Venn diagram to visualize the overlap between the two sets\n",
    "    fig, ax = plt.subplots(figsize=(5,4))\n",
    "    venn = venn2([set1,set2],ax=ax )\n",
    "    venn.get_patch_by_id('10').set_color('darkblue')\n",
    "    venn.get_patch_by_id('01').set_color('darkblue')\n",
    "    venn.get_patch_by_id('11').set_color('green')\n",
    "    # Add labels to the diagram\n",
    "    venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(FP))\n",
    "    venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(TN))\n",
    "    venn.get_label_by_id('11').set_text('A & P\\n' + str(TP+FN))\n",
    "\n",
    "\n",
    "    # Show the Venn diagram\n",
    "    plt.show()\n",
    "    pass\n",
    "\n",
    "cProfile.run('my_method()')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping does not exist\n",
      "         263 function calls in 0.001 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.001    0.001 1557581429.py:5(my_method)\n",
      "        1    0.000    0.000    0.001    0.001 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "        4    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _validators.py:226(validate_bool_kwarg)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:324(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1154(needs_i8_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:151(classes_and_not_datetimelike)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:156(<lambda>)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1751(pandas_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:684(is_integer_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 function.py:56(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:11108(_logical_func)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:11178(all)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:11618(all)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:550(_get_axis_number)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        2    0.000    0.000    0.000    0.000 nanops.py:195(_get_fill_value)\n",
      "        2    0.000    0.000    0.000    0.000 nanops.py:217(_maybe_get_mask)\n",
      "        2    0.000    0.000    0.000    0.000 nanops.py:261(_get_values)\n",
      "        2    0.000    0.000    0.000    0.000 nanops.py:350(_na_ok_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 nanops.py:542(nanall)\n",
      "        2    0.000    0.000    0.000    0.000 series.py:4773(_reduce)\n",
      "        2    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "       44    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "       16    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_bool}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "#THEOREM 1 USING NORMAL IF ELSE CONDITION\n",
    "\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    \n",
    "    if(np.logical_and(data.predicted_Output.all(),data.Actual_Output.all())):\n",
    "        flag=1\n",
    "               \n",
    "    else:\n",
    "        flag=0\n",
    "    if(flag==1):\n",
    "        print(\"one-one mapping exists\")\n",
    "    else:\n",
    "        print(\"one-one mapping does not exist\")   \n",
    "    pass\n",
    "\n",
    "cProfile.run('my_method()')    \n",
    "    \n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n",
      "         3830 function calls (3775 primitive calls) in 0.012 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.012    0.012 1309236263.py:3(my_method)\n",
      "        1    0.000    0.000    0.012    0.012 1309236263.py:7(predictive_parity)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(copyto)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isclose)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(nan_to_num)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(reshape)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(sum)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(union1d)\n",
      "       18    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(unique)\n",
      "       18    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       10    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "       17    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.012    0.012 <string>:1(<module>)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "       12    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "       30    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "       12    0.000    0.000    0.001    0.000 _array_api.py:83(unique_values)\n",
      "       30    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:105(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:119(get_shape)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1287(_process_toarray_args)\n",
      "       36    0.000    0.000    0.000    0.000 _base.py:1301(isspmatrix)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:291(nnz)\n",
      "        2    0.000    0.000    0.007    0.003 _classification.py:232(confusion_matrix)\n",
      "        2    0.000    0.000    0.003    0.002 _classification.py:59(_check_targets)\n",
      "       30    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "       30    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        2    0.000    0.000    0.001    0.000 _coo.py:127(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 _coo.py:240(getnnz)\n",
      "        2    0.000    0.000    0.000    0.000 _coo.py:266(_check)\n",
      "        2    0.000    0.000    0.000    0.000 _coo.py:320(toarray)\n",
      "        2    0.000    0.000    0.000    0.000 _data.py:20(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _data.py:23(_get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:39(_amax)\n",
      "        8    0.000    0.000    0.000    0.000 _methods.py:43(_amin)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        4    0.000    0.000    0.000    0.000 _sputils.py:147(get_index_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        6    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "        4    0.000    0.000    0.001    0.000 array_ops.py:231(comparison_op)\n",
      "        4    0.000    0.000    0.000    0.000 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "        4    0.000    0.000    0.003    0.001 arraylike.py:40(__eq__)\n",
      "       18    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       18    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       18    0.000    0.000    0.002    0.000 arraysetops.py:138(unique)\n",
      "       18    0.001    0.000    0.001    0.000 arraysetops.py:323(_unique1d)\n",
      "        2    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 arraysetops.py:898(union1d)\n",
      "        7    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       20    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "       24    0.000    0.000    0.000    0.000 base.py:324(ndim)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5304(__getitem__)\n",
      "        7    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:690(_simple_new)\n",
      "        8    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:870(_reset_identity)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:986(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        8    0.000    0.000    0.000    0.000 blocks.py:500(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:836(_slice)\n",
      "        4    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       16    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       40    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1751(pandas_dtype)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        4    0.000    0.000    0.003    0.001 common.py:57(new_method)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:96(is_bool_indexer)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "        8    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "        8    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "        4    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:198(reshape)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:2183(_sum_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:2188(sum)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       16    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      100    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      100    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       51    0.000    0.000    0.001    0.000 generic.py:5888(__getattr__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        7    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:2522(check_bool_indexer)\n",
      "        7    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        8    0.000    0.000    0.000    0.000 inference.py:188(is_array_like)\n",
      "       31    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "        4    0.000    0.000    0.001    0.000 managers.py:2023(getitem_mgr)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:2054(index)\n",
      "       64    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       40    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        4    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        4    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "       12    0.000    0.000    0.000    0.000 multiclass.py:114(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 multiclass.py:116(<genexpr>)\n",
      "        8    0.000    0.000    0.000    0.000 multiclass.py:126(is_multilabel)\n",
      "        8    0.000    0.000    0.002    0.000 multiclass.py:210(type_of_target)\n",
      "        4    0.000    0.000    0.000    0.000 multiclass.py:23(_unique_multiclass)\n",
      "        2    0.000    0.000    0.002    0.001 multiclass.py:44(unique_labels)\n",
      "        6    0.000    0.000    0.001    0.000 multiclass.py:81(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 numeric.py:115(inferred_type)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:150(ones)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:541(equals)\n",
      "       20    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:956(__getitem__)\n",
      "        4    0.000    0.000    0.001    0.000 series.py:1068(_get_values)\n",
      "        4    0.000    0.000    0.002    0.000 series.py:3194(_construct_result)\n",
      "        8    0.000    0.000    0.002    0.000 series.py:342(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       64    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        8    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       24    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "        4    0.000    0.000    0.003    0.001 series.py:6233(_cmp_method)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       40    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        4    0.000    0.000    0.002    0.000 series.py:966(__getitem__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 type_check.py:400(_nan_to_num_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 type_check.py:404(nan_to_num)\n",
      "        8    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        4    0.000    0.000    0.000    0.000 utils.py:430(check_array_indexer)\n",
      "        4    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "       10    0.000    0.000    0.001    0.000 validation.py:320(_num_samples)\n",
      "        4    0.000    0.000    0.001    0.000 validation.py:383(check_consistent_length)\n",
      "        4    0.000    0.000    0.001    0.000 validation.py:394(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        4    0.000    0.000    0.001    0.000 validation.py:629(check_array)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEFC799F90}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       20    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.any}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.012    0.012 {built-in method builtins.exec}\n",
      "      166    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "      173    0.000    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "       37    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  569/557    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       41    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  142/122    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.max}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method from_iterable}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method numpy.arange}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method numpy.array}\n",
      "       39    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    70/54    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    44/37    0.000    0.000    0.002    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       20    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method scipy.sparse._sparsetools.coo_todense}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "       30    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method 'insert' of 'list' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'pop' of 'set' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "       22    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       18    0.001    0.000    0.001    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_float}\n",
      "       12    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_integer}\n",
      "        7    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       24    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       16    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       11    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        4    0.000    0.000    0.000    0.000 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    import numpy as np\n",
    "    from sklearn.metrics import confusion_matrix\n",
    "\n",
    "    def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "    \n",
    "        # create a confusion matrix for each group\n",
    "        cm_group0 = confusion_matrix(y_true[sensitive_attr ==0], y_pred[sensitive_attr ==0])\n",
    "        cm_group1 = confusion_matrix(y_true[sensitive_attr ==1], y_pred[sensitive_attr ==1])\n",
    "        \n",
    "        # compute the true positive rate and false positive rate for each group\n",
    "        tpr_group0 = cm_group0[1, 1] / np.sum(cm_group0[1, :])\n",
    "        fpr_group0 = cm_group0[0, 1] / np.sum(cm_group0[0, :])\n",
    "        tpr_group1 = cm_group1[1, 1] / np.sum(cm_group1[1, :])\n",
    "        fpr_group1 = cm_group1[0, 1] / np.sum(cm_group1[0, :])\n",
    "        \n",
    "        # check if the true positive rate and false positive rate are equal across groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Predictive parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Predictive parity is not satisfied.\")\n",
    "    predictive_parity(data.Purchased,data.predicted_Output,data.Gender)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalized odds is not satisfied.\n",
      "         3487 function calls (3406 primitive calls) in 0.012 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.012    0.012 346682159.py:3(my_method)\n",
      "        1    0.000    0.000    0.011    0.011 346682159.py:7(equalized_odds)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "       12    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(unique)\n",
      "       12    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.012    0.012 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       26    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       26    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        9    0.000    0.000    0.001    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "       12    0.000    0.000    0.002    0.000 array_ops.py:231(comparison_op)\n",
      "        3    0.000    0.000    0.000    0.000 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "       12    0.000    0.000    0.008    0.001 arraylike.py:40(__eq__)\n",
      "       12    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       12    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       12    0.000    0.000    0.001    0.000 arraysetops.py:138(unique)\n",
      "       12    0.000    0.000    0.001    0.000 arraysetops.py:323(_unique1d)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        6    0.000    0.000    0.001    0.000 arraysetops.py:373(intersect1d)\n",
      "        3    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        3    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       24    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "       12    0.000    0.000    0.001    0.000 blocks.py:2172(new_block)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "       12    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       36    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       72    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "       12    0.000    0.000    0.008    0.001 common.py:57(new_method)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "       12    0.000    0.000    0.001    0.000 config.py:262(__call__)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       24    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       24    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       36    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "       12    0.000    0.000    0.001    0.000 construction.py:493(sanitize_array)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "       12    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        9    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "        9    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       24    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      198    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      198    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       12    0.000    0.000    0.001    0.000 generic.py:5844(__finalize__)\n",
      "       39    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       24    0.000    0.000    0.001    0.000 generic.py:5904(__setattr__)\n",
      "        3    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        3    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       51    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.001    0.001 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.001    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.001    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "       12    0.000    0.000    0.001    0.000 managers.py:1934(from_array)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       24    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "       12    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        9    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "       12    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "       12    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       48    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "       12    0.000    0.000    0.005    0.000 series.py:3194(_construct_result)\n",
      "       12    0.000    0.000    0.004    0.000 series.py:342(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       48    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "       12    0.000    0.000    0.008    0.001 series.py:6233(_cmp_method)\n",
      "       36    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       24    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.001    0.001    0.001    0.001 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "       24    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        9    0.000    0.000    0.000    0.000 {built-in method _operator.eq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       36    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.012    0.012 {built-in method builtins.exec}\n",
      "      228    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       57    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  644/632    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       39    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  202/154    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       39    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    40/19    0.001    0.000    0.002    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       52    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       26    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       36    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       33    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       27    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        3    0.000    0.000    0.000    0.000 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    #equlaized odds\n",
    "    import numpy as np\n",
    "\n",
    "    def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "        # find indices of positive predictions and sensitive attribute values\n",
    "        pos_indices = np.where(y_pred == 1)[0]\n",
    "        sensitive_indices = np.where(sensitive_attr ==0)[0]\n",
    "        # find indices of positive predictions and sensitive attribute values for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr ==0)[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr ==1)[0])\n",
    "        # compute true positive rates for each group\n",
    "        tpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        tpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        # compute false positive rates for each group\n",
    "        fpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        fpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        # check if equalized odds is satisfied for both groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Equalized odds is satisfied.\")\n",
    "        else:\n",
    "            print(\"Equalized odds is not satisfied.\")\n",
    "        return tpr_group0, tpr_group1, fpr_group0, fpr_group1\n",
    "    equalized_odds(data.Purchased,data.predicted_Output,data.Gender)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Demographic parity is not satisfied.\n",
      "         1783 function calls (1744 primitive calls) in 0.005 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.005    0.005 3661779702.py:3(my_method)\n",
      "        1    0.000    0.000    0.005    0.005 3661779702.py:9(demographic_parity)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        2    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unique)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.005    0.005 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "        6    0.000    0.000    0.001    0.000 array_ops.py:231(comparison_op)\n",
      "        5    0.000    0.000    0.000    0.000 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "        6    0.000    0.000    0.003    0.001 arraylike.py:40(__eq__)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:138(unique)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:323(_unique1d)\n",
      "        2    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        2    0.000    0.000    0.001    0.000 arraysetops.py:373(intersect1d)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        6    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       18    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       36    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        6    0.000    0.000    0.003    0.001 common.py:57(new_method)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       18    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "        6    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        1    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "        1    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      106    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      106    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       20    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       26    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        6    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        1    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "        6    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       24    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        6    0.000    0.000    0.002    0.000 series.py:3194(_construct_result)\n",
      "        6    0.000    0.000    0.001    0.000 series.py:342(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       24    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "        6    0.000    0.000    0.003    0.001 series.py:6233(_cmp_method)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "       12    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method _operator.eq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.005    0.005 {built-in method builtins.exec}\n",
      "      123    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  326/320    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "       20    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "   100/76    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       15    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     18/9    0.000    0.000    0.001    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       18    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       13    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       14    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        5    0.000    0.000    0.000    0.000 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    #equlaized odds\n",
    "    import numpy as np\n",
    "    import numpy as np\n",
    "\n",
    "# define function to compute demographic parity\n",
    "    def demographic_parity(y_pred, sensitive_attr):\n",
    "        # find indices of positive predictions and sensitive attribute values\n",
    "        pos_indices = np.where(y_pred == 1)[0]  \n",
    "        sensitive_indices = np.where(sensitive_attr ==0)[0]\n",
    "        # find indices of positive predictions for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr ==0)[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr ==1)[0])\n",
    "        # compute probabilities of positive predictions for each group\n",
    "        prob_pos_group0 = len(pos_indices_group0) / len(np.where(sensitive_attr ==0)[0])\n",
    "        prob_pos_group1 = len(pos_indices_group1) / len(np.where(sensitive_attr ==1)[0])\n",
    "        # check if demographic parity is satisfied\n",
    "        if np.isclose(prob_pos_group0, prob_pos_group1, rtol=1e-3):\n",
    "            print(\"Demographic parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Demographic parity is not satisfied.\")\n",
    "        return prob_pos_group0, prob_pos_group1\n",
    "    demographic_parity(data.predicted_Output,data.Gender)\n",
    "    \n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.2"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "52634da84371cba311ea128a5ea7cdc41ff074b781779e754b270ff9f8153cee"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
