Next Article in Journal
Spherical Indoor Coandă Effect Drone (SpICED): A Spherical Blimp sUAS for Safe Indoor Use
Previous Article in Journal
Assessment of Indiana Unmanned Aerial System Crash Scene Mapping Program
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

PX4 Simulation Results of a Quadcopter with a Disturbance-Observer-Based and PSO-Optimized Sliding Mode Surface Controller

1
Department of Mechanical & Industrial Engineering, Northeastern University, Boston, MA 02115, USA
2
Conducted Research While at Department of Mechanical & Industrial Engineering, Northeastern University, Boston, MA 02115, USA
3
Air Force Research Laboratory, Rome, NY 13441, USA
4
Department of Electrical & Computer Engineering, Northeastern University, Boston, MA 02115, USA
*
Author to whom correspondence should be addressed.
These authors contributed equally to this work.
Drones 2022, 6(9), 261; https://doi.org/10.3390/drones6090261
Submission received: 28 July 2022 / Revised: 8 September 2022 / Accepted: 14 September 2022 / Published: 18 September 2022
(This article belongs to the Section Drone Design and Development)

Abstract

:
This work designed a disturbance-observer-based nonlinear sliding mode surface controller (SMC) and validated the controller using a simulated PX4-conducted quadcopter. To achieve this goal, this research (1) developed a dynamic mathematical model; (2) built a PX4-based simulated UAV following the model-based design process; (3) developed appropriate sliding mode control laws for each degree of freedom; (4) implemented disturbance observers on the proposed SMC controller to achieve finer disturbance rejection such as crosswind effect and other mutational disturbances; (5) optimized the SMC controller’s parameters based on particle swarm optimization (PSO) method; and (6) evaluated and compared the quadcopter’s tracking performance under a range of noise and disturbances. Comparisons of PID control strategies against the SMC were documented under the same conditions. Consequently, the SMC controller with disturbance observer facilitates accurate and fast UAV adaptation in uncertain dynamic environments.

1. Introduction

An unmanned aerial vehicle (UAV) is an aircraft that does not have any human pilot, crew, or passengers on board. Quadrotor, a type of UAV, usually designed in an X configuration, with two diagonal motors rotating in one direction and two other diagonal motors rotating in the opposite direction to balance the torque. Quadrotors are under-actuated systems with four control inputs but six degrees of freedom. The attitude and altitude of the vehicle can be adjusted by controlling the four motors using pulse-width modulation (PWM) to increase and decrease thrust. Quadrotors are being used in an increasing number of civilian applications, including data collection, product delivery, and rescue searches [1,2]. In agriculture, quadcopters are used to spray pesticides and implement artificial rainfall [3]. In addition, UAVs have applications and developments in the fields of transportation, aerial photography, disaster relief, and artificial intelligence [4]. In the military field, quadcopters are used for combat, reconnaissance, patrol, and defense [5].
With the rapid development of science and technology, more and more disciplines and topics related to UAVs have been developed, such as UAV control [6] and UAV aerodynamics [7]. Recent research in the field of UAV control has progressed in several directions. Linear controllers have been proposed to control the position and the attitude of UAVs, for example, the Linear Quadratic Regulator (LQR) [6,8,9]. LQR is an optimal control strategy, primarily for linear systems, whereby a controller is designed by optimizing certain performance indicators such as control effort and state variables. The control law of LQR has a linear relationship with the state of the system and is applicable also to multi-input and multi-output systems (MIMO). However, the LQR design may require an accurate system model, may lack robustness, and would be more feasible for linear models [10].
Although Proportional Integral Derivative (PID) control is more than 100 years old, it is still the most commonly used control method for UAVs due to its simplicity, intuitiveness, reliable performance, and ease of adjustment. However, PID controllers do not perform well in the face of high-frequency noise and external disturbances due to their simplified linear model and simple structure. Therefore, many researchers have conducted experiments and proposed modifications over the traditional PID controller. For example, Goel et al. [11] introduces an adaptive Digital PID Control for unknown dynamics problems, and Dong and He [12] propose a fuzzy PID method for quadrotor aircraft. Meanwhile, to improve the robustness of the controller in the face of wind disturbances, Zhou et al. [13] uses a cascade PID attitude control in the inner-loop control of the UAV. The automatic PID gain tuned by reinforcement learning neural networks is also mentioned within the field of UAV control [14].
In addition, some researchers have proposed the backstepping method. Backstepping is a recursive design method, applicable to both linear control and nonlinear control. The main idea of this method is to obtain a feedback controller by recursively constructing the Lyapunov function of the system and selecting an appropriate control law so that the Lyapunov function is bounded along the trajectory of the closed-loop system and the trajectory tends to be stable. The controller is designed without excessive simplification of the model, and the control of the UAV is more accurate, and the response speed is improved [15]. However, due to its weak disturbance-rejection capabilities, researchers usually combine the backstepping control with other methods such as disturbance observer-based control [16] and adaptive backstepping control [17].
The sliding mode control (SMC) has been proven to be a robust way to maintain the stability of an unknown UAV dynamics [18,19]. Much work has been conducted in this area as well, for example, in [20] where researchers verified the second-order sliding-mode approach and implemented it on a fixed-wing micro aerial vehicle (MAV). The study verifies that the performance of the sliding-mode controller exceeds a benchmark classical controller. The basic idea of sliding-mode control is to design the switching hyperplane (sliding mode plane) according to the dynamic characteristics of the system and then force the system state to converge from outside the hyperplane to the switching hyperplane by the sliding-mode controller. Sliding-mode control can overcome uncertainties of the system and provide provable stability in the control of nonlinear systems [21]. Moreover, it has the characteristics of having a fast response, simple operation, and robustness to external environmental disturbances [22].
Other research on UAVs, such as attitude estimation for collision recovery [23], bidirectional thrust for aggressive, and inverted quadrotor flight [24]; swift maneuvers [25]; and ROS-based trajectory generation [26] have also been developed. A controller-tuning strategy for the MAV carrying a cable-suspended load is proposed in [27], which finds a reasonable trade-off between the fast displacements of the MAV and well-damped oscillations of the load. On the other hand, the system may lose robustness to non-ideal dynamics and uncertainty.
In general, a controller that can be adopted into a real-world autopilot requires far more adaptability, robustness, and sophistication. This is because it should handle the non-linearities of the UAV, under-actuation limitations, as well as sensor dynamics, sensor noise, and disturbances in the surrounding environment [28]. In this study, we chose the PX4 autopilot as the UAV simulation platform. Some previous studies have validated the advantages and feasibility of PX4 in developing new flight controllers. For example, Gomez et al. developed a new PX4 Optimal PID Tuning method [29], Saengphet et al. focused on PX4 implemented PID control [30], and Niit and Smit validated the PX4 autopilot architecture with adaptive control and demonstrated the robustness of the controller under ideal conditions [31].
Nowadays, we still have a wide variety of quadrotor control problems, since non-linearity and inter-dependency of UAV state variables within the mathematical model, as well as sensor implementations, noise, Kalman filters, and GPS delays, combined together are the main challenges in the design of fast responding, accurately tracking UAV controllers. In addition, the robustness of UAVs becomes a stringent requirement, in the face of turbulence effects and increasingly diverse external disturbances such as wind gusts [13] and additional loads [27]. Given the many strengths of sliding-mode controllers (SMC), this work focuses on the design of SMC that can be embedded into the PX4 framework. Simulation results show that SMC control outperforms PID control in many aspects, especially under large sensor noise and different types of random disturbances.
The design process of the SMC controller can be divided into six parts. (1) The development of a mathematical model in the MATLAB for the theory validation; (2) building a general PX4-based quadrotor as well as the test sites in a high-quality simulator; (3) developing a 6-degrees-of-freedom sliding-mode surface controller, which is a control scheme that includes an outer loop for position control and an inner loop for attitude control; (4) developing a 6-degreed-of-freedom disturbance observer that detects disturbance forces in the NED frame XYZ and disturbance moments around the NED frame XYZ axis; (5) optimizing SMC parameters based on an offline particle swarm optimization (PSO) method, a process that improves transient performance while reducing response time; and (6) verifying and comparing SMC against benchmark PID controllers in terms of settling time, overshoot, rise time, and tracking performance.
The article is presented in five sections. In Section 2, some assumptions and an introduction about the PX4 autopilot and baseline PID controllers (e.g., PID Position only controller, PID Rate based controller) will be described. The dynamic equations of quadrotors will be listed. The details of the SMC control structure and the disturbance observer will also be derived. Finally, the PSO algorithm will be implemented to optimize the SMC parameters. In Section 3, time simulations of UAV maneuvers are evaluated with SMC and PID controllers, including controllers optimized with PSO, and performances of these controllers are documented under noisy sensors and wind disturbances. In Section 4, we discuss the results, and, in Section 5, some future directions will be presented.

2. Materials and Methods

Computer simulation is used in many research areas to reduce experimental costs as well as the research and development cycle [10]. PX4 is an autopilot flight-control architecture and jMAVsim is the simulator we used in this study. One advantage of using PX4 and jMAVsim is that they provide a comprehensive model of the UAV and its sensors, as well as the UAV environment, such as wind speeds.
Table 1 shows the sensor properties: GPS interval (GPS_I), GPS Delay (GPS_D), GPS Start time (GPS_S), Accelerometer Noise (Acc_N), Gyroscope Noise (Gyr_N), Magnetometer Noise (Mag_N), and Pressure Sensor Noise (Prs_N), and Table 2 introduces the initial Magnetometer condition, including the set values and their deviations (N: north; E: east; D: down; Incl: Magnetic inclination; Decl: Magnetic declination; H-Magn: Magnetic field strength; T-Magn: Magnetic flux density). Table 3 displays the wind conditions (N: north; E: east; D: down; SET: current wind; DEV: deviation), and, in the beginning of simulations, the airflow speed has been set to zero, which will be adjusted in the wind-resistance-testing section. The final Table 4 gives the home position as well as the gravity setting (LAT: latitude; LON: longitude; ALT: altitude; Grav: Gravity; INIT: initial home position).
The general approach in this manuscript can be summarized as follows: We first utilized the mathematical model of the UAV to design the inner/outer loop SMC. The UAV model as well as the SMC architecture is next implemented in MATLAB/SIMULINK to verify the reliability of SMC. This architecture also includes disturbance observers who are able to compensate against disturbances. Benchmark PID controllers are also implemented in these simulations. Next, PSO was used as an offline optimization tool to intelligently iterate the controller’s parameters to improve, for example, the settling time, overshoot, and tracking performance.
Once the SMC and PID controllers performed as expected in the ideal mathematical model, we next port them to the PX4-based simulated UAV as shown in Figure 1, where we can simulate and evaluate the UAV flight dynamics, by customizing the physical parameters of the UAV, the noise range of the sensors, the ambient magnetic field, and the environmental disturbances. Finally, we can quantify the performance of SMC and PID based on simulation data collected from PX4 flight tests.

