{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "3f701e41",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gymnasium as gym\n",
    "import math\n",
    "import random\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import namedtuple, deque\n",
    "from itertools import count\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "# import gymnasium as gym\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import gpytorch\n",
    "from scipy.linalg import solve\n",
    "from gpytorch.kernels import RBFKernel,ScaleKernel,LinearKernel\n",
    "from sklearn.gaussian_process import GaussianProcessRegressor\n",
    "from sklearn.gaussian_process.kernels import RBF, WhiteKernel\n",
    "from joblib import Parallel, delayed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "8050bbd0",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ExactGPModel(gpytorch.models.ExactGP):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(ExactGPModel, self).__init__(train_x, train_y, likelihood)\n",
    "        self.mean_module = gpytorch.means.ConstantMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(gpytorch.kernels.RBFKernel())\n",
    "\n",
    "    def forward(self, x):\n",
    "        mean_x = self.mean_module(x)\n",
    "        covar_x = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(mean_x, covar_x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "5c53ec97",
   "metadata": {},
   "outputs": [],
   "source": [
    "is_ipython = 'inline' in matplotlib.get_backend()\n",
    "if is_ipython:\n",
    "    from IPython import display\n",
    "\n",
    "plt.ion()\n",
    "\n",
    "# if GPU is to be used\n",
    "device = torch.device(\n",
    "    \"cuda\" if torch.cuda.is_available() else\n",
    "    \"mps\" if torch.backends.mps.is_available() else\n",
    "    \"cpu\"\n",
    ")\n",
    "\n",
    "Transition = namedtuple('Transition',\n",
    "                        ('state', 'action', 'next_state', 'reward','cost'))\n",
    "\n",
    "class ReplayMemory(object):\n",
    "\n",
    "    def __init__(self, capacity):\n",
    "        self.memory = deque([], maxlen=capacity)\n",
    "\n",
    "    def push(self, *args):\n",
    "        \"\"\"Save a transition\"\"\"\n",
    "        self.memory.append(Transition(*args))\n",
    "\n",
    "    def sample(self, batch_size):\n",
    "        return random.sample(self.memory, batch_size)\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.memory)\n",
    "class DQN(nn.Module):\n",
    "\n",
    "    def __init__(self, n_observations, n_actions):\n",
    "        super(DQN, self).__init__()\n",
    "        self.layer1 = nn.Linear(n_observations, 64)\n",
    "        self.layer2 = nn.Linear(64, 64)\n",
    "        self.layer3 = nn.Linear(64, n_actions)\n",
    "\n",
    "    # Called with either one element to determine next action, or a batch\n",
    "    # during optimization. Returns tensor([[left0exp,right0exp]...]).\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.layer1(x))\n",
    "        x = F.relu(self.layer2(x))\n",
    "        return self.layer3(x)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "9ae8b779",
   "metadata": {},
   "outputs": [],
   "source": [
    "BATCH_SIZE = 128\n",
    "GAMMA = 0.99\n",
    "EPS_START = 0.9\n",
    "EPS_END = 0.05\n",
    "EPS_DECAY = 12000\n",
    "TAU = 0.005\n",
    "LR = 1e-4\n",
    "nrow=20\n",
    "ncol=20\n",
    "# nA=8\n",
    "# nS = 144\n",
    "Lbd=0\n",
    "Rbd=10\n",
    "Ubd=10\n",
    "Dbd=0\n",
    "T=180\n",
    "LEFT = 0\n",
    "DOWN = 1\n",
    "RIGHT = 2\n",
    "UP = 3\n",
    "cost_threshold=0.3\n",
    "\n",
    "input_dim = 2\n",
    "hidden_dim = 32\n",
    "latent_dim = 16\n",
    "# safety_bound=0.3\n",
    "sigma_noise=0.1\n",
    "move_lb=0.6\n",
    "move_ub=1.2\n",
    "test_safe_para=0.7\n",
    "# Get number of actions from gym action space\n",
    "n_actions = 4\n",
    "# Get the number of state observations\n",
    "state=np.zeros(2)\n",
    "n_observations = len(state)\n",
    "num_episodes = 250\n",
    "Method=1 \n",
    "policy_net = DQN(n_observations, n_actions).to(device)\n",
    "target_net = DQN(n_observations, n_actions).to(device)\n",
    "target_net.load_state_dict(policy_net.state_dict())\n",
    "\n",
    "optimizer = optim.AdamW(policy_net.parameters(), lr=LR, amsgrad=True)\n",
    "memory = ReplayMemory(10000)\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "93a9be79",
   "metadata": {},
   "outputs": [],
   "source": [
    "def state_to_block(s):\n",
    "    a=int(np.floor(s[0]/Rbd*nrow))\n",
    "    b=int(np.floor(s[1]/Ubd*nrow))\n",
    "    if a==nrow:\n",
    "        a=int(a-1)\n",
    "    if b==ncol:\n",
    "        b=int(b-1)\n",
    "    return int(a),int(b)\n",
    "\n",
    "def select_action(state,steps_done):\n",
    "    \n",
    "    sample = random.random()\n",
    "    eps_threshold = EPS_END + (EPS_START - EPS_END) * \\\n",
    "        math.exp(-1. * steps_done / EPS_DECAY)\n",
    "    steps_done += 1\n",
    "    if sample > eps_threshold:\n",
    "        with torch.no_grad():\n",
    "            # t.max(1) will return the largest column value of each row.\n",
    "            # second column on max result is index of where max element was\n",
    "            # found, so we pick action with the larger expected reward.\n",
    "            return policy_net(state).max(1).indices.view(1, 1),steps_done\n",
    "    else:\n",
    "        return torch.tensor([[np.random.choice(4, 1)[0]]], device=device, dtype=torch.long),steps_done# change\n",
    "def select_result_action(state,result_steps_done):\n",
    "    result_steps_done\n",
    "    \n",
    "    sample = random.random()\n",
    "    eps_threshold = EPS_END + (EPS_START - EPS_END) * \\\n",
    "        math.exp(-1. * result_steps_done / EPS_DECAY)\n",
    "    result_steps_done += 1\n",
    "    if True:\n",
    "        with torch.no_grad():\n",
    "            # t.max(1) will return the largest column value of each row.\n",
    "            # second column on max result is index of where max element was\n",
    "            # found, so we pick action with the larger expected reward.\n",
    "            return policy_net(state).max(1).indices.view(1, 1), result_steps_done\n",
    "    else:\n",
    "        return torch.tensor([[np.random.choice(4, 1)[0]]], device=device, dtype=torch.long)# change\n",
    "\n",
    "def cal_grid_center(point,divide_dist):\n",
    "    return np.round(np.array(point)/divide_dist)*divide_dist\n",
    "\n",
    "\n",
    "def test_safe_action(state,action,mean,cov):\n",
    "    next_state=np.copy(state)\n",
    "    dist=np.random.uniform(move_lb,move_ub,1)\n",
    "    if action == LEFT:\n",
    "        next_state[0] = max(state[0] - dist, Lbd)\n",
    "    elif action == DOWN:\n",
    "        next_state[1] = max(state[1] - dist, Dbd)\n",
    "    elif action == RIGHT:\n",
    "        next_state[0] = min(state[0] + dist, Rbd)\n",
    "    elif action == UP:\n",
    "        next_state[1] = min(state[1] + dist, Ubd)\n",
    "    row,col=state_to_block(state)\n",
    "    b=(mean[row,col]+test_safe_para*cov[row,col,row,col] <cost_threshold)\n",
    "    return b\n",
    "\n",
    "\n",
    "def select_safe_action(state,mean,cov,steps_safe_done):\n",
    "    steps_safe_done\n",
    "    \n",
    "    sample = random.random()\n",
    "    eps_threshold = EPS_END + (EPS_START - EPS_END) * \\\n",
    "        math.exp(-1. * steps_safe_done / EPS_DECAY)\n",
    "    steps_safe_done += 1\n",
    "    if sample > eps_threshold:\n",
    "        with torch.no_grad():\n",
    "            # t.max(1) will return the largest column value of each row.\n",
    "            # second column on max result is index of where max element was\n",
    "            # found, so we pick action with the larger expected reward.\n",
    "            return policy_net(state).max(1).indices.view(1, 1),steps_safe_done\n",
    "    else:\n",
    "        possible_action=np.ones(4)\n",
    "        for i in range(4):\n",
    "            if test_safe_action(state.numpy()[0],i,mean,cov)!=True:\n",
    "                possible_action[i]=0\n",
    "        if np.sum(possible_action)==0:\n",
    "            with torch.no_grad():\n",
    "                return policy_net(state).max(1).indices.view(1, 1),steps_safe_done\n",
    "        else:\n",
    "            a=np.random.choice(4,size=1,p=possible_action/np.sum(possible_action))[0]\n",
    "            return torch.tensor([[a]], device=device, dtype=torch.long),steps_safe_done# change\n",
    "\n",
    "episode_durations = []\n",
    "\n",
    "\n",
    "def plot_durations(show_result=False):\n",
    "    plt.figure(1)\n",
    "    durations_t = torch.tensor(episode_durations, dtype=torch.float)\n",
    "    if show_result:\n",
    "        plt.title('Result')\n",
    "    else:\n",
    "        plt.clf()\n",
    "        plt.title('Training...')\n",
    "    plt.xlabel('Episode')\n",
    "    plt.ylabel('Duration')\n",
    "    plt.plot(durations_t.numpy())\n",
    "    # Take 100 episode averages and plot them too\n",
    "    if len(durations_t) >= 100:\n",
    "        means = durations_t.unfold(0, 100, 1).mean(1).view(-1)\n",
    "        means = torch.cat((torch.zeros(99), means))\n",
    "        plt.plot(means.numpy())\n",
    "\n",
    "    plt.pause(0.001)  # pause a bit so that plots are updated\n",
    "    if is_ipython:\n",
    "        if not show_result:\n",
    "            display.display(plt.gcf())\n",
    "            display.clear_output(wait=True)\n",
    "        else:\n",
    "            display.display(plt.gcf())\n",
    "\n",
    "def cal_cost(s):\n",
    "    c1=np.array([3,3])\n",
    "    c2=np.array([7,7])\n",
    "    d1=np.linalg.norm(s-c1)\n",
    "    d2=np.linalg.norm(s-c2)\n",
    "    return max(4-2*d1,4-2*d2,0)\n",
    "\n",
    "def cal_reward(s):\n",
    "    end=10*np.ones(2)\n",
    "    dist=np.linalg.norm(s-end)\n",
    "    if dist<1:\n",
    "        return 10*(1-dist)\n",
    "    else:\n",
    "        return 0\n",
    "def not_same_data(i_episode,epi_len,X_train,obs):\n",
    "    for i in range(i_episode+1):\n",
    "        for j in range(int(epi_len[i])):\n",
    "            if np.linalg.norm(X_train[i,j]-obs)<1e-6:\n",
    "                return False\n",
    "    return True\n",
    "def env_step(state,action,t):\n",
    "    \n",
    "    next_state=np.copy(state)\n",
    "    dist=np.random.uniform(move_lb,move_ub,1)\n",
    "    if action == LEFT:\n",
    "        next_state[0] = max(state[0] - dist, Lbd)\n",
    "    elif action == DOWN:\n",
    "        next_state[1] = max(state[1] - dist, Dbd)\n",
    "    elif action == RIGHT:\n",
    "        next_state[0] = min(state[0] + dist, Rbd)\n",
    "    elif action == UP:\n",
    "        next_state[1] = min(state[1] + dist, Ubd)\n",
    "\n",
    "    reward=cal_reward(state)\n",
    "    cost=cal_cost(next_state)\n",
    "    if next_state[0]==Rbd and next_state[1]==Ubd:\n",
    "        truncated=True\n",
    "    elif t>T:\n",
    "        truncated=True\n",
    "    else:  truncated=False\n",
    "\n",
    "    return next_state,reward,cost,False,truncated\n",
    "def result_route():\n",
    "    steps_done=10000\n",
    "    result_episode=np.zeros((T,7))\n",
    "    state=np.zeros(2)\n",
    "    # result_episode[0,0:2]=np.copy(state)\n",
    "    state = torch.tensor(state, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "    for t in range(T):\n",
    "        action,steps_done = select_action(state,steps_done)\n",
    "        #action = select_safe_action(state,model)\n",
    "        observation, reward, cost, terminated, truncated = env_step(state.numpy()[0],action.numpy()[0][0],t) #change\n",
    "        reward = torch.tensor([reward], device=device)\n",
    "        cost=torch.tensor([cost], device=device)\n",
    "        result_episode[t,0:2]=np.copy(state.numpy()[0])\n",
    "        result_episode[t,2]=action.numpy()[0][0]\n",
    "        result_episode[t,3:5]=np.copy(observation)\n",
    "        result_episode[t,5]=reward\n",
    "        result_episode[t,6]=cost\n",
    "        next_state = torch.tensor(observation, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "        state = next_state\n",
    "    return result_episode\n",
    "\n",
    "def result_safe_route(mean,cov):\n",
    "    result_episode=np.zeros((T,7))\n",
    "    state=np.zeros(2)\n",
    "    steps_safe_done=10000\n",
    "    # result_episode[0,0:2]=np.copy(state)\n",
    "    state = torch.tensor(state, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "    for t in range(T):\n",
    "        action, steps_safe_done= select_safe_action(state,mean,cov,steps_safe_done)\n",
    "        observation, reward, cost, terminated, truncated = env_step(state.numpy()[0],action.numpy()[0][0],t) #change\n",
    "        result_episode[t,0:2]=np.copy(state.numpy()[0])\n",
    "        result_episode[t,2]=action.numpy()[0][0]\n",
    "        result_episode[t,3:5]=np.copy(observation)\n",
    "        result_episode[t,5]=reward\n",
    "        result_episode[t,6]=cost\n",
    "        next_state = torch.tensor(observation, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "        state = next_state\n",
    "    return result_episode\n",
    "def gauss_fit(mu_input,cov_input,data_block,n_visit_block):\n",
    "    mu=np.copy(mu_input)\n",
    "    cov=np.copy(cov_input)\n",
    "    new_mu=np.zeros((nrow,ncol))\n",
    "    new_cov=np.zeros((nrow,ncol,nrow,ncol))\n",
    "\n",
    "    # for s in initial_gauss_set:\n",
    "    #     visit_set[to_row_col(s)[0],to_row_col(s)[1]]=1\n",
    "    for row in range(nrow):\n",
    "        for col in range(ncol):\n",
    "            if  n_visit_block[row,col]>0:\n",
    "                y=np.copy(data_block[row,col])\n",
    "                new_mu=mu+cov[:,:,row,col]/(cov[row,col,row,col]+sigma_noise)*(y-mu[row,col])\n",
    "                new_mu[row,col]=np.copy(y)\n",
    "                for j1 in range(nrow):\n",
    "                    for k1 in range(ncol):\n",
    "                        for j2 in range(nrow):\n",
    "                            for k2 in range(ncol):\n",
    "                                new_cov[j1,k1,j2,k2]=cov[j1,k1,j2,k2]-cov[j1,k1,row,col]*cov[j2,k2,row,col]/(cov[row,col,row,col]+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",
    "def optimize_model():\n",
    "    if len(memory) < BATCH_SIZE:\n",
    "        return\n",
    "    transitions = memory.sample(BATCH_SIZE)\n",
    "    # Transpose the batch (see https://stackoverflow.com/a/19343/3343043 for\n",
    "    # detailed explanation). This converts batch-array of Transitions\n",
    "    # to Transition of batch-arrays.\n",
    "    batch = Transition(*zip(*transitions))\n",
    "\n",
    "    # Compute a mask of non-final states and concatenate the batch elements\n",
    "    # (a final state would've been the one after which simulation ended)\n",
    "    non_final_mask = torch.tensor(tuple(map(lambda s: s is not None,\n",
    "                                          batch.next_state)), device=device, dtype=torch.bool)\n",
    "    non_final_next_states = torch.cat([s for s in batch.next_state\n",
    "                                                if s is not None])\n",
    "    state_batch = torch.cat(batch.state)\n",
    "    action_batch = torch.cat(batch.action)\n",
    "    reward_batch = torch.cat(batch.reward)\n",
    "    cost_batch = torch.cat(batch.cost)\n",
    "    # Compute Q(s_t, a) - the model computes Q(s_t), then we select the\n",
    "    # columns of actions taken. These are the actions which would've been taken\n",
    "    # for each batch state according to policy_net\n",
    "    state_action_values = policy_net(state_batch).gather(1, action_batch)\n",
    "\n",
    "    # Compute V(s_{t+1}) for all next states.\n",
    "    # Expected values of actions for non_final_next_states are computed based\n",
    "    # on the \"older\" target_net; selecting their best reward with max(1).values\n",
    "    # This is merged based on the mask, such that we'll have either the expected\n",
    "    # state value or 0 in case the state was final.\n",
    "    next_state_values = torch.zeros(BATCH_SIZE, device=device)\n",
    "    with torch.no_grad():\n",
    "        next_state_values[non_final_mask] = target_net(non_final_next_states).max(1).values\n",
    "    # Compute the expected Q values\n",
    "    expected_state_action_values = (next_state_values * GAMMA) + reward_batch\n",
    "\n",
    "    # Compute Huber loss\n",
    "    criterion = nn.SmoothL1Loss()\n",
    "    loss = criterion(state_action_values, expected_state_action_values.unsqueeze(1))\n",
    "\n",
    "    # Optimize the model\n",
    "    optimizer.zero_grad()\n",
    "    loss.backward()\n",
    "    # In-place gradient clipping\n",
    "    torch.nn.utils.clip_grad_value_(policy_net.parameters(), 100)\n",
    "    optimizer.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "07e1fd37",
   "metadata": {},
   "outputs": [],
   "source": [
    "def one_rep():\n",
    "    policy_net = DQN(n_observations, n_actions).to(device)\n",
    "    target_net = DQN(n_observations, n_actions).to(device)\n",
    "    target_net.load_state_dict(policy_net.state_dict())\n",
    "    optimizer = optim.AdamW(policy_net.parameters(), lr=LR, amsgrad=True)\n",
    "    memory = ReplayMemory(10000)\n",
    "    \n",
    "    steps_done = 0\n",
    "    steps_safe_done=0\n",
    "    total_cost=np.zeros(num_episodes)\n",
    "\n",
    "    # GPmodel = GaussianProcessNN(input_dim, hidden_dim, latent_dim)\n",
    "    kernel = RBF(length_scale=5,length_scale_bounds=(1e-2, 1e6)) #+ WhiteKernel(noise_level=0.1)\n",
    "    gp = GaussianProcessRegressor(kernel=kernel, n_restarts_optimizer=10)\n",
    "    X_train=np.zeros((num_episodes,T,2))\n",
    "    Y_train=np.zeros((num_episodes,T))\n",
    "    epi_len=np.zeros(num_episodes)\n",
    "    epi_violation=np.zeros(num_episodes)\n",
    "    # scaler = StandardScaler()\n",
    "    n_visit_block=np.zeros((num_episodes,nrow,ncol))\n",
    "    data_block=np.zeros((num_episodes,nrow,ncol))\n",
    "    mean_block=np.zeros((num_episodes+1,nrow,ncol))\n",
    "    cov_block=np.zeros((num_episodes+1,nrow,ncol,nrow,ncol))\n",
    "    mean_initial=np.zeros((nrow,ncol))\n",
    "    for  i1 in range(nrow):\n",
    "        for j1 in range(ncol):\n",
    "            for  i2 in range(nrow):\n",
    "                for j2 in range(ncol):\n",
    "                    cov_block[0,i1,j1,i2,j2]=np.exp(-(i1-i2)**2/50-(j1-j2)**2/50)\n",
    "    for i_episode in range(num_episodes):\n",
    "        # Initialize the environment and get its state\n",
    "        state=np.zeros(2)\n",
    "        state = torch.tensor(state, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "        if i_episode==0:\n",
    "            for t in range(T):\n",
    "                if Method==1 and epi_violation[i_episode]>1.5:\n",
    "                    break\n",
    "                action ,steps_done= select_action(state,steps_done)\n",
    "                observation, reward, cost, terminated, truncated = env_step(state.numpy()[0],action.numpy()[0][0],t) #change\n",
    "                if cost>cost_threshold:\n",
    "                    epi_violation[i_episode]+=1\n",
    "                    total_cost[i_episode]+=cost\n",
    "                reward = torch.tensor([reward-25*cost], device=device)\n",
    "                cost=torch.tensor([cost], device=device)\n",
    "\n",
    "                done = terminated or truncated\n",
    "                if not_same_data(i_episode,epi_len,X_train,observation):\n",
    "                    X_train[i_episode, int(epi_len[i_episode])]=np.copy(observation)\n",
    "                    Y_train[i_episode, int(epi_len[i_episode])]=cost\n",
    "                    epi_len[i_episode]=epi_len[i_episode]+1\n",
    "                row,col=state_to_block(observation)\n",
    "                data_block[i_episode,row,col]=data_block[i_episode,row,col]*n_visit_block[i_episode,row,col]+cost\n",
    "                n_visit_block[i_episode,row,col]+=1\n",
    "                data_block[i_episode,row,col]=data_block[i_episode,row,col]/n_visit_block[i_episode,row,col]\n",
    "                \n",
    "                if terminated:\n",
    "                    next_state = None\n",
    "                else:\n",
    "                    next_state = torch.tensor(observation, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "                # Store the transition in memory\n",
    "                memory.push(state, action, next_state, reward,cost)\n",
    "                # Move to the next state\n",
    "                state = next_state\n",
    "                # Perform one step of the optimization (on the policy network)\n",
    "                optimize_model()\n",
    "                # Soft update of the target network's weights\n",
    "                # theta′ ← τ theta + (1 −τ )theta′\n",
    "                target_net_state_dict = target_net.state_dict()\n",
    "                policy_net_state_dict = policy_net.state_dict()\n",
    "                for key in policy_net_state_dict:\n",
    "                    target_net_state_dict[key] = policy_net_state_dict[key]*TAU + target_net_state_dict[key]*(1-TAU)\n",
    "                target_net.load_state_dict(target_net_state_dict)\n",
    "\n",
    "                if done:\n",
    "                    episode_durations.append(t + 1)\n",
    "                    plot_durations()\n",
    "                    break\n",
    "            # X=np.copy(X_train[i_episode,0:int(epi_len[i_episode])])\n",
    "            # Y=np.copy(Y_train[i_episode,0:int(epi_len[i_episode])])\n",
    "            # X = scaler.fit_transform(X)\n",
    "        else:\n",
    "            for t in range(T):\n",
    "                if Method==1 and epi_violation[i_episode]>1.5:\n",
    "                    break\n",
    "                if Method==0:\n",
    "                    action,steps_done = select_action(state,steps_done)\n",
    "                elif Method==1:\n",
    "                    action ,steps_safe_done= select_safe_action(state,mean_block[i_episode],cov_block[i_episode],steps_safe_done)\n",
    "                    # possible_action=np.ones(4)\n",
    "                    # for i in range(4):\n",
    "                    #     if test_safe_action(state.numpy()[0],i,gp)!=True:\n",
    "                    #         possible_action[i]=0\n",
    "                    # if np.sum(possible_action)==0:\n",
    "                    #     with torch.no_grad():\n",
    "                    #     action=policy_net(state).max(1).indices.view(1, 1)\n",
    "                #     else:\n",
    "                #         a=np.random.choice(4,size=1,p=possible_action/np.sum(possible_action))[0]\n",
    "                #         action=torch.tensor([[a]], device=device, dtype=torch.long)# change\n",
    "                observation, reward, cost, terminated, truncated = env_step(state.numpy()[0],action.numpy()[0][0],t) #change\n",
    "                if cost>cost_threshold:\n",
    "                    epi_violation[i_episode]+=1\n",
    "                    total_cost[i_episode]+=cost\n",
    "                #reward = torch.tensor([reward], device=device)\n",
    "                \n",
    "                reward = torch.tensor([reward-25*cost], device=device)\n",
    "                cost=torch.tensor([cost], device=device)\n",
    "\n",
    "                done = terminated or truncated\n",
    "                if not_same_data(i_episode,epi_len,X_train,observation):\n",
    "                    X_train[i_episode, int(epi_len[i_episode])]=np.copy(observation)\n",
    "                    Y_train[i_episode, int(epi_len[i_episode])]=cost\n",
    "                    epi_len[i_episode]+=1\n",
    "                row,col=state_to_block(observation)\n",
    "                data_block[i_episode,row,col]=data_block[i_episode,row,col]*n_visit_block[i_episode,row,col]+cost\n",
    "                n_visit_block[i_episode,row,col]+=1\n",
    "                data_block[i_episode,row,col]=data_block[i_episode,row,col]/n_visit_block[i_episode,row,col]\n",
    "                if terminated:\n",
    "                    next_state = None\n",
    "                else:\n",
    "                    next_state = torch.tensor(observation, dtype=torch.float32, device=device).unsqueeze(0)\n",
    "                # Store the transition in memory\n",
    "                memory.push(state, action, next_state, reward,cost)\n",
    "                # Move to the next state\n",
    "                state = next_state\n",
    "                # Perform one step of the optimization (on the policy network)\n",
    "                optimize_model()\n",
    "                # Soft update of the target network's weights\n",
    "                # theta′ ← τ theta + (1 −τ )theta′\n",
    "                target_net_state_dict = target_net.state_dict()\n",
    "                policy_net_state_dict = policy_net.state_dict()\n",
    "                for key in policy_net_state_dict:\n",
    "                    target_net_state_dict[key] = policy_net_state_dict[key]*TAU + target_net_state_dict[key]*(1-TAU)\n",
    "                target_net.load_state_dict(target_net_state_dict)\n",
    "\n",
    "                if done:\n",
    "                    episode_durations.append(t + 1)\n",
    "                    plot_durations()\n",
    "                    break\n",
    "        new_mu,new_cov=gauss_fit(mean_block[i_episode],cov_block[i_episode],data_block[i_episode],n_visit_block[i_episode])\n",
    "        mean_block[i_episode+1]=np.copy(new_mu)\n",
    "        cov_block[i_episode+1]=np.copy(new_cov)\n",
    "        \n",
    "    return np.sum(epi_violation),np.sum(epi_len),new_mu,new_cov"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "8339fd42",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_multi_rep=10\n",
    "# num_episodes = 20\n",
    "total_violation_multi=np.zeros(num_multi_rep)\n",
    "total_data_number_multi=np.zeros(num_multi_rep)\n",
    "mu_multi=np.zeros((num_multi_rep,nrow,ncol))\n",
    "cov_multi=np.zeros((num_multi_rep,nrow,ncol,nrow,ncol))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ecb6588",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(0)\n",
    "mul_calls = [delayed(one_rep)() for rep in range(num_multi_rep)]\n",
    "result_mul_delayed = Parallel(n_jobs=-3)(mul_calls)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "30b0a4aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(num_multi_rep):\n",
    "    total_violation_multi[i]=np.copy(result_mul_delayed[i][0])\n",
    "    total_data_number_multi[i]=np.copy(result_mul_delayed[i][1])\n",
    "    mu_multi[i]=np.copy(result_mul_delayed[i][2])\n",
    "    cov_multi[i]=np.copy(result_mul_delayed[i][3])\n",
    "vio_rate_multi=total_violation_multi/total_data_number_multi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "d309ea07",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.02238412, 0.0165499 , 0.02249364, 0.02176124, 0.01863807,\n",
       "        0.02272727, 0.0169951 , 0.02051174, 0.02117141, 0.01865937]),\n",
       " 0.020189185295453143,\n",
       " 4.8303158475861796e-06)"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vio_rate_multi,np.mean(vio_rate_multi),np.var(vio_rate_multi)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "f0776173",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_episode=result_safe_route(mu_multi[0],cov_multi[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "86669ff5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "# 定义圆的参数\n",
    "circles = [\n",
    "    (3, 3, 2),  \n",
    "    (7, 7, 2),   \n",
    "    # (10, 10, 1) \n",
    "]\n",
    "\n",
    "# 绘制圆\n",
    "for x, y, radius in circles:\n",
    "    circle = plt.Circle((x, y), radius, edgecolor='blue', fill=False, linewidth=2)\n",
    "    ax.add_patch(circle)\n",
    "\n",
    "circle = plt.Circle((10, 10), 1, edgecolor='green', fill=False, linewidth=2)\n",
    "ax.add_patch(circle)\n",
    "\n",
    "# 设置坐标范围和比例\n",
    "ax.set_xlim(0, 10)\n",
    "ax.set_ylim(0, 10)\n",
    "ax.set_aspect('equal')\n",
    "\n",
    "# 设置标题和坐标轴标签\n",
    "ax.set_title(\"Circles with Centers (3,3) and (7,7), Radius 2\")\n",
    "ax.set_xlabel(\"X-axis\")\n",
    "ax.set_ylabel(\"Y-axis\")\n",
    "plt.plot(result_episode[:,0], result_episode[:,1], marker='o', label='y = x^2')\n",
    "#plt.plot(X_train.reshape(num_episodes*T,2)[:,0], X_train.reshape(num_episodes*T,2)[:,1], 'go')\n",
    "# 显示图像\n",
    "plt.grid(True)  # 添加网格\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "4c0580b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAakAAAHHCAYAAAAF0qdxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAACioklEQVR4nOydd3xT1fvH3zdpmu5JF3uPMmXLEJClyHDgHuDAAQ7060B/TsS9cG/FhQtRcYCAikzZILvs3b1X2ib398dpVpO0aZs2TXver1fg3HPXk9ub+7nnOc95jqKqqopEIpFIJA0QjbcNkEgkEonEFVKkJBKJRNJgkSIlkUgkkgaLFCmJRCKRNFikSEkkEomkwSJFSiKRSCQNFilSEolEImmwSJGSSCQSSYNFipREIpFIGiw+L1Jt27Zl+vTpHjve9OnTadu2rceOV1ccO3YMRVFYsGCB29u+/PLLdW9YE+TFF1+ka9eumEymej/3e++9R+vWrTEYDPV+7sqozv0J8N133xEVFUV+fn7dGuaEOXPmMGjQoHo/b01xdm2ffPJJFEXxnlF1SIMVqcOHD3PbbbfRvn17AgICCAsLY+jQobz++usUFRV527wGye+//86TTz5ZZ8dPSUnh/vvvp2vXrgQFBREcHEy/fv2YN28e2dnZdXbewsJCnnzySVatWlVn56gpubm5vPDCCzz00ENoNNaf07333kvfvn2JiooiKCiIbt268eSTT7r9EHZ3/+nTp1NSUsL777/v0e9VnxiNRp544gnuuusuQkJCAOuD2NVnxowZlR5z1apVle7/zDPPWLadPXs2O3fuZMmSJTX+DgsWLLA7vp+fHy1atGD69OmcPn26xsdtyGzevJk777yT7t27ExwcTOvWrbniiitISkry6Hn8PHo0D/Hbb79x+eWXo9frueGGG+jRowclJSWsXbuWBx54gD179vDBBx8AcODAAbuHQ1OhTZs2FBUVodPpLHW///47b7/9dp0I1ebNm5kwYQL5+flcd9119OvXD4AtW7bw/PPPs3r1apYvX+7x84IQqaeeegqAkSNH1sk5asonn3xCWVkZV199tV395s2bGT58ODfeeCMBAQFs376d559/npUrV7J69eoq71l39w8ICGDatGm8+uqr3HXXXT75Nv3LL79w4MABbr31VktdTEwMX3zxhcO2y5Yt46uvvmLcuHGVHrNbt25O9//iiy9Yvny53f7x8fFMmTKFl19+mcmTJ9fim8DcuXNp164dxcXF/PvvvyxYsIC1a9eye/duAgICanXsynj00UeZM2dOnR3fGS+88ALr1q3j8ssvp1evXiQnJ/PWW2/Rt29f/v33X3r06OGZE6kNjCNHjqghISFq165d1TNnzjisP3jwoDp//vxqHTM/P9/tbadNm6a2adOmWsdvKMyaNUt19ic9evSoCqgvvfRSjY6blZWltmjRQo2Li1P37dvnsD45OVl9+umna3Rsd0hLS1MB9YknnvDocatzX7iiV69e6nXXXefWti+//LIKqBs2bKjRuVztv2XLFhVQ//zzzxodty4w33OffvppldtOnjxZHTZsmFvHHT16tBoWFqYWFRXVyK6OHTuqnTp1cqhftGiRqiiKevjw4Rod99NPP1UBdfPmzXb1Dz30kAqo3377bY2O64zqXNu6ZN26darBYLCrS0pKUvV6vXrttdd67DwNrgny4osvkp+fz8cff0xCQoLD+o4dO3LPPfdYliv2SZmb3f/88w8zZ84kNjaWli1bWtYvXbqUESNGEBoaSlhYGAMGDGDhwoWV2mQymZg/fz7du3cnICCAuLg4brvtNrKysuy227JlC+PHj6dZs2YEBgbSrl07brrppkqPfd999xEdHY1qk4ze/Eb8xhtvWOpSUlJQFIV3330XcPRLT58+nbfffhvAzu1QkQ8++IAOHTqg1+sZMGAAmzdvrtQ+gPfff5/Tp0/z6quv0rVrV4f1cXFxPProo3Z1S5cuZfjw4QQHBxMaGspFF13Enj177LaZPn06ISEhnD59mosvvpiQkBBiYmK4//77MRqNlu8ZExMDwFNPPWX5Xratxf379zN16lSioqIICAigf//+Dq6byu6LvLw8Zs+eTdu2bdHr9cTGxjJ27Fi2bdtW6XU5evQo//33H2PGjKnyGgKWvs6aukZd7d+vXz+ioqL4+eefqzzGmjVruPzyy2ndujV6vZ5WrVpx7733OrjQ3fnbmMnOzmb69OmEh4cTERHBtGnT3P6OxcXFLFu2zK1rePbsWf7++28uvfTSGrVKNm3axKFDh7j22msd1pnP7841rA7Dhw8HRPeFmZKSEh5//HH69etHeHg4wcHBDB8+nL///tthf3evbcU+qcr6BCv+fmp6/w8ZMgR/f3+7uk6dOtG9e3f27dtX6b7VocG5+3755Rfat2/PkCFDanWcmTNnEhMTw+OPP05BQQEgHlQ33XQT3bt35+GHHyYiIoLt27ezbNkyrrnmGpfHuu2221iwYAE33ngjd999N0ePHuWtt95i+/btrFu3Dp1OR2pqKuPGjSMmJoY5c+YQERHBsWPHWLx4caV2Dh8+nNdee409e/ZYmsdr1qxBo9GwZs0a7r77bksdwHnnnefSxjNnzrBixQqnbg6AhQsXkpeXx2233YaiKLz44otceumlHDlyxM5tWJElS5YQGBjI1KlTK/0uZr744gumTZvG+PHjeeGFFygsLOTdd99l2LBhbN++3S4wxWg0Mn78eAYNGsTLL7/MypUreeWVV+jQoQN33HEHMTExvPvuu9xxxx1ccsklXHrppQD06tULgD179jB06FBatGjBnDlzCA4O5rvvvuPiiy/mhx9+4JJLLrGzzdl9cfvtt7No0SLuvPNOEhMTycjIYO3atezbt4++ffu6/J7r168HcLlNWVkZ2dnZlJSUsHv3bh599FFCQ0MZOHCgW9exOvv37duXdevWVXnM77//nsLCQu644w6io6PZtGkTb775JqdOneL777+327aqvw2AqqpMmTKFtWvXcvvtt9OtWzd+/PFHpk2b5tZ33Lp1KyUlJZVeZzPffPMNJpPJqci4w1dffQXgdP/w8HA6dOjAunXruPfee2t0fGccO3YMgMjISEtdbm4uH330EVdffTUzZswgLy+Pjz/+mPHjx7Np0yb69OkD1P7auktN739nqKpKSkoK3bt395yBHmuTeYCcnBwVUKdMmeL2Pm3atFGnTZtmWTY3u4cNG6aWlZVZ6rOzs9XQ0FB10KBBDq4Ck8lkKVd0961Zs0YF1K+++spun2XLltnV//jjj06b+1WRmpqqAuo777xjsVOj0aiXX365GhcXZ9nu7rvvVqOioiy2OmvyV+Xui46OVjMzMy31P//8swqov/zyS6U2RkZGqr1793br++Tl5akRERHqjBkz7OqTk5PV8PBwu/pp06apgDp37ly7bc855xy1X79+luXK3H2jR49We/bsqRYXF1vqTCaTOmTIEDu3jqv7QlVVNTw8XJ01a5Zb38+WRx99VAXUvLw8p+s3bNigApZPly5d1L///tvt41dn/1tvvVUNDAys8piFhYUOdc8995yqKIp6/Phx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YIdWSEWCg4OBmoc4u+L2228nISGB//3vf05Hk6empjJv3jwAxo8fT1hYGM8++6zTvrm0tLRqnz8oKAhw/F6xsbGMHDmS999/n7Nnz9boXEaj0eGhHxsbS/Pmzav8u5lforZs2WJXn52d7fS7f/TRRwCWN21X1GT/bdu2VRkRa24Z2d6nqqrW6PdkZsKECZSVlVmGRoC4pm+++aZb+/fr1w9/f3+Ha2iLeYhITd3dCxcuJCgoyCHS05acnBwOHz5c66jiiowcOZKBAwcyf/58y3PH2d9h48aNbNiwwW7f2lzbsLAwmjVrZunrNvPOO+/YLdfm/jcajVx55ZVs2LCB77//3qONClsaXEuqQ4cOLFy4kCuvvJJu3brZZZxYv34933//fY1y9YWFhfHaa69xyy23MGDAAK655hoiIyPZuXMnhYWFfPbZZ073GzFiBLfddhvPPfccO3bsYNy4ceh0Og4ePMj333/P66+/ztSpU/nss8945513uOSSS+jQoQN5eXl8+OGHhIWFMWHChCrtGz58ON988w09e/a0vAX17duX4OBgkpKS3PqBmltad999N+PHj0er1XLVVVdV4yo5JzIykh9//JEJEybQp08fu4wT27Zt4+uvv7bcoGFhYbz77rtcf/319O3bl6uuuoqYmBhOnDjBb7/9xtChQ3nrrbeqdf7AwEASExP59ttv6dy5M1FRUfTo0YMePXrw9ttvM2zYMHr27MmMGTNo3749KSkpbNiwgVOnTrFz585Kj52Xl0fLli2ZOnUqvXv3JiQkhJUrV7J582ZeeeWVSvdt3749PXr0YOXKlXbj4VatWsXdd9/N1KlT6dSpEyUlJaxZs4bFixfTv39/rrvuOrvjKIrCiBEjLGmfqrv/1q1byczMZMqUKZXa27VrVzp06MD999/P6dOnCQsL44cffnCr/88VkyZNYujQocyZM4djx46RmJjI4sWL3W4tBgQEMG7cOFauXOm0pWQ0Gvn2228ZPHiwpZXujIrX0ExmZiZLly7lsssuq9TlvnLlSkvIty3Tp0/ns88+4+jRozXO6fnAAw9w+eWXs2DBAm6//XYmTpzI4sWLueSSS7jooos4evQo7733HomJiXaBMbW9trfccgvPP/88t9xyC/3792f16tUOL5m1uf//97//sWTJEiZNmkRmZiZffvml3fqK92mN8VicoIdJ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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "# 定义圆的参数\n",
    "circles = [\n",
    "    (3, 3, 2),  \n",
    "    (7, 7, 2),   \n",
    "    # (10, 10, 1) \n",
    "]\n",
    "\n",
    "# 绘制圆\n",
    "for x, y, radius in circles:\n",
    "    circle = plt.Circle((x, y), radius, edgecolor='blue', fill=False, linewidth=2)\n",
    "    ax.add_patch(circle)\n",
    "\n",
    "circle = plt.Circle((10, 10), 1, edgecolor='green', fill=False, linewidth=2)\n",
    "ax.add_patch(circle)\n",
    "\n",
    "# 设置坐标范围和比例\n",
    "ax.set_xlim(0, 10)\n",
    "ax.set_ylim(0, 10)\n",
    "ax.set_aspect('equal')\n",
    "\n",
    "# 设置标题和坐标轴标签\n",
    "ax.set_title(\"Circles with Centers (3,3) and (7,7), Radius 2\")\n",
    "ax.set_xlabel(\"X-axis\")\n",
    "for i in range(num_multi_rep):\n",
    "    result_episode=result_safe_route(mu_multi[i],cov_multi[i])\n",
    "    plt.plot(result_episode[:,0], result_episode[:,1], marker='o', label='y = x^2')\n",
    "#plt.plot(X_train.reshape(num_episodes*T,2)[:,0], X_train.reshape(num_episodes*T,2)[:,1], 'go')\n",
    "# 显示图像\n",
    "plt.grid(True)  # 添加网格\n",
    "plt.show()"
   ]
  }
 ],
 "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": 5
}
