{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0602b88a-085e-407a-b729-afc15df6a90d",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Modelling congestion with UTD19 traffice data\n",
    "\n",
    "This demo uses the UTD19 dataset from ETH Zurich on traffic congestion detection. https://utd19.ethz.ch/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "243a5669-2cb7-4ce3-8529-a33fd217dcde",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c357c3e8-2d17-40dc-b880-26388b9721ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "detectors = pd.read_csv(\"./downloads/detectors_public.csv\")\n",
    "detectors = detectors[detectors[\"citycode\"] == \"zurich\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "709560ac-a98c-4470-9218-18a94b15cf68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total 1020 detectors in Zurich.\n"
     ]
    },
    {
     "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>detid</th>\n",
       "      <th>length</th>\n",
       "      <th>pos</th>\n",
       "      <th>fclass</th>\n",
       "      <th>road</th>\n",
       "      <th>limit</th>\n",
       "      <th>citycode</th>\n",
       "      <th>lanes</th>\n",
       "      <th>linkid</th>\n",
       "      <th>long</th>\n",
       "      <th>lat</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>22606</th>\n",
       "      <td>K2D11</td>\n",
       "      <td>0.377599</td>\n",
       "      <td>0.015064</td>\n",
       "      <td>primary</td>\n",
       "      <td>Seebahnstrasse</td>\n",
       "      <td>50</td>\n",
       "      <td>zurich</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1128.0</td>\n",
       "      <td>8.518458</td>\n",
       "      <td>47.375536</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22607</th>\n",
       "      <td>K2D13</td>\n",
       "      <td>0.059272</td>\n",
       "      <td>0.014468</td>\n",
       "      <td>tertiary</td>\n",
       "      <td>Badenerstrasse</td>\n",
       "      <td>50</td>\n",
       "      <td>zurich</td>\n",
       "      <td>1.0</td>\n",
       "      <td>212.0</td>\n",
       "      <td>8.518211</td>\n",
       "      <td>47.375198</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22608</th>\n",
       "      <td>K2D14</td>\n",
       "      <td>0.161521</td>\n",
       "      <td>0.006782</td>\n",
       "      <td>primary</td>\n",
       "      <td>Seebahnstrasse</td>\n",
       "      <td>50</td>\n",
       "      <td>zurich</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1109.0</td>\n",
       "      <td>8.518765</td>\n",
       "      <td>47.374964</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22609</th>\n",
       "      <td>K2D15</td>\n",
       "      <td>0.158996</td>\n",
       "      <td>0.020170</td>\n",
       "      <td>primary</td>\n",
       "      <td>Seebahnstrasse</td>\n",
       "      <td>50</td>\n",
       "      <td>zurich</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1108.0</td>\n",
       "      <td>8.518818</td>\n",
       "      <td>47.374825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22610</th>\n",
       "      <td>K2D16</td>\n",
       "      <td>0.156223</td>\n",
       "      <td>0.017910</td>\n",
       "      <td>primary</td>\n",
       "      <td>Seebahnstrasse</td>\n",
       "      <td>50</td>\n",
       "      <td>zurich</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1106.0</td>\n",
       "      <td>8.518857</td>\n",
       "      <td>47.374831</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       detid    length       pos    fclass            road limit citycode   \n",
       "22606  K2D11  0.377599  0.015064   primary  Seebahnstrasse    50   zurich  \\\n",
       "22607  K2D13  0.059272  0.014468  tertiary  Badenerstrasse    50   zurich   \n",
       "22608  K2D14  0.161521  0.006782   primary  Seebahnstrasse    50   zurich   \n",
       "22609  K2D15  0.158996  0.020170   primary  Seebahnstrasse    50   zurich   \n",
       "22610  K2D16  0.156223  0.017910   primary  Seebahnstrasse    50   zurich   \n",
       "\n",
       "       lanes  linkid      long        lat  \n",
       "22606    1.0  1128.0  8.518458  47.375536  \n",
       "22607    1.0   212.0  8.518211  47.375198  \n",
       "22608    1.0  1109.0  8.518765  47.374964  \n",
       "22609    1.0  1108.0  8.518818  47.374825  \n",
       "22610    1.0  1106.0  8.518857  47.374831  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(f\"Total {len(detectors)} detectors in Zurich.\")\n",
    "detectors.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1e9a27ff-131a-433f-bfbe-a1092cff00cf",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Filter Zurich dataset\n",
    "\n",
    "Since the UTD dataset is very large, we filter the dataset for measurements in Zurich and save to a file."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "e1e979f4-c964-47b4-aaed-afcae4e860fd",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "........."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "..."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "............................................................................................."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "....."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "....."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ".."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ".."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "......"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "."
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-19-3cec19ebeda3>:4: DtypeWarning: Columns (2) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  for chunk in reader:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "......"
     ]
    }
   ],
   "source": [
    "chunksize = 10 ** 6\n",
    "chunks = []\n",
    "with pd.read_csv(\"./downloads/utd19_u.csv\", chunksize=chunksize) as reader:\n",
    "    for chunk in reader:\n",
    "        chunk = chunk[chunk[\"city\"] == \"zurich\"]\n",
    "        chunks.append(chunk)\n",
    "        print(\".\", end=\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "f7e173ab-52a3-4e80-bda3-e850534be264",
   "metadata": {},
   "outputs": [],
   "source": [
    "chunks = [c for c in chunks if len(c) > 0]\n",
    "df_zurich = pd.concat(chunks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "c27c6210-0af8-4b37-848f-ce8fc5eacf0d",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_zurich.to_csv(\"downloads/utd_zurich.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "25947ed0-2206-439a-a707-adc3bf691ce1",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_zurich = pd.read_csv(\"downloads/utd_zurich.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "721f4770-fd12-4184-8c44-84f0ef1063e0",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Preliminary Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3320305b-d833-410b-a05d-481df9311450",
   "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>day</th>\n",
       "      <th>interval</th>\n",
       "      <th>detid</th>\n",
       "      <th>flow</th>\n",
       "      <th>occ</th>\n",
       "      <th>error</th>\n",
       "      <th>city</th>\n",
       "      <th>speed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>130955369</th>\n",
       "      <td>2015-10-26</td>\n",
       "      <td>180</td>\n",
       "      <td>K10D11</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.005556</td>\n",
       "      <td>0.0</td>\n",
       "      <td>zurich</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130955370</th>\n",
       "      <td>2015-10-26</td>\n",
       "      <td>360</td>\n",
       "      <td>K10D11</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>zurich</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130955371</th>\n",
       "      <td>2015-10-26</td>\n",
       "      <td>540</td>\n",
       "      <td>K10D11</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.007778</td>\n",
       "      <td>0.0</td>\n",
       "      <td>zurich</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130955372</th>\n",
       "      <td>2015-10-26</td>\n",
       "      <td>720</td>\n",
       "      <td>K10D11</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.008333</td>\n",
       "      <td>0.0</td>\n",
       "      <td>zurich</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130955373</th>\n",
       "      <td>2015-10-26</td>\n",
       "      <td>900</td>\n",
       "      <td>K10D11</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>zurich</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                  day  interval   detid  flow       occ  error    city  speed\n",
       "130955369  2015-10-26       180  K10D11  40.0  0.005556    0.0  zurich    NaN\n",
       "130955370  2015-10-26       360  K10D11   0.0  0.000000    0.0  zurich    NaN\n",
       "130955371  2015-10-26       540  K10D11  40.0  0.007778    0.0  zurich    NaN\n",
       "130955372  2015-10-26       720  K10D11  40.0  0.008333    0.0  zurich    NaN\n",
       "130955373  2015-10-26       900  K10D11   0.0  0.000000    0.0  zurich    NaN"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_zurich.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b6a0d9aa-63ba-4f35-b871-48b1565027b4",
   "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>interval</th>\n",
       "      <th>flow</th>\n",
       "      <th>occ</th>\n",
       "      <th>error</th>\n",
       "      <th>speed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>3.425002e+06</td>\n",
       "      <td>3.425002e+06</td>\n",
       "      <td>3.425002e+06</td>\n",
       "      <td>3.425002e+06</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>4.312433e+04</td>\n",
       "      <td>2.074920e+02</td>\n",
       "      <td>1.000321e-01</td>\n",
       "      <td>2.170510e-03</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>2.493403e+04</td>\n",
       "      <td>2.031532e+02</td>\n",
       "      <td>1.632819e-01</td>\n",
       "      <td>4.653815e-02</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>2.160000e+04</td>\n",
       "      <td>4.000000e+01</td>\n",
       "      <td>8.333334e-03</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>4.320000e+04</td>\n",
       "      <td>1.400000e+02</td>\n",
       "      <td>3.333333e-02</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>6.480000e+04</td>\n",
       "      <td>3.200000e+02</td>\n",
       "      <td>1.100000e-01</td>\n",
       "      <td>0.000000e+00</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>8.622000e+04</td>\n",
       "      <td>6.240000e+03</td>\n",
       "      <td>2.833556e+01</td>\n",
       "      <td>1.000000e+00</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           interval          flow           occ         error  speed\n",
       "count  3.425002e+06  3.425002e+06  3.425002e+06  3.425002e+06    0.0\n",
       "mean   4.312433e+04  2.074920e+02  1.000321e-01  2.170510e-03    NaN\n",
       "std    2.493403e+04  2.031532e+02  1.632819e-01  4.653815e-02    NaN\n",
       "min    0.000000e+00  0.000000e+00  0.000000e+00  0.000000e+00    NaN\n",
       "25%    2.160000e+04  4.000000e+01  8.333334e-03  0.000000e+00    NaN\n",
       "50%    4.320000e+04  1.400000e+02  3.333333e-02  0.000000e+00    NaN\n",
       "75%    6.480000e+04  3.200000e+02  1.100000e-01  0.000000e+00    NaN\n",
       "max    8.622000e+04  6.240000e+03  2.833556e+01  1.000000e+00    NaN"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_zurich.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b952849c-4dcf-4f20-a302-6e1b22ef3146",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count     3425002\n",
       "unique       1020\n",
       "top        K10D11\n",
       "freq         3359\n",
       "Name: detid, dtype: object"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_zurich[\"detid\"].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "34f46713-4075-4c34-afeb-95e9c34614ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f71191e0fd0>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = df_zurich[df_zurich[\"detid\"] == \"K2D13\"]\n",
    "plt.scatter(df[\"occ\"], df[\"flow\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81e3f4cf-9b32-46c3-bcd6-767df4ee61a8",
   "metadata": {},
   "source": [
    "# Analysis and Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "f690a469-4c2d-48e5-ab36-6efce5472001",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>#sk-container-id-4 {color: black;background-color: white;}#sk-container-id-4 pre{padding: 0;}#sk-container-id-4 div.sk-toggleable {background-color: white;}#sk-container-id-4 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-4 label.sk-toggleable__label-arrow:before {content: \"▸\";float: left;margin-right: 0.25em;color: #696969;}#sk-container-id-4 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-container-id-4 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-container-id-4 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-container-id-4 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-container-id-4 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-container-id-4 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: \"▾\";}#sk-container-id-4 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 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-4 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-4 div.sk-estimator:hover {background-color: #d4ebff;}#sk-container-id-4 div.sk-parallel-item::after {content: \"\";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-container-id-4 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 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-4 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-4 div.sk-item {position: relative;z-index: 1;}#sk-container-id-4 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;position: relative;}#sk-container-id-4 div.sk-item::before, #sk-container-id-4 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-4 div.sk-parallel-item {display: flex;flex-direction: column;z-index: 1;position: relative;background-color: white;}#sk-container-id-4 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-container-id-4 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-container-id-4 div.sk-parallel-item:only-child::after {width: 0;}#sk-container-id-4 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-4 div.sk-label label {font-family: monospace;font-weight: bold;display: inline-block;line-height: 1.2em;}#sk-container-id-4 div.sk-label-container {text-align: center;}#sk-container-id-4 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-4 div.sk-text-repr-fallback {display: none;}</style><div id=\"sk-container-id-4\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>KernelRidge(alpha=1.0, kernel=&#x27;rbf&#x27;)</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-4\" type=\"checkbox\" checked><label for=\"sk-estimator-id-4\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">KernelRidge</label><div class=\"sk-toggleable__content\"><pre>KernelRidge(alpha=1.0, kernel=&#x27;rbf&#x27;)</pre></div></div></div></div></div>"
      ],
      "text/plain": [
       "KernelRidge(alpha=1.0, kernel='rbf')"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.kernel_ridge import KernelRidge\n",
    "import numpy as np\n",
    "n_samples, n_features = 30, 10\n",
    "rng = np.random.RandomState(0)\n",
    "y = rng.randn(n_samples)\n",
    "X = rng.randn(n_samples, n_features)\n",
    "krr = KernelRidge(alpha=1.0, kernel=\"rbf\")\n",
    "krr.fit(np.array(df2[\"occ\"]).reshape(-1, 1), df2[\"flow\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "08cc0461-e474-413b-a4e9-a12dd8e0be02",
   "metadata": {},
   "outputs": [],
   "source": [
    "ypred = krr.predict(np.linspace(0., 1.0, 100).reshape(-1, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "76c10d56-1e12-4941-9512-d4b0825b6871",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Flow')"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(9,9))\n",
    "df2 = df_zurich[df_zurich[\"detid\"] == \"K10D11\"]\n",
    "plt.scatter(df2[\"occ\"], df2[\"flow\"])\n",
    "plt.plot(np.linspace(0., 1.0, 100),ypred, \"r\")\n",
    "plt.xlabel(\"Occupancy\")\n",
    "plt.ylabel(\"Flow\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "a821086c-22ab-45bd-b90b-c947b57211b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-35-a45738fe6108>:4: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  plt.plot(np.linspace(0., 1.0, 100),ypred/np.linspace(0., 1.0, 100), \"r\")\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Speed')"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(9,9))\n",
    "df2 = df_zurich[df_zurich[\"detid\"] == \"K10D11\"]\n",
    "plt.scatter(df2[\"occ\"], df2[\"flow\"]/df2[\"occ\"])\n",
    "plt.plot(np.linspace(0., 1.0, 100),ypred/np.linspace(0., 1.0, 100), \"r\")\n",
    "plt.xlabel(\"Occupancy\")\n",
    "plt.ylabel(\"Speed\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a36cf76e-f64a-4da3-aa2d-657d7cfc37e9",
   "metadata": {},
   "source": [
    "# Optional: Visualizing Detector Locations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "04746d43-c007-4652-b491-3c040c092f56",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0a5617ed3dfa468eadc6fed1499071d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Map(center=[47.375536, 8.518458], controls=(ZoomControl(options=['position', 'zoom_in_text', 'zoom_in_title', …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from ipyleaflet import Map, Marker\n",
    "\n",
    "center = (47.375536, 8.518458)\n",
    "\n",
    "m = Map(center=center, zoom=11)\n",
    "\n",
    "for i in range(len(detectors)):\n",
    "    marker = Marker(location=(detectors.iloc[i][\"lat\"], detectors.iloc[i][\"long\"]), \n",
    "                    title=detectors.iloc[i][\"detid\"], \n",
    "                    draggable=False,\n",
    "                   opacity=0.8)\n",
    "    m.add_layer(marker);\n",
    "    \n",
    "m.layout.width = '100%'\n",
    "m.layout.height = '700px'\n",
    "display(m)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65532525-9751-4a75-a00f-0f64da5d084c",
   "metadata": {},
   "source": [
    "# Building up Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "dcf697dd-02f8-45cf-bb58-8c7490fbbc03",
   "metadata": {},
   "outputs": [],
   "source": [
    "sensors = [\"K418D12\", \"K582D11\", \"K324D11\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "5f78b98a-ba7d-4e1d-88b0-147b2615df7a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fit_model_detector(df, detector_id):\n",
    "    from sklearn.kernel_ridge import KernelRidge\n",
    "\n",
    "    \n",
    "    df = df[df[\"detid\"] == detector_id].copy()\n",
    "    \n",
    "    df[\"speed\"] = df[\"flow\"]/df[\"occ\"]\n",
    "    df = df.dropna()\n",
    "    df = df[~df.isin([np.nan, np.inf, -np.inf]).any(axis=1)]\n",
    "    \n",
    "    # plt.figure(figsize=(9,9))\n",
    "    # df2 = df_zurich[df_zurich[\"detid\"] == detector_id]\n",
    "    # plt.scatter(df[\"occ\"], df[\"flow\"])\n",
    "    # plt.plot(np.linspace(0., 1.0, 100),ypred, \"r\")\n",
    "    # plt.xlabel(\"Occupancy\")\n",
    "    # plt.ylabel(\"Flow\")\n",
    "    \n",
    "    n_samples, n_features = 30, 10\n",
    "    rng = np.random.RandomState(0)\n",
    "    y = rng.randn(n_samples)\n",
    "    X = rng.randn(n_samples, n_features)\n",
    "    krr = KernelRidge(alpha=1.0, kernel=\"rbf\")\n",
    "    krr.fit(np.array(df[\"occ\"]).reshape(-1, 1), df[\"flow\"])\n",
    "    \n",
    "    \n",
    "    xpred=np.linspace(0.01, 1.0, 100)\n",
    "    ypred = krr.predict(xpred.reshape(-1, 1))\n",
    "    \n",
    "    plt.figure(figsize=(5,5))\n",
    "    # plt.title(f\"Detector: {detector_id}\")\n",
    "    plt.scatter(df[\"occ\"], df[\"flow\"], label=\"Data\")\n",
    "    plt.plot(xpred,ypred, \"r\", label = \"Model\")\n",
    "    plt.xlabel(\"Occupancy (%)\")\n",
    "    plt.xlim(0,min(1,max(df[\"occ\"].max(), 0.5)))\n",
    "    plt.ylabel(\"Flow (veh/h-lane)\")\n",
    "    plt.legend()\n",
    "    plt.savefig(f\"figures/sensor_flow_{detector_id}.png\",\n",
    "                dpi = 800, \n",
    "                bbox_inches = 'tight')\n",
    "    \n",
    "    plt.figure(figsize=(5,5))\n",
    "    # plt.title(f\"Detector: {detector_id}\")\n",
    "    plt.scatter(df[\"occ\"], df[\"flow\"] / df[\"occ\"] / 20000, label = \"Data\")\n",
    "    plt.plot(xpred,ypred / xpred / 20000, \"r\", label = \"Model\")\n",
    "    plt.xlabel(\"Occupancy (%)\")\n",
    "    plt.xlim(0,min(1,max(df[\"occ\"].max(), 0.5)))\n",
    "    plt.ylabel(\"Speed\")\n",
    "    plt.legend()\n",
    "    plt.savefig(f\"figures/sensor_speed_{detector_id}.png\",\n",
    "                dpi = 800, \n",
    "                bbox_inches = 'tight')\n",
    "    \n",
    "    return krr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "cc7f6fd1-26e5-4f07-a426-a42024e975b3",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVgAAAE9CAYAAABOVXqpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAoc0lEQVR4nO3de3hV1Z3/8feXEExAICoXJYggUi0IBBrQFuutHcUrtHVGaLUdnRlqZ+xU59Epzs8W7U2en221M7W1jGO1VdHOD6XWu9UqXkbbIOE2iCKiJtiCQLglQBK+vz/ODjkczsk5OTkrJzn5vJ7nPDln7732WbuxH1bWXmttc3dERCT3euW7AiIihUoBKyISiAJWRCQQBayISCAKWBGRQBSwIiKB9M53BXJp0KBBPnLkyHxXQ0QKzNKlSz9y98HtLVdQATty5EiqqqryXQ0RKTBm9l425dRFICISiAJWRCQQBayISCAF1QcrItlrbGykpqaGPXv25LsqeVNSUsLw4cMpLi7OyfkUsCICQE1NDf3792fkyJGYWb6r0+ncnS1btlBTU8OoUaNyck51EYgIAHv27OGoo47qkeEKYGYcddRROW3BK2BF5ICeGq4tcn39BRWwK2u3M23+8yxeVpvvqohIFoqKiqioqGDcuHFMnDiRH//4x+zfv7/NMhs2bOCBBx7opBq2T0EFLEBtXQM3PLxSISvSDZWWllJdXc3q1at59tlneeKJJ7j55pvbLKOA7WQNjc3c+vTafFdDpKAtXlbLtPnPM2ru40H+chwyZAgLFizgpz/9Ke7Ohg0b+PSnP83kyZOZPHkyr776KgBz587lpZdeoqKigttuuy3lcflQsKMINtY15LsKIgVr8bJabnh4JQ2NzUDrX44AMyeV5+x7jj/+ePbv38+mTZsYMmQIzz77LCUlJbz99tvMnj2bqqoq5s+fzw9/+EMee+wxAOrr65Melw8FG7DDykrzXQWRgnXr02sPhGuLlr8ccxmwEBs+BbFxuldffTXV1dUUFRXx1ltvJT0+0+M6Q0EGbGlxEdefe2K+qyFSsFL9hZjrvxzXr19PUVERQ4YM4eabb2bo0KEsX76c/fv3U1JSkrTMbbfdltFxnSFYH6yZ3W1mm8xsVYr915tZdfRaZWbNZnZktG+Dma2M9rWrbV9eVsotnx+f839FRaRVqr8Qc/mX4+bNm7nqqqu4+uqrMTO2b9/OMcccQ69evfj1r39Nc3OsBd2/f3927tx5oFyq4/Ih5E2ue4DpqXa6+63uXuHuFcANwIvuvjXukLOi/ZWZfuH48oG8MvdshatIYNefeyKlxUUHbcvFX44NDQ0Hhml99rOf5ZxzzmHevHkA/OM//iP33nsvp556Km+99Rb9+vUDYMKECfTu3ZuJEydy2223pTwuH6ylfyPIyc1GAo+5+8lpjnsA+IO7/2f0eQNQ6e4ftef7KisrXevBimRnzZo1fPzjH8/4+MXLarn16bVsrGtgWFkp1597YkE0bpL972BmS9vT2GuR9z5YM+tLrKV7ddxmB54xMwd+4e4L8lI5EUlp5qTyggjUkPIesMBFwCsJ3QPT3H2jmQ0BnjWzN919SbLCZjYHmAMwYsSI8LUVEclQV5hoMAtYGL/B3TdGPzcBjwBTUxV29wXuXunulYMHt/uROSIiweQ1YM1sIHAG8Nu4bf3MrH/Le+AcIOlIBBGRrixYF4GZLQTOBAaZWQ0wDygGcPc7o8M+Bzzj7rvjig4FHolWtekNPODuT4Wqp4hIKMEC1t1nZ3DMPcSGc8VvWw9MDFMrEZHO0xX6YEVEgNh6rJdffvmBz01NTQwePJgLL7ywXecZOXIkH33U9ijPTI7pKAWsiHQZ/fr1Y9WqVTQ0xKbcPvvss5SXd9+hYApYEelSzjvvPB5//HEAFi5cyOzZrb2NW7duZebMmUyYMIFTTz2VFStWALBlyxbOOeccJk2axFe/+lXiJ1Ddd999TJ06lYqKCr761a926tRZBayIdCmzZs3iwQcfZM+ePaxYsYJTTjnlwL558+YxadIkVqxYwQ9+8AO+/OUvA3DzzTdz2mmnsWzZMi6++GLef/99IDYr66GHHuKVV145sLrW/fff32nX0hUmGohIV3PNNVBdndtzVlTA7benPWzChAls2LCBhQsXcv755x+07+WXX2bRokUAnH322WzZsoXt27ezZMkSHn74YQAuuOACjjjiCACee+45li5dypQpU4DYWgdDhgzJ3TWloYAVkS7n4osv5rrrruOFF15gy5YtB7YnWzul5UGFyR5Y6O585Stf4ZZbbglX2TYoYEXkUBm0NEO68sorGThwIOPHj+eFF144sP3000/n/vvv51vf+hYvvPACgwYNYsCAAQe233jjjTz55JNs27YNgM985jPMmDGDa6+9liFDhrB161Z27tzJcccd1ynXoYAVkS5n+PDhfOMb3zhk+0033cQVV1zBhAkT6Nu3L/feey8Q65udPXs2kydP5owzzjiwLsnYsWP53ve+xznnnMP+/fspLi7mjjvu6LSADbpcYWfTcoUi2WvvcoWFKpfLFWoUgYhIIApYEZFAFLAiIoEoYEXkgEK6J5ONXF+/AlZEACgpKWHLli09NmTdnS1btuT0Md8apiUiQGxoVE1NDZs3b853VfKmpKSE4cOH5+x8ClgRAaC4uJhRo0bluxoFRV0EIiKBKGBFRAJRwIqIBKKAFREJRAErIhKIAlZEJBAFrIhIIApYEZFAFLAiIoEoYEVEAgkWsGZ2t5ltMrNVKfafaWbbzaw6en07bt90M1trZuvMbG6oOoqIhBSyBXsPMD3NMS+5e0X0+g6AmRUBdwDnAWOB2WY2NmA9RUSCCBaw7r4E2JpF0anAOndf7+77gAeBGTmtnIhIJ8h3H+wnzWy5mT1pZuOibeXAB3HH1ETbRES6lXwuV/gGcJy77zKz84HFwBjAkhybcgVgM5sDzAEOPKpXRKQryFsL1t13uPuu6P0TQLGZDSLWYj027tDhwMY2zrPA3SvdvXLw4MFB6ywi0h55C1gzO9rMLHo/NarLFuBPwBgzG2VmfYBZwKP5qqeISLaCdRGY2ULgTGCQmdUA84BiAHe/E7gE+JqZNQENwCyPPQyoycyuBp4GioC73X11qHqKiIRihfSAs8rKSq+qqsp3NUSkwJjZUnevbG+5fI8iEBEpWApYEZFAFLAiIoEoYEVEAlHAiogEooAVEQlEASsiEogCVkQkEAWsiEggClgRkUAUsCIigShgRUQCUcCKiASigBURCUQBKyISiAJWRCQQBayISCAKWBGRQBSwIiKBKGBFRAJRwIqIBKKAFREJRAErIhKIAlZEJBAFrIhIIMEC1szuNrNNZrYqxf4vmdmK6PWqmU2M27fBzFaaWbWZVYWqo4hISCFbsPcA09vY/y5whrtPAL4LLEjYf5a7V7h7ZaD6iYgE1TvUid19iZmNbGP/q3EfXwOGh6qLiEg+dJU+2L8Dnoz77MAzZrbUzObkqU4iIh0SrAWbKTM7i1jAnha3eZq7bzSzIcCzZvamuy9JUX4OMAdgxIgRwesrIpKpvLZgzWwCcBcww923tGx3943Rz03AI8DUVOdw9wXuXunulYMHDw5dZRGRjOUtYM1sBPAwcLm7vxW3vZ+Z9W95D5wDJB2JICLSlQXrIjCzhcCZwCAzqwHmAcUA7n4n8G3gKOBnZgbQFI0YGAo8Em3rDTzg7k+FqqeISCghRxHMTrP/74G/T7J9PTDx0BIiIt1LVxlFICJScBSwIiKBKGBFRAJRwIqIBKKAFREJRAErIhKIAlZEJBAFrIhIIApYEZFAFLAiIoEoYEVEAlHAiogEooAVEQlEASsiEogCVkQkEAWsiEggClgRkUAUsCIigShgRUQCUcCKiASigBURCUQBKyISiAJWRCQQBayISCAKWBGRQIIFrJndbWabzGxViv1mZv9uZuvMbIWZTY7bN93M1kb75oaqo4hISCFbsPcA09vYfx4wJnrNAX4OYGZFwB3R/rHAbDMbG7CeIiJBBAtYd18CbG3jkBnArzzmNaDMzI4BpgLr3H29u+8DHoyOFRHpVvLZB1sOfBD3uSbalmq7iEi3ks+AtSTbvI3tyU9iNsfMqsysavPmzTmrnIhIR/Vua2f8jadk3P2NDnx3DXBs3OfhwEagT4rtqeqwAFgAUFlZmTKIRUQ6W5sBC/wo+lkCVALLibUwJwCvA6d14LsfBa42sweBU4Dt7v6hmW0GxpjZKKAWmAV8sQPfIyKSF20GrLufBRCF4Bx3Xxl9Phm4rq2yZrYQOBMYZGY1wDygODrvncATwPnAOqAeuCLa12RmVwNPA0XA3e6+OsvrExHJm3Qt2BYntYQrgLuvMrOKtgq4++w0+x34pxT7niAWwCIi3VamAbvGzO4C7iN2w+kyYE2wWomIFIBMA/YK4GvAN6LPS4gmBoiISHIZBay77zGzO4En3H1t4DqJiBSEjMbBmtnFQDXwVPS5wsweDVgvEZFuL9OJBvOITWGtA3D3amBkkBqJiBSITAO2yd23B62JiEiByfQm1yoz+yJQZGZjgH8GXg1XreysrN3OyLmPA3DZqSP43szxea6RiPRkmbZgvw6MA/YCDwDbgWsC1Skn7nvtfW5cvDL9gSIigWQUsO5e7+7/BzjT3ae4+43uvidw3Tps4esfpD9IRCSQTEcRfMrM/pdocoGZTTSznwWtWQ40u9Z+EZH8ybSL4DbgXGALgLsvB04PValcKbJkKx+KiHSOjNeDdffEv7ebc1yXnJt9yrHpDxIRCSTTUQQfmNmnADezPsRGEXTptQg0ikBE8i3TgL0K+AmxR7fUEltKMOlKWPk0vnwgVfMvyHc1RESAzNci+Aj4UuC6iIgUlExHERxvZr8zs81mtsnMfmtmx4eunIhId5bpTa4HgN8AxwDDgP8GFoaqlIhIIcg0YM3df+3uTdGrZeFtERFJIdObXH8ws7nAg8SC9VLgcTM7EsDdtwaqn4hIt5VpwF4a/ZwT/WwZwX8lscBVf6yISII2A9bMpgAfuPuo6PNXgC8AG4Cb1HIVEUktXR/sL4B9AGZ2OnALcC+x1bQWhK2aiEj3lq6LoCiulXopsMDdFwGLzKw6aM1ERLq5dC3YIjNrCeHPAM/H7cu0/1ZEpEdKF5ILgRfN7COgAXgJwMxOINZN0KXU1Tcybf7zbKxrYFhZKdefeyIzJ5Xnu1oi0kO1GbDu/n0ze47YBINn3A8ssNqL2FMOupTaugaa6hoOvL/h4dgTDRSyIpIPaScauPtr7v6Iu++O2/aWu7+RrqyZTTeztWa2LhpHm7j/ejOrjl6rzKy5ZWytmW0ws5XRvqpMLmZ/wgLbDY3N3Py71ZkUFRHJuYzXg20vMysC7gDOA8YCs81sbPwx7n6ru1e4ewVwA/BiwtCvs6L9ldnWY1t9I4uX1WZbXEQka8ECFpgKrHP39e6+j9gssBltHD+bQOsb3Pr02hCnFRFpU8iALQfin4JQE207hJn1BaYDi+I2O/CMmS01sznJykVl55hZlZlVNdcnv++2MeqXFRHpTCGHWiV7IFaqBWIuAl5J6B6Y5u4bzWwI8KyZvenuSw45ofsCokkPfYd9LOn5h5WVtq/mIiI5ELIFWwPEPxRrOLAxxbGzSOgecPeN0c9NwCPEuhzalOwpssVFxvXnnphZjUVEcihkwP4JGGNmo6LneM0CHk08yMwGAmcAv43b1s/M+re8B84BVmVVCy2qKCJ5Eixg3b0JuJrY87vWAL9x99VmdpWZXRV36OeIjbHdHbdtKPCymS0H/gg87u5PZVOPxv2um1wikhdBp7u6+xPAEwnb7kz4fA9wT8K29cDEXNVDN7lEJB9CdhF0GbrJJSL5UPABW1pcpJtcIpIXBR+wDY3N3Pr0Ws3mEpFOV/ABC60LvyhkRaQz9YiAhdaWrIhIZ+kxAQsaTSAinatHBaxGE4hIZ+pRAavRBCLSmXpUwH578cp8V0FEepAeFbA79jYz+obHNZpARDpFjwpYgGaHax6q5ka1ZkUksIIK2PHlAzM+9v7X3ldLVkSCKqiAXVmb+ZPEHT1KRkTCKqiAbS+NixWRkHp0wGpcrIiE1KMD9qyTBue7CiJSwIIuuN3V3ffa+9z32vuUlRZz08XjmDkp6UNvRUSy0qNbsC3qGhq5/r+Xa1SBiOSUAjaiZ3eJSK4VVMC2ZxxsMrUaVSAiOVRQAZsL0+Y/r64CEcmJggrY9kw0SEVPPxCRXCmogM0VPf1ARHJBAZtCbV0DFTc/o5asiGStoAN21NZaTl+/NOvyGr4lIh0RNGDNbLqZrTWzdWY2N8n+M81su5lVR69vZ1o2E3NeX8RPfvdDcM/6GjR8S0SyFSxgzawIuAM4DxgLzDazsUkOfcndK6LXd9pZtk2rjz6BI/bspHzH5qyvA2LdBRpdICLtFbIFOxVY5+7r3X0f8CAwoxPKHrBq6GgATv7LuvYWPYRGF4hIe4UM2HLgg7jPNdG2RJ80s+Vm9qSZjWtn2TatGTySJuvFuD+/096iSWl0gYi0R8jFXizJtsTO0DeA49x9l5mdDywGxmRYNvYlZnOAOQBFAw5eHWtv8WG8PWgEJ/8lNwELWkNWRDIXsgVbAxwb93k4sDH+AHff4e67ovdPAMVmNiiTsnHnWODule5eWdT30Kmyq4eOzmnAlvUtztm5RKSwhQzYPwFjzGyUmfUBZgGPxh9gZkebmUXvp0b12ZJJ2UytGjqaIbu3MXjX1g5cSqtde5rUDysiGQkWsO7eBFwNPA2sAX7j7qvN7Cozuyo67BJglZktB/4dmOUxSctmU49VR7fc6MpNK1bDtkQkU0EX3I7+7H8iYdudce9/Cvw007LZWDN4FPsxxv95HX8YPaWjpwPUDysimSnomVwAuw/ry7tHlue0H1bP8hKRTBR8wEKsHzZXQ7VKi4u4/twTc3IuESlsPSJgVx49mvKdmzmyPvvlDA0oLyvlls+P17O7RCQjPeKhh6uHngDAuL+8w0ujJre7fJEZ79xyfq6rJSIFrke0YFcPPR7IfiRBcwcWixGRnqtHBOyOksN5r+zorPthy0o1uUBE2q9HBCzEbnRl24Kta2jU4tsi0m49JmBXDx3NyLoPGbBnV1bl6xoatZqWiLRLjwnYlqULx/1lfdbn0GpaItIePSdgj24ZSdCxtWFrNYtLRDLUYwJ2a9+B1PYfnJMZXTcuXpmDGolIoesxAQuw+ujRnJyDGV33v/a++mJFJK0eFbCrho7m+K219N3XsT/zHdQXKyJp9biA7YXz8U3vdvhcWlFLRNLpcQELuVkbVitqiUg6PSpgNx1+JJv7leWkH/askwanP0hEerQeFbCYsXLoCTl5jPd9r72v2V0i0qaeFbDEugnGfPQ+hzXu7fC56hoaueahakbOfZxp859X2IrIQXpcwK4+ejS9fT8nbd6Q0/PW1jVoKq2IHKTHBeyqaG3Yig/fyvm5NZVWROL1uICtHTCYVUNHM+f1hylp3JPz82v4loi06HEBixk3fXYO5Ts387XX/l/OTx9q+NbiZbVMm/88o9TfK9Jt9LyABaqGj2Px2DO46vVFDK/7c87OG+qBiIuX1XLDwyuprWvAUX+vSHfRIwMW4JYzr6CpVxE3/uG/OnSeIjMg7AMRb316LQ2NzQdtU3+vSNfXIx56mMxf+g/ijk/+Df+65Fec9u4yXh41KavzdMbDEFP166q/V6RrC9qCNbPpZrbWzNaZ2dwk+79kZiui16tmNjFu3wYzW2lm1WZWFaJ+d035HBvKjuGm3/+C3s1NWZ2jM/5MT9Wvq+m6Il1bsIA1syLgDuA8YCww28zGJhz2LnCGu08AvgssSNh/lrtXuHtliDru613Mdz7zD5ywtYavvPFYVudI1Reay5tS1597IqXFRQdtC9XfKyK5E7IFOxVY5+7r3X0f8CAwI/4Ad3/V3bdFH18DhgesT1LPj57CH47/BN94+QEG7d6WvkCCZH2hub4pNXNSObd8fjzlZaUYYft7RSR3QgZsOfBB3OeaaFsqfwc8GffZgWfMbKmZzQlQvxgzvvOZOZQ07eObL9yb1SkS+0JD3JSaOamcV+aezbvzL+CVuWcrXEW6gZABa0m2edIDzc4iFrDfjNs8zd0nE+ti+CczOz1F2TlmVmVmVc3127Oq6LtHlvNfU2by16t+z78s+TXm+9tVPrEvNNXNp9q6Bg2tEulBQo4iqAGOjfs8HNiYeJCZTQDuAs5z9y0t2919Y/Rzk5k9QqzLYUlieXdfQNR3e9gxY5IGeCZ+9OnLOKJhB//8Pw8xattGrrvgWvb27pO2XHEv46yTBjNt/vNsrGtgWFkpA0uLqWtoTHr8tQ9VU/XeVr43c3y2VT3I4mW13Pr02gPfff25J6p1K9JFhGzB/gkYY2ajzKwPMAt4NP4AMxsBPAxc7u5vxW3vZ2b9W94D5wCr0n3hYb0Pvpyh/fsc1G85Zki/lGWbinozd/rXueXMv+WiN1/igYX/xlG769JeZJ/evVi0tPag/tbd+5oo7pWsAR9rwufqmV6agCDStZl71o2+9Cc3Ox+4HSgC7nb375vZVQDufqeZ3QV8AXgvKtLk7pVmdjzwSLStN/CAu38/3fdVVlZ6VVXqEV2Ll9Vy7UPVyfsp4kxf+wq3P/YjNvU7gisvmce6QSPSffUh+hb3or4xdVdDeVkpr8w9u93njTdt/vNJHyOei3OLSCszW5rNaKagAdvZ2grYltZe4s2nVCZuXMtdD3+Xw5oa+eb0r/PkidPAkrdKs7Vh/gUdKj9q7uNJ/7Ew4N0OnltEWmUbsAU7kyuxb7J+X1PG4QqwfNiJzLz8x/znw9/l57+dz/Kjx/DjT1/Gi6Mm5yRoLapjR/pLh5WVJm3BagKCSNdQkGsRJOub3Faf/KYTQFGK/tLagUO46Cu3c/15/8xR9du597/nsXjhN/nkeys6XMf4R39nOylBExBEuraC7CJI1TeZymWnjuCRN2rZvS91C3dAr/38ylYz7Kc/YsiOj/ifEeNZOPFcfn/CKdT3ya7FaMBtl1Yc0nVRWlyU8USC+Jb6wNJizKCuvlEjCkRySH2wtAZsqr7JVEqLi/jCJ8pZtLT2oKAzYi3N8riwOvG6R/hi9ZP8wx8fYdjOj2jofRjPjZ7C7z5+Oi8c/wn2Fh8GQC+D/WkqUR79KZ+LG1XJ+pjbE9Qikpr6YOOk6pssKy1m554mmhP+UWlobOYPb27mls+PTzumdNCggfyycgb3fOIiPlG7hovWLOH8N1/hwrUvs7NPKS8eX8mmyadw3OfP59tv7Wfj9j2U9S1m154mGuMSt+VP+Wsfqk56De1dKaut2WMKWJH8KMgWbFutuVTDtDK9857s3IcXwS+O3cm0qt/DU09BbdSHOngwnH46nHEGLw44ju+8V8T6eg4K71wNtdKIApFw1IKN09JiS9YavfXptR26857q3NMmlQOzwB3eeQdefLH1tWgRZwDPmcHHPgYVFeATYeMEbvr4AP7l9Xp27m+90ZbNjSqNKBDpegqyBduWkH2VKaetvvceLFsGy5dDdXXstWHDgXL7e/emZuBQ3i4bxkdHj+Dj0yYy4VMTYMQIOO44OOKItEPD2rouSP6PjYhkRje5yCxgIcz8/XQTGcpKi7np4nGt31NXB6tXw9tvx15vvdX6vr7+4ML9+sXCdtgwOOaY2Kvl/dChPLfF+fGybazZ1xsr6k2z+4Ebc4Bufol0kAKWzAM2hEyGhhX3Mm7964ltB5s7fPRRrNX7/vuxn++9Bx98AB9+CBs3xn7u23dI0WbrxbbS/tT1HUjZsccw6Lhj+F3NHjb26ktdaX/qSvqz47B+7CjpR59BR/Ff1/wVlJXBwIHQJ/3CNiI9lfpg8yyTu/6N+z39XX2z2M2xwYOhMsXv0x22bYMPP+Trtz+Fb9rEUfXbObJ+O4Pq6ziyfgdD63YzqOkdprxbyxENOzmsOclEi5/FvS8pgQEDYmE7YEDrq3//Q1/9+sHhh7e++vU79FVSkvOpxSLdjQI2iWy6EFLdZEqU6QSINutgBkceCUceyWNHbcCPOumQ8i2jB74w/3lqt9VT0rSXsoZdDNi7iwF7dzOqqJFb/+q4WFDv2AHbtx/68913YefO1tfevRnVHYBevaBv39ZXv34Hfy4tPfRnuldJyaE/W169eyvQpctRwCZI7EttWQIQaDNkrz/3xIwWk0m2BkFimJ510uCDJj20VYd0owcO1MuMPxeX8GcGUVpcxGWfHw/t7YNtbIRdu5K/du8+9FVf3/pq+bx7N2zeDA0Nsc/xPxtTT2dOq1evgwO3pAQOOyz158MOa/0c/zPxlWx7/LY+fQ7dX1SUvr7SI6gPNkFHxqW2BGW6Vmr8uZLdHGuZQZZJHTIZFdFtFuVubo4Fbfxrz57k7/fubd3Wsn3v3tbPidvj97W8T/yZK0VFyYM33baW98m2Jdvfp0/7j1UrPyvqg82RVH2pmfSxzpxUflCoXZPBLK1kM7BS/ZMXH9yJaxCUFPdKuQZBfL1aysY/gaHLBG5RUWu/bmdzj7WgW8I4PnwTX4nb9+079JhMtm3b1rotcV/L51w3gIqLk4dvquBu7zGZvE/1s7i44P4BUMAmyNWA/UwnNbRnSmxR9B9fYqu1rqGR0uIibru0Im1QZtsFUvDMWoOgf/981ybGPdaqjw/dZIGcaltb2xP3Jf7csaPtY/ft61iXTiodCfdsj83kPFlSwCZI1pea7RKAmZwr05tjwIE1FDqy7oDWLOhGzGI373r3jt0k7GrcDw3ddMG9d2/rXwrpjk08d/y27dvTH9uc+frPoShgE7Q1zTbEuZKFcFt9sNCxboyOlBU5iFlrC7Aram5OH/pt/UMQ//6GG7KqggI2icQ+y5DnShbCiaMI4OCWb7pujLZuamnNAukxiopah/h1VJYBq1EEXVRbIZlu3YFkw8WO6FvMvIvGJd2vqbMibdNUWQorYNNJFcBtTdnV4i8i2VHA0rMCNpV0T3PQI71F2i/bgC3Ihx72ZOn6UnUzS6TzKGALTLInzcbTzSyRzqOALTAzJ5Vzy+fHU1ZafMg+PdJbpHMpYAvQzEnlVM87h9svraC8rBQj1veqkQIinSvoTS4zmw78BCgC7nL3+Qn7Ldp/PlAP/K27v5FJ2WQOH36iD77sx7ozLiI51eVucplZEXAHcB4wFphtZmMTDjsPGBO95gA/b0fZQzQ278dpnV+/eFltri5HRKTdQnYRTAXWuft6d98HPAjMSDhmBvArj3kNKDOzYzIs26aW+fUiIvkSMmDLgQ/iPtdE2zI5JpOyAJjZHDOrMrOq5vrtB+3TkCQRyaeQAZtsYcfEDt9Ux2RSNrbRfYG7V7p7ZVHfgQft05AkEcmnkIu91ADHxn0eDmzM8Jg+GZRtk4YkiUi+hWzB/gkYY2ajzKwPMAt4NOGYR4EvW8ypwHZ3/zDDsocoLuqlIUki0mUEa8G6e5OZXQ08TWyo1d3uvtrMror23wk8QWyI1jpiw7SuaKtsuu886ej+VM2/IMj1iIi0lxZ7ERFJo8uNgxUR6ekUsCIigShgRUQCUcCKiASigBURCUQBKyISiAJWRCSQghoHa2Y7gUJdQmsQ8FG+KxGQrq97K/TrO9Hd+7e3UMi1CPJhbTaDgbsDM6sq1GsDXV931xOuL5ty6iIQEQlEASsiEkihBeyCfFcgoEK+NtD1dXe6viQK6iaXiEhXUmgtWBGRLqPbBayZTTeztWa2zszmJtlvZvbv0f4VZjY5H/XMVgbXd5KZ/Y+Z7TWz6/JRx47I4Pq+FP3eVpjZq2Y2MR/1zFYG1zcjurbq6Flyp+WjntlId21xx00xs2Yzu6Qz69dRGfzuzjSz7dHvrtrMvp32pO7ebV7EFt9+Bzie2GNllgNjE445H3iS2HO9TgVez3e9c3x9Q4ApwPeB6/Jd5wDX9yngiOj9eQX4+zuc1q65CcCb+a53rq4t7rjniS2mf0m+653j392ZwGPtOW93a8F25FHg3UHa63P3Te7+J6AxHxXsoEyu71V33xZ9fI3Y89i6i0yub5dH/28F+pHiYZ5dUCb/3wP4OrAI2NSZlcuBTK+vXbpbwHbkUeDdQXeueybae31/R+yvke4io+szs8+Z2ZvA48CVnVS3jkp7bWZWDnwOuLMT65Urmf63+UkzW25mT5rZuHQn7W4B25FHgXcH3bnumcj4+szsLGIB+82gNcqtjK7P3R9x95OAmcB3Q1cqRzK5ttuBb7p7c/jq5Fwm1/cGcJy7TwT+A1ic7qTdLWA78ijw7qA71z0TGV2fmU0A7gJmuPuWTqpbLrTr9+fuS4DRZjYodMVyIJNrqwQeNLMNwCXAz8xsZqfUruPSXp+773D3XdH7J4DitL+7fHcut7MjujewHhhFa0f0uIRjLuDgm1x/zHe9c3l9ccfeRPe7yZXJ728EsacMfyrf9Q10fSfQepNrMlDb8rkrv9rz32Z0/D10r5tcmfzujo773U0F3k/3u+tWi714Bx4F3h1kcn1mdjRQBQwA9pvZNcTudu7IV70zleHv79vAUcRaPwBN3k0WEcnw+r4AfNnMGoEG4FKP/h/blWV4bd1Whtd3CfA1M2si9ruble53p5lcIiKBdLc+WBGRbkMBKyISiAJWRCQQBayISCAKWBGRQBSwEpyZDTez35rZ22b2jpn9xMz65LteIZjZ7WZ2evT+/mjlrB/E7f+Wmc2I+3yhmd2cj7pKeApYCcpig1kfBha7+xjgY8RWlPp+XisWgJkdCZzq7kui2Wi4+wTg02Y2MFp0aKq7/zau2OPAxWbWNw9VlsAUsBLa2cAed/8lgMfmqV8LXGlmfc2syMx+aGYro9be1+HAmqKvRgtr/NHM+pvZ35rZT1tObGaPmdmZ0ftdZvYjM3vDzJ4zs8HR9n8wsz9F51nUEmRmdo/F1g1+1czWx69damb/GtVnuZnNN7PRZvZG3P4xZrY0ybVeAjwVvW8ESs2sF7GZQc3Ad4hNpDggGqj+AnBhtv8DS9elgJXQxgEHhVE06+x9YtNG5xCbnjgpau3dH3UfPAR8w2MLa3yW2MyZtvQD3nD3ycCLwLxo+8PuPiU6zxpiC8i0OAY4jVi4zQcws/OILcJySlTm/7r7O8B2M6uIyl1BbCpoomkt1+rua6JrfAP4Da1TZJclKVcFfDrN9Uk31K2mykq3ZCRfMatl+2eBO929CcDdt5rZeOBDj6172xLIRFNnU9lPLJQB7iPWLQFwspl9Dygj1jXxdFyZxe6+H/hfMxsabfss8Et3r2+pT7T9LuAKM/sX4FJic9ETHQNsbvng7tccuFiz3wFfNbP/A0wEnnX3/4x2bwKGtXVx0j2pBSuhrSa2ytIBZjaA2MpF75A8gFOFchMH/zdb0sb3tpS/B7ja3ccDNyeU2ZvwnW199yJiT1i4EFjqyVf5akhWp+imVhWxVvbJ7v43wOVx/a4lpG+hSzekgJXQngP6mtmXAcysCPgRcE/USnwGuMrMekf7jwTeBIaZ2ZRoW/9o/wagwsx6mdmxHNyK7EWsDxTgi8DL0fv+wIdmVgx8KYP6PkPUPxxXH9x9D7HW78+BX6You4ZYV8AB0fd+A7gV6EtreLf0zULsxt+qDOom3YwCVoKKbuJ8DvhrM3sbeAvYA/xbdMhdxPoqV5jZcuCLHntkx6XAf0TbniXWynsFeBdYCfyQWP9mi93AuOjm09nEbigBfAt4PTrHmxnU9yngUaDKzKqB+AdL3k8sIJ9JUfxxYs9tivdPwL3RPyYriA2sWAm84u510TFnRWWlwGg1LSkIZrbL3Q8P/B3XAQPd/VttHPMycGFceKY751DgAXf/TG5qKV2JAlYKQuiANbNHgNHA2e7+URvHnQI0uPuKDM87BWh09+qcVFS6FAWsiEgg6oMVEQlEASsiEogCVkQkEAWsiEggClgRkUAUsCIigfx/h4tWKzeklvQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "krrs = [fit_model_detector(df_zurich, detector_id) for detector_id in sensors]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "42b0efbc-dc48-4504-a978-aa69d23baae8",
   "metadata": {},
   "outputs": [],
   "source": [
    "sensors = [\"K418D12\", \"K582D11\", \"K324D11\"]\n",
    "distance_sensors = [1.2, 0.9, 2.1]\n",
    "capacity = [17000., 10000., 17000.]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "6ded1d3c-c8ae-4328-a655-0de1a990d8ce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5eefe15880>"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhsAAAIICAYAAADHZSyIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAABOFElEQVR4nO3dd7xcZYH/8c8zfW7vIZWEkIQkBAJGOgiKQgBBLAvCWlEXFVx1V3D7+sJde28IiKjrT0BhFQXpAgIihCWQhBBIIclNvb1Pf35/nJm5JTfJ3GTKvWe+79frvE6ZM2eeO4Tcb55qrLWIiIiIFIqn1AUQERERd1PYEBERkYJS2BAREZGCUtgQERGRglLYEBERkYJS2BAREZGC8pXqg5uamuzcuXNL9fEiIiKSR88//3y7tbZ5vNdKFjbmzp3LqlWrSvXxIiIikkfGmK37e03NKCIiIlJQChsiIiJSUAobIiIiUlAl67MhIiJSbPF4nNbWViKRSKmLMmWFQiFmzZqF3+/P+T0KGyIiUjZaW1uprq5m7ty5GGNKXZwpx1pLR0cHra2tzJs3L+f3qRlFRETKRiQSobGxUUHjEBljaGxsnHDNkMKGiIiUFQWNw3Mo35/ChoiISBFVVVVlj++77z4WLFjAtm3bstd+85vfYIwZNRfV+eefT11dHRdddNGoZz3yyCOceOKJLF++nDPOOIONGzcCcNttt9Hc3MwJJ5zAggULOO+883j66aez7/v1r3/N0qVL8Xg8oz7noYce4g1veAPLli3jDW94A48++mhefmaFDRERkRJ45JFHuPbaa7n//vuZM2cOAH19fXz3u9/l5JNPHnXv5z73OX7xi1/s84yPf/zj/PKXv2T16tVcccUVfPGLX8y+dtlll/HCCy/w2muv8fnPf553vvOdrF+/HoBjjz2Wu+++m7POOmvU85qamvj973/PmjVr+NnPfsb73ve+vPysChsiIiJF9uc//5mPfvSj3HvvvcyfPz97/d/+7d+47rrrCIVCo+5/y1veQnV19T7PMcbQ29sLQE9PDzNmzBj388455xw+9rGPcdNNNwGwePFiFi1atM99J5xwQvYZS5cuJRKJEI1GD+2HHEGjUUREpCx94ffreHlnb16fuWRGDf/x9qUHvCcajXLJJZfw2GOPccwxx2Svv/DCC2zfvp2LLrqIr3/96zl93i233MIFF1xAOBympqaGZ555Zr/3nnjiifz4xz/O7QcB7rrrLk444QSCwWDO79kf1WyIiIgUkd/v57TTTuMnP/lJ9loqleIzn/kM3/jGNyb0rG9961vcd999tLa28qEPfYjPfvaz+73XWpvzc9etW8f1118/oXByIKrZEBGRsnSwGohC8Xg83HnnnZx77rn893//N//8z/9MX18fa9eu5eyzzwZg9+7dXHzxxdxzzz2sWLFi3Oe0tbXx4osvZvt3XHbZZZx//vn7/dwXXniBxYsXH7R8ra2tXHrppfz85z8f1cRzOBQ2REREiqyiooI//OEPnHnmmUybNo2rrrqK9vb27Otnn302X//61/cbNADq6+vp6enh1VdfZeHChTz00EP7DROPP/44N910E3/6058OWK7u7m4uvPBCvvSlL3H66acf2g83DoUNERGREmhoaOD+++/nrLPOoqmpiUsuuWS/95555pm88sor9Pf3M2vWLH7yk59w3nnncfPNN/Oud70Lj8dDfX09t956a/Y9d9xxB08++SSDg4PMmzePu+66KxtG/vd//5drr72WtrY2LrzwQpYvX84DDzzA97//fTZu3MgNN9zADTfcAMCDDz5IS0vLYf2sZiJtOPm0YsUKO3Jsr4iISKGtX78+p6YEObDxvkdjzPPW2nGrYtRBVERERApKYUNEREQKSmFDRERECsp9YeNX74Wfvb3UpRAREZE094WNZByifaUuhYiIiKS5L2x4A07gEBERkUnBfWHDF4BkrNSlEBERGdf+lpjPLAu/fPlyli9fzi233JK977rrrmPp0qUsXryYT33qU9mpx6+88koWLVrEsccey4c//GHicecf24e6xHxHRwfnnHMOVVVVXHPNNXn7md0XNrwKGyIiMvmNt8T8ZZddxurVq1m9ejUf+chHAHj66ad56qmneOmll1i7di3PPfccjz/+OOCEjVdeeYU1a9YwNDQ0KqAcyhLzoVCIG264IeeF4HLlwrDhVzOKiIhMavtbYn48xhgikQixWIxoNEo8HmfatGkAXHDBBRhjMMZw0kkn0draOu4zcl1ivrKykjPOOGOfJe4Pl/umK/cGIBEtdSlERGSy++PnYfea/D7ziGWw8ssHvGV/S8yDs6z7E088wcKFC/nWt77F7NmzOfXUUznnnHOYPn061lquueaafWbvjMfj/OIXv+A73/nOfj93okvM55MLazbUQVRERCav8ZaYB3j729/O66+/zksvvcS5557LBz7wAQA2btzI+vXraW1tZceOHTz66KM88cQTo977iU98grPOOoszzzxzv59bquVJwK01G+qzISIiB3OQGohCGW+JeYDGxsbsPR/96Ee5/vrrAWfRtFNOOSXbsXTlypU888wz2f4WX/jCF2hraztorUWuS8wXgktrNhQ2RERk8sosMf/LX/4yW8Oxa9eu7Ov33HNPNhjMmTOHxx9/nEQiQTwe5/HHH8++dsstt/DAAw/wq1/9Co9n/7/SM0vMf/SjHy3gT7V/7qzZsElIJcHjLXVpRERExjV2iflnnnmGe+65B5/PR0NDA7fddhsA7373u3n00UdZtmwZxhjOP/983v52Z6bsq6++miOPPJJTTz0VgHe+8538+7//O3BoS8wDzJ07l97eXmKxGL/97W958MEHWbJkyWH9rO5bYv7P34RHvgD/shv84fw/X0REpiwtMZ8fWmLeG3D2akoRERGZFNwXNnxBZ68RKSIiIpOC+8KG1+/sVbMhIiIyKbgwbKgZRUREZDJxb9hIKGyIiIhMBi4MG2pGERERmUxcGDYyHUQVNkREZPLZ3xLzN954I8uWLWP58uWcccYZvPzyywCsXr2aU089laVLl3Lcccdxxx137PPMa6+9dtRztcR8oWVrNjQaRUREJq+xS8xfccUVrFmzhtWrV3Pdddfx2c9+FnBmG/35z3/OunXruP/++/n0pz9Nd3d39jmrVq0adZ6hJeYLSR1ERURkkhtvifmamprs6wMDAxhjAFi4cCELFiwAYMaMGbS0tNDW1gZAMpnkc5/7HF/96lcP+HlaYj7fsmFDy8yLiMj+feXZr/BK5yt5feYxDcdw/UnXH/CeAy0x/4Mf/IBvfvObxGIxHn300X3e++yzzxKLxbIB5fvf/z4XX3wx06dPP2jZtMR8PqkZRUREJrH9LTEP8MlPfpJNmzbxla98hS9+8YujXtu1axfve9/7+OlPf4rH42Hnzp38+te/5tprr83pc7XEfD751EFUREQO7mA1EIWyvyXmR7r88sv5+Mc/nj3v7e3lwgsv5Itf/CKnnHIK4CwZv3HjRo4++mgABgcHOfroo9m4ceO4n1vKJebdFzayzSiq2RARkckps8T8mWeeybRp07jqqqt47bXXsn0z7r33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\n",
      "text/plain": [
       "<Figure size 648x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(9,9))\n",
    "for detid, krr_sensor, cap, distance_sensor in zip(sensors, krrs, capacity, distance_sensors):\n",
    "    xpred=np.linspace(0.01, 1.0, 100)\n",
    "    ypred = krr.predict(xpred.reshape(-1, 1))\n",
    "    plt.plot(xpred, (ypred / xpred / cap) / distance_sensor, label=detid)\n",
    "    \n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "8035fdc0-82b3-402f-9b4b-54f04de5397f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import dill as pickle\n",
    "\n",
    "with open(\"utd_models.pkl\", 'wb') as f:  # open a text file\n",
    "    state_dict = {\"sensors\": sensors, \"distances\": distance_sensors, \"capacity\": capacity, \"fitted_models\": krrs}\n",
    "    pickle.dump(state_dict, f) # serialize the list"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f136aa8-ddd8-4ee7-a87b-5a079a28aee9",
   "metadata": {},
   "source": [
    "# Test reading"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "9f3f1141-03c1-4a0f-88d1-5959e221b9cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "from smfg.problems import PopulationBanditsProblem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "3f871b78-baa5-4c1b-be9d-d2f2a188f2fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_utd_problem(file_name):\n",
    "    with open(file_name, 'rb') as f: \n",
    "        data = pickle.load(f)\n",
    "        \n",
    "    models = data[\"fitted_models\"]\n",
    "    distances = data[\"distances\"]\n",
    "    capacity = data[\"capacity\"]\n",
    "    sensors = data[\"sensors\"]\n",
    "    \n",
    "    operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1)[0] / x[i] / c) / d \n",
    "                                                    for i,(m,d,c) in enumerate(zip(models, distances, capacity))]),\n",
    "                                           nan=0., posinf=2., neginf=0.)\n",
    "    \n",
    "    return PopulationBanditsProblem(operator_utd, {\"data\":data})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "942beb4e-eabc-4bc7-9a8c-4ebfee1a0c35",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = load_utd_problem(\"utd_models.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "83a64b22-8fd0-481a-90f8-88566469ac6d",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n",
      "<ipython-input-97-7298c502aadd>:10: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  operator_utd = lambda x: np.nan_to_num(np.array([(m.predict(np.array(x[i]).reshape(-1,1)).reshape(-1) / x[i] / c) / d\n"
     ]
    }
   ],
   "source": [
    "r1 = []\n",
    "for x in np.linspace(0.,1.,100):\n",
    "    r1.append(p.operator([x, 0, 0])[0])\n",
    "    \n",
    "r2 = []\n",
    "for x in np.linspace(0.,1.,100):\n",
    "    r2.append(p.operator([0, x, 0])[1])\n",
    "    \n",
    "r3 = []\n",
    "for x in np.linspace(0.,1.,100):\n",
    "    r3.append(p.operator([0, 0, x])[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "5b135510-b266-4a15-88fc-f5d72e502f4e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f5eeed2c520>]"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAD4CAYAAADiry33AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAsHklEQVR4nO3de5RkVX3o8e/vPKqqq9890zMM82AGHEUgvBwRAiLgI4PRoMGlEB/RpZn44CZmGW/U3Ku5GtdNlpqoER1ZSIhXBZMICAYEogkYUTMDMjIIg8PMwDTz6pmeflbX+3f/OKeqq7urumt6uqd6Tv0+a511ztl7n6p9oOe3d+19HqKqGGOMiS6n0RUwxhizsCzQG2NMxFmgN8aYiLNAb4wxEWeB3hhjIs5rdAWqWbp0qa5du7bR1TDGmJPGo48+elhVe6vlLcpAv3btWrZu3droahhjzElDRJ6rlWdDN8YYE3EW6I0xJuIs0BtjTMRZoDfGmIizQG+MMRE3a6AXkdUi8h8i8pSIPCkif1qljIjIl0Vkp4j8SkQurMjbKCI7wryPzfcJGGOMmVk9Pfo88BFVfSlwMfAhETlrSpmrgfXhsgn4GoCIuMCNYf5ZwPVVjjXGGLOAZg30qrpfVR8Lt0eAp4CVU4pdA3xTAz8HukRkBXARsFNVd6lqFrg9LLsg/vIff59v3fe3C/XxxhhzUjqmMXoRWQtcAPxiStZKYG/Ffl+YViu92mdvEpGtIrK1v7//WKpV9iA7+OULP57TscYYE1V1B3oRaQO+B3xYVYenZlc5RGdIn56oepOqblDVDb29Ve/inZWrUNDcnI41xpioqusRCCLiEwT5b6vqHVWK9AGrK/ZXAfuAWI30BeEiFDW/UB9vjDEnpXquuhHgG8BTqvp3NYrdDbwrvPrmYmBIVfcDW4D1IrJORGLAdWHZBeEpFCzQG2PMJPX06C8F3gk8ISKPh2mfANYAqOpm4F7g9cBOIAW8J8zLi8gNwP2AC9yiqk/O5wlUsh69McZMN2ugV9X/ovpYe2UZBT5UI+9egoZgwbkqFCmciK8yxpiTRqTujHVwLNAbY8wUkQr0LkKRYqOrYYwxi0q0Ar26FCzQG2PMJJEK9I441qM3xpgpIhXoXVyKYoHeGGMqRSrQO7gUqt94a4wxTStagV48CgKoBXtjjCmJVKB3xSMnQD7T6KoYY8yiEalA74hHHoFcqtFVMcaYRSNSgd51fPIC5NONrooxxiwa0Qr04pMToZgdb3RVjDFm0YhWoHdj5BFy6bFGV8UYYxaNaAV6J0ZOIJexMXpjjCmJVKD3nBh5EXLp0UZXxRhjFo1IBXrXS5BHKGRsjN4YY0oiFeh9N05OoJC1oRtjjCmZ9cUjInIL8AbgkKqeUyX/o8DbKz7vpUCvqg6IyB5gBCgAeVXdMF8Vr8bzEqgIGRu6McaYsnp69LcCG2tlqurnVPV8VT0f+DjwkKoOVBS5Msxf0CAP4HsJALJZu+rGGGNKZg30qvowMDBbudD1wG3HVaPj4PlJAPIZ69EbY0zJvI3Ri0iSoOf/vYpkBR4QkUdFZNMsx28Ska0isrW/v39OdYiHgT5rY/TGGFM2n5OxbwR+OmXY5lJVvRC4GviQiFxe62BVvUlVN6jqht7e3jlVIOa3AJDL29CNMcaUzGegv44pwzaqui9cHwLuBC6ax++bJu75AORzdnmlMcaUzEugF5FO4FXA9yvSWkWkvbQNvA7YPh/fV0vCjwGQL1igN8aYknour7wNuAJYKiJ9wKcAH0BVN4fF3gw8oKqVYybLgTtFpPQ931HVH85f1acr9egL1qM3xpiyWQO9ql5fR5lbCS7DrEzbBZw314rNRYsX9OgLBXvxiDHGlETqzthEOdDb8+iNMaYkUoG+JRyjLxatR2+MMSXRCvRhj75oQzfGGFMWqUAfCydji5ptcE2MMWbxiFSg950g0KsFemOMKYtUoPec4CKiYjHX4JoYY8ziEclAr2qB3hhjSiIV6MtDN+QbXBNjjFk8IhXoyz168qDa4NoYY8ziEKlAX+rRF1Ao2ISsMcZAxAJ9qUefEwF73o0xxgARC/SlHn1eBPL2GARjjIGIBvqcADl7y5QxxkDEAn1p6CaPQM569MYYA1EN9IKN0RtjTChSgd4RB1EJJmPzFuiNMQbqCPQicouIHBKRqq8BFJErRGRIRB4Pl09W5G0UkR0islNEPjafFa/FETccurFAb4wxUF+P/lZg4yxlfqKq54fLpwFExAVuBK4GzgKuF5Gzjqey9XBxw8lYC/TGGAN1BHpVfRgYmMNnXwTsVNVdGjxO8nbgmjl8zjFxcMOhG5uMNcYYmL8x+ktEZJuI3CciZ4dpK4G9FWX6wrSqRGSTiGwVka39/f1zrogjXjh0Y5dXGmMMzE+gfww4TVXPA/4BuCtMlyplaz6ARlVvUtUNqrqht7d3zpVxxScnUMza0I0xxsA8BHpVHVbV0XD7XsAXkaUEPfjVFUVXAfuO9/tm44hHXoRCxnr0xhgD8xDoReQUEZFw+6LwM48AW4D1IrJORGLAdcDdx/t9s3Edn5wIhawFemOMAfBmKyAitwFXAEtFpA/4FOADqOpm4C3AB0QkD4wD16mqAnkRuQG4H3CBW1T1yQU5iwqu45HFsR69McaEZg30qnr9LPlfAb5SI+9e4N65VW1uPPHJiEPRLq80xhggYnfGQvAYhAwOaoHeGGOACAZ63/HIiYPaGL0xxgARDPSe45MVx55eaYwxocgFet/1ydkNU8YYUxa5QB8LL6+0RyAYY0wgcoE+GKMHsccUG2MMEMVA7/rkERzr0RtjDBDBQB93ffICUrBAb4wxEMFAH3N9CgKuDd0YYwwQwUAf92IUAKeQaXRVjDFmUYhcoI+5HgVRvKIN3RhjDEQw0Me9YOjG0QIUco2ujjHGNFzkAn3CjVGUYrBjz7sxxpjoBXrf9VEJX2Vlgd4YY6IX6D0nePJyHsCuvDHGmNkDvYjcIiKHRGR7jfy3i8ivwuURETmvIm+PiDwhIo+LyNb5rHgtvuMDBI9BsB69McbU1aO/Fdg4Q/5u4FWqei7wGeCmKflXqur5qrphblU8NqUefU6wQG+MMdT3hqmHRWTtDPmPVOz+nOAl4A1T7tFjPXpjjIH5H6N/L3Bfxb4CD4jIoyKyaaYDRWSTiGwVka39/f1zrkB5jF7ExuiNMYY6evT1EpErCQL9ZRXJl6rqPhFZBjwoIk+r6sPVjlfVmwiHfTZs2KBzrcdEoMdePmKMMcxTj15EzgVuBq5R1SOldFXdF64PAXcCF83H983EJmONMWay4w70IrIGuAN4p6o+U5HeKiLtpW3gdUDVK3fm08TllTZ0Y4wxUMfQjYjcBlwBLBWRPuBTgA+gqpuBTwJLgK+KCEA+vMJmOXBnmOYB31HVHy7AOUwy0aPHevTGGEN9V91cP0v++4D3VUnfBZw3/YiFNWky1gK9McZE+c5YC/TGGAMRDPSloZuUeDZGb4wxRDjQj4tvl1caYwwRDvRjeJAba3BtjDGm8SIX6Etj9CPEIT3c4NoYY0zjRTjQJyA92NjKGGPMIhC5QF8auhmSOJo62uDaGGNM40Uu0Jd69KPEUOvRG2NM9AJ9eTJWYsj4YGMrY4wxi0DkAn2pRz9GDMmOQCHf4BoZY0xjRTjQBz170kMNrI0xxjRe5AL9xJ2xYaAftwlZY0xzi1ygL/XoxyV8XptNyBpjmlzkAr0rLoKQxg0SbELWGNPkIhfoRQRXPNJSCvQ2dGOMaW6RC/RAEOixoRtjjIE6Ar2I3CIih0Sk6msAJfBlEdkpIr8SkQsr8jaKyI4w72PzWfGZeI5HVsJTsx69MabJ1dOjvxXYOEP+1cD6cNkEfA1ARFzgxjD/LOB6ETnreCpbL8/xKIqSd5M2Rm+MaXqzBnpVfRgYmKHINcA3NfBzoEtEVgAXATtVdZeqZoHbw7ILznN8RPJkYx3WozfGNL35GKNfCeyt2O8L02qlVyUim0Rkq4hs7e/vP64K+Y4HUiTrddgYvTGm6c1HoJcqaTpDelWqepOqblDVDb29vcdVoeBa+gJpr8OGbowxTc+bh8/oA1ZX7K8C9gGxGukLLubGQAqk3Q4Y338ivtIYYxat+ejR3w28K7z65mJgSFX3A1uA9SKyTkRiwHVh2QXnOx4iBVJuuw3dGGOa3qw9ehG5DbgCWCoifcCnIHhimKpuBu4FXg/sBFLAe8K8vIjcANwPuMAtqvrkApzDNDHXB0mTctptMtYY0/RmDfSqev0s+Qp8qEbevQQNwQnlOz7ipBhz2iGfhlwa/MSJroYxxiwKkbwz1nM8HCky6rQFCTZ8Y4xpYpEM9L7j4zgFRiQM9DZ8Y4xpYpEM9J7jIVJkSEuBfrCh9THGmEaKZKD3HR/HLXAo3xIkWI/eGNPEIhnoPcfDcYrsz4QTsDZGb4xpYtEN9FJkbzoeJFiP3hjTxCIZ6H3HBymwd8wDxMbojTFNLZKB3nM8kAKD6QKa6LShG2NMU4tkoPcdHyUPQDHeaUM3xpimFslA7zkeSgGAXKzLhm6MMU0tsoG+qEGgT3v2vBtjTHOLZKD3HZ+85gAl5drLR4wxzS2SgT548QhAkVFptaEbY0xTi2Sg9x0/2JACw7QFQzda8+VWxhgTaZEM9KUefVtcGCi2ghYgO9rgWhljTGNEOtB3tjocKdjzbowxza2uQC8iG0Vkh4jsFJGPVcn/qIg8Hi7bRaQgIj1h3h4ReSLM2zrfJ1BNaeimq9XlUD4ZJNo4vTGmSdXzKkEXuBF4LcGLwLeIyN2q+utSGVX9HPC5sPwbgT9T1YGKj7lSVQ/Pa81nUAr0nS3CgaPhg82sR2+MaVL19OgvAnaq6i5VzQK3A9fMUP564Lb5qNxclYZu2lscXkjbEyyNMc2tnkC/Ethbsd8Xpk0jIklgI/C9imQFHhCRR0VkU60vEZFNIrJVRLb29/fXUa3aSj36joTD3vFYkGhDN8aYJlVPoJcqabWuVXwj8NMpwzaXquqFwNXAh0Tk8moHqupNqrpBVTf09vbWUa3ayj36pHAgZ5OxxpjmVk+g7wNWV+yvAvbVKHsdU4ZtVHVfuD4E3EkwFLSgSj36trgwThx1fBu6McY0rXoC/RZgvYisE5EYQTC/e2ohEekEXgV8vyKtVUTaS9vA64Dt81HxmZR69K0JAYSCPcHSGNPEZr3qRlXzInIDcD/gAreo6pMi8v4wf3NY9M3AA6o6VnH4cuBOESl913dU9YfzeQLVlHr0reELprJ+J54FemNMk5o10AOo6r3AvVPSNk/ZvxW4dUraLuC846rhHJR69C2xYHphuGUlycO/OdHVMMaYRSHSd8a2hBfc7G89E/qfhuzYDEcZY0w0RTLQl4ZuYp7iCOyJvQS0CAeeaHDNjDHmxItkoC/16Avk6U7G2OGcEWTs+2UDa2WMMY0RyUBf6tHnijm6W2M8n+uA9hXwwmMNrpkxxpx4kQz0pR59vpinJxljYCwLp15gPXpjTFOKfKDvbvXDQH8hHPkNpIcbXDtjjDmxIhnoK4duelrjDIzlgh49wP5tDayZMcaceJEM9JOGblp9jqay6Irwcv59Nk5vjGkukQz0kyZjkzEKRWXY7YLONTZOb4xpOpEO9EGPPrhr6uhYFlbahKwxpvlEMtBPHroJAv2R0pU3R/dAamCGo40xJloiGehFBE+8cDK2okdfnpB9vHGVM8aYEyySgR6CXn2+GNwZCzCQykJpQtZunDLGNJHIBnrf8af36Fu6oed0C/TGmKYS2UBf6tEnYy5xzwlumgI4/Qp49kf2IhJjTNOoK9CLyEYR2SEiO0XkY1XyrxCRIRF5PFw+We+xC8VzgjF6EaGnNTYR6F/2bsin4fHbZjzeGGOiYtZALyIucCPBy73PAq4XkbOqFP2Jqp4fLp8+xmPnXWe8k4Hx4Oqa3vY4+4bGg4wV58HKDbD1FtBa7zg3xpjoqKdHfxGwU1V3qWoWuB24ps7PP55jj8vq9tXsHdkLwHmrunj8+UHyhWKQ+fL3Bs+92fNfJ6IqxhjTUPUE+pXA3or9vjBtqktEZJuI3CciZx/jsfNudftq+kb7KGqRDWu7GcsWePrASJB59psh0Rn06o0xJuLqCfRSJW3qmMdjwGmqeh7wD8Bdx3BsUFBkk4hsFZGt/f39dVRrZqvbV5MpZOhP9fPytT0AbNkT3ijlt8D5b4en7oHRQ8f9XcYYs5jVE+j7gNUV+6uAfZUFVHVYVUfD7XsBX0SW1nNsxWfcpKobVHVDb2/vMZxCdavbg6/dO7KXU7taWNnVMhHoAV72Hijm4JffOu7vMsaYxayeQL8FWC8i60QkBlwH3F1ZQEROEREJty8KP/dIPcculMpAD/Dytd1s2XMULU3A9r4Y1r4SfrHZLrU0xkTarIFeVfPADcD9wFPAP6vqkyLyfhF5f1jsLcB2EdkGfBm4TgNVj12IE5lqRdsKXHEnAv26HvpHMjw/kJoo9Lq/htQRuO8vTkSVjDGmIbx6CoXDMfdOSdtcsf0V4Cv1Hnsi+I7PKa2n0DfSB1Aep//v3QOctqQ1KHTq+fDKP4eH/gZe+sZgMcaYiInsnbEw+RLLF/W20dnis3XPlGGay/8cTjkX7vkwjB0+8ZU0xpgFFv1APxoEeseRcJx+yiOKXR/e/HXIDMPdfwLFQgNqaowxCyfygX4oM8RwNngh+Ia1Pew6PMbh0czkgsvPgtf8H9jxb3DXBy3YG2MiJfKBHiqvvAnG6acN3wBc8kG48n/Br26HO/8YCvkTVk9jjFlITRXoz1nZQdxzpg/flLzqo/DqT8IT/wJ3vA+yYyeqqsYYs2AiHehXta8CKF95E/dcLlzTzY+eOkihWOOBZq/8CLz2M/DkXfD1y+3Z9caYk16kA32r30pPoqfcowd4+8Vr2HMkxYO/PlD7wEv/BP7wHsiNwzdeCw9/DvKZ2uWNMWYRi3Sgh8mXWAJcfc4KTluS5Gv/+ezEXbLVrHslfOCnwbX1P/5r+MoG2PZdKBZPQK2NMWb+NF2gdx1h0+Wns61viJ89e2Tmg1u64S3/CO+4AxJdcOcm+Por4fHvQC69sBU3xph50hSB/uDYQbKFbDnt2gtXsbQtztceenb2DxCBF70aNj0E134Dinm46wPwdy+FBz8Fh55awNobY8zxa4pAryh9o33ltITv8t7L1vGT3xxm+wtD9X2Q48BvvQU++PNg/H7tpfDIl+GrF8NXL4GHPgcHnrC3VhljFp2mCPQwceVNydsvXkN73OMffvybY/tAEVh3ObztW/CRHfD6zwcvMfmPv4bNl8EXzoS7PhSM5w/unf3zjDFmgdX1ULOTWekSy8pxeoCOhM8fv+p0Pv/AM3x3y/O87eVrjv3D25bBRX8ULCMHYOe/w28ehKfvgcfD59x3roZVL4eVF8KpF8KKcyHefrynZYwxdYt8oF+SWEKL1zIt0AN84IoX8fNdA/zv7z/J2ad2cs7Kzrl/UfspcME7gqVYgEO/huceged+Cn1b4Mk7Jsp2r4Xl58Dys6H3JdB7JvScAX5i7t9vjDE1yIyXGDbIhg0bdOvWrfP2eW+9563E3Bjfev30t0kdGc3wu1/+L2Kewz3/4zI6W/x5+95JRg8FN18dfAIObIeD22FgF2jpck0Jev9LzoCe06FnHXSvg+7ToGtNMDxkjDE1iMijqrqhal4zBPpbt9/KFx79Anf83h2s714/Lf/R547ytq//jMvWL2XzO15Gwnfn7btnlEvDkZ3Q/3SwLi0DuyE9OLlsvDMI+J0roXMVdKwMl1ODpf0UiLWemHobYxad4w70IrIR+BLgAjer6t9MyX87UHpN0yjwAVXdFubtAUaAApCvVZFK8x3oj6aP8pp/eQ3XvvhaPvGKT1Qt851fPM8n7nyCi9b2cNO7XkZXMjZv3z8n40fh6B44+hwMPg9De8P1CzDcV/31h/GOIOC3LZ9Yl5deaF0WzCskl4BzghozY8wJMVOgn3WMXkRc4EbgtQQv+94iIner6q8riu0GXqWqR0XkauAm4BUV+VeqasPe6tGd6OZ1a1/HPc/ew4cv/DBJPzmtzB+8Yg3tCY+P/PM2rv3aI9z6notY3TO93AnT0h0sp15QPT87BsP7YfgFGN4HoweCCeGR/TByMJgXGDkA+So3dokDLT1B0G9dCq29wZJcCq1LwvXSiXWiK7i81BhzUqpnMvYiYKeq7gIQkduBa4ByoFfVRyrK/xxYNZ+VnA9vfclb+cGuH3Df7vu49sXXVi3zxvNOZVl7nD/65lauufGn/NXvnc0bz11B+N7zxSXWCktfFCy1qEJmBMb6YfRgME8wegjGDgVv0xrrD5Z9jwf7mRr3FJQahuSScOkJG4IlFenhuqU7WCc6g0tRjTENN+vQjYi8Bdioqu8L998JvEJVb6hR/s+BMyvK7waOAgp8XVVvqnHcJmATwJo1a1723HPPze2MalBVfv/u3yfmxvjuG747Y9mdh0b5yD8/zra+Ia46cxmfedM5rOxqmdf6LEr5TPCy9LHDkDoMY0fC9WEYHwjTj0BqIFiPDwR3Clcj7kTQT/aEDUL35IahpWfKujt445cx5pgd19ANUK1bVrV1EJErgfcCl1UkX6qq+0RkGfCgiDytqg9P+8CgAbgJgjH6Oup1TESEt73kbXz2F59l++HtnLP0nJplX7SsjTs+eCm3PrKHz9+/g9d84SHecfEa/ujy01nWHuFLIL34xORuPVSDVzBWBv/KRqC8Hc437Hss2K94HMU08Y6wgZjSEExK656cF2+3Xw/GzKCeHv0lwF+p6u+E+x8HUNX/O6XcucCdwNWq+kyNz/orYFRVPz/Td873ZGzJaHaUq/7lKq5cfSV/e/nf1nXM3oEUf//gM9z1+Av4rsN1L1/NOy85jRcts5ue5kQ1mF8oNQTl9dFgqUwrNxhHaw8rATheOKfRU6MxmJoXrr0GT7gbM4+O66obEfGAZ4BXAy8AW4A/UNUnK8qsAX4MvKtyvF5EWgFHVUfC7QeBT6vqD2f6zoUK9ABfeuxL3PzEzXzm0s/wphe9qe7j9hwe46v/uZM7HnuBfFHZcFo3b335an7n7FMW7tp7M6GQDy45ndQ4VKzLjcSUxqIww3sEYm3VfyGU16U5h4r8eIf9ejCL0nxcXvl64IsEl1feoqqfFZH3A6jqZhG5GbgWKA2s51V1g4icTtDLh2CY6Duq+tnZvm8hA32+mOf9//5+Hjv4GLduvJVze889puP7RzLc+cs+bt+yl139Y/iu8NtnLGXjOadwxUt6WdHZBGP5JwtVyKWmB//Sr4RqDUZqYPo9DJUcb3qjUHW+oWIuItEFbuRvQjcN1vQ3TE01mB7kun+7jmwhy+1vuJ1lyWXH/Bmqyi/3DnL/9gPct/0Azw+kADijt5VXru/l4tN7eNlpPfS2x+e7+mahFQswPjgxvzCpITgyubGonI8o5mp/ZqKr4sqkKUNMlWmV25797Zj6WaCvYsfADt553ztZ3b6aL175xfJTLudCVdlxcISfPHOYn+w8zC92HSGTDx5tsG5pKxes7uK3VnVy7qouXrqinWTMeneRowrZ0SkNQpVfDZXzDqkjkJvhBfSVQ0s1L2XtmZwXa+C9H6ahLNDX8NMXfspHH/ooAJ++9NO85rTXzMvnZvIFtr8wzNY9A2zZc5RtfYP0jwRjxSKwbkkrL13RwYuXt7N+eRsvXt7GaUta8V27Kanp5NLVG4OqjUO4zDQx7SUqGoTuKo1DlWEnm3eIBAv0M+gb6eOjD32U7Ue289YXv5UPnv9BlrQsmffvOTCUZlvfIE/tHw6XkfJwDwSvOFzTk+T0pa2sW9rKaUtbWbskyWk9razoSlgjYCYU8uG8w9TLWCsvca0y91D9quj65x0mNRTd9hiNRcYC/SxyhRx//9jf8+2nvk3cjXP9mdfz7rPfTXeie0G/N5XN8+yhMZ45OMKuw6Ps6h9jV/8Ye46MlYd+AByBFZ0trO5pYWVXkpXdLazqauHUrhZWdCU4tbOFlpj9ozMzKBZrXLV0ZPq8Q2WDMeO8Q2f1XwnVrmQqDTP5Sfv1sEAs0Ndp99BuNm/bzH277yPmxrhqzVVcc8Y1XLziYtwT2HspFpVDIxl2Hx5j70CKvUdT7B1I0Xd0nBcGxzkwnJ72xsLOFp8VnQlO6UxwSkeC5R3B9rL2OMs7gvWStjiuY//ITJ0q5x0q5xZmmpweHwiOqcWNT78butq9DpPS7Y7peligP0bPDj7LbU/fxn2772M4O8ySxBIuW3kZl626jEtWXEJnvLHPhs/mixwYSrNvaJz9Q+PsG0xzYCjN/qE0B4bHOTCU4chYZlpj4AgsaYvT2xZnWUew7m2Ps7QtztL2OEvbYvS2BfudLT6ONQpmLvKZ6pe0TkqrbDCOzvw4DYBYe/groXuiISgtySn75fyupmogLNDPUbaQ5aG+h3hgzwM8su8RhrPDCMIZXWdwwbILOK/3PM7sOZPTu07HdxbXH1SuUOTQSIZDw2kODmc4NJKmfyTDoXD78GiW/pEMh0cz5IvT/wZcR+hpjbGkNcbStniw3Rbs97TGK7aDpSNhDYM5DqUH8E29+W3q9viU9PRgxct7qoi1BwG/pWtKYxAuia6JRqFyP9Z60g0xWaCfB/linu2Ht/Oz/T9j26FtbOvfxmgu+InqOz5ndJ3B6Z2ns65zHes617GmfQ2r21fTFmtrcM1nViwqQ+M5Do9m6B/NcHg0y5HRoAEYGMvSP5Itbw+MZRnNVO91uY7QnfTpTk4E/65kjJ7WIK07GaO71Q/Swv32hGeNgzk+xWLwvKXxgeDeh3KDUFoGqzcO44Mzzz84fhD8KxuCRNcs685gu0GNhAX6BVDUIruHdrNjYAdPH32aZwaeYffQbvaN7ZtUrjvezaltp3Jq26mc0noKy5PLWd66nOXJ5fS29LK0ZSkJ7+R5UFo6VygH/anLkbEsg6mJ/aOpHEdTWQpVfjFAMJTUlYzRFTYQXS1BQ9Cd9OlujdHZ4tOV9OlqCcoES4zWmLs4Hx1tTh6lZy6lB6c0CuF2qTGotp0epuYVTBA0EonOYCk1BOXtzokGoep255yfwWSB/gRK5VI8P/I8zw8/z96Rvewd2cuBsQPsG9vH/tH9pAvTXwTS7rezpGUJPYme8ror3kV3opvueDddiS664sHSGe8k6SVPmkCnqgyn8+UG4Ggqy9GxoAEYTE1fD6aCBmI8V6j5mZ4jdCV9Olv8sDEIGomOsGHorFiXlo5wHffs6iRznIrF4F6G9FDQAJQagvJ6aObtmeYiWnrgL3bPqVrH+5hicwySfpIze87kzJ4zp+WpKsPZYQ6mDnIodYj+VD9H0kfK6yPjR9g5uJOj6aMMZYbQGr0GTzw64h10xDrK6/ZYe7Af66At1kZ7rJ12v522WBttfriE20k/iSMn5rp8ESkH29OW1P9O23SuwPB4jqNh8B8cD9ZD47mwYcgxPJ5jaDzHweE0zxwcYSiVY6TG0FJJ3HMmNQCVDUFHi09Hwis3Ch0Jn44Wj46ET2fSpy1mQ02G4G1rpTH+Y70Cu/T8pfRw+OsgbCwyw8H2ArEe/SJVKBYYyg4xmB5kMDOxDGeGGcwMMpQdYjgzzHA2WEazo4xkRxjODlPQ2r1hAEFo9Vtp9Vtp89to9VtJ+slyI1DKa/VbafFayttJL1kum/SS5XXcjS+aXxj5QpHhdJ6hsBGoXEoNw1Bqet5IOmgkZvrnIALtcY/2xESj0F7RGJQaifZEsN+eCLbbw3LtCe/EvXjeNB3r0Z+EXMelJ9FDT6LnmI5TVcbz44xkRxjJjjCaGy2vR3OjjGXHGMmNkMqlGMuNBWm5McZyY/Sn+hnLB9upXGrWBqPEEScI/F6SFr8lWHstk7e9lun5NZaElyiX94/x8jjPdcqTwceqWFRG0nmG0xMNw3C4X96ekt53NMXI/mB7JD3zrwmAmOtMC/5tcW9So9AW92gr5YfbbfFSOY/WuGd3SptjYoE+YkQk6Gn7SZa3Lp/z56gq2WK23AikcinG8+PBdj5VbihS+SC9lJ/KpxjPjTOWH2MoPcSB/IFJZbLFGd4uVYUnXjnwVzYC5TQ32C4tVdPC/bgbLx+bcCfyY04MEcFxhM5kMEwzl0fcFYvKaDZoDEbS+aDRGM8xkqnYT+cYDbdH0jlGM3meH0hN2q8xdz1J3HPKjUJrfKIhaEtM3g+2XVoryiVj7qTj4p6zaH6RmYVhgd5UJSLE3ThxN37Mvypmki/mSefTE41CfjxYcuOMF8bL+6UyldupfIpMPlNOH8oMkc6ng/RChvHc+DE3JBAMZVUG/1KDEHfj5fS4F5+UPrVM3I0T9+JB2TCtrSPOku54uN8WrN0EnuPVDKyqSipbYCSdZzQTLCOlxiGTZzSdZyxMHw63xzJB3oHhNKP9QZnRTH7SYzRm4jpCMubSGvNoDRuF0n4y7tEac0nGgrRk3CXpu2F6mBbmt5S3XVpiLjHXGpDFwgK9OaE8xwsmhRfo/oJCsRAE/bAxyBQykxqNUl66kCaTz5AuBHmTtsNjSscNZgaD/YpjMoUMxZlu1JmBI065sSgvXpy4EyfmxoJfGW6MhBusS2Vibox4W5yWzhhdU44vlYu5beVtB49CwSNXcMnlHLJ5h1zOIZVVxjJ5Utk8o5lC0Fhk86QyBUazeVKZPGPZAgeG04xnC4xl84xlCqSy9f3aKHEdIem75QagJebR4jskY8FcRUvMLee3xFxa/GBJxFwSnjMpLV7K853gWN8l4bvEPccmyOtQV6AXkY3AlwjeMHWzqv7NlHwJ818PpIB3q+pj9RxrzHxyHZekEwxdLSRVJV/MM16YaCQy+UzQSExpENL5NNlCtryfKWTK+aX0yvVodrS8XUrPFXLBeqabfOrkiYfv+kHD4MTwXZ+YGyMWixFriRFzY3Q5MZa5wbbv+OW1Kz6iPqgLuBSLHsWigxY9CkWXYsElX3CCJe+QKzjk8g7ZnJAN10M54VDKIZOD8SyMZ4VMVsjWNyU0TcxzSHhBA5CoaAzi3sQ6PnXfK6UH2zHPCdMr8jwnTA/yy4vrlMvH3JOjoZk10IuIC9wIvBboA7aIyN2q+uuKYlcD68PlFcDXgFfUeawxJx0RwXf9YLL4BL5jvKhFsoVsucEoNQaZQoZsMWwY8unydqlMrpibXn5qenhMtpBlLD/GYGawnJ4pZMgX8+X8uQyRAeCHyxRxoEUcPMfHEw9PPFzHxxUPRzwcXBw8BBfBA1xEXVAXVQfUpaguWnQoqsNo0WG44FAoOhTSDoWUUCg45AvBOldwKBQEcNDwc1CnYt8p75e/g4l0JcxXF1dcfNfDdz1irkfM8Yh54bbn4rsTjYPnCL7r4IeNhO+G++F2Z4vPDVetn+NfR2319OgvAnaq6i4AEbkduAaoDNbXAN/U4FrNn4tIl4isANbWcawxpk6OOOVJ5EZSVfKaJ1fIlRuMUkORK+aCpTCxzhazk7bzxXxwTGHKdviZuWKunJ4r5KqmB+tMOS9fzJPXPIViPtiuXHTyFVE12pvj+28CZMJlIjFoTISw0cCBQrhoqaEJtlUdPG3nhqu+P881qy/QrwT2Vuz3EfTaZyuzss5jARCRTcAmgDVr1tRRLWNMo4gIvvj4jr/gw2TzobJhKmiBQrFAXvOTGo3KtHKZcuNRKKeXyhS1WG5ISuULWph0bOV+QQsUtUiumKOoRYpanJbX6td/U+GxqCfQVxuAmjolU6tMPccGiao3ATdBcMNUHfUyxpi6VDZMzaieQN8Hky4rXgXsq7NMrI5jjTHGLKB6bq/bAqwXkXUiEgOuA+6eUuZu4F0SuBgYUtX9dR5rjDFmAc3ao1fVvIjcANxPcInkLar6pIi8P8zfDNxLcGnlToLLK98z07ELcibGGGOqsoeaGWNMBMz0UDN7MpIxxkScBXpjjIk4C/TGGBNxFuiNMSbiFuVkrIj0A8/N8fClwOF5rM7JoBnPGZrzvJvxnKE5z/tYz/k0Ve2tlrEoA/3xEJGttWaeo6oZzxma87yb8ZyhOc97Ps/Zhm6MMSbiLNAbY0zERTHQ39ToCjRAM54zNOd5N+M5Q3Oe97ydc+TG6I0xxkwWxR69McaYChbojTEm4iIT6EVko4jsEJGdIvKxRtdnoYjIahH5DxF5SkSeFJE/DdN7RORBEflNuO5udF3nm4i4IvJLEflBuN8M59wlIv8qIk+H/88vifp5i8ifhX/b20XkNhFJRPGcReQWETkkItsr0mqep4h8PIxvO0Tkd47luyIR6CteQn41cBZwvYic1dhaLZg88BFVfSlwMfCh8Fw/BvxIVdcDPwr3o+ZPgacq9pvhnL8E/FBVzwTOIzj/yJ63iKwE/gTYoKrnEDze/Dqiec63AhunpFU9z/Df+HXA2eExXw3jXl0iEeipeIG5qmaB0kvII0dV96vqY+H2CME//JUE5/tPYbF/At7UkAouEBFZBfwucHNFctTPuQO4HPgGgKpmVXWQiJ83wXsyWkTEA5IEb6WL3Dmr6sPAwJTkWud5DXC7qmZUdTfBuz8uqve7ohLoa72cPNJEZC1wAfALYHn4Vi/C9bIGVm0hfBH4n0CxIi3q53w60A/8YzhkdbOItBLh81bVF4DPA88D+wneVvcAET7nKWqd53HFuKgE+rpfQh4VItIGfA/4sKoON7o+C0lE3gAcUtVHG12XE8wDLgS+pqoXAGNEY8iipnBM+hpgHXAq0Coi72hsrRaF44pxUQn09bzAPDJExCcI8t9W1TvC5IMisiLMXwEcalT9FsClwO+JyB6CYbmrRORbRPucIfi77lPVX4T7/0oQ+KN83q8Bdqtqv6rmgDuA3yba51yp1nkeV4yLSqBvmpeQi4gQjNk+pap/V5F1N/CH4fYfAt8/0XVbKKr6cVVdpaprCf7f/lhV30GEzxlAVQ8Ae0XkJWHSq4FfE+3zfh64WESS4d/6qwnmoaJ8zpVqnefdwHUiEheRdcB64L/r/lRVjcRC8HLyZ4Bngb9sdH0W8DwvI/jJ9ivg8XB5PbCEYJb+N+G6p9F1XaDzvwL4Qbgd+XMGzge2hv+/7wK6o37ewP8Bnga2A/8PiEfxnIHbCOYhcgQ99vfOdJ7AX4bxbQdw9bF8lz0CwRhjIi4qQzfGGGNqsEBvjDERZ4HeGGMizgK9McZEnAV6Y4yJOAv0xhgTcRbojTEm4v4/KQJ6rTfjW0AAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(r1)\n",
    "plt.plot(r2)\n",
    "plt.plot(r3)"
   ]
  }
 ],
 "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
