Matlab code for quadcopter
Dependents: combination combination
Diff: LAAP.cpp
- Revision:
- 0:25d32fc1c12e
diff -r 000000000000 -r 25d32fc1c12e LAAP.cpp --- /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] +//