{
 "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>TaxonomyLevel</th>\n",
       "      <th>TaxonomyValue</th>\n",
       "      <th>InstitutionId</th>\n",
       "      <th>InstitutionName</th>\n",
       "      <th>DegreeInstitutionId</th>\n",
       "      <th>DegreeInstitutionName</th>\n",
       "      <th>Total</th>\n",
       "      <th>Men</th>\n",
       "      <th>Women</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Field</td>\n",
       "      <td>Mathematics</td>\n",
       "      <td>82</td>\n",
       "      <td>Georgia Tech</td>\n",
       "      <td>243.0</td>\n",
       "      <td>University of Alabama</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Domain</td>\n",
       "      <td>Mathematics and Computing</td>\n",
       "      <td>82</td>\n",
       "      <td>Georgia Tech</td>\n",
       "      <td>243.0</td>\n",
       "      <td>University of Alabama</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>82</td>\n",
       "      <td>Georgia Tech</td>\n",
       "      <td>243.0</td>\n",
       "      <td>University of Alabama</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Field</td>\n",
       "      <td>Mathematics</td>\n",
       "      <td>82</td>\n",
       "      <td>Georgia Tech</td>\n",
       "      <td>251.0</td>\n",
       "      <td>UC Berkeley</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Domain</td>\n",
       "      <td>Mathematics and Computing</td>\n",
       "      <td>82</td>\n",
       "      <td>Georgia Tech</td>\n",
       "      <td>251.0</td>\n",
       "      <td>UC Berkeley</td>\n",
       "      <td>20.0</td>\n",
       "      <td>14.0</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411539</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>395</td>\n",
       "      <td>Texas Southern</td>\n",
       "      <td>557973.0</td>\n",
       "      <td>Xavier University of Louisiana</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411540</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>101</td>\n",
       "      <td>Jewish Theological Seminary</td>\n",
       "      <td>53.0</td>\n",
       "      <td>City University of New York, The</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411541</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>50</td>\n",
       "      <td>Concordia Seminary</td>\n",
       "      <td>58.0</td>\n",
       "      <td>Drew</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411542</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>50</td>\n",
       "      <td>Concordia Seminary</td>\n",
       "      <td>548894.0</td>\n",
       "      <td>Pontifica Institute di Studi Arabi e d'Islamis...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>411543</th>\n",
       "      <td>Academia</td>\n",
       "      <td>Academia</td>\n",
       "      <td>50</td>\n",
       "      <td>Concordia Seminary</td>\n",
       "      <td>538136.0</td>\n",
       "      <td>Capella University</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>411544 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       TaxonomyLevel              TaxonomyValue  InstitutionId  \\\n",
       "0              Field                Mathematics             82   \n",
       "1             Domain  Mathematics and Computing             82   \n",
       "2           Academia                   Academia             82   \n",
       "3              Field                Mathematics             82   \n",
       "4             Domain  Mathematics and Computing             82   \n",
       "...              ...                        ...            ...   \n",
       "411539      Academia                   Academia            395   \n",
       "411540      Academia                   Academia            101   \n",
       "411541      Academia                   Academia             50   \n",
       "411542      Academia                   Academia             50   \n",
       "411543      Academia                   Academia             50   \n",
       "\n",
       "                    InstitutionName  DegreeInstitutionId  \\\n",
       "0                      Georgia Tech                243.0   \n",
       "1                      Georgia Tech                243.0   \n",
       "2                      Georgia Tech                243.0   \n",
       "3                      Georgia Tech                251.0   \n",
       "4                      Georgia Tech                251.0   \n",
       "...                             ...                  ...   \n",
       "411539               Texas Southern             557973.0   \n",
       "411540  Jewish Theological Seminary                 53.0   \n",
       "411541           Concordia Seminary                 58.0   \n",
       "411542           Concordia Seminary             548894.0   \n",
       "411543           Concordia Seminary             538136.0   \n",
       "\n",
       "                                    DegreeInstitutionName  Total   Men  Women  \n",
       "0                                   University of Alabama    1.0   1.0    0.0  \n",
       "1                                   University of Alabama    1.0   1.0    0.0  \n",
       "2                                   University of Alabama    1.0   1.0    0.0  \n",
       "3                                             UC Berkeley    3.0   1.0    2.0  \n",
       "4                                             UC Berkeley   20.0  14.0    5.0  \n",
       "...                                                   ...    ...   ...    ...  \n",
       "411539                     Xavier University of Louisiana    1.0   1.0    0.0  \n",
       "411540                   City University of New York, The    1.0   1.0    0.0  \n",
       "411541                                               Drew    1.0   1.0    0.0  \n",
       "411542  Pontifica Institute di Studi Arabi e d'Islamis...    1.0   0.0    0.0  \n",
       "411543                                 Capella University    1.0   1.0    0.0  \n",
       "\n",
       "[411544 rows x 9 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",
    "dataframe=pd.read_csv('edgelists.csv')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "dataframe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe.isnull().sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "le = LabelEncoder()\n",
    "dataframe['TaxonomyLevel'] = le.fit_transform(dataframe['TaxonomyLevel'])\n",
    "dataframe['InstitutionName'] = le.fit_transform(dataframe['InstitutionName'])\n",
    "dataframe['DegreeInstitutionName'] = le.fit_transform(dataframe['DegreeInstitutionName'])\n",
    "dataframe['TaxonomyValue']=le.fit_transform(dataframe['TaxonomyValue'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe.columns\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe.fillna(0, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "y=dataframe[['Men','Women']]\n",
    "y\n",
    "x=dataframe[['TaxonomyLevel','TaxonomyValue','InstitutionId','InstitutionName','DegreeInstitutionId','DegreeInstitutionName']]\n",
    "x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe.dropna( inplace=True)\n",
    "dataframe['DegreeInstitutionId'].fillna(dataframe[['DegreeInstitutionId']].mean(), inplace=True)\n",
    "dataframe['DegreeInstitutionName'].fillna(dataframe[['DegreeInstitutionName']].mean(), inplace=True)\n",
    "dataframe['Total'].fillna(dataframe[['Total']].mean(), inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe.isnull().sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe=dataframe.dropna()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(288080, 6)\n",
      "(123464, 6)\n",
      "(288080, 2)\n",
      "(123464, 2)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "x_train,x_test,y_train,y_test=train_test_split(x,y,test_size=0.3,random_state=1)\n",
    "print(x_train.shape)\n",
    "print(x_test.shape)\n",
    "print(y_train.shape)\n",
    "print(y_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(288080, 6)\n",
      "(123464, 6)\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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "x.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LinearRegression\n",
    "lr=LinearRegression()\n",
    "lr.fit(x_train,y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred_test=lr.predict(x_test)\n",
    "y_pred_test\n",
    "y_pred_train=lr.predict(x_train)\n",
    "y_pred_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "predicted_output_=np.concatenate((y_pred_train,y_pred_test),axis=0)\n",
    "predicted_output_final=[]\n",
    "for i in range(len(dataframe)):\n",
    "    if(predicted_output_[i][0]>predicted_output_[i][1]):\n",
    "        predicted_output_final.append(1)\n",
    "    else:\n",
    "        predicted_output_final.append(0)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe['predicted_output_final']=predicted_output_final\n",
    "dataframe['predicted_output_final'].value_counts(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "#CODE TO FIND ACTUAL OUTPUT\n",
    "\n",
    "from scipy.spatial.distance import euclidean\n",
    "distance=[]\n",
    "euclidean_distance_value=[]\n",
    "\n",
    "\n",
    "for i in range(0, len(dataframe)):\n",
    "    # Get the Euclidean distance between the first row and the current row\n",
    "    distance_i = euclidean(x.iloc[0, :-1], x.iloc[i, :-1])\n",
    "    \n",
    "        \n",
    "    # Add the Euclidean distance to the list of Euclidean distances\n",
    "    euclidean_distance_value.append(np.sqrt(distance_i))\n",
    "\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "euclidean_distance_value=np.ceil(euclidean_distance_value)\n",
    "print(euclidean_distance_value)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "Actual_value1=[]\n",
    "for i in range(len(dataframe)):\n",
    "    if(euclidean_distance_value[i] <np.average(euclidean_distance_value)):   \n",
    "        Actual_value1.append(1)\n",
    "    else:\n",
    "        Actual_value1.append(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe['Actual_value1']=Actual_value1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe['Actual_value1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1    408901\n",
      "0      2643\n",
      "Name: predicted_output_final, dtype: int64\n",
      "count of women (D) in the predicted output is  2643\n",
      "count of men (ND) in the predicted output is  408901\n"
     ]
    }
   ],
   "source": [
    "#count of actual outcome for discriminating and non-discriminating class\n",
    "value_counts = dataframe['predicted_output_final'].value_counts()\n",
    "print(value_counts)\n",
    "count_AD=value_counts[0]\n",
    "count_AND=value_counts[1]\n",
    "print(\"count of women (D) in the predicted output is \",count_AD)\n",
    "print(\"count of men (ND) in the predicted output is \",count_AND)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1    314606\n",
      "0     96938\n",
      "Name: Actual_value1, dtype: int64\n",
      "count of women (D) in the ACTUAL output is  96938\n",
      "count of men (ND) in the ACTUAL output is  314606\n"
     ]
    }
   ],
   "source": [
    "#count of expected outcome for discriminating and non-discriminating class\n",
    "value_countsP = dataframe['Actual_value1'].value_counts()\n",
    "print(value_countsP)\n",
    "count_ED=value_countsP[0]\n",
    "count_END=value_countsP[1]\n",
    "print(\"count of women (D) in the ACTUAL output is \",count_ED)\n",
    "print(\"count of men (ND) in the ACTUAL output is \",count_END)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias for women -0.9689966293982243\n"
     ]
    }
   ],
   "source": [
    "print(\"degree of bias for women\",(count_AD-count_ED)/(dataframe['Women']>dataframe['Men']).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "degree of bias for men 0.4083873258956413\n"
     ]
    }
   ],
   "source": [
    "print(\"degree of bias for men\",(count_AND-count_END)/(dataframe['Men']>dataframe['Women']).sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "count_both_same=0\n",
    "count_both_diff=0\n",
    "for i in range(len(dataframe)):\n",
    "    if((dataframe.predicted_output_final.iloc[i]==dataframe.Actual_value1.iloc[i])):\n",
    "        flag=1\n",
    "        count_both_same=count_both_same+1\n",
    "    else:\n",
    "        flag=0\n",
    "        count_both_diff=count_both_diff+1\n",
    "\n",
    "if(flag==1):\n",
    "    print(\"one-one mapping exists\")\n",
    "else:\n",
    "    print(\"one-one mapping does not exist\")\n",
    "\n",
    "        \n",
    "        \n",
    "print(count_both_same)\n",
    "print(count_both_diff)\n",
    "    \n",
    "    \n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "one-one mapping doesnot exiats\n"
     ]
    }
   ],
   "source": [
    "\n",
    "if np.logical_and(dataframe.predicted_output_final.all(), dataframe.Actual_value1.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 exiats\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.7612527457574403\n"
     ]
    }
   ],
   "source": [
    "\n",
    "Accuracy=count_both_same/len (dataframe)\n",
    "print(\"new model accuracy is\",Accuracy)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7612527457574403\n"
     ]
    }
   ],
   "source": [
    "#original formula for accuracy\n",
    "from sklearn.metrics import accuracy_score\n",
    "print(accuracy_score(dataframe.predicted_output_final,dataframe.Actual_value1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "new model accuracy is 0.7612527457574403\n",
      "         50 function calls (48 primitive calls) in 0.001 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.001    0.001 2313406709.py:3(my_method)\n",
      "        1    0.000    0.000    0.001    0.001 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.000    0.000 frame.py:1498(__len__)\n",
      "        1    0.000    0.000    0.001    0.001 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.001    0.000 iostream.py:465(_schedule_flush)\n",
      "        4    0.000    0.000    0.001    0.000 iostream.py:535(write)\n",
      "        1    0.000    0.000    0.000    0.000 iostream.py:90(_event_pipe)\n",
      "        1    0.000    0.000    0.000    0.000 range.py:946(__len__)\n",
      "        1    0.001    0.001    0.001    0.001 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.exec}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "      7/5    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        1    0.000    0.000    0.001    0.001 {built-in method builtins.print}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        4    0.000    0.000    0.000    0.000 {method '__exit__' of '_thread.RLock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'acquire' of '_thread.lock' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'append' of 'collections.deque' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'write' of '_io.StringIO' objects}\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    Accuracy=count_both_same/len (dataframe)\n",
    "    print(\"new model accuracy is\",Accuracy)\n",
    "    pass\n",
    "cProfile.run('my_method()')\n",
    " \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7612527457574403\n",
      "         918 function calls (910 primitive calls) in 0.048 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.048    0.048 3587065122.py:3(my_method)\n",
      "        1    0.000    0.000    0.001    0.001 <__array_function__ internals>:177(average)\n",
      "        1    0.000    0.000    0.003    0.003 <__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.023    0.023 <__array_function__ internals>:177(union1d)\n",
      "        5    0.000    0.000    0.039    0.008 <__array_function__ internals>:177(unique)\n",
      "       13    0.000    0.000    0.000    0.000 <frozen abc>:117(__instancecheck__)\n",
      "        4    0.000    0.000    0.000    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen importlib._bootstrap>:1209(_handle_fromlist)\n",
      "        1    0.000    0.000    0.048    0.048 <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.019    0.010 _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.001    0.001 _classification.py:137(_weighted_sum)\n",
      "        1    0.001    0.001    0.047    0.047 _classification.py:146(accuracy_score)\n",
      "        1    0.000    0.000    0.044    0.044 _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.001    0.001 _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.047    0.047 _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.001    0.000    0.039    0.008 arraysetops.py:138(unique)\n",
      "        5    0.003    0.001    0.038    0.008 arraysetops.py:323(_unique1d)\n",
      "        1    0.000    0.000    0.000    0.000 arraysetops.py:894(_union1d_dispatcher)\n",
      "        1    0.001    0.001    0.023    0.023 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.001    0.001 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.020    0.010 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.000    0.000 numeric.py:1878(isscalar)\n",
      "        4    0.000    0.000    0.000    0.000 range.py:353(dtype)\n",
      "        2    0.000    0.000    0.000    0.000 range.py:378(inferred_type)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        1    0.000    0.000    0.000    0.000 threading.py:568(is_set)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:1152(column_or_1d)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:257(_is_arraylike)\n",
      "        3    0.000    0.000    0.000    0.000 validation.py:262(_is_arraylike_not_scalar)\n",
      "        4    0.000    0.000    0.000    0.000 validation.py:320(_num_samples)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:383(check_consistent_length)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:394(<listcomp>)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:571(_ensure_no_complex_data)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:581(_check_estimator_name)\n",
      "        2    0.000    0.000    0.000    0.000 validation.py:590(_pandas_dtype_needs_early_conversion)\n",
      "        2    0.000    0.000    0.001    0.000 validation.py:629(check_array)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:165(simplefilter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:181(_add_filter)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:440(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:466(__enter__)\n",
      "        6    0.000    0.000    0.000    0.000 warnings.py:487(__exit__)\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method _abc._abc_instancecheck}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method _warnings._filters_mutated}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.any}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method builtins.callable}\n",
      "        1    0.000    0.000    0.048    0.048 {built-in method builtins.exec}\n",
      "       25    0.000    0.000    0.000    0.000 {built-in method builtins.getattr}\n",
      "       65    0.000    0.000    0.000    0.000 {built-in method builtins.hasattr}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.hash}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "      119    0.000    0.000    0.000    0.000 {built-in method builtins.isinstance}\n",
      "        7    0.000    0.000    0.000    0.000 {built-in method builtins.issubclass}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.iter}\n",
      "       17    0.000    0.000    0.000    0.000 {built-in method builtins.len}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.min}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method builtins.next}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "       13    0.000    0.000    0.000    0.000 {built-in method numpy.asanyarray}\n",
      "    18/12    0.000    0.000    0.000    0.000 {built-in method numpy.asarray}\n",
      "     10/8    0.003    0.000    0.043    0.005 {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.005    0.001    0.005    0.001 {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.001    0.001 {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.001    0.001    0.001    0.001 {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.030    0.006    0.030    0.006 {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",
    "\tprint(accuracy_score(dataframe.predicted_output_final,dataframe.Actual_value1))\n",
    "\tpass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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YSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkMS3rDpQGIQQAQK1Wl3FPiMpGclJiWXeBqMwkJycB+CcL8lIhQjEhIQEA4OFes4x7QkREZSUhIQEqlSrPMgpRkOh8wWm1WkRGRsLOzg4KhaKsu1PhqNVquLm5ISwsDPb29mXdHaJSx9+BsiWEQEJCAqpXrw6lMu+rhhXiSFGpVKJGjRpl3Y0Kz97enn8QqELj70DZye8IMRsH2hAREUkYikRERBKGIpU4CwsLzJkzBxYWFmXdFaIywd+BF0eFGGhDRERUEDxSJCIikjAUiYiIJAxFIiIiCUOR6D+sU6dOUCgUmDt3rt46Dw8PKBQKbNy4sVT7tHHjRigUCnh4eJRqu0SlgaFI5drcuXOhUCj0viwtLVGjRg3069cPO3fuLNCciOVdaGgo5s6dazCAiSqKCjGjDREAuLi4yK/j4+MRERGBiIgI7N+/Hxs3bsSePXteqCHzderUgaWlZYFn6shPaGgo5s2bBwB5BqNKpUKDBg3g6upaLO0S/ZfwSJEqjKioKPkrKSkJt27dQrdu3QAAhw8fxqefflrGPSyc48ePIygoCAMHDizVdgcOHIigoCAcP368VNslKg0MRaqQlEolGjdujH379qFu3boAgNWrVyMzM7OMe0ZEZYmhSBWapaUlhgwZAiDrsTJBQUEIDQ2Vrz2GhoYiODgYEyZMQK1atWBhYaE3wESr1WLLli3o3bs3XFxcYG5ujsqVK6N79+7Ytm1bntcrNRoNvv/+e7Ro0QI2NjZwcnJCp06dsGvXrnz7XpCBNpcuXYKfnx/q1q0La2tr2Nvbo1GjRhg3bhyOHDmis63OnTvL3//7Guwbb7whryvIQJvg4GBMnDgR9erVg5WVFezt7dGiRQvMnz8/1+eanjp1Sm4PAB48eIBx48bBzc0NFhYWqFGjBt566y1ERETk2m5QUBAmTJiA+vXrw9raGpaWlnBzc0Pbtm3x8ccfIygoKNe6RAAAQVSOzZkzRwAQef2or1y5Ui5z7tw5ERISIn+/ZcsWYWtrKwAIa2trYWNjI9zd3eW6MTEx4pVXXpHLAxAqlUrn+379+om0tDS9dlNTU0WPHj3kckqlUjg4OAiFQiEAiA8//FB07NhRABBz5szRq+/u7i4AiA0bNuity8zMFFOnTtXph42NjXB0dJS3r1Kp5PKtWrUSjo6OclkXFxedr6lTp8plN2zYIADovA857dixQ1hYWMjbsrOz0/nezc1N3LlzR6/eyZMn5TInTpyQ33c7Ozthamoqr6tevboIDw/Xq//HH3/otGNmZiYcHBx03gND7yNRTgxFKtcKEoqzZs2SywQGBuqEoq2trfDx8RGXL1+Wy9+9e1cIkRU82aHl7e0t9u/fL5KSkoQQQiQmJopNmzaJKlWqCABi+vTpeu2+9957AoBQKBRi4cKFIj4+XgghRHR0tJg4caJOwBY2FD/44AN5H8aNGyf3WQgh4uLixN69e8WwYcN06uQMpbzkFYpXr14VZmZmAoBo3769uHnzphBCCI1GI/bt2yeqVasmAIg6deqIhISEXNt3dHQU/fr1E4GBgUIIIdLS0sSOHTuEnZ2dACBef/11vbbr1KkjAIju3buLgIAAeXlKSoq4deuWmDdvnsH3iignhiKVa/mFYnx8vKhevboAIJycnIRGo9EJRXd3d70/3tk2b94sAAhPT08RFxdnsMyVK1eEQqEQ5ubmIjo6Wl4eEREhH/189tlnBuuOGDEizyOc3ELx7t27QqlUCgDigw8+MLhtQ4ojFHv27CkAiLp168ofEHK6du2avN+LFy/Otf3OnTsLjUajV3/58uUCgLCyshIZGRny8ujoaLluZGRkAfeYSB+vKVKFFBcXh+PHj6NLly6IjIwEAEybNk3vqdyTJ0+Gra2twW2sW7cOADBx4sRcb4to2bIlGjdujPT0dJw8eVJevmvXLmRmZsLKygrvv/++wbrG3i+4adMmaLVaODs7y7dYlIa4uDj5OuWsWbNgbW2tV6Z58+YYNGgQAGDbtm25buvjjz82+IT0/v37AwBSUlJw//59ebmdnZ1c/vHjx8bvBFV4DEWqMHIOHHF0dISvry+uXr0KABg9ejQ++eQTvTrt27c3uC2NRoOLFy8CyAqvqlWr5vp19+5dAMDDhw/l+leuXAEAtGrVKtcnsdevX9+oewHPnz8PAOjWrRssLS0LXd9Y165dkwcV+fr65lou+zaYmzdvIiMjw2AZHx8fg8urV68uv46NjZVfW1lZoWvXrgCAnj174vPPP8elS5eQnp5euJ2gCo8371OFkfPmfQsLC1SqVAnNmzfHqFGjdEZe5lSlShWDy2NjY5GWlgYAeP78eYHaT05Oll8/efIEAPINvRo1auQ52tKQqKgoAIC7u3uh6hVV9j4Bee9XjRo1AACZmZmIjY3V+X/JZmdnZ7Cuqek/f7L+Hahr165Fv379cOPGDSxYsAALFiyAubk5Wrdujf79+2P8+PFwcnIq1D5RxcNQpAojOywKw8TExOByjUYjvz58+DB69uxpdL+KW/YtDRVNzZo1ce3aNRw9ehSHDh3CuXPncOPGDZw7dw7nzp3DokWLsGvXLnTp0qWsu0r/YTx9SmQEZ2dn+agl52nRgso+As3vKLCwR4kAULVqVaP7VRQ5j6rDw8NzLZe9ztTUtNiP3JRKJXr06IFly5bhypUriI2NxZYtW1CzZk08f/4cI0eO5ClVyhNDkcgIZmZmaNOmDQBg//79ha7fqlUrAFnXFhMTEw2WuX//fp7hkpuXXnoJAHD06FGkpqYWuF7OgS3CiAnSW7RoIW8jryngjh07BgDw8vKCmZlZodspDDs7O4wcOVIeFBUdHY2AgIASbZNebAxFIiNNmDABAHDo0CEcOnQoz7I5B4UAwODBg2FiYoKUlBQsWbLEYJ358+cb1a833ngDJiYmiImJwZw5cwpcL+eAn7i4uEK36+DggB49egAAFi9erHMNNduNGzfw66+/AgBGjBhR6DZyk9/Rn5WVlfza0KhWomz86SAy0ujRo+Hr6wshBAYOHIiFCxfKt3cAQFJSEk6ePIlJkyahdu3aOnVdXV0xadIkAMCCBQuwaNEiJCQkAACePn2KyZMn4+effzbqCRh169bFrFmzAABff/013nzzTZ3bF9RqNXbs2KE3kXj9+vVhbm4OIGvQijFHiwsXLoSZmRkePHiAHj16yEdlWq0Whw4dQu/evZGZmYk6derg7bffLvT2c3P+/Hk0a9YM3333HQIDA6HVagFkHfGeP38eEydOBJA1yKdZs2bF1i6VQ2V6lyRRCSvIjDb/lvPm/ZCQkDzLxsfHiz59+uhMJWZvb68zXRsAYWpqqlc3JSVF+Pr6ymVMTEx0pmEr6jRvkyZN0umXra1trtO8ZRs/frxc3traWtSsWVO4u7uLmTNnymXym+Zt+/btwtzcXOf9sLS0LNQ0b3nJLnPy5EmDdSFN8ebs7KwzPZy9vb04ffp0ntsm4pEiURHY29tj//79OHToEIYNG4aaNWsiLS0NycnJcHV1Rffu3bFo0SL5XsWcLC0tcfjwYSxbtgze3t4wNzeHEAIdOnTAzp078eWXXxrdLxMTE6xYsQJnz57FqFGjULNmTWRkZEAIgUaNGmH8+PHyacycVq5ciblz56Jp06YAgEePHuHhw4d49uxZgdseNmwYbt++jbfffht16tRBWloaTE1N4e3tjXnz5uHWrVto2LCh0ftmSOvWrbFz505MnDgRLVu2RKVKlaBWq2FpaQlvb2988MEHCAwMRIcOHYq1XSp/FELwkeNEREQArykSERHJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpERESS/wdq33G3HVXDrQAAAABJRU5ErkJggg==",
      "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=dataframe.Actual_value1, y_pred=dataframe.predicted_output_final)\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": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "TP=0\n",
    "FN=0\n",
    "TN=0\n",
    "FP=0\n",
    "for i in range(len(dataframe)):\n",
    "    if((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==1)):\n",
    "        TP=TP+1\n",
    "    if((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==0)):\n",
    "        TN=TN+1\n",
    "    if((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==0)):\n",
    "        FN=FN+1\n",
    "    if((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==1)):\n",
    "        FP=FP+1\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "75522\n",
      "20753\n"
     ]
    }
   ],
   "source": [
    "FP_women_count=0\n",
    "FP_men_count=0\n",
    "for i in range(len(dataframe)):\n",
    "    if((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==1)):\n",
    "        if(dataframe.Men.iloc[i] >=dataframe.Women.iloc[i]):\n",
    "            FP_men_count=FP_men_count+1\n",
    "    if((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==1)):\n",
    "        if(dataframe.Men.iloc[i] <dataframe.Women.iloc[i]):\n",
    "            FP_women_count=FP_women_count+1\n",
    "print(FP_men_count)\n",
    "print(FP_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1500\n",
      "480\n"
     ]
    }
   ],
   "source": [
    "FN_women_count=0\n",
    "FN_men_count=0\n",
    "for i in range(len(dataframe)):\n",
    "    if((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==0)):\n",
    "        if(dataframe.Men.iloc[i] >=dataframe.Women.iloc[i]):\n",
    "            FN_men_count=FN_men_count+1\n",
    "    if((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==0)):\n",
    "        if(dataframe.Men.iloc[i] <dataframe.Women.iloc[i]):\n",
    "            FN_women_count=FN_women_count+1\n",
    "print(FN_men_count)\n",
    "print(FN_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "237210\n",
      "76079\n"
     ]
    }
   ],
   "source": [
    "tp_women_count=0\n",
    "tp_men_count=0\n",
    "for i in range(len(dataframe)):\n",
    "    if(((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==1))or ((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==0))):\n",
    "        if(dataframe.Men.iloc[i] >=dataframe.Women.iloc[i]):\n",
    "            tp_men_count=tp_men_count+1\n",
    "    if(((dataframe.Actual_value1.iloc[i]==1) and (dataframe.predicted_output_final.iloc[i]==1))or ((dataframe.Actual_value1.iloc[i]==0) and (dataframe.predicted_output_final.iloc[i]==0))):\n",
    "        if(dataframe.Men.iloc[i] <dataframe.Women.iloc[i]):\n",
    "            tp_women_count=tp_women_count+1\n",
    "print(tp_men_count)\n",
    "print(tp_women_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x500 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 = dataframe.predicted_output_final\n",
    "list2 = dataframe.Actual_value1\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",
    "\n",
    "# Create a Venn diagram to visualize the overlap between the two sets\n",
    "fig, ax = plt.subplots(figsize=(8,5))\n",
    "venn = venn2([set1,set2],ax=ax )\n",
    " #Set the colors of the diagram\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 & E=0\\n' + str(FP))\n",
    "venn.get_label_by_id('01').set_text('P=0 & E=1\\n' + str(FN))\n",
    "venn.get_label_by_id('11').set_text('E & P\\n' + str(TP+TN))\n",
    "\n",
    "\n",
    "# Show the Venn diagram\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib_venn import venn2, venn2_circles\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.transforms as transforms\n",
    "\n",
    "# Define two sets of binary data\n",
    "list1 = dataframe.predicted_output_final\n",
    "list2 = dataframe.Actual_value1\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=(10, 6))\n",
    "\n",
    "# Outer Venn diagram\n",
    "venn = venn2([set1, set2], ax=ax)\n",
    "for patch in venn.patches:\n",
    "    patch.set_edgecolor('black')\n",
    "    patch.set_linewidth(2) \n",
    "venn.get_patch_by_id('10').set_facecolor('white')\n",
    "venn.get_patch_by_id('01').set_facecolor('white')\n",
    "venn.get_patch_by_id('11').set_facecolor('grey')\n",
    "\n",
    "# Add labels to the outer diagram\n",
    "venn.get_label_by_id('10').set_text('FP\\n' + str(FP))\n",
    "venn.get_label_by_id('01').set_text('FN\\n' + str(FN))\n",
    "venn.get_label_by_id('11').set_text('TP+TN\\n' + str(TP + TN))\n",
    "fp_center_x, fp_center_y = venn.set_labels[0].get_position()\n",
    "ax.add_patch(plt.Circle((fp_center_x - 0.3, fp_center_y + 0.8), radius=0.1, color='gray', alpha=0.6))\n",
    "ax.text(fp_center_x - 0.3, fp_center_y + 0.8, 'Women: ' + str(FP_women_count), fontsize=12, color='black')\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x - 0.2, fn_center_y + 0.1), radius=0.1, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x - 0.58, fn_center_y + 0.08, 'Men: ' + str(FP_men_count), fontsize=12, color='black')\n",
    "\n",
    "# Draw circles for old and young in FN zone\n",
    "fn_center_x, fn_center_y = venn.set_labels[1].get_position()\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.6), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.6, 'Women: ' + str(FN_women_count), fontsize=12, color='black')\n",
    "ax.add_patch(plt.Circle((fn_center_x + 0.27, fn_center_y + 0.3), radius=0.05, color='gray', alpha=0.6))\n",
    "ax.text(fn_center_x + 0.27, fn_center_y + 0.3, 'Men: ' + str(FN_men_count), fontsize=12, color='black')\n",
    "\n",
    "#plt.title(\"Venn diagram with subsets of OLD and YOUNG in FP and FN zones\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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YSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkMS3rDpQGIQQAQK1Wl3FPiMpGclJiWXeBqMwkJycB+CcL8lIhQjEhIQEA4OFes4x7QkREZSUhIQEqlSrPMgpRkOh8wWm1WkRGRsLOzg4KhaKsu1PhqNVquLm5ISwsDPb29mXdHaJSx9+BsiWEQEJCAqpXrw6lMu+rhhXiSFGpVKJGjRpl3Y0Kz97enn8QqELj70DZye8IMRsH2hAREUkYikRERBKGIpU4CwsLzJkzBxYWFmXdFaIywd+BF0eFGGhDRERUEDxSJCIikjAUiYiIJAxFIiIiCUOR6D+sU6dOUCgUmDt3rt46Dw8PKBQKbNy4sVT7tHHjRigUCnh4eJRqu0SlgaFI5drcuXOhUCj0viwtLVGjRg3069cPO3fuLNCciOVdaGgo5s6dazCAiSqKCjGjDREAuLi4yK/j4+MRERGBiIgI7N+/Hxs3bsSePXteqCHzderUgaWlZYFn6shPaGgo5s2bBwB5BqNKpUKDBg3g6upaLO0S/ZfwSJEqjKioKPkrKSkJt27dQrdu3QAAhw8fxqefflrGPSyc48ePIygoCAMHDizVdgcOHIigoCAcP368VNslKg0MRaqQlEolGjdujH379qFu3boAgNWrVyMzM7OMe0ZEZYmhSBWapaUlhgwZAiDr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Ek6ePIlJkyahdu3aOnVdXV0xadIkAMCCBQuwaNEiJCQkAACePn2KyZMn4+effzbqCRh169bFrFmzAABff/013nzzTZ3bF9RqNXbs2KE3kXj9+vVhbm4OIGvQijFHiwsXLoSZmRkePHiAHj16yEdlWq0Whw4dQu/evZGZmYk6derg7bffLvT2c3P+/Hk0a9YM3333HQIDA6HVagFkHfGeP38eEydOBJA1yKdZs2bF1i6VQ2V6lyRRCSvIjDb/lvPm/ZCQkDzLxsfHiz59+uhMJWZvb68zXRsAYWpqqlc3JSVF+Pr6ymVMTEx0pmEr6jRvkyZN0umXra1trtO8ZRs/frxc3traWtSsWVO4u7uLmTNnymXym+Zt+/btwtzcXOf9sLS0LNQ0b3nJLnPy5EmDdSFN8ebs7KwzPZy9vb04ffp0ntsm4pEiURHY29tj//79OHToEIYNG4aaNWsiLS0NycnJcHV1Rffu3bFo0SL5XsWcLC0tcfjwYSxbtgze3t4wNzeHEAIdOnTAzp078eWXXxrdLxMTE6xYsQJnz57FqFGjULNmTWRkZEAIgUaNGmH8+PHyacycVq5ciblz56Jp06YAgEePHuHhw4d49uxZgdseNmwYbt++jbfffht16tRBWloaTE1N4e3tjXnz5uHWrVto2LCh0ftmSOvWrbFz505MnDgRLVu2RKVKlaBWq2FpaQlvb2988MEHCAwMRIcOHYq1XSp/FELwkeNEREQArykSERHJGIpEREQShiIREZGEoUhERCRhKBIREUkYikRERBKGIhERkYShSEREJGEoEhERSRiKREREEoYiERGRhKFIREQkYSgSERFJGIpERESS/wdq33G3HVXDrQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         271632 function calls (265439 primitive calls) in 0.661 seconds\n",
      "\n",
      "   Ordered by: standard name\n",
      "\n",
      "   ncalls  tottime  percall  cumtime  percall filename:lineno(function)\n",
      "        1    0.000    0.000    0.661    0.661 311736131.py:3(my_method)\n",
      "      184    0.000    0.000    0.004    0.000 <__array_function__ internals>:177(all)\n",
      "      710    0.001    0.000    0.009    0.000 <__array_function__ internals>:177(amax)\n",
      "      714    0.001    0.000    0.011    0.000 <__array_function__ internals>:177(amin)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(any)\n",
      "      840    0.001    0.000    0.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",
      "        6    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(clip)\n",
      "       24    0.000    0.000    0.001    0.000 <__array_function__ internals>:177(column_stack)\n",
      "       48    0.000    0.000    0.003    0.000 <__array_function__ internals>:177(concatenate)\n",
      "        7    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",
      "       20    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",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(linspace)\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",
      "       24    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",
      "       88    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",
      "        4    0.000    0.000    0.000    0.000 <__array_function__ internals>:177(searchsorted)\n",
      "        1    0.000    0.000    0.023    0.023 <__array_function__ internals>:177(union1d)\n",
      "       15    0.000    0.000    0.076    0.005 <__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",
      "        5    0.000    0.000    0.000    0.000 <frozen _collections_abc>:283(__subclasshook__)\n",
      "       36    0.000    0.000    0.000    0.000 <frozen _collections_abc>:315(__subclasshook__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen _collections_abc>:362(__subclasshook__)\n",
      "        3    0.000    0.000    0.000    0.000 <frozen _collections_abc>:381(__subclasshook__)\n",
      "       49    0.000    0.000    0.000    0.000 <frozen _collections_abc>:409(__subclasshook__)\n",
      "        8    0.000    0.000    0.000    0.000 <frozen _collections_abc>:778(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 <frozen _collections_abc>:78(_check_methods)\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",
      "     3636    0.002    0.000    0.005    0.000 <frozen abc>:117(__instancecheck__)\n",
      "   180/87    0.000    0.000    0.001    0.000 <frozen abc>:121(__subclasscheck__)\n",
      "        1    0.000    0.000    0.000    0.000 <frozen genericpath>:121(_splitext)\n",
      "        2    0.000    0.000    0.001    0.000 <frozen genericpath>:27(isfile)\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.661    0.661 <string>:1(<module>)\n",
      "        1    0.000    0.000    0.017    0.017 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.016    0.016 ImageFile.py:499(_save)\n",
      "        1    0.000    0.000    0.016    0.016 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.002    0.000    0.003    0.000 __init__.py:101(check_in_list)\n",
      "       13    0.000    0.000    0.000    0.000 __init__.py:106(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:109(__call__)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:112(__eq__)\n",
      "       27    0.000    0.000    0.000    0.000 __init__.py:115(__hash__)\n",
      "       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",
      "       70    0.001    0.000    0.001    0.000 __init__.py:134(check_shape)\n",
      "        1    0.000    0.000    0.003    0.003 __init__.py:1456(inner)\n",
      "     1626    0.001    0.000    0.002    0.000 __init__.py:1467(debug)\n",
      "      210    0.000    0.000    0.000    0.000 __init__.py:154(<genexpr>)\n",
      "       22    0.000    0.000    0.000    0.000 __init__.py:1623(<lambda>)\n",
      "      344    0.001    0.000    0.002    0.000 __init__.py:163(match)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:1675(_safe_first_finite)\n",
      "        6    0.000    0.000    0.000    0.000 __init__.py:1685(safe_isfinite)\n",
      "       12    0.000    0.000    0.000    0.000 __init__.py:1715(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:1718(sanitize_sequence)\n",
      "      278    0.003    0.000    0.005    0.000 __init__.py:1726(normalize_kwargs)\n",
      "     1626    0.001    0.000    0.001    0.000 __init__.py:1734(isEnabledFor)\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",
      "     1780    0.001    0.000    0.002    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.006    0.000 __init__.py:1994(_setattr_cm)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2039(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 __init__.py:2051(add)\n",
      "       16    0.000    0.000    0.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.002    0.000    0.003    0.000 __init__.py:291(process)\n",
      "        4    0.000    0.000    0.000    0.000 __init__.py:313(blocked)\n",
      "       14    0.000    0.000    0.000    0.000 __init__.py:318(wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 __init__.py:53(__get__)\n",
      "       14    0.000    0.000    0.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",
      "     4394    0.004    0.000    0.006    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",
      "     4394    0.005    0.000    0.011    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.003    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.055    0.009 _array_api.py:83(unique_values)\n",
      "       15    0.000    0.000    0.000    0.000 _array_api.py:90(get_namespace)\n",
      "        1    0.000    0.000    0.001    0.001 _axes.py:104(set_title)\n",
      "        1    0.000    0.000    0.003    0.003 _axes.py:5459(imshow)\n",
      "        4    0.000    0.000    0.003    0.001 _axes.py:626(text)\n",
      "        1    0.000    0.000    0.006    0.006 _axes.py:7937(matshow)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1025(get_yaxis_text1_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:105(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:1051(get_yaxis_text2_transform)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1077(_update_transScale)\n",
      "      6/5    0.000    0.000    0.001    0.000 _base.py:1082(get_position)\n",
      "        6    0.000    0.000    0.001    0.000 _base.py:1134(_set_position)\n",
      "        2    0.000    0.000    0.000    0.000 _base.py:1162(set_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1173(get_axes_locator)\n",
      "        8    0.000    0.000    0.000    0.000 _base.py:1179(_set_artist_props)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:1189(_gen_axes_patch)\n",
      "        6    0.000    0.000    0.000    0.000 _base.py:119(get_shape)\n",
      "        1    0.000    0.000    0.002    0.002 _base.py:1206(_gen_axes_spines)\n",
      "        1    0.000    0.000    0.002    0.002 _base.py:1221(<dictcomp>)\n",
      "        1    0.000    0.000    0.036    0.036 _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.037    0.037 _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.229    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.289    0.144 _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.014    0.007 _base.py:3157(grid)\n",
      "        2    0.000    0.000    0.002    0.001 _base.py:3316(tick_params)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3405(set_axis_on)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3423(set_xlabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3488(get_xbound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3536(get_xlim)\n",
      "       12    0.000    0.000    0.000    0.000 _base.py:3558(_validate_converted_limits)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3575(set_xlim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3672(set_ylabel)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3737(get_ybound)\n",
      "        5    0.000    0.000    0.000    0.000 _base.py:3785(get_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3807(set_ylim)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3971(set_navigate)\n",
      "        1    0.000    0.000    0.000    0.000 _base.py:3987(set_navigate_mode)\n",
      "        7    0.000    0.000    0.001    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.163    0.081 _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.059    0.059 _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.017    0.017 _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.001    0.000    0.001    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.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.002    0.002    0.091    0.091 _classification.py:232(confusion_matrix)\n",
      "        1    0.000    0.000    0.044    0.044 _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.004    0.004 _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.001    0.001 _coo.py:266(_check)\n",
      "        1    0.000    0.000    0.001    0.001 _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",
      "       12    0.000    0.000    0.000    0.000 _methods.py:103(_clip_dep_is_byte_swapped)\n",
      "        6    0.001    0.000    0.001    0.000 _methods.py:108(_clip_dep_invoke_with_casting)\n",
      "        6    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.007    0.000 _methods.py:43(_amin)\n",
      "      168    0.000    0.000    0.002    0.000 _methods.py:47(_sum)\n",
      "       93    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",
      "       12    0.000    0.000    0.000    0.000 _methods.py:93(_clip_dep_is_scalar_nan)\n",
      "        3    0.000    0.000    0.000    0.000 _pylab_helpers.py:100(get_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:105(_set_new_active_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:118(set_active)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:33(get_fig_manager)\n",
      "        1    0.000    0.000    0.000    0.000 _pylab_helpers.py:77(destroy_all)\n",
      "        2    0.000    0.000    0.000    0.000 _pylab_helpers.py:90(get_all_fig_managers)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:109(getdtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:135(getdata)\n",
      "        2    0.000    0.000    0.000    0.000 _sputils.py:147(get_index_dtype)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:216(isintlike)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:238(isshape)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:295(check_shape)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:308(<genexpr>)\n",
      "        3    0.000    0.000    0.000    0.000 _sputils.py:313(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 _sputils.py:93(to_native)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:28(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 _tight_bbox.py:34(<lambda>)\n",
      "        1    0.000    0.000    0.000    0.000 _tight_bbox.py:36(restore_bbox)\n",
      "        1    0.000    0.000    0.002    0.002 _tight_bbox.py:8(adjust_bbox)\n",
      "      174    0.001    0.000    0.001    0.000 _ufunc_config.py:132(geterr)\n",
      "      174    0.001    0.000    0.003    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.003    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.002    0.000    0.076    0.005 arraysetops.py:138(unique)\n",
      "       15    0.006    0.000    0.073    0.005 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.023    0.023 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.001    0.000 artist.py:1048(set_visible)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:1080(set_in_layout)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1093(get_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1097(set_label)\n",
      "        2    0.000    0.000    0.000    0.000 artist.py:1113(get_zorder)\n",
      "       26    0.000    0.000    0.000    0.000 artist.py:1117(set_zorder)\n",
      "       82    0.000    0.000    0.000    0.000 artist.py:1132(sticky_edges)\n",
      "       20    0.000    0.000    0.000    0.000 artist.py:1159(update_from)\n",
      "      312    0.004    0.000    0.018    0.000 artist.py:1180(_update_props)\n",
      "       34    0.000    0.000    0.002    0.000 artist.py:1205(update)\n",
      "      278    0.000    0.000    0.016    0.000 artist.py:1216(_internal_update)\n",
      "      244    0.001    0.000    0.019    0.000 artist.py:1227(set)\n",
      "       50    0.000    0.000    0.006    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.038    0.009 artist.py:1408(_get_tightbbox_for_layout_only)\n",
      "      244    0.000    0.000    0.020    0.000 artist.py:147(<lambda>)\n",
      "       82    0.001    0.000    0.002    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.009    0.000    0.016    0.000 artist.py:319(stale)\n",
      "       27    0.000    0.000    0.043    0.002 artist.py:352(get_tightbbox)\n",
      "      571    0.001    0.000    0.004    0.000 artist.py:417(pchanged)\n",
      "        8    0.000    0.000    0.000    0.000 artist.py:430(is_transform_set)\n",
      "       99    0.000    0.000    0.001    0.000 artist.py:438(set_transform)\n",
      "      286    0.001    0.000    0.001    0.000 artist.py:451(get_transform)\n",
      "    100/2    0.001    0.000    0.292    0.146 artist.py:54(draw_wrapper)\n",
      "       14    0.000    0.000    0.000    0.000 artist.py:604(get_url)\n",
      "        1    0.000    0.000    0.000    0.000 artist.py:608(set_url)\n",
      "       64    0.000    0.000    0.000    0.000 artist.py:618(get_gid)\n",
      "       12    0.000    0.000    0.000    0.000 artist.py:632(get_snap)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:671(get_sketch_params)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:730(get_path_effects)\n",
      "        5    0.000    0.000    0.000    0.000 artist.py:733(get_figure)\n",
      "       81    0.000    0.000    0.001    0.000 artist.py:737(set_figure)\n",
      "        6    0.000    0.000    0.000    0.000 artist.py:761(set_clip_box)\n",
      "       19    0.000    0.000    0.004    0.000 artist.py:778(set_clip_path)\n",
      "       24    0.000    0.000    0.000    0.000 artist.py:840(get_alpha)\n",
      "      762    0.000    0.000    0.000    0.000 artist.py:847(get_visible)\n",
      "     7600    0.002    0.000    0.002    0.000 artist.py:851(get_animated)\n",
      "       32    0.000    0.000    0.000    0.000 artist.py:855(get_in_layout)\n",
      "       30    0.000    0.000    0.000    0.000 artist.py:866(_fully_clipped_to_axes)\n",
      "       56    0.000    0.000    0.000    0.000 artist.py:890(get_clip_on)\n",
      "       47    0.000    0.000    0.000    0.000 artist.py:894(get_clip_box)\n",
      "       46    0.000    0.000    0.000    0.000 artist.py:898(get_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 artist.py:912(set_clip_on)\n",
      "       48    0.000    0.000    0.001    0.000 artist.py:929(_set_gc_clip)\n",
      "        2    0.000    0.000    0.292    0.146 artist.py:93(draw_wrapper)\n",
      "      200    0.000    0.000    0.000    0.000 artist.py:939(get_rasterized)\n",
      "      200    0.000    0.000    0.000    0.000 artist.py:966(get_agg_filter)\n",
      "       11    0.000    0.000    0.000    0.000 axis.py:1012(_translate_tick_params)\n",
      "       11    0.000    0.000    0.000    0.000 axis.py:1060(<dictcomp>)\n",
      "        2    0.000    0.000    0.008    0.004 axis.py:1077(set_clip_path)\n",
      "        4    0.000    0.000    0.001    0.000 axis.py:1157(_set_lim)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1175(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1232(_set_artist_props)\n",
      "       84    0.006    0.000    0.185    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.018    0.000 axis.py:1299(<listcomp>)\n",
      "       48    0.000    0.000    0.037    0.001 axis.py:1301(<listcomp>)\n",
      "       20    0.001    0.000    0.254    0.013 axis.py:1304(get_tightbbox)\n",
      "       40    0.000    0.000    0.003    0.000 axis.py:1329(<genexpr>)\n",
      "       20    0.000    0.000    0.001    0.000 axis.py:1348(<listcomp>)\n",
      "        4    0.000    0.000    0.059    0.015 axis.py:1363(draw)\n",
      "       84    0.001    0.000    0.026    0.000 axis.py:1477(get_majorticklocs)\n",
      "       84    0.003    0.000    0.046    0.001 axis.py:1481(get_minorticklocs)\n",
      "       10    0.000    0.000    0.029    0.003 axis.py:1539(_get_tick)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:154(<dictcomp>)\n",
      "        4    0.000    0.000    0.006    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.019    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.013    0.003 axis.py:1616(grid)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:1647(<dictcomp>)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:1658(update_units)\n",
      "        6    0.000    0.000    0.000    0.000 axis.py:1719(_have_units_and_converter)\n",
      "      118    0.000    0.000    0.001    0.000 axis.py:1725(convert_units)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:1742(set_units)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1775(set_label_text)\n",
      "       14    0.000    0.000    0.001    0.000 axis.py:1796(set_major_formatter)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1822(set_minor_formatter)\n",
      "       28    0.000    0.000    0.001    0.000 axis.py:1836(_set_formatter)\n",
      "       16    0.000    0.000    0.001    0.000 axis.py:1862(set_major_locator)\n",
      "       14    0.000    0.000    0.000    0.000 axis.py:1878(set_minor_locator)\n",
      "        2    0.000    0.000    0.000    0.000 axis.py:1894(set_pickradius)\n",
      "       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.001    0.000    0.074    0.003 axis.py:2083(_get_tick_boxes_siblings)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2091(<listcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 axis.py:2145(_get_ticks_position)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2161(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2167(<genexpr>)\n",
      "       24    0.000    0.000    0.000    0.000 axis.py:2173(<genexpr>)\n",
      "      672    0.001    0.000    0.024    0.000 axis.py:2208(getter)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:2212(setter)\n",
      "       10    0.000    0.000    0.000    0.000 axis.py:223(get_tick_padding)\n",
      "        1    0.000    0.000    0.004    0.004 axis.py:2237(__init__)\n",
      "        7    0.000    0.000    0.004    0.001 axis.py:2241(_init)\n",
      "       16    0.001    0.000    0.090    0.006 axis.py:2298(_update_label_position)\n",
      "       16    0.000    0.000    0.004    0.000 axis.py:2338(_update_offset_text_position)\n",
      "        6    0.000    0.000    0.002    0.000 axis.py:237(set_clip_path)\n",
      "        2    0.000    0.000    0.002    0.001 axis.py:2385(set_ticks_position)\n",
      "        1    0.000    0.000    0.002    0.002 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.005    0.005 axis.py:2496(__init__)\n",
      "        7    0.000    0.000    0.005    0.001 axis.py:2500(_init)\n",
      "        8    0.000    0.000    0.049    0.006 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.015    0.002 axis.py:293(draw)\n",
      "      336    0.001    0.000    0.003    0.000 axis.py:305(set_label1)\n",
      "      336    0.000    0.000    0.003    0.000 axis.py:318(set_label2)\n",
      "       50    0.000    0.000    0.000    0.000 axis.py:342(_set_artist_props)\n",
      "       23    0.001    0.000    0.005    0.000 axis.py:351(_apply_params)\n",
      "      115    0.000    0.000    0.000    0.000 axis.py:359(<genexpr>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:376(<dictcomp>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:389(<dictcomp>)\n",
      "       23    0.000    0.000    0.000    0.000 axis.py:394(<dictcomp>)\n",
      "        5    0.000    0.000    0.014    0.003 axis.py:416(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:438(_get_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:441(_get_text2_transform)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:444(_apply_tickdir)\n",
      "      221    0.002    0.000    0.010    0.000 axis.py:455(update_position)\n",
      "        5    0.000    0.000    0.015    0.003 axis.py:477(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:499(_get_text1_transform)\n",
      "        5    0.000    0.000    0.000    0.000 axis.py:502(_get_text2_transform)\n",
      "        5    0.000    0.000    0.001    0.000 axis.py:505(_apply_tickdir)\n",
      "      125    0.001    0.000    0.006    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.022    0.002 axis.py:58(__init__)\n",
      "      6/4    0.000    0.000    0.017    0.004 axis.py:583(__get__)\n",
      "        2    0.000    0.000    0.007    0.004 axis.py:643(__init__)\n",
      "       30    0.000    0.000    0.000    0.000 axis.py:693(isDefault_majloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:701(isDefault_majfmt)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:709(isDefault_minloc)\n",
      "       28    0.000    0.000    0.000    0.000 axis.py:717(isDefault_minfmt)\n",
      "       84    0.000    0.000    0.000    0.000 axis.py:727(get_remove_overlapping_locs)\n",
      "      432    0.000    0.000    0.002    0.000 axis.py:758(get_transform)\n",
      "        4    0.000    0.000    0.000    0.000 axis.py:761(get_scale)\n",
      "       14    0.000    0.000    0.012    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.017    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.007    0.001 backend_agg.py:200(draw_text)\n",
      "       24    0.000    0.000    0.067    0.003 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.063    0.002 backend_agg.py:263(_prepare_font)\n",
      "       24    0.000    0.000    0.000    0.000 backend_agg.py:273(points_to_pixels)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:277(buffer_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:286(clear)\n",
      "        4    0.000    0.000    0.000    0.000 backend_agg.py:289(option_image_nocomposite)\n",
      "        2    0.000    0.000    0.000    0.000 backend_agg.py:297(option_scale_image)\n",
      "        2    0.000    0.000    0.120    0.060 backend_agg.py:392(draw)\n",
      "        2    0.000    0.000    0.001    0.000 backend_agg.py:405(get_renderer)\n",
      "       35    0.000    0.000    0.000    0.000 backend_agg.py:43(get_hinting_flag)\n",
      "        1    0.000    0.000    0.000    0.000 backend_agg.py:435(buffer_rgba)\n",
      "        2    0.000    0.000    0.137    0.069 backend_agg.py:452(_print_pil)\n",
      "        2    0.000    0.000    0.137    0.069 backend_agg.py:462(print_png)\n",
      "        2    0.000    0.000    0.001    0.000 backend_agg.py:78(__init__)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1002(set_snap)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1017(get_hatch)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1021(get_hatch_path)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1028(get_hatch_color)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1036(get_hatch_linewidth)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:1040(get_sketch_params)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1252(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1257(_process)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1284(__init__)\n",
      "        1    0.000    0.000    0.001    0.001 backend_bases.py:1571(_get_renderer)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1581(Done)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1584(_draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1642(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1671(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 backend_bases.py:1693(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:172(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:1727(new_manager)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:1748(is_saving)\n",
      "       31    0.000    0.000    0.000    0.000 backend_bases.py:179(open_group)\n",
      "       31    0.000    0.000    0.000    0.000 backend_bases.py:186(close_group)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2053(draw)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:2174(_switch_canvas_and_return_print_method)\n",
      "        2    0.000    0.000    0.137    0.069 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.493    0.493 backend_bases.py:2237(print_figure)\n",
      "        3    0.000    0.000    0.000    0.000 backend_bases.py:2411(mpl_connect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2474(mpl_disconnect)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2809(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2840(notify_axes_change)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2846(create_with_canvas)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2921(destroy)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:2937(set_window_title)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3572(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:3577(draw_if_interactive)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:447(get_image_magnification)\n",
      "       22    0.000    0.000    0.000    0.000 backend_bases.py:661(flipy)\n",
      "       48    0.000    0.000    0.002    0.000 backend_bases.py:679(new_gc)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:735(_draw_disabled)\n",
      "        1    0.000    0.000    0.000    0.000 backend_bases.py:743(<dictcomp>)\n",
      "       86    0.000    0.000    0.000    0.000 backend_bases.py:744(<lambda>)\n",
      "       48    0.001    0.000    0.002    0.000 backend_bases.py:756(__init__)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:797(restore)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:824(get_clip_path)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:839(get_dashes)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:876(get_snap)\n",
      "       36    0.000    0.000    0.000    0.000 backend_bases.py:887(set_alpha)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:904(set_antialiased)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:909(set_capstyle)\n",
      "       10    0.000    0.000    0.000    0.000 backend_bases.py:920(set_clip_rectangle)\n",
      "       48    0.000    0.000    0.001    0.000 backend_bases.py:924(set_clip_path)\n",
      "       12    0.000    0.000    0.000    0.000 backend_bases.py:929(set_dashes)\n",
      "       82    0.000    0.000    0.000    0.000 backend_bases.py:959(set_foreground)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:979(set_joinstyle)\n",
      "       24    0.000    0.000    0.000    0.000 backend_bases.py:990(set_linewidth)\n",
      "       48    0.000    0.000    0.000    0.000 backend_bases.py:994(set_url)\n",
      "        2    0.000    0.000    0.000    0.000 backend_bases.py:998(set_gid)\n",
      "        1    0.000    0.000    0.002    0.002 backend_inline.py:21(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:231(_fetch_figure_metadata)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:255(_is_transparent)\n",
      "        1    0.000    0.000    0.000    0.000 backend_inline.py:30(new_figure_manager_given_figure)\n",
      "        1    0.000    0.000    0.497    0.497 backend_inline.py:72(show)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:2581(is_object)\n",
      "        2    0.000    0.000    0.000    0.000 base.py:2622(is_categorical)\n",
      "       10    0.000    0.000    0.000    0.000 base.py:313(shape)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5254(__contains__)\n",
      "        4    0.000    0.000    0.000    0.000 base.py:5363(_can_hold_identifiers_and_holds_name)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:382(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:405(_scale_norm)\n",
      "        2    0.000    0.000    0.009    0.005 cm.py:427(to_rgba)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:520(get_array)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:575(set_cmap)\n",
      "       26    0.000    0.000    0.000    0.000 cm.py:589(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:593(norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:622(set_norm)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:649(autoscale_None)\n",
      "        2    0.000    0.000    0.000    0.000 cm.py:660(changed)\n",
      "        1    0.000    0.000    0.000    0.000 cm.py:699(_ensure_cmap)\n",
      "        1    0.000    0.000    0.001    0.001 colors.py:1008(_init)\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.002    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.000    0.000 colors.py:1382(autoscale_None)\n",
      "       12    0.000    0.000    0.000    0.000 colors.py:203(_sanitize_extrema)\n",
      "      349    0.001    0.000    0.003    0.000 colors.py:213(_is_nth_color)\n",
      "       99    0.000    0.000    0.002    0.000 colors.py:218(is_color_like)\n",
      "       10    0.000    0.000    0.000    0.000 colors.py:231(_has_alpha_channel)\n",
      "       99    0.000    0.000    0.003    0.000 colors.py:237(_check_color_like)\n",
      "      250    0.001    0.000    0.003    0.000 colors.py:265(to_rgba)\n",
      "        4    0.000    0.000    0.001    0.000 colors.py:549(_create_lookup_table)\n",
      "        2    0.001    0.001    0.009    0.004 colors.py:683(__call__)\n",
      "        1    0.000    0.000    0.000    0.000 colors.py:839(_set_extremes)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1278(is_bool_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1433(is_extension_array_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:146(classes)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:148(<lambda>)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:1532(_is_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1556(get_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:1591(_is_dtype_type)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:162(is_object_dtype)\n",
      "        4    0.000    0.000    0.000    0.000 common.py:192(is_sparse)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:362(apply_if_callable)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:544(is_string_dtype)\n",
      "        2    0.000    0.000    0.000    0.000 common.py:573(condition)\n",
      "        3    0.000    0.000    0.000    0.000 configurable.py:521(instance)\n",
      "        1    0.000    0.000    0.000    0.000 configurable.py:565(initialized)\n",
      "      612    0.002    0.000    0.002    0.000 contextlib.py:104(__init__)\n",
      "  612/587    0.001    0.000    0.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.001    0.000    0.004    0.000 contextlib.py:287(helper)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:450(_create_exit_wrapper)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:460(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:490(enter_context)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:522(_push_cm_exit)\n",
      "        3    0.000    0.000    0.000    0.000 contextlib.py:527(_push_exit_callback)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:543(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:546(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:751(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:754(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 contextlib.py:757(__exit__)\n",
      "     1038    0.000    0.000    0.000    0.000 copy.py:107(_copy_immutable)\n",
      "   748/12    0.002    0.000    0.005    0.000 copy.py:128(deepcopy)\n",
      "      584    0.000    0.000    0.000    0.000 copy.py:182(_deepcopy_atomic)\n",
      "    48/12    0.000    0.000    0.005    0.000 copy.py:227(_deepcopy_dict)\n",
      "       12    0.000    0.000    0.001    0.000 copy.py:237(_deepcopy_method)\n",
      "      128    0.000    0.000    0.000    0.000 copy.py:243(_keep_alive)\n",
      "      481    0.002    0.000    0.006    0.000 copy.py:259(_reconstruct)\n",
      "      144    0.000    0.000    0.000    0.000 copy.py:264(<genexpr>)\n",
      "     1579    0.005    0.000    0.013    0.000 copy.py:66(copy)\n",
      "      457    0.001    0.000    0.001    0.000 copyreg.py:104(__newobj__)\n",
      "        2    0.000    0.000    0.000    0.000 copyreg.py:113(_slotnames)\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.000    0.000 core.py:5731(min)\n",
      "        3    0.000    0.000    0.000    0.000 core.py:5830(max)\n",
      "       11    0.000    0.000    0.000    0.000 core.py:587(filled)\n",
      "        8    0.000    0.000    0.001    0.000 core.py:6625(array)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:6642(is_masked)\n",
      "        2    0.000    0.000    0.000    0.000 core.py:8025(asarray)\n",
      "       12    0.000    0.000    0.000    0.000 cycler.py:165(keys)\n",
      "      110    0.000    0.000    0.000    0.000 cycler.py:239(__iter__)\n",
      "       10    0.000    0.000    0.000    0.000 cycler.py:364(by_key)\n",
      "       10    0.000    0.000    0.000    0.000 cycler.py:386(<dictcomp>)\n",
      "       12    0.000    0.000    0.001    0.000 decorator.py:199(fix)\n",
      "       12    0.000    0.000    0.495    0.041 decorator.py:229(fun)\n",
      "        1    0.000    0.000    0.000    0.000 decorators.py:45(wrapper)\n",
      "       35    0.000    0.000    0.001    0.000 deprecation.py:289(wrapper)\n",
      "      7/5    0.000    0.000    0.002    0.000 deprecation.py:379(wrapper)\n",
      "       12    0.000    0.000    0.000    0.000 deprecation.py:398(<genexpr>)\n",
      "    76/68    0.001    0.000    0.030    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.497    0.497 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.178    0.178 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.292    0.146 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.002    0.000    0.003    0.000 figure.py:54(_stale_figure_callback)\n",
      "        1    0.000    0.000    0.059    0.059 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.059    0.059 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",
      "     1622    0.002    0.000    0.005    0.000 font_manager.py:1074(_expand_aliases)\n",
      "     1622    0.008    0.000    0.016    0.000 font_manager.py:1082(score_family)\n",
      "     1622    0.001    0.000    0.001    0.000 font_manager.py:1112(score_style)\n",
      "     1622    0.001    0.000    0.001    0.000 font_manager.py:1129(score_variant)\n",
      "     1622    0.009    0.000    0.010    0.000 font_manager.py:1140(score_stretch)\n",
      "     1622    0.004    0.000    0.011    0.000 font_manager.py:1158(score_weight)\n",
      "     1622    0.001    0.000    0.001    0.000 font_manager.py:1176(score_size)\n",
      "       49    0.001    0.000    0.061    0.001 font_manager.py:1200(findfont)\n",
      "      294    0.001    0.000    0.001    0.000 font_manager.py:1256(<genexpr>)\n",
      "       35    0.000    0.000    0.061    0.002 font_manager.py:1270(_find_fonts_by_props)\n",
      "        2    0.014    0.007    0.058    0.029 font_manager.py:1360(_findfont_cached)\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.004    0.000 font_manager.py:588(__init__)\n",
      "       92    0.000    0.000    0.003    0.000 font_manager.py:608(_from_any)\n",
      "     1055    0.006    0.000    0.009    0.000 font_manager.py:631(__hash__)\n",
      "      343    0.000    0.000    0.006    0.000 font_manager.py:642(__eq__)\n",
      "     2712    0.001    0.000    0.001    0.000 font_manager.py:648(get_family)\n",
      "     2677    0.001    0.000    0.001    0.000 font_manager.py:664(get_style)\n",
      "     2677    0.001    0.000    0.001    0.000 font_manager.py:670(get_variant)\n",
      "     2677    0.001    0.000    0.001    0.000 font_manager.py:676(get_weight)\n",
      "     2677    0.001    0.000    0.001    0.000 font_manager.py:685(get_stretch)\n",
      "     2712    0.001    0.000    0.001    0.000 font_manager.py:693(get_size)\n",
      "     1057    0.000    0.000    0.000    0.000 font_manager.py:699(get_file)\n",
      "      102    0.000    0.000    0.000    0.000 font_manager.py:715(set_family)\n",
      "       67    0.000    0.000    0.001    0.000 font_manager.py:729(set_style)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:742(set_variant)\n",
      "       70    0.000    0.000    0.000    0.000 font_manager.py:755(set_weight)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:781(set_stretch)\n",
      "      111    0.001    0.000    0.001    0.000 font_manager.py:807(set_size)\n",
      "       67    0.000    0.000    0.000    0.000 font_manager.py:837(set_file)\n",
      "     1055    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.494    0.041 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.493    0.055 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.495    0.495 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",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:1341(_searchsorted_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 fromnumeric.py:1345(searchsorted)\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.005    0.000 fromnumeric.py:198(reshape)\n",
      "        6    0.000    0.000    0.000    0.000 fromnumeric.py:2107(_clip_dispatcher)\n",
      "        6    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.003    0.000 fromnumeric.py:2432(all)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2519(_cumsum_dispatcher)\n",
      "        2    0.000    0.000    0.000    0.000 fromnumeric.py:2523(cumsum)\n",
      "      168    0.000    0.000    0.000    0.000 fromnumeric.py:2600(_ptp_dispatcher)\n",
      "      168    0.001    0.000    0.003    0.000 fromnumeric.py:2604(ptp)\n",
      "      710    0.000    0.000    0.000    0.000 fromnumeric.py:2698(_amax_dispatcher)\n",
      "      710    0.001    0.000    0.007    0.000 fromnumeric.py:2703(amax)\n",
      "      714    0.000    0.000    0.000    0.000 fromnumeric.py:2824(_amin_dispatcher)\n",
      "      714    0.001    0.000    0.009    0.000 fromnumeric.py:2829(amin)\n",
      "       24    0.000    0.000    0.000    0.000 fromnumeric.py:3148(_ndim_dispatcher)\n",
      "       24    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.003    0.000 fromnumeric.py:38(_wrapit)\n",
      "     1254    0.003    0.000    0.013    0.000 fromnumeric.py:51(_wrapfunc)\n",
      "     1632    0.005    0.000    0.017    0.000 fromnumeric.py:69(_wrapreduction)\n",
      "     1632    0.002    0.000    0.002    0.000 fromnumeric.py:70(<dictcomp>)\n",
      "       20    0.000    0.000    0.000    0.000 function_base.py:1316(_diff_dispatcher)\n",
      "       20    0.001    0.000    0.001    0.000 function_base.py:1320(diff)\n",
      "        4    0.000    0.000    0.000    0.000 function_base.py:18(_linspace_dispatcher)\n",
      "        4    0.000    0.000    0.000    0.000 function_base.py:23(linspace)\n",
      "     1364    0.001    0.000    0.002    0.000 function_base.py:346(iterable)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:35(update_wrapper)\n",
      "        1    0.000    0.000    0.000    0.000 functools.py:65(wraps)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:40(_check)\n",
      "        2    0.000    0.000    0.000    0.000 generic.py:45(_instancecheck)\n",
      "       18    0.000    0.000    0.000    0.000 generic.py:5888(__getattr__)\n",
      "        4    0.000    0.000    0.000    0.000 generic.py:640(_info_axis)\n",
      "      172    0.001    0.000    0.001    0.000 getlimits.py:476(__new__)\n",
      "      172    0.002    0.000    0.002    0.000 getlimits.py:558(smallest_normal)\n",
      "      172    0.000    0.000    0.002    0.000 getlimits.py:581(tiny)\n",
      "       13    0.000    0.000    0.000    0.000 getlimits.py:668(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 getlimits.py:679(min)\n",
      "        8    0.000    0.000    0.000    0.000 getlimits.py:692(max)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:101(set_width_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:123(set_height_ratios)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:145(get_grid_positions)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:191(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:199(<listcomp>)\n",
      "        1    0.000    0.000    0.000    0.000 gridspec.py:228(__getitem__)\n",
      "        2    0.000    0.000    0.000    0.000 gridspec.py:232(_normalize)\n",
      "        1    0.000    0.000    0.059    0.059 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.289    0.144 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.017    0.017 image.py:1567(imsave)\n",
      "        4    0.000    0.000    0.016    0.004 image.py:160(_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:247(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:287(get_size)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:294(set_alpha)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:308(_get_scalar_alpha)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:321(changed)\n",
      "        2    0.002    0.001    0.033    0.016 image.py:328(_make_image)\n",
      "        2    0.000    0.000    0.037    0.019 image.py:617(draw)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:685(set_data)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:745(get_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:756(set_interpolation)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:778(set_interpolation_stage)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:802(set_resample)\n",
      "        2    0.000    0.000    0.000    0.000 image.py:816(get_resample)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:820(set_filternorm)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:833(get_filternorm)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:837(set_filterrad)\n",
      "        4    0.000    0.000    0.000    0.000 image.py:852(get_filterrad)\n",
      "        1    0.000    0.000    0.000    0.000 image.py:905(__init__)\n",
      "        2    0.000    0.000    0.033    0.016 image.py:940(make_image)\n",
      "        1    0.000    0.000    0.001    0.001 image.py:956(set_extent)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:139(iloc)\n",
      "        2    0.000    0.000    0.000    0.000 indexing.py:2656(check_deprecated_indexers)\n",
      "        2    0.000    0.000    0.000    0.000 inference.py:325(is_hashable)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:167(get_annotations)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2037(_signature_bound_method)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2331(_signature_from_function)\n",
      "      2/1    0.000    0.000    0.000    0.000 inspect.py:2426(_signature_from_callable)\n",
      "        4    0.000    0.000    0.000    0.000 inspect.py:2683(__init__)\n",
      "       74    0.000    0.000    0.000    0.000 inspect.py:2736(name)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:2740(default)\n",
      "      163    0.000    0.000    0.000    0.000 inspect.py:2748(kind)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:2828(__init__)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2836(args)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2859(kwargs)\n",
      "       12    0.000    0.000    0.000    0.000 inspect.py:2889(apply_defaults)\n",
      "       10    0.000    0.000    0.000    0.000 inspect.py:292(isclass)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:2969(__init__)\n",
      "        5    0.000    0.000    0.000    0.000 inspect.py:3018(<genexpr>)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3023(from_callable)\n",
      "       54    0.000    0.000    0.000    0.000 inspect.py:3031(parameters)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3039(replace)\n",
      "       16    0.000    0.000    0.000    0.000 inspect.py:3075(_bind)\n",
      "       16    0.000    0.000    0.001    0.000 inspect.py:3206(bind)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:3277(signature)\n",
      "        2    0.000    0.000    0.000    0.000 inspect.py:378(isfunction)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:735(unwrap)\n",
      "        1    0.000    0.000    0.000    0.000 inspect.py:755(_is_wrapper)\n",
      "        5    0.000    0.000    0.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.002    0.000 lines.py:1026(get_path)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1040(set_antialiased)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1052(set_color)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1064(set_drawstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1099(set_gapcolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1122(set_linewidth)\n",
      "       30    0.000    0.000    0.001    0.000 lines.py:1137(set_linestyle)\n",
      "       20    0.000    0.000    0.001    0.000 lines.py:1182(set_marker)\n",
      "       90    0.000    0.000    0.001    0.000 lines.py:1196(_set_markercolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1210(set_markeredgecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1220(set_markerfacecolor)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1230(set_markerfacecoloralt)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1240(set_markeredgewidth)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1255(set_markersize)\n",
      "      723    0.002    0.000    0.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.006    0.000 lines.py:1335(update_from)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1358(set_dash_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1374(set_solid_joinstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1406(set_dash_capstyle)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:1422(set_solid_capstyle)\n",
      "       30    0.001    0.000    0.010    0.000 lines.py:272(__init__)\n",
      "       36    0.000    0.000    0.000    0.000 lines.py:33(_get_dash_pattern)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:538(set_markevery)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:597(get_markevery)\n",
      "       77    0.000    0.000    0.000    0.000 lines.py:63(_scale_dashes)\n",
      "       60    0.000    0.000    0.001    0.000 lines.py:635(set_data)\n",
      "       22    0.001    0.000    0.004    0.000 lines.py:654(recache)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:697(_transform_path)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:712(_get_transformed_path)\n",
      "       30    0.000    0.000    0.000    0.000 lines.py:718(set_transform)\n",
      "       24    0.001    0.000    0.006    0.000 lines.py:729(draw)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:893(get_drawstyle)\n",
      "       12    0.000    0.000    0.000    0.000 lines.py:933(get_markeredgecolor)\n",
      "       24    0.000    0.000    0.000    0.000 lines.py:959(_get_markerfacecolor)\n",
      "       18    0.000    0.000    0.000    0.000 managers.py:2058(dtype)\n",
      "       16    0.000    0.000    0.000    0.000 managers.py:2069(internal_values)\n",
      "       62    0.000    0.000    0.008    0.000 markers.py:228(__init__)\n",
      "      112    0.000    0.000    0.001    0.000 markers.py:277(_recache)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:293(__bool__)\n",
      "       44    0.000    0.000    0.000    0.000 markers.py:299(get_fillstyle)\n",
      "       62    0.000    0.000    0.000    0.000 markers.py:302(_set_fillstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:318(get_joinstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:321(get_capstyle)\n",
      "       12    0.000    0.000    0.000    0.000 markers.py:324(get_marker)\n",
      "       62    0.001    0.000    0.007    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",
      "        7    0.000    0.000    0.000    0.000 multiarray.py:1079(copyto)\n",
      "       48    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",
      "       88    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.040    0.010 multiclass.py:210(type_of_target)\n",
      "        2    0.000    0.000    0.016    0.008 multiclass.py:23(_unique_multiclass)\n",
      "        1    0.000    0.000    0.037    0.037 multiclass.py:44(unique_labels)\n",
      "        3    0.000    0.000    0.021    0.007 multiclass.py:81(<genexpr>)\n",
      "        2    0.000    0.000    0.001    0.001 numeric.py:150(ones)\n",
      "       10    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.002    0.000    0.015    0.000 numeric.py:2278(isclose)\n",
      "       84    0.003    0.000    0.009    0.000 numeric.py:2359(within_tol)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:73(_zeros_like_dispatcher)\n",
      "        3    0.000    0.000    0.000    0.000 numeric.py:77(zeros_like)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:228(obj2sctype)\n",
      "       12    0.000    0.000    0.000    0.000 numerictypes.py:282(issubclass_)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:356(issubdtype)\n",
      "        6    0.000    0.000    0.000    0.000 numerictypes.py:433(__getitem__)\n",
      "       70    0.000    0.000    0.006    0.000 patches.py:262(get_transform)\n",
      "       44    0.000    0.000    0.000    0.000 patches.py:273(get_patch_transform)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:288(get_edgecolor)\n",
      "        3    0.000    0.000    0.000    0.000 patches.py:292(get_facecolor)\n",
      "        7    0.000    0.000    0.000    0.000 patches.py:304(set_antialiased)\n",
      "       19    0.000    0.000    0.000    0.000 patches.py:317(_set_edgecolor)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:332(set_edgecolor)\n",
      "       19    0.000    0.000    0.001    0.000 patches.py:343(_set_facecolor)\n",
      "       13    0.000    0.000    0.000    0.000 patches.py:350(set_facecolor)\n",
      "       11    0.000    0.000    0.000    0.000 patches.py:384(set_linewidth)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:399(set_linestyle)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:434(set_fill)\n",
      "       10    0.000    0.000    0.000    0.000 patches.py:456(set_capstyle)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:476(set_joinstyle)\n",
      "        6    0.000    0.000    0.002    0.000 patches.py:48(__init__)\n",
      "        6    0.000    0.000    0.000    0.000 patches.py:496(set_hatch)\n",
      "       12    0.000    0.000    0.003    0.000 patches.py:533(_draw_paths_with_artist_properties)\n",
      "       12    0.000    0.000    0.005    0.000 patches.py:582(draw)\n",
      "       39    0.000    0.000    0.009    0.000 patches.py:603(get_window_extent)\n",
      "        2    0.000    0.000    0.001    0.000 patches.py:689(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 patches.py:730(get_path)\n",
      "       28    0.000    0.000    0.000    0.000 patches.py:734(_convert_units)\n",
      "       26    0.001    0.000    0.004    0.000 patches.py:742(get_patch_transform)\n",
      "       52    0.000    0.000    0.000    0.000 patches.py:763(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:768(rotation_point)\n",
      "        2    0.000    0.000    0.000    0.000 patches.py:855(set_bounds)\n",
      "       26    0.000    0.000    0.001    0.000 patches.py:876(get_bbox)\n",
      "       68    0.000    0.000    0.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.001    0.000    0.001    0.000 pathlib.py:536(__str__)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:56(parse_parts)\n",
      "       14    0.000    0.000    0.001    0.000 pathlib.py:868(__new__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:118(_safe_getattr)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:184(group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:201(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:232(text)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:280(begin_group)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:304(end_group)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:313(flush)\n",
      "       12    0.000    0.000    0.000    0.000 pretty.py:321(_get_mro)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:355(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:372(pretty)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:417(_in_deferred_types)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:482(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:490(__init__)\n",
      "        3    0.000    0.000    0.000    0.000 pretty.py:495(enq)\n",
      "        2    0.000    0.000    0.000    0.000 pretty.py:512(remove)\n",
      "        1    0.000    0.000    0.000    0.000 pretty.py:775(_repr_pprint)\n",
      "        1    0.000    0.000    0.493    0.493 pylabtools.py:111(print_figure)\n",
      "        1    0.000    0.000    0.062    0.062 pyplot.py:1328(subplots)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:185(_get_required_interactive_framework)\n",
      "        5    0.000    0.000    0.000    0.000 pyplot.py:198(_get_backend_mod)\n",
      "        3    0.000    0.000    0.000    0.000 pyplot.py:2280(gca)\n",
      "        1    0.000    0.000    0.001    0.001 pyplot.py:3055(title)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3062(xlabel)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:3070(ylabel)\n",
      "        2    0.000    0.000    0.000    0.000 pyplot.py:358(_warn_if_gui_out_of_main_thread)\n",
      "        1    0.000    0.000    0.002    0.002 pyplot.py:380(new_figure_manager)\n",
      "        1    0.000    0.000    0.000    0.000 pyplot.py:387(draw_if_interactive)\n",
      "        1    0.000    0.000    0.497    0.497 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.002    0.000 scale.py:115(get_transform)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:704(scale_factory)\n",
      "        4    0.000    0.000    0.000    0.000 scale.py:78(limit_range_for_scale)\n",
      "       14    0.000    0.000    0.000    0.000 scale.py:96(__init__)\n",
      "       18    0.000    0.000    0.000    0.000 series.py:596(dtype)\n",
      "        4    0.000    0.000    0.000    0.000 series.py:603(dtypes)\n",
      "       16    0.000    0.000    0.000    0.000 series.py:708(_values)\n",
      "        6    0.000    0.000    0.000    0.000 series.py:846(__array__)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:198(utcnow)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:272(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:279(extract_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:598(msg_id)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:643(msg_header)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:647(msg)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:673(sign)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:688(serialize)\n",
      "        1    0.000    0.000    0.001    0.001 session.py:752(send)\n",
      "        1    0.000    0.000    0.000    0.000 session.py:852(<listcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 session.py:92(json_packer)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:207(_arrays_for_stack_dispatcher)\n",
      "       24    0.000    0.000    0.000    0.000 shape_base.py:608(_column_stack_dispatcher)\n",
      "       24    0.000    0.000    0.001    0.000 shape_base.py:612(column_stack)\n",
      "        5    0.000    0.000    0.000    0.000 socket.py:613(send)\n",
      "       44    0.000    0.000    0.001    0.000 spines.py:135(get_patch_transform)\n",
      "       36    0.002    0.000    0.092    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.009    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.003    0.000 spines.py:227(_adjust_location)\n",
      "        8    0.000    0.000    0.002    0.000 spines.py:285(draw)\n",
      "        4    0.000    0.000    0.000    0.000 spines.py:292(set_position)\n",
      "    44/40    0.000    0.000    0.001    0.000 spines.py:332(get_spine_transform)\n",
      "        4    0.000    0.000    0.002    0.000 spines.py:35(__init__)\n",
      "        4    0.000    0.000    0.002    0.000 spines.py:425(linear_spine)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:538(__init__)\n",
      "        1    0.000    0.000    0.000    0.000 spines.py:541(from_dict)\n",
      "       44    0.000    0.000    0.000    0.000 spines.py:551(__getattr__)\n",
      "       64    0.000    0.000    0.000    0.000 spines.py:558(__getitem__)\n",
      "        8    0.000    0.000    0.000    0.000 spines.py:584(__iter__)\n",
      "        7    0.000    0.000    0.000    0.000 spines.py:587(__len__)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:416(_broadcast_shape)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:476(_broadcast_arrays_dispatcher)\n",
      "       22    0.000    0.000    0.001    0.000 stride_tricks.py:480(broadcast_arrays)\n",
      "       22    0.000    0.000    0.000    0.000 stride_tricks.py:538(<listcomp>)\n",
      "       66    0.000    0.000    0.000    0.000 stride_tricks.py:542(<genexpr>)\n",
      "      110    0.000    0.000    0.001    0.000 text.py:1000(set_horizontalalignment)\n",
      "       24    0.000    0.000    0.067    0.003 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.002    0.000 text.py:1184(set_position)\n",
      "      575    0.001    0.000    0.002    0.000 text.py:1195(set_x)\n",
      "      385    0.000    0.000    0.001    0.000 text.py:1206(set_y)\n",
      "       62    0.000    0.000    0.001    0.000 text.py:1217(set_rotation)\n",
      "      109    0.000    0.000    0.001    0.000 text.py:1249(set_verticalalignment)\n",
      "      798    0.001    0.000    0.001    0.000 text.py:1265(set_text)\n",
      "      182    0.001    0.000    0.002    0.000 text.py:1283(_preprocess_math)\n",
      "       55    0.000    0.000    0.005    0.000 text.py:1307(set_fontproperties)\n",
      "       31    0.000    0.000    0.010    0.000 text.py:132(__init__)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1321(set_usetex)\n",
      "      364    0.000    0.000    0.000    0.000 text.py:1335(get_usetex)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:1339(set_parse_math)\n",
      "      182    0.000    0.000    0.000    0.000 text.py:1351(get_parse_math)\n",
      "       55    0.001    0.000    0.011    0.000 text.py:185(_reset_visual_defaults)\n",
      "       34    0.000    0.000    0.003    0.000 text.py:221(update)\n",
      "       40    0.000    0.000    0.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.000    0.000 text.py:348(update_from)\n",
      "      160    0.012    0.000    0.128    0.001 text.py:363(_get_layout)\n",
      "      124    0.000    0.000    0.000    0.000 text.py:434(<listcomp>)\n",
      "       36    0.000    0.000    0.000    0.000 text.py:437(<listcomp>)\n",
      "       14    0.000    0.000    0.000    0.000 text.py:584(_update_clip_properties)\n",
      "        6    0.000    0.000    0.000    0.000 text.py:591(set_clip_box)\n",
      "        4    0.000    0.000    0.001    0.000 text.py:596(set_clip_path)\n",
      "        4    0.000    0.000    0.000    0.000 text.py:601(set_clip_on)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:606(get_wrap)\n",
      "       55    0.000    0.000    0.000    0.000 text.py:610(set_wrap)\n",
      "       22    0.000    0.000    0.000    0.000 text.py:687(_get_wrapped_text)\n",
      "       38    0.002    0.000    0.063    0.002 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.114    0.001 text.py:918(get_window_extent)\n",
      "      320    0.002    0.000    0.087    0.000 text.py:93(_get_text_metrics_with_cache)\n",
      "       69    0.000    0.000    0.002    0.000 text.py:985(set_color)\n",
      "        2    0.000    0.000    0.000    0.000 textpath.py:26(__init__)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1118(_wait_for_tstate_lock)\n",
      "        4    0.000    0.000    0.000    0.000 threading.py:1161(ident)\n",
      "        7    0.000    0.000    0.000    0.000 threading.py:1185(is_alive)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:1446(current_thread)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:236(__init__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:264(__enter__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:267(__exit__)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:273(_release_save)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:276(_acquire_restore)\n",
      "        2    0.000    0.000    0.000    0.000 threading.py:279(_is_owned)\n",
      "        2    0.000    0.000    0.001    0.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.004    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.004    0.000 ticker.py:2031(set_params)\n",
      "      168    0.016    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.002    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.006    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.005    0.000 ticker.py:568(__call__)\n",
      "       24    0.000    0.000    0.001    0.000 ticker.py:668(get_offset)\n",
      "      168    0.001    0.000    0.052    0.000 ticker.py:696(set_locs)\n",
      "      168    0.003    0.000    0.013    0.000 ticker.py:705(_compute_offset)\n",
      "      168    0.004    0.000    0.010    0.000 ticker.py:744(_set_order_of_magnitude)\n",
      "      168    0.007    0.000    0.027    0.000 ticker.py:778(_set_format)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:654(get)\n",
      "      149    0.000    0.000    0.000    0.000 traitlets.py:692(__get__)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:1006(minpos)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1017(minposx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:1028(minposy)\n",
      "     2254    0.001    0.000    0.001    0.000 transforms.py:1039(get_points)\n",
      "        7    0.000    0.000    0.000    0.000 transforms.py:1057(set)\n",
      "       26    0.000    0.000    0.001    0.000 transforms.py:1087(__init__)\n",
      "     1960    0.002    0.000    0.002    0.000 transforms.py:110(__init__)\n",
      "       53    0.000    0.000    0.001    0.000 transforms.py:1109(get_points)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:131(__getstate__)\n",
      "      130    0.000    0.000    0.002    0.000 transforms.py:1335(__add__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:134(<dictcomp>)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:136(__setstate__)\n",
      "       12    0.000    0.000    0.000    0.000 transforms.py:141(<dictcomp>)\n",
      "        4    0.000    0.000    0.000    0.000 transforms.py:1463(__array__)\n",
      "      160    0.001    0.000    0.012    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.004    0.000 transforms.py:1588(transform_path)\n",
      "       39    0.000    0.000    0.003    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.005    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.001    0.000    0.002    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.005    0.000 transforms.py:2001(rotate_deg)\n",
      "       58    0.000    0.000    0.000    0.000 transforms.py:2033(translate)\n",
      "       92    0.001    0.000    0.001    0.000 transforms.py:2046(scale)\n",
      "      141    0.000    0.000    0.000    0.000 transforms.py:209(<lambda>)\n",
      "       49    0.000    0.000    0.000    0.000 transforms.py:2122(get_matrix)\n",
      "      682    0.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.000    0.000    0.001    0.000 transforms.py:2347(__init__)\n",
      "   138/74    0.000    0.000    0.001    0.000 transforms.py:2376(_invalidate_internal)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:2391(__eq__)\n",
      "  467/257    0.001    0.000    0.001    0.000 transforms.py:2405(<lambda>)\n",
      "      160    0.000    0.000    0.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.002    0.000 transforms.py:2503(composite_transform_factory)\n",
      "       55    0.000    0.000    0.000    0.000 transforms.py:253(x0)\n",
      "       28    0.000    0.000    0.000    0.000 transforms.py:2581(__init__)\n",
      "  113/111    0.000    0.000    0.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.004    0.000 transforms.py:318(ymin)\n",
      "      243    0.001    0.000    0.003    0.000 transforms.py:323(xmax)\n",
      "      263    0.001    0.000    0.004    0.000 transforms.py:328(ymax)\n",
      "      463    0.001    0.000    0.001    0.000 transforms.py:343(intervalx)\n",
      "      263    0.001    0.000    0.001    0.000 transforms.py:352(intervaly)\n",
      "      161    0.001    0.000    0.001    0.000 transforms.py:361(width)\n",
      "      105    0.000    0.000    0.000    0.000 transforms.py:367(height)\n",
      "       11    0.000    0.000    0.000    0.000 transforms.py:373(size)\n",
      "       23    0.000    0.000    0.000    0.000 transforms.py:379(bounds)\n",
      "        6    0.000    0.000    0.000    0.000 transforms.py:385(extents)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:474(transformed)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:493(anchored)\n",
      "        5    0.000    0.000    0.000    0.000 transforms.py:534(shrunk_to_aspect)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:619(padded)\n",
      "      138    0.002    0.000    0.003    0.000 transforms.py:624(translated)\n",
      "       99    0.001    0.000    0.025    0.000 transforms.py:649(union)\n",
      "       99    0.000    0.000    0.005    0.000 transforms.py:654(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:655(<listcomp>)\n",
      "       99    0.000    0.000    0.003    0.000 transforms.py:656(<listcomp>)\n",
      "       99    0.000    0.000    0.004    0.000 transforms.py:657(<listcomp>)\n",
      "        2    0.000    0.000    0.001    0.000 transforms.py:660(intersection)\n",
      "      604    0.004    0.000    0.008    0.000 transforms.py:754(__init__)\n",
      "       49    0.000    0.000    0.001    0.000 transforms.py:784(frozen)\n",
      "       26    0.000    0.000    0.001    0.000 transforms.py:790(unit)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:795(null)\n",
      "      205    0.001    0.000    0.010    0.000 transforms.py:800(from_bounds)\n",
      "      232    0.001    0.000    0.011    0.000 transforms.py:809(from_extents)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:856(update_from_path)\n",
      "        1    0.000    0.000    0.000    0.000 transforms.py:932(update_from_data_xy)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:958(x0)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:963(y0)\n",
      "       13    0.000    0.000    0.000    0.000 transforms.py:968(x1)\n",
      "       24    0.000    0.000    0.000    0.000 transforms.py:973(y1)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:988(intervalx)\n",
      "        2    0.000    0.000    0.000    0.000 transforms.py:993(intervaly)\n",
      "        1    0.000    0.000    0.000    0.000 type_check.py:400(_nan_to_num_dispatcher)\n",
      "        1    0.000    0.000    0.000    0.000 type_check.py:404(nan_to_num)\n",
      "        1    0.000    0.000    0.000    0.000 tz.py:74(utcoffset)\n",
      "     12/6    0.000    0.000    0.000    0.000 units.py:164(get_converter)\n",
      "      118    0.000    0.000    0.001    0.000 units.py:56(_is_natively_supported)\n",
      "        2    0.000    0.000    0.001    0.001 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.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.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 0x00007FFF5DDE9F90}\n",
      "     3636    0.002    0.000    0.003    0.000 {built-in method _abc._abc_instancecheck}\n",
      "   180/87    0.001    0.000    0.001    0.000 {built-in method _abc._abc_subclasscheck}\n",
      "        6    0.000    0.000    0.000    0.000 {built-in method _operator.index}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method _stat.S_ISREG}\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",
      "     4942    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",
      "     2298    0.003    0.000    0.004    0.000 {built-in method builtins.any}\n",
      "      578    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.661    0.661 {built-in method builtins.exec}\n",
      "     7608    0.006    0.000    0.028    0.000 {built-in method builtins.getattr}\n",
      "      890    0.001    0.000    0.001    0.000 {built-in method builtins.hasattr}\n",
      "1774/1088    0.001    0.000    0.006    0.000 {built-in method builtins.hash}\n",
      "     1714    0.000    0.000    0.000    0.000 {built-in method builtins.id}\n",
      "    13025    0.006    0.000    0.011    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",
      "5839/5832    0.002    0.000    0.002    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.001    0.000 {built-in method builtins.setattr}\n",
      "      430    0.002    0.000    0.002    0.000 {built-in method builtins.sorted}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method builtins.sum}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method from_iterable}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.cos}\n",
      "      336    0.000    0.000    0.000    0.000 {built-in method math.floor}\n",
      "      504    0.001    0.000    0.001    0.000 {built-in method math.log10}\n",
      "      208    0.000    0.000    0.000    0.000 {built-in method math.radians}\n",
      "      197    0.000    0.000    0.000    0.000 {built-in method math.sin}\n",
      "        4    0.015    0.004    0.015    0.004 {built-in method matplotlib._image.resample}\n",
      "      600    0.002    0.000    0.002    0.000 {built-in method matplotlib._path.affine_transform}\n",
      "        1    0.000    0.000    0.000    0.000 {built-in method matplotlib._path.update_path_extents}\n",
      "       29    0.000    0.000    0.000    0.000 {built-in method nt.fspath}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.getpid}\n",
      "        2    0.000    0.000    0.000    0.000 {built-in method nt.stat}\n",
      "      173    0.001    0.000    0.001    0.000 {built-in method numpy.arange}\n",
      "      935    0.007    0.000    0.007    0.000 {built-in method numpy.array}\n",
      "     1210    0.001    0.000    0.001    0.000 {built-in method numpy.asanyarray}\n",
      "1764/1758    0.003    0.000    0.003    0.000 {built-in method numpy.asarray}\n",
      "4493/3318    0.013    0.000    0.145    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.core._multiarray_umath.normalize_axis_index}\n",
      "       18    0.000    0.000    0.000    0.000 {built-in method numpy.empty}\n",
      "      348    0.000    0.000    0.000    0.000 {built-in method numpy.geterrobj}\n",
      "        4    0.000    0.000    0.000    0.000 {built-in method numpy.promote_types}\n",
      "      174    0.000    0.000    0.000    0.000 {built-in method numpy.seterrobj}\n",
      "       12    0.001    0.000    0.001    0.000 {built-in method numpy.zeros}\n",
      "        1    0.001    0.001    0.001    0.001 {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",
      "     4400    0.002    0.000    0.002    0.000 {function RcParams.__getitem__ at 0x0000027AB42C71A0}\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",
      "       93    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",
      "     1994    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",
      "       36    0.002    0.000    0.002    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",
      "        6    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.003    0.000    0.003    0.000 {method 'copy' of 'numpy.ndarray' objects}\n",
      "      424    0.000    0.000    0.000    0.000 {method 'count' of 'str' objects}\n",
      "        2    0.000    0.000    0.000    0.000 {method 'cumsum' of 'numpy.ndarray' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'decode' of 'bytes' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}\n",
      "        1    0.000    0.000    0.000    0.000 {method 'discard' of 'set' objects}\n",
      "       11    0.001    0.000    0.001    0.000 {method 'draw_glyphs_to_bitmap' of 'matplotlib.ft2font.FT2Font' objects}\n",
      "        1    0.004    0.004    0.004    0.004 {method 'draw_image' of 'matplotlib.backends._backend_agg.RendererAgg' objects}\n",
      "        6    0.001    0.000    0.001    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.016    0.016    0.016    0.016 {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.010    0.000    0.010    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",
      "     9608    0.003    0.000    0.003    0.000 {method 'get' of 'dict' objects}\n",
      "        3    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",
      "       60    0.000    0.000    0.000    0.000 {method 'index' of 'list' 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",
      "     5974    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",
      "     3283    0.001    0.000    0.001    0.000 {method 'lower' of 'str' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'lstrip' of 'str' objects}\n",
      "      344    0.001    0.000    0.001    0.000 {method 'match' of 're.Pattern' objects}\n",
      "     1374    0.001    0.000    0.009    0.000 {method 'max' of 'numpy.ndarray' objects}\n",
      "      536    0.001    0.000    0.008    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",
      "     4140    0.025    0.000    0.025    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",
      "      559    0.001    0.000    0.001    0.000 {method 'reshape' of 'numpy.ndarray' objects}\n",
      "       14    0.000    0.000    0.000    0.000 {method 'reverse' of 'list' objects}\n",
      "        3    0.000    0.000    0.000    0.000 {method 'rfind' of 'str' objects}\n",
      "      840    0.005    0.000    0.005    0.000 {method 'round' of 'numpy.ndarray' objects}\n",
      "       39    0.000    0.000    0.000    0.000 {method 'rpartition' of 'str' objects}\n",
      "        4    0.000    0.000    0.000    0.000 {method 'searchsorted' of 'numpy.ndarray' 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.057    0.003    0.057    0.003 {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.003    0.000 {method 'sum' of 'numpy.ndarray' objects}\n",
      "        2    0.003    0.002    0.003    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.000    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=dataframe.Actual_value1, y_pred=dataframe.predicted_output_final)\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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    list1 = dataframe.predicted_output_final\n",
    "    list2 = dataframe.Actual_value1           \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",
    "    fig, ax = plt.subplots(figsize=(8,5))\n",
    "    venn = venn2([set1,set2],ax=ax )\n",
    "    venn.get_label_by_id('10').set_text('P=1 & A=0\\n' + str(FP))\n",
    "    venn.get_label_by_id('01').set_text('P=0 & A=1\\n' + str(TN))\n",
    "    venn.get_label_by_id('11').set_text('A & P\\n' + str(TP+FN))\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predictive parity is not satisfied.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from sklearn.metrics import confusion_matrix\n",
    "\n",
    "def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "    # 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",
    "    cm_group2 = confusion_matrix(y_true[sensitive_attr == 2], y_pred[sensitive_attr == 2])\n",
    "    \n",
    "    # compute the positive predictive value (PPV) for each group\n",
    "    ppv_group0 = cm_group0[1, 1] / np.sum(cm_group0[:, 1])\n",
    "    ppv_group1 = cm_group1[1, 1] / np.sum(cm_group1[:, 1])\n",
    "    ppv_group2 = cm_group2[1, 1] / np.sum(cm_group2[:, 1])\n",
    "    \n",
    "    # compute the negative predictive value (NPV) for each group\n",
    "    npv_group0 = cm_group0[0, 0] / np.sum(cm_group0[:, 0])\n",
    "    npv_group1 = cm_group1[0, 0] / np.sum(cm_group1[:, 0])\n",
    "    npv_group2 = cm_group2[0, 0] / np.sum(cm_group2[:, 0])\n",
    "    \n",
    "    # check if the PPV and NPV are approximately equal across all groups\n",
    "    tolerance = 0.1 # set a tolerance level for differences between groups\n",
    "    if np.isclose(ppv_group0, ppv_group1, rtol=tolerance) and np.isclose(ppv_group1, ppv_group2, rtol=tolerance) and np.isclose(npv_group0, npv_group1, rtol=tolerance) and np.isclose(npv_group1, npv_group2, rtol=tolerance):\n",
    "        print(\"Predictive parity is satisfied.\")\n",
    "    else:\n",
    "        print(\"Predictive parity is not satisfied.\")\n",
    "predictive_parity(dataframe.Actual_value1,dataframe.predicted_output_final,dataframe.TaxonomyLevel)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#predictive parity\n",
    "\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "    import numpy as np\n",
    "    from sklearn.metrics import confusion_matrix\n",
    "\n",
    "    def predictive_parity(y_true, y_pred, sensitive_attr):\n",
    "        # 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",
    "        cm_group2 = confusion_matrix(y_true[sensitive_attr == 2], y_pred[sensitive_attr == 2])\n",
    "    \n",
    "        # compute the positive predictive value (PPV) for each group\n",
    "        ppv_group0 = cm_group0[1, 1] / np.sum(cm_group0[:, 1])\n",
    "        ppv_group1 = cm_group1[1, 1] / np.sum(cm_group1[:, 1])\n",
    "        ppv_group2 = cm_group2[1, 1] / np.sum(cm_group2[:, 1])\n",
    "        \n",
    "        # compute the negative predictive value (NPV) for each group\n",
    "        npv_group0 = cm_group0[0, 0] / np.sum(cm_group0[:, 0])\n",
    "        npv_group1 = cm_group1[0, 0] / np.sum(cm_group1[:, 0])\n",
    "        npv_group2 = cm_group2[0, 0] / np.sum(cm_group2[:, 0])\n",
    "    \n",
    "        # check if the PPV and NPV are approximately equal across all groups\n",
    "        tolerance = 0.1 # set a tolerance level for differences between groups\n",
    "        if np.isclose(ppv_group0, ppv_group1, rtol=tolerance) and np.isclose(ppv_group1, ppv_group2, rtol=tolerance) and np.isclose(npv_group0, npv_group1, rtol=tolerance) and np.isclose(npv_group1, npv_group2, rtol=tolerance):\n",
    "            print(\"Predictive parity is satisfied.\")\n",
    "        else:\n",
    "            print(\"Predictive parity is not satisfied.\")\n",
    "    predictive_parity(dataframe.Actual_value1,dataframe.predicted_output_final,dataframe.TaxonomyLevel)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#equlaized odds\n",
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "  import numpy as np\n",
    "\n",
    "  def equalized_odds(y_true, y_pred, sensitive_attr):\n",
    "      # find indices of positive predictions and sensitive attribute values\n",
    "      pos_indices = np.where(y_pred == 1)[0]\n",
    "      sensitive_indices = np.where(sensitive_attr ==1)[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",
    "      pos_indices_group2 = np.intersect1d(pos_indices, np.where(sensitive_attr ==2)[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",
    "      tpr_group2 = len(np.intersect1d(pos_indices_group2, 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",
    "      fpr_group2 = len(np.intersect1d(pos_indices_group2, np.where(y_true == 0)[0])) / len(np.where(y_true == 0)[0])\n",
    "      # check if equalized odds is satisfied for both groups\n",
    "      tolerance = 0.1 # set a tolerance level for differences between groups\n",
    "      if np.isclose(tpr_group0, tpr_group1, rtol=tolerance) and np.isclose(tpr_group1, tpr_group2, rtol=tolerance) and np.isclose(fpr_group0, fpr_group1, rtol=tolerance) and np.isclose(fpr_group1, fpr_group2, rtol=tolerance):\n",
    "        print(\"Equalized odds is satisfied.\")\n",
    "      else:\n",
    "          print(\"Equalized odds is not satisfied.\")      \n",
    "      #if np.isclose(tpr_group0, tpr_group1, rtol=1e-3) and np.isclose(fpr_group0, fpr_group1, rtol=1e-3):\n",
    "          \n",
    "      #return tpr_group0, tpr_group1, fpr_group0, fpr_group1\n",
    "  equalized_odds(dataframe.Actual_value1,dataframe.predicted_output_final,dataframe.TaxonomyLevel)\n",
    "  pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#demographic parity \n",
    "# import necessary packages\n",
    "import cProfile\n",
    "\n",
    "def my_method():\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 ==1)[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",
    "        pos_indices_group2 = np.intersect1d(pos_indices, np.where(sensitive_attr ==2)[0])\n",
    "        \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",
    "        prob_pos_group2 = len(pos_indices_group1) / len(np.where(sensitive_attr ==2)[0])\n",
    "        # check if demographic parity is satisfied\n",
    "        tolerance=0.1\n",
    "        if np.isclose(prob_pos_group0, prob_pos_group1, rtol=tolerance) and np.isclose(prob_pos_group1, prob_pos_group2, rtol=tolerance) :\n",
    "        \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(dataframe.predicted_output_final,dataframe.TaxonomyLevel)\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import cProfile\n",
    "\n",
    "def my_method():\n",
    "          \n",
    "    \n",
    "    #for i in range(len(dataframe)):\n",
    "    if np.logical_and(dataframe.predicted_output_final.all(), dataframe.Actual_value1.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 exiats\")\n",
    "    pass\n",
    "cProfile.run('my_method()')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.2"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "52634da84371cba311ea128a5ea7cdc41ff074b781779e754b270ff9f8153cee"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
