{
 "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>Loan_ID</th>\n",
       "      <th>Gender</th>\n",
       "      <th>Married</th>\n",
       "      <th>Dependents</th>\n",
       "      <th>Education</th>\n",
       "      <th>Self_Employed</th>\n",
       "      <th>ApplicantIncome</th>\n",
       "      <th>CoapplicantIncome</th>\n",
       "      <th>LoanAmount</th>\n",
       "      <th>Loan_Amount_Term</th>\n",
       "      <th>Credit_History</th>\n",
       "      <th>Property_Area</th>\n",
       "      <th>Loan_Status</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>LP001002</td>\n",
       "      <td>Male</td>\n",
       "      <td>No</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>5849</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>LP001003</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>1</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>4583</td>\n",
       "      <td>1508.0</td>\n",
       "      <td>128.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Rural</td>\n",
       "      <td>N</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>LP001005</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>Yes</td>\n",
       "      <td>3000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>66.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>LP001006</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>0</td>\n",
       "      <td>Not Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>2583</td>\n",
       "      <td>2358.0</td>\n",
       "      <td>120.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>LP001008</td>\n",
       "      <td>Male</td>\n",
       "      <td>No</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>6000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>141.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>976</th>\n",
       "      <td>LP002971</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>3+</td>\n",
       "      <td>Not Graduate</td>\n",
       "      <td>Yes</td>\n",
       "      <td>4009</td>\n",
       "      <td>1777.0</td>\n",
       "      <td>113.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>977</th>\n",
       "      <td>LP002975</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>4158</td>\n",
       "      <td>709.0</td>\n",
       "      <td>115.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Urban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>978</th>\n",
       "      <td>LP002980</td>\n",
       "      <td>Male</td>\n",
       "      <td>No</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>3250</td>\n",
       "      <td>1993.0</td>\n",
       "      <td>126.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Semiurban</td>\n",
       "      <td>Y</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>979</th>\n",
       "      <td>LP002986</td>\n",
       "      <td>Male</td>\n",
       "      <td>Yes</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>No</td>\n",
       "      <td>5000</td>\n",
       "      <td>2393.0</td>\n",
       "      <td>158.0</td>\n",
       "      <td>360.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Rural</td>\n",
       "      <td>N</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>980</th>\n",
       "      <td>LP002989</td>\n",
       "      <td>Male</td>\n",
       "      <td>No</td>\n",
       "      <td>0</td>\n",
       "      <td>Graduate</td>\n",
       "      <td>Yes</td>\n",
       "      <td>9200</td>\n",
       "      <td>0.0</td>\n",
       "      <td>98.0</td>\n",
       "      <td>180.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Rural</td>\n",
       "      <td>N</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>981 rows × 13 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Loan_ID Gender Married Dependents     Education Self_Employed  \\\n",
       "0    LP001002   Male      No          0      Graduate            No   \n",
       "1    LP001003   Male     Yes          1      Graduate            No   \n",
       "2    LP001005   Male     Yes          0      Graduate           Yes   \n",
       "3    LP001006   Male     Yes          0  Not Graduate            No   \n",
       "4    LP001008   Male      No          0      Graduate            No   \n",
       "..        ...    ...     ...        ...           ...           ...   \n",
       "976  LP002971   Male     Yes         3+  Not Graduate           Yes   \n",
       "977  LP002975   Male     Yes          0      Graduate            No   \n",
       "978  LP002980   Male      No          0      Graduate            No   \n",
       "979  LP002986   Male     Yes          0      Graduate            No   \n",
       "980  LP002989   Male      No          0      Graduate           Yes   \n",
       "\n",
       "     ApplicantIncome  CoapplicantIncome  LoanAmount  Loan_Amount_Term  \\\n",
       "0               5849                0.0         NaN             360.0   \n",
       "1               4583             1508.0       128.0             360.0   \n",
       "2               3000                0.0        66.0             360.0   \n",
       "3               2583             2358.0       120.0             360.0   \n",
       "4               6000                0.0       141.0             360.0   \n",
       "..               ...                ...         ...               ...   \n",
       "976             4009             1777.0       113.0             360.0   \n",
       "977             4158              709.0       115.0             360.0   \n",
       "978             3250             1993.0       126.0             360.0   \n",
       "979             5000             2393.0       158.0             360.0   \n",
       "980             9200                0.0        98.0             180.0   \n",
       "\n",
       "     Credit_History Property_Area Loan_Status  \n",
       "0               1.0         Urban           Y  \n",
       "1               1.0         Rural           N  \n",
       "2               1.0         Urban           Y  \n",
       "3               1.0         Urban           Y  \n",
       "4               1.0         Urban           Y  \n",
       "..              ...           ...         ...  \n",
       "976             1.0         Urban           Y  \n",
       "977             1.0         Urban           Y  \n",
       "978             NaN     Semiurban           Y  \n",
       "979             1.0         Rural           N  \n",
       "980             1.0         Rural           N  \n",
       "\n",
       "[981 rows x 13 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",
    "dataf=pd.read_csv('loan_sanction.csv')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "dataf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Loan_ID', 'Gender', 'Married', 'Dependents', 'Education',\n",
       "       'Self_Employed', 'ApplicantIncome', 'CoapplicantIncome', 'LoanAmount',\n",
       "       'Loan_Amount_Term', 'Credit_History', 'Property_Area', 'Loan_Status'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataf.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "lec = LabelEncoder()\n",
    "dataf['Loan_ID'] = lec.fit_transform(dataf['Loan_ID'])\n",
    "\n",
    "dataf['Married'] = lec.fit_transform(dataf['Married'])\n",
    "dataf['Dependents']=lec.fit_transform(dataf['Dependents'])\n",
    "dataf['Education'] = lec.fit_transform(dataf['Education'])\n",
    "dataf['Self_Employed'] = lec.fit_transform(dataf['Self_Employed'])\n",
    "dataf['LoanAmount'] = lec.fit_transform(dataf['LoanAmount'])\n",
    "dataf['Loan_Amount_Term']=lec.fit_transform(dataf['Loan_Amount_Term'])\n",
    "\n",
    "dataf['Credit_History'] = lec.fit_transform(dataf['Credit_History'])\n",
    "dataf['Property_Area'] = lec.fit_transform(dataf['Property_Area'])\n",
    "dataf['Loan_Status']=lec.fit_transform(dataf['Loan_Status'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf.Gender.unique"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf.Gender[dataf.Gender== 'Male' ]=1\n",
    "dataf.Gender[dataf.Gender == 'Female']=0\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=dataf['Loan_Status']\n",
    "x=dataf[['Loan_ID', 'Gender', 'Married', 'Dependents', 'Education',\n",
    "       'Self_Employed', 'ApplicantIncome', 'CoapplicantIncome', 'LoanAmount',\n",
    "       'Loan_Amount_Term', 'Credit_History', 'Property_Area']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf.isnull().sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(480, 12)\n",
      "(480, 12)\n",
      "(480,)\n",
      "(480,)\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.5,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": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf['ApplicantIncome']=dataf['ApplicantIncome'].astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(480, 12)\n",
      "(480, 12)\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": 12,
   "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>LinearRegression()</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\">LinearRegression</label><div class=\"sk-toggleable__content\"><pre>LinearRegression()</pre></div></div></div></div></div>"
      ],
      "text/plain": [
       "LinearRegression()"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LinearRegression\n",
    "lr=LinearRegression()\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": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "Predicted_Test_loan= lr.predict(x_test)\n",
    "Predicted_Train_loan=lr.predict(x_train) \n",
    "\n",
    "Predicted_Final_loan=np.concatenate((Predicted_Test_loan,Predicted_Train_loan),axis=0)\n",
    "dataf['Predicted_Final_loan']=Predicted_Final_loan\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "predicted_new=[]\n",
    "for i in range(len(dataf)):\n",
    "    if(Predicted_Final_loan[i]>=np.average(Predicted_Final_loan)):   \n",
    "        predicted_new.append(1)\n",
    "    else:\n",
    "        predicted_new.append(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf['predicted_new']=predicted_new"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1    554\n",
       "0    406\n",
       "Name: predicted_new, dtype: int64"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "VC_PREDICTED=dataf['predicted_new'].value_counts()\n",
    "VC_PREDICTED"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "#CODE TO FIND ACTUAL OUTPUT\n",
    "\n",
    "from scipy.spatial.distance import euclidean\n",
    "distance_sn=[]\n",
    "euclidean_distance_value_LP=[]\n",
    "\n",
    "\n",
    "for i in range(0, len(dataf)):\n",
    "    # Get the Euclidean distance between the first row and the current row\n",
    "    distance_i_LP = euclidean(x.iloc[400], x.iloc[i])\n",
    "    \n",
    "    \n",
    "    \n",
    "    # Add the Euclidean distance to the list of Euclidean distances\n",
    "    euclidean_distance_value_LP.append(np.sqrt(distance_i_LP))\n",
    "\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "Actual_Output_lp=[]\n",
    "for i in range(len(dataf)):\n",
    "    if(euclidean_distance_value_LP[i]>np.average(euclidean_distance_value_LP)):   \n",
    "        Actual_Output_lp.append(1)\n",
    "    else:\n",
    "        Actual_Output_lp.append(0)\n",
    "#Actual_Output=data['Purchased']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Actual_output_loan=dataf['Loan_Status']\n",
    "dataf['Actual_output_loan']=Actual_Output_lp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0    593\n",
       "1    367\n",
       "Name: Actual_output_loan, dtype: int64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "VC_ACTUAL=dataf['Actual_output_loan'].value_counts()\n",
    "VC_ACTUAL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of women (D) in the predicted output is  406\n",
      "count of men (ND) in the predicted output is  554\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",
    "Count_P_D=VC_PREDICTED[0]\n",
    "Count_P_ND=VC_PREDICTED[1]\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": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of women (D) in the actual output is  593\n",
      "count of men (ND) in the actual output is  367\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",
    "Count_A_D=VC_ACTUAL[0]\n",
    "Count_A_ND=VC_ACTUAL[1]\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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "count_men=(dataf.Gender==1).sum()\n",
    "count_men\n",
    "count_women=(dataf.Gender==0).sum()\n",
    "count_women"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "deg_of_bias_women=((Count_P_D-Count_A_D)/count_women)\n",
    "print(\"degree of bias of women\",deg_of_bias_women)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "deg_of_bias_men=((Count_P_ND-Count_A_ND)/count_men)\n",
    "print(\"degree of bias of men\",deg_of_bias_men)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "Count_both_same=0\n",
    "Count_both_diff=0\n",
    "for i in range(len(dataf)):\n",
    "    if((dataf.Predicted_Final_loan.iloc[i]==dataf.Actual_output_loan.iloc[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": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping does not exist\n"
     ]
    }
   ],
   "source": [
    "\n",
    "if(np.logical_and(dataf.predicted_new.all(),dataf.Actual_output_loan.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": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.0\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 3644109245.py:4(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 base.py:925(__len__)\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 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.000    0.000 {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": [
    "#THEOREM2 ---- ACCURACY OF MODEL\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    Accuracy=Count_both_same/len (dataf)\n",
    "    print(\"new model accuracy is\",Accuracy)\n",
    "    pass\n",
    "cProfile.run('my_method()')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5052083333333334\n",
      "         915 function calls (907 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 3752924148.py:4(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",
      "        9    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.001    0.001 _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.002    0.002 _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.001    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",
      "       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.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",
      "        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",
      "       66    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",
      "      120    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": [
    "#original formula for accuracy\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    from sklearn.metrics import accuracy_score\n",
    "    print(accuracy_score(dataf.predicted_new,dataf.Actual_output_loan))\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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du3apWeeeUYNGjRQZmamjDFq0KCBnn32We3atUutW7d2095JnTp10v/+9z/deeedCgsLk91uV/Xq1fXCCy9oy5Ytud5EL0ldunTRzJkz1b9/fzVp0kQhISFKTExUUFCQbrjhBo0dO1Y7d+5U/fr1i1TPxf58lbTHHntM3377rdq2bavAwEBlZGSoatWqevLJJ/XLL7/oqquuyrf//Pnz9fTTT6tu3bo6d+6c9u/fr/3795foKdXJkydr8eLF8vDwyPN+xPbt22vEiBGSpKeeekq7du0qsfHhPJsxpfiJMwAAFzGOFAEAsBCKAABYCEUAACyEIgAAFkIRAAALoQgAgIVQBADAQigCAGAhFOFykydPVs2aNeXn56fmzZvrp59+cndJQKlYvXq17rrrLkVGRspms2nRokXuLgkFIBThUnPnztXw4cMVHR2trVu3qkmTJurUqVOe3wAPXE5SUlLUpEkTTZ482d2loJCY5g0u1bx5c11//fWaNGmSJCkzM1PVq1fXk08+eVF9awPgajabTQsXLtQ999zj7lKQD44U4TLp6enasmWL2rdv71jm4eGh9u3ba/369W6sDAByRyjCZU6cOCG73a6IiIhsyyMiInL9QlwAcDdCEQAAC6EIl6lQoYI8PT0VFxeXbXlcXFye3zkIAO5EKMJlfHx8dN1112nFihWOZZmZmVqxYoVatGjhxsoAIHde7i4Al7fhw4erb9++atasmW644Qa9//77SklJUf/+/d1dGuByp0+f1p49exyP9+3bp23btik8PFw1atRwY2XIC7dkwOUmTZqk8ePH6+jRo2ratKkmTpyo5s2bu7sswOVWrVqldu3a5Vjet29fTZ8+vfQLQoEIRQAALHymCACAhVAEAMBCKAIAYCEUAQCwEIoAAFgIRQAALIQiAAAWQhEul5aWplGjRiktLc3dpQBuwf+BSwc378PlkpKSFBISosTERAUHB7u7HKDU8X/g0sGRIgAAFkIRAABLmfiWjMzMTB0+fFhBQUGy2WzuLqfMSUpKyvYnUNbwf8C9jDFKTk5WZGSkPDzyPxYsE58pHjp0SNWrV3d3GQAANzp48KCqVauWb5sycaQYFBQkSVq05leVCwxyczVA6Us4fMTdJQBuc+ZMivre28GRBfkpE6GYdcq0XGCQygVx5RfKnvRyye4uAXC7wnx8xoU2AABYCEUA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eqpatWqJjAtcTDhSRJlx9OhRx09KSop27NihDh06SJK+++47vfLKK26usGhWrFih3bt3q2vXrqU6bteuXbV7926tWLGiVMcFSgOhiDLJw8NDjRo10uLFi1WnTh1J0scff6yMjAw3VwbAnQhFlGl+fn667777JJ3/Wpndu3crJibG8dljTEyM9u7dq0GDBqlWrVry9fXNcYFJZmamvvzyS91+++2KiIiQj4+PKlasqI4dO2r27Nn5fl5pt9v1wQcf6Nprr1W5cuUUHh6utm3bav78+QXWXpgLbTZu3Kj+/furTp06CggIUHBwsBo2bKgBAwbo+++/z7atdu3aOR7/8zPYfv36OdYV5kKbvXv3avDgwbryyivl7++v4OBgXXvttRozZkye32u6atUqx3iStGfPHg0YMEDVq1eXr6+vqlWrpkceeUSxsbF5jrt7924NGjRIdevWVUBAgPz8/FS9enXdeOONeumll7R79+48+wKSJANcxqKjo40kk98/9cmTJzvarF271uzbt8/x+MsvvzSBgYFGkgkICDDlypUzUVFRjr4nT540N998s6O9JBMSEpLtcZcuXUxaWlqOcc+ePWs6derkaOfh4WFCQ0ONzWYzkszzzz9v2rRpYySZ6OjoHP2joqKMJDNt2rQc6zIyMszQoUOz1VGuXDkTFhbm2H5ISIijfbNmzUxYWJijbURERLafoUOHOtpOmzbNSMr2PFxo7ty5xtfX17GtoKCgbI+rV69ufvvttxz9Vq5c6Wjz448/Op73oKAg4+Xl5VgXGRlpDh06lKP/Dz/8kG0cb29vExoamu05yO15BC5EKOKyVphQHDFihKPNrl27soViYGCgad68udm0aZOj/e+//26MOR88WaHVtGlTs2TJEpOSkmKMMeb06dNmxowZplKlSkaSeeqpp3KM+/TTTxtJxmazmddee80kJiYaY4yJi4szgwcPzhawRQ3F5557zrEPAwYMcNRsjDEJCQlm0aJFpmfPntn6XBhK+ckvFLds2WK8vb2NJNOyZUvz66+/GmOMsdvtZvHixaZKlSpGkqldu7ZJTk7Oc/ywsDDTpUsXs2vXLmOMMWlpaWbu3LkmKCjISDIPPfRQjrFr165tJJmOHTua7du3O5anpqaaHTt2mNGjR+f6XAEXIhRxWSsoFBMTE01kZKSRZMLDw43dbs8WilFRUTle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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=dataf.Actual_output_loan, y_pred=dataf.predicted_new)\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": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "TruePositive=0\n",
    "FalseNegative=0\n",
    "TrueNegative=0\n",
    "FalsePositive=0\n",
    "for i in range(len(dataf)):\n",
    "    if((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==1)):\n",
    "        TruePositive=TruePositive+1\n",
    "    if((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==0)):\n",
    "        TrueNegative= TrueNegative +1\n",
    "    if((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==0)):\n",
    "        FalseNegative=FalseNegative+1\n",
    "    if((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==1)):\n",
    "        FalsePositive=FalsePositive+1\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "259\n",
      "72\n"
     ]
    }
   ],
   "source": [
    "FP_women_count=0\n",
    "FP_men_count=0\n",
    "for i in range(len(dataf)):\n",
    "    if((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==1)):\n",
    "        if(dataf.Gender.iloc[i] ==1):\n",
    "            FP_men_count=FP_men_count+1\n",
    "    if((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==1)):\n",
    "        if(dataf.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": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "121\n",
      "23\n"
     ]
    }
   ],
   "source": [
    "FN_women_count=0\n",
    "FN_men_count=0\n",
    "for i in range(len(dataf)):\n",
    "    if((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==0)):\n",
    "        if(dataf.Gender.iloc[i] ==1):\n",
    "            FN_men_count=FN_men_count+1\n",
    "    if((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==0)):\n",
    "        if(dataf.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": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "398\n",
      "87\n"
     ]
    }
   ],
   "source": [
    "TP_women_count=0\n",
    "TP_men_count=0\n",
    "for i in range(len(dataf)):\n",
    "    if(((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==1))or((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==0)) ):\n",
    "        if(dataf.Gender.iloc[i] ==1):\n",
    "            TP_men_count=TP_men_count+1\n",
    "    if(((dataf.Actual_output_loan.iloc[i]==1) and (dataf.predicted_new.iloc[i]==1))or((dataf.Actual_output_loan.iloc[i]==0) and (dataf.predicted_new.iloc[i]==0)) ):\n",
    "        if(dataf.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": 34,
   "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 = dataf.predicted_new\n",
    "list2 = dataf.Actual_output_loan\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",
    "# 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(FalsePositive))\n",
    "venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(FalseNegative))\n",
    "venn.get_label_by_id('11').set_text('A & P\\n' + str(TruePositive+TrueNegative))\n",
    "\n",
    "\n",
    "# Show the Venn diagram\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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 = dataf.predicted_new\n",
    "list2 = dataf.Actual_output_loan\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(FalsePositive))\n",
    "venn.get_label_by_id('01').set_text('FN\\n' + str(FalseNegative))\n",
    "venn.get_label_by_id('11').set_text('TP+TN\\n' + str(TruePositive + TrueNegative))\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.8), radius=0.15, color='gray', alpha=0.6))\n",
    "ax.text(fp_center_x - 0.3, fp_center_y + 0.8, 'Women: ' + 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.45, fn_center_y + 0.1), radius=0.15, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.58, fn_center_y + 0.08, 'Men: ' + 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, 'Women: ' + 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, 'Men: ' + 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.01, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.2, fn_center_y + 0.6, 'Women: ' + str(TP_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.01, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.2, fn_center_y + 0.3, 'Men: ' + 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": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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du3apWeeeUYNGjRQZmamjDFq0KCBnn32We3atUutW7d2095JnTp10v/+9z/deeedCgsLk91uV/Xq1fXCCy9oy5Ytud5EL0ldunTRzJkz1b9/fzVp0kQhISFKTExUUFCQbrjhBo0dO1Y7d+5U/fr1i1TPxf58lbTHHntM3377rdq2bavAwEBlZGSoatWqevLJJ/XLL7/oqquuyrf//Pnz9fTTT6tu3bo6d+6c9u/fr/3795foKdXJkydr8eLF8vDwyPN+xPbt22vEiBGSpKeeekq7du0qsfHhPJsxpfiJMwAAFzGOFAEAsBCKAABYCEUAACyEIgAAFkIRAAALoQgAgIVQBADAQigCAGAhFOFykydPVs2aNeXn56fmzZvrp59+cndJQKlYvXq17rrrLkVGRspms2nRokXuLgkFIBThUnPnztXw4cMVHR2trVu3qkmTJurUqVOe3wAPXE5SUlLUpEkTTZ482d2loJCY5g0u1bx5c11//fWaNGmSJCkzM1PVq1fXk08+eVF9awPgajabTQsXLtQ999zj7lKQD44U4TLp6enasmWL2rdv71jm4eGh9u3ba/369W6sDAByRyjCZU6cOCG73a6IiIhsyyMiInL9QlwAcDdCEQAAC6EIl6lQoYI8PT0VFxeXbXlcXFye3zkIAO5EKMJlfHx8dN1112nFihWOZZmZmVqxYoVatGjhxsoAIHde7i4Al7fhw4erb9++atasmW644Qa9//77SklJUf/+/d1dGuByp0+f1p49exyP9+3bp23btik8PFw1atRwY2XIC7dkwOUmTZqk8ePH6+jRo2ratKkmTpyo5s2bu7sswOVWrVqldu3a5Vjet29fTZ8+vfQLQoEIRQAALHymCACAhVAEAMBCKAIAYCEUAQCwEIoAAFgIRQAALIQiAAAWQhEul5aWplGjRiktLc3dpQBuwf+BSwc378PlkpKSFBISosTERAUHB7u7HKDU8X/g0sGRIgAAFkIRAABLmfiWjMzMTB0+fFhBQUGy2WzuLqfMSUpKyvYnUNbwf8C9jDFKTk5WZGSkPDzyPxYsE58pHjp0SNWrV3d3GQAANzp48KCqVauWb5sycaQYFBQkSVq05leVCwxyczVA6Us4fMTdJQBuc+ZMivre28GRBfkpE6GYdcq0XGCQygVx5RfKnvRyye4uAXC7wnx8xoU2AABYCEUA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eqpatWqJjAtcTDhSRJlx9OhRx09KSop27NihDh06SJK+++47vfLKK26usGhWrFih3bt3q2vXrqU6bteuXbV7926tWLGiVMcFSgOhiDLJw8NDjRo10uLFi1WnTh1J0scff6yMjAw3VwbAnQhFlGl+fn667777JJ3/Wpndu3crJibG8dljTEyM9u7dq0GDBqlWrVry9fXNcYFJZmamvvzyS91+++2KiIiQj4+PKlasqI4dO2r27Nn5fl5pt9v1wQcf6Nprr1W5cuUUHh6utm3bav78+QXWXpgLbTZu3Kj+/furTp06CggIUHBwsBo2bKgBAwbo+++/z7atdu3aOR7/8zPYfv36OdYV5kKbvXv3avDgwbryyivl7++v4OBgXXvttRozZkye32u6atUqx3iStGfPHg0YMEDVq1eXr6+vqlWrpkceeUSxsbF5jrt7924NGjRIdevWVUBAgPz8/FS9enXdeOONeumll7R79+48+wKSJANcxqKjo40kk98/9cmTJzvarF271uzbt8/x+MsvvzSBgYFGkgkICDDlypUzUVFRjr4nT540N998s6O9JBMSEpLtcZcuXUxaWlqOcc+ePWs6derkaOfh4WFCQ0ONzWYzkszzzz9v2rRpYySZ6OjoHP2joqKMJDNt2rQc6zIyMszQoUOz1VGuXDkTFhbm2H5ISIijfbNmzUxYWJijbURERLafoUOHOtpOmzbNSMr2PFxo7ty5xtfX17GtoKCgbI+rV69ufvvttxz9Vq5c6Wjz448/Op73oKAg4+Xl5VgXGRlpDh06lKP/Dz/8kG0cb29vExoamu05yO15BC5EKOKyVphQHDFihKPNrl27soViYGCgad68udm0aZOj/e+//26MOR88WaHVtGlTs2TJEpOSkmKMMeb06dNmxowZplKlSkaSeeqpp3KM+/TTTxtJxmazmddee80kJiYaY4yJi4szgwcPzhawRQ3F5557zrEPAwYMcNRsjDEJCQlm0aJFpmfPntn6XBhK+ckvFLds2WK8vb2NJNOyZUvz66+/GmOMsdvtZvHixaZKlSpGkqldu7ZJTk7Oc/ywsDDTpUsXs2vXLmOMMWlpaWbu3LkmKCjISDIPPfRQjrFr165tJJmOHTua7du3O5anpqaaHTt2mNGjR+f6XAEXIhRxWSsoFBMTE01kZKSRZMLDw43dbs8WilFRUTle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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         214146 function calls (208151 primitive calls) in 0.466 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.466    0.466 3621249033.py:3(my_method)\n",
      "      184    0.000    0.000    0.004    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.001    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",
      "      230    0.000    0.000    0.003    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.013    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.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "      840    0.002    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",
      "       22    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.466    0.466 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.016    0.016 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.015    0.015 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.015    0.015 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.015    0.015 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",
      "     1265    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.000    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.005    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.002    0.000 __init__.py:65(check_isinstance)\n",
      "     2772    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",
      "     2772    0.004    0.000    0.008    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.005    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.001    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.000    0.000 _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.004    0.001 _axes.py:626(text)\n",
      "        1    0.000    0.000    0.004    0.004 _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.030    0.030 _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.003    0.001 _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.183    0.046 _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.221    0.110 _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.011    0.006 _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: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.133    0.066 _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.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.002    0.002 _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.016    0.016 _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.018    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.004    0.004 _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.001    0.001 _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.001    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.007    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.002    0.002 _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.002    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.001    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.001    0.000 artist.py:1159(update_from)\n",
      "      312    0.004    0.000    0.018    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.015    0.000 artist.py:1216(_internal_update)\n",
      "      244    0.001    0.000    0.017    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.037    0.009 artist.py:1408(_get_tightbbox_for_layout_only)\n",
      "      244    0.000    0.000    0.018    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.009    0.000    0.015    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.035    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.224    0.112 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.005    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.224    0.112 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.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",
      "       84    0.005    0.000    0.174    0.002 axis.py:1252(_update_ticks)\n",
      "       48    0.000    0.000    0.048    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.033    0.001 axis.py:1301(<listcomp>)\n",
      "       20    0.001    0.000    0.210    0.011 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.057    0.014 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.032    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.007    0.002 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.024    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.011    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.001    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.066    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.021    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.004    0.004 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2241(_init)\n",
      "       16    0.001    0.000    0.085    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.003    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.004    0.001 axis.py:2500(_init)\n",
      "        8    0.000    0.000    0.041    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.014    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.001    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.017    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.002    0.000    0.009    0.000 axis.py:455(update_position)\n",
      "        5    0.000    0.000    0.014    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.025    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.006    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.010    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.020    0.002 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.014    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.006    0.001 backend_agg.py:200(draw_text)\n",
      "       24    0.000    0.000    0.009    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",
      "       35    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.091    0.045 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.001    0.000 backend_agg.py:405(get_renderer)\n",
      "       35    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.107    0.053 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.107    0.053 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.107    0.053 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.392    0.392 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.397    0.397 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.006    0.003 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.003    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.005    0.003 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.007    0.000 contextlib.py:141(__exit__)\n",
      "      612    0.001    0.000    0.004    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.005    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.005    0.000 copy.py:227(_deepcopy_dict)\n",
      "       12    0.000    0.000    0.001    0.000 copy.py:237(_deepcopy_method)\n",
      "      128    0.000    0.000    0.000    0.000 copy.py:243(_keep_alive)\n",
      "      481    0.002    0.000    0.006    0.000 copy.py:259(_reconstruct)\n",
      "      144    0.000    0.000    0.000    0.000 copy.py:264(<genexpr>)\n",
      "     1579    0.005    0.000    0.011    0.000 copy.py:66(copy)\n",
      "      457    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.394    0.033 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       35    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.001    0.000    0.031    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.397    0.397 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.003    0.003 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.147    0.147 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.001 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.224    0.112 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.053    0.053 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.053    0.053 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",
      "       49    0.001    0.000    0.003    0.000 font_manager.py:1200(findfont)\n",
      "      294    0.000    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       35    0.000    0.000    0.003    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       35    0.000    0.000    0.001    0.000 font_manager.py:1490(get_font)\n",
      "       70    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",
      "       90    0.000    0.000    0.003    0.000 font_manager.py:608(_from_any)\n",
      "     1059    0.005    0.000    0.009    0.000 font_manager.py:631(__hash__)\n",
      "      345    0.000    0.000    0.006    0.000 font_manager.py:642(__eq__)\n",
      "     1094    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "     1094    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "      102    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       67    0.000    0.000    0.001    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.001    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",
      "     1059    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",
      "      420    0.001    0.000    0.010    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.393    0.033 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.392    0.044 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.394    0.394 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.001    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.008    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.001    0.000    0.001    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.002    0.000    0.002    0.000 getlimits.py:558(smallest_normal)\n",
      "      172    0.000    0.000    0.002    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.053    0.053 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.221    0.110 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.016    0.016 image.py:1567(imsave)\n",
      "        4    0.000    0.000    0.016    0.004 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.002    0.001    0.027    0.013 image.py:328(_make_image)\n",
      "        2    0.000    0.000    0.031    0.015 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.027    0.013 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.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",
      "        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.002    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.001    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.002    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.006    0.001 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.011    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.004    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.009    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.001    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.001    0.000    0.008    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",
      "      230    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.001    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.006    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.009    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.001    0.000    0.005    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.002    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.007    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.001    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.392    0.392 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.056    0.056 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.397    0.397 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.003    0.003 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",
      "        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.009    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.001    0.001 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.001    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.000    0.000    0.000    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.002    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.009    0.002 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.005    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.000 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.001    0.000 text.py:1000(set_horizontalalignment)\n",
      "       24    0.000    0.000    0.009    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.005    0.000 text.py:1307(set_fontproperties)\n",
      "       31    0.000    0.000    0.010    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.010    0.000 text.py:185(_reset_visual_defaults)\n",
      "       34    0.000    0.000    0.004    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.001    0.000 text.py:348(update_from)\n",
      "      160    0.010    0.000    0.061    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.002    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.002    0.000    0.029    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.027    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",
      "        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.001 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.001 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.001    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.003    0.000 ticker.py:2031(set_params)\n",
      "      168    0.014    0.000    0.026    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.003    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.004    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.004    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.048    0.000 ticker.py:696(set_locs)\n",
      "      168    0.003    0.000    0.012    0.000 ticker.py:705(_compute_offset)\n",
      "      168    0.003    0.000    0.009    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.001    0.000 transforms.py:1057(set)\n",
      "       26    0.000    0.000    0.001    0.000 transforms.py:1087(__init__)\n",
      "     1960    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",
      "      130    0.000    0.000    0.002    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.010    0.000 transforms.py:1467(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1568(get_matrix)\n",
      "      424    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",
      "  660/424    0.002    0.000    0.003    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",
      "     1199    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",
      "      307    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",
      "      475    0.002    0.000    0.004    0.000 transforms.py:1881(__init__)\n",
      "      779    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      209    0.001    0.000    0.002    0.000 transforms.py:194(set_children)\n",
      "      186    0.002    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",
      "       92    0.001    0.000    0.001    0.000 transforms.py:2046(scale)\n",
      "      141    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.000    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",
      "       86    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",
      "  467/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",
      "  230/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",
      "      130    0.000    0.000    0.002    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.004    0.000    0.007    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.024    0.000 transforms.py:649(union)\n",
      "       99    0.000    0.000    0.004    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.008    0.000 transforms.py:754(__init__)\n",
      "       49    0.000    0.000    0.002    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.002    0.002 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.003    0.003 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",
      "      625    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFF673D9F90}\n",
      "      392    0.001    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",
      "        4    0.000    0.000    0.000    0.000 {built-in method _thread.allocate_lock}\n",
      "       37    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.466    0.466 {built-in method builtins.exec}\n",
      "     7600    0.006    0.000    0.025    0.000 {built-in method builtins.getattr}\n",
      "      887    0.000    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "1782/1092    0.001    0.000    0.006    0.000 {built-in method builtins.hash}\n",
      "     1714    0.001    0.000    0.001    0.000 {built-in method builtins.id}\n",
      "     6522    0.003    0.000    0.004    0.000 {built-in method builtins.isinstance}\n",
      "      605    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "     1476    0.001    0.000    0.001    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.001    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",
      "      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.015    0.004    0.015    0.004 {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",
      "4456/3297    0.009    0.000    0.060    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",
      "     2778    0.001    0.000    0.001    0.000 {function RcParams.__getitem__ at 0x0000026BE7503920}\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",
      "      457    0.001    0.000    0.002    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",
      "        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",
      "       10    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "     1990    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",
      "       35    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        2    0.000    0.000    0.001    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",
      "     1206    0.004    0.000    0.004    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.003    0.003    0.003    0.003 {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.015    0.015    0.015    0.015 {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",
      "     6364    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",
      "       35    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       24    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",
      "     5970    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.001    0.000    0.001    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.005    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",
      "      415    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",
      "        2    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",
      "       35    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       35    0.008    0.000    0.008    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.003    0.001    0.003    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",
      "      575    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",
      "     1260    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": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    conf_matrix = confusion_matrix(y_true=dataf.Actual_output_loan, y_pred=dataf.predicted_new)\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()\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "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": [
      "         72641 function calls (70604 primitive calls) in 0.201 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 3395053026.py:16(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 3395053026.py:17(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 3395053026.py:19(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 3395053026.py:20(<listcomp>)\n",
      "        1    0.000    0.000    0.201    0.201 3395053026.py:3(my_method)\n",
      "       88    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(all)\n",
      "       92    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amax)\n",
      "       85    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.002    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.001    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.001    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.002    0.000 <__array_function__ internals>:177(full_like)\n",
      "       64    0.000    0.000    0.002    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.000    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.000    0.000    0.001    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.018    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.001    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.201    0.201 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.012    0.012 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",
      "      930    0.002    0.000    0.003    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.001    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.004    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.003    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.001    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.001    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.001    0.000    0.001    0.000 __init__.py:272(_compile)\n",
      "      397    0.002    0.000    0.004    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.002    0.000 __init__.py:550(_get_data_path)\n",
      "      165    0.001    0.000    0.002    0.000 __init__.py:65(check_isinstance)\n",
      "     1748    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",
      "     1748    0.002    0.000    0.005    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.005    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.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",
      "       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.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.048    0.048 _base.py:1262(__clear)\n",
      "        1    0.000    0.000    0.048    0.048 _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.003    0.001 _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.040    0.013 _base.py:2371(add_patch)\n",
      "        3    0.001    0.000    0.039    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.014 _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.020    0.010 _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: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.012    0.006 _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.071    0.071 _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.002    0.002 _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.015    0.015 _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.001    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.001    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",
      "        8    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",
      "        8    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.000    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.001    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.004    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.004    0.004 _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.004    0.004 _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.001    0.001 _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.001    0.001 _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.001    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.003    0.000    0.016    0.000 artist.py:1180(_update_props)\n",
      "       24    0.000    0.000    0.003    0.000 artist.py:1205(update)\n",
      "      175    0.000    0.000    0.013    0.000 artist.py:1216(_internal_update)\n",
      "      155    0.000    0.000    0.015    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.015    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.005    0.000 artist.py:319(stale)\n",
      "       18    0.000    0.000    0.009    0.000 artist.py:352(get_tightbbox)\n",
      "      390    0.001    0.000    0.004    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.030    0.015 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.001    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.030    0.015 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.010    0.005 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.002    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.025    0.004 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.020    0.005 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.001    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.001    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.003    0.003 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.004    0.004 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.004    0.001 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.004    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.013    0.004 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.011    0.004 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.001    0.000    0.019    0.003 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.025    0.006 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",
      "       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.013    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.024    0.002 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.022    0.003 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.003    0.001 backend_agg.py:109(draw_path)\n",
      "        8    0.000    0.000    0.004    0.000 backend_agg.py:200(draw_text)\n",
      "       20    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",
      "       28    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.018    0.009 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.001    0.001 backend_agg.py:405(get_renderer)\n",
      "       28    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.031    0.015 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.031    0.015 backend_agg.py:462(print_png)\n",
      "        2    0.001    0.000    0.001    0.001 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.002    0.002 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.031    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.065    0.065 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.003    0.003 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.069    0.069 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.030    0.001 bezier.py:275(axis_aligned_extrema)\n",
      "      268    0.001    0.000    0.003    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.001    0.000    0.002    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.001    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",
      "      144    0.001    0.000    0.001    0.000 copy.py:259(_reconstruct)\n",
      "      234    0.001    0.000    0.004    0.000 copy.py:66(copy)\n",
      "      144    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.001    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.066    0.006 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       28    0.000    0.000    0.001    0.000 deprecation.py:289(wrapper)\n",
      "    31/17    0.000    0.000    0.004    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.030    0.001 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.069    0.069 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.003    0.003 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.016    0.016 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.001 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.003    0.003 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.030    0.015 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.071    0.071 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.072    0.072 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",
      "       42    0.001    0.000    0.003    0.000 font_manager.py:1200(findfont)\n",
      "      252    0.000    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       28    0.000    0.000    0.002    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       28    0.000    0.000    0.000    0.000 font_manager.py:1490(get_font)\n",
      "       56    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",
      "       76    0.000    0.000    0.002    0.000 font_manager.py:608(_from_any)\n",
      "      281    0.001    0.000    0.002    0.000 font_manager.py:631(__hash__)\n",
      "       87    0.000    0.000    0.001    0.000 font_manager.py:642(__eq__)\n",
      "      309    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "      309    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "       88    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       60    0.000    0.000    0.001    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.001    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",
      "      281    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",
      "      143    0.000    0.000    0.004    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.066    0.005 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.065    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.066    0.066 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.001    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.001    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",
      "       85    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "       85    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.000    0.000    0.001    0.000 fromnumeric.py:38(_wrapit)\n",
      "      142    0.001    0.000    0.003    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "      292    0.001    0.000    0.004    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "      292    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.001    0.000    0.001    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.000    0.000    0.000    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.004    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.001    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.072    0.072 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.002    0.002 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.014 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.012    0.012 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.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.002    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.004    0.000    0.008    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.001    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.002    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.001    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.008    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.003    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.002    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.001    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.004    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "        8    0.000    0.000    0.005    0.001 patches.py:582(draw)\n",
      "        3    0.000    0.000    0.002    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.001    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.002    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.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.002    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.002    0.000 pathlib.py:868(__new__)\n",
      "       64    0.000    0.000    0.000    0.000 polynomial.py:167(_roots_dispatcher)\n",
      "       64    0.002    0.000    0.017    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.065    0.065 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.075    0.075 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.003    0.003 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.069    0.069 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.003    0.003 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.013    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.000    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.001    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.009    0.002 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.008    0.002 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.001    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.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",
      "       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",
      "       20    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.000    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.000    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.011    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.010    0.000 text.py:185(_reset_visual_defaults)\n",
      "       24    0.000    0.000    0.004    0.000 text.py:221(update)\n",
      "       18    0.000    0.000    0.001    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.014    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.001    0.000 text.py:596(set_clip_path)\n",
      "        5    0.000    0.000    0.001    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.019    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.000    0.000    0.009    0.000 text.py:918(get_window_extent)\n",
      "       65    0.000    0.000    0.009    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       62    0.000    0.000    0.003    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.001 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.001 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.005    0.000 ticker.py:1969(__init__)\n",
      "       14    0.001    0.000    0.003    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.005    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.005    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.005    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.005    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.001    0.000 transforms.py:1057(set)\n",
      "       27    0.000    0.000    0.001    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.001    0.000 transforms.py:1376(contains_branch)\n",
      "        3    0.000    0.000    0.001    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.003    0.000 transforms.py:1467(transform)\n",
      "      189    0.000    0.000    0.002    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.002    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.001    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.001    0.000 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.002    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.002    0.002 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.003    0.003 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",
      "      225    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFF673D9F90}\n",
      "      298    0.001    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",
      "       30    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.201    0.201 {built-in method builtins.exec}\n",
      "     2270    0.002    0.000    0.002    0.000 {built-in method builtins.getattr}\n",
      "      386    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "  488/314    0.000    0.000    0.001    0.000 {built-in method builtins.hash}\n",
      "      646    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     4151    0.002    0.000    0.003    0.000 {built-in method builtins.isinstance}\n",
      "      509    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.001    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.003    0.000    0.003    0.000 {built-in method numpy.asarray}\n",
      " 1778/791    0.007    0.000    0.034    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",
      "     1748    0.001    0.000    0.001    0.000 {function RcParams.__getitem__ at 0x0000026BE7503920}\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",
      "      144    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",
      "     1429    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",
      "       28    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.003    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.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",
      "        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",
      "     1445    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",
      "       28    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       20    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",
      "     3036    0.002    0.000    0.002    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",
      "      472    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",
      "       28    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       28    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",
      "      162    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": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    \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 = dataf.predicted_new\n",
    "    list2 = dataf.Actual_output_loan\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",
    "\n",
    "    # Add labels to the diagram\n",
    "    venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(FalsePositive))\n",
    "    venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(TrueNegative))\n",
    "    venn.get_label_by_id('11').set_text('A & P\\n' + str(TruePositive+FalseNegative))\n",
    "\n",
    "\n",
    "    # Show the Venn diagram\n",
    "    plt.show()\n",
    "\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping does not exist\n",
      "         263 function calls in 0.002 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.002    0.002 846823239.py:5(my_method)\n",
      "        1    0.000    0.000    0.002    0.002 <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.001    0.000 generic.py:11108(_logical_func)\n",
      "        2    0.000    0.000    0.001    0.000 generic.py:11178(all)\n",
      "        2    0.000    0.000    0.001    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.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",
      "        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.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",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.002    0.002 {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.001    0.001 {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(dataf.predicted_new.all(),dataf.Actual_output_loan.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": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n",
      "         3811 function calls (3756 primitive calls) in 0.015 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.015    0.015 4137023581.py:3(my_method)\n",
      "        1    0.000    0.000    0.015    0.015 4137023581.py:4(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",
      "       16    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.015    0.015 <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.004    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.001    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.001    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:5464(equals)\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:839(is_)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:870(_reset_identity)\n",
      "       20    0.000    0.000    0.000    0.000 base.py:925(__len__)\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.001    0.000    0.001    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.004    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.001    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.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",
      "        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.002    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.001    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.001    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.002    0.000 series.py:1068(_get_values)\n",
      "        4    0.000    0.000    0.002    0.001 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.003    0.001 series.py:966(__getitem__)\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",
      "        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 0x00007FFF673D9F90}\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.015    0.015 {built-in method builtins.exec}\n",
      "      166    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "      172    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",
      "  560/548    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.001    0.001 {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.000    0.000    0.000    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",
      "        8    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",
      "       12    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",
    "    def predictive_parity(y_true, y_pred, sensitive_attr):\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",
    "        # 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",
    "        # 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(dataf.Actual_output_loan,dataf.predicted_new,dataf.Gender)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalized odds is not satisfied.\n",
      "         3226 function calls (3150 primitive calls) in 0.009 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.009    0.009 2965255660.py:3(my_method)\n",
      "        1    0.000    0.000    0.009    0.009 2965255660.py:4(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",
      "       11    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.009    0.009 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       24    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       24    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "       12    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.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "       11    0.000    0.000    0.002    0.000 array_ops.py:231(comparison_op)\n",
      "        2    0.000    0.000    0.001    0.000 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "       11    0.000    0.000    0.006    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",
      "       11    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       22    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "       11    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "       44    0.000    0.000    0.000    0.000 base.py:925(__len__)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "       11    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       33    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       66    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",
      "       11    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "       11    0.000    0.000    0.006    0.001 common.py:57(new_method)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       22    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       22    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       33    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "       11    0.000    0.000    0.001    0.000 construction.py:493(sanitize_array)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "       11    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",
      "       11    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",
      "       11    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "       11    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",
      "       11    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       22    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      180    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      180    0.000    0.000    0.001    0.000 generic.py:45(_instancecheck)\n",
      "       11    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       36    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       22    0.000    0.000    0.000    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",
      "       47    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",
      "       11    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       22    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "       11    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",
      "       11    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",
      "       11    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",
      "       11    0.000    0.000    0.003    0.000 series.py:3194(_construct_result)\n",
      "       11    0.000    0.000    0.003    0.000 series.py:342(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "       11    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       44    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "       11    0.000    0.000    0.006    0.001 series.py:6233(_cmp_method)\n",
      "       33    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       22    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       11    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",
      "       22    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",
      "       33    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.009    0.009 {built-in method builtins.exec}\n",
      "      208    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       11    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       53    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  592/581    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       36    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  187/143    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",
      "       39    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "       11    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    39/18    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",
      "       48    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       24    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       11    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",
      "        2    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",
      "        2    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",
      "       11    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",
      "       33    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       31    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       25    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        2    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",
    "    def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "        pos_indices = np.where(y_pred == 1)[0]\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",
    "        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",
    "        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",
    "        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(dataf.Actual_output_loan,dataf.predicted_new,dataf.Gender)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Demographic parity is not satisfied.\n",
      "         1522 function calls (1488 primitive calls) in 0.008 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.007    0.007 658928851.py:11(demographic_parity)\n",
      "        1    0.000    0.000    0.007    0.007 658928851.py:3(my_method)\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.001    0.001 <__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",
      "        5    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.008    0.008 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        6    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",
      "        5    0.000    0.000    0.001    0.000 array_ops.py:231(comparison_op)\n",
      "        4    0.000    0.000    0.001    0.000 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "        5    0.000    0.000    0.005    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",
      "        5    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        5    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "       20    0.000    0.000    0.000    0.000 base.py:925(__len__)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        5    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       30    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",
      "        5    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        5    0.000    0.000    0.005    0.001 common.py:57(new_method)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       10    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       10    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       15    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        5    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",
      "        5    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",
      "        5    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        5    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",
      "        5    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       10    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "       88    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "       88    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        5    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       17    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       10    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",
      "       22    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",
      "        5    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       10    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        5    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",
      "        5    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",
      "        5    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.001    0.001 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "        5    0.000    0.000    0.003    0.001 series.py:3194(_construct_result)\n",
      "        5    0.000    0.000    0.002    0.000 series.py:342(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "        5    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "        5    0.000    0.000    0.005    0.001 series.py:6233(_cmp_method)\n",
      "       15    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       10    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        5    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",
      "       10    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",
      "       15    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.008    0.008 {built-in method builtins.exec}\n",
      "      103    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       26    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  274/269    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "    85/65    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",
      "        5    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     17/8    0.001    0.000    0.002    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",
      "       24    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        5    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",
      "        4    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",
      "        4    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",
      "        5    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",
      "       15    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       11    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       12    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        4    0.001    0.000    0.001    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",
    "#demographic parity \n",
    "# import necessary packages\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(dataf.predicted_new,dataf.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
}
