Matlab code for quadcopter

Dependents:   combination combination

Files at this revision

API Documentation at this revision

Comitter:
Glaxys_finest1
Date:
Mon Nov 25 10:51:06 2019 +0000
Commit message:
hello1

Changed in this revision

LAAP.cpp Show annotated file Show diff for this revision Revisions of this file
LAAP.h Show annotated file Show diff for this revision Revisions of this file
rtwtypes.h Show annotated file Show diff for this revision Revisions of this file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/LAAP.cpp	Mon Nov 25 10:51:06 2019 +0000
@@ -0,0 +1,1113 @@
+//
+// File: LAAP.cpp
+//
+// Code generated for Simulink model 'LAAP'.
+//
+// Model version                  : 1.2
+// Simulink Coder version         : 9.1 (R2019a) 23-Nov-2018
+// C/C++ source code generated on : Mon Nov 18 17:57:49 2019
+//
+// Target selection: ert.tlc
+// Embedded hardware selection: ARM Compatible->ARM Cortex
+// Code generation objectives:
+//    1. Execution efficiency
+//    2. RAM efficiency
+// Validation result: Not run
+//
+#include "LAAP.h"
+
+// Model step function
+void LAAPModelClass::step()
+{
+  static const int8_T b[3] = { 0, 1, 0 };
+
+  static const real_T b_0[12] = { 0.0028, 0.003, 3.1623, 0.0012, 0.0012, 3.68,
+    1.6056, 1.6056, 1.0, 0.153, 0.153, 0.1 };
+
+  static const int8_T c[3] = { 0, 1, 0 };
+
+  static const real_T a[16] = { 0.25, 0.25, 0.25, 0.25, 0.0, 2.193, 0.0, -2.193,
+    -2.193, 0.0, 2.193, 0.0, 4.2591, -4.2591, 4.2591, -4.2591 };
+
+  int32_T r1;
+  int32_T i;
+  real_T Fdes_idx_2;
+  real_T Fdes_idx_1;
+  real_T Fdes_idx_0;
+  real_T rtb_TmpSignalConversionAtSFun_0;
+  real_T rtb_TmpSignalConversionAtSFun_1;
+  int32_T R_tmp;
+  int32_T b_I_tmp;
+  int32_T b_I_tmp_0;
+
+  // Outputs for Atomic SubSystem: '<Root>/Adaptive large angle controller'
+  // Delay: '<S1>/Delay1'
+  memcpy(&rtDW.Delay1[0], &rtDW.psy[0], 12U * sizeof(real_T));
+
+  // Outputs for Atomic SubSystem: '<S1>/quadcopter_dynamics_prediction'
+  // MATLAB Function: '<S3>/Euler equations of motion1 ' incorporates:
+  //   Constant: '<S1>/mass '
+  //   Delay: '<S1>/Delay'
+  //   Delay: '<S3>/Delay'
+  //   Delay: '<S3>/Delay1'
+
+  rtDW.b_I[0] = 0.01023564759;
+  rtDW.b_I[3] = 0.0;
+  rtDW.b_I[6] = 0.0;
+  rtDW.b_I[1] = 0.0;
+  rtDW.b_I[4] = 0.01023564759;
+  rtDW.b_I[7] = 0.0;
+  rtDW.b_I[2] = 0.0;
+  rtDW.b_I[5] = 0.0;
+  rtDW.b_I[8] = 0.02047129518;
+  rtDW.maxval = std::cos(rtDW.Delay1_DSTATE_l[2]);
+  rtDW.b_I_k[0] = rtDW.maxval;
+  rtDW.Add1_k = std::sin(rtDW.Delay1_DSTATE_l[2]);
+  rtDW.b_I_k[3] = -rtDW.Add1_k;
+  rtDW.b_I_k[6] = 0.0;
+  rtDW.b_I_k[1] = rtDW.Add1_k;
+  rtDW.b_I_k[4] = rtDW.maxval;
+  rtDW.b_I_k[7] = 0.0;
+  rtDW.b_I_k[2] = 0.0;
+  rtDW.d[0] = 1.0;
+  rtDW.b_I_k[5] = 0.0;
+  rtDW.d[3] = 0.0;
+  rtDW.b_I_k[8] = 1.0;
+  rtDW.d[6] = 0.0;
+  rtDW.d[1] = 0.0;
+  Fdes_idx_0 = std::cos(rtDW.Delay1_DSTATE_l[0]);
+  rtDW.d[4] = Fdes_idx_0;
+  Fdes_idx_1 = std::sin(rtDW.Delay1_DSTATE_l[0]);
+  rtDW.d[7] = -Fdes_idx_1;
+  rtDW.d[2] = 0.0;
+  rtDW.d[5] = Fdes_idx_1;
+  rtDW.d[8] = Fdes_idx_0;
+  rtDW.maxval = std::cos(rtDW.Delay1_DSTATE_l[1]);
+  rtDW.dv0[0] = rtDW.maxval;
+  rtDW.dv0[3] = 0.0;
+  rtDW.Add1_k = std::sin(rtDW.Delay1_DSTATE_l[1]);
+  rtDW.dv0[6] = rtDW.Add1_k;
+  for (r1 = 0; r1 < 3; r1++) {
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.R_c[R_tmp] = 0.0;
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i] * rtDW.b_I_k[r1];
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i + 1] * rtDW.b_I_k[r1 + 3];
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i + 2] * rtDW.b_I_k[r1 + 6];
+    }
+
+    rtDW.dv0[1 + 3 * r1] = b[r1];
+  }
+
+  rtDW.dv0[2] = -rtDW.Add1_k;
+  rtDW.dv0[5] = 0.0;
+  rtDW.dv0[8] = rtDW.maxval;
+  rtDW.w_dot[0] = 0.0;
+  rtDW.w_dot[1] = 0.0;
+  rtDW.w_dot[2] = rtDW.Delay_DSTATE[0];
+  rtDW.dv2[0] = 0.0;
+  rtDW.dv2[1] = 0.0;
+  rtDW.dv2[2] = -7.3575;
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.wb[r1] = 0.0;
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.b_I_k[R_tmp] = 0.0;
+      rtDW.b_I_k[R_tmp] += rtDW.dv0[3 * i] * rtDW.R_c[r1];
+      rtDW.b_I_k[R_tmp] += rtDW.dv0[3 * i + 1] * rtDW.R_c[r1 + 3];
+      rtDW.b_I_k[R_tmp] += rtDW.dv0[3 * i + 2] * rtDW.R_c[r1 + 6];
+      rtDW.wb[r1] += rtDW.b_I_k[R_tmp] * rtDW.w_dot[i];
+    }
+
+    rtDW.a_dotdot[r1] = (rtDW.dv2[r1] + rtDW.wb[r1]) * 1.3333333333333333;
+  }
+
+  rtDW.b_I_k[0] = rtDW.maxval;
+  rtDW.b_I_k[3] = 0.0;
+  rtDW.b_I_k[6] = -Fdes_idx_0 * rtDW.Add1_k;
+  rtDW.b_I_k[1] = 0.0;
+  rtDW.b_I_k[4] = 1.0;
+  rtDW.b_I_k[7] = Fdes_idx_1;
+  rtDW.b_I_k[2] = rtDW.Add1_k;
+  rtDW.b_I_k[5] = 0.0;
+  rtDW.b_I_k[8] = Fdes_idx_0 * rtDW.maxval;
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.wb[r1] = rtDW.b_I_k[r1 + 6] * rtDW.Delay_DSTATE_h[2] + (rtDW.b_I_k[r1 +
+      3] * rtDW.Delay_DSTATE_h[1] + rtDW.b_I_k[r1] * rtDW.Delay_DSTATE_h[0]);
+  }
+
+  rtDW.b_I_k[0] = 0.0;
+  rtDW.b_I_k[3] = -rtDW.wb[2];
+  rtDW.b_I_k[6] = rtDW.wb[1];
+  rtDW.b_I_k[1] = rtDW.wb[2];
+  rtDW.b_I_k[4] = 0.0;
+  rtDW.b_I_k[7] = -rtDW.wb[0];
+  rtDW.b_I_k[2] = -rtDW.wb[1];
+  rtDW.b_I_k[5] = rtDW.wb[0];
+  rtDW.b_I_k[8] = 0.0;
+  rtDW.w_dot[0] = rtDW.Delay_DSTATE[1];
+  rtDW.w_dot[1] = rtDW.Delay_DSTATE[2];
+  rtDW.w_dot[2] = rtDW.Delay_DSTATE[3];
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.dv2[r1] = 0.0;
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.R_c[R_tmp] = 0.0;
+      rtDW.R_c[R_tmp] += rtDW.b_I[3 * i] * rtDW.b_I_k[r1];
+      rtDW.R_c[R_tmp] += rtDW.b_I[3 * i + 1] * rtDW.b_I_k[r1 + 3];
+      rtDW.R_c[R_tmp] += rtDW.b_I[3 * i + 2] * rtDW.b_I_k[r1 + 6];
+      rtDW.dv2[r1] += rtDW.R_c[R_tmp] * rtDW.wb[i];
+    }
+
+    rtDW.Iw_dot[r1] = rtDW.w_dot[r1] - rtDW.dv2[r1];
+  }
+
+  rtDW.w_dot[1] = rtDW.Iw_dot[1] - rtDW.Iw_dot[0] * 0.0;
+  rtDW.w_dot[2] = (rtDW.Iw_dot[2] - rtDW.Iw_dot[0] * 0.0) - rtDW.w_dot[1] * 0.0;
+  rtDW.w_dot[2] /= 0.02047129518;
+  rtDW.w_dot[0] = rtDW.Iw_dot[0] - rtDW.w_dot[2] * 0.0;
+  rtDW.w_dot[1] -= rtDW.w_dot[2] * 0.0;
+  rtDW.w_dot[1] /= 0.01023564759;
+  rtDW.w_dot[0] -= rtDW.w_dot[1] * 0.0;
+  rtDW.w_dot[0] /= 0.01023564759;
+
+  // DiscreteIntegrator: '<S13>/Integrator'
+  for (r1 = 0; r1 < 6; r1++) {
+    if (rtDW.Integrator_PrevResetState != 0) {
+      rtDW.Integrator_DSTATE_ep[r1] = 0.0;
+      if (rtDW.Integrator_DSTATE_ep[r1] >= 10.0) {
+        rtDW.Integrator_DSTATE_ep[r1] = 10.0;
+      } else {
+        if (rtDW.Integrator_DSTATE_ep[r1] <= -10.0) {
+          rtDW.Integrator_DSTATE_ep[r1] = -10.0;
+        }
+      }
+    }
+
+    if (rtDW.Integrator_DSTATE_ep[r1] >= 10.0) {
+      rtDW.Integrator_DSTATE_ep[r1] = 10.0;
+    } else {
+      if (rtDW.Integrator_DSTATE_ep[r1] <= -10.0) {
+        rtDW.Integrator_DSTATE_ep[r1] = -10.0;
+      }
+    }
+
+    rtDW.Integrator[r1] = rtDW.Integrator_DSTATE_ep[r1];
+  }
+
+  // DiscreteIntegrator: '<S14>/Integrator' incorporates:
+  //   Inport: '<Root>/phi'
+  //   Inport: '<Root>/psi'
+  //   Inport: '<Root>/theta'
+  //   Inport: '<Root>/x'
+  //   Inport: '<Root>/y'
+  //   Inport: '<Root>/z'
+
+  if (rtDW.Integrator_IC_LOADING != 0) {
+    rtDW.Integrator_DSTATE_k[0] = rtU.x;
+    rtDW.Integrator_DSTATE_k[1] = rtU.y;
+    rtDW.Integrator_DSTATE_k[2] = rtU.z;
+    rtDW.Integrator_DSTATE_k[3] = rtU.phi;
+    rtDW.Integrator_DSTATE_k[4] = rtU.theta;
+    rtDW.Integrator_DSTATE_k[5] = rtU.psi;
+    for (r1 = 0; r1 < 6; r1++) {
+      if (rtDW.Integrator_DSTATE_k[r1] >= 10.0) {
+        rtDW.Integrator_DSTATE_k[r1] = 10.0;
+      } else {
+        if (rtDW.Integrator_DSTATE_k[r1] <= -10.0) {
+          rtDW.Integrator_DSTATE_k[r1] = -10.0;
+        }
+      }
+    }
+  }
+
+  if (rtDW.Integrator_PrevResetState_n != 0) {
+    rtDW.Integrator_DSTATE_k[0] = rtU.x;
+    rtDW.Integrator_DSTATE_k[1] = rtU.y;
+    rtDW.Integrator_DSTATE_k[2] = rtU.z;
+    rtDW.Integrator_DSTATE_k[3] = rtU.phi;
+    rtDW.Integrator_DSTATE_k[4] = rtU.theta;
+    rtDW.Integrator_DSTATE_k[5] = rtU.psi;
+    for (r1 = 0; r1 < 6; r1++) {
+      if (rtDW.Integrator_DSTATE_k[r1] >= 10.0) {
+        rtDW.Integrator_DSTATE_k[r1] = 10.0;
+      } else {
+        if (rtDW.Integrator_DSTATE_k[r1] <= -10.0) {
+          rtDW.Integrator_DSTATE_k[r1] = -10.0;
+        }
+      }
+    }
+  }
+
+  for (r1 = 0; r1 < 6; r1++) {
+    if (rtDW.Integrator_DSTATE_k[r1] >= 10.0) {
+      rtDW.Integrator_DSTATE_k[r1] = 10.0;
+    } else {
+      if (rtDW.Integrator_DSTATE_k[r1] <= -10.0) {
+        rtDW.Integrator_DSTATE_k[r1] = -10.0;
+      }
+    }
+
+    rtDW.Integrator_p[r1] = rtDW.Integrator_DSTATE_k[r1];
+  }
+
+  // Update for Delay: '<S3>/Delay' incorporates:
+  //   DiscreteIntegrator: '<S13>/Integrator'
+
+  rtDW.Delay_DSTATE_h[0] = rtDW.Integrator_DSTATE_ep[3];
+
+  // Update for Delay: '<S3>/Delay1' incorporates:
+  //   DiscreteIntegrator: '<S14>/Integrator'
+
+  rtDW.Delay1_DSTATE_l[0] = rtDW.Integrator_DSTATE_k[3];
+
+  // Update for Delay: '<S3>/Delay' incorporates:
+  //   DiscreteIntegrator: '<S13>/Integrator'
+
+  rtDW.Delay_DSTATE_h[1] = rtDW.Integrator_DSTATE_ep[4];
+
+  // Update for Delay: '<S3>/Delay1' incorporates:
+  //   DiscreteIntegrator: '<S14>/Integrator'
+
+  rtDW.Delay1_DSTATE_l[1] = rtDW.Integrator_DSTATE_k[4];
+
+  // Update for Delay: '<S3>/Delay' incorporates:
+  //   DiscreteIntegrator: '<S13>/Integrator'
+
+  rtDW.Delay_DSTATE_h[2] = rtDW.Integrator_DSTATE_ep[5];
+
+  // Update for Delay: '<S3>/Delay1' incorporates:
+  //   DiscreteIntegrator: '<S14>/Integrator'
+
+  rtDW.Delay1_DSTATE_l[2] = rtDW.Integrator_DSTATE_k[5];
+
+  // Update for DiscreteIntegrator: '<S13>/Integrator' incorporates:
+  //   MATLAB Function: '<S3>/Euler equations of motion1 '
+
+  rtDW.dv1[0] = 0.0001 * rtDW.a_dotdot[0];
+  rtDW.dv1[1] = 0.0001 * rtDW.a_dotdot[1];
+  rtDW.dv1[2] = 0.0001 * rtDW.a_dotdot[2];
+  rtDW.dv1[3] = 0.0001 * rtDW.w_dot[0];
+  rtDW.dv1[4] = 0.0001 * rtDW.w_dot[1];
+  rtDW.dv1[5] = 0.0001 * rtDW.w_dot[2];
+  rtDW.Integrator_PrevResetState = 0;
+
+  // Update for DiscreteIntegrator: '<S14>/Integrator'
+  rtDW.Integrator_IC_LOADING = 0U;
+  for (r1 = 0; r1 < 6; r1++) {
+    // Update for DiscreteIntegrator: '<S13>/Integrator'
+    rtDW.Integrator_DSTATE_ep[r1] += rtDW.dv1[r1];
+    if (rtDW.Integrator_DSTATE_ep[r1] >= 10.0) {
+      rtDW.Integrator_DSTATE_ep[r1] = 10.0;
+    } else {
+      if (rtDW.Integrator_DSTATE_ep[r1] <= -10.0) {
+        rtDW.Integrator_DSTATE_ep[r1] = -10.0;
+      }
+    }
+
+    // Update for DiscreteIntegrator: '<S14>/Integrator'
+    rtDW.Integrator_DSTATE_k[r1] += 0.0001 * rtDW.Integrator[r1];
+    if (rtDW.Integrator_DSTATE_k[r1] >= 10.0) {
+      rtDW.Integrator_DSTATE_k[r1] = 10.0;
+    } else {
+      if (rtDW.Integrator_DSTATE_k[r1] <= -10.0) {
+        rtDW.Integrator_DSTATE_k[r1] = -10.0;
+      }
+    }
+  }
+
+  // Update for DiscreteIntegrator: '<S14>/Integrator'
+  rtDW.Integrator_PrevResetState_n = 0;
+
+  // End of Outputs for SubSystem: '<S1>/quadcopter_dynamics_prediction'
+
+  // Outputs for Atomic SubSystem: '<S1>/largepaa'
+  // Outputs for Enabled SubSystem: '<S2>/large_controller' incorporates:
+  //   EnablePort: '<S5>/Enable'
+
+  // MATLAB Function: '<S5>/MATLAB Function3' incorporates:
+  //   Constant: '<S2>/mass 1'
+  //   Delay: '<S2>/Delay'
+  //   Inport: '<Root>/angles'
+  //   Inport: '<Root>/r'
+  //   Inport: '<Root>/rdot'
+  //   Inport: '<Root>/wb'
+  //   Inport: '<Root>/x'
+  //   Inport: '<Root>/y'
+  //   Inport: '<Root>/z'
+
+  rtDW.a_dotdot[0] = rtU.r[0] - rtU.x;
+  rtDW.a_dotdot[1] = rtU.r[1] - rtU.y;
+  rtDW.a_dotdot[2] = rtU.r[2] - rtU.z;
+  Fdes_idx_0 = -rtDW.Delay_DSTATE_hf[0] * rtDW.a_dotdot[0] -
+    rtDW.Delay_DSTATE_hf[3] * rtU.rdot[0];
+  rtDW.Iw_dot[0] = rtU.rdot[0];
+  rtDW.w_dot[0] = 0.0;
+  Fdes_idx_1 = -rtDW.Delay_DSTATE_hf[1] * rtDW.a_dotdot[1] -
+    rtDW.Delay_DSTATE_hf[4] * rtU.rdot[1];
+  rtDW.Iw_dot[1] = rtU.rdot[1];
+  rtDW.w_dot[1] = 0.0;
+  Fdes_idx_2 = ((-rtDW.Delay_DSTATE_hf[2] * rtDW.a_dotdot[2] -
+                 rtDW.Delay_DSTATE_hf[5] * rtU.rdot[2]) - 7.3575) + 7.3575;
+  rtDW.Iw_dot[2] = rtU.rdot[2];
+  rtDW.w_dot[2] = 1.0;
+  rtDW.maxval = std::sqrt((Fdes_idx_0 * Fdes_idx_0 + Fdes_idx_1 * Fdes_idx_1) +
+    Fdes_idx_2 * Fdes_idx_2);
+  if (rtDW.maxval == 0.0) {
+    rtDW.maxval = 1.0;
+  }
+
+  rtDW.maxval = 1.0 / rtDW.maxval;
+  rtDW.Zbdes[0] = rtDW.maxval * Fdes_idx_0;
+  rtDW.Zbdes[1] = rtDW.maxval * Fdes_idx_1;
+  rtDW.Zbdes[2] = rtDW.maxval * Fdes_idx_2;
+  rtDW.crossZX[0] = rtDW.Zbdes[1] * 0.0 - rtDW.Zbdes[2] * 0.0;
+  rtDW.crossZX[1] = rtDW.Zbdes[2] - rtDW.Zbdes[0] * 0.0;
+  rtDW.crossZX[2] = rtDW.Zbdes[0] * 0.0 - rtDW.Zbdes[1];
+  rtDW.maxval = std::sqrt((rtDW.crossZX[0] * rtDW.crossZX[0] + rtDW.crossZX[1] *
+    rtDW.crossZX[1]) + rtDW.crossZX[2] * rtDW.crossZX[2]);
+  if (rtDW.maxval == 0.0) {
+    rtDW.maxval = 1.0;
+  }
+
+  rtDW.maxval = 1.0 / rtDW.maxval;
+  rtDW.Add1_k = rtDW.maxval * rtDW.crossZX[0];
+  rtDW.b_I[3] = rtDW.Add1_k;
+  rtDW.b_I[6] = rtDW.Zbdes[0];
+  rtDW.crossZX[0] = rtDW.Add1_k;
+  rtDW.Add1_k = rtDW.maxval * rtDW.crossZX[1];
+  rtDW.b_I[4] = rtDW.Add1_k;
+  rtDW.b_I[7] = rtDW.Zbdes[1];
+  rtDW.crossZX[1] = rtDW.Add1_k;
+  rtDW.Add1_k = rtDW.maxval * rtDW.crossZX[2];
+  rtDW.b_I[5] = rtDW.Add1_k;
+  rtDW.b_I[8] = rtDW.Zbdes[2];
+  rtDW.b_I[0] = rtDW.crossZX[1] * rtDW.Zbdes[2] - rtDW.Add1_k * rtDW.Zbdes[1];
+  rtDW.b_I[1] = rtDW.Add1_k * rtDW.Zbdes[0] - rtDW.crossZX[0] * rtDW.Zbdes[2];
+  rtDW.b_I[2] = rtDW.crossZX[0] * rtDW.Zbdes[1] - rtDW.crossZX[1] * rtDW.Zbdes[0];
+  rtDW.maxval = std::cos(rtU.angles[2]);
+  rtDW.b_I_k[0] = rtDW.maxval;
+  rtDW.Add1_k = std::sin(rtU.angles[2]);
+  rtDW.b_I_k[3] = -rtDW.Add1_k;
+  rtDW.b_I_k[6] = 0.0;
+  rtDW.b_I_k[1] = rtDW.Add1_k;
+  rtDW.b_I_k[4] = rtDW.maxval;
+  rtDW.b_I_k[7] = 0.0;
+  rtDW.b_I_k[2] = 0.0;
+  rtDW.d[0] = 1.0;
+  rtDW.b_I_k[5] = 0.0;
+  rtDW.d[3] = 0.0;
+  rtDW.b_I_k[8] = 1.0;
+  rtDW.d[6] = 0.0;
+  rtDW.d[1] = 0.0;
+  rtDW.maxval = std::cos(rtU.angles[0]);
+  rtDW.d[4] = rtDW.maxval;
+  rtDW.Add1_k = std::sin(rtU.angles[0]);
+  rtDW.d[7] = -rtDW.Add1_k;
+  rtDW.d[2] = 0.0;
+  rtDW.d[5] = rtDW.Add1_k;
+  rtDW.d[8] = rtDW.maxval;
+  rtDW.maxval = std::cos(rtU.angles[1]);
+  rtDW.dv0[0] = rtDW.maxval;
+  rtDW.dv0[3] = 0.0;
+  rtDW.Add1_k = std::sin(rtU.angles[1]);
+  rtDW.dv0[6] = rtDW.Add1_k;
+  for (r1 = 0; r1 < 3; r1++) {
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.R_c[R_tmp] = 0.0;
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i] * rtDW.b_I_k[r1];
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i + 1] * rtDW.b_I_k[r1 + 3];
+      rtDW.R_c[R_tmp] += rtDW.d[3 * i + 2] * rtDW.b_I_k[r1 + 6];
+    }
+
+    rtDW.dv0[1 + 3 * r1] = c[r1];
+  }
+
+  rtDW.dv0[2] = -rtDW.Add1_k;
+  rtDW.dv0[5] = 0.0;
+  rtDW.dv0[8] = rtDW.maxval;
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.Zbdes[r1] = 0.0;
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.R[R_tmp] = 0.0;
+      rtDW.R[R_tmp] += rtDW.dv0[3 * i] * rtDW.R_c[r1];
+      rtDW.R[R_tmp] += rtDW.dv0[3 * i + 1] * rtDW.R_c[r1 + 3];
+      rtDW.R[R_tmp] += rtDW.dv0[3 * i + 2] * rtDW.R_c[r1 + 6];
+      rtDW.Zbdes[r1] += rtDW.R[R_tmp] * rtDW.w_dot[i];
+    }
+  }
+
+  for (r1 = 0; r1 < 3; r1++) {
+    for (i = 0; i < 3; i++) {
+      R_tmp = r1 + 3 * i;
+      rtDW.b_I_k[R_tmp] = 0.0;
+      rtDW.R_c[R_tmp] = 0.0;
+      rtDW.b_I_k[R_tmp] += rtDW.b_I[3 * r1] * rtDW.R[3 * i];
+      rtDW.R_c[R_tmp] += rtDW.R[3 * r1] * rtDW.b_I[3 * i];
+      b_I_tmp = 3 * r1 + 1;
+      b_I_tmp_0 = 3 * i + 1;
+      rtDW.b_I_k[R_tmp] += rtDW.b_I[b_I_tmp] * rtDW.R[b_I_tmp_0];
+      rtDW.R_c[R_tmp] += rtDW.R[b_I_tmp] * rtDW.b_I[b_I_tmp_0];
+      b_I_tmp = 3 * r1 + 2;
+      b_I_tmp_0 = 3 * i + 2;
+      rtDW.b_I_k[R_tmp] += rtDW.b_I[b_I_tmp] * rtDW.R[b_I_tmp_0];
+      rtDW.R_c[R_tmp] += rtDW.R[b_I_tmp] * rtDW.b_I[b_I_tmp_0];
+    }
+  }
+
+  for (r1 = 0; r1 < 9; r1++) {
+    rtDW.b_I[r1] = (rtDW.b_I_k[r1] - rtDW.R_c[r1]) * 0.5;
+  }
+
+  rtDW.Xc[0] = rtDW.b_I[5];
+  rtDW.Xc[1] = rtDW.b_I[6];
+  rtDW.Xc[2] = rtDW.b_I[1];
+  rtDW.b_I_k[0] = -rtDW.Delay_DSTATE_hf[6];
+  rtDW.b_I_k[3] = -0.0;
+  rtDW.b_I_k[6] = -0.0;
+  rtDW.b_I_k[1] = -0.0;
+  rtDW.b_I_k[4] = -rtDW.Delay_DSTATE_hf[7];
+  rtDW.b_I_k[7] = -0.0;
+  rtDW.b_I_k[2] = -0.0;
+  rtDW.b_I_k[5] = -0.0;
+  rtDW.b_I_k[8] = -rtDW.Delay_DSTATE_hf[8];
+  rtDW.R_c[0] = rtDW.Delay_DSTATE_hf[9];
+  rtDW.R_c[3] = 0.0;
+  rtDW.R_c[6] = 0.0;
+  rtDW.R_c[1] = 0.0;
+  rtDW.R_c[4] = rtDW.Delay_DSTATE_hf[10];
+  rtDW.R_c[7] = 0.0;
+  rtDW.R_c[2] = 0.0;
+  rtDW.R_c[5] = 0.0;
+  rtDW.R_c[8] = rtDW.Delay_DSTATE_hf[11];
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.psy[r1] = rtDW.a_dotdot[r1];
+    rtDW.psy[r1 + 3] = rtDW.Iw_dot[r1];
+    rtDW.psy[r1 + 6] = rtDW.Xc[r1];
+    rtDW.psy[r1 + 9] = rtU.wb[r1];
+    rtDW.crossZX[r1] = rtU.wb[r1];
+    rtDW.w_dot[r1] = rtDW.b_I_k[r1 + 6] * rtDW.Xc[2] + (rtDW.b_I_k[r1 + 3] *
+      rtDW.Xc[1] + rtDW.b_I_k[r1] * rtDW.Xc[0]);
+  }
+
+  rtDW.A[0] = ((Fdes_idx_0 * rtDW.Zbdes[0] + Fdes_idx_1 * rtDW.Zbdes[1]) +
+               Fdes_idx_2 * rtDW.Zbdes[2]) + 7.3575;
+  for (r1 = 0; r1 < 3; r1++) {
+    rtDW.A[r1 + 1] = rtDW.w_dot[r1] - (rtDW.R_c[r1 + 6] * rtDW.crossZX[2] +
+      (rtDW.R_c[r1 + 3] * rtDW.crossZX[1] + rtDW.R_c[r1] * rtDW.crossZX[0]));
+  }
+
+  // End of MATLAB Function: '<S5>/MATLAB Function3'
+
+  // Saturate: '<S5>/Saturation'
+  if (rtDW.A[0] > 27.0) {
+    rtDW.maxval = 27.0;
+  } else if (rtDW.A[0] < 0.0) {
+    rtDW.maxval = 0.0;
+  } else {
+    rtDW.maxval = rtDW.A[0];
+  }
+
+  if (rtDW.A[1] > 1.6) {
+    Fdes_idx_0 = 1.6;
+  } else if (rtDW.A[1] < -1.6) {
+    Fdes_idx_0 = -1.6;
+  } else {
+    Fdes_idx_0 = rtDW.A[1];
+  }
+
+  if (rtDW.A[2] > 1.6) {
+    Fdes_idx_1 = 1.6;
+  } else if (rtDW.A[2] < -1.6) {
+    Fdes_idx_1 = -1.6;
+  } else {
+    Fdes_idx_1 = rtDW.A[2];
+  }
+
+  if (rtDW.A[3] > 0.6) {
+    Fdes_idx_2 = 0.6;
+  } else if (rtDW.A[3] < -0.6) {
+    Fdes_idx_2 = -0.6;
+  } else {
+    Fdes_idx_2 = rtDW.A[3];
+  }
+
+  // End of Saturate: '<S5>/Saturation'
+
+  // MATLAB Function: '<S5>/MATLAB Function1'
+  for (r1 = 0; r1 < 4; r1++) {
+    rtDW.Add1_k = a[r1 + 12] * Fdes_idx_2 + (a[r1 + 8] * Fdes_idx_1 + (a[r1 + 4]
+      * Fdes_idx_0 + a[r1] * rtDW.maxval));
+    rtDW.A[r1] = rtDW.Add1_k;
+  }
+
+  if (rtDW.A[0] < 0.0) {
+    rtDW.A[0] = 0.0;
+  }
+
+  if (rtDW.A[1] < 0.0) {
+    rtDW.A[1] = 0.0;
+  }
+
+  if (rtDW.A[2] < 0.0) {
+    rtDW.A[2] = 0.0;
+  }
+
+  if (rtDW.A[3] < 0.0) {
+    rtDW.A[3] = 0.0;
+  }
+
+  rtDW.duty[0] = (3485.3574033876184 * std::sqrt(rtDW.A[0]) * 0.1865 + 768.0) /
+    20000.0;
+  rtDW.duty[1] = (3485.3574033876184 * std::sqrt(rtDW.A[1]) * 0.1865 + 768.0) /
+    20000.0;
+  rtDW.duty[2] = (3485.3574033876184 * std::sqrt(rtDW.A[2]) * 0.1865 + 768.0) /
+    20000.0;
+  rtDW.duty[3] = (3485.3574033876184 * std::sqrt(rtDW.A[3]) * 0.1865 + 768.0) /
+    20000.0;
+
+  // End of MATLAB Function: '<S5>/MATLAB Function1'
+  // End of Outputs for SubSystem: '<S2>/large_controller'
+
+  // MATLAB Function: '<S6>/MATLAB Function3'
+  rtDW.F[0] = 0.001;
+  rtDW.F[12] = 0.0;
+  rtDW.F[24] = 0.0;
+  rtDW.F[36] = 0.0;
+  rtDW.F[48] = 0.0;
+  rtDW.F[60] = 0.0;
+  rtDW.F[72] = 0.0;
+  rtDW.F[84] = 0.0;
+  rtDW.F[96] = 0.0;
+  rtDW.F[108] = 0.0;
+  rtDW.F[120] = 0.0;
+  rtDW.F[132] = 0.0;
+  rtDW.F[1] = 0.0;
+  rtDW.F[13] = 0.001;
+  rtDW.F[25] = 0.0;
+  rtDW.F[37] = 0.0;
+  rtDW.F[49] = 0.0;
+  rtDW.F[61] = 0.0;
+  rtDW.F[73] = 0.0;
+  rtDW.F[85] = 0.0;
+  rtDW.F[97] = 0.0;
+  rtDW.F[109] = 0.0;
+  rtDW.F[121] = 0.0;
+  rtDW.F[133] = 0.0;
+  rtDW.F[2] = 0.0;
+  rtDW.F[14] = 0.0;
+  rtDW.F[26] = 0.001;
+  rtDW.F[38] = 0.0;
+  rtDW.F[50] = 0.0;
+  rtDW.F[62] = 0.0;
+  rtDW.F[74] = 0.0;
+  rtDW.F[86] = 0.0;
+  rtDW.F[98] = 0.0;
+  rtDW.F[110] = 0.0;
+  rtDW.F[122] = 0.0;
+  rtDW.F[134] = 0.0;
+  rtDW.F[3] = 0.0;
+  rtDW.F[15] = 0.0;
+  rtDW.F[27] = 0.0;
+  rtDW.F[39] = 0.001;
+  rtDW.F[51] = 0.0;
+  rtDW.F[63] = 0.0;
+  rtDW.F[75] = 0.0;
+  rtDW.F[87] = 0.0;
+  rtDW.F[99] = 0.0;
+  rtDW.F[111] = 0.0;
+  rtDW.F[123] = 0.0;
+  rtDW.F[135] = 0.0;
+  rtDW.F[4] = 0.0;
+  rtDW.F[16] = 0.0;
+  rtDW.F[28] = 0.0;
+  rtDW.F[40] = 0.0;
+  rtDW.F[52] = 0.001;
+  rtDW.F[64] = 0.0;
+  rtDW.F[76] = 0.0;
+  rtDW.F[88] = 0.0;
+  rtDW.F[100] = 0.0;
+  rtDW.F[112] = 0.0;
+  rtDW.F[124] = 0.0;
+  rtDW.F[136] = 0.0;
+  rtDW.F[5] = 0.0;
+  rtDW.F[17] = 0.0;
+  rtDW.F[29] = 0.0;
+  rtDW.F[41] = 0.0;
+  rtDW.F[53] = 0.0;
+  rtDW.F[65] = 0.001;
+  rtDW.F[77] = 0.0;
+  rtDW.F[89] = 0.0;
+  rtDW.F[101] = 0.0;
+  rtDW.F[113] = 0.0;
+  rtDW.F[125] = 0.0;
+  rtDW.F[137] = 0.0;
+  rtDW.F[6] = 0.0;
+  rtDW.F[18] = 0.0;
+  rtDW.F[30] = 0.0;
+  rtDW.F[42] = 0.0;
+  rtDW.F[54] = 0.0;
+  rtDW.F[66] = 0.0;
+  rtDW.F[78] = 0.0001;
+  rtDW.F[90] = 0.0;
+  rtDW.F[102] = 0.0;
+  rtDW.F[114] = 0.0;
+  rtDW.F[126] = 0.0;
+  rtDW.F[138] = 0.0;
+  rtDW.F[7] = 0.0;
+  rtDW.F[19] = 0.0;
+  rtDW.F[31] = 0.0;
+  rtDW.F[43] = 0.0;
+  rtDW.F[55] = 0.0;
+  rtDW.F[67] = 0.0;
+  rtDW.F[79] = 0.0;
+  rtDW.F[91] = 0.0001;
+  rtDW.F[103] = 0.0;
+  rtDW.F[115] = 0.0;
+  rtDW.F[127] = 0.0;
+  rtDW.F[139] = 0.0;
+  rtDW.F[8] = 0.0;
+  rtDW.F[20] = 0.0;
+  rtDW.F[32] = 0.0;
+  rtDW.F[44] = 0.0;
+  rtDW.F[56] = 0.0;
+  rtDW.F[68] = 0.0;
+  rtDW.F[80] = 0.0;
+  rtDW.F[92] = 0.0;
+  rtDW.F[104] = 0.0001;
+  rtDW.F[116] = 0.0;
+  rtDW.F[128] = 0.0;
+  rtDW.F[140] = 0.0;
+  rtDW.F[9] = 0.0;
+  rtDW.F[21] = 0.0;
+  rtDW.F[33] = 0.0;
+  rtDW.F[45] = 0.0;
+  rtDW.F[57] = 0.0;
+  rtDW.F[69] = 0.0;
+  rtDW.F[81] = 0.0;
+  rtDW.F[93] = 0.0;
+  rtDW.F[105] = 0.0;
+  rtDW.F[117] = 0.0001;
+  rtDW.F[129] = 0.0;
+  rtDW.F[141] = 0.0;
+  rtDW.F[10] = 0.0;
+  rtDW.F[22] = 0.0;
+  rtDW.F[34] = 0.0;
+  rtDW.F[46] = 0.0;
+  rtDW.F[58] = 0.0;
+  rtDW.F[70] = 0.0;
+  rtDW.F[82] = 0.0;
+  rtDW.F[94] = 0.0;
+  rtDW.F[106] = 0.0;
+  rtDW.F[118] = 0.0;
+  rtDW.F[130] = 0.0001;
+  rtDW.F[142] = 0.0;
+  rtDW.F[11] = 0.0;
+  rtDW.F[23] = 0.0;
+  rtDW.F[35] = 0.0;
+  rtDW.F[47] = 0.0;
+  rtDW.F[59] = 0.0;
+  rtDW.F[71] = 0.0;
+  rtDW.F[83] = 0.0;
+  rtDW.F[95] = 0.0;
+  rtDW.F[107] = 0.0;
+  rtDW.F[119] = 0.0;
+  rtDW.F[131] = 0.0;
+  rtDW.F[143] = 0.0001;
+  rtDW.maxval = 0.0;
+  for (r1 = 0; r1 < 12; r1++) {
+    rtDW.rtb_Delay1_m[r1] = 0.0;
+    for (i = 0; i < 12; i++) {
+      rtDW.rtb_Delay1_m[r1] += rtDW.F[12 * r1 + i] * rtDW.Delay1[i];
+    }
+
+    rtDW.maxval += rtDW.rtb_Delay1_m[r1] * rtDW.Delay1[r1];
+  }
+
+  // SignalConversion: '<S9>/TmpSignal ConversionAt SFunction Inport2' incorporates:
+  //   Inport: '<Root>/angles'
+  //   Inport: '<Root>/r'
+  //   Inport: '<Root>/rdot'
+  //   Inport: '<Root>/wb'
+  //   MATLAB Function: '<S6>/MATLAB Function3'
+  //   Sum: '<S6>/Add1'
+  //   Sum: '<S6>/Add2'
+  //   Sum: '<S6>/Add3'
+  //   Sum: '<S6>/Add4'
+
+  rtDW.rtb_Delay1_m[0] = rtU.r[0] - rtDW.Integrator_p[0];
+  rtDW.rtb_Delay1_m[3] = rtU.rdot[0] - rtDW.Integrator[0];
+  rtDW.rtb_Delay1_m[6] = rtU.angles[0] - rtDW.Integrator_p[3];
+  rtDW.rtb_Delay1_m[9] = rtU.wb[0] - rtDW.wb[0];
+  rtDW.rtb_Delay1_m[1] = rtU.r[1] - rtDW.Integrator_p[1];
+  rtDW.rtb_Delay1_m[4] = rtU.rdot[1] - rtDW.Integrator[1];
+  rtDW.rtb_Delay1_m[7] = rtU.angles[1] - rtDW.Integrator_p[4];
+  rtDW.rtb_Delay1_m[10] = rtU.wb[1] - rtDW.wb[1];
+  rtDW.rtb_Delay1_m[2] = rtU.r[2] - rtDW.Integrator_p[2];
+  rtDW.rtb_Delay1_m[5] = rtU.rdot[2] - rtDW.Integrator[2];
+  rtDW.rtb_Delay1_m[8] = rtU.angles[2] - rtDW.Integrator_p[5];
+  rtDW.rtb_Delay1_m[11] = rtU.wb[2] - rtDW.wb[2];
+  for (r1 = 0; r1 < 12; r1++) {
+    // MATLAB Function: '<S6>/MATLAB Function3'
+    rtDW.F_c[r1] = 0.0;
+    for (i = 0; i < 12; i++) {
+      rtDW.F_c[r1] += rtDW.F[12 * i + r1] * rtDW.Delay1[i];
+    }
+
+    // Update for Delay: '<S2>/Delay' incorporates:
+    //   MATLAB Function: '<S6>/MATLAB Function3'
+    //   SignalConversion: '<S9>/TmpSignal ConversionAt SFunction Inport2'
+
+    rtDW.Delay_DSTATE_hf[r1] = rtDW.F_c[r1] * rtDW.rtb_Delay1_m[r1] / (1.0 +
+      rtDW.maxval) + b_0[r1];
+  }
+
+  // End of Outputs for SubSystem: '<S1>/largepaa'
+
+  // Outputs for Atomic SubSystem: '<S1>/small_angle_control'
+  // Sum: '<S22>/Add1' incorporates:
+  //   Inport: '<Root>/x'
+
+  rtDW.maxval = rtU.x - rtDW.Integrator_p[0];
+
+  // Gain: '<S144>/Filter Coefficient' incorporates:
+  //   DiscreteIntegrator: '<S136>/Filter'
+  //   Gain: '<S135>/Derivative Gain'
+  //   Sum: '<S136>/SumD'
+
+  Fdes_idx_0 = (1.68326013623818 * rtDW.maxval - rtDW.Filter_DSTATE) *
+    206.264558996617;
+
+  // Sum: '<S22>/Add2' incorporates:
+  //   Inport: '<Root>/y'
+
+  Fdes_idx_1 = rtU.y - rtDW.Integrator_p[1];
+
+  // Gain: '<S276>/Filter Coefficient' incorporates:
+  //   DiscreteIntegrator: '<S268>/Filter'
+  //   Gain: '<S267>/Derivative Gain'
+  //   Sum: '<S268>/SumD'
+
+  Fdes_idx_2 = (1.68326013623818 * Fdes_idx_1 - rtDW.Filter_DSTATE_k) *
+    206.264558996617;
+
+  // SignalConversion: '<S21>/TmpSignal ConversionAt SFunction Inport1' incorporates:
+  //   DiscreteIntegrator: '<S141>/Integrator'
+  //   DiscreteIntegrator: '<S273>/Integrator'
+  //   Gain: '<S146>/Proportional Gain'
+  //   Gain: '<S278>/Proportional Gain'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+  //   Sum: '<S150>/Sum'
+  //   Sum: '<S282>/Sum'
+
+  rtb_TmpSignalConversionAtSFun_1 = (0.576051138105677 * rtDW.maxval +
+    rtDW.Integrator_DSTATE) + Fdes_idx_0;
+  rtb_TmpSignalConversionAtSFun_0 = (0.576051138105677 * Fdes_idx_1 +
+    rtDW.Integrator_DSTATE_a) + Fdes_idx_2;
+
+  // Sum: '<S23>/Add1' incorporates:
+  //   Constant: '<S4>/Constant'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+
+  rtDW.Add1_k = (rtb_TmpSignalConversionAtSFun_1 * 0.0 -
+                 rtb_TmpSignalConversionAtSFun_0) * 0.1019367991845056 -
+    rtDW.Integrator_p[3];
+
+  // Gain: '<S188>/Filter Coefficient' incorporates:
+  //   DiscreteIntegrator: '<S180>/Filter'
+  //   Gain: '<S179>/Derivative Gain'
+  //   Sum: '<S180>/SumD'
+
+  rtDW.FilterCoefficient_a = (0.171115754916436 * rtDW.Add1_k -
+    rtDW.Filter_DSTATE_m) * 176.087006843524;
+
+  // Sum: '<S23>/Add2' incorporates:
+  //   Constant: '<S4>/Constant'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+
+  rtb_TmpSignalConversionAtSFun_1 = (rtb_TmpSignalConversionAtSFun_0 * 0.0 +
+    rtb_TmpSignalConversionAtSFun_1) * 0.1019367991845056 - rtDW.Integrator_p[4];
+
+  // Gain: '<S56>/Filter Coefficient' incorporates:
+  //   DiscreteIntegrator: '<S48>/Filter'
+  //   Gain: '<S47>/Derivative Gain'
+  //   Sum: '<S48>/SumD'
+
+  rtb_TmpSignalConversionAtSFun_0 = (0.171115754916436 *
+    rtb_TmpSignalConversionAtSFun_1 - rtDW.Filter_DSTATE_l) * 176.087006843524;
+
+  // Gain: '<S100>/Filter Coefficient' incorporates:
+  //   Constant: '<S4>/Constant'
+  //   DiscreteIntegrator: '<S92>/Filter'
+  //   Gain: '<S91>/Derivative Gain'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+  //   Sum: '<S23>/Add3'
+  //   Sum: '<S92>/SumD'
+
+  rtDW.FilterCoefficient_k = ((0.0 - rtDW.Integrator_p[5]) * 0.0490884878345462
+    - rtDW.Filter_DSTATE_lo) * 270.43836739932;
+
+  // SignalConversion: '<S4>/ConcatBufferAtVector ConcatenateIn2' incorporates:
+  //   Constant: '<S4>/Constant'
+  //   Delay: '<S1>/Delay'
+  //   DiscreteIntegrator: '<S185>/Integrator'
+  //   DiscreteIntegrator: '<S53>/Integrator'
+  //   DiscreteIntegrator: '<S97>/Integrator'
+  //   Gain: '<S102>/Proportional Gain'
+  //   Gain: '<S190>/Proportional Gain'
+  //   Gain: '<S58>/Proportional Gain'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+  //   Sum: '<S106>/Sum'
+  //   Sum: '<S194>/Sum'
+  //   Sum: '<S23>/Add3'
+  //   Sum: '<S62>/Sum'
+
+  rtDW.Delay_DSTATE[1] = (0.421511657975665 * rtDW.Add1_k +
+    rtDW.Integrator_DSTATE_m) + rtDW.FilterCoefficient_a;
+  rtDW.Delay_DSTATE[2] = (0.421511657975665 * rtb_TmpSignalConversionAtSFun_1 +
+    rtDW.Integrator_DSTATE_e) + rtb_TmpSignalConversionAtSFun_0;
+  rtDW.Delay_DSTATE[3] = ((0.0 - rtDW.Integrator_p[5]) * 0.00309186213155581 +
+    rtDW.Integrator_DSTATE_o) + rtDW.FilterCoefficient_k;
+
+  // Sum: '<S22>/Add3' incorporates:
+  //   Inport: '<Root>/z'
+
+  rtDW.Add3_a = rtU.z - rtDW.Integrator_p[2];
+
+  // Gain: '<S232>/Filter Coefficient' incorporates:
+  //   DiscreteIntegrator: '<S224>/Filter'
+  //   Gain: '<S223>/Derivative Gain'
+  //   Sum: '<S224>/SumD'
+
+  rtDW.FilterCoefficient_i = (1.46547031640698 * rtDW.Add3_a -
+    rtDW.Filter_DSTATE_n) * 19.9677854964375;
+
+  // Sum: '<S4>/Add' incorporates:
+  //   Delay: '<S1>/Delay'
+  //   DiscreteIntegrator: '<S229>/Integrator'
+  //   Gain: '<S234>/Proportional Gain'
+  //   Sum: '<S238>/Sum'
+
+  rtDW.Delay_DSTATE[0] = ((0.547568478085603 * rtDW.Add3_a +
+    rtDW.Integrator_DSTATE_ao) + rtDW.FilterCoefficient_i) + 7.3575;
+
+  // Update for DiscreteIntegrator: '<S141>/Integrator' incorporates:
+  //   Gain: '<S138>/Integral Gain'
+
+  rtDW.Integrator_DSTATE += 0.0492289691165195 * rtDW.maxval * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S136>/Filter'
+  rtDW.Filter_DSTATE += 0.0001 * Fdes_idx_0;
+
+  // Update for DiscreteIntegrator: '<S273>/Integrator' incorporates:
+  //   Gain: '<S270>/Integral Gain'
+
+  rtDW.Integrator_DSTATE_a += 0.0492289691165195 * Fdes_idx_1 * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S268>/Filter'
+  rtDW.Filter_DSTATE_k += 0.0001 * Fdes_idx_2;
+
+  // Update for DiscreteIntegrator: '<S185>/Integrator' incorporates:
+  //   Gain: '<S182>/Integral Gain'
+
+  rtDW.Integrator_DSTATE_m += 0.230387898131499 * rtDW.Add1_k * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S180>/Filter'
+  rtDW.Filter_DSTATE_m += 0.0001 * rtDW.FilterCoefficient_a;
+
+  // Update for DiscreteIntegrator: '<S53>/Integrator' incorporates:
+  //   Gain: '<S50>/Integral Gain'
+
+  rtDW.Integrator_DSTATE_e += 0.230387898131499 *
+    rtb_TmpSignalConversionAtSFun_1 * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S48>/Filter'
+  rtDW.Filter_DSTATE_l += 0.0001 * rtb_TmpSignalConversionAtSFun_0;
+
+  // Update for DiscreteIntegrator: '<S97>/Integrator' incorporates:
+  //   Constant: '<S4>/Constant'
+  //   Gain: '<S94>/Integral Gain'
+  //   MATLAB Function: '<S4>/MATLAB Function4'
+  //   Sum: '<S23>/Add3'
+
+  rtDW.Integrator_DSTATE_o += (0.0 - rtDW.Integrator_p[5]) * 4.32690066926921E-5
+    * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S92>/Filter'
+  rtDW.Filter_DSTATE_lo += 0.0001 * rtDW.FilterCoefficient_k;
+
+  // Update for DiscreteIntegrator: '<S229>/Integrator' incorporates:
+  //   Gain: '<S226>/Integral Gain'
+
+  rtDW.Integrator_DSTATE_ao += 0.0506661578399485 * rtDW.Add3_a * 0.0001;
+
+  // Update for DiscreteIntegrator: '<S224>/Filter'
+  rtDW.Filter_DSTATE_n += 0.0001 * rtDW.FilterCoefficient_i;
+
+  // End of Outputs for SubSystem: '<S1>/small_angle_control'
+  // End of Outputs for SubSystem: '<Root>/Adaptive large angle controller'
+
+  // Outport: '<Root>/u1 '
+  rtY.u1 = rtDW.duty[0];
+
+  // Outport: '<Root>/u2 '
+  rtY.u2 = rtDW.duty[1];
+
+  // Outport: '<Root>/u3'
+  rtY.u3 = rtDW.duty[2];
+
+  // Outport: '<Root>/u4'
+  rtY.u4 = rtDW.duty[3];
+}
+
+// Model initialize function
+void LAAPModelClass::initialize()
+{
+  {
+    int32_T i;
+
+    // SystemInitialize for Atomic SubSystem: '<Root>/Adaptive large angle controller' 
+    // SystemInitialize for Atomic SubSystem: '<S1>/quadcopter_dynamics_prediction' 
+    // InitializeConditions for DiscreteIntegrator: '<S13>/Integrator'
+    for (i = 0; i < 6; i++) {
+      rtDW.Integrator_DSTATE_ep[i] = 0.0;
+      if (rtDW.Integrator_DSTATE_ep[i] >= 10.0) {
+        rtDW.Integrator_DSTATE_ep[i] = 10.0;
+      } else {
+        if (rtDW.Integrator_DSTATE_ep[i] <= -10.0) {
+          rtDW.Integrator_DSTATE_ep[i] = -10.0;
+        }
+      }
+    }
+
+    // End of InitializeConditions for DiscreteIntegrator: '<S13>/Integrator'
+
+    // InitializeConditions for DiscreteIntegrator: '<S14>/Integrator'
+    rtDW.Integrator_IC_LOADING = 1U;
+
+    // End of SystemInitialize for SubSystem: '<S1>/quadcopter_dynamics_prediction' 
+    // End of SystemInitialize for SubSystem: '<Root>/Adaptive large angle controller' 
+  }
+}
+
+// Constructor
+LAAPModelClass::LAAPModelClass()
+{
+  // Currently there is no constructor body generated.
+}
+
+// Destructor
+LAAPModelClass::~LAAPModelClass()
+{
+  // Currently there is no destructor body generated.
+}
+
+// Root-level input access methods
+
+// Root inport: '<Root>/rdot' set method
+void LAAPModelClass::setrdot(real_T localArgInput[3])
+{
+  rtU.rdot[0] = localArgInput[0];
+  rtU.rdot[1] = localArgInput[1];
+  rtU.rdot[2] = localArgInput[2];
+}
+
+// Root inport: '<Root>/r' set method
+void LAAPModelClass::setr(real_T localArgInput[3])
+{
+  rtU.r[0] = localArgInput[0];
+  rtU.r[1] = localArgInput[1];
+  rtU.r[2] = localArgInput[2];
+}
+
+// Root inport: '<Root>/wb' set method
+void LAAPModelClass::setwb(real_T localArgInput[3])
+{
+  rtU.wb[0] = localArgInput[0];
+  rtU.wb[1] = localArgInput[1];
+  rtU.wb[2] = localArgInput[2];
+}
+
+// Root inport: '<Root>/angles' set method
+void LAAPModelClass::setangles(real_T localArgInput[3])
+{
+  rtU.angles[0] = localArgInput[0];
+  rtU.angles[1] = localArgInput[1];
+  rtU.angles[2] = localArgInput[2];
+}
+
+// Root inport: '<Root>/x' set method
+void LAAPModelClass::setx(real_T localArgInput)
+{
+  rtU.x = localArgInput;
+}
+
+// Root inport: '<Root>/y' set method
+void LAAPModelClass::sety(real_T localArgInput)
+{
+  rtU.y = localArgInput;
+}
+
+// Root inport: '<Root>/z' set method
+void LAAPModelClass::setz(real_T localArgInput)
+{
+  rtU.z = localArgInput;
+}
+
+// Root inport: '<Root>/phi' set method
+void LAAPModelClass::setphi(real_T localArgInput)
+{
+  rtU.phi = localArgInput;
+}
+
+// Root inport: '<Root>/theta' set method
+void LAAPModelClass::settheta(real_T localArgInput)
+{
+  rtU.theta = localArgInput;
+}
+
+// Root inport: '<Root>/psi' set method
+void LAAPModelClass::setpsi(real_T localArgInput)
+{
+  rtU.psi = localArgInput;
+}
+
+// Root-level output access methods
+
+// Root outport: '<Root>/u1 ' get method
+real_T LAAPModelClass::getu1_() const
+{
+  return rtY.u1;
+}
+
+// Root outport: '<Root>/u2 ' get method
+real_T LAAPModelClass::getu2_() const
+{
+  return rtY.u2;
+}
+
+// Root outport: '<Root>/u3' get method
+real_T LAAPModelClass::getu3() const
+{
+  return rtY.u3;
+}
+
+// Root outport: '<Root>/u4' get method
+real_T LAAPModelClass::getu4() const
+{
+  return rtY.u4;
+}
+
+// Real-Time Model get method
+RT_MODEL * LAAPModelClass::getRTM()
+{
+  return (&rtM);
+}
+
+//
+// File trailer for generated code.
+//
+// [EOF]
+//
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/LAAP.h	Mon Nov 25 10:51:06 2019 +0000
@@ -0,0 +1,514 @@
+//
+// File: LAAP.h
+//
+// Code generated for Simulink model 'LAAP'.
+//
+// Model version                  : 1.2
+// Simulink Coder version         : 9.1 (R2019a) 23-Nov-2018
+// C/C++ source code generated on : Mon Nov 18 17:57:49 2019
+//
+// Target selection: ert.tlc
+// Embedded hardware selection: ARM Compatible->ARM Cortex
+// Code generation objectives:
+//    1. Execution efficiency
+//    2. RAM efficiency
+// Validation result: Not run
+//
+#ifndef RTW_HEADER_LAAP_h_
+#define RTW_HEADER_LAAP_h_
+#include <cmath>
+#include <string.h>
+#ifndef LAAP_COMMON_INCLUDES_
+# define LAAP_COMMON_INCLUDES_
+#include "rtwtypes.h"
+#endif                                 // LAAP_COMMON_INCLUDES_
+
+// Macros for accessing real-time model data structure
+#ifndef rtmGetErrorStatus
+# define rtmGetErrorStatus(rtm)        ((rtm)->errorStatus)
+#endif
+
+#ifndef rtmSetErrorStatus
+# define rtmSetErrorStatus(rtm, val)   ((rtm)->errorStatus = (val))
+#endif
+
+// Forward declaration for rtModel
+typedef struct tag_RTM RT_MODEL;
+
+// Block signals and states (default storage) for system '<Root>'
+typedef struct {
+  real_T psy[12];                      // '<S5>/MATLAB Function3'
+  real_T duty[4];                      // '<S5>/MATLAB Function1'
+  real_T Delay_DSTATE[4];              // '<S1>/Delay'
+  real_T Delay_DSTATE_h[3];            // '<S3>/Delay'
+  real_T Delay1_DSTATE_l[3];           // '<S3>/Delay1'
+  real_T Integrator_DSTATE_ep[6];      // '<S13>/Integrator'
+  real_T Integrator_DSTATE_k[6];       // '<S14>/Integrator'
+  real_T Delay_DSTATE_hf[12];          // '<S2>/Delay'
+  real_T F[144];
+  real_T Delay1[12];                   // '<S1>/Delay1'
+  real_T rtb_Delay1_m[12];
+  real_T F_c[12];
+  real_T b_I[9];
+  real_T R[9];
+  real_T d[9];
+  real_T dv0[9];
+  real_T b_I_k[9];
+  real_T R_c[9];
+  real_T Integrator[6];                // '<S13>/Integrator'
+  real_T Integrator_p[6];              // '<S14>/Integrator'
+  real_T dv1[6];
+  real_T A[4];
+  real_T a_dotdot[3];
+  real_T Iw_dot[3];
+  real_T w_dot[3];
+  real_T Zbdes[3];
+  real_T Xc[3];
+  real_T crossZX[3];
+  real_T wb[3];                        // '<S3>/Euler equations of motion1 '
+  real_T dv2[3];
+  real_T Integrator_DSTATE;            // '<S141>/Integrator'
+  real_T Filter_DSTATE;                // '<S136>/Filter'
+  real_T Integrator_DSTATE_a;          // '<S273>/Integrator'
+  real_T Filter_DSTATE_k;              // '<S268>/Filter'
+  real_T Integrator_DSTATE_m;          // '<S185>/Integrator'
+  real_T Filter_DSTATE_m;              // '<S180>/Filter'
+  real_T Integrator_DSTATE_e;          // '<S53>/Integrator'
+  real_T Filter_DSTATE_l;              // '<S48>/Filter'
+  real_T Integrator_DSTATE_o;          // '<S97>/Integrator'
+  real_T Filter_DSTATE_lo;             // '<S92>/Filter'
+  real_T Integrator_DSTATE_ao;         // '<S229>/Integrator'
+  real_T Filter_DSTATE_n;              // '<S224>/Filter'
+  real_T maxval;
+  real_T Add1_k;                       // '<S23>/Add1'
+  real_T FilterCoefficient_a;          // '<S188>/Filter Coefficient'
+  real_T FilterCoefficient_k;          // '<S100>/Filter Coefficient'
+  real_T Add3_a;                       // '<S22>/Add3'
+  real_T FilterCoefficient_i;          // '<S232>/Filter Coefficient'
+  int8_T Integrator_PrevResetState;    // '<S13>/Integrator'
+  int8_T Integrator_PrevResetState_n;  // '<S14>/Integrator'
+  uint8_T Integrator_IC_LOADING;       // '<S14>/Integrator'
+} DW;
+
+// External inputs (root inport signals with default storage)
+typedef struct {
+  real_T rdot[3];                      // '<Root>/rdot'
+  real_T r[3];                         // '<Root>/r'
+  real_T wb[3];                        // '<Root>/wb'
+  real_T angles[3];                    // '<Root>/angles'
+  real_T x;                            // '<Root>/x'
+  real_T y;                            // '<Root>/y'
+  real_T z;                            // '<Root>/z'
+  real_T phi;                          // '<Root>/phi'
+  real_T theta;                        // '<Root>/theta'
+  real_T psi;                          // '<Root>/psi'
+} ExtU;
+
+// External outputs (root outports fed by signals with default storage)
+typedef struct {
+  real_T u1;                           // '<Root>/u1 '
+  real_T u2;                           // '<Root>/u2 '
+  real_T u3;                           // '<Root>/u3'
+  real_T u4;                           // '<Root>/u4'
+} ExtY;
+
+// Real-time Model Data Structure
+struct tag_RTM {
+  const char_T * volatile errorStatus;
+};
+
+// Class declaration for model LAAP
+class LAAPModelClass {
+  // public data and function members
+ public:
+  // model initialize function
+  void initialize();
+
+  // model step function
+  void step();
+
+  // Constructor
+  LAAPModelClass();
+
+  // Destructor
+  ~LAAPModelClass();
+
+  // Root inport: '<Root>/rdot' set method
+  void setrdot(real_T localArgInput[3]);
+
+  // Root inport: '<Root>/r' set method
+  void setr(real_T localArgInput[3]);
+
+  // Root inport: '<Root>/wb' set method
+  void setwb(real_T localArgInput[3]);
+
+  // Root inport: '<Root>/angles' set method
+  void setangles(real_T localArgInput[3]);
+
+  // Root inport: '<Root>/x' set method
+  void setx(real_T localArgInput);
+
+  // Root inport: '<Root>/y' set method
+  void sety(real_T localArgInput);
+
+  // Root inport: '<Root>/z' set method
+  void setz(real_T localArgInput);
+
+  // Root inport: '<Root>/phi' set method
+  void setphi(real_T localArgInput);
+
+  // Root inport: '<Root>/theta' set method
+  void settheta(real_T localArgInput);
+
+  // Root inport: '<Root>/psi' set method
+  void setpsi(real_T localArgInput);
+
+  // Root outport: '<Root>/u1 ' get method
+  real_T getu1_() const;
+
+  // Root outport: '<Root>/u2 ' get method
+  real_T getu2_() const;
+
+  // Root outport: '<Root>/u3' get method
+  real_T getu3() const;
+
+  // Root outport: '<Root>/u4' get method
+  real_T getu4() const;
+
+  // Real-Time Model get method
+  RT_MODEL * getRTM();
+
+  // protected data and function members
+ protected:
+  // External inputs
+  ExtU rtU;
+
+  // External outputs
+  ExtY rtY;
+
+  // private data and function members
+ private:
+  // Block signals and states
+  DW rtDW;
+
+  // Real-Time Model
+  RT_MODEL rtM;
+};
+
+//-
+//  These blocks were eliminated from the model due to optimizations:
+//
+//  Block '<S13>/Saturation' : Eliminated Saturate block
+//  Block '<S14>/Saturation' : Eliminated Saturate block
+
+
+//-
+//  The generated code includes comments that allow you to trace directly
+//  back to the appropriate location in the model.  The basic format
+//  is <system>/block_name, where system is the system number (uniquely
+//  assigned by Simulink) and block_name is the name of the block.
+//
+//  Use the MATLAB hilite_system command to trace the generated code back
+//  to the model.  For example,
+//
+//  hilite_system('<S3>')    - opens system 3
+//  hilite_system('<S3>/Kp') - opens and selects block Kp which resides in S3
+//
+//  Here is the system hierarchy for this model
+//
+//  '<Root>' : 'LAAP'
+//  '<S1>'   : 'LAAP/Adaptive large angle controller'
+//  '<S2>'   : 'LAAP/Adaptive large angle controller/largepaa'
+//  '<S3>'   : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction'
+//  '<S4>'   : 'LAAP/Adaptive large angle controller/small_angle_control'
+//  '<S5>'   : 'LAAP/Adaptive large angle controller/largepaa/large_controller'
+//  '<S6>'   : 'LAAP/Adaptive large angle controller/largepaa/parameter_adaptation_algorithm'
+//  '<S7>'   : 'LAAP/Adaptive large angle controller/largepaa/large_controller/MATLAB Function1'
+//  '<S8>'   : 'LAAP/Adaptive large angle controller/largepaa/large_controller/MATLAB Function3'
+//  '<S9>'   : 'LAAP/Adaptive large angle controller/largepaa/parameter_adaptation_algorithm/MATLAB Function3'
+//  '<S10>'  : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction/Euler equations of motion1 '
+//  '<S11>'  : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction/Integrator (Discrete or Continuous)'
+//  '<S12>'  : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction/Integrator (Discrete or Continuous)1'
+//  '<S13>'  : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction/Integrator (Discrete or Continuous)/Discrete'
+//  '<S14>'  : 'LAAP/Adaptive large angle controller/quadcopter_dynamics_prediction/Integrator (Discrete or Continuous)1/Discrete'
+//  '<S15>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1'
+//  '<S16>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2'
+//  '<S17>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3'
+//  '<S18>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4'
+//  '<S19>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5'
+//  '<S20>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6'
+//  '<S21>'  : 'LAAP/Adaptive large angle controller/small_angle_control/MATLAB Function4'
+//  '<S22>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Subsystem'
+//  '<S23>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Subsystem1'
+//  '<S24>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Anti-windup'
+//  '<S25>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/D Gain'
+//  '<S26>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Filter'
+//  '<S27>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Filter ICs'
+//  '<S28>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/I Gain'
+//  '<S29>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Ideal P Gain'
+//  '<S30>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Ideal P Gain Fdbk'
+//  '<S31>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Integrator'
+//  '<S32>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Integrator ICs'
+//  '<S33>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/N Copy'
+//  '<S34>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/N Gain'
+//  '<S35>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/P Copy'
+//  '<S36>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Parallel P Gain'
+//  '<S37>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Reset Signal'
+//  '<S38>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Saturation'
+//  '<S39>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Saturation Fdbk'
+//  '<S40>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Sum'
+//  '<S41>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Sum Fdbk'
+//  '<S42>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Tracking Mode'
+//  '<S43>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Tracking Mode Sum'
+//  '<S44>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/postSat Signal'
+//  '<S45>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/preSat Signal'
+//  '<S46>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Anti-windup/Passthrough'
+//  '<S47>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/D Gain/Internal Parameters'
+//  '<S48>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Filter/Disc. Forward Euler Filter'
+//  '<S49>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Filter ICs/Internal IC - Filter'
+//  '<S50>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/I Gain/Internal Parameters'
+//  '<S51>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Ideal P Gain/Passthrough'
+//  '<S52>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Ideal P Gain Fdbk/Disabled'
+//  '<S53>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Integrator/Discrete'
+//  '<S54>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Integrator ICs/Internal IC'
+//  '<S55>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/N Copy/Disabled'
+//  '<S56>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/N Gain/Internal Parameters'
+//  '<S57>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/P Copy/Disabled'
+//  '<S58>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Parallel P Gain/Internal Parameters'
+//  '<S59>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Reset Signal/Disabled'
+//  '<S60>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Saturation/Passthrough'
+//  '<S61>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Saturation Fdbk/Disabled'
+//  '<S62>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Sum/Sum_PID'
+//  '<S63>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Sum Fdbk/Disabled'
+//  '<S64>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Tracking Mode/Disabled'
+//  '<S65>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/Tracking Mode Sum/Passthrough'
+//  '<S66>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/postSat Signal/Forward_Path'
+//  '<S67>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller1/preSat Signal/Forward_Path'
+//  '<S68>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Anti-windup'
+//  '<S69>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/D Gain'
+//  '<S70>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Filter'
+//  '<S71>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Filter ICs'
+//  '<S72>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/I Gain'
+//  '<S73>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Ideal P Gain'
+//  '<S74>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Ideal P Gain Fdbk'
+//  '<S75>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Integrator'
+//  '<S76>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Integrator ICs'
+//  '<S77>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/N Copy'
+//  '<S78>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/N Gain'
+//  '<S79>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/P Copy'
+//  '<S80>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Parallel P Gain'
+//  '<S81>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Reset Signal'
+//  '<S82>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Saturation'
+//  '<S83>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Saturation Fdbk'
+//  '<S84>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Sum'
+//  '<S85>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Sum Fdbk'
+//  '<S86>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Tracking Mode'
+//  '<S87>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Tracking Mode Sum'
+//  '<S88>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/postSat Signal'
+//  '<S89>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/preSat Signal'
+//  '<S90>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Anti-windup/Passthrough'
+//  '<S91>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/D Gain/Internal Parameters'
+//  '<S92>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Filter/Disc. Forward Euler Filter'
+//  '<S93>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Filter ICs/Internal IC - Filter'
+//  '<S94>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/I Gain/Internal Parameters'
+//  '<S95>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Ideal P Gain/Passthrough'
+//  '<S96>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Ideal P Gain Fdbk/Disabled'
+//  '<S97>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Integrator/Discrete'
+//  '<S98>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Integrator ICs/Internal IC'
+//  '<S99>'  : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/N Copy/Disabled'
+//  '<S100>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/N Gain/Internal Parameters'
+//  '<S101>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/P Copy/Disabled'
+//  '<S102>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Parallel P Gain/Internal Parameters'
+//  '<S103>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Reset Signal/Disabled'
+//  '<S104>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Saturation/Passthrough'
+//  '<S105>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Saturation Fdbk/Disabled'
+//  '<S106>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Sum/Sum_PID'
+//  '<S107>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Sum Fdbk/Disabled'
+//  '<S108>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Tracking Mode/Disabled'
+//  '<S109>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/Tracking Mode Sum/Passthrough'
+//  '<S110>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/postSat Signal/Forward_Path'
+//  '<S111>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller2/preSat Signal/Forward_Path'
+//  '<S112>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Anti-windup'
+//  '<S113>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/D Gain'
+//  '<S114>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Filter'
+//  '<S115>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Filter ICs'
+//  '<S116>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/I Gain'
+//  '<S117>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Ideal P Gain'
+//  '<S118>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Ideal P Gain Fdbk'
+//  '<S119>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Integrator'
+//  '<S120>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Integrator ICs'
+//  '<S121>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/N Copy'
+//  '<S122>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/N Gain'
+//  '<S123>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/P Copy'
+//  '<S124>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Parallel P Gain'
+//  '<S125>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Reset Signal'
+//  '<S126>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Saturation'
+//  '<S127>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Saturation Fdbk'
+//  '<S128>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Sum'
+//  '<S129>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Sum Fdbk'
+//  '<S130>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Tracking Mode'
+//  '<S131>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Tracking Mode Sum'
+//  '<S132>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/postSat Signal'
+//  '<S133>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/preSat Signal'
+//  '<S134>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Anti-windup/Passthrough'
+//  '<S135>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/D Gain/Internal Parameters'
+//  '<S136>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Filter/Disc. Forward Euler Filter'
+//  '<S137>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Filter ICs/Internal IC - Filter'
+//  '<S138>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/I Gain/Internal Parameters'
+//  '<S139>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Ideal P Gain/Passthrough'
+//  '<S140>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Ideal P Gain Fdbk/Disabled'
+//  '<S141>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Integrator/Discrete'
+//  '<S142>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Integrator ICs/Internal IC'
+//  '<S143>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/N Copy/Disabled'
+//  '<S144>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/N Gain/Internal Parameters'
+//  '<S145>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/P Copy/Disabled'
+//  '<S146>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Parallel P Gain/Internal Parameters'
+//  '<S147>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Reset Signal/Disabled'
+//  '<S148>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Saturation/Passthrough'
+//  '<S149>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Saturation Fdbk/Disabled'
+//  '<S150>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Sum/Sum_PID'
+//  '<S151>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Sum Fdbk/Disabled'
+//  '<S152>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Tracking Mode/Disabled'
+//  '<S153>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/Tracking Mode Sum/Passthrough'
+//  '<S154>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/postSat Signal/Forward_Path'
+//  '<S155>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller3/preSat Signal/Forward_Path'
+//  '<S156>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Anti-windup'
+//  '<S157>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/D Gain'
+//  '<S158>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Filter'
+//  '<S159>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Filter ICs'
+//  '<S160>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/I Gain'
+//  '<S161>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Ideal P Gain'
+//  '<S162>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Ideal P Gain Fdbk'
+//  '<S163>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Integrator'
+//  '<S164>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Integrator ICs'
+//  '<S165>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/N Copy'
+//  '<S166>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/N Gain'
+//  '<S167>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/P Copy'
+//  '<S168>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Parallel P Gain'
+//  '<S169>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Reset Signal'
+//  '<S170>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Saturation'
+//  '<S171>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Saturation Fdbk'
+//  '<S172>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Sum'
+//  '<S173>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Sum Fdbk'
+//  '<S174>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Tracking Mode'
+//  '<S175>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Tracking Mode Sum'
+//  '<S176>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/postSat Signal'
+//  '<S177>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/preSat Signal'
+//  '<S178>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Anti-windup/Passthrough'
+//  '<S179>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/D Gain/Internal Parameters'
+//  '<S180>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Filter/Disc. Forward Euler Filter'
+//  '<S181>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Filter ICs/Internal IC - Filter'
+//  '<S182>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/I Gain/Internal Parameters'
+//  '<S183>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Ideal P Gain/Passthrough'
+//  '<S184>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Ideal P Gain Fdbk/Disabled'
+//  '<S185>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Integrator/Discrete'
+//  '<S186>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Integrator ICs/Internal IC'
+//  '<S187>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/N Copy/Disabled'
+//  '<S188>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/N Gain/Internal Parameters'
+//  '<S189>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/P Copy/Disabled'
+//  '<S190>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Parallel P Gain/Internal Parameters'
+//  '<S191>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Reset Signal/Disabled'
+//  '<S192>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Saturation/Passthrough'
+//  '<S193>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Saturation Fdbk/Disabled'
+//  '<S194>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Sum/Sum_PID'
+//  '<S195>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Sum Fdbk/Disabled'
+//  '<S196>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Tracking Mode/Disabled'
+//  '<S197>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/Tracking Mode Sum/Passthrough'
+//  '<S198>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/postSat Signal/Forward_Path'
+//  '<S199>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller4/preSat Signal/Forward_Path'
+//  '<S200>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Anti-windup'
+//  '<S201>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/D Gain'
+//  '<S202>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Filter'
+//  '<S203>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Filter ICs'
+//  '<S204>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/I Gain'
+//  '<S205>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Ideal P Gain'
+//  '<S206>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Ideal P Gain Fdbk'
+//  '<S207>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Integrator'
+//  '<S208>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Integrator ICs'
+//  '<S209>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/N Copy'
+//  '<S210>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/N Gain'
+//  '<S211>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/P Copy'
+//  '<S212>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Parallel P Gain'
+//  '<S213>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Reset Signal'
+//  '<S214>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Saturation'
+//  '<S215>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Saturation Fdbk'
+//  '<S216>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Sum'
+//  '<S217>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Sum Fdbk'
+//  '<S218>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Tracking Mode'
+//  '<S219>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Tracking Mode Sum'
+//  '<S220>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/postSat Signal'
+//  '<S221>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/preSat Signal'
+//  '<S222>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Anti-windup/Passthrough'
+//  '<S223>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/D Gain/Internal Parameters'
+//  '<S224>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Filter/Disc. Forward Euler Filter'
+//  '<S225>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Filter ICs/Internal IC - Filter'
+//  '<S226>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/I Gain/Internal Parameters'
+//  '<S227>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Ideal P Gain/Passthrough'
+//  '<S228>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Ideal P Gain Fdbk/Disabled'
+//  '<S229>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Integrator/Discrete'
+//  '<S230>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Integrator ICs/Internal IC'
+//  '<S231>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/N Copy/Disabled'
+//  '<S232>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/N Gain/Internal Parameters'
+//  '<S233>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/P Copy/Disabled'
+//  '<S234>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Parallel P Gain/Internal Parameters'
+//  '<S235>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Reset Signal/Disabled'
+//  '<S236>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Saturation/Passthrough'
+//  '<S237>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Saturation Fdbk/Disabled'
+//  '<S238>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Sum/Sum_PID'
+//  '<S239>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Sum Fdbk/Disabled'
+//  '<S240>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Tracking Mode/Disabled'
+//  '<S241>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/Tracking Mode Sum/Passthrough'
+//  '<S242>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/postSat Signal/Forward_Path'
+//  '<S243>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller5/preSat Signal/Forward_Path'
+//  '<S244>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Anti-windup'
+//  '<S245>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/D Gain'
+//  '<S246>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Filter'
+//  '<S247>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Filter ICs'
+//  '<S248>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/I Gain'
+//  '<S249>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Ideal P Gain'
+//  '<S250>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Ideal P Gain Fdbk'
+//  '<S251>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Integrator'
+//  '<S252>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Integrator ICs'
+//  '<S253>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/N Copy'
+//  '<S254>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/N Gain'
+//  '<S255>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/P Copy'
+//  '<S256>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Parallel P Gain'
+//  '<S257>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Reset Signal'
+//  '<S258>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Saturation'
+//  '<S259>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Saturation Fdbk'
+//  '<S260>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Sum'
+//  '<S261>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Sum Fdbk'
+//  '<S262>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Tracking Mode'
+//  '<S263>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Tracking Mode Sum'
+//  '<S264>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/postSat Signal'
+//  '<S265>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/preSat Signal'
+//  '<S266>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Anti-windup/Passthrough'
+//  '<S267>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/D Gain/Internal Parameters'
+//  '<S268>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Filter/Disc. Forward Euler Filter'
+//  '<S269>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Filter ICs/Internal IC - Filter'
+//  '<S270>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/I Gain/Internal Parameters'
+//  '<S271>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Ideal P Gain/Passthrough'
+//  '<S272>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Ideal P Gain Fdbk/Disabled'
+//  '<S273>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Integrator/Discrete'
+//  '<S274>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Integrator ICs/Internal IC'
+//  '<S275>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/N Copy/Disabled'
+//  '<S276>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/N Gain/Internal Parameters'
+//  '<S277>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/P Copy/Disabled'
+//  '<S278>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Parallel P Gain/Internal Parameters'
+//  '<S279>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Reset Signal/Disabled'
+//  '<S280>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Saturation/Passthrough'
+//  '<S281>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Saturation Fdbk/Disabled'
+//  '<S282>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Sum/Sum_PID'
+//  '<S283>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Sum Fdbk/Disabled'
+//  '<S284>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Tracking Mode/Disabled'
+//  '<S285>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/Tracking Mode Sum/Passthrough'
+//  '<S286>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/postSat Signal/Forward_Path'
+//  '<S287>' : 'LAAP/Adaptive large angle controller/small_angle_control/Discrete PID Controller6/preSat Signal/Forward_Path'
+
+#endif                                 // RTW_HEADER_LAAP_h_
+
+//
+// File trailer for generated code.
+//
+// [EOF]
+//
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rtwtypes.h	Mon Nov 25 10:51:06 2019 +0000
@@ -0,0 +1,102 @@
+//
+// File: rtwtypes.h
+//
+// Code generated for Simulink model 'LAAP'.
+//
+// Model version                  : 1.2
+// Simulink Coder version         : 9.1 (R2019a) 23-Nov-2018
+// C/C++ source code generated on : Mon Nov 18 17:57:49 2019
+//
+// Target selection: ert.tlc
+// Embedded hardware selection: ARM Compatible->ARM Cortex
+// Code generation objectives:
+//    1. Execution efficiency
+//    2. RAM efficiency
+// Validation result: Not run
+//
+
+#ifndef RTWTYPES_H
+#define RTWTYPES_H
+
+// Logical type definitions
+#if (!defined(__cplusplus))
+#  ifndef false
+#   define false                       (0U)
+#  endif
+
+#  ifndef true
+#   define true                        (1U)
+#  endif
+#endif
+
+//=======================================================================*
+//  Target hardware information
+//    Device type: ARM Compatible->ARM Cortex
+//    Number of bits:     char:   8    short:   16    int:  32
+//                        long:  32    long long:  64
+//                        native word size:  32
+//    Byte ordering: LittleEndian
+//    Signed integer division rounds to: Zero
+//    Shift right on a signed integer as arithmetic shift: on
+// =======================================================================
+
+//=======================================================================*
+//  Fixed width word size data types:                                     *
+//    int8_T, int16_T, int32_T     - signed 8, 16, or 32 bit integers     *
+//    uint8_T, uint16_T, uint32_T  - unsigned 8, 16, or 32 bit integers   *
+//    real32_T, real64_T           - 32 and 64 bit floating point numbers *
+// =======================================================================
+typedef signed char int8_T;
+typedef unsigned char uint8_T;
+typedef short int16_T;
+typedef unsigned short uint16_T;
+typedef int int32_T;
+typedef unsigned int uint32_T;
+typedef long long int64_T;
+typedef unsigned long long uint64_T;
+typedef float real32_T;
+typedef double real64_T;
+
+//===========================================================================*
+//  Generic type definitions: boolean_T, char_T, byte_T, int_T, uint_T,       *
+//                            real_T, time_T, ulong_T, ulonglong_T.           *
+// ===========================================================================
+typedef double real_T;
+typedef double time_T;
+typedef unsigned char boolean_T;
+typedef int int_T;
+typedef unsigned int uint_T;
+typedef unsigned long ulong_T;
+typedef unsigned long long ulonglong_T;
+typedef char char_T;
+typedef unsigned char uchar_T;
+typedef char_T byte_T;
+
+//=======================================================================*
+//  Min and Max:                                                          *
+//    int8_T, int16_T, int32_T     - signed 8, 16, or 32 bit integers     *
+//    uint8_T, uint16_T, uint32_T  - unsigned 8, 16, or 32 bit integers   *
+// =======================================================================
+#define MAX_int8_T                     ((int8_T)(127))
+#define MIN_int8_T                     ((int8_T)(-128))
+#define MAX_uint8_T                    ((uint8_T)(255U))
+#define MAX_int16_T                    ((int16_T)(32767))
+#define MIN_int16_T                    ((int16_T)(-32768))
+#define MAX_uint16_T                   ((uint16_T)(65535U))
+#define MAX_int32_T                    ((int32_T)(2147483647))
+#define MIN_int32_T                    ((int32_T)(-2147483647-1))
+#define MAX_uint32_T                   ((uint32_T)(0xFFFFFFFFU))
+#define MAX_int64_T                    ((int64_T)(9223372036854775807LL))
+#define MIN_int64_T                    ((int64_T)(-9223372036854775807LL-1LL))
+#define MAX_uint64_T                   ((uint64_T)(0xFFFFFFFFFFFFFFFFULL))
+
+// Block D-Work pointer type
+typedef void * pointer_T;
+
+#endif                                 // RTWTYPES_H
+
+//
+// File trailer for generated code.
+//
+// [EOF]
+//