2.1. Baseline PID Controllers and Quadrotor Dynamics Equations

Two predefined proportional-integral-derivative (PID) controllers were chosen as the baseline and compared with SMC. The first PID controller is a pure-position PID controller, which is widely used for the position control of quadcopters [32]. This controller can track the desired attitude, including the pitch, roll, and yaw, based on only position errors. In its control loop, shown in Figure 2, three separate PID modules compare the difference between the current XYZ position values and the desired XYZ position values, and those PID for XY positions help generate the desired rotation angles for roll and pitch. In our simulations, we limit the maximum rotation angle in roll and pitch to 50 degrees. The inputs to the PID controllers are errors in X, Y, Z, Y a w , P i t c h , and R o l l . The outputs are virtual control signals τ T h r u s t , τ P i t c h , τ R o l l , τ Y a w , which can be converted to PWM signals in four channels to the motors via the mixer.
The second PID controller is a rate controller shown in Figure 3, which controls the speed of the UAV in addition to position tracking, so this PID controller has the potential to offer greater flight dynamic responses, as it acts on the “rate” [33]. In short, the rate controller tracks the desired trajectory based on the velocity error, while the pure position controller tracks based on position error. In our experiments, the velocity limits are set to 20 m/s in the XY direction and 10 m/s in the Z direction. The inputs to the controllers are errors in X, V x , Y, V y , Z, V z , Y a w , P i t c h , and R o l l . The outputs are virtual control signals, which are converted to PWM signals in four channels to the motors via the mixer.
We use the X mode quadcopter drone in PX4, as shown in Figure 4, and NED (north, east, and down) as the global coordinate system. The UAV dynamics equations are expressed as [34]:
x ¨ = 1 m [ ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) · ( T 1 + T 2 + T 3 + T 4 ) + K 1 · x ˙ · | x ˙ | ] y ¨ = 1 m [ ( sin ϕ cos ψ + cos ϕ sin θ sin ψ ) · ( T 1 + T 2 + T 3 + T 4 ) + K 1 · y ˙ · | y ˙ | ] z ¨ = 1 m [ ( cos ϕ cos θ ) ( T 1 + T 2 + T 3 + T 4 ) + K 1 · z ˙ · | z ˙ | ] + g p ˙ = 1 J x [ 2 2 l ( T 2 + T 3 T 1 T 4 ) q · r ( J z J y ) K 2 · p · | p | ] q ˙ = 1 J y [ 2 2 l ( T 1 + T 3 T 2 T 4 ) p · r ( J x J z ) K 2 · q · | q | ] r ˙ = 1 J z [ ( Q 1 + Q 2 Q 3 Q 4 ) p · q ( J y J x ) K 2 · r · | r | ] ϕ ˙ = p + q · tan θ sin ϕ + r · tan θ cos ϕ θ ˙ = q · cos ϕ r · sin ϕ ψ ˙ = q sin ϕ cos θ + r cos ϕ cos θ
where the x , y , z directions are in the global coordinate system, x , y , z are in drone’s body coordinate system; p , q , r are angular velocity in the drone body frame; ϕ , θ , ψ are Euler angles; m is the mass of the drone; l is the distance between the center of the propeller and the center of the drone; J x , J y , J z are the moment of inertia; T 1 4 are the thrusts of each propeller; Q 1 4 are anti-torques of each motor given by the propellers; K 1 is the coefficient of air drag force; K 2 is the air drag torque coefficient; T _ m a x is the full thrust of motor; and Q _ m a x is anti-torque at the full thrust of the motor. x , y , z , p , q , r , ϕ , θ , ψ are also shown in Figure 4. The aerodynamic forces are modeled as a nonlinear drag opposing the motion, and the aerodynamics moments are modeled as a nonlinear drag moment opposing the rotation:
F d r a g = K 1 · v · | v | M d r a g = K 2 · w · | w |
The thrust of each propeller T 1 4 and torque Q 1 4 are determined by normalized signal v 1 4 .
T 1 4 = T m a x · v 1 4 Q 1 4 = Q m a x · v 1 4
where:
v 1 v 2 v 3 v 4 = ( 1000 · 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 · τ T τ P τ R τ Y P m i n ) · 1 P m a x P m i n ,
where τ T , τ P , τ R ,   and   τ Y represent the τ T h r u s t , τ P i t c h , τ R o l l ,   and   τ Y a w virtual control inputs to control the thrust, pitch motion, roll motion, and yaw motion of the drone, respectively, the ranges of the virtual control inputs are set as: 1 τ T 2 ; 0.05 τ P 0.05 ; 0.05 τ R 0.05 ; 0.1 τ Y 0.1 ; and P m a x , P m i n , which are represented as P W M _ m a x , P W M _ m i n , which are the maximum and minimum values in the process of PWM normalization, respectively. Equation (4) is a normalization process, which is called “mixing” in PX4 architecture, the structure of the 4 × 4 matrix which provides the virtual control signals is decided by the motor number and propeller spin direction. Mixing means to receive commands (e.g., turn right) and translate them to actuator commands, here with regards to motors or servos. According to the PX4 definition, P W M _ m a x = 2000 and P W M _ m i n = 1000 . Substituting these into Equation (4), we have:
v 1 + v 2 + v 3 + v 4 v 2 + v 3 v 1 v 4 v 1 + v 3 v 2 v 4 v 1 + v 2 v 3 v 4 = 4 τ T 4 4 τ R 4 τ P 4 τ Y
The physical parameters of the UAV dynamics model are shown in Table 5.

2.2. Sliding Mode Controller

Sliding-mode control (SMC), a type of variable structure control (VSC), is a nonlinear control method [22]. The non-linearity is created by the discontinuity in the control law as explained next. The sliding-mode control designs a sliding surface (usually expressed as s = 0 ), and it has different control actions, usually expressed as u = u + u , to make the system states approach to the sliding surface depending on the sign of s. SMC has the advantages of a fast response, robustness, and handling nonlinear dynamical systems. However, when the state trajectory reaches the sliding surface, instead of sliding along the surface perfectly, it will rapidly switch between both sides of the surface. Hence, it is common for SMC to have chattering problems.
The overall control structure of the SMC controller is shown in Figure 5. Each SMC is equipped with a disturbance observer.

2.2.1. SMC X-Y Position Controller

The position controllers of x and y are similar. Figure 6 shows an example of how the system approaches the desired sliding surface. Here the x and y axes are the error e and derivative of error e ˙ , respectively, and X 0 is the initial state, which means there is some error between the initial state and desired state. Naturally, the desired final value should be ( e , e ˙ ) = ( 0 , 0 ) , which means the error and the derivative of the error must both go to zero, and the system reaches its steady state. Moreover, the blue line is the sliding surface that should be designed, and the system states should approach this line and slide over the line toward ( e , e ˙ ) = ( 0 , 0 ) .
In this process, the motion of the system state can be divided into two types: one is the reaching mode (the process that the system state leaves X 0 and moves toward the sliding surface), which is controlled by control law u; and the other is called sliding mode (the process that the system state approaches the desired value along the sliding surface and remains on this surface, moving toward the origin ( 0 , 0 ) ), which is defined by the sliding-mode surface. To obtain high performance of the state trajectories, we should carefully design the characters of both the control laws and the sliding surfaces. Accordingly, the design of the sliding mode controller is performed in two steps. A reasonable sliding surface makes the system to have quality performance in the sliding mode, and the design of the control law u needs to ensure that the system can reach the sliding-mode surface from any state. According to (1):
x ¨ = 1 m [ u 1 · Thrust + K 1 · x ˙ · | x ˙ | ] ,
where u 1 = sin ϕ sin ψ + cos ϕ sin θ cos ψ is the control signal and Thrust  = T 1 + T 2 + T 3 + T 4 . The sliding surface is selected as:
s = a 1 e + e ˙ ,
where a 1 > 0 , and e = x d e s _ x is the tracking error. To perform the stability analysis, we choose V ( s ) = 1 2 s 2 > 0 as the Lyapunov function. If V ˙ ( s ) < 0 , then the system is stable, since this implies s approaches 0 (i.e., e 0 and e ˙ 0 ). To this end, we obtain V ˙ ( s ) as:
V ˙ ( s ) = s s ˙ = s ( a 1 e ˙ + e ¨ ) = s ( a 1 e ˙ + x ¨ d e s _ x ¨ ) = s [ a 1 e ˙ 1 m ( u 1 · Thrust + K 1 · x ˙ · | x ˙ | ) d e s _ x ¨ ] .
Next, we propose the control law:
u 1 = k 1 · m Thrust · s a t ( s ϵ ) + k 2 · m Thrust · e ˙ + c · m Thrust · s K 1 · x ˙ · | x ˙ | Thrust m · d e s _ x ¨ Thrust ,
where:
k 1 = k 1 , ( b 1 · | e | + b 2 · | e ˙ | ) < k 1 ( b 1 · | e | + b 2 · | e ˙ | ) , ( b 1 · | e | + b 2 · | e ˙ | ) k 1 .
In (9), the saturation function is used to solve the chattering problem due to the switches in the sign of s:
s a t ( s ϵ ) = s ϵ , | s | < ϵ s i g n ( s ϵ ) = 1 , s ϵ 1 , s ϵ , | s | ϵ ,
where ϵ > 0 is a user-defined constant value. Here, we use ϵ = 0.5 . Inserting (9) into (8), we obtain:
V ˙ ( s ) = s [ ( a 1 k 2 ) · e ˙ k 1 · s a t ( s ϵ ) c · s ] .
From Equation (12), we can derive that a 1 k 2 = 0 k 1 > 0 c > 0 is the sufficient condition for V ˙ ( s ) < 0 to hold. These are the conditions for stability in the x direction. When optimizing the SMC using PSO in Section 2.4, these conditions will be incorporated into PSO to make sure PSO will optimize the drone dynamics while respecting theoretical stability.
Figure 6 shows how e and e ˙ reach the sliding surface. The data used in this figure are from one of the simulation tests conducted with PX4. Due to the aforementioned sensor noise, we observe from the zoom-in figure that e and e ˙ do not reach (0,0) perfectly.
Due to the outputs of the SMC, the position controller should be desired values of roll angle and pitch angle to be passed to the attitude controller, we need to calculate the desired ϕ and θ , see Figure 5. Recall that we have u 1 = ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) from the x controller, and, similarly, we use the same SMC controller structure for the y direction, where it is easy to show that the control law will be u 2 = ( sin ϕ cos ψ + cos ϕ sin θ sin ψ ) . Then, using u 1 , u 2 , we derive the desired ϕ and θ quantities as:
ϕ = arcsin ( u 1 sin ψ u 2 cos ψ ) θ = arcsin u 1 cos ψ + u 2 sin ψ cos ϕ .
The above quantities are denoted below by d e s _ ϕ and d e s _ θ , respectively.

