{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 45,
   "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": 46,
   "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=0.75\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",
    "\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",
    "        \"BBAAAAAAAAFF\",\n",
    "        \"AAFFFFFFFFFF\",\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": 47,
   "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": 48,
   "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": 49,
   "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. , 1. , 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0. , 0. ],\n",
       "       [0.5, 0.5, 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": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "map_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "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": 51,
   "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",
    "        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": 52,
   "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": 53,
   "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": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0.])"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sa_visit[N,11]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "m1,c1=gauss_fit_initial(mu_0,cov_0,dataset_0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "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": 57,
   "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": 58,
   "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": 59,
   "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": 60,
   "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",
    "            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": 61,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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73pXnH766XH11VfHtm3bKl1WYj355JNx7bXXxmte85pKl5JoBw8ejCuvvDI+/OEPx1lnnVXpchJr27Zt0dXVFeeee2686lWvive85z3xyCOPVLqsxFiyZElceuml4z7z+1M5mQps1S5VzV1vb290dXXFxIkTIyKio6Mj+vv7K1xVMi1cuDCuvPLKsf0dO3bErFmzKlhRsl177bVxySWXRFdXV6VLSbQ77rgjHn744ZgxY0bcd999ceDAgUqXlEizZ8+O+++/P372s5/F0NBQrFq1Ki644IJKl5UYq1evjmuuuWbcZ35/qCapau6y2Wy0t7eP7WcymaitrY29e/dWsKrkO3DgQHz2s5+N973vfZUuJZEeeOCB+PGPfxyf+cxnKl1Kou3fvz9uuOGGOOuss2LXrl3xuc99Lt70pjfF008/XenSEmf27Nnxzne+M17/+tfHpEmTYvPmzXHrrbdWuqzE+MPfmUP8/lTOoYcYl3Ordqlq7urq6vKeDt7Q0BAjIyMVqigdbrjhhjj11FPdc3cMnnnmmbjqqqviS1/6UjQ2Nla6nET75je/GU899VQ88MADceONN8aPfvSjGB4ejjvvvLPSpSXOQw89FN/+9rfjpz/9aezbty+WLl0aF198sQUAx8HvD9UkVc1da2tr7N69e9xnw8PDMWHChApVlHz3339/3H777XHXXXfFKaecUulyEudTn/pUdHZ2xoIFCypdSuI99thj0dXVFVOmTImIF35MOzo63Ct2DO6+++5YsmRJvPGNb4zm5ua4+eabY+fOndHb21vp0hLL7w/VJFXPuevs7IzVq1eP7Q8MDEQul4vW1tYKVpVcAwMDsXTp0rj99ttj9uzZlS4nke66667YvXt3TJo0KSIiRkZG4p577omHHnooVq1aVdniEmb69Ol5U7C7du2K8847r0IVJdfBgwdjz549Y/vDw8MxMjISzz//fAWrSja/P5XjDRX5UtXczZs3L7LZbKxbty6WLVsWPT09MX/+/Kitra10aYnz9NNPx8KFC+Ptb397XHLJJbF///6IiDj11FMjk4QbDqrEgw8+GM8999zY/nXXXRddXV0eO3EMFixYEB/4wAfijjvuiIULF8Y3v/nN6O3tja9//euVLi1xzj///Ljsssvi3HPPjdNPPz3WrFkTU6dOjY6OjkqXllh+f6gmqWru6urqYs2aNbF06dLo7u6Ompqa2LRpU6XLSqQf/vCH0d/fH/39/Xn/a3TGjBmVKyxhpk+fPm7/tNNOiylTpoxNLVK4yZMnx/e+97247rrr4iMf+Ui88pWvjHvuuSfa2toqXVrivOMd74jt27fH5z//+fjd734X55xzTnzrW99y68Vx8PtTQd5QkSczmsI7aJ944onYunVrdHV1xeTJkytdDgAnCb8/5ZPNZqO5uTl2/vb/RWNTU9nGHc5mY+YZk2NoaCiayjhuMVLZ3AEA6aa5O7JUTcsCACcXs7L5UvUoFACAk53kDgBIrHK/NSIJD4yQ3AEApIjkDgBIsPI+xDgJd91J7gAAUkRzBwCQIqZlAYDEsqAin+QOACBFNHcAACmiuQMASBHNHQBAilhQAQAklgUV+SR3AAApIrkDABIrU+Y3VJT3bRjHRnIHAJAikjsAILHcc5dPcgcAkCKaOwCAFDEtCwAkVubFrZzjVTvJHQBAikjuAIDkEt3lkdwBAKSI5g4AIEVMywIAieUNFfkkdwAAKSK5AwASyxsq8knuAABSRHIHACSWJ6Hkk9wBAKSI5g4AIEVMywIAyWVeNo/kDgAgRSR3AEBieYhxPskdAMAJ1NfXF52dndHS0hLd3d0xOjr6sud84xvfiDPPPDOmTZsWd999d1Hjae4AAE6QXC4XixYtirlz58aWLVuiv78/1q9ff9Rz+vr64q/+6q/i+uuvjx/84AfxyU9+Mnbs2FHwmJo7ACCxDr2hopxbMTZu3BhDQ0OxcuXKmDlzZvT09MTatWuPes6aNWvirW99a1xxxRXxute9Lt7//vfHnXfeWfCY7rkDABIrm81WZLyXjltfXx/19fV5x/f29kZXV1dMnDgxIiI6Ojqiv7//qGP09vbG2972trH9N7zhDXHTTTcVXKPmDgBInAkTJsTUqVNjVntb2cc+7bTToq1t/Lg33HBD/P3f/33esdlsNtrb28f2M5lM1NbWxt69e6OlpeWw13/pOU1NTfH4448XXJ/mDgBInIaGhhgYGIgDBw6UfezR0dHIvGR+9nCpXUREXV1d3v+toaEhRkZGjtjcvfScQ8cXSnMHACRSQ0NDNDQ0VLqMo2ptbY2+vr5xnw0PD8eECROOes7u3bsLPv6lLKgAADhBOjs7Y/PmzWP7AwMDkcvlorW1teBztm3bFmeccUbBY2ruAABOkHnz5kU2m41169ZFRERPT0/Mnz8/amtrY9++ffH888/nnfOOd7wjvva1r8XDDz8c+/fvjy984Qtx4YUXFjxmZrSQJ+kBAHBM7rvvvli6dGm84hWviJqamti0aVPMnj07MplMbNu2LebMmZN3zt/93d/FrbfeGg0NDTFr1qx48MEH4xWveEVB42nuAABOsCeeeCK2bt0aXV1dMXny5ILO6e/vj9/+9rfx5je/uah77jR3AAAp4p47AIAU0dwBAKSI5g4AIEU0dwAAKaK5AwBIEc0dAECKaO4AAFJEcwcAkCKaOwCAFPn/ASveq7rdPQzlAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_set(map_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rCr8NmzYoPr6es2ZM0f9+vVTQUGBFi9eHO1uGWn37t164YUX9K//+q9KT0/XlClTVFxcHO1uGeubb77RY489posuuijaXTHasWPHdNddd+mRRx5R3759o90dYxUXFysnJ0eXX365zj//fN155536/PPPo90tY4wfP14TJkxodoy/P9FjRWEz2VlV+JWUlCgnJ0cJCQmSpKysLJWVlUW5V2bKzc3VXXfdFdovLy9X//79o9gjsz322GMaO3ascnJyot0Voy1cuFC7du3SBRdcoLfffluHDx+OdpeMlJmZqU2bNunPf/6z6uvrtWDBAl1//fXR7pYxFi1apAcffLDZMf7+wBRnVeFn27b8fn9o37IsxcbGqq6uLoq9Mt/hw4c1e/Zs3XPPPdHuipE2b96sP/3pT3rxxRej3RWjNTY2asaMGerbt6/27dunuXPn6pprrtGhQ4ei3TXjZGZm6tZbb9Vll12m5ORkFRUV6aWXXop2t4zx478zJ/D3J3pOLOAcyc1kZ1XhFxcX12LV9Pj4eDU1NUWpR2eHGTNmqHPnzrzjdwq+++473X333XrttdfUtWvXaHfHaG+99Za+/fZbbd68Wc8++6w++OADNTQ06M0334x214yzbds2vfPOO/r000918OBB5eXl6eabb2Yywmng7w9McVYVfqmpqaqpqWl2rKGhQZ06dYpSj8y3adMmzZ8/XytWrNA555wT7e4Y51e/+pWys7M1cuTIaHfFePv371dOTo66desm6fgf2qysLN5NOwUrV67U+PHjdeWVVyopKUnPP/+8KioqVFJSEu2uGYu/PzDFWbWOX3Z2thYtWhTar6ysVCAQUGpqahR7Za7Kykrl5eVp/vz5yszMjHZ3jLRixQrV1NQoOTlZktTU1KTVq1dr27ZtWrBgQXQ7Z5jevXu3GNbdt2+frr766ij1yFzHjh1TbW1taL+hoUFNTU06evRoFHtlNv7+RA9f7nDmrCr8hg4dKtu2tWTJEk2aNEkFBQUaMWKEYmNjo9014xw6dEi5ubkaM2aMxo4dq8bGRklS586dZZn+gkMEffzxx/r+++9D+48//rhycnJYOuMUjBw5Ug888IAWLlyo3NxcvfXWWyopKdHvfve7aHfNONdee60mTpyoyy+/XOnp6SosLFSPHj2UlZUV7a4Zi78/MMVZVfjFxcWpsLBQeXl5ys/PV0xMjLZs2RLtbhnp/fffV1lZmcrKylr8v9gLLrggeh0zTO/evZvtd+nSRd26dQsNVyJ8aWlpevfdd/X444/r0Ucf1c9+9jOtXr1aGRkZ0e6accaNG6fdu3fr5Zdf1hdffKFLL71Ua9eu5XWO08Dfnyjiyx2OWMGz8G3eL7/8Ujt37lROTo7S0tKi3R0AgEfw9ydybNtWUlKSKqq/VtfExIi122Db6tcrTfX19UqMYLtuOSsLPwAAcHaj8Ds1Z9VQLwAA8BZGep05q5ZzAQAAQNtI/AAAgLEi/TUN0xe2IPEDAADwCBI/AABgsMgu4Gz6W34kfgAAAB5B4QcAAOARDPUCAABjMbnDGRI/AAAAj6DwAwAA8AgKPwAAAI+g8AMAAPAIJncAAABjMbnDGRI/AAAAjyDxAwAAxrIi/OWOyH4lxH0kfgAAAB5B4gcAAIzFO37OkPgBAAB4BIUfAACARzDUCwAAjGX9sEWyPZOR+AEAAHgEiR8AADAXkZ8jJH4AAAAeQeEHAADgEQz1AgAAY/HlDmdI/AAAADyCxA8AABiLL3c4Q+IHAADgESR+AADAWKzm4gyJHwAAgEdQ+AEAAHgEQ70AAMBcjPU6QuIHAADgESR+AADAWCzg7AyJHwAAQAcqLS1Vdna2UlJSlJ+fr2AweNJ71qxZoz59+qhnz55auXJls3Pz589Xenq6+vbtq02bNjnqC4UfAABABwkEAho1apQGDx6sHTt2qKysTEuXLm33ntLSUt1+++2aNm2aNm7cqOnTp6u8vFyStHHjRj3++ON644039Nvf/laTJ0/W119/HXZ/KPwAAICxTny5I5KbExs2bFB9fb3mzJmjfv36qaCgQIsXL273nsLCQg0fPlyTJ0/WgAEDdP/99+vNN9+UJL322muaOHGixowZo6uvvlpjxozR2rVrw+4P7/gBAABj2bYdlfZ+2q7P55PP52txfUlJiXJycpSQkCBJysrKUllZWbttlJSU6KabbgrtDxkyRM8991zo3IQJE5qd++///m9Nnjw5rP5T+AEAAON06tRJPXr0UH9/RsTb7tKlizIymrc7Y8YMPfPMMy2utW1bfr8/tG9ZlmJjY1VXV6eUlJRWn//TexITE3XgwIGTngsHhR8AADBOfHy8Kisrdfjw4Yi3HQwGZf1kzLe1tE+S4uLiWpyLj49XU1NTm4XfT+85cf3JzoWDwg8AABgpPj5e8fHx0e5Gu1JTU1VaWtrsWENDgzp16tTuPTU1Na1e3965cDC5AwAAoINkZ2erqKgotF9ZWalAIKDU1NSw7ykuLlavXr1Oei4cFH4AAAAdZOjQobJtW0uWLJEkFRQUaMSIEYqNjdXBgwd19OjRFveMGzdOq1at0q5du9TY2Kh58+bphhtukCTdeuutWrBggaqrq/W///u/Wrx4cehcOKxgOKsIAgAA4JS8/fbbysvL07nnnquYmBht2bJFmZmZsixLxcXFGjRoUIt7nnrqKb300kuKj49X//799fHHH+vcc89VMBjUv/3bv+n3v/+9JOkXv/iF3n777RbvHLaFwg8AAKCDffnll9q5c6dycnKUlpYW1j1lZWWqrq7WsGHDWrzHt337dn377bcaNmxY2EWfROEHAADgGbzjBwAA4BEUfgAAAB5B4QcAAOARFH4AAAAeQeEHAADgERR+AAAAHkHhBwAA4BEUfgAAAB5B4QcAAOAR/x+yLqxUgBSI6QAAAABJRU5ErkJggg==",
      "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": 63,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 6.22437601e-01],\n",
       "       [5.00000000e-01, 5.00000000e-01, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 5.00000000e-01, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 5.00000000e-01, 0.00000000e+00, 0.00000000e+00],\n",
       "       [1.00000000e+00, 1.00000000e+00, 1.50000000e+00, 1.50000000e+00,\n",
       "        1.00000000e+00, 1.00000000e+00, 1.05953556e+00, 7.18207599e-01,\n",
       "        3.99037001e-01, 5.00000000e-01, 0.00000000e+00, 0.00000000e+00],\n",
       "       [1.06419561e+00, 1.01148158e+00, 1.88369730e+00, 1.84785321e+00,\n",
       "        8.15749408e-01, 5.00000000e-01, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 5.00000000e-01, 0.00000000e+00, 0.00000000e+00],\n",
       "       [6.82756159e-01, 4.87897709e-01, 1.03548629e+00, 8.49382712e-01,\n",
       "        6.52301148e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00],\n",
       "       [3.28201205e-01, 2.44301378e-01, 5.94422868e-01, 5.23481909e-01,\n",
       "        6.88055831e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00],\n",
       "       [2.46200471e-01, 5.98738635e-01, 1.50397141e+00, 2.23423725e+00,\n",
       "        1.95719161e+00, 1.04420694e+00, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 5.00000000e-01, 5.00000000e-01, 5.00000000e-01],\n",
       "       [2.45097451e-01, 8.65565978e-01, 2.22669774e+00, 3.61363902e+00,\n",
       "        3.46340805e+00, 1.72310423e+00, 5.00000000e-01, 5.00000000e-01,\n",
       "        4.89927346e-01, 7.41833928e-01, 1.55062221e+00, 1.45364353e+00],\n",
       "       [1.80978862e-01, 7.14571578e-01, 1.94140609e+00, 3.40822818e+00,\n",
       "        3.58209902e+00, 1.92573905e+00, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 7.45896734e-01, 1.94001250e+00, 1.65698075e+00],\n",
       "       [9.45915273e-02, 4.04731757e-01, 1.18707765e+00, 2.27828690e+00,\n",
       "        2.64856998e+00, 1.60974365e+00, 5.00000000e-01, 5.00000000e-01,\n",
       "        5.00000000e-01, 5.00000000e-01, 1.34101675e+00, 1.08846816e+00],\n",
       "       [3.32170559e-02, 1.49791158e-01, 4.59928558e-01, 9.13329965e-01,\n",
       "        1.06082098e+00, 5.52946816e-01, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 5.00000000e-01, 5.00000000e-01],\n",
       "       [3.02873027e-03, 1.12917382e-02, 2.76915449e-02, 4.23841549e-02,\n",
       "        3.65374374e-02, 1.35491334e-02, 0.00000000e+00, 0.00000000e+00,\n",
       "        0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00]])"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_predict.reshape(nrow,ncol)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.85778598, 0.83114165, 0.67185936, 0.30302968, 0.03520889,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        ])"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sigma.reshape(12,12)[5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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v/c7lS6hKOfUVe8kW10V13Y209wBAKllQUWSlhsAIEM0dwAAGWJaFgBILQsqkiR3AAAZIrkDAFIrF2VeUFG+oc6Y5A4AIEMkdwBAatXkclFTxuiunGOdKckdAECGaO4AADLEtCwAkFqeUJEkuQMAyBDJHQCQWjYxTpLcAQBkiOYOACBDJqS5e8973hM7duyYiEsDAIyqyZX/OBO//vWv40c/+lEcPXq0tF/ASZS8udu5c2fcc889pb4sAEAq3XnnnXHBBRfEmjVrYvbs2XHnnXdGRERvb2+0t7fH9OnTo6urK0ZGRkb/zkMPPRTz58+PlpaW2LRp07jGK2lz96tf/Squv/76uOiii0p5WQCAk8v9n0UV5TjG+3DZwcHB+NjHPhb/+Z//GY899lhs2bIlurq6olAoxMqVK2PRokWxd+/e6OvrG531HBgYiFWrVkVnZ2fs2bMndu7cGbt37y56zJI2d9dff32sXr06Ojo6SnlZAIBUyufzccstt8TChQsjIuKSSy6J//mf/4m77747BgcHY9OmTTF37tzo7u6O22+/PSJenAWdNWtWrFu3LubNmxc33XTT6LlilKy52717d9x///2xcePG0362UChEPp8fcwAAjNfLmxiX84iIRB9TKBROWl9ra2tcffXVERHx3HPPxebNm2P16tXR09MTHR0dMWXKlIiIWLhwYfT19UVERE9PT1x++eWj265ceumlsW/fvqK/k5I0d88++2x85CMfiS9/+csxderU035+w4YN0dTUNHq0traWogwAgLJobW0d08ts2LDht36+p6cnZs6cGf/xH/8RX/rSlyKfz0dbW9vo+VwuF7W1tXH06NHEucbGxjhy5EjRtZWkufvc5z4X7e3tsXz58qI+f+ONN8bg4ODo0d/fX4oyAADKor+/f0wvc+ONN/7Wzy9cuDDuvffemDdvXqxZsybq6uqivr5+zGcmT54cw8PDiXMvv1+skjyhYteuXTEwMBDTpk2LiIjh4eG444474pFHHolbb7018fn6+vrE/yAAgPHKvfSnnONFvJimNTY2Fv/3crlYtGhRfPWrX425c+fGhg0bore3d8xnhoaGYtKkSdHc3BwDAwOJ94tVkubuBz/4QTz//POjr2+44Ybo6OiID33oQ6W4PABAKj300EPxb//2b/H3f//3ERExadKkyOVyMX/+/Ni6devo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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": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "76823"
      ]
     },
     "execution_count": 66,
     "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": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [ 1.,  0.,  1.,  1.,  1.,  0.,  1.,  0.,  1., -1., -1., -1.],\n",
       "       [ 0.,  0., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1.,  0.,  0.,  0.,  0., -1., -1.,  1.,  1.,  1.,  1.],\n",
       "       [-1., -1., -1., -1.,  0.,  0., -1., -1., -1.,  1.,  0.,  0.],\n",
       "       [-1., -1., -1., -1.,  0.,  0., -1., -1., -1., -1.,  1.,  0.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.],\n",
       "       [-1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1., -1.]])"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unsafe_set.reshape(nrow,ncol)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x224ce9185b0>]"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiIAAAGbCAYAAAD5mfsKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAlpUlEQVR4nO3dfXBV1cHv8V9ISGIkIQn4iECEiLaKY4qlgYwVLC0OFoSpVx1NvXeoSn27jHbaSSu26qBOUnwJoqPYAgaroH20VbS9tGNFbW3TOqQxEgP4kEaIcpFQSc6ByAHJun/4eO4J2TmcE5Kzz17r+5k5z7h39iZrrSdz1q/rZe8MY4wRAACAD4b5XQAAAOAugggAAPANQQQAAPiGIAIAAHxDEAEAAL4hiAAAAN8QRAAAgG8IIgAAwDdZfhcgnp6eHu3evVv5+fnKyMjwuzgAACABxhiFw2GNHTtWw4bFH/NI6yCye/dulZSU+F0MAAAwAO3t7Ro/fnzca9I6iOTn50v6vCIFBQU+lwYAACQiFAqppKQk2o/Hk9ZB5IvpmIKCAoIIAAABk8iyCharAgAA3xBEAACAbwgiAADANwQRAADgG4IIAADwDUEEAAD4hiACAAB8QxABAAC+IYgAAADfJB1E9u3bp9LSUn3wwQcJXf/mm2/qnHPO0ejRo1VbW5vsrwMAABZLKojs27dPl156acIhpKOjQwsWLFBlZaXq6+u1bt06vf766wMpJwAAsFBSQeTqq6/Wd7/73YSvX7duncaOHas777xTZ511lu666y6tWbMm6UICAAA7JfXSu1WrVqm0tFS33XZbQtc3NTVp1qxZ0ZfeTJs2Tbfffnu/10ciEUUikehxKBRKpnhJ2Rs6pKfqP9CBQ59pT+iQLjxztP5nxQS1dhzUf25uV9u+g/rm2f+hymmnD1kZhkLXp0f07Nu7NP8rYzWu8CRJ0l/+q0Md4Yj+x1fjv4oZAIBUSyqIlJaWJvWPh0IhTZ48OXpcUFCg3bt393t9TU2Nli5dmtTvGKgn//qBnnizNXr8x/c+1vQzRunhP72v/7NljyTp1ZaP9aVT8zV1QlFKyjQY7vjtFv1+y/9V3V/b9I87ZkuS/teatyVJZeMLdeZ/jPCzeAAA9DKku2aysrKUk5MTPc7NzVV3d3e/1y9ZskRdXV3RT3t7+5CVrfvwZ33OHYx8poORo73Ofbi///Kmo7/8V4ck6eNQpM/P9oYPpbo4AADEldSISLKKi4vV0dERPQ6Hw8rOzu73+pycnF7BBQAA2G1IR0TKy8tVX18fPW5sbNS4ceOG8lcmzBiPc//9AQAAqTEoQSQUCunIkSN9zi9YsEB//etf9ac//UlHjhzR/fffrzlz5gzGrwQAABYYlCBSVlam3//+933Ojx49WsuXL9fcuXN16qmnavv27frZz342GL8SAABYYEBrRMwx8xrxHnB20003ac6cOdq2bZtmzJihESPSY9eG8ZiEMaZv3QAAwNAZ0sWqXygtLU166y8AALAfL70DAAC+cTaIeM/AMC0DAEAqORtEAACA/wgiAADAN84GEa9JmM93zaS8KAAAOMvZIAIAAPxHEAEAAL5xNoj0/64Z5mYAAEgVZ4MIAADwH0EkBotVAQBILYeDCIkDAAC/ORxEAACA35wNIp6LVY1hagYAgBRyNogAAAD/EUQAAIBvnA0iPEcEAAD/ORtEAACA/wgiAADAN84GEa8pGB5oBgBAajkbRAAAgP8IIgAAwDfOBhHvXTPsmQEAIJWcDSIAAMB/BBEAAOAbZ4OI5xSM6e8HAABgKDgbRAAAgP8IIgAAwDfOBhFX3jVjeEIbACCNORtEAACA/wgiAADAN84GEVfeNWNbfQAAdnE2iAAAAP8RRCzHgAgAIJ25G0R41wwAAL5zN4gAAADfEUQsx3NEAADpzNkg4tU9f75rho4bAIBUcTaIAAAA/xFELMf4DgAgnTkbRLymYIzouAEASCVngwgAAPAfQSSGMca6R6LbVh8AgF2cDSL0zwAA+M/ZIAIAAPxHEIlh42JVHloPAEhnzgYR1k4AAOA/Z4MIAADwH0EklpF1QyWWVQcAYBlngwj9MwAA/nM2iAAAAP8RRGIY9pgAAJBSzgYRr3fNAACA1HI2iAAAAP8RRGIYY98uE9vqAwCwi7NBhP4ZAAD/ORtEAACA/5IKIs3NzSovL1dRUZGqqqqOu+DTGKObb75ZxcXFKiws1Pe+9z19+umnJ1TgQeNRdGPsezeLbfUBANgl4SASiUQ0f/58TZ06VZs3b1ZLS4vWrl0b956nn35a27dvV2Njo/7yl7/ovffeU01NzYmWGQAAWCLhILJx40Z1dXWptrZWkyZNUnV1tdasWRP3nrfffltXXHGFJkyYoPPOO0/f+c53tGPHjhMuNBLHYlUAQDpLOIg0NTWpoqJCeXl5kqSysjK1tLTEvefcc8/VM888o48//lg7d+7Uc889p4svvrjf6yORiEKhUK/PUPGasrDwVTMAAKS1hINIKBRSaWlp9DgjI0OZmZnav39/v/csWrRIBw4c0JgxYzRx4kSVlpZq4cKF/V5fU1OjkSNHRj8lJSWJFg8AAARQwkEkKytLOTk5vc7l5uaqu7u733tWrFihwsJC7dy5U7t27dJnn32mqqqqfq9fsmSJurq6op/29vZEi4d+MMADAEhnCQeR4uJidXR09DoXDoeVnZ3d7z3r1q1TVVWVTj/9dJWUlKimpibuupKcnBwVFBT0+gwVrykYYwxTMwAApFDCQaS8vFz19fXR47a2NkUiERUXF/d7T09Pj/bu3Rs93rNnj44ePTrAogIAANtkJXrhzJkzFQqFVFdXp2uvvVbV1dWaPXu2MjMz1dnZqfz8fGVmZva6Z8aMGfr5z3+uzMxMHT58WMuWLdOCBQsGvRLoHy/3AwCks4SDSFZWllavXq3KykpVVVVp2LBheuONNyRJRUVFamxs1JQpU3rdc9999ykUCunHP/6xwuGw5syZoxUrVgxm+QfMc2pGrKkAACCVEg4ikrRgwQK1traqoaFBFRUVGjVqlKT+/1d3YWGhfvWrX514KQEAgJWSCiKSNGbMGM2bN28oyoIhwAgPACCdOfvSO88HmhnWVAAAkErOBhEAAOA/gojlGOABAKQzZ4OIdwdNrw0AQCo5G0QAAID/CCK2Y5AHAJDGnA0iXv3z57tmUl4UAACc5WwQAQAA/iOIxPj8Ee92DYnYVh8AgF2cDSJMwQAA4D9ngwgAAPAfQSSGjYtVbasPAMAuDgcRemgAAPzmcBBxA3ELAJDOCCIxDHtMAABIKWeDCGsnAADwn7NBxBWGxAUASGMEkRif75qh4wYAIFWcDSLEDQAA/OdsEHEFgQsAkM4IIjGMLO+4ra4cACCInA0irAUBAMB/zgYRV5C3AADpjCASwxhj9fSFxVUDAASUs0GEThkAAP85G0RcwUPrAQDpjCByDJu7bdaLAADSjbNBhE4ZAAD/ORtEnEHgAgCkMWeDiFf/bPu7ZlgvAgBIN84GEQAA4D+CiOUYAwEApDNng4jXFIyxfPLC4lknAEBAORtEAACA/wgilmMUBACQzggiMT7fNeN3KYaOxVUDAAQUQQQAAPiGIGI5u5ffAgCCztkg4jUFY4zdHbfND2sDAASTs0HEFWQPAEA6I4jEMLK747a4agCAgHI2iNg8BQMAQFA4G0RcQdwCAKQzgkgMY4zVUzOkEgBAunE2iFgdOAAACAhng4gr2LILAEhnBJEYtnfZLNAFAKQbZ4MIAwUAAPjP2SDiCgIXACCdEURiGbvXVFhcNQBAQDkbRFgvAQCA/5wNIgAAwH8EkRjG8nESpmYAAOnG2SBCpwwAgP+cDSKuIHABANJZUkGkublZ5eXlKioqUlVVVcI7THp6enTBBRfooYceGlAhU8UYuztui6sGAAiohINIJBLR/PnzNXXqVG3evFktLS1au3ZtQvc+8cQT6urq0q233jrQcg46OmUAAPyXcBDZuHGjurq6VFtbq0mTJqm6ulpr1qw57n27d+/WHXfcoUcffVTDhw8/ocIieXYvvwUABF3CQaSpqUkVFRXKy8uTJJWVlamlpeW49/3gBz/QhAkT1N7err/97W9xr41EIgqFQr0+qWTUt+O2aarG5oe1AQCCKeEgEgqFVFpaGj3OyMhQZmam9u/f3+899fX1ev755zV+/Hi1trZq4cKFWrx4cb/X19TUaOTIkdFPSUlJosVLHn0yAAC+SziIZGVlKScnp9e53NxcdXd393vPqlWrNH36dP3ud7/TPffco02bNunxxx/X9u3bPa9fsmSJurq6op/29vZEi4d+MAgCAEhnCQeR4uJidXR09DoXDoeVnZ3d7z0ffvih5s6dq4yMDElSSUmJTjnlFLW2tnpen5OTo4KCgl6fVPLaNWPTGgt7agIAsEXCQaS8vFz19fXR47a2NkUiERUXF/d7z/jx4/Xpp59Gjw8cOKBPPvlE48aNG2BxB49NAQMAgKBKOIjMnDlToVBIdXV1kqTq6mrNnj1bmZmZ6uzs1NGjR/vcU1lZqVWrVum1117Tzp07dcstt+jss89WWVnZ4NUAcRG3AADpLCvhC7OytHr1alVWVqqqqkrDhg3TG2+8IUkqKipSY2OjpkyZ0uueiy++WMuWLdPNN9+s9vZ2TZkyRS+88EJ0qibdeL1rxqY1FjbVBQBgh4SDiCQtWLBAra2tamhoUEVFhUaNGiUp/rbQ66+/Xtdff/2JlXIIuNIps2UXAJDOkgoikjRmzBjNmzdvKMoCAAAcw0vvYnjumrFqQMGqygAALOBsEHGlS3alngCAYHI2iAAAAP8RRGKYmP/b+5wd7JpmAgDYwNkg4spuEkeqCQAIKGeDCAAA8J+zQcRzoMAYj10z9gwp2FMTAIAtnA0i7iB+AADSF0EkhlHfbtumbtyiwR0AgCWcDSJ0ygAA+M/ZIOIKAhcAIJ0RRGJ8/oj3Y1er+lOWodD33cIAAPjL2SBClwwAgP+cDSKuIHABANIZQSSGMX0nL2yazmC9CAAg3bgbROiVAQDwnbtBxBHkLQBAOiOIxDDq23Hb1JFbVBUAgCWcDSJ0ygAA+M/ZIOIKmxbbAgDsQxCJ4fVAM5u6cZveJAwAsIOzQYQ+GQAA/zkbRFxB4AIApDOCSAyjvlMxdOQAAAwdZ4OIK4s4CVIAgHTmbBABAAD+I4jEMMb0mZuxaeSE0REAQLpxNoi40inbFKQAAPZxNogAAAD/EUSOYfOuGUZHAADpxtkgYlPAiMeVegIAgsnZIAIAAPxHEIlh/7tm/C4BAAC9ORtE6JMBAPCfs0EEAAD4jyASw3jtK7FoPsOiqgAALOFsEDl2LYitHKkmACCgnA0iAADAfwSRGJ/vmjnmnD9FGRI21QUAYAeCiOV4mioAIJ0RRGIY9e24bVpj4cq6GABAcBBEAACAb5wNIq4MDrhSTwBAMDkbRLx4Lla1qCe3pyYAAFsQRAAAgG+cDSKu7CZxo5YAgKByNoh48XrEu1UduVWVAQDYwNkgYtHSDwAAAsvZIOIKmxbbAgDsQxCJYT5/olnfc5ZwZV0MACA4nA0irnTJrtQTABBMzgYRAADgP4LIMfq8a8ancgwFm6aZAAB2cDaIuLKI05FqAgACytkgAgAA/Jd0EGlublZ5ebmKiopUVVWV1MhCZ2enTjvtNH3wwQfJ/tqUMMbwrhkAAFIoqSASiUQ0f/58TZ06VZs3b1ZLS4vWrl2b8P1VVVXas2dPsmUcEu50yu7UFAAQPEkFkY0bN6qrq0u1tbWaNGmSqqurtWbNmoTu/fOf/6yXX35Zo0aNGlBBAQCAfZIKIk1NTaqoqFBeXp4kqaysTC0tLce9LxKJ6MYbb9QjjzyiESNGxL0uFAr1+qSSMXaPH1g0ywQAsERSQSQUCqm0tDR6nJGRoczMTO3fvz/ufdXV1frSl76kq666Ku51NTU1GjlyZPRTUlKSTPGS40inTPgAAKSzpIJIVlaWcnJyep3Lzc1Vd3d3v/ds3bpVTzzxhFauXHncf3/JkiXq6uqKftrb25MpHgAACJisZC4uLi5Wc3Nzr3PhcFjZ2dme1xtjdMMNN+i+++7T2LFjj/vv5+Tk9Ak6qWTUd5eMTSMKvGsGAJBukhoRKS8vV319ffS4ra1NkUhExcXFntfv2rVLb731lqqqqlRYWKjCwkLt2rVLZWVlWr9+/YmV/AS50iW7Uk8AQDAlNSIyc+ZMhUIh1dXV6dprr1V1dbVmz56tzMxMdXZ2Kj8/X5mZmdHrx40bp7a2tl7/xoUXXqjnnntOU6ZMGZQKAACA4EoqiGRlZWn16tWqrKxUVVWVhg0bpjfeeEOSVFRUpMbGxl4BIysrSxMnTuzzb4wfPz7u7hm/eO2asWk6w6ZpJgCAHZIKIpK0YMECtba2qqGhQRUVFdHngiT6BNJ0eaqqTU9MjceRagIAAirpICJJY8aM0bx58wa7LAAAwDG89C6Gkde7Zvwpy1CwqCoAAEs4G0Rc6ZRdmYICAASTs0HEVhkZGX4XAQCAhBFEYngNHgRtPCHuCAijIwCANONsEHGlT3akmgCAgHI2iNiKqRkAQJAQRGJ4jR4EbeQk3tRMwKoCAHCAs0HE84mpQUsdCbCwSgAAizgbRLx4johYNI5AKAEApBuCSAwbO2qbghQAwD7OBhEbQwcAAEHjbBDx4jV6YFNg4SmrAIB0QxCJYWU/bWOdAADWcDaIWBk6AAAIGGeDiBfbs4nt9QMABA9BJIaNoyQWVgkAYBGCCAAA8A1BJIb3rhl7xhQsqgoAwBIEkVgWdtSEDwBAOnM2iNg00gEAQFA5G0S82PD23XgsqgoAwBIEkRg2jpLwrhkAQDpzNojQPQMA4D9ng4gXrwERmwKLjSM+AIBgczaI2B46vkD2AACkM2eDCAAA8B9BJIbnKAkjCgAADBlng4jnU1QtnJyxr0YAAJs4G0RslZGR4XcRAABIGEEkhvcC1mCNKcTbGcM0EwAg3TgbRFzplNmyCwBIZ84GEVsxNQMACBKCSAyv0YOgDSjEnZoJ2DQTAMB+zgYRzxfcpbwUQ8/GOgEA7OFsELEVUzMAgCAhiMSw4bHvfaZmTOzPUlsWAACOx9kgYsNWXQAAgs7ZIGIrpmYAAEFCEInhOXURsPmMY6dmYkd5glUTAIALHA4iXu+aAQAAqeRwEOnLhsWq8QRscAcA4ACCSC/29dSEDwBAOnM2iNBBAwDgP2eDiBfPqRmLAgvbkwEA6YYgEsOm0PEFG+sEALCHs0GE/hkAAP85G0S8eE1d2DSdwegIACDdEERi2NhRW1glAIBFnA0ifV4OBwAAUs7ZIOLFgie8AwAQKASRGDaGDkZ+AADpzNkgQvcMAID/nA0iXrx3zdiD0REAQLohiMSysJ+2sEoAAIs4G0QYHAAAwH9JBZHm5maVl5erqKhIVVVVCQ31L126VMXFxcrJydFll12mcDg84MIONdt3zdhUFwCAHRIOIpFIRPPnz9fUqVO1efNmtbS0aO3atXHvWbdundatW6c//OEPeu+997R161b9/Oc/P9EyDxkb11BYWCUAgEUSDiIbN25UV1eXamtrNWnSJFVXV2vNmjVx72lvb9dTTz2ladOm6cwzz9RVV12lxsbGEy70YLAxdEhSRkaG30UAACBhWYle2NTUpIqKCuXl5UmSysrK1NLSEvee22+/vdfx9u3bddZZZ/V7fSQSUSQSiR6HQqFEizcoPKdmArbcM17AClZNAAAuSHhEJBQKqbS0NHqckZGhzMxM7d+/P6H733//fb344ou64YYb+r2mpqZGI0eOjH5KSkoSLd6gsHOQxMpKAQAskXAQycrKUk5OTq9zubm56u7uPu69PT09uu6667Ro0SKde+65/V63ZMkSdXV1RT/t7e2JFi9ptnbPTM0AAIIk4amZ4uJiNTc39zoXDoeVnZ193HvvvfdeffLJJ3rggQfiXpeTk9Mn7KSSZzgJWGI5dmom9tDOER8AQJAlPCJSXl6u+vr66HFbW5sikYiKi4vj3vfKK6+otrZWv/nNb6LrS9KVrQtYAQBIVwkHkZkzZyoUCqmurk6SVF1drdmzZyszM1OdnZ06evRon3u2bt2qyspKPfrooyopKdGBAwcSmspJCUszB1MzAIAgSWqNyOrVq7V48WKNHj1aGzZs0LJlyyRJRUVF2rJlS597fvnLX+rgwYNauHCh8vPzlZ+fr8mTJw9e6QeZ966ZYOkzNdPrv4NWGwCA7RJeIyJJCxYsUGtrqxoaGlRRUaFRo0ZJ6n9KY/ny5Vq+fPmJl3II2LAeBACAoEsqiEjSmDFjNG/evKEoCwYBUzMAgCBx9qV3XrymLoK2gJVdMwCAIHE2iHgFDDpqAABSy9kgYiumZgAAQUIQieE1IhK0UZK+u2ZMzH8DAJBenA0iNrzgDgCAoHM2iNiKqRkAQJAQRGJ4Ts2kvhgnJN6umcDNMwEArOdsELEhdAAAEHTOBhEvNixWjRXvce8AAKQDgkgv9nXV9tUIAGATZ4MIO2QAAPCfs0HEi/e6keAGlmPrE+RpJgCAnQgiMWzsp4P2rhwAgFucDSL0zwAA+M/ZIOLFthfhHVv0IE8zAQDsRBCJQTcNAEBqORtECB0AAPjP2SDiJcjTMF7iPu4dAIA0QBCJYWM/TfgAAKQzd4OIpR00b98FAASJu0HEg/eumWAlltjyGvXeKROsmgAAXEAQAQAAvnE2iNj6TA2mZgAAQeJsEPHi/a6ZYOk1NWN61ylgs0wAAAcQRGLYOkoCAEC6cjaI2Do6wNQMACBInA0iXjynZgIWWHrvmjG9p2YY8QEApBmCSIyghQ4AAILO2SBia+ZgagYAECTOBhEvXlMXQZvO6LNrptcPU14cAADiIojEYGoGAIDUcjaIBO3R7YliagYAECTOBhEvXtEkaHnl2IB17LtnAABIJwSRWPTUAACklLNBxNbMwdQMACBInA0iXrx3zQRLvF0ztq6LAQAEF0EkBv00AACp5WwQsTV0MDUDAAgSZ4OIF9t2zRj1npsJWl0AAPYjiMRgDQUAAKlFEInhHUOCG06OzVXBrQkAwFYEkRg2DogE7V05AAC3OBlEmIIBACA9OBlE+mPDYtVYRr3LH+S6AADsRBCJRU8NAEBKORlEbM4bPEcEABAkTgaR/tgwNdP7Ee+9l6qycBUAkG4IIjGCFjoAAAg6J4OIzXmDqRkAQJA4GUT64/323WDFlt6PeGfXDAAgvRFEYtBRAwCQWk4GEZsfaMbUDAAgSJwMIv3xyidByyy9d80Eb2oJAOAWgkgMumwAAFLLySBic+BgagYAECRJB5Hm5maVl5erqKhIVVVVCa23eOGFFzRhwgSNHTtWzz777IAKmgpedQlaaOlVB3Psrpmg1QYAYLukgkgkEtH8+fM1depUbd68WS0tLVq7dm3ce5qbm3XNNdfozjvv1B//+Efddddd2r59+4mUGQAAWCKpILJx40Z1dXWptrZWkyZNUnV1tdasWRP3ntWrV2vWrFlatGiRzjvvPC1evFhPP/30CRX6RNk8MMDUDAAgSLKSubipqUkVFRXKy8uTJJWVlamlpeW493z729+OHk+bNk333HOP57WRSESRSCR6HAqFkineCdsTOtTn3DvtnVr6ynspLceJOBj5LPrfy/64TW0dB6PH/2j7JFB1AQAMvaxhGfrpvMn+/f5kLg6FQiotLY0eZ2RkKDMzU/v371dRUVFC9xQUFGj37t2e19bU1Gjp0qXJFGlQdXYf6XNux94D2rH3gA+lOXHr/7Gr1/G2PWFt2xP2qTQAgHSUnTUsOEEkKytLOTk5vc7l5uaqu7u73yBy7D1fXO9lyZIl+uEPfxg9DoVCKikpSaaICRmWIf3vWZMkSXPPO01vt32iz44adX56WJI086xT9O6HXdr5yUGNPGn4oP/+odYRjuiU/P/f5oeO9OjI0R7l5yb1/24AgAMyh/m7gTapnqm4uFjNzc29zoXDYWVnZ8e9p6OjI6Hrc3Jy+gSdoZCVOUxVc86OHp87dmSfa6afMWrIywEAgOuSikHl5eWqr6+PHre1tSkSiai4uDjhexobGzVu3LgBFBUAANgmqSAyc+ZMhUIh1dXVSZKqq6s1e/ZsZWZmqrOzU0ePHu1zz+WXX67nnntOW7Zs0YEDB/TII49ozpw5g1N6AAAQaEkFkaysLK1evVqLFy/W6NGjtWHDBi1btkySVFRUpC1btvS55ytf+Ypuu+02fe1rX9O4ceOUmZmpW265ZXBKDwAAAi3DDOBxm3v27FFDQ4MqKio0alRiaylaWlr00Ucf6aKLLoq7piRWKBTSyJEj1dXVpYKCgmSLCQAAfJBM/z2gIJIqBBEAAIInmf7byZfeAQCA9EAQAQAAviGIAAAA3xBEAACAbwgiAADANwQRAADgG4IIAADwDUEEAAD4Jq3fC//Fs9ZCoZDPJQEAAIn6ot9O5JmpaR1EwuGwJKmkpMTnkgAAgGSFw2GNHDky7jVp/Yj3np4e7d69W/n5+crIyBjUfzsUCqmkpETt7e08Pn4I0c6pQTunDm2dGrRzagxVOxtjFA6HNXbsWA0bFn8VSFqPiAwbNkzjx48f0t9RUFDAH3kK0M6pQTunDm2dGrRzagxFOx9vJOQLLFYFAAC+IYgAAADfOBtEcnJydPfddysnJ8fvoliNdk4N2jl1aOvUoJ1TIx3aOa0XqwIAALs5OyICAAD8RxABAAC+IYgAAADfEEQAAIBvnAwizc3NKi8vV1FRkaqqqhJ6Fj68bdiwQWeccYaysrI0ZcoUbd26VVL8Nn7zzTd1zjnnaPTo0aqtrfWr6IF1ySWXaO3atZLit+ULL7ygCRMmaOzYsXr22Wd9KGmw/eQnP9H8+fOjx/xND67Vq1erpKREeXl5+sY3vqF//etfkmjnwbBv3z6Vlpbqgw8+iJ4baLum5HvEOObQoUNm4sSJ5sYbbzQ7duwwc+fONU8++aTfxQqkHTt2mKKiIvPrX//a7Nmzx1x55ZXmggsuiNvGe/fuNQUFBWbp0qXm/fffN1/96lfNpk2bfK5JcDzzzDNGkqmrq4vbllu2bDHZ2dlm1apV5t133zVnnnmm2bZtm8+lD46mpiYzYsQI09raaoyJ/73B33TyduzYYUpKSkxDQ4PZuXOnue6668yMGTNo50HQ0dFhpk+fbiSZtrY2Y8zA/35T9T3iXBB58cUXTVFRkTl48KAxxph33nnHfP3rX/e5VMH0yiuvmF/84hfR402bNpmTTjopbhsvX77cnH322aanp8cYY8xLL71krrnmmtQXPoD+/e9/m1NPPdV8+ctfNnV1dXHb8rbbbjNz5syJ3vvwww+bn/70p76UO2iOHj1qpk+fbu68887oOf6mB9fzzz9vrrzyyujxW2+9ZU477TTaeRB861vfMitWrOgVRAbarqn6HnFuaqapqUkVFRXKy8uTJJWVlamlpcXnUgXTpZdeqhtuuCF6vH37dp111llx27ipqUmzZs2KvsRw2rRpamhoSH3hA+hHP/qRLrvsMlVUVEiK35ZNTU365je/Gb2Xdk7cE088oS1btmjixIl6+eWXdfjwYf6mB9nkyZO1adMmvfPOO+rq6tLjjz+uiy++mHYeBKtWrdKtt97a69xA2zVV3yPOBZFQKKTS0tLocUZGhjIzM7V//34fSxV8hw8f1kMPPaSbbropbhsf+7OCggLt3r3bjyIHyuuvv67XXntN999/f/RcvLaknQfmwIEDuvvuu3XGGWdo586dWr58uS688EL+pgfZ5MmTdcUVV+j8889XYWGh6uvr9eCDD9LOgyC2jb4w0HZNVZs7F0SysrL6PMo2NzdX3d3dPpXIDnfffbdOPvlkLVq0KG4bH/sz2v74Dh06pBtvvFErV65Ufn5+9Hy8tqSdB+a3v/2tDh48qNdff11Lly7Vq6++qnA4rCeffJK/6UH09ttv65VXXtHf//53dXZ2qrKyUnPnzuW7Y4gMtF1T1ebOBZHi4mJ1dHT0OhcOh5Wdne1TiYJv06ZNeuyxx7R+/XoNHz48bhsf+zPa/vjuvfdelZeXa968eb3Ox2tL2nlgPvzwQ1VUVGj06NGSPv8iLisrU2dnJ3/Tg+jZZ5/V1VdfrenTp2vkyJG677771NraynfHEBlou6aqzZ0LIuXl5aqvr48et7W1KRKJqLi42MdSBVdbW5sqKyv12GOPafLkyZLit/GxP2tsbNS4ceNSXu4gWb9+vTZs2KDCwkIVFhZq/fr1uuWWW/TUU0/125a088CMHz9en376aa9zO3fu1MMPP8zf9CDq6enR3r17o8fhcDj6v85p58E30O/klLX5oC9/TXNHjhwxp5xySnTr0qJFi8yll17qc6mCqbu720yePNl8//vfN+FwOPo5fPhwv23c0dFhcnNzzauvvmoOHz5sLrnkErN48WI/q5H22tvbTVtbW/Rz+eWXmwceeCBuW77zzjvm5JNPNu+++64Jh8NmypQp5sEHH/S5Julv3759pqCgwKxcudK0t7ebFStWmNzcXLNr1y7+pgfR888/b/Ly8kxtba1Zt26dmTVrlpkwYQLfHYNIMbtm4vV76fA94lwQMcaYDRs2mLy8PDNq1ChzyimnmPfee8/vIgXSSy+9ZCT1+bS1tcVt45UrV5rhw4eboqIiU1paavbs2eNjLYJn4cKFpq6uzhgTvy3vuOMOk52dbQoKCszUqVNNd3e3TyUOlrfeestUVFSYk046yZxxxhnm5ZdfNsbE/97gbzo5PT095p577jGnn366GT58uDn//PPNP//5T2MM7TxYYoOIMQNv11R8j2T8d4Gds2fPHjU0NKiiokKjRo3yuzhWitfGbW1t2rZtm2bMmKERI0b4VEI7xGvLlpYWffTRR7rooouYTx8E/E2nBu08NAbarkP9PeJsEAEAAP5zbrEqAABIHwQRAADgG4IIAADwDUEEAAD4hiACAAB8QxABAAC+IYgAAADfEEQAAIBvCCIAAMA3/w8I1VVhBKZg/AAAAABJRU5ErkJggg==",
      "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": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rCr8NmzYoPr6es2ZM0f9+vVTQUGBFi9eHO1uGWn37t164YUX9K//+q9KT0/XlClTVFxcHO1uGeubb77RY489posuuijaXTHasWPHdNddd+mRRx5R3759o90dYxUXFysnJ0eXX365zj//fN155536/PPPo90tY4wfP14TJkxodoy/P9FjRWEz2VlV+JWUlCgnJ0cJCQmSpKysLJWVlUW5V2bKzc3VXXfdFdovLy9X//79o9gjsz322GMaO3ascnJyot0Voy1cuFC7du3SBRdcoLfffluHDx+OdpeMlJmZqU2bNunPf/6z6uvrtWDBAl1//fXR7pYxFi1apAcffLDZMf7+wBRnVeFn27b8fn9o37IsxcbGqq6uLoq9Mt/hw4c1e/Zs3XPPPdHuipE2b96sP/3pT3rxxRej3RWjNTY2asaMGerbt6/27dunuXPn6pprrtGhQ4ei3TXjZGZm6tZbb9Vll12m5ORkFRUV6aWXXop2t4zx478zJ/D3J3pOLOAcyc1kZ1XhFxcX12LV9Pj4eDU1NUWpR2eHGTNmqHPnzrzjdwq+++473X333XrttdfUtWvXaHfHaG+99Za+/fZbbd68Wc8++6w++OADNTQ06M0334x214yzbds2vfPOO/r000918OBB5eXl6eabb2Yywmng7w9McVYVfqmpqaqpqWl2rKGhQZ06dYpSj8y3adMmzZ8/XytWrNA555wT7e4Y51e/+pWys7M1cuTIaHfFePv371dOTo66desm6fgf2qysLN5NOwUrV67U+PHjdeWVVyopKUnPP/+8KioqVFJSEu2uGYu/PzDFWbWOX3Z2thYtWhTar6ysVCAQUGpqahR7Za7Kykrl5eVp/vz5yszMjHZ3jLRixQrV1NQoOTlZktTU1KTVq1dr27ZtWrBgQXQ7Z5jevXu3GNbdt2+frr766ij1yFzHjh1TbW1taL+hoUFNTU06evRoFHtlNv7+RA9f7nDmrCr8hg4dKtu2tWTJEk2aNEkFBQUaMWKEYmNjo9014xw6dEi5ubkaM2aMxo4dq8bGRklS586dZZn+gkMEffzxx/r+++9D+48//rhycnJYOuMUjBw5Ug888IAWLlyo3NxcvfXWWyopKdHvfve7aHfNONdee60mTpyoyy+/XOnp6SosLFSPHj2UlZUV7a4Zi78/MMVZVfjFxcWpsLBQeXl5ys/PV0xMjLZs2RLtbhnp/fffV1lZmcrKylr8v9gLLrggeh0zTO/evZvtd+nSRd26dQsNVyJ8aWlpevfdd/X444/r0Ucf1c9+9jOtXr1aGRkZ0e6accaNG6fdu3fr5Zdf1hdffKFLL71Ua9eu5XWO08Dfnyjiyx2OWMGz8G3eL7/8Ujt37lROTo7S0tKi3R0AgEfw9ydybNtWUlKSKqq/VtfExIi122Db6tcrTfX19UqMYLtuOSsLPwAAcHaj8Ds1Z9VQLwAA8BZGep05q5ZzAQAAQNtI/AAAgLEi/TUN0xe2IPEDAADwCBI/AABgsMgu4Gz6W34kfgAAAB5B4QcAAOARDPUCAABjMbnDGRI/AAAAj6DwAwAA8AgKPwAAAI+g8AMAAPAIJncAAABjMbnDGRI/AAAAjyDxAwAAxrIi/OWOyH4lxH0kfgAAAB5B4gcAAIzFO37OkPgBAAB4BIUfAACARzDUCwAAjGX9sEWyPZOR+AEAAHgEiR8AADAXkZ8jJH4AAAAeQeEHAADgEQz1AgAAY/HlDmdI/AAAADyCxA8AABiLL3c4Q+IHAADgESR+AADAWKzm4gyJHwAAgEdQ+AEAAHgEQ70AAMBcjPU6QuIHAADgESR+AADAWCzg7AyJHwAAQAcqLS1Vdna2UlJSlJ+fr2AweNJ71qxZoz59+qhnz55auXJls3Pz589Xenq6+vbtq02bNjnqC4UfAABABwkEAho1apQGDx6sHTt2qKysTEuXLm33ntLSUt1+++2aNm2aNm7cqOnTp6u8vFyStHHjRj3++ON644039Nvf/laTJ0/W119/HXZ/KPwAAICxTny5I5KbExs2bFB9fb3mzJmjfv36qaCgQIsXL273nsLCQg0fPlyTJ0/WgAEDdP/99+vNN9+UJL322muaOHGixowZo6uvvlpjxozR2rVrw+4P7/gBAABj2bYdlfZ+2q7P55PP52txfUlJiXJycpSQkCBJysrKUllZWbttlJSU6KabbgrtDxkyRM8991zo3IQJE5qd++///m9Nnjw5rP5T+AEAAON06tRJPXr0UH9/RsTb7tKlizIymrc7Y8YMPfPMMy2utW1bfr8/tG9ZlmJjY1VXV6eUlJRWn//TexITE3XgwIGTngsHhR8AADBOfHy8Kisrdfjw4Yi3HQwGZf1kzLe1tE+S4uLiWpyLj49XU1NTm4XfT+85cf3JzoWDwg8AABgpPj5e8fHx0e5Gu1JTU1VaWtrsWENDgzp16tTuPTU1Na1e3965cDC5AwAAoINkZ2erqKgotF9ZWalAIKDU1NSw7ykuLlavXr1Oei4cFH4AAAAdZOjQobJtW0uWLJEkFRQUaMSIEYqNjdXBgwd19OjRFveMGzdOq1at0q5du9TY2Kh58+bphhtukCTdeuutWrBggaqrq/W///u/Wrx4cehcOKxgOKsIAgAA4JS8/fbbysvL07nnnquYmBht2bJFmZmZsixLxcXFGjRoUIt7nnrqKb300kuKj49X//799fHHH+vcc89VMBjUv/3bv+n3v/+9JOkXv/iF3n777RbvHLaFwg8AAKCDffnll9q5c6dycnKUlpYW1j1lZWWqrq7WsGHDWrzHt337dn377bcaNmxY2EWfROEHAADgGbzjBwAA4BEUfgAAAB5B4QcAAOARFH4AAAAeQeEHAADgERR+AAAAHkHhBwAA4BEUfgAAAB5B4QcAAOAR/x+yLqxUgBSI6QAAAABJRU5ErkJggg==",
      "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": 71,
   "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(data_list[N])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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cN3j8bR6XExMTIt9sbGxampqUlJSUrv3+Pbbb7Vhwwa9+uqrwW2bNm0K/t9er1czZszQunXrgong6dD4AQAAY52a2RrO+0lSfHx8s8avLcnJySotLW22raGhQZ07dz7tuW+//bZGjBjRboPYs2dPVVdXn/ZapzDUCwAA0EHS09NVVFQUXK+srJTf71dycvJpz127dq1uu+224PqRI0c0ePBgHTlyJLitqKhI/fv3D7keGj8AAIAOMnLkSPl8Pi1btkySlJ+frzFjxig6OlqHDx/W8ePHWz3vyJEj+vjjj3XDDTcEt11wwQXq1auX7r//fu3atUvz58/X6tWrlZOTE3I9DPUCAABjWT8u4byfHTExMSosLFRWVpZyc3MVFRWlbdu2SZKSkpJUXFysK6+8ssV5//M//6OkpCQNGDCg2fb/+I//0F133aXhw4fr4osv1ltvvaVRo0aFXo/N+gEAAGDDhAkTVFFRod27dysjI0Pdu3eXpHZfw/KrX/1KX331VYvtF110kbZs2XLGtdD4AQAAY0VZYf5W7xneq3fv3ho3bpzD1djHM34AAAAuQeMHAADgEgz1AgAAo4VzcofpSPwAAABcgsQPAAAYy7JOLuG8n8lI/AAAAFyCxA8AABgrUt/qNRWJHwAAgEvQ+AEAALgEQ70AAMBYUQpvimV6YmZ6/QAAAAgRiR8AADAWkzvsIfEDAABwCccav8LCQqWkpCguLk433HCD/vnPfzp1aQAAADjAkcavoqJCzz77rDZs2KB9+/Zp4MCBuuuuu5y4NAAAQJusCCwmc6TxKy4uVkZGhq6++mpddNFFuvvuu/XFF184cWkAAAA4xJHJHampqdqyZYv+8pe/yOv1atGiRbrxxhuduDQAAECbmNxhj2ON3+23366rrrpKkuT1evX555+3ebzf75ff7w+u+3w+J8oAAABAOxwZ6t2xY4feffddffbZZzp8+LCysrJ0yy23KBAItHp8QUGBEhISgktKSooTZQAAAJeJisBiMkfqX7NmjSZPnqxrr71WCQkJev7551VRUaGSkpJWj8/Ly1N9fX1wqaqqcqIMAAAAtMORod4TJ06otrY2uN7Q0KCmpiYdP3681eM9Ho88Ho8TtwYAAECIHGn8RowYoalTp+rqq69Wr169VFhYqN69eystLc2JywMAALSKyR32ONL4TZo0SXv37tUrr7yiL7/8UldccYXWr1+vTp06OXF5AAAAOMCRxs+yLM2aNUuzZs1y4nIAAAAhCfdLlc3O+8yfnAIAAIAQ0fgBAAC4hCNDvQAAAJFgWSeXcN7PZCR+AAAALkHiBwAAjBUlS1FhnHIRznt1BBI/AAAAl6DxAwAAcAmGegEAgLGY3GEPiR8AAIBLkPgBAABjWT/+E877mYzEDwAAwCVI/AAAgLF4xs8eEj8AAACXoPEDAABwCYZ6AQCAsawwf7nD9MkdNH4AYJC6nb+LdAkhSUqfHukSALSCxg8AABiLyR328IwfAACAS9D4AQAAuARDvQAAwFgM9dpD4gcAAOASJH4AAMBYfKvXHhI/AAAAlyDxAwAAxoqyTi7hvJ/JSPwAAABcgsYPAADAJRjqBQAAxmJyhz0kfgAAAC5B4gcAAIzFC5ztIfEDAABwCRo/AAAAl2CoFwAAGMtSeCdcGD7SS+IHAADgFiR+AADAWHy5wx4SPwAAAJcg8QMAAMbiBc72kPgBAAC4BI0fAACASzDUCwAAjMWXO+wh8QMAAHAJEj8AAGAsS+F9qbLhgR+JHwAAQEcqLS1Venq6kpKSlJubq0AgcNpz0tLSZFlWcMnOzg7uW7dunfr3768+ffpozZo1tmqh8QMAAOggfr9f48eP19ChQ7Vr1y6VlZVp+fLl7Z7T1NSkiooKff3116qrq1NdXZ1ee+01SSebyDvvvFOzZs3S5s2bNXv2bJWXl4dcD40fAAAwVpQsRVlhXGwO9m7atEn19fWaN2+eBg4cqPz8fC1durTdc4qLi5WWlqYLL7xQiYmJSkxM1AUXXCBJKiws1OjRo5Wdna3Bgwdr+vTpWrlypY3fFwAAAGzx+XzNFr/f3+pxJSUlysjIUFxcnKSTQ7hlZWXtXnvHjh06ePBgsPHLyckJXr+kpES//OUvg8cOGzZMu3fvDrluGj8AAGAsKwKLJKWkpCghISG4FBQUtFqfz+eT1+v9//ValqKjo1VXV9fmz1ReXq7hw4dr+/bt2rx5sz788EPNnz+/1evFx8fr0KFDof2yxKxeAAAA26qqqhQfHx9c93g8rR4XExPTYl9sbKyampqUlJTU6jmLFy9utj579mwtWLBATzzxRIvrnbpWqGj8AACAuSL0Ppf4+PhmjV9bkpOTVVpa2mxbQ0ODOnfuHPIte/bsqerq6uD1ampqzvhaDPUCAAB0kPT0dBUVFQXXKysr5ff7lZyc3OY51113naqqqoLrRUVF6t+/f6vXKy4uVt++fUOuh8YPAACgg4wcOVI+n0/Lli2TJOXn52vMmDGKjo7W4cOHdfz48RbnXH755br33nv1+eefa8WKFZo7d65ycnIkSZMmTdJbb72lPXv2qLGxUQsWLNDYsWNDroehXgAAYCzrx3/CeT87YmJiVFhYqKysLOXm5ioqKkrbtm2TJCUlJam4uFhXXnlls3NefvllTZs2TaNHj1bPnj310ksvaerUqZKkIUOGaObMmbrmmmsUGxurQYMG6f777w+9HlvVAwAAwJYJEyaooqJCu3fvVkZGhrp37y5JbX7BIzExUevXr2/zer/97W915513qrq6WqNGjbL1jB+NHwAAMJclWQZ8rLd3794aN26cY2WkpqYqNTXV9nk84wcAAOASNH4AAAAuwVAvAAAwVoRe42csGj8A+FFS+vRIl3BadTt/F+kSABiMxg8AAJiLyM8WnvEDAABwCRI/AABgrHP9Bc7nGhI/AAAAl6DxAwAAcAmGegEAgLGsMH+5I6xfCekAJH4AAAAuQeIHAACMxdtc7CHxAwAAcAkaPwAAAJdgqBcAAJiLsV5bSPwAAABcgsQPAAAYiy932EPiBwAA4BIkfgAAwFi8wNkeEj8AAACXsN341dbWyuv1av/+/cFtpaWlSk9PV1JSknJzcxUIBJysEQAAAA6w1fjV1tYqMzOzWdPn9/s1fvx4DR06VLt27VJZWZmWL1/ucJkAAAAtWRFYTGar8Zs8ebKmTJnSbNumTZtUX1+vefPmaeDAgcrPz9fSpUsdLRIAAABnz9bkjiVLlsjr9WrmzJnBbSUlJcrIyFBcXJwkKS0tTWVlZe1ex+/3y+/3B9d9Pp+dMgAAAE7iBc622Er8vF5vi20+n6/ZdsuyFB0drbq6ujavU1BQoISEhOCSkpJipwwAAACcgbOe1RsTEyOPx9NsW2xsrJqamto8Jy8vT/X19cGlqqrqbMsAAADAaZz1e/ySk5NVWlrabFtDQ4M6d+7c5jkej6dFswgAAGAXX+6w56wTv/T0dBUVFQXXKysr5ff7lZycfLaXBgAAgIPOuvEbOXKkfD6fli1bJknKz8/XmDFjFB0dfdbFAQAAtOfUlzvCuZjsrId6Y2JiVFhYqKysLOXm5ioqKkrbtm1zoDQAAAA46Ywav59/mWPChAmqqKjQ7t27lZGRoe7duztSHAAAAJxz1onfKb1799a4ceOcuhwAAMBp8Ro/e876GT8AAACYwbHEDwAAIOyI/Gwh8QMAAHAJEj8AAGAsXuBsD4kfAACAS9D4AQAAuARDvQAAwFjh/pqG6V/uIPEDAABwCRI/AABgLN7mYg+JHwAAgEvQ+AEAALgEQ70AAMBcjPXaQuIHAADgEiR+AADH1e38XaRLQBj4fD716r4kojXw5Q57SPwAAABcgsQPAAAYixc420PiBwAA4BI0fgAAAC7BUC8AADAWb3Oxh8QPAADAJUj8AACAuYj8bCHxAwAAcAkaPwAAAJdgqBcAABiLL3fYQ+IHAADgEiR+AADAXGH+cofhgR+JHwAAgFuQ+AEAAGPxNhd7SPwAAABcgsYPAADAJRjqBQAA5mKs1xYSPwAAAJcg8QMAAMbiBc72kPgBAAB0oNLSUqWnpyspKUm5ubkKBAKnPeeZZ55RcnKyPB6Pbr31VjU0NAT3paWlybKs4JKdnR1yLTR+AAAAHcTv92v8+PEaOnSodu3apbKyMi1fvrzdc1atWqVVq1bp/fff19/+9jft3btXL7zwgiSpqalJFRUV+vrrr1VXV6e6ujq99tprIdfDUC8AADCWFeYvd9i916ZNm1RfX6958+YpLi5O+fn5euCBBzRt2rQ2z6mqqtKKFSs0bNgwSdIdd9yhnTt3SpKKi4uVlpamCy+88Izqp/EDAACwyefzNVv3eDzyeDwtjispKVFGRobi4uIknRymLSsra/faTzzxRLP18vJyDRo0SJK0Y8cOHTx4UBdeeKGOHTumrKwsvfLKK63euzUM9QIAAGNZEVgkKSUlRQkJCcGloKCg1fp8Pp+8Xu//r9eyFB0drbq6upB+vr///e9av3697rnnHkknm8Dhw4dr+/bt2rx5sz788EPNnz8/pGtJJH4AAAC2VVVVKT4+PrjeVuIWExPTYl9sbKyampqUlJTU7j1OnDihu+++W9nZ2br88sslSYsXL252zOzZs7VgwYIWKWFbaPwAAIC5IvQC5/j4+GaNX1uSk5NVWlrabFtDQ4M6d+582nOfe+45ffvtt3rppZfaPKZnz56qrq4+7bVOYagXAACgg6Snp6uoqCi4XllZKb/fr+Tk5HbPe/fddzVv3jz98Y9/DD4fKEnXXXedqqqqgutFRUXq379/yPXQ+AEAAHSQkSNHyufzadmyZZKk/Px8jRkzRtHR0Tp8+LCOHz/e4py9e/cqKytLr732mlJSUtTY2KimpiZJ0uWXX657771Xn3/+uVasWKG5c+cqJycn5Hpo/AAAgLGsCPxjR0xMjAoLCzV9+nT16NFDGzZs0L//+79LkpKSkrRnz54W57z55pv67rvvNHXqVHXr1k3dunVTamqqJOnll1+Wx+PR6NGjNWfOHL300kuaOnVq6L+vQCivj+5gPp9PCQkJ8gz+P7KiTz/mDQBuVbfzd5EuAQjy+Xzq1T1B9fX1IT3v5vS9ExIStKfya3XrFr57NzT4NNjb0/bP/NVXX2n37t3KyMhQ9+7dO7DC9jG5AwAAGMtSmF/gfIbn9e7dW+PGjXO0ljPBUC8AAIBL0PgBAAC4BEO9AADAWBF6jZ+xSPwAAABcgsQPAAAYy7LCPLnD8MiPxA8AAMAlSPwAAIDBeMrPDhI/AAAAlzgnEr9THw8JHD8a4UoA4Nzm8/kiXQIQ1PDjv4/nwEfAEKJzovFraGiQJB0tWxHhSgDg3Nar+5JIlwC00NDQoISEhIjcm8kd9pwTjV+fPn1UVVWlbt26yXLgN+rz+ZSSkqKqqqqwfzvwfMPv0jn8Lp3B79E5/C6d49bfZSAQUENDg/r06RPpUhCic6Lxi4qKUr9+/Ry/bnx8vKv+B9iR+F06h9+lM/g9OoffpXPc+LuMVNJ3ClM77GFyBwAAgEvQ+AEAALjEOTHU6zSPx6M5c+bI4/FEuhTj8bt0Dr9LZ/B7dA6/S+fwu4wcJnfYYwWYgw0AAAzj8/mUkJCg8v9bo25hfK6ywefTpRddqPr6eiOf5zwvEz8AAOAO1o//hPN+JuMZPwAAAJcg8QMAAObifS62nHeJX2lpqdLT05WUlKTc3Fw+I3MWNmzYoAEDBigmJkZXXnml9u7dG+mSjHfTTTdp+fLlkS7DeI8//rjGjx8f6TKMVlhYqJSUFMXFxemGG27QP//5z0iXZJTa2lp5vV7t378/uI2/PzDBedX4+f1+jR8/XkOHDtWuXbtUVlbGH9kzVFFRoWnTpumFF15QdXW1LrnkEmVnZ0e6LKOtWrVKmzdvjnQZxvvrX/+qRYsW6dVXX410KcaqqKjQs88+qw0bNmjfvn0aOHCg7rrrrkiXZYza2lplZmY2a/r4+wNTnFeN36ZNm1RfX6958+Zp4MCBys/P19KlSyNdlpH27t2rF154Qb/+9a/Vq1cv5eTkqLi4ONJlGevbb7/Vo48+qksvvTTSpRjtxIkTuueee/Twww9rwIABkS7HWMXFxcrIyNDVV1+tiy66SHfffbe++OKLSJdljMmTJ2vKlCnNtvH3J3KsCCwmO68av5KSEmVkZCguLk6SlJaWprKysghXZabMzEzdc889wfXy8nINGjQoghWZ7dFHH9Wtt96qjIyMSJditMWLF2vPnj26+OKL9c477+jo0aORLslIqamp2rJli/7yl7+ovr5eixYt0o033hjpsoyxZMkSzZgxo9k2/v7AFOdV4+fz+eT1eoPrlmUpOjpadXV1EazKfEePHtXcuXN13333RboUI23dulV//vOf9eKLL0a6FKM1NjZqzpw5GjBggA4cOKD58+dr+PDhOnLkSKRLM05qaqpuv/12XXXVVUpMTFRRUZFefvnlSJdljJ/+nTmFvz+Rc+oFzuFcTHZeNX4xMTEt3poeGxurpqamCFV0fpgzZ466dOnCM35n4Pvvv9e9996r119/Xd26dYt0OUZ7++239d1332nr1q165pln9OGHH6qhoUErV66MdGnG2bFjh95991199tlnOnz4sLKysnTLLbcwGeEs8PcHpjivGr/k5GTV1NQ029bQ0KDOnTtHqCLzbdmyRQsXLtTq1avVqVOnSJdjnOeee07p6ekaN25cpEsx3sGDB5WRkaEePXpIOvmHNi0tjWfTzsCaNWs0efJkXXvttUpISNDzzz+viooKlZSURLo0Y/H3B6Y4r97jl56eriVLlgTXKysr5ff7lZycHMGqzFVZWamsrCwtXLhQqampkS7HSKtXr1ZNTY0SExMlSU1NTVq7dq127NihRYsWRbY4w/Tr16/FsO6BAwd0/fXXR6gic504cUK1tbXB9YaGBjU1Nen48eMRrMps/P2JHL7cYc951fiNHDlSPp9Py5Yt07Rp05Sfn68xY8YoOjo60qUZ58iRI8rMzNTEiRN16623qrGxUZLUpUsXWaY/4BBGn3zyiX744Yfg+mOPPaaMjAxenXEGxo0bpwcffFCLFy9WZmam3n77bZWUlOgPf/hDpEszzogRIzR16lRdffXV6tWrlwoLC9W7d2+lpaVFujRj8fcHpjivGr+YmBgVFhYqKytLubm5ioqK0rZt2yJdlpE++OADlZWVqaysrMX/F3vxxRdHrjDD9OvXr9l6165d1aNHj+BwJULXvXt3vffee3rsscf0yCOP6Be/+IXWrl2rlJSUSJdmnEmTJmnv3r165ZVX9OWXX+qKK67Q+vXreZzjLPD3J4L4coctVuA8fJr3q6++0u7du5WRkaHu3btHuhwAgEvw9yd8fD6fEhISVFH9jbrFx4ftvg0+nwb27a76+nrFh/G+TjkvGz8AAHB+o/E7M+fVUC8AAHAXRnrtOa9e5wIAAIC2kfgBAABjhftrGqa/2ILEDwAAwCVI/AAAgMHC+wJn05/yI/EDAABwCRo/AAAAl2CoFwAAGIvJHfaQ+AEAALgEjR8AAIBL0PgBAAC4BI0fAACASzC5AwAAGIvJHfaQ+AEAALgEiR8AADCWFeYvd4T3KyHOI/EDAABwCRI/AABgLJ7xs4fEDwAAwCVo/AAAAFyCoV4AAGAs68clnPczGYkfAACAS5D4AQAAcxH52ULiBwAA4BI0fgAAAC7BUC8AADAWX+6wh8QPAADAJUj8AACAsfhyhz0kfgAAAC5B4gcAAIzF21zsIfEDAABwCRo/AAAAl2CoFwAAmIuxXltI/AAAAFyCxA8AABiLFzjbQ+IHAADQgUpLS5Wenq6kpCTl5uYqEAic9px169apf//+6tOnj9asWdNs38KFC9WrVy8NGDBAW7ZssVULjR8AAEAH8fv9Gj9+vIYOHapdu3aprKxMy5cvb/ec0tJS3XnnnZo1a5Y2b96s2bNnq7y8XJK0efNmPfbYY3rzzTf1+9//XtnZ2frmm29CrofGDwAAGOvUlzvCudixadMm1dfXa968eRo4cKDy8/O1dOnSds8pLCzU6NGjlZ2drcGDB2v69OlauXKlJOn111/X1KlTNXHiRF1//fWaOHGi1q9fH3I9POMHAACM5fP5InK/n9/X4/HI4/G0OL6kpEQZGRmKi4uTJKWlpamsrKzde5SUlOjmm28Org8bNkzPPvtscN+UKVOa7fvv//5vZWdnh1Q/jR8AADBO586d1bt3bw3ypoT93l27dlVKSvP7zpkzR08//XSLY30+n7xeb3DdsixFR0errq5OSUlJrV7/5+fEx8fr0KFDp90XCho/AABgnNjYWFVWVuro0aNhv3cgEJD1szHf1tI+SYqJiWmxLzY2Vk1NTW02fj8/59Txp9sXCho/AABgpNjYWMXGxka6jHYlJyertLS02baGhgZ17ty53XNqampaPb69faFgcgcAAEAHSU9PV1FRUXC9srJSfr9fycnJIZ9TXFysvn37nnZfKGj8AAAAOsjIkSPl8/m0bNkySVJ+fr7GjBmj6OhoHT58WMePH29xzqRJk/TWW29pz549amxs1IIFCzR27FhJ0u23365Fixapurpa//u//6ulS5cG94XCCoTyFkEAAACckXfeeUdZWVm64IILFBUVpW3btik1NVWWZam4uFhXXnlli3OefPJJvfzyy4qNjdWgQYP0ySef6IILLlAgENC//du/6Y9//KMk6Ve/+pXeeeedFs8ctoXGDwAAoIN99dVX2r17tzIyMtS9e/eQzikrK1N1dbVGjRrV4jm+nTt36rvvvtOoUaNCbvokGj8AAADX4Bk/AAAAl6DxAwAAcAkaPwAAAJeg8QMAAHAJGj8AAACXoPEDAABwCRo/AAAAl6DxAwAAcAkaPwAAAJf4f5LgkfWFvHENAAAAAElFTkSuQmCC",
      "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": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "76824"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_visit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x224c123bc40>]"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "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
}
