{"cells":[{"cell_type":"code","execution_count":33,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":1088,"status":"ok","timestamp":1730309693326,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"},"user_tz":300},"id":"dj4A8w9QyhBO","outputId":"47efb4e0-5e74-41ea-c045-fc0066ef1c44"},"outputs":[{"output_type":"stream","name":"stdout","text":["Drive already mounted at /content/drive/; to attempt to forcibly remount, call drive.mount(\"/content/drive/\", force_remount=True).\n","/content/drive/MyDrive/Colab Notebooks/nonlinear-sys-id/simple pendulum neurips\n"]}],"source":["# ------------------------------mount drive-------------------------------------\n","from google.colab import drive\n","drive.mount('/content/drive/')\n","%cd /content/drive/MyDrive/Colab\\ Notebooks/nonlinear-sys-id/simple\\ pendulum\\ neurips/"]},{"cell_type":"markdown","metadata":{"id":"Aj1u35iCv1ia"},"source":["# Getting Trajectory Data of Pendulum"]},{"cell_type":"code","source":["import numpy as np\n","from scipy.stats import truncnorm\n","import random\n","import matplotlib.pyplot as plt\n","import math\n","\n","g = 9.81  # (m/s^2)  gravity constant\n","dt = 0.01  # time_step for discrete-time system\n","\n","def system_parameters():\n","    m = 0.1  # (kg)    mass\n","    l = 0.5  # (m) distance between the rotor and the center of mass\n","    k = 2  # controller gain\n","    return m, l, k\n","\n","def generate_u(input_, time_hor, s_, mean, std, u_max, lb, ub):  # noise in control input\n","    if input_ == \"trunc_guass\":\n","        np.random.seed(s_)\n","        rv = truncnorm(-u_max, u_max, loc=mean, scale=std)\n","        r1 = rv.rvs(size=time_hor)\n","        return r1\n","    elif input_ == \"uniform\":\n","        np.random.seed(s_)\n","        r1 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        return r1\n","    elif input_ == \"bernouli\":\n","        np.random.seed(s_)\n","        r0 = np.random.rand(time_hor)\n","        r1 = []\n","        for k in range(len(r0)):\n","          if r0[k] < 0.5:\n","            r1.append(0.5)\n","          else:\n","            r1.append(-0.5)\n","        return r1\n","\n","def generate_w(distr, time_hor, s_, mean, std, w_max, lb, ub):  # disturbance\n","    if distr == \"trunc_guass\":\n","        np.random.seed(s_)\n","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r1 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r2 = rv.rvs(size=time_hor)\n","        return r1, r2\n","    elif distr == \"uniform\":\n","        np.random.seed(s_)\n","        r1 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        r2 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        return r1, r2\n","    elif distr == \"bernouli\":\n","        np.random.seed(s_)\n","        r01 = np.random.rand(time_hor)\n","        r02 = np.random.rand(time_hor)\n","        r1 = []\n","        r2 = []\n","        for k in range(len(r01)):\n","          if r01[k] < 0.5:\n","            r1.append(100)\n","          else:\n","            r1.append(-100)\n","        for k in range(len(r02)):\n","          if r02[k] < 0.5:\n","            r2.append(100)\n","          else:\n","            r2.append(-100)\n","        return r1, r2\n","\n","class SimplePendulumDynamics:\n","    def __init__(self, distr, input):\n","        self.state = None\n","        self.u0 = None\n","        self.distr = distr\n","        self.input = input\n","        self.m, self.l, self.k = system_parameters()\n","        self.alpha_list = []\n","        self.omega_list = []\n","        self.phi_s_u_list = []\n","        self.b_s_list = []\n","        self.phi_list = []\n","        self.state_list = []\n","\n","    def plot_trajectory(self):\n","        t_list = np.array(range(len(self.alpha_list))) * dt\n","        fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n","        plt.subplots_adjust(left=0.1, right=0.9, bottom=0.1, top=0.9, wspace=0.5, hspace=0.4)   # wspace: space between subplots in a row\n","\n","        # print(np.sin(np.array(self.alpha_list)))\n","        axs[0].plot(t_list, np.sin(np.array(self.alpha_list)), label='$sin(\\\\alpha)$')\n","        axs[0].plot(t_list, np.array(self.alpha_list), label='$\\\\alpha$')\n","        # axs[0].scatter(t_list, np.sin(np.array(self.alpha_list)), marker='o')\n","        # plt.title(\"Quadrotor's Position\")\n","        axs[0].set_xlabel('time (s)')\n","        axs[0].set_ylabel('$\\\\alpha$ ($rad$)')\n","        axs[0].legend()\n","\n","        # print(np.array(self.omega_list))\n","        axs[1].plot(t_list, self.omega_list, label='$\\omega$')\n","        # axs[1].scatter(t_list, self.omega_list, marker='o')\n","        # plt.title(\"Quadrotor's Angular Velocity\")\n","        axs[1].set_xlabel('time (s)')\n","        axs[1].set_ylabel('$\\omega$ ($rad/s^{2}$)')\n","        axs[1].legend()\n","\n","        plt.show()\n","\n","    def update_feature_list(self, phi_s_u, s_, s, ex):\n","        self.phi_s_u_list.append(phi_s_u)\n","        self.b_s_list.append(s - s_ - ex)\n","\n","    def update_feat(self, y):\n","        self.phi_list.append(y)\n","\n","\n","    def get_trajectory_3(self, x0, time_hor, s_u, s_w, param_u, mult_u, param_w, mult_w):\n","\n","        # ----------------------------------------- initial states -----------------------------------------------------\n","        self.state = x0\n","        x = np.array(x0)\n","        alpha_ = x[0]  # angle\n","        omega_ = x[1]  # angular velocity\n","\n","        #  ------------------------------------- Storing the states - ---------------------------------------------\n","        self.alpha_list = [alpha_]\n","        self.omega_list = [omega_]\n","        self.state_list = [np.array([alpha_, omega_])]\n","\n","        if self.input == \"trunc_guass\":\n","          u_max_ = param_u[2]\n","        else:\n","          u_max_ = 1.0\n","\n","        if self.distr == \"trunc_guass\":\n","          w_max_ = param_w[2]\n","        else:\n","          w_max_ = 1.0\n","\n","        # -----------------  random noise and disturbance generation ---------------------------------------------------\n","        U1_list = generate_u(self.input, time_hor, s_u, mean=param_u[0], std=param_u[1], u_max=u_max_, lb=param_u[0], ub=param_u[1])\n","        W1_list, W2_list = generate_w(self.distr, time_hor, s_w, mean=param_w[0], std=param_w[1], w_max=w_max_, lb=param_w[0], ub=param_w[1])\n","\n","        for t in range(time_hor):\n","\n","            s_ = omega_\n","\n","            # ------------------  noise in control input  (for exploration)  ----------------------------------------\n","            u1 = U1_list[t]\n","\n","            # ----------------   noise in control input  (for exploration)  -----------------------------------------\n","            w1 = mult_w[0] * W1_list[t]\n","            w2 = mult_w[1] * W2_list[t]\n","\n","            # ----------------------------------------  PD control + noise  ------------------------------------------\n","            u = - self.k * omega_ + u1\n","\n","            # ------------------------------------------  Dynamic model ----------------------------------------------\n","            alpha_dot = omega_ + w1\n","            omega_dot = - g * math.sin(alpha_) / self.l + u / (self.m * self.l * self.l) + w2\n","\n","            phi_s_u = np.array([-g*math.sin(alpha_), u])\n","            self.update_feat(phi_s_u)\n","\n","            # -------------------------------------- Updating the states --------------------------------------------\n","            alpha = alpha_ + dt * alpha_dot\n","            omega = omega_ + dt * omega_dot\n","\n","            self.state = np.array([alpha, omega])\n","\n","            s = omega\n","\n","            self.update_feature_list(dt * phi_s_u, s_, s, 0)\n","\n","            omega_ = omega\n","            alpha_ = alpha\n","\n","            # ------------------------------------- Storing the states ----------------------------------------------\n","            self.alpha_list.append(alpha)\n","            self.omega_list.append(omega)\n","            self.state_list.append(np.array([alpha, omega]))"],"metadata":{"id":"NOS3prsCLk9-","executionInfo":{"status":"ok","timestamp":1730309695299,"user_tz":300,"elapsed":169,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":34,"outputs":[]},{"cell_type":"code","execution_count":35,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":208,"status":"ok","timestamp":1730309700411,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"},"user_tz":300},"id":"bBkYqpUKv52B","outputId":"de953b00-b706-49e5-c0e2-41e52252d6fc"},"outputs":[{"output_type":"stream","name":"stdout","text":["-----------------------------------------------------------------------\n","ground truth =  [2.0, 40.0]\n","-----------------------------------------------------------------------\n","------------------Getting Trajectory Data of Quadrotor-----------------\n","e =  1\n","-------------------------------Data Saved------------------------------\n"]}],"source":["# --------------------------import packages-------------------------------------\n","import numpy as np\n","import math\n","import matplotlib.pyplot as plt\n","from matplotlib.colors import to_rgba\n","from scipy.stats import norm\n","np.set_printoptions(threshold=np.inf)\n","\n","# ----------------------import classes and functions----------------------------\n","# from pendulum_dynamics import SimplePendulumDynamics\n","\n","# --------------------------ground_truth parameters-----------------------------\n","m, l, _ = system_parameters()\n","ground_truth = [1 / l, 1 / m / l / l]\n","print(\"-----------------------------------------------------------------------\")\n","print(\"ground truth = \", ground_truth)\n","print(\"-----------------------------------------------------------------------\")\n","\n","n_epoch = 1             # number trajectories\n","max_time_hor = 100      # maximum trajectory length\n","\n","# ------------------------------disturbacne-------------------------------------\n","disturbance: str = \"trunc_guass\"\n","parameter_dist = [0.0, 0.5, 2]  # mean and std\n","\n","# disturbance: str = \"bernouli\"\n","\n","# disturbance: str = \"uniform\"\n","# parameter_dist = [-1, 1]  # lb and ub\n","\n","mult_w = [1, 1]\n","seeds_w = range(300, 500) # fixing seeds\n","w_max = 0.01             # maximum disturbance (required to run set membership)\n","\n","# ---------------------------------noise----------------------------------------\n","c_input: str = \"trunc_guass\"\n","parameter_input = [0.0, 0.5, 2]  # mean and std and scale\n","\n","# c_input: str = \"bernouli\"\n","\n","# c_input: str = \"uniform\"\n","# parameter_input = [-1, 1]  # lb and ub\n","\n","mult_u = [1]\n","seeds_u = range(100, 300)   # fixing seeds\n","\n","\n","print('------------------Getting Trajectory Data of Quadrotor-----------------')\n","# theta_hat_list = []\n","Delta_S_list = []\n","Phi_S_U_list = []\n","Phi_list = []\n","State_list = []\n","\n","for e in range(n_epoch):\n","  x0 = [0.0 , 0.0]\n","  pend = SimplePendulumDynamics(c_input, disturbance)\n","  pend.get_trajectory_3(x0, max_time_hor, seeds_u[e], seeds_w[e], parameter_input, mult_u, parameter_dist, mult_w)\n","  # print(\"---------------------------------------------------------------------\")\n","  print(\"e = \", e + 1)\n","  # pend.plot_trajectory()\n","\n","  Delta_S_list.append(pend.b_s_list)\n","  Phi_S_U_list.append(pend.phi_s_u_list)     # nonlinear feature vector\n","\n","  Phi_list.append(pend.phi_list)\n","  State_list.append(pend.state_list)\n","\n","print('-------------------------------Data Saved------------------------------')"]},{"cell_type":"code","source":["n_ = 1000\n","n__ = 2\n","L_ = np.random.uniform(0,1, size = (n_,n__))\n","row_sums = L_.sum(axis=1)\n","L = L_ / row_sums[:, np.newaxis]"],"metadata":{"id":"a9LLgCWAEHuX","executionInfo":{"status":"ok","timestamp":1730309412871,"user_tz":300,"elapsed":220,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":27,"outputs":[]},{"cell_type":"code","source":["def feature_new(state_, phi_, w1, w2, u):\n","\n","  alpha_ = state_[0]\n","  omega_ = state_[1]\n","\n","  s_ = omega_\n","\n","  m, l, _ = system_parameters()\n","\n","  theta_star = np.array([1 / l, 1 / m / l / l])\n","\n","  dt = 0.01\n","  g = 9.8\n","  alpha = alpha_ + dt * omega_ + w1\n","  omega = omega_ + theta_star @ phi_ +w2\n","\n","  phi_new = dt*np.array([- g * math.sin(alpha), u])\n","\n","  return phi_new\n","\n","def estimate_max_prob(L, state_list, phi_list, time_hor_, num_traj, num_iter, c, c_input, disturbance, param_u, mult_u, param_w):\n","\n","  probs = []\n","  stds = []\n","  b_phi = []\n","  n_ = 0\n","  e = 0\n","\n","  if c_input == \"trunc_guass\":\n","    u_max_ = param_u[2]\n","  else:\n","    u_max_ = 1.0\n","\n","  if disturbance == \"trunc_guass\":\n","    w_max_ = param_w[2]\n","  else:\n","    w_max_ = 1.0\n","\n","  seeds_u = range(100, 100+num_iter*len(L)*time_hor_)\n","  seeds_w = range(3000, 3000+num_iter*len(L)*time_hor_)\n","\n","  U1_list = generate_u(c_input, num_iter*len(L)*time_hor_, seeds_u, mean=param_u[0], std=param_u[1], u_max=u_max_, lb=param_u[0], ub=param_u[1])\n","  W1_list, W2_list = generate_w(disturbance, num_iter*len(L)*time_hor_, seeds_w, mean=param_w[0], std=param_w[1], w_max=w_max_, lb=param_w[0], ub=param_w[1])\n","\n","  ind = 0\n","\n","  b_phi_ = []\n","  for tt in range(time_hor_):\n","\n","    print(\"-------------------------\")\n","    print(\"T = \", tt+1)\n","\n","    for k in range(len(L)):\n","\n","      l = L[k, :]\n","      n = 0\n","\n","      for j in range(num_iter):\n","\n","        y = feature_new(state_list[e][tt], phi_list[e][tt], mult_w[0]*W1_list[ind], mult_w[1]*W2_list[ind], mult_u[0]*U1_list[ind])\n","        z = np.dot(l, y)\n","        if (abs(z) <= c):\n","          n = n + 1\n","\n","        ind = ind + 1\n","        b_phi_.append(np.dot(y, y))\n","\n","      if k == 0:\n","        b_phi.append(np.mean(np.array(b_phi_)))\n","      probs.append(n / num_iter)\n","      n_ = n_ + 1\n","  print(\"-------------------------\")\n","\n","  return np.max(np.array(probs)), np.max(np.array(b_phi))\n","\n","\n","# c_list = [1e-3, 2e-3, 3e-3, 4e-3, 5e-3, 0.1]\n","# c_list = [1e-4, 2e-4, 3e-4, 4e-4, 5e-4, 1e-3, 0.005]\n","c_list = [5e-4, 1e-3, 2e-3, 3e-3, 4e-3, 5e-3]\n","prob_list = []\n","for c in c_list:\n","  num_iter = 20\n","  num_traj = 1\n","  time_hor_ = 50\n","  p, b_phi = estimate_max_prob(L, State_list, Phi_S_U_list, time_hor_, num_traj, num_iter, c, c_input, disturbance, parameter_input, mult_u, parameter_dist)\n","  print(\"c = \", c)\n","  print(\"max prob = \", p)\n","  print(\"max b_phi = \", b_phi)\n","  print(\"----------------------------------------------------------------------------------------------\")\n","  prob_list.append(p)\n","print(np.array(c_list) * np.array(prob_list))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"pnTOaypzt8uz","executionInfo":{"status":"ok","timestamp":1730309843452,"user_tz":300,"elapsed":73606,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"b9a3f288-a232-4e16-ab0e-930e7277d4dd"},"execution_count":36,"outputs":[{"output_type":"stream","name":"stdout","text":["-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.0005\n","max prob =  0.35\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.001\n","max prob =  0.45\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.002\n","max prob =  0.7\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.003\n","max prob =  0.8\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.004\n","max prob =  0.9\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","-------------------------\n","T =  1\n","-------------------------\n","T =  2\n","-------------------------\n","T =  3\n","-------------------------\n","T =  4\n","-------------------------\n","T =  5\n","-------------------------\n","T =  6\n","-------------------------\n","T =  7\n","-------------------------\n","T =  8\n","-------------------------\n","T =  9\n","-------------------------\n","T =  10\n","-------------------------\n","T =  11\n","-------------------------\n","T =  12\n","-------------------------\n","T =  13\n","-------------------------\n","T =  14\n","-------------------------\n","T =  15\n","-------------------------\n","T =  16\n","-------------------------\n","T =  17\n","-------------------------\n","T =  18\n","-------------------------\n","T =  19\n","-------------------------\n","T =  20\n","-------------------------\n","T =  21\n","-------------------------\n","T =  22\n","-------------------------\n","T =  23\n","-------------------------\n","T =  24\n","-------------------------\n","T =  25\n","-------------------------\n","T =  26\n","-------------------------\n","T =  27\n","-------------------------\n","T =  28\n","-------------------------\n","T =  29\n","-------------------------\n","T =  30\n","-------------------------\n","T =  31\n","-------------------------\n","T =  32\n","-------------------------\n","T =  33\n","-------------------------\n","T =  34\n","-------------------------\n","T =  35\n","-------------------------\n","T =  36\n","-------------------------\n","T =  37\n","-------------------------\n","T =  38\n","-------------------------\n","T =  39\n","-------------------------\n","T =  40\n","-------------------------\n","T =  41\n","-------------------------\n","T =  42\n","-------------------------\n","T =  43\n","-------------------------\n","T =  44\n","-------------------------\n","T =  45\n","-------------------------\n","T =  46\n","-------------------------\n","T =  47\n","-------------------------\n","T =  48\n","-------------------------\n","T =  49\n","-------------------------\n","T =  50\n","-------------------------\n","c =  0.005\n","max prob =  1.0\n","max b_phi =  0.0016217202038761298\n","----------------------------------------------------------------------------------------------\n","[0.000175 0.00045  0.0014   0.0024   0.0036   0.005   ]\n"]}]},{"cell_type":"code","source":["delta = 0.1\n","time_hor = 30000\n","\n","n_x = 1\n","n_u = 1\n","n_phi = 2\n","\n","w_max = 0.01\n","u_max = 0.01\n","sigma_u = np.sqrt((2*u_max)**2/12)\n","sigma_w = np.sqrt((2*w_max)**2/12)\n","\n","s_phi = 0.005\n","p_phi = 0.85\n","b_phi = 0.00266\n","\n","theo_bound = []\n","time_list = []\n","for k in range(time_hor):\n","  cc = b_phi/delta/s_phi/s_phi\n","  cond = (10/p_phi) * (np.log(1/delta) + 2*n_phi*np.log(10/p_phi) + n_phi*np.log(cc))\n","  if (k+1) >= cond:\n","    time_list.append(k+1)\n","    theo_bound_ = (90*sigma_w/p_phi) * np.sqrt((n_x + np.log(1/delta) + n_phi*np.log(10/p_phi) + n_phi*np.log(cc)) / ((k+1)*s_phi))\n","    theo_bound.append(theo_bound_)\n","\n","disturbance = \"uniform\"\n","name1 = 'lse_theo_bound_1_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'delta' +   '_' + str(delta) + '.csv'\n","name2 = 'lse_theo_bound_2_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'delta' +   '_' + str(delta) + '.csv'\n","np.savetxt(name1, np.array(time_list), delimiter = \",\")\n","np.savetxt(name2, np.array(theo_bound), delimiter = \",\")"],"metadata":{"id":"ezjs0GP_VJ-g","executionInfo":{"status":"ok","timestamp":1730308348130,"user_tz":300,"elapsed":607,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":7,"outputs":[]},{"cell_type":"code","source":["delta = 0.1\n","time_hor = 30000\n","\n","n_x = 1\n","n_u = 1\n","n_phi = 2\n","\n","sigma_u = 0.001\n","sigma_w = 0.001\n","w_max = 0.01\n","\n","s_phi = 0.0005\n","p_phi = 0.75\n","b_phi = 9.681352864644174e-05\n","\n","theo_bound = []\n","time_list = []\n","for k in range(time_hor):\n","  cc = b_phi/delta/s_phi/s_phi\n","  cond = (10/p_phi) * (np.log(1/delta) + 2*n_phi*np.log(10/p_phi) + n_phi*np.log(cc))\n","  if (k+1) >= cond:\n","    time_list.append(k+1)\n","    theo_bound_ = (90*sigma_w/p_phi) * np.sqrt((n_x + np.log(1/delta) + n_phi*np.log(10/p_phi) + n_phi*np.log(cc)) / ((k+1)*s_phi))\n","    theo_bound.append(theo_bound_)\n","\n","disturbance = \"trunc_guass\"\n","name1 = 'lse_theo_bound_1_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'delta' +   '_' + str(delta) + '.csv'\n","name2 = 'lse_theo_bound_2_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'delta' +   '_' + str(delta) + '.csv'\n","np.savetxt(name1, np.array(time_list), delimiter = \",\")\n","np.savetxt(name2, np.array(theo_bound), delimiter = \",\")"],"metadata":{"id":"_4vGUrnWUTJK","executionInfo":{"status":"ok","timestamp":1730309552448,"user_tz":300,"elapsed":1929,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":31,"outputs":[]},{"cell_type":"code","source":["import numpy as np\n","import math\n","import matplotlib.pyplot as plt\n","\n","eps = 0.1\n","T = 30000\n","\n","n_x = 1\n","n_u = 1\n","n_phi = 2\n","\n","w_max = 0.01\n","u_max = 0.01\n","sigma_u = np.sqrt((2*u_max)**2/12)\n","sigma_w = np.sqrt((2*w_max)**2/12)\n","\n","s_phi = 0.005\n","p_phi = 0.85\n","b_phi = np.sqrt(0.00266)\n","\n","\n","a1 = s_phi * p_phi / 4\n","a2 = (8 * b_phi / (s_phi * p_phi) ) ** 2\n","a3 = (p_phi ** 2) / 8\n","a4 = max (1, (4 * b_phi * np.sqrt(n_x) / a1))\n","\n","m = (1 / a3) * (np.log(T/eps) + n_phi*np.log(a2) + 2.5*np.log(n_phi) + np.log(np.log(a2 * n_phi)) + 7)\n","print(m)\n","m_ = int(np.ceil(m))\n","theo_diam = []\n","a = ((n_phi) ** 2.5)  * (a2 ** n_phi)  * np.exp(-a3*m)\n","b = ((n_phi * n_x) ** 2.5)  * (a4 ** (n_phi * n_x))\n","for t in range(m_, T):\n","  diam_= 4 / t\n","  theo_diam.append(diam_)\n","\n","disturbance = \"uniform_\"\n","name1 = 'sme_theo_bound_1_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'eps' +   '_' + str(eps) + '.csv'\n","name2 = 'sme_theo_bound_2_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'eps' +   '_' + str(eps) + '.csv'\n","np.savetxt(name1, np.array(range(m_, T)), delimiter = \",\")\n","np.savetxt(name2, 1000 * np.array(theo_diam), delimiter = \",\")"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"hMdqz5DKSJRc","executionInfo":{"status":"ok","timestamp":1730308802746,"user_tz":300,"elapsed":408,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"5f8c9f1d-fefd-4892-baf5-d4d47ffb1157"},"execution_count":17,"outputs":[{"output_type":"stream","name":"stdout","text":["464.31610994520514\n"]}]},{"cell_type":"code","source":["import numpy as np\n","import math\n","import matplotlib.pyplot as plt\n","\n","eps = 0.1\n","T = 30000\n","\n","n_x = 1\n","n_u = 1\n","n_phi = 2\n","\n","w_max = 0.01\n","u_max = 0.01\n","sigma_u = 0.005\n","sigma_w = 0.005\n","\n","\n","s_phi = 0.004\n","p_phi = 0.9\n","b_phi = np.sqrt(0.0016)\n","\n","\n","a1 = s_phi * p_phi / 4\n","a2 = (8 * b_phi / (s_phi * p_phi) ) ** 2\n","a3 = (p_phi ** 2) / 8\n","a4 = max (1, (4 * b_phi * np.sqrt(n_x) / a1))\n","\n","m = (1 / a3) * (np.log(T/eps) + n_phi*np.log(a2) + 2.5*np.log(n_phi) + np.log(np.log(a2 * n_phi)) + 7)\n","print(m)\n","m_ = int(np.ceil(m))\n","theo_diam = []\n","a = ((n_phi) ** 2.5)  * (a2 ** n_phi)  * np.exp(-a3*m)\n","b = ((n_phi * n_x) ** 2.5)  * (a4 ** (n_phi * n_x))\n","for t in range(m_, T):\n","  diam_= 4 / t\n","  theo_diam.append(diam_)\n","\n","disturbance = \"trunc_\"\n","name1 = 'sme_theo_bound_1_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'eps' +   '_' + str(eps) + '.csv'\n","name2 = 'sme_theo_bound_2_' + 'w_' + disturbance + '_' + str(sigma_w) + '_' + 's_phi' '_' + str(s_phi) + '_' + 'p_phi' +  '_' + str(p_phi) +  '_' + 'eps' +   '_' + str(eps) + '.csv'\n","np.savetxt(name1, np.array(range(m_, T)), delimiter = \",\")\n","np.savetxt(name2, 1000 * np.array(theo_diam), delimiter = \",\")"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"etKvekTjSGpP","executionInfo":{"status":"ok","timestamp":1730309850566,"user_tz":300,"elapsed":314,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"155bcb88-6f51-4b08-f61d-230b0de44f25"},"execution_count":37,"outputs":[{"output_type":"stream","name":"stdout","text":["410.496470594187\n"]}]},{"cell_type":"code","source":["print(name1)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"0uxLvl12cSHB","executionInfo":{"status":"ok","timestamp":1730309852801,"user_tz":300,"elapsed":2,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"2a4cb043-4374-4411-ba9e-ef1b0388ddbf"},"execution_count":38,"outputs":[{"output_type":"stream","name":"stdout","text":["sme_theo_bound_1_w_trunc__0.005_s_phi_0.004_p_phi_0.9_eps_0.1.csv\n"]}]}],"metadata":{"colab":{"provenance":[{"file_id":"1Y0Ux1iq6vi7AfbndrgdcvChEUuSicb42","timestamp":1716925749762}],"gpuType":"T4","authorship_tag":"ABX9TyMJkP/eMOAZzjOgtyIRu6Ki"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"},"accelerator":"GPU"},"nbformat":4,"nbformat_minor":0}