2.2.2. SMC Altitude Controller

According to Equations (1), (3), and (5):
z ¨ = 1 m [ ( cos ϕ cos θ ) · T m a x ( 4 τ T 4 ) + K 1 · z ˙ · | z ˙ | ] + g ,
and τ T is the control signal. The sliding surface is designed as:
s = a 2 e + e ˙ ,
where a 2 > 0 , and e = z d e s _ z . Let the control law be:
τ T = m 4 cos θ cos ϕ · T m a x · k 3 · s a t ( s ϵ ) + k 4 · e ˙ cos θ cos ϕ + K 1 · z ˙ · | z ˙ | + m g m · d e s _ z ¨ 4 T m a x · cos ϕ cos θ + 1 ,
where:
k 3 = k 3 , ( b 3 · | e | + b 4 · | e ˙ | ) < k 3 ( b 3 · | e | + b 4 · | e ˙ | ) , ( b 3 · | e | + b 4 · | e ˙ | ) k 3 ,
with k 3 > 0 and k 4 > 0 . Proposing again V ( s ) = 1 2 s 2 > 0 , it is possible to render V ˙ ( s ) < 0 for τ T in (16). To show this, we calculate V ˙ ( s ) as:
V ˙ ( s ) = s s ˙ = s ( a 2 e ˙ + z ¨ d e s _ z ¨ ) = s [ ( a 2 4 T m a x m · k 4 ) e ˙ 4 cos ϕ cos θ · T m a x m · k 3 · s a t ( s ϵ ) ] ,
Hence, a 2 4 T m a x m · k 4 = 0 k 3 > 0 satisfy V ˙ ( s ) < 0 .
In Figure 7, we show how e and e ˙ approach the sliding surface in the z direction in one of the simulation tests.

2.2.3. SMC Attitude Controller

Different from the position control, as for the attitude controllers, the reaching law is designed as the following isokinetic form: s ˙ = c · s g n ( s ) . Firstly, we present the roll-angle control. According to Equations (1), (3), and (5), we derive the following relationship:
ϕ ¨ = p ˙ + q ˙ · tan θ s i n ϕ + q · ( 1 cos 2 θ · θ ˙ · sin ϕ + tan θ cos ϕ · ϕ ˙ ) + r ˙ · tan θ cos ϕ + r · ( 1 cos 2 θ · θ ˙ · cos ϕ tan θ sin ϕ · ϕ ˙ ) = 2 2 · l · T m a x J x · τ R 2 2 · l · T m a x · tan θ sin ϕ J y · τ P + 4 Q m a x tan θ cos ϕ J z · τ Y + f ϕ ,
where f ϕ :
f ϕ = q · ( 1 cos 2 θ · θ ˙ · sin ϕ + tan θ cos ϕ · ϕ ˙ ) + r · ( 1 cos 2 θ · θ ˙ · cos ϕ tan θ sin ϕ · ϕ ˙ ) J z J y J x · q r K 2 J x · p · | p | J x J z J y · p r · tan θ sin ϕ K 2 J y · q · | q | · tan θ sin ϕ J y J x J z · p q · tan θ cos ϕ K 2 J z · r · | r | · tan θ cos ϕ .
Next, we propose a sliding surface:
s ϕ = a 3 e ϕ + e ˙ ϕ ,
where a 3 > 0 and e ϕ = ϕ d e s _ ϕ . The control law:
τ R = k 5 · s a t ( s ϕ ϵ ) + k 6 · e ˙ ϕ J x J y · tan θ sin ϕ · τ P + 4 J x · Q m a x · tan θ cos ϕ 2 2 J z · l · T m a x · τ Y + J x 2 2 · l · T m a x · ( f ϕ d e s _ ϕ ¨ )
can guarantee stability. To show this, let V ( s ) = 1 2 s 2 > 0 . Then:
V ˙ ( s ) = s ϕ s ˙ ϕ = s ϕ ( a 3 e ˙ ϕ + ϕ ¨ d e s _ ϕ ¨ ) = s ϕ [ ( a 3 2 2 · l · T m a x J x · k 6 ) e ˙ ϕ 2 2 · l · T m a x J x · k 5 · s a t ( s ϕ ϵ ) ] .
Thus, we obtain a 3 2 2 T m a x l J x k 6 = 0 k 5 > 0 to make V ˙ ( s ) < 0 .
Secondly, for the pitch-angle controller, consider similarly,
θ ¨ = q ˙ · cos ϕ q · sin ϕ · ϕ ˙ r ˙ · sin ϕ r · cos ϕ · ϕ ˙ = cos ϕ · 2 2 · l · T m a x J y · τ P 4 Q m a x sin ϕ J z · τ Y + f θ ,
where f θ :
f θ = ( q · sin ϕ · ϕ ˙ + r · cos ϕ · ϕ ˙ + J x J z J y · p r · cos ϕ + K 2 J y · q · | q | · cos ϕ ) + J y J x J z · p q · sin ϕ + K 2 J z · r · | r | · sin ϕ .
We next propose the sliding surface:
s θ = a 3 e θ + e ˙ θ ,
with a 3 > 0 and e θ = θ d e s _ θ . The control law:
τ P = 1 cos ϕ · k 5 · s a t ( s θ ϵ ) + k 6 cos ϕ · e ˙ θ 4 J y · Q m a x · tan ϕ 2 2 J z · l · T m a x · τ Y + J y cos ϕ · 2 2 · l · T m a x · ( f θ d e s _ θ ¨ )
can guarantee stability. To show this, let V ( s ) = 1 2 s 2 > 0 , then:
V ˙ ( s ) = s θ s ˙ θ = s θ ( a 3 e ˙ θ + θ ¨ d e s _ θ ¨ ) = s θ [ ( a 3 2 2 · l · T m a x J y · k 6 ) e ˙ θ cos θ · 2 2 · l · T m a x J y · k 5 · s a t ( s θ ϵ ) ] .
Hence, we obtain a 3 2 2 T m a x l J y k 6 = 0 k 5 > 0 to make V ˙ ( s ) < 0 .
Thirdly, for the yaw angle, we have:
ψ ¨ = q ˙ · sin ϕ cos θ + q · cos ϕ cos θ · ϕ ˙ + sin ϕ sin θ · θ ˙ cos 2 θ + r ˙ · cos ϕ cos θ + r · sin ϕ cos θ · ϕ ˙ + cos ϕ sin θ · θ ˙ cos 2 θ = cos ϕ · 4 Q m a x cos θ · J z · τ Y sin ϕ · 2 2 · l · T m a x cos θ · J y · τ P + f ψ ,
where f ψ :
f ψ = q · cos ϕ cos θ · ϕ ˙ + sin ϕ sin θ · θ ˙ cos 2 θ + r · sin ϕ cos θ · ϕ ˙ + cos ϕ sin θ · θ ˙ cos 2 θ cos ϕ ( J y J x ) cos θ · J z · p q cos ϕ · K 2 cos θ · J z · r · | r | sin ϕ ( J x J z ) cos θ · J y · p r sin ϕ · K 2 cos θ · J y · . q · | q |
With the sliding surface:
s ψ = a 4 e ψ + e ˙ ψ ,
where a 4 > 0 and e ψ = ψ d e s _ ψ . The control law:
τ Y = cos θ cos ϕ · k 7 · s a t ( s ψ ϵ ) k 8 · cos θ cos ϕ · e ˙ ψ + 2 2 J z · l · T m a x · tan ϕ 4 J y · Q m a x · τ P J z · cos θ 4 · Q m a x · cos ϕ · ( f ψ d e s _ ψ ¨ )
can guarantee stability. Stability analysis follows similarly, where we set V ( s ) = 1 2 s 2 > 0 and obtain:
V ˙ ( s ) = s ψ s ˙ ψ = s ψ ( a 4 e ˙ ψ + ψ ¨ d e s _ ψ ¨ ) = s ψ [ ( a 4 4 Q m a x J z · k 8 ) e ˙ ψ cos ϕ · 4 Q m a x cos θ · J z · k 7 · s a t ( s ψ ϵ ) ] .
Hence, we obtain a 4 4 Q m a x J z · k 8 = 0 k 7 > 0 to make V ˙ ( s ) < 0 .
Finally, based on Equations (22), (27), and (32), we have:
τ R τ P τ Y = A 1 B ,
where:
A = 1 J x J y · tan θ sin ϕ 4 J x · Q m a x · tan θ cos ϕ 2 2 J z · l · T m a x 0 1 4 J y · Q m a x · tan ϕ 2 2 J z · l · T m a x 0 2 2 J z · l · T m a x · tan ϕ 4 J y · Q m a x 1
B = k 5 · s a t ( s ϕ ϵ ) + k 6 · e ˙ ϕ + J x 2 2 · l · T m a x · ( f ϕ d e s _ ϕ ¨ ) 1 cos ϕ · k 5 · s a t ( s θ ϵ ) + k 6 cos ϕ · e ˙ θ + J y cos ϕ · 2 2 · l · T m a x · ( f θ d e s _ θ ¨ ) cos θ cos ϕ · k 7 · s a t ( s ψ ϵ ) k 8 · cos θ cos ϕ · e ˙ ψ J z · cos θ 4 · Q m a x · cos ϕ · ( f ψ d e s _ ψ ¨ ) .
In other words, we have a unique closed-form solution for τ R , τ P , and τ Y based on all known and measured quantities. Combining τ R , τ P , and τ Y with τ T in (16), we can construct, based on the mixer, the PWM signals to be sent to each of the UAV motors.
Figure 8 shows how e and e ˙ approach the sliding surface in the yaw motion in one of the simulation tests. Notice that, because of sensor noise, the state of the system cannot come back to (0,0) perfectly. Therefore, the state will move around the origin with a relatively small error due to noise.

2.3. Disturbance Observer

The SMC controller includes six separate disturbance observers, one for each of X, Y, Z, Yaw, Pitch, and Roll (see Figure 5). In the X, Y, and Z directions, disturbance observers estimate the horizontal and vertical forces, while in the Yaw, Pitch, and Roll directions, disturbance observers estimate the disturbance torque around each axis. The estimated disturbance will then be fed back into the loop and thus be compensated by the SMC controller [16], see Figure 9.
We present below the disturbance observers of x and pitch controllers as examples, since the disturbance observers for the other four directions are quite similar to these two examples. Firstly, for the x controller:
x ¨ = 1 m [ ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) · Thrust + K 1 · x ˙ · | x ˙ | ] + d ,
where d is the disturbance assumed to be a continuous signal, independent of the UAV states, and u 1 = sin ϕ sin ψ + cos ϕ sin θ cos ψ is the control signal. Hence, the disturbance observer is formed as:
d o b = z i n + k o b x ˙ z ˙ i n = k o b · d o b + k o b · 1 m [ ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) · Thrust + K 1 · x ˙ · | x ˙ | ] ,
where d o b is the value, which the observer shows, and z i n is an intermediary variable. So, the error between the actual disturbance and the value of the disturbance observers e * = d d o b reads:
e ˙ * = d ˙ d ˙ o b = d ˙ z ˙ i n k o b x ¨ = d ˙ + k o b · d o b k o b · 1 m [ ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) · Thrust + K 1 · x ˙ · | x ˙ | ] + k o b · 1 m [ ( sin ϕ sin ψ + cos ϕ sin θ cos ψ ) · Thrust + K 1 · x ˙ · | x ˙ | ] k o b · d = k o b · e * + d ˙ .
Therefore, if d ˙ is bounded, then the disturbance error e * is bounded as along k o b > 0 . Moreover, when d ˙ 0 , we have e * 0 . Next, to eliminate the steady-state error caused by disturbances, we should bring the d o b back to the controller. Therefore, to eliminate the influence of disturbance, we bring back the value of the observed disturbance and obtain the new control law:
u 1 n e w = u 1 o r i g i n a l + d o b · m Thrust .
Similarly, for the pitch controller:
q ˙ = 1 J y [ 2 2 · T m a x · l · τ P p · ( J x J z ) K 2 · q · | q | ] + d ,
where d is the generic notation for disturbance and should be considered different from that in (37). We have the disturbance observer as follows:
d o b = z i n + k o b · q z ˙ i n = k o b · d o b k o b · 1 J y [ 2 2 · T m a x · l · τ P p · r ( J x J z ) K 2 · q · | q | ] .
Hence, the new control law reads:
τ P n e w = τ P o r i g i n a l + d o b · J y 2 2 · T m a x · l ,
where we select k o b = 5 .

2.4. Particle Swarm Optimization for PIDs and SMC

Notice that, in Section 2.2, we established the theoretical conditions guaranteeing the stability of the SMC-drone dynamics based on the Lyapunov stability theory. The next question is then how to optimize the SMC parameters for improved drone performance without violating stability. Since stability conditions are established in Section 2.2, these conditions can guide us to carefully tune the SMC controller gains. To this end, we propose to utilize PSO, as we explain next.

2.4.1. PSO Optimization Procedures

Particle-Swarm Optimization (PSO) is an evolutionary computational method that originated from the study and simulation of birds’ predatory behavior [35]. PSO is inspired by the fact that we can imagine birds finding food by using a set of particles to solve a problem. Based on the observation of the activity behavior of a group of birds, the PSO algorithm uses the information-sharing property among individuals in a group to change the movement of the whole group in the problem-solving space from disorder to order, so as to obtain the optimal solution. In addition, compared with other swarm-intelligence algorithm methods [27] and back propagation neural network algorithms [36], PSO has the advantages of fewer parameters to be adjusted, fast convergence, and simple algorithmic structure [37,38,39].
In detail, the basic idea of PSO is to consider a swarm of particles as a population of potential solutions to a problem. According to some simple mathematical formulations, these particles can move in the problem-solving space to search for solutions. The movement of each particle is guided by its individual best-known position and the best-known position of the entire population of particles (which is also called the global best position). In addition, the individual best position and the global best position should be updated when the particles find other better positions. Thus, when this process is repeated, the whole swarm is expected to move toward a solution of higher quality.
In view of the above, the mathematical expressions for velocity and position updates are given by:
v i j k + 1 = ω v i j k + c 1 r 1 P b e s t i j x i j k + c 2 r 2 G b e s t j x i j k x i j k + 1 = x i j k + l r · v i j k + 1 ,
where 1 i N , 1 j D , 1 k K . Here, N is the number of particles in the swarm, D is the dimension of particle (the number of the parameters), K is the maximum number of iterations, x i j k + 1 is the position of particle i in the dimension j at iteration k, v i j k + 1 is the velocity of particle i in the dimension j at iteration k, P b e s t i j is a personal best position of particle i in the dimension j, G b e s t i j is a global best position of all particles in the dimension j, ω is the inertia weight factor, c 1 and c 2 are the acceleration constants, r 1 and r 1 are random numbers in the interval [0, 1], and l r is the learn rate ( 0 l r 1 ), which is the proportion at which the velocity affects the movement of the particle (where l r = 0 means velocity will not affect the particle at all, and l r = 1 means velocity will fully affect the particle) [37].
To choose the P b e s t and G b e s t of the particles, we use a scoring system concerning three standards: the Integraltime absolute error (ITAE), settling time (Ts), and the absolute value addition of overshoot and undershoot between desired trajectory and actual flight path ( O s U s = a b s ( o v e r s h o o t ) + a b s ( u n d e r s h o o t ) ). As the performance of the controller is superior when all these three standards have smaller values, and we want the change of scores be more sensitive when the controller has a satisfactory performance, we use the normal distribution to build the score model. Moreover, we divide the parameters into three parts: to control the x and y motion, to control the z motion, and to control the yaw angle. Each part will have their own scoring system, and the general formula is as follows:
S c o r e i = 100 · 1 σ i 2 π e ( x i ) 2 2 σ i 2 ,
where S c o r e i is the score when the standard has x i value, where x i is either ITAE, Ts, or OsUs, and the value of σ i is shown in Table 6. Thus, we have the scores shown in Figure 10.
The flow chart of the PSO algorithm is shown in Figure 11. In this paper, the parameter initialization process is omitted, but the core idea is to initialize the parameters within a reasonable range of the SMC parameters respecting the stability criterion, and the initialization script will select the initial particle population. Then, the flight performance is scored according to the simulation of the mathematical UAV model. Based on the scoring results, the algorithm can find the individual best position of each particle and the best-known position of the swarm of all particles; thus, the position and velocity of the particles can be updated and iterated based on the mathematical formula. Finally, after a sufficient number of iterations, we can arrive at a final solution to the problem.
For the case of SMC, optimization can iterate while respecting the theoretical stability conditions derived in Section 2.2 on the SMC parameters. In other words, the SMC stability conditions can be incorporated into PSO to assure that PSO always suggests a stabilizing set of SMC parameters. On the other hand, since we do not have explicit stability conditions for the PID controllers, there is no guarantee that the PSO at each iteration will yield stabilizing parameters. However, we judiciously select the initial PID gains in view of PX4 documentation and find out that PSO eventually yields optimized and stabilizing PID gains.

2.4.2. PSO-Tuned Results

In the simulations, we choose:
  • The initial state: x 0 = 0 m , y 0 = 0 m , z 0 = 0 m , ψ 0 = 0 d e g r e e s ;
  • The desired position and yaw angle: x d = 4 m , y d = 4 m , z 0 = 20 m , ψ 0 = 90 d e g r e e s ;
  • The PSO algorithm parameters: ω = 0.4 , c 1 = 0.5 , c 2 = 0.5 , l r = 0.5 .
During the PSO tuning, we observed the change of scores and values of the three predefined standards in Figure 12.
From Figure 12, the total score keeps increasing, even though one of the criteria fluctuates up and down, and this swarm of particles almost finds the optimal solution at around 20 iterations. Finally, after 100 iterations, we obtain a high total score and small ITAE, short settling time, and low overshoot and undershoot, which means expected flight performance. The optimized parameters for SMC controller are provided in Table 7, and the fixed parameters for SMC are listed as following: ϵ = 0.5 , k 1 = 0.001 , k 3 = 0.1 , k o b = 5 .
It is important to note that the above PSO algorithm is run offline, meaning it is iterated first in conjunction with the SIMULINK model, to reveal the optimum control parameters. Once these parameters are revealed (Table 7), we can then implement them in SIMULINK as well as in PX4 for comparison purposes. In Figure 13, we compare the performance of the initialized and optimized SMC parameters and observe an improvement in the controller performance. In the left panel of Figure 13, the settling time of XYZ is significantly reduced, and, in the right panel of Figure 13, the pitch and roll change rapidly and the yaw angle converges quickly to the reference value.
As a control group, we also need to use the same PSO method to adjust the PID position and PID rate parameters. For the sake of brevity, here we provide only the results of PSO, see Table 8 and Table 9.

3. Simulation Results

Now that we have PSO-optimized SMC and PSO-optimized PID controllers at hand, we next incorporate these controllers into PX4 under various scenarios. We note here that PSO is implemented offline a priori. In PX4 simulations, we do not perform PSO optimization in real time.

3.1. Trajectory Tracking Performance

In the previous sections, the SMC controller was designed on a fully nonlinear mathematical model of a quadrotor aircraft. In this section, the SMC controller has been continuously developed under the PX4 architecture and validated with a PX4-simulated UAV, which means that environmental noise and uncertainties have been taken into account. Several test scenarios, including step tracking, slope tracking, and force and torque disturbances have been applied. All small oscillations in position and attitude are considered to be the combined result of sensor noise, wind interference, discretization, time delay, and vehicle dynamics uncertainty. As a baseline for comparison, a PSO-tuned PID-position controller and a PSO-tuned PID-rate were also tested.
The following is the list of standards used to evaluate the performance of the controllers:
  • The Maximum Overshoot (Mp);
  • The Settling time (Ts);
  • The Rise time (Tr);
  • The Integral absolute error (IAE);
  • The Integral time absolute error (ITAE);
  • The Integral square error (ISE);
  • The Integral time squared error (ITSE).
The IAE, ITAE, ISE, and ITSE are assumed to be measured starting from two times the settling time (2 · T s ) and last for 10 s (2 · T s + 10), during which we assume that the UAV reached a relatively stable state.
We would like to find out which controller has less overshoot, less settling time, and smaller IAE, ITAE, ISE, and ITSE. However, rise time is not our main concern, as it can easily lead to large overshoot and significant wander of the UAV. From our point of view, the desired controller should enable smooth, rapid, and accurate UAV movement.

3.1.1. Step Profile Tracking

In the first case of this study, the UAV is controlled to track a step contour in terms of distance, height, and angle, respectively. Throughout the time axis, the UAV should rise from 0 m to 20 m, starting at 5 s and moving from 0 m to 4 m in the X and Y directions, starting at 15 s, and rotating 90 degrees starting at 40 s, as shown in the black dash reference curves in Figure 14.
Table 10 summarizes the simulation results, which show the SMC controller has the smallest overshoot and the smallest settling time. Compared to the PID controllers, its rise time becomes slightly longer in the horizontal position (X and Y), but slightly shorter in height and angle (Z and YAW). Furthermore, we analyzed the zoom-in figures of z and yaw motion. The PID-based controllers need a longer time to reach steady states, which leads to a small steady-state error even after a long period of time. In contrast, the SMC UAV does not have many errors, given its IAE, ITAE, ISE, and ITSE values are relatively small. Figure 14 shows that SMC motion has a smaller range and fewer oscillations, and its time derivative is smaller, compared to the PID, especially in terms of pitch and roll tracking. If we assume that smoothness and stability have greater weights in our evaluation, SMC is more preferable.
It can be observed that the proposed SMC outperforms the other two PID control methods in terms of tracking accuracy. The benchmark PID-position and PID-rate controllers can stabilize the simulated UAV under PX4 architecture but with a larger overshoot. These phenomena are undesirable in reality, especially when tracking accuracy and stability are required. On the other hand, the proposed SMC can exhibit much improved tracking performance.

3.1.2. Ramp Profile Tracking

The second case focuses on the ramp tracking performance. This is also important when the UAV is intended to perform curvilinear trajectory tracking. We separate the ramp experiment into four discrete scenarios: (a) ramp only in the X direction; (b) ramp only in the Y direction; (c) ramp only in the Z direction; and (d) ramp only in the Yaw.
The tracking results for this case study are given in Figure 15, where the error histograms in panels b, d, f, and h show that the PID-rate-based controller design exhibits much larger tracking error (blue bars shift away from the origin in the error histograms). Although the PID-position controller gives a finer tracking performance than the PID-rate, see panels a, c, e, and g, and behaves similarly to the SMC, it is more oscillatory.
In detail, for X and Y slope tracking, SMC fits the reference value best (compare IAE, ITAE, ISE, and ITSE on Table 10), and the PID-position controller, however, has a relatively smaller tracking error than the PID-rate controller (Table 10); it continuously oscillates around the reference slope (panels a, c), which results in a wider position error distribution around the zero-error than SMC, see panels b and d. A similar result arises in the Z-axis slope tracking, where the green area (SMC) is larger than the red area (PID-position) near the zero-error boundary, see panel f. Finally, the yaw angular tracking performance of SMC outperforms the PID controllers, see panel g zoom-in plot.

3.1.3. Complex Trajectory Tracking

Finally, we introduce a complex trajectory which is a combination of X, Y, and Z position set-points. We set these references as: x = 10 · cos ( 0.125 t + 3.75 ) · sin ( 0.25 t 7.5 ) ; y = 10 · sin ( 0.125 t 3.75 ) · sin ( 0.25 t 7.5 ) ; z = 10 . The UAV takes off at 0 s and starts tracking the trajectory at 30 s . The result is shown in Figure 16a (top view), from which we can see the trajectory resembles a flower. To compare the overall tracking performance of three controllers, the figure also introduces a timeline in Figure 16b,c.
From the top view of Figure 16a, we observe that SMC tracks the desired trajectory during the simulation, while PID-position- and PID-rate-based controllers show notable tracking errors and deviations continuously. Panel a also shows that PID-position produces oscillations around the reference (overshoots and undershoots). On the other hand, from the time trace of x and y in Figure 16b,c, we observe the PID-rate controller has a persistent time delay (about 1 s) compared with SMC and the desired set-points.
Figure 17 and Figure 18 show the error histograms of the SMC controller and the PID controllers during the flower-pattern trajectory-tracking simulations. These two figures show that the position errors of SMC are mostly concentrated around zero with respect to the both x and y directions, i.e., −0.19 m to +0.06 m in the x direction and −0.08 m to +0.23 m in the y direction; conversely, the position-error distribution of PID controllers is relatively scattered across the range of errors in the histograms. We can observe that SMC responded quicker than the PID controllers from Figure 16 (see when the slope changes in the desired trajectory), and, meanwhile, it produces smaller position-tracking errors as evident in Figure 17 and Figure 18. Therefore, combining the performances of the tracking accuracy and tracking speed, SMC demonstrates superiority over these two PID controllers with respect to complex trajectory tracking.

3.2. Disturbance Resistance

Accurate control of position and altitude in environments with disturbances is critical to the safety of UAVs. In this study, the UAV was controlled to maintain its position under disturbances in different directions. There are six discrete scenarios: (1) Constant force disturbance in X direction, (2) Constant force disturbance in Y direction, (3) Constant force disturbance in Z direction, (4) Constant torque disturbance around X axis, (5) Constant torque disturbance around Y axis, and (6) Constant torque disturbance around Z axis.

3.2.1. Force Disturbances

The tracking performance, together with their force disturbance estimates from the proposed disturbance observer, is illustrated in Figure 19. In scenario (1), panel (a) and panel (b) correspond to a constant force disturbance added in the X direction as 1 m/s 2 ; in scenario (2), panel (c) and panel (d) correspond to a constant force disturbance added in the Y direction as 1 m/s 2 ; and in scenario (3), panel (e) and panel (f) correspond to a constant force disturbance added in the Z direction as 10 m/s 2 .
Despite the relatively small gain used in the design of the observer ( k o b = 5 ), disturbance estimates can quickly converge to the true value of the disturbance. It can also be observed that the proposed SMC controller outperforms the other two controllers in resisting the force disturbance. In both the vertical and horizontal directions, the PID-position and PID-rate controllers have large oscillations in the presence of disturbance bursts, and they have large steady-state errors in the presence of disturbances. These phenomena are undesirable, especially when the natural wind changes rapidly or when the payload changes, and these characteristics are likely to cause a true UAV crash. On the other hand, SMC control can use the estimated disturbance information to form an active compensation-control effort. As a result, it exhibits a much-improved force-interference-rejection capability with a higher tracking accuracy.

3.2.2. Comparison of the Wind Resistance under the Cross-Wind Effect

Crosswind, as a special form of disturbance, often occurs when UAVs are flying, especially in indoor or narrow environments, and these winds can be superimposed in multiple directions and are often unpredictable. Therefore, the wind resistance of UAVs is often used as an important factor to evaluate their flight-control performance. For this reason, in addition to the tracking performance, we investigate the effects of variable crosswinds. The wind resistance results in the horizontal plane for each controller are listed in Figure 20 and Figure 21, with X representing north and Y representing east. The corresponding estimates of the disturbances based on the disturbance observer in SMC are also shown in Figure 20.
First, we add a variation of horizontal wind as shown in Figure 20. Starting at 18 s, we add 3 m/s (about 5.83 Kts) of wind in the X and Y in each 5 s, which means the resultant wind added in each period should be 3 2 m/s in the northeast direction. Although the wind added looks more similar to step functions, the actual wind’s increasing rate was around 4.2426 m/s 2 , which means that the wind speed was accelerated to the reference value in about 1 s. Starting from around 55 s, the wind speed was gradually reduced down to 0 m/s. Throughout the simulations, SMC was able to reject wind forces and maintain the desired point within ±20 cm, but the PID drifted considerably, up to 75 cm away from the desired point. During the test, the maximum wind resistance of the SMC- and PID-controlled PX4 UAV was 30.5 m/s (about 59.28 Kts); exceeding this value would result in irreversible trajectory deviation, leading to instability.
In addition, the wind speed estimated by the disturbance observer is also shown, which matches well with the actual wind-speed magnitude. Due to the symmetry of the UAV, the response on the Y-axis is similar to the response on the X-axis, and the Y-plot is omitted here for clarity. It can be observed from Figure 21 that UAV motion with the SMC controller is concentrated more around the origin than with other controllers; hence, SMC has the best crosswind resistance in terms of position accuracy. This is due to its active disturbance compensation.

3.2.3. Torque Disturbances

The tracking performance together with the torque disturbance estimates from the proposed disturbance observer is illustrated in Figure 22. In scenario (4), panels (a) and (b) correspond to a constant torque disturbance added around the X axis as 5 rad/s 2 ; in scenario (5), panels (c) and (d) correspond to a constant torque disturbance added around the Y axis as 5 rad/s 2 ; in scenario (6), panels (e) and (f) correspond to a constant torque disturbance added around the Z axis as 1 rad/s 2 .
It can be seen that the proposed SMC controller is superior to the other two PID controllers in the face of torque disturbance especially in the yaw direction. The PID-position and PID-rate controllers initially have larger drifts when pitch and roll disturbances are present, although they can slowly stabilize the UAV. These phenomena may cause the UAV to move uncontrollably during takeoff, especially when the center of gravity is not near the center of the UAV. SMC has smaller drifts and corrects faster (see panels a, c, and t < 30 s). In the steady state, however, PID is more acceptable in terms of keeping the tracking error in x and y small. Note that, in the yaw direction, the other two controllers cannot quickly compensate for the disturbance (settling time out of range of the plot), so the PID-rate will slowly return to its original angle, while the PID-position will be slower. On the other hand, SMC is able to use the estimated disturbance information to form active compensation. In the case of circular wind or rotational forces acting on the UAV, SMC controllers with disturbance observers are more sensitive to torque than PID-based controllers, which results in SMC having stronger torque immunity.

4. Discussion and Conclusions

This work describes the design and implementation of a disturbance-observer-based sliding-mode surface controller (SMC) and validates a SMC with a simulated PX4 quadcopter. As a model-based design, this study started from a mathematical MATLAB/ SIMULINK model, from which we adopted the PSO algorithm to optimize the parameters for the controllers, followed by testing and validating in a highly realistic jMavsim simulator. In the simulations, we compared two different benchmark PID controllers (PID-rate controller and PID-position controller) with the proposed SMC and evaluated their performance by applying different disturbances (e.g., disturbance-force, disturbance-torque, and crosswind effects.) within the sensor-noisy environment.
On the one hand, for precise motion in the horizontal plane, SMC is way ahead of the pack. On the other hand, the PID-based controller took more time to return to the reference value under sudden increases in force and torque disturbances, while the SMC could track the desired trajectory smoothly and quickly. In addition, when focusing on contour tracking under wind effects, both PID controllers performed similarly but were inferior to the SMC controller. This means that the SMC-based UAV has improved wind resistance. Another advantage of the SMC controller is that the sliding-mode controller was designed for a fully nonlinear model based on Lyapunov stability analysis; however, the PID controller was designed for a simplified linear form, which leads to a more robust SMC approach. An SMC with disturbance observers facilitates accurate and fast UAV adaptation in inconsistent dynamic environments.

5. Future Work

Future work can be divided into three parts. The first part is to optimize the proposed SMC controller to an actual UAV. No matter how superior the simulation results are, there may still be some discrepancies in reality. Therefore, it is necessary to repeat the tests on a real UAV to find the discrepancies and then improve and modify the controllers. The second part is to enrich the mathematical dynamic model. We will add more noise, simulate the process of signal transmission, and model more complex real-world environmental factors. The third part is to improve the SMC controller. In this study, we used a relatively basic form of a sliding surface; in the future, we will consider designing an adaptive sliding control law.

Author Contributions

Conceptualization, R.S. and J.M.-L.; methodology, Y.J., X.W., R.S. and J.M.-L.; software, Y.J. and X.W.; validation, Y.J., X.W. and C.F.; formal analysis, Y.J. and X.W.; investigation, Y.J., X.W. and C.F.; resources, R.S. and J.M.-L.; data curation, Y.J. and X.W.; writing—original draft preparation, Y.J. and X.W.; writing—review and editing, J.H.-J., R.S. and J.M.-L.; visualization, Y.J.; supervision, J.H.-J., C.G., R.S. and J.M.-L.; project administration, J.H.-J., C.G., R.S. and J.M.-L.; funding acquisition, J.H.-J., C.G., R.S. and J.M.-L. All authors have read and agreed to the published version of the manuscript.

Funding

This work is funded by the Air Force Research Laboratory.

Data Availability Statement

Not applicable.

Acknowledgments

