{"cells":[{"cell_type":"code","execution_count":1,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":25492,"status":"ok","timestamp":1730310987055,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"},"user_tz":300},"id":"dj4A8w9QyhBO","outputId":"adde413a-60a6-462a-e8d3-99a131b328b4"},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/drive/\n","/content/drive/MyDrive/Colab Notebooks/nonlinear-sys-id/quadrotor 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/quadrotor\\ neurips/"]},{"cell_type":"markdown","metadata":{"id":"Aj1u35iCv1ia"},"source":["# Getting Trajectory Data of Quadrotor"]},{"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","\n","g = 9.81  # (m/s^2)  gravity constant\n","dt = 0.01  # time_step for discrete-time system\n","\n","\n","def system_parameters():\n","    # -------------------------- Quadcoptor --------------------------\n","    I_xx = 4.856e-3  # (kg/m^2) moment of inertia\n","    I_yy = 4.856e-3  # (kg/m^2) moment of inertia\n","    I_zz = 8.801e-3  # (kg/m^2) moment of inertia\n","    m = 0.468  # (kg)    weight\n","    Ax = 0.25  # (kg/s)  drag force coefficients\n","    Ay = 0.25  # (kg/s)  drag force coefficients\n","    Az = 0.25  # (kg/s)  drag force coefficients\n","    # --------------------------- Rotor -------------------------------\n","    l = 0.225  # (m) distance between the rotor and the center of mass\n","    k = 2.980e-6  # lift constant of the rotor\n","    b = 1.140e-7  # drag constant of the rotor\n","    I_r = 3.357e-5  # (kg/m^2) moment of inertia\n","    return I_xx, I_yy, I_zz, Ax, Ay, Az, m, l, k, b, I_r\n","\n","\n","def euler_to_quaternion(roll, pitch, yaw):\n","\n","    cr = np.cos(roll * 0.5)\n","    sr = np.sin(roll * 0.5)\n","    cp = np.cos(pitch * 0.5)\n","    sp = np.sin(pitch * 0.5)\n","    cy = np.cos(yaw * 0.5)\n","    sy = np.sin(yaw * 0.5)\n","\n","    q0 = cr * cp * cy + sr * sp * sy\n","    q1 = sr * cp * cy - cr * sp * sy\n","    q2 = cr * sp * cy + sr * cp * sy\n","    q3 = cr * cp * sy - sr * sp * cy\n","\n","    return q0, q1, q2, q3\n","\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","        rv = truncnorm(-u_max, u_max, loc=mean, scale=std)\n","        r2 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-u_max, u_max, loc=mean, scale=std)\n","        r3 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-u_max, u_max, loc=mean, scale=std)\n","        r4 = rv.rvs(size=time_hor)\n","        return r1, r2, r3, r4\n","    elif input_ == \"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","        r3 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        r4 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        return r1, r2, r3, r4\n","\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","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r3 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r4 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r5 = rv.rvs(size=time_hor)\n","        rv = truncnorm(-w_max, w_max, loc=mean, scale=std)\n","        r6 = rv.rvs(size=time_hor)\n","        return r1, r2, r3, r4, r5, r6\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","        r3 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        r4 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        r5 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        r6 = np.random.uniform(low=lb, high=ub, size=time_hor)\n","        return r1, r2, r3, r4, r5, r6\n","\n","\n","class QuadrotorDynamics:\n","    def __init__(self, distr, input):\n","        self.distr = distr\n","        self.input = input\n","        self.I_xx, self.I_yy, self.I_zz, self.Ax, self.Ay, self.Az, self.m, self.l, self.k, self.b, self.I_r = system_parameters()\n","        self.px_list = []\n","        self.py_list = []\n","        self.pz_list = []\n","        self.vx_list = []\n","        self.vy_list = []\n","        self.vz_list = []\n","        self.q0_list = []\n","        self.q1_list = []\n","        self.q2_list = []\n","        self.q3_list = []\n","        self.wx_list = []\n","        self.wy_list = []\n","        self.wz_list = []\n","        self.phi_s_u_list = []\n","        self.b_s_list = []\n","        self.u1_lis = []\n","        self.u2_lis = []\n","        self.u3_lis = []\n","        self.u4_lis = []\n","        self.state_list = []\n","\n","    def plot_trajectory(self):\n","        t_list = np.array(range(len(self.px_list))) * dt\n","        fig = plt.figure()\n","        plt.plot(t_list, self.px_list, label='$p_{x}$')\n","        plt.plot(t_list, self.py_list, label='$p_{y}$')\n","        plt.plot(t_list, self.pz_list, label='$p_{z}$')\n","        plt.title(\"Quadrotor's Position\")\n","        plt.xlabel('time (s)')\n","        plt.ylabel(\"Quadrotor's Position\")\n","        plt.legend()\n","\n","        fig = plt.figure()\n","        plt.plot(t_list, self.vx_list, label='$v_{x}$')\n","        plt.plot(t_list, self.vy_list, label='$v_{y}$')\n","        plt.plot(t_list, self.vz_list, label='$v_{z}$')\n","        plt.title(\"Quadrotor's Translation Velocity\")\n","        plt.xlabel('time (s)')\n","        plt.ylabel(\"Quadrotor's Translation Velocity\")\n","        plt.legend()\n","\n","        fig = plt.figure()\n","        plt.plot(t_list, self.q0_list, label='$q_{0}$')\n","        plt.plot(t_list, self.q1_list, label='$q_{1}$')\n","        plt.plot(t_list, self.q2_list, label='$q_{2}$')\n","        plt.plot(t_list, self.q3_list, label='$q_{3}$')\n","        plt.title(\"Quaternions\")\n","        plt.xlabel('time (s)')\n","        plt.ylabel(\"Quaternion\")\n","        plt.legend()\n","\n","        fig = plt.figure()\n","        plt.plot(t_list, self.wx_list, label='$\\omega_{x}$')\n","        plt.plot(t_list, self.wy_list, label='$\\omega_{y}$')\n","        plt.plot(t_list, self.wz_list, label='$\\omega_{z}$')\n","        plt.title(\"Quadrotor's Angular Velocity\")\n","        plt.xlabel('time (s)')\n","        plt.ylabel(\"Quadrotor's Angular Velocity\")\n","        plt.legend()\n","\n","        fig = plt.figure()\n","        plt.plot(t_list[1:], self.u1_lis, label='$u_{1}$')\n","        plt.plot(t_list[1:], self.u2_lis, label='$u_{2}$')\n","        plt.plot(t_list[1:], self.u3_lis, label='$u_{3}$')\n","        plt.plot(t_list[1:], self.u4_lis, label='$u_{4}$')\n","        plt.title(\"control\")\n","        plt.xlabel('time (s)')\n","        plt.ylabel(\"control\")\n","        plt.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","\n","    def get_trajectory_3(self, x0, time_hor, s_u, s_w, param_u, mult_u, param_w):\n","\n","        g_ = np.array([0, 0, g])  # gravity vector in inertial frame\n","        J = np.diag(np.array([self.I_xx, self.I_yy, self.I_zz]))  # inertia matrix\n","        drag = np.diag(np.array([self.Ax, self.Ay, self.Az]))  # drag force coefficients\n","\n","        # ----------------------------------------- initial states -----------------------------------------------------\n","        x = np.array(x0)\n","        p = x[:3]  # position in inertial frame\n","        v = x[3:6]  # velocity in inertial frame\n","        q = x[6:10]  # quaternions\n","        omega = x[10:]  # angular velocity in body frame\n","\n","        #  ------------------------------------- Storing the states - ---------------------------------------------\n","        self.px_list = [p[0]]\n","        self.py_list = [p[1]]\n","        self.pz_list = [p[2]]\n","\n","        self.vx_list = [v[0]]\n","        self.vy_list = [v[1]]\n","        self.vz_list = [v[2]]\n","\n","        self.q0_list = [q[0]]\n","        self.q1_list = [q[1]]\n","        self.q2_list = [q[2]]\n","        self.q3_list = [q[3]]\n","\n","        self.wx_list = [omega[0]]\n","        self.wy_list = [omega[1]]\n","        self.wz_list = [omega[2]]\n","\n","        self.state_list.append(np.array([p[0], p[1], p[2], v[0], v[1], v[2], q[0], q[1], q[2], q[3], omega[0], omega[1], omega[2]]))\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, U2_list, U3_list, U4_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, W3_list, W4_list, W5_list, W6_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","        # ---------------------------------- controller gains  ------------------------------------------------------\n","        kp_z = 0.75\n","        kd_z = 1.25\n","        kp_phi = 0.03\n","        kp_theta = 0.03\n","        kp_psi = 0.03\n","        kd_phi = 0.00875\n","        kd_theta = 0.00875\n","        kd_psi = 0.00875\n","\n","        # ---------------------------------   desired states   ---------------------------------------------------------\n","        pz_d = 5.\n","        vz_d = 0.\n","        q0_d, q1_d, q2_d, q3_d = euler_to_quaternion(0, 0, 0)\n","\n","        for t in range(time_hor):\n","\n","            s_ = np.array([v[0], v[1], v[2], omega[0], omega[1], omega[2]])\n","\n","            q0 = q[0]\n","            q1 = q[1]\n","            q2 = q[2]\n","            q3 = q[3]\n","\n","            omega1 = omega[0]\n","            omega2 = omega[1]\n","            omega3 = omega[2]\n","\n","            # ------------------  noise in control input  (for exploration)  ----------------------------------------\n","            u1 = mult_u[0] * U1_list[t]\n","            u2 = mult_u[1] * U2_list[t]\n","            u3 = mult_u[2] * U3_list[t]\n","            u4 = mult_u[3] * U4_list[t]\n","\n","            # ----------------   noise in control input  (for exploration)  -----------------------------------------\n","            w1 = W1_list[t]\n","            w2 = W2_list[t]\n","            w3 = W3_list[t]\n","            w4 = W4_list[t]\n","            w5 = W5_list[t]\n","            w6 = W6_list[t]\n","\n","            # ----------------------------------------  control + noise  ------------------------------------------\n","            pi_z = kp_z * (pz_d - p[2]) + kd_z * (vz_d - v[2])\n","            f_c = np.array([0, 0, (5 + pi_z + u1)])\n","\n","            qe1 = - q0_d * q1 - q3_d * q2 + q2_d * q3 + q1_d * q0\n","            qe2 = q3_d * q1 - q0_d * q2 - q1_d * q3 + q2_d * q0\n","            qe3 = - q2_d * q1 + q1_d * q2 - q0_d * q3 + q3_d * q0\n","            qe4 = q1_d * q1 + q2_d * q2 + q3_d * q3 + q0_d * q0\n","\n","            pi_phi = -kd_phi * omega1 + kp_phi * qe1 * qe4\n","            pi_theta = -kd_theta * omega2 + 2 * kp_theta * qe2 * qe4\n","            pi_psi = -kd_psi * omega3 + 2 * kp_psi * qe3 * qe4\n","            tau_c = np.array([pi_phi + u2, pi_theta + u3, pi_psi + u4])\n","\n","            # ------------------------------------------  Dynamic model ----------------------------------------------\n","            Q = np.array([[q0 * q0 + q1 * q1 - q2 * q2 - q3 * q3, 2 * (q1 * q2 - q0 * q3),\n","                           2 * (q0 * q2 + q1 * q3)],\n","                          [2 * (q1 * q2 + q0 * q3), q0 * q0 - q1 * q1 + q2 * q2 - q3 * q3,\n","                           2 * (q2 * q3 - q0 * q1)],\n","                          [2 * (q1 * q3 - q0 * q2), 2 * (q0 * q1 + q2 * q3),\n","                           q0 * q0 - q1 * q1 - q2 * q2 + q3 * q3]])\n","\n","            Omega = np.array([[0, -omega1, -omega2, -omega3],\n","                              [omega1, 0, omega3, -omega2],\n","                              [omega2, -omega3, 0, omega1],\n","                              [omega3, omega2, -omega1, 0]])\n","\n","            theta_star = np.array(\n","                [[1 / self.m, 0., 0., -self.Ax / self.m, 0., 0., 0., 0., 0., 0., 0., 0.],\n","                 [0., 1 / self.m, 0., 0., -self.Ay / self.m, 0., 0., 0., 0., 0., 0., 0.],\n","                 [0., 0., 1 / self.m, 0., 0., -self.Az / self.m, 0., 0., 0., 0., 0., 0.],\n","                 [0., 0., 0., 0., 0., 0., (self.I_yy - self.I_zz) / self.I_xx, 0., 0., 1 / self.I_xx, 0., 0.],\n","                 [0., 0., 0., 0., 0., 0., 0., (self.I_zz - self.I_xx) / self.I_yy, 0., 0., 1 / self.I_yy, 0.],\n","                 [0., 0., 0., 0., 0., 0., 0., 0., (self.I_yy - self.I_xx) / self.I_zz, 0., 0., 1 / self.I_zz]])\n","            Qfc = Q @ f_c\n","            phi_s_u = np.array([Qfc[0], Qfc[1], Qfc[2],\n","                                v[0], v[1], v[2],\n","                                omega2 * omega3, omega1 * omega3, omega1 * omega2,\n","                                tau_c[0], tau_c[1], tau_c[2]])\n","\n","            p_dot = v\n","            q_dot = Omega @ q / 2\n","            s_dot = - np.array([0., 0., g, 0., 0., 0.]) + theta_star @ phi_s_u + np.array([w1, w2, w3, w4, w5, w6])\n","\n","            # -------------------------------------- Updating the states --------------------------------------------\n","            p = p + dt * p_dot\n","            q = (q + dt * q_dot) / (q0 * q0 + q1 * q1 + q2 * q2 + q3 * q3)\n","            s = s_ + dt * s_dot\n","            v = s[:3]\n","            omega = s[3:]\n","\n","            self.update_feature_list(dt * phi_s_u, s_, s, - dt * np.array([0., 0., g, 0., 0., 0.]))\n","\n","            # ------------------------------------- Storing the states ----------------------------------------------\n","            self.px_list.append(p[0])\n","            self.py_list.append(p[1])\n","            self.pz_list.append(p[2])\n","\n","            self.vx_list.append(v[0])\n","            self.vy_list.append(v[1])\n","            self.vz_list.append(v[2])\n","\n","            self.q0_list.append(q[0])\n","            self.q1_list.append(q[1])\n","            self.q2_list.append(q[2])\n","            self.q3_list.append(q[3])\n","\n","            self.wx_list.append(omega[0])\n","            self.wy_list.append(omega[1])\n","            self.wz_list.append(omega[2])\n","\n","            self.u1_lis.append(f_c[2])\n","            self.u2_lis.append(tau_c[0])\n","            self.u3_lis.append(tau_c[1])\n","            self.u4_lis.append(tau_c[2])\n","\n","            self.state_list.append(np.array([p[0], p[1], p[2], v[0], v[1], v[2], q[0], q[1], q[2], q[3], omega[0], omega[1], omega[2]]))\n","\n"],"metadata":{"id":"NOS3prsCLk9-","executionInfo":{"status":"ok","timestamp":1730310992417,"user_tz":300,"elapsed":1516,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":2,"outputs":[]},{"cell_type":"code","execution_count":3,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":207,"status":"ok","timestamp":1730311054645,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"},"user_tz":300},"id":"bBkYqpUKv52B","outputId":"8f2d4eec-7c24-4078-aef9-98ebf98b7f96"},"outputs":[{"output_type":"stream","name":"stdout","text":["-----------------------------------------------------------------------\n","ground truth =  [2.1367521367521367, -0.5341880341880342, -0.5341880341880342, -0.5341880341880342, -0.8123970345963756, 205.9308072487644, 0.8123970345963756, 205.9308072487644, 0.0, 113.62345188046812]\n","-----------------------------------------------------------------------\n","------------------Getting Trajectory Data of Quadrotor-----------------\n","e =  1\n","-------------------------------Data Saved------------------------------\n"]}],"source":["# --------------------------import packages-------------------------------------\n","import numpy as np\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","# --------------------------ground_truth parameters-----------------------------\n","I_xx, I_yy, I_zz, Ax, Ay, Az, m, _, _, _, _ = system_parameters()\n","ground_truth = [1 / m, -Ax / m, -Ay / m, -Az / m,\n","                (I_yy - I_zz) / I_xx, 1 / I_xx,\n","                (I_zz - I_xx) / I_yy, 1 / I_yy,\n","                (I_xx - I_yy) / I_zz, 1 / I_zz]\n","\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.1, 10]  # mean and std\n","\n","# disturbance: str = \"uniform\"\n","# parameter_dist = [-1, 1]  # lb and ub\n","\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.1, 10]  # mean and std\n","\n","# c_input: str = \"uniform\"\n","# parameter_input = [-1, 1]  # lb and ub\n","\n","mult_u = [1, 0.2, 0.2, 0.2]\n","\n","seeds_u = range(100, 200)   # fixing seeds\n","\n","print('------------------Getting Trajectory Data of Quadrotor-----------------')\n","\n","theta_hat_list = []\n","Delta_S_list = []\n","Phi_S_U_list = []\n","State_list = []\n","\n","for e in range(n_epoch):\n","\n","  # q0, q1, q2, q3 = euler_to_quaternion(10 * np.pi/180, 10 * np.pi/180, 10 * np.pi/180)\n","  q0 = 1\n","  q1 = 0\n","  q2 = 0\n","  q3 = 0\n","  x0 = [0., 0., 1., 0., 0., 0., q0, q1, q2, q3, 0., 0., 0.]\n","  qudt = QuadrotorDynamics(c_input, disturbance)\n","  qudt.get_trajectory_3(x0, max_time_hor, seeds_u[e], seeds_w[e], parameter_input, mult_u, parameter_dist)\n","  # print(\"---------------------------------------------------------------------\")\n","  print(\"e = \", e + 1)\n","  # qudt.plot_trajectory()\n","\n","  Delta_S_list.append(qudt.b_s_list)\n","  Phi_S_U_list.append(qudt.phi_s_u_list)     # nonlinear feature vector\n","  State_list.append(qudt.state_list)\n","\n","print('-------------------------------Data Saved------------------------------')"]},{"cell_type":"code","source":["n_ = 1000\n","n__ = 12\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":1730311058058,"user_tz":300,"elapsed":198,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":4,"outputs":[]},{"cell_type":"code","source":["def feature_new(state_, phi_, w1, w2, w3, w4, w5, w6, f_, tau1, tau2, tau3):\n","\n","  s_ = np.array([state_[3], state_[4], state_[5], state_[10], state_[11], state_[12]])\n","  q_ = [state_[6], state_[7], state_[8], state_[9]]\n","\n","  I_xx, I_yy, I_zz, Ax, Ay, Az, m, _, _, _, _ = system_parameters()\n","\n","  theta_star = np.array(\n","        [[1 / m, 0., 0., -Ax / m, 0., 0., 0., 0., 0., 0., 0., 0.],\n","        [0., 1 / m, 0., 0., -Ay / m, 0., 0., 0., 0., 0., 0., 0.],\n","        [0., 0., 1 / m, 0., 0., -Az / m, 0., 0., 0., 0., 0., 0.],\n","        [0., 0., 0., 0., 0., 0., (I_yy - I_zz) / I_xx, 0., 0., 1 / I_xx, 0., 0.],\n","        [0., 0., 0., 0., 0., 0., 0., (I_zz - I_xx) / I_yy, 0., 0., 1 / I_yy, 0.],\n","        [0., 0., 0., 0., 0., 0., 0., 0., (I_yy - I_xx) / I_zz, 0., 0., 1 / I_zz]])\n","\n","  dt = 0.01\n","  g = 9.8\n","  s = s_ - dt * np.array([0., 0., g, 0., 0., 0.]) + theta_star @ phi_ + np.array([w1, w2, w3, w4, w5, w6])\n","\n","  q0 = q_[0]\n","  q1 = q_[1]\n","  q2 = q_[2]\n","  q3 = q_[3]\n","  Q = np.array([[q0 * q0 + q1 * q1 - q2 * q2 - q3 * q3, 2 * (q1 * q2 - q0 * q3),\n","                  2 * (q0 * q2 + q1 * q3)],\n","                [2 * (q1 * q2 + q0 * q3), q0 * q0 - q1 * q1 + q2 * q2 - q3 * q3,\n","                  2 * (q2 * q3 - q0 * q1)],\n","                [2 * (q1 * q3 - q0 * q2), 2 * (q0 * q1 + q2 * q3),\n","                  q0 * q0 - q1 * q1 - q2 * q2 + q3 * q3]])\n","  Qfc = Q @ np.array([0, 0, f_])\n","  omega = s[3:]\n","  omega1 = s[3]\n","  omega2 = s[4]\n","  omega3 = s[5]\n","  phi_new = np.array([Qfc[0], Qfc[1], Qfc[2],\n","                    s[0], s[1], s[2],\n","                    omega2 * omega3, omega1 * omega3, omega1 * omega2,\n","                    tau1, tau2, tau3])\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, U2_list, U3_list, U4_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, W3_list, W4_list, W5_list, W6_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], W1_list[ind], W2_list[ind] , W3_list[ind], W4_list[ind], W5_list[ind], W6_list[ind],\n","                        mult_u[0]*U1_list[ind], mult_u[1]*U2_list[ind], mult_u[2]*U3_list[ind], mult_u[3]*U4_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, 5e-3, 1e-2, 5e-2, 0.1, 0.5]\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":1730311313178,"user_tz":300,"elapsed":253861,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"e721ad6f-49e4-42b3-e834-89ddc712d3f6"},"execution_count":5,"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.001\n","max prob =  0.3\n","max b_phi =  1.5233735091432863\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 =  0.75\n","max b_phi =  1.5233735091432863\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.01\n","max prob =  0.95\n","max b_phi =  1.5233735091432863\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.05\n","max prob =  1.0\n","max b_phi =  1.5233735091432863\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.1\n","max prob =  1.0\n","max b_phi =  1.5233735091432863\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.5\n","max prob =  1.0\n","max b_phi =  1.5233735091432863\n","----------------------------------------------------------------------------------------------\n","[3.00e-04 3.75e-03 9.50e-03 5.00e-02 1.00e-01 5.00e-01]\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","b_phi = 2\n","n_x = 6\n","n_u = 4\n","n_phi = 12\n","\n","sigma_u = 0.5\n","sigma_w = 0.005\n","w_max = 0.01\n","s_phi = 0.05\n","p_phi = 0.95\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":1729903955526,"user_tz":300,"elapsed":378,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"271f1957-44e7-4a7f-dcb9-96c532ce3275"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["1490.4592345260874\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 = 6\n","n_u = 4\n","n_phi = 12\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.05\n","p_phi = 0.8\n","b_phi = np.sqrt(5)\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":1729903951538,"user_tz":300,"elapsed":390,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"8705eaed-9f55-439c-e79a-3df6bb99d3e3"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["2187.2988722064138\n"]}]},{"cell_type":"code","source":["delta = 0.1\n","time_hor = 30000\n","\n","n_x = 6\n","n_u = 4\n","n_phi = 12\n","\n","sigma_u = 0.001\n","sigma_w = 0.001\n","w_max = 0.01\n","\n","s_phi = 0.01\n","p_phi = 0.95\n","\n","b_phi = 2\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":1730311321840,"user_tz":300,"elapsed":1439,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":6,"outputs":[]},{"cell_type":"code","source":["print(name1)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"Mpy-DSz3l4Jp","executionInfo":{"status":"ok","timestamp":1730311331926,"user_tz":300,"elapsed":172,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"d98969a2-dec4-4f0b-e95d-2f5a9114a13a"},"execution_count":7,"outputs":[{"output_type":"stream","name":"stdout","text":["lse_theo_bound_1_w_trunc_guass_0.001_s_phi_0.01_p_phi_0.95_delta_0.1.csv\n"]}]},{"cell_type":"code","source":["delta = 0.1\n","time_hor = 30000\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.05\n","p_phi = 0.8\n","b_phi = 5\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":1730311387130,"user_tz":300,"elapsed":1285,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}}},"execution_count":8,"outputs":[]},{"cell_type":"code","source":["print(name1)"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"I2NhKj41mIHL","executionInfo":{"status":"ok","timestamp":1730311395728,"user_tz":300,"elapsed":165,"user":{"displayName":"Negin Musavi","userId":"05530520244936385717"}},"outputId":"627354c8-2aa6-4e60-ec5f-bfa6031758ee"},"execution_count":9,"outputs":[{"output_type":"stream","name":"stdout","text":["lse_theo_bound_1_w_uniform_0.005773502691896258_s_phi_0.05_p_phi_0.8_delta_0.1.csv\n"]}]},{"cell_type":"code","source":["delta = 0.1\n","time_hor = 30000\n","\n","n_x = 6\n","n_u = 4\n","n_phi = 12\n","\n","sigma_u = 0.1\n","sigma_w = 0.001\n","w_max = 0.01\n","s_phi = 0.01\n","p_phi = 0.95\n","b_phi = 2\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":"ONTuAYfAI3l3"},"execution_count":null,"outputs":[]}],"metadata":{"colab":{"provenance":[{"file_id":"1Y0Ux1iq6vi7AfbndrgdcvChEUuSicb42","timestamp":1716925749762}],"gpuType":"T4","authorship_tag":"ABX9TyMN8Ulk4xblNailC+V8G4Fc"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"},"accelerator":"GPU"},"nbformat":4,"nbformat_minor":0}