{
 "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>age</th>\n",
       "      <th>workclass</th>\n",
       "      <th>fnlwgt</th>\n",
       "      <th>education</th>\n",
       "      <th>education-num</th>\n",
       "      <th>marital-status</th>\n",
       "      <th>occupation</th>\n",
       "      <th>relationship</th>\n",
       "      <th>race</th>\n",
       "      <th>sex</th>\n",
       "      <th>capital-gain</th>\n",
       "      <th>capital-loss</th>\n",
       "      <th>hours-per-week</th>\n",
       "      <th>native-country</th>\n",
       "      <th>salary</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>39</td>\n",
       "      <td>State-gov</td>\n",
       "      <td>77516</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>13</td>\n",
       "      <td>Never-married</td>\n",
       "      <td>Adm-clerical</td>\n",
       "      <td>Not-in-family</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>2174</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>50</td>\n",
       "      <td>Self-emp-not-inc</td>\n",
       "      <td>83311</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>13</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Exec-managerial</td>\n",
       "      <td>Husband</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>38</td>\n",
       "      <td>Private</td>\n",
       "      <td>215646</td>\n",
       "      <td>HS-grad</td>\n",
       "      <td>9</td>\n",
       "      <td>Divorced</td>\n",
       "      <td>Handlers-cleaners</td>\n",
       "      <td>Not-in-family</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>53</td>\n",
       "      <td>Private</td>\n",
       "      <td>234721</td>\n",
       "      <td>11th</td>\n",
       "      <td>7</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Handlers-cleaners</td>\n",
       "      <td>Husband</td>\n",
       "      <td>Black</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>28</td>\n",
       "      <td>Private</td>\n",
       "      <td>338409</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>13</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Prof-specialty</td>\n",
       "      <td>Wife</td>\n",
       "      <td>Black</td>\n",
       "      <td>Female</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>Cuba</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104094</th>\n",
       "      <td>37</td>\n",
       "      <td>Private</td>\n",
       "      <td>126954</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>13</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Exec-managerial</td>\n",
       "      <td>Husband</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>50</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&gt;50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104095</th>\n",
       "      <td>38</td>\n",
       "      <td>Private</td>\n",
       "      <td>85074</td>\n",
       "      <td>Assoc-acdm</td>\n",
       "      <td>12</td>\n",
       "      <td>Divorced</td>\n",
       "      <td>Adm-clerical</td>\n",
       "      <td>Unmarried</td>\n",
       "      <td>White</td>\n",
       "      <td>Female</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104096</th>\n",
       "      <td>26</td>\n",
       "      <td>Private</td>\n",
       "      <td>383306</td>\n",
       "      <td>12th</td>\n",
       "      <td>8</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Craft-repair</td>\n",
       "      <td>Husband</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&lt;=50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104097</th>\n",
       "      <td>50</td>\n",
       "      <td>Private</td>\n",
       "      <td>128143</td>\n",
       "      <td>Bachelors</td>\n",
       "      <td>13</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Craft-repair</td>\n",
       "      <td>Husband</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>0</td>\n",
       "      <td>1887</td>\n",
       "      <td>50</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&gt;50K</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104098</th>\n",
       "      <td>47</td>\n",
       "      <td>Private</td>\n",
       "      <td>185041</td>\n",
       "      <td>Some-college</td>\n",
       "      <td>10</td>\n",
       "      <td>Married-civ-spouse</td>\n",
       "      <td>Craft-repair</td>\n",
       "      <td>Husband</td>\n",
       "      <td>White</td>\n",
       "      <td>Male</td>\n",
       "      <td>7298</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>United-States</td>\n",
       "      <td>&gt;50K</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>104099 rows × 15 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        age         workclass  fnlwgt     education  education-num  \\\n",
       "0        39         State-gov   77516     Bachelors             13   \n",
       "1        50  Self-emp-not-inc   83311     Bachelors             13   \n",
       "2        38           Private  215646       HS-grad              9   \n",
       "3        53           Private  234721          11th              7   \n",
       "4        28           Private  338409     Bachelors             13   \n",
       "...     ...               ...     ...           ...            ...   \n",
       "104094   37           Private  126954     Bachelors             13   \n",
       "104095   38           Private   85074    Assoc-acdm             12   \n",
       "104096   26           Private  383306          12th              8   \n",
       "104097   50           Private  128143     Bachelors             13   \n",
       "104098   47           Private  185041  Some-college             10   \n",
       "\n",
       "            marital-status         occupation   relationship   race     sex  \\\n",
       "0            Never-married       Adm-clerical  Not-in-family  White    Male   \n",
       "1       Married-civ-spouse    Exec-managerial        Husband  White    Male   \n",
       "2                 Divorced  Handlers-cleaners  Not-in-family  White    Male   \n",
       "3       Married-civ-spouse  Handlers-cleaners        Husband  Black    Male   \n",
       "4       Married-civ-spouse     Prof-specialty           Wife  Black  Female   \n",
       "...                    ...                ...            ...    ...     ...   \n",
       "104094  Married-civ-spouse    Exec-managerial        Husband  White    Male   \n",
       "104095            Divorced       Adm-clerical      Unmarried  White  Female   \n",
       "104096  Married-civ-spouse       Craft-repair        Husband  White    Male   \n",
       "104097  Married-civ-spouse       Craft-repair        Husband  White    Male   \n",
       "104098  Married-civ-spouse       Craft-repair        Husband  White    Male   \n",
       "\n",
       "        capital-gain  capital-loss  hours-per-week native-country salary  \n",
       "0               2174             0              40  United-States  <=50K  \n",
       "1                  0             0              13  United-States  <=50K  \n",
       "2                  0             0              40  United-States  <=50K  \n",
       "3                  0             0              40  United-States  <=50K  \n",
       "4                  0             0              40           Cuba  <=50K  \n",
       "...              ...           ...             ...            ...    ...  \n",
       "104094             0             0              50  United-States   >50K  \n",
       "104095             0             0              40  United-States  <=50K  \n",
       "104096             0             0              40  United-States  <=50K  \n",
       "104097             0          1887              50  United-States   >50K  \n",
       "104098          7298             0              40  United-States   >50K  \n",
       "\n",
       "[104099 rows x 15 columns]"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "import pandas as pd\n",
    "import csv\n",
    "import sys\n",
    "import numpy as np\n",
    "count=0 \n",
    "data_uci=pd.read_csv('uciadultdataset.csv')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "data_uci"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['age', 'workclass', 'fnlwgt', 'education', 'education-num',\n",
       "       'marital-status', 'occupation', 'relationship', 'race', 'sex',\n",
       "       'capital-gain', 'capital-loss', 'hours-per-week', 'native-country',\n",
       "       'salary'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_uci.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "lec = LabelEncoder()\n",
    "data_uci['workclass'] = lec.fit_transform(data_uci['workclass'])\n",
    "data_uci['education'] = lec.fit_transform(data_uci['education'])\n",
    "data_uci['marital-status'] = lec.fit_transform(data_uci['marital-status'])\n",
    "data_uci['occupation'] = lec.fit_transform(data_uci['occupation'])\n",
    "data_uci['race'] = lec.fit_transform(data_uci['race'])\n",
    "data_uci['relationship'] = lec.fit_transform(data_uci['relationship'])\n",
    "data_uci.salary[data_uci.salary=='<=50K']=0\n",
    "data_uci.salary[data_uci.salary=='>50K']=1\n",
    "data_uci.sex[data_uci.sex=='Male']=1\n",
    "data_uci.sex[data_uci.sex=='Female']=0\n",
    "data_uci.sex[data_uci.sex=='unknown']=2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci.dropna(inplace=True)\n",
    "data_uci.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci['salary'].astype('int')\n",
    "data_uci['sex'].astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=data_uci['salary']\n",
    "x=data_uci[['age', 'workclass', 'education', 'marital-status', 'occupation',\n",
    "       'race', 'relationship', 'sex']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=y.astype('int')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(83279, 8)\n",
      "(20820, 8)\n",
      "(83279,)\n",
      "(20820,)\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.2,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": [
      "(83279, 8)\n",
      "(20820, 8)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.preprocessing import StandardScaler\n",
    "sc=StandardScaler()\n",
    "x_train=sc.fit_transform(x_train)\n",
    "x_test=sc.fit_transform(x_test)\n",
    "print(x_train.shape)\n",
    "print(x_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>#sk-container-id-1 {color: black;background-color: white;}#sk-container-id-1 pre{padding: 0;}#sk-container-id-1 div.sk-toggleable {background-color: white;}#sk-container-id-1 label.sk-toggleable__label {cursor: pointer;display: block;width: 100%;margin-bottom: 0;padding: 0.3em;box-sizing: border-box;text-align: center;}#sk-container-id-1 label.sk-toggleable__label-arrow:before {content: \"▸\";float: left;margin-right: 0.25em;color: #696969;}#sk-container-id-1 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-container-id-1 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-container-id-1 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-container-id-1 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-container-id-1 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-container-id-1 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: \"▾\";}#sk-container-id-1 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 input.sk-hidden--visually {border: 0;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;}#sk-container-id-1 div.sk-estimator {font-family: monospace;background-color: #f0f8ff;border: 1px dotted black;border-radius: 0.25em;box-sizing: border-box;margin-bottom: 0.5em;}#sk-container-id-1 div.sk-estimator:hover {background-color: #d4ebff;}#sk-container-id-1 div.sk-parallel-item::after {content: \"\";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-container-id-1 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-1 div.sk-serial::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: 0;}#sk-container-id-1 div.sk-serial {display: flex;flex-direction: column;align-items: center;background-color: white;padding-right: 0.2em;padding-left: 0.2em;position: relative;}#sk-container-id-1 div.sk-item {position: relative;z-index: 1;}#sk-container-id-1 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;position: relative;}#sk-container-id-1 div.sk-item::before, #sk-container-id-1 div.sk-parallel-item::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: -1;}#sk-container-id-1 div.sk-parallel-item {display: flex;flex-direction: column;z-index: 1;position: relative;background-color: white;}#sk-container-id-1 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-container-id-1 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-container-id-1 div.sk-parallel-item:only-child::after {width: 0;}#sk-container-id-1 div.sk-dashed-wrapped {border: 1px dashed gray;margin: 0 0.4em 0.5em 0.4em;box-sizing: border-box;padding-bottom: 0.4em;background-color: white;}#sk-container-id-1 div.sk-label label {font-family: monospace;font-weight: bold;display: inline-block;line-height: 1.2em;}#sk-container-id-1 div.sk-label-container {text-align: center;}#sk-container-id-1 div.sk-container {/* jupyter's `normalize.less` sets `[hidden] { display: none; }` but bootstrap.min.css set `[hidden] { display: none !important; }` so we also need the `!important` here to be able to override the default hidden behavior on the sphinx rendered scikit-learn.org. See: https://github.com/scikit-learn/scikit-learn/issues/21755 */display: inline-block !important;position: relative;}#sk-container-id-1 div.sk-text-repr-fallback {display: none;}</style><div id=\"sk-container-id-1\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>LinearRegression()</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-1\" type=\"checkbox\" checked><label for=\"sk-estimator-id-1\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">LinearRegression</label><div class=\"sk-toggleable__content\"><pre>LinearRegression()</pre></div></div></div></div></div>"
      ],
      "text/plain": [
       "LinearRegression()"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LinearRegression\n",
    "lr=LinearRegression()\n",
    "lr.fit(x_train,y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_prediction=lr.predict(x_test)\n",
    "y_prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "Predicted_Test_salary= lr.predict(x_test)\n",
    "Predicted_Train_salary=lr.predict(x_train) \n",
    "\n",
    "Predicted_Final_salary=np.concatenate((Predicted_Train_salary,Predicted_Test_salary))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "predicted_newuci=[]\n",
    "for i in range(len(data_uci)):\n",
    "    if(Predicted_Final_salary[i]<=np.average(Predicted_Final_salary)):   \n",
    "        predicted_newuci.append(0)\n",
    "    else:\n",
    "        predicted_newuci.append(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci['predicted_newuci']=predicted_newuci\n",
    "vc_predicted=data_uci['predicted_newuci'].value_counts()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "#CODE TO FIND ACTUAL OUTPUT\n",
    "\n",
    "from scipy.spatial.distance import euclidean\n",
    "distance1=[]\n",
    "euclidean_distance_value1=[]\n",
    "\n",
    "\n",
    "for i in range(0, len(data_uci)):\n",
    "    # Get the Euclidean distance between the first row and the current row\n",
    "    distance1_i = euclidean(x.iloc[100, :-1], x.iloc[i, :-1])\n",
    "    \n",
    "    # Add the distance to the list of distances\n",
    "    #distance.append(distance_i)\n",
    "    \n",
    "    # Add the Euclidean distance to the list of Euclidean distances\n",
    "    euclidean_distance_value1.append(np.sqrt(distance1_i))\n",
    "\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "euclidean_distance_value1=np.ceil(euclidean_distance_value1)\n",
    "print(euclidean_distance_value1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "Actual_value_salary=[]\n",
    "for i in range(len(data_uci)):\n",
    "    if(euclidean_distance_value1[i] <=np.ceil(np.average(euclidean_distance_value1))):   \n",
    "        Actual_value_salary.append(0)\n",
    "    else:\n",
    "        Actual_value_salary.append(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_uci['Actual_value_salary']=Actual_value_salary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0    77915\n",
       "1    26184\n",
       "Name: Actual_value_salary, dtype: int64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vc_actual=data_uci['Actual_value_salary'].value_counts()\n",
    "vc_actual"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of female (D) in the predicted output is  48978\n",
      "count of male (ND) in the predicted output is  55121\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in actual output\n",
    "Count_Pd=vc_predicted[0]\n",
    "Count_Pnd=vc_predicted[1]\n",
    "print(\"count of female (D) in the predicted output is \",Count_Pd)\n",
    "print(\"count of male (ND) in the predicted output is \",Count_Pnd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count of female (D) in the actual output is  77915\n",
      "count of male (ND) in the actual output is  26184\n"
     ]
    }
   ],
   "source": [
    "#code for finding frequency of occurence of Discriminating and Non-Discriminating class in expected output\n",
    "Count_Ad=vc_actual[0]\n",
    "Count_And=vc_actual[1]\n",
    "print(\"count of female (D) in the actual output is \",Count_Ad)\n",
    "print(\"count of male (ND) in the actual output is \",Count_And)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1    69646\n",
       "0    34453\n",
       "Name: sex, dtype: int64"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_uci['sex'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias of female -0.8398978318288683\n"
     ]
    }
   ],
   "source": [
    "degree_of_bias_d=((Count_Pd-Count_Ad)/34453)\n",
    "print(\"degree of bias of female\",degree_of_bias_d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "deg of bias of  male 0.4154868908480028\n"
     ]
    }
   ],
   "source": [
    "degree_of_bias_nd=((Count_Pnd-Count_And)/69646)\n",
    "print(\"deg of bias of  male\",degree_of_bias_nd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping doesnot exists\n"
     ]
    }
   ],
   "source": [
    "\n",
    "if np.logical_and(data_uci.Actual_value_salary.iloc,data_uci.predicted_newuci.all()):\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 exists\")\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TgjNNqeknZ2d1tfuVK9eHb+f8EHlypV1blej0aCqpweePHmCCRMmYvWanN/mUdqUxq+OAgALM/3mP7334JHy/u/05hvKrE0qlQoODg5IT0/XurWreo0aOHDwsM6vn9q3dw/GjB6l3IBvYmICKysrrblOu7/1Fvbs3Z/j92PJ4kXKdx2am5vDyspKuU9XkiRMm/4BPv/iy3wnzejQri0uXryALl274sjRX/TaB6+ygnx11Cs50IYKJ/un5vBsExzr8uIX/mavG63jBuXssr7bMLu6devixs3b+O67Nfj556O4f+8e4uPj4ejoiNp16qB37z6YMGFirgNxAOCPP/7AkydPAHDUKRXc5198iWPHfsHZM2cQFBSIZ8+eQaPRoEKFCqjfoAF69eqNwUOGwtLSUmf9/gMGoqFXI6xZvQpnzpxGUGAgUlJS4ObmBq9GjTBkyFAMGPiuzmDr0eNthIeH4+KFC3jyJBhJSUnwqFIF7dq2w7jxE9C8Re6XDLI8ePBAmZ+VA2wKjkeKRKVAaT1SJAL4JcNEREQGYSgSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpE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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#CREATE CONFUSION MATRIX\n",
    "# Calculate the confusion matrix\n",
    "from sklearn.metrics import confusion_matrix\n",
    "conf_matrix = confusion_matrix(y_true=data_uci.Actual_value_salary, y_pred=data_uci.predicted_newuci)\n",
    "#\n",
    "# Print the confusion matrix using Matplotlib\n",
    "#\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "ax.matshow(conf_matrix, cmap=plt.cm.Blues, alpha=0.3)\n",
    "for i in range(conf_matrix.shape[0]):\n",
    "    for j in range(conf_matrix.shape[1]):\n",
    "        ax.text(x=j, y=i,s=conf_matrix[i, j], va='center', ha='center', size='xx-large')\n",
    " \n",
    "plt.xlabel('Predictions', fontsize=18)\n",
    "plt.ylabel('Actuals', fontsize=18)\n",
    "plt.title('Confusion Matrix', fontsize=18)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TgjNNqeknZ2d1tfuVK9eHb+f8EHlypV1blej0aCqpweePHmCCRMmYvWanN/mUdqUxq+OAgALM/3mP7334JHy/u/05hvKrE0qlQoODg5IT0/XurWreo0aOHDwsM6vn9q3dw/GjB6l3IBvYmICKysrrblOu7/1Fvbs3Z/j92PJ4kXKdx2am5vDyspKuU9XkiRMm/4BPv/iy3wnzejQri0uXryALl274sjRX/TaB6+ygnx11Cs50IYKJ/un5vBsExzr8uIX/mavG63jBuXssr7bMLu6devixs3b+O67Nfj556O4f+8e4uPj4ejoiNp16qB37z6YMGFirgNxAOCPP/7AkydPAHDUKRXc5198iWPHfsHZM2cQFBSIZ8+eQaPRoEKFCqjfoAF69eqNwUOGwtLSUmf9/gMGoqFXI6xZvQpnzpxGUGAgUlJS4ObmBq9GjTBkyFAMGPiuzmDr0eNthIeH4+KFC3jyJBhJSUnwqFIF7dq2w7jxE9C8Re6XDLI8ePBAmZ+VA2wKjkeKRKVAaT1SJAL4JcNEREQGYSgSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpEREQyhiIREZGMoUhERCRjKBIREckYikRERDKGIhERkYyhSEREJGMoEhERyRiKREREMoYiERGRjKFIREQkYygSERHJGIpE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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.591 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.591    0.591 3881667541.py:3(my_method)\n",
      "      184    0.000    0.000    0.005    0.000 <__array_function__ internals>:177(all)\n",
      "      710    0.001    0.000    0.010    0.000 <__array_function__ internals>:177(amax)\n",
      "      714    0.001    0.000    0.012    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(any)\n",
      "      840    0.001    0.000    0.011    0.000 <__array_function__ internals>:177(around)\n",
      "       22    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(broadcast_arrays)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(can_cast)\n",
      "        2    0.000    0.000    0.001    0.001 <__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.002    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(cumsum)\n",
      "       16    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(diff)\n",
      "      230    0.001    0.000    0.003    0.000 <__array_function__ internals>:177(dot)\n",
      "        5    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(empty_like)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(in1d)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(inv)\n",
      "       84    0.000    0.000    0.015    0.000 <__array_function__ internals>:177(isclose)\n",
      "        3    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(isin)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(min_scalar_type)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(nan_to_num)\n",
      "       12    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "      168    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(nonzero)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ones_like)\n",
      "      168    0.000    0.000    0.004    0.000 <__array_function__ internals>:177(ptp)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ravel_multi_index)\n",
      "      234    0.001    0.000    0.007    0.000 <__array_function__ internals>:177(reshape)\n",
      "       84    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(result_type)\n",
      "      840    0.002    0.000    0.015    0.000 <__array_function__ internals>:177(round_)\n",
      "        1    0.000    0.000    0.007    0.007 <__array_function__ internals>:177(union1d)\n",
      "       15    0.000    0.000    0.024    0.002 <__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.002    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.591    0.591 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.018    0.018 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.017    0.017 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.017    0.017 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.017    0.017 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.003    0.000    0.003    0.000 __init__.py:101(check_in_list)\n",
      "       13    0.000    0.000    0.000    0.000 __init__.py:106(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:109(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:112(__eq__)\n",
      "       27    0.000    0.000    0.000    0.000 __init__.py:115(__hash__)\n",
      "       16    0.000    0.000    0.000    0.000 __init__.py:119(_weak_or_strong_ref)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1286(is_interactive)\n",
      "      212    0.001    0.000    0.001    0.000 __init__.py:1314(is_math_text)\n",
      "      172    0.000    0.000    0.001    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       66    0.000    0.000    0.001    0.000 __init__.py:134(check_shape)\n",
      "        1    0.000    0.000    0.005    0.005 __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.007    0.000    0.009    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.004    0.000    0.007    0.000 __init__.py:1726(normalize_kwargs)\n",
      "       19    0.000    0.000    0.000    0.000 __init__.py:175(check_getitem)\n",
      "      278    0.002    0.000    0.002    0.000 __init__.py:1765(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:183(dumps)\n",
      "      158    0.000    0.000    0.000    0.000 __init__.py:1834(_str_equal)\n",
      "       25    0.000    0.000    0.000    0.000 __init__.py:1845(_str_lower_equal)\n",
      "      102    0.001    0.000    0.001    0.000 __init__.py:190(__init__)\n",
      "      998    0.004    0.000    0.007    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.001    0.000 __init__.py:221(connect)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:2290(_unpack_to_numpy)\n",
      "       11    0.000    0.000    0.000    0.000 __init__.py:235(_connect_picklable)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:265(disconnect)\n",
      "      344    0.001    0.000    0.001    0.000 __init__.py:272(_compile)\n",
      "  582/580    0.003    0.000    0.005    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.002    0.000 __init__.py:550(_get_data_path)\n",
      "      211    0.001    0.000    0.002    0.000 __init__.py:65(check_isinstance)\n",
      "     2772    0.003    0.000    0.005    0.000 __init__.py:691(_get)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:708(safe_masked_invalid)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:73(get_projection_class)\n",
      "     2772    0.004    0.000    0.009    0.000 __init__.py:742(__getitem__)\n",
      "      148    0.000    0.000    0.000    0.000 __init__.py:80(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:825(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:826(<dictcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 __init__.py:828(__contains__)\n",
      "     1510    0.002    0.000    0.003    0.000 __init__.py:831(clean)\n",
      "     1510    0.001    0.000    0.001    0.000 __init__.py:834(<listcomp>)\n",
      "     1508    0.005    0.000    0.010    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.017    0.003 _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.005    0.005 _axes.py:5459(imshow)\n",
      "        4    0.000    0.000    0.006    0.001 _axes.py:626(text)\n",
      "        1    0.000    0.000    0.011    0.011 _axes.py:7937(matshow)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:1025(get_yaxis_text1_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:105(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1051(get_yaxis_text2_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1077(_update_transScale)\n",
      "      6/5    0.000    0.000    0.001    0.000 _base.py:1082(get_position)\n",
      "        6    0.000    0.000    0.001    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1179(_set_artist_props)\n",
      "        1    0.000    0.000    0.001    0.001 _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.010    0.010 _base.py:1206(_gen_axes_spines)\n",
      "        1    0.000    0.000    0.010    0.010 _base.py:1221(<dictcomp>)\n",
      "        1    0.000    0.000    0.055    0.055 _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.055    0.055 _base.py:1388(clear)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1522(_set_title_offset_trans)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1608(get_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1616(set_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1702(set_adjustable)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1766(set_box_aspect)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1803(get_anchor)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:1862(get_data_ratio)\n",
      "        5    0.000    0.000    0.003    0.001 _base.py:1876(apply_aspect)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:222(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2278(add_image)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2312(_add_text)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:235(set_prop_cycle)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:2446(_unit_change_handler)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:2485(update_datalim)\n",
      "        5    0.000    0.000    0.001    0.000 _base.py:2510(_process_unit_info)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:2569(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:291(nnz)\n",
      "        4    0.001    0.000    0.228    0.057 _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.270    0.135 _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.017    0.009 _base.py:3157(grid)\n",
      "        2    0.000    0.000    0.002    0.001 _base.py:3316(tick_params)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3405(set_axis_on)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3423(set_xlabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3488(get_xbound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3536(get_xlim)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3575(set_xlim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3672(set_ylabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3737(get_ybound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3785(get_ylim)\n",
      "        1    0.000    0.000    0.001    0.001 _base.py:3807(set_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3971(set_navigate)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3987(set_navigate_mode)\n",
      "        7    0.000    0.000    0.000    0.000 _base.py:4273(get_children)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4299(get_default_bbox_extra_artists)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:4328(<listcomp>)\n",
      "        2    0.000    0.000    0.128    0.064 _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.085    0.085 _base.py:574(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:652(<dictcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:73(wrapper)\n",
      "        1    0.000    0.000    0.001    0.001 _base.py:790(set_subplotspec)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:799(get_window_extent)\n",
      "        1    0.000    0.000    0.015    0.015 _base.py:818(_init_axis)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:827(set_figure)\n",
      "      732    0.002    0.000    0.020    0.000 _base.py:841(_unstale_viewLim)\n",
      "      732    0.004    0.000    0.017    0.000 _base.py:844(<dictcomp>)\n",
      "     2928    0.002    0.000    0.002    0.000 _base.py:845(<genexpr>)\n",
      "      730    0.001    0.000    0.021    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.001    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.001    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.001    0.001    0.032    0.032 _classification.py:232(confusion_matrix)\n",
      "        1    0.000    0.000    0.015    0.015 _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.002    0.002 _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.001    0.000    0.001    0.000 _methods.py:108(_clip_dep_invoke_with_casting)\n",
      "        2    0.000    0.000    0.001    0.000 _methods.py:127(_clip)\n",
      "      168    0.001    0.000    0.002    0.000 _methods.py:281(_ptp)\n",
      "     1374    0.001    0.000    0.007    0.000 _methods.py:39(_amax)\n",
      "      536    0.001    0.000    0.005    0.000 _methods.py:43(_amin)\n",
      "      168    0.000    0.000    0.002    0.000 _methods.py:47(_sum)\n",
      "       89    0.000    0.000    0.001    0.000 _methods.py:55(_any)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:93(_clip_dep_is_scalar_nan)\n",
      "        3    0.000    0.000    0.000    0.000 _pylab_helpers.py:100(get_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        2    0.000    0.000    0.001    0.000 _sputils.py:147(get_index_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.001    0.001 _tight_bbox.py:8(adjust_bbox)\n",
      "      174    0.001    0.000    0.001    0.000 _ufunc_config.py:132(geterr)\n",
      "      174    0.001    0.000    0.002    0.000 _ufunc_config.py:33(seterr)\n",
      "       87    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       87    0.000    0.000    0.002    0.000 _ufunc_config.py:430(__enter__)\n",
      "       87    0.000    0.000    0.001    0.000 _ufunc_config.py:435(__exit__)\n",
      "      168    0.000    0.000    0.001    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 _util.py:5(is_path)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       15    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       15    0.000    0.000    0.024    0.002 arraysetops.py:138(unique)\n",
      "       15    0.003    0.000    0.023    0.002 arraysetops.py:323(_unique1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:373(intersect1d)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:519(_in1d_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:524(in1d)\n",
      "        9    0.000    0.000    0.000    0.000 arraysetops.py:630(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 arraysetops.py:761(_isin_dispatcher)\n",
      "        3    0.000    0.000    0.001    0.000 arraysetops.py:766(isin)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        1    0.000    0.000    0.007    0.007 arraysetops.py:898(union1d)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:1007(set_alpha)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1025(_set_alpha_for_array)\n",
      "     1294    0.002    0.000    0.008    0.000 artist.py:103(_stale_axes_callback)\n",
      "      114    0.000    0.000    0.002    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       26    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "       82    0.000    0.000    0.000    0.000 artist.py:1132(sticky_edges)\n",
      "       20    0.000    0.000    0.001    0.000 artist.py:1159(update_from)\n",
      "      312    0.005    0.000    0.023    0.000 artist.py:1180(_update_props)\n",
      "       34    0.000    0.000    0.004    0.000 artist.py:1205(update)\n",
      "      278    0.000    0.000    0.020    0.000 artist.py:1216(_internal_update)\n",
      "      244    0.001    0.000    0.023    0.000 artist.py:1227(set)\n",
      "       50    0.000    0.000    0.005    0.000 artist.py:1233(_cm_set)\n",
      "       25    0.000    0.000    0.000    0.000 artist.py:1238(<dictcomp>)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:1375(get_mouseover)\n",
      "        4    0.000    0.000    0.032    0.008 artist.py:1408(_get_tightbbox_for_layout_only)\n",
      "      244    0.001    0.000    0.024    0.000 artist.py:147(<lambda>)\n",
      "       82    0.002    0.000    0.004    0.000 artist.py:180(__init__)\n",
      "      278    0.001    0.000    0.002    0.000 artist.py:271(convert_xunits)\n",
      "      276    0.000    0.000    0.001    0.000 artist.py:283(convert_yunits)\n",
      "     4199    0.001    0.000    0.001    0.000 artist.py:295(axes)\n",
      "      107    0.000    0.000    0.000    0.000 artist.py:300(axes)\n",
      "7598/5140    0.010    0.000    0.017    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.040    0.001 artist.py:352(get_tightbbox)\n",
      "      571    0.001    0.000    0.006    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.002    0.000 artist.py:438(set_transform)\n",
      "      286    0.001    0.000    0.001    0.000 artist.py:451(get_transform)\n",
      "    100/2    0.001    0.000    0.273    0.137 artist.py:54(draw_wrapper)\n",
      "       14    0.000    0.000    0.000    0.000 artist.py:604(get_url)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:608(set_url)\n",
      "       64    0.000    0.000    0.000    0.000 artist.py:618(get_gid)\n",
      "       12    0.000    0.000    0.000    0.000 artist.py:632(get_snap)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:671(get_sketch_params)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:730(get_path_effects)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:733(get_figure)\n",
      "       81    0.000    0.000    0.001    0.000 artist.py:737(set_figure)\n",
      "        6    0.000    0.000    0.000    0.000 artist.py:761(set_clip_box)\n",
      "       19    0.001    0.000    0.011    0.001 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.003    0.000    0.003    0.000 artist.py:851(get_animated)\n",
      "       32    0.000    0.000    0.000    0.000 artist.py:855(get_in_layout)\n",
      "       30    0.000    0.000    0.000    0.000 artist.py:866(_fully_clipped_to_axes)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:890(get_clip_on)\n",
      "       47    0.000    0.000    0.000    0.000 artist.py:894(get_clip_box)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\n",
      "       48    0.000    0.000    0.001    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.273    0.137 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.018    0.009 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.002    0.001 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.006    0.000    0.198    0.002 axis.py:1252(_update_ticks)\n",
      "       48    0.000    0.000    0.055    0.001 axis.py:1295(_get_ticklabel_bboxes)\n",
      "       48    0.000    0.000    0.016    0.000 axis.py:1299(<listcomp>)\n",
      "       48    0.000    0.000    0.039    0.001 axis.py:1301(<listcomp>)\n",
      "       20    0.001    0.000    0.244    0.012 axis.py:1304(get_tightbbox)\n",
      "       40    0.000    0.000    0.004    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.056    0.014 axis.py:1363(draw)\n",
      "       84    0.000    0.000    0.023    0.000 axis.py:1477(get_majorticklocs)\n",
      "       84    0.003    0.000    0.047    0.001 axis.py:1481(get_minorticklocs)\n",
      "       10    0.000    0.000    0.046    0.005 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.008    0.002 axis.py:1560(_copy_tick_props)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1574(get_major_locator)\n",
      "       84    0.000    0.000    0.029    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.017    0.004 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.001    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.001    0.000 axis.py:1796(set_major_formatter)\n",
      "       14    0.000    0.000    0.001    0.000 axis.py:1822(set_minor_formatter)\n",
      "       28    0.000    0.000    0.001    0.000 axis.py:1836(_set_formatter)\n",
      "       16    0.000    0.000    0.001    0.000 axis.py:1862(set_major_locator)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1878(set_minor_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1894(set_pickradius)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:196(_set_labelrotation)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:208(_apply_tickdir)\n",
      "       24    0.000    0.000    0.075    0.003 axis.py:2083(_get_tick_boxes_siblings)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2091(<listcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2145(_get_ticks_position)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2161(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2167(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2173(<genexpr>)\n",
      "      672    0.002    0.000    0.024    0.000 axis.py:2208(getter)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:2212(setter)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:223(get_tick_padding)\n",
      "        1    0.000    0.000    0.004    0.004 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2241(_init)\n",
      "       16    0.001    0.000    0.102    0.006 axis.py:2298(_update_label_position)\n",
      "       16    0.000    0.000    0.005    0.000 axis.py:2338(_update_offset_text_position)\n",
      "        6    0.000    0.000    0.007    0.001 axis.py:237(set_clip_path)\n",
      "        2    0.000    0.000    0.004    0.002 axis.py:2385(set_ticks_position)\n",
      "        1    0.000    0.000    0.003    0.003 axis.py:2425(tick_top)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2449(get_ticks_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2462(get_minpos)\n",
      "        1    0.000    0.000    0.003    0.003 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.004    0.001 axis.py:2500(_init)\n",
      "        8    0.000    0.000    0.044    0.005 axis.py:2559(_update_label_position)\n",
      "        8    0.000    0.000    0.001    0.000 axis.py:2598(_update_offset_text_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2721(get_minpos)\n",
      "      336    0.000    0.000    0.000    0.000 axis.py:289(get_loc)\n",
      "        8    0.000    0.000    0.014    0.002 axis.py:293(draw)\n",
      "      336    0.001    0.000    0.003    0.000 axis.py:305(set_label1)\n",
      "      336    0.001    0.000    0.003    0.000 axis.py:318(set_label2)\n",
      "       50    0.000    0.000    0.001    0.000 axis.py:342(_set_artist_props)\n",
      "       23    0.001    0.000    0.008    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.023    0.005 axis.py:416(__init__)\n",
      "        5    0.000    0.000    0.001    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.002    0.000 axis.py:444(_apply_tickdir)\n",
      "      221    0.002    0.000    0.011    0.000 axis.py:455(update_position)\n",
      "        5    0.000    0.000    0.023    0.005 axis.py:477(__init__)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:499(_get_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:502(_get_text2_transform)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:505(_apply_tickdir)\n",
      "      125    0.001    0.000    0.005    0.000 axis.py:516(update_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:543(__init__)\n",
      "      256    0.000    0.000    0.000    0.000 axis.py:549(locator)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:553(locator)\n",
      "      418    0.000    0.000    0.000    0.000 axis.py:560(formatter)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:564(formatter)\n",
      "       10    0.001    0.000    0.035    0.003 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.025    0.006 axis.py:583(__get__)\n",
      "        2    0.000    0.000    0.006    0.003 axis.py:643(__init__)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:701(isDefault_majfmt)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:709(isDefault_minloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:717(isDefault_minfmt)\n",
      "       84    0.000    0.000    0.000    0.000 axis.py:727(get_remove_overlapping_locs)\n",
      "      432    0.000    0.000    0.003    0.000 axis.py:758(get_transform)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_scale)\n",
      "       14    0.000    0.000    0.013    0.001 axis.py:765(_set_scale)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:821(limit_range_for_scale)\n",
      "        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.024    0.002 axis.py:855(clear)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:893(reset_ticks)\n",
      "       11    0.000    0.000    0.024    0.002 axis.py:913(set_tick_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:100(_update_methods)\n",
      "        6    0.000    0.000    0.001    0.000 backend_agg.py:109(draw_path)\n",
      "       11    0.000    0.000    0.005    0.000 backend_agg.py:200(draw_text)\n",
      "       24    0.001    0.000    0.011    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.005    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.001    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.113    0.056 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.007    0.003 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.131    0.065 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.131    0.065 backend_agg.py:462(print_png)\n",
      "        2    0.006    0.003    0.006    0.003 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.007    0.007 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.001    0.000 backend_bases.py:2174(_switch_canvas_and_return_print_method)\n",
      "        2    0.000    0.000    0.131    0.065 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.449    0.449 backend_bases.py:2237(print_figure)\n",
      "        3    0.000    0.000    0.000    0.000 backend_bases.py:2411(mpl_connect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2474(mpl_disconnect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2809(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2840(notify_axes_change)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2846(create_with_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2921(destroy)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2937(set_window_title)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3572(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3577(draw_if_interactive)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:447(get_image_magnification)\n",
      "       22    0.000    0.000    0.000    0.000 backend_bases.py:661(flipy)\n",
      "       48    0.000    0.000    0.002    0.000 backend_bases.py:679(new_gc)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:735(_draw_disabled)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:743(<dictcomp>)\n",
      "       86    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       48    0.001    0.000    0.002    0.000 backend_bases.py:756(__init__)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:797(restore)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:824(get_clip_path)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:839(get_dashes)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:876(get_snap)\n",
      "       36    0.000    0.000    0.000    0.000 backend_bases.py:887(set_alpha)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:904(set_antialiased)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:909(set_capstyle)\n",
      "       10    0.000    0.000    0.000    0.000 backend_bases.py:920(set_clip_rectangle)\n",
      "       48    0.000    0.000    0.001    0.000 backend_bases.py:924(set_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:929(set_dashes)\n",
      "       82    0.000    0.000    0.000    0.000 backend_bases.py:959(set_foreground)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:979(set_joinstyle)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:990(set_linewidth)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:994(set_url)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:998(set_gid)\n",
      "        1    0.000    0.000    0.003    0.003 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.453    0.453 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.001    0.001 cm.py:405(_scale_norm)\n",
      "        2    0.000    0.000    0.007    0.004 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.001    0.001 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.002    0.001 colors.py:1315(__call__)\n",
      "        3    0.000    0.000    0.001    0.000 colors.py:1382(autoscale_None)\n",
      "       12    0.000    0.000    0.000    0.000 colors.py:203(_sanitize_extrema)\n",
      "      349    0.001    0.000    0.010    0.000 colors.py:213(_is_nth_color)\n",
      "       99    0.000    0.000    0.003    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.004    0.000 colors.py:237(_check_color_like)\n",
      "      250    0.001    0.000    0.010    0.000 colors.py:265(to_rgba)\n",
      "        2    0.001    0.001    0.007    0.004 colors.py:683(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      612    0.002    0.000    0.003    0.000 contextlib.py:104(__init__)\n",
      "  612/587    0.001    0.000    0.009    0.000 contextlib.py:132(__enter__)\n",
      "  612/587    0.002    0.000    0.008    0.000 contextlib.py:141(__exit__)\n",
      "      612    0.002    0.000    0.004    0.000 contextlib.py:287(helper)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:450(_create_exit_wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:460(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:490(enter_context)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:522(_push_cm_exit)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:527(_push_exit_callback)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:543(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:546(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:751(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:754(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:757(__exit__)\n",
      "     1038    0.000    0.000    0.000    0.000 copy.py:107(_copy_immutable)\n",
      "   748/12    0.003    0.000    0.006    0.001 copy.py:128(deepcopy)\n",
      "      584    0.000    0.000    0.000    0.000 copy.py:182(_deepcopy_atomic)\n",
      "    48/12    0.001    0.000    0.006    0.000 copy.py:227(_deepcopy_dict)\n",
      "       12    0.000    0.000    0.001    0.000 copy.py:237(_deepcopy_method)\n",
      "      128    0.000    0.000    0.000    0.000 copy.py:243(_keep_alive)\n",
      "      481    0.003    0.000    0.007    0.000 copy.py:259(_reconstruct)\n",
      "      144    0.000    0.000    0.001    0.000 copy.py:264(<genexpr>)\n",
      "     1579    0.006    0.000    0.013    0.000 copy.py:66(copy)\n",
      "      457    0.001    0.000    0.001    0.000 copyreg.py:104(__newobj__)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1283(_replace_dtype_fields_recursive)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1315(_replace_dtype_fields)\n",
      "       14    0.000    0.000    0.000    0.000 core.py:1329(make_mask_descr)\n",
      "       33    0.000    0.000    0.000    0.000 core.py:1362(getmask)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:1545(_shrink_mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1555(make_mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1644(make_mask_none)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:1816(_check_mask_axis)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:1828(masked_where)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:199(_recursive_fill_value)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:220(_get_dtype_of)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:2332(masked_invalid)\n",
      "       12    0.000    0.000    0.002    0.000 core.py:2808(__new__)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:285(_extremum_fill_value)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:287(_scalar_fill_value)\n",
      "       21    0.000    0.000    0.000    0.000 core.py:2940(_update_from)\n",
      "       21    0.000    0.000    0.001    0.000 core.py:2966(__array_finalize__)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:299(minimum_fill_value)\n",
      "        8    0.000    0.000    0.000    0.000 core.py:3205(__getitem__)\n",
      "        4    0.000    0.000    0.000    0.000 core.py:3222(_scalar_heuristic)\n",
      "       61    0.000    0.000    0.000    0.000 core.py:3401(dtype)\n",
      "       28    0.000    0.000    0.000    0.000 core.py:3417(shape)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3429(__setmask__)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:350(maximum_fill_value)\n",
      "        4    0.000    0.000    0.000    0.000 core.py:3500(mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3510(mask)\n",
      "        1    0.000    0.000    0.000    0.000 core.py:3640(shrink_mask)\n",
      "       20    0.000    0.000    0.000    0.000 core.py:3676(_get_data)\n",
      "        6    0.000    0.000    0.000    0.000 core.py:3770(filled)\n",
      "        3    0.000    0.000    0.001    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.001    0.000    0.001    0.000 cycler.py:364(by_key)\n",
      "       10    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "       12    0.000    0.000    0.001    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.451    0.038 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       35    0.000    0.000    0.001    0.000 deprecation.py:289(wrapper)\n",
      "      7/5    0.000    0.000    0.007    0.001 deprecation.py:379(wrapper)\n",
      "       12    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    76/68    0.001    0.000    0.049    0.001 deprecation.py:443(wrapper)\n",
      "       10    0.000    0.000    0.000    0.000 dir2.py:54(get_real_method)\n",
      "        1    0.000    0.000    0.453    0.453 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.002    0.002 display_functions.py:45(publish_display_data)\n",
      "        1    0.000    0.000    0.000    0.000 displaypub.py:43(_validate_data)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:105(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:183(encode)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:205(iterencode)\n",
      "      284    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1232(__reduce_ex__)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:1243(name)\n",
      "       24    0.000    0.000    0.000    0.000 enum.py:192(__get__)\n",
      "      284    0.000    0.000    0.001    0.000 enum.py:691(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:101(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:131(update)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1474(add_gridspec)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1598(sca)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:1604(gca)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:161(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1650(_process_projection_requirements)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1686(get_default_bbox_extra_artists)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1687(<listcomp>)\n",
      "        1    0.000    0.000    0.147    0.147 figure.py:1694(get_tightbbox)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1745(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.001 figure.py:191(_get_draw_artists)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:203(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:204(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2105(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2353(__repr__)\n",
      "        1    0.000    0.000    0.002    0.002 figure.py:2360(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2553(_check_layout_engines_compat)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:2572(set_layout_engine)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:259(get_children)\n",
      "        4    0.000    0.000    0.000    0.000 figure.py:2638(get_layout_engine)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:2645(_repr_html_)\n",
      "        9    0.000    0.000    0.000    0.000 figure.py:2696(axes)\n",
      "      808    0.000    0.000    0.000    0.000 figure.py:2718(_get_dpi)\n",
      "      360    0.000    0.000    0.000    0.000 figure.py:2721(_set_dpi)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:2875(set_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3096(clear)\n",
      "        2    0.000    0.000    0.273    0.137 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.003    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.085    0.085 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.085    0.085 figure.py:760(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:80(bubble)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:86(add)\n",
      "        3    0.000    0.000    0.000    0.000 figure.py:91(current)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:933(clear)\n",
      "       42    0.000    0.000    0.000    0.000 font_manager.py:1061(get_default_size)\n",
      "       49    0.001    0.000    0.003    0.000 font_manager.py:1200(findfont)\n",
      "      294    0.000    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       35    0.000    0.000    0.003    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       35    0.000    0.000    0.001    0.000 font_manager.py:1490(get_font)\n",
      "       70    0.000    0.000    0.000    0.000 font_manager.py:1515(<genexpr>)\n",
      "       67    0.001    0.000    0.005    0.000 font_manager.py:588(__init__)\n",
      "       90    0.000    0.000    0.004    0.000 font_manager.py:608(_from_any)\n",
      "     1059    0.006    0.000    0.009    0.000 font_manager.py:631(__hash__)\n",
      "      345    0.000    0.000    0.006    0.000 font_manager.py:642(__eq__)\n",
      "     1094    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "     1094    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "      102    0.000    0.000    0.001    0.000 font_manager.py:715(set_family)\n",
      "       67    0.001    0.000    0.001    0.000 font_manager.py:729(set_style)\n",
      "       67    0.000    0.000    0.001    0.000 font_manager.py:742(set_variant)\n",
      "       70    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "      111    0.001    0.000    0.001    0.000 font_manager.py:807(set_size)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "     1059    0.000    0.000    0.000    0.000 font_manager.py:857(get_math_fontfamily)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:865(set_math_fontfamily)\n",
      "      420    0.001    0.000    0.011    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.450    0.038 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.449    0.050 formatters.py:328(__call__)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:356(_check_return)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:371(lookup)\n",
      "       11    0.000    0.000    0.000    0.000 formatters.py:394(lookup_by_type)\n",
      "       40    0.000    0.000    0.000    0.000 formatters.py:550(_in_deferred_types)\n",
      "        1    0.000    0.000    0.001    0.001 formatters.py:693(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:828(_check_return)\n",
      "        1    0.000    0.000    0.451    0.451 formatters.py:88(format)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:905(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:942(_check_return)\n",
      "        1    0.000    0.000    0.000    0.000 formatters.py:951(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:1888(_nonzero_dispatcher)\n",
      "      168    0.000    0.000    0.001    0.000 fromnumeric.py:1892(nonzero)\n",
      "      234    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "      234    0.001    0.000    0.006    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2107(_clip_dispatcher)\n",
      "        2    0.000    0.000    0.001    0.000 fromnumeric.py:2111(clip)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 fromnumeric.py:2333(any)\n",
      "      184    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "      184    0.001    0.000    0.004    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:2600(_ptp_dispatcher)\n",
      "      168    0.001    0.000    0.003    0.000 fromnumeric.py:2604(ptp)\n",
      "      710    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "      710    0.001    0.000    0.008    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.010    0.000 fromnumeric.py:2829(amin)\n",
      "       12    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "       12    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "     1680    0.001    0.000    0.001    0.000 fromnumeric.py:3241(_around_dispatcher)\n",
      "      840    0.001    0.000    0.008    0.000 fromnumeric.py:3245(around)\n",
      "      840    0.001    0.000    0.012    0.000 fromnumeric.py:3754(round_)\n",
      "      234    0.002    0.000    0.004    0.000 fromnumeric.py:38(_wrapit)\n",
      "     1246    0.003    0.000    0.014    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "     1632    0.006    0.000    0.020    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "     1632    0.002    0.000    0.002    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       16    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       16    0.001    0.000    0.001    0.000 function_base.py:1320(diff)\n",
      "     1364    0.001    0.000    0.002    0.000 function_base.py:346(iterable)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:35(update_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:65(wraps)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "      172    0.001    0.000    0.001    0.000 getlimits.py:476(__new__)\n",
      "      172    0.002    0.000    0.002    0.000 getlimits.py:558(smallest_normal)\n",
      "      172    0.000    0.000    0.002    0.000 getlimits.py:581(tiny)\n",
      "       13    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:101(set_width_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:123(set_height_ratios)\n",
      "        1    0.000    0.000    0.001    0.001 gridspec.py:145(get_grid_positions)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:191(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:199(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:228(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 gridspec.py:232(_normalize)\n",
      "        1    0.000    0.000    0.085    0.085 gridspec.py:265(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:329(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:33(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:413(get_subplot_params)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:430(<dictcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:546(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:556(_from_subplot_args)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:604(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:608(num2)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:612(get_gridspec)\n",
      "        1    0.000    0.000    0.001    0.001 gridspec.py:653(get_position)\n",
      "        3    0.000    0.000    0.000    0.000 gridspec.py:75(get_geometry)\n",
      "        6    0.000    0.000    0.000    0.000 hatch.py:182(_validate_hatch_pattern)\n",
      "        4    0.000    0.000    0.000    0.000 hmac.py:117(update)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:122(copy)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:139(_current)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:161(hexdigest)\n",
      "        3    0.000    0.000    0.000    0.000 image.py:1004(get_extent)\n",
      "      4/2    0.000    0.000    0.270    0.135 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.018    0.018 image.py:1567(imsave)\n",
      "        4    0.000    0.000    0.018    0.005 image.py:160(_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:247(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:287(get_size)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:294(set_alpha)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:308(_get_scalar_alpha)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:321(changed)\n",
      "        2    0.002    0.001    0.034    0.017 image.py:328(_make_image)\n",
      "        2    0.000    0.000    0.038    0.019 image.py:617(draw)\n",
      "        1    0.000    0.000    0.001    0.001 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.034    0.017 image.py:940(make_image)\n",
      "        1    0.000    0.000    0.002    0.002 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.001    0.001 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:215(send_multipart)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:287(send_multipart)\n",
      "        2    0.000    0.000    0.001    0.001 iostream.py:480(flush)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:107(json_default)\n",
      "        2    0.000    0.000    0.000    0.000 jsonutil.py:38(_ensure_tzinfo)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:52(encode_images)\n",
      "        1    0.000    0.000    0.000    0.000 jsonutil.py:77(json_clean)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:112(_makearray)\n",
      "        6    0.000    0.000    0.000    0.000 linalg.py:117(isComplexType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:130(_realType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:136(_commonType)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "        3    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "        3    0.001    0.000    0.001    0.000 linalg.py:469(inv)\n",
      "       10    0.000    0.000    0.003    0.000 lines.py:1026(get_path)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1040(set_antialiased)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1052(set_color)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1064(set_drawstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1099(set_gapcolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1122(set_linewidth)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1137(set_linestyle)\n",
      "       20    0.000    0.000    0.002    0.000 lines.py:1182(set_marker)\n",
      "       90    0.000    0.000    0.001    0.000 lines.py:1196(_set_markercolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1210(set_markeredgecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1220(set_markerfacecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1230(set_markerfacecoloralt)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1240(set_markeredgewidth)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1255(set_markersize)\n",
      "      723    0.003    0.000    0.006    0.000 lines.py:1269(set_xdata)\n",
      "      435    0.001    0.000    0.003    0.000 lines.py:1290(set_ydata)\n",
      "       12    0.000    0.000    0.007    0.001 lines.py:1335(update_from)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       30    0.002    0.000    0.014    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.001    0.000 lines.py:63(_scale_dashes)\n",
      "       60    0.000    0.000    0.002    0.000 lines.py:635(set_data)\n",
      "       22    0.001    0.000    0.005    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.001    0.000 lines.py:718(set_transform)\n",
      "       24    0.001    0.000    0.006    0.000 lines.py:729(draw)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:893(get_drawstyle)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:933(get_markeredgecolor)\n",
      "       24    0.000    0.000    0.000    0.000 lines.py:959(_get_markerfacecolor)\n",
      "       18    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       16    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       62    0.000    0.000    0.010    0.000 markers.py:228(__init__)\n",
      "      112    0.000    0.000    0.002    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:293(__bool__)\n",
      "       44    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       62    0.000    0.000    0.001    0.000 markers.py:302(_set_fillstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:318(get_joinstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:321(get_capstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:324(get_marker)\n",
      "       62    0.001    0.000    0.009    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.012    0.003 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.006    0.003 multiclass.py:23(_unique_multiclass)\n",
      "        1    0.000    0.000    0.012    0.012 multiclass.py:44(unique_labels)\n",
      "        3    0.000    0.000    0.006    0.002 multiclass.py:81(<genexpr>)\n",
      "        1    0.000    0.000    0.001    0.001 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.014    0.000 numeric.py:2278(isclose)\n",
      "       84    0.003    0.000    0.008    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.010    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.006    0.000 patches.py:317(_set_edgecolor)\n",
      "       13    0.000    0.000    0.006    0.000 patches.py:332(set_edgecolor)\n",
      "       19    0.000    0.000    0.001    0.000 patches.py:343(_set_facecolor)\n",
      "       13    0.000    0.000    0.001    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.001    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.009    0.002 patches.py:48(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "       12    0.000    0.000    0.002    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "       12    0.000    0.000    0.004    0.000 patches.py:582(draw)\n",
      "       39    0.000    0.000    0.009    0.000 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.001    0.001 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.001    0.000 patches.py:734(_convert_units)\n",
      "       26    0.001    0.000    0.008    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.003    0.000 patches.py:876(get_bbox)\n",
      "       68    0.000    0.000    0.001    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       66    0.000    0.000    0.001    0.000 path.py:202(_update_values)\n",
      "      240    0.000    0.000    0.000    0.000 path.py:211(vertices)\n",
      "      159    0.000    0.000    0.000    0.000 path.py:225(codes)\n",
      "       19    0.000    0.000    0.000    0.000 path.py:244(simplify_threshold)\n",
      "       19    0.000    0.000    0.000    0.000 path.py:256(should_simplify)\n",
      "       12    0.000    0.000    0.001    0.000 path.py:281(__deepcopy__)\n",
      "       39    0.001    0.000    0.007    0.000 path.py:603(get_extents)\n",
      "        7    0.000    0.000    0.000    0.000 path.py:730(unit_rectangle)\n",
      "       66    0.001    0.000    0.003    0.000 path.py:99(__init__)\n",
      "       28    0.000    0.000    0.000    0.000 pathlib.py:147(splitroot)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:484(_parse_args)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:504(_from_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:523(_format_parsed_parts)\n",
      "       14    0.000    0.000    0.000    0.000 pathlib.py:536(__str__)\n",
      "       14    0.001    0.000    0.001    0.000 pathlib.py:56(parse_parts)\n",
      "       14    0.000    0.000    0.002    0.000 pathlib.py:868(__new__)\n",
      "        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.449    0.449 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.088    0.088 pyplot.py:1328(subplots)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        5    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:2280(gca)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:3055(title)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3062(xlabel)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3070(ylabel)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:358(_warn_if_gui_out_of_main_thread)\n",
      "        1    0.000    0.000    0.003    0.003 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.453    0.453 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.003    0.003 pyplot.py:690(figure)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:866(gcf)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:887(get_fignums)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:926(close)\n",
      "        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.012    0.001 scale.py:103(set_default_locators_and_formatters)\n",
      "      516    0.001    0.000    0.003    0.000 scale.py:115(get_transform)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:704(scale_factory)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:96(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:198(utcnow)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:272(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:279(extract_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:598(msg_id)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:643(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:647(msg)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:673(sign)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:688(serialize)\n",
      "        1    0.000    0.000    0.001    0.001 session.py:752(send)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:852(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 session.py:92(json_packer)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 shape_base.py:612(column_stack)\n",
      "        5    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:135(get_patch_transform)\n",
      "       36    0.002    0.000    0.096    0.003 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.007    0.002 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.007    0.002 spines.py:221(clear)\n",
      "       44    0.001    0.000    0.002    0.000 spines.py:227(_adjust_location)\n",
      "        8    0.000    0.000    0.002    0.000 spines.py:285(draw)\n",
      "        4    0.000    0.000    0.000    0.000 spines.py:292(set_position)\n",
      "    44/40    0.000    0.000    0.001    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.009    0.002 spines.py:35(__init__)\n",
      "        4    0.000    0.000    0.010    0.002 spines.py:425(linear_spine)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:538(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:541(from_dict)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:551(__getattr__)\n",
      "       64    0.000    0.000    0.000    0.000 spines.py:558(__getitem__)\n",
      "        8    0.000    0.000    0.000    0.000 spines.py:584(__iter__)\n",
      "        7    0.000    0.000    0.000    0.000 spines.py:587(__len__)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:416(_broadcast_shape)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:476(_broadcast_arrays_dispatcher)\n",
      "       22    0.000    0.000    0.001    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       66    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "      110    0.000    0.000    0.001    0.000 text.py:1000(set_horizontalalignment)\n",
      "       24    0.000    0.000    0.011    0.000 text.py:101(_get_text_metrics_with_cache_impl)\n",
      "       55    0.000    0.000    0.001    0.000 text.py:1030(set_linespacing)\n",
      "       44    0.000    0.000    0.001    0.000 text.py:1098(set_fontsize)\n",
      "        3    0.000    0.000    0.000    0.000 text.py:1150(set_fontweight)\n",
      "       84    0.000    0.000    0.001    0.000 text.py:1184(set_position)\n",
      "      575    0.001    0.000    0.002    0.000 text.py:1195(set_x)\n",
      "      385    0.000    0.000    0.001    0.000 text.py:1206(set_y)\n",
      "       62    0.000    0.000    0.001    0.000 text.py:1217(set_rotation)\n",
      "      109    0.000    0.000    0.001    0.000 text.py:1249(set_verticalalignment)\n",
      "      798    0.001    0.000    0.001    0.000 text.py:1265(set_text)\n",
      "      182    0.001    0.000    0.002    0.000 text.py:1283(_preprocess_math)\n",
      "       55    0.001    0.000    0.007    0.000 text.py:1307(set_fontproperties)\n",
      "       31    0.000    0.000    0.016    0.001 text.py:132(__init__)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "      364    0.000    0.000    0.000    0.000 text.py:1335(get_usetex)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:1351(get_parse_math)\n",
      "       55    0.001    0.000    0.015    0.000 text.py:185(_reset_visual_defaults)\n",
      "       34    0.000    0.000    0.006    0.000 text.py:221(update)\n",
      "       40    0.000    0.000    0.003    0.000 text.py:270(_get_xy_display)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:277(_get_multialignment)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:315(get_rotation)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:323(get_transform_rotates_text)\n",
      "       62    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "      160    0.000    0.000    0.000    0.000 text.py:344(get_rotation_mode)\n",
      "        8    0.000    0.000    0.001    0.000 text.py:348(update_from)\n",
      "      160    0.012    0.000    0.068    0.000 text.py:363(_get_layout)\n",
      "      124    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        6    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        4    0.000    0.000    0.002    0.000 text.py:596(set_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       38    0.001    0.000    0.025    0.001 text.py:738(draw)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:808(get_color)\n",
      "      178    0.001    0.000    0.003    0.000 text.py:893(get_unitless_position)\n",
      "       84    0.000    0.000    0.000    0.000 text.py:901(get_position)\n",
      "      428    0.000    0.000    0.000    0.000 text.py:907(get_text)\n",
      "      178    0.004    0.000    0.089    0.000 text.py:918(get_window_extent)\n",
      "      320    0.002    0.000    0.029    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       69    0.001    0.000    0.003    0.000 text.py:985(set_color)\n",
      "        2    0.000    0.000    0.000    0.000 textpath.py:26(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        4    0.000    0.000    0.000    0.000 threading.py:1161(ident)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:1446(current_thread)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:236(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:264(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:267(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:273(_release_save)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:276(_acquire_restore)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:279(_is_owned)\n",
      "        2    0.000    0.000    0.001    0.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.002    0.000 ticker.py:1899(scale_range)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:1917(__init__)\n",
      "       58    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "      336    0.000    0.000    0.001    0.000 ticker.py:1932(closeto)\n",
      "      168    0.001    0.000    0.001    0.000 ticker.py:1942(le)\n",
      "      168    0.000    0.000    0.001    0.000 ticker.py:1949(ge)\n",
      "       16    0.000    0.000    0.005    0.000 ticker.py:1969(__init__)\n",
      "       16    0.001    0.000    0.003    0.000 ticker.py:2010(_validate_steps)\n",
      "       16    0.000    0.000    0.001    0.000 ticker.py:2025(_staircase)\n",
      "       16    0.000    0.000    0.005    0.000 ticker.py:2031(set_params)\n",
      "      168    0.017    0.000    0.029    0.000 ticker.py:2074(_raw_ticks)\n",
      "      168    0.001    0.000    0.046    0.000 ticker.py:2134(__call__)\n",
      "      168    0.001    0.000    0.038    0.000 ticker.py:2138(tick_values)\n",
      "      168    0.001    0.000    0.034    0.000 ticker.py:215(format_ticks)\n",
      "      168    0.001    0.000    0.006    0.000 ticker.py:218(<listcomp>)\n",
      "      168    0.000    0.000    0.000    0.000 ticker.py:238(set_locs)\n",
      "      360    0.001    0.000    0.002    0.000 ticker.py:247(fix_minus)\n",
      "       28    0.000    0.000    0.000    0.000 ticker.py:259(_set_locator)\n",
      "       14    0.000    0.000    0.004    0.000 ticker.py:2889(__init__)\n",
      "       14    0.000    0.000    0.005    0.000 ticker.py:427(__init__)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:454(set_useOffset)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:500(set_useLocale)\n",
      "      336    0.001    0.000    0.003    0.000 ticker.py:516(_format_maybe_minus_and_locale)\n",
      "       14    0.000    0.000    0.005    0.000 ticker.py:533(set_useMathText)\n",
      "      336    0.001    0.000    0.004    0.000 ticker.py:568(__call__)\n",
      "       24    0.000    0.000    0.000    0.000 ticker.py:668(get_offset)\n",
      "      168    0.001    0.000    0.054    0.000 ticker.py:696(set_locs)\n",
      "      168    0.004    0.000    0.013    0.000 ticker.py:705(_compute_offset)\n",
      "      168    0.004    0.000    0.011    0.000 ticker.py:744(_set_order_of_magnitude)\n",
      "      168    0.008    0.000    0.028    0.000 ticker.py:778(_set_format)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "     2254    0.001    0.000    0.001    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.001    0.000 transforms.py:1057(set)\n",
      "       26    0.000    0.000    0.001    0.000 transforms.py:1087(__init__)\n",
      "     1960    0.002    0.000    0.002    0.000 transforms.py:110(__init__)\n",
      "       53    0.000    0.000    0.001    0.000 transforms.py:1109(get_points)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:131(__getstate__)\n",
      "      130    0.000    0.000    0.003    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.001    0.000 transforms.py:1463(__array__)\n",
      "      160    0.001    0.000    0.011    0.000 transforms.py:1467(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1568(get_matrix)\n",
      "      424    0.001    0.000    0.003    0.000 transforms.py:157(invalidate)\n",
      "       39    0.000    0.000    0.003    0.000 transforms.py:1588(transform_path)\n",
      "       39    0.000    0.000    0.002    0.000 transforms.py:1597(transform_path_affine)\n",
      "       56    0.000    0.000    0.001    0.000 transforms.py:1607(transform_path_non_affine)\n",
      "  660/424    0.002    0.000    0.002    0.000 transforms.py:167(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1696(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1714(set)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1751(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1752(<lambda>)\n",
      "      214    0.000    0.000    0.000    0.000 transforms.py:1753(<lambda>)\n",
      "     1199    0.003    0.000    0.004    0.000 transforms.py:1764(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:1768(__array__)\n",
      "       11    0.000    0.000    0.001    0.000 transforms.py:1772(__eq__)\n",
      "      561    0.001    0.000    0.006    0.000 transforms.py:1777(transform)\n",
      "       39    0.000    0.000    0.002    0.000 transforms.py:1794(transform_path_affine)\n",
      "      307    0.000    0.000    0.000    0.000 transforms.py:1803(get_affine)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:1827(frozen)\n",
      "       30    0.000    0.000    0.000    0.000 transforms.py:1831(is_separable)\n",
      "      600    0.002    0.000    0.006    0.000 transforms.py:1843(transform_affine)\n",
      "       13    0.000    0.000    0.001    0.000 transforms.py:1864(inverted)\n",
      "      475    0.002    0.000    0.005    0.000 transforms.py:1881(__init__)\n",
      "      779    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      209    0.002    0.000    0.003    0.000 transforms.py:194(set_children)\n",
      "      186    0.002    0.000    0.004    0.000 transforms.py:1978(rotate)\n",
      "      186    0.001    0.000    0.004    0.000 transforms.py:2001(rotate_deg)\n",
      "       58    0.000    0.000    0.001    0.000 transforms.py:2033(translate)\n",
      "       92    0.001    0.000    0.001    0.000 transforms.py:2046(scale)\n",
      "      141    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "      682    0.001    0.000    0.001    0.000 transforms.py:2126(transform)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2190(__init__)\n",
      "      104    0.000    0.000    0.001    0.000 transforms.py:2214(<lambda>)\n",
      "       68    0.000    0.000    0.000    0.000 transforms.py:2222(transform_non_affine)\n",
      "      160    0.000    0.000    0.001    0.000 transforms.py:2254(get_affine)\n",
      "       29    0.000    0.000    0.001    0.000 transforms.py:2281(__init__)\n",
      "       77    0.000    0.000    0.001    0.000 transforms.py:2307(get_matrix)\n",
      "       31    0.000    0.000    0.001    0.000 transforms.py:2323(blended_transform_factory)\n",
      "       86    0.001    0.000    0.002    0.000 transforms.py:2347(__init__)\n",
      "   138/74    0.000    0.000    0.001    0.000 transforms.py:2376(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2391(__eq__)\n",
      "  467/257    0.001    0.000    0.001    0.000 transforms.py:2405(<lambda>)\n",
      "      160    0.000    0.000    0.008    0.000 transforms.py:2413(transform_affine)\n",
      "      160    0.000    0.000    0.001    0.000 transforms.py:2417(transform_non_affine)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:2426(transform_path_non_affine)\n",
      "  230/171    0.002    0.000    0.008    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.003    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.001    0.000 transforms.py:2581(__init__)\n",
      "  113/111    0.000    0.000    0.001    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.001    0.000 transforms.py:2764(get_transformed_points_and_affine)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2791(get_affine)\n",
      "      172    0.004    0.000    0.007    0.000 transforms.py:2822(nonsingular)\n",
      "       40    0.000    0.000    0.000    0.000 transforms.py:283(y1)\n",
      "      336    0.003    0.000    0.003    0.000 transforms.py:2902(_interval_contains_close)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:293(p0)\n",
      "      243    0.001    0.000    0.006    0.000 transforms.py:313(xmin)\n",
      "      267    0.001    0.000    0.005    0.000 transforms.py:318(ymin)\n",
      "      243    0.001    0.000    0.004    0.000 transforms.py:323(xmax)\n",
      "      263    0.001    0.000    0.004    0.000 transforms.py:328(ymax)\n",
      "      463    0.001    0.000    0.002    0.000 transforms.py:343(intervalx)\n",
      "      263    0.001    0.000    0.001    0.000 transforms.py:352(intervaly)\n",
      "      161    0.000    0.000    0.000    0.000 transforms.py:361(width)\n",
      "      105    0.000    0.000    0.000    0.000 transforms.py:367(height)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:373(size)\n",
      "       23    0.000    0.000    0.001    0.000 transforms.py:379(bounds)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:385(extents)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:474(transformed)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:493(anchored)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:534(shrunk_to_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:619(padded)\n",
      "      138    0.002    0.000    0.004    0.000 transforms.py:624(translated)\n",
      "       99    0.001    0.000    0.028    0.000 transforms.py:649(union)\n",
      "       99    0.000    0.000    0.006    0.000 transforms.py:654(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:655(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:656(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:657(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.001 transforms.py:660(intersection)\n",
      "      604    0.005    0.000    0.011    0.000 transforms.py:754(__init__)\n",
      "       49    0.000    0.000    0.002    0.000 transforms.py:784(frozen)\n",
      "       26    0.000    0.000    0.002    0.000 transforms.py:790(unit)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:795(null)\n",
      "      205    0.001    0.000    0.011    0.000 transforms.py:800(from_bounds)\n",
      "      232    0.001    0.000    0.012    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.001    0.000 units.py:164(get_converter)\n",
      "      118    0.000    0.000    0.001    0.000 units.py:56(_is_natively_supported)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "        5    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.001    0.001 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.001    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.001    0.000    0.001    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       82    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _struct.pack}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _thread.allocate_lock}\n",
      "       37    0.000    0.000    0.000    0.000 {built-in method _thread.get_ident}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method binascii.b2a_base64}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.__build_class__}\n",
      "     1698    0.001    0.000    0.001    0.000 {built-in method builtins.abs}\n",
      "       64    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "     2294    0.002    0.000    0.004    0.000 {built-in method builtins.any}\n",
      "      574    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "      318    0.000    0.000    0.000    0.000 {built-in method builtins.delattr}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.dir}\n",
      "      336    0.000    0.000    0.000    0.000 {built-in method builtins.divmod}\n",
      "        1    0.000    0.000    0.592    0.592 {built-in method builtins.exec}\n",
      "     7600    0.007    0.000    0.028    0.000 {built-in method builtins.getattr}\n",
      "      888    0.001    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "1782/1092    0.001    0.000    0.006    0.000 {built-in method builtins.hash}\n",
      "     1714    0.001    0.000    0.001    0.000 {built-in method builtins.id}\n",
      "     6523    0.003    0.000    0.005    0.000 {built-in method builtins.isinstance}\n",
      "      605    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "     1476    0.001    0.000    0.001    0.000 {built-in method builtins.iter}\n",
      "2523/2516    0.001    0.000    0.001    0.000 {built-in method builtins.len}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.locals}\n",
      "     1061    0.001    0.000    0.001    0.000 {built-in method builtins.max}\n",
      "       27    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "1418/1318    0.002    0.000    0.014    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.repr}\n",
      "       22    0.000    0.000    0.000    0.000 {built-in method builtins.round}\n",
      "      809    0.001    0.000    0.002    0.000 {built-in method builtins.setattr}\n",
      "      430    0.002    0.000    0.002    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sum}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method from_iterable}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "      336    0.000    0.000    0.000    0.000 {built-in method math.floor}\n",
      "      504    0.001    0.000    0.001    0.000 {built-in method math.log10}\n",
      "      208    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "        4    0.017    0.004    0.018    0.004 {built-in method matplotlib._image.resample}\n",
      "      600    0.002    0.000    0.002    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "       29    0.000    0.000    0.000    0.000 {built-in method nt.fspath}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "      169    0.001    0.000    0.001    0.000 {built-in method numpy.arange}\n",
      "      931    0.005    0.000    0.005    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.004    0.000    0.004    0.000 {built-in method numpy.asarray}\n",
      "4456/3297    0.011    0.000    0.095    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       16    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "      348    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.promote_types}\n",
      "      174    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method scipy.sparse._sparsetools.coo_todense}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method sys.exc_info}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method sys.getrecursionlimit}\n",
      "      112    0.000    0.000    0.000    0.000 {built-in method sys.intern}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method utcnow}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method zlib.crc32}\n",
      "     2778    0.002    0.000    0.002    0.000 {function RcParams.__getitem__ at 0x00000224B984EF20}\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.002    0.000    0.002    0.000 {method '__reduce_ex__' of 'object' objects}\n",
      "       15    0.001    0.000    0.001    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'add' of 'set' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "       89    0.000    0.000    0.001    0.000 {method 'any' of 'numpy.ndarray' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "     1990    0.001    0.000    0.001    0.000 {method 'append' of 'list' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.generic' objects}\n",
      "       32    0.001    0.000    0.001    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'cleanup' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.OrderedDict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       35    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        2    0.000    0.000    0.001    0.000 {method 'clip' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of '_hashlib.HMAC' objects}\n",
      "       19    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "      160    0.000    0.000    0.000    0.000 {method 'copy' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'copy' of 'numpy.generic' objects}\n",
      "     1206    0.004    0.000    0.004    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      424    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.003    0.003    0.003    0.003 {method 'draw_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'draw_markers' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.001    0.000    0.001    0.000 {method 'draw_path' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       11    0.001    0.000    0.001    0.000 {method 'draw_text_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        1    0.017    0.017    0.017    0.017 {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.002    0.000    0.002    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'flush' of '_io.BytesIO' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'format' of 'str' objects}\n",
      "     6364    0.002    0.000    0.002    0.000 {method 'get' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'get' of 'mappingproxy' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'get_bitmap_offset' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       35    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       24    0.000    0.000    0.000    0.000 {method 'get_width_height' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.StringIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'hexdigest' of '_hashlib.HMAC' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'insert' of 'list' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'isidentifier' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'islower' of 'bytes' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'isoformat' of 'datetime.datetime' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.ndarray' objects}\n",
      "     5970    0.002    0.000    0.002    0.000 {method 'items' of 'dict' objects}\n",
      "       36    0.000    0.000    0.000    0.000 {method 'items' of 'mappingproxy' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'join' of 'bytes' objects}\n",
      "       18    0.000    0.000    0.000    0.000 {method 'join' of 'str' objects}\n",
      "       39    0.000    0.000    0.000    0.000 {method 'lower' of 'str' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'lstrip' of 'str' objects}\n",
      "      344    0.001    0.000    0.001    0.000 {method 'match' of 're.Pattern' objects}\n",
      "     1374    0.002    0.000    0.009    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "      536    0.001    0.000    0.006    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'move_to_end' of 'collections.OrderedDict' objects}\n",
      "      168    0.000    0.000    0.000    0.000 {method 'nonzero' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pixel_access' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.OrderedDict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.deque' objects}\n",
      "      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.026    0.000    0.026    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.002    0.000    0.002    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'reverse' of 'list' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rfind' of 'str' objects}\n",
      "      840    0.005    0.000    0.005    0.000 {method 'round' of 'numpy.ndarray' objects}\n",
      "       39    0.000    0.000    0.000    0.000 {method 'rpartition' of 'str' objects}\n",
      "       84    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       35    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       35    0.008    0.000    0.008    0.000 {method 'set_text' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       33    0.000    0.000    0.000    0.000 {method 'setdefault' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'setimage' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'sort' of 'list' objects}\n",
      "       18    0.018    0.001    0.018    0.001 {method 'sort' of 'numpy.ndarray' objects}\n",
      "      188    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'splitlines' of 'str' objects}\n",
      "       59    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "      168    0.000    0.000    0.002    0.000 {method 'sum' of 'numpy.ndarray' objects}\n",
      "        2    0.004    0.002    0.004    0.002 {method 'take' of 'numpy.ndarray' objects}\n",
      "      186    0.000    0.000    0.000    0.000 {method 'tolist' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'update' of '_hashlib.HMAC' objects}\n",
      "      575    0.001    0.000    0.001    0.000 {method 'update' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'upper' of 'str' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'values' of 'collections.OrderedDict' objects}\n",
      "     1260    0.000    0.000    0.000    0.000 {method 'values' of 'dict' objects}\n",
      "       17    0.000    0.000    0.000    0.000 {method 'values' of 'mappingproxy' objects}\n",
      "    27/21    0.000    0.000    0.001    0.000 {method 'view' of 'numpy.generic' objects}\n",
      "    37/35    0.000    0.000    0.001    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",
    "    from sklearn.metrics import confusion_matrix\n",
    "    conf_matrix = confusion_matrix(y_true=data_uci.Actual_value_salary, y_pred=data_uci.predicted_newuci)\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": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "True_Positive=0\n",
    "False_Negative=0\n",
    "True_Negative=0\n",
    "False_Positive=0\n",
    "for i in range(len(data_uci)):\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==1)):\n",
    "        True_Positive=True_Positive+1\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==0)):\n",
    "        True_Negative =True_Negative+1\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==0)):\n",
    "        False_Negative=False_Negative+1\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==1)):\n",
    "        False_Positive=False_Positive+1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "28871\n",
      "12353\n"
     ]
    }
   ],
   "source": [
    "FP_women_count=0\n",
    "FP_men_count=0\n",
    "for i in range(len(data_uci)):\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==1)):\n",
    "        if(data_uci.sex.iloc[i] ==1):\n",
    "            FP_men_count=FP_men_count+1\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==1)):\n",
    "        if(data_uci.sex.iloc[i] ==0):\n",
    "            FP_women_count=FP_women_count+1\n",
    "print(FP_men_count)\n",
    "print(FP_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7116\n",
      "5171\n"
     ]
    }
   ],
   "source": [
    "FN_women_count=0\n",
    "FN_men_count=0\n",
    "for i in range(len(data_uci)):\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==0)):\n",
    "        if(data_uci.sex.iloc[i] ==1):\n",
    "            FN_men_count=FN_men_count+1\n",
    "    if((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==0)):\n",
    "        if(data_uci.sex.iloc[i] ==0):\n",
    "            FN_women_count=FN_women_count+1\n",
    "print(FN_men_count)\n",
    "print(FN_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "33659\n",
      "16929\n"
     ]
    }
   ],
   "source": [
    "TP_women_count=0\n",
    "TP_men_count=0\n",
    "for i in range(len(data_uci)):\n",
    "    if(((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==1)) or((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==0))):\n",
    "        if(data_uci.sex.iloc[i] ==1):\n",
    "            TP_men_count=TP_men_count+1\n",
    "    if(((data_uci.Actual_value_salary.iloc[i]==1) and (data_uci.predicted_newuci.iloc[i]==1)) or((data_uci.Actual_value_salary.iloc[i]==0) and (data_uci.predicted_newuci.iloc[i]==0))):\n",
    "        if(data_uci.sex.iloc[i] ==0):\n",
    "            TP_women_count=TP_women_count+1\n",
    "print(TP_men_count)\n",
    "print(TP_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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//wgZrOFpqY9JM9ht5Fdu16iuHgayWSSt956mSVLrjzn2o9TFAWTycKll36YXbteAnREowkCgZhm9hfU1Ct2IBDTbEsEwGg04XbnkpNTzMUX30Jt7TL27Hl1TLc1d+6F3HDD57jggvdvfbybTqenurqOmpoLyMsrY9GitefUCnn99adYunQdy5Zdy5YtT59b0e9x8OBWurqa+OQnv0dZWS1z517I9dffzSuvPE48Hjuv254ovogfjHHcNrvapQAQDobZ+cJOLv7gxcxbNY8tz245q+vpDXqWrVtGflk+ZTPLuOimi876dxpNRty5bnKKcrj45oupXVrLntf2jPUujBuD3gDG5Lg9x1588WEuvPAmVq26geLiaXzkI1/DbLa87+Nep9Mze/YKystrKSysZOXKD5wxdN5r8+anWLbsGpYtu4bNm58aU+3HZWRY+chHvsrq1R/E7c5Br9cRiYyEiFZopiWiKElCobimQ+S9zGYLgcDIzpqDg11885s3nfHyV111F1df/anz+p11dZfw85//M/v3b2bu3FXndN1wOMCuXS9wzz0PU1hYRSjkp6FhF9OnLxy9zPr132Hbtj+d8Xbuu2+kO6SpaS8lJTW4XDmjP5szZyWPPPJdOjuPUl5ee071TYZgLASGBFarNk7NfPOFNymsLKSwspBlVy/j8f96nHWfWIfuDIODpgwTc5bP4cn7nqRiVgV29/kFojnDTMCj/owfo96AQoJ4IoHRMNK1NtbnWDweo63tEOvWfXL0Z3q9ntraZTQ17T3jbdTVXcIzz9zPokVXUF4+65zuQ19fO01Ne/nMZ+4FkjzxxI8YGOgkJ6d49DL33fcPNDbuOu1tZGcX8c1v/vGUPzseIiNrRbTxRkgzIRIOx4nFFDIytB8iyWSS+vptHDiwhTVrbgPA7c7ja1977IzXs9vPb11CZ+dRHnzw37j++rt5+OFvccst/8KiRWsBaG09yPe+dzv/9V8v43BknfL6O3ZsJD+/nOLiGgAWL76SzZufOiFErrvubq644uNnVY/H039CgACj79i8Xm0eMhSKBdEZk1iM2ugK2LxhM8vWLQNgzoo5hPwhjrx5hJmLZ572Os/+4lnaDrexZO0SfvT3P+ILP/nCaBfYoz94lIHOAT73P59739+dTCap317PgTcOsObWNeNyf86HwWAAXZJwPIRdbz+v55jf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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from matplotlib_venn import venn2\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = data_uci.predicted_newuci\n",
    "list2 = data_uci.Actual_value_salary\n",
    "\n",
    "        \n",
    "# Create sets from the binary data lists\n",
    "set1 = set([i for i, x in enumerate(list1)if x==1] )\n",
    "set2 = set([i for i, x in enumerate(list2)if x==1])\n",
    "\n",
    "set1_zeros = set([i for i, x in enumerate(list1) if x == 0])\n",
    "set2_zeros = set([i for i, x in enumerate(list2) if x == 0])\n",
    "\n",
    "# Create a Venn diagram to visualize the overlap between the two sets\n",
    "fig, ax = plt.subplots(figsize=(5,4))\n",
    "venn = venn2([set1,set2],ax=ax )\n",
    "venn.get_patch_by_id('10').set_color('darkblue')\n",
    "venn.get_patch_by_id('01').set_color('darkblue')\n",
    "venn.get_patch_by_id('11').set_color('green')\n",
    "# Add labels to the diagram\n",
    "venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(False_Positive))\n",
    "venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(False_Negative ))\n",
    "venn.get_label_by_id('11').set_text('A & P\\n' + str(True_Positive+True_Negative))\n",
    "\n",
    "\n",
    "# Show the Venn diagram\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         113772 function calls (108454 primitive calls) in 0.196 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.002    0.002    0.195    0.195 765438538.py:3(my_method)\n",
      "        1    0.021    0.021    0.021    0.021 765438538.py:8(<listcomp>)\n",
      "        1    0.024    0.024    0.024    0.024 765438538.py:9(<listcomp>)\n",
      "      312    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(all)\n",
      "      146    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amax)\n",
      "      139    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(any)\n",
      "      288    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(append)\n",
      "      576    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(atleast_1d)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(atleast_2d)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(broadcast_arrays)\n",
      "        8    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(column_stack)\n",
      "      910    0.001    0.000    0.003    0.000 <__array_function__ internals>:177(concatenate)\n",
      "      585    0.001    0.000    0.002    0.000 <__array_function__ internals>:177(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(cumsum)\n",
      "      288    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(diag)\n",
      "       14    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(diff)\n",
      "      121    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(dot)\n",
      "      288    0.000    0.000    0.013    0.000 <__array_function__ internals>:177(eigvals)\n",
      "      291    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(empty_like)\n",
      "      288    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(full_like)\n",
      "      288    0.000    0.000    0.004    0.000 <__array_function__ internals>:177(hstack)\n",
      "      144    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(imag)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(in1d)\n",
      "       12    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(intersect1d)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(inv)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(isin)\n",
      "      144    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(isreal)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(linspace)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(mean)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ndim)\n",
      "      288    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(nonzero)\n",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(norm)\n",
      "      576    0.000    0.000    0.002    0.000 <__array_function__ internals>:177(ravel)\n",
      "        1    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(ravel_multi_index)\n",
      "      144    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(real)\n",
      "       76    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(reshape)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(result_type)\n",
      "      288    0.000    0.000    0.031    0.000 <__array_function__ internals>:177(roots)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(sum)\n",
      "       24    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(vstack)\n",
      "        3    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(zeros_like)\n",
      "       12    0.000    0.000    0.000    0.000 <frozen _collections_abc>:778(__contains__)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen _collections_abc>:794(values)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen _collections_abc>:812(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 <frozen _collections_abc>:815(__len__)\n",
      "       65    0.000    0.000    0.000    0.000 <frozen _collections_abc>:878(__iter__)\n",
      "      298    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       50    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen genericpath>:121(_splitext)\n",
      "       14    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "       12    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:405(parent)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen ntpath>:231(splitext)\n",
      "       61    0.000    0.000    0.000    0.000 <string>:1(<lambda>)\n",
      "        1    0.001    0.001    0.196    0.196 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.007    0.007 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.006    0.006 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.006    0.006 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.007    0.007 PngImagePlugin.py:1242(_save)\n",
      "       10    0.000    0.000    0.000    0.000 PngImagePlugin.py:154(_crc32)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:282(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:285(add)\n",
      "        1    0.000    0.000    0.000    0.000 PngImagePlugin.py:328(add_text)\n",
      "      930    0.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",
      "       15    0.000    0.000    0.000    0.000 __init__.py:119(_weak_or_strong_ref)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1286(is_interactive)\n",
      "       74    0.000    0.000    0.000    0.000 __init__.py:1314(is_math_text)\n",
      "       58    0.000    0.000    0.000    0.000 __init__.py:1327(_to_unmasked_float_array)\n",
      "       36    0.000    0.000    0.000    0.000 __init__.py:134(check_shape)\n",
      "      106    0.000    0.000    0.000    0.000 __init__.py:154(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 __init__.py:1623(<lambda>)\n",
      "      251    0.000    0.000    0.001    0.000 __init__.py:163(match)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:1675(_safe_first_finite)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:1685(safe_isfinite)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:1715(<genexpr>)\n",
      "      179    0.001    0.000    0.002    0.000 __init__.py:1726(normalize_kwargs)\n",
      "       18    0.000    0.000    0.000    0.000 __init__.py:175(check_getitem)\n",
      "      179    0.001    0.000    0.001    0.000 __init__.py:1765(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:183(dumps)\n",
      "      116    0.000    0.000    0.000    0.000 __init__.py:1834(_str_equal)\n",
      "       79    0.000    0.000    0.000    0.000 __init__.py:190(__init__)\n",
      "      478    0.001    0.000    0.001    0.000 __init__.py:1994(_setattr_cm)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2039(__init__)\n",
      "       15    0.000    0.000    0.000    0.000 __init__.py:221(connect)\n",
      "       10    0.000    0.000    0.000    0.000 __init__.py:2290(_unpack_to_numpy)\n",
      "       11    0.000    0.000    0.000    0.000 __init__.py:235(_connect_picklable)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:254(method)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:265(disconnect)\n",
      "      251    0.000    0.000    0.000    0.000 __init__.py:272(_compile)\n",
      "      397    0.001    0.000    0.001    0.000 __init__.py:291(process)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:318(wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:53(__get__)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:550(_get_data_path)\n",
      "      165    0.000    0.000    0.001    0.000 __init__.py:65(check_isinstance)\n",
      "     1766    0.001    0.000    0.001    0.000 __init__.py:691(_get)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:73(get_projection_class)\n",
      "     1766    0.003    0.000    0.004    0.000 __init__.py:742(__getitem__)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:80(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:825(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:826(<dictcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 __init__.py:828(__contains__)\n",
      "       56    0.000    0.000    0.000    0.000 __init__.py:831(clean)\n",
      "       56    0.000    0.000    0.000    0.000 __init__.py:834(<listcomp>)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:880(get_siblings)\n",
      "       54    0.000    0.000    0.000    0.000 __init__.py:884(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:98(get_projection_class)\n",
      "        9    0.000    0.000    0.000    0.000 _arc.py:153(angle_as_point)\n",
      "        3    0.000    0.000    0.000    0.000 _arc.py:168(start_point)\n",
      "        6    0.000    0.000    0.000    0.000 _arc.py:188(mid_point)\n",
      "        8    0.000    0.000    0.000    0.000 _arc.py:25(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 _arc.py:44(length_degrees)\n",
      "        5    0.000    0.000    0.002    0.000 _axes.py:626(text)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:1025(get_yaxis_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:1051(get_yaxis_text2_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1077(_update_transScale)\n",
      "      6/5    0.000    0.000    0.001    0.000 _base.py:1082(get_position)\n",
      "        6    0.000    0.000    0.000    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "       11    0.000    0.000    0.000    0.000 _base.py:1179(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1189(_gen_axes_patch)\n",
      "        1    0.000    0.000    0.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.017    0.017 _base.py:1388(clear)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1522(_set_title_offset_trans)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1608(get_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1616(set_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1702(set_adjustable)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1766(set_box_aspect)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1803(get_anchor)\n",
      "        5    0.000    0.000    0.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",
      "        5    0.000    0.000    0.000    0.000 _base.py:2312(_add_text)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:235(set_prop_cycle)\n",
      "        3    0.000    0.000    0.019    0.006 _base.py:2371(add_patch)\n",
      "        3    0.000    0.000    0.018    0.006 _base.py:2384(_update_patch_limits)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:2446(_unit_change_handler)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:2485(update_datalim)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2510(_process_unit_info)\n",
      "        4    0.000    0.000    0.000    0.000 _base.py:2569(<listcomp>)\n",
      "        4    0.000    0.000    0.004    0.001 _base.py:2939(_update_title_position)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:2994(<genexpr>)\n",
      "        2    0.000    0.000    0.018    0.009 _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.003 _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:3396(set_axis_off)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3405(set_axis_on)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3488(get_xbound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3536(get_xlim)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3575(set_xlim)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3737(get_ybound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3785(get_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3807(set_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3971(set_navigate)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3987(set_navigate_mode)\n",
      "        7    0.000    0.000    0.000    0.000 _base.py:4273(get_children)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4299(get_default_bbox_extra_artists)\n",
      "        3    0.000    0.000    0.001    0.000 _base.py:4328(<listcomp>)\n",
      "        2    0.000    0.000    0.042    0.021 _base.py:4331(get_tightbbox)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:4416(<listcomp>)\n",
      "       28    0.000    0.000    0.000    0.000 _base.py:564(_axis_map)\n",
      "       28    0.000    0.000    0.000    0.000 _base.py:567(<dictcomp>)\n",
      "        1    0.000    0.000    0.026    0.026 _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",
      "       14    0.000    0.000    0.000    0.000 _base.py:799(get_window_extent)\n",
      "        1    0.000    0.000    0.006    0.006 _base.py:818(_init_axis)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:827(set_figure)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:841(_unstale_viewLim)\n",
      "       16    0.000    0.000    0.000    0.000 _base.py:844(<dictcomp>)\n",
      "       64    0.000    0.000    0.000    0.000 _base.py:845(<genexpr>)\n",
      "       14    0.000    0.000    0.000    0.000 _base.py:855(viewLim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:881(_set_lim_and_transforms)\n",
      "    29/15    0.000    0.000    0.000    0.000 _base.py:917(get_xaxis_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:945(get_xaxis_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 _base.py:971(get_xaxis_text2_transform)\n",
      "    29/15    0.000    0.000    0.000    0.000 _base.py:997(get_yaxis_transform)\n",
      "       14    0.000    0.000    0.000    0.000 _binary.py:101(o32be)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:100(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:101(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:102(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:20(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _common.py:33(get_label_by_id)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:70(mix_colors)\n",
      "        1    0.000    0.000    0.001    0.001 _common.py:92(prepare_venn_axes)\n",
      "        1    0.000    0.000    0.000    0.000 _common.py:99(<listcomp>)\n",
      "        1    0.000    0.000    0.001    0.001 _math.py:100(find_distance_by_area)\n",
      "        8    0.000    0.000    0.000    0.000 _math.py:126(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _math.py:129(circle_circle_intersection)\n",
      "        8    0.000    0.000    0.000    0.000 _math.py:175(vector_angle_in_degrees)\n",
      "        1    0.000    0.000    0.000    0.000 _math.py:199(normalize_by_center_of_mass)\n",
      "        8    0.000    0.000    0.000    0.000 _math.py:44(circle_intersection_area)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:164(_mean)\n",
      "       64    0.000    0.000    0.000    0.000 _methods.py:39(_amax)\n",
      "       64    0.000    0.000    0.000    0.000 _methods.py:43(_amin)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:55(_any)\n",
      "      289    0.000    0.000    0.001    0.000 _methods.py:61(_all)\n",
      "        4    0.000    0.000    0.000    0.000 _methods.py:67(_count_reduce_items)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        2    0.000    0.000    0.000    0.000 _region.py:126(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 _region.py:132(subtract_and_intersect_circle)\n",
      "        4    0.000    0.000    0.000    0.000 _region.py:230(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 _region.py:459(label_position)\n",
      "        3    0.000    0.000    0.000    0.000 _region.py:461(<listcomp>)\n",
      "        3    0.000    0.000    0.001    0.000 _region.py:482(make_patch)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.001    0.001 _tight_bbox.py:8(adjust_bbox)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 _util.py:5(is_path)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:104(compute_venn2_colors)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:113(<listcomp>)\n",
      "        1    0.003    0.003    0.003    0.003 _venn2.py:117(compute_venn2_subsets)\n",
      "        1    0.000    0.000    0.027    0.027 _venn2.py:183(venn2)\n",
      "        1    0.000    0.000    0.001    0.001 _venn2.py:239(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:246(<listcomp>)\n",
      "        1    0.000    0.000    0.001    0.001 _venn2.py:247(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:251(<listcomp>)\n",
      "        1    0.000    0.000    0.001    0.001 _venn2.py:254(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:29(compute_venn2_areas)\n",
      "        1    0.000    0.000    0.001    0.001 _venn2.py:57(solve_venn2_circles)\n",
      "        1    0.000    0.000    0.000    0.000 _venn2.py:89(compute_venn2_regions)\n",
      "        1    0.000    0.000    0.000    0.000 _zeros_py.py:658(brentq)\n",
      "        1    0.000    0.000    0.000    0.000 _zeros_py.py:70(results_c)\n",
      "       24    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       24    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 arraysetops.py:138(unique)\n",
      "       24    0.000    0.000    0.000    0.000 arraysetops.py:323(_unique1d)\n",
      "       12    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "       12    0.000    0.000    0.001    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",
      "        9    0.000    0.000    0.000    0.000 artist.py:1007(set_alpha)\n",
      "      233    0.000    0.000    0.001    0.000 artist.py:103(_stale_axes_callback)\n",
      "       71    0.000    0.000    0.000    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       18    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "      199    0.001    0.000    0.007    0.000 artist.py:1180(_update_props)\n",
      "       24    0.000    0.000    0.001    0.000 artist.py:1205(update)\n",
      "      175    0.000    0.000    0.006    0.000 artist.py:1216(_internal_update)\n",
      "      155    0.000    0.000    0.007    0.000 artist.py:1227(set)\n",
      "       26    0.000    0.000    0.001    0.000 artist.py:1233(_cm_set)\n",
      "       13    0.000    0.000    0.000    0.000 artist.py:1238(<dictcomp>)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:1375(get_mouseover)\n",
      "      155    0.000    0.000    0.007    0.000 artist.py:147(<lambda>)\n",
      "       61    0.000    0.000    0.001    0.000 artist.py:180(__init__)\n",
      "      107    0.000    0.000    0.001    0.000 artist.py:271(convert_xunits)\n",
      "      107    0.000    0.000    0.000    0.000 artist.py:283(convert_yunits)\n",
      "      886    0.000    0.000    0.000    0.000 artist.py:295(axes)\n",
      "       84    0.000    0.000    0.000    0.000 artist.py:300(axes)\n",
      "2080/1741    0.001    0.000    0.002    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.057    0.002 artist.py:352(get_tightbbox)\n",
      "      390    0.000    0.000    0.001    0.000 artist.py:417(pchanged)\n",
      "       11    0.000    0.000    0.000    0.000 artist.py:430(is_transform_set)\n",
      "       79    0.000    0.000    0.000    0.000 artist.py:438(set_transform)\n",
      "       88    0.000    0.000    0.000    0.000 artist.py:451(get_transform)\n",
      "     28/2    0.000    0.000    0.019    0.010 artist.py:54(draw_wrapper)\n",
      "       22    0.000    0.000    0.000    0.000 artist.py:618(get_gid)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:632(get_snap)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:671(get_sketch_params)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:730(get_path_effects)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:733(get_figure)\n",
      "       60    0.000    0.000    0.000    0.000 artist.py:737(set_figure)\n",
      "        3    0.000    0.000    0.000    0.000 artist.py:761(set_clip_box)\n",
      "       22    0.000    0.000    0.003    0.000 artist.py:778(set_clip_path)\n",
      "       10    0.000    0.000    0.000    0.000 artist.py:840(get_alpha)\n",
      "      198    0.000    0.000    0.000    0.000 artist.py:847(get_visible)\n",
      "     2082    0.000    0.000    0.000    0.000 artist.py:851(get_animated)\n",
      "       29    0.000    0.000    0.000    0.000 artist.py:855(get_in_layout)\n",
      "       27    0.000    0.000    0.001    0.000 artist.py:866(_fully_clipped_to_axes)\n",
      "       51    0.000    0.000    0.000    0.000 artist.py:890(get_clip_on)\n",
      "       39    0.000    0.000    0.000    0.000 artist.py:894(get_clip_box)\n",
      "       42    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\n",
      "       18    0.000    0.000    0.000    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.019    0.010 artist.py:93(draw_wrapper)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:939(get_rasterized)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:966(get_agg_filter)\n",
      "        8    0.000    0.000    0.000    0.000 axis.py:1012(_translate_tick_params)\n",
      "        8    0.000    0.000    0.000    0.000 axis.py:1060(<dictcomp>)\n",
      "        2    0.000    0.000    0.005    0.003 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:1157(_set_lim)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1175(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1232(_set_artist_props)\n",
      "        6    0.000    0.000    0.009    0.002 axis.py:1539(_get_tick)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:154(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1574(get_major_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1590(get_major_ticks)\n",
      "        4    0.000    0.000    0.007    0.002 axis.py:1616(grid)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1647(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1658(update_units)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1719(_have_units_and_converter)\n",
      "       96    0.000    0.000    0.001    0.000 axis.py:1725(convert_units)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:1742(set_units)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1796(set_major_formatter)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1822(set_minor_formatter)\n",
      "       28    0.000    0.000    0.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",
      "        6    0.000    0.000    0.000    0.000 axis.py:196(_set_labelrotation)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2014(_set_tick_locations)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2022(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2041(set_ticks)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:208(_apply_tickdir)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2145(_get_ticks_position)\n",
      "       36    0.000    0.000    0.000    0.000 axis.py:2161(<genexpr>)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2182(get_label_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2212(setter)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:223(get_tick_padding)\n",
      "        1    0.000    0.000    0.003    0.003 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.003    0.000 axis.py:2241(_init)\n",
      "        6    0.000    0.000    0.001    0.000 axis.py:237(set_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2449(get_ticks_position)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2462(get_minpos)\n",
      "        1    0.000    0.000    0.001    0.001 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.001    0.000 axis.py:2500(_init)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:2721(get_minpos)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:342(_set_artist_props)\n",
      "       14    0.000    0.000    0.002    0.000 axis.py:351(_apply_params)\n",
      "       70    0.000    0.000    0.000    0.000 axis.py:359(<genexpr>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:376(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:389(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:394(<dictcomp>)\n",
      "        3    0.000    0.000    0.004    0.001 axis.py:416(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:438(_get_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:441(_get_text2_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:444(_apply_tickdir)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:455(update_position)\n",
      "        3    0.000    0.000    0.005    0.002 axis.py:477(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:499(_get_text1_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:502(_get_text2_transform)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:505(_apply_tickdir)\n",
      "        3    0.000    0.000    0.000    0.000 axis.py:516(update_position)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:543(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:549(locator)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:553(locator)\n",
      "       58    0.000    0.000    0.000    0.000 axis.py:560(formatter)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:564(formatter)\n",
      "        6    0.000    0.000    0.007    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.004    0.002 axis.py:643(__init__)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:701(isDefault_majfmt)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:709(isDefault_minloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:717(isDefault_minfmt)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:758(get_transform)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_scale)\n",
      "       14    0.000    0.000    0.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",
      "        4    0.000    0.000    0.000    0.000 axis.py:828(_set_autoscale_on)\n",
      "       12    0.000    0.000    0.009    0.001 axis.py:855(clear)\n",
      "       16    0.000    0.000    0.000    0.000 axis.py:893(reset_ticks)\n",
      "        8    0.000    0.000    0.007    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",
      "        4    0.000    0.000    0.002    0.000 backend_agg.py:109(draw_path)\n",
      "        8    0.000    0.000    0.002    0.000 backend_agg.py:200(draw_text)\n",
      "       20    0.000    0.000    0.006    0.000 backend_agg.py:221(get_text_width_height_descent)\n",
      "       10    0.000    0.000    0.000    0.000 backend_agg.py:259(get_canvas_width_height)\n",
      "       28    0.000    0.000    0.004    0.000 backend_agg.py:263(_prepare_font)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:277(buffer_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:286(clear)\n",
      "        4    0.000    0.000    0.000    0.000 backend_agg.py:289(option_image_nocomposite)\n",
      "        2    0.000    0.000    0.013    0.007 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:405(get_renderer)\n",
      "       28    0.000    0.000    0.000    0.000 backend_agg.py:43(get_hinting_flag)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:435(buffer_rgba)\n",
      "        2    0.000    0.000    0.020    0.010 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.020    0.010 backend_agg.py:462(print_png)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:78(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:1002(set_snap)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1017(get_hatch)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1021(get_hatch_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1028(get_hatch_color)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1036(get_hatch_linewidth)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:1040(get_sketch_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1252(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1257(_process)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1284(__init__)\n",
      "        1    0.000    0.000    0.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",
      "       11    0.000    0.000    0.000    0.000 backend_bases.py:179(open_group)\n",
      "       11    0.000    0.000    0.000    0.000 backend_bases.py:186(close_group)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2053(draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2174(_switch_canvas_and_return_print_method)\n",
      "        2    0.000    0.000    0.020    0.010 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.092    0.092 backend_bases.py:2237(print_figure)\n",
      "        3    0.000    0.000    0.000    0.000 backend_bases.py:2411(mpl_connect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2474(mpl_disconnect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2809(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2840(notify_axes_change)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2846(create_with_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2921(destroy)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2937(set_window_title)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3572(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3577(draw_if_interactive)\n",
      "       16    0.000    0.000    0.000    0.000 backend_bases.py:661(flipy)\n",
      "       18    0.000    0.000    0.001    0.000 backend_bases.py:679(new_gc)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:735(_draw_disabled)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:743(<dictcomp>)\n",
      "       34    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       18    0.000    0.000    0.001    0.000 backend_bases.py:756(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:797(restore)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:824(get_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:839(get_dashes)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:876(get_snap)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:887(set_alpha)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:904(set_antialiased)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:909(set_capstyle)\n",
      "       16    0.000    0.000    0.000    0.000 backend_bases.py:920(set_clip_rectangle)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:924(set_clip_path)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:929(set_dashes)\n",
      "       36    0.000    0.000    0.000    0.000 backend_bases.py:959(set_foreground)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:979(set_joinstyle)\n",
      "        8    0.000    0.000    0.000    0.000 backend_bases.py:990(set_linewidth)\n",
      "       18    0.000    0.000    0.000    0.000 backend_bases.py:994(set_url)\n",
      "        1    0.000    0.000    0.001    0.001 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.095    0.095 backend_inline.py:72(show)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:742(__iter__)\n",
      "      156    0.002    0.000    0.003    0.000 bezier.py:191(__init__)\n",
      "      156    0.001    0.000    0.001    0.000 bezier.py:195(<listcomp>)\n",
      "      156    0.002    0.000    0.004    0.000 bezier.py:200(__call__)\n",
      "      144    0.000    0.000    0.000    0.000 bezier.py:224(control_points)\n",
      "      300    0.000    0.000    0.000    0.000 bezier.py:234(degree)\n",
      "      144    0.003    0.000    0.012    0.000 bezier.py:239(polynomial_coefficients)\n",
      "      156    0.004    0.000    0.051    0.000 bezier.py:275(axis_aligned_extrema)\n",
      "      262    0.000    0.000    0.001    0.000 colors.py:213(_is_nth_color)\n",
      "       80    0.000    0.000    0.001    0.000 colors.py:218(is_color_like)\n",
      "        6    0.000    0.000    0.000    0.000 colors.py:231(_has_alpha_channel)\n",
      "       80    0.000    0.000    0.001    0.000 colors.py:237(_check_color_like)\n",
      "      182    0.000    0.000    0.001    0.000 colors.py:265(to_rgba)\n",
      "        6    0.000    0.000    0.000    0.000 colors.py:307(_to_rgba_no_colorcycle)\n",
      "       24    0.000    0.000    0.000    0.000 colors.py:384(<genexpr>)\n",
      "       30    0.000    0.000    0.000    0.000 colors.py:394(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 colors.py:494(to_rgb)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      257    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "  257/244    0.000    0.000    0.002    0.000 contextlib.py:132(__enter__)\n",
      "  257/244    0.000    0.000    0.002    0.000 contextlib.py:141(__exit__)\n",
      "      257    0.000    0.000    0.001    0.000 contextlib.py:287(helper)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:450(_create_exit_wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:460(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:490(enter_context)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:522(_push_cm_exit)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:527(_push_exit_callback)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:543(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:546(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:751(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:754(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:757(__exit__)\n",
      "       18    0.000    0.000    0.000    0.000 copy.py:107(_copy_immutable)\n",
      "      144    0.002    0.000    0.003    0.000 copy.py:259(_reconstruct)\n",
      "      234    0.001    0.000    0.004    0.000 copy.py:66(copy)\n",
      "      144    0.000    0.000    0.000    0.000 copyreg.py:104(__newobj__)\n",
      "       12    0.000    0.000    0.000    0.000 core.py:587(filled)\n",
      "       18    0.000    0.000    0.000    0.000 cycler.py:165(keys)\n",
      "      176    0.000    0.000    0.000    0.000 cycler.py:239(__iter__)\n",
      "       16    0.000    0.000    0.000    0.000 cycler.py:364(by_key)\n",
      "       16    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.093    0.008 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       28    0.000    0.000    0.000    0.000 deprecation.py:289(wrapper)\n",
      "    31/17    0.000    0.000    0.001    0.000 deprecation.py:379(wrapper)\n",
      "       84    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    59/51    0.000    0.000    0.012    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.095    0.095 display_functions.py:105(display)\n",
      "        1    0.000    0.000    0.001    0.001 display_functions.py:45(publish_display_data)\n",
      "        1    0.000    0.000    0.000    0.000 displaypub.py:43(_validate_data)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:105(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:183(encode)\n",
      "        4    0.000    0.000    0.000    0.000 encoder.py:205(iterencode)\n",
      "      150    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "      150    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:101(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:131(update)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1474(add_gridspec)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1598(sca)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:161(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:1650(_process_projection_requirements)\n",
      "        1    0.000    0.000    0.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.064    0.064 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",
      "      143    0.000    0.000    0.000    0.000 figure.py:2718(_get_dpi)\n",
      "       70    0.000    0.000    0.000    0.000 figure.py:2721(_set_dpi)\n",
      "        2    0.000    0.000    0.000    0.000 figure.py:2875(set_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:3096(clear)\n",
      "        2    0.000    0.000    0.019    0.010 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",
      "      106    0.000    0.000    0.000    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.026    0.026 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.026    0.026 figure.py:760(subplots)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:80(bubble)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:86(add)\n",
      "        1    0.000    0.000    0.000    0.000 figure.py:933(clear)\n",
      "       31    0.000    0.000    0.001    0.000 font_manager.py:1061(get_default_size)\n",
      "       42    0.000    0.000    0.001    0.000 font_manager.py:1200(findfont)\n",
      "      252    0.000    0.000    0.000    0.000 font_manager.py:1256(<genexpr>)\n",
      "       28    0.000    0.000    0.003    0.000 font_manager.py:1270(_find_fonts_by_props)\n",
      "       28    0.000    0.000    0.000    0.000 font_manager.py:1490(get_font)\n",
      "       56    0.000    0.000    0.000    0.000 font_manager.py:1515(<genexpr>)\n",
      "       60    0.000    0.000    0.001    0.000 font_manager.py:588(__init__)\n",
      "       76    0.000    0.000    0.001    0.000 font_manager.py:608(_from_any)\n",
      "      281    0.001    0.000    0.001    0.000 font_manager.py:631(__hash__)\n",
      "       87    0.000    0.000    0.001    0.000 font_manager.py:642(__eq__)\n",
      "      309    0.000    0.000    0.000    0.000 font_manager.py:648(get_family)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:664(get_style)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:670(get_variant)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:676(get_weight)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:685(get_stretch)\n",
      "      309    0.000    0.000    0.000    0.000 font_manager.py:693(get_size)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "       88    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:729(set_style)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       62    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "       90    0.000    0.000    0.002    0.000 font_manager.py:807(set_size)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "      281    0.000    0.000    0.000    0.000 font_manager.py:857(get_math_fontfamily)\n",
      "       60    0.000    0.000    0.000    0.000 font_manager.py:865(set_math_fontfamily)\n",
      "      143    0.000    0.000    0.004    0.000 font_manager.py:893(copy)\n",
      "       12    0.000    0.000    0.093    0.008 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.093    0.010 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.093    0.093 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",
      "      576    0.000    0.000    0.000    0.000 fromnumeric.py:1777(_ravel_dispatcher)\n",
      "      576    0.001    0.000    0.001    0.000 fromnumeric.py:1781(ravel)\n",
      "      288    0.000    0.000    0.000    0.000 fromnumeric.py:1888(_nonzero_dispatcher)\n",
      "      288    0.000    0.000    0.001    0.000 fromnumeric.py:1892(nonzero)\n",
      "       76    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "       76    0.000    0.000    0.001    0.000 fromnumeric.py:198(reshape)\n",
      "        3    0.000    0.000    0.000    0.000 fromnumeric.py:2183(_sum_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 fromnumeric.py:2188(sum)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2328(_any_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:2333(any)\n",
      "      312    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "      312    0.000    0.000    0.003    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "      146    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "      146    0.000    0.000    0.001    0.000 fromnumeric.py:2703(amax)\n",
      "      139    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "      139    0.000    0.000    0.001    0.000 fromnumeric.py:2829(amin)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:3340(_mean_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:3345(mean)\n",
      "       78    0.000    0.000    0.001    0.000 fromnumeric.py:38(_wrapit)\n",
      "      366    0.001    0.000    0.001    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "      624    0.002    0.000    0.004    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "      624    0.001    0.000    0.001    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       14    0.000    0.000    0.000    0.000 function_base.py:1320(diff)\n",
      "        6    0.000    0.000    0.000    0.000 function_base.py:18(_linspace_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 function_base.py:23(linspace)\n",
      "      288    0.001    0.000    0.009    0.000 function_base.py:2301(__call__)\n",
      "      288    0.002    0.000    0.005    0.000 function_base.py:2331(_get_ufunc_and_otypes)\n",
      "      288    0.000    0.000    0.000    0.000 function_base.py:2361(<listcomp>)\n",
      "      864    0.000    0.000    0.000    0.000 function_base.py:2362(<genexpr>)\n",
      "      288    0.001    0.000    0.001    0.000 function_base.py:2366(<listcomp>)\n",
      "      288    0.000    0.000    0.000    0.000 function_base.py:2390(<listcomp>)\n",
      "      288    0.002    0.000    0.008    0.000 function_base.py:2400(_vectorize_call)\n",
      "      288    0.000    0.000    0.001    0.000 function_base.py:2410(<listcomp>)\n",
      "      245    0.000    0.000    0.000    0.000 function_base.py:346(iterable)\n",
      "      288    0.000    0.000    0.000    0.000 function_base.py:5440(_append_dispatcher)\n",
      "      288    0.001    0.000    0.002    0.000 function_base.py:5444(append)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:35(update_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:65(wraps)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:476(__new__)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:558(smallest_normal)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:581(tiny)\n",
      "        9    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        6    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:101(set_width_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:123(set_height_ratios)\n",
      "        1    0.000    0.000    0.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.026    0.026 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",
      "        9    0.000    0.000    0.000    0.000 hatch.py:182(_validate_hatch_pattern)\n",
      "        4    0.000    0.000    0.000    0.000 hmac.py:117(update)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:122(copy)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:139(_current)\n",
      "        1    0.000    0.000    0.000    0.000 hmac.py:161(hexdigest)\n",
      "      4/2    0.000    0.000    0.018    0.009 image.py:113(_draw_list_compositing_images)\n",
      "       28    0.000    0.000    0.000    0.000 image.py:123(<genexpr>)\n",
      "        1    0.000    0.000    0.007    0.007 image.py:1567(imsave)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2037(_signature_bound_method)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "      2/1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "      170    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "      307    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "       40    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2836(args)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2859(kwargs)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "       10    0.000    0.000    0.000    0.000 inspect.py:292(isclass)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "       78    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3039(replace)\n",
      "       40    0.000    0.000    0.001    0.000 inspect.py:3075(_bind)\n",
      "       40    0.000    0.000    0.001    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        5    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:215(send_multipart)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:287(send_multipart)\n",
      "        2    0.000    0.000    0.001    0.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",
      "      289    0.000    0.000    0.000    0.000 linalg.py:107(get_linalg_error_extobj)\n",
      "      289    0.000    0.000    0.000    0.000 linalg.py:112(_makearray)\n",
      "      870    0.000    0.000    0.000    0.000 linalg.py:117(isComplexType)\n",
      "      577    0.000    0.000    0.000    0.000 linalg.py:130(_realType)\n",
      "      289    0.001    0.000    0.001    0.000 linalg.py:136(_commonType)\n",
      "      289    0.000    0.000    0.000    0.000 linalg.py:180(_assert_stacked_2d)\n",
      "      289    0.000    0.000    0.000    0.000 linalg.py:186(_assert_stacked_square)\n",
      "      288    0.001    0.000    0.002    0.000 linalg.py:192(_assert_finite)\n",
      "        4    0.000    0.000    0.000    0.000 linalg.py:2338(_norm_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 linalg.py:2342(norm)\n",
      "      289    0.000    0.000    0.000    0.000 linalg.py:465(_unary_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 linalg.py:469(inv)\n",
      "      288    0.005    0.000    0.013    0.000 linalg.py:969(eigvals)\n",
      "        6    0.000    0.000    0.001    0.000 lines.py:1026(get_path)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1040(set_antialiased)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1052(set_color)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1064(set_drawstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1099(set_gapcolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1122(set_linewidth)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1137(set_linestyle)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:1182(set_marker)\n",
      "       54    0.000    0.000    0.000    0.000 lines.py:1196(_set_markercolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1210(set_markeredgecolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1220(set_markerfacecolor)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1230(set_markerfacecoloralt)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1240(set_markeredgewidth)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1255(set_markersize)\n",
      "       45    0.000    0.000    0.000    0.000 lines.py:1269(set_xdata)\n",
      "       45    0.000    0.000    0.000    0.000 lines.py:1290(set_ydata)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       18    0.000    0.000    0.003    0.000 lines.py:272(__init__)\n",
      "       27    0.000    0.000    0.000    0.000 lines.py:33(_get_dash_pattern)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:538(set_markevery)\n",
      "       59    0.000    0.000    0.000    0.000 lines.py:63(_scale_dashes)\n",
      "       36    0.000    0.000    0.000    0.000 lines.py:635(set_data)\n",
      "        6    0.000    0.000    0.001    0.000 lines.py:654(recache)\n",
      "       18    0.000    0.000    0.000    0.000 lines.py:718(set_transform)\n",
      "        6    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       30    0.000    0.000    0.001    0.000 markers.py:228(__init__)\n",
      "       60    0.000    0.000    0.000    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       30    0.000    0.000    0.000    0.000 markers.py:302(_set_fillstyle)\n",
      "       30    0.000    0.000    0.001    0.000 markers.py:327(_set_marker)\n",
      "       18    0.000    0.000    0.000    0.000 markers.py:482(_set_nothing)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:791(_set_tickleft)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:797(_set_tickright)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:805(_set_tickup)\n",
      "        3    0.000    0.000    0.000    0.000 markers.py:811(_set_tickdown)\n",
      "        4    0.000    0.000    0.000    0.000 mathtext.py:196(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:1029(unravel_index)\n",
      "      585    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "      910    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "      121    0.000    0.000    0.000    0.000 multiarray.py:740(dot)\n",
      "      291    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",
      "      288    0.000    0.000    0.001    0.000 numeric.py:150(ones)\n",
      "       10    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        6    0.000    0.000    0.000    0.000 numeric.py:290(full)\n",
      "      288    0.000    0.000    0.000    0.000 numeric.py:354(_full_like_dispatcher)\n",
      "      288    0.000    0.000    0.002    0.000 numeric.py:358(full_like)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:73(_zeros_like_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:77(zeros_like)\n",
      "       45    0.000    0.000    0.003    0.000 patches.py:262(get_transform)\n",
      "       18    0.000    0.000    0.000    0.000 patches.py:273(get_patch_transform)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:288(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:292(get_facecolor)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:304(set_antialiased)\n",
      "       31    0.000    0.000    0.000    0.000 patches.py:317(_set_edgecolor)\n",
      "       19    0.000    0.000    0.000    0.000 patches.py:332(set_edgecolor)\n",
      "       31    0.000    0.000    0.001    0.000 patches.py:343(_set_facecolor)\n",
      "       19    0.000    0.000    0.000    0.000 patches.py:350(set_facecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:377(set_alpha)\n",
      "       14    0.000    0.000    0.000    0.000 patches.py:384(set_linewidth)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:399(set_linestyle)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:434(set_fill)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:456(set_capstyle)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:476(set_joinstyle)\n",
      "        9    0.000    0.000    0.001    0.000 patches.py:48(__init__)\n",
      "        9    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "        8    0.001    0.000    0.003    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "        8    0.000    0.000    0.003    0.000 patches.py:582(draw)\n",
      "       12    0.000    0.000    0.052    0.004 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:689(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 patches.py:730(get_path)\n",
      "       29    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       27    0.000    0.000    0.002    0.000 patches.py:742(get_patch_transform)\n",
      "       54    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:768(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:855(set_bounds)\n",
      "       27    0.000    0.000    0.001    0.000 patches.py:876(get_bbox)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:943(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 patches.py:955(get_path)\n",
      "       12    0.000    0.000    0.000    0.000 path.py:162(_fast_from_codes_and_verts)\n",
      "       34    0.000    0.000    0.000    0.000 path.py:202(_update_values)\n",
      "       71    0.000    0.000    0.000    0.000 path.py:211(vertices)\n",
      "       70    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.000    0.000 path.py:350(__len__)\n",
      "      168    0.001    0.000    0.004    0.000 path.py:353(iter_segments)\n",
      "      168    0.001    0.000    0.009    0.000 path.py:419(iter_bezier)\n",
      "       12    0.000    0.000    0.000    0.000 path.py:466(cleaned)\n",
      "       12    0.001    0.000    0.051    0.004 path.py:603(get_extents)\n",
      "        5    0.000    0.000    0.000    0.000 path.py:730(unit_rectangle)\n",
      "        6    0.000    0.000    0.001    0.000 path.py:924(arc)\n",
      "       34    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",
      "      288    0.000    0.000    0.000    0.000 polynomial.py:167(_roots_dispatcher)\n",
      "      288    0.004    0.000    0.029    0.000 polynomial.py:171(roots)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:118(_safe_getattr)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:184(group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:201(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:232(text)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:280(begin_group)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:304(end_group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:313(flush)\n",
      "       12    0.000    0.000    0.000    0.000 pretty.py:321(_get_mro)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:355(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:372(pretty)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:417(_in_deferred_types)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:482(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:490(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:495(enq)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:512(remove)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:775(_repr_pprint)\n",
      "        1    0.000    0.000    0.092    0.092 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.027    0.027 pyplot.py:1328(subplots)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        5    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:358(_warn_if_gui_out_of_main_thread)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.095    0.095 pyplot.py:400(show)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:690(figure)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:887(get_fignums)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:926(close)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:140(validate_bool)\n",
      "        1    0.000    0.000    0.000    0.000 rcsetup.py:152(validate_axisbelow)\n",
      "       14    0.000    0.000    0.003    0.000 scale.py:103(set_default_locators_and_formatters)\n",
      "       12    0.000    0.000    0.000    0.000 scale.py:115(get_transform)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:704(scale_factory)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:96(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:198(utcnow)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:272(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:279(extract_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:598(msg_id)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:643(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:647(msg)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:673(sign)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:688(serialize)\n",
      "        1    0.000    0.000    0.000    0.000 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",
      "      576    0.000    0.000    0.000    0.000 shape_base.py:19(_atleast_1d_dispatcher)\n",
      "      299    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "      291    0.000    0.000    0.000    0.000 shape_base.py:218(_vhstack_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:223(vstack)\n",
      "      576    0.001    0.000    0.001    0.000 shape_base.py:23(atleast_1d)\n",
      "      288    0.001    0.000    0.003    0.000 shape_base.py:299(hstack)\n",
      "        8    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "        8    0.000    0.000    0.000    0.000 shape_base.py:612(column_stack)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:77(_atleast_2d_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 shape_base.py:81(atleast_2d)\n",
      "        5    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "    28/24    0.000    0.000    0.000    0.000 spines.py:202(_ensure_position_is_set)\n",
      "        4    0.000    0.000    0.002    0.001 spines.py:208(register_axis)\n",
      "        4    0.000    0.000    0.002    0.001 spines.py:221(clear)\n",
      "        4    0.000    0.000    0.000    0.000 spines.py:292(set_position)\n",
      "    28/24    0.000    0.000    0.000    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.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",
      "       28    0.000    0.000    0.000    0.000 spines.py:551(__getattr__)\n",
      "       64    0.000    0.000    0.000    0.000 spines.py:558(__getitem__)\n",
      "       13    0.000    0.000    0.000    0.000 spines.py:584(__iter__)\n",
      "        7    0.000    0.000    0.000    0.000 spines.py:587(__len__)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:416(_broadcast_shape)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:476(_broadcast_arrays_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "        6    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       18    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "       94    0.000    0.000    0.000    0.000 text.py:1000(set_horizontalalignment)\n",
      "       20    0.000    0.000    0.006    0.000 text.py:101(_get_text_metrics_with_cache_impl)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:1030(set_linespacing)\n",
      "       30    0.000    0.000    0.002    0.000 text.py:1098(set_fontsize)\n",
      "        2    0.000    0.000    0.000    0.000 text.py:1150(set_fontweight)\n",
      "       24    0.000    0.000    0.000    0.000 text.py:1184(set_position)\n",
      "       70    0.000    0.000    0.000    0.000 text.py:1195(set_x)\n",
      "       70    0.000    0.000    0.000    0.000 text.py:1206(set_y)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1217(set_rotation)\n",
      "       93    0.000    0.000    0.000    0.000 text.py:1249(set_verticalalignment)\n",
      "       71    0.000    0.000    0.000    0.000 text.py:1265(set_text)\n",
      "       56    0.000    0.000    0.000    0.000 text.py:1283(_preprocess_math)\n",
      "       48    0.000    0.000    0.002    0.000 text.py:1307(set_fontproperties)\n",
      "       24    0.000    0.000    0.004    0.000 text.py:132(__init__)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "       97    0.000    0.000    0.000    0.000 text.py:1335(get_usetex)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "       56    0.000    0.000    0.000    0.000 text.py:1351(get_parse_math)\n",
      "       48    0.000    0.000    0.004    0.000 text.py:185(_reset_visual_defaults)\n",
      "       24    0.000    0.000    0.001    0.000 text.py:221(update)\n",
      "       18    0.000    0.000    0.001    0.000 text.py:270(_get_xy_display)\n",
      "       25    0.000    0.000    0.000    0.000 text.py:277(_get_multialignment)\n",
      "       35    0.000    0.000    0.000    0.000 text.py:315(get_rotation)\n",
      "       35    0.000    0.000    0.000    0.000 text.py:323(get_transform_rotates_text)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:329(set_rotation_mode)\n",
      "       25    0.000    0.000    0.000    0.000 text.py:344(get_rotation_mode)\n",
      "       25    0.001    0.000    0.011    0.000 text.py:363(_get_layout)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:432(<listcomp>)\n",
      "       15    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       13    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        3    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        5    0.000    0.000    0.001    0.000 text.py:596(set_clip_path)\n",
      "        5    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       48    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       16    0.000    0.000    0.013    0.001 text.py:738(draw)\n",
      "       10    0.000    0.000    0.000    0.000 text.py:808(get_color)\n",
      "       33    0.000    0.000    0.001    0.000 text.py:893(get_unitless_position)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:901(get_position)\n",
      "      106    0.000    0.000    0.000    0.000 text.py:907(get_text)\n",
      "       33    0.000    0.000    0.007    0.000 text.py:918(get_window_extent)\n",
      "       65    0.000    0.000    0.008    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       62    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.000    0.000 threading.py:288(wait)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:555(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:604(wait)\n",
      "        4    0.000    0.000    0.000    0.000 ticker.py:1651(nonsingular)\n",
      "        2    0.000    0.000    0.000    0.000 ticker.py:1716(__init__)\n",
      "       58    0.000    0.000    0.000    0.000 ticker.py:192(set_axis)\n",
      "       14    0.000    0.000    0.001    0.000 ticker.py:1969(__init__)\n",
      "       14    0.000    0.000    0.001    0.000 ticker.py:2010(_validate_steps)\n",
      "       14    0.000    0.000    0.000    0.000 ticker.py:2025(_staircase)\n",
      "       14    0.000    0.000    0.001    0.000 ticker.py:2031(set_params)\n",
      "       28    0.000    0.000    0.000    0.000 ticker.py:259(_set_locator)\n",
      "       14    0.000    0.000    0.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",
      "       14    0.000    0.000    0.001    0.000 ticker.py:533(set_useMathText)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "      405    0.000    0.000    0.000    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:1057(set)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:1087(__init__)\n",
      "      670    0.000    0.000    0.000    0.000 transforms.py:110(__init__)\n",
      "       91    0.000    0.000    0.001    0.000 transforms.py:1109(get_points)\n",
      "       95    0.000    0.000    0.001    0.000 transforms.py:1335(__add__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:1350(_iter_break_from_left_to_right)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:1362(depth)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1376(contains_branch)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1395(contains_branch_seperately)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1413(__sub__)\n",
      "       49    0.000    0.000    0.002    0.000 transforms.py:1467(transform)\n",
      "      189    0.000    0.000    0.001    0.000 transforms.py:157(invalidate)\n",
      "       12    0.000    0.000    0.001    0.000 transforms.py:1588(transform_path)\n",
      "       12    0.000    0.000    0.001    0.000 transforms.py:1597(transform_path_affine)\n",
      "  413/189    0.001    0.000    0.001    0.000 transforms.py:167(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1696(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:1705(__eq__)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:1714(set)\n",
      "        8    0.000    0.000    0.000    0.000 transforms.py:1751(<lambda>)\n",
      "        8    0.000    0.000    0.000    0.000 transforms.py:1752(<lambda>)\n",
      "       50    0.000    0.000    0.000    0.000 transforms.py:1753(<lambda>)\n",
      "      359    0.000    0.000    0.001    0.000 transforms.py:1764(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1768(__array__)\n",
      "    13/12    0.000    0.000    0.000    0.000 transforms.py:1772(__eq__)\n",
      "      112    0.000    0.000    0.001    0.000 transforms.py:1777(transform)\n",
      "       12    0.000    0.000    0.001    0.000 transforms.py:1794(transform_path_affine)\n",
      "      189    0.000    0.000    0.000    0.000 transforms.py:1803(get_affine)\n",
      "       30    0.000    0.000    0.000    0.000 transforms.py:1831(is_separable)\n",
      "      124    0.000    0.000    0.001    0.000 transforms.py:1843(transform_affine)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:1864(inverted)\n",
      "      187    0.000    0.000    0.001    0.000 transforms.py:1881(__init__)\n",
      "      183    0.000    0.000    0.000    0.000 transforms.py:1921(get_matrix)\n",
      "      181    0.001    0.000    0.001    0.000 transforms.py:194(set_children)\n",
      "       52    0.000    0.000    0.001    0.000 transforms.py:1978(rotate)\n",
      "       52    0.000    0.000    0.001    0.000 transforms.py:2001(rotate_deg)\n",
      "       54    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       68    0.000    0.000    0.000    0.000 transforms.py:2046(scale)\n",
      "       90    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       51    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:2126(transform)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:2162(__eq__)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2190(__init__)\n",
      "       29    0.000    0.000    0.000    0.000 transforms.py:2281(__init__)\n",
      "       47    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",
      "       77    0.000    0.000    0.001    0.000 transforms.py:2347(__init__)\n",
      "   144/80    0.000    0.000    0.000    0.000 transforms.py:2376(_invalidate_internal)\n",
      "     12/6    0.000    0.000    0.000    0.000 transforms.py:2391(__eq__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:2398(_iter_break_from_left_to_right)\n",
      "     12/6    0.000    0.000    0.000    0.000 transforms.py:2404(<lambda>)\n",
      "       97    0.000    0.000    0.000    0.000 transforms.py:2405(<lambda>)\n",
      "       49    0.000    0.000    0.002    0.000 transforms.py:2413(transform_affine)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:2417(transform_non_affine)\n",
      "       20    0.000    0.000    0.000    0.000 transforms.py:2426(transform_path_non_affine)\n",
      "   120/69    0.001    0.000    0.002    0.000 transforms.py:2436(get_affine)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:246(frozen)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:250(__array__)\n",
      "       95    0.000    0.000    0.001    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       29    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "       87    0.000    0.000    0.000    0.000 transforms.py:2597(get_matrix)\n",
      "       27    0.000    0.000    0.000    0.000 transforms.py:263(y0)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:2639(__init__)\n",
      "       40    0.000    0.000    0.000    0.000 transforms.py:2651(get_matrix)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:2673(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:2683(get_matrix)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:2822(nonsingular)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:293(p0)\n",
      "       49    0.000    0.000    0.001    0.000 transforms.py:313(xmin)\n",
      "       61    0.000    0.000    0.001    0.000 transforms.py:318(ymin)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:323(xmax)\n",
      "       61    0.000    0.000    0.001    0.000 transforms.py:328(ymax)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:343(intervalx)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:352(intervaly)\n",
      "       73    0.000    0.000    0.000    0.000 transforms.py:361(width)\n",
      "       42    0.000    0.000    0.000    0.000 transforms.py:367(height)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:373(size)\n",
      "       23    0.000    0.000    0.000    0.000 transforms.py:379(bounds)\n",
      "       18    0.000    0.000    0.000    0.000 transforms.py:385(extents)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:474(transformed)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:493(anchored)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:534(shrunk_to_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:619(padded)\n",
      "       15    0.000    0.000    0.000    0.000 transforms.py:624(translated)\n",
      "        3    0.000    0.000    0.001    0.000 transforms.py:649(union)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:654(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:655(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:656(<listcomp>)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:657(<listcomp>)\n",
      "        9    0.000    0.000    0.001    0.000 transforms.py:660(intersection)\n",
      "      174    0.001    0.000    0.001    0.000 transforms.py:754(__init__)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:784(frozen)\n",
      "       29    0.000    0.000    0.000    0.000 transforms.py:790(unit)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:795(null)\n",
      "       48    0.000    0.000    0.001    0.000 transforms.py:800(from_bounds)\n",
      "       76    0.000    0.000    0.002    0.000 transforms.py:809(from_extents)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:856(update_from_path)\n",
      "        3    0.000    0.000    0.000    0.000 transforms.py:932(update_from_data_xy)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:988(intervalx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:993(intervaly)\n",
      "      288    0.000    0.000    0.000    0.000 twodim_base.py:236(_diag_dispatcher)\n",
      "      288    0.001    0.000    0.001    0.000 twodim_base.py:240(diag)\n",
      "      144    0.000    0.000    0.000    0.000 type_check.py:117(_real_dispatcher)\n",
      "      144    0.000    0.000    0.000    0.000 type_check.py:121(real)\n",
      "      144    0.000    0.000    0.000    0.000 type_check.py:163(_imag_dispatcher)\n",
      "      144    0.000    0.000    0.000    0.000 type_check.py:167(imag)\n",
      "      144    0.000    0.000    0.000    0.000 type_check.py:206(_is_type_dispatcher)\n",
      "      144    0.001    0.000    0.001    0.000 type_check.py:247(isreal)\n",
      "        1    0.000    0.000    0.000    0.000 tz.py:74(utcoffset)\n",
      "     10/6    0.000    0.000    0.000    0.000 units.py:164(get_converter)\n",
      "       96    0.000    0.000    0.001    0.000 units.py:56(_is_natively_supported)\n",
      "       15    0.000    0.000    0.000    0.000 weakref.py:46(__new__)\n",
      "        2    0.000    0.000    0.000    0.000 widgets.py:38(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 zmqshell.py:63(_flush_streams)\n",
      "        1    0.000    0.000    0.000    0.000 zmqshell.py:73(_hooks)\n",
      "        1    0.000    0.000    0.001    0.001 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",
      "      234    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEFC799F90}\n",
      "      298    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       50    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method _struct.pack}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _thread.allocate_lock}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method _thread.get_ident}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method binascii.b2a_base64}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.__build_class__}\n",
      "      319    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "      424    0.000    0.000    0.001    0.000 {built-in method builtins.any}\n",
      "      436    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "      205    0.000    0.000    0.000    0.000 {built-in method builtins.delattr}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.dir}\n",
      "        1    0.000    0.000    0.196    0.196 {built-in method builtins.exec}\n",
      "     2718    0.001    0.000    0.001    0.000 {built-in method builtins.getattr}\n",
      "      627    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "  488/314    0.000    0.000    0.001    0.000 {built-in method builtins.hash}\n",
      "      646    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "     5068    0.001    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "     1629    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "      362    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "2608/2589    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.locals}\n",
      "      196    0.000    0.000    0.000    0.000 {built-in method builtins.max}\n",
      "       30    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "1352/1300    0.001    0.000    0.003    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.repr}\n",
      "       16    0.000    0.000    0.000    0.000 {built-in method builtins.round}\n",
      "      362    0.000    0.000    0.000    0.000 {built-in method builtins.setattr}\n",
      "        9    0.000    0.000    0.000    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sum}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "     1764    0.000    0.000    0.000    0.000 {built-in method math.factorial}\n",
      "       68    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "      124    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.cleanup_path}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "       29    0.000    0.000    0.000    0.000 {built-in method nt.fspath}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "      596    0.001    0.000    0.001    0.000 {built-in method numpy.arange}\n",
      "      457    0.001    0.000    0.001    0.000 {built-in method numpy.array}\n",
      "     3099    0.002    0.000    0.002    0.000 {built-in method numpy.asanyarray}\n",
      "     1886    0.001    0.000    0.001    0.000 {built-in method numpy.asarray}\n",
      "6317/2055    0.008    0.000    0.043    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method numpy.core._multiarray_umath.normalize_axis_index}\n",
      "      325    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "      288    0.001    0.000    0.001    0.000 {built-in method numpy.frompyfunc}\n",
      "      583    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method scipy.optimize._zeros._brentq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method sys.exc_info}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method sys.getrecursionlimit}\n",
      "      112    0.000    0.000    0.000    0.000 {built-in method sys.intern}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method utcnow}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method zlib.crc32}\n",
      "     1766    0.000    0.000    0.000    0.000 {function RcParams.__getitem__ at 0x00000238064C3920}\n",
      "        1    0.000    0.000    0.000    0.000 {method '__array_prepare__' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__contains__' of 'frozenset' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__enter__' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.lock' objects}\n",
      "      144    0.000    0.000    0.000    0.000 {method '__reduce_ex__' of 'object' objects}\n",
      "       15    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'add' of 'set' objects}\n",
      "      289    0.000    0.000    0.002    0.000 {method 'all' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'any' of 'numpy.ndarray' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "     2683    0.000    0.000    0.000    0.000 {method 'append' of 'list' objects}\n",
      "      301    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'cleanup' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.OrderedDict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'clear' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'clear' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of 'ImagingCore' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'copy' of '_hashlib.HMAC' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "       72    0.000    0.000    0.000    0.000 {method 'copy' of 'list' objects}\n",
      "      388    0.001    0.000    0.001    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      148    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'dot' of 'numpy.ndarray' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        4    0.001    0.000    0.002    0.000 {method 'draw_path' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'draw_text_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        1    0.006    0.006    0.006    0.006 {method 'encode' of 'ImagingEncoder' objects}\n",
      "        7    0.000    0.000    0.000    0.000 {method 'encode' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'extend' of 'list' objects}\n",
      "       42    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",
      "     1893    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'get' of 'mappingproxy' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'get_bitmap_offset' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'get_descent' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method 'get_width_height' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'getvalue' of '_io.StringIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'hexdigest' of '_hashlib.HMAC' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'isidentifier' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'islower' of 'bytes' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'isoformat' of 'datetime.datetime' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'item' of 'numpy.ndarray' objects}\n",
      "     3377    0.000    0.000    0.000    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",
      "      306    0.000    0.000    0.000    0.000 {method 'join' of 'str' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'lower' of 'str' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'lstrip' of 'str' objects}\n",
      "      251    0.000    0.000    0.000    0.000 {method 'match' of 're.Pattern' objects}\n",
      "       64    0.000    0.000    0.000    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "       64    0.000    0.000    0.001    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'move_to_end' of 'collections.OrderedDict' objects}\n",
      "      288    0.000    0.000    0.000    0.000 {method 'nonzero' of 'numpy.ndarray' objects}\n",
      "      312    0.001    0.000    0.001    0.000 {method 'outer' of 'numpy.ufunc' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'pixel_access' of 'ImagingCore' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'collections.deque' objects}\n",
      "      302    0.000    0.000    0.000    0.000 {method 'pop' of 'dict' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'pop' of 'list' objects}\n",
      "      598    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "     1046    0.004    0.000    0.004    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'release' of '_thread.lock' objects}\n",
      "       46    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'replace' of 'datetime.datetime' objects}\n",
      "       86    0.000    0.000    0.000    0.000 {method 'replace' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "      179    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'reverse' of 'list' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rfind' of 'str' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'rpartition' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       28    0.000    0.000    0.000    0.000 {method 'set_size' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       28    0.003    0.000    0.003    0.000 {method 'set_text' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "       31    0.000    0.000    0.000    0.000 {method 'setdefault' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'setimage' of 'ImagingEncoder' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'sort' of 'list' objects}\n",
      "       36    0.000    0.000    0.000    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "       53    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'splitlines' of 'str' objects}\n",
      "       58    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "       52    0.000    0.000    0.000    0.000 {method 'tolist' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'update' of '_hashlib.HMAC' objects}\n",
      "      162    0.000    0.000    0.000    0.000 {method 'update' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'upper' of 'str' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'values' of 'collections.OrderedDict' objects}\n",
      "      307    0.000    0.000    0.000    0.000 {method 'values' of 'dict' objects}\n",
      "       41    0.000    0.000    0.000    0.000 {method 'values' of 'mappingproxy' objects}\n",
      "       16    0.000    0.000    0.000    0.000 {method 'write' of '_io.BytesIO' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    #Define two sets of binary data\n",
    "    list1 = data_uci.predicted_newuci\n",
    "    list2 = data_uci.Actual_value_salary       \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",
    "    # 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",
    "        # Add labels to the diagram\n",
    "    venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(False_Positive))\n",
    "    venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(True_Negative))\n",
    "    venn.get_label_by_id('11').set_text('A & P\\n' + str(True_Positive+False_Negative))\n",
    "    # Show the Venn diagram\n",
    "    plt.show()\n",
    "    pass\n",
    "cProfile.run('my_method()')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from matplotlib_venn import venn2, venn2_circles\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = data_uci.predicted_newuci\n",
    "list2 = data_uci.Actual_value_salary \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.7), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fp_center_x - 0.3, fp_center_y + 0.8, 'Female: ' + str(FP_women_count), fontsize=12, color='black')\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.5, fn_center_y + 0.2), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.58, fn_center_y + 0.08, 'Male: ' + str(FP_men_count), fontsize=12, color='black')\n",
    "\n",
    "# Draw circles for old and young in FN zone\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.6, 'Female: ' + str(FN_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.3, 'Male: ' + str(FN_men_count), fontsize=12, color='black')\n",
    "\n",
    "# Draw circles for old and young in Correct Prediction zone\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.2, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.27, fn_center_y + 0.6, 'Female: ' + str(TP_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.2, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.27, fn_center_y + 0.3, 'Male: ' + str(TP_men_count), fontsize=12, color='black')\n",
    "\n",
    "#plt.title(\"Venn diagram with subsets of OLD and YOUNG in FP and FN zones\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.5989778960412684\n",
      "         50 function calls (48 primitive calls) in 0.000 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 3173097760.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.000    0.000 {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 (data_uci)\n",
    "    print(\"new model accuracy is\",Accuracy)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5989778960412684\n",
      "         935 function calls (915 primitive calls) in 0.009 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.009    0.009 860521017.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.001    0.001 <__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.004    0.004 <__array_function__ internals>:177(union1d)\n",
      "        5    0.000    0.000    0.006    0.001 <__array_function__ internals>:177(unique)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "     11/5    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.009    0.009 <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.002    0.001 _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.008    0.008 _classification.py:146(accuracy_score)\n",
      "        1    0.000    0.000    0.007    0.007 _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.008    0.008 _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.006    0.001 arraysetops.py:138(unique)\n",
      "        5    0.001    0.000    0.006    0.001 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.004    0.004 arraysetops.py:898(union1d)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:1096(__new__)\n",
      "        4    0.000    0.000    0.000    0.000 enum.py:691(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:198(reshape)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:391(_average_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 function_base.py:396(average)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        7    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "        3    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3075(_bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "       18    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       16    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        2    0.000    0.000    0.000    0.000 multiclass.py:126(is_multilabel)\n",
      "        2    0.000    0.000    0.003    0.001 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:1152(column_or_1d)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:257(_is_arraylike)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:262(_is_arraylike_not_scalar)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:629(check_array)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "     11/5    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.009    0.009 {built-in method builtins.exec}\n",
      "       25    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       66    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "      120    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    18/12    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     10/8    0.001    0.000    0.007    0.001 {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.001    0.000    0.001    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.004    0.001    0.004    0.001 {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(data_uci.Predicted_Final_salary,data_uci.Actual_value_salary))\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5989778960412684\n",
      "The time of execution of above program is : 7.55620002746582 ms\n"
     ]
    }
   ],
   "source": [
    "# Import time module\n",
    "import time\n",
    "\n",
    "# record start time\n",
    "start = time.time()\n",
    "\n",
    "# define a sample code segment\n",
    "from sklearn.metrics import accuracy_score\n",
    "print(accuracy_score(data_uci.Predicted_Final_salary,data_uci.Actual_value_salary))\n",
    "\n",
    "# record end time\n",
    "end = time.time()\n",
    "\n",
    "# print the difference between start\n",
    "# and end time in milli. secs\n",
    "print(\"The time of execution of above program is :\",\n",
    "\t(end-start) *10**3,\"ms\")\n",
    "\t\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.5989778960412684\n",
      "The time of execution of above program is : 0.0 ms\n"
     ]
    }
   ],
   "source": [
    "# Import time module\n",
    "import time\n",
    "\n",
    "# record start time\n",
    "start = time.time()\n",
    "\n",
    "# define a sample code segment\n",
    "Accuracy=(True_Positive+False_Negative)/len (data_uci)\n",
    "print(\"new model accuracy is\",Accuracy)\n",
    "\n",
    "# record end time\n",
    "end = time.time()\n",
    "\n",
    "# print the difference between start\n",
    "# and end time in milli. secs\n",
    "print(\"The time of execution of above program is :\",\n",
    "\t(end-start) * 10**3, \"ms\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n",
      "         3827 function calls (3772 primitive calls) in 0.044 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.044    0.044 3921912886.py:3(my_method)\n",
      "        1    0.000    0.000    0.044    0.044 3921912886.py:4(predictive_parity)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        2    0.000    0.000    0.001    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.004    0.002 <__array_function__ internals>:177(union1d)\n",
      "       18    0.000    0.000    0.011    0.001 <__array_function__ internals>:177(unique)\n",
      "       18    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "       10    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "       16    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.044    0.044 <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.008    0.001 _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.015    0.008 _classification.py:232(confusion_matrix)\n",
      "        2    0.000    0.000    0.009    0.004 _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:39(_amax)\n",
      "        8    0.000    0.000    0.000    0.000 _methods.py:43(_amin)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        4    0.000    0.000    0.000    0.000 _sputils.py:147(get_index_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        6    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       14    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        7    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:178(__get__)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:29(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 accessor.py:45(_validate)\n",
      "        4    0.000    0.000    0.021    0.005 array_ops.py:231(comparison_op)\n",
      "        4    0.000    0.000    0.020    0.005 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "        4    0.000    0.000    0.022    0.006 arraylike.py:40(__eq__)\n",
      "       18    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       18    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       18    0.000    0.000    0.011    0.001 arraysetops.py:138(unique)\n",
      "       18    0.001    0.000    0.011    0.001 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.004    0.002 arraysetops.py:898(union1d)\n",
      "        7    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       20    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "       24    0.000    0.000    0.000    0.000 base.py:324(ndim)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.002    0.001    0.002    0.001 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.002    0.001    0.002    0.001 blocks.py:836(_slice)\n",
      "        4    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       16    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       12    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       20    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       40    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1751(pandas_dtype)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        4    0.000    0.000    0.022    0.006 common.py:57(new_method)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        8    0.000    0.000    0.000    0.000 common.py:96(is_bool_indexer)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "        8    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        4    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "        8    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       12    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        4    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "        4    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        8    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:193(_reshape_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:198(reshape)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:2183(_sum_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:2188(sum)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:3152(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "       10    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       16    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      100    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      100    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        8    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       51    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       12    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        7    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        4    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        4    0.000    0.000    0.000    0.000 indexing.py:2522(check_bool_indexer)\n",
      "        7    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        8    0.000    0.000    0.000    0.000 inference.py:188(is_array_like)\n",
      "       31    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "        4    0.000    0.000    0.005    0.001 managers.py:2023(getitem_mgr)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:2054(index)\n",
      "       64    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       40    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        4    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        8    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        4    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        4    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "       12    0.000    0.000    0.000    0.000 multiclass.py:114(<genexpr>)\n",
      "        6    0.000    0.000    0.000    0.000 multiclass.py:116(<genexpr>)\n",
      "        8    0.000    0.000    0.000    0.000 multiclass.py:126(is_multilabel)\n",
      "        8    0.000    0.000    0.006    0.001 multiclass.py:210(type_of_target)\n",
      "        4    0.000    0.000    0.002    0.001 multiclass.py:23(_unique_multiclass)\n",
      "        2    0.000    0.000    0.005    0.003 multiclass.py:44(unique_labels)\n",
      "        6    0.000    0.000    0.003    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.002    0.001 range.py:956(__getitem__)\n",
      "        4    0.000    0.000    0.005    0.001 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.022    0.006 series.py:6233(_cmp_method)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       40    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        4    0.000    0.000    0.005    0.001 series.py:966(__getitem__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 type_check.py:400(_nan_to_num_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 type_check.py:404(nan_to_num)\n",
      "        8    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        4    0.000    0.000    0.000    0.000 utils.py:430(check_array_indexer)\n",
      "        4    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "       10    0.000    0.000    0.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.000    0.000 validation.py:629(check_array)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "       20    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method __new__ of type object at 0x00007FFEFC799F90}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "       10    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "       60    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       20    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.any}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.044    0.044 {built-in method builtins.exec}\n",
      "      166    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "      172    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       37    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  568/556    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       41    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  142/122    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.max}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method from_iterable}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method numpy.arange}\n",
      "        8    0.000    0.000    0.000    0.000 {built-in method numpy.array}\n",
      "       39    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    70/54    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    44/37    0.001    0.000    0.013    0.000 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       20    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       28    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       14    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method numpy.zeros}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method scipy.sparse._sparsetools.coo_todense}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'astype' of 'numpy.ndarray' objects}\n",
      "       30    0.000    0.000    0.000    0.000 {method 'copy' of 'dict' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "       18    0.002    0.000    0.002    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method 'insert' of 'list' objects}\n",
      "       10    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'min' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'pop' of 'set' objects}\n",
      "        6    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "       22    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "       20    0.000    0.000    0.000    0.000 {method 'remove' of 'list' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        8    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       18    0.008    0.000    0.008    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'startswith' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_float}\n",
      "       12    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_integer}\n",
      "        7    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       24    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       16    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       11    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        4    0.020    0.005    0.020    0.005 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "        # create a confusion matrix for each group\n",
    "        cm_group0 = confusion_matrix(y_true[sensitive_attr ==0], y_pred[sensitive_attr ==0])\n",
    "        cm_group1 = confusion_matrix(y_true[sensitive_attr ==1], y_pred[sensitive_attr ==1])   \n",
    "        # compute the true positive rate and false positive rate for each group\n",
    "        tpr_group0 = cm_group0[1, 1] / np.sum(cm_group0[1, :])\n",
    "        fpr_group0 = cm_group0[0, 1] / np.sum(cm_group0[0, :])\n",
    "        tpr_group1 = cm_group1[1, 1] / np.sum(cm_group1[1, :])\n",
    "        fpr_group1 = cm_group1[0, 1] / np.sum(cm_group1[0, :]) \n",
    "        # check if the true positive rate and false positive rate are equal across groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Predictive parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Predictive parity is not satisfied.\")\n",
    "    predictive_parity(data_uci.Actual_value_salary,data_uci.Predicted_Final_salary,data_uci.sex)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalized odds is not satisfied.\n",
      "         3226 function calls (3150 primitive calls) in 0.025 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.025    0.025 2079806232.py:3(my_method)\n",
      "        1    0.000    0.000    0.025    0.025 2079806232.py:4(equalized_odds)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        6    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        6    0.000    0.000    0.009    0.001 <__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.003    0.000 <__array_function__ internals>:177(unique)\n",
      "       11    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.025    0.025 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       24    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       24    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        9    0.000    0.000    0.001    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "       11    0.000    0.000    0.011    0.001 array_ops.py:231(comparison_op)\n",
      "        2    0.000    0.000    0.009    0.004 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "       11    0.000    0.000    0.014    0.001 arraylike.py:40(__eq__)\n",
      "       12    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "       12    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "       12    0.000    0.000    0.003    0.000 arraysetops.py:138(unique)\n",
      "       12    0.001    0.000    0.003    0.000 arraysetops.py:323(_unique1d)\n",
      "        6    0.000    0.000    0.000    0.000 arraysetops.py:368(_intersect1d_dispatcher)\n",
      "        6    0.001    0.000    0.009    0.001 arraysetops.py:373(intersect1d)\n",
      "        3    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        6    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        3    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "       11    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       22    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "       11    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "       11    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "       11    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "       14    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       33    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       66    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "       11    0.000    0.000    0.014    0.001 common.py:57(new_method)\n",
      "       11    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       22    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "       11    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       22    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       33    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "       11    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "       11    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        9    0.000    0.000    0.001    0.000 expressions.py:225(evaluate)\n",
      "        9    0.000    0.000    0.001    0.000 expressions.py:64(_evaluate_standard)\n",
      "       11    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "       11    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        3    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       11    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       22    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "      180    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "      180    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       11    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       36    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       22    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        3    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        3    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       47    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       22    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "       11    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "       11    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        9    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "       11    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        6    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "       11    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       44    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "       11    0.000    0.000    0.002    0.000 series.py:3194(_construct_result)\n",
      "       11    0.000    0.000    0.002    0.000 series.py:342(__init__)\n",
      "       11    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "       11    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       44    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "       11    0.000    0.000    0.014    0.001 series.py:6233(_cmp_method)\n",
      "       33    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       22    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "       11    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "       22    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        9    0.001    0.000    0.001    0.000 {built-in method _operator.eq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       33    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        3    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.025    0.025 {built-in method builtins.exec}\n",
      "      208    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       11    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       53    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  592/581    0.000    0.000    0.001    0.000 {built-in method builtins.isinstance}\n",
      "       36    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "  187/143    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       39    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "       11    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "    39/18    0.002    0.000    0.010    0.001 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       48    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       24    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       11    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "       12    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "       18    0.007    0.000    0.007    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "       11    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       33    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       31    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       25    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        2    0.009    0.004    0.009    0.004 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "        # find indices of positive predictions and sensitive attribute values\n",
    "        pos_indices = np.where(y_pred == 1)[0]\n",
    "        #sensitive_indices = np.where(sensitive_attr ==0)[0]\n",
    "        # find indices of positive predictions and sensitive attribute values for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr ==0)[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr ==1)[0])\n",
    "        # compute true positive rates for each group\n",
    "        tpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        tpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 1)[0])) / len(np.where(y_true == 1)[0])\n",
    "        # compute false positive rates for each group\n",
    "        fpr_group0 = len(np.intersect1d(pos_indices_group0, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        fpr_group1 = len(np.intersect1d(pos_indices_group1, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "        # check if equalized odds is satisfied for both groups\n",
    "        if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "            print(\"Equalized odds is satisfied.\")\n",
    "        else:\n",
    "            print(\"Equalized odds is not satisfied.\")\n",
    "        return tpr_group0, tpr_group1, fpr_group0, fpr_group1\n",
    "    equalized_odds(data_uci.Actual_value_salary,data_uci.Predicted_Final_salary,data_uci.sex)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Demographic parity is not satisfied.\n",
      "         1522 function calls (1488 primitive calls) in 0.024 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.024    0.024 852908627.py:3(my_method)\n",
      "        1    0.000    0.000    0.024    0.024 852908627.py:9(demographic_parity)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(all)\n",
      "        2    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        2    0.000    0.000    0.004    0.002 <__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.001    0.000 <__array_function__ internals>:177(unique)\n",
      "        5    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(where)\n",
      "        1    0.000    0.000    0.024    0.024 <string>:1(<module>)\n",
      "        2    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "       12    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        6    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:452(_no_nep50_warning)\n",
      "        1    0.000    0.000    0.000    0.000 array_ops.py:136(_na_arithmetic_op)\n",
      "        5    0.000    0.000    0.018    0.004 array_ops.py:231(comparison_op)\n",
      "        4    0.000    0.000    0.017    0.004 array_ops.py:60(comp_method_OBJECT_ARRAY)\n",
      "        5    0.000    0.000    0.019    0.004 arraylike.py:40(__eq__)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:125(_unpack_tuple)\n",
      "        4    0.000    0.000    0.000    0.000 arraysetops.py:133(_unique_dispatcher)\n",
      "        4    0.000    0.000    0.001    0.000 arraysetops.py:138(unique)\n",
      "        4    0.000    0.000    0.001    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.004    0.002 arraysetops.py:373(intersect1d)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        5    0.000    0.000    0.000    0.000 base.py:58(_validate_set_axis)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:7277(ensure_index)\n",
      "        5    0.000    0.000    0.000    0.000 base.py:7372(maybe_extract_name)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2091(maybe_coerce_values)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2120(get_block_type)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2172(new_block)\n",
      "        5    0.000    0.000    0.000    0.000 blocks.py:2186(check_ndim)\n",
      "        5    0.000    0.000    0.000    0.000 cast.py:1422(sanitize_to_nanoseconds)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:1048(is_numeric_v_string_like)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:1420(is_1d_only_ea_dtype)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        7    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "       15    0.000    0.000    0.000    0.000 common.py:1725(validate_all_hashable)\n",
      "       30    0.000    0.000    0.000    0.000 common.py:1744(<genexpr>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:566(require_length_match)\n",
      "        5    0.000    0.000    0.019    0.004 common.py:57(new_method)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:77(get_op_result_name)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:116(_get_single_key)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:134(_get_option)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:262(__call__)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:579(_select_options)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:597(_get_root)\n",
      "       10    0.000    0.000    0.000    0.000 config.py:611(_get_deprecated_option)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:638(_translate_key)\n",
      "        5    0.000    0.000    0.000    0.000 config.py:650(_warn_if_deprecated)\n",
      "       10    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "       15    0.000    0.000    0.000    0.000 construction.py:461(ensure_wrapped_if_datetimelike)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:493(sanitize_array)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:676(_sanitize_ndim)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:713(_sanitize_str_dtypes)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:733(_maybe_repeat)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:744(_try_cast)\n",
      "        5    0.000    0.000    0.000    0.000 construction.py:861(is_empty_data)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:104(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:132(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:141(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 contextlib.py:287(helper)\n",
      "        5    0.000    0.000    0.000    0.000 dispatch.py:13(should_extension_dispatch)\n",
      "        1    0.000    0.000    0.000    0.000 expressions.py:225(evaluate)\n",
      "        1    0.000    0.000    0.000    0.000 expressions.py:64(_evaluate_standard)\n",
      "        5    0.000    0.000    0.000    0.000 flags.py:49(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 flags.py:53(allows_duplicate_labels)\n",
      "        5    0.000    0.000    0.000    0.000 flags.py:85(allows_duplicate_labels)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2427(_all_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "        5    0.000    0.000    0.000    0.000 generic.py:259(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 generic.py:332(attrs)\n",
      "       10    0.000    0.000    0.000    0.000 generic.py:353(flags)\n",
      "       88    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "       88    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        5    0.000    0.000    0.000    0.000 generic.py:5844(__finalize__)\n",
      "       17    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "       10    0.000    0.000    0.000    0.000 generic.py:5904(__setattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "       22    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:203(schedule)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:444(_is_master_process)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:465(_schedule_flush)\n",
      "        2    0.000    0.000    0.000    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:1891(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:1934(from_array)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:2009(_block)\n",
      "       10    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:228(set_axis)\n",
      "        5    0.000    0.000    0.000    0.000 managers.py:2433(_using_copy_on_write)\n",
      "        5    0.000    0.000    0.000    0.000 missing.py:108(isna)\n",
      "        1    0.000    0.000    0.000    0.000 missing.py:140(dispatch_fill_zeros)\n",
      "        5    0.000    0.000    0.000    0.000 missing.py:191(_isna)\n",
      "        2    0.000    0.000    0.000    0.000 multiarray.py:152(concatenate)\n",
      "        5    0.000    0.000    0.000    0.000 multiarray.py:345(where)\n",
      "        1    0.000    0.000    0.000    0.000 multiarray.py:668(result_type)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2274(_isclose_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2278(isclose)\n",
      "        1    0.000    0.000    0.000    0.000 numeric.py:2359(within_tol)\n",
      "       20    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        5    0.000    0.000    0.001    0.000 series.py:3194(_construct_result)\n",
      "        5    0.000    0.000    0.001    0.000 series.py:342(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 series.py:546(_constructor)\n",
      "        5    0.000    0.000    0.000    0.000 series.py:565(_set_axis)\n",
      "       20    0.000    0.000    0.000    0.000 series.py:611(name)\n",
      "        5    0.000    0.000    0.019    0.004 series.py:6233(_cmp_method)\n",
      "       15    0.000    0.000    0.000    0.000 series.py:661(name)\n",
      "       10    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        5    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "       10    0.000    0.000    0.000    0.000 typing.py:2214(cast)\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method _operator.eq}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.abs}\n",
      "       15    0.000    0.000    0.000    0.000 {built-in method builtins.all}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.024    0.024 {built-in method builtins.exec}\n",
      "      103    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "       26    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "  274/269    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "    85/65    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       15    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     17/8    0.001    0.000    0.004    0.001 {built-in method numpy.core._multiarray_umath.implement_array_function}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "       24    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "       12    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        5    0.000    0.000    0.000    0.000 {built-in method pandas._libs.missing.checknull}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'all' of 'numpy.generic' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'flatten' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'get' of 'dict' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'items' of 'dict' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'ravel' of 'numpy.ndarray' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'reduce' of 'numpy.ufunc' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'reset' of '_contextvars.ContextVar' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'set' of '_contextvars.ContextVar' objects}\n",
      "        6    0.003    0.000    0.003    0.000 {method 'sort' of 'numpy.ndarray' objects}\n",
      "        5    0.000    0.000    0.000    0.000 {method 'split' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "       15    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_list_like}\n",
      "       11    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "       12    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "        4    0.017    0.004    0.017    0.004 {pandas._libs.ops.scalar_compare}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    #demographic parity \n",
    "    # import necessary packages\n",
    "    import numpy as np\n",
    "\n",
    "    # define function to compute demographic parity\n",
    "    def demographic_parity(y_pred, sensitive_attr):\n",
    "        # find indices of positive predictions and sensitive attribute values\n",
    "        pos_indices = np.where(y_pred == 1)[0]  \n",
    "        #sensitive_indices = np.where(sensitive_attr ==0)[0]\n",
    "        # find indices of positive predictions for each group\n",
    "        pos_indices_group0 = np.intersect1d(pos_indices, np.where(sensitive_attr ==0)[0])\n",
    "        pos_indices_group1 = np.intersect1d(pos_indices, np.where(sensitive_attr ==1)[0])\n",
    "        # compute probabilities of positive predictions for each group\n",
    "        prob_pos_group0 = len(pos_indices_group0) / len(np.where(sensitive_attr ==0)[0])\n",
    "        prob_pos_group1 = len(pos_indices_group1) / len(np.where(sensitive_attr== 1)[0])\n",
    "        # check if demographic parity is satisfied\n",
    "        if np.isclose(prob_pos_group0, prob_pos_group1, rtol=1e-3):\n",
    "            print(\"Demographic parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Demographic parity is not satisfied.\")\n",
    "        return prob_pos_group0, prob_pos_group1\n",
    "    demographic_parity(data_uci.Predicted_Final_salary,data_uci.sex)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping doesnot exiats\n",
      "         177 function calls in 0.001 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.001    0.001 3059037898.py:3(my_method)\n",
      "        1    0.000    0.000    0.001    0.001 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.000    0.000 _methods.py:61(_all)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:132(geterr)\n",
      "        2    0.000    0.000    0.000    0.000 _ufunc_config.py:33(seterr)\n",
      "        1    0.000    0.000    0.000    0.000 _ufunc_config.py:426(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 _ufunc_config.py:430(__enter__)\n",
      "        1    0.000    0.000    0.000    0.000 _ufunc_config.py:435(__exit__)\n",
      "        1    0.000    0.000    0.000    0.000 _validators.py:226(validate_bool_kwarg)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:324(ndim)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1154(needs_i8_conversion)\n",
      "        1    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        3    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        3    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:151(classes_and_not_datetimelike)\n",
      "        1    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:156(<lambda>)\n",
      "        5    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        3    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 common.py:1751(pandas_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:684(is_integer_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 construction.py:399(extract_array)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:3758(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 frame.py:4274(_get_item_cache)\n",
      "        1    0.000    0.000    0.000    0.000 function.py:56(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 generic.py:11108(_logical_func)\n",
      "        1    0.000    0.000    0.000    0.000 generic.py:11178(all)\n",
      "        1    0.000    0.000    0.000    0.000 generic.py:11618(all)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "        1    0.000    0.000    0.000    0.000 generic.py:550(_get_axis_number)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "        1    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 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",
      "        1    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "        1    0.000    0.000    0.000    0.000 nanops.py:195(_get_fill_value)\n",
      "        1    0.000    0.000    0.000    0.000 nanops.py:217(_maybe_get_mask)\n",
      "        1    0.000    0.000    0.000    0.000 nanops.py:261(_get_values)\n",
      "        1    0.000    0.000    0.000    0.000 nanops.py:350(_na_ok_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 nanops.py:542(nanall)\n",
      "        1    0.000    0.000    0.000    0.000 series.py:4773(_reduce)\n",
      "        1    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "        1    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",
      "       29    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "        9    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",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "        2    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        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",
      "        1    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_bool}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_iterator}\n",
      "        1    0.000    0.000    0.000    0.000 {pandas._libs.lib.is_scalar}\n",
      "        2    0.000    0.000    0.000    0.000 {pandas._libs.lib.item_from_zerodim}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "          \n",
    "    \n",
    "    \n",
    "    if np.logical_and(data_uci.Actual_value_salary.iloc,data_uci.Predicted_Final_salary.all()):\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 exists\")\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
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
