{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import sys\n",
    "\n",
    "# import gymnasium as gym\n",
    "import numpy as np\n",
    "from joblib import Parallel, delayed\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import truncnorm\n",
    "import pandas as pd\n",
    "from sklearn.gaussian_process import GaussianProcessRegressor\n",
    "from sklearn.gaussian_process.kernels import RBF,RationalQuadratic,DotProduct,ConstantKernel as C\n",
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(0)\n",
    "\n",
    "#Hole=[5,7,11,12]\n",
    "T=80 # Time Horizon\n",
    "# K=130\n",
    "N=1000 #  Iteration number of outer loop \n",
    "M=40# iteration number for Q-learning\n",
    "\n",
    "#Hole=[5,6,7,17,18,19]\n",
    "\n",
    "# initial_gauss_set=[0,1,2,3,4,5,6,7,8,9]\n",
    "# safe_s0=[0,1,2,3,4,5,9,10,11,12,13,14]\n",
    "\n",
    "\n",
    "# 8*8 parameter\n",
    "# nA=8\n",
    "# nS = 64\n",
    "# nrow = ncol = 8\n",
    "# e_risk=1.5\n",
    "\n",
    "\n",
    "# 12*12 parameter\n",
    "nA=8\n",
    "nS = 144\n",
    "nrow = 12\n",
    "ncol = 12\n",
    "\n",
    "e_risk=1.25\n",
    "safe_s0=[0,1,2,3,4,5]\n",
    "initial_gauss_set=[0,1,2,3,4,5,12,13,14,15,16,17,24,25,26,27,28,29]\n",
    "total_violation=0\n",
    "# e_risk=0.75\n",
    "# safe_s0=[0,1,2,3,4,5,12,13,14,15,16,17]\n",
    "# initial_gauss_set=[0,1,2,3,4,5,12,13,14,15,16,17,24,25,26,27,28,29]\n",
    "\n",
    "# e_risk=0.75\n",
    "# safe_s0=[0,1,2,3,4,5,12,13,14,15,16,17,24,25,28,29]\n",
    "# initial_gauss_set=[0,1,2,3,4,5,12,13,14,15,16,17,24,25,26,27,28,29]\n",
    "# 16*16 parameter\n",
    "# nA=8\n",
    "# nS = 256\n",
    "# nrow = 16\n",
    "# ncol = 16\n",
    "# e_risk=0.75\n",
    "\n",
    "# safe_s0=[0,1,2,3,4,5,6,16,17,18,19,20,21,22,35,36,37,38]\n",
    "# initial_gauss_set=[0,1,2,3,4,16,17,18,19,20,32,33,34,35,36]\n",
    "\n",
    "c_Qlearning=20\n",
    "# gamma=0.97\n",
    "#n=10  sample number of transition kernel\n",
    " # data number for post##change every time\n",
    "\n",
    "# V=50 #number of comparasion\n",
    "# mt=30\n",
    "\n",
    "\n",
    "\"\"\"\"\"\n",
    "V=50 #number of comparasion\n",
    "mt=50\n",
    "K=40\n",
    "\"\"\"\"\"\n",
    "# 8*8 parameter\n",
    "# cost_s=0\n",
    "# cost_d=1\n",
    "# cost_h=2\n",
    "\n",
    "\n",
    "# 16*16 parameter\n",
    "cost_s=0\n",
    "cost_A=0.5\n",
    "cost_B=1\n",
    "cost_C=1.5\n",
    "cost_D=2\n",
    "# beta=0.7\n",
    "# nu=0.5\n",
    "# prior=np.ones(4)\n",
    "sigma_noise=0\n",
    "LEFT = 0\n",
    "DOWN = 1\n",
    "RIGHT = 2\n",
    "UP = 3\n",
    "#action in {(+-1,+-2),(+-2,+-1)}\n",
    "MAPS = {\n",
    "    \"4x4\": [\"SFFF\", \"FHFH\", \"FFFH\", \"HFFG\"],\n",
    "    \"5x5\": [\n",
    "        \"SFFFF\",\n",
    "        \"HHHFF\",\n",
    "        \"FFFFF\",\n",
    "        \"FFHHH\",\n",
    "        \"FFFFG\",\n",
    "    ],\n",
    "    \"8x8\": [\n",
    "        \"SBFFFFDD\",\n",
    "        \"DBBBFFBD\",\n",
    "        \"DDDDBFBD\",\n",
    "        \"DDDBFFBD\",\n",
    "        \"DBBFBBBB\",\n",
    "        \"DBFBDDDD\",\n",
    "        \"BBFFBBBD\",\n",
    "        \"DDBFFFFG\",\n",
    "    ],\n",
    "    \"12x12\":[\n",
    "        \"SFFFFFFFFFFF\",\n",
    "        \"AAAAAAAAAAFF\",\n",
    "        \"BBCCBBBBBAFF\",\n",
    "        \"BAAAAAAAAAFF\",\n",
    "        \"AFFFFFFFFFFF\",\n",
    "        \"FFFFFFFFFFFF\",\n",
    "        \"FFAAAAAAAAAA\",\n",
    "        \"FABBBBAABBBB\",\n",
    "        \"FAAACCAAABCC\",\n",
    "        \"FFAABBAAAABB\",\n",
    "        \"FFFFAAFFFFAA\",\n",
    "        \"FFFFFFFFFFFG\",\n",
    "    ],\n",
    "    \"16x16\":[\n",
    "        \"SFFFFFFFFFFFFFFF\",\n",
    "        \"AAAFFFFFFFFFFFFF\",\n",
    "        \"BBBAFFFFFFAAAFFF\",\n",
    "        \"CDCBAFFFFABBBAFF\",\n",
    "        \"BBBAFFFFABBAAFFF\",\n",
    "        \"AAAFFFFAABAAFFFF\",\n",
    "        \"FFFFFAAABBAFFFFF\",\n",
    "        \"FFFFABBBBAFFFFFF\",\n",
    "        \"FFFABCDCBAAAAAAA\",\n",
    "        \"FFFABBBBBAABBBBB\",\n",
    "        \"FFFAAAAAAFABCCCC\",\n",
    "        \"FFFFFFFFFFFABCDD\",\n",
    "        \"AAFFFFFFFFFFABCD\",\n",
    "        \"ABAFFFFAAFFFABCC\",\n",
    "        \"FAFFFFABBAFFFABB\",\n",
    "        \"FFFFFABBBBAFFFFG\",\n",
    "    ],\n",
    "}\n",
    "desc = MAPS[\"12x12\"]\n",
    "desc = np.asarray(desc, dtype=\"c\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [],
   "source": [
    "def to_row_col(state):\n",
    "    return int((state - state% ncol)/ ncol), state% ncol\n",
    "        \n",
    "def to_s(row, col):\n",
    "    return row * ncol + col\n",
    "\n",
    "def inc(row, col, a):\n",
    "    if a == LEFT:\n",
    "        col = max(col - 1, 0)\n",
    "    elif a == DOWN:\n",
    "        row = min(row + 1, nrow - 1)\n",
    "    elif a == RIGHT:\n",
    "        col = min(col + 1, ncol - 1)\n",
    "    elif a == UP:\n",
    "        row = max(row - 1, 0)\n",
    "    return (row, col)\n",
    "\n",
    "\n",
    "def inc_random(row, col, a):#a=(+-1,+-2)\n",
    "    choice=np.zeros(2)\n",
    "    if a[0]>=0:\n",
    "        choice[0]=RIGHT\n",
    "    else:\n",
    "        choice[0]=LEFT\n",
    "    if a[1]>=0:\n",
    "        choice[1]=UP\n",
    "    else:\n",
    "        choice[1]=DOWN\n",
    "    action=np.random.choice(choice,p=np.absolute(a)/3)\n",
    "    return inc(row, col,action)\n",
    "\n",
    "# def order_to_sa(n):\n",
    "#     return [int((n - n% nA)/ nA), n% nA]\n",
    "def action_to_number(a):\n",
    "    if abs(abs(a[0])-1)<=1e-5:\n",
    "        i=0\n",
    "    else: \n",
    "        i=4\n",
    "    if a[0]>=0 and a[1]>=0:\n",
    "        j=0\n",
    "    elif    a[0]>=0 and a[1]<0:\n",
    "        j=1\n",
    "    elif    a[0]<0 and a[1]>=0:\n",
    "        j=2\n",
    "    else:j=3\n",
    "    return i+j\n",
    "\n",
    "def number_to_action(n):\n",
    "    i,j=int((n - n% 4)/ 4), n% 4\n",
    "    if i==0 and j==0:\n",
    "        h=np.array([1,2])\n",
    "    elif i==0 and j==1:\n",
    "        h=np.array([1,-2])\n",
    "    elif i==0 and j==2:\n",
    "        h=np.array([-1,2])\n",
    "    elif i==0 and j==3:\n",
    "        h=np.array([-1,-2])        \n",
    "    elif i==1 and j==0:\n",
    "        h=np.array([2,1])\n",
    "    elif i==1 and j==1:\n",
    "        h=np.array([2,-1])\n",
    "    elif i==1 and j==2:\n",
    "        h=np.array([-2,1])\n",
    "    else:\n",
    "        h=np.array([-2,-1])  \n",
    "    return h \n",
    "\n",
    "def order_to_state(n):\n",
    "    return [int((n - n%  nrow)/ nrow), n%  nrow]\n",
    "\n",
    "# def sa_to_s(s,a):\n",
    "#     row,col=to_row_col(s)\n",
    "#     return int(to_s(inc(row,col,a)[0],inc(row,col,a)[1]))\n",
    "def compare_set(A,B):\n",
    "    l1=len(A)\n",
    "    l2=len(B)\n",
    "    if l1!=l2:\n",
    "        return False   \n",
    "    else: \n",
    "        for i in range(l1):\n",
    "            if A[i]!=B[i]:\n",
    "                return False\n",
    "    return True\n",
    "\n",
    "def sa_to_s_random(s,a):\n",
    "    row,col=to_row_col(s)\n",
    "    (new_row,new_col)=inc_random(row,col,number_to_action(a))\n",
    "    return int(to_s(new_row,new_col))\n",
    "\n",
    "def stateset_to_grid(S):\n",
    "    grid=2*np.ones((nrow,ncol))\n",
    "    for s in S:\n",
    "        grid[to_row_col(s)[0],to_row_col(s)[1]]=0\n",
    "    \n",
    "    return grid\n",
    "\n",
    "def plot_set(S,color='Blues'):\n",
    "    plt.rcParams['font.sans-serif'] = ['SimHei']  \n",
    "    plt.rcParams['axes.unicode_minus'] = False  \n",
    "    plt.figure(figsize=(8, 8))\n",
    "    plt.imshow(S,cmap=color) \n",
    "    plt.colorbar()\n",
    "    plt.show()\n",
    "\n",
    "def plot_state_set(S,color='Blues'):\n",
    "    plot_set(stateset_to_grid(S),color)\n",
    "    \n",
    "\n",
    "def plot_route(dataset,color='Blues'):\n",
    "    S=[]\n",
    "    l=len(dataset)\n",
    "    if l !=0:\n",
    "        for i in range(l):\n",
    "            S.append(dataset[i][0])\n",
    "            if dataset[i][0]==nS-1:\n",
    "                break\n",
    "        if dataset[l-1][0]!=nS-1:     \n",
    "            S.append(dataset[l-1][2])\n",
    "    plot_state_set(S,color)\n",
    "\n",
    "def distance_p2s(s,S):\n",
    "    g=np.zeros(len(S))\n",
    "    for i in range(len(S)):\n",
    "        r1,c1=to_row_col(s)\n",
    "        r2,c2=to_row_col(S[i])\n",
    "        g[i]=np.sqrt((r1-r2)**2+(c1-c2)**2)\n",
    "    return np.min(g)\n",
    "\n",
    "def distance_p2p(s1,s2):\n",
    "    r1,c1=to_row_col(s1)\n",
    "    r2,c2=to_row_col(s2)\n",
    "    np.sqrt((r1-r2)**2+(c1-c2)**2)\n",
    "    return np.min(np.sqrt((r1-r2)**2+(c1-c2)**2)) \n",
    "\n",
    "def gauss_fit_initial(mu_input,cov_input,dataset):\n",
    "    mu=np.copy(mu_input)\n",
    "    cov=np.copy(cov_input)\n",
    "    new_mu=np.zeros(nS)\n",
    "    new_cov=np.zeros((nS,nS))\n",
    "    for i in range(len(dataset)):\n",
    "        s=dataset[i][0]\n",
    "        row,col=to_row_col(s)\n",
    "        y=dataset[i][3]\n",
    "        new_mu=mu+cov[:,s]/(cov[s,s])*(y-mu[s])#+sigma_noise)\n",
    "        new_mu[s]=y\n",
    "        for j in range(nS):\n",
    "            for k in range(nS):\n",
    "                new_cov[j,k]=cov[j,k]-cov[j,s]*cov[k,s]/(cov[s,s])#+sigma_noise)\n",
    "                    #print(str(i)+','+str(j)+','+str(k)+':'+str(new_cov[j,k]-cov[j,k]))\n",
    "        new_cov[:,s]=0\n",
    "        new_cov[s,:]=0\n",
    "        mu=np.copy(new_mu)\n",
    "        cov=np.copy(new_cov)\n",
    "\n",
    "    return mu, cov\n",
    "\n",
    "def gauss_fit(mu_input,cov_input,dataset,state_visit):\n",
    "    mu=np.copy(mu_input)\n",
    "    cov=np.copy(cov_input)\n",
    "    new_mu=np.zeros(nS)\n",
    "    new_cov=np.zeros((nS,nS))\n",
    "    visit_set=np.copy(state_visit)\n",
    "    for s in initial_gauss_set:\n",
    "        visit_set[to_row_col(s)[0],to_row_col(s)[1]]=1\n",
    "    for i in range(len(dataset)):\n",
    "        s=dataset[i][0]\n",
    "        row,col=to_row_col(s)\n",
    "        if  visit_set[row,col]==0:\n",
    "            visit_set[row,col]+=1\n",
    "            y=dataset[i][3]\n",
    "            new_mu=mu+cov[:,s]/(cov[s,s])*(y-mu[s])#+sigma_noise)\n",
    "            new_mu[s]=y\n",
    "            for j in range(nS):\n",
    "                for k in range(nS):\n",
    "                    new_cov[j,k]=cov[j,k]-cov[j,s]*cov[k,s]/(cov[s,s])#+sigma_noise)\n",
    "                    #print(str(i)+','+str(j)+','+str(k)+':'+str(new_cov[j,k]-cov[j,k]))\n",
    "                    #print(str(i)+','+str(j)+','+str(k)+':'+str(cov[j,s]*cov[s,k]/(cov[s,s]+sigma_noise)))\n",
    "            new_cov[:,s]=0\n",
    "            new_cov[s,:]=0\n",
    "            mu=np.copy(new_mu)\n",
    "            cov=np.copy(new_cov)\n",
    "\n",
    "    return mu, cov\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def sa_to_order_random(s,a):\n",
    "    return s*nA+action_to_number(a)\n",
    "\n",
    "\n",
    "\n",
    "def gauss_fit_random(mu_input,cov_input,dataset):\n",
    "    mu=np.copy(mu_input)\n",
    "    cov=np.copy(cov_input)\n",
    "    new_mu=np.zeros(nS)\n",
    "    new_cov=np.zeros((nS,nS))\n",
    "    for i in range(len(dataset)):\n",
    "        s=dataset[i][0]\n",
    "        a=dataset[i][1]\n",
    "        y=dataset[i][3]\n",
    "        order_sa=sa_to_order_random(s,number_to_action(a))\n",
    "        new_mu=mu+cov[:,order_sa]*(y-mu)/(cov[order_sa,order_sa]+sigma_noise)\n",
    "        for j in range(nS):\n",
    "            for k in range(nS):\n",
    "                for c in range(nA):\n",
    "                    for d in range(nA):\n",
    "                        order_1=sa_to_order_random(j,number_to_action(c))\n",
    "                        order_2=sa_to_order_random(k,number_to_action(d))\n",
    "                        new_cov[order_1,order_2]=cov[order_1,order_2]-cov[order_1,order_sa]*cov[order_sa,order_2]/(cov[order_sa,order_sa]+sigma_noise)\n",
    "                #print(str(i)+','+str(j)+','+str(k)+':'+str(new_cov[j,k]-cov[j,k]))\n",
    "                #print(str(i)+','+str(j)+','+str(k)+':'+str(cov[j,s]*cov[s,k]/(cov[s,s]+sigma_noise)))\n",
    "        mu=np.copy(new_mu)\n",
    "        cov=np.copy(new_cov)\n",
    "    return mu, cov\n",
    "#     return 0\n",
    "\n",
    "# def gauss_predict(mu,sigma,x_predict):\n",
    "##     return 0\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "map_type=np.zeros((nrow,ncol))\n",
    "\n",
    "\n",
    "s_A=[]\n",
    "s_B=[]\n",
    "s_C=[]\n",
    "s_D=[]\n",
    "for s in range(nS):\n",
    "    row,col=to_row_col(s)\n",
    "    if desc[row,col]==b'A':\n",
    "        map_type[row,col]=cost_A\n",
    "        s_A.append(s)\n",
    "    elif desc[row,col]==b'B':\n",
    "        map_type[row,col]=cost_B\n",
    "        s_B.append(s)\n",
    "    elif desc[row,col]==b'C':\n",
    "        map_type[row,col]=cost_C\n",
    "        s_C.append(s)\n",
    "    elif desc[row,col]==b'D':\n",
    "        map_type[row,col]=cost_D\n",
    "        s_D.append(s)\n",
    "        # for a in range(nA):\n",
    "        #     map_type[inc(row,col,a)[0],inc(row,col,a)[1]]=max(map_type[inc(row,col,a)[0],inc(row,col,a)[1]],1)\n",
    "map_type[0,0]=0\n",
    "map_type[nrow-1,ncol-1]=0\n",
    "\n",
    "true_cost=np.zeros((nS,nA))\n",
    "for s in range(nS):\n",
    "    row,col=to_row_col(s)\n",
    "    # for i in range(nA):\n",
    "        # a=number_to_action(i)\n",
    "        # choice=np.zeros(2)\n",
    "        # if a[0]>=0:\n",
    "        #     choice[0]=RIGHT\n",
    "        # else:\n",
    "        #     choice[0]=LEFT\n",
    "        # if a[1]>=0:\n",
    "        #     choice[1]=UP\n",
    "        # else:\n",
    "        #     choice[1]=DOWN\n",
    "        # for j in range(2):\n",
    "        #     new_s=to_s(inc(row,col,choice[j])[0],inc(row,col,choice[j])[1])\n",
    "        #     new_row,new_col=to_row_col(new_s)\n",
    "        #     if map_type[new_row,new_col]==2:\n",
    "        #         true_cost[s,i]+=cost_h*a[j]/3\n",
    "        #     elif map_type[new_row,new_col]==1:\n",
    "        #         true_cost[s,i]=cost_d*a[j]/3\n",
    "\n",
    "    if desc[row,col]==b'A':\n",
    "        true_cost[s]=cost_A\n",
    "    elif desc[row,col]==b'B':\n",
    "        true_cost[s]=cost_B\n",
    "    elif desc[row,col]==b'C':\n",
    "        true_cost[s]=cost_C\n",
    "    elif desc[row,col]==b'D':\n",
    "        true_cost[s]=cost_D\n",
    "# true_cost[0,0]=0\n",
    "# true_cost[0,3]=0\n",
    "# true_cost[63,1]=0\n",
    "# true_cost[63,2]=0\n",
    "r=np.zeros((nS,nA))\n",
    "r[nS-1,1]=1\n",
    "# r[nS-2,2]=T\n",
    "#r[nS-9,1]=5\n",
    "#r[0,2]=1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. ],\n",
       "       [0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0. , 0. ],\n",
       "       [1. , 1. , 1.5, 1.5, 1. , 1. , 1. , 1. , 1. , 0.5, 0. , 0. ],\n",
       "       [1. , 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0. , 0. ],\n",
       "       [0.5, 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. ],\n",
       "       [0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. ],\n",
       "       [0. , 0. , 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5],\n",
       "       [0. , 0.5, 1. , 1. , 1. , 1. , 0.5, 0.5, 1. , 1. , 1. , 1. ],\n",
       "       [0. , 0.5, 0.5, 0.5, 1.5, 1.5, 0.5, 0.5, 0.5, 1. , 1.5, 1.5],\n",
       "       [0. , 0. , 0.5, 0.5, 1. , 1. , 0.5, 0.5, 0.5, 0.5, 1. , 1. ],\n",
       "       [0. , 0. , 0. , 0. , 0.5, 0.5, 0. , 0. , 0. , 0. , 0.5, 0.5],\n",
       "       [0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. , 0. ]])"
      ]
     },
     "execution_count": 131,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "map_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {},
   "outputs": [],
   "source": [
    "def count_route_holes(dataset):\n",
    "    num=0\n",
    "    l=len(dataset)\n",
    "    for i in range(l):\n",
    "        if map_type[to_row_col(dataset[i][0])]>e_risk:\n",
    "            num=num+1\n",
    "    if l>0 and map_type[to_row_col(dataset[l-1][2])]>e_risk:\n",
    "            num=num+1\n",
    "    return num"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initial iteration\n",
    "\n",
    "pi=np.zeros((nS,nA))    \n",
    "\n",
    "\n",
    "S0=[]\n",
    "policy_list=[]\n",
    "unsafe_sa=np.zeros((nS,nA))\n",
    "unsafe_set=-np.ones(nS)\n",
    "for i in range(nS):\n",
    "    if map_type[to_row_col(i)[0],to_row_col(i)[1]]>e_risk:\n",
    "        unsafe_set[i]+=1\n",
    "state_visit=np.zeros((N+1,nrow,ncol))\n",
    "sa_visit=np.zeros((N+1,nS,nA))\n",
    "# 8*8version policy\n",
    "# for s in [0,9,10,11]:\n",
    "#     S0.append([s,0])\n",
    "#     S0.append([s,4])\n",
    "#     pi[s,0]=0.5\n",
    "#     pi[s,4]=0.5\n",
    "# for s in [1,2,3,12]:\n",
    "#     S0.append([s,1])\n",
    "#     S0.append([s,5])\n",
    "#     pi[s,1]=0.5\n",
    "#     pi[s,5]=0.5\n",
    "# for s in [4]:\n",
    "#     S0.append([s,1])\n",
    "#     pi[s,1]=1\n",
    "# for s in [5,13,14]:\n",
    "#     S0.append([s,3])\n",
    "#     pi[s,3]=1\n",
    "# for s in [6,7,15]:\n",
    "#     pi[s,3]=1\n",
    "# for s in [8]:\n",
    "#     pi[s,1]=0.5\n",
    "#     pi[s,5]=0.5\n",
    "# for s in range(16,nS):\n",
    "#     #if s not in safe_s0:\n",
    "#         pi[s]=0.125\n",
    "# pi[nS-1]=np.array([0,1,0,0,0,0,0,0])    \n",
    "#12*12 version policy\n",
    "for s in [0,1,2,3,4,5,12,13,14,15,16,17,24,27,28,29]:\n",
    "    S0.append([s,0])\n",
    "    S0.append([s,4])\n",
    "    pi[s,1]=0.5\n",
    "    pi[s,5]=0.5\n",
    "for s in [25,26]:\n",
    "    S0.append([s,2])\n",
    "    S0.append([s,6])\n",
    "    pi[s,2]=0.5\n",
    "    pi[s,6]=0.5\n",
    "pi[nS-1]=np.array([0,1,0,0,0,0,0,0])    \n",
    "\n",
    "#16*16 version policy\n",
    "# for s in [0,1,2,3,4,5,6,19,20,21,22,36,37,38]:\n",
    "#     S0.append([s,1])\n",
    "#     S0.append([s,5])\n",
    "#     pi[s,1]=0.5\n",
    "#     pi[s,5]=0.5\n",
    "# for s in [16,17,18,32,33,34,35]:\n",
    "#     S0.append([s,0])\n",
    "#     S0.append([s,4])\n",
    "#     pi[s,0]=0.5\n",
    "#     pi[s,4]=0.5\n",
    "# for s in range(nS):\n",
    "#     if s not in [0,1,2,3,4,5,6,16,17,18,19,20,21,22,32,33,34,35,36,37,38]:\n",
    "#         pi[s]=0.125\n",
    "# pi[nS-1]=np.array([0,1,0,0,0,0,0,0])    \n",
    "\n",
    "\n",
    "S_list=[]\n",
    "data_list=[]\n",
    "S0=np.copy(safe_s0)\n",
    "S_list.append(S0)\n",
    "policy_list.append(pi)\n",
    "S=np.copy(S_list[-1])\n",
    "dataset=[]\n",
    "t=0\n",
    "s=0\n",
    "a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "mu_0=np.zeros(nS)\n",
    "cov_0=np.zeros((nS,nS))\n",
    "for  i in range(nS):\n",
    "    for j in range(nS):\n",
    "        cov_0[i,j]=np.exp(-distance_p2p(i,j)**2/6)\n",
    "# for i in range(nS):\n",
    "#      cov_0[i,i]= cov_0[i,i]+distance_p2s(i,S_list[-1])/10    \n",
    "s_next_old=np.zeros((nS,4))\n",
    "for i in range(nS):\n",
    "    for j in range(4):\n",
    "        new_row,new_col=inc(to_row_col(i)[0],to_row_col(i)[1],j)\n",
    "        s_next_old[i,j]=int(to_s(new_row,new_col))\n",
    "total_visit=1\n",
    "n_violate=0\n",
    "#state_visit[0,0,0]+=1\n",
    "while (s in S and t<T and n_violate<1.5):\n",
    "    row,col=to_row_col(s)\n",
    "    state_visit[0,row,col]+=1\n",
    "    sa_visit[0,s,a]+=1\n",
    "    new_row,new_col=inc_random(row,col,number_to_action(a))\n",
    "    new_s=to_s(new_row,new_col)\n",
    "    #noise=truncnorm.rvs(-0.3, 0.3, size=1)[0]\n",
    "    #noise=0\n",
    "    if map_type[new_row,new_col]>e_risk:\n",
    "        n_violate+=1\n",
    "        total_violation+=1\n",
    "        unsafe_sa[s,a]+=1\n",
    "        unsafe_set[new_s]+=1\n",
    "    dataset.append([s,a,new_s,true_cost[s,a]])\n",
    "    # if true_cost[s,a]!=0:\n",
    "    #     dataset.append([s,a,new_s,true_cost[s,a]+noise])\n",
    "    # else:\n",
    "    #     dataset.append([s,a,new_s,0])\n",
    "\n",
    "    s=new_s\n",
    "    total_visit+=1\n",
    "\n",
    "    a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "    t+=1\n",
    "# if len(dataset)>0:\n",
    "#     row,col=to_row_col(s)\n",
    "#     state_visit[0,row,col]+=1   \n",
    "data_list.append(dataset)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(nS):\n",
    "    for j in range(nS):\n",
    "        if cov_0[i,j]!=cov_0[j,i]:\n",
    "            print(str(i)+','+str(j))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [],
   "source": [
    "cov_list=np.zeros((N+1,nS,nS))\n",
    "sigma_list=np.zeros((N+1,nrow,ncol))\n",
    "y_predict_list=np.zeros((N+1,nrow,ncol))\n",
    "data_len=len(dataset)\n",
    "\n",
    "# x_scale=3\n",
    "# x_predict=np.zeros((nS,2))\n",
    "# for i in range(nrow):\n",
    "#     for j in range(ncol):\n",
    "#         #x_predict[i*nrow+j]=np.array([i-(nrow-1)/2,j-(ncol-1)/2])/x_scale\n",
    "#         x_predict[i*nrow+j]=np.array([i,j])/x_scale\n",
    "\n",
    "\n",
    "# x_train=np.zeros((data_len,2))\n",
    "# y_train=np.zeros(data_len)\n",
    "# for i in range(data_len):\n",
    "#     x_train[i]=np.array([to_row_col(dataset[i][2])[0],to_row_col(dataset[i][2])[1]])/x_scale\n",
    "#     y_train[i]=dataset[i][3]\n",
    "# kernel =C(1.0, (1e-3, 3))* RBF(length_scale=2.0,length_scale_bounds=[1e-7,10])#+C(1.0, (1e-3, 1))*DotProduct()\n",
    "# #kernel=RationalQuadratic()\n",
    "# gp = GaussianProcessRegressor(kernel=kernel, n_restarts_optimizer=15)\n",
    "# gp.fit(x_train,y_train)\n",
    "# #y_predict,sigma,cov=gp.predict(x_predict,return_std=True,return_cov=True)\n",
    "# y_predict,cov=gp.predict(x_predict,return_cov=True)\n",
    "dataset_0=[]\n",
    "for s in initial_gauss_set:\n",
    "    dataset_0.append([s,0,0,true_cost[s,0]])\n",
    "\n",
    "y_predict,cov=gauss_fit_initial(mu_0,cov_0,dataset_0)\n",
    "new_y,new_cov=gauss_fit(y_predict,cov,dataset,np.zeros((nrow,ncol)))\n",
    "y_predict=np.copy(new_y)\n",
    "cov=np.copy(new_cov)\n",
    "sigma=np.diag(cov)\n",
    "beta=np.ones(M)\n",
    "visit_set=[]\n",
    "visit_set_list=[]\n",
    "for s in range(nS):\n",
    "    if state_visit[0,to_row_col(s)[0],to_row_col(s)[1]]>0:\n",
    "        visit_set.append(s)\n",
    "visit_set_list.append(visit_set)\n",
    "y_predict_list[0]=np.copy(y_predict.reshape(nrow,ncol))\n",
    "sigma_list[0]=np.copy(sigma.reshape(nrow,ncol))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0.])"
      ]
     },
     "execution_count": 136,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sa_visit[N,11]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "metadata": {},
   "outputs": [],
   "source": [
    "m1,c1=gauss_fit_initial(mu_0,cov_0,dataset_0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_n=10\n",
    "mu_5=np.zeros(test_n).T\n",
    "for i in range(test_n):\n",
    "    mu_5[i]=true_cost[i,0]\n",
    "B=np.linalg.inv(cov_0[0:test_n,0:test_n])\n",
    "test_mu=cov_0[:,0:test_n]@B@mu_5"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(nS):\n",
    "    for j in range(nS):\n",
    "        if cov_0[i,i]*cov_0[j,j]<cov_0[i,j]**2:\n",
    "            print(str(i)+','+str(j))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def Qlearning(rtilde,M,T,n_visit,total_visit,weight,set,unsafe_sa):\n",
    "#     Q=np.zeros((M+1,T,nS,nA))\n",
    "#     Q[0,T-1]=rtilde\n",
    "#     for m in range(M):\n",
    "#         for t in range(T-2,-1,-1):  \n",
    "#             Q_max=np.zeros((nS,nA))\n",
    "#             for s in range(nS):\n",
    "#                 for a in range(nA):\n",
    "#                     prob=number_to_action(a)/3\n",
    "#                     choice=np.zeros(2)\n",
    "#                     if prob[0]>=0:\n",
    "#                         choice[0]=RIGHT\n",
    "#                     else:\n",
    "#                         choice[0]=LEFT\n",
    "#                     if prob[1]>=0:\n",
    "#                         choice[1]=UP\n",
    "#                     else:\n",
    "#                         choice[1]=DOWN\n",
    "#                     Q_max[s,a]+=abs(prob[0])*np.max(Q[m,t+1,int(s_next_old[s,int(choice[0])]),:])\n",
    "#                     Q_max[s,a]+=abs(prob[1])*np.max(Q[m,t+1,int(s_next_old[s,int(choice[1])]),:])\n",
    "#             Q[m+1,t]=(1-beta[m])*Q[m,t]+beta[m]*(rtilde+Q_max)\n",
    "#     pi=np.zeros((nS,nA))\n",
    "#     for s in set:\n",
    "#         for a in range(nA):\n",
    "#             if n_visit[s,a]==0:\n",
    "#                 Q[M,0,s,a]+=weight*np.sqrt((total_visit)/(n_visit[s,a]+1))\n",
    "#     for s in range(nS):\n",
    "#         pi[s,np.argmax(Q[M,0,s])]=1\n",
    "#     return pi\n",
    "def Qlearning(rtilde,M,T,n_visit,total_visit,weight,set,unsafe_set):\n",
    "    Q=np.zeros((M+1,T,nS,nA))\n",
    "    Q[0,T-1]=rtilde\n",
    "    for t in range(T-2,-1,-1):  \n",
    "        Q_max=np.zeros((nS,nA))\n",
    "        for s in range(nS):\n",
    "            for a in range(nA):\n",
    "                prob=number_to_action(a)/3\n",
    "                choice=np.zeros(2)\n",
    "                if prob[0]>=0:\n",
    "                    choice[0]=RIGHT\n",
    "                else:\n",
    "                    choice[0]=LEFT\n",
    "                if prob[1]>=0:\n",
    "                    choice[1]=UP\n",
    "                else:\n",
    "                    choice[1]=DOWN\n",
    "                Q_max[s,a]+=abs(prob[0])*np.max(Q[0,t+1,int(s_next_old[s,int(choice[0])]),:])\n",
    "                Q_max[s,a]+=abs(prob[1])*np.max(Q[0,t+1,int(s_next_old[s,int(choice[1])]),:])\n",
    "        Q[0,t]=rtilde+Q_max\n",
    "    pi=np.zeros((nS,nA))\n",
    "    bound_set=[]\n",
    "    for s in range(nS):\n",
    "        if distance_p2s(s,set)<1.1:\n",
    "            bound_set.append(s)\n",
    "    for s in set:\n",
    "        for a in range(nA):\n",
    "            if n_visit[s,a]==0:\n",
    "                if unsafe_set[s,a]==0:\n",
    "                    Q[0,0,s,a]+=weight*np.sqrt(np.log(total_visit)/(n_visit[s,a]+1))\n",
    "    for s in range(nS):\n",
    "        pi[s,np.argmax(Q[0,0,s])]=1\n",
    "    return pi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "def final_route(rtilde,pi):\n",
    "    s=0\n",
    "    a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "    n_violate=0\n",
    "    final_data=[]\n",
    "    t=0\n",
    "    #while (s_next[s,a] in S and t<T and true_cost[s,a]*(1+noise) <e_risk ):\n",
    "    while ( t<T and n_violate<0.5 ):\n",
    "        row,col=to_row_col(s)\n",
    "        new_row,new_col=inc_random(row,col,number_to_action(a))\n",
    "        new_s=to_s(new_row,new_col)\n",
    "        # noise=truncnorm.rvs(-0.3, 0.3, size=1)[0]\n",
    "        # noise=0  \n",
    "        #if true_cost[s,a]*(1+noise)>e_risk:\n",
    "        if map_type[to_row_col(new_s)]>e_risk:\n",
    "            n_violate+=1\n",
    "        final_data.append([s,a,new_s,true_cost[s,a]])\n",
    "        #if true_cost[s,a]!=0:\n",
    "            #dataset.append([s,a,new_s,true_cost[s,a]+noise])\n",
    "        #else:\n",
    "            #dataset.append([s,a,new_s,0])\n",
    "        #dataset.append([s,a,new_s,(true_cost[s,a]!=0)*(true_cost[s,a]+noise)])\n",
    "        s=new_s\n",
    "\n",
    "        #state_visit[n+1,to_row_col(s)[0],to_row_col(s)[1]]+=1\n",
    "        a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "        t+=1\n",
    "    return final_data\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mean+sigma:\n",
    "alpha=1.96*np.ones(N)\n",
    "\n",
    "\n",
    "for i in range(M):\n",
    "    beta[i]=0.1#beta[i]/np.sqrt(np.sqrt(i+2))\n",
    "for n in range(N):\n",
    "    state_visit[n+1]=np.copy(state_visit[n])\n",
    "    sa_visit[n+1]=np.copy(sa_visit[n])\n",
    "    B=np.zeros(nS)\n",
    "    for i in range(nS):\n",
    "        B[i]=y_predict[i]+alpha[n]*sigma[i]\n",
    "        \n",
    "        #B[i]=y_predict[i]+alpha[n]*sigma[i]#+alpha[n]*distance_p2s(i,S_list[-1])\n",
    "        # if distance_p2s(i,visit_set)<=1.5:\n",
    "        #     B[i]=y_predict[i]+alpha[n]*sigma[i]\n",
    "        # else:\n",
    "        #     B[i]=e_risk+1\n",
    "\n",
    "    # new_S=np.copy(np.where(B<=e_risk)[0])\n",
    "    # if compare_set(new_S,S):\n",
    "    #     test=y_predict+alpha[n]*sigma\n",
    "    #     for s in S:\n",
    "    #        test[s]=1e5\n",
    "    #     for s in visit_set:\n",
    "    #         test[s]=1e5\n",
    "    #     min_index=np.argmin(test)\n",
    "    #     B[min_index]=0\n",
    "    #     S=np.copy(np.where(B<=e_risk)[0])\n",
    "    # else: \n",
    "    #     S=np.copy(new_S)\n",
    "    # rtilde=np.zeros((nS,nA))\n",
    "    # S_list.append(S)\n",
    "\n",
    "    new_S=np.copy(np.where(B<=e_risk)[0])\n",
    "    test_bool=compare_set(new_S,S)\n",
    "    if test_bool:\n",
    "        test=y_predict+alpha[n]*sigma\n",
    "        for s in S:\n",
    "           test[s]=1e6\n",
    "        for s in visit_set:\n",
    "            test[s]=1e6\n",
    "        for s in range(nS):\n",
    "            if distance_p2s(s,S)>1.1:\n",
    "                test[s]=1e6\n",
    "        min_index=np.argmin(test)\n",
    "        if test[min_index] !=1e6:\n",
    "            B[min_index]=0\n",
    "        S=np.copy(np.where(B<=e_risk)[0])\n",
    "    else: \n",
    "        S=np.copy(new_S)\n",
    "    rtilde=np.zeros((nS,nA))\n",
    "    S_list.append(S)\n",
    "\n",
    "    for s in range(nS):\n",
    "        for a in range(nA):\n",
    "            if s in S:\n",
    "                rtilde[s,a]=r[s,a]#-10*sa_visit[n+1,s,a]/total_visit\n",
    "            else: \n",
    "               rtilde[s,a]=-T#-10*sa_visit[n+1,s,a]/total_visit\n",
    "            if unsafe_set[s]>0:\n",
    "                rtilde[s,a]=-T*T\n",
    "    # rtilde[0,1]=-T\n",
    "    # rtilde[0,0]=-T\n",
    "    # rtilde[0,3]=-T\n",
    "    rtilde[nS-2,5]=T\n",
    "\n",
    "\n",
    "    rtilde[nS-1,0]=-T\n",
    "    rtilde[nS-1,2]=-T\n",
    "    rtilde[nS-1,3]=-T\n",
    "    rtilde[nS-1,4]=-T\n",
    "    rtilde[nS-1,6]=-T\n",
    "    rtilde[nS-1,7]=-T\n",
    "    rtilde[nS-1,1]=T\n",
    "    rtilde[nS-1,5]=T\n",
    "    #Q-learning \n",
    "    pi=Qlearning(rtilde,M,T,sa_visit[n+1],total_visit,c_Qlearning,S,unsafe_sa)\n",
    "    pi[nS-1]=np.array([0,1,0,0,0,0,0,0])    \n",
    "    #pi[0]=np.array([0,1,1,0])\n",
    "    policy_list.append(pi)\n",
    "    dataset=[]\n",
    "    t=0\n",
    "    #random start\n",
    "    start_set=[]\n",
    "    unvisited_set=[]\n",
    "    for s in range(nS):\n",
    "        row,col=to_row_col(s)\n",
    "        if map_type[row,col]<=e_risk and state_visit[n,row,col]>0:\n",
    "            start_set.append(s)\n",
    "        if state_visit[n,row,col]==0:\n",
    "            unvisited_set.append(s)\n",
    "\n",
    "    #s=0\n",
    "    s=np.random.choice(start_set,p=np.ones(len(start_set))/len(start_set))\n",
    "    a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "    n_violate=0\n",
    "\n",
    "    #while (s_next[s,a] in S and t<T and true_cost[s,a]*(1+noise) <e_risk ):\n",
    "    while (s in S and t<T and n_violate<0.5 ):\n",
    "        row,col=to_row_col(s)\n",
    "        state_visit[n+1,row,col]+=1\n",
    "        sa_visit[n+1,s,a]+=1\n",
    "        total_visit+=1\n",
    "        new_row,new_col=inc_random(row,col,number_to_action(a))\n",
    "        new_s=to_s(new_row,new_col)\n",
    "        # noise=truncnorm.rvs(-0.3, 0.3, size=1)[0]\n",
    "        # noise=0  \n",
    "        #if true_cost[s,a]*(1+noise)>e_risk:\n",
    "        if map_type[to_row_col(new_s)]>e_risk:\n",
    "            n_violate+=1\n",
    "            total_violation+=1\n",
    "            unsafe_sa[s,a]+=1\n",
    "            unsafe_set[new_s]+=1\n",
    "        dataset.append([s,a,new_s,true_cost[s,a]])\n",
    "        #if true_cost[s,a]!=0:\n",
    "            #dataset.append([s,a,new_s,true_cost[s,a]+noise])\n",
    "        #else:\n",
    "            #dataset.append([s,a,new_s,0])\n",
    "        #dataset.append([s,a,new_s,(true_cost[s,a]!=0)*(true_cost[s,a]+noise)])\n",
    "        s=new_s\n",
    "\n",
    "        #state_visit[n+1,to_row_col(s)[0],to_row_col(s)[1]]+=1\n",
    "        a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "        t+=1\n",
    "    # if len(dataset)>0:\n",
    "    #     row,col=to_row_col(s)\n",
    "    #     state_visit[n+1,row,col]+=1   \n",
    "    data_list.append(dataset)\n",
    "    # data_len=len(dataset)\n",
    "    # x_train=np.zeros((data_len,2))\n",
    "    # y_train=np.zeros(data_len)\n",
    "    # for i in range(data_len):\n",
    "    #     #x_train[i]=np.array([to_row_col(dataset[i][2])[0]-(nrow-1)/2,to_row_col(dataset[i][2])[1]-(ncol-1)/2])/x_scale\n",
    "    #     x_train[i]=np.array([to_row_col(dataset[i][2])[0],to_row_col(dataset[i][2])[1]])/x_scale\n",
    "    #     y_train[i]=dataset[i][3]\n",
    "    # gp.fit(x_train,y_train)\n",
    "    # y_predict,cov=gp.predict(x_predict,return_cov=True)\n",
    "    if len(dataset)==0: print('No data')\n",
    "    else:\n",
    "        new_y,new_cov=gauss_fit(y_predict,cov,dataset,state_visit[n])\n",
    "        y_predict=np.copy(new_y)\n",
    "        cov=np.copy(new_cov)\n",
    "        sigma=np.diag(cov)\n",
    "    \n",
    "    #print(str(n)+'ite: mu '+str(y_predict.reshape(8,8)))\n",
    "    #print(str(n)+'ite: sigma '+str(sigma.reshape(8,8)))\n",
    "    # print(str(n)+'ite: sigma '+str(sigma[1])+' last:'+str(sigma[-1]))\n",
    "    y_predict_list[n+1]=np.copy(y_predict.reshape(nrow,ncol))\n",
    "    sigma_list[n+1]=np.copy(sigma.reshape(nrow,ncol))\n",
    "    visit_set=[]\n",
    "    for s in range(nS):\n",
    "        if state_visit[n+1,to_row_col(s)[0],to_row_col(s)[1]]>0:\n",
    "            visit_set.append(s)\n",
    "    visit_set_list.append(visit_set)  \n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAncAAAKDCAYAAAB4ySxtAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAxpElEQVR4nO3df5BddX0//tfdXbJrYHezm3SIIStZYrCNuI2kqztUos6EAckPS/WjCZ3vQJQBaRV/wKppRQoyG7QYRYeIJmliacAPOjrgj/ijQlpsY5mkcWXdmEpc4iJSkw/J3g0LN0D2+wdk63KTcG9yc+89J49H5vxxbs8579feKXNfPt/nfU5mdHR0NAAASIWaShcAAEDpaO4AAFJEcwcAkCKaOwCAFNHcAQCkiOYOACBFNHcAACmiuQMASJG6ShcAAHAsnnnmmThw4EDZx50wYUI0NDSUfdxCae4AgMR55pln4hWNkyOeGyn72FOnTo2BgYGqbfA0dwBA4hw4cCDiuZGon31ZRO2E8g38/IF4ov+rceDAAc0dAEDJ1TVEpozN3Wim+pcrVH+FAAAUTHMHAJAipmUBgOTKREQmU97xqpzkDgAgRSR3AEByZWpe2Mo5XpWr/goBACiY5g4AIEVMywIAyZXJlHlBRfWvqJDcAQCkiOQOAEguCyryVH+FAAAUTHIHACSXe+7ySO4AAFJEcwcAkCKmZQGABCvzgooE5GLVXyEAAAWT3AEAyWVBRR7JHQBAimjuAABSxLQsAJBc3lCRp/orBACgYJI7ACC5LKjII7kDAEgRyR0AkFzuuctT/RUCAFAwzR0AQIqYlgUAksuCijySOwCAFJHcAQDJZUFFnuqvEACAgmnuAABSxLQsAJBcmUyZp2UtqAAAoIw0dwBActVkyr8Vac+ePdHe3h6PPvpoUec9++yz8brXvS42bdpU1HmaOwCAE2TPnj2xcOHCohu7iIjPfOYz0dfXV/R5mjsAgBNkyZIlcemllxZ93q9+9au49dZbY8aMGUWfq7kDAJLr0HPuyrkVYfXq1XHNNdcU/WddddVV8fGPfzzOPPPMos/V3AEAFCmbzY7bcrncYY9rb28v+trr1q2LoaGhuO66646pNs0dAJBch94tW84tItra2qK5uXlsW7FiRUn+nN27d8fy5cvjH//xH6O2tvaYruE5dwAARRocHIympqax/fr6+pJc90Mf+lC8973vjT/90z895mtkRkdHR0tSDQBAmWSz2Whubo76N98QmbqGso07+twzkfvXG2NoaGhcc/dyMplMDAwMvOwCiUwmE42NjVFT88Lk6v79+6OhoSE+8YlPxMc//vGCxpLcAQCUWTabjVe84hVxyimnjPt8YGBg3P6SJUviQx/6UFx00UUFX9s9dwAAZdbR0RHf/e538z6fMWPGuK2hoSGmTp0akyZNKvjakjsAILn+YJFD2cY7Bi+9C67QhxoX+3aKCMkdAECqSO4AgOQ6hgcLH/d4Va76KwQAoGCaOwCAFDEtCwAkV0IWVJST5A4AIEUkdwBAcllQkaf6KwQAoGCSOwAgudxzl0dyBwCQIpo7AIAUMS0LACRYmRdUJCAXq4rm7uDBg/H4449HY2NjZBIwlw0ARIyOjsbw8HBMmzYtamqqv+k5WVRFc/f4449HW1tbpcsAAI7B4OBgTJ8+vTKDW1CRpyqau8bGxoiIeGRgMBqbmipcDQBQiOFsNl7d3jb2O051qIrm7tBUbGNTUzRp7gAgUdxSVV2qorkDADgmmUyZ31BR/Y2sux8BAFJEcgcAJJd3y+ap/goBACiY5A4ASC6PQskjuQMASBHNHQBAipiWBQCSy4KKPNVfIQAABZPcAQDJZUFFHskdAECKaO4AAFLEtCwAkFwWVOQpWYV9fX3R2dkZLS0t0d3dHaOjo6W6NAAABSpJc5fL5WLRokUxd+7c2LJlS/T398f69etLcWkAgCM7tKCinFuVK0lzt3HjxhgaGoqVK1fGzJkzo6enJ9auXVuKSwMAUISS3HPX29sbXV1dMXHixIiI6OjoiP7+/lJcGgDgiDKZTGQ8CmWckjR32Ww22tvbx/YzmUzU1tbG3r17o6WlJe/4XC4XuVxu3PkAABy/kkzL1tXVRX19/bjPGhoaYmRk5LDHr1ixIpqbm8e2tra2UpQBAHDSK0lz19raGrt37x732fDwcEyYMOGwxy9fvjyGhobGtsHBwVKUAQCcZA5Ny5Zzq3YlmZbt7OyM1atXj+0PDAxELpeL1tbWwx5fX1+fl/QBAHD8SpLczZs3L7LZbKxbty4iInp6emL+/PlRW1tbissDABxepgJblStJcldXVxdr1qyJpUuXRnd3d9TU1MSmTZtKcWkAAIpQstePLV68OHbu3Blbt26Nrq6umDx5cqkuDQBAgUr6btmpU6fGggULSnlJAIAj8py7fNX/9lsAAApW0uQOAKCcJHf5JHcAACkiuQMAEktyl09yBwCQIpo7AIAUMS0LACSWadl8kjsAgBSR3AEAyVXu971Wf3AnuQMASBPNHQBAipiWBQASy4KKfJI7AIAUqark7vv9v4uJp+2vdBkAnAQWnjOt0iVQAplMlDm5K99Qx0pyBwCQIlWV3AEAFCMTZb7nLgHRneQOACBFNHcAACliWhYASCyPQsknuQMASBHJHQCQXN4tm0dyBwCQIpo7AIAUMS0LACRXmRdUjFpQAQBAOUnuAIDEKvejUMr7NoxjI7kDAEgRzR0AQIqYlgUAEsu0bD7JHQBAimjuAIDkylRgK9KePXuivb09Hn300YKO/8pXvhKvfOUr45RTTok3v/nN8bvf/a6o8TR3AAAnyJ49e2LhwoUFN3Y/+clP4vrrr48777wzBgYGYnR0NK677rqixtTcAQCJdeieu3JuxViyZElceumlBR//q1/9Kr785S/H/PnzY/r06bFs2bLYtm1bUWNaUAEAcIKsXr062tvb44Mf/GBBxy9btmzc/o4dO2LWrFlFjam5AwAoUjabHbdfX18f9fX1ece1t7cf8xhPPvlkfPnLX4677rqrqPNMywIAiVWpadm2trZobm4e21asWFHyv+1v/uZv4rzzzou3ve1tRZ0nuQMAKNLg4GA0NTWN7R8utTseX/3qV+OBBx6I3t7eos/V3AEAiVWphxg3NTWNa+5KacuWLfGBD3wg7rvvvjj99NOLPt+0LABAmWWz2Xj22WfzPv/9738fixYtio9+9KPxZ3/2Z7F///7Yv39/UdfW3AEAlFlHR0d897vfzfv87rvvjieeeCKuv/76aGxsHNuKYVoWAEispLxbdnR0dNz+kR5q/MEPfrDgx6YcieQOACBFJHcAQHId4/tej2u8Kie5AwBIEckdAJBYSbnnrpwkdwAAKaK5AwBIEdOyAEBimZbNJ7kDAEgRyR0AkFiSu3ySOwCAFNHcAQCkiGlZACC5vKEij+QOACBFJHcAQGJZUJGvqpq7L/zLzqhrOLXSZSRe7//9eqVLSI0/fff/qXQJkEjXXTSr0iXASauqmjsAgGJI7vK55w4AIEU0dwAAKWJaFgBIrEyUeVo2Ac9CkdwBAKSI5A4ASCwLKvJJ7gAAUkRzBwCQIqZlAYDk8m7ZPJI7AIAUkdwBAIllQUU+yR0AQIpI7gCAxJLc5ZPcAQCkSMmau3vvvTfOOuusqKurizlz5sT27dtLdWkAAApUkuZu586dsWzZsrjlllvit7/9bZx99tlxxRVXlOLSAABHlMmUf6t2JWnutm/fHrfccku8613vitNPPz2uvvrq2LZtWykuDQBAEUqyoGLhwoXj9nfs2BGzZs0qxaUBAI7ohTStnAsqyjbUMSv5atkDBw7EZz/72fjIRz5yxGNyuVzkcrmx/Ww2W+oyAABOSiVfLXvDDTfEqaeeetR77lasWBHNzc1jW1tbW6nLAAA4KZW0ubv//vvj9ttvj7vuuitOOeWUIx63fPnyGBoaGtsGBwdLWQYAcLIo92KKk2ladmBgIJYuXRq33357zJ49+6jH1tfXR319famGBgDgRSVp7p5++ulYuHBhvP3tb49LLrkk9u/fHxERp556aiKe5AwAJJM3VOQrybTsD3/4w+jv74/Vq1dHY2Pj2LZr165SXB4AgAKVJLl7+9vfHqOjo6W4FABAwcr9YOEEBHfeLQsAkCaaOwCAFCn5Q4wBAMqlpiYTNTXlmysdLeNYx0pyBwCQIpI7ACCxLKjIJ7kDAEgRzR0AQIqYlgUAEssbKvJJ7gAAUkRyBwAklgUV+SR3AAApIrkDABLLPXf5JHcAACmiuQMASBHTsgBAYpmWzae5K8J1F82qdAmFuehvK10BAFAhmjsAILE8CiWfe+4AAFJEcwcAkCKmZQGAxMpEmRdURPXPy0ruAABSRHIHACSWBRX5JHcAACmiuQMASBHTsgBAYnlDRT7JHQBAikjuAIDEsqAin+QOACBFJHcAQGK55y6f5A4AIEU0dwAAKWJaFgBILAsq8knuAABOoD179kR7e3s8+uijBR3/r//6r/Enf/InMWXKlFi5cmXR42nuAIDEOrSgopxbMfbs2RMLFy4suLHbvXt3LF68OJYuXRqbN2+ODRs2xAMPPFDUmJo7AIATZMmSJXHppZcWfPyGDRti2rRpcf3118esWbPik5/8ZKxdu7aoMTV3AABFymaz47ZcLnfY41avXh3XXHNNwdft7e2Nt771rWMJ4Rve8IbYunVrUbVp7gCA5Mr876KKcmzx4qxsW1tbNDc3j20rVqw4bHnt7e1F/TnZbHbcOU1NTfH4448XdQ2rZQEAijQ4OBhNTU1j+/X19SW5bl1d3bhrNTQ0xMjISHHXKEklAAAVUKk3VDQ1NY1r7kqltbU1du/ePbY/PDwcEyZMKOoapmUBAKpEZ2dnbN68eWx/27ZtccYZZxR1Dc0dAJBY5bzfrpQPTM5ms/Hss8/mfb548eL493//9/iXf/mXePbZZ+Mzn/lMXHjhhUVdW3MHAFBmHR0d8d3vfjfv8ylTpsTnPve5uPjii+P000+PHTt2xCc+8Ymiru2eOwCAE2x0dHTc/tEeavy+970vLrzwwvjlL38Z559/fpx22mlFjaW5AwASq1ILKk609vb2oh+jcohpWQCAFJHcAQCJVcpFDoWOV+0kdwAAKaK5AwBIEdOyAEBipXVBxfGQ3AEApIjkDgBILMldPskdAECKSO4AgMTyKJR8kjsAgBTR3AEApIhpWQAgsSyoyFdVzd0182fGxNMaK13GES08Z1qlSwAAOKqqau4AAIphQUU+99wBAKSI5g4AIEVMywIAiWVBRT7JHQBAikjuAIDEykSZF1SUb6hjJrkDAEgRyR0AkFg1mUzUlDG6K+dYx0pyBwCQIpo7AIAUMS0LACSWN1Tkk9wBAKSI5A4ASCwPMc4nuQMASBHNHQBAipyQ5u6iiy6K9evXn4hLAwCMqcmUf6t2JW/uNmzYED/4wQ9KfVkAAApQ0gUVTz75ZFx77bXxmte8ppSXBQA4vEyZFzkkILkraXN37bXXxiWXXBJPP/10KS8LAECBStbcPfDAA/HjH/84fvGLX8QHPvCBox6by+Uil8uN7Wez2VKVAQCcRDzEOF9J7rl75pln4qqrroovfelL0djY+LLHr1ixIpqbm8e2tra2UpQBAHDSK0lz96lPfSo6OztjwYIFBR2/fPnyGBoaGtsGBwdLUQYAwEmvJNOyd911V+zevTsmTZoUEREjIyNxzz33xEMPPRSrVq3KO76+vj7q6+tLMTQAcBLLvPivnONVu5I0dw8++GA899xzY/vXXXdddHV1xeWXX16KywMAUKCSNHfTp08ft3/aaafFlClTYsqUKaW4PADAYZX7wcJJeIhxSR+Fcoi3UwAAVIZ3ywIApMgJSe4AAMohk8mU9Q0VZX0bxjGS3AEApIjkDgBILG+oyCe5AwBIEckdAJBYNZlM1JQxTivnWMdKcgcAkCKaOwCAFDEtCwAklgUV+SR3AAApIrkDABLLQ4zzSe4AAFJEcwcAkCKmZQGAxLKgIp/kDgAgRaoqubto9iujqamp0mUAAAnhDRX5JHcAACmiuQMASJGqmpYFAChG5sWtnONVO8kdAECKSO4AgMTyhop8kjsAgBSR3AEAiVWTeWEr53jVTnIHAJAimjsAgBQxLQsAJJYFFfkkdwAAKSK5AwASLQFhWllJ7gAAUkRzBwCQIqZlAYDEsqAin+QOAOAE6uvri87OzmhpaYnu7u4YHR096vGjo6Nx9dVXR2tra0yaNCkuv/zyePrppwseT3MHACTWoTdUlHMrRi6Xi0WLFsXcuXNjy5Yt0d/fH+vXrz/qOXfeeWfs2LEjtm3bFg8++GD84he/iBUrVhT+nRRXIgAAhdq4cWMMDQ3FypUrY+bMmdHT0xNr16496jkPPfRQvPOd74wzzzwzXve618Vf/MVfxCOPPFLwmJo7ACCxDt1zV84tIiKbzY7bcrncYevr7e2Nrq6umDhxYkREdHR0RH9//1H/pte+9rXxz//8z/E///M/sWvXrvja174WF1xwQcHfieYOAKBIbW1t0dzcPLYdado0m81Ge3v72H4mk4na2trYu3fvEa99xRVXxP79+2Pq1KkxY8aMaG9vj8suu6zg2jR3AABFGhwcjKGhobFt+fLlhz2urq4u6uvrx33W0NAQIyMjR7z2bbfdFpMmTYpdu3bFb37zm3juueeiu7u74No0dwBAYmUqsEVENDU1jdte2sAd0traGrt37x732fDwcEyYMOGIf9OGDRuiu7s7XvWqV0VbW1usWLHiZe/T+0OaOwCAE6SzszM2b948tj8wMBC5XC5aW1uPeM7Bgwfj97///dj+E088Ec8//3zBY3qIMQCQWDWZTNSU8cHCxY41b968yGazsW7duli2bFn09PTE/Pnzo7a2Nvbt2xeNjY1RW1s77pzzzz8/brnllqitrY0DBw7Epz/96Vi8eHHBY2ruAABOkLq6ulizZk0sXbo0uru7o6amJjZt2hQRES0tLbFt27aYM2fOuHNuvvnmyGaz8dGPfjSGh4fjwgsvjNtuu63wMUtYPwAAL7F48eLYuXNnbN26Nbq6umLy5MkREUd8U8WkSZPin/7pn455PM0dAJBYmcwLWznHOxZTp06NBQsWlLaYI7CgAgAgRSR3AEBi/eFbI8o1XrWT3AEApIjkDgBIrKTcc1dOkjsAgBTR3AEApIhpWQAgsar9DRWVILkDAEgRyR0AkFgWVOST3AEApIjmDgAgRUzLAgCJ5Q0V+SR3AAApIrlLoe/0PV7pEgA4CYzsH650CVET5U2qkpCKJaFGAAAKJLkDABLLPXf5JHcAACmiuQMASBHTsgBAYmUyETXeUDGO5A4AIEUkdwBAYtWUObkr51jHSnIHAJAimjsAgBQxLQsAJJbn3OWT3AEApIjkDgBILAsq8knuAABSRHIHACRWJlPeBwsn4JY7yR0AQJqUvLn72Mc+FosWLSr1ZQEAKEBJp2V//vOfx6pVq6K3t7eUlwUAOKyaTCZqyjhXWs6xjlXJkruDBw/GlVdeGR/+8IfjrLPOKtVlAQAoQsmauzvuuCMefvjhmDFjRtx3331x4MCBUl0aAOCwaiqwVbuS1Lh///644YYb4qyzzopdu3bF5z73uXjTm94UTz/99GGPz+Vykc1mx20AABy/kjR33/zmN+Opp56KBx54IG688cb40Y9+FMPDw3HnnXce9vgVK1ZEc3Pz2NbW1laKMgAATnolae4ee+yx6OrqiilTpkRERF1dXXR0dMQjjzxy2OOXL18eQ0NDY9vg4GApygAATjKHnnNXzq3alWS17PTp0/OmYHft2hXnnXfeYY+vr6+P+vr6UgwNAMAfKElyt2DBgujv74877rgjHnvssfjCF74Qvb298Zd/+ZeluDwAwGHVRGbscShl2aL6o7uSNHeTJ0+O733ve/HVr341zj777LjtttvinnvucS8dAECZlewhxn/+538emzdvLtXlAABelnfL5kvC41oAACiQ5g4AIEVK+m5ZAIByqsm8sJVzvGonuQMASBHJHQCQWJlMRE0ZVzlYUAEAQFlp7gAAUsS0LACQWJ5zl09yBwCQIpI7ACCxPAoln+QOACBFNHcAACliWhYASKzMi//KOV61k9wBAKSI5K4I3+l7vNIlFOTW7/+q0iXAONddNKvSJaSG/76pJs8981SlS7Cg4jAkdwAAKSK5AwASS3KXT3IHAJAimjsAgBQxLQsAJFYmk4lMGV/4Ws6xjpXkDgAgRSR3AEBiWVCRT3IHAJAimjsAgBQxLQsAJFYm88JWzvGqneQOACBFJHcAQGLVZDJRU8Y4rZxjHSvJHQBAikjuAIDE8iiUfJI7AIAU0dwBAJxAfX190dnZGS0tLdHd3R2jo6MFnXfw4ME477zz4rOf/WxR42nuAIDkyvzv41DKsUWR07K5XC4WLVoUc+fOjS1btkR/f3+sX7++oHPvuOOOGBoaimuuuaaoMTV3AAAnyMaNG2NoaChWrlwZM2fOjJ6enli7du3Lnvf444/H3/7t38YXv/jFOOWUU4oaU3MHACRWTWTKvhWjt7c3urq6YuLEiRER0dHREf39/S973oc+9KE488wzY3BwMP7jP/6jyO8EAICiZLPZcVsulzvice3t7WP7mUwmamtrY+/evUe89ubNm+PrX/96TJ8+PXbu3BmXXXZZvP/97y+4Ns0dAECR2traorm5eWxbsWLFYY+rq6uL+vr6cZ81NDTEyMjIEa+9evXqeOMb3xjf+c534qabbor7778/Vq1aFTt27CioNs+5AwASq1Lvlh0cHIympqaxz1/awB3S2toafX194z4bHh6OCRMmHHGMxx57LC6++OLIvDhYW1tb/NEf/VHs3LkzXvOa17xsjZI7AIAiNTU1jduO1Nx1dnbG5s2bx/YHBgYil8tFa2vrEa89ffr0ePrpp8f29+/fH08++WScccYZBdWmuQMAEuvQGyrKuRVj3rx5kc1mY926dRER0dPTE/Pnz4/a2trYt29fPP/883nnLF26NFavXh0//vGPY9euXfHXf/3X8cd//MfR0dFR0JimZQEATpC6urpYs2ZNLF26NLq7u6OmpiY2bdoUEREtLS2xbdu2mDNnzrhzLrjggvj0pz8dV199dQwODsacOXPiG9/4xtg07cuOWeK/AQCgbGoymagp4013xzLW4sWLY+fOnbF169bo6uqKyZMnR0Qc9U0V733ve+O9733vMdWouQMAOMGmTp0aCxYsKMtY7rkDAEgRyR0AkFiVehRKNZPcAQCkiOQOAEismijzgooi3y1bCZI7AIAU0dwBAKSIaVkAILEsqMgnuQMASBHJHQCQWDVR3qQqCalYEmoEAKBAkjsAILEymUxkyngjXDnHOlaSOwCAFNHcAQCkiGlZACCxMi9u5Ryv2mnuUui6i2ZVuoTU+P+W9VS6hHS46G8rXUFqJOW/71u//6tKl/Cyev/v1ytdQuKNPn+g0iVwGJo7ACCxajJlfresBRUAAJST5g4AIEVMywIAiVb9E6XlJbkDAEgRyR0AkFiZzAtbOcerdpI7AIAUkdwBAInl3bL5JHcAACmiuQMA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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_set(map_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OnSoioqKtGzZslh3y0i7du3S3Llz9etf/1oZGRkqKChQWVlZrLtlrK+//lr333+/zjzzzFh3xWg//PCDbr75Zt17770aMmRIrLtjrLKyMuXm5ur888/XaaedpptuukmffvpprLtljClTpmjq1KltPuP3J3asGGwmO6kKv/LycuXm5iopKUmSlJ2drcrKyhj3ykx5eXm6+eabw/tVVVUaNmxYDHtktvvvv19XX321cnNzY90Voy1ZskQ7d+7U6aefrjfeeEMHDhyIdZeMlJWVpU2bNunPf/6zmpqatHjxYl1++eWx7pYxli5dqrvuuqvNZ/z+wBQnVeFn27YCgUB437IsxcfHq7GxMYa9Mt+BAwf0zDPP6NZbb411V4y0efNm/elPf9JTTz0V664YraWlRXPmzNGQIUO0d+9eLViwQJdccon2798f664ZJysrS9ddd53OO+88paSkqLS0VE8//XSsu2WMn/7OHMHvT+wcWcA5mpvJTqrCLyEhod2q6YmJiWptbY1Rj04Oc+bMUa9evXjG7xh89913uuWWW/TCCy+oT58+se6O0V577TV9++232rx5sx577DG9++67am5u1ssvvxzrrhln27ZtevPNN/XRRx/pm2++UX5+vq666iomIxwHfn9gipOq8EtLS1N9fX2bz5qbm9WzZ88Y9ch8mzZt0qJFi7R69Wr16NEj1t0xzhNPPKGcnBxNmDAh1l0x3meffabc3Fz17dtX0uEf2uzsbJ5NOwZr1qzRlClTdOGFFyo5OVlPPvmkqqurVV5eHuuuGYvfH5jipFrHLycnR0uXLg3v19TUKBgMKi0tLYa9MldNTY3y8/O1aNEiZWVlxbo7Rlq9erXq6+uVkpIiSWptbdWrr76qbdu2afHixbHtnGEGDRrUblh37969uvjii2PUI3P98MMPamhoCO83NzertbVVhw4dimGvzMbvT+zw5g5nTqrCb/To0bJtW8uXL9f06dNVVFSkcePGKT4+PtZdM87+/fuVl5enyZMn6+qrr1ZLS4skqVevXrJMf8Ahij744AN9//334f0HHnhAubm5LJ1xDCZMmKA777xTS5YsUV5enl577TWVl5fr97//fay7ZpxLL71U06ZN0/nnn6+MjAyVlJSof//+ys7OjnXXjMXvD0xxUhV+CQkJKikpUX5+vgoLCxUXF6ctW7bEultGeuedd1RZWanKysp2/y/29NNPj13HDDNo0KA2+71791bfvn3Dw5WIXHp6ut566y098MADuu+++/SLX/xCr776qjIzM2PdNeNce+212rVrl5599ll9/vnnOuecc/T666/zOMdx4PcnhnhzhyNW6CR8mveLL77Qjh07lJubq/T09Fh3BwDgEfz+RI9t20pOTlZ13Vfq4/dHrd1m29bQgelqamqSP4rtuuWkLPwAAMDJjcLv2JxUQ70AAMBbGOl15qRazgUAAACdI/EDAADGivbbNExf2ILEDwAAwCNI/AAAgMGiu4Cz6U/5kfgBAAB4BIUfAACARzDUCwAAjMXkDmdI/AAAADyCwg8AAMAjKPwAAAA8gsIPAADAI5jcAQAAjMXkDmdI/AAAADyCxA8AABjLivKbO6L7lhD3kfgBAAB4BIkfAAAwFs/4OUPiBwAA4BEUfgAAAB7BUC8AADCW9eMWzfZMRuIHAADgESR+AADAXER+jpD4AQAAeASFHwAAgEcw1AsAAIzFmzucIfEDAADwCBI/AABgLN7c4QyJHwAAgEeQ+AEAAGOxmoszJH4AAAAeQeEHAADgEQz1AgAAczHW6wiJHwAAgEeQ+AEAAGOxgLMzJH4AAADdqKKiQjk5OUpNTVVhYaFCodBRr1m7dq0GDx6sAQMGaM2aNW2OLVq0SBkZGRoyZIg2bdrkqC8UfgAAAN0kGAxq4sSJGjlypLZv367KykqtWLGiy2sqKip0ww03aNasWdq4caNmz56tqqoqSdLGjRv1wAMP6KWXXtLvfvc7zZgxQ1999VXE/aHwAwAAxjry5o5obk5s2LBBTU1Nmj9/voYOHaqioiItW7asy2tKSko0duxYzZgxQ8OHD9cdd9yhl19+WZL0wgsvaNq0aZo8ebIuvvhiTZ48Wa+//nrE/eEZPwAAYCzbtmPS3s/b9fl88vl87c4vLy9Xbm6ukpKSJEnZ2dmqrKzsso3y8nJdeeWV4f1Ro0bp8ccfDx+bOnVqm2P/8z//oxkzZkTUfwo/AABgnJ49e6p///4aFsiMetu9e/dWZmbbdufMmaNHH3203bm2bSsQCIT3LctSfHy8GhsblZqa2uH9f36N3+/Xvn37jnosEhR+AADAOImJiaqpqdGBAwei3nYoFJL1szHfjtI+SUpISGh3LDExUa2trZ0Wfj+/5sj5RzsWCQo/AABgpMTERCUmJsa6G11KS0tTRUVFm8+am5vVs2fPLq+pr6/v8PyujkWCyR0AAADdJCcnR6WlpeH9mpoaBYNBpaWlRXxNWVmZBg4ceNRjkaDwAwAA6CajR4+Wbdtavny5JKmoqEjjxo1TfHy8vvnmGx06dKjdNddee61eeeUV7dy5Uy0tLVq4cKHGjx8vSbruuuu0ePFi1dXV6Z///KeWLVsWPhYJKxTJKoIAAAA4Jm+88Yby8/N1yimnKC4uTlu2bFFWVpYsy1JZWZnOPffcdtc8/PDDevrpp5WYmKhhw4bpgw8+0CmnnKJQKKR/+7d/0x/+8AdJ0q9+9Su98cYb7Z457AyFHwAAQDf74osvtGPHDuXm5io9PT2iayorK1VXV6cxY8a0e47vk08+0bfffqsxY8ZEXPRJFH4AAACewTN+AAAAHkHhBwAA4BEUfgAAAB5B4QcAAOARFH4AAAAeQeEHAADgERR+AAAAHkHhBwAA4BEUfgAAAB7x/wPxHq1SLYZ/HQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_state_set(S_list[N])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "final_state_visit=np.copy(state_visit[N])\n",
    "final_state_visit[nrow-1,ncol-1]=0\n",
    "plot_set(np.minimum(final_state_visit,500))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "77173"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_data_number=0\n",
    "for i in range(len(data_list)):\n",
    "    total_data_number+=len(data_list[i])\n",
    "total_data_number"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6"
      ]
     },
     "execution_count": 150,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_violation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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aDzNHQCQWO8sqCjlMRF79+6NFStWxJo1a+KVV16Jiy66KFauXBm5XC6WLVsWCxcujJ07d0Zvb29s2bIlIiL27dsXy5cvj/b29ujq6oqtW7fGk08+WfCYmjsAgNNkz549sWbNmrjuuuti9uzZceutt8bu3btj+/btMTg4GGvXro158+ZFZ2dnbNq0KSIitm7dGuecc07cc889ceGFF8ZXvvKVsdcK4Zo7AIAJymaz4x7X1dVFXV1d3vuWLl067vGLL74YF154YXR3d0dbW1tMmTIlIiIWLFgQvb29ERHR3d0dn/jEJ8ZSwg9/+MPxT//0TwXXJrkDAJIr89+LKkpxxNuzss3NzdHQ0DB2rF69+oSlHjp0KO6///645ZZbIpvNRktLy3//Z2QyUV1dHQMDA3mv1dfXx6uvvlrwVyK5AwCYoP7+/qivrx97fKzU7k+tWrUqpk6dGitXroy777477zOTJ0+O4eHhqKmpGffaO88XSnMHACRWue5QUV9fP665O5Ennngi1q1bF08//XRMmjQpmpqaoqenZ9x7hoaGora2NpqammLfvn15zxfKtCwAwGnU19cX7e3tsW7dupg/f35ERLS2tkZXV9e49+RyuWhqasp7bffu3XHuuecWPJ7mDgBIrFJeb3cyGyYfPHgwli5dGldffXVcc801ceDAgThw4EBcfvnlkc1mY/PmzRER0dnZGYsXL47q6upYvnx5/PKXv4yf/exncfjw4bjvvvviiiuuKHhM07IAAKfJ448/Hr29vdHb2xsbNmwYe76vry82btwY7e3t0dHREVVVVbFjx46IiJg1a1Y88MADcdVVV8W0adNixowZY3vgFUJzBwBwmlx99dXj7jzxbueff37s3bs3du3aFW1tbTFz5syx12655Za44oor4oUXXojLL788pk2bVvCYmjsAILHKtaCiWObMmRNLliw55mstLS3jtkQplGvuAABSRHIHACTWySxyONXxKp3kDgAgRTR3AAApYloWAEispC+oOB0kdwAAKSK5AwASS3KXT3IHAJAikjsAILFshZJPcgcAkCKaOwCAFDEtCwAklgUV+SqquWuYPCmmnzWp3GUc15tHRspdQkEOHjpa7hJOaDh3pNwlFOTNw5X/Xe47mCt3CanRUFe5f/+84+XsG+UuoSB/fmRquUs4offV15W7BDgtKqq5AwCYCAsq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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "state_attemp=np.minimum(300*np.ones((nrow,ncol)),final_state_visit)\n",
    "plot_set(state_attemp)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x241adb29070>]"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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5d/vtILIYCGIAAAw/KTy73dGbnoHAACGBoIIAACwhiACAACsIYgAAABrCCIAAMAagggAALCGIAIAAKwhiAAAAGtS2n13sB1fay0UClnuCQAAcOv4v9tu1kwd0kEkHA5LkoqLiy33BAAApCocDqugoCBhmyG9xHt3d7f27dunvLw8ZWVleXrtUCik4uJitbW1sXz8AGKcBwfjPHgY68HBOA+OgRpnY4zC4bAmTJigUaMSPwUypO+IjBo1SpMmTRrQ75Gfn88v+SBgnAcH4zx4GOvBwTgPjoEY52R3Qo7jYVUAAGANQQQAAFiTsUEkEAjojjvuUCAQsN2VEY1xHhyM8+BhrAcH4zw4hsI4D+mHVQEAwMiWsXdEAACAfQQRAABgDUEEAABYQxABAADWZGQQaWpqUllZmYLBoCorK12thY++bdmyRaeddpr8fr+mT5+unTt3Sko8xq+//rrOOussjRs3TjU1Nba6PmxddNFF2rBhg6TEY7l582ZNnjxZEyZM0NNPP22hp8PbT3/6Uy1atCh2zO+0t9atW6fi4mLl5ubqP/7jP/TPf/5TEuPshQMHDqikpETvv/9+7LN0x3VQ/o6YDPPpp5+aKVOmmOuvv97s3r3bLFiwwDz++OO2uzUs7d692wSDQfOb3/zG7N+/31x++eXmvPPOSzjGH3/8scnPzzcrVqww7733nvn6179utm3bZvknGT6eeuopI8nU1tYmHMsdO3aY7Oxss3btWvP222+b008/3bz77ruWez98NDY2mjFjxpiWlhZjTOK/G/xOp2737t2muLjY1NfXmz179phrrrnGzJ49m3H2QHt7u5k1a5aRZFpbW40x6f/+DtbfkYwLIs8995wJBoPm8OHDxhhj3nrrLfPNb37Tcq+GpxdffNH88pe/jB1v27bNnHDCCQnHeNWqVebMM8803d3dxhhjnn/+eXPVVVcNfueHoX/961/m5JNPNl/96ldNbW1twrG85ZZbzPz582PnPvjgg+bnP/+5lX4PN8eOHTOzZs0yt912W+wzfqe99eyzz5rLL788dvzGG2+YU045hXH2wLe//W2zevVqRxBJd1wH6+9IxpVmGhsbVV5ertzcXElSaWmpmpubLfdqeLr44ot13XXXxY537dqlM844I+EYNzY2au7cubFNDGfOnKn6+vrB7/ww9OMf/1iXXHKJysvLJSUey8bGRn3rW9+Kncs4u/fYY49px44dmjJlil544QUdPXqU32mPTZs2Tdu2bdNbb72lzs5OPfroo7rwwgsZZw+sXbtWN998s+OzdMd1sP6OZFwQCYVCKikpiR1nZWXJ5/Pp4MGDFns1/B09elQPPPCAbrjhhoRj/OWv5efna9++fTa6PKy8+uqreuWVV3TvvffGPks0loxzeg4dOqQ77rhDp512mvbs2aNVq1bp/PPP53faY9OmTdNll12mc889V4WFhaqrq9P999/POHug5xgdl+64DtaYZ1wQ8fv9vZayzcnJUVdXl6UejQx33HGHTjzxRC1dujThGH/5a4x9cp9++qmuv/56rVmzRnl5ebHPE40l45ye3/3udzp8+LBeffVVrVixQi+99JLC4bAef/xxfqc99Oabb+rFF1/U3//+d3V0dKiiokILFizgb8cASXdcB2vMMy6IFBUVqb293fFZOBxWdna2pR4Nf9u2bdMjjzyiTZs2afTo0QnH+MtfY+yTu+uuu1RWVqaFCxc6Pk80loxzej744AOVl5dr3Lhxkv79h7i0tFQdHR38Tnvo6aef1pVXXqlZs2apoKBAd999t1paWvjbMUDSHdfBGvOMCyJlZWWqq6uLHbe2tioSiaioqMhir4av1tZWVVRU6JFHHtG0adMkJR7jL3+toaFBEydOHPR+DyebNm3Sli1bVFhYqMLCQm3atEk33XSTnnjiibhjyTinZ9KkSTpy5Ijjsz179ujBBx/kd9pD3d3d+vjjj2PH4XA49r9zxtl76f5NHrQx9/zx1yHus88+MyeddFJs6tLSpUvNxRdfbLlXw1NXV5eZNm2a+cEPfmDC4XDsdfTo0bhj3N7ebnJycsxLL71kjh49ai666CKzbNkymz/GkNfW1mZaW1tjr0svvdTcd999CcfyrbfeMieeeKJ5++23TTgcNtOnTzf333+/5Z9k6Dtw4IDJz883a9asMW1tbWb16tUmJyfH7N27l99pDz377LMmNzfX1NTUmI0bN5q5c+eayZMn87fDQ+oxaybRv3tD4e9IxgURY4zZsmWLyc3NNWPHjjUnnXSSeeedd2x3aVh6/vnnjaRer9bW1oRjvGbNGjN69GgTDAZNSUmJ2b9/v8WfYvhZsmSJqa2tNcYkHstbb73VZGdnm/z8fDNjxgzT1dVlqcfDyxtvvGHKy8vNCSecYE477TTzwgsvGGMS/93gdzo13d3d5s477zSnnnqqGT16tDn33HPNP/7xD2MM4+yVnkHEmPTHdTD+jmRFO5xx9u/fr/r6epWXl2vs2LG2uzMiJRrj1tZWvfvuu5o9e7bGjBljqYcjQ6KxbG5u1ocffqgLLriAeroH+J0eHIzzwEh3XAf670jGBhEAAGBfxj2sCgAAhg6CCAAAsIYgAgAArCGIAAAAawgiAADAGoIIAACwhiACAACsIYgAAABrCCIAAMCa/w8ugrgtF/ZbggAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "count_hole_list=np.zeros(N+1)\n",
    "for i in range(i+1):\n",
    "    count_hole_list[i]=count_route_holes(data_list[i])\n",
    "count_hole_list\n",
    "plt.plot(np.linspace(0,N,N+1),count_hole_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OnSoioqKtGzZslh3y0i7du3S3Llz9etf/1oZGRkqKChQWVlZrLtlrK+//lr333+/zjzzzFh3xWg//PCDbr75Zt17770aMmRIrLtjrLKyMuXm5ur888/XaaedpptuukmffvpprLtljClTpmjq1KltPuP3J3asGGwmO6kKv/LycuXm5iopKUmSlJ2drcrKyhj3ykx5eXm6+eabw/tVVVUaNmxYDHtktvvvv19XX321cnNzY90Voy1ZskQ7d+7U6aefrjfeeEMHDhyIdZeMlJWVpU2bNunPf/6zmpqatHjxYl1++eWx7pYxli5dqrvuuqvNZ/z+wBQnVeFn27YCgUB437IsxcfHq7GxMYa9Mt+BAwf0zDPP6NZbb411V4y0efNm/elPf9JTTz0V664YraWlRXPmzNGQIUO0d+9eLViwQJdccon2798f664ZJysrS9ddd53OO+88paSkqLS0VE8//XSsu2WMn/7OHMHvT+wcWcA5mpvJTqrCLyEhod2q6YmJiWptbY1Rj04Oc+bMUa9evXjG7xh89913uuWWW/TCCy+oT58+se6O0V577TV9++232rx5sx577DG9++67am5u1ssvvxzrrhln27ZtevPNN/XRRx/pm2++UX5+vq666iomIxwHfn9gipOq8EtLS1N9fX2bz5qbm9WzZ88Y9ch8mzZt0qJFi7R69Wr16NEj1t0xzhNPPKGcnBxNmDAh1l0x3meffabc3Fz17dtX0uEf2uzsbJ5NOwZr1qzRlClTdOGFFyo5OVlPPvmkqqurVV5eHuuuGYvfH5jipFrHLycnR0uXLg3v19TUKBgMKi0tLYa9MldNTY3y8/O1aNEiZWVlxbo7Rlq9erXq6+uVkpIiSWptbdWrr76qbdu2afHixbHtnGEGDRrUblh37969uvjii2PUI3P98MMPamhoCO83NzertbVVhw4dimGvzMbvT+zw5g5nTqrCb/To0bJtW8uXL9f06dNVVFSkcePGKT4+PtZdM87+/fuVl5enyZMn6+qrr1ZLS4skqVevXrJMf8Ahij744AN9//334f0HHnhAubm5LJ1xDCZMmKA777xTS5YsUV5enl577TWVl5fr97//fay7ZpxLL71U06ZN0/nnn6+MjAyVlJSof//+ys7OjnXXjMXvD0xxUhV+CQkJKikpUX5+vgoLCxUXF6ctW7bEultGeuedd1RZWanKysp2/y/29NNPj13HDDNo0KA2+71791bfvn3Dw5WIXHp6ut566y098MADuu+++/SLX/xCr776qjIzM2PdNeNce+212rVrl5599ll9/vnnOuecc/T666/zOMdx4PcnhnhzhyNW6CR8mveLL77Qjh07lJubq/T09Fh3BwDgEfz+RI9t20pOTlZ13Vfq4/dHrd1m29bQgelqamqSP4rtuuWkLPwAAMDJjcLv2JxUQ70AAMBbGOl15qRazgUAAACdI/EDAADGivbbNExf2ILEDwAAwCNI/AAAgMGiu4Cz6U/5kfgBAAB4BIUfAACARzDUCwAAjMXkDmdI/AAAADyCwg8AAMAjKPwAAAA8gsIPAADAI5jcAQAAjMXkDmdI/AAAADyCxA8AABjLivKbO6L7lhD3kfgBAAB4BIkfAAAwFs/4OUPiBwAA4BEUfgAAAB7BUC8AADCW9eMWzfZMRuIHAADgESR+AADAXER+jpD4AQAAeASFHwAAgEcw1AsAAIzFmzucIfEDAADwCBI/AABgLN7c4QyJHwAAgEeQ+AEAAGOxmoszJH4AAAAeQeEHAADgEQz1AgAAczHW6wiJHwAAgEeQ+AEAAGOxgLMzJH4AAADdqKKiQjk5OUpNTVVhYaFCodBRr1m7dq0GDx6sAQMGaM2aNW2OLVq0SBkZGRoyZIg2bdrkqC8UfgAAAN0kGAxq4sSJGjlypLZv367KykqtWLGiy2sqKip0ww03aNasWdq4caNmz56tqqoqSdLGjRv1wAMP6KWXXtLvfvc7zZgxQ1999VXE/aHwAwAAxjry5o5obk5s2LBBTU1Nmj9/voYOHaqioiItW7asy2tKSko0duxYzZgxQ8OHD9cdd9yhl19+WZL0wgsvaNq0aZo8ebIuvvhiTZ48Wa+//nrE/eEZPwAAYCzbtmPS3s/b9fl88vl87c4vLy9Xbm6ukpKSJEnZ2dmqrKzsso3y8nJdeeWV4f1Ro0bp8ccfDx+bOnVqm2P/8z//oxkzZkTUfwo/AABgnJ49e6p///4aFsiMetu9e/dWZmbbdufMmaNHH3203bm2bSsQCIT3LctSfHy8GhsblZqa2uH9f36N3+/Xvn37jnosEhR+AADAOImJiaqpqdGBAwei3nYoFJL1szHfjtI+SUpISGh3LDExUa2trZ0Wfj+/5sj5RzsWCQo/AABgpMTERCUmJsa6G11KS0tTRUVFm8+am5vVs2fPLq+pr6/v8PyujkWCyR0AAADdJCcnR6WlpeH9mpoaBYNBpaWlRXxNWVmZBg4ceNRjkaDwAwAA6CajR4+Wbdtavny5JKmoqEjjxo1TfHy8vvnmGx06dKjdNddee61eeeUV7dy5Uy0tLVq4cKHGjx8vSbruuuu0ePFi1dXV6Z///KeWLVsWPhYJKxTJKoIAAAA4Jm+88Yby8/N1yimnKC4uTlu2bFFWVpYsy1JZWZnOPffcdtc8/PDDevrpp5WYmKhhw4bpgw8+0CmnnKJQKKR/+7d/0x/+8AdJ0q9+9Su98cYb7Z457AyFHwAAQDf74osvtGPHDuXm5io9PT2iayorK1VXV6cxY8a0e47vk08+0bfffqsxY8ZEXPRJFH4AAACewTN+AAAAHkHhBwAA4BEUfgAAAB5B4QcAAOARFH4AAAAeQeEHAADgERR+AAAAHkHhBwAA4BEUfgAAAB7x/wPxHq1SLYZ/HQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_state_set(S_list[N])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9evXBxPBM6HwAwAAxjo9szWc7UlSQkJCk8KvNSkpKSopKWlyrL6+XrGxsWe89+2339aNN97YZoHYrVs3VVVVnfFZpzHUCwAA0E4yMjJUWFgY3K+oqJDf71dKSsoZ7123bp1uv/324P7Ro0c1YMAAHT16NHissLBQffr0Cbk/FH4AAADtZNiwYfL5fFq2bJkkKTc3VyNHjlR0dLSOHDmiEydOtHjf0aNH9dFHH+mmm24KHrvooovUvXt33Xfffdq9e7cWLFig1atXa8aMGSH3h6FeAABgLOvHLZzt2RETE6OCggJlZ2crJydHUVFR2rFjhyQpOTlZRUVFGjRoULP7/vd//1fJycnq27dvk+P/9V//pbvuuktDhw7VpZdeqrVr12r48OGh98dm/wEAAGDD2LFjVV5erj179igzM1NdunSRpDaXYfnVr36lr776qtnxSy65RNu2bTvrvlD4AQAAY0VZYf5W71m21aNHD40ePdrh3tjHO34AAAAuQeEHAADgEgz1AgAAo4VzcofpSPwAAABcgsQPAAAYy7JObeFsz2QkfgAAAC5B4gcAAIwVqW/1morEDwAAwCUo/AAAAFyCoV4AAGCsKIU3xTI9MTO9/wAAAAgRiR8AADAWkzvsIfEDAABwCccKv4KCAqWmpio+Pl433XST/vnPfzr1aAAAADjAkcKvvLxczz//vDZu3Kj9+/erX79+uuuuu5x4NAAAQKusCGwmc6TwKyoqUmZmpq655hpdcskluvvuu/XFF1848WgAAAA4xJHJHWlpadq2bZv+8pe/yOv1avHixbr55pudeDQAAECrmNxhj2OF3x133KGrr75akuT1evXZZ5+1er3f75ff7w/u+3w+J7oBAACANjgy1Ltr1y69++67+vTTT3XkyBFlZ2frtttuUyAQaPH6vLw8JSYmBrfU1FQnugEAAFwmKgKbyRzp/5o1azRx4kRdd911SkxM1Isvvqjy8nIVFxe3eP3MmTNVV1cX3CorK53oBgAAANrgyFDvyZMnVVNTE9yvr69XY2OjTpw40eL1Ho9HHo/HiaYBAAAQIkcKvxtvvFFTpkzRNddco+7du6ugoEA9evRQenq6E48HAABoEZM77HGk8JswYYL27dunV199VV9++aWuuuoqbdiwQR06dHDi8QAAAHCAI4WfZVmaNWuWZs2a5cTjAAAAQhLuRZXN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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_route(data_list[N])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_route(final_route(rtilde,pi))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "77174"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_visit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x241a01699a0>]"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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5d/vtILIYCGIAAAw/KTy73dGbnoHAACGBoIIAACwhiACAACsIYgAAABrCCIAAMAagggAALCGIAIAAKwhiAAAAGtS2n13sB1fay0UClnuCQAAcOv4v9tu1kwd0kEkHA5LkoqLiy33BAAApCocDqugoCBhmyG9xHt3d7f27dunvLw8ZWVleXrtUCik4uJitbW1sXz8AGKcBwfjPHgY68HBOA+OgRpnY4zC4bAmTJigUaMSPwUypO+IjBo1SpMmTRrQ75Gfn88v+SBgnAcH4zx4GOvBwTgPjoEY52R3Qo7jYVUAAGANQQQAAFiTsUEkEAjojjvuUCAQsN2VEY1xHhyM8+BhrAcH4zw4hsI4D+mHVQEAwMiWsXdEAACAfQQRAABgDUEEAABYQxABAADWZGQQaWpqUllZmYLBoCorK12thY++bdmyRaeddpr8fr+mT5+unTt3Sko8xq+//rrOOussjRs3TjU1Nba6PmxddNFF2rBhg6TEY7l582ZNnjxZEyZM0NNPP22hp8PbT3/6Uy1atCh2zO+0t9atW6fi4mLl5ubqP/7jP/TPf/5TEuPshQMHDqikpETvv/9+7LN0x3VQ/o6YDPPpp5+aKVOmmOuvv97s3r3bLFiwwDz++OO2uzUs7d692wSDQfOb3/zG7N+/31x++eXmvPPOSzjGH3/8scnPzzcrVqww7733nvn6179utm3bZvknGT6eeuopI8nU1tYmHMsdO3aY7Oxss3btWvP222+b008/3bz77ruWez98NDY2mjFjxpiWlhZjTOK/G/xOp2737t2muLjY1NfXmz179phrrrnGzJ49m3H2QHt7u5k1a5aRZFpbW40x6f/+DtbfkYwLIs8995wJBoPm8OHDxhhj3nrrLfPNb37Tcq+GpxdffNH88pe/jB1v27bNnHDCCQnHeNWqVebMM8803d3dxhhjnn/+eXPVVVcNfueHoX/961/m5JNPNl/96ldNbW1twrG85ZZbzPz582PnPvjgg+bnP/+5lX4PN8eOHTOzZs0yt912W+wzfqe99eyzz5rLL788dvzGG2+YU045hXH2wLe//W2zevVqRxBJd1wH6+9IxpVmGhsbVV5ertzcXElSaWmpmpubLfdqeLr44ot13XXXxY537dqlM844I+EYNzY2au7cubFNDGfOnKn6+vrB7/ww9OMf/1iXXHKJysvLJSUey8bGRn3rW9+Kncs4u/fYY49px44dmjJlil544QUdPXqU32mPTZs2Tdu2bdNbb72lzs5OPfroo7rwwgsZZw+sXbtWN998s+OzdMd1sP6OZFwQCYVCKikpiR1nZWXJ5/Pp4MGDFns1/B09elQPPPCAbrjhhoRj/OWv5efna9++fTa6PKy8+uqreuWVV3TvvffGPks0loxzeg4dOqQ77rhDp512mvbs2aNVq1bp/PPP53faY9OmTdNll12mc889V4WFhaqrq9P999/POHug5xgdl+64DtaYZ1wQ8fv9vZayzcnJUVdXl6UejQx33HGHTjzxRC1dujThGH/5a4x9cp9++qmuv/56rVmzRnl5ebHPE40l45ye3/3udzp8+LBeffVVrVixQi+99JLC4bAef/xxfqc99Oabb+rFF1/U3//+d3V0dKiiokILFizgb8cASXdcB2vMMy6IFBUVqb293fFZOBxWdna2pR4Nf9u2bdMjjzyiTZs2afTo0QnH+MtfY+yTu+uuu1RWVqaFCxc6Pk80loxzej744AOVl5dr3Lhxkv79h7i0tFQdHR38Tnvo6aef1pVXXqlZs2apoKBAd999t1paWvjbMUDSHdfBGvOMCyJlZWWqq6uLHbe2tioSiaioqMhir4av1tZWVVRU6JFHHtG0adMkJR7jL3+toaFBEydOHPR+DyebNm3Sli1bVFhYqMLCQm3atEk33XSTnnjiibhjyTinZ9KkSTpy5Ijjsz179ujBBx/kd9pD3d3d+vjjj2PH4XA49r9zxtl76f5NHrQx9/zx1yHus88+MyeddFJs6tLSpUvNxRdfbLlXw1NXV5eZNm2a+cEPfmDC4XDsdfTo0bhj3N7ebnJycsxLL71kjh49ai666CKzbNkymz/GkNfW1mZaW1tjr0svvdTcd999CcfyrbfeMieeeKJ5++23TTgcNtOnTzf333+/5Z9k6Dtw4IDJz883a9asMW1tbWb16tUmJyfH7N27l99pDz377LMmNzfX1NTUmI0bN5q5c+eayZMn87fDQ+oxaybRv3tD4e9IxgURY4zZsmWLyc3NNWPHjjUnnXSSeeedd2x3aVh6/vnnjaRer9bW1oRjvGbNGjN69GgTDAZNSUmJ2b9/v8WfYvhZsmSJqa2tNcYkHstbb73VZGdnm/z8fDNjxgzT1dVlqcfDyxtvvGHKy8vNCSecYE477TTzwgsvGGMS/93gdzo13d3d5s477zSnnnqqGT16tDn33HPNP/7xD2MM4+yVnkHEmPTHdTD+jmRFO5xx9u/fr/r6epWXl2vs2LG2uzMiJRrj1tZWvfvuu5o9e7bGjBljqYcjQ6KxbG5u1ocffqgLLriAeroH+J0eHIzzwEh3XAf670jGBhEAAGBfxj2sCgAAhg6CCAAAsIYgAgAArCGIAAAAawgiAADAGoIIAACwhiACAACsIYgAAABrCCIAAMCa/w8ugrgtF/ZbggAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "count_hole_list=np.zeros(N+1)\n",
    "for i in range(N+1):\n",
    "    count_hole_list[i]=count_route_holes(data_list[i])\n",
    "count_hole_list\n",
    "plt.plot(np.linspace(0,N,N+1),count_hole_list)"
   ]
  }
 ],
 "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
