within AIDAModelica; model ComputeDroneAttitude "[SimuD6 KM] Compute drone attitude" // CP: 65001 // SimulationX Version: 3.8.2.45319 x64 Modelica.Blocks.Interfaces.RealInput DroneAngularVelocities[3](quantity = "Mechanics.Rotation.RotVelocity", displayUnit = "rad/s") "'input Real' as connector" annotation( Placement(transformation(extent = {{-135, 5}, {-95, 45}}), iconTransformation(extent = {{-95, -20}, {-55, 20}}))); Modelica.Blocks.Interfaces.RealInput AttitudeFB[3](quantity = "Mechanics.Rotation.Angle", displayUnit = "rad") "'input Real' as connector" annotation( Placement(transformation(extent = {{-135, -25}, {-95, 15}}), iconTransformation(origin = {-25, -50}, extent = {{-20, -20}, {20, 20}}, rotation = -270))); Modelica.Blocks.Interfaces.RealOutput Attitude[3](quantity = "Mechanics.Rotation.Angle", displayUnit = "rad") "'output Real' as connector" annotation( Placement(transformation(extent = {{75, 5}, {95, 25}}), iconTransformation(extent = {{61.7, -10}, {81.7, 10}}))); ComputationChangeAngleVelocity computationChangeAngleVelocity1 annotation( Placement(transformation(extent = {{-60, 10}, {-45, 25}}))); Modelica.Blocks.Continuous.Integrator integrator7 annotation( Placement(transformation(extent = {{10, 35}, {30, 55}}))); Modelica.Blocks.Continuous.Integrator integrator8 annotation( Placement(transformation(extent = {{10, 5}, {30, 25}}))); Modelica.Blocks.Continuous.Integrator integrator9 annotation( Placement(transformation(extent = {{10, -25}, {30, -5}}))); equation connect(computationChangeAngleVelocity1.DronAngularVelocities[:], DroneAngularVelocities[:]) annotation( Line(points = {{-60, 20}, {-65, 20}, {-110, 20}, {-110, 25}, {-115, 25}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator7.u, computationChangeAngleVelocity1.ChangeAngleVelocity[1]) annotation( Line(points = {{8, 45}, {3, 45}, {-40.3, 45}, {-40.3, 17.3}, {-45.3, 17.3}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator8.u, computationChangeAngleVelocity1.ChangeAngleVelocity[2]) annotation( Line(points = {{8, 15}, {3, 15}, {-40.3, 15}, {-40.3, 17.3}, {-45.3, 17.3}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator9.u, computationChangeAngleVelocity1.ChangeAngleVelocity[3]) annotation( Line(points = {{8, -15}, {3, -15}, {-40.3, -15}, {-40.3, 17.7}, {-45.3, 17.7}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator7.y, Attitude[1]) annotation( Line(points = {{31, 45}, {36, 45}, {80, 45}, {80, 15}, {85, 15}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator8.y, Attitude[2]) annotation( Line(points = {{31, 15}, {36, 15}, {80, 15}, {85, 15}}, color = {0, 0, 127}, thickness = 0.0625)); connect(integrator9.y, Attitude[3]) annotation( Line(points = {{31, -15}, {36, -15}, {80, -15}, {80, 15}, {85, 15}}, color = {0, 0, 127}, thickness = 0.0625)); connect(computationChangeAngleVelocity1.Attitude[:], AttitudeFB[:]) annotation( Line(points = {{-60, 15}, {-65, 15}, {-110, 15}, {-110, -5}, {-115, -5}}, color = {0, 0, 127}, thickness = 0.0625)); annotation( DroneAngularVelocities(flags = 2), AttitudeFB(flags = 2), Attitude(flags = 2), computationChangeAngleVelocity1(DronAngularVelocities(flags = 2), Attitude(flags = 2), ChangeAngleVelocity(flags = 2), W(flags = 2)), integrator7(u(flags = 2), y(flags = 2)), integrator8(u(flags = 2), y(flags = 2)), integrator9(u(flags = 2), y(flags = 2)), Icon(coordinateSystem(extent = {{-75, -50}, {75, 50}}, initialScale = 0.1), graphics = {Rectangle(fillColor = {255, 255, 255}, fillPattern = FillPattern.Solid, extent = {{-76.7, 50}, {76.7, -50}}), Text(origin = {-3, 3}, extent = {{-13, 5}, {13, -5}}, textString = "%name")}), experiment(StopTime = 1, StartTime = 0, Interval = 0.002, MaxInterval = "0.001")); end ComputeDroneAttitude;