{
 "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>Unnamed: 0</th>\n",
       "      <th>Age</th>\n",
       "      <th>Sex</th>\n",
       "      <th>Job</th>\n",
       "      <th>Housing</th>\n",
       "      <th>Saving accounts</th>\n",
       "      <th>Checking account</th>\n",
       "      <th>Credit amount</th>\n",
       "      <th>Duration</th>\n",
       "      <th>Purpose</th>\n",
       "      <th>Risk</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>67</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>own</td>\n",
       "      <td>NaN</td>\n",
       "      <td>little</td>\n",
       "      <td>1169</td>\n",
       "      <td>6</td>\n",
       "      <td>radio/TV</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>female</td>\n",
       "      <td>2</td>\n",
       "      <td>own</td>\n",
       "      <td>little</td>\n",
       "      <td>moderate</td>\n",
       "      <td>5951</td>\n",
       "      <td>48</td>\n",
       "      <td>radio/TV</td>\n",
       "      <td>bad</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>49</td>\n",
       "      <td>male</td>\n",
       "      <td>1</td>\n",
       "      <td>own</td>\n",
       "      <td>little</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2096</td>\n",
       "      <td>12</td>\n",
       "      <td>education</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>45</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>free</td>\n",
       "      <td>little</td>\n",
       "      <td>little</td>\n",
       "      <td>7882</td>\n",
       "      <td>42</td>\n",
       "      <td>furniture/equipment</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>53</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>free</td>\n",
       "      <td>little</td>\n",
       "      <td>little</td>\n",
       "      <td>4870</td>\n",
       "      <td>24</td>\n",
       "      <td>car</td>\n",
       "      <td>bad</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>995</th>\n",
       "      <td>995</td>\n",
       "      <td>31</td>\n",
       "      <td>female</td>\n",
       "      <td>1</td>\n",
       "      <td>own</td>\n",
       "      <td>little</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1736</td>\n",
       "      <td>12</td>\n",
       "      <td>furniture/equipment</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>996</th>\n",
       "      <td>996</td>\n",
       "      <td>40</td>\n",
       "      <td>male</td>\n",
       "      <td>3</td>\n",
       "      <td>own</td>\n",
       "      <td>little</td>\n",
       "      <td>little</td>\n",
       "      <td>3857</td>\n",
       "      <td>30</td>\n",
       "      <td>car</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>997</th>\n",
       "      <td>997</td>\n",
       "      <td>38</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>own</td>\n",
       "      <td>little</td>\n",
       "      <td>NaN</td>\n",
       "      <td>804</td>\n",
       "      <td>12</td>\n",
       "      <td>radio/TV</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>998</th>\n",
       "      <td>998</td>\n",
       "      <td>23</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>free</td>\n",
       "      <td>little</td>\n",
       "      <td>little</td>\n",
       "      <td>1845</td>\n",
       "      <td>45</td>\n",
       "      <td>radio/TV</td>\n",
       "      <td>bad</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>999</th>\n",
       "      <td>999</td>\n",
       "      <td>27</td>\n",
       "      <td>male</td>\n",
       "      <td>2</td>\n",
       "      <td>own</td>\n",
       "      <td>moderate</td>\n",
       "      <td>moderate</td>\n",
       "      <td>4576</td>\n",
       "      <td>45</td>\n",
       "      <td>car</td>\n",
       "      <td>good</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1000 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0  Age     Sex  Job Housing Saving accounts Checking account  \\\n",
       "0             0   67    male    2     own             NaN           little   \n",
       "1             1   22  female    2     own          little         moderate   \n",
       "2             2   49    male    1     own          little              NaN   \n",
       "3             3   45    male    2    free          little           little   \n",
       "4             4   53    male    2    free          little           little   \n",
       "..          ...  ...     ...  ...     ...             ...              ...   \n",
       "995         995   31  female    1     own          little              NaN   \n",
       "996         996   40    male    3     own          little           little   \n",
       "997         997   38    male    2     own          little              NaN   \n",
       "998         998   23    male    2    free          little           little   \n",
       "999         999   27    male    2     own        moderate         moderate   \n",
       "\n",
       "     Credit amount  Duration              Purpose  Risk  \n",
       "0             1169         6             radio/TV  good  \n",
       "1             5951        48             radio/TV   bad  \n",
       "2             2096        12            education  good  \n",
       "3             7882        42  furniture/equipment  good  \n",
       "4             4870        24                  car   bad  \n",
       "..             ...       ...                  ...   ...  \n",
       "995           1736        12  furniture/equipment  good  \n",
       "996           3857        30                  car  good  \n",
       "997            804        12             radio/TV  good  \n",
       "998           1845        45             radio/TV   bad  \n",
       "999           4576        45                  car  good  \n",
       "\n",
       "[1000 rows x 11 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",
    "dataf1=pd.read_csv('german_credit_data.csv')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "dataf1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Unnamed: 0', 'Age', 'Sex', 'Job', 'Housing', 'Saving accounts',\n",
       "       'Checking account', 'Credit amount', 'Duration', 'Purpose', 'Risk'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataf1.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "lec = LabelEncoder()\n",
    "dataf1['Housing'] = lec.fit_transform(dataf1['Housing'])\n",
    "dataf1['Saving accounts'] = lec.fit_transform(dataf1['Saving accounts'])\n",
    "dataf1['Checking account'] = lec.fit_transform(dataf1['Checking account'])\n",
    "dataf1['Purpose'] = lec.fit_transform(dataf1['Purpose'])\n",
    "\n",
    "dataf1.Risk[dataf1.Risk=='good']=1\n",
    "dataf1.Risk[dataf1.Risk=='bad']=0\n",
    "\n",
    "dataf1.Sex[dataf1.Sex=='male']=1\n",
    "dataf1.Sex[dataf1.Sex=='female']=0\n",
    "dataf1.Sex[dataf1.Sex=='unknown']=2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf1.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf1['Risk'].astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf1.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=dataf1['Risk']\n",
    "x=dataf1[['Age', 'Sex', 'Job', 'Housing', 'Saving accounts',\n",
    "       'Checking account', 'Credit amount', 'Duration', 'Purpose']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=y.astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf1.isnull().sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(900, 9)\n",
      "(100, 9)\n",
      "(900,)\n",
      "(100,)\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.1,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": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(900, 9)\n",
      "(100, 9)\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>LogisticRegression(random_state=0)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-1\" type=\"checkbox\" checked><label for=\"sk-estimator-id-1\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">LogisticRegression</label><div class=\"sk-toggleable__content\"><pre>LogisticRegression(random_state=0)</pre></div></div></div></div></div>"
      ],
      "text/plain": [
       "LogisticRegression(random_state=0)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LogisticRegression\n",
    "lr=LogisticRegression(random_state=0)\n",
    "lr.fit(x_train,y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_prediction=lr.predict(x_test)\n",
    "y_prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "Predicted_Test_credit= lr.predict(x_test)\n",
    "Predicted_Train_credit=lr.predict(x_train) \n",
    "\n",
    "Predicted_Final_credit=np.concatenate((Predicted_Train_credit,Predicted_Test_credit),axis=0)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataf1['Predicted_Final_credit']=Predicted_Final_credit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "vc_pred=dataf1['Predicted_Final_credit'].value_counts()\n",
    "vc_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "#CODE TO FIND ACTUAL OUTPUT\n",
    "\n",
    "from scipy.spatial.distance import euclidean\n",
    "distance_gc=[]\n",
    "euclidean_distance_value_gc=[]\n",
    "\n",
    "\n",
    "for i in range(0, len(dataf1)):\n",
    "    # Get the Euclidean distance between the first row and the current row\n",
    "    distance_i_gc = euclidean(x.iloc[0, :-1], x.iloc[i, :-1])\n",
    "    \n",
    "   \n",
    "    # Add the Euclidean distance to the list of Euclidean distances\n",
    "    euclidean_distance_value_gc.append(np.sqrt(distance_i_gc))\n",
    "\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "Actual_Output_gc=[]\n",
    "for i in range(len(dataf1)):\n",
    "    if(euclidean_distance_value_gc[i] <np.ceil(np.average(euclidean_distance_value_gc))):   \n",
    "        Actual_Output_gc.append(0)\n",
    "    else:\n",
    "        Actual_Output_gc.append(1)\n",
    "#Actual_Output=data['Purchased']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Actual_output_credit=dataf1['Risk']\n",
    "dataf1['Actual_output_credit']=Actual_Output_gc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "vc_actual=dataf1['Actual_output_credit'].value_counts()\n",
    "vc_actual"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of  (D) in the actual output is  192\n",
      "count of  (ND) in the actual output is  808\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in actual output\n",
    "Count_PD=0\n",
    "Count_PND=0    \n",
    "Count_PD=vc_pred[0]\n",
    "Count_PND=vc_pred[1]\n",
    "print(\"count of  (D) in the actual output is \",Count_PD)\n",
    "print(\"count of  (ND) in the actual output is \",Count_PND)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of  (D) in the expected output is  588\n",
      "count of (ND) in the expected output is  412\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in expected output\n",
    "Count_AD=0\n",
    "Count_AND=0\n",
    "Count_AD=vc_actual[0]\n",
    "Count_AND=vc_actual[1]\n",
    "print(\"count of  (D) in the expected output is \",Count_AD)\n",
    "print(\"count of (ND) in the expected output is \",Count_AND)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "588\n",
      "412\n"
     ]
    }
   ],
   "source": [
    "average_age = np.average(dataf1['Age'])\n",
    "count_of_young = (dataf1['Age'] < average_age).sum()\n",
    "print(count_of_young)\n",
    "count_of_old=(dataf1['Age'] > average_age).sum()\n",
    "print(count_of_old)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias of D class -0.673469387755102\n"
     ]
    }
   ],
   "source": [
    "degree_of_bias=(Count_PD-Count_AD)/count_of_young\n",
    "print(\"degree of bias of D class\",degree_of_bias)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "deg of bias of ND class 0.9611650485436893\n"
     ]
    }
   ],
   "source": [
    "degree_of_bias1=((Count_PND-Count_AND)/count_of_old)\n",
    "print(\"deg of bias of ND class\",degree_of_bias1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping doesnot exiats\n",
      "         111 function calls (109 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 1818713774.py:3(my_method)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(array_equal)\n",
      "        1    0.000    0.000    0.001    0.001 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:61(_all)\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",
      "        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",
      "        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",
      "        6    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2403(_array_equal_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2407(array_equal)\n",
      "        2    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        2    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.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "      5/3    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\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 '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",
      "        1    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_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",
    "    \n",
    "    #for i in range(len(dataf1)):\n",
    "    if np.array_equal(dataf1.Predicted_Final_credit, dataf1.Actual_output_credit):\n",
    "        f = 1\n",
    "    else:\n",
    "        f = 0\n",
    "\n",
    "    if(f==1):\n",
    "        print(\"one-one mapping exists\")\n",
    "    else:\n",
    "        print(\"one-one mapping doesnot exiats\")\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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_pred=dataf1.Predicted_Final_credit,y_true=dataf1.Actual_output_credit)\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=i, y=j,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": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "True_Positive=0\n",
    "False_Negative=0\n",
    "True_Negative=0\n",
    "False_Positive=0\n",
    "for i in range(len(dataf1)):\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==1)):\n",
    "        True_Positive=True_Positive+1\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==0)):\n",
    "        True_Negative=True_Negative+1\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==0)):\n",
    "        False_Negative=False_Negative+1\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==1)):\n",
    "        False_Positive=False_Positive+1\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "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 = dataf1.Predicted_Final_credit\n",
    "list2 = dataf1.Actual_output_credit        \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",
    "# 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('FP\\n' + str(False_Positive))\n",
    "venn.get_label_by_id('01').set_text('FN\\n' + str(False_Negative))\n",
    "venn.get_label_by_id('11').set_text('TP\\n' + str(True_Positive+ True_Negative))\n",
    "# Show the Venn diagram\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "202\n",
      "277\n"
     ]
    }
   ],
   "source": [
    "FP_young_count=0\n",
    "FP_old_count=0\n",
    "for i in range(len(dataf1)):\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==1)):\n",
    "        if(dataf1.Age.iloc[i] > np.average(dataf1.Age)):\n",
    "            FP_old_count=FP_old_count+1\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==1)):\n",
    "        if(dataf1.Age.iloc[i] <=np.average(dataf1.Age)):\n",
    "            FP_young_count=FP_young_count+1\n",
    "print(FP_old_count)\n",
    "print(FP_young_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "32\n",
      "51\n"
     ]
    }
   ],
   "source": [
    "FN_young_count=0\n",
    "FN_old_count=0\n",
    "for i in range(len(dataf1)):\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==0)):\n",
    "        if(dataf1.Age.iloc[i] > np.average(dataf1.Age)):\n",
    "            FN_old_count=FN_old_count+1\n",
    "    if((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==0)):\n",
    "        if(dataf1.Age.iloc[i] <=np.average(dataf1.Age)):\n",
    "            FN_young_count=FN_young_count+1\n",
    "print(FN_old_count)\n",
    "print(FN_young_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "178\n",
      "260\n"
     ]
    }
   ],
   "source": [
    "TP_young_count=0\n",
    "TP_old_count=0\n",
    "for i in range(len(dataf1)):\n",
    "    if(((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==1)) or ((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==0)) ):\n",
    "        if(dataf1.Age.iloc[i] > np.average(dataf1.Age)):\n",
    "            TP_old_count=TP_old_count+1\n",
    "    if(((dataf1.Actual_output_credit.iloc[i]==1) and (dataf1.Predicted_Final_credit.iloc[i]==1)) or ((dataf1.Actual_output_credit.iloc[i]==0) and (dataf1.Predicted_Final_credit.iloc[i]==0)) ):\n",
    "        if(dataf1.Age.iloc[i] <=np.average(dataf1.Age)):\n",
    "            TP_young_count=TP_young_count+1\n",
    "print(TP_old_count)\n",
    "print(TP_young_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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q6pafD4ffn5+CAsLs8m5n3rqKdx1112IiIiwyfFcCS7F77333sOYMWMwfPjwAR+LBLbZCR1r91qiGQmEgaLT6Vh3OhFx5yMmJgYLFy7E5s2buTbF4eDz+eDxeDadifeWUaNG4e6778Ynn3wy4GORwDY7wXKjBey/tSXBcej4oyYeHufksccec9gGHlxjcanbKsWsL7zxxhs2+d46LiE663VAMR0V0k7Zvn07lEolAGDNmjUcW0NwFp5//nlUVlaCYRg8//zzXJtDINgVn3zyCQwGA3x9ffHpp59ybU6/YBgG//73vwG0L+0sW7aMY4tsj0PNxMksnGBLLCPzjtHQBAKhHcv91pFnsB01wwHmq/3CIe5eRMQJgwG5rgiEnnF08bMM0h15MHIjHELELf/55GZLsCVExAmE7rGIn6OLuOX37eifozscQsQJBAKBQBgIRMQ5xFlGhAT7wtlH6ATCQHAWD6jl9+2ssS8O8anIzZYwGJDrikDoGUcXcWcPYHWIT0Vutta89957oCgKzzzzDACgtLQUFEV1+ffbb7+x7zt8+DCmTp0Kd3d3BAYG4sUXX4TJZOLoU3CPswe82CPfffcdJkyYgH/84x/strfffhvLli3DtGnTkJqaimeffRalpaVW78vNzcXjjz+O2bNnY86cOXjyySeRn58/xNa7FracwZrNZrzyyiuIioqCm5sbhg0bhjfffNPqnr5+/XrEx8dDJpPBy8sLqampOHv27IDO6wo1RhxKxAEi5OfOncNXX32FpKQkdltYWBiqq6ut/l5//XXI5XIsWrQIAJCVlYWbbroJCxcuxIULF7B582bs3LkTL730ElcfhXNEIhEoigJN0zCbzVyb4/Tk5uZi69atiI2NtdqekJCA1157Db/99hs+++wzMAyDtWvXst+JVqvF008/jcDAQHz33Xf45ptvIJVK8dRTT7n0IHSwsaU7/f3338eXX36Jzz77DFeuXMH777+PDz74wCr/PC4uDp999hkuXbqEkydPIjIyEvPnz0ddXV2/z9tRL8hMnEOIiLej0Whw991349///je8vLzY7Xw+H4GBgVZ/27Ztw8qVKyGXywEAmzdvRlJSEl599VXExMRg1qxZ+OCDD/D555+jpaWFq4/EKa7QHMFe0Gq1eOWVV/Dyyy93aoRy6623Yty4cQgODkZ8fDyeeOIJ1NbWorq6GkC7p0mtVuPRRx9FZGQkhg0bhjVr1qC+vp7dh2B7LH3fbVHN8NSpU1i2bBluvvlmREZGYsWKFZg/fz7+/PNPdp+77roLqampiI6OxsiRI/HRRx+hubkZ2dnZ/T5vx8E5EXEO6fif78ozprVr1+Lmm29GamrqDfc7f/48Ll68iNWrV7Pb2traOtUHd3Nzg16vx/nz5wfFXnvHzc2NHSA6a3MEe+H999/HtGnTMGnSpBvup9PpsHPnToSEhCAgIAAAEBERAU9PT+zYsQNGoxF6vR47duxAVFQUgoKChsJ8l8NsNoOmaVAUZZM2vVOnTsXhw4fZJZCsrCycPHmS9RRej8FgwNdffw1PT0+MHj263+d1hSZHDtHFrONIsK2tzaphvavwyy+/IDMzE+fOnetx340bNyIhIQFTp05lty1YsAAff/wxfv75Z6xcuRI1NTV44403AMBlZzPXX1eEweHAgQPIy8vDDz/80O0+v/32Gz755BPodDpERETg888/Z3/nMpkMX331FZ577jls3LgRQPsS0meffUba6w4Stu4c+dJLL6G5uRnx8fHg8/kwm814++23cffdd1vtt3v3btx5553QarUICgrCwYMH4evr2+/zdhycd/S8ORMOMRN39ZttRUUF1q1bh59++qnH0aROp8OmTZusZuEAMH/+fHz44Yd47LHHIBaLERcXh5tuugmA87qZeqLjj9oVr6uhoKamBv/4xz/w1ltv3VAMFi1ahJ9++glff/01wsPD8dJLL7HfiV6vx5tvvonRo0fj22+/xcaNGzFs2DCsW7eOeFAGCcv/PUVRNpnB/vrrr/jpp5+wadMmZGZm4vvvv8ff//53fP/991b7zZkzBxcvXsSpU6ewcOFCrFy5ku2b0R86zsSJiHNIx4vIFX+058+fh1KpxLhx4yAQCCAQCHDs2DF88sknEAgEVksMW7ZsgVarxX333dfpOM8++yyamppQXl4OlUrFNgOIjo4ess9iT0gkEuJOH2Ty8vLQ0NCAe+65B5MmTcKkSZOQmZmJX375BZMmTWKvXblcjvDwcIwbNw4ffPABSktLcfToUQDA/v37UV1djddeew0jR47EqFGj8Pbbb6OqqgrHjh3j8uM5LR3bj9piJv7888/jpZdewp133olRo0bh3nvvxV/+8he8++67VvvJZDLExMRg8uTJ2LhxIwQCAet9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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from matplotlib_venn import venn2, venn2_circles\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = dataf1.Predicted_Final_credit\n",
    "list2 = dataf1.Actual_output_credit\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(False_Positive))\n",
    "venn.get_label_by_id('01').set_text('FN\\n' + str(False_Negative))\n",
    "venn.get_label_by_id('11').set_text('TP+TN\\n' + str(True_Positive + True_Negative))\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, 'Old: ' + str(FP_old_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, 'Young: ' + str(FP_young_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, 'Old: ' + str(FN_old_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, 'Young: ' + str(FN_young_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.1, 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, 'Old: ' + str(TP_old_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.1, 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, 'Young: ' + str(TP_young_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": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Li5OderUkbu7u7Zu3aopU6aU9tCQC0IRxSIoKMh2eWjJkiXZ1j29lqxX89WrV7fdpJP1flNusl5xly1bVtWrV7d3yHbJeg/o5MmTeZbZtWtXodosW7asnnrqKb399tuSMs+0C3Ijzo3wfOUl64abtLQ0lStXTt26dStQvazn/ZZbbsnzkvHVZ2R/l/XCrahnkIUxYcIE7dy5U15eXlqzZo3t/3nq1KnaunVriY0DBUMoothMnTpV3t7eSklJUa9evRQVFZVv+UuXLql37962MyuLxaK+fftKylyYO7dX/KdPn9Ynn3wiSXrssceK+QiurXHjxrZx5BZ+586ds91U8Xepqan5tn313Z9Zf7zzcyM8X3np2rWrxo0bp7Fjx+r9998v8GLaWasfRUdH57pSz6lTpzRjxow86/v6+kqSYmNjCz9oO2zZskVvvfWWJOm9995T/fr1NXr0aD344IOyWq3q379/kW8GQvEiFFFs6tSpo88++0xubm46fPiwmjRporfffltHjx61lbFarfrll180fvx41ahRQ6tWrcrWxquvvip/f3/FxMSoQ4cO2r59u23ftm3b1KFDB8XGxiowMFAvv/xyiR1blrvvvtu2WPXAgQO1Z88eGYahjIwMhYaGqm3btsrIyMi17rJly9SqVSt98skn+vPPP23brVarNm7caDueli1bFviuxOv9+cqLq6ur3nnnHb377rvq379/gevdc889KlOmjAzD0COPPGK7IpH1HLZt2zbf5fBuvfVWSVJ8fLxtOoujXLx4UU888YQyMjLUq1cvDR8+3LZv/vz5qlixok6cOKEnn3zSoeNAIZXeFEn8U23dutWoVatWtmW33NzcjMDAQNsqHjKX6HrssceMtLS0bPVDQ0MNPz+/PJct8/f3N3788ccc/V5rInWW4ODgXJdTM4xrT943DMP45ptvbKumyFwWzcPDw5Bk1K5dO9vqPle7enkymUu8lS1bNttzUqlSJSMsLCxbvYIs81Zaz9e1ZLVf2Lr5Td7/6KOPsj2P3t7etue/XLly2RYcyO247rvvPtt+Hx8fIzg42AgODjbee+89W5msyfvXWjwgv+ewW7duhiSjatWqRkxMTI663333nW3Jv08//bQAzwpKAmeKKHatWrVSeHi4li5dqv79+6tWrVry8PBQQkKCAgMDdc899+i1115TWFiYlixZ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AAA4nN2heOrUKfn5+SkwMPCaZcuWLSs/Pz9FRUXZ2x0AAA5ndyimpKQU6g5UwzCUkJBgb3cAADic3aFYvnx5JSQkFGieYlRUlOLj41WuXDl7uwMAwOHsDsW77rpLkjRr1qxrls0q06JFC3u7AwDA4ewOxaFDh8owDL3zzjv69NNP8yz3ySef6J133pHFYtHQoUPt7Q4AAIeze5k3SXrkkUe0cuVKWSwW3XrrrXrooYcUHBwsSYqMjNS6det0+PBhGYah3r1764svvii2gRcGy7zhZscyb7iZlcgyb5K0cOFCWSwWffHFFzp48KAOHTqUbX9W3j766KOaO3duUboCAMDhirTMm6enp5YvX65NmzapX79+Cg4Olru7uzw8PBQSEqL+/fvr+++/15IlS+Tp6VlcYwYAwCGKdKaYpX379mrfvn2e+zMyMvT1119r7ty5WrNmTXF0CQBAsSuWUMzLH3/8oblz52rRokWKjo52ZFcAABRZsYdicnKyVqxYoblz52r79u2S/npvsX79+sXdHQAAxabYQnHnzp2aO3euVqxYocTEREmZYVivXj316dNHffr00a233lpc3QEAUOyKFIrnz5/XokWLNG/ePIWHh0v666zQYrFo9+7duuOOO4o+SgAASkChQ9EwDK1fv17z5s3TV199pfT0dBmGIU9PT/Xo0UMDBw5Uly5dJHG5FABwYylwKB47dkzz5s3TwoULdebMGRmGIYvFonvuuUcDBgzQI488Ih8fH0eOFQAAhypwKNauXVsWi0WGYah69eoaMGCABgwYoOrVqztyfAAAlJhCXz597rnn9M4778jNzc0R4wEAoNQUeEUbd3d3GYahDz/8UJUqVdLIkSO1c+dOR44NAIASVeBQPHPmjGbMmKFGjRopJiZGH330kVq1aqW6devqzTff1IkTJxw5TgAAHK7Aoejv769Ro0bpl19+0d69ezVixAj5+fnpjz/+0BtvvKEaNWqoffv2mj9/viPHCwCAw9i1IPjtt9+uWbNm6cyZM/rss8/Upk0bGYah0NBQDRs2zFbu22+/VXp6erENFgAARyrSp2S4u7vbPgnj6NGjeu2111S5cmVJsn2GYvny5TV48GCtX7+egAQAXNeK9CHDuTEMQxs3btScOXO0bt06XblyRRaLRVLmJdiLFy8WZ3cFwocM42bHhwzjZlaYDxku0pli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rnXLP5MkPTzgSfn6+dvKLJ/3kWa/N02SNGbC27lOvcjPx9OnaOePm5WU8Ndd878d/lX/eupxfbt2pTw8vfTaOzPl7OxchCNEXm64u0/twYLgxe/MmTPq1PE+hV31/qKPj48SEhJsj4OCgvTV1xtsL2YkqWaNEEWal1VdXV3l6+ury5cvKynprzvtmjVvrjVr1qpChQolcCQ3B+4+LZwzp06o971NbI/d3D3kVaaMkhMTbR/hJEkP9H5ML0/7INv0ilY1y8owDDk5Ock/sFy+/cxds0lBlapk29ardWPbcm9lvH10JS3N1qd/2XKaMmOu7mjJVZTCKMzdp//IG23geBUrVtTPu/dq9uxPtXr1Kh0+dMj2A1erVi3d/8CDGjXqWd1yyy3Z6s2dt0AbN36jn376UadOntT58+fl5OSkkJAQ3X57Uz38cB893KcPr4JRqsqVr6ApH87Vnu0/6siBfbp4LlpxsTFyd/dQ5eAQ3Xp7cz34cD81apbzTtKs84yMjAzFXDiXbz9Zi11cbfCoF7X1+406GnZIF8+fk5u7u6rXqad77uuiPgOHy9e/YJ84A/twpgjcBDhTxM3spp+nCACAPQhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgIhQBADARigAAmAhFAABMhCIAACZCEQAAE6EIAICJUAQAwEQoAgBgcintAZQEwzAkSfHx8aU8EqB0JCXws4+bV1JigqS/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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         214155 function calls (208160 primitive calls) in 0.251 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.251    0.251 1470072618.py:3(my_method)\n",
      "      184    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(all)\n",
      "      710    0.000    0.000    0.005    0.000 <__array_function__ internals>:177(amax)\n",
      "      714    0.001    0.000    0.005    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(any)\n",
      "      840    0.001    0.000    0.005    0.000 <__array_function__ internals>:177(around)\n",
      "       22    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(broadcast_arrays)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(can_cast)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(clip)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(column_stack)\n",
      "       44    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(cumsum)\n",
      "       16    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(diff)\n",
      "      230    0.000    0.000    0.001    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.000    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.000    0.000 <__array_function__ internals>:177(inv)\n",
      "       84    0.000    0.000    0.008    0.000 <__array_function__ internals>:177(isclose)\n",
      "        3    0.000    0.000    0.000    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.002    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.000    0.000    0.003    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.001    0.000    0.007    0.000 <__array_function__ internals>:177(round_)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(union1d)\n",
      "       15    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(unique)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unravel_index)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(zeros_like)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:778(__contains__)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:794(values)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:812(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 <frozen _collections_abc>:815(__len__)\n",
      "       40    0.000    0.000    0.000    0.000 <frozen _collections_abc>:878(__iter__)\n",
      "      392    0.000    0.000    0.001    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       82    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen genericpath>:121(_splitext)\n",
      "       23    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "       39    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:405(parent)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen ntpath>:231(splitext)\n",
      "       82    0.000    0.000    0.000    0.000 <string>:1(<lambda>)\n",
      "        1    0.000    0.000    0.251    0.251 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.011    0.011 Image.py:2346(save)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:2875(_check_size)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2896(new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:2973(frombuffer)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:321(preinit)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:417(_getencoder)\n",
      "        3    0.000    0.000    0.000    0.000 Image.py:512(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 Image.py:539(size)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:543(_new)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:603(_copy)\n",
      "        1    0.000    0.000    0.000    0.000 Image.py:609(_ensure_mutable)\n",
      "        2    0.000    0.000    0.000    0.000 Image.py:835(load)\n",
      "        1    0.000    0.000    0.011    0.011 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.011    0.011 ImageFile.py:527(_encode_tile)\n",
      "        1    0.000    0.000    0.000    0.000 ImageFile.py:75(_tilesort)\n",
      "        5    0.000    0.000    0.000    0.000 PngImagePlugin.py:1078(putchunk)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1092(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:1096(write)\n",
      "        1    0.000    0.000    0.011    0.011 PngImagePlugin.py:1242(_save)\n",
      "       10    0.000    0.000    0.000    0.000 PngImagePlugin.py:154(_crc32)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:282(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:285(add)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:328(add_text)\n",
      "     1265    0.001    0.000    0.001    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.000    0.000    0.001    0.000 __init__.py:1314(is_math_text)\n",
      "      172    0.000    0.000    0.000    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       66    0.000    0.000    0.000    0.000 __init__.py:134(check_shape)\n",
      "        1    0.000    0.000    0.001    0.001 __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.000    0.000    0.001    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.001    0.000    0.003    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.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",
      "      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.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",
      "        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.000    0.000    0.000    0.000 __init__.py:272(_compile)\n",
      "  582/580    0.001    0.000    0.002    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.000    0.000 __init__.py:550(_get_data_path)\n",
      "      211    0.000    0.000    0.001    0.000 __init__.py:65(check_isinstance)\n",
      "     2772    0.001    0.000    0.002    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.002    0.000    0.004    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.001    0.000    0.001    0.000 __init__.py:831(clean)\n",
      "     1510    0.000    0.000    0.000    0.000 __init__.py:834(<listcomp>)\n",
      "     1508    0.002    0.000    0.005    0.000 __init__.py:880(get_siblings)\n",
      "     1508    0.001    0.000    0.001    0.000 __init__.py:884(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:98(get_projection_class)\n",
      "        4    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "       15    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:83(unique_values)\n",
      "       15    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "        1    0.000    0.000    0.000    0.000 _axes.py:104(set_title)\n",
      "        1    0.000    0.000    0.001    0.001 _axes.py:5459(imshow)\n",
      "        4    0.000    0.000    0.001    0.000 _axes.py:626(text)\n",
      "        1    0.000    0.000    0.003    0.003 _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.000    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "        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.001    0.001 _base.py:1206(_gen_axes_spines)\n",
      "        1    0.000    0.000    0.001    0.001 _base.py:1221(<dictcomp>)\n",
      "        1    0.000    0.000    0.017    0.017 _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.017    0.017 _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.000    0.000 _base.py:1862(get_data_ratio)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:1876(apply_aspect)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:222(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2278(add_image)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2312(_add_text)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:235(set_prop_cycle)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:2446(_unit_change_handler)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2485(update_datalim)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2510(_process_unit_info)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2569(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:291(nnz)\n",
      "        4    0.000    0.000    0.098    0.025 _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.119    0.059 _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.007    0.004 _base.py:3157(grid)\n",
      "        2    0.000    0.000    0.001    0.000 _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.000    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.073    0.036 _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.025    0.025 _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.000    0.000 _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.005    0.005 _base.py:818(_init_axis)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:827(set_figure)\n",
      "      732    0.001    0.000    0.009    0.000 _base.py:841(_unstale_viewLim)\n",
      "      732    0.002    0.000    0.008    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.010    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.002    0.002 _classification.py:232(confusion_matrix)\n",
      "        1    0.000    0.000    0.001    0.001 _classification.py:59(_check_targets)\n",
      "       15    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "       15    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:127(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _coo.py:240(getnnz)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:266(_check)\n",
      "        1    0.000    0.000    0.000    0.000 _coo.py:320(toarray)\n",
      "        1    0.000    0.000    0.000    0.000 _data.py:20(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _data.py:23(_get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:103(_clip_dep_is_byte_swapped)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:108(_clip_dep_invoke_with_casting)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:127(_clip)\n",
      "      168    0.000    0.000    0.001    0.000 _methods.py:281(_ptp)\n",
      "     1374    0.001    0.000    0.003    0.000 _methods.py:39(_amax)\n",
      "      536    0.000    0.000    0.002    0.000 _methods.py:43(_amin)\n",
      "      168    0.000    0.000    0.001    0.000 _methods.py:47(_sum)\n",
      "       89    0.000    0.000    0.000    0.000 _methods.py:55(_any)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:93(_clip_dep_is_scalar_nan)\n",
      "        3    0.000    0.000    0.000    0.000 _pylab_helpers.py:100(get_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:147(get_index_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.001    0.001 _tight_bbox.py:8(adjust_bbox)\n",
      "      174    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "      174    0.001    0.000    0.001    0.000 _ufunc_config.py:33(seterr)\n",
      "       87    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       87    0.000    0.000    0.001    0.000 _ufunc_config.py:430(__enter__)\n",
      "       87    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "      168    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",
      "        4    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       15    0.000    0.000    0.001    0.000 arraysetops.py:138(unique)\n",
      "       15    0.000    0.000    0.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.000    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.000    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.001    0.000    0.004    0.000 artist.py:103(_stale_axes_callback)\n",
      "      114    0.000    0.000    0.001    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       26    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "       82    0.000    0.000    0.000    0.000 artist.py:1132(sticky_edges)\n",
      "       20    0.000    0.000    0.000    0.000 artist.py:1159(update_from)\n",
      "      312    0.002    0.000    0.008    0.000 artist.py:1180(_update_props)\n",
      "       34    0.000    0.000    0.001    0.000 artist.py:1205(update)\n",
      "      278    0.000    0.000    0.007    0.000 artist.py:1216(_internal_update)\n",
      "      244    0.000    0.000    0.008    0.000 artist.py:1227(set)\n",
      "       50    0.000    0.000    0.003    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.019    0.005 artist.py:1408(_get_tightbbox_for_layout_only)\n",
      "      244    0.000    0.000    0.009    0.000 artist.py:147(<lambda>)\n",
      "       82    0.001    0.000    0.001    0.000 artist.py:180(__init__)\n",
      "      278    0.000    0.000    0.001    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.005    0.000    0.008    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.019    0.001 artist.py:352(get_tightbbox)\n",
      "      571    0.000    0.000    0.002    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.000    0.000 artist.py:451(get_transform)\n",
      "    100/2    0.001    0.000    0.120    0.060 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.000    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.003    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.001    0.000    0.001    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.000    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.120    0.060 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.005    0.002 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.003    0.000    0.091    0.001 axis.py:1252(_update_ticks)\n",
      "       48    0.000    0.000    0.027    0.001 axis.py:1295(_get_ticklabel_bboxes)\n",
      "       48    0.000    0.000    0.009    0.000 axis.py:1299(<listcomp>)\n",
      "       48    0.000    0.000    0.018    0.000 axis.py:1301(<listcomp>)\n",
      "       20    0.000    0.000    0.111    0.006 axis.py:1304(get_tightbbox)\n",
      "       40    0.000    0.000    0.001    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.029    0.007 axis.py:1363(draw)\n",
      "       84    0.000    0.000    0.012    0.000 axis.py:1477(get_majorticklocs)\n",
      "       84    0.001    0.000    0.022    0.000 axis.py:1481(get_minorticklocs)\n",
      "       10    0.000    0.000    0.016    0.002 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.003    0.001 axis.py:1560(_copy_tick_props)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1574(get_major_locator)\n",
      "       84    0.000    0.000    0.010    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.007    0.002 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.000    0.000 axis.py:1836(_set_formatter)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:1862(set_major_locator)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1878(set_minor_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1894(set_pickradius)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:196(_set_labelrotation)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:208(_apply_tickdir)\n",
      "       24    0.000    0.000    0.036    0.002 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.012    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.001    0.001 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.001    0.000 axis.py:2241(_init)\n",
      "       16    0.000    0.000    0.046    0.003 axis.py:2298(_update_label_position)\n",
      "       16    0.000    0.000    0.002    0.000 axis.py:2338(_update_offset_text_position)\n",
      "        6    0.000    0.000    0.001    0.000 axis.py:237(set_clip_path)\n",
      "        2    0.000    0.000    0.001    0.000 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.001    0.001 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.001    0.000 axis.py:2500(_init)\n",
      "        8    0.000    0.000    0.023    0.003 axis.py:2559(_update_label_position)\n",
      "        8    0.000    0.000    0.000    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.008    0.001 axis.py:293(draw)\n",
      "      336    0.000    0.000    0.002    0.000 axis.py:305(set_label1)\n",
      "      336    0.000    0.000    0.002    0.000 axis.py:318(set_label2)\n",
      "       50    0.000    0.000    0.000    0.000 axis.py:342(_set_artist_props)\n",
      "       23    0.000    0.000    0.002    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.008    0.002 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.000    0.000 axis.py:444(_apply_tickdir)\n",
      "      221    0.001    0.000    0.005    0.000 axis.py:455(update_position)\n",
      "        5    0.000    0.000    0.008    0.002 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.000    0.000 axis.py:505(_apply_tickdir)\n",
      "      125    0.001    0.000    0.003    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.000    0.000    0.012    0.001 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.009    0.002 axis.py:583(__get__)\n",
      "        2    0.000    0.000    0.002    0.001 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.001    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.004    0.000 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.007    0.001 axis.py:855(clear)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:893(reset_ticks)\n",
      "       11    0.000    0.000    0.009    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.000    0.000 backend_agg.py:109(draw_path)\n",
      "       11    0.000    0.000    0.003    0.000 backend_agg.py:200(draw_text)\n",
      "       24    0.000    0.000    0.005    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.003    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.058    0.029 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.069    0.035 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.069    0.035 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.000    0.000 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.069    0.035 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.214    0.214 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.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",
      "       86    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       48    0.000    0.000    0.001    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.000    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.001    0.001 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.218    0.218 backend_inline.py:72(show)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:382(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:405(_scale_norm)\n",
      "        2    0.000    0.000    0.004    0.002 cm.py:427(to_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:520(get_array)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:575(set_cmap)\n",
      "       26    0.000    0.000    0.000    0.000 cm.py:589(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:593(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:622(set_norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:649(autoscale_None)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:660(changed)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:699(_ensure_cmap)\n",
      "        1    0.000    0.000    0.000    0.000 colors.py:1213(__init__)\n",
      "       15    0.000    0.000    0.000    0.000 colors.py:1241(vmin)\n",
      "        5    0.000    0.000    0.000    0.000 colors.py:1245(vmin)\n",
      "       13    0.000    0.000    0.000    0.000 colors.py:1252(vmax)\n",
      "        5    0.000    0.000    0.000    0.000 colors.py:1256(vmax)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:1263(clip)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:1273(_changed)\n",
      "        6    0.000    0.000    0.001    0.000 colors.py:1280(process_value)\n",
      "        2    0.000    0.000    0.001    0.001 colors.py:1315(__call__)\n",
      "        3    0.000    0.000    0.000    0.000 colors.py:1382(autoscale_None)\n",
      "       12    0.000    0.000    0.000    0.000 colors.py:203(_sanitize_extrema)\n",
      "      349    0.000    0.000    0.001    0.000 colors.py:213(_is_nth_color)\n",
      "       99    0.000    0.000    0.001    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.001    0.000 colors.py:237(_check_color_like)\n",
      "      250    0.000    0.000    0.001    0.000 colors.py:265(to_rgba)\n",
      "        2    0.001    0.000    0.004    0.002 colors.py:683(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      612    0.001    0.000    0.001    0.000 contextlib.py:104(__init__)\n",
      "  612/587    0.000    0.000    0.004    0.000 contextlib.py:132(__enter__)\n",
      "  612/587    0.001    0.000    0.004    0.000 contextlib.py:141(__exit__)\n",
      "      612    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.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.001    0.000    0.002    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.000    0.000    0.002    0.000 copy.py:227(_deepcopy_dict)\n",
      "       12    0.000    0.000    0.000    0.000 copy.py:237(_deepcopy_method)\n",
      "      128    0.000    0.000    0.000    0.000 copy.py:243(_keep_alive)\n",
      "      481    0.001    0.000    0.003    0.000 copy.py:259(_reconstruct)\n",
      "      144    0.000    0.000    0.000    0.000 copy.py:264(<genexpr>)\n",
      "     1579    0.003    0.000    0.006    0.000 copy.py:66(copy)\n",
      "      457    0.000    0.000    0.000    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.000    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.000    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.216    0.018 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.000    0.000 deprecation.py:289(wrapper)\n",
      "      7/5    0.000    0.000    0.001    0.000 deprecation.py:379(wrapper)\n",
      "       12    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    76/68    0.000    0.000    0.014    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.218    0.218 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.002    0.002 display_functions.py:45(publish_display_data)\n",
      "        1    0.000    0.000    0.000    0.000 displaypub.py:43(_validate_data)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:105(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:183(encode)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:205(iterencode)\n",
      "      284    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1232(__reduce_ex__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1243(name)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:192(__get__)\n",
      "      284    0.000    0.000    0.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",
      "        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.080    0.080 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.000    0.000 figure.py:191(_get_draw_artists)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:203(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:204(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2105(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2353(__repr__)\n",
      "        1    0.000    0.000    0.001    0.001 figure.py:2360(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2553(_check_layout_engines_compat)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:2572(set_layout_engine)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:259(get_children)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:2638(get_layout_engine)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2645(_repr_html_)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:2696(axes)\n",
      "      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.120    0.060 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.001    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.025    0.025 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.025    0.025 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.000    0.000    0.002    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.002    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       35    0.000    0.000    0.000    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.000    0.000    0.001    0.000 font_manager.py:588(__init__)\n",
      "       90    0.000    0.000    0.001    0.000 font_manager.py:608(_from_any)\n",
      "     1059    0.003    0.000    0.005    0.000 font_manager.py:631(__hash__)\n",
      "      345    0.000    0.000    0.003    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.000    0.000 font_manager.py:729(set_style)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       70    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "      111    0.000    0.000    0.000    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.000    0.000    0.005    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.215    0.018 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.215    0.024 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.216    0.216 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.000    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.002    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2107(_clip_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2111(clip)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       24    0.000    0.000    0.000    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.002    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:2600(_ptp_dispatcher)\n",
      "      168    0.000    0.000    0.001    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.004    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.004    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.000    0.000    0.000    0.000 fromnumeric.py:3241(_around_dispatcher)\n",
      "      840    0.001    0.000    0.004    0.000 fromnumeric.py:3245(around)\n",
      "      840    0.001    0.000    0.006    0.000 fromnumeric.py:3754(round_)\n",
      "      234    0.001    0.000    0.001    0.000 fromnumeric.py:38(_wrapit)\n",
      "     1246    0.001    0.000    0.006    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "     1632    0.003    0.000    0.008    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "     1632    0.001    0.000    0.001    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       16    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       16    0.000    0.000    0.000    0.000 function_base.py:1320(diff)\n",
      "     1364    0.001    0.000    0.001    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.000    0.000    0.000    0.000 getlimits.py:476(__new__)\n",
      "      172    0.001    0.000    0.001    0.000 getlimits.py:558(smallest_normal)\n",
      "      172    0.000    0.000    0.001    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.025    0.025 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.000    0.000 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.119    0.059 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.011    0.011 image.py:1567(imsave)\n",
      "        4    0.000    0.000    0.010    0.003 image.py:160(_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:247(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:287(get_size)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:294(set_alpha)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:308(_get_scalar_alpha)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:321(changed)\n",
      "        2    0.001    0.001    0.018    0.009 image.py:328(_make_image)\n",
      "        2    0.000    0.000    0.021    0.010 image.py:617(draw)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:685(set_data)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:745(get_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:756(set_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:778(set_interpolation_stage)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:802(set_resample)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:816(get_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:820(set_filternorm)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:833(get_filternorm)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:837(set_filterrad)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:852(get_filterrad)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:905(__init__)\n",
      "        2    0.000    0.000    0.018    0.009 image.py:940(make_image)\n",
      "        1    0.000    0.000    0.001    0.001 image.py:956(set_extent)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2037(_signature_bound_method)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "      2/1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "       74    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "      163    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2836(args)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2859(kwargs)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "       10    0.000    0.000    0.000    0.000 inspect.py:292(isclass)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "       54    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3039(replace)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:3075(_bind)\n",
      "       16    0.000    0.000    0.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.001    0.000 iostream.py:480(flush)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:107(json_default)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:38(_ensure_tzinfo)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:52(encode_images)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:77(json_clean)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:112(_makearray)\n",
      "        6    0.000    0.000    0.000    0.000 linalg.py:117(isComplexType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:130(_realType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:136(_commonType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:469(inv)\n",
      "       10    0.000    0.000    0.001    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.000    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.000    0.000 lines.py:1137(set_linestyle)\n",
      "       20    0.000    0.000    0.001    0.000 lines.py:1182(set_marker)\n",
      "       90    0.000    0.000    0.000    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.001    0.000    0.003    0.000 lines.py:1269(set_xdata)\n",
      "      435    0.001    0.000    0.002    0.000 lines.py:1290(set_ydata)\n",
      "       12    0.000    0.000    0.003    0.000 lines.py:1335(update_from)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       30    0.001    0.000    0.005    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.000    0.000    0.002    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.000    0.000    0.003    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.004    0.000 markers.py:228(__init__)\n",
      "      112    0.000    0.000    0.001    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:293(__bool__)\n",
      "       44    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       62    0.000    0.000    0.000    0.000 markers.py:302(_set_fillstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:318(get_joinstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:321(get_capstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:324(get_marker)\n",
      "       62    0.000    0.000    0.004    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.000    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.000    0.000 multiclass.py:44(unique_labels)\n",
      "        3    0.000    0.000    0.000    0.000 multiclass.py:81(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:150(ones)\n",
      "        6    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:215(_ones_like_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:219(ones_like)\n",
      "       84    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "       84    0.001    0.000    0.007    0.000 numeric.py:2278(isclose)\n",
      "       84    0.001    0.000    0.004    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.003    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.000    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.001    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.001    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "       12    0.000    0.000    0.002    0.000 patches.py:582(draw)\n",
      "       39    0.000    0.000    0.004    0.000 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:689(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 patches.py:730(get_path)\n",
      "       28    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       26    0.000    0.000    0.002    0.000 patches.py:742(get_patch_transform)\n",
      "       52    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:768(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:855(set_bounds)\n",
      "       26    0.000    0.000    0.001    0.000 patches.py:876(get_bbox)\n",
      "       68    0.000    0.000    0.000    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       66    0.000    0.000    0.000    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.000    0.000    0.003    0.000 path.py:603(get_extents)\n",
      "        7    0.000    0.000    0.000    0.000 path.py:730(unit_rectangle)\n",
      "       66    0.000    0.000    0.001    0.000 path.py:99(__init__)\n",
      "       28    0.000    0.000    0.000    0.000 pathlib.py:147(splitroot)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:484(_parse_args)\n",
      "       14    0.000    0.000    0.000    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.000    0.000 pathlib.py:56(parse_parts)\n",
      "       14    0.000    0.000    0.000    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.215    0.215 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.026    0.026 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.000    0.000 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.001    0.001 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.218    0.218 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:690(figure)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:866(gcf)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:887(get_fignums)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:926(close)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:140(validate_bool)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:152(validate_axisbelow)\n",
      "       14    0.000    0.000    0.003    0.000 scale.py:103(set_default_locators_and_formatters)\n",
      "      516    0.000    0.000    0.001    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.000    0.000 session.py:92(json_packer)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 shape_base.py:612(column_stack)\n",
      "        5    0.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.001    0.000    0.045    0.001 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.002    0.001 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.002    0.001 spines.py:221(clear)\n",
      "       44    0.000    0.000    0.001    0.000 spines.py:227(_adjust_location)\n",
      "        8    0.000    0.000    0.001    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.000    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.001    0.000 spines.py:35(__init__)\n",
      "        4    0.000    0.000    0.001    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.000    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       66    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "      110    0.000    0.000    0.000    0.000 text.py:1000(set_horizontalalignment)\n",
      "       24    0.000    0.000    0.005    0.000 text.py:101(_get_text_metrics_with_cache_impl)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1030(set_linespacing)\n",
      "       44    0.000    0.000    0.000    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.000    0.000    0.001    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.000    0.000 text.py:1217(set_rotation)\n",
      "      109    0.000    0.000    0.000    0.000 text.py:1249(set_verticalalignment)\n",
      "      798    0.000    0.000    0.000    0.000 text.py:1265(set_text)\n",
      "      182    0.000    0.000    0.001    0.000 text.py:1283(_preprocess_math)\n",
      "       55    0.000    0.000    0.002    0.000 text.py:1307(set_fontproperties)\n",
      "       31    0.000    0.000    0.005    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.000    0.000    0.005    0.000 text.py:185(_reset_visual_defaults)\n",
      "       34    0.000    0.000    0.002    0.000 text.py:221(update)\n",
      "       40    0.000    0.000    0.001    0.000 text.py:270(_get_xy_display)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:277(_get_multialignment)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:315(get_rotation)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:323(get_transform_rotates_text)\n",
      "       62    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:344(get_rotation_mode)\n",
      "        8    0.000    0.000    0.000    0.000 text.py:348(update_from)\n",
      "      160    0.006    0.000    0.033    0.000 text.py:363(_get_layout)\n",
      "      124    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        6    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        4    0.000    0.000    0.001    0.000 text.py:596(set_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       38    0.001    0.000    0.015    0.000 text.py:738(draw)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:808(get_color)\n",
      "      178    0.000    0.000    0.001    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.002    0.000    0.040    0.000 text.py:918(get_window_extent)\n",
      "      320    0.001    0.000    0.014    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       69    0.000    0.000    0.001    0.000 text.py:985(set_color)\n",
      "        2    0.000    0.000    0.000    0.000 textpath.py:26(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        4    0.000    0.000    0.000    0.000 threading.py:1161(ident)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:1446(current_thread)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:236(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:264(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:267(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:273(_release_save)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:276(_acquire_restore)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:279(_is_owned)\n",
      "        2    0.000    0.000    0.001    0.000 threading.py:288(wait)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:555(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.001    0.000 threading.py:604(wait)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1633(raise_if_exceeds)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1651(nonsingular)\n",
      "       84    0.000    0.000    0.000    0.000 ticker.py:1755(__call__)\n",
      "       84    0.000    0.000    0.000    0.000 ticker.py:1758(tick_values)\n",
      "      168    0.001    0.000    0.001    0.000 ticker.py:1899(scale_range)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1917(__init__)\n",
      "       58    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "      336    0.000    0.000    0.000    0.000 ticker.py:1932(closeto)\n",
      "      168    0.000    0.000    0.001    0.000 ticker.py:1942(le)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1949(ge)\n",
      "       16    0.000    0.000    0.001    0.000 ticker.py:1969(__init__)\n",
      "       16    0.000    0.000    0.001    0.000 ticker.py:2010(_validate_steps)\n",
      "       16    0.000    0.000    0.000    0.000 ticker.py:2025(_staircase)\n",
      "       16    0.000    0.000    0.001    0.000 ticker.py:2031(set_params)\n",
      "      168    0.007    0.000    0.014    0.000 ticker.py:2074(_raw_ticks)\n",
      "      168    0.001    0.000    0.022    0.000 ticker.py:2134(__call__)\n",
      "      168    0.001    0.000    0.018    0.000 ticker.py:2138(tick_values)\n",
      "      168    0.000    0.000    0.017    0.000 ticker.py:215(format_ticks)\n",
      "      168    0.001    0.000    0.003    0.000 ticker.py:218(<listcomp>)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:238(set_locs)\n",
      "      360    0.000    0.000    0.001    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.001    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.002    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.002    0.000 ticker.py:516(_format_maybe_minus_and_locale)\n",
      "       14    0.000    0.000    0.001    0.000 ticker.py:533(set_useMathText)\n",
      "      336    0.001    0.000    0.002    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.025    0.000 ticker.py:696(set_locs)\n",
      "      168    0.002    0.000    0.006    0.000 ticker.py:705(_compute_offset)\n",
      "      168    0.002    0.000    0.005    0.000 ticker.py:744(_set_order_of_magnitude)\n",
      "      168    0.004    0.000    0.013    0.000 ticker.py:778(_set_format)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "     2254    0.001    0.000    0.001    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:1057(set)\n",
      "       26    0.000    0.000    0.000    0.000 transforms.py:1087(__init__)\n",
      "     1960    0.001    0.000    0.001    0.000 transforms.py:110(__init__)\n",
      "       53    0.000    0.000    0.000    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.001    0.000 transforms.py:1335(__add__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:134(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:136(__setstate__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:141(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1463(__array__)\n",
      "      160    0.001    0.000    0.006    0.000 transforms.py:1467(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1568(get_matrix)\n",
      "      424    0.000    0.000    0.002    0.000 transforms.py:157(invalidate)\n",
      "       39    0.000    0.000    0.002    0.000 transforms.py:1588(transform_path)\n",
      "       39    0.000    0.000    0.001    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.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",
      "        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.001    0.000    0.002    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.000    0.000    0.003    0.000 transforms.py:1777(transform)\n",
      "       39    0.000    0.000    0.001    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.001    0.000    0.002    0.000 transforms.py:1843(transform_affine)\n",
      "       13    0.000    0.000    0.001    0.000 transforms.py:1864(inverted)\n",
      "      475    0.001    0.000    0.002    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.001    0.000 transforms.py:194(set_children)\n",
      "      186    0.001    0.000    0.002    0.000 transforms.py:1978(rotate)\n",
      "      186    0.000    0.000    0.002    0.000 transforms.py:2001(rotate_deg)\n",
      "       58    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       92    0.000    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.000    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.000    0.000 transforms.py:2281(__init__)\n",
      "       77    0.000    0.000    0.000    0.000 transforms.py:2307(get_matrix)\n",
      "       31    0.000    0.000    0.000    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.000    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.000    0.000    0.000    0.000 transforms.py:2405(<lambda>)\n",
      "      160    0.000    0.000    0.004    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.001    0.000    0.004    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.001    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       55    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "  113/111    0.000    0.000    0.000    0.000 transforms.py:2597(get_matrix)\n",
      "       74    0.000    0.000    0.000    0.000 transforms.py:263(y0)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:2639(__init__)\n",
      "       32    0.000    0.000    0.000    0.000 transforms.py:2651(get_matrix)\n",
      "       22    0.000    0.000    0.000    0.000 transforms.py:2673(__init__)\n",
      "      136    0.000    0.000    0.000    0.000 transforms.py:2683(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:273(x1)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2736(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2751(_revalidate)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2764(get_transformed_points_and_affine)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2791(get_affine)\n",
      "      172    0.002    0.000    0.003    0.000 transforms.py:2822(nonsingular)\n",
      "       40    0.000    0.000    0.000    0.000 transforms.py:283(y1)\n",
      "      336    0.001    0.000    0.001    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.000    0.000    0.003    0.000 transforms.py:313(xmin)\n",
      "      267    0.000    0.000    0.002    0.000 transforms.py:318(ymin)\n",
      "      243    0.000    0.000    0.002    0.000 transforms.py:323(xmax)\n",
      "      263    0.000    0.000    0.002    0.000 transforms.py:328(ymax)\n",
      "      463    0.001    0.000    0.001    0.000 transforms.py:343(intervalx)\n",
      "      263    0.000    0.000    0.000    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.001    0.000    0.001    0.000 transforms.py:624(translated)\n",
      "       99    0.001    0.000    0.013    0.000 transforms.py:649(union)\n",
      "       99    0.000    0.000    0.002    0.000 transforms.py:654(<listcomp>)\n",
      "       99    0.000    0.000    0.002    0.000 transforms.py:655(<listcomp>)\n",
      "       99    0.000    0.000    0.002    0.000 transforms.py:656(<listcomp>)\n",
      "       99    0.000    0.000    0.002    0.000 transforms.py:657(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:660(intersection)\n",
      "      604    0.002    0.000    0.004    0.000 transforms.py:754(__init__)\n",
      "       49    0.000    0.000    0.001    0.000 transforms.py:784(frozen)\n",
      "       26    0.000    0.000    0.000    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.004    0.000 transforms.py:800(from_bounds)\n",
      "      232    0.000    0.000    0.005    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.000    0.000 validation.py:1152(column_or_1d)\n",
      "        5    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:629(check_array)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "       10    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       16    0.000    0.000    0.000    0.000 weakref.py:46(__new__)\n",
      "        2    0.000    0.000    0.000    0.000 weakref.py:68(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 widgets.py:38(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 zmqshell.py:63(_flush_streams)\n",
      "        1    0.000    0.000    0.000    0.000 zmqshell.py:73(_hooks)\n",
      "        1    0.000    0.000    0.002    0.002 zmqshell.py:80(publish)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.fill}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.map_buffer}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method PIL._imaging.zip_encoder}\n",
      "      625    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEA04C9F90}\n",
      "      392    0.000    0.000    0.000    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.000    0.000    0.000    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.001    0.000    0.002    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.251    0.251 {built-in method builtins.exec}\n",
      "     7600    0.003    0.000    0.013    0.000 {built-in method builtins.getattr}\n",
      "      888    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "1782/1092    0.001    0.000    0.003    0.000 {built-in method builtins.hash}\n",
      "     1714    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     6523    0.001    0.000    0.002    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.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "2523/2516    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",
      "     1061    0.000    0.000    0.000    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.007    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.000    0.000    0.001    0.000 {built-in method builtins.setattr}\n",
      "      430    0.001    0.000    0.001    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.000    0.000    0.000    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.009    0.002    0.009    0.002 {built-in method matplotlib._image.resample}\n",
      "      600    0.001    0.000    0.001    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.002    0.000    0.002    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.001    0.000    0.001    0.000 {built-in method numpy.asarray}\n",
      "4456/3297    0.005    0.000    0.032    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.001    0.000    0.001    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 0x0000017C598FEF20}\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.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",
      "        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.000    0.000    0.000    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.000    0.000 {method 'clip' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of '_hashlib.HMAC' objects}\n",
      "       19    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "      160    0.000    0.000    0.000    0.000 {method 'copy' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'copy' of 'numpy.generic' objects}\n",
      "     1206    0.002    0.000    0.002    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      424    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.002    0.002    0.002    0.002 {method 'draw_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'draw_markers' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'draw_path' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'draw_text_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        1    0.011    0.011    0.011    0.011 {method 'encode' of 'ImagingEncoder' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {method 'encode' of 'str' objects}\n",
      "       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.001    0.000    0.001    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.000    0.000    0.000    0.000 {method 'match' of 're.Pattern' objects}\n",
      "     1374    0.001    0.000    0.004    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "      536    0.000    0.000    0.003    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.011    0.000    0.011    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.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",
      "      840    0.003    0.000    0.003    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.004    0.000    0.004    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.001    0.000 {method 'sum' of 'numpy.ndarray' objects}\n",
      "        2    0.002    0.001    0.002    0.001 {method 'take' of 'numpy.ndarray' objects}\n",
      "      186    0.000    0.000    0.000    0.000 {method 'tolist' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'update' of '_hashlib.HMAC' objects}\n",
      "      575    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",
      "        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",
    "   \n",
    "    from sklearn.metrics import confusion_matrix\n",
    "    conf_matrix = confusion_matrix(y_true=dataf1.Actual_output_credit, y_pred=dataf1.Predicted_Final_credit)\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": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         54876 function calls (51404 primitive calls) in 0.157 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.157    0.157 1894348369.py:3(my_method)\n",
      "      276    0.001    0.000    0.005    0.000 <__array_function__ internals>:177(all)\n",
      "       42    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amax)\n",
      "       30    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amin)\n",
      "       10    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(any)\n",
      "      224    0.000    0.000    0.005    0.000 <__array_function__ internals>:177(append)\n",
      "      448    0.001    0.000    0.004    0.000 <__array_function__ internals>:177(atleast_1d)\n",
      "       10    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(atleast_2d)\n",
      "      682    0.001    0.000    0.006    0.000 <__array_function__ internals>:177(concatenate)\n",
      "      460    0.001    0.000    0.003    0.000 <__array_function__ internals>:177(copyto)\n",
      "      224    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(diag)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(dot)\n",
      "      224    0.000    0.000    0.023    0.000 <__array_function__ internals>:177(eigvals)\n",
      "      224    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(empty_like)\n",
      "      224    0.000    0.000    0.004    0.000 <__array_function__ internals>:177(full_like)\n",
      "      224    0.000    0.000    0.007    0.000 <__array_function__ internals>:177(hstack)\n",
      "      112    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(imag)\n",
      "      112    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(isreal)\n",
      "       12    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(linspace)\n",
      "        8    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(mean)\n",
      "       12    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "      224    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(nonzero)\n",
      "        8    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(norm)\n",
      "      448    0.001    0.000    0.004    0.000 <__array_function__ internals>:177(ravel)\n",
      "      112    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(real)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(reshape)\n",
      "       12    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "      224    0.001    0.000    0.053    0.000 <__array_function__ internals>:177(roots)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(sum)\n",
      "       10    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(vstack)\n",
      "      118    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       14    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "       24    0.000    0.000    0.000    0.000 <string>:1(<lambda>)\n",
      "        1    0.000    0.000    0.157    0.157 <string>:1(<module>)\n",
      "      212    0.000    0.000    0.001    0.000 __init__.py:101(check_in_list)\n",
      "       38    0.000    0.000    0.000    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       32    0.000    0.000    0.001    0.000 __init__.py:134(check_shape)\n",
      "       92    0.000    0.000    0.000    0.000 __init__.py:154(<genexpr>)\n",
      "      111    0.000    0.000    0.001    0.000 __init__.py:163(match)\n",
      "       12    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",
      "       12    0.000    0.000    0.000    0.000 __init__.py:1715(<genexpr>)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:1726(normalize_kwargs)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:1765(<dictcomp>)\n",
      "       32    0.000    0.000    0.000    0.000 __init__.py:1834(_str_equal)\n",
      "       24    0.000    0.000    0.000    0.000 __init__.py:190(__init__)\n",
      "       36    0.000    0.000    0.000    0.000 __init__.py:1994(_setattr_cm)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:2290(_unpack_to_numpy)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:254(method)\n",
      "      111    0.000    0.000    0.000    0.000 __init__.py:272(_compile)\n",
      "      118    0.001    0.000    0.001    0.000 __init__.py:291(process)\n",
      "       66    0.000    0.000    0.000    0.000 __init__.py:65(check_isinstance)\n",
      "      345    0.000    0.000    0.001    0.000 __init__.py:691(_get)\n",
      "      345    0.001    0.000    0.001    0.000 __init__.py:742(__getitem__)\n",
      "       20    0.000    0.000    0.000    0.000 __init__.py:831(clean)\n",
      "       20    0.000    0.000    0.000    0.000 __init__.py:834(<listcomp>)\n",
      "       20    0.000    0.000    0.000    0.000 __init__.py:880(get_siblings)\n",
      "       20    0.000    0.000    0.000    0.000 __init__.py:884(<listcomp>)\n",
      "       18    0.000    0.000    0.000    0.000 _arc.py:153(angle_as_point)\n",
      "        6    0.000    0.000    0.000    0.000 _arc.py:168(start_point)\n",
      "       12    0.000    0.000    0.000    0.000 _arc.py:188(mid_point)\n",
      "       16    0.000    0.000    0.000    0.000 _arc.py:25(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 _arc.py:44(length_degrees)\n",
      "       14    0.000    0.000    0.013    0.001 _axes.py:626(text)\n",
      "       24    0.000    0.000    0.001    0.000 _base.py:1179(_set_artist_props)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1616(set_aspect)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1702(set_adjustable)\n",
      "       14    0.000    0.000    0.001    0.000 _base.py:2312(_add_text)\n",
      "       10    0.000    0.000    0.123    0.012 _base.py:2371(add_patch)\n",
      "       10    0.002    0.000    0.118    0.012 _base.py:2384(_update_patch_limits)\n",
      "       10    0.000    0.000    0.001    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",
      "        2    0.000    0.000    0.000    0.000 _base.py:3396(set_axis_off)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        2    0.000    0.000    0.001    0.001 _base.py:3575(set_xlim)\n",
      "        2    0.000    0.000    0.001    0.000 _base.py:3807(set_ylim)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:564(_axis_map)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:567(<dictcomp>)\n",
      "        4    0.000    0.000    0.001    0.000 _base.py:73(wrapper)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:841(_unstale_viewLim)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:844(<dictcomp>)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:845(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:855(viewLim)\n",
      "        2    0.000    0.000    0.000    0.000 _common.py:100(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _common.py:101(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _common.py:102(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _common.py:20(__init__)\n",
      "        6    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",
      "        2    0.000    0.000    0.000    0.000 _common.py:70(mix_colors)\n",
      "        2    0.000    0.000    0.003    0.002 _common.py:92(prepare_venn_axes)\n",
      "        2    0.000    0.000    0.000    0.000 _common.py:99(<listcomp>)\n",
      "        2    0.000    0.000    0.002    0.001 _math.py:100(find_distance_by_area)\n",
      "       14    0.000    0.000    0.002    0.000 _math.py:126(<lambda>)\n",
      "        4    0.000    0.000    0.000    0.000 _math.py:129(circle_circle_intersection)\n",
      "       16    0.000    0.000    0.000    0.000 _math.py:175(vector_angle_in_degrees)\n",
      "        2    0.000    0.000    0.000    0.000 _math.py:199(normalize_by_center_of_mass)\n",
      "       14    0.000    0.000    0.002    0.000 _math.py:44(circle_intersection_area)\n",
      "        8    0.000    0.000    0.001    0.000 _methods.py:164(_mean)\n",
      "      224    0.000    0.000    0.002    0.000 _methods.py:61(_all)\n",
      "        8    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        4    0.000    0.000    0.000    0.000 _region.py:126(__init__)\n",
      "        4    0.000    0.000    0.001    0.000 _region.py:132(subtract_and_intersect_circle)\n",
      "        8    0.000    0.000    0.000    0.000 _region.py:230(__init__)\n",
      "        6    0.000    0.000    0.001    0.000 _region.py:459(label_position)\n",
      "        6    0.000    0.000    0.000    0.000 _region.py:461(<listcomp>)\n",
      "        6    0.001    0.000    0.009    0.001 _region.py:482(make_patch)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        2    0.000    0.000    0.001    0.000 _venn2.py:104(compute_venn2_colors)\n",
      "        2    0.000    0.000    0.001    0.000 _venn2.py:113(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _venn2.py:117(compute_venn2_subsets)\n",
      "        2    0.000    0.000    0.122    0.061 _venn2.py:183(venn2)\n",
      "        2    0.000    0.000    0.009    0.004 _venn2.py:239(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.000 _venn2.py:246(<listcomp>)\n",
      "        2    0.000    0.000    0.005    0.003 _venn2.py:247(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _venn2.py:251(<listcomp>)\n",
      "        2    0.000    0.000    0.003    0.002 _venn2.py:254(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _venn2.py:29(compute_venn2_areas)\n",
      "        2    0.000    0.000    0.002    0.001 _venn2.py:57(solve_venn2_circles)\n",
      "        2    0.000    0.000    0.001    0.001 _venn2.py:89(compute_venn2_regions)\n",
      "        2    0.000    0.000    0.002    0.001 _zeros_py.py:658(brentq)\n",
      "        2    0.000    0.000    0.000    0.000 _zeros_py.py:70(results_c)\n",
      "       10    0.000    0.000    0.000    0.000 artist.py:1007(set_alpha)\n",
      "       39    0.000    0.000    0.000    0.000 artist.py:103(_stale_axes_callback)\n",
      "       18    0.000    0.000    0.002    0.000 artist.py:1180(_update_props)\n",
      "       14    0.000    0.000    0.002    0.000 artist.py:1205(update)\n",
      "        4    0.000    0.000    0.000    0.000 artist.py:1216(_internal_update)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:1375(get_mouseover)\n",
      "       24    0.001    0.000    0.001    0.000 artist.py:180(__init__)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:271(convert_xunits)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:283(convert_yunits)\n",
      "      258    0.000    0.000    0.000    0.000 artist.py:295(axes)\n",
      "       48    0.000    0.000    0.000    0.000 artist.py:300(axes)\n",
      "  577/475    0.001    0.000    0.001    0.000 artist.py:319(stale)\n",
      "      114    0.000    0.000    0.001    0.000 artist.py:417(pchanged)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:430(is_transform_set)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:438(set_transform)\n",
      "       34    0.000    0.000    0.000    0.000 artist.py:451(get_transform)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:737(set_figure)\n",
      "       24    0.001    0.000    0.009    0.000 artist.py:778(set_clip_path)\n",
      "      577    0.000    0.000    0.000    0.000 artist.py:851(get_animated)\n",
      "       10    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "       14    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\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:1574(get_major_locator)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1590(get_major_ticks)\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",
      "       28    0.000    0.000    0.001    0.000 axis.py:1725(convert_units)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1862(set_major_locator)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:2014(_set_tick_locations)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2022(<listcomp>)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:2041(set_ticks)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2212(setter)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2462(get_minpos)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2721(get_minpos)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:549(locator)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:553(locator)\n",
      "        8    0.000    0.000    0.000    0.000 axis.py:560(formatter)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_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",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:72(show)\n",
      "      126    0.003    0.000    0.006    0.000 bezier.py:191(__init__)\n",
      "      126    0.001    0.000    0.001    0.000 bezier.py:195(<listcomp>)\n",
      "      126    0.004    0.000    0.007    0.000 bezier.py:200(__call__)\n",
      "      112    0.000    0.000    0.000    0.000 bezier.py:224(control_points)\n",
      "      238    0.000    0.000    0.000    0.000 bezier.py:234(degree)\n",
      "      112    0.006    0.000    0.020    0.000 bezier.py:239(polynomial_coefficients)\n",
      "      126    0.006    0.000    0.087    0.001 bezier.py:275(axis_aligned_extrema)\n",
      "      123    0.000    0.000    0.001    0.000 colors.py:213(_is_nth_color)\n",
      "       14    0.000    0.000    0.000    0.000 colors.py:218(is_color_like)\n",
      "       14    0.000    0.000    0.001    0.000 colors.py:237(_check_color_like)\n",
      "      109    0.001    0.000    0.003    0.000 colors.py:265(to_rgba)\n",
      "       12    0.000    0.000    0.001    0.000 colors.py:307(_to_rgba_no_colorcycle)\n",
      "       48    0.000    0.000    0.000    0.000 colors.py:384(<genexpr>)\n",
      "       60    0.000    0.000    0.000    0.000 colors.py:394(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 colors.py:494(to_rgb)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "       24    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "       24    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "       24    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "       24    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "       14    0.000    0.000    0.000    0.000 copy.py:259(_reconstruct)\n",
      "       14    0.000    0.000    0.001    0.000 copy.py:66(copy)\n",
      "       14    0.000    0.000    0.000    0.000 copyreg.py:104(__newobj__)\n",
      "       12    0.000    0.000    0.000    0.000 cycler.py:165(keys)\n",
      "      132    0.000    0.000    0.000    0.000 cycler.py:239(__iter__)\n",
      "       12    0.000    0.000    0.001    0.000 cycler.py:364(by_key)\n",
      "       12    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "    32/28    0.000    0.000    0.013    0.000 deprecation.py:443(wrapper)\n",
      "       20    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "       20    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "       63    0.000    0.000    0.000    0.000 figure.py:54(_stale_figure_callback)\n",
      "        4    0.000    0.000    0.000    0.000 font_manager.py:1061(get_default_size)\n",
      "       14    0.000    0.000    0.001    0.000 font_manager.py:588(__init__)\n",
      "       14    0.000    0.000    0.001    0.000 font_manager.py:608(_from_any)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:729(set_style)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "       22    0.000    0.000    0.000    0.000 font_manager.py:807(set_size)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "       14    0.000    0.000    0.000    0.000 font_manager.py:865(set_math_fontfamily)\n",
      "       14    0.000    0.000    0.001    0.000 font_manager.py:893(copy)\n",
      "      448    0.000    0.000    0.000    0.000 fromnumeric.py:1777(_ravel_dispatcher)\n",
      "      448    0.001    0.000    0.002    0.000 fromnumeric.py:1781(ravel)\n",
      "      224    0.000    0.000    0.000    0.000 fromnumeric.py:1888(_nonzero_dispatcher)\n",
      "      224    0.000    0.000    0.002    0.000 fromnumeric.py:1892(nonzero)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 fromnumeric.py:198(reshape)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2183(_sum_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2188(sum)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:2333(any)\n",
      "      276    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "      276    0.001    0.000    0.004    0.000 fromnumeric.py:2432(all)\n",
      "       42    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "       42    0.000    0.000    0.001    0.000 fromnumeric.py:2703(amax)\n",
      "       30    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "       30    0.000    0.000    0.001    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",
      "        8    0.000    0.000    0.000    0.000 fromnumeric.py:3340(_mean_dispatcher)\n",
      "        8    0.000    0.000    0.001    0.000 fromnumeric.py:3345(mean)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:38(_wrapit)\n",
      "      248    0.001    0.000    0.002    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "      364    0.002    0.000    0.005    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "      364    0.001    0.000    0.001    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 function_base.py:18(_linspace_dispatcher)\n",
      "       12    0.001    0.000    0.001    0.000 function_base.py:23(linspace)\n",
      "      224    0.001    0.000    0.014    0.000 function_base.py:2301(__call__)\n",
      "      224    0.003    0.000    0.007    0.000 function_base.py:2331(_get_ufunc_and_otypes)\n",
      "      224    0.000    0.000    0.001    0.000 function_base.py:2361(<listcomp>)\n",
      "      672    0.000    0.000    0.000    0.000 function_base.py:2362(<genexpr>)\n",
      "      224    0.001    0.000    0.001    0.000 function_base.py:2366(<listcomp>)\n",
      "      224    0.000    0.000    0.001    0.000 function_base.py:2390(<listcomp>)\n",
      "      224    0.003    0.000    0.013    0.000 function_base.py:2400(_vectorize_call)\n",
      "      224    0.000    0.000    0.002    0.000 function_base.py:2410(<listcomp>)\n",
      "       44    0.000    0.000    0.000    0.000 function_base.py:346(iterable)\n",
      "      224    0.000    0.000    0.000    0.000 function_base.py:5440(_append_dispatcher)\n",
      "      224    0.001    0.000    0.004    0.000 function_base.py:5444(append)\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",
      "       10    0.000    0.000    0.000    0.000 hatch.py:182(_validate_hatch_pattern)\n",
      "      224    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "      224    0.000    0.000    0.001    0.000 linalg.py:112(_makearray)\n",
      "      680    0.000    0.000    0.001    0.000 linalg.py:117(isComplexType)\n",
      "      448    0.000    0.000    0.001    0.000 linalg.py:130(_realType)\n",
      "      224    0.001    0.000    0.002    0.000 linalg.py:136(_commonType)\n",
      "      224    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "      224    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "      224    0.001    0.000    0.004    0.000 linalg.py:192(_assert_finite)\n",
      "        8    0.000    0.000    0.000    0.000 linalg.py:2338(_norm_dispatcher)\n",
      "        8    0.000    0.000    0.000    0.000 linalg.py:2342(norm)\n",
      "      224    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "      224    0.009    0.000    0.022    0.000 linalg.py:969(eigvals)\n",
      "       10    0.000    0.000    0.000    0.000 lines.py:33(_get_dash_pattern)\n",
      "       23    0.000    0.000    0.000    0.000 lines.py:63(_scale_dashes)\n",
      "      460    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "      682    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "       12    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:740(dot)\n",
      "      224    0.000    0.000    0.000    0.000 multiarray.py:84(empty_like)\n",
      "      224    0.001    0.000    0.002    0.000 numeric.py:150(ones)\n",
      "       16    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "       12    0.000    0.000    0.000    0.000 numeric.py:290(full)\n",
      "      224    0.000    0.000    0.000    0.000 numeric.py:354(_full_like_dispatcher)\n",
      "      224    0.001    0.000    0.003    0.000 numeric.py:358(full_like)\n",
      "        4    0.000    0.000    0.001    0.000 patches.py:1521(__init__)\n",
      "        4    0.000    0.000    0.001    0.000 patches.py:1557(_recompute_transform)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:1576(get_path)\n",
      "        4    0.000    0.000    0.001    0.000 patches.py:1580(get_patch_transform)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:1601(set_width)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:1620(set_height)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:1648(get_angle)\n",
      "        4    0.000    0.000    0.002    0.000 patches.py:1861(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:1876(set_radius)\n",
      "       34    0.000    0.000    0.008    0.000 patches.py:262(get_transform)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:273(get_patch_transform)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:304(set_antialiased)\n",
      "       39    0.000    0.000    0.001    0.000 patches.py:317(_set_edgecolor)\n",
      "       19    0.000    0.000    0.001    0.000 patches.py:332(set_edgecolor)\n",
      "       42    0.000    0.000    0.002    0.000 patches.py:343(_set_facecolor)\n",
      "       22    0.000    0.000    0.002    0.000 patches.py:350(set_facecolor)\n",
      "        4    0.000    0.000    0.000    0.000 patches.py:361(set_color)\n",
      "       10    0.000    0.000    0.001    0.000 patches.py:377(set_alpha)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:384(set_linewidth)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:399(set_linestyle)\n",
      "       10    0.000    0.000    0.001    0.000 patches.py:434(set_fill)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:456(set_capstyle)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:476(set_joinstyle)\n",
      "       10    0.000    0.000    0.004    0.000 patches.py:48(__init__)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "       24    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       24    0.001    0.000    0.005    0.000 patches.py:742(get_patch_transform)\n",
      "       48    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "       24    0.000    0.000    0.002    0.000 patches.py:876(get_bbox)\n",
      "        6    0.000    0.000    0.003    0.000 patches.py:943(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:955(get_path)\n",
      "       10    0.000    0.000    0.000    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       28    0.000    0.000    0.001    0.000 path.py:202(_update_values)\n",
      "       62    0.000    0.000    0.000    0.000 path.py:211(vertices)\n",
      "       30    0.000    0.000    0.000    0.000 path.py:225(codes)\n",
      "       20    0.000    0.000    0.000    0.000 path.py:244(simplify_threshold)\n",
      "       20    0.000    0.000    0.000    0.000 path.py:256(should_simplify)\n",
      "       10    0.000    0.000    0.000    0.000 path.py:350(__len__)\n",
      "      136    0.002    0.000    0.007    0.000 path.py:353(iter_segments)\n",
      "      136    0.001    0.000    0.015    0.000 path.py:419(iter_bezier)\n",
      "       10    0.000    0.000    0.001    0.000 path.py:466(cleaned)\n",
      "        4    0.000    0.000    0.000    0.000 path.py:800(unit_circle)\n",
      "       12    0.002    0.000    0.004    0.000 path.py:924(arc)\n",
      "       28    0.001    0.000    0.002    0.000 path.py:99(__init__)\n",
      "      224    0.000    0.000    0.000    0.000 polynomial.py:167(_roots_dispatcher)\n",
      "      224    0.008    0.000    0.050    0.000 polynomial.py:171(roots)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        1    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.000    0.000 pyplot.py:400(show)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "      448    0.000    0.000    0.000    0.000 shape_base.py:19(_atleast_1d_dispatcher)\n",
      "      234    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "      234    0.000    0.000    0.001    0.000 shape_base.py:218(_vhstack_dispatcher)\n",
      "       10    0.000    0.000    0.000    0.000 shape_base.py:223(vstack)\n",
      "      448    0.002    0.000    0.002    0.000 shape_base.py:23(atleast_1d)\n",
      "      224    0.001    0.000    0.006    0.000 shape_base.py:299(hstack)\n",
      "       10    0.000    0.000    0.000    0.000 shape_base.py:77(_atleast_2d_dispatcher)\n",
      "       10    0.000    0.000    0.000    0.000 shape_base.py:81(atleast_2d)\n",
      "       26    0.000    0.000    0.000    0.000 text.py:1000(set_horizontalalignment)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:1030(set_linespacing)\n",
      "        8    0.000    0.000    0.000    0.000 text.py:1098(set_fontsize)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:1217(set_rotation)\n",
      "       24    0.000    0.000    0.000    0.000 text.py:1249(set_verticalalignment)\n",
      "       17    0.000    0.000    0.000    0.000 text.py:1265(set_text)\n",
      "       14    0.000    0.000    0.002    0.000 text.py:1307(set_fontproperties)\n",
      "       14    0.000    0.000    0.007    0.000 text.py:132(__init__)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "       14    0.000    0.000    0.004    0.000 text.py:185(_reset_visual_defaults)\n",
      "       14    0.000    0.000    0.002    0.000 text.py:221(update)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "       28    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "       14    0.000    0.000    0.005    0.000 text.py:596(set_clip_path)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "        3    0.000    0.000    0.000    0.000 text.py:901(get_position)\n",
      "       14    0.000    0.000    0.001    0.000 text.py:985(set_color)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1651(nonsingular)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1716(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:259(_set_locator)\n",
      "        1    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "        1    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\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",
      "       48    0.000    0.000    0.000    0.000 transforms.py:1039(get_points)\n",
      "       24    0.000    0.000    0.001    0.000 transforms.py:1087(__init__)\n",
      "      242    0.000    0.000    0.000    0.000 transforms.py:110(__init__)\n",
      "       94    0.000    0.000    0.002    0.000 transforms.py:1335(__add__)\n",
      "       56    0.000    0.000    0.000    0.000 transforms.py:1350(_iter_break_from_left_to_right)\n",
      "       64    0.000    0.000    0.000    0.000 transforms.py:1362(depth)\n",
      "       10    0.000    0.000    0.002    0.000 transforms.py:1376(contains_branch)\n",
      "       10    0.000    0.000    0.002    0.000 transforms.py:1395(contains_branch_seperately)\n",
      "       10    0.000    0.000    0.001    0.000 transforms.py:1413(__sub__)\n",
      "      140    0.000    0.000    0.000    0.000 transforms.py:157(invalidate)\n",
      "      140    0.000    0.000    0.000    0.000 transforms.py:167(_invalidate_internal)\n",
      "       20    0.000    0.000    0.001    0.000 transforms.py:1705(__eq__)\n",
      "       20    0.000    0.000    0.000    0.000 transforms.py:1751(<lambda>)\n",
      "       20    0.000    0.000    0.000    0.000 transforms.py:1752(<lambda>)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:1753(<lambda>)\n",
      "       90    0.000    0.000    0.000    0.000 transforms.py:1764(__init__)\n",
      "       48    0.000    0.000    0.001    0.000 transforms.py:1772(__eq__)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1777(transform)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1843(transform_affine)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:1881(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      128    0.001    0.000    0.001    0.000 transforms.py:194(set_children)\n",
      "       28    0.000    0.000    0.001    0.000 transforms.py:1978(rotate)\n",
      "       28    0.000    0.000    0.001    0.000 transforms.py:2001(rotate_deg)\n",
      "       52    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       56    0.000    0.000    0.000    0.000 transforms.py:2046(scale)\n",
      "       64    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       60    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:2126(transform)\n",
      "       20    0.000    0.000    0.001    0.000 transforms.py:2162(__eq__)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:2307(get_matrix)\n",
      "       80    0.000    0.000    0.001    0.000 transforms.py:2347(__init__)\n",
      "    48/28    0.000    0.000    0.001    0.000 transforms.py:2391(__eq__)\n",
      "    64/48    0.000    0.000    0.001    0.000 transforms.py:2398(_iter_break_from_left_to_right)\n",
      "    44/20    0.000    0.000    0.000    0.000 transforms.py:2404(<lambda>)\n",
      "       94    0.000    0.000    0.002    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:263(y0)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:2822(nonsingular)\n",
      "       48    0.000    0.000    0.001    0.000 transforms.py:754(__init__)\n",
      "       24    0.000    0.000    0.001    0.000 transforms.py:790(unit)\n",
      "       24    0.000    0.000    0.001    0.000 transforms.py:809(from_extents)\n",
      "       10    0.000    0.000    0.000    0.000 transforms.py:856(update_from_path)\n",
      "       10    0.000    0.000    0.001    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",
      "      224    0.000    0.000    0.000    0.000 twodim_base.py:236(_diag_dispatcher)\n",
      "      224    0.002    0.000    0.002    0.000 twodim_base.py:240(diag)\n",
      "      112    0.000    0.000    0.000    0.000 type_check.py:117(_real_dispatcher)\n",
      "      112    0.000    0.000    0.000    0.000 type_check.py:121(real)\n",
      "      112    0.000    0.000    0.000    0.000 type_check.py:163(_imag_dispatcher)\n",
      "      112    0.000    0.000    0.000    0.000 type_check.py:167(imag)\n",
      "      112    0.000    0.000    0.000    0.000 type_check.py:206(_is_type_dispatcher)\n",
      "      112    0.001    0.000    0.001    0.000 type_check.py:247(isreal)\n",
      "     12/8    0.000    0.000    0.001    0.000 units.py:164(get_converter)\n",
      "       28    0.000    0.000    0.000    0.000 units.py:56(_is_natively_supported)\n",
      "       48    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFF5DDE9F90}\n",
      "      118    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "      258    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "      280    0.001    0.000    0.001    0.000 {built-in method builtins.any}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method builtins.delattr}\n",
      "        1    0.000    0.000    0.157    0.157 {built-in method builtins.exec}\n",
      "      907    0.001    0.000    0.001    0.000 {built-in method builtins.getattr}\n",
      "      361    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "      464    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     2233    0.001    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "     1180    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "       64    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "1889/1879    0.001    0.000    0.001    0.000 {built-in method builtins.len}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method builtins.max}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "      504    0.000    0.000    0.001    0.000 {built-in method builtins.next}\n",
      "       22    0.000    0.000    0.000    0.000 {built-in method builtins.setattr}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.sorted}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "     1398    0.000    0.000    0.000    0.000 {built-in method math.factorial}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.cleanup_path}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "      478    0.002    0.000    0.002    0.000 {built-in method numpy.arange}\n",
      "      240    0.001    0.000    0.001    0.000 {built-in method numpy.array}\n",
      "     2404    0.003    0.000    0.003    0.000 {built-in method numpy.asanyarray}\n",
      "     1330    0.002    0.000    0.002    0.000 {built-in method numpy.asarray}\n",
      "4628/1336    0.013    0.000    0.069    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "      248    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "      224    0.001    0.000    0.001    0.000 {built-in method numpy.frompyfunc}\n",
      "      450    0.001    0.000    0.001    0.000 {built-in method numpy.zeros}\n",
      "        2    0.000    0.000    0.002    0.001 {built-in method scipy.optimize._zeros._brentq}\n",
      "      345    0.000    0.000    0.000    0.000 {function RcParams.__getitem__ at 0x00000223C3292FC0}\n",
      "       14    0.000    0.000    0.000    0.000 {method '__reduce_ex__' of 'object' objects}\n",
      "      224    0.000    0.000    0.003    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "     1576    0.000    0.000    0.000    0.000 {method 'append' of 'list' objects}\n",
      "      236    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "       76    0.000    0.000    0.000    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'dot' of 'numpy.ndarray' objects}\n",
      "      696    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "      900    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "      224    0.000    0.000    0.000    0.000 {method 'join' of 'str' objects}\n",
      "      111    0.000    0.000    0.000    0.000 {method 'match' of 're.Pattern' objects}\n",
      "      224    0.000    0.000    0.000    0.000 {method 'nonzero' of 'numpy.ndarray' objects}\n",
      "      252    0.002    0.000    0.002    0.000 {method 'outer' of 'numpy.ufunc' objects}\n",
      "      100    0.000    0.000    0.000    0.000 {method 'pop' of 'dict' objects}\n",
      "      456    0.001    0.000    0.001    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "      596    0.004    0.000    0.004    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "       36    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        6    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 'tolist' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'update' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'values' of 'collections.OrderedDict' objects}\n",
      "       32    0.000    0.000    0.000    0.000 {method 'values' of 'dict' objects}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():   \n",
    "    \n",
    "    venn = venn2([set1, set2], ax=ax) \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",
    "    # 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(False_Positive))\n",
    "    venn.get_label_by_id('01').set_text('FN\\n' + str(False_Negative))\n",
    "    venn.get_label_by_id('11').set_text('TP+TN\\n' + str(True_Positive + True_Negative))\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, 'Old: ' + str(FP_old_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, 'Young: ' + str(FP_young_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, 'Old: ' + str(FN_old_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, 'Young: ' + str(FN_young_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",
    "\n",
    "\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.438\n"
     ]
    }
   ],
   "source": [
    "#original formula for accuracy\n",
    "from sklearn.metrics import accuracy_score\n",
    "print(accuracy_score(dataf1.Predicted_Final_credit,dataf1.Actual_output_credit))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.438\n"
     ]
    }
   ],
   "source": [
    "#THEOREM2 ---- ACCURACY OF MODEL\n",
    "Accuracy=(True_Positive+False_Negative)/len (dataf1)\n",
    "print(\"new model accuracy is\",Accuracy)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.438\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.000    0.000 1985470506.py:3(my_method)\n",
      "        1    0.000    0.000    0.000    0.000 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.000    0.000 frame.py:1498(__len__)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        4    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        1    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "      7/5    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        1    0.000    0.000    0.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": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    Accuracy=(True_Positive+False_Negative)/len (dataf1)\n",
    "    print(\"new model accuracy is\",Accuracy)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.438\n",
      "         921 function calls (913 primitive calls) in 0.004 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.004    0.004 1872961513.py:3(my_method)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(average)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(reshape)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(union1d)\n",
      "        5    0.000    0.000    0.001    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.004    0.004 <string>:1(<module>)\n",
      "        4    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "        6    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "        2    0.000    0.000    0.000    0.000 _array_api.py:83(unique_values)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "       10    0.000    0.000    0.000    0.000 _base.py:1301(isspmatrix)\n",
      "        1    0.000    0.000    0.000    0.000 _classification.py:137(_weighted_sum)\n",
      "        1    0.000    0.000    0.002    0.002 _classification.py:146(accuracy_score)\n",
      "        1    0.000    0.000    0.002    0.002 _classification.py:59(_check_targets)\n",
      "        8    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "        8    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "        7    0.000    0.000    0.000    0.000 _param_validation.py:103(make_constraint)\n",
      "        1    0.000    0.000    0.003    0.003 _param_validation.py:169(wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:179(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:185(<dictcomp>)\n",
      "       10    0.000    0.000    0.000    0.000 _param_validation.py:226(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _param_validation.py:258(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:262(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:272(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:28(validate_parameter_constraints)\n",
      "        3    0.000    0.000    0.000    0.000 _param_validation.py:471(is_satisfied_by)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:530(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _param_validation.py:538(is_satisfied_by)\n",
      "        2    0.000    0.000    0.000    0.000 _param_validation.py:547(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 _param_validation.py:74(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:138(unique)\n",
      "        5    0.000    0.000    0.000    0.000 arraysetops.py:323(_unique1d)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:898(union1d)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:391(_average_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:396(average)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.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.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",
      "       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.001    0.000 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.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.001    0.000 validation.py:1152(column_or_1d)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:257(_is_arraylike)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:262(_is_arraylike_not_scalar)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:629(check_array)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.any}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.004    0.004 {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.001    0.001 {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": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    from sklearn.metrics import accuracy_score\n",
    "    print(accuracy_score(dataf1.Predicted_Final_credit,dataf1.Actual_output_credit))\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from sklearn.metrics import confusion_matrix\n",
    "\n",
    "def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "    \n",
    "    # create a confusion matrix for each group\n",
    "    cm_group0 = confusion_matrix(y_true[sensitive_attr >np.average(dataf1['Age'])], y_pred[sensitive_attr >np.average(dataf1['Age'])])\n",
    "    cm_group1 = confusion_matrix(y_true[sensitive_attr <np.average(dataf1['Age'])], y_pred[sensitive_attr <np.average(dataf1['Age'])])\n",
    "    \n",
    "    # compute the true positive rate and false positive rate for each group\n",
    "    tpr_group0 = cm_group0[1, 1] / np.sum(cm_group0[1, :])\n",
    "    fpr_group0 = cm_group0[0, 1] / np.sum(cm_group0[0, :])\n",
    "    tpr_group1 = cm_group1[1, 1] / np.sum(cm_group1[1, :])\n",
    "    fpr_group1 = cm_group1[0, 1] / np.sum(cm_group1[0, :])\n",
    "    \n",
    "    # check if the true positive rate and false positive rate are equal across groups\n",
    "    if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "        print(\"Predictive parity is satisfied.\")\n",
    "    else:\n",
    "        print(\"Predictive parity is not satisfied.\")\n",
    "predictive_parity(dataf1.Actual_output_credit,dataf1.Predicted_Final_credit,dataf1.Age)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n",
      "         3966 function calls (3911 primitive calls) in 0.012 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.012    0.012 3872488367.py:3(my_method)\n",
      "        1    0.000    0.000    0.012    0.012 3872488367.py:7(predictive_parity)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        4    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(average)\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.001    0.000 <__array_function__ internals>:177(unique)\n",
      "       18    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       10    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "       17    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.012    0.012 <string>:1(<module>)\n",
      "        8    0.000    0.000    0.000    0.000 _array_api.py:168(_asarray_with_order)\n",
      "       12    0.000    0.000    0.000    0.000 _array_api.py:63(__getattr__)\n",
      "       30    0.000    0.000    0.000    0.000 _array_api.py:70(asarray)\n",
      "       12    0.000    0.000    0.001    0.000 _array_api.py:83(unique_values)\n",
      "       30    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:105(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:119(get_shape)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1287(_process_toarray_args)\n",
      "       36    0.000    0.000    0.000    0.000 _base.py:1301(isspmatrix)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:291(nnz)\n",
      "        2    0.000    0.000    0.006    0.003 _classification.py:232(confusion_matrix)\n",
      "        2    0.000    0.000    0.003    0.002 _classification.py:59(_check_targets)\n",
      "       30    0.000    0.000    0.000    0.000 _config.py:22(_get_threadlocal_config)\n",
      "       30    0.000    0.000    0.000    0.000 _config.py:30(get_config)\n",
      "        2    0.000    0.000    0.000    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:164(_mean)\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",
      "        4    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\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.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "        4    0.000    0.000    0.000    0.000 array_ops.py:231(comparison_op)\n",
      "        2    0.000    0.000    0.001    0.001 arraylike.py:48(__lt__)\n",
      "        2    0.000    0.000    0.001    0.000 arraylike.py:56(__gt__)\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.001    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",
      "       10    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5304(__getitem__)\n",
      "        7    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:690(_simple_new)\n",
      "        8    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:870(_reset_identity)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:986(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        8    0.000    0.000    0.000    0.000 blocks.py:500(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 blocks.py:836(_slice)\n",
      "        4    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       16    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       40    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1751(pandas_dtype)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "       11    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.002    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",
      "        4    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "        4    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\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",
      "        7    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        7    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",
      "        4    0.000    0.000    0.000    0.000 function_base.py:391(_average_dispatcher)\n",
      "        4    0.000    0.000    0.001    0.000 function_base.py:396(average)\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",
      "       92    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "       92    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",
      "       59    0.000    0.000    0.001    0.000 generic.py:5888(__getattr__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        7    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:2522(check_bool_indexer)\n",
      "       11    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",
      "       35    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.001 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "        4    0.000    0.000    0.001    0.000 managers.py:2023(getitem_mgr)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:2054(index)\n",
      "       64    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       44    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:140(dispatch_fill_zeros)\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.000    0.000 range.py:541(equals)\n",
      "       20    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:956(__getitem__)\n",
      "        4    0.000    0.000    0.001    0.000 series.py:1068(_get_values)\n",
      "        4    0.000    0.000    0.001    0.000 series.py:3194(_construct_result)\n",
      "        8    0.000    0.000    0.001    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.002    0.000 series.py:6233(_cmp_method)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       44    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        4    0.000    0.000    0.002    0.000 series.py:966(__getitem__)\n",
      "        1    0.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.000    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.000    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",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.gt}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.lt}\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",
      "       11    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.012    0.012 {built-in method builtins.exec}\n",
      "      158    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "      177    0.000    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "       45    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  593/581    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       45    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",
      "       51    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    74/58    0.000    0.000    0.001    0.000 {built-in method numpy.asarray}\n",
      "    48/41    0.000    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.core._multiarray_umath.normalize_axis_index}\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",
      "        9    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",
      "        4    0.000    0.000    0.000    0.000 {method 'mean' 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",
      "        2    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "       26    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",
      "        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",
      "       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",
      "       12    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_integer}\n",
      "       11    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",
      "       20    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       15    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",
    "    import numpy as np\n",
    "    from sklearn.metrics import confusion_matrix\n",
    "\n",
    "    def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "    \n",
    "        # create a confusion matrix for each group\n",
    "        cm_group0 = confusion_matrix(y_true[sensitive_attr >np.average(dataf1['Age'])], y_pred[sensitive_attr >np.average(dataf1['Age'])])\n",
    "        cm_group1 = confusion_matrix(y_true[sensitive_attr <np.average(dataf1['Age'])], y_pred[sensitive_attr <np.average(dataf1['Age'])])\n",
    "        \n",
    "        # compute the true positive rate and false positive rate for each group\n",
    "        tpr_group0 = cm_group0[1, 1] / np.sum(cm_group0[1, :])\n",
    "        fpr_group0 = cm_group0[0, 1] / np.sum(cm_group0[0, :])\n",
    "        tpr_group1 = cm_group1[1, 1] / np.sum(cm_group1[1, :])\n",
    "        fpr_group1 = cm_group1[0, 1] / np.sum(cm_group1[0, :])\n",
    "        \n",
    "        # check if the true positive rate and false positive rate are equal across groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Predictive parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Predictive parity is not satisfied.\")\n",
    "    predictive_parity(dataf1.Actual_output_credit,dataf1.Predicted_Final_credit,dataf1.Age)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalized odds is not satisfied.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(0.3325242718446602,\n",
       " 0.46601941747572817,\n",
       " 0.3435374149659864,\n",
       " 0.4710884353741497)"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#equlaized odds\n",
    "import numpy as np\n",
    "\n",
    "def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "    # find indices of positive predictions and sensitive attribute values\n",
    "    pos_indices = np.where(y_pred == 1)[0]\n",
    "    sensitive_indices = np.where(sensitive_attr <np.average(dataf1['Age']))[0]\n",
    "    # find indices of positive predictions and sensitive attribute values for each group\n",
    "    pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "    pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr <np.average(dataf1['Age']))[0])\n",
    "    # compute true positive rates for each group\n",
    "    tpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "    tpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "    # compute false positive rates for each group\n",
    "    fpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "    fpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "    # check if equalized odds is satisfied for both groups\n",
    "    if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "        print(\"Equalized odds is satisfied.\")\n",
    "    else:\n",
    "        print(\"Equalized odds is not satisfied.\")\n",
    "    return tpr_group0, tpr_group1, fpr_group0, fpr_group1\n",
    "equalized_odds(dataf1.Actual_output_credit,dataf1.Predicted_Final_credit,dataf1.Age)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalized odds is not satisfied.\n",
      "         3589 function calls (3508 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.008    0.008 2310706915.py:3(my_method)\n",
      "        1    0.000    0.000    0.008    0.008 2310706915.py:7(equalized_odds)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(average)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "       12    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(unique)\n",
      "       12    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.008    0.008 <string>:1(<module>)\n",
      "        3    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        3    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "       26    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       26    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "       13    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "       12    0.000    0.000    0.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "       12    0.000    0.000    0.001    0.000 array_ops.py:231(comparison_op)\n",
      "        9    0.000    0.000    0.003    0.000 arraylike.py:40(__eq__)\n",
      "        2    0.000    0.000    0.001    0.001 arraylike.py:48(__lt__)\n",
      "        1    0.000    0.000    0.001    0.001 arraylike.py:56(__gt__)\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.000    0.000 arraysetops.py:138(unique)\n",
      "       12    0.000    0.000    0.000    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",
      "        9    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        3    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       24    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "       12    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "       12    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       36    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       72    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "       12    0.000    0.000    0.005    0.000 common.py:57(new_method)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       24    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       24    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       36    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "       12    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "       12    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "       12    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "       12    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        6    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        6    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",
      "        3    0.000    0.000    0.000    0.000 function_base.py:391(_average_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 function_base.py:396(average)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       24    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      192    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      192    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       45    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       24    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",
      "        6    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       54    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",
      "       12    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       27    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "       12    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "       12    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "       12    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "       12    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "       12    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       48    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "       12    0.000    0.000    0.003    0.000 series.py:3194(_construct_result)\n",
      "       12    0.000    0.000    0.002    0.000 series.py:342(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "       12    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       48    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "       12    0.000    0.000    0.005    0.000 series.py:6233(_cmp_method)\n",
      "       36    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       27    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       15    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",
      "       24    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        9    0.000    0.000    0.000    0.000 {built-in method _operator.eq}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method _operator.gt}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.lt}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       36    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        6    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",
      "      222    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       15    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       63    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  662/650    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       42    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  202/154    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       48    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "       15    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    43/22    0.000    0.000    0.002    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       52    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       26    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'mean' of 'numpy.ndarray' objects}\n",
      "        5    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",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       36    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       36    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       30    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",
    "    #equlaized odds\n",
    "    import numpy as np\n",
    "\n",
    "    def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "        # find indices of positive predictions and sensitive attribute values\n",
    "        pos_indices = np.where(y_pred == 1)[0]\n",
    "        sensitive_indices = np.where(sensitive_attr <np.average(dataf1['Age']))[0]\n",
    "        # find indices of positive predictions and sensitive attribute values for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr <np.average(dataf1['Age']))[0])\n",
    "        # compute true positive rates for each group\n",
    "        tpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        tpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        # compute false positive rates for each group\n",
    "        fpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        fpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        # check if equalized odds is satisfied for both groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Equalized odds is satisfied.\")\n",
    "        else:\n",
    "            print(\"Equalized odds is not satisfied.\")\n",
    "        return tpr_group0, tpr_group1, fpr_group0, fpr_group1\n",
    "    equalized_odds(dataf1.Actual_output_credit,dataf1.Predicted_Final_credit,dataf1.Age)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#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 <np.average(dataf1['Age']))[0]\n",
    "    # find indices of positive predictions for each group\n",
    "    pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "    pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr <np.average(dataf1['Age']))[0])\n",
    "    # compute probabilities of positive predictions for each group\n",
    "    prob_pos_group0 = len(pos_indices_group0) / len(np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "    prob_pos_group1 = len(pos_indices_group1) / len(np.where(sensitive_attr <np.average(dataf1['Age']))[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(dataf1.Predicted_Final_credit,dataf1.Age)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Demographic parity is not satisfied.\n",
      "         1953 function calls (1914 primitive calls) in 0.004 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.004    0.004 1274260033.py:10(demographic_parity)\n",
      "        1    0.000    0.000    0.004    0.004 1274260033.py:3(my_method)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        5    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(average)\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(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(unique)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.004    0.004 <string>:1(<module>)\n",
      "        5    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        5    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\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",
      "        6    0.000    0.000    0.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "        6    0.000    0.000    0.000    0.000 array_ops.py:231(comparison_op)\n",
      "        1    0.000    0.000    0.001    0.001 arraylike.py:40(__eq__)\n",
      "        3    0.000    0.000    0.001    0.000 arraylike.py:48(__lt__)\n",
      "        2    0.000    0.000    0.001    0.000 arraylike.py:56(__gt__)\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.000    0.000 arraysetops.py:373(intersect1d)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        9    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       12    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        6    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        6    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       18    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       36    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        6    0.000    0.000    0.002    0.000 common.py:57(new_method)\n",
      "        6    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       12    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        6    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       18    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        6    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "        6    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        6    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "        6    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        6    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        7    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        7    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 function_base.py:391(_average_dispatcher)\n",
      "        5    0.000    0.000    0.000    0.000 function_base.py:396(average)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "       96    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "       96    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        6    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       30    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        7    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       31    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       17    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        6    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        6    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "        6    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       24    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        6    0.000    0.000    0.001    0.000 series.py:3194(_construct_result)\n",
      "        6    0.000    0.000    0.001    0.000 series.py:342(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       24    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "        6    0.000    0.000    0.002    0.000 series.py:6233(_cmp_method)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       17    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",
      "       12    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method _operator.eq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.gt}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method _operator.lt}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.004    0.004 {built-in method builtins.exec}\n",
      "      113    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",
      "       40    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  356/350    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "       25    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "   100/76    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       30    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",
      "    23/14    0.000    0.000    0.001    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'mean' of 'numpy.ndarray' objects}\n",
      "        7    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",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       18    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       18    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       19    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",
    "    #equlaized odds\n",
    "    import numpy as np\n",
    "\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 <np.average(dataf1['Age']))[0]\n",
    "        # find indices of positive predictions for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr <np.average(dataf1['Age']))[0])\n",
    "        # compute probabilities of positive predictions for each group\n",
    "        prob_pos_group0 = len(pos_indices_group0) / len(np.where(sensitive_attr >np.average(dataf1['Age']))[0])\n",
    "        prob_pos_group1 = len(pos_indices_group1) / len(np.where(sensitive_attr <np.average(dataf1['Age']))[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(dataf1.Predicted_Final_credit,dataf1.Age)\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
}
