{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6da8ab6d-b602-496c-968e-948d3d5dbcdb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gymnasium as gym\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import stable_baselines3\n",
    "import time\n",
    "from utils import set_size\n",
    "from utils import linestyle_tuple\n",
    "from utils import load_csv\n",
    "from stable_baselines3 import PPO\n",
    "from stable_baselines3 import SAC\n",
    "from stable_baselines3.common.env_checker import check_env\n",
    "from stable_baselines3.common.callbacks import CheckpointCallback\n",
    "import pde_control_gym\n",
    "from pde_control_gym.src import TunedReward1D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "307a8313-126e-479f-b94c-69dbf2188e70",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Print Versioning\n",
    "print(\"Gym version\", gym.__version__)\n",
    "print(\"Numpy version\", np.__version__)\n",
    "print(\"Stable Baselines3 version\", stable_baselines3.__version__)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec9efd4f-b0e3-4c70-9c15-6e677066c310",
   "metadata": {},
   "source": [
    "Helper Functions for the Environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32177259-8979-4957-baf5-e8f15c9c563e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# NO NOISE\n",
    "def noiseFunc(state):\n",
    "    return state\n",
    "\n",
    "# Chebyshev Polynomial Beta Functions\n",
    "def solveBetaFunction(x, gamma):\n",
    "    beta = np.zeros(len(x), dtype=np.float32)\n",
    "    for idx, val in enumerate(x):\n",
    "        beta[idx] = 50*math.cos(gamma*math.acos(val))\n",
    "    return beta\n",
    "\n",
    "# Kernel function solver for backstepping\n",
    "def solveKernelFunction(beta):\n",
    "    k = np.zeros((len(beta), len(beta)))\n",
    "    # First we calculate a at each timestep\n",
    "    a = beta\n",
    "\n",
    "    # FD LOOP\n",
    "    k[1][1] = -(a[1] + a[0]) * dx / 4\n",
    "    for i in range(1, len(beta)-1):\n",
    "        k[i+1][0] = 0\n",
    "        k[i+1][i+1] = k[i][i]-dx/4.0*(a[i-1] + a[i])\n",
    "        k[i+1][i] = k[i][i] - dx/2 * a[i]\n",
    "        for j in range(1, i):\n",
    "                k[i+1][j] = -k[i-1][j] + k[i][j+1] + k[i][j-1] + a[j]*(dx**2)*(k[i][j+1]+k[i][j-1])/2\n",
    "    return k\n",
    "\n",
    "# Control convolution solver\n",
    "def solveControl(kernel, u):\n",
    "    return sum(kernel[-1][0:len(u)-1]*u[0:len(u)-1])*dx\n",
    "\n",
    "# Set initial condition function here\n",
    "def getInitialCondition(nx):\n",
    "    return np.ones(nx+1)*np.random.uniform(1, 10)\n",
    "\n",
    "# Returns beta functions passed into PDE environment. Currently gamma is always\n",
    "# set to 8, but this can be modified for further problems\n",
    "def getBetaFunction(nx):\n",
    "    return solveBetaFunction(np.linspace(0, 1, nx+1), 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da1f129a-e88d-48d1-96ba-da0c85abda38",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Timestep and spatial step for PDE Solver\n",
    "T = 1\n",
    "dt = 1e-5\n",
    "dx = 5e-3\n",
    "X = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ac9fc8b-2b8f-4e1b-a46b-64222b995b65",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Backstepping does not need to normalize actions to be between -1 and 1, so normalize is set to False. Otherwise, \n",
    "# parameters are same as RL algorithms\n",
    "parabolicParameters = {\n",
    "        \"T\": T, \n",
    "        \"dt\": dt, \n",
    "        \"X\": X,\n",
    "        \"dx\": dx, \n",
    "        \"reward_class\": TunedReward1D(int(round(T/dt)), -1e3, 3e2),\n",
    "        \"normalize\": None,\n",
    "        \"sensing_loc\": \"full\", \n",
    "        \"control_type\": \"Dirchilet\", \n",
    "        \"sensing_type\": None,\n",
    "        \"sensing_noise_func\": lambda state: state,\n",
    "        \"limit_pde_state_size\": True,\n",
    "        \"max_state_value\": 1e10,\n",
    "        \"max_control_value\": 20,\n",
    "        \"reset_init_condition_func\": getInitialCondition,\n",
    "        \"reset_recirculation_func\": getBetaFunction,\n",
    "        \"control_sample_rate\": 0.001,\n",
    "}\n",
    "\n",
    "parabolicParametersBackstepping = parabolicParameters.copy()\n",
    "parabolicParametersBackstepping[\"normalize\"] = False\n",
    "\n",
    "parabolicParametersRL = parabolicParameters.copy()\n",
    "parabolicParametersRL[\"normalize\"] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8f53c44-2173-4da4-bbad-387f37f640e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Make environments\n",
    "envRL = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersRL)\n",
    "envBcks = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBackstepping)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf23d021-501d-4ca7-a507-8c1c2d93aa1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save a checkpoint every 10000 steps\n",
    "checkpoint_callback = CheckpointCallback(\n",
    "  save_freq=10000,\n",
    "  save_path=\"./logsPPO\",\n",
    "  name_prefix=\"rl_model\",\n",
    "  save_replay_buffer=True,\n",
    "  save_vecnormalize=True,\n",
    ")\n",
    "\n",
    "# TRAINING. SKIP IF WANT TO USE PRELOADED MODELS\n",
    "# Train PPO\n",
    "model = PPO(\"MlpPolicy\",envRL, verbose=1, tensorboard_log=\"./tb/\")\n",
    "# Train for 500k timesteps\n",
    "#model.learn(total_timesteps=5e5, callback=checkpoint_callback)\n",
    "\n",
    "# Train SAC\n",
    "model = SAC(\"MlpPolicy\",envRL, verbose=1, tensorboard_log=\"./tb/\")\n",
    "# Train for 500k timesteps\n",
    "# model.learn(total_timesteps=5e5, callback=checkpoint_callback)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cad8d344-d209-49c7-a629-dcb72a0d1815",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Visualize Rewards\n",
    "\n",
    "# In TensorBoard, save the avg rewards plot as a csv and then put their paths here\n",
    "# Set your tensorboard avg_rew paths. WILL NEED UPDATING\n",
    "filenamesPPO = [\"PPOData/PPO_17.csv\", \"PPOData/PPO_18.csv\", \"PPOData/PPO_19.csv\", \"PPOData/PPO_20.csv\", \"PPOData/PPO_21.csv\"]\n",
    "filenamesSAC = [\"SACData/SAC_5.csv\", \"SACData/SAC_6.csv\", \"SACData/SAC_12.csv\", \"SACData/SAC_3.csv\", \"SACData/SAC_7.csv\"]\n",
    "\n",
    "timePPOArr = []\n",
    "rewardPPOArr = []\n",
    "for name in filenamesPPO:\n",
    "    times, rewards = load_csv(name)\n",
    "    timePPOArr.append(times)\n",
    "    rewardPPOArr.append(rewards)\n",
    "\n",
    "timeSACArr = []\n",
    "rewardSACArr = []\n",
    "for name in filenamesSAC:\n",
    "    times, rewards = load_csv(name)\n",
    "    timeSACArr.append(times)\n",
    "    rewardSACArr.append(rewards)\n",
    "\n",
    "# takes max amount of timesteps all data has\n",
    "maxTimestep = np.inf\n",
    "for data in timePPOArr:\n",
    "    maxTimestep = min(maxTimestep, data[-1])\n",
    "for data in timeSACArr:\n",
    "    maxTimestep = min(maxTimestep, data[-1])\n",
    "print(maxTimestep)\n",
    "\n",
    "# remove data after minTimestep\n",
    "maxDataSeqPPO = []\n",
    "for data in timePPOArr:\n",
    "    for i in range(len(data)):\n",
    "        if data[i] >= maxTimestep:\n",
    "            maxDataSeqPPO.append(i)\n",
    "            break\n",
    "maxDataSeqSAC = []\n",
    "for data in timeSACArr:\n",
    "    for i in range(len(data)):\n",
    "        if data[i] >= maxTimestep:\n",
    "            maxDataSeqSAC.append(i)\n",
    "            break\n",
    "\n",
    "# Get mean and std of each value at time step \n",
    "rewardArrCleanPPO = []\n",
    "for i, data in enumerate(rewardPPOArr):\n",
    "    rewardArrCleanPPO.append(data[:min(maxDataSeqPPO)])\n",
    "rewardArrPPO = np.array(rewardArrCleanPPO)\n",
    "meanArrPPO = rewardArrPPO.mean(axis=0)\n",
    "stdArrPPO = rewardArrPPO.std(axis=0)\n",
    "\n",
    "rewardArrCleanSAC = []\n",
    "for i, data in enumerate(rewardSACArr):\n",
    "    rewardArrCleanSAC.append(data[:min(maxDataSeqSAC)])\n",
    "rewardArrSAC = np.array(rewardArrCleanSAC)\n",
    "meanArrSAC = rewardArrSAC.mean(axis=0)\n",
    "stdArrSAC = rewardArrSAC.std(axis=0)\n",
    "\n",
    "# Set size according to latex textwidth\n",
    "fig = plt.figure(figsize=set_size(432, 0.99, (1, 1), height_add=0))\n",
    "ax = fig.subplots(ncols=1)\n",
    "t = timePPOArr[0]\n",
    "x = t[:maxDataSeqPPO[0]]\n",
    "mean = meanArrPPO\n",
    "std = stdArrPPO\n",
    "# 95 confidence interval\n",
    "cis = (mean - 2*std, mean + 2*std)\n",
    "ax.plot(x, mean, label=\"PPO\")\n",
    "ax.fill_between(x, cis[0], cis[1], alpha=0.2)\n",
    "\n",
    "t = timeSACArr[0]\n",
    "x = t[:min(maxDataSeqSAC)]\n",
    "mean = meanArrSAC\n",
    "std = stdArrSAC\n",
    "# 95 confidence interval\n",
    "cis = (mean - 2*std, mean + 2*std)\n",
    "ax.plot(x, mean, label=\"SAC\")\n",
    "ax.fill_between(x, cis[0], cis[1], alpha=0.2)\n",
    "\n",
    "plt.legend()\n",
    "plt.title(\"Training Reward for Parabolic PDE\")\n",
    "plt.xlabel(\"Episode Number\")\n",
    "plt.ylabel(\"Average Reward\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "648bd8f0-7f37-404d-bb6c-f857f0fd3802",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load RL models. # DUMMY ARGUMENTS NEED TO BE MODIFIED\n",
    "# ppoModelPath = \"parabolicModels/ppoBestModelParabolic\"\n",
    "# sacModelPath = \"parabolicModels/sacBestModelParabolic2\"\n",
    "ppoModel = PPO.load(ppoModelPath)\n",
    "sacModel = SAC.load(sacModelPath)\n",
    "\n",
    "# For backstepping controller\n",
    "spatial = np.linspace(dx, X, int(round(X/dx)))\n",
    "beta = solveBetaFunction(spatial, 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c93c80f-723e-4fc0-98a5-deeb0db023ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Runs a single epsiode calculation\n",
    "# Parameter varies. For SAC and PPO it is the model itself\n",
    "# For backstepping it is the beta function\n",
    "def runSingleEpisode(model, env, parameter):\n",
    "    terminate = False\n",
    "    truncate = False\n",
    "\n",
    "    # Holds the resulting states\n",
    "    uStorage = []\n",
    "\n",
    "    # Reset Environment\n",
    "    obs,__ = env.reset()\n",
    "    uStorage.append(obs)\n",
    "\n",
    "    i = 0\n",
    "    rew = 0\n",
    "    while not truncate and not terminate:\n",
    "        # use backstepping controller\n",
    "        action = model(obs, parameter)\n",
    "        obs, rewards, terminate, truncate, info = env.step(action)\n",
    "        uStorage.append(obs)\n",
    "        rew += rewards \n",
    "    u = np.array(uStorage)\n",
    "    return rew, u"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49278e04-7771-4a5c-9d75-0ca82a512b78",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define Controllers\n",
    "def bcksController(obs, kernel):\n",
    "    return solveControl(kernel, obs)\n",
    "\n",
    "def RLController(obs, model):\n",
    "    action, _state = model.predict(obs)\n",
    "    return action\n",
    "\n",
    "def openLoopController(_, _a):\n",
    "    return 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47c16b5c-42bb-409b-ace7-46bf5e4731f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Run comparisons\n",
    "num_instances = 50\n",
    "# Backstepping. Controller is slow so this will take some time.\n",
    "total_bcks_reward = 0\n",
    "kernel = solveKernelFunction(beta)\n",
    "for i in range(num_instances):\n",
    "    rew, _ = runSingleEpisode(bcksController, envBcks, kernel)\n",
    "    total_bcks_reward += rew\n",
    "print(\"Backstepping Reward Average:\", total_bcks_reward/num_instances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f4a6fba2-974b-4867-9f35-e51ff86f33c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# PPO\n",
    "total_ppo_reward = 0\n",
    "s = time.time()\n",
    "for i in range(num_instances):\n",
    "    rew, _ = runSingleEpisode(RLController, envRL, ppoModel)\n",
    "    total_ppo_reward += rew\n",
    "print(\"PPO Reward Average:\", total_ppo_reward/num_instances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9512075b-3361-4a79-8096-da1a1fa8d153",
   "metadata": {},
   "outputs": [],
   "source": [
    "# SAC\n",
    "total_sac_reward = 0\n",
    "for i in range(num_instances):\n",
    "    rew, _ = runSingleEpisode(RLController, envRL, sacModel)\n",
    "    total_sac_reward += rew\n",
    "print(\"SAC Reward Average:\", total_sac_reward/num_instances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6a4398e-f756-411c-9618-f445940d8867",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy\n",
    "# from tqdm import tqdm\n",
    "from tqdm import trange, tqdm\n",
    "def getInitialConditionRandom(nx):\n",
    "    return np.ones(nx+1) * (1 + np.random.rand() * 9)\n",
    "\n",
    "\n",
    "\n",
    "parabolicParametersBacksteppingRandom = parabolicParametersBackstepping.copy()\n",
    "parabolicParametersBacksteppingRandom[\"reset_init_condition_func\"] = getInitialConditionRandom\n",
    "\n",
    "\n",
    "\n",
    "parabolicParametersRLRandom = parabolicParametersRL.copy()\n",
    "parabolicParametersRLRandom[\"reset_init_condition_func\"] = getInitialConditionRandom\n",
    "\n",
    "\n",
    "# Make environments\n",
    "envBcksRandom = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingRandom)\n",
    "\n",
    "\n",
    "envRLRandom = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersRLRandom)\n",
    "\n",
    "xs_bcks = []\n",
    "ys_bcks = []\n",
    "xs_ppo = []\n",
    "ys_ppo = []\n",
    "xs_sac = []\n",
    "ys_sac = []\n",
    "xs_bcks_dense = []\n",
    "ys_bcks_dense = []\n",
    "xs_ppo_dense = []\n",
    "ys_ppo_dense = []\n",
    "xs_sac_dense = []\n",
    "ys_sac_dense = []\n",
    "for i in range(15000):\n",
    "    \n",
    "    rewBcksRandom, uBcksRandom = runSingleEpisode(bcksController, envBcksRandom, kernel)\n",
    "    xs_bcks.append((uBcksRandom.transpose()[:,::20])[-1])\n",
    "    ys_bcks.append((uBcksRandom.transpose()[:,::20])[100])\n",
    "\n",
    "    rewPPORandom, uPPORandom = runSingleEpisode(RLController, envRLRandom, ppoModel)\n",
    "    xs_ppo.append((uPPORandom.transpose()[:,::20])[-1])\n",
    "    ys_ppo.append((uPPORandom.transpose()[:,::20])[100])\n",
    "    \n",
    "\n",
    "    rewSACRandom, uSACRandom = runSingleEpisode(RLController, envRLRandom, sacModel)\n",
    "    xs_sac.append((uSACRandom.transpose()[:,::20])[-1])\n",
    "    ys_sac.append((uSACRandom.transpose()[:,::20])[100])\n",
    "    if i % 1000 == 0: print(i)\n",
    "    # xs_bcks_dense.append((uBcksRandom.transpose())[-1])\n",
    "    # ys_bcks_dense.append((uBcksRandom.transpose())[100])\n",
    "\n",
    "    # xs_ppo_dense.append((uPPORandom.transpose())[-1])\n",
    "    # ys_ppo_dense.append((uPPORandom.transpose())[100])\n",
    "\n",
    "    # xs_sac_dense.append((uSACRandom.transpose())[-1])\n",
    "    # ys_sac_dense.append((uSACRandom.transpose())[100])\n",
    "\n",
    "        \n",
    "data_bcks = {\"a\": np.stack(xs_bcks), \"u\": np.stack(ys_bcks)}\n",
    "scipy.io.savemat(\"data_bcks_parabolic_train3.mat\", data_bcks)\n",
    "\n",
    "data_ppo = {\"a\": np.stack(xs_ppo), \"u\": np.stack(ys_ppo)}\n",
    "scipy.io.savemat(\"data_ppo_parabolic_train3.mat\", data_ppo)\n",
    "\n",
    "data_sac = {\"a\": np.stack(xs_sac), \"u\": np.stack(ys_sac)}\n",
    "scipy.io.savemat(\"data_sac_parabolic_train3.mat\", data_sac)\n",
    "\n",
    "# data_bcks_dense = {\"a\": np.stack(xs_bcks_dense), \"u\": np.stack(ys_bcks_dense)}\n",
    "# scipy.io.savemat(\"data_bcks_parabolic_test_dense.mat\", data_bcks_dense)\n",
    "\n",
    "# data_ppo_dense = {\"a\": np.stack(xs_ppo_dense), \"u\": np.stack(ys_ppo_dense)}\n",
    "# scipy.io.savemat(\"data_ppo_parabolic_test_dense.mat\", data_ppo_dense)\n",
    "\n",
    "# data_sac_dense = {\"a\": np.stack(xs_sac_dense), \"u\": np.stack(ys_sac_dense)}\n",
    "# scipy.io.savemat(\"data_sac_parabolic_test_dense.mat\", data_sac_dense)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72d3dd5a-c0dc-496a-9a6e-d7f1dba7e86f",
   "metadata": {},
   "outputs": [],
   "source": [
    "RL_1000 = np.load(\"../../../verify-pde-control/parabolic_ppo_unsafe_train_100_2_0.1regpf012_dense_nonominal_mpc100.npy\")\n",
    "RL_reward_beforeQP = []\n",
    "RL_reward_afterQP = []\n",
    "uBcks_beforeQP_list = []\n",
    "uBcks_afterQP_list = []\n",
    "uBcks_beforeQP,uBcks_afterQP = 0,0\n",
    "for i in range(RL_1000[\"safe_label\"].transpose().shape[0]):\n",
    "    # if i < 1:continue\n",
    "    # if RL_1000[\"Y_nominal\"][0, i] < 2: continue\n",
    "    U_list = RL_1000[\"U_nominal\"][:, i]\n",
    "    # print(U_list[0])\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_beforeQP, uBcks_beforeQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_list)\n",
    "\n",
    "\n",
    "    U_safe_list = RL_1000[\"U_safe\"][:, i]\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_afterQP, uBcks_afterQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_safe_list)\n",
    "    # print((uBcks_afterQP.transpose())[100,-1])\n",
    "    # if (uBcks_afterQP.transpose())[100,-1] < 0: continue\n",
    "    RL_reward_beforeQP.append(reward_beforeQP)\n",
    "    uBcks_beforeQP_list.append(uBcks_beforeQP)\n",
    "\n",
    "    RL_reward_afterQP.append(reward_afterQP)\n",
    "    uBcks_afterQP_list.append(uBcks_afterQP)\n",
    "    # print(uBcks_beforeQP,uBcks_afterQP)\n",
    "    # break\n",
    "\n",
    "result = np.array([RL_reward_beforeQP, RL_reward_afterQP])\n",
    "# print(result)\n",
    "print(np.mean(result, axis=1))\n",
    "print(np.std(result, axis=1))\n",
    "# parabolic_ppo_unsafe_test_10_20_0.1regpf012.npy\n",
    "# \\[149.48226465 148.28584658]\n",
    "# [14.90717115 16.57245199]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_1regpfall\n",
    "# [149.48226465 148.59446071]\n",
    "# [14.90717115 18.4567359 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_0.1regpfall\n",
    "# [149.48226465 146.87924966]\n",
    "# [14.90717115 15.58608927]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_1regpf012abs\n",
    "# [149.48226465 149.55279552]\n",
    "# [14.90717115 15.9574768 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_0.1regpf012abs\n",
    "# [149.48226465 149.17735881]\n",
    "# [14.90717115 14.78229849]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_1regpfallabs\n",
    "# [149.48226465 145.94413243]\n",
    "# [14.90717115 15.18367739]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_0.1regpfallabs\n",
    "# [149.48226465 147.72511486]\n",
    "# [14.90717115 14.45201557]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_20_0.1regpf012_dense.npy\n",
    "# [149.48226465 149.45822283]\n",
    "# [14.90717115 17.96586758]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_35_0.1regpf012_dense.npy\n",
    "# [149.48226465 149.63474481]\n",
    "# [14.90717115 17.49210765]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_50_0.1regpf012_dense.npy\n",
    "# [149.48226465 121.21808524]\n",
    "# [14.90717115 51.86428054]\n",
    "\n",
    "# parabolic_ppo_unsafe_test_10_100_0.1regpf012_dense.npy\n",
    "# [149.48226465  -7.83913163]\n",
    "# [14.90717115 23.21345541]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpf012_dense.npy\n",
    "# [151.79801319 153.98727636]\n",
    "# [17.81187421 21.3633951 ]\n",
    "\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_35_0.1regpf012_dense.npy\n",
    "# [151.79801319 143.13323775]\n",
    "# [17.81187421 21.4305031 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_50_0.1regpf012_dense.npy\n",
    "# [151.79801319 112.99019654]\n",
    "# [17.81187421 55.95012163]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_5_0.1regpf012_dense.npy\n",
    "# [151.79801319 152.01480501]\n",
    "# [17.81187421 17.97407726]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_10_0.1regpf012_dense.npy\n",
    "# [151.79801319 152.45142246]\n",
    "# [17.81187421 18.70171355]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_15_5_0.1regpf012_dense.npy\n",
    "# [151.79801319 153.66772238]\n",
    "# [17.81187421 19.50159613]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_10_0.1regpf012_dense.npy\n",
    "# [151.79801319 153.98727636]\n",
    "# [17.81187421 21.3633951 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpf012_dense.npy\n",
    "# [151.79801319 153.98727636]\n",
    "# [17.81187421 21.3633951 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_25_5_0.1regpf012_dense.npy\n",
    "# [151.79801319 154.26699125]\n",
    "# [17.81187421 21.04646034]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_30_0.1regpf012_dense.npy\n",
    "# [151.79801319 149.61648735]\n",
    "# [17.81187421 20.64877022]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_1regpf012abs_dense.npy\n",
    "# [151.79801319 149.38470182]\n",
    "# [17.81187421 18.15717248]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpf012abs_dense.npy\n",
    "# [151.79801319 148.43324766]\n",
    "# [17.81187421 15.87661575]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpfallabs_dense.npy\n",
    "# [151.79801319 153.2630596 ]\n",
    "# [17.81187421 20.4065062 ]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_1regpf012abs.npy\n",
    "# [151.79801319 151.68848849]\n",
    "# [17.81187421 22.12759295]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpf012abs.npy\n",
    "# [151.79801319 153.78261048]\n",
    "# [17.81187421 21.24060078]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_1regpfallabs.npy\n",
    "# 151.79801319 146.87746693]\n",
    "# [17.81187421 19.07407617]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_10_20_0.1regpfallabs.npy\n",
    "# [151.79801319 149.32652277]\n",
    "# [17.81187421 18.73001296]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpfallabs.npy\n",
    "# [160.48040498 159.25816905]\n",
    "# [19.1325583  22.48956136]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpfallabs_dense.npy\n",
    "# [160.48040498 160.58639614]\n",
    "# [19.1325583  21.96660781]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpf012_dense.npy\n",
    "# [160.48040498 163.66884574]\n",
    "# [19.1325583 22.6505233]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_20_0.1regpf012_dense.npy\n",
    "# [160.48040498 163.01209038]\n",
    "# [19.1325583  21.62136179]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_30_0.1regpf012_dense.npy\n",
    "# [160.48040498 160.91085018]\n",
    "# [19.1325583  30.43335189]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpf012_dense_noalpha.npy\n",
    "# [160.48040498 163.66933819]\n",
    "# [19.1325583  22.65026645]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpf012_dense_opt10.npy\n",
    "# [160.48040498 163.66884574]\n",
    "# [19.1325583 22.6505233]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_25_0.1regpf012_dense_opt100.npy\n",
    "# [160.48040498 163.66884574]\n",
    "# [19.1325583 22.6505233]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_2_0.1regpf012_dense_nonominal.npy\n",
    "# [160.48040498 -12.99701131]\n",
    "# [19.1325583  37.02777024]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_1_0.1regpf012_dense_nonominal.npy\n",
    "# [160.48040498  34.74512796]\n",
    "# [19.1325583  43.76407896]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_5_0.1regpf012_dense_nonominal.npy\n",
    "# [ 160.48040498 -119.48746868]\n",
    "# [19.1325583 67.6996449]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_2_0.1regpf012_dense_nonominal_mpc100.npy\n",
    "# [160.48040498 -12.99701131]\n",
    "# [19.1325583  37.02777024]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_2_0.1regpf012_dense_nonominal_noalpha.npy\n",
    "# [160.48040498 -12.99701131]\n",
    "# [19.1325583  37.02777024]\n",
    "\n",
    "# parabolic_ppo_unsafe_train_100_20_0.1regpf012_dense_opt100.npy\n",
    "# [160.48040498 163.01209038]\n",
    "# [19.1325583  21.62136179]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6fa8de96-743c-4bfe-ba95-1edcbd8b2908",
   "metadata": {},
   "outputs": [],
   "source": [
    "threshold = [\"50\"] #\"50\",\"80\",\"100\",\"120\" \n",
    "# name = [\"_1regpf012.npy\", \"_0.1regpf012.npy\",\"_1regpfall.npy\", \"_0.1regpfall.npy\",\n",
    "#        \"_1regpf012_dense.npy\", \"_0.1regpf012_dense.npy\",\"_1regpfall_dense.npy\", \"_0.1regpfall_dense.npy\",\n",
    "#        \"_1regpf012_abs.npy\", \"_0.1regpf012_abs.npy\",\"_1regpfall_abs.npy\", \"_0.1regpfall_abs.npy\",\n",
    "#        \"_1regpf012_abs_dense.npy\", \"_0.1regpf012_abs_dense.npy\",\"_1regpfall_abs_dense.npy\", \"_0.1regpfall_abs_dense.npy\"]\n",
    "\n",
    "name = [\"_1regpfall_abs.npy\"] # \"_1regpfall_abs.npy\",\"_1regpfall_abs_dense.npy\"\n",
    "# \"_1regpfall_abs.npy\" 50， 70impoved，80 47 improved\n",
    "# \"_1regpfall_abs_dense.npy\" 35 55improved, 50 55improved, 80, 35improved\n",
    "for thre in threshold:\n",
    "    for na in name:\n",
    "        try:\n",
    "            RL_1000 = np.load(\"../../../verify-pde-control/parabolic_sac_unsafe_train_100_\"+thre+na)\n",
    "        except:\n",
    "            print(\"../../../verify-pde-control/parabolic_sac_unsafe_train_100_\"+thre+na, \"not exist\")\n",
    "            continue\n",
    "        RL_reward_beforeQP = []\n",
    "        RL_reward_afterQP = []\n",
    "        uBcks_beforeQP_list = []\n",
    "        uBcks_afterQP_list = []\n",
    "        uBcks_beforeQP,uBcks_afterQP = 0,0\n",
    "        for i in range(RL_1000[\"safe_label\"].transpose().shape[0]):\n",
    "            # if i < 1:continue\n",
    "            # if RL_1000[\"Y_nominal\"][0, i] < 2: continue\n",
    "            U_list = RL_1000[\"U_nominal\"][:, i]\n",
    "            # print(U_list[0])\n",
    "            def getInitialConditionFixed(nx):\n",
    "                return np.ones(nx+1) * U_list[0]\n",
    "            parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "            parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "            # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "            envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "            \n",
    "            \n",
    "            reward_beforeQP, uBcks_beforeQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_list)\n",
    "        \n",
    "        \n",
    "            U_safe_list = RL_1000[\"U_safe\"][:, i]\n",
    "            def getInitialConditionFixed(nx):\n",
    "                return np.ones(nx+1) * U_list[0]\n",
    "            parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "            parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "            # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "            envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "            \n",
    "            \n",
    "            reward_afterQP, uBcks_afterQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_safe_list)\n",
    "            # print((uBcks_afterQP.transpose())[100,-1])\n",
    "            # if (uBcks_afterQP.transpose())[100,-1] < 0: continue\n",
    "            RL_reward_beforeQP.append(reward_beforeQP)\n",
    "            uBcks_beforeQP_list.append(uBcks_beforeQP)\n",
    "        \n",
    "            RL_reward_afterQP.append(reward_afterQP)\n",
    "            uBcks_afterQP_list.append(uBcks_afterQP)\n",
    "            # print(uBcks_beforeQP,uBcks_afterQP)\n",
    "            # break\n",
    "        \n",
    "        result = np.array([RL_reward_beforeQP, RL_reward_afterQP])\n",
    "        # print(result)\n",
    "        print(\"Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_100_\"+thre+na)\n",
    "        print(np.mean(result, axis=1))\n",
    "        print(np.std(result, axis=1))\n",
    "        print(\"end...\")\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpf012.npy\n",
    "# [156.23533962 155.88915966]\n",
    "# [4.11305574 4.3754842 ]\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpf012.npy\n",
    "# [156.23533962 155.87589572]\n",
    "# [4.11305574 4.39648114]\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpfall.npy\n",
    "# [156.23533962 155.97961443]\n",
    "# [4.11305574 4.07886311]\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpfall.npy\n",
    "# [156.23533962 155.93192795]\n",
    "# [4.11305574 4.3569167 ]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpf012_dense.npy\n",
    "# [156.23533962 155.99187986]\n",
    "# [4.11305574 4.16199828]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpf012_dense.npy\n",
    "# [156.23533962 155.98402034]\n",
    "# [4.11305574 4.11623512]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpfall_dense.npy\n",
    "# [156.23533962 155.94379888]\n",
    "# [4.11305574 4.31355407]\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpfall_dense.npy\n",
    "# [156.23533962 155.77503923]\n",
    "# [4.11305574 4.24825255]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpf012_abs.npy\n",
    "# [156.23533962 156.03609175]\n",
    "# [4.11305574 3.50784423]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpf012_abs.npy\n",
    "# [156.23533962 154.4685648 ]\n",
    "# [4.11305574 5.26250375]\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpfall_abs.npy\n",
    "# [156.23533962 156.31257558]\n",
    "# [4.11305574 4.11051373]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpfall_abs.npy\n",
    "# [156.23533962 156.00447325]\n",
    "# [4.11305574 4.30876949]\n",
    "\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpf012_abs_dense.npy\n",
    "# [156.23533962 154.84805911]\n",
    "# [4.11305574 4.58713106]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpf012_abs_dense.npy\n",
    "# [156.23533962 155.68611099]\n",
    "# [4.11305574 4.2342919 ]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_1regpfall_abs_dense.npy\n",
    "# [156.23533962 156.46839368]\n",
    "# [4.11305574 4.60057724]\n",
    "\n",
    "\n",
    "# parabolic_sac_unsafe_train_10_20_0.1regpfall_abs_dense.npy\n",
    "# [156.23533962 156.12588742]\n",
    "# [4.11305574 3.88429914]\n",
    "\n",
    "\n",
    "'''\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpf012.npy\n",
    "[156.23533962 155.88915966]\n",
    "[4.11305574 4.3754842 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpf012.npy\n",
    "[156.23533962 155.87589572]\n",
    "[4.11305574 4.39648114]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpfall.npy\n",
    "[156.23533962 155.05973843]\n",
    "[4.11305574 6.3837523 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpfall.npy\n",
    "[156.23533962 155.93192795]\n",
    "[4.11305574 4.3569167 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpf012_dense.npy\n",
    "[156.23533962 155.99187986]\n",
    "[4.11305574 4.16199828]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpf012_dense.npy\n",
    "[156.23533962 155.98402034]\n",
    "[4.11305574 4.11623512]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpfall_dense.npy\n",
    "[156.23533962 155.94379888]\n",
    "[4.11305574 4.31355407]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpfall_dense.npy\n",
    "[156.23533962 155.77503923]\n",
    "[4.11305574 4.24825255]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpf012_abs.npy\n",
    "[156.23533962 156.03609175]\n",
    "[4.11305574 3.50784423]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpf012_abs.npy\n",
    "[156.23533962 153.59876466]\n",
    "[4.11305574 5.68875964]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpfall_abs.npy\n",
    "[156.23533962 157.10028786]\n",
    "[4.11305574 4.77851834]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpfall_abs.npy\n",
    "[156.23533962 156.00447325]\n",
    "[4.11305574 4.30876949]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpf012_abs_dense.npy\n",
    "[156.23533962 154.3779857 ]\n",
    "[4.11305574 4.84748916]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpf012_abs_dense.npy\n",
    "[156.23533962 156.06648578]\n",
    "[4.11305574 4.34391531]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_1regpfall_abs_dense.npy\n",
    "[156.23533962 157.15897559]\n",
    "[4.11305574 4.67958634]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_25_0.1regpfall_abs_dense.npy\n",
    "[156.23533962 156.12588742]\n",
    "[4.11305574 3.88429914]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpf012.npy\n",
    "[156.23533962 154.66242591]\n",
    "[4.11305574 7.5500989 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpf012.npy\n",
    "[156.23533962 154.64561843]\n",
    "[4.11305574 7.58379279]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpfall.npy\n",
    "[156.23533962 153.44555113]\n",
    "[4.11305574 8.17920266]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpfall.npy\n",
    "[156.23533962 155.93192795]\n",
    "[4.11305574 4.3569167 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpf012_dense.npy\n",
    "[156.23533962 154.82485782]\n",
    "[4.11305574 7.14126031]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpf012_dense.npy\n",
    "[156.23533962 155.42369869]\n",
    "[4.11305574 5.46116691]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpfall_dense.npy\n",
    "[156.23533962 155.39485088]\n",
    "[4.11305574 5.65634171]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpfall_dense.npy\n",
    "[156.23533962 155.13423271]\n",
    "[4.11305574 5.79785783]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpf012_abs.npy\n",
    "[156.23533962 156.39145883]\n",
    "[4.11305574 3.79212323]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpf012_abs.npy\n",
    "[156.23533962 151.99560332]\n",
    "[4.11305574 4.81550941]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpfall_abs.npy\n",
    "[156.23533962 157.62794683]\n",
    "[4.11305574 4.87335077]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpfall_abs.npy\n",
    "[156.23533962 156.00447325]\n",
    "[4.11305574 4.30876949]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpf012_abs_dense.npy\n",
    "[156.23533962 154.8428367 ]\n",
    "[4.11305574 4.81250612]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpf012_abs_dense.npy\n",
    "[156.23533962 155.94751873]\n",
    "[4.11305574 4.80991881]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_1regpfall_abs_dense.npy\n",
    "[156.23533962 157.15897559]\n",
    "[4.11305574 4.67958634]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_30_0.1regpfall_abs_dense.npy\n",
    "[156.23533962 155.81835147]\n",
    "[4.11305574 4.69370555]\n",
    "end...\n",
    "\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_35_1regpfall_abs.npy\n",
    "[156.23533962 157.41336817]\n",
    "[4.11305574 4.27273818]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_35_1regpfall_abs_dense.npy\n",
    "[156.23533962 157.76467526]\n",
    "[4.11305574 5.37042157]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_40_1regpfall_abs.npy\n",
    "[156.23533962 157.8605277 ]\n",
    "[4.11305574 4.1034946 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_40_1regpfall_abs_dense.npy\n",
    "[156.23533962 156.74677791]\n",
    "[4.11305574 5.08254725]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_45_1regpfall_abs.npy\n",
    "[156.23533962 157.8605277 ]\n",
    "[4.11305574 4.1034946 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_45_1regpfall_abs_dense.npy\n",
    "[156.23533962 155.81167341]\n",
    "[4.11305574 6.04774019]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_50_1regpfall_abs.npy\n",
    "[156.23533962 157.8605277 ]\n",
    "[4.11305574 4.1034946 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_50_1regpfall_abs_dense.npy\n",
    "[156.23533962 155.07828112]\n",
    "[4.11305574 7.99857374]\n",
    "end...\n",
    "\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_60_1regpfall_abs.npy\n",
    "[156.23533962 157.13584401]\n",
    "[4.11305574 4.31016345]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_70_1regpfall_abs.npy\n",
    "[156.23533962 157.0620036 ]\n",
    "[4.11305574 4.29969063]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_80_1regpfall_abs.npy\n",
    "[156.23533962 155.78634887]\n",
    "[4.11305574 5.37481721]\n",
    "end...\n",
    "\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_100_35_1regpfall_abs.npy\n",
    "[155.26352884 156.24973375]\n",
    "[5.57911463 5.5413279 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_100_35_1regpfall_abs_dense.npy\n",
    "[155.26352884 155.24254045]\n",
    "[5.57911463 5.39845998]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_100_45_1regpfall_abs.npy\n",
    "[155.26352884 156.44728438]\n",
    "[5.57911463 5.62521227]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_50_1regpfall_abs.npy\n",
    "[156.23533962 157.8605277 ]\n",
    "[4.11305574 4.1034946 ]\n",
    "end...\n",
    "Now: ../../../verify-pde-control/parabolic_sac_unsafe_train_10_50_1regpfall_abs_dense.npy\n",
    "[156.23533962 155.07828112]\n",
    "[4.11305574 7.99857374]\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3c8ef16-1779-4ccc-9177-8a1094af26eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_earliest_true(condition):\n",
    "    # Iterate over the first two dimensions (10 and 8) and check for each slice\n",
    "    earliest_indices = np.full(condition.shape[:2], 0)  # Initialize with -1 (indicating no valid index)\n",
    "\n",
    "    for i in range(condition.shape[0]):  # Iterate over first dimension\n",
    "        for j in range(condition.shape[1]):  # Iterate over second dimension\n",
    "            # For each slice (i, j), find the earliest index where the condition is True\n",
    "            # and all subsequent values are also True\n",
    "            for k in range(condition.shape[2]):\n",
    "                if not condition[i, j, condition.shape[2]-k-1]: \n",
    "                    # print(k)\n",
    "                    if k == 0:\n",
    "                        earliest_indices[i,j] = -1\n",
    "                    else:\n",
    "                        earliest_indices[i,j] = condition.shape[2]-k\n",
    "                    break\n",
    "            # valid_indices = np.where(np.cumprod(condition[i, j, :]) == 1)[0]\n",
    "            # if len(valid_indices) > 0:\n",
    "            #     earliest_indices[i, j] = valid_indices[0]  # Store the first valid index\n",
    "    return earliest_indices\n",
    "RL_1000 = np.load(\"../../../verify-pde-control/parabolic_ppo_all_train_100_25_para_0.1reg_1pf_time_CBFnoT_pf12_addsafe__le1safe_20.npy\")\n",
    "\n",
    "RL_reward_beforeQP = []\n",
    "RL_reward_afterQP = []\n",
    "uBcks_beforeQP_list = []\n",
    "uBcks_afterQP_list = []\n",
    "uBcks_beforeQP,uBcks_afterQP = 0,0\n",
    "for i in range(RL_1000[\"safe_label\"].transpose().shape[0]):\n",
    "    # if i < 1:continue\n",
    "    # if RL_1000[\"Y_nominal\"][0, i] < 2: continue\n",
    "    U_list = RL_1000[\"U_nominal\"][:, i]\n",
    "    # print(U_list[0])\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_beforeQP, uBcks_beforeQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_list)\n",
    "\n",
    "\n",
    "    U_safe_list = RL_1000[\"U_safe\"][:, i]\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_afterQP, uBcks_afterQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_safe_list)\n",
    "    # print((uBcks_afterQP.transpose())[100,-1])\n",
    "    # if (uBcks_afterQP.transpose())[100,-1] < 0: continue\n",
    "    RL_reward_beforeQP.append(reward_beforeQP)\n",
    "    uBcks_beforeQP_list.append(uBcks_beforeQP)\n",
    "\n",
    "    RL_reward_afterQP.append(reward_afterQP)\n",
    "    uBcks_afterQP_list.append(uBcks_afterQP)\n",
    "    # print(uBcks_beforeQP,uBcks_afterQP)\n",
    "    # break\n",
    "\n",
    "\n",
    "result = np.array([uBcks_beforeQP_list, uBcks_afterQP_list]) #(2, 100, 1001, 201) # first 100 is num of samples, second 201 is num of 201 spatial steps\n",
    "# print(result.shape)\n",
    "condition = result[:, :,:, 100] < 0.6\n",
    "earliest_index = find_earliest_true(condition)\n",
    "valid_earliest_index_beforeQP = earliest_index[0,earliest_index[0,:]>=0]\n",
    "valid_earliest_index_afterQP = earliest_index[1,earliest_index[1,:]>=0]\n",
    "# result.shape[2] - earliest_index\n",
    "print(f\"beforeQP PF steps among {valid_earliest_index_beforeQP.shape[0]} PF trajectories\", np.mean(result.shape[2] - valid_earliest_index_beforeQP), np.std(result.shape[2] - valid_earliest_index_beforeQP))\n",
    "print(f\"afterQP PF steps among {valid_earliest_index_afterQP.shape[0]} PF trajectories\", np.mean(result.shape[2] - valid_earliest_index_afterQP), np.std(result.shape[2] - valid_earliest_index_afterQP))\n",
    "\n",
    "\n",
    "# output_boundary_endtime_diff = result[:, :,-1, 0] - 1\n",
    "# output_boundary_endtime_diff = np.where(output_boundary_endtime_diff < 0, 0, output_boundary_endtime_diff)\n",
    "# # print(\"< 1 distance: beforeQP and afterQP\")\n",
    "# # print(np.mean(output_boundary_endtime_diff, axis=1))\n",
    "# # print(np.std(output_boundary_endtime_diff, axis=1))\n",
    "# print(\"times less than 1: beforeQP and afterQP\",np.sum(output_boundary_endtime_diff == 0, axis=1))\n",
    "\n",
    "reward_result = np.array([RL_reward_beforeQP,RL_reward_afterQP])\n",
    "print(\"reward: beforeQP and afterQP\")\n",
    "print(np.mean(reward_result, axis=1))\n",
    "print(np.std(reward_result, axis=1))\n",
    "\n",
    "# parabolic_ppo_all_train_100_25_0.1regpf012_dense.npy\n",
    "# use this\n",
    "# beforeQP PF steps among 60 PF trajectories 154.96666666666667 142.12775551907126\n",
    "# afterQP PF steps among 81 PF trajectories 506.9382716049383 222.9604596334866\n",
    "# reward: beforeQP and afterQP\n",
    "# [164.49623817 168.21342539]\n",
    "# [20.67811387 23.51961498]\n",
    "\n",
    "# parabolic_ppo_all_train_100_20_0.1regpf012_dense.npy\n",
    "# beforeQP PF steps among 60 PF trajectories 154.96666666666667 142.12775551907126\n",
    "# afterQP PF steps among 79 PF trajectories 453.8354430379747 242.30295036678626\n",
    "# reward: beforeQP and afterQP\n",
    "# [164.49623817 167.36970806]\n",
    "# [20.67811387 22.69178541]\n",
    "\n",
    "\n",
    "\n",
    "# parabolic_ppo_allmix50_train_100_25_0.1regpf012_dense.npy\n",
    "# beforeQP PF steps among 32 PF trajectories 148.8125 118.19143303873594\n",
    "# afterQP PF steps among 38 PF trajectories 497.2631578947368 219.83865904585647\n",
    "# reward: beforeQP and afterQP\n",
    "# [163.7632271  167.17898335]\n",
    "# [21.73755702 24.76326815]\n",
    "\n",
    "\n",
    "# parabolic_ppo_all_train_100_25_para_0.1reg_1pf_time_CBFnoT_pf12_addsafe__le1safe_20.npy\n",
    "# used\n",
    "# beforeQP PF steps among 60 PF trajectories 154.96666666666667 142.12775551907126\n",
    "# afterQP PF steps among 46 PF trajectories 519.3913043478261 304.28937016259846\n",
    "# reward: beforeQP and afterQP\n",
    "# [164.49623817 162.90573742]\n",
    "# [20.67811387 19.62749147]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a57e2d48-745e-4e1a-9825-f037ab1f3a92",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_earliest_true(condition):\n",
    "    # Iterate over the first two dimensions (10 and 8) and check for each slice\n",
    "    earliest_indices = np.full(condition.shape[:2], 0)  # Initialize with -1 (indicating no valid index)\n",
    "\n",
    "    for i in range(condition.shape[0]):  # Iterate over first dimension\n",
    "        for j in range(condition.shape[1]):  # Iterate over second dimension\n",
    "            # For each slice (i, j), find the earliest index where the condition is True\n",
    "            # and all subsequent values are also True\n",
    "            for k in range(condition.shape[2]):\n",
    "                if not condition[i, j, condition.shape[2]-k-1]: \n",
    "                    # print(k)\n",
    "                    if k == 0:\n",
    "                        earliest_indices[i,j] = -1\n",
    "                    else:\n",
    "                        earliest_indices[i,j] = condition.shape[2]-k\n",
    "                    break\n",
    "            # valid_indices = np.where(np.cumprod(condition[i, j, :]) == 1)[0]\n",
    "            # if len(valid_indices) > 0:\n",
    "            #     earliest_indices[i, j] = valid_indices[0]  # Store the first valid index\n",
    "    return earliest_indices\n",
    "RL_1000 = np.load(\"../../../verify-pde-control/parabolic_sac_all_train_100_45_para_1reg_1pf_time_CBFnoT_pfall_addsafe__abs_20.npy\")\n",
    "\n",
    "RL_reward_beforeQP = []\n",
    "RL_reward_afterQP = []\n",
    "uBcks_beforeQP_list = []\n",
    "uBcks_afterQP_list = []\n",
    "uBcks_beforeQP,uBcks_afterQP = 0,0\n",
    "for i in range(RL_1000[\"safe_label\"].transpose().shape[0]):\n",
    "    # if i < 1:continue\n",
    "    # if RL_1000[\"Y_nominal\"][0, i] < 2: continue\n",
    "    U_list = RL_1000[\"U_nominal\"][:, i]\n",
    "    # print(U_list[0])\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_beforeQP, uBcks_beforeQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_list)\n",
    "\n",
    "\n",
    "    U_safe_list = RL_1000[\"U_safe\"][:, i]\n",
    "    def getInitialConditionFixed(nx):\n",
    "        return np.ones(nx+1) * U_list[0]\n",
    "    parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "    parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "    # hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "    envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "    \n",
    "    \n",
    "    reward_afterQP, uBcks_afterQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_safe_list)\n",
    "    # print((uBcks_afterQP.transpose())[100,-1])\n",
    "    # if (uBcks_afterQP.transpose())[100,-1] < 0: continue\n",
    "    RL_reward_beforeQP.append(reward_beforeQP)\n",
    "    uBcks_beforeQP_list.append(uBcks_beforeQP)\n",
    "\n",
    "    RL_reward_afterQP.append(reward_afterQP)\n",
    "    uBcks_afterQP_list.append(uBcks_afterQP)\n",
    "    # print(uBcks_beforeQP,uBcks_afterQP)\n",
    "    # break\n",
    "\n",
    "\n",
    "result = np.array([uBcks_beforeQP_list, uBcks_afterQP_list]) #(2, 100, 1001, 201) # first 100 is num of samples, second 201 is num of 201 spatial steps\n",
    "# print(result.shape)\n",
    "condition = result[:, :,:, 100] > -0.26\n",
    "earliest_index = find_earliest_true(condition)\n",
    "valid_earliest_index_beforeQP = earliest_index[0,earliest_index[0,:]>=0]\n",
    "valid_earliest_index_afterQP = earliest_index[1,earliest_index[1,:]>=0]\n",
    "# result.shape[2] - earliest_index\n",
    "print(f\"beforeQP PF steps among {valid_earliest_index_beforeQP.shape[0]} PF trajectories\", np.mean(result.shape[2] - valid_earliest_index_beforeQP), np.std(result.shape[2] - valid_earliest_index_beforeQP))\n",
    "print(f\"afterQP PF steps among {valid_earliest_index_afterQP.shape[0]} PF trajectories\", np.mean(result.shape[2] - valid_earliest_index_afterQP), np.std(result.shape[2] - valid_earliest_index_afterQP))\n",
    "\n",
    "\n",
    "# output_boundary_endtime_diff = result[:, :,-1, 0] - 1\n",
    "# output_boundary_endtime_diff = np.where(output_boundary_endtime_diff < 0, 0, output_boundary_endtime_diff)\n",
    "# # print(\"< 1 distance: beforeQP and afterQP\")\n",
    "# # print(np.mean(output_boundary_endtime_diff, axis=1))\n",
    "# # print(np.std(output_boundary_endtime_diff, axis=1))\n",
    "# print(\"times less than 1: beforeQP and afterQP\",np.sum(output_boundary_endtime_diff == 0, axis=1))\n",
    "\n",
    "reward_result = np.array([RL_reward_beforeQP,RL_reward_afterQP])\n",
    "print(\"reward: beforeQP and afterQP\")\n",
    "print(np.mean(reward_result, axis=1))\n",
    "print(np.std(reward_result, axis=1))\n",
    "\n",
    "# parabolic_sac_all_train_100_35_1regpfall_abs.npy\n",
    "# beforeQP PF steps among 72 PF trajectories 118.38888888888889 130.79081639901554\n",
    "# afterQP PF steps among 85 PF trajectories 391.77647058823527 312.12702453707334\n",
    "# reward: beforeQP and afterQP\n",
    "# [156.45416823 157.33406515]\n",
    "# [6.22818798 6.49886271]\n",
    "\n",
    "\n",
    "# parabolic_sac_all_train_100_45_1regpfall_abs.npy\n",
    "# use this\n",
    "# beforeQP PF steps among 72 PF trajectories 118.38888888888889 130.79081639901554\n",
    "# afterQP PF steps among 87 PF trajectories 449.7816091954023 317.6951631253969\n",
    "# reward: beforeQP and afterQP\n",
    "# [156.45416823 157.52711165]\n",
    "# [6.22818798 6.80757931]\n",
    "\n",
    "\n",
    "# parabolic_sac_allmix50_train_100_35_1regpfall_abs\n",
    "# eforeQP PF steps among 38 PF trajectories 104.28947368421052 93.1187436315185\n",
    "# afterQP PF steps among 43 PF trajectories 376.3953488372093 308.2667328516294\n",
    "# reward: beforeQP and afterQP\n",
    "# [156.65804436 157.59450509]\n",
    "# [5.46053013 5.66244958]\n",
    "\n",
    "\n",
    "# parabolic_sac_all_train_100_45_para_1reg_1pf_time_CBFnoT_pfall_addsafe__abs_20.npy\n",
    "# used\n",
    "# beforeQP PF steps among 72 PF trajectories 118.38888888888889 130.79081639901554\n",
    "# afterQP PF steps among 90 PF trajectories 543.1555555555556 310.89608521573433\n",
    "# reward: beforeQP and afterQP\n",
    "# [156.45416823 157.93568582]\n",
    "# [6.22818798 6.88752578]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b306d090-e7dd-471d-9dd6-5118f7f19a19",
   "metadata": {},
   "outputs": [],
   "source": [
    "qp_works = 0\n",
    "print(result.shape)\n",
    "for i in range(result.shape[1]):\n",
    "    if (result[0, i] - result[1, i]) < 0.0:\n",
    "        qp_works += 1\n",
    "        print(\"working\",result[:, i])\n",
    "    else:\n",
    "        pass\n",
    "        # print(\"not working\", result[:, i])\n",
    "print(qp_works)\n",
    "# 10\n",
    "# [164.17202344 164.30086977]\n",
    "# [20.25973315 21.05437584] 51\n",
    "\n",
    "# 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d4a4608-1498-4a9c-aa6f-bb66299b71ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1094eb1-7aab-4c81-b88e-e8e018baec8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "uBcks_beforeQP.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "261fd62f-65fc-422f-9dee-f68918c4b17a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def runSingleEpisodeQP(model, env, parameter):\n",
    "    terminate = False\n",
    "    truncate = False\n",
    "\n",
    "    # Holds the resulting states\n",
    "    uStorage = []\n",
    "\n",
    "    # Reset Environment\n",
    "    obs,__ = env.reset()\n",
    "    uStorage.append(obs)\n",
    "\n",
    "    i = 0\n",
    "    rew = 0\n",
    "    while not truncate and not terminate:\n",
    "        # use backstepping controller\n",
    "        action = model(obs, parameter,i)\n",
    "        # print(action)\n",
    "        obs, rewards, terminate, truncate, info = env.step(action)\n",
    "        # print(action, obs)\n",
    "        uStorage.append(obs)\n",
    "        rew += rewards \n",
    "        i += 1\n",
    "    u = np.array(uStorage)\n",
    "    return rew, u\n",
    "\n",
    "def QP_filter_Controller(obs, parameter,index):\n",
    "    # print(obs)\n",
    "    # print(parameter)\n",
    "    return parameter[index+1]\n",
    "\n",
    "# reward_class_no_penalty =  TunedReward1D(int(round(T/dt)), -1e-4, 3e2) # no penalize\n",
    "# reward_class =  TunedReward1D(int(round(T/dt)), -1e3, 3e2) # with penalize\n",
    "# reward_class = NormReward(int(round(T/dt)),\"2\", \"temporal\", -1e-4, 3e2)\n",
    "\n",
    "def getInitialConditionFixed(nx):\n",
    "    return np.ones(nx+1) * 1.6064452\n",
    "# ppo\n",
    "# U_list = [5.5032945, -5.573125, -7.7780714, -5.4272566, -7.373337, -9.997107, -4.6177063, -7.3362265, -5.9887877, -4.587183, -5.823312, -6.1635923, -6.0655155, -5.377701, -3.6982517, -3.8902073, -5.5814342, -5.0831127, -5.370241, -5.805416, -6.430519, -3.4754848, -3.7889462, -4.9852285, -6.706913, -4.575754, -6.110157, -4.686098, -4.452132, -3.9169083, -4.8952675, -2.632679, -3.5326824, -3.1189156, -3.7576122, -4.1710567, -4.678581, -4.349923, -3.7056866, -3.0855484, -4.3252707, -5.1583433, -4.439726, -4.065242, -4.2640324, -2.3109074, -1.9379883, -3.3393211, -6.048831, -1.6790752, -4.799762, -2.4814968, -2.3415222, -4.547558, -1.2150459, -2.9021206, -2.0234299, -0.22552872, -2.2863426, -2.500391, -1.253006, -2.3867893, -2.3003845, -3.9076767, -3.391426, -1.1009464, -3.6390514, -1.2063103, -2.6597939, -2.6458206, -2.5175705, -5.645995, -4.508897, -2.2732258, -4.2863646, -2.900961, -1.9175205, -3.5289307, -2.425808, -1.7565594, -2.485218, -3.1309776, -4.019289, -4.0902348, -2.7531776, -2.9579773, -2.393465, -3.1583633, -2.256277, -4.173131, -2.6877441, -3.1116295, -3.299366, -4.053088, -2.6149254, -3.6322079, -3.0513268, -1.7944565, -1.8430538, -3.4142933, -3.302061, -4.1399813, -3.7027702, -3.3257065, -0.516737, -1.810646, -4.2704697, -2.2046642, -2.614071, -3.478796, -2.2834644, -3.3702965, -2.357891, -3.2452087, -4.130335, -2.5716476, -2.1568928, -1.570858, -2.3733559, -3.1866665, -2.3657207, -3.0097713, -3.2471485, -1.4467316, -3.6336288, -2.5325928, -3.8257866, -3.2992783, -2.8010864, -1.682518, -1.8743057, -0.65436363, -3.2118206, -2.9979897, -2.4641685, -4.169078, -3.1789322, -2.3966026, -3.1789665, -1.3083057, -2.2180977, -2.2307281, -3.5588398, -1.3362083, -3.0638828, -2.8304234, -2.8893757, -3.3373375, -2.4243088, -2.1283932, -3.4842415, -2.5107803, -0.6998291, -2.2021942, -4.50181, -2.2322254, -1.4267216, -2.2012386, -2.2091408, -1.6662502, -3.6723137, -1.8987064, -2.190115, -3.3139877, -2.4567986, -0.5985584, -4.156763, -3.9893532, -1.6146317, -4.046255, -3.1845436, -2.7524586, -0.9182644, -2.7059155, -1.6789379, -2.2891064, -1.1522884, -2.4665146, -2.3041744, -3.9076023, 1.5708961, -1.605236, -2.4064865, -1.262497, -3.0495148, -5.9794903, -2.188795, -0.698349, -1.4494877, -2.7203789, -3.8358994, 1.267437, -1.9517536, -3.2213898, -1.9550972, -3.7140446, -0.2817936, -1.9074192, -2.5549488, -3.6033058, -0.9648514, -2.5704918, -4.1200457, 0.3628769, -1.0867767, -2.4335575, -2.4090614, -2.6579418, -1.7362175, -4.733694, 0.37082863, -1.9274368, -3.264536, -0.39655876, -2.8357563, -1.7162952, -3.3913498, -1.4970188, -3.259262, -1.0741615, -3.229248, -1.0476475, -4.128895, 0.41124344, -1.9664536, -3.2986717, -0.40197754, -3.4667702, 1.2460327, -2.5124168, -3.0509548, 1.3427181, -3.1873436, -4.058754, 0.75935364, -2.585186, -0.5605011, -3.4722633, -0.04906082, -3.7821407, 2.105526, -2.1079292, -2.271635, -2.648508, 0.55744934, -1.0204163, -2.1399841, -1.1849804, -3.0816345, 1.726841, -1.480463, -1.1406479, -2.1063766, -0.71328163, -2.9834747, 0.768404, -1.5336018, -1.1559639, -1.6222172, -2.0228195, -0.9056244, -2.8285484, 0.34895706, -2.1602783, 1.047945, -2.6647644, 0.76325417, -2.1112309, 0.09752083, -4.5636578, 2.2487526, -0.62094307, -1.2704067, -1.5853271, -0.8118439, 0.439476, -2.7952023, 3.1212444, 2.2275257, 0.5374565, -3.5756989, 1.6732101, -0.3230629, -1.8687172, 2.3388958, 0.66020775, -1.2664509, 0.6384754, -2.2306595, 2.7286053, 1.9742184, 0.9084587, 0.5743313, -2.1999435, 3.2850494, 1.5019016, 2.3513527, 0.3092594, -2.0948296, 3.316597, 0.34397507, -1.4775867, 1.1082458, -0.25738907, -4.064213, 2.5259285, -1.2776546, 0.6644478, -0.66824913, 0.45877647, -0.81300354, -0.25681114, -1.5844688, 1.7154484, -0.08606529, -1.4341297, 0.37956238, 0.5204277, -2.1125183, 3.0539246, 1.3882217, -1.4055367, 1.7362232, 0.73282623, -1.1797924, 0.5264931, -0.48760796, -0.16176033, -2.4079933, 1.5406494, 0.3254814, -0.60199547, -0.6922264, -0.66176987, 0.43336105, -0.61042595, -1.7169533, 4.1451035, 0.6256447, -0.29520226, -0.87979126, 0.06916809, -0.20001411, 0.23191261, -1.1919975, 3.8707466, 0.020118713, -3.5972424, 1.6093292, 2.3488216, 2.6822567, 0.06535339, -5.148205, 1.1461906, -0.59119225, -0.6798649, 0.16784668, -0.20261574, -0.8760834, -0.17915916, 0.47217178, 0.0019741058, -1.7631359, 3.9553413, 2.1017494, 0.50102425, -1.6865139, 2.424715, 1.2348747, 1.4235096, 1.0891361, 1.0378418, -1.529377, 1.9429302, -0.82504463, -0.021648407, -3.1599598, 2.6810455, 1.0195007, -0.38676834, -1.8075733, 2.7140846, 1.0279427, 0.93424606, -0.9564514, 0.54868317, -0.84586525, 0.37865448, -1.6000729, 2.9911213, 1.6796684, -0.3178463, -3.6596794, 0.7993412, -0.6348305, -1.150135, 1.8910141, -1.0285301, 1.0163307, -2.2027493, 4.6050816, 3.196066, 2.0316772, -0.59394073, -2.820448, 3.0035686, 1.7764244, 0.7363796, -1.7043667, -0.64735603, -0.34062386, -0.042720795, -1.8325157, 3.5502129, 1.8760662, 0.098220825, -4.6769505, 2.9316483, 0.6305218, -0.24117851, -2.4241028, 3.8399925, 1.6221466, -0.5060787, -3.013794, 2.414959, 2.3096657, 0.17160606, -4.814168, 1.4499836, -2.790123, 2.328022, 1.1043949, -0.676136, -2.5546818, 3.064211, 0.8132572, 0.46987724, -0.4922104, -2.104576, 2.9777508, -0.113752365, -1.9508133, 2.702713, 1.9929714, -2.0109596, 2.3279572, 0.34996223, -4.308648, 1.7128525, -1.1095734, 0.6431351, -0.94088364, -0.09546089, -2.7067833, 2.792614, 1.0567741, -0.77908325, -0.1255455, -0.83836746, -0.9087963, -0.18722534, -2.0765839, 2.1961594, 0.016355515, -1.9887371, 1.5251808, 0.4952278, -5.3024206, 1.2747574, -0.16186523, -1.430851, 1.8621216, 1.616394, 1.2215767, -0.8783417, -0.34013367, -1.640398, -1.8040867, -0.30330086, -1.1232529, 0.18937111, -1.3813992, 0.93491554, -1.7861385, 2.7734776, 1.7961769, 0.16217422, -3.7670803, 2.2371292, -0.23620796, -4.4968023, 2.8732796, 1.0714378, 1.0090485, -1.2685757, -0.035186768, -1.6548481, -0.4477291, -1.9352341, 1.6235523, -2.2751465, 2.73979, 3.5747242, -0.8734207, -3.06736, 3.1634407, 0.6537132, -0.8248539, -2.24852, 2.5808601, 0.6397934, -0.21766472, 0.41536522, -2.0108986, 3.1373177, 1.1578083, -0.72724533, -1.7978306, 2.3079586, -1.0111179, -1.9520016, 3.0480003, -2.3283806, 3.6720085, 0.6219559, -3.453762, 3.1286907, 1.3949413, -0.34973335, -3.6402168, 2.0923882, 1.4548302, -1.2884922, -0.36109734, -1.0380955, -0.88863564, 0.21746445, -2.4415321, 1.6896076, -0.12073517, -3.6674004, 2.5277405, -0.22679901, -1.8151646, 1.453743, -0.6325817, -1.6417065, 2.9344559, -0.036251068, -3.0752792, 3.4825287, 2.303482, 0.29150963, -3.800293, 2.1373158, 0.8784332, -2.4548645, 2.2684479, 1.8924408, 2.1036758, 1.916935, -0.13415337, -3.9984665, 1.4803524, 0.9508991, -0.6995754, -2.0426693, 4.139431, -0.23169327, -2.9768066, 1.0184174, -1.8879795, 1.5852737, -1.0347252, -1.9304428, 3.5672188, -0.3737564, -2.0631523, 1.1801376, -1.0282993, -0.44493866, -1.9936066, 1.5188389, -0.691988, -1.2304859, 1.9837799, -0.19215965, -3.1501617, 1.2817955, -1.2335033, 0.17882347, -0.8443661, -0.49678993, -1.3906708, 0.8753414, -1.2230034, -1.5411339, 0.9524002, 0.89476395, -1.209671, 0.9841633, -1.0492439, -2.1720448, 0.369236, -1.5501289, 3.097744, -0.020015717, -1.3602562, 1.6409035, -0.16485023, -2.5660095, 3.0746918, 0.6615143, -2.0235653, 0.37656593, -0.29200935, -1.4567223, 0.28372574, -2.2649956, 0.8941269, -0.80166626, -1.6139164, 1.4105511, 0.28327942, -1.0557384, -0.43140793, -1.4197769, 2.5674934, 0.66462517, -1.5058002, 1.0065479, 0.035125732, -3.2897034, 2.115612, 0.17404938, 0.4204712, -2.8787842, 1.4156303, -0.14416885, -3.193781, 1.7398453, -0.87845993, -1.115427, -0.38110542, -1.4287243, -0.6914654, -2.2048035, -0.37591934, -0.60424614, -0.10322952, -0.9743233, -0.09563255, -1.126276, -0.90835, 1.3975792, -0.4811859, -3.6443157, -0.047822952, -1.27561, -1.6391163, 1.3794403, 0.93569946, -0.6746979, -1.6353874, 3.2134533, -0.43964577, -4.369588, 1.2577038, -0.9220867, 0.033649445, -1.6152401, 2.0560932, 0.063705444, -3.3631363, 2.7493324, -0.091817856, -2.9122124, 0.7007599, 1.0416603, 1.3655357, 0.9321823, 0.11675072, -3.1925716, 2.3393269, -0.6700535, -1.2187614, 3.265726, 0.9104538, -0.5910778, -1.8400536, 2.447195, 0.5459881, -2.4997482, 2.4091434, 3.2303524, 2.359312, -0.15984154, -5.0207243, 1.1389751, 0.17085648, -1.8785286, 3.5731926, 2.5248451, 3.488367, 0.091817856, -4.033313, 2.3774986, 0.5354786, -3.4934578, 2.123314, 1.0308914, -0.67991066, -1.000452, -0.5355034, -0.3316784, -0.35671997, 0.37514114, -1.4475307, 0.15443611, -1.245739, 0.3086357, -1.0535603, 0.1388073, 0.6318054, -0.18911743, -1.1481323, -0.4690342, -1.7232895, 2.2679043, 0.61156464, -1.5180035, -0.102048874, -0.927763, -0.13978195, -1.3769588, 3.176611, 2.3286781, 0.051826477, -3.0903358, 1.1054516, 0.2877426, -1.4052334, 0.42870522, -1.2455082, 2.4627914, 0.57052803, -1.3812065, 0.55615425, -3.7831326, 2.3832989, 0.31591797, -2.572752, 2.603157, 1.7357788, 2.0082474, 0.3207283, -3.5674076, 2.624298, 1.3290138, -1.2224731, -1.4195614, 0.690506, 1.0910988, -0.07729912, -1.9420986, 4.3268967, 2.4480343, -1.0734882, -2.7480545, 1.9826488, -1.0216312, 1.4379139, 1.5945644, 1.5819397, 0.3602562, -2.0779324, 2.0495014, 0.1576786, -2.1588058, 1.8049316, -0.4284973, -1.0652313, -0.54662323, -0.39985466, -1.7895317, 1.068676, -1.0323868, 0.13180542, 0.2503624, -1.797163, 3.7566853, 1.9324608, 0.39214897, -1.9484158, 2.2153568, 1.3790169, -1.424654, -0.69740295, -1.6142731, 3.2194977, 0.17802048, -3.4384212, 2.043169, -1.2116699, 1.0146732, -2.5719585, 5.341816, 1.1558895, 1.5379543, 1.6371937, 1.6034355, -1.1673584, 0.45638847, -2.7095032, 3.1460667, -0.0016117096, -4.5319185, 2.3795109, 1.0270538, -0.25354576, -2.0996017, 3.5441494, 0.48301888, -4.569769, 3.08947, -1.8049126, 1.7562771, 0.9250603, -1.6835384, 1.058857, -2.1260624, 3.2486172, -1.3967724, -0.07511902, -1.7228298, 2.7355194, 2.352686, -0.35149193, -3.0441246, 5.234226, 0.516407, -2.4538574, 2.4932709, -0.5061016, -5.1532383, 0.62908554, -0.81324387, -2.8069859, 2.3674698, -1.321125, 0.8995552, -1.7823181, -1.0506783, -0.46593475, -0.49096298, -1.9572983, 1.926405, -1.4353142, -2.615322, 2.4716473, -0.49429703, -2.858694, 2.4379883, 2.4733505, 1.5379562, 1.26684, 0.3903885, -3.906765, 3.147478, -1.1402817, -0.32440567, -2.9425201, 1.7422333, -1.8347912, 1.3389664, -0.06999016, -1.2932568, -0.3349514, -0.3107376, -0.86047363, -0.18986511, -1.3543472, 0.48900795, -0.35136604, -0.16698456, -3.3465767, 2.776287, 0.6697235, -3.0751266, 4.1773033, 2.2404175, 3.3817768, 0.36198425, -3.112194, 4.2445564, 1.2884254, -1.2381973, -3.1532803, 1.5238991, 1.3071098, 0.9818344, -1.3976269, 0.56733704, -1.6439915, 2.2521381, 0.6133232, -2.7177162, 3.3330956, -0.6815815, -2.314846, 2.2324944, 2.0118923, 0.5348129, -4.919922, 0.889843, -1.302782, 2.443821, -0.7913666, -1.7298546, 0.7984848, 0.5415516, -0.70000076, -2.2112427, 0.70095825, -1.40699, -0.064798355, -1.9855156, 0.31833458, -2.003008, 2.6354523, 1.1746311, -0.79179955, -0.06411934, -2.0360832, 2.5498772, 0.37176132, -0.17871666, -1.4126587, 0.42895317, 0.13027954, -1.0183334, 0.15672302, -3.8528404, 2.9963284, 1.3830528, -0.55400276, -0.88856125, -2.2901, 3.902687, 0.59698296, -1.9143448, 2.053728, 2.3484802, -0.31960678, -3.740017, 1.8083534, 0.107278824, -2.807045, 4.9716263, 1.1205826, -0.8644829, -3.9314308, 2.532631, 0.5530777, -1.9505157, 1.5411472, -0.08450127, -2.3396034, 2.3147678, 1.370842, -0.033189774, -4.8041744, 1.1939659, -0.99005127, -1.2137108, -1.688961, -2.0043163, 0.25712204, -1.7323494, -0.16025162, -0.997036, -1.4458828, 0.88614273, -0.35792923, -2.1717625, 1.6551208, -2.0735855, 0.8628197, -0.9292183, -0.6778641, -0.1500206, -1.2956696, -0.11624527, 0.21170044, -2.4435158, 0.8821335, -0.54364014, -1.5248165, 0.023021698, -0.203516]\n",
    "# U_list = [2.3043175, -6.3257446, -6.9290686, -4.2645273, -4.880657, -5.8078403, -4.1832275, -3.6776085, -4.3169003, -6.13225, -4.5113163, -3.9562817, -5.104162, -3.868742, -6.0242615, -2.1049461, -4.4905663, -4.5087223, -1.7489433, -2.312027, -3.863636, -4.25601, -5.44322, -1.9265442, -4.9205866, -5.3553343, -4.6825504, -3.5638294, -2.4738712, -6.5351152, -2.6550503, -1.4986668, -4.3056736, -1.8673344, -4.403119, -4.431529, -2.461216, -0.8508415, -5.1426897, -2.9595585, -3.3642883, -3.715866, -1.5763493, -6.1288157, -0.67268944, -2.5177135, -5.3989105, -0.003288269, -2.4617233, -4.1197624, -3.6089783, -2.165842, -2.6746578, -3.4534626, -3.5961838, -2.0261345, -5.0191774, 0.65927505, -0.20858192, -5.124504, -0.027280807, -2.830759, -2.1533508, -4.012972, -1.1180859, 0.16564941, -5.6331816, 2.7770805, -3.3205261, -3.4148693, 0.83437157, -3.0814266, -0.5408859, -3.7865715, 0.52809906, -4.368313, 1.2461376, -3.9673653, 0.9545212, -2.9815216, 1.4913673, -4.583229, 0.6496067, -2.3996773, 0.9768753, -3.4784203, 2.592453, -1.1647034, -3.5382004, 1.4275398, -3.5302982, 4.5303516, 2.244318, 1.5411148, -1.5957146, -0.794075, -2.4849396, 2.9490852, 0.88433075, -2.8018208, 2.843092, 2.7188911, 1.9426842, -0.6451473, -4.033787, 2.8993187, 0.02453804, -2.8861122, 1.4799767, 1.883524, 1.1135826, -0.3094902, -2.4326801, 1.2312012, -1.2240028, 0.09371185, -1.056921, 1.0537834, -1.5855579, 1.4197922, 0.23587036, -0.6939888, -1.8151608, 2.3367386, 2.3783855, 0.69740295, -1.1847763, 1.0937996, -1.1862488, 1.6497498, -0.8284817, -0.23228836, -0.87473106, 1.3156166, 1.1150589, 0.7319298, -1.0408573, -0.073524475, -2.419117, 2.7914047, 0.39082336, -1.0115471, 1.5608635, 1.1576252, -0.4474144, -2.8857517, 0.86733246, -1.1740704, 0.8255024, -1.3551979, 3.094677, 3.2217312, -1.5469017, 1.9330673, -1.1599941, 1.1962872, 0.1113987, -1.9002686, 4.623041, 2.5316048, 0.043785095, -4.8741713, 1.6196442, 0.44849586, -2.9057503, 3.3668804, 0.08792877, -4.0263004, 4.264288, 1.1464787, -1.1473751, 0.3087616, -1.6334934, 3.0214787, -0.39128494, -3.7094345, 0.7053795, -1.5004902, 2.7690735, 1.2009354, 0.43388557, -3.433857, 2.087963, -1.4883194, 1.5567627, -0.5758953, -2.4239788, 4.016472, 2.0788498, -1.970581, 2.0995865, -0.5994053, -3.1150417, 2.3295994, -0.30679703, -2.6673775, 0.8427639, -1.3287582, 0.062294006, 0.038316727, -3.2700615, -1.3519993, 3.0107384, 1.3150501, 0.7848091, -1.1103401, 2.2666645, -0.48093414, -1.7732639, 5.2609024, 0.72846603, -0.68097305, -2.6189213, 1.8311596, 0.80126, -0.3876953, -2.218504, 3.0650158, -0.33592224, -3.1948433, 1.305088, 1.3032799, -0.82382965, -1.164341, 4.1946297, 2.9978142, 2.5909996, 1.5009575, -1.7825203, 2.8389626, 2.2779007, 0.5140896, -4.112234, 2.4064922, -0.34029388, -0.15808487, -2.38517, 1.8034649, -0.9948864, -0.6517391, -1.0281715, 2.1402092, -2.321619, 4.2028027, 2.8831062, 2.804264, 0.9369087, -1.544487, -1.2122593, 0.950531, -0.10784912, -1.5956593, 1.0522289, -0.8613434, -2.2209377, 3.6417847, 2.4968166, 0.5231304, -5.081156, -0.37160873, -0.74502563, -1.833189, 1.7015305, -0.8271332, -1.5264759, -0.7655964, 0.5561924, -3.0638885, 1.6309471, 0.5349941, -0.6319065, -2.0252151, 1.9752579, -0.25193024, -1.1103878, -2.1745644, 3.3801231, 1.6890335, 0.4959793, -3.2989101, 3.0163555, 2.216833, -0.31700325, -2.5222511, 3.073227, 0.13843536, -2.5650864, 4.0464, 0.8184929, -1.6163177, 0.21280289, -1.4217834, 0.79322815, -2.0272331, 1.9353771, 1.0415058, -1.6032295, 3.1001701, 1.7739849, -0.4240284, -3.590477, 2.561617, 1.8752213, -2.204815, 2.802908, 0.5072937, -2.2164307, 4.2933846, 0.24629974, -3.4906616, 3.1807518, 1.8780556, 1.2152843, -0.14683533, -2.2929077, 2.6522865, -1.0135288, 0.20106316, -2.1550922, 2.7079315, 0.9889755, 1.1495285, -0.90464973, -1.3329735, -0.6880398, -1.226696, 0.1560688, -2.237011, -0.25709724, -0.41118622, -0.3762455, -0.8345108, -1.960949, 2.9127789, 0.23052597, -2.6674652, 1.7430954, 0.24331665, -2.9790726, 3.5753918, 2.7620792, 2.9108047, 0.0034255981, -3.1818333, 2.0353146, -1.2338524, -2.9573936, 4.183552, 1.9926567, 0.5788803, -3.3482933, 3.7218933, 1.1700478, -2.9094162, 2.1485558, 0.7581234, -0.6711464, -1.2875042, 0.2509079, -1.7590809, -1.1402225, -1.6216965, -0.75348663, -0.76044464, 0.023448944, -0.35749817, -2.7206879, 3.4042664, 0.12117767, -2.052578, 1.9833736, 0.5524292, -3.3651543, 2.0073872, -0.128479, -3.0201874, 2.3057709, -1.2070122, -0.8033085, -2.125393, 2.028139, -1.5748615, 0.7313423, -0.3468151, -3.5583038, -0.13629532, -0.3643303, -1.7882328, 0.60575867, -1.4923325, -1.5097084, -0.025579453, -1.4683895, -1.21274, -0.60974884, -1.9534016, 2.724949, -0.28505135, -3.5025826, 2.916441, 0.5966263, -1.5904846, -1.279871, -0.32746315, -0.37517166, -1.0507526, -0.30418015, -0.6545944, -2.8348942, 1.313385, -0.005552292, -3.7842903, 0.7934036, -2.209217, -0.020824432, -2.9278316, 3.0937805, 1.0271797, -2.2836723, 1.6029549, -2.579773, 2.1282501, -1.6157169, -1.1645603, -2.2883167, 1.3404446, -0.87088776, -2.4947796, 1.0940704, -1.5023975, -0.9048519, -1.8563423, 1.4314041, -1.0241299, -1.7663498, 0.8846512, -0.5340595, -2.3361034, 3.3132915, 2.581421, 0.8960686, 0.4350052, -1.4645367, 1.4148293, 0.59934616, -4.2736387, 2.3356056, 0.5419426, -2.9178848, 4.1083145, 0.61501694, -0.72746277, -2.3004265, 2.9050846, 1.1552715, -0.22118568, -1.4562778, 2.6111813, -0.74103546, -3.722927, -0.1271286, -0.5445709, 0.40755463, -0.7550831, 1.0286598, 0.36592484, -2.8844604, 4.4659405, 2.8264084, 2.9680538, -0.4380951, -3.4010296, 2.8748608, 0.6719551, -2.8369713, 1.5818634, 1.3952274, -0.01219368, -3.6558685, 1.4043999, 0.3493576, -1.6382732, 0.3001976, -2.1723156, 2.990612, 1.0181904, -0.70980835, -1.0580387, -0.8335705, 0.09680939, 0.012325287, -1.3037033, 0.43276787, -2.5457191, 2.7378254, 2.0711899, 0.72278595, -3.003708, 2.9584408, 0.06385994, -3.2536201, 2.575695, 1.6327457, 1.3505058, -0.40115547, -2.9894009, 2.634449, 0.5836983, 1.419136, 0.14725876, -3.6451397, 2.9345016, 0.6501789, -1.6578941, 2.0852451, -1.5931587, -0.26455116, 0.36896706, -0.99954987, -0.52997017, -2.3935127, 1.6406517, 0.26052475, -2.3276138, 4.70467, -0.44644928, -3.8202934, 2.0617714, -1.6538467, 0.3678913, -1.91469, 0.19579124, -1.8685684, 0.15049744, -2.6609573, -2.2646103, 1.8347187, -1.4272995, 0.26097488, -3.2832947, 4.1502075, 1.8494015, 0.36951828, -0.95786095, -0.42049026, -2.3065987, 3.1657505, 2.6867485, 1.1733055, -0.39058495, -1.9262924, 1.8057346, 0.13195801, -4.5385056, 1.456543, -1.200489, -1.40411, -0.60409355, -2.1721592, 1.1088543, -1.79393, 1.1192589, 0.0758934, -1.798727, 1.1561394, -1.7176857, 0.48646927, -3.293579, -0.2059288, 0.28831673, 1.2830334, -1.4923649, -0.6816311, -1.3525562, -0.8038769, -0.7731323, -1.4344769, 0.26379776, 0.60746, -0.5121212, -3.6387596, 3.2145042, 1.3373108, 0.93136597, -1.6111393, 3.5411549, 1.2367401, -1.0628529, -2.7698708, 1.8114662, -0.7437401, -2.9510098, 2.7624016, 0.21240044, -3.0946503, 1.2852879, -2.8223648, 1.5803947, 0.49080086, -0.19944572, -0.88591003, -0.8817215, 0.40053368, -2.1061954, 1.5808697, -2.7423325, 2.1490974, 2.4618683, 0.76039314, -0.9987316, -1.0620499, 0.061462402, -0.762228, 0.71883774, -1.7441235, 0.19240189, -0.69306564, -1.1228218, 0.6772766, 1.2914963, -0.7710533, 0.17524338, -3.352005, 1.9627972, 0.60759354, -1.1984138, 0.84305763, -0.9465294, -1.9759579, 3.5872478, 0.5089588, -1.5802078, 0.7486954, -0.6574421, -0.32476616, -3.9492378, 2.2695045, 1.2298374, 1.1458244, -1.2986946, 0.38115692, -2.0482235, 2.1127586, 1.3046799, -1.1990585, -0.92285347, 0.19392014, -1.3645382, 1.7431164, 0.8772049, -0.753706, -1.2768478, 2.3035545, 0.72790337, -1.0356197, -0.8497696, -2.7706604, 1.5696888, -0.7365532, -0.12452698, -3.238657, 0.67007065, -1.0598793, -0.008867264, -2.31147, -0.29077148, -1.1211033, -0.14230347, -1.8621216, 0.015968323, -0.57421875, -1.9818974, 3.0224113, 0.30127525, -3.233677, 0.44499207, -1.0803871, -0.72566795, 0.29653358, -2.1187763, 1.5531616, 0.62991333, -1.4825249, 0.99746513, 1.065567, -1.1533871, 0.7280235, 1.1290569, -1.2580738, 1.3351231, 1.5292454, 0.52820206, -1.9401894, 2.566145, 1.4812698, 1.26478, 1.6470623, 1.9321442, 0.58062744, -0.054430008, -4.15689, 1.2016449, -1.5295143, 2.3954983, 1.8090229, 1.1302395, -0.43712997, -2.8979778, 2.235754, 1.0635395, 1.7535877, 1.4852543, 1.1286335, -0.65192413, -3.3087559, 2.690752, 0.37607574, -0.100666046, -2.261547, 3.1469154, 0.98046875, -1.0845566, -0.5272026, -0.70609856, -2.4734955, 2.1958008, 1.4670353, 0.31559944, -3.7526588, 3.0743523, 0.976408, 0.6820259, -2.443388, 2.6772766, -1.1457386, -2.1575527, 4.733391, 1.7512779, 0.9011116, -2.1648674, 1.9644566, 0.83771706, -2.1564655, 3.2254887, 2.3803558, -0.22063446, -5.266925, 2.9184074, -0.01685524, -4.0009546, 2.6401806, 0.586462, -3.6727867, 1.2636604, -1.4055557, 0.258049, -0.9262314, -2.2836342, 0.7490349, -1.7061844, 2.543356, -1.1119576, -1.3499069, 2.4722443, 2.4992962, 2.0241451, 0.38133812, -1.4538536, 2.9365883, -0.3583126, -1.4943542, 0.786232, -1.0214272, -0.3359642, -0.5306015, -0.8201008, 0.9291954, -0.32021713, -1.5620117, 1.7394409, 0.010402679, -1.2893105, 0.17932701, -0.2021389, -2.9203873, 2.4872398, 0.29762268, -1.3593826, 2.4121876, 0.6509094, -1.7344894, 2.477148, -0.1606369, -3.513319, 2.5061207, 1.5989609, 0.58660316, -2.7856445, 1.6326885, -0.06021881, -0.22312355, -2.9077988, 4.3856983, 2.1052895, 0.4760399, -1.824213, 2.4164486, -0.4467392, -3.212925, 2.9230843, -0.6015053, -3.7926064, 0.46601486, -1.3045883, -0.7033043, -1.2559929, 0.32229233, -1.4327469, 1.4425125, 0.44995308, -3.944065, 0.16630554, -3.2183495, 2.095911, 0.9145527, -0.024776459, -4.0215855, 0.5686188, 0.48863983, -2.1705017, 1.7392159, 0.49471283, -2.5894375, 4.096279, 2.5243683, 2.9016266, 2.0272484, 2.2897987, 3.5296745, -1.4402237, -0.5096359, -3.2292843, 2.4126015, -0.4555111, -2.325035, 5.309725, 2.116066, 2.7594662, 0.3618145, -1.3689709, -1.7252979, 1.3918648, -1.1944752, -1.2882004, 0.8950043, -1.6823311, 0.93875504, 1.2565918, -1.0734882, -3.5359402, 2.2654877, -1.0760803, -0.8317795, -0.87036324, 0.80833054, -0.58228874, 0.048610687, -2.337059, 2.2762108, 0.9354477, -1.2433605, -0.3169613, 0.7297878, -0.1577034, -0.45596313, -0.3324337, -1.2863274, -0.61239624, -0.41462135, -0.86351204, -0.094106674, 0.691391, -0.84820557, -1.0195408, -3.2534008, 1.9652023, -0.3135662, -1.1893559, 1.0581322, -0.53731155, -0.681551, -2.7878342, 1.1688385, -1.1277866, -1.4792995, -1.5342541, -0.4098587, -1.8697929, 2.681244, -0.98571014, 1.0922661, 0.3927307, -2.5953255, 5.267973, 3.3677082, 1.2352638, 0.41402435, -3.674614, 3.562313, 1.2093315, -1.8818111, 0.22900772, -1.0753994, -1.9812317, 1.4172955, 0.9187622, -0.45833206, -1.8251781, 2.2161503, -2.835287, 4.507559, 2.9295387, 3.033598, 2.0826569, -2.3634453, 1.2225266, -3.649397, 1.5855389, -1.0934715, -2.9811878, 2.8931637, 0.8880768, -1.2305756, -1.1795616, -1.2918587, -1.8397655, 2.7070084, -0.14245224, -2.327488, -1.8544865, 3.2788677, 0.013933182, -2.6951733, 3.2612228, 1.2308598, -0.22166824, -5.0704746, 2.2216892, -1.8782196, 0.26330185, -2.1428947, 2.047987, -0.26410484, -2.5511456, 3.272173, -0.23358154, -2.5190487, 1.5920715, -1.0248909, -2.5879688, 1.9031143, -0.97784233, -1.3066063, 0.1698761, -1.8006363, -1.6166515, 2.0823765, -0.2356224, -1.4878922, 0.8944092, -1.3173637, -0.66778564, -2.5786, 2.5158463, 0.64801216, -1.7370281, 1.7829914, -1.8565903, -1.66922, 0.15739632, -1.0836334, 0.78089714, -1.1245956, 0.9128494, -0.30175972, -1.6275005, 3.0141945, 1.1505127, 1.4745102, -0.33296204, -2.367075, 4.192318, 0.081703186, -3.6477108, 1.8443565, 1.0573349, 0.03586769, -3.0657654, 4.735523, -0.48163605, -3.4951382]\n",
    "U_list = [1.6064452, -8.151268, -1.8868408, -6.9291067, -1.2593479, -2.4463406, -4.1774445, -4.2193108, -3.1020699, -4.115076, -3.9334774, -5.3141785, -3.7813625, -1.1069527, -5.3608847, -1.8574314, -5.380149, -2.737503, -4.1169357, -4.261364, -2.5365486, -2.3514194, -4.131255, -5.286045, -1.635191, -4.1607, -2.088997, -3.6219215, -3.8170528, -2.2900486, -2.6704865, -3.1524372, -3.1507072, -1.3452244, -2.8303967, -2.7371407, -2.5296612, -2.5457935, -3.0574532, -4.0096035, -0.7879505, -2.1757755, -4.31898, 0.8517761, -2.4351273, -1.6693306, -2.2660732, -4.3969297, 0.5593853, -2.4454613, -2.310135, -1.8987675, -0.81523705, -2.0939827, -2.569725, -0.6923771, -1.8800793, -2.3717632, -0.7055836, -3.1352234, 0.65403366, -1.90518, -1.8833256, -1.1466923, -0.04565239, -2.21027, 0.41195107, -1.1065769, -4.254339, 1.7920876, -2.3367329, -0.16506958, -0.8205013, -1.9716206, 0.40616035, -2.2434006, 1.6915874, -2.4324646, 1.3827515, -2.2241821, 1.1479206, -0.98736, -0.43003845, -0.98283005, -1.8989143, 2.2827606, 1.2820339, -0.3115921, 1.0201283, -2.426117, 3.15588, 0.7604065, -2.1149426, 3.8591766, -1.0048828, -1.4706478, 3.3899326, -1.3621483, 0.8535309, -0.71481705, 1.0243721, -0.44229698, -0.41253662, -0.40584564, 1.4280128, 2.000723, -1.5394802, 3.342804, -0.8766098, 0.45294, -0.04450798, -1.4593277, 1.2203941, 3.0718575, -0.607008, -3.004757, 4.0013905, 1.453516, -0.550333, -4.541936, 0.73451996, -0.44782448, -0.87794113, 1.7544403, 0.3935833, 1.0235195, 2.0903625, 0.059581757, -2.5489635, 2.3546124, 0.79068375, -0.010942459, -2.1160107, 2.5251179, 2.9494934, -1.2543716, 0.6393261, 0.4802208, 0.13187408, -1.0104942, 3.3110218, 1.4489574, -1.6040306, 2.9365997, 1.504261, 0.605917, -1.1593037, 2.1836643, 0.35915184, -2.1202545, 2.6303844, 2.8531456, 0.35886955, -1.009615, 0.5926933, -1.106596, 2.3586044, 2.2230625, 0.07052994, -1.727356, -0.29154396, 1.1477699, -0.052013397, 0.027570724, -3.6004047, 1.2073879, 0.84010696, 0.4382801, -0.21163177, -3.4479485, 0.44414902, -0.7120514, 1.0159531, 1.3572922, 0.27921295, -0.38990974, -0.5085659, -2.7683907, 3.4098148, 2.3965683, 1.0306015, -1.4134178, 1.7716007, -1.0035973, 0.7639408, -2.8154907, 1.251709, -1.5732231, 3.1013603, 2.6538582, 1.0823479, 1.0610161, -0.3792057, -2.8318233, 1.9622688, 2.6031475, -0.65232086, -3.4477425, 3.0382366, 1.1912422, -0.027742386, -3.9309597, 1.3463421, 0.12968826, -0.6025963, 0.5591793, 0.44521332, -1.0186367, -0.28468895, 0.5338383, 0.05578804, -0.96466255, 0.6030483, -1.2759876, 2.0505695, -0.78385353, 1.0142021, 1.1968765, 1.6902771, 1.4135551, -0.23025131, -2.8162842, 1.46105, -1.8996601, 2.320549, 1.5673447, -0.21484756, -2.7003326, 2.081417, 1.4314651, 1.8733425, 2.4589806, 0.6880665, -1.8759727, 0.24978638, -1.1143188, 1.8735809, -0.03651619, -1.9166946, 2.421585, 1.523447, 0.073358536, -1.6578407, 2.9775734, 1.563118, -0.8110676, -0.7713833, -1.408392, 5.8055897, 0.31849098, -2.9746513, 2.7414742, 1.1796646, -0.85015106, -2.347702, 3.9205627, 1.7911568, 2.059328, 0.6247997, -1.8008308, 0.08601189, -0.32428932, -1.3025875, 2.5220413, 0.92458344, -1.310236, -0.4409237, 1.6452408, 1.5562401, -0.0197258, -3.925169, 2.5789871, 1.146843, -1.7217102, 1.9875526, -1.1424999, -1.2373142, -1.0565205, -0.31189156, -1.9993019, 2.4208145, 1.2769127, -1.5791416, 2.9297562, 1.1676598, 0.19282341, -2.043501, 2.8237247, 0.92224884, -1.3450832, 0.091192245, -1.6156025, -0.14400291, -1.2404995, -1.9549828, 2.3970318, -0.43361855, -0.21763611, -1.6876011, 1.6186752, 0.5380821, -1.7038174, 1.3009415, -1.6742535, 2.2444553, -0.3243618, -3.2269363, 1.0502338, -0.17341614, -1.8294888, 2.8223705, 0.09826851, -2.8703003, 3.3945007, 2.773796, 1.3205318, 2.2014065, -0.94026756, -3.460186, 2.0458431, -0.5685539, 0.756979, -2.9721107, 2.3134727, 0.037517548, -3.0830593, 2.1190681, 0.55794144, 0.06309128, -2.8695068, 1.8809776, -0.94576645, -1.3287716, 1.0224991, 0.13904762, -2.780283, 3.565548, 0.41297913, -3.1213875, 3.8318615, 0.99027824, -1.8573551, 1.2686749, 0.35354805, -5.1910706, 2.564701, -2.1761818, 1.5043793, -0.18152809, -2.132166, 2.980095, -1.2316017, -1.140377, -0.82411766, -0.29580498, -1.9211483, 0.6097584, -1.4322414, 2.2716522, 0.88264847, -0.10131836, -1.2257214, 0.825861, -1.0770264, -1.2679081, -1.549057, 1.1686878, 0.7077675, 0.6237583, -0.06593132, -2.2315483, 1.1493874, 0.28627396, -3.354313, 3.1930618, 1.0012417, -1.9467163, 1.5437031, 1.235012, -3.1547146, 1.871952, 0.3035698, -0.92416954, -1.6153889, 0.96928596, 0.71268463, -1.6820316, 3.4716244, -0.075481415, -3.9186344, 2.8488503, 0.71136665, -1.4667473, 0.44695282, -1.5092163, 0.56733894, -0.9288063, 0.32638168, 0.95197296, 0.067502975, -3.8508892, 1.3372192, -1.7721081, 0.9050484, -0.9283905, -0.05823326, -0.2763939, 0.71886444, -0.506855, -0.22203064, -2.3887901, 3.3743286, 0.6296387, -3.0444183, 3.4711914, -0.6709175, -0.8641262, -0.42697716, -0.8758106, -1.2864132, 2.0422287, 0.15708733, -1.9732895, 2.7385292, 0.16021347, -2.5637665, 0.85663795, -0.5585251, -3.2517662, -0.30491257, -0.84191895, -0.84685135, -1.2698002, -0.22443771, -1.8656006, -0.3587551, -1.771534, 0.43353653, -2.3825893, 1.5085258, -0.29648972, -1.165863, -0.80827904, -2.5428505, 1.0318012, -0.914299, -0.8618431, -2.551281, 2.6218624, -1.0628052, 1.1082554, -1.0431786, -1.0672531, -0.9493294, -0.50536346, 0.46581078, -0.5905342, -2.4088593, 2.658041, 2.8599758, 2.1589947, 1.0811977, -0.8193855, -2.5073204, 3.631691, 0.6037407, -3.1047745, 3.6713486, 0.0709877, -5.065365, 2.855259, 0.7044773, -2.118328, 4.1790657, 2.810936, 2.0790176, 0.023891449, -5.8984356, 1.862854, -1.2566395, -0.0633831, -3.0308132, 2.3043041, 0.8347721, -0.27960205, -1.7802715, 2.1637535, -1.1619205, -0.11480713, -2.693348, 2.1345806, 0.35885048, -1.3571167, 1.8910675, -0.6244011, -2.4061413, 2.4292717, -0.36460114, -1.9318562, 2.5334148, 2.6539764, 1.592205, 0.9537277, -1.8899422, 0.7974434, -0.7682133, -2.7621422, 1.817833, 0.66542053, -1.1144619, -1.8957901, 3.9793282, 2.6715584, 3.0102081, 0.8639889, -2.8729916, 1.4678802, 0.9296684, -3.2123833, 2.200756, 1.8208351, 0.60783577, -2.5358238, 1.5923195, 0.64663315, -2.3585815, 3.3033714, -1.6724167, 0.8274174, -1.4398174, 1.7628498, 0.9044914, -0.8095474, -2.015545, 4.6520634, 1.8225136, 0.6780224, -3.7848625, 1.4290524, 0.2520008, -2.3888206, 3.01116, 0.52656364, -0.25712776, -2.3094902, 2.2089348, 0.9735203, -0.0978241, -1.5977993, 1.8504143, -0.9090576, -2.6488667, 1.5705147, 0.53474426, -1.3546429, -0.7289028, -1.0858765, 0.8829613, -0.066949844, -1.1204224, 0.31084442, 0.55493927, -0.17827797, -2.9928188, 1.114914, -0.06946564, -1.6664524, 1.4067192, -1.7706375, 0.82203865, -0.034812927, -2.5695896, 3.7684097, 0.98327637, -1.0538216, -2.4054775, 2.6873608, -0.36592102, -3.017599, 2.6463528, 0.11979866, -4.606434, 2.3779583, -2.6131382, 2.6205654, -1.8861313, 0.6759243, -1.2673988, -0.8306904, -0.43166542, -2.3456078, 1.7083893, -1.4108639, -1.262495, 1.3177013, -1.6199589, 0.12669563, -0.51350975, -0.9395752, -0.6656723, -1.6621609, -0.685379, 0.107048035, -1.3554897, 0.1613884, -2.5982761, 0.9845257, 0.9479294, -1.6739826, 2.2540112, 1.3325157, -0.30815697, -0.6811447, -1.2309914, -1.4428349, 0.29626656, -2.9974842, 0.945776, -1.6998138, 1.0322342, 0.94276047, 0.40670395, -1.4759521, 1.6716747, -1.3504238, -0.6223068, -0.6693039, -0.67783356, -0.45512962, -2.3517437, 2.9498482, 1.3328209, 2.1205864, 1.9486923, -0.628994, -2.6867065, 2.3912048, 1.5152817, -0.58706474, -1.233221, -0.1317749, -1.0758438, 1.8303032, -0.64115715, -3.0354347, 1.5884132, -1.1179771, -0.4119854, -2.1369057, 3.9682198, 2.24889, 1.2606125, -0.728672, -4.1176033, 0.76517296, 0.2979107, -0.37864113, -1.1056004, 0.47110748, 0.064928055, -1.8165264, 2.3244572, 1.943636, 1.9837189, -1.2223015, -1.8602905, 1.3841228, -0.39362526, -3.1179695, 1.5682297, 0.9257221, 1.5241776, -0.20759773, -2.796463, 4.7428284, 2.1906853, 0.30919647, -2.0422764, 1.7974358, 1.376152, 2.5055466, 0.77334404, -1.3678665, -2.548788, 2.9731178, 0.54652214, -2.6655445, 2.671482, 0.46767235, -2.9572983, 1.3442078, -1.9229088, 0.40764618, -0.19021988, -0.5308666, 0.45410156, 0.37921715, -0.99593735, 0.6099529, -0.8132725, -2.4539146, 2.4125366, -2.1795158, 0.44918442, -0.56134796, -1.2026119, 0.15231705, -0.9564152, -2.0527267, 2.354313, -0.6611271, -1.132206, -0.59716415, -1.0173721, -0.5762501, -0.37734032, -3.3498611, 1.8388367, -0.6099663, -0.8955841, -1.2553196, -0.19285011, -1.1472282, 0.4428959, -1.1125965, -0.39705658, -2.2942715, 1.7996254, -0.8872547, -2.3341198, 2.0823307, -0.058914185, -0.81842804, -1.3479271, -0.82040405, -0.3032093, -1.8084412, 0.5485172, -0.7994633, -1.553196, 2.0553055, 0.15650177, -0.52399063, -3.7958126, 1.2894287, -0.81809616, -1.4889774, 1.1239414, 0.970747, -0.076334, -3.662302, -0.9244175, 1.1316128, 0.28058624, -2.6411648, 2.6805077, 1.0578537, 0.29498672, -2.4192886, 2.5257893, 1.0077972, -0.27085114, -3.322403, 2.070118, 0.013465881, -1.6675873, 2.5604725, 1.4892311, 0.5980892, -2.9516945, 1.5798779, 1.1813889, 0.7848854, -0.75299835, -2.0364914, 0.1461792, -1.1820068, 1.4889927, -0.06896019, -2.56287, 3.2167454, 0.96450806, 0.9901829, -0.3082962, -3.4713078, 0.77817917, -2.343134, 1.9286728, -0.76873016, 0.19366074, -2.1449432, 3.2090073, 1.7643242, 0.75704956, -1.3742905, 1.7437363, 1.7585411, -2.670805, 2.377081, 1.5573101, -0.21515465, -4.8905487, 1.62146, -3.1533833, 1.8759346, 0.04825592, -0.9311943, 0.3813057, -2.659998, 0.39873505, 0.40555763, -2.3911457, 0.16301918, -0.021814346, -0.3843422, -2.387661, 1.9207077, 1.4445972, 0.7290039, -0.96847534, -2.0108433, 4.20446, 3.1892757, 1.8050308, 1.5964031, -0.009889603, -2.9983597, 3.3372097, -0.30251884, -3.9095917, 2.0873947, 0.35571098, -0.7845726, -0.49699593, -2.6238537, 1.5802994, -0.36330414, -1.415245, 3.721712, 2.2385788, -0.26329803, -1.3890171, 0.47923088, -2.092167, 0.11228371, -0.10584259, -0.4986744, -1.6062508, 1.8998909, -0.11145973, -2.4141674, 3.9632874, 0.79013824, -1.6091557, 1.0722713, 0.22151756, -4.131031, 2.7273655, 1.030941, -1.3552322, 0.48623085, -1.249939, -0.86888695, -0.004142761, 0.038463593, -2.036354, 4.5624046, 3.4104004, 1.6072388, 0.28165627, -3.0273476, 3.593729, 0.24781036, -0.47162056, -2.6104507, 4.2926292, 1.513834, -0.007949829, -3.8972874, 2.7105236, -1.0960693, -0.40934753, -1.0312634, 0.7497959, -0.1097641, -2.4789333, 2.7526245, 1.4763794, -1.8607368, 0.87441254, -2.1088867, 0.96577644, -1.0338593, 1.2049007, -0.8293438, -2.4337502, 1.9202652, -0.23840714, -3.3267975, 2.0067806, -1.1739864, -0.8531914, -0.23381042, -1.1195221, 2.1099834, 1.3946819, -0.04527664, -4.546337, 0.16015244, -1.768673, 1.3890686, -2.760355, 1.8744507, -0.4229374, -1.336338, 1.2092743, -0.021446228, -2.5435696, 4.2186966, 2.138153, 1.3584614, 0.48557472, -2.7927551, 2.1956177, 2.1064568, -1.2062111, -1.2003708, 0.20334625, -1.031601, -0.14598274, -0.94574165, -0.1985054, -0.69481087, -3.4360733, 1.8442154, -0.609663, -2.3979397, 2.137003, -0.16243172, -1.6181011, 1.0137367, -0.631279, -2.3990479, 3.5812416, 0.44966125, -2.1961422, 3.1758976, 1.9485359, -0.72766876, -1.6366596, 2.3772736, 1.5954666, 2.5702133, 2.249031, 1.217268, -1.8069115, 0.627182, -2.8458157, 3.3542347, 0.69830704, -3.4687366, 2.2840328, -0.9438305, -2.669918, 2.1388817, -1.4287071, -1.8016319, 0.6338215, -2.4272175, 4.075344, 2.9089909, 0.1199379, -2.9563122, 2.5002632, -0.12691116, -3.4079456, 3.3844147, 2.1474743, -1.1441803, -1.4745197, -0.43070984, 1.0037003, -0.93450737, -0.4926834, 0.29037094, -0.4343109, -0.8223648, 0.03781891, -1.9629765, 1.8914223, 0.021343231, -1.7808342, 1.2988052, -0.59448624, -1.9560738, 2.047369, -0.07988548, -0.2936535, -3.3970127, 2.3369617, 0.8053932]\n",
    "# U_list = [1.5527567, -5.5753593, -4.878807, -4.314396, -2.7212486, -4.446451, -4.7020254, -3.8046627, -5.0218916, -2.9026623, -5.615802, -2.9816437, -6.185377, -1.9110756, -3.7507992, -2.4864807, -3.2342243, -3.9716225, -3.7994347, -3.4314995, -4.276911, -2.796217, -3.5194302, -3.5034065, -3.701212, -1.6647873, -2.6678638, -3.6926098, -2.1289463, -2.3961163, -3.0700684, -3.725298, -4.299658, -2.3564415, -2.3968735, -1.7860851, -3.3848686, -3.450924, -0.3191738, -3.7683105, 0.0019683838, -2.4895477, -2.7973442, -0.7047539, -2.3474598, -0.11876297, -3.6058083, -3.2733688, -1.2793503, -1.6953506, -2.2783432, -3.4727325, 1.3280144, -2.7848148, -1.8957958, -2.1532478, 0.18836784, -2.247507, -1.5626907, -2.3130836, 0.52833366, -2.221365, -2.1576824, -0.20820999, -1.3472195, -2.2188072, -1.1508064, -1.0759583, -1.4333744, -0.45461655, -3.7856445, 2.5433064, -3.147503, 4.463028, -2.5925617, 0.8186455, -3.0772705, 3.0619793, -1.3610001, -1.2514648, -0.45560455, -2.149063, 2.5813751, -1.1098518, -0.7092056, -0.83716583, -1.4162331, 0.3731575, -0.98869514, 1.8245296, 0.063568115, -0.63456535, -1.6564674, -0.0051956177, -1.2882462, 1.2309227, 0.13904381, -2.6304264, 2.9922657, 1.1166, -2.581581, 1.5800705, -0.38671303, -1.0990505, 0.99054146, 1.3935375, 0.3276291, -1.1300831, 2.2902794, -1.5411816, 1.8219643, -0.37870216, -1.760767, 0.5492897, 0.24926949, -0.052171707, 4.1470795, -1.9962158, 3.1201515, -1.8874359, 3.524849, -2.6083221, 2.9434586, -0.975832, 0.20416641, -1.4607105, 2.35878, 1.5259323, 0.019954681, -2.9864044, 3.3590126, 1.3187561, -2.3390408, 3.269081, 0.5141487, -2.3996544, 0.8592758, 1.2049141, -1.4999905, 2.4830418, 2.752779, -2.6394348, 2.8281498, 0.030633926, -1.2172184, 2.781559, -0.88770866, 2.5361366, -0.3505516, -4.406267, 2.127201, -1.1866112, 1.3853989, 1.360302, 1.3249779, 0.6863327, -0.5837116, -1.5024586, 1.172142, 0.95435333, 0.007965088, -2.7534485, 0.58086395, -0.29107666, -0.68865585, 0.81934166, 0.226017, -0.9077053, 1.3828659, 1.7510414, 0.63624954, 0.6652603, 0.9563446, 0.48962402, -1.2327938, 1.4658642, 0.6451912, -0.50229454, -0.33763695, 0.58021736, -1.2845306, 0.19811249, 1.8940659, 1.5549583, 1.5104771, -0.36384392, -4.5837507, 1.8506889, 2.1108665, 0.8472214, 2.7533722, 1.1559258, 1.49123, -0.2958145, -4.189152, 2.5621033, 1.1965714, 0.2805729, -2.118494, 2.1722908, 0.7099266, 0.73675156, 0.18898392, -2.000595, 3.1959133, 3.2645493, -0.5686588, -4.6651926, 0.67458725, 0.89894867, 1.4149818, 1.5879745, 1.9762249, -1.4180984, 2.75523, 0.061172485, -3.9265823, 1.6517849, -0.23404503, -2.7720718, 2.7312431, 2.1048927, 0.14505386, -3.3533287, 2.2502422, 1.1564522, 0.3653164, -2.448576, 4.2542477, 2.0466404, -0.21343613, -3.3547573, 1.3717823, 1.2855644, 0.77663803, -2.584526, 4.164999, 3.0522118, -1.6936798, 1.2034607, -0.13506317, -3.707964, 2.3835716, 0.08571434, -1.6130409, 2.8804035, 1.3677826, 0.770216, -1.0302181, -1.0949249, 0.3867073, -3.1756306, 2.8555965, 1.571167, -0.7340565, -2.265133, 0.35792923, -0.5797024, 1.0195827, -1.3194962, 2.4659576, 1.2989311, -1.4259186, 0.5347481, -0.76834106, 0.29836845, -0.599205, -1.6435509, 2.2778168, 0.67832565, -0.41015625, -2.2099228, 2.6471176, -1.269846, -0.11179733, -1.6458302, 3.8454647, 1.9181786, 1.311554, -0.5053978, -3.6480503, 5.7106934, 2.3152199, -0.59274864, -4.0937634, 2.5758553, 0.22735786, -3.5239582, 1.061039, -2.1435719, 1.701891, 1.1803398, -0.014690399, -0.9548626, 0.025161743, -2.6823654, 0.79862976, -2.9801636, 1.8431282, 0.5376797, 1.2059498, 0.47777557, -1.3720417, 2.1896458, 0.15080261, -1.9822807, 2.9546204, -0.17845726, -4.413784, 2.7515144, -1.2453365, 1.8068542, -0.88404274, -0.29384995, -1.9530468, 3.48954, 0.92411804, -1.7190895, 2.4241066, 0.24678802, -2.0728111, 2.106676, 0.037239075, -2.1741333, 2.920496, 1.4665203, 1.4377289, 1.0672417, -0.21687508, -2.606781, 3.0238914, 2.840248, 0.6549187, -1.7776356, 2.0142517, 1.0440426, -2.2527714, 1.7933731, -1.058094, -3.612461, 3.0638275, 0.83177185, -2.9832497, 2.0137558, -0.8443222, -1.2621727, 1.6719208, 3.1065464, 0.90743065, -1.352047, -1.8980179, 3.0681496, 2.751007, 2.8714638, 1.9971066, -1.2767944, -1.2500095, -2.242487, 2.5908318, -0.46038246, -1.39892, 1.4228554, 0.16815948, -2.4643364, 2.306858, 0.40619087, -2.7583694, 4.9130936, 0.97849846, -2.2519798, 2.2356014, 2.070881, 0.596159, -3.4796562, 1.5104141, 1.2094269, -2.111271, 3.125286, 1.3973789, 0.49954605, -2.6450768, 2.595684, -1.905014, 1.815424, -1.7382698, 1.8956165, 1.7742329, -0.9364586, -3.5648384, 1.8085403, -0.70892715, 0.8333397, -0.7855549, -0.09235191, -0.15599823, -2.3952923, -0.84731865, 1.5800667, -1.6161098, -0.14380074, -0.1703949, -2.2808895, 0.58997345, -1.3124046, -0.43185425, -2.0316925, 0.71328354, -1.3461838, -0.22787666, -1.9787865, 1.5000114, -0.1353569, -1.6176472, 0.7509594, -0.53910446, -0.13947487, -3.1412868, 0.49220657, -1.0816116, 0.051927567, -3.9083462, 1.2013779, 0.62841797, 0.18143082, -2.8052025, 3.1856766, 1.877346, 0.28335953, -4.6992645, 2.277256, 1.6734104, 0.75587845, -2.0539322, 0.056583405, -1.8406792, 2.9032936, 1.5025921, 0.9102211, -2.3982315, 3.0178528, 1.2915611, -0.44198418, -2.886507, 1.4753876, 0.9010086, -0.5212898, -2.14645, 3.082201, 0.37813187, -3.1948967, 5.104908, 3.3485394, 0.06491852, -3.2283802, 2.551609, -0.9540863, -1.2002907, -0.96004295, -1.4391975, -0.11929321, -0.88302994, -2.5506134, 2.047615, 0.66137123, 0.026853561, -1.7504711, 3.1300755, -0.5990906, -4.0258236, 3.4298325, 1.1010056, -1.1901932, -0.7804966, -3.2104778, 2.1898842, 1.04636, 0.8838177, -2.4328403, 6.0105553, 1.225193, 0.43364525, -4.38698, 2.615982, 2.9227161, 1.163868, -1.0548439, -4.4679737, 2.7035904, -0.018831253, -3.2853775, 1.4493752, -0.8861904, -1.2949924, -0.22107506, -0.61165047, -2.1678028, 1.8336105, 1.3342667, 0.16514969, -0.5576401, -1.2543259, -1.1069279, -1.4476471, -1.3478622, -0.2760868, -1.1491127, 0.007276535, 0.047424316, -2.7098026, 2.2427216, 1.0627632, -1.666872, -0.68104935, -1.5342846, 0.77882576, -2.4739742, 2.2350483, 1.5313148, -0.4622631, -1.922512, 0.32411766, -1.8429279, 1.027689, -1.4781113, 0.6413727, -1.4072628, -0.026535034, -1.2797966, 0.029146194, -2.4302177, 3.5414524, 0.2904358, -1.2070045, -2.485302, 3.9284973, 2.393383, -0.21964836, -2.9612427, 2.663025, 0.24242401, -2.9676914, 3.3993626, -1.4953461, -1.2836761, 1.8546829, -0.02394104, -2.4066753, 4.391773, 2.7768536, 0.8995819, -4.098152, 3.6575127, 1.526104, -1.432642, -2.270811, 3.5913162, 0.81850815, -1.8171082, -0.45017433, -1.3593788, 1.0594463, 1.1227798, 0.08215904, -3.6993504, 3.68359, 0.80475616, -2.4820728, 2.7856216, 0.14781761, -3.613882, 0.79429245, -1.0438461, 1.7449169, 0.50045395, -2.59729, 1.3224564, 0.8014698, -2.4104195, 2.5845718, 1.5116806, -0.6178322, -2.0258179, 1.9408875, -0.29158783, -1.559866, 1.262476, -1.1114845, -0.58252525, -2.5398788, 3.5262947, 0.2240448, -0.25501633, -3.1072025, 3.3379917, -0.7516937, -2.8688602, 4.208662, 1.702671, 0.8924179, -1.1600342, -2.0841331, 2.2483425, 0.48921585, -2.424408, 1.6677551, 1.3478088, 0.041038513, -2.7963047, 5.1887417, 3.1840897, 0.9459572, -2.636221, 1.3692665, -0.9476929, -0.13471603, -2.2989368, 3.8928318, 2.383236, -0.45476532, -2.5406685, 3.2881832, -0.4227581, -2.8899612, 5.4994698, 0.20980644, -4.8025475, 2.2792473, 0.78926086, -2.3227062, 0.38627815, -0.79870033, -0.4475422, -3.08646, 1.9133949, -0.22978592, -0.12889099, -1.2883968, 0.08692169, -1.6022987, 0.7677059, -3.128912, 2.3560944, 1.1149235, -3.162611, 2.1491795, -0.33684158, -2.3652077, 1.4490032, 1.0851364, -0.7976856, -2.5023727, 1.6153622, 2.0523643, -0.13470078, -3.2171745, 2.637539, 2.2731762, 1.3556767, -1.5011139, -1.9024601, 0.5142994, -1.209629, -0.027168274, -2.4212418, 2.843666, 0.7121868, -1.6900864, -1.7147808, -0.8110447, -2.586979, 3.3517265, 2.0905018, 2.8079796, 3.386572, 2.8927631, -0.14460564, -3.0051498, 3.0251503, 0.9360504, -3.8441448, 4.135784, -2.2447433, 2.319683, 1.1107044, -1.2246265, -2.9148464, 1.811367, -0.43055344, -1.5388145, -0.25372696, -0.10551071, -1.1103172, -0.41610336, -0.2832203, -3.4191933, 3.3192482, -0.4493885, -2.7066536, 3.5369568, -1.465847, -0.1649971, -1.2436886, 0.7784729, -1.0971222, -0.26400185, -3.2283611, 1.8615303, -3.1474152, 1.6306152, 0.4176216, -2.2432175, -1.1003952, -1.1637573, 0.7550583, -2.0683384, -0.3906212, -4.0645695, 2.0540962, -2.868166, 1.4826603, -1.025547, -1.7250443, -0.09212875, -0.7583904, -2.4678574, 1.7640972, 1.1660233, 0.50927734, -2.1121159, -0.28236008, -1.5420265, -0.5237751, -2.6250458, 2.6474972, 1.3356438, 0.03592491, -0.76112556, -3.2158508, 3.186102, 0.23322868, -2.611824, 2.1381721, 0.4385357, -2.39324, 3.0235786, 1.7971325, 1.8619709, 0.26849365, -3.3791447, 2.005167, -0.88949585, -1.8993301, 1.5502186, -0.95463943, 1.1690311, -1.1470871, -2.0129795, 1.5702915, -2.5856934, 0.46107292, -0.68375015, -2.2156506, -0.7581177, 1.2352352, -2.541977, 1.9930687, -0.2639656, -4.188793, 2.117157, -0.27078438, -1.6213245, 1.4879265, 1.4329376, -1.1588593, -0.7829876, 0.20012856, -2.287506, 2.9975681, -0.62701416, -2.2472572, 1.9191437, 1.0676117, -0.0503273, -1.0256596, -4.1928177, 1.4072819, 0.2102623, -1.2156239, -0.43713188, -1.6624508, 0.34909058, -1.5572796, -0.040166855, -0.7187805, -0.3989334, -2.9679718, 0.50935555, -1.152359, -0.50453186, -2.5782204, 4.365757, 3.9589844, 1.4886684, -1.0801449, -3.8167782, 3.0461197, 1.5496655, 0.7634144, -2.49749, 2.3446388, 0.39955902, -3.5758553, 3.0184765, 1.2988873, -0.2345562, -3.4669533, 3.2344723, 0.41017532, -2.5160828, 4.11458, 1.7434273, 0.724247, -3.5752068, 1.4307556, -1.936018, 1.6027641, -1.8218727, -0.89167976, -1.1104355, 0.59609604, -1.9605312, 2.2597294, -1.6466084, -0.23579788, -0.38369942, -2.6794758, 2.789997, 0.69886017, -0.32729912, -1.1483555, -1.1744041, -1.6830196, 0.13518143, -0.00051116943, -2.9910622, 3.4168587, 1.3540726, -0.30399132, -3.8345165, 2.5982666, -0.763361, -4.267688, 1.1052818, -2.3011246, 1.4384651, 0.76559067, -0.86501503, -0.9136677, -1.5964489, 0.9635906, -1.459549, -0.7070446, -3.108511, 3.168293, 0.6987648, -0.23658371, -2.3551388, 4.5707397, 2.1644897, 1.3417358, 0.5322914, -5.3184175, 3.699503, -0.27606773, -3.48209, 4.643902, 2.6691475, 2.2423553, 0.07870674, -4.0440464, 3.0053062, -0.059604645, -2.9168625, 4.2062035, 2.3156013, -0.92780685, -3.8717613, 2.7364845, 2.0962067, -1.1425037, -2.2188187, 1.8448868, 1.5240269, -1.6397991, -0.72203064, -0.64307785, -3.2680855, 3.9554176, -0.026241302, -1.965374, 1.770958, -0.23772812, -2.1405716, 0.68639755, 1.0406857, 0.64637184, -3.202942, 3.5824604, -0.64424324, -3.470972, 3.1329117, 1.0284691, -2.7602406, 1.2949562, -0.08573532, -3.3772297, 1.2070751, -1.4953499, 0.1457138, -0.06387138, -3.5062294, 1.6324959, -1.6722641, 1.0862179, -0.8804188, -2.0130005, 3.2634735, -0.023796082, -2.0876255, 0.7522106, 0.58096886, -1.6568527, 1.9102192, 0.8118973, -2.4383564, 3.7071629, 1.5492535, -0.99793243, -1.3047428, -1.0328789, -1.1486015, 0.18270874, -0.9621811, -0.9731083, -1.2927628, -1.1829891, 1.6316433, 0.7372856, 0.1570301, -2.9439049, 4.867836, 2.1909485, -0.21787834, -2.8349838, 3.963768, 0.122182846, -3.9596825, 3.536705, 0.31654358, -1.3562126, 1.0204201, -2.1032104, 0.76722145, -2.4797783, 3.5757065, 1.8951702, 0.73184204, -4.2947006, 3.3981113, -1.6037102, -0.42817307, -1.8750172, 1.0431404, 0.46882248, -0.4132614, -2.9313583, 3.372116, 0.39824295, -2.4183865, 1.12183, -1.3367691, -0.5367489, -2.303032, 1.5759563, 0.058347702, -3.5895367, 3.0475807, -0.8434181, -3.118576, 1.7414703, -2.301176, -0.39722824, -1.7688293, 0.7765598, -0.21752167, -1.783083, 0.5579281, -2.7202778, 2.9775772, 0.37814903, -2.616375]\n",
    "\n",
    "# sac\n",
    "# U_list = [5.414479, 13.6943245, 6.737919, -1.4116383, -15.878218, 2.0415401, 11.883478, -12.460169, 18.540043, 15.989639, 10.549917, 7.4516907, 15.486492, 12.833923, 12.351456, -14.793518, 2.3114376, -12.606421, 9.233444, -16.279337, 10.991688, 2.8182907, 11.371559, 7.0601273, -0.18647385, 7.8772087, 3.0575066, 4.0379906, 0.07736397, 2.9936218, 11.991655, -7.8768234, -8.862894, 2.7116585, 3.4345264, 13.078705, 9.8074, 13.228119, 13.207127, 10.606209, 2.3662605, -0.11846161, 1.1179047, 1.814764, -3.8936005, 8.674536, -1.7833538, -7.6276445, 10.394348, 2.2616348, 1.0796776]\n",
    "# U_list = [9.9052515, 15.933079, 16.819916, -15.480906, -12.982727, -11.169411, -1.3884354, 12.963764, 4.570591, 1.6753864, -9.258332, -1.1977978, 10.823498, -4.6682215, -8.100311, -0.76138306, 11.713013, -1.1016998, -0.3859768, 4.751175, 1.9874783, 11.862745, -6.792221, 0.42554474, 2.7659988, 6.0947113, 5.412056, 4.699177, 8.645184, 5.9337215, 2.0537071, 14.013359, 11.627483, 0.76327324, 7.638443, 13.869091, -8.363653, -4.835432, -2.5752602, -11.574808, 11.517239, 0.5907364, 6.616297, 10.301319, 1.0391026, 3.1400795, -2.3702354, -5.737729, -5.26517, -0.05091858, 2.6315594]\n",
    "\n",
    "parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "# hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "\n",
    "\n",
    "reward_beforeQP, uBcks_beforeQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_list)\n",
    "\n",
    "\n",
    "\n",
    "# U_safe_list = [5.503294467926025, -5.573125003488144, -7.778071397279973, -5.427256696890687, -7.373336789433065, -9.9971064796026, -4.617706364110884, -7.336226404778564, -5.988787765606414, -4.587183044845439, -5.823311924425237, -6.163592360856207, -6.065515638441919, -5.377700813581534, -3.698251822682831, -3.890207243875956, -5.581434382337019, -5.083112657983726, -5.370241291845314, -5.805416058758716, -6.430519175599311, -3.475484768650155, -3.788946232846211, -4.985228424319509, -6.7069130197319105, -4.575754053002221, -6.110157062541003, -4.686097988935678, -4.4521322546367905, -3.9169081495324534, -4.895267504169805, -2.6326788130543335, -3.5326823936559997, -3.118915373467594, -3.757612209577598, -4.171056537137879, -4.678581226149742, -4.3499229299817515, -3.7056865354299013, -3.085548211015869, -4.32527062136263, -5.158343228507768, -4.439725847948008, -4.065241730975124, -4.26403233770429, -2.3109073369720434, -1.9379882552641412, -3.339321117313041, -6.04883072595862, -1.6790752397088298, -4.799761551493699, -2.4814968189898607, -2.341521890744385, -4.5475579486592395, -1.215045631881818, -2.902120667232346, -2.0234295534487465, -0.2255286757704269, -2.2863423148373805, -2.5003908650555857, -1.2530057196790914, -2.3867891771232976, -2.3003843093265424, -3.907676511377055, -3.391425827021518, -1.100946171846978, -3.6390511845698335, -1.20631001757463, -2.6597935848172334, -2.6458203896104138, -2.5175702241221494, -5.645994926656819, -4.508896553299959, -2.2732255096147824, -4.286364287751152, -2.9009606684726137, -1.9175201672589388, -3.528930426913554, -2.425807604801488, -1.7565591593265495, -2.48521769827644, -3.1309774788505607, -4.019288678247587, -4.090234577354046, -2.753177303645, -2.9579771558203234, -2.3934646911231106, -3.1583631984741274, -2.256276737523617, -4.173130818920164, -2.687743798438273, -3.1116293262317427, -3.299365684259296, -4.053088021257828, -2.614925074481757, -3.632207693741613, -3.051326441050346, -1.7944562887754287, -1.8430534691721867, -3.414293136710832, -3.3020606983897913, -4.139981130794105, -3.702769856558202, -3.3257063299493907, -0.5167365444214873, -1.8106459153546908, -4.270469181495368, -2.2046640783556555, -2.6140704389719893, -3.4787958250759417, -2.2834639754383623, -3.3702962994707164, -2.3578906246810583, -3.2452085603015135, -4.130334391112083, -2.5716474418756903, -2.1568923088974223, -1.5708578211515274, -2.3733553940558885, -3.1866662714555574, -2.3711406086632243, -3.0097711251762362, -3.252568359279464, -1.4467313364982388, -3.639048690300526, -2.5325925290169167, -3.8312064283513356, -3.299278042707307, -2.8065062316240548, -1.6825177691305058, -1.87972555296433, -0.6543633417702281, -3.2172404705415394, -2.9979894291452425, -2.4695884426891572, -4.169077617848167, -3.1843520982274205, -2.3966023685650057, -3.1843864305028555, -1.3083054853384297, -2.223517600926244, -2.2307278869036296, -3.5642596978950687, -1.3362080687399853, -3.069302726805746, -2.8304231085710185, -2.894795582996495, -3.3373372523148888, -2.4297286615094444, -2.1283929077928647, -3.489661351512269, -2.5107800548964647, -0.7052489640757367, -2.202193919276148, -4.507230057666903, -2.2322251233244756, -1.432141550443931, -2.229958823422405, -2.2145607385975845, -1.6949703922197132, -3.6777337104742864, -1.9274265975576528, -2.1955350280079537, -3.342707908084205, -2.462218612890184, -0.6272785769955336, -4.162183147076804, -4.018073417569551, -1.6200517746076466, -4.074975350206157, -3.1899637695953524, -2.781178782945287, -0.9236845186553646, -2.7686701978000685, -1.6843580660622601, -2.3518611255749904, -1.1577085612786968, -2.5292693372751303, -2.3095945626298553, -3.9703570965842148, 1.5654760345498735, -1.6679909226289085, -2.4119066887940344, -1.3252518247293694, -3.0549349694645125, -6.042245270689184, -2.19421526862675, -0.7611041970788417, -1.454907877301367, -2.7831341230378737, -3.8413194517740985, 1.2046818198138656, -1.9571736656778294, -3.284145148129303, -1.9605172479313788, -3.7767999466471363, -0.28721370194667006, -1.9701745813220466, -2.5603689433837227, -3.6660611968384753, -0.9702714826843968, -2.6332472141369205, -4.125465865136861, 0.30012139660329673, -1.092196917355026, -2.4963129814589617, -2.414481579457928, -2.720697286283487, -1.741637625571415, -4.796449539782136, 0.3654085628877928, -1.9901923001300954, -3.2699559821084714, -0.459314197723236, -2.84117636560491, -1.7790506368885897, -3.396769837736387, -1.5597742078471608, -3.26468212950438, -1.1369169361092215, -3.234668091628536, -1.1104028824381, -4.134314873307248, 0.3484880135359365, -1.9718737234257597, -3.3614271664252353, -0.40739771215483334, -3.529525621099472, 1.240612585634536, -2.575172307656592, -3.0563751263485566, 1.2799627022475963, -3.192763897677154, -4.121509464729732, 0.7539333095015044, -2.6479415370587756, -0.5659214160363755, -3.53501889629222, -0.054481140073179724, -3.8448963048564817, 2.1001055620081805, -2.17068478209392, -2.277055652294579, -2.711263636395122, 0.5520286942783477, -1.0831718360029097, -2.145404750731317, -1.2477359610987175, -3.0870551607485632, 1.66408536955141, -1.4858837029978114, -1.2034034715709847, -2.111797324961075, -0.7760372185273834, -2.9888954159241203, 0.7056484013757629, -1.5390224825614078, -1.2187195121312495, -1.6276379035479787, -2.085575150696789, -0.9110451427404351, -2.8913040784716966, 0.3435362571581626, -2.223033986393423, 1.0425242459605633, -2.7275200754800633, 0.7578333919196174, -2.1739865440466044, 0.09210004814626327, -4.626413389021584, 2.2433317026548556, -0.6836986117885342, -1.2758275287200869, -1.6480827072780837, -0.8172646765073788, 0.3767204683601424, -2.800623066007078, 3.0584888425611982, 2.2221048862589177, 0.4747008915321178, -3.581119764913141, 1.6104545795125862, -0.328483778740023, -1.9314727644094116, 2.333474985003291, 0.5974522824682911, -1.2718716768944924, 0.5757199519733067, -2.2360802712323258, 2.6658499201560435, 1.9687973908035437, 0.8457034092655622, 0.568910276513221, -2.2626988861727195, 3.279628416413785, 1.4391462756914652, 2.345931700008392, 0.2465040882300773, -2.100250650263164, 3.253841725730391, 0.3385540967934011, -1.5403418180655617, 1.102824896631815, -0.3201441548396442, -4.069633827821648, 2.4631734974221136, -1.283075690477248, 0.6016927963203589, -0.6736701586091423, 0.3960214788369658, -0.8184245718347976, -0.3195661529805047, -1.5898898803679495, 1.6526933370735524, -0.09148633107720716, -1.496884823059835, 0.37414135204430377, 0.45767260475285276, -2.117939355960929, 2.991169438239277, 1.3828006486333342, -1.4682917475363038, 1.7308021168164904, 0.6700712285494692, -1.1852135582712018, 0.46373806961154607, -0.4930291110885756, -0.22451533933118206, -2.4134144725794195, 1.477894360693691, 0.32006030523557083, -0.6647506064916424, -0.697647539276617, -0.7245250043610749, 0.4279399468651226, -0.6731810854600067, -1.7223744694565122, 4.082348083125774, 0.6202235396631712, -0.3579575419336347, -0.8852123725118455, 0.006412794871133443, -0.20543523807096253, 0.1691573110830209, -1.1974186326560394, 3.807991345532267, 0.014697597564960141, -3.6599974215613624, 1.6039080935761794, 2.286066386269434, 2.676835560890182, 0.0025981356512634335, -5.153626108743041, 1.0834354164099782, -0.5966134557429124, -0.7426201640727381, 0.16242549704115472, -0.2653710279563679, -0.8815045970549855, -0.2665005943957648, 0.46675057666293096, -0.0853673232667087, -1.7685570700486588, 3.867999819303933, 2.096328203755589, 0.41368276035076734, -1.691935088598215, 2.337373548462111, 1.229453644253268, 1.3361681159968986, 1.0837150371385595, 0.9505003117152602, -1.5347980819191926, 1.8555887548124166, -0.8304657219345737, -0.10898993354327002, -3.1653809729400146, 2.593704020173974, 1.014079645399348, -0.47410981410335706, -1.8129944431934328, 2.6267431496295477, 1.0225215570385862, 0.8469046144442847, -0.9618724790911566, 0.46134172980886534, -0.8512863098529388, 0.2913130496653058, -1.605493892982694, 2.903779769750955, 1.674247328372231, -0.4051878735500476, -3.6651004061657924, 0.7119995711544935, -0.6402515027092059, -1.2374766696030828, 1.8855929715193005, -1.115871747871196, 1.010909619336572, -2.290090883000729, 4.599660544477202, 3.108724257207442, 2.026256159412852, -0.6812824468826046, -2.8258689080547166, 2.916227040929599, 1.7710035488991442, 0.6490381201773663, -1.7097874406579914, -0.7346975941937752, -0.34604456465497524, -0.1300623356647601, -1.8379363819993424, 3.462871386612179, 1.870645596532241, 0.010879283542536644, -4.682371101477501, 2.844306656494965, 0.6251010801817491, -0.3285200859091755, -2.4295234105928367, 3.752651026600589, 1.616726000286845, -0.5934202809468014, -3.019214547039909, 2.3276173769744593, 2.30424497170604, 0.0842644236880834, -4.819588801063973, 1.3626420143890674, -2.7955438056731774, 2.240680414874888, 1.0989740965425616, -0.7634775286816047, -2.5601025729873337, 2.9768694068014985, 0.8078363812284541, 0.3825357801041638, -0.4976312301922272, -2.191917679351817, 2.9723299034332475, -0.20109394269194025, -1.9562342837860607, 2.615371504950318, 1.9875503198338, -2.098301133498452, 2.3225360450871184, 0.2626206432240825, -4.314069201225565, 1.625510856366319, -1.114994421777582, 0.5557934785655481, -0.9463046878289143, -0.1828025006608267, -2.712204384683745, 2.7052724439753466, 1.0513530470554278, -0.8664247353109285, -0.13096660972117125, -0.9257089474030376, -0.9142174035640247, -0.27456681972300556, -2.0820049263982847, 2.108817893146878, 0.010934436084581556, -2.0760787713651747, 1.5197597594252974, 0.40788622346106296, -5.3078414794197935, 1.1874158183564565, -0.16728613993275676, -1.518192658106201, 1.8567006278009748, 1.5290522868309186, 1.2161557506007474, -0.9656834817759967, -0.34555456760956904, -1.7277398356945208, -1.8095076433799742, -0.39064264357322953, -1.1286738051374678, 0.10202931432566276, -1.3868200802379116, 0.8475737329263926, -1.7915594563722417, 2.686135686410197, 1.7907559088513798, 0.07483239227447358, -3.7725014591390655, 2.14978728087597, -0.24162906926115202, -4.584144334548839, 2.8678584334544857, 0.9840959536960128, 1.003627308046517, -1.355917577529837, -0.040607962449329627, -1.7421899972945738, -0.45315030239483267, -2.0225759720059813, 1.6181312389186777, -2.362488374276765, 2.73436882074263, 3.4873821333868165, -0.8788417556982759, -3.154701784910614, 3.158019600722283, 0.5663714572120426, -0.8302749616462544, -2.3358616850190828, 2.575439003073071, 0.5524517145505143, -0.22308590783116333, 0.32802353811628393, -2.0163197783670777, 3.049976042434608, 1.1523872279964698, -0.8145869332883393, -1.803251670569197, 2.220616909085109, -1.01653902099254, -2.0393433846992792, 3.0425792500051747, -2.4157223890041877, 3.666587451395272, 0.5346141378132216, -3.4591830719485452, 3.0413489532102886, 1.3895201271176765, -0.43707501288456285, -3.6456381909132043, 2.005046404086059, 1.4494089926544538, -1.3758338959859628, -0.36651855543216616, -1.1254371708400157, -0.8940568432111187, 0.13012271392115338, -2.446953353933467, 1.6022658697930439, -0.12615650044183813, -3.7547422910701442, 2.522319166670669, -0.31414083606607335, -1.8205858905306096, 1.3664011609999562, -0.6380030935500409, -1.7290482436164183, 2.9290344777588606, -0.12359284472215393, -3.0807005524068964, 3.395186802974493, 2.2980607636897465, 0.2041678280130128, -3.805714432553331, 2.0499739751158614, 0.8730119510188805, -2.5422061594380665, 2.2630265692647944, 1.8050993628767884, 2.098254536003579, 1.8016297733549882, -0.13957456261989964, -4.11377162873464, 1.4749311603715531, 0.8355938485467496, -0.7049965841091117, -2.1579745435453797, 4.134009644248791, -0.34699857587179483, -2.982227837399777, 0.9031120382271629, -1.8934006905313518, 1.4699684354084175, -1.0401463561596112, -2.0457480193042565, 3.5617978128408785, -0.489061634420751, -2.0685733737939964, 1.0648324220521763, -1.0337203642796604, -0.5602438234352585, -1.9990275980074594, 1.403533680971349, -0.6974089800699668, -1.3457910295298925, 1.9783589700615911, -0.30746473751128267, -3.1555827441246302, 1.1664904067504258, -1.2389243151904603, 0.06351836712496972, -0.8497870518261417, -0.612095065855784, -1.3960917248226261, 0.760036315102524, -1.2284243358629547, -1.656438920993197, 0.946979296942728, 0.7794589166035157, -1.215091969341601, 0.8688582570532608, -1.0546648813609218, -2.2873498867927546, 0.36381502498322416, -1.665434085917469, 3.0923231256826247, -0.13532085120164172, -1.3656770957816926, 1.5255983771778565, -0.17027111844011333, -2.681314744943621, 3.0692709134388414, 0.546209131119439, -2.028986285403634, 0.2612607957128139, -0.29743033171628586, -1.5720273687036306, 0.27830474850331566, -2.380300694250537, 0.8887058891329351, -0.916971389746096, -1.6193375039814137, 1.2952459890550463, 0.277858306961817, -1.171043547099317, -0.4368290248069835, -1.535082012043632, 2.5620723248309067, 0.5493199707491376, -1.5112214238591415, 0.8912427231136908, 0.029704562405341584, -3.405008712330301, 2.1101909602172517, 0.05874405593408394, 0.4150500650381863, -2.9940896031237125, 1.4102092445124716, -0.25947417590009625, -3.199202113505934, 1.6245398979319807, -0.8838811827857436, -1.2307323114489472, -0.3865266852311189, -1.5440295778678328, -0.6968866446389521, -2.3201087549348367, -0.3813405973581476, -0.7195514808806829, -0.10865077931914957, -1.089628607152691, -0.10972093508219156, -1.2415813474515298, -0.922438376806281, 1.2822738538081913, -0.49527428566336795, -3.7596210628405524, -0.06191133483782807, -1.3909152312560318, -1.6532046287696405, 1.2641350830228921, 0.9216110980257097, -0.7900030212047122, -1.6494756728728364, 3.098148244432422, -0.4537339964893592, -4.484892797540625, 1.243615610487427, -1.037391569102284, 0.019561321055038938, -1.7305449373932342, 2.0420051311909218, -0.05159939034342731, -3.3772242977623366, 2.6340276133953457, -0.10590581952903921, -3.0275171713044537, 0.6866719278756817, 0.9263554216697676, 1.3514477682262394, 0.8168774229095552, 0.10266269858464039, -3.3078764806152785, 2.3252388953120997, -0.7853584203433011, -1.232849328326961, 3.150421229668381, 0.8963659130392214, -0.7063825815087066, -1.854141399423793, 2.3318903131482775, 0.53190014646741, -2.61505280089773, 2.3950554642002997, 3.11504774178752, 2.3452240745179322, -0.27514612009986283, -5.034812471646842, 1.0236705319591684, 0.15676814888927293, -1.9938330988472908, 3.559104306158292, 2.409540755372972, 3.4742787915167126, -0.023486513712897228, -4.047401224059127, 2.26219426683815, 0.5213899810334395, -3.608762372513639, 2.1092252509117086, 0.9155866740372849, -0.6939992024343384, -1.1157568017908952, -0.5495919277335135, -0.44698312449986677, -0.37080850588138237, 0.25983639629225674, -1.4616192910460315, 0.039131367335129674, -1.2598275298926866, 0.1933309685052782, -1.0676488060292515, 0.02350255808300883, 0.61771682437909, -0.30442218229404805, -1.1622208981701307, -0.5843389580688845, -1.7373780439359736, 2.1525994372939286, 0.5974761764170351, -1.6333083984056893, -0.11613731663812832, -1.0430678897057541, -0.11574505209421568, -1.4922637563779526, 3.200647796988843, 2.2133731047158554, 0.0758633208359889, -3.205640988561073, 1.1294884558091063, 0.17243758976996926, -1.3811965048581705, 0.3134001914129376, -1.22147131271743, 2.3474863810822617, 0.5945648765485849, -1.4965114916142293, 0.5930426577141178, -3.8984376481041645, 2.4201872244701508, 0.2006130931893031, -2.5358637136124753, 2.4878522497290296, 1.772667226567005, 1.8929426116899313, 0.35761671942951123, -3.6827123167079217, 2.661186474669971, 1.2137090179983252, -1.1855847998196123, -1.5348661904338323, 0.7273943593498688, 0.9757939843782415, -0.04041075777799508, -2.057403536169887, 4.363784980625365, 2.3327293712588917, -1.036599891056671, -2.8633594920158894, 2.019537275555063, -1.136936225133696, 1.4748023465834699, 1.479259339999543, 1.6188281564690037, 0.24495113475290875, -2.041043854361437, 1.9341964041429938, 0.1945670111025315, -2.2741107429994836, 1.8418200950917303, -0.5438021564425535, -1.0283427472087574, -0.6619280693755636, -0.36296605987367414, -1.904836559797105, 1.105564535883655, -1.14769164477707, 0.16869396848128915, 0.13505758719315875, -1.7602744750175994, 3.641380367969986, 1.9693493819366772, 0.27684409575363045, -1.9115271023539613, 2.1000519599349436, 1.4159056436554742, -1.5399587929548497, -0.6605141561223213, -1.729577862704219, 3.2563863754629487, 0.06271571232059525, -3.4015327881781054, 1.9278643063851169, -1.1747814719484673, 0.8993685030370662, -2.535070110890178, 5.226511034263921, 1.1927779041151148, 1.422649525514088, 1.674082071204662, 1.4881307152347736, -1.130469955601388, 0.3410837107833222, -2.6726147124965287, 3.0307619724219412, 0.035276693558312644, -4.647223159667875, 2.416399275240888, 0.9117493574333357, -0.21665740093444086, -2.2149061883799286, 3.5810377436690537, 0.36771443305337836, -4.532880740723289, 2.9741654947385987, -1.7680244919057664, 1.6409726391204904, 0.96194823319534, -1.7988429373297103, 1.0957449267315091, -2.2413669030217998, 3.285505138281092, -1.5120769090888198, -0.038231122116616945, -1.8381343566823043, 2.77240727508784, 2.2373814086797656, -0.31460400574555436, -3.1594289914453393, 5.271114118486235, 0.40110271476191794, -2.416969634314359, 2.37796654532326, -0.46921382743143525, -5.268542773260152, 0.6659733571230895, -0.9285483567171022, -2.7700981269064364, 2.252165331000696, -1.2842372817377914, 0.7842507124671547, -1.7454303796277095, -1.1659827236496776, -0.42904705920422614, -0.6062674385600539, -1.9204105609952826, 1.8111006083065595, -1.3984264366937573, -2.730626662100577, 2.5085349618037576, -0.6096014795755318, -2.8218065675302064, 2.3226837659760795, 2.5102377918536654, 1.42265174607678, 1.3037272023519613, 0.2750840012151903, -3.8698775754002277, 3.0321736404141566, -1.1033942225023061, -0.4397101266811214, -2.905632737847686, 1.6269288601172311, -1.797903781762347, 1.2236619573588987, -0.033102772698970995, -1.4085612334536117, -0.2980640144043214, -0.4260420994858132, -0.8235862401262644, -0.30516960173622554, -1.3174598345132331, 0.37370346210741356, -0.31447866807424774, -0.2822890687027675, -3.3096893730063535, 2.6609826771593807, 0.7066107903782317, -3.1904312450503776, 4.214190631097932, 2.125113111512518, 3.4186641033528353, 0.246679825201908, -3.07530697576944, 4.1292519082956, 1.325312437293956, -1.353502033464566, -3.116393072086016, 1.4085944852588446, 1.3439972553249895, 0.8665298285388863, -1.360739446891916, 0.45203244903245743, -1.6071040423386371, 2.136833511514168, 0.6502105353891743, -2.8330206348880447, 3.3699828919951464, -0.7968859609798082, -2.2779589045650432, 2.1171899781722905, 2.0487793349919734, 0.41950858835775673, -4.883034739815361, 0.7745386459566808, -1.2658948976433244, 2.3285165636546017, -0.7544794238939581, -1.8451590664269597, 0.8353719510986188, 0.42624699247903575, -0.6631136390580146, -2.326547155775871, 0.7378453783156651, -1.5222945281718703, -0.027911242236900335, -2.1008200998082893, 0.3552217034328855, -2.1094524815907563, 2.6723392954253136, 1.068186538681425, -0.7549124779372001, -0.17056392237097961, -1.9991961137067342, 2.4434326964638102, 0.408648374132877, -0.2851610797715467, -1.3757716020237645, 0.32250875241700205, 0.16716666288526127, -1.124777911953038, 0.19361014338492666, -3.959284877253572, 3.033215583661427, 1.2766081610516493, -0.5171154156313555, -0.9950059751372238, -2.253212796466773, 3.796242397240371, 0.6338701501946211, -2.020789643409421, 2.0906152681337566, 2.2420354449623345, -0.28271965424291423, -3.846461850635001, 1.845240497589753, 0.0008339870965072826, -2.7701579417561284, 4.865181515995596, 1.1574697136012269, -0.9709275282529912, -3.894543538387456, 2.4261862053954477, 0.5899651308492189, -2.056960664967823, 1.5780346517395678, -0.19094616797699437, -2.302715921602516, 2.2083229908148727, 1.4077294550707897, -0.1396347228310102, -4.767286746146869, 1.0875209866117306, -0.9531634888216054, -1.320155755502105, -1.6520732687885307, -2.1107612992945857, 0.29400983013793436, -1.8387943723391569, -0.1233638120746896, -1.1034809610154976, -1.4089949649486648, 0.7796977964226475, -0.3210413680234474, -2.2782074816877635, 1.6920087642257435, -2.18003052303718, 0.8997075635535161, -1.035663251446726, -0.640976231111285, -0.2564655808000449, -1.258781692536008, -0.22269025118428054, 0.24858830578987678, -2.5499608470722475, 0.9190213245102363, -0.6500851610485139, -1.4879285986597957, -0.08342334723918121, -0.3099610495150724]\n",
    "# U_safe_list = [2.3043174743652344, -6.3277444590731875, -6.9250687061945655, -4.262527072106707, -4.872657231757131, -5.801840076372088, -4.171227592598171, -3.667608281231793, -4.308900314139095, -6.118249631597934, -4.499316363859052, -3.9382815008358705, -5.0961622868850185, -3.846741828238578, -6.020261559450418, -2.078945974949761, -4.490566362424815, -4.478722143988762, -1.744943469444351, -2.2860268052015726, -3.863636199537595, -4.234009912586771, -5.447220321411905, -1.9005439539300824, -4.9285867525145335, -5.325334066078085, -4.6945505965993135, -3.5378292564817, -2.481871278834845, -6.505115065293239, -2.667050320686485, -1.46466648519322, -4.31367358408545, -1.8373340877820965, -4.407119072119642, -4.405528844679452, -2.469215992033625, -0.8208412453847131, -5.146689819577588, -2.933558144420317, -3.3642884043724024, -3.6858657628503124, -1.5803493912589346, -6.094815376457859, -0.6806895758244735, -2.479713221396537, -5.402910564700434, 0.030711957415064717, -2.46172331502423, -4.081762349484393, -3.612978264471778, -2.1318419859222786, -2.6746577981690933, -3.4154625576521767, -3.6001837677456905, -1.9921344434911816, -5.01917740853996, 0.6892751757135329, -0.20458207163783015, -5.09050409197846, -0.02728095615013615, -2.7927590864425156, -2.157350885373873, -3.970971926050993, -1.1260859780772279, 0.2116493867514464, -5.645181816954775, 2.8270804683132837, -3.3365262594337963, -3.360869469216709, 0.822371460856246, -3.031426784981818, -0.5488860974354992, -3.7405716374613576, 0.524098865112208, -4.32631299783759, 1.2461374334817066, -3.9293654299589207, 0.9585210058849754, -2.9475217653952086, 1.4993671330290255, -4.553229242801422, 0.6616065241292546, -2.373677525360904, 0.9928751264306612, -3.456420564324503, 2.612452871482745, -1.1467037847968413, -3.522200281584375, 1.4495395137392961, -3.5182981445032055, 4.556351374760311, 2.2523180293101177, 1.5711146121267348, -1.5837145167861308, -0.7680752618651923, -2.4689395163086374, 2.9710849036347327, 0.9043308764448739, -2.7758208612375483, 2.8590920400220057, 2.7488910184821407, 1.9626842610236963, -0.6111474631551346, -4.0097868268853745, 2.9293184463587068, 0.052538059409471316, -2.8521122153341594, 1.5039766697732375, 1.9215237184909029, 1.1415826320644555, -0.2674904832891798, -2.4006801617560996, 1.2692008760055842, -1.188002900484662, 0.13571151838152673, -1.0169210683046686, 1.0997830618315447, -1.5415579957674481, 1.4697918377972883, 0.2838702997975133, -0.6399892462119396, -1.763160704089728, 2.394738095232583, 2.4343853880469624, 0.7594024943285831, -1.1247763658014946, 1.1597991492598112, -1.122248830843608, 1.7197492980961897, -0.7604817501183501, -0.1582888096069155, -0.802731130019998, 1.3936161908808344, 1.1910587991744652, 0.8139293471689371, -0.9608574270339485, 0.0124750761345922, -2.3351170628218423, 2.881404230017665, 0.4788232100920542, -0.9175475605594556, 1.6528633090740588, 1.255624812241308, -0.3514146379773191, -2.783752203748577, 0.9673321751590667, -1.0680708703827122, 0.929502119551552, -1.245198411348042, 3.202676648137066, 3.33573084301554, -1.434902201299911, 2.0510669846922838, -1.0439946097882338, 1.3182868131503938, 0.23139823365306178, -1.7742687704861737, 4.747040685626752, 2.661604630042916, 0.171784740334596, -4.740171600523695, 1.7436437607524287, 0.5864954442537282, -2.7777506560029277, 3.508880028732733, 0.21992839692972588, -3.8803010833702274, 4.392287438377361, 1.2964779623385994, -1.0153753760110984, 0.46276094073493823, -1.497493693137704, 3.179477894573779, -0.2512852426763228, -3.5474351519400216, 0.8493792193247547, -1.3344907258828016, 2.9170731068833167, 1.3709349228234942, 0.5858852771369758, -3.2598573423305197, 2.2439628314895064, -1.3103198221518824, 1.716762422269193, -0.3938957237581917, -2.2599790352488807, 4.202471501183595, 2.246849546821858, -1.7805814956440145, 2.2715862493263845, -0.40540573514351763, -2.9390419860733967, 2.52759898804527, -0.126797273236269, -2.4653778360383285, 1.0267636084612892, -1.1227585379996299, 0.25029371214935203, 0.24831638411217227, -3.078061665754438, -1.1379996577537668, 3.2067381801056687, 1.5330498191784727, 0.9848088257162377, -0.8883403418052467, 2.4706642538744124, -0.2549343340527912, -1.5652640911671991, 5.490902017225039, 0.9404659699661639, -0.4469734902726259, -2.4029214208226843, 2.069159050211624, 1.0212598348711541, -0.14569578010775786, -1.9945040892367327, 3.3110152068398975, -0.10792240320876623, -2.944843662401013, 1.5370878885009294, 1.5572797192068037, -0.587829747837139, -0.9063412402505264, 4.434629649197115, 3.259813896681976, 2.834999531728892, 1.7669572336322972, -1.534520553807459, 3.1089622726136668, 2.52990052475746, 0.7880894051774021, -3.8562342701084784, 2.6844920828576733, -0.08029400077481874, 0.12391487222578235, -2.1211700849622215, 2.0894646318853347, -0.7268864976527478, -0.3617393578127803, -0.756171659090489, 2.434208935280026, -2.045619096443863, 4.500802478811806, 3.163106303068469, 3.106263886102738, 1.22090876358501, -1.2384869618048242, -0.924259288411724, 1.2605310420427713, 0.1841509168255815, -1.2816592705470384, 1.3482289594861303, -0.5433433822203142, -1.920937577765164, 3.9637848923426873, 2.800816620030071, 0.8491306311094604, -4.773155691044542, -0.04160853974406109, -0.43302531350551554, -1.4991887641166386, 2.017530678068704, -0.48913294521150874, -1.2064756114129178, -0.42359620658442054, 0.8801926798326694, -2.7178884537473778, 1.9589474294637856, 0.8849943359697363, -0.29990626931854614, -1.6712149458884369, 2.311258202034276, 0.10607002794552045, -0.7703874252244187, -1.8125641092932483, 3.7241236362691215, 2.0550338164927098, 0.8439798600496378, -2.928909877487399, 3.368356069583877, 2.5908335102163846, 0.03899727167785194, -2.144250792718026, 3.4332275389400255, 0.520435759756424, -2.2010856371113388, 4.432400474672818, 1.1864935513234176, -1.2263175359925071, 0.5848035502279689, -1.0277832286227522, 1.1692288068628276, -1.629232872785792, 2.3153777360406256, 1.4435061308623744, -1.2192287922640954, 3.5061704672126552, 2.1619855794800404, -0.014028072909127332, -3.1984764556597494, 2.9756171459240477, 2.271221677927622, -1.7868148686819723, 3.202908380493989, 0.9292936630018858, -1.8124303966411954, 4.719384595778251, 0.6542999441174633, -3.060661722297368, 3.59275194397045, 2.312055708772391, 1.6312844679744902, 0.291164772507841, -1.8729076920532517, 3.0942866641227056, -0.5895287484433194, 0.6470631988332798, -1.7270922275762697, 3.1579315684931544, 1.420975431449131, 1.6035285160679678, -0.4686498579391465, -0.8749735770624056, -0.24803989853208996, -0.7646961653766766, 0.6000686927642054, -1.7710110709389255, 0.1909026413992141, 0.05881368222128458, 0.07575439779119542, -0.36051089803129344, -1.504949127969132, 3.390778686580802, 0.6905257802632949, -2.185465524134429, 2.2070952599229603, 0.7293162617339704, -2.511072504822925, 4.0653912304611595, 3.234079274755084, 3.404804198386614, 0.47942574308270913, -2.6838336288468554, 2.51531475661667, -0.7318527443416087, -2.473393475854584, 4.68955130883171, 2.4806570911392445, 1.0888799493774286, -2.856292689320446, 4.235892918765444, 1.6660485066973596, -2.391416775684206, 2.6485565402832325, 1.2801228914510148, -0.16714569909200883, -0.761504659103025, 0.7589086068060968, -1.2290813513012608, -0.6282218898353786, -1.0876969247634634, -0.2374860147078035, -0.2224451102489411, 0.5434495888963173, 0.1845013626433456, -2.1966873117948236, 3.950265830105195, 0.6491783187862783, -1.5025785165645402, 2.5153742394046166, 1.1064287238540373, -2.829153681412583, 2.5653866365654494, 0.41152158716212206, -2.4581879971038916, 2.849771445258364, -0.6410128057115116, -0.2553078453987947, -1.5553935650033281, 2.58013979531969, -1.0008621677781093, 1.2873429859442584, 0.23118422576851572, -2.9983033944612654, 0.44570402390775143, 0.19967012741980206, -1.202233397757368, 1.1737590765611348, -0.9023330402372949, -0.9377081235519764, 0.5684199403227694, -0.8923892222015066, -0.6147405384703006, -0.029748557998152236, -1.3514021265694964, 3.308949126021128, 0.3209480642959761, -2.9145825292694436, 3.526440241590194, 1.1886264696981588, -0.9764853877371706, -0.6838707332213172, 0.2905361008484988, 0.22482861807244525, -0.4287533817326903, 0.2998200842152645, -0.02859516112255278, -2.2268940206818453, 1.9433842990671337, 0.6064479028786653, -3.150291062602605, 1.409403814780001, -1.5712178869456466, 0.5991757934147817, -2.2858324332950133, 3.7177807462480477, 1.673179007823478, -1.655672037874444, 2.2529541695854505, -1.9477727082981229, 2.7822494316839084, -0.9797166693320261, -0.5065609442048071, -1.6483164739925424, 2.0024438962879003, -0.22688744592918475, -1.8287802150865673, 1.7420707679034084, -0.8323981299466823, -0.25285160987508526, -1.182342900407889, 2.0874043534826914, -0.3461304513838286, -1.1063496936872408, 1.5666506466496912, 0.12994053144799445, -1.6501039191515474, 3.981291598136943, 3.271420214738214, 1.5680686900327263, 1.12900449606434, -0.7885364275512412, 2.1128284994794058, 1.279346425234019, -3.5716395633697857, 3.0196059334088776, 1.247941981115332, -2.229884685435115, 4.818313962760044, 1.3070170433970478, -0.01346340722182049, -1.6044263567996833, 3.6230840014997057, 1.8552715724331055, 0.500813758035406, -0.7522779013593546, 3.337180560780439, -0.03303547697900022, -2.9929279706501575, 0.5848714148910066, 0.18942808794065513, 1.1235546354677926, -0.017084064576124547, 1.7486598075979263, 1.1079238305472927, -2.160460419132084, 5.211939471774599, 3.5544085842324993, 3.718052777340631, 0.29390515047495036, -2.647030801022197, 3.6108610912146677, 1.429954023706955, -2.096970788513806, 2.343862308896746, 2.1392277377767304, 0.7538052535527413, -2.9078684148385374, 2.1743988307042628, 1.1013577276521236, -0.8642743195179037, 1.056197731652981, -1.3943166534428428, 3.7506121275756303, 1.8001893321142006, 0.05419179478402647, -0.2720398477887329, -0.0655703268876433, 0.8868082038042076, 0.7843254384406126, -0.5097045139992815, 1.2087680405397467, -1.7477203285690166, 3.5178254701617906, 2.873188938296039, 1.5067859942914428, -2.1977090334640934, 3.746440923697685, 0.8738587146707459, -2.4616199971156103, 3.389693755516305, 2.428745751492409, 2.1685046268884207, 0.3988445691879523, -2.167401951659599, 3.438448989670599, 1.4096971736634032, 2.227136126855351, 0.9772576118283496, -2.833139543576669, 3.768500483814819, 1.4661793266036174, -0.8198950570350689, 2.9052455157556896, -0.7511596977852832, 0.5594490571870327, 1.2149661129736842, -0.1715495838330181, 0.32002884358041683, -1.5615125233421505, 2.4946508594260877, 1.0965249020477703, -1.469614751960421, 5.544670269922301, 0.41554969768583305, -2.9762933040515573, 2.927770445789406, -0.8058466386760639, 1.237890347136613, -1.062689981047276, 1.0697903489252667, -1.0125683173390936, 1.0284964889420962, -1.8009572759000658, -1.3826112194523148, 2.6987189897227726, -0.5413004568957831, 1.1289751617260553, -2.3932956558541036, 5.022207812206114, 2.743400670226606, 1.2455186432381087, -0.059861822400648634, 0.4595101599098488, -1.404599429105815, 4.049750801625203, 3.592747852295929, 2.0613056992716228, 0.519414578654164, -1.0342921114078418, 2.719734150438512, 1.027958193064558, -3.620505997777741, 2.3565431825973864, -0.2784894650807246, -0.5001097359217166, 0.3219060032084826, -1.2641589241956463, 2.0388538899702553, -0.8819298365178039, 2.0532584248215926, 0.9918935726182898, -0.8607274249148986, 2.076139587252408, -0.7756861385151979, 1.4104694466642176, -2.3475795970390436, 0.7220714413143359, 1.23831630805023, 2.215033543014295, -0.5383654074267952, 0.2543691284136802, -0.3945566834414649, 0.13612329057203887, 0.1888671405607738, -0.49047673535907244, 1.2297972364207226, 1.5554602408511418, 0.457878219621648, -2.6867595556113084, 4.188503528526212, 2.2933110723234567, 1.9093653391931866, -0.6511390556706029, 4.523154197030976, 2.2007405181567155, -0.076853356786728, -1.8018703026690783, 2.801465786690983, 0.22826029814958737, -1.9570102699041172, 3.738401991227045, 1.2103998781561813, -2.1146500934854995, 2.2872873697918976, -1.8383645634093337, 2.5863942061163243, 1.4788009808035785, 0.8105536663327939, 0.10609012226276526, 0.13227796367516476, 1.3965338352464531, -1.0881960690973074, 2.5808697834837293, -1.7203329902555424, 3.153097609480108, 3.4878675334906575, 1.7683932692599118, 0.03126776236547357, -0.05004962168451321, 1.095461702715852, 0.25377218079128205, 1.7568369767244576, -0.7241232176819832, 1.2344011923099742, 0.330934487756247, -0.07682252657343724, 1.705276656699505, 2.341495508951425, 0.26094678798116355, 1.2292426170364479, -2.316004897642335, 3.020796503014367, 1.647593690046131, -0.13641455760682675, 1.887057739570162, 0.11946985851170666, -0.927957684851128, 4.657247355028062, 1.5609590013901542, -0.5062081393313065, 1.804695625394368, 0.42055767050476334, 0.7352340526682273, -2.8672381346492557, 3.3335047997512337, 2.3158373944810364, 2.213824713629572, -0.20869480001567808, 1.4531571388848423, -0.954223714686691, 3.1887589058620396, 2.402679788758519, -0.119058370035793, 0.17914640451851938, 1.2779203553523875, -0.25853825045271606, 2.8311165448336286, 1.9872048087803478, 0.3382941471587291, -0.16284794351452092, 3.399554706674815, 1.8459031718178949, 0.06438036111793544, 0.2722301951893087, -1.6666602934950898, 2.6956886985884694, 0.3714468891972391, 1.00547291089822, -2.1266569207240646, 1.8040705965871666, 0.0561206405814918, 1.1291326309841452, -1.1914701084992085, 0.8512284822003267, 0.0028966666810337216, 1.0036964441372902, -0.7341216764092788, 1.1659682949870103, 0.5577811736344191, -0.8278973918746715, 4.158411330024672, 1.459275065605084, -2.0936769236526853, 1.6069919520590474, 0.06361292869186208, 0.44033192370932284, 1.444533626219334, -0.9487764291958456, 2.705161776940793, 1.8039132282168566, -0.3265247767325601, 2.175465110898017, 2.2255672517581733, 0.028612868312279716, 1.8920237250091194, 2.3150568195463848, -0.09007354751194008, 2.525123012756808, 2.7012454953688465, 1.7222019536956168, -0.7641893801450461, 3.764144965813898, 2.661269971274658, 2.4667799552215683, 2.8310623866769564, 3.1381441639322247, 1.7686276543377861, 1.1555699576719007, -2.9648895277218, 2.415644798952485, -0.3335139306013044, 3.613498205418068, 3.0090231131312866, 2.3522394194195613, 0.7668700955678904, -1.671977870169144, 3.443754031387096, 2.293539434086483, 2.9655877023165775, 2.7192542819474284, 2.3446335266058558, 0.5860756914415788, -2.088755683594547, 3.932751842040375, 1.6000760459652046, 1.145333808600185, -1.0335467850303868, 4.39691523625595, 2.2124690991846254, 0.16944328538454556, 0.7087976627086281, 0.5519012519515627, -1.2334953238818454, 3.4578005390220596, 2.71103555822682, 1.5815991087446264, -2.5046585213853287, 4.3443518690190785, 2.22840841369233, 1.956025552114511, -1.1873876966123245, 3.9552761794119533, 0.11426177837764762, -0.8755531527195899, 5.997391112571302, 3.037277329866697, 2.169111787502141, -0.8748679942719946, 3.236456759209057, 2.13171634352409, -0.8804653340261321, 4.523487796112818, 3.6603561593297744, 1.0813648325428176, -3.982924341449154, 4.224406641996097, 1.2711455534959786, -2.690955534518366, 3.932181361633946, 1.9004609379925341, -2.376785751715408, 2.5816594196174947, -0.1055546786514352, 1.580047925485701, 0.3777696040311529, -0.9576351676925015, 2.0570359447379705, -0.3761854393679869, 3.855356907981866, 0.22204135567051253, -0.03390594873727615, 3.8102432079966775, 3.8192971277099677, 3.3661440062377324, 1.7053389928701908, -0.10785474104807236, 4.264589345657976, 0.9916861563277735, -0.16235317019837758, 2.140230866795605, 0.31457400085454346, 1.0220345699552809, 0.8093996003040846, 0.5418979293380062, 2.2731965954258957, 1.0457816419010442, -0.2140106401679187, 3.109439643093424, 1.362403756243646, 0.08468824650560691, 1.5353281616813437, 1.1758597447995953, -1.560386132102769, 3.8692385887414957, 1.661623974662314, 0.02661618661738885, 3.780188739645917, 2.0409082462364267, -0.3624883188344139, 3.8711469911512495, 1.215364169413613, -2.115320368057951, 3.88612178082675, 3.000959596801181, 1.9706042063449676, -1.379645625012131, 3.020689563691656, 1.349780215831629, 1.1688775776206857, -1.4937998729502624, 5.781699536259646, 3.523288365228723, 1.8760411383342106, -0.402214118606139, 3.820449820341844, 0.9792596723863198, -1.8049237231020125, 4.353083139977457, 0.8104959731141097, -2.358607304027032, 1.8820161130866726, 0.13341070951798883, 0.7166970708209082, 0.18600608644180738, 1.746293678283644, 0.013252039247959146, 2.8705138803203116, 1.8999520670557786, -2.512063792891615, 1.6203044833717968, -1.782348071537319, 3.5539100903268945, 2.3545542332072618, 1.4372224984407467, -2.5775839268093588, 2.0346178036805895, 1.9366414132169556, -0.7005027439928426, 3.191217423926526, 1.968711669784966, -1.1334358594753322, 5.57427807386091, 3.9843698319897047, 4.383625434488636, 3.4912500040241756, 3.7757976406418265, 4.997676043707168, 0.049775055681379854, 0.9623654485709157, -1.7352854342472028, 3.8886029705405125, 1.0424876404566703, -0.8450338388851488, 6.811723482401135, 3.6000672841706436, 4.265464760987811, 1.8498157704030636, 0.14102762778827582, -0.2332966397793026, 2.9058632477161837, 0.3015260643456603, 0.22979809206196933, 2.395005458938238, -0.1603325352854199, 2.4427562901253967, 2.7825902686225845, 0.4345129807550965, -2.005941472519339, 3.7774890023500465, 0.45791840741628675, 0.684221698545878, 0.6676354491791017, 2.3283318044994648, 0.9597100038471353, 1.5726119199606163, -0.7910603020692406, 3.8042118507363174, 2.4854465767956526, 0.28864062239139265, 1.2370376009447455, 2.265788873119016, 1.4002955524709932, 1.0840380341504332, 1.2295652066394496, 0.2576737344350821, 0.9536026035883651, 1.1333797810346713, 0.7064868788055492, 1.4578944018120072, 2.2653899039922862, 0.7077955839593759, 0.558458177989337, -1.6933998195637852, 3.5472011927539597, 1.2504348378386911, 0.39664297907972923, 2.6261332957800168, 1.0526872060016785, 0.8904500758943303, -1.193835384210729, 2.744839620245182, 0.470212193022121, 0.10070154377157259, 0.06774471844789787, 1.1741424438622179, -0.2637940662599476, 4.269244929116974, 0.6242886771259464, 2.684267044325532, 2.006729558769507, -0.9993243621540042, 6.885971915432378, 4.967709165230042, 2.857262797803628, 2.0180254455952653, -2.0486146797003357, 5.170314206308683, 2.839330689913254, -0.26981010759133106, 1.8630069733179653, 0.5406015776860276, -0.3432324441247374, 3.0372964840970216, 2.560761537256326, 1.165668977053281, -0.17917877258253156, 3.8441513379146617, -1.1852876613330636, 6.139560066338015, 4.583537968713131, 4.669599133347072, 3.7406560593925633, -0.7234438171800885, 2.8765257092280763, -2.0053954519973214, 3.235538085317671, 0.5545298415089182, -1.3351886994142887, 4.5371648842481935, 2.5380758863237816, 0.4174254444731904, 0.4664373031763489, 0.35214226542196947, -0.19776660873060337, 4.347009289462983, 1.4955467953285506, -0.691487132157965, -0.2204875017497443, 4.910868473182598, 1.6439322198629043, -1.0671722367052663, 4.88722173956819, 2.8548607059772966, 1.4003305973300257, -3.450473641643077, 3.8396880514982286, -0.2622187449389113, 1.8773007191256283, -0.5308938441586744, 3.6579859230977263, 1.3438959478597443, -0.9451466836191003, 4.8761737127868745, 1.368417279779237, -0.9190480617900558, 3.190070308070858, 0.5711096090425034, -0.9939700616570235, 3.495114931899332, 0.6121563691039, 0.2813942720939284, 1.755874798290165, -0.21663566232124332, -0.03465280826014805, 3.662377020888778, 1.342376238610882, 0.08810834150684776, 2.468407883791656, 0.2546366883583122, 0.9022130371730555, -1.0105994634247164, 4.0818449517090585, 2.212012610642285, -0.17502935233744665, 3.342991838224714, -0.29859145168950363, -0.11321952322729167, 1.7113952434382327, 0.468366981695306, 2.330896025406105, 0.42340481490631454, 2.4588483575415694, 1.2422406971798754, -0.08550159653634637, 4.554194882706577, 2.6885117609480176, 3.010510655721953, 1.2010369968583063, -0.8350744596920432, 5.722317165326672, 1.6097036346671647, -2.121711727425577, 3.368356939308649, 2.579333669515904, 1.5558681897217301, -1.5477665153349562, 6.251523846991256, 1.0323628529903317, -1.9811393644896498]\n",
    "\n",
    "U_safe_list = [1.6064451932907104, -8.149268160705788, -1.8908408614933307, -6.9231068682570935, -1.2673479729922903, -2.4363405759129932, -4.181444451846453, -4.213310715813861, -3.110069886586068, -4.105076022521381, -3.945477410381919, -5.308178392576757, -3.797362548457521, -1.1049526059582249, -5.372884657291614, -1.8594313211664186, -5.388148877170323, -2.7435029837116858, -4.120935738314728, -4.27136387176224, -2.5445486391044767, -2.357419344175149, -4.135255198669682, -5.296045069993987, -1.643191069485482, -4.1666997921064635, -2.100996991693677, -3.6239215048959963, -3.8250529383509217, -2.296048622552256, -2.6744865605653274, -3.1544372520226247, -3.150707358017513, -1.3432244307276946, -2.826396757983872, -2.7311406738498576, -2.521661283217128, -2.5357935501551694, -3.0454532391904934, -3.995603481819437, -0.7799506705801207, -2.1577755438572623, -4.306980301439609, 0.865776221272661, -2.4271273321749334, -1.659330393796374, -2.262073304265982, -4.3909295132982535, 0.5673851673308263, -2.4434610544349127, -2.3061350790663937, -1.9007672398945417, -0.8152372516814239, -2.099982467250605, -2.573725210818452, -0.7023768914855495, -1.888079468549563, -2.3857630316718073, -0.7175837762478068, -3.153223179440964, 0.6380335113848332, -1.927179765586196, -1.9033257918950994, -1.1726920930879245, -0.06965264226403178, -2.240269747329556, 0.38395080471309484, -1.140576722844024, -4.2863394216001325, 1.762087779891182, -2.3727330531701227, -0.19906939274155633, -0.8605014911918261, -2.0096203942431643, 0.3621601662853209, -2.285400402589083, 1.6435873107689076, -2.478464420937904, 1.3307513191239195, -2.274181963491479, 1.0919204717825437, -1.0413598389798935, -0.490038544689412, -1.0408298792478305, -1.9549144742217663, 2.228760731128496, 1.2300338747787123, -0.3615920462822757, 0.9721281849625143, -2.472116831186831, 3.1118798357375113, 0.7184065575523348, -2.1549427602939772, 3.821176761498755, -1.040883007278751, -1.5046476874292054, 3.3579325477826956, -1.3921481537177485, 0.8255308438033921, -0.7408169237312947, 1.0003720642174017, -0.46429686261608794, -0.43253663446256496, -0.4238455305753561, 1.4120128799834788, 1.9867228842727016, -1.5514801327014425, 3.3328039813191097, -0.8846097016627823, 0.44693998715366234, -0.0485079115291569, -1.4613276739987597, 1.2203941961020632, 3.0738574930160283, -0.603007979857864, -2.998756864245017, 4.009390434898307, 1.4635158289725112, -0.5383331367769983, -4.527936254433818, 0.7425199120021375, -0.4298248078371145, -0.8659411113025612, 1.7764399171833318, 0.4095833332472125, 1.049519093923898, 2.110362536803734, 0.08958135754279084, -2.524963751465691, 2.3886118562315986, 0.8186836397604225, 0.02705702158551304, -2.084010719268406, 2.5671173449357028, 2.9854932066978677, -1.2083722398908705, 0.6793259354695351, 0.5302201365341332, 0.17587389327042047, -0.9564949125067344, 3.3590217015126314, 1.5069568571545986, -1.5520307314681645, 2.998599162274566, 1.5602609810494528, 0.6719164698226976, -1.0993037348734447, 2.253663815943817, 0.4231517430426379, -2.0462550543231757, 2.698384381267772, 2.9311451940923305, 0.4308695807768004, -0.9276153114403698, 0.6686933659621559, -1.020596350091175, 2.4386044234852875, 2.313062261216153, 0.15452997046674, -1.633356274610371, -0.20354395402085856, 1.245769677280812, 0.0399866145801866, 0.12957051582908008, -3.504404601522481, 1.3133877342343183, 0.9401069357466554, 0.5482798847074335, -0.1076317598178207, -3.333948685962689, 0.5521490572439802, -0.5940515318511572, 1.1279531416224131, 1.4792919585538655, 0.3952130364530717, -0.2639099383964023, -0.3885658346318337, -2.638390824628452, 3.533814917018219, 2.530568381014298, 1.1586016074268741, -1.2754178110558243, 1.9036008013757169, -0.861597239760151, 0.8999408694556337, -2.6694906740613007, 1.3917090474467955, -1.4232230117140645, 3.245360370098581, 2.80785804258813, 1.2303479857862953, 1.2190159555266362, -0.22720562720422777, -2.669823468384486, 2.1182688525885283, 2.7691475186347887, -0.4923207472031095, -3.2777426654010853, 3.2022367888446865, 1.3652418415131322, 0.1402576831886222, -3.7529599370482103, 1.5183421409900006, 0.31168793796496885, -0.4265962841720352, 0.7451789897977577, 0.6252133424939643, -0.8286370658361122, -0.10068894645718274, 0.7278378902019611, 0.24378803640007618, -0.7666629146806301, 0.7950483088321221, -1.0739879698644401, 2.2465695609649288, -0.5778538772637987, 1.2142021123714244, 1.406876202183419, 1.8942770979256807, 1.6275548262804094, -0.02225132215511394, -2.5982843040162535, 1.6730500870972378, -1.6776602459392436, 2.5365490904424064, 1.7933446087902283, 0.005152420479191733, -2.4703324888121116, 2.305417091854963, 1.6654654433862177, 2.101342535830838, 2.696980839471742, 0.9200664724306193, -1.6339727199917817, 0.48578638701638965, -0.8683188246029587, 2.113580945595288, 0.21348378276730529, -1.6726945497613883, 2.6755849301555443, 1.7714471694251301, 0.3313584997670276, -1.4058405195193586, 3.2395733777959848, 1.819118164470467, -0.5450675927638642, -0.5113831404470943, -1.1383920112600592, 6.069589953074512, 0.5924908909985405, -2.706651465263519, 3.0194740648059977, 1.451664578975226, -0.5681511256313954, -2.0717019363166287, 4.206562652145529, 2.0711570453475474, 2.349328053398729, 0.9087999401143065, -1.5068308843617544, 0.3740121131739329, -0.02628930974582744, -1.0105872504083777, 2.8240414177746587, 1.220583775086027, -1.0042359541946482, -0.14092337861274018, 1.9552407464691512, 1.8602403448219889, 0.29427412359496685, -3.617168704660969, 2.89698716180488, 1.4588430469937634, -1.3997100222456922, 2.303552691571724, -0.8164997338933446, -0.9173141872508381, -0.7265202653512617, 0.012108472641386925, -1.6653017088580029, 2.7488144581764686, 1.6149128950741058, -1.2471416378904792, 3.271756340647137, 1.5036598351942416, 0.5388235561180252, -1.7035007170235872, 3.1737248919811307, 1.2662488899330242, -0.991082864632169, 0.43919228221767526, -1.2576021120231573, 0.2079971267986025, -0.8784991098638031, -1.5989827314323861, 2.7630321312625554, -0.0736185562154219, 0.15236424294733553, -1.3236010698410041, 1.9926755896248167, 0.9060821596695519, -1.3258169753227023, 1.6729414271586052, -1.2922530626228408, 2.620455310237105, 0.061638597127092964, -2.8469361408196505, 1.4402342864332596, 0.21058397142502372, -1.435488454925654, 3.210370568232122, 0.49626875578272944, -2.4783001398527063, 3.796501029818536, 3.1697962672561175, 1.7265322353060029, 2.6014066876496713, -0.5302672600946252, -3.0561859994949714, 2.459843535853942, -0.16055391063758861, 1.1749793597419185, -2.5601107754218333, 2.7354731227524454, 0.45351764631146807, -2.6570590121418363, 2.5390682595107705, 0.9879417828515571, 0.48709144481932753, -2.4355065612007465, 2.308977827399815, -0.5077662043358586, -0.896771426662724, 1.4644993892461926, 0.5750478402379144, -2.3342827232526915, 4.0055482005346335, 0.8629793714053804, -2.677387217793637, 4.285861572118883, 1.4382783493866214, -1.3993550274035087, 1.7206749788074944, 0.8155481428575868, -4.73507052598319, 3.030701069484202, -1.716181903242557, 1.9743792266427036, 0.28247180533986693, -1.658165976702513, 3.448094919864218, -0.7536017656247722, -0.6683768012935047, -0.3421177750560318, 0.18019529191866468, -1.4351484325242936, 1.0897586586352759, -0.9422415498329073, 2.75565253758856, 1.376648403428625, 0.3866819164296089, -0.727721339705532, 1.3178612118909427, -0.5750263433712561, -0.7719079157167812, -1.0430569854640552, 1.6686880947355007, 1.2177674204370206, 1.1277585927510358, 0.4480685898973107, -1.7235479668251514, 1.6673872230215139, 0.7982742824552247, -2.832312813831514, 3.7090621637453864, 1.5272419194782643, -1.4267159525788315, 2.073703293024927, 1.7590124272992966, -2.620714423590208, 2.399952446901864, 0.8415699366653726, -0.39216917827974385, -1.073388807120601, 1.5052863271722003, 1.2586847666082477, -1.1420312936187997, 4.021624447885451, 0.468518967318289, -3.3646341731088896, 3.396850650489853, 1.2693669171624506, -0.914746954382224, 1.0089530898592685, -0.9532159692619189, 1.1333392214510596, -0.3688059714470455, 0.8963819693938504, 1.515973360855014, 0.6415032013385726, -3.282888903360117, 1.9152195277104411, -1.2001078270234302, 1.487048677089014, -0.3523902277304387, 0.5277670699672754, 0.3036063313481918, 1.3088647832749203, 0.07714522482956454, 0.37196969613004427, -1.8007898553209998, 3.972329043233266, 1.221638877215355, -2.4424179582244605, 4.067191518880918, -0.06491704634091633, -0.26412585251682685, 0.18302332123588627, -0.2718102619724476, -0.6724126774879196, 2.650229021743556, 0.7750878145434754, -1.3612891175794601, 3.3605298216589645, 0.7762137493413803, -1.9377660718727938, 1.476638264492479, 0.07147527152304889, -2.6277660493974935, 0.32908779310040615, -0.21391887245003716, -0.20885098016693604, -0.6378001025619113, 0.41756264280960664, -1.2296005277017201, 0.28724525530132183, -1.1315338998262376, 1.083536908091709, -1.7385892682402044, 2.1625262773389196, 0.35151042644368147, -0.5078626792698842, -0.15627890217926677, -1.88085012932671, 1.6878013730345884, -0.24829860309974805, -0.2018429593610307, -1.8812805501208558, 3.2858625949900926, -0.3888047472180105, 1.7762555659881656, -0.3651781219600636, -0.39525298508139883, -0.26732893226937193, 0.1706366504939325, 1.1518112727961878, 0.0894659156235349, -1.7188587992396762, 3.3420411106578314, 3.5539761051940175, 2.8469947888163034, 1.7791980944483683, -0.12738550650355762, -1.8053201560988938, 4.327690924478887, 1.3097408442398617, -2.404774379380612, 4.3813486315183425, 0.774987923953816, -4.351364378294527, 3.563259199535608, 1.422477788727413, -1.406328020037833, 4.901066137102028, 3.5269358837369538, 2.8050181881761844, 0.7438914253882132, -5.16843498217451, 2.586853903726663, -0.5226389461250776, 0.6646168539129604, -2.2928126994930764, 3.036304033311538, 1.5767725350077697, 0.4563979260867228, -1.0342710864907687, 2.9037534717219415, -0.41192015136140725, 0.6291929539995209, -1.9393475631815065, 2.8825808213925512, 1.1168507690407594, -0.6051164321605, 2.6530677494546424, 0.13159911941802704, -1.6401411462767257, 3.1892718198625545, 0.40539900986266986, -1.1678561507167586, 3.307414900719671, 3.421976393013395, 2.3702050432519925, 1.7257276019419834, -1.107942211757397, 1.5734433316553833, 0.01778658087722107, -1.982142238657886, 2.6078328651173095, 1.4494204875606584, -0.32046195329450455, -1.107790241285599, 4.7773278825888, 3.463558135999577, 3.8122079078901905, 1.6599885831034982, -2.0669917893966314, 2.2678799265647314, 1.73966835071122, -2.408383312597195, 3.01475593815929, 2.6288350375049987, 1.4258357312727483, -1.7238236027681495, 2.414319403699558, 1.4626334192086716, -1.5325816851574174, 4.1233718180535135, -0.8424167431595535, 1.6514178040467442, -0.6058175401741366, 2.5908501670798643, 1.7424914977781398, 0.022452930943202887, -1.1735449335357018, 5.488063714810508, 2.6685135108526836, 1.518022879399453, -2.934862589161746, 2.273052770380403, 1.1060006688602542, -1.5408201383054774, 3.8691597467367345, 1.3785641502961, 0.6048719397039193, -1.453489648478623, 3.0749345034745446, 1.8335207663964894, 0.7721755767451057, -0.7337989631580939, 2.724414067466462, -0.04105719531462171, -1.770866924016552, 2.4425150773128763, 1.4167438916991912, -0.47864228053758495, 0.15709683668672625, -0.2058759253980469, 1.7729609205051773, 0.8170507529172966, -0.2264226553708042, 1.1988449707057072, 1.4529389019479666, 0.7137225239182072, -2.090819082823252, 2.0109145259936696, 0.8365340973213122, -0.7664518156655475, 2.316718897705762, -0.8666368535210012, 1.736038413979152, 0.8731876704682264, -1.6515898460894434, 4.68041032009792, 1.9052762707250466, -0.13782110331662523, -1.4794777587704786, 3.6073611470769293, 0.5640788060517323, -2.0935986367854156, 3.580352472224952, 1.0477991508655151, -3.668434084134894, 3.3099587813107547, -1.6711383121547598, 3.5565658510526674, -0.940131427312842, 1.6159248466860419, -0.31739890118671354, 0.11331015929995658, 0.5223344890999968, -1.3976072776354584, 2.6663893371313705, -0.4588632987311456, -0.30049507233899675, 2.2737018619204292, -0.6539588497627093, 1.0866961732585452, 0.4564902323680897, 0.024425303852197544, 0.30832763492242776, -0.6941602852498789, 0.29262097676082277, 1.079048574548736, -0.3734897709476215, 1.1373888840691535, -1.6122761212794146, 1.9645262374317127, 1.9379293913477298, -0.6899820668557339, 3.2480112600530404, 2.3205164029197505, 0.689843024003217, 0.3108558754676807, -0.22899139865722162, -0.44683419637367194, 1.302266577272981, -1.9974835436449183, 1.9557759857559134, -0.6958132906300278, 2.0462342583152306, 1.9507610500943002, 1.4247039913308939, -0.4639515133829235, 2.6936748125692205, -0.3344231138294589, 0.4036933092240318, 0.35069672752020153, 0.3521665258726401, 0.5688710596895845, -1.317743577355536, 3.977848898402911, 2.370820993774437, 3.1525871871417195, 2.9906925095569434, 0.40700681319863463, -1.640706358346101, 3.4312056703056015, 2.565281830422869, 0.4569360852764959, -0.17922092067561124, 0.9162258873584079, -0.017843725908782915, 2.8823040898896153, 0.42084299070251774, -1.9794340976041411, 2.654413355093716, -0.05797640136010784, 0.6580148150982907, -1.0729049847796404, 5.0422200882180235, 3.3168905483980353, 2.3386127996504413, 0.3433287390216293, -3.035603164810304, 1.8411737124260554, 1.3839107357502556, 0.7013597405675256, -0.01560025906524487, 1.5551082702367722, 1.1589280761849707, -0.7285256006653498, 3.4224573587211538, 3.035636629974718, 3.085719018368259, -0.12630093229385864, -0.7542903190683816, 2.484123382440842, 0.7163749505575154, -2.0139690962824233, 2.682230004780145, 2.0337227117633603, 2.6421778280293395, 0.9044027788404065, -1.6744628852809953, 5.858828929711265, 3.3166855668916426, 1.4291969953555537, -0.9122760994849202, 2.9214362059719434, 2.510152438912151, 3.633547076098651, 1.9113444135638886, -0.23586599672675845, -1.4067876816277973, 4.109118197231467, 1.692522513125546, -1.525544121073878, 3.821482407946128, 1.6116728023134357, -1.803297863736411, 2.4922081575186468, -0.7649084007296594, 1.5596464946010684, 0.9717805428537716, 0.6251337884932155, 1.620101907780004, 1.5392174788612039, 0.17406302575745514, 1.773953324895004, 0.360727843560376, -1.2859142624384248, 3.590536846452956, -1.007515384821133, 1.6311847099252148, 0.6146524508457816, -0.016611702029699416, 1.3323174054111888, 0.23358511433679752, -0.8687262002622873, 3.548313189931555, 0.5268733854263274, 0.065794278890003, 0.5948363888928299, 0.18462806082215621, 0.6197504148254467, 0.8286598081246623, -2.1498606765639323, 3.048836794317772, 0.5940341722048998, 0.3184158931687264, -0.0473190914857895, 1.0251499632956396, 0.06477220828453767, 1.6648959381397574, 0.10340388635616193, 0.8289435551902855, -1.074270955881886, 3.0296254269976046, 0.33674578971279345, -1.1001197433309287, 3.3103312811307006, 1.179085829955234, 0.4135724336536697, -0.10592716681485825, 0.41559648822993367, 0.9427906585276062, -0.5684406472067316, 1.7985171290399151, 0.44453721669895785, -0.29919587008981097, 3.3033060673002943, 1.414501793011091, 0.7280098779407886, -2.5338126077279455, 2.545429314060751, 0.4479038807018654, -0.228976860631807, 2.3939414479879773, 2.234747705227786, 1.1976660711640719, -2.394301583550547, 0.35358251715815214, 2.403613206904705, 1.562586380927037, -1.3651642118678105, 3.966507823571824, 2.3378542747338393, 1.5849870417893683, -1.1352880127417997, 3.8197895680511422, 2.295797695634686, 1.0271490089814463, -2.0304024889522374, 3.372118146647786, 1.309466376241911, -0.36158720072699424, 3.860472839263533, 2.7992311963914247, 1.9020895912068987, -1.6376945893701347, 2.887878168937899, 2.4993886244207673, 2.096885775561244, 0.5690013683358259, -0.7204910373005227, 1.4721788880830857, 0.13799358741351497, 2.8189924576633487, 1.2550402408521073, -1.228870221961465, 4.544745689388659, 2.3025079145788325, 2.322183164767633, 1.033703571430756, -2.1353072976347143, 2.1241790616310894, -1.003133347680265, 3.278672620644734, 0.5752704030016353, 1.5476604831980652, -0.796942644378138, 4.567007003138947, 3.1163248443005465, 2.1190492622169543, -0.018289740113974773, 3.109736014910318, 3.1185417000776248, -1.300805344919631, 3.741081475549148, 2.931309750954547, 1.1528460129772462, -3.5125491803813063, 2.993460621153357, -1.7713837312733673, 3.2519353333806826, 1.4342554929059546, 0.44880638395596506, 1.7713052306168677, -1.275997226603355, 1.792734649529514, 1.793558224282318, -0.9931462309444825, 1.5550197152103316, 1.3801852032289688, 1.0116584056819953, -0.9816615858047655, 3.3207082670421038, 2.854596640444136, 2.13300456851783, 0.4455241227502782, -0.6028427764388802, 5.622459424028996, 4.601276077650876, 3.2270302036873844, 3.012403345543756, 1.4161096712147199, -1.5783593267909204, 4.7672091213340835, 1.1214815405989462, -2.4755921605222895, 3.515395055452867, 1.7937102950696797, 0.6474278069587704, 0.9450034237585285, -1.1878533737902366, 3.0262986490475967, 1.0766961896885583, 0.03475435753956191, 5.165712392205645, 3.69257811351293, 1.1847021233558586, 0.06898235151187038, 1.9312311175969477, -0.6301675216067153, 1.568283886161847, 1.36015681888842, 0.9613258580145008, -0.13625140543569358, 3.363891116947965, 1.3625396007106545, -0.9461671928359614, 5.441286866086223, 2.262138424798362, -0.1271560899343669, 2.548271490168812, 1.7075171782877376, -2.6510308761401724, 4.217364991529969, 2.5149411873814493, 0.13876738689089763, 1.9742311068136438, 0.24806061172387928, 0.6231132482377539, 1.4978567767462962, 1.5344638801422512, -0.5303544355450569, 6.062405095663674, 4.920400094280588, 3.111239233820637, 1.7956560382768956, -1.5193469626149785, 5.111728823121332, 1.759811014295959, 1.0503793131825958, -1.0944499474983935, 5.818628958225993, 3.033834792414094, 1.5220499983439666, -2.373286521423612, 4.2445235730662105, 0.43193151243275096, 1.128652312235893, 0.5007375630067905, 2.2917957805654012, 1.426236755816884, -0.9329334537436509, 4.2926253888346615, 3.0263794168673783, -0.3167358389417281, 2.4284125061782404, -0.5608857564810172, 2.523776360177756, 0.5181417860287034, 2.7669007301657373, 0.7266571983647587, -0.8677502284489194, 3.4802663098973277, 1.3315929089868703, -1.7627965579729938, 3.580780503950457, 0.3940145407697706, 0.7248085756938352, 1.3381906184615069, 0.4624778161788825, 3.6859843657686575, 2.980681723010214, 1.534724317646745, -2.9563372325090924, 1.7441533382154226, -0.17467309462050906, 2.9770695940643996, -1.162355096744129, 3.4664516295653662, 1.1790625119512086, 0.25966283810538116, 2.8152742908470216, 1.5785546703938813, -0.933569533498364, 5.8226972936628805, 3.7521533384471084, 2.9664621773574105, 2.1035749541380326, -1.1807544477176783, 3.8176178276381805, 3.7224574573212372, 0.41978907088662964, 0.41962986327615326, 1.8333463111167774, 0.5923996420789841, 1.488017375984903, 0.6822590122885082, 1.4394946662004102, 0.9371897511102212, -1.7940732533962702, 3.480216196456407, 1.0363370830681404, -0.757938710934301, 3.787003084894316, 1.481569413032215, 0.03589906099012552, 2.661737812386658, 1.026721143251855, -0.7470469135785756, 5.243241736869898, 2.1056622641355567, -0.530141939961247, 4.835898597348372, 3.6185361966644294, 0.9363323435629205, 0.03734060451177612, 4.037274597382005, 3.2734669088830586, 4.234214423987563, 3.931031445524134, 2.8852690227933486, -0.12091125969629246, 2.2911831046177973, -1.1558153746456057, 5.01423579070541, 2.392307156986938, -1.812735395648648, 3.9740329061522814, 0.7081708022116651, -0.9839179098136057, 3.7868831176266973, 0.25329309009146783, -0.1576306743489262, 2.311821588037567, -0.7872161965104318, 5.749344225258831, 4.544992228150644, 1.7899378472055858, -1.3243106238995246, 4.166263209596657, 1.5010904997135945, -1.7459457556407116, 5.008416227155234, 3.8054739820498824, 0.4758212629559999, 0.1794798944018865, 1.1852916464915175, 2.6536997551073753, 0.6774941681534834, 1.1533161180985942, 1.8983723784323807, 1.2076885480362378, 0.7816366340768433, 1.675818415747706, -0.36297497208653695, 3.525421746267746, 1.617344682453389, -0.15083463371797023, 2.8908066804789847, 1.031513425073861, -0.36807245858728166, 3.66936862406488, 1.5041158397645482, 1.324346081313486, -1.8170114233151402, 3.9509613439474904, 2.419392805702735]\n",
    "# U_safe_list = [1.552756667137146, -5.575359394086433, -4.878807114908227, -4.31439598001279, -2.7212486628203294, -4.446451268763383, -4.702025503848461, -3.8046627724527866, -5.021891675663369, -2.9026623732434302, -5.615801896842413, -2.9816437704668317, -6.185377185515563, -1.9110757238933331, -3.750799149738441, -2.486480823703147, -3.234224296998832, -3.971622627849939, -3.7994346176450904, -3.431499629260003, -4.276910739610685, -2.7962171154611326, -3.5194301466999605, -3.503406684503517, -3.7012119147775593, -1.66478748664602, -2.6678638450080143, -3.6926099625866584, -2.1289462762038056, -2.396116450693313, -3.0700683567113174, -3.7252980650474967, -4.299657838165331, -2.3564416395026058, -2.3968734686575317, -1.786085283806898, -3.3848686164872106, -3.450924057671756, -0.3191737780432504, -3.7683106758575775, 0.001968425474956348, -2.4895478930098704, -2.7973440450867884, -0.7047540213578429, -2.3474596329660926, -0.1187631416150623, -3.605808105827009, -3.273369110899665, -1.2793502049596555, -1.6953509079064304, -2.2783431055237315, -3.472732791038851, 1.3280144191979844, -2.7848150757413066, -1.8957956795380824, -2.1532480776881755, 0.18836799216103373, -2.247507339964642, -1.5626905566915639, -2.3130838964288074, 0.5283339559758815, -2.221365222947682, -2.1576821092963883, -0.20821022987998106, -1.347219163138675, -2.2188074003451703, -1.1508061209379434, -1.0759584046126776, -1.4333741069072516, -0.45461668667026345, -3.7856442809448367, 2.543306136828548, -3.1475026647831896, 4.463027729245411, -2.592561476688445, 0.8186453437083827, -3.077270248023126, 3.061979179362467, -1.360999802135268, -1.251465108939513, -0.45560430647111616, -2.1490633766381535, 2.5813754809443594, -1.1098521292876313, -0.7092053550111928, -0.8371661213524959, -1.4162327888168988, 0.3731572620816195, -0.9886948798367143, 1.8245294660608096, 0.06356836102980878, -0.6345654776816474, -1.656467169233622, -0.005195732991708724, -1.2882459014335268, 1.2309225284987377, 0.1390441004214722, -2.630426605326832, 2.9922660601933444, 1.1165997443111308, -2.581580684725793, 1.5800701964983972, -0.38671258705375067, -1.0990507406656462, 0.9905419130109863, 1.3935373102433886, 0.3276295259400399, -1.1300832825251774, 2.2902798656612617, -1.5411817663065932, 1.8219647432359238, -0.3787023596982664, -1.7607663943146576, 0.5492895331274639, 0.2492701081576456, -0.05217189084460472, 4.1470801372009305, -1.996215951709658, 3.120152152755793, -1.8874360452872025, 3.5248495853991813, -2.6083222718642247, 2.943459185988843, -0.9758321471288838, 0.20416696432113213, -1.4607106874622815, 2.358780461620711, 1.525932083880022, 0.01995516522475782, -2.9864047690948183, 3.3590129817355887, 1.3187558110135313, -2.3390405578640525, 3.269080808373971, 0.5141488180277634, -2.399654800717556, 0.859275921255005, 1.2049137826802934, -1.4999903346962924, 2.4830414949451978, 2.7527790259571816, -2.639435194623232, 2.828149814686469, 0.030633448836439925, -1.2172183797444518, 2.7815584690820714, -0.8877086482545451, 2.5361361119792463, -0.3505516148526908, -4.406267605612996, 2.1272009650400037, -1.186611729350446, 1.385398775234819, 1.360301391090431, 1.3249777848685085, 0.6863321297476404, -0.5837117521388677, -1.5024591711900968, 1.1721419038493082, 0.9543526982468364, 0.00796499086646918, -2.7534490052659777, 0.5808638569549771, -0.29107707177736586, -0.6886559277092488, 0.8193411941700077, 0.22601690646780526, -0.9077057126516621, 1.382865808501549, 1.7510408863789024, 0.6362494272792105, 0.6652597553209461, 0.9563444973558148, 0.4896234704324769, -1.2327940192678284, 1.46586360801534, 0.6451909877417279, -0.5022951657205823, -0.337637175887437, 0.5802167936731593, -1.2845308794864536, 0.19811193263608118, 1.8940656491716368, 1.5549578220057327, 1.5104768591129982, -0.3638444063939943, -4.5837508231986135, 1.8506884017884175, 2.1108666734410804, 0.8472208221879072, 2.7533723090094213, 1.1559252136631102, 1.4912301027728176, -0.2958150330541258, -4.189151526013745, 2.5621028150599585, 1.196571702949143, 0.2805725566504833, -2.1184936089591133, 2.1722905016468275, 0.7099269179091721, 0.7367512154960849, 0.18898421180011837, -2.0005955092583037, 3.1959137028391638, 3.264548949902789, -0.568658379393753, -4.6651927060829195, 0.6745876703847102, 0.8989484527610756, 1.4149822750512726, 1.5879743174996719, 1.9762253557999543, -1.4180986690002584, 2.7552304134995325, 0.06117227315785101, -3.9265819556778183, 1.6517847393429719, -0.23404461114586184, -2.7720718820905432, 2.7312436247328264, 2.104892591184168, 0.14505430164973632, -3.35332891941421, 2.250242649958466, 1.1564517950815087, 0.3653168387380106, -2.4485762626549814, 4.254248059710164, 2.0466398783924404, -0.21343579897910558, -3.354757786580606, 1.3717826534946767, 1.2855637237612854, 0.7766383809965305, -2.5845268828574746, 4.164999251598431, 3.052211102795397, -1.6936796135170766, 1.2034600221191312, -0.13506294546476738, -3.7079644819281867, 2.3835717973559554, 0.08571386046200757, -1.6130407941820408, 2.880403117800185, 1.3677826294295414, 0.7702155889578961, -1.0302180355649284, -1.0949252758113772, 0.38670744333268203, -3.1756310309705924, 2.8555967240134237, 1.571166674607909, -0.7340563025647384, -2.26513333618864, 0.35792943091092866, -0.5797027965495118, 1.0195829606144002, -1.3194965931447342, 2.465957840013118, 1.2989305882388607, -1.4259184552867623, 0.5347475210260626, -0.7683409507955616, 0.29836790444691985, -0.5992048963623233, -1.6435514362305668, 2.277816803217604, 0.6783250953490523, -0.4101561734011625, -2.209923433623274, 2.6471176004536687, -1.2698465773350591, -0.11179731860710262, -1.6458307682423339, 3.845464607247152, 1.91817791925682, 1.3115539545627257, -0.505398525454396, -3.6480503346235196, 5.710692830523882, 2.315220051046083, -0.5927491429592493, -4.09376315194703, 2.575854690496314, 0.22735790972484438, -3.5239589406355236, 1.0610390097693312, -2.1435725982864398, 1.7018909554629431, 1.1803391670965055, -0.014690404140935698, -0.9548631580527882, 0.025161738846918524, -2.68236594126752, 0.7986297369855038, -2.9801640911582155, 1.8431281916084572, 0.537679219581193, 1.205949776308671, 0.4777751217418853, -1.3720416908497555, 2.1896452901576566, 0.15080258179955308, -1.9822811332257544, 2.9546202756057482, -0.1784576534616491, -4.413784305300169, 2.751514145312555, -1.2453367221612552, 1.8068539667477097, -0.8840429296772072, -0.29385024161429385, -1.9530470491965843, 3.4895397498478786, 0.9241177170795254, -1.7190899463455054, 2.4241062175740353, 0.24678757276733165, -2.0728115870781494, 2.1066756192742986, 0.03723858748958264, -2.1741338372664387, 2.9204954071271914, 1.466519729612898, 1.4377282420634856, 1.0672410884219943, -0.21687569701794018, -2.606781493901238, 3.023890880335557, 2.840247611202628, 0.654918206483444, -1.7776362589062984, 2.0142512835107027, 1.0440418226574337, -2.252772012279138, 1.793372320708201, -1.058094664443388, -3.6124618890186895, 3.0638267747897316, 0.8317712385526619, -2.9832504213438824, 2.013755201289584, -0.8443229909892125, -1.262173312555845, 1.6719200035884114, 3.1065459901076764, 0.9074298678822288, -1.3520475181282592, -1.8980186886039974, 3.0681489396377373, 2.7510063578954487, 2.871463147947267, 1.997105843259078, -1.2767952587216342, -1.2500103563372704, -2.242487767507285, 2.5908309234280296, -0.4603833258986043, -1.3989208143623273, 1.4228544993732584, 0.168158741295656, -2.464337216120569, 2.306857411421106, 0.4061900855324865, -2.7583701386913617, 4.913092773700825, 0.9784977858350885, -2.251980504979386, 2.2356007972891803, 2.0708803063119348, 0.596158387956848, -3.4796568210565084, 1.5104135366425453, 1.2094264120917586, -2.1112715244519222, 3.125285641363277, 1.397378408281611, 0.4995457010193576, -2.6450772937380407, 2.595683738018394, -1.905014575699397, 1.8154236420853493, -1.7382703412988576, 1.895616210300588, 1.774232382445689, -0.9364588649894614, -3.5648389843447603, 1.8085401061018018, -0.7089277554953242, 0.8333394603716187, -0.7855554895209025, -0.09235217389307593, -0.15599885480378362, -2.395292631941473, -0.847319286563561, 1.580066254415371, -1.6161104563766457, -0.14380119962682159, -0.17039549042465296, -2.2808900032085404, 0.5899728717918151, -1.3124051303655762, -0.4318548215555893, -2.0316930260294868, 0.7132830229497813, -1.346184312590438, -0.22787720955739132, -1.9787869739883064, 1.5000109356556095, -0.1353574569291851, -1.617647726197447, 0.750958829707244, -0.5391050131288466, -0.13947540888769083, -3.1412872885443903, 0.4922060470300238, -1.0816119719233939, 0.05192704809148552, -3.90834657446203, 1.2013773755613073, 0.6284175023470198, 0.18143030125945359, -2.8052029814602975, 3.1856761356190617, 1.8773455704763364, 0.28335901009420184, -4.6992649253475065, 2.2772555068874425, 1.6734100985963778, 0.7558779120151229, -2.0539324160013166, 0.05658285471933766, -1.840679393762457, 2.903292969433707, 1.502591785853383, 0.9102204489196737, -2.3982317932036494, 3.0178521615550125, 1.2915608406096908, -0.44198468397492263, -2.8865071967825315, 1.475387114681027, 0.9010085354625517, -0.5212902715368983, -2.1464500329543625, 3.0822006737095506, 0.3781319875438385, -3.1948970081042063, 5.104908045456341, 3.348539104083713, 0.06491833945847247, -3.2283804743977527, 2.551608925745768, -0.9540865587781155, -1.2002907675246206, -0.9600432086386803, -1.4391976237525341, -0.1192934579390652, -0.8830299927426495, -2.5506135706869912, 2.047615106523608, 0.6613709659162765, 0.026853647774714773, -1.7504713241556686, 3.1300755127927005, -0.5990908169929838, -4.025823754647263, 3.4298321427580873, 1.1010054828043394, -1.19019333641846, -0.7804966211765532, -3.2104779482120733, 2.1898841543193157, 1.0463597800611666, 0.8838176647318505, -2.4328406301006993, 6.010555370105521, 1.2251926620068758, 0.43364514241557117, -4.386980332457469, 2.615981840428958, 2.9227156333785302, 1.1638676915868018, -1.054844429314116, -4.46797379976806, 2.7035898477282814, -0.018831482560472068, -3.2853778556433184, 1.4493749840498822, -0.8861908646555179, -1.2949926381056684, -0.2210755030915692, -0.6116506669327464, -2.16780320312283, 1.8336103920360074, 1.3342661498685544, 0.16514949127895306, -0.5576406382839281, -1.254326041614604, -1.1069284271703594, -1.4476472678584287, -1.3478628034223306, -0.2760870310780774, -1.1491132565639504, 0.007276325078692025, 0.04742372136787765, -2.7098028712212, 2.242720896876918, 1.0627630598169162, -1.6668725668383644, -0.681049539507967, -1.5342851326541762, 0.7788255858354205, -2.4739747555587286, 2.235048170313803, 1.5313142351068478, -0.4622631132410788, -1.922512635560551, 0.32411763142908967, -1.8429285171044825, 1.0276889282918091, -1.4781118639369737, 0.6413726434798264, -1.4072633956014755, -0.026535085823070403, -1.2797971952623897, 0.029146143094749277, -2.430218296942357, 3.5414522413243503, 0.29043517861090606, -1.2070046027024546, -2.4853025219073146, 3.9284971499923813, 2.3933826007686463, -0.21964875106141335, -2.961243283878602, 2.6630245844039564, 0.2424234774642997, -2.9676918229183684, 3.399361926092652, -1.4953465212115589, -1.2836769019578327, 1.8546823541450976, -0.02394183276020101, -2.406675867789545, 4.391772312033837, 2.7768530985972575, 0.8995811181247433, -4.098152437751651, 3.657511918996434, 1.5261037645300348, -1.4326427612814854, -2.270811337572468, 3.5913153283053276, 0.8185077748762524, -1.8171091801033157, -0.45017471140317866, -1.3593798437860727, 1.0594459892977284, 1.1227788728218826, 0.08215870592312058, -3.699351093301729, 3.68358954194764, 0.8047554681478601, -2.4820732640678216, 2.7856209561731617, 0.14781720049131764, -3.613882878809008, 0.7942920315740594, -1.0438468756320702, 1.7449165216435176, 0.5004531911844339, -2.5972902687594797, 1.3224556085814498, 0.8014696839286444, -2.4104203235648214, 2.584571766682984, 1.51167981506741, -0.6178323156041188, -2.0258185857702387, 1.9408872664803312, -0.29158854611442564, -1.5598662461111417, 1.262475307977084, -1.1114848158326822, -0.5825258938594828, -2.5398791453121703, 3.5262942529051458, 0.224044498324929, -0.2550168252956695, -3.107202809108003, 3.3379911147757326, -0.751694073238923, -2.868861021607799, 4.20866186550802, 1.7026704530116064, 0.8924176961513695, -1.160034877818461, -2.084133421638853, 2.2483419090466583, 0.48921552716592487, -2.424408477246388, 1.6677547971044078, 1.3478082087284662, 0.041038174054392584, -2.7963054289531186, 5.188741429813945, 3.184088772516489, 0.9459567197368415, -2.6362220345136933, 1.3692660585452359, -0.9476939692350328, -0.13471643126695199, -2.298937911661696, 3.892831324360941, 2.383234716603411, -0.4547660216398981, -2.5406699215228485, 3.2881825907766142, -0.42275944499043305, -2.8899619881326544, 5.4994682445257155, 0.20980581500907647, -4.802548533450235, 2.2792467007325286, 0.7892598444021957, -2.322706686804395, 0.38627713182621903, -0.7987007953329339, -0.4475431876172564, -3.0864604684961705, 1.9133939937845668, -0.22978631001615213, -0.12889196811475756, -1.2883971923643003, 0.08692072129487372, -1.6022990818451035, 0.767704925105491, -3.1289123616220422, 2.356093410517488, 1.1149231474923909, -3.1626118233995015, 2.1491791187950184, -0.33684229632636686, -2.3652078450609224, 1.4490025086364682, 1.085136160291313, -0.7976863392010358, -2.502373071277816, 1.6153613434384084, 2.0523641849799787, -0.13470157412449169, -3.2171749045151046, 2.6375381245546947, 2.273175845527021, 1.3556758497455945, -1.50111418440747, -1.9024609134336146, 0.5142990817553255, -1.2096298496449975, -0.027168556348897255, -2.421242546309813, 2.843665820212209, 0.7121859828715884, -1.69008670582798, -1.7147815497788628, -0.811045044770708, -2.586979663462998, 3.3517261038509787, 2.09050113067714, 2.8079791371824285, 3.386571236066075, 2.8927626921013143, -0.14460621348335678, -3.0051501431644283, 3.0251496075019446, 0.9360500913553551, -3.844145382963333, 4.135783942134367, -2.2447438557479558, 2.319682812298197, 1.1107038125068271, -1.2246266954807652, -2.9148471426575355, 1.811366931646262, -0.4305541761838043, -1.5388145341839845, -0.26191626612621455, -0.10551072201451461, -1.118506556083454, -0.416103372375801, -0.29140960867830135, -3.419193269477546, 3.311058902949802, -0.4493884874500509, -2.714842904784242, 3.536956823172659, -1.4740363701161607, -0.16499697987092077, -1.251877944954182, 0.7784730311814201, -1.105311560152992, -0.26400170637680276, -3.2365504783660493, 1.8615304981994996, -3.1556045128217614, 1.6306154260701078, 0.40943235182390136, -2.2432172675880793, -1.1085844331700594, -1.1637571005676364, 0.7468690952865051, -2.0683381666976857, -0.3988103682222084, -4.064569223389299, 2.0459070399575046, -2.868165681496066, 1.474471098723419, -1.0255467221331855, -1.7332333459616587, -0.09212844182638946, -0.7665795316406241, -2.467857132211975, 1.7559079918155964, 1.166023471853805, 0.5010880877617216, -2.1121157193456384, -0.2905493030975288, -1.5420263572823387, -0.5319643240822609, -2.6250456167845186, 2.6393078348024153, 1.3356439861154286, 0.02773555141680273, -0.7611254051817014, -3.224040209674464, 3.1861020954884225, 0.2250394146226915, -2.611823685228046, 2.1299829064933453, 0.4385359678772147, -2.4014294557441156, 3.023578993596857, 1.7889432343195528, 1.861971268363959, 0.2603043458562331, -3.379144305735281, 1.9969776641751684, -0.8894954511861215, -1.9075194296078246, 1.5502189876633565, -0.9628286947667641, 1.1690315353826009, -1.1552763513249795, -2.012979010638446, 1.5621021664479064, -2.5856928678113036, 0.4528835372253104, -0.6837497035230626, -2.2238400572172816, -0.7581172267175589, 1.2270457499976635, -2.5419764620903607, 1.9848792547850769, -0.2639650194771548, -4.196982712485302, 2.1171575622054206, -0.2789738297728457, -1.621323846725545, 1.4797369709590873, 1.432938303309811, -1.1670487765044948, -0.7829870245852817, 0.19193897586551767, -2.2875055342130963, 2.98937866332158, -0.6270136069990713, -2.2554468771672385, 1.9191442856342746, 1.0594219791924422, -0.050326674522921166, -1.0338491661281717, -4.192817286225591, 1.3990921638065208, 0.21026261770634846, -1.223813520013615, -0.43713157409843006, -1.6706404698565587, 0.3490909021099924, -1.5654692636137009, -0.04016653746225529, -0.7269701714005317, -0.3989331085060712, -2.976161564748687, 0.5093558566629781, -1.1605488319448307, -0.5045315414311062, -2.586410248391254, 4.365757443026041, 3.950794649105595, 1.488668996594015, -1.0883348092040217, -3.816777744591718, 3.0379298620817314, 1.5496658589988783, 0.755224632243702, -2.497489563014142, 2.3364490301490184, 0.39955931979125126, -3.5840450573570672, 3.018476773708926, 1.2906976157708447, -0.23455583084364662, -3.4751428806022853, 3.2344727484021405, 0.401985669060017, -2.51608211325879, 4.106390416137223, 1.7434279879387304, 0.7160573569079167, -3.575205988191783, 1.4225660203872428, -1.9360172535009497, 1.594574532746086, -1.8218719716912801, -0.8998693031118785, -1.1104347579873775, 0.587906463993753, -1.9605305026541373, 2.2515398302546634, -1.646607616724168, -0.2439875200381687, -0.3836987054862675, -2.6876655309044475, 2.789997839313628, 0.6906704642440706, -0.3272984519978763, -1.1565451331645784, -1.1744034514783834, -1.6912092739878029, 0.1351820709344338, -0.008700784528806516, -2.991061614947057, 3.4086690744878103, 1.354072972181939, -0.3121809696460298, -3.8345159876523667, 2.590076830470756, -0.7633604852496774, -4.275877771419069, 1.1052823265229108, -2.3093145894892553, 1.438465628417589, 0.7574006522043453, -0.865014525696779, -0.9218576349596299, -1.596448406994341, 0.9554007047043376, -1.4595484608455536, -0.7152345245342042, -3.1085105072072565, 3.1601030325617137, 0.6987653659796251, -0.2447736950563888, -2.3551381868112458, 4.562549665671944, 2.1644901474553535, 1.3335457881765285, 0.5322918642320928, -5.326607721697834, 3.6995032843822173, -0.2842577192206557, -3.482089472951202, 4.635711652153808, 2.6691482258154338, 2.234165178931838, 0.07870740364683115, -4.0522366438673965, 3.005306931385121, -0.0677947785736217, -2.9168616750996534, 4.198013270448249, 2.315602208136397, -0.9359968022328724, -3.871760513810159, 2.728294472857491, 2.096207696069314, -1.1506936720035776, -2.2188178036615227, 1.836696821111949, 1.5240277796672217, -1.6479891187993383, -0.7220297286423829, -0.6512678815308357, -3.2680845455636245, 3.9472274396574027, -0.026240297231424847, -1.9735640073014986, 1.7709589763524036, -0.24591818554490263, -2.140570614707258, 0.6782074897926611, 1.0406865230449966, 0.6381817790707407, -3.2029409747358386, 3.574270297870547, -0.6442422279380935, -3.479162328313529, 3.132912774051647, 1.0202785817628444, -2.7602393803192626, 1.2867656903536533, -0.08573426317366284, -3.3854203313539495, 1.2070761950069482, -1.5035405073876484, 0.14571485978899545, -0.07206205249981057, -3.5062283058889534, 1.6243052673190084, -1.6722630261667746, 1.078027266342409, -0.8804177130789412, -2.021191211094398, 3.263474736044145, -0.0319868411724622, -2.087624338541218, 0.7440198859376812, 0.58096990617355, -1.6650433362110073, 1.9102202484370991, 0.8037067053419866, -2.4383553149075397, 3.6989721638429307, 1.5492544783498943, -1.0061230208620566, -1.304741830527064, -1.0410694627879105, -1.1486005455219583, 0.17451815828660866, -0.9621801093383056, -0.9812988920801411, -1.2927617855596054, -1.1911797195760494, 1.6316441669048345, 0.7290949732443357, 0.1570309486530732, -2.952095425248282, 4.867836997332006, 2.1827578982949296, -0.21787750872613287, -2.8431743458030008, 3.963768848855352, 0.11399241534234417, -3.9596813846467285, 3.528514569904636, 0.3165448094775911, -1.3644029036630139, 1.0204213063123007, -2.1114007168751607, 0.7672226843722001, -2.487968561522231, 3.5757077660098275, 1.886979994838092, 0.7318432204344845, -4.302890897065319, 3.398112603769505, -1.6119003964620982, -0.4281718919658033, -1.8832073876745392, 1.0431415626742364, 0.4606323089776003, -0.41326021871577723, -2.9395485383700555, 3.372117334570021, 0.39005263675260604, -2.41838526248398, 1.1136396952480743, -1.3367679544564908, -0.5449391614836907, -2.3030307826004446, 1.5677660597995589, 0.05834878910241059, -3.597727140457047, 3.0475817877929785, -0.8516086875041049, -3.1185751524856187, 1.7332797945838854, -2.3011751465685393, -0.4054187443851527, -1.7688284237494827, 0.7683693660202868, -0.21752079202383356, -1.791273327393193, 0.5579289410368347, -2.7284681704057414, 2.977578053780917, 0.36995854558170205, -2.624565400614139]\n",
    "\n",
    "parabolicParametersBacksteppingFixed = parabolicParametersBackstepping.copy()\n",
    "parabolicParametersBacksteppingFixed[\"reset_init_condition_func\"] = getInitialConditionFixed\n",
    "# hyperbolicParametersBacksteppingFixed[\"reward_class\"] = reward_class_no_penalty\n",
    "envBcksFixed = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingFixed)\n",
    "\n",
    "\n",
    "reward_afterQP, uBcks_afterQP = runSingleEpisodeQP(QP_filter_Controller, envBcksFixed, U_safe_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d37bf91e-20b9-4d83-93c0-09435b0ba2ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "mpl.rcParams.update(mpl.rcParamsDefault)\n",
    "i=9\n",
    "uBcks_beforeQP = uBcks_beforeQP_list[i]\n",
    "uBcks_afterQP = uBcks_afterQP_list[i]\n",
    "print(RL_reward_beforeQP[i], RL_reward_afterQP[i])\n",
    "x = np.linspace(0, 1, 1001)  # Generate 100 points from 0 to 10\n",
    "y1 = (uBcks_beforeQP.transpose())[100]  # First line: sine function\n",
    "y2 = (uBcks_afterQP.transpose())[100]\n",
    "# Create the plot\n",
    "print(y2)\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.plot(x, y1, label='before QP', linestyle='-', marker='o')  # Plot the first line with markers\n",
    "plt.plot(x, y2, label='after QP', linestyle='--', marker='x')  # Plot the second line with a different style\n",
    "\n",
    "plt.plot(x, y1, linestyle='--')  # Plot the first line with markers\n",
    "plt.plot(x, y2,  linestyle='--')  # Plot the second line with a different style\n",
    "\n",
    "# Add titles and labels\n",
    "plt.title('Plot of Two Lines')\n",
    "plt.xlabel('x-axis')\n",
    "plt.ylabel('y-axis')\n",
    "\n",
    "# Add a legend to differentiate the lines\n",
    "plt.legend()\n",
    "# print(reward_beforeQP, reward_afterQP)\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acca0176-738c-42d9-80e1-2c9be823b506",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8aa8927-39b0-45c0-8c84-150147c45d3b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2efb7302-fe2c-4686-b5f9-1168c5a6815d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# PLOT EXAMPLE PROBLEMS.\n",
    "\n",
    "# First Build Same Initial Condition Environments\n",
    "# Set initial condition function here\n",
    "def getInitialConditionTen(nx):\n",
    "    return np.ones(nx+1)*10\n",
    "\n",
    "def getInitialConditionOne(nx):\n",
    "    return np.ones(nx+1)*1\n",
    "\n",
    "parabolicParametersBacksteppingTen = parabolicParametersBackstepping.copy()\n",
    "parabolicParametersBacksteppingTen[\"reset_init_condition_func\"] = getInitialConditionTen\n",
    "\n",
    "parabolicParametersBacksteppingOne = parabolicParametersBackstepping.copy()\n",
    "parabolicParametersBacksteppingOne[\"reset_init_condition_func\"] = getInitialConditionOne\n",
    "\n",
    "parabolicParametersRLTen = parabolicParametersRL.copy()\n",
    "parabolicParametersRLTen[\"reset_init_condition_func\"] = getInitialConditionTen\n",
    "\n",
    "parabolicParametersRLOne = parabolicParametersRL.copy()\n",
    "parabolicParametersRLOne[\"reset_init_condition_func\"] = getInitialConditionOne\n",
    "\n",
    "# Make environments\n",
    "envBcksTen = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingTen)\n",
    "envBcksOne = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersBacksteppingOne)\n",
    "\n",
    "envRLTen = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersRLTen)\n",
    "envRLOne = gym.make(\"PDEControlGym-ReactionDiffusionPDE1D\", **parabolicParametersRLOne)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80b4b856-1914-4264-8578-ee418a76e83b",
   "metadata": {},
   "outputs": [],
   "source": [
    "rewBcksTen, uBcksTen = runSingleEpisode(bcksController, envBcksTen, kernel)\n",
    "rewBcksOne, uBcksOne = runSingleEpisode(bcksController, envBcksOne, kernel)\n",
    "\n",
    "rewPPOTen, uPPOTen = runSingleEpisode(RLController, envRLTen, ppoModel)\n",
    "rewPPOOne, uPPOOne = runSingleEpisode(RLController, envRLOne, ppoModel)\n",
    "\n",
    "rewSACTen, uSACTen = runSingleEpisode(RLController, envRLTen, sacModel)\n",
    "rewSACOne, uSACOne = runSingleEpisode(RLController, envRLOne, sacModel)\n",
    "\n",
    "rewOpenTen,uOpenTen = runSingleEpisode(openLoopController, envBcksTen, _)\n",
    "rewOpenTen,uOpenOne = runSingleEpisode(openLoopController, envBcksOne, _)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ccca3e9-4aa9-4114-9396-11919ab36eef",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import matplotlib as mpl\n",
    "mpl.rcParams.update(mpl.rcParamsDefault)\n",
    "# PLOT OPENLOOOP EXAMPLE. PLOTS ARE NOT SCALED THE SAME ON Z SO MAY HAVE TO ADJUST\n",
    "fig = plt.figure(figsize=set_size(433, 0.99, (1, 2), height_add=1))\n",
    "subfigs = fig.subfigures(nrows=1, ncols=1, hspace=0)\n",
    "\n",
    "subfig = subfigs\n",
    "subfig.suptitle(r\"Open-loop (U(t)=0) instability of reaction-diffusion PDE for u(x, 0)=1, 10\")\n",
    "subfig.subplots_adjust(left=0.03, bottom=0.05, right=1, top=0.95, wspace=0, hspace=0)\n",
    "X = 1\n",
    "dx = 5e-3\n",
    "T = 1\n",
    "spatial = np.linspace(0, X, int(round(X/dx))+1)\n",
    "temporal = np.linspace(0, T, len(uPPOOne))\n",
    "meshx, mesht = np.meshgrid(spatial, temporal)\n",
    "\n",
    "ax = subfig.subplots(nrows=1, ncols=2, subplot_kw={\"projection\": \"3d\", \"computed_zorder\": False})\n",
    "\n",
    "for axes in ax:\n",
    "    for axis in [axes.xaxis, axes.yaxis, axes.zaxis]:\n",
    "        axis._axinfo['axisline']['linewidth'] = 1\n",
    "        axis._axinfo['axisline']['color'] = \"b\"\n",
    "        axis._axinfo['grid']['linewidth'] = 0.2\n",
    "        axis._axinfo['grid']['linestyle'] = \"--\"\n",
    "        axis._axinfo['grid']['color'] = \"#d1d1d1\"\n",
    "        axis.set_pane_color((1,1,1))\n",
    "\n",
    "ax[0].view_init(10, 35)\n",
    "ax[0].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[1].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[0].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[1].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[0].set_zlabel(r\"$u(x, t)$\", rotation=90, labelpad=-7)\n",
    "\n",
    "ax[0].zaxis.set_rotate_label(False)\n",
    "ax[0].set_xticks([0, 0.5, 1])\n",
    "ax[0].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[1].tick_params(axis='z', which='major', pad=-1)\n",
    "\n",
    "ax[0].plot_surface(meshx, mesht, uOpenOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=1, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uOpenOne.transpose())[100] \n",
    "ax[0].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[1].plot_surface(meshx, mesht, uOpenTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=1, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[1].view_init(10, 35)\n",
    "ax[1].zaxis.set_rotate_label(False)\n",
    "ax[1].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uOpenTen.transpose())[100] \n",
    "ax[1].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6d72053-c14f-4e6d-a918-989f2bfa4f58",
   "metadata": {},
   "outputs": [],
   "source": [
    "print((uOpenOne.transpose()[:,::20]).shape) # spatial * temporal\n",
    "# np.max((uPPOTen.transpose())[130][800:]) # spatial * temporal\n",
    "np.max((uOpenOne.transpose())[100][800:]) # spatial * temporal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5078b80e-47c6-45e7-a1e2-78ec06a35256",
   "metadata": {},
   "outputs": [],
   "source": [
    "# PLOT EACH EXAMPLE. PLOTS ARE NOT SCALED THE SAME ON Z SO MAY HAVE TO ADJUST\n",
    "fig = plt.figure(figsize=set_size(433, 0.99, (2, 3), height_add=1))\n",
    "subfigs = fig.subfigures(nrows=2, ncols=1, hspace=0)\n",
    "\n",
    "subfig = subfigs[0]\n",
    "subfig.suptitle(r\"Example trajectories for $u(0, x)=1$ with backstepping, PPO, and SAC\")\n",
    "subfig.subplots_adjust(left=0.03, bottom=0.05, right=1, top=0.95, wspace=0, hspace=0)\n",
    "\n",
    "spatial = np.linspace(0, X, int(round(X/dx))+1)\n",
    "temporal = np.linspace(0, T, len(uPPOOne))\n",
    "meshx, mesht = np.meshgrid(spatial, temporal)\n",
    "\n",
    "ax = subfig.subplots(nrows=1, ncols=3, subplot_kw={\"projection\": \"3d\", \"computed_zorder\": False})\n",
    "\n",
    "for axes in ax:\n",
    "    for axis in [axes.xaxis, axes.yaxis, axes.zaxis]:\n",
    "        axis._axinfo['axisline']['linewidth'] = 1\n",
    "        axis._axinfo['axisline']['color'] = \"b\"\n",
    "        axis._axinfo['grid']['linewidth'] = 0.2\n",
    "        axis._axinfo['grid']['linestyle'] = \"--\"\n",
    "        axis._axinfo['grid']['color'] = \"#d1d1d1\"\n",
    "        axis.set_pane_color((1,1,1))\n",
    "\n",
    "ax[0].view_init(10, 35)\n",
    "ax[0].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[1].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[2].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[0].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[2].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[1].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[0].set_zlabel(r\"$u(x, t)$\", rotation=90, labelpad=-7)\n",
    "\n",
    "ax[0].zaxis.set_rotate_label(False)\n",
    "ax[0].set_xticks([0, 0.5, 1])\n",
    "ax[0].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[1].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[2].tick_params(axis='z', which='major', pad=-1)\n",
    "\n",
    "ax[0].plot_surface(meshx, mesht, uBcksOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uBcksOne.transpose())[-1] \n",
    "ax[0].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[1].plot_surface(meshx, mesht, uPPOOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[1].view_init(10, 35)\n",
    "ax[1].zaxis.set_rotate_label(False)\n",
    "ax[1].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uPPOOne.transpose())[-1] \n",
    "ax[1].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[2].plot_surface(meshx, mesht, uSACOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[2].view_init(10, 35)\n",
    "ax[2].zaxis.set_rotate_label(False)\n",
    "ax[2].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uSACOne.transpose())[-1] \n",
    "ax[2].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    "ax[0].set_zticks([-10, 0, 10])\n",
    "ax[1].set_zticks([-10, 0, 10])\n",
    "ax[2].set_zticks([-10, 0, 10])\n",
    "\n",
    "\n",
    "subfig = subfigs[1]\n",
    "subfig.suptitle(r\"Example trajectories for $u(0, x)=10$ with backstepping, PPO, and SAC\")\n",
    "subfig.subplots_adjust(left=0.03, bottom=0.05, right=1, top=0.95, wspace=0, hspace=0)\n",
    "meshx, mesht = np.meshgrid(spatial, temporal)\n",
    "\n",
    "ax = subfig.subplots(nrows=1, ncols=3, subplot_kw={\"projection\": \"3d\", \"computed_zorder\": False})\n",
    "\n",
    "for axes in ax:\n",
    "    for axis in [axes.xaxis, axes.yaxis, axes.zaxis]:\n",
    "        axis._axinfo['axisline']['linewidth'] = 1\n",
    "        axis._axinfo['axisline']['color'] = \"b\"\n",
    "        axis._axinfo['grid']['linewidth'] = 0.2\n",
    "        axis._axinfo['grid']['linestyle'] = \"--\"\n",
    "        axis._axinfo['grid']['color'] = \"#d1d1d1\"\n",
    "        axis.set_pane_color((1,1,1))\n",
    "\n",
    "ax[0].view_init(10, 35)\n",
    "ax[0].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[1].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[2].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[0].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[2].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[1].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[0].set_zlabel(r\"$u(x, t)$\", rotation=90, labelpad=-7)\n",
    "\n",
    "ax[0].zaxis.set_rotate_label(False)\n",
    "ax[0].set_xticks([0, 0.5, 1])\n",
    "ax[0].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[1].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[2].tick_params(axis='z', which='major', pad=-1)\n",
    "\n",
    "ax[0].plot_surface(meshx, mesht, uBcksTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uBcksTen.transpose())[-1] \n",
    "ax[0].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[1].plot_surface(meshx, mesht, uPPOTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[1].view_init(10, 35)\n",
    "ax[1].zaxis.set_rotate_label(False)\n",
    "ax[1].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uPPOTen.transpose())[-1] \n",
    "ax[1].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[2].plot_surface(meshx, mesht, uSACTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[2].view_init(10, 35)\n",
    "ax[2].zaxis.set_rotate_label(False)\n",
    "ax[2].set_xticks([0, 0.5, 1])\n",
    "ax[0].set_zticks([-20, 0, 20])\n",
    "ax[1].set_zticks([-20, 0, 20])\n",
    "\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uSACTen.transpose())[-1] \n",
    "ax[2].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    "ax[2].set_zticks([-20, 0, 20])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "197ae71f-0904-4030-b739-a8e4192bfead",
   "metadata": {},
   "outputs": [],
   "source": [
    "# PLOT EACH EXAMPLE. PLOTS ARE NOT SCALED THE SAME ON Z SO MAY HAVE TO ADJUST\n",
    "fig = plt.figure(figsize=set_size(433, 0.99, (2, 3), height_add=1))\n",
    "subfigs = fig.subfigures(nrows=2, ncols=1, hspace=0)\n",
    "\n",
    "subfig = subfigs[0]\n",
    "subfig.suptitle(r\"Example trajectories for $u(0, x)=1$ with backstepping, PPO, and SAC\")\n",
    "subfig.subplots_adjust(left=0.03, bottom=0.05, right=1, top=0.95, wspace=0, hspace=0)\n",
    "\n",
    "spatial = np.linspace(0, X, int(round(X/dx))+1)\n",
    "temporal = np.linspace(0, T, len(uPPOOne))\n",
    "meshx, mesht = np.meshgrid(spatial, temporal)\n",
    "\n",
    "ax = subfig.subplots(nrows=1, ncols=3, subplot_kw={\"projection\": \"3d\", \"computed_zorder\": False})\n",
    "\n",
    "for axes in ax:\n",
    "    for axis in [axes.xaxis, axes.yaxis, axes.zaxis]:\n",
    "        axis._axinfo['axisline']['linewidth'] = 1\n",
    "        axis._axinfo['axisline']['color'] = \"b\"\n",
    "        axis._axinfo['grid']['linewidth'] = 0.2\n",
    "        axis._axinfo['grid']['linestyle'] = \"--\"\n",
    "        axis._axinfo['grid']['color'] = \"#d1d1d1\"\n",
    "        axis.set_pane_color((1,1,1))\n",
    "\n",
    "ax[0].view_init(10, 35)\n",
    "ax[0].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[1].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[2].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[0].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[2].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[1].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[0].set_zlabel(r\"$u(x, t)$\", rotation=90, labelpad=-7)\n",
    "\n",
    "ax[0].zaxis.set_rotate_label(False)\n",
    "ax[0].set_xticks([0, 0.5, 1])\n",
    "ax[0].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[1].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[2].tick_params(axis='z', which='major', pad=-1)\n",
    "\n",
    "ax[0].plot_surface(meshx, mesht, uBcksOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uBcksOne.transpose())[-1] \n",
    "ax[0].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[1].plot_surface(meshx, mesht, uPPOOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[1].view_init(10, 35)\n",
    "ax[1].zaxis.set_rotate_label(False)\n",
    "ax[1].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uPPOOne.transpose())[-1] \n",
    "ax[1].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[2].plot_surface(meshx, mesht, uSACOne, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[2].view_init(10, 35)\n",
    "ax[2].zaxis.set_rotate_label(False)\n",
    "ax[2].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uSACOne.transpose())[-1] \n",
    "ax[2].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    "ax[0].set_zticks([-10, 0, 10])\n",
    "ax[1].set_zticks([-10, 0, 10])\n",
    "ax[2].set_zticks([-10, 0, 10])\n",
    "\n",
    "\n",
    "subfig = subfigs[1]\n",
    "subfig.suptitle(r\"Example trajectories for $u(0, x)=10$ with backstepping, PPO, and SAC\")\n",
    "subfig.subplots_adjust(left=0.03, bottom=0.05, right=1, top=0.95, wspace=0, hspace=0)\n",
    "meshx, mesht = np.meshgrid(spatial, temporal)\n",
    "\n",
    "ax = subfig.subplots(nrows=1, ncols=3, subplot_kw={\"projection\": \"3d\", \"computed_zorder\": False})\n",
    "\n",
    "for axes in ax:\n",
    "    for axis in [axes.xaxis, axes.yaxis, axes.zaxis]:\n",
    "        axis._axinfo['axisline']['linewidth'] = 1\n",
    "        axis._axinfo['axisline']['color'] = \"b\"\n",
    "        axis._axinfo['grid']['linewidth'] = 0.2\n",
    "        axis._axinfo['grid']['linestyle'] = \"--\"\n",
    "        axis._axinfo['grid']['color'] = \"#d1d1d1\"\n",
    "        axis.set_pane_color((1,1,1))\n",
    "\n",
    "ax[0].view_init(10, 35)\n",
    "ax[0].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[1].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[2].set_xlabel(\"x\", labelpad=-3)\n",
    "ax[0].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[2].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[1].set_ylabel(\"Time\", labelpad=-3)\n",
    "ax[0].set_zlabel(r\"$u(x, t)$\", rotation=90, labelpad=-7)\n",
    "\n",
    "ax[0].zaxis.set_rotate_label(False)\n",
    "ax[0].set_xticks([0, 0.5, 1])\n",
    "ax[0].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='x', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[1].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[2].tick_params(axis='y', which='major', pad=-3)\n",
    "ax[0].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[1].tick_params(axis='z', which='major', pad=-1)\n",
    "ax[2].tick_params(axis='z', which='major', pad=-1)\n",
    "\n",
    "ax[0].plot_surface(meshx, mesht, uBcksTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uBcksTen.transpose())[100] \n",
    "ax[0].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[1].plot_surface(meshx, mesht, uPPOTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[1].view_init(10, 35)\n",
    "ax[1].zaxis.set_rotate_label(False)\n",
    "ax[1].set_xticks([0, 0.5, 1])\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uPPOTen.transpose())[100] \n",
    "ax[1].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    " \n",
    "ax[2].plot_surface(meshx, mesht, uSACTen, edgecolor=\"black\",lw=0.2, rstride=50, cstride=5, \n",
    "                        alpha=1, color=\"white\", shade=False, rasterized=True, antialiased=True)\n",
    "ax[2].view_init(10, 35)\n",
    "ax[2].zaxis.set_rotate_label(False)\n",
    "ax[2].set_xticks([0, 0.5, 1])\n",
    "ax[0].set_zticks([-20, 0, 20])\n",
    "ax[1].set_zticks([-20, 0, 20])\n",
    "\n",
    "test = np.ones(len(temporal))\n",
    "vals = (uSACTen.transpose())[100] \n",
    "ax[2].plot(test[1:], temporal[1:], vals[1:], color=\"red\", lw=0.1, antialiased=False, rasterized=False)\n",
    "ax[2].set_zticks([-20, 0, 20])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11b1700d-f3ee-4633-8e3f-3e45301d87f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# BUILD CONTROL SIGNAL PLOTS \n",
    "fig = plt.figure(figsize=set_size(433, 0.99, (1, 2), height_add=1))\n",
    "subfigs = fig.subfigures(nrows=1, ncols=1, hspace=0)\n",
    "\n",
    "subfig = subfigs\n",
    "subfig.suptitle(r\"Control Signals for $u(0, x)=1$ and $u(0, x)=10$\")\n",
    "subfig.subplots_adjust(left=0.1, bottom=0.2, right=.98, top=0.86, wspace=0.25, hspace=0.1)\n",
    "\n",
    "spatial = np.linspace(dx, X, int(round(X/dx)))\n",
    "temporal = np.linspace(0, T, len(uPPOOne))\n",
    "ax = subfig.subplots(nrows=1, ncols=2)\n",
    "l2, = ax[0].plot(temporal, uSACOne.transpose()[-1], label=\"SAC\", linestyle=linestyle_tuple[2][1], color=\"green\")\n",
    "l1, = ax[0].plot(temporal, uPPOOne.transpose()[-1], label=\"PPO\", linestyle=linestyle_tuple[2][1], color=\"orange\")\n",
    "\n",
    "l3, = ax[0].plot(temporal, uBcksOne.transpose()[-1], label=\"Backstepping\", color=\"#0096FF\")\n",
    "ax[0].set_xlabel(\"Time\")\n",
    "ax[0].set_ylabel(R\"$U(t)$\", labelpad=-2)\n",
    "\n",
    "l2, = ax[1].plot(temporal, uSACTen.transpose()[-1], label=\"SAC\", linestyle=linestyle_tuple[2][1], color=\"green\")\n",
    "l1, = ax[1].plot(temporal, uPPOTen.transpose()[-1], label=\"PPO\", linestyle=linestyle_tuple[2][1], color=\"orange\")\n",
    "l3, = ax[1].plot(temporal, uBcksTen.transpose()[-1], label=\"Backstepping\", color=\"#0096FF\")\n",
    "ax[1].set_xlabel(\"Time\")\n",
    "ax[1].set_ylabel(r\"$U(t)$\", labelpad=-2)\n",
    "plt.legend([l1, l2, l3], [\"PPO\", \"SAC\", \"Backstepping\"], loc=\"lower left\", bbox_to_anchor=[.56,.86], reverse=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62ff0c35-9d39-4a9e-a3f4-1991a2df27b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# PDE L2 Error\n",
    "def getPDEl2(u, uhat):\n",
    "    nt = len(u)\n",
    "    nx = len(u[0])\n",
    "    pdeError = np.zeros(nt-1)\n",
    "    for i in range(1, nt):\n",
    "        error = 0\n",
    "        for j in range(nx):\n",
    "            error += (u[i][j] - uhat[i][j])**2\n",
    "        error = np.sqrt(error)\n",
    "        pdeError[i-1] = error\n",
    "    return pdeError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "03599419-4ba8-4837-9bfd-b043aed40ff6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Share Rewards and L2 Norms for each problem\n",
    "print((\"InitialCondition\\tModel Trained\\tParabolic1D Rewards\\tParabolic1DTotalL2Norm\").expandtabs(30))\n",
    "print((\"u(x, 0)=1\\tBackstepping\\t\" + str(rewBcksOne) +\"\\t\" + str(sum(getPDEl2(uBcksOne, np.zeros(uBcksOne.shape))))).expandtabs(30))\n",
    "print((\"u(x, 0)=1\\tPPO\\t\" + str(rewPPOOne) +\"\\t\" + str(sum(getPDEl2(uPPOOne, np.zeros(uBcksOne.shape))))).expandtabs(30))\n",
    "print((\"u(x, 0)=1\\tSAC\\t\" + str(rewSACOne) +\"\\t\" + str(sum(getPDEl2(uSACOne, np.zeros(uBcksOne.shape))))).expandtabs(30))\n",
    "print((\"u(x, 0)=10\\tBackstepping\\t\" + str(rewBcksTen) +\"\\t\" + str(sum(getPDEl2(uBcksTen, np.zeros(uBcksOne.shape))))).expandtabs(30))\n",
    "print((\"u(x, 0)=10\\tPPO\\t\" + str(rewPPOTen) +\"\\t\" + str(sum(getPDEl2(uPPOTen, np.zeros(uBcksOne.shape))))).expandtabs(30))\n",
    "print((\"u(x, 0)=10\\tSAC\\t\" + str(rewSACTen) +\"\\t\" + str(sum(getPDEl2(uSACTen, np.zeros(uBcksOne.shape))))).expandtabs(30))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pdecontrol",
   "language": "python",
   "name": "pdecontrol"
  },
  "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
