{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 153,
   "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": 154,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(0)\n",
    "total_violation=0\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",
    "epsilon_start = 1.0\n",
    "epsilon_end = 0.1\n",
    "epsilon_decay_rate = 0.9985\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.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",
    "\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=30\n",
    "alpha=0.3*np.ones(N)\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": 155,
   "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": 156,
   "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",
    "\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": 157,
   "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": 157,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "map_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "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": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "map_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "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": 160,
   "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": 161,
   "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": 162,
   "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": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "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": 164,
   "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((T,nS,nA))\n",
    "    Q[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[t+1,int(s_next_old[s,int(choice[0])]),:])\n",
    "                Q_max[s,a]+=abs(prob[1])*np.max(Q[t+1,int(s_next_old[s,int(choice[1])]),:])\n",
    "        Q[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",
    "            if unsafe_set[s,a]==0:\n",
    "                Q[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,s])]=1\n",
    "    return pi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "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,map_type[row,col]])\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": 166,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mean+sigma:\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",
    "    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[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",
    "    start_p=np.zeros(len(start_set))\n",
    "    for i in range(len(start_set)):\n",
    "        row,col=to_row_col(start_set[i])\n",
    "        start_p[i]=np.exp(-2*state_visit[n+1,row,col])\n",
    "    # start_p=np.sum(start_p)-start_p\n",
    "    if np.sum(start_p)>0:\n",
    "        s=np.random.choice(start_set,p=start_p/np.sum(start_p))\n",
    "    else:\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",
    "    if s not in S:\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",
    "        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",
    "        s=new_s\n",
    "    else:\n",
    "        while (s in S and t<T and n_violate<1.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",
    "            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",
    "            s=new_s\n",
    "            \n",
    "            epsilon = max(epsilon_end, epsilon_start * (epsilon_decay_rate ** n))\n",
    "            if np.random.random() > epsilon:\n",
    "                a=np.random.choice([0,1,2,3,4,5,6,7],p=pi[s])\n",
    "            else:\n",
    "                possible_action=np.ones(nA)\n",
    "                for i in range(nA):\n",
    "                    if unsafe_sa[s,i]>0:\n",
    "                        possible_action[i]=0  \n",
    "                a=np.random.choice([0,1,2,3,4,5,6,7],size=1,p=possible_action/np.sum(possible_action))[0]\n",
    "                # a=np.random.choice([0,1,2,3,4,5,6,7],p=np.ones(nA)/nA)\n",
    "            t+=1\n",
    "    row,col=to_row_col(s)\n",
    "    state_visit[n+1,row,col]+=1\n",
    "    data_list.append(dataset)\n",
    "\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": 167,
   "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": 168,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 169,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.76371007, 0.76371007, 1.63006093, 1.63006093, 0.76371007,\n",
       "       0.76371007, 1.55895836, 1.77439597, 1.22593277, 0.59817754,\n",
       "       0.23204573, 0.07574604])"
      ]
     },
     "execution_count": 169,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_predict.reshape(nrow,ncol)[4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.85977051, 0.85977051, 0.85977051, 0.85977051, 0.85977051,\n",
       "       0.85977051, 0.86579383, 0.90786754, 0.96181123, 0.98711308,\n",
       "       0.99602914, 0.99906871])"
      ]
     },
     "execution_count": 170,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sigma.reshape(12,12)[5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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krSojBJcURK4WbNmxQ9+8IP41re+FZdeemk89NBDsWnTJu+2AQCcA0XbyPc973lPbNu2rVjdAQCclrNQAQBIggQOACAxRT0LFQCglKoyr7VSjlcJVOAAABKjAgcAJCuTiagq4coCixgAADgjEjgAgMSYQgUAkmUfOAAAkqACBwAkyzYiAAAkQQIHAJAYU6gAQLIyr/8p5XiVQAUOACAxFVWBm1JTFbU1lZtTfvX6y8odQkGqK+UNSwDOa5Xw88YiBgAAklBRFTgAgIlQgQMAIAkSOACAxJhCBQCSlclkIlPCA0pLOdapqMABACRGBQ4ASJZFDAAAJEECBwCQGFOoAECyMpnXWinHqwQqcAAAiVGBAwCSVZXJRFUJy2JnOtYf//jHeP755+PSSy+NmTNnnn0cZ90DAAAn9d3vfjfmzp0bt912W8yZMye++93vRkREX19ftLW1xcyZM6OzszNGR0cL7lMCBwAk69g2IqVsEzE0NBR/8zd/E//xH/8RzzzzTKxatSo6Ozsjn8/H0qVLY+HChbF9+/bo7++Pnp6ewr/viYUBAEChcrlcPPjgg9Ha2hoREVdeeWX813/9V2zevDmGhoZi5cqVMX/+/Ojq6or169cX3K934AAAJiiXy427zmazkc1mj3uuubk5PvKRj0RExKuvvhoPPPBALF++PHp7e6O9vT2mTp0aERGtra3R399f8PgqcABAujL/vZVIKVq8PoXa3NwcDQ0NY627u/uUYfb29kZTU1P88Ic/jK9//euRy+WipaXlv7+NTCaqq6tj//79BX3bKnAAABM0ODgY9fX1Y9cnqr69UWtrazz++ONx5513xm233Rbz588/7mvq6upiZGSkoFWqKnAAQLKqIlPyFhFRX18/rp0ugctkMrFw4cL41re+FY888kg0NjbG3r17xz0zPDwctbW1BX7fAACcEz/96U+js7Nz7Lq2tjYymUxcfvnlsW3btrH7u3fvjnw+H42NjQX1K4EDADhHLr300vjmN78Z3/zmN2NwcDA+97nPxfvf//644YYbIpfLxYYNGyIioqurKxYtWhTV1dUF9SuBAwCSVcoFDGdy7upb3vKW+Nd//dd46KGH4s/+7M9iZGQk/uVf/iVqampi3bp18bd/+7cxe/bsePTRR+Mf//EfC+7XIgYAgHPo2muvjWefffa4+8uWLYuBgYHYsWNH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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,1000))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "62"
      ]
     },
     "execution_count": 172,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(start_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([5.38018616e-32, 1.50078576e-41, 8.62880116e-60, 4.18639400e-51,\n",
       "       1.33361482e-34, 1.10893902e-40, 1.10893902e-40, 9.22114642e-47,\n",
       "       5.30171867e-65, 2.89464031e-63, 3.09335001e-50, 5.38018616e-32,\n",
       "       5.03457536e-45, 6.05460190e-39, 7.28129018e-33, 1.33361482e-34,\n",
       "       9.85415469e-34, 7.28129018e-33, 5.38018616e-32, 7.28129018e-33,\n",
       "       5.38018616e-32, 5.38018616e-32, 7.28129018e-33, 7.28129018e-33,\n",
       "       9.85415469e-34, 5.38018616e-32, 5.38018616e-32, 5.38018616e-32,\n",
       "       7.28129018e-33, 3.72007598e-44, 1.33361482e-34, 5.38018616e-32,\n",
       "       7.28129018e-33, 5.38018616e-32, 1.33361482e-34, 7.28129018e-33,\n",
       "       1.33361482e-34, 5.38018616e-32, 8.19401262e-40, 7.28129018e-33,\n",
       "       7.28129018e-33, 5.38018616e-32, 5.38018616e-32, 5.38018616e-32,\n",
       "       7.28129018e-33, 7.28129018e-33, 5.38018616e-32, 9.85415469e-34,\n",
       "       7.28129018e-33, 9.85415469e-34, 5.38018616e-32, 5.38018616e-32,\n",
       "       1.33361482e-34, 9.85415469e-34, 7.28129018e-33, 5.38018616e-32,\n",
       "       7.28129018e-33, 5.38018616e-32, 7.28129018e-33, 5.38018616e-32,\n",
       "       7.28129018e-33, 7.28129018e-33])"
      ]
     },
     "execution_count": 173,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "start_p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1572"
      ]
     },
     "execution_count": 174,
     "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": 175,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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krSojBJcURK4WbNmxQ9+8IP41re+FZdeemk89NBDsWnTJu+2AQCcA0XbyPc973lPbNu2rVjdAQCclrNQAQBIggQOACAxRT0LFQCglKoyr7VSjlcJVOAAABKjAgcAJCuTiagq4coCixgAADgjEjgAgMSYQgUAkmUfOAAAkqACBwAkyzYiAAAkQQIHAJAYU6gAQLIyr/8p5XiVQAUOACAxFVWBm1JTFbU1lZtTfvX6y8odQkGqK+UNSwDOa5Xw88YiBgAAklBRFTgAgIlQgQMAIAkSOACAxJhCBQCSlclkIlPCA0pLOdapqMABACRGBQ4ASJZFDAAAJEECBwCQGFOoAECyMpnXWinHqwQqcAAAiVGBAwCSVZXJRFUJy2JnOtYf//jHeP755+PSSy+NmTNnnn0cZ90DAAAn9d3vfjfmzp0bt912W8yZMye++93vRkREX19ftLW1xcyZM6OzszNGR0cL7lMCBwAk69g2IqVsEzE0NBR/8zd/E//xH/8RzzzzTKxatSo6Ozsjn8/H0qVLY+HChbF9+/bo7++Pnp6ewr/viYUBAEChcrlcPPjgg9Ha2hoREVdeeWX813/9V2zevDmGhoZi5cqVMX/+/Ojq6or169cX3K934AAAJiiXy427zmazkc1mj3uuubk5PvKRj0RExKuvvhoPPPBALF++PHp7e6O9vT2mTp0aERGtra3R399f8PgqcABAujL/vZVIKVq8PoXa3NwcDQ0NY627u/uUYfb29kZTU1P88Ic/jK9//euRy+WipaXlv7+NTCaqq6tj//79BX3bKnAAABM0ODgY9fX1Y9cnqr69UWtrazz++ONx5513xm233Rbz588/7mvq6upiZGSkoFWqKnAAQLKqIlPyFhFRX18/rp0ugctkMrFw4cL41re+FY888kg0NjbG3r17xz0zPDwctbW1BX7fAACcEz/96U+js7Nz7Lq2tjYymUxcfvnlsW3btrH7u3fvjnw+H42NjQX1K4EDADhHLr300vjmN78Z3/zmN2NwcDA+97nPxfvf//644YYbIpfLxYYNGyIioqurKxYtWhTV1dUF9SuBAwCSVcoFDGdy7upb3vKW+Nd//dd46KGH4s/+7M9iZGQk/uVf/iVqampi3bp18bd/+7cxe/bsePTRR+Mf//EfC+7XIgYAgHPo2muvjWefffa4+8uWLYuBgYHYsWNH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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": 176,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "50"
      ]
     },
     "execution_count": 176,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_violation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1bbe1e0b7c0>]"
      ]
     },
     "execution_count": 177,
     "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(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": 178,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 179,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAn4AAAKICAYAAADuG/dkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5AElEQVR4nO3de3BVVZ728WcnIScGyA0EGoh44EXLKAHFYHQQpBsLlYCjWCPBqkGsjBoveE0rpYC3SRwRUHxBNGGAsrmMTUujjYjYgCNOFKHSadKBdJsOTAjSJhpyEoMHhPP+gZzXmAtnw845LPb3Q+2q3te1kqqu/HzWXmtbgUAgIAAAAJzzoiLdAQAAAIQHhR8AAIBLUPgBAAC4BIUfAACAS1D4AQAAuASFHwAAgEtQ+AEAALgEhR8AAIBLUPgBAAC4BIUfAACAS1D4AQAAdKJ169Zp4MCBiomJ0bBhw7R79+5T3vPxxx/rkksuUc+ePTVv3rwW59asWaMBAwaob9++WrVqla2+UPgBAAB0ksrKSk2bNk0vvviiampqdNFFFyknJ6fDe2prazVx4kRlZ2eruLhYK1as0JYtWyRJZWVluuOOOzRz5kxt3LhRs2bNUkVFRcj9sQKBQOCMfiIAAAC06Q9/+IMOHDigu+++W5K0ZcsWjR8/Xs3Nze3e88orr+iNN95QeXm5LMvSunXr9Nvf/la/+c1v9PDDD2vPnj364IMPJEmvvvqqamtr9cILL4TUn5gz/5EAAADC7/vvv9eRI0fC3m4gEJBlWS2OeTweeTyeVtdmZWW12K+oqNDgwYM7fH5paanGjBkTbGPEiBF68skng+duvPHG4LUjRozQc889F3LfKfwAAIBxvv/+e53XvYf0Q/vJWWfp1q2bmpqaWhybPXu2nnnmmQ7vO3LkiObOnatHH320w+t8Pp/S0tKC+wkJCTpw4EDwnNfrbfNcKCj8AACAcY4cOSL90CxP2lQpOjZ8DR87oqby5aqurlZCQkLwcFtp38/Nnj1bXbt2PeU7fjExMS2eFxcXFxwa7uhcKCj8AACAuWLiZIWx8AtYJ+bFJiQktCj8TmXz5s1auHChPvvsM3Xp0qXDa1NSUlRbWxvcb2xsVGxs7CnPhYJZvQAAAJ2oqqpK2dnZWrhwYYsh3PZkZGSouLg4uF9SUqJ+/fqd8lwoKPwAAAA6yeHDh5WVlaWbb75Zt9xyi5qamtTU1KRAICCfz6ejR4+2umfixIn69NNP9dFHH+no0aN66aWXNG7cOEnSpEmTtHr1au3atUtNTU1asGBB8FwoKPwAAIC5LEmWFcbNXvc+/PBDlZeXq7CwUN27dw9u+/btU3p6utavX9/qnp49e2r+/Pm66aab1Lt3b1VUVOjpp5+WJA0dOlQPPfSQrrzySvXr10/R0dG67777Qv91sY4fAAAwjc/nU2JiojxD75EVfeqJFU4JHPPLX/qGGhoabL3jdzqqqqq0Z88eXXvtterWrVuLc+Xl5aqpqdHo0aNtvePH5A4AAGAuK+rEFs72wsTr9bZYuuWn0tLSQnpf8OcY6gUAAHAJCj8AAACXYKgXAACY6+Ski3C2ZzASPwAAAJcg8QMAAOY6hyd3dAazew8AAICQkfgBAABz8Y6fLSR+AAAALkHhBwAA4BIM9QIAAIOFeXKH4ZmZ2b0HAABAyEj8AACAuZjcYQuJHwAAgEtQ+AEAALgEQ70AAMBcfLnDFrN7DwAAgJCR+AEAAHMxucMWEj8AAACXIPEDAADm4h0/W8zuPQAAAEJG4QcAAOASDPUCAABzMbnDFhI/AAAAlyDxAwAA5mJyhy1m9x4AAAAho/ADAABwCYZ6AQCAuSwrzEO9TO4AAACAAUj8AACAuaKsE1s42zMYiR8AAIBLUPgBAAC4BEO9AADAXKzjZ4vZvQcAAEDISPwAAIC5+FavLSR+AAAALkHiBwAAzMU7fraY3XsAAACEjMIPAADAJRjqBQAA5mJyhy0kfgAAAC5B4gcAAMzF5A5bzO49AAAAQkbhBwAA4BIM9QIAAHMxucMWEj8AAACXIPEDAADmYnKHLWb3HgAAACEj8QMAAObiHT9bSPwAAABcgsIPAADAJRjqBQAABgvz5A7DM7OzovA7fvy4Dhw4oO7du8syfOwcAAC3CAQCamxsVN++fRUVZXZB5BZnReF34MABpaamRrobAADgNFRXV6t///6RaZzJHbacFYVf9+7dJUmxaVNlRcdGuDcAACAUgWNHdKR8efDvOM5+Z0Xhd3J414qOpfADAMAwvKZljrOi8AMAADgtlhXmL3eYXeTyJiYAAIBLkPgBAABz8a1eW8zuPQAAAEJG4gcAAMzFci62kPgBAAC4BIUfAACASzDUCwAAzMXkDlvM7j0AAABCRuEHAADMdXJyRzg3m+rq6uT1erV3795TXvvMM8/IsqxW29atWyVJ6enpLY7n5OTY6gtDvQAAAJ2krq5OWVlZIRV9kvTkk0/q4YcfDu7v27dP119/vS6//HI1NzersrJSX3/9tbp06SJJ8ng8tvpD4QcAANBJJk+erClTpujzzz8P6fq4uDjFxcUF93/961/r4YcfVmJioj799FOlp6fr/PPPP+3+MNQLAADMdXJyRzg3GwoLCzV9+vTT+tEOHDigtWvXBu/fvn279u/fr/PPP19JSUnKzc2V3++39UzHCr+ysjJlZGQoOTlZeXl5CgQCTj0aAADgrOLz+Vps7RVgXq/3tNtYvHixsrOz1a1bN0lSRUWFRo4cqW3btmnjxo3atGmT5s+fb+uZjhR+fr9fEyZM0PDhw7Vjxw6Vl5dr2bJlTjwaAACgfRGa3JGamqrExMTgVlBQ4OiPdezYMRUWFuree+8NHlu8eLFWrVqliy++WFdddZVmzZqlNWvW2HquI+/4bdiwQQ0NDZo3b57i4+OVn5+v+++/X9OmTXPi8QAAAGeV6upqJSQkBPftTrI4lS1btqhHjx5KS0tr95pevXqppqbG1nMdSfxKS0uVmZmp+Ph4SSemGpeXlzvxaAAAgHa1tfRJZ2+SlJCQ0GJzuvB7++23deutt7Y4dvXVV6u6ujq4X1xcrAEDBth6riOFn8/nazGGbVmWoqOjVV9f3+b1fr+/1dg4AACAW/h8Ph09erTd8x988IGuu+66FscuvfRS3XPPPfr888+1fPlyzZ07V7m5ubbadaTwi4mJaVXpxsXFqbm5uc3rCwoKWoyLp6amOtENAAAAI6Snp2v9+vVtnqusrNSBAwc0YsSIFsdffvlleTwejRkzRrNnz9acOXM0depUW+068o5fSkqKysrKWhxrbGxUbGxsm9fPmDFDjz76aHDf5/NR/AEAANt+OvwapgZP67afr3bS0YLOgwYN0g8//NDqeFJSktauXXta7Z/kSOGXkZGhwsLC4H5VVZX8fr9SUlLavN7j8Tg+Fg4AAICOOTLUO2rUKPl8Pi1dulSSlJ+fr7Fjxyo6OtqJxwMAALTNisBmMEcSv5iYGBUVFSk7O1t5eXmKiooKfkwYAAAAZwfHvtU7ceJEVVZWaufOncrMzFSPHj2cejQAAAAc4FjhJ0l9+vTR+PHjnXwkAABAu0yZ3HG2cOxbvQAAADi7OZr4AQAAhBOJnz0kfgAAAC5B4gcAAIxF4mcPiR8AAIBLUPgBAAC4BEO9AADAWAz12kPiBwAA4BIkfgAAwFzh/n6u2YEfiR8AAIBbUPgBAAC4BEO9AADAWEzusIfEDwAAwCVI/AAAgLEsS2FO/MLXVGcg8QMAAHAJEj8AAGAsS2F+x8/wyI/EDwAAwCUo/AAAAFyCoV4AAGAslnOxh8QPAADAJUj8AACAufhWry0kfgAAAC5B4QcAAOASDPUCAABzhXlyR4DJHQAAADABiR8AADBWuJdzCe9XQpxH4gcAAOASFH4AAAAuwVAvAAAwFkO99pD4AQAAuASJHwAAMBdf7rCFxA8AAMAlSPwAAICxeMfPHhI/AAAAl6DwAwAAcAmGegEAgLEY6rWHxA8AAMAlSPwAAICxSPzsIfEDAABwCQo/AAAAl2CoFwAAGIuhXntI/AAAAFyCxA8AAJiLb/XaQuIHAADgEiR+AADAWLzjZw+JHwAAgEtQ+AEAALgEQ70AAMBYDPXaQ+IHAADgEiR+AADAWCR+9pD4AQAAuASFHwAAgEsw1AsAAMzFlztsIfEDAABwCRI/AABgLCZ32EPiBwAA4BIkfgAAwFgkfvaQ+AEAALgEhR8AAIBLMNQLAACMZSnMQ72Gr+dC4gcAAOASJH4AAMBYTO6wh8QPAACgE9XV1cnr9Wrv3r0hXT9x4sRgQWtZlsaOHRs89/HHH+uSSy5Rz549NW/ePNt9ofADAADoJHV1dcrKygq56JOkHTt2aNeuXaqvr1d9fb3WrVsnSaqtrdXEiROVnZ2t4uJirVixQlu2bLHVHwo/AABgLisCmw2TJ0/WlClTQr6+pqZGgUBAl112mZKSkpSUlKSuXbtKklasWKG+fftq5syZGjx4sGbNmqUlS5bY6g+FHwAAgE0+n6/F5vf727yusLBQ06dPD/m527dv17Fjx9S/f3917dpVkydPVn19vSSptLRUY8aMCb5nOGLECO3cudNWvyn8AACAsX76Lly4NklKTU1VYmJicCsoKGizf16v19bPs2fPHg0dOlTr16/XZ599pqqqKs2YMUPSiWLzp89LSEjQgQMHbD2fWb0AAAA2VVdXKyEhIbjv8Xgcee6MGTOChZ4kzZkzR7feeqsWL16smJiYFu3ExcWpubnZ1vMp/AAAgLEitZxLQkJCi8Kvs/Tq1UvffPON/H6/UlJSVFtbGzzX2Nio2NhYW89jqBcAAOAscfvtt2vbtm3B/eLiYvXu3Vsej0cZGRkqLi4OnispKVG/fv1sPd+xwm/dunUaOHCgYmJiNGzYMO3evdupRwMAAJxTfD6fjh492ur4kCFD9Mgjj2jbtm36/e9/rxkzZig3N1fSifX9Pv30U3300Uc6evSoXnrpJY0bN85Wu44UfpWVlZo2bZpefPFF1dTU6KKLLlJOTo4TjwYAAGiXZYV/c0J6errWr1/f6vgTTzyh9PR03XDDDcrNzdV9992np556SpLUs2dPzZ8/XzfddJN69+6tiooKPf3007batQKBQOBMO/+HP/xBBw4c0N133y1J2rJli8aPHx/yC4c+n0+JiYnyDPk3WdH2xqoBAEBkBI4dkX9XoRoaGsLyvttPnawdvA+sUZQnPmztHvc3q+r/3haRn/mkqqoq7dmzR9dee626detm615HJndkZWW12K+oqNDgwYOdeDQAAEC7TqRw4ZzcEbam2uX1em0vE3OS47N6jxw5orlz5+rRRx9t9xq/399ioUOfz+d0NwAAAPAzjs/qnT17trp27drhO34FBQUtFj1MTU11uhsAAAD4GUcLv82bN2vhwoVauXKlunTp0u51M2bMUENDQ3Crrq52shsAAMAtwj2x4ywY6j0Tjg31VlVVKTs7WwsXLlRaWlqH13o8HsdWuAYAAEBoHCn8Dh8+rKysLN1888265ZZb1NTUJEnq2rVrWF+4BAAA7hKpL3eYypGh3g8//FDl5eUqLCxU9+7dg9u+ffuceDwAAAAc4Ejid/PNN8uB5QABAABscXJR5VDbMxnf6gUAAHAJCj8AAACXcHwBZwAAgHCJirIUFRW+8ddAGNvqDCR+AAAALkHiBwAAjMXkDntI/AAAAFyCwg8AAMAlGOoFAADG4ssd9pD4AQAAuASJHwAAMBaTO+wh8QMAAHAJEj8AAGAs3vGzh8QPAADAJSj8AAAAXIKhXgAAYCyGeu0h8QMAAHAJEj8AAGAslnOxh8QPAADAJSj8AAAAXIKhXgAAYCxLYZ7cIbPHekn8AAAAXILEDwAAGIvJHfaQ+AEAALgEhR8AAIBLMNQLAACMxZc77CHxAwAAcAkSPwAAYCwmd9hD4gcAAOASJH4AAMBYvONnD4kfAACAS1D4AQAAuARDvQAAwFhM7rCHxA8AAMAlSPwAAICxmNxhD4kfAACAS1D4AQAAuARDvQAAwFxhntwhs0d6SfwAAADcgsQPAAAYi8kd9pD4AQAAuASJHwAAMBYLONtD4gcAAOASFH4AAAAuwVAvAAAwFpM77CHxAwAAcAkSPwAAYCwmd9hD4gcAAOASFH4AAAAuwVAvAAAwFpM77CHxAwAAcAkSPwAAYCwSP3tI/AAAAFyCxA8AABiL5VzsIfEDAABwCQo/AAAAl2CoFwAAGIvJHfaQ+AEAALgEhR8AADDWyckd4dzsqqurk9fr1d69e0O6/s0339QvfvELdenSRaNHj9ZXX30VPDdx4sRgymlZlsaOHWurLxR+AAAAnaSurk5ZWVkhF33btm3TzJkz9dZbb6mqqkqBQECPP/548PyOHTu0a9cu1dfXq76+XuvWrbPVHwo/AACATjJ58mRNmTIl5Ov/9re/6Y033tDYsWPVv39/TZs2TSUlJZKkmpoaBQIBXXbZZUpKSlJSUpK6du1qqz8UfgAAwFg/HfYM12ZHYWGhpk+fHvL106ZN0z//8z8H9ysqKjR48GBJ0vbt23Xs2DH1799fXbt21eTJk1VfX2+rPxR+AAAANvl8vhab3+9v8zqv13vabXz77bd64403dO+990qS9uzZo6FDh2r9+vX67LPPVFVVpRkzZth6JoUfAAAwlqUwT+74sd3U1FQlJiYGt4KCAsd/tvvvv1/XXHONbrzxRknSjBkztGnTJg0dOlRDhgzRnDlztGbNGlvPZB0/AAAAm6qrq5WQkBDc93g8jj5/+fLl2rJli0pLS9u9plevXvrmm2/k9/tDbp/EDwAAGCvKssK+SVJCQkKLzcnCb8eOHXrwwQe1evVq9e7dO3j89ttv17Zt24L7xcXF6t27t622KfwAAADCzOfz6ejRo62Of/3115owYYJ+/etf68orr1RTU5OampokSUOGDNEjjzyibdu26fe//71mzJih3NxcW+1S+AEAAIRZenq61q9f3+r4qlWrdPDgQc2cOVPdu3cPbpL0xBNPKD09XTfccINyc3N133336amnnrLVrhUIBAKO/ARnwOfzKTExUZ4h/yYrOjbS3QEAACEIHDsi/65CNTQ0tHjfLRxO1g5j5nykmPPsrWV3Jn44/J225I2NyM/sBBI/AAAAl2BWLwAAMNbpLKp8pu2ZjMQPAADAJSj8AAAAXKJTCr8bbrhBy5Yt64xHAwAABEVZ4d9M5njht2LFCm3cuNHpxwIAAOAMOTq549tvv9Vjjz2miy++2MnHAgAAtM0K84QLwxM/Rwu/xx57TLfccosOHz7s5GMBAADgAMcKvy1btuiPf/yj/vKXv+jBBx/s8Fq/3y+/3x/c9/l8TnUDAAC4iGWd2MLZnskcecfv+++/1z333KPXX389+FmRjhQUFCgxMTG4paamOtENAAAAdMCRwu/5559XRkaGxo8fH9L1M2bMUENDQ3Crrq52ohsAAADogCNDvStXrlRtba2SkpIkSc3NzXr77be1fft2LVq0qNX1Ho9HHo/HiaYBAICLWT/+C2d7JnOk8Pvkk0/0ww8/BPcff/xxZWZm6s4773Ti8QAAAHCAI4Vf//79W+x369ZNPXv2VM+ePZ14PAAAQJvCvaiy6Qs4O7qcy0l8tQMAAODsw7d6AQAAXKJTEj8AAIBwsCwrrF/uCOtXQjoBiR8AAIBLkPgBAABj8eUOe0j8AAAAXILEDwAAGCvKshQVxhgunG11BhI/AAAAl6DwAwAAcAmGegEAgLGY3GEPiR8AAIBLkPgBAABjsYCzPSR+AAAALkHhBwAA4BIM9QIAAGMxucMeEj8AAACXIPEDAADG4ssd9pD4AQAAuASFHwAAgEsw1AsAAIxl/biFsz2TkfgBAAC4BIkfAAAwFl/usIfEDwAAwCVI/AAAgLGirBNbONszGYkfAACAS1D4AQAAuARDvQAAwFhM7rCHxA8AAMAlSPwAAIDRDA/hworEDwAAwCUo/AAAAFyCoV4AAGAsJnfYQ+IHAADgEiR+AADAWHy5wx4SPwAAAJcg8QMAAMbiHT97SPwAAABcgsIPAADAJRjqBQAAxrJ+3MLZnslI/AAAAFyCxA8AABgryrIUFcYJF+FsqzOQ+AEAALgEhR8AAIBLMNQLAACMZVkntnC2ZzISPwAAAJcg8QMAAMbiyx32kPgBAAC4BIkfAAAwFu/42UPiBwAA4BIUfgAAAC7BUC8AADAWX+6wh8QPAADAJUj8AACAsZjcYQ+JHwAAQCeqq6uT1+vV3r17Q7r+448/1iWXXKKePXtq3rx5Lc6tWbNGAwYMUN++fbVq1SrbfaHwAwAA6CR1dXXKysoKueirra3VxIkTlZ2dreLiYq1YsUJbtmyRJJWVlemOO+7QzJkztXHjRs2aNUsVFRW2+kPhBwAAjHXyyx3h3OyYPHmypkyZEvL1K1asUN++fTVz5kwNHjxYs2bN0pIlSyRJRUVFGjNmjHJycjRkyBA98MADeuutt2z1h8IPAADAJp/P12Lz+/1tXldYWKjp06eH/NzS0lKNGTMmWGCOGDFCO3fuDJ775S9/Gbz2p+dCReEHAACMFRWBTZJSU1OVmJgY3AoKCtrsn9frtfXz+Hy+FvckJCTowIEDpzwXKmb1AgAA2FRdXa2EhITgvsfjceS5MTExLZ4VFxen5ubmU54L+fmO9BIAACACTue9uzNtTzqRtv208HNKSkqKamtrg/uNjY2KjY095blQMdQLAABwlsjIyFBxcXFwv6SkRP369TvluVBR+AEAAISZz+fT0aNHWx2fOHGiPv30U3300Uc6evSoXnrpJY0bN06SNGnSJK1evVq7du1SU1OTFixYEDwXKgo/AABgLMuSosK4OTWqnJ6ervXr17c63rNnT82fP1833XSTevfurYqKCj399NOSpKFDh+qhhx7SlVdeqX79+ik6Olr33XefrXZ5xw8AAKCTBQKBFvsdLeh87733aty4cdqzZ4+uvfZadevWLXju3//933XHHXeopqZGo0ePtv2OH4UfAAAw1skkLpzthYPX6213KZi0tDSlpaWd1nMZ6gUAAHAJCj8AAACXYKgXAAAYK1Lr+JmKxA8AAMAlSPwAAICxztXJHZ2FxA8AAMAlSPwAAICxLAcXVQ61PZOR+AEAALiE44XfE088oQkTJjj9WAAAAJwhR4d6//znP2vRokUqLS118rEAAABtirIsRYVx/DWcbXUGxxK/48eP6+6779YjjzyigQMHOvVYAAAAOMSxwm/x4sXatWuXLrzwQr377rs6cuSIU48GAABoU1QENpM50v+mpibNnj1bAwcO1L59+zR//nyNHDlShw8fbvN6v98vn8/XYgMAAEDncqTwe+edd/Tdd99py5YtevbZZ7Vp0yY1NjbqrbfeavP6goICJSYmBrfU1FQnugEAAIAOOFL47d+/X5mZmerZs6ckKSYmRunp6fryyy/bvH7GjBlqaGgIbtXV1U50AwAAuMzJdfzCuZnMkVm9/fv3bzWsu2/fPl1zzTVtXu/xeOTxeJxoGgAAACFyJPEbP368ysvLtXjxYu3fv18LFixQaWmpbr31ViceDwAA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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": 180,
   "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": 181,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1573"
      ]
     },
     "execution_count": 181,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_visit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1bbe39b87f0>]"
      ]
     },
     "execution_count": 182,
     "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
}