The authors would also like to thank Weite Zhang, Chang, Liu, Xu Mao, and Yi Huang for their help in the simulations and experiments.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Erdos, D.; Erdos, A.; Watkins, S.E. An experimental UAV system for search and rescue challenge. IEEE Aerosp. Electron. Syst. Mag. 2013, 28, 32–37. [Google Scholar] [CrossRef]
  2. Naidoo, Y.; Stopforth, R.; Bright, G. Development of an UAV for search rescue applications. In Proceedings of the IEEE Africon ’11, Victoria Falls, Zambia, 13–15 September 2011; pp. 1–6. [Google Scholar] [CrossRef]
  3. Andaluz, V.H.; López, E.; Manobanda, D.; Guamushig, F.; Chicaiza, F.; Sánchez, J.S.; Rivas, D.; Pérez, F.; Sánchez, C.; Morales, V. Nonlinear controller of quadcopters for agricultural monitoring. In Proceedings of the International Symposium on Visual Computing, Las Vegas, NV, USA, 14–16 December 2015; Springer: Cham, Switzerland, 2015; pp. 476–487. [Google Scholar]
  4. Cao, M.; Chen, W.; Li, Y. Research on detection and tracking technology of quad-rotor aircraft based on open source flight control. In Proceedings of the 2020 39th Chinese Control Conference (CCC), Shenyang, China, 27–29 July 2020; pp. 6509–6514. [Google Scholar]
  5. Chaudhary, S.; Prava, A.; Nidhi, N.; Nath, V. Design of all-terrain rover quadcopter for military engineering services. In Nanoelectronics, Circuits and Communication Systems; Springer: Cham, Switzerland, 2019; pp. 507–513. [Google Scholar]
  6. Argentim, L.M.; Rezende, W.C.; Santos, P.E.; Aguiar, R.A. PID, LQR and LQR-PID on a quadcopter platform. In Proceedings of the 2013 International Conference on Informatics, Electronics and Vision (ICIEV), Dhaka, Bangladesh, 17–18 May 2013; pp. 1–6. [Google Scholar] [CrossRef]
  7. Panagiotou, P.; Kaparos, P.; Salpingidou, C.; Yakinthos, K. Aerodynamic design of a MALE UAV. Aerosp. Sci. Technol. 2016, 50, 127–138. [Google Scholar] [CrossRef]
  8. Kuantama, E.; Tarca, I.; Tarca, R. Feedback linearization LQR control for quadcopter position tracking. In Proceedings of the 2018 5th International Conference on Control, Decision and Information Technologies (CoDIT), Thessaloniki, Greece, 10–13 April 2018; pp. 204–209. [Google Scholar] [CrossRef]
  9. Panomrattanarug, B.; Higuchi, K.; Mora-Camino, F. Attitude control of a quadrotor aircraft using LQR state feedback controller with full order state observer. In Proceedings of the SICE Annual Conference 2013, Nagoya, Japan, 14–17 September 2013; pp. 2041–2046. [Google Scholar]
  10. Khatoon, S.; Gupta, D.; Das, L.K. PID & LQR control for a quadrotor: Modeling and simulation. In Proceedings of the 2014 International Conference on Advances in Computing, Communications and Informatics (ICACCI), Delhi, India, 24–27 September 2014; 2014; pp. 796–802. [Google Scholar] [CrossRef]
  11. Goel, A.; Salim, A.M.; Ansari, A.; Ravela, S.; Bernstein, D. Adaptive digital PID control of a quadcopter with unknown dynamics. arXiv 2020, arXiv:2006.00416. [Google Scholar]
  12. Dong, J.; He, B. Novel fuzzy PID-type iterative learning control for quadrotor UAV. Sensors 2019, 19, 24. [Google Scholar] [CrossRef] [PubMed]
  13. Zhou, J.; Deng, R.; Shi, Z.; Zhong, Y. Robust cascade PID attitude control of quadrotor helicopters subject to wind disturbance. In Proceedings of the 2017 36th Chinese Control Conference (CCC), IEEE, Dalian, China, 26–28 July 2017; pp. 6558–6563. [Google Scholar]
  14. Park, D.; Yu, H.; Xuan-Mung, N.; Lee, J.; Hong, S.K. Multicopter PID attitude controller gain auto-tuning through reinforcement learning neural networks. In Proceedings of the 2019 2nd International Conference on Control and Robot Technology, Jeju, Korea, 12–14 December 2019; pp. 80–84. [Google Scholar]
  15. Ha, C.; Zuo, Z.; Choi, F.B.; Lee, D. Passivity-based adaptive backstepping control of quadrotor-type UAVs. Robot. Auton. Syst. 2014, 62, 1305–1315. [Google Scholar] [CrossRef]
  16. Moeini, A.; Rafique, M.A.; Xue, Z.; Lynch, A.F.; Zhao, Q. Disturbance observer-based integral backstepping control for UAVs. In Proceedings of the 2020 International Conference on Unmanned Aircraft Systems (ICUAS), IEEE, Athens, Greece, 1–4 September 2020; pp. 382–388. [Google Scholar]
  17. Fang, Z.; Gao, W. Adaptive backstepping control of an indoor micro-quadrotor. Res. J. Appl. Sci. Eng. Technol. 2012, 4, 4216–4226. [Google Scholar]
  18. Zheng, E.H.; Xiong, J.J.; Luo, J.L. Second order sliding mode control for a quadrotor UAV. Disturbance Estimation and Mitigation. ISA Trans. 2014, 53, 1350–1356. [Google Scholar] [CrossRef] [PubMed]
  19. Gong, X.; Hou, Z.C.; Zhao, C.J.; Bai, Y.; Tian, Y.T. Adaptive backstepping sliding mode trajectory tracking control for a quad-rotor. Int. J. Autom. Comput. 2012, 9, 555–560. [Google Scholar] [CrossRef]
  20. Guruganesh, R.; Bandyopadhyay, B.; Arya, H.; Singh, G. Design and hardware implementation of autopilot control laws for MAV using super twisting control. J. Intell. Robot. Syst. 2018, 90, 455–471. [Google Scholar] [CrossRef]
  21. Chen, F.; Jiang, R.; Zhang, K.; Jiang, B.; Tao, G. Robust Backstepping Sliding-Mode Control and Observer-Based Fault Estimation for a Quadrotor UAV. IEEE Trans. Ind. Electron. 2016, 63, 5044–5056. [Google Scholar] [CrossRef]
  22. Besnard, L.; Shtessel, Y.B.; Landrum, B. Quadrotor vehicle control via sliding mode controller driven by sliding mode disturbance observer. Advances in Guidance and Control of Aerospace Vehicles using Sliding Mode Control and Observation Techniques. J. Frankl. Inst. 2012, 349, 658–684. [Google Scholar] [CrossRef]
  23. Battiston, A.; Sharf, I.; Nahon, M. Attitude estimation for collision recovery of a quadcopter unmanned aerial vehicle. Int. J. Robot. Res. 2019, 38, 1286–1306. [Google Scholar] [CrossRef]
  24. Jothiraj, W.; Miles, C.; Bulka, E.; Sharf, I.; Nahon, M. Enabling bidirectional thrust for aggressive and inverted quadrotor flight. In Proceedings of the 2019 International Conference on Unmanned Aircraft Systems (ICUAS), IEEE, Atlanta, GA, USA, 11–14 June 2019; pp. 534–541. [Google Scholar]
  25. Camci, E.; Kayacan, E. Learning motion primitives for planning swift maneuvers of quadrotor. Auton. Robot. 2019, 43, 1733–1745. [Google Scholar] [CrossRef]
  26. Salunkhe, D.H.; Sharma, S.; Topno, S.A.; Darapaneni, C.; Kankane, A.; Shah, S.V. Design, trajectory generation and control of quadrotor research platform. In Proceedings of the 2016 International Conference on Robotics and Automation for Humanitarian Applications (RAHA), Amritapuri, India, 18–20 December 2016; pp. 1–7. [Google Scholar]
  27. Ortiz, N.A.S.; Laroche, E.; Kiefer, R.; Durand, S. Controller tuning strategy for quadrotor MAV carrying a cable-suspended load. In Proceedings of the International Micro Air Vehicle Conference and Flight Competition (IMAV), Beijing, China, 18–21 September 2016; pp. 17–21. [Google Scholar]
  28. Nazaruddin, Y.Y.; Andrini, A.D.; Anditio, B. PSO based PID controller for quadrotor with virtual sensor. IFAC-PapersOnLine 2018, 51, 358–363. [Google Scholar] [CrossRef]
  29. Gomez, V.; Gomez, N.; Rodas, J.; Paiva, E.; Saad, M.; Gregor, R. Pareto Optimal PID Tuning for PX4-Based Unmanned Aerial Vehicles by Using a Multi-Objective Particle Swarm Optimization Algorithm. Aerospace 2020, 7, 71. [Google Scholar] [CrossRef]
  30. Saengphet, W.; Tantrairatn, S.; Thumtae, C.; Srisertpol, J. Implementation of system identification and flight control system for UAV. In Proceedings of the 2017 3rd International Conference on Control, Automation and Robotics (ICCAR), Nagoya, Japan, 24–26 April 2017; pp. 678–683. [Google Scholar]
  31. Niit, E.A.; Smit, W.J. Integration of model reference adaptive control (MRAC) with PX4 firmware for quadcopters. In Proceedings of the 2017 24th International Conference on Mechatronics and Machine Vision in Practice (M2VIP), Auckland, New Zealand, 21–23 November 2017; pp. 1–6. [Google Scholar]
  32. Khan, H.S.; Kadri, M.B. Position control of quadrotor by embedded PID control with hardware in loop simulation. In Proceedings of the 17th IEEE International Multi Topic Conference 2014, IEEE, Karachi, Pakistan, 8–10 December 2014; pp. 395–400. [Google Scholar]
  33. Kaba, A. Improved PID rate control of a quadrotor with a convexity-based surrogated model. Aircr. Eng. Aerosp. Technol. 2021, 93, 1287–1301. [Google Scholar] [CrossRef]
  34. Wang, X. Sliding Mode Control Design with Disturbance Observer for a Quadrotor. Master’s Thesis, Northeastern University, Boston, MA, USA, 2021. [Google Scholar]
  35. Bonyadi, M.R.; Michalewicz, Z. Particle swarm optimization for single objective continuous space problems: A review. Evol. Comput. 2017, 25, 1–54. [Google Scholar] [CrossRef]
  36. Li, P.; Lin, Z.; Shen, H.; Zhang, Z.; Mei, X. Optimized neural network based sliding mode control for quadrotors with disturbances. Math. Biosci. Eng. MBE 2021, 18, 1774–1793. [Google Scholar] [CrossRef] [PubMed]
  37. Boubertakh, H. Optimal stabilization of a quadrotor UAV by a constrained fuzzy control and PSO. In Proceedings of the MATEC Web of Conferences. EDP Sciences, Sibiu, Romania, 7–9 June 2017; Volume 99, p. 03001. [Google Scholar]
  38. Xu, J.; Ma, Y.; Huang, J. 3D path tracking controller based on fuzzy PID optimized by PSO for quadrotor. In Proceedings of the 2019 Chinese Automation Congress (CAC), Hangzhou, China, 22–24 November 2019; pp. 3522–3527. [Google Scholar]
  39. Noordin, A.; Basri, M.M.; Mohamed, Z.; Abidin, A.Z. Modelling and PSO fine-tuned PID control of quadrotor UAV. Int. J. Adv. Sci. Eng. Inf. Technol. 2017, 7, 1367–1373. [Google Scholar] [CrossRef] [Green Version]
Figure 1. Simulated PX4-based quadcopter flying in the windy jMavsim simulator environment.
Figure 1. Simulated PX4-based quadcopter flying in the windy jMavsim simulator environment.
Drones 06 00261 g001
Figure 2. The PID-position-only controller diagram.
Figure 2. The PID-position-only controller diagram.
Drones 06 00261 g002
Figure 3. The PID-rate controller diagram.
Figure 3. The PID-rate controller diagram.
Drones 06 00261 g003
Figure 4. Euler angles and the coordinate system.
Figure 4. Euler angles and the coordinate system.
Drones 06 00261 g004
Figure 5. The SMC controller diagram.
Figure 5. The SMC controller diagram.
Drones 06 00261 g005
Figure 6. Sliding-surface tracking of x position controller on the plane of e vs. e ˙ .
Figure 6. Sliding-surface tracking of x position controller on the plane of e vs. e ˙ .
Drones 06 00261 g006
Figure 7. Sliding-surface tracking of z altitude controller on the plane of e vs. e ˙ .
Figure 7. Sliding-surface tracking of z altitude controller on the plane of e vs. e ˙ .
Drones 06 00261 g007
Figure 8. Sliding-surface tracking of ψ yaw controller on the plane of e vs. e ˙ .
Figure 8. Sliding-surface tracking of ψ yaw controller on the plane of e vs. e ˙ .
Drones 06 00261 g008
Figure 9. Disturbance observer structure combined with SMC controller.
Figure 9. Disturbance observer structure combined with SMC controller.
Drones 06 00261 g009
Figure 10. (Left): Defined ITAE score curve for X, Y, Z, and YAW; (Middle): Integrated Overshoot and Undershoot (OsUs) score curve for X, Y, Z, and YAW; (Right): Defined Settling Time (Ts) score curve for X, Y, Z, and YAW.
Figure 10. (Left): Defined ITAE score curve for X, Y, Z, and YAW; (Middle): Integrated Overshoot and Undershoot (OsUs) score curve for X, Y, Z, and YAW; (Right): Defined Settling Time (Ts) score curve for X, Y, Z, and YAW.
Drones 06 00261 g010
Figure 11. Process flow of the PSO.
Figure 11. Process flow of the PSO.
Drones 06 00261 g011
Figure 12. Score and standards vs. PSO Iterations. (Top-left): Weighted average score of Ts, OsUs, and ITAE combined for each direction; (Top-right): Score of Ts for each direction; (Bottom-left): Score of OsUs for each direction; (Bottom-right): Score of ITAE for each direction.
Figure 12. Score and standards vs. PSO Iterations. (Top-left): Weighted average score of Ts, OsUs, and ITAE combined for each direction; (Top-right): Score of Ts for each direction; (Bottom-left): Score of OsUs for each direction; (Bottom-right): Score of ITAE for each direction.
Drones 06 00261 g012
Figure 13. Comparison of step-tracking performance before and after the PSO tuning. Simulations are based on the SIMULINK mathematical UAV model.
Figure 13. Comparison of step-tracking performance before and after the PSO tuning. Simulations are based on the SIMULINK mathematical UAV model.
Drones 06 00261 g013
Figure 14. Comparison of step-tracking performance of PSO optimized SMC, PID-position, and PID-rate controllers from the PX4 conducted jMavsim simulation under normal noise levels. (a) X vs. Time. (b) Pitch vs. Time. (c) Y vs. Time. (d) Roll vs. Time. (e) Z vs. Time. (f) Yaw vs. Time.
Figure 14. Comparison of step-tracking performance of PSO optimized SMC, PID-position, and PID-rate controllers from the PX4 conducted jMavsim simulation under normal noise levels. (a) X vs. Time. (b) Pitch vs. Time. (c) Y vs. Time. (d) Roll vs. Time. (e) Z vs. Time. (f) Yaw vs. Time.
Drones 06 00261 g014aDrones 06 00261 g014bDrones 06 00261 g014c
Figure 15. Comparison of ramp tracking with error histogram from the PX4 conducted jMavsim simulation under normal noise levels. (a) X Ramp vs. Time. (b) X Error histogram. (c) Y Ramp vs. Time. (d) Y Error histogram. (e) Z Ramp vs. Time. (f) Z Error histogram. (g) Yaw Ramp vs. Time. (h) Yaw Error histogram.
Figure 15. Comparison of ramp tracking with error histogram from the PX4 conducted jMavsim simulation under normal noise levels. (a) X Ramp vs. Time. (b) X Error histogram. (c) Y Ramp vs. Time. (d) Y Error histogram. (e) Z Ramp vs. Time. (f) Z Error histogram. (g) Yaw Ramp vs. Time. (h) Yaw Error histogram.
Drones 06 00261 g015aDrones 06 00261 g015bDrones 06 00261 g015c
Figure 16. Comparison of flower-pattern complex trajectory tracking results from the PX4 conducted jMavsim simulation under normal noise levels. (a) Top view of tracking results of a flower-pattern complex trajectory. (b) Tracking results in x direction with the timeline. (c) Tracking results in y direction with the timeline.
Figure 16. Comparison of flower-pattern complex trajectory tracking results from the PX4 conducted jMavsim simulation under normal noise levels. (a) Top view of tracking results of a flower-pattern complex trajectory. (b) Tracking results in x direction with the timeline. (c) Tracking results in y direction with the timeline.
Drones 06 00261 g016
Figure 17. X position error histogram tracking the flower-pattern complex trajectory.
Figure 17. X position error histogram tracking the flower-pattern complex trajectory.
Drones 06 00261 g017
Figure 18. Y position error histogram tracking the flower-pattern complex trajectory.
Figure 18. Y position error histogram tracking the flower-pattern complex trajectory.
Drones 06 00261 g018
Figure 19. Origin-tracking results and disturbance estimation results under constant force-disturbance. (a) X vs. Time. (b) Estimated disturbance in the x direction. Actual disturbance is 1 m/s 2 . (c) Y vs. Time. (d) Estimated disturbance in the y direction. (e) Actual disturbance is 1 m/s 2 . (f) Z vs. Time. Estimated disturbance in the z direction. Actual disturbance is 10 m/s 2 .
Figure 19. Origin-tracking results and disturbance estimation results under constant force-disturbance. (a) X vs. Time. (b) Estimated disturbance in the x direction. Actual disturbance is 1 m/s 2 . (c) Y vs. Time. (d) Estimated disturbance in the y direction. (e) Actual disturbance is 1 m/s 2 . (f) Z vs. Time. Estimated disturbance in the z direction. Actual disturbance is 10 m/s 2 .
Drones 06 00261 g019aDrones 06 00261 g019b
Figure 20. Comparison of the origin tracking performance under unidirectional crosswind effect and SMC disturbanceobserver real-time wind velocity estimation results.
Figure 20. Comparison of the origin tracking performance under unidirectional crosswind effect and SMC disturbanceobserver real-time wind velocity estimation results.
Drones 06 00261 g020
Figure 21. Top view of the origin-tracking results under unidirectional crosswind effect.
Figure 21. Top view of the origin-tracking results under unidirectional crosswind effect.
Drones 06 00261 g021
Figure 22. Origin-tracking results and disturbance estimation results under constant torque disturbance. (a) Y vs. Time. (b) Estimated disturbance in the ϕ Roll direction. Actual disturbance is 5 rad/s 2 . (c) X vs. Time. (d) Estimated disturbance in the θ Pitch direction. Actual disturbance is 5 rad/s 2 . (e) Yaw vs. Time. (f) Estimated disturbance in the ψ Yaw direction. Actual disturbance is 1 rad/s 2 .
Figure 22. Origin-tracking results and disturbance estimation results under constant torque disturbance. (a) Y vs. Time. (b) Estimated disturbance in the ϕ Roll direction. Actual disturbance is 5 rad/s 2 . (c) X vs. Time. (d) Estimated disturbance in the θ Pitch direction. Actual disturbance is 5 rad/s 2 . (e) Yaw vs. Time. (f) Estimated disturbance in the ψ Yaw direction. Actual disturbance is 1 rad/s 2 .
Drones 06 00261 g022aDrones 06 00261 g022bDrones 06 00261 g022c
Table 1. Sensors (GPS, Accelerometer, Gyroscope, Magnetometer, Pressure Sensor) configuration.
Table 1. Sensors (GPS, Accelerometer, Gyroscope, Magnetometer, Pressure Sensor) configuration.
Sensors Properties GPS I GPS D GPS S ACC N GYO N MAG N PRS N
Value50300100.050.010.0050.1
Unitmsmsmsm/s 2 rad/sGaussm
Table 2. Magnetic field settings.
Table 2. Magnetic field settings.
Mag-Field SettingsNEDInclDeclH-MagnT-Magn
Value0.44870.016690.8935363.335882.130.449011
UnitGaussGaussGaussdegdegoerstedsGauss
Table 3. Initial wind settings.
Table 3. Initial wind settings.
Wind SettingsN-SETE-SETD-SETN-DEVE-DEVD-DEV
Value000000
Unitm/sm/sm/sm/sm/sm/s
Table 4. Initial position settings.
Table 4. Initial position settings.
Home PositionLATLONALTINIT-NINIT-EINIT-DGrav
Value55.75339537.6254271550009.81
Unitdegdegmmmmm/s 2
Table 5. UAV dynamics model parameters.
Table 5. UAV dynamics model parameters.
Parameterml J x J y J z K 1 K 2
Value0.80.1650.0050.0050.0090.010
Unitkgmkg · m 2 kg · m 2 kg · m 2 N/(m/s)N · m/(rad/s)
T m a x Q m a x P m a x P m i n
40.0520001000
NN · m μ s μ s
Table 6. Value of σ .
Table 6. Value of σ .
i ITAE x + y ITAE z ITAE yaw OsUs x + y OsUs z OsUs yaw Ts x + y Ts z Ts yaw
σ i 18363150.51525419
Table 7. SMC Controller parameters after PSO Tuning.
Table 7. SMC Controller parameters after PSO Tuning.
Parameter a 1 a 2 k 2 b 1 x b 2 x b 1 y b 2 y c x c y
Value3.552410.00003.55240.74261.43050.59301.08950.28710.3867
b 3 b 4 a 3 k 5 k 6 a 4 k 7 k 8 k 4
0.63730.02238.19100.03880.02192.76400.31470.12440.5000
Table 8. PSO-tuned parameters in PID-position-only controller.
Table 8. PSO-tuned parameters in PID-position-only controller.
PID GainxyzYawPitchRoll
Kp25.635327.17693.23930.30170.08850.0885
Ki0.14360.23720.26370.00040.01130.0113
Kd21.375920.26332.29440.18790.03980.0398
Table 9. PSO-tuned parameters in PID-rate controller.
Table 9. PSO-tuned parameters in PID-rate controller.
PID GainxyzvxvyvzYawPitchRoll
Kp1.55511.79645.514628.525627.41395.53940.24780.09220.0922
Ki000.0617000.27100.00250.01410.0141
Kd0.22870.92171.83260.11330.17450.37720.16890.04760.0476
Table 10. Step-tracking performance.
Table 10. Step-tracking performance.
ControllerMpTsTrIAEITAEISEITSE
PID P O S 52.0197%4.6427s0.7134s0.261014.26870.00770.4232
XPID R A T E 14.0381%3.1368s0.8642s0.16778.46300.00370.1854
SMC4.5037%2.2240s1.3705s0.17738.95420.00380.1915
PID P O S 6.6901%2.6134s0.8304s0.255612.60730.00740.3599
YPID R A T E 7.4420%3.7456s0.8379s0.13056.72140.00250.1258
SMC3.8777%2.3412s1.4672s0.10965.26850.00170.0823
PID P O S 15.0943%3.9990s1.5232s0.856027.45860.08172.5453
ZPID R A T E 6.0805%3.4192s1.7296s0.23637.17250.00770.2246
SMC3.0367%2.4962s1.6328s0.06061.85770.00060.0174
PID P O S 2.6836%1.5183s1.0185s0.996962.82740.10106.3625
YawPID R A T E 2.7375%1.6036s1.0796s6.4843409.25214.2104265.3702
SMC0.0390%1.4370s0.9618s0.09515.97570.00130.0838
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Jing, Y.; Wang, X.; Heredia-Juesas, J.; Fortner, C.; Giacomo, C.; Sipahi, R.; Martinez-Lorenzo, J. PX4 Simulation Results of a Quadcopter with a Disturbance-Observer-Based and PSO-Optimized Sliding Mode Surface Controller. Drones 2022, 6, 261. https://doi.org/10.3390/drones6090261

AMA Style

Jing Y, Wang X, Heredia-Juesas J, Fortner C, Giacomo C, Sipahi R, Martinez-Lorenzo J. PX4 Simulation Results of a Quadcopter with a Disturbance-Observer-Based and PSO-Optimized Sliding Mode Surface Controller. Drones. 2022; 6(9):261. https://doi.org/10.3390/drones6090261

Chicago/Turabian Style

Jing, Yutao, Xianghe Wang, Juan Heredia-Juesas, Charles Fortner, Christopher Giacomo, Rifat Sipahi, and Jose Martinez-Lorenzo. 2022. "PX4 Simulation Results of a Quadcopter with a Disturbance-Observer-Based and PSO-Optimized Sliding Mode Surface Controller" Drones 6, no. 9: 261. https://doi.org/10.3390/drones6090261

APA Style

Jing, Y., Wang, X., Heredia-Juesas, J., Fortner, C., Giacomo, C., Sipahi, R., & Martinez-Lorenzo, J. (2022). PX4 Simulation Results of a Quadcopter with a Disturbance-Observer-Based and PSO-Optimized Sliding Mode Surface Controller. Drones, 6(9), 261. https://doi.org/10.3390/drones6090261

Article Metrics

Back to TopTop