This disclosure relates generally to unmanned aerial vehicles and, more particularly, to trajectory tracking controllers for rotorcraft unmanned aerial vehicles.
Unmanned aerial vehicles (UAVs), commonly referred to as drones, are becoming more readily available and have developed into a rapidly growing market. UAVs are now being used in a wide variety of industries, such as farming, shipping, forestry management, surveillance, disaster scenarios, gaming, etc. In fact, UAVs have even become large enough to carry small payloads. Further, UAVs are now being autonomously controlled to complete a particular mission, such as delivering a package.
The figures are not to scale. Instead, to clarify multiple layers and regions, the thickness of the layers may be enlarged in the drawings. Wherever possible, the same reference numbers will be used throughout the drawing(s) and accompanying written description to refer to the same or like parts. As used in this patent, stating that any part (e.g., a layer, film, area, or plate) is in any way positioned on (e.g., positioned on, located on, disposed on, or formed on, etc.) another part, indicates that the referenced part is either in contact with the other part, or that the referenced part is above the other part with one or more intermediate part(s) located therebetween. Stating that any part is in contact with another part means that there is no intermediate part between the two parts.
A rotorcraft, sometimes referred to as a non-fixed wing aircraft or rotary-wing aircraft, is an aircraft that uses lift generated by one or more propellers or rotor blades. For example, a rotorcraft may include one or multiple rotor blades (e.g., rotor assemblies) mounted on a single mast or multiple masts. Rotorcrafts are a common type of unmanned aerial vehicle (UAV) that use multiple rotor blades, referred to herein as a multi-rotor rotorcraft. For example, a quadcopter UAV is a multi-rotor rotorcraft that generates lift via four rotor blades.
Rotorcraft UAVs are a rapidly growing market and are now being used in all aspects of our world such as for farming, shipping, surveillance, gaming, etc. UAVs are also being used as part of autonomous systems that automatically control the flight of the UAV to perform a particular mission, such as picking up or delivering a package. Trajectory tracking is a key component for autonomous navigation in a complex dynamic environment. Trajectory tracking is the ability to precisely follow a planned or reference trajectory. As used herein, the terms “reference trajectory,” “desired trajectory,” and “planned trajectory” (and variations thereof) are used interchangeably and are defined to mean an intended or planned path in 3D space as function of time. A planned trajectory may also take into account velocity, acceleration and/or jerk. Trajectory tracking, unlike waypoint navigation, includes the constraint of time. Trajectory tracking is becoming more important today as UAVs are used to perform more complex tasks.
For example, a group of UAVs may be used in a warehouse or factory setting to perform various tasks such as moving objects around the facility. However, following a path without considering time-dependence can lead to collisions. For example, the paths of two UAVs may conflict. Therefore, precisely following an appropriate, time-dependent trajectory ensures no collisions. In such an instance, the conflict can be solved by adjusting the velocity of the planned trajectory of one or both of the UAV S using a trajectory planner. The planned trajectory is often the output of a planning and collision avoidance algorithm. As such, trajectory tracking is advantageous because it includes an extra degree of freedom to increase or decrease speed in the presence of a dynamic object that is on a collision path.
As another example, it is often desired to have a UAV land on a moving object, such as a car or a boat. The dynamic nature of the moving object forces the UAV to calculate a time dependent trajectory and to have a trajectory tracking controller to precisely land on the moving object. Further, in some scenarios, such as outdoor scenarios, there are external disturbances such as wind that can affect the flight behavior of the UAV. Also, in some instances, there may be payload changes that can further affect the flight of the UAV.
Unlike attitude controllers that only stabilize the orientation of a UAV (and are mainly used to be remote controlled by a human pilot), trajectory tracking controllers are used to precisely follow a path as a function of time (e.g., controls both position and orientation). Attitude controllers, such as PID controllers, only control the rotational motion of the UAV and may require trial-and-error tuning. Although an attitude controller may be used to autonomously navigate in 3D space via waypoint navigation, the paths followed are not precise and are not given as a function of time. A trajectory tracking controller, on the other hand, autonomously controls a UAV to fly along a planned trajectory (e.g., provided by a trajectory planner) by generating instructions to control the propeller motors of the UAV based on the current position/orientation of the UAV in reference to the planned trajectory. In particular, trajectory tracking controllers use algorithms or calculations to determine the speed at which to operate each of the propeller motors (based on the desired thrusts) to fly the UAV in accordance with the planned trajectory.
Known methodologies for controlling the autonomous flight of a multi-rotor UAV require a precise modeling and characterization of the UAV system parameters, such as the mass of the UAV (and/or the mass of a payload carried by the UAV), the motor thrusts, moments of inertia of the UAV, the size of the UAV, parameters of the motors such as the drag and thrust coefficients, etc., for the design of the proper controller. In other words, the algorithms and calculations to determine how much thrust to generate are based heavily on the various parameters specific to the UAV. As such, known controllers are tuned specifically based on the system parameters of the respective UAV. Thus, known controllers can only be used for a certain type or model of UAV having the same system parameters. To use a known controller for different UAVs (having different system parameters), a significant amount of time and cost must be incurred to reconfigure, modify, and/or retune the controller to the new system parameters for maintaining precise trajectory tracking capability for autonomous navigation. These issues present significant challenges with the wide use of UAVs.
Also, if one or more of these parameters change, the UAV platform destabilizes and/or performance otherwise degrades. For instance, if the weight of the UAV changes, e.g., by adding a different battery, a camera, a payload, etc., the performance of the UAV may vary (mismatch) greatly from the performance configured by the original precise modeling and characterization of the UAV system parameters. As another example, if the motor parameters (e.g., the thrust and/or drag coefficients) change due to degradation the performance may also greatly vary from the intended performance. This can be detrimental to the flight mission and to the UAV itself (e.g., may cause a collision). Thus, the performance of the UAV degrades without proper (reconfigured) modeling of the new system parameters.
Therefore, known model-based controllers, such a model-based trajectory controllers, differential flatness-based trajectory controllers, and model predictive control-based trajectory controllers all require knowledge of the system parameters. As such, these known trajectory controllers cannot be used to control other UAVs (having different system parameters) without significant tuning of the controller. Further, these known controllers cannot effectively control the trajectory of the UAV if any of the system parameters change during flight (e.g., by changing payloads, degradation of the motors, etc.) without being reconfigured. Also, while these known controllers may be robust to external disturbances (e.g., wind) when the parameters are known, known controllers become inaccurate without the correct system parameters. For instance, known controllers often used inertial measurement unit (IMU)-based approaches to measure and cancel out disturbances through the controller. However, these IMU-based approaches are ineffective under system parameter uncertainty such as where the drag and thrust coefficients of the motors are unknown and/or changing. Some known manufactures have attempted to create controllers that are more robust to parameter variations (which still require knowledge of the changed parameters), but they do no not perform well in the presence of external disturbances. Thus, a tradeoff exists between designing for changes in the system parameters or for external disturbances.
Disclosed herein are example methods, apparatus, systems, and articles of manufacture for controlling trajectory tracking of a rotorcraft (manned or unmanned) that are insensitive to parameter variations and robust to external disturbances. Example methods, apparatus, system, and articles of manufacture disclosed herein may be used to autonomously navigate a rotorcraft UAV without knowledge of the various system parameters used in known controllers, such as the mass of the UAV, the moments of inertia of the UAV, the motor thrusts, the size of the UAV, and the drag and thrust coefficients of the motor. As such, the examples disclosed herein can be easily adapted to control multiple different UAVs having different system parameters with minimal (if any) tuning. Further, by not being heavily dependent on system parameters such as mass, the examples disclosed herein can continue to precisely track a planned trajectory despite changing system parameters (e.g., changing payloads).
Disclosed herein are example trajectory tracking controllers that may be used to autonomously navigate a UAV in accordance with a planned trajectory. Example trajectory tracking controllers disclosed herein may be integrated into the hardware and/or software in the UAV, may be located at a ground station communicating with the UAV, and/or may communicate with the UAV in another manner such as via a network (e.g., the internet). An example trajectory tracking controller disclosed herein calculates control variables (for x, y, z position and yaw ψ), which are used to determine the speeds to operate the propeller motors, independent of (without knowledge of) the mass and/or other system parameters of the UAV (such as the moments of inertia, the motor thrusts, etc.). As such, the example controller can be easily adapted to control other types of UAVs having different system parameters (e.g., a heavier or lighter UAV, a UAV with different moments of inertia, etc.) with minimal or no tuning.
In some examples, the example trajectory tracking controller maintains precise navigation by rapidly switching between a plurality of different values for the motor drivers based on the calculated control variables. Each of the values corresponds to one of a plurality of (e.g., eight) different speeds within the motor speed range or spectrum. By increasing and/or decreasing the speeds of the motors rapidly (e.g., at around 1,000 Hertz (Hz)) between these discrete values, the net result is a smooth, linear path that tracks the planned trajectory and which has the same effect on the UAV as a nonlinear trajectory controller having knowledge of the system parameters and measuring external disturbances.
Further, by not using the system parameters in the calculation of the control variables, the example controller can maintain precise navigation of the UAV even when the systems parameters change in flight. For example, if the UAV changes payload (which may change the center of mass of the UAV) during a mission (e.g., picks up a package on the ground or in flight), the example controller continues to accurately control the flight path of the UAV along the planned trajectory, independent of the variation of the weight. As another example, the motor parameters may change due to aging/degrading conditions that generate less thrust over time or by changing the motors in the UAV to more powerful motors (e.g., to generate more thrust) or less powerful motors (e.g., to save battery power). As another example, the moments of inertia may change such as when an irregularly shaped UAV is implemented (e.g., such as a 3D printed UAV made by a hobbyist) or by placing a payload (e.g., a camera) off center. In these examples, the example controller continues to accurately control the flight path of the UAV independent of these variations. Thus, the example controller enables the UAV to fly precisely along the planned trajectory similar to known trajectory controllers that have knowledge of these system parameters.
Still further, example trajectory tracking controllers disclosed herein are robust to external disturbances, such forces caused by wind, storms, thermals, etc., even under parameter uncertainties. The example trajectory tracking controllers are capable of calculating disturbance rejection control laws for cancelling out IMU-based disturbances without knowledge of the system parameters of the UAV. Therefore, unlike known methodologies that lose precision under external disturbances, the example controllers disclosed herein provide precise trajectory tracking even with external disturbances. Thus, the example controllers disclosed herein are capable of robust trajectory tracking (despite external disturbances) in the absence of knowledge of the system parameters, such as mass, motor parameters, moments of inertia, etc.
Also, the example calculations performed by the example trajectory tracking controllers are less complex than known methodologies. As such, the example controllers disclosed herein can also be easily adapted for use with smaller UAVs that typically have reduced computational capabilities. Additionally or alternatively, the example controllers disclosed herein can be used as fail-safe backup controllers for UAVs that typically have greatly reduced computational capabilities. Also, because the example controllers can be applied to various types of UAVs with minimal (if any) tuning, the example controllers can be more easily used by custom made hobbyist UAVs than known controllers that require significant tuning to the system parameters. Thus, the examples disclosed herein may provide a ready-to-fly controller for original equipment manufacturers (OEMs), makers, hobbyists, etc. that can be easily adapted and used for any type of UAV. Furthermore, less time may be incurred developing controllers for different UAVs because the example controllers can be used with a wide range of different UAV, as opposed to known controllers that need to be tuned specifically to the systems parameters of the UAV.
Thus, example trajectory tracking controllers disclosed herein enable precise trajectory tracking that can be used to resolve various challenges in autonomous navigation, such as how to solve conflicting paths in dynamic environments under variable payloads. Further, the example controllers can be used to enable UAVs to land on moving objects (e.g., a moving car, a moving boat, etc.), which is often subject to external disturbances such as wind. The example controllers disclosed herein can also be used to control an onboard gimbal camera to track an object (e.g., a target), for example, in the presence of variations in the UAV orientation and external disturbances. These and many other advantages will be apparent to one of ordinary sill in the art in view of this disclosure.
In the illustrated example, the X axis of the quadcopter reference frame extends through the first and third motors M1, M3, the Y axis of the quadcopter reference frame extends through the second and fourth motors M2, M4, and the Z axis extends perpendicular to the X and Y axes and through a center of the UAV 100. Assuming, for example, the first motor M1 represents the front of the UAV 100, in this example, roll angle ϕ is defined as movement (rotation) about the X axis and is obtained when the balance of thrust from the second and fourth motors M2, M4 is changed (e.g., the speed of the second motor M2 is increased and/or the speed of the fourth M4 is decreased, or vice versa). Therefore, lateral acceleration (e.g., side-to-side movement) is obtained by changing the roll angle ϕ. Pitch angle θ is defined as a movement (rotation) about the Y axis and is obtained when the balance of thrust from the first and third motors M1, M3 is changed (e.g., the speed of the first motor M1 is increased and/or the speed of the third motor M3 is decreased, or vice versa). When the pitch angle θ is changed, forward or backward acceleration is achieved. Yaw angle ψ is defined as a moment (rotation) about the Z axis and is obtained when a combination of the first and third motors M1, M3 change or the second and fourth motors M2, M4 change. As disclosed in further detail herein, these principles and techniques can be used for controlling the orientation and position of the UAV 100 in three-dimensional (3D) space to enable the UAV 100 to acquire and track a reference trajectory in a manner that is insensitive to system parameters and robust to external disturbances in accordance with the teachings of this disclosure.
In the illustrated example of
In the illustrated example, the UAV 100 includes a sensor system 206 including one or more sensors for detecting the orientation, positon, and/or one or more other parameters of the UAV 100. In the illustrated example, the sensor system 206 includes an inertial measurement unit (IMU) 208. The IMU 208 may include one or more sensors that measure linear and/or angular velocities and accelerations to determine orientation, position, velocity and/or acceleration of the UAV 100. For example, the IMU 208 may include a solid-state accelerometer, a gyro, a magnetometer, a static or dynamic pressure sensor, and/or any other IMU. In the illustrated example, the sensor system 206 includes a Global Position System (GPS) sensor 210 to detect GPS signals and determine the position (location), speed and/or acceleration of the UAV 100. In the illustrated example, the UAV 100 also includes the camera 212 that may be used to record images or video. In some examples, the camera 212 may be used as part of the sensor system 206 for determining the positon and/or orientation of the UAV 100. In some examples, the camera 212 is carried by the UAV 100 via a gimbal to enable the camera 212 to turn relative to the UAV 100. In other examples, the UAV 100 may include more or fewer devices.
In the illustrated example, the UAV 100 includes a flight control system 214. The flight control system 214 is configured to control the flight of the UAV 100. In particular, the flight control system 214 sends commands or instructions to the motor controller(s) 201 to control the speeds of the motors M1, M2, M3, M4 accordingly. The flight control system 214 may control the flight of the UAV 100 based on one or more commands from a manual controller, for example, such as a remote control operated by a human pilot.
In the illustrated example, the example trajectory tracking system 200 includes an example trajectory tracking controller 216 constructed in accordance with one or more principles of this disclosure. In the illustrated example, the trajectory tracking controller 216 is implemented as part of the flight control system 214. The example trajectory tracking controller 216 automatically generates instructions to control the speeds of the motors M1, M2, M3, M4 to fly the UAV 100 according to a planned trajectory. In general, the input to the trajectory tracking controller 216 is the planned trajectory and the output of the trajectory tracking controller 216 is the speed or power values for the motors M1, M2, M3, M4. A planned trajectory may be generated and/or otherwise managed by a reference trajectory manager 218 (e.g., a trajectory planner) and may be stored in a memory 220 (e.g., a databse) of the flight control system 214. In some examples, the reference trajectory manager 218 receives a planned trajectory from a remote location, such as a ground station. Additionally or alternatively, the reference trajectory manager 218 may generate a planned trajectory based on one or more input parameters. In some examples, the reference trajectory manager 218 may update, modify and/or otherwise change a planned trajectory based on changes to the mission. The trajectory tracking controller 216 generates instructions to navigate the UAV 100 based a system of equations that compares the position and/or orientation information from the sensor system 206 to the planned trajectory. As disclosed in further detail herein, the example trajectory tracking controller 216 can generate instructions for precisely flying the UAV 100 along a planned trajectory without knowledge of one or more of the various system parameters, such the mass of the UAV 100, the moments of inertia, the motor parameters, and the distance between the propeller motors and the center of mass, which are used in known controllers.
In the illustrated example, the example trajectory tracking controller 216 is part of the flight control system 214 onboard the UAV 100. As such, the trajectory tracking controller 216 is carried by the UAV 100 (e.g., integrated into the hardware of the flight control system 214 of the UAV 100). However, in other examples, the example trajectory tracking controller 216 may be part of a ground station that communicates (e.g., via commands or signals through the wireless transceiver 204) with the UAV 100. Also, while in the illustrated example the trajectory tracking controller 216 operates the motors M1, M2, M3, M4 through the motor controller(s) 201, in other examples, the trajectory tracking controller 216 may incorporate one or more motor controller(s) and/or may otherwise control the motors M1, M2, M3, M4 directly.
Before turning to the details of the example trajectory tracking controller 216 in
In Tables 1 and 2 above, uT, uϕ, uθ, uψ are control variables (sometimes referred to as control signals) that are input to the motor controller(s) 201 that are used to determine the speeds to drive the motors M1, M2, M3, M4. The control variables uT, uϕ, uθ, uψ can be found using Equation 1 below:
In Equation 1,
In Tables 1 and 2, cT is a thrust coefficient of the motors M1, M2, M3, M4 and represents a proportionality constant between the angular speed of the propeller from a motor (squared) and the force (thrust) it generates. For example, the force (thrust) generated by the propeller (R1) of the first motor M1 is cT
The control variables uT, uϕ, uθ, uψ can be solved for using the equations from Table 2 and used to determine the motor speeds
In Equation Group A, xref, yref, and zref are the reference signals for the planned trajectory along the x, y, z, axes of the global reference frame, and α, β1, β2, β3 are tuning parameters (gains) of the disturbance rejecter 300. The reference signals xref, yref, zref for the planned trajectory may be provided by the reference trajectory manager 218 (
In the illustrated example of
ux=−({umlaut over (x)}ref+k1exk2ėx+ūx+
uy=−(ÿref+k1ey+k2ėy+ūy+
uz=−({umlaut over (z)}ref+k1ez+k2ėz+ūz+δz) Equation 7
In Equation Group B, ux, uy, uz are the virtual controls that represent the required forces along the x, y, z axes in order to track the planned trajectory, {umlaut over (x)}ref, ÿref, {umlaut over (z)}ref are the desired accelerations corresponding to the planned trajectory along the x, y, z axes of the global reference frame, and k1 and k2 are tuning parameters (gains) of the position trajectory tracker 302. The gains (α, β1, β2, β3, k1, k2) from Equation Group A and Equation Group B are system-independent and, in some examples, are tuned beforehand. The accelerations ÿref, ÿref, {umlaut over (z)}ref are based on (by twice differentiating) the reference signals xref, yref, zref of the planned trajectory provided by the reference trajectory manager 218 (
In the illustrated example of
In other words, using the required forces ux, uy, uz in each axis, the desired values of pitch and roll ϕref, θref needed to reach those values can be obtained. If the roll ϕ and pitch θ of the UAV 100 follow these roll and pitch reference trajectories ϕref, θref, the trajectory tracking controller 216 can obtain a precise position trajectory tracking. As illustrated in
In the illustrated example, the altitude controller 306 uses an altitude feedback that ensures a trajectory tracking in the z direction despite mass (and/or other system parameter) uncertainty. In known controllers, the position dynamics depend strongly on the mass of the UAV 100. Although the mass can sometimes be measured beforehand, often there are changes in the mass (e.g., due to payload changes) that can render these dynamics ineffective. Instead, the example altitude controller 306 of
In Equation 10, vz is the velocity of the UAV 100 along the z axis of the global reference frame, żref is the linear velocity along the z axis of the global reference frame given by the desired trajectory, and k3 is a tuning parameter. As can be understood from Equation 10, the thrust control variable uT is output as either a first (high) value or a second (low) value depending on the outcome of the equation. For example, if the equation is less than zero, then the first (high) value is selected and output. However, if the equation is zero or above, then the second (low) value is selected and output. The first (high) and second (low) output values represent a total of the thrusts from all four motors M1, M2, M3, M4. In this example, the first (high) value is 26, and the second (low) value is 10. However, in other examples, other values may be used for the high and or low values (e.g., 15 and 30, 50 and 100, etc.), and/or the thrust control variable uT may be divided into more than two output value options (e.g., 10, 15, 20 and 25).
As can be seen above, Equation Group D does not require knowledge of system parameters of the UAV 100, such as the mass, the moments of inertia, the thrust and drag coefficients of the motors, and the distance from the propellers to the center of mass, unlike the methodologies used in known controllers. Thus, the thrust control variable uT is determined independent of the mass and other system parameters. Nonetheless, the signal of the thrust control variable uT has the same effect in the system dynamics as if the total thrust applied to the UAV 100 if the mass and motor thrust coefficient were known, as shown in Equation 11 below:
Since uT affects the acceleration in the x and y directions, such control eliminates the dependency on the unknown term
which is associated with the mass and the thrust from the rotors (R1, R2, R3, R4). As illustrated in
In the illustrated example, the attitude controller 308 forces the roll ϕ and pitch θ of the UAV 100 to follow the roll and pitch reference trajectories ϕref, θref (given in Equation Group C) and the yaw ψ to follow a yaw reference trajectory ψref given as an input, despite uncertainty on the moment of inertia parameters of the system in the presence of external disturbances. The yaw reference trajectory ψref may be provided by a trajectory planner, such as the reference trajectory manager 218 (
As seen in Equation Group E above, each of the control variables uϕ, uθ, uψ is output as either a positive value (e.g., torque in a positive direction) or a negative value (e.g., torque in a negative direction), depending on the result of the respective equation. In this example, output values of the control variables are 2 or −2, where 2 represents in a bias in one direction, and −2 represents a bias in the opposite direction. For example, uϕ=2 may indicate a roll in one direction where the second motor M2 is increased and/or the fourth motor M4 is decreased, and uϕ=−2 may indicate a roll in the other direction where the second motor M2 is decreased and/or the fourth motor M4 is increased. However, in other examples, other output value options may be implemented (e.g., −5 and 5, −10 and 10, etc.) and/or more output value options may be implemented (e.g., −4, −2, 2, and 4). These control variables u99, uθ, uψ, which are independent of the system parameters, maintain the orientation of the UAV 100 necessary to maintain the UAV 100 at the desired trajectory. These values, which may be calculated rapidly, result in a trajectory that holds in the desired direction, as disclosed in further detail herein. For example, using the control variable for roll uϕ, the equality of the angular velocity ωx holds, as shown in Equation 15 below.
ωX=−(−{dot over (ϕ)}ref+tan(θ)sin(θ)ωy+tan(θ)cos(ϕ)ωZ+k4|ϕ−ϕref|1/2sign(ϕ−ϕref) Equation 15
With such behavior on the angular velocity ωX, the behavior of the roll ϕ becomes as shown in Equation 16 below.
{dot over (ϕ)}={dot over (ϕ)}ref−k4|ϕ−ϕref|1/2sign(ϕ−ϕref)
Using control theory, it can be verified that the roll ϕ converges to the roll reference trajectory ϕref (the trajectory desired to track the planned trajectory in 3D space). The same can be verified for pitch θ and yaw ψ. Thus, the example control variables uϕ, uθ, uψ can be used to control the roll ϕ, pitch θ, and yaw ψ for precisely tracking the planned trajectory independent of the system parameters of the UAV 100, such as the mass of the UAV 100, the moments of inertia of the UAV 100, the drag and thrust coefficients of the motors M1, M2, M3, M4, and the distance between the motors and the center of mass of the UAV 100. As illustrated in
In the illustrated example, the motor speed selector 310 uses the control variables uT, uϕ, uθ, uψ calculated using Equation Group D and Equation Group E to select between different motor speeds configurations for the motors M1, M2, M3, M4 (each row representing a different motor speed configuration). In particular, the motor speed selector 310 uses an example switching table (which may be referred to as a motor speed configuration table), such as Table 3 below.
As can be seen from Table 3, the motor speeds for each motor M1, M2, M3, M4 are selected from a number of values representing discrete speeds or intensity values from the motor input range (e.g., a total motor speed range or spectrum). For example, in Table 3, the motor speeds are selected from eight (8) values, where 1 represents the lowest selectable speed value and 8 represents the highest selectable speed value. An example correlation may include: 1=10%, 2=15%, 3=20%, 4=25%, 5=75%, 6=80%, 7=85%, and 8=90%, where the percentages correspond to a duty cycle of the pulse-width modulation (PWM) signal that is used for powering the respective motors M1, M2, M3, M4, for example. These correlations are selected such that the speed values of 1, 2, 3, 4 are equally separated from the values for 5, 6, 7, 8, respectively (e.g., by 65%). In the example Table 3, the speed values for the motors M1, M2, M3, M4 are different than each other for each motor speed configuration.
As can be seen above in Table 3, the speeds values of 1, 2, 3, 4 are used for the lower thrust value (10) of the thrust control variable uT, and the speed values of 5, 6, 7, 8 are used for the higher thrust value (26) of the thrust control variable uT. Thus, in this example, there are eight different motor speed configurations to produce a low thrust (10), and eight different motor speed configuration to produce a high thrust (26), which can be used to affect the speed in the z direction. Each configuration is dependent on the combination of the output values for the control variables uT, uϕ, uθ, uψ. The total thrust for each of the low thrust combinations is 10, and the total thrust for each of the high thrust combinations is 26. Thus, the total thrusts for the configurations can be maintained. For example, if the thrust control variable uT is 10, and the roll, pitch, and yaw control variables uϕ, uθ, uψ, are −2, then the motor speed selector 310 selects the motor speed configuration in the first row of Table 3, where M1 is 3, M2 is 4, M3 is 1, and M4 is 2 and, thus, the thrust is 10. In such an example, the first motor M1 is activated at 20%, the second motor M2 is activated at 25%, the third motor M3 is activated at 10%, and the fourth motor M4 is activated at 15%. As another example, if the thrust control variable uT is 10, and the roll, pitch, and yaw control variables uϕ, uθ, uψ, are −2, −2, 2, respectively, then the motor speed selector 310 selects the motor speed configuration in the second row of Table 3, where M1 is 4, M2 is 3, M3 is 2, and M4 is 1, and, thus, the total thrust is also 10.
The altitude controller 306 and the attitude controller 308 rapidly calculate and recalculate (update) the values of the control variables uT, uϕ, uθ, uψ and, in response, the motor speed selector 310 quickly changes the speeds of the motors M1, M2, M3, M4 based on the output values (e.g., high or low, positive or negative, etc.) of the control variables uT, uϕ, uθ, uψ. By rapidly switching between the different motor speed configuration (different speeds for the motors M1, M2, M3, M4), the resulting flight path is a smooth, linear flight path flown by the UAV 100 along the desired trajectory. In some examples, the control variables uT, uϕ, uθ, uψ are calculated at a relatively high frequency, such as around 1,000 Hz. As such, the motor speeds can also be switched (e.g., between intensities 1-8) at a relatively high frequency. As such, the trajectory tracking controller 216 is constantly checking and changing the speeds of the motors M1, M2, M3, M4 at relatively fast, small increments that results in a flight path along the desired trajectory and does so without the need of the system parameters of the UAV 100. In other examples, the control variables uT, uϕ, uθ, uψ and/or the motor speeds may be calculated at a higher frequency (e.g., 1,500 Hz) or a lower frequency (e.g., 750 Hz). In some examples, the control variables uT, uϕ, uθ, uψ and/or the motor speeds are calculated and adjusted at a frequency of at least 500 Hz.
As can be seen by the equations above, the calculations of the control variables uT, uϕ, uθ, uψ and the selections of the motors speeds are independent of (not based on) the system parameters that are used in known controllers. In particular, the equations in Equation Groups A-E do not take into account mass (m), moments of inertia (IX, IY, IZ), thrust and drag coefficients of the motors (cT, cQ), and the distance (d) from the propellers to the center of mass, which are used in the equations of Tables 1 and 2. As such, the same calculations and controls can be used to control a UAV having a different system parameters than the UAV 100. Even though the thrusts generated by different UAVs may vary, the thrusts are proportional to each respective UAV and are compensated for by using a plurality of discrete values (e.g., 1-8) from the motor speed input. Further, even if one or more of the system parameters of the UAV 100 changes such as, for example, by adding a heavier payload, the example trajectory tracking controller 216 can continue to precisely track the planned trajectory (e.g., by selecting a motor speed configuration with a higher thrust for a longer duration of the trajectory). The system parameters may change for a variety of reasons. For example, the motors may degrade with time, which can affect the thrust and drag motor coefficients. As another example, a user (e.g., a pilot) may modify the UAV 100 in one or more of the following ways, for example: by adding a camera or other sensors that change the mass of the platform; by changing one or more of the motors to more powerful motors to increase lifting capability; by changing one or more of the motors to less powerful (e.g., lighter) motors to increase battery autonomy; by adding one or more batteries to increase the autonomy; by increasing the number of motors (e.g., to convert from a quadcopter to a hexacopter); by adding a case (e.g., a 3D printed case that looks like a spaceship), which may affect the center of mass; and/or by adding protections to increase safety. In other examples, the system parameters may be change for different reasons. Instead of using the mass and other system parameters like known controllers, the example trajectory tracking controller 216 makes relatively fast, small changes to the speeds of the motors (based on changes between the current x, y, z position of the UAV 100 and the reference signals xref, yref, zref from the planned trajectory) independent of these system parameters. As such, the example trajectory tracking controller 216 can continue to effectively operate to track the UAV 100 along a planned trajectory while advantageously enabling such changes to be made to the UAV platform.
As illustrated in
The example motor speed configuration Table 3 can be generated using the matrix from Equation 1 and the output values from the control variables uT, uϕ, uθ, uψ. For example, the speeds
By expanding the matrix in Equation 17, it can be seen that the speed values for motors M1, M2, M3, and M4 can be calculated as follows:
M1=0.25uT−0.5uθ+0.25uψ
M2=0.25uT−0.5uϕ−0.25uψ
M3=0.25uT+0.5uθ+0.25uψ
M4=0.25uT+0.5uϕ−0.25uψ
Thus, the values for M1, M2, M3, M4 can be calculated once the output values for the control variables uT, uϕ, uθ, uψ are known. For example, assuming the results of the control variables uT, uϕ, uθ, uψ correspond to the first motor speed configuration where uT=10, uϕ=−2, uθ=−2, and uψ=−2, and uψ=−2, then the speed values for M1, M2, M3, M4 can be calculated as follows:
M1=0.25(10)−0.5(−2)+0.25(−2)=3
M2=0.25(10)−0.5(−2)−0.25(−2)=4
M3=0.25(10)+0.5(−2)+0.25(−2)=1
M4=0.25(10)+0.5(−2)−0.25(−2)=2
Thus, the motor speed configuration table can be generated by inputting the different combinations of possible output values for the control variables uT, uϕ, uθ, uψ. While in this example the matrix equation is associated with the orientation of the X, Y, Z axes of the local reference frame shown in
In some examples, the motor speed configuration table is generated beforehand and stored in the memory 220 of the flight control system 214. In other examples, the motor speed selector 310 may generate the table once knowing the number of rotors or motors of the UAV 100 and the numbers of speed values to use. For example, during an initial use or calibration of the trajectory tracking controller 216, a user may input the number of motors of the UAV 100. In some examples, the controller 216 may automatically determine the number of motors of a UAV such as by detecting a mechanical connection of the motors to the motor controller(s) (e.g., the motor controller(s) 201 (
While in the example above, the motor speed configuration table is already generated and can be used to identify a particular motor speed configuration (and, thus, motor speeds) based on the output values for the control variables uT, uϕ, uθ, uψ, in other examples, the motor speed selector 310 may instead calculate (and recalculate) the motor speed values using Equation 17 above each time the output values for the control variables uT, uϕ, uθ, uψ are calculated, which results in the same effect. However, in some examples, using such a table may decrease the computational power to implement the motor speed selector 310, which may be advantageous in smaller UAVs with lower computational capabilities, for instance.
Below is an example process to generate a motor speed configuration table, such as Table 3 above. First, it is decided how many output value options are used for the thrust control variable uT and for each of the roll, pitch, and yaw torque variables uϕ, uθ, uψ, For example, the thrust control variable uT is to be selected between a high output value (aT,Low) and a low output value (aT,Low), and the roll, pitch, and yaw torque variables uϕ, uθ, uψ are to be selected between a positive output value (+aϕ, +aθ, +aψ) and a negative output value output value (−aϕ, −aθ, −aψ). Thus, in this example, the output values for each of the control variables is one of two output values. The number of output value options may be decided and input by a user, for example. Based on the number of rotors (e.g., four with a quadcopter) and the set of desired values (two for each variable), there are 16 combinations. The combinations of the high and low output values for thrust control variable uT and the positive and negative output values for the roll, pitch, and yaw control variables uϕ, uθ, uψ can be used to fill out the first four columns on the left in Table 3, for example. Then, using Equation 1 (or Equation 17) above and working backwards, the output values (for each of the thrust, roll, pitch, torque, and yaw control variables uT, uϕ, uθ, uψ) can be solved for knowing that there are two values (a high and a low) for the thrust control variable uT and two output values (a positive and a negative) for each of the roll, pitch, and yaw torque variables uϕ, uθ, uψ. Then, the output values are used in the different combinations (motor speed configurations) to solve for the motor speed values. In this example, the calculations result in eight (8) motor speed values (e.g., 1-8). The motor speed values may be correlated to specific levels within the motor speed input range. These motor speeds can then be input into the four right columns in Table 3 for the appropriate motors M1, M2, M3, M4 for each of the 16 combinations. In other examples, instead of having only two output options (high and low) for the thrust control variable uT, there could be three or more output values (a high, a medium, a low, etc.). Likewise, instead of only a single positive and negative output value for the roll, pitch, and yaw control variables uϕ, uθ, uψ, there could be two or more positive values and/or two or more negative values. Using different numbers of values results in a different number of combinations and, thus a different number of discrete motor speed values. In some examples, using a higher number of output values can be used to finer control of the thrust, roll, pitch, and yaw control dynamics, for example.
While an example manner of implementing the example trajectory tracking controller 216 of
Flowcharts representative of example machine readable instructions for implementing the example trajectory tracking controller 216 of
As mentioned above, the example processes of
At block 404, the disturbance rejecter 300 determines the disturbance rejection control laws ūx, ūy, ūz (which can be used to eliminate the IMU-based disturbance values
At block 408, the orientation reference generator 304 determines the roll and pitch reference trajectories ϕref, θref based on the determined forces (e.g., the control variables ux, uy, uz) in the x, y, z directions using Equation Group C. Thus, in some examples, the orientation reference generator 304 provides means for determining a roller reference trajectory ϕref and a pitch reference θref trajectory to be performed to navigate the UAV 100 along a planned trajectory. At block 410, the altitude controller 306 determines whether the thrust control variable uT is a first (high) output value or a second (low) output value based on the current velocity vz in the z direction (e.g., determined using the sensor system 206) and the desired velocity żref in the z direction (e.g., based on information provided by the position trajectory tracker 302) using Equation Group D. For example, using Equation Group D above, the altitude controller 306 determines the thrust control variable uT to be either 26 or 10. Thus, in some examples, the altitude controller 306 provides means for calculating or determining an output value of a thrust control variable uT based on a planned trajectory of the UAV 100. As disclosed herein, the calculation of the output value of the thrust control variable uT is independent of the system parameters of the UAV 100, including the mass of the UAV 100, the moments of inertia of the UAV 100, the drag coefficient of the motors M1, M2, M3, M4, the thrust coefficient of the motors M1, M2, M3, M4, and the distance between the motors M1, M2, M3, M4 and a center of mass of the UAV 100.
At block 412, the attitude controller 308 determines, for the roll, pitch, and yaw control variables uϕ, uθ, uψ, a first (positive) or a second (negative) output value based on the determined roll and pitch reference trajectories ϕref, θref and the yaw reference trajectory ψref using Equation Group E. For example, as seen in Equation Group E above, the roll, pitch, and yaw control variables uϕ, u74, uψ, are determined to be either 2 or −2. Thus, in some examples, the attitude controller 308 provides means for calculating or determining output values of roll, pitch, and yaw control variables based on a planned trajectory of the UAV 100. Similar to the calculation of the thrust control variable uT, the calculations of the output values for roll, pitch, and yaw control variables uϕ, uθ, uψ are independent of the system parameters of the UAV 100, including the mass of the UAV 100, the moments of inertia of the UAV 100, the drag coefficient of the motors M1, M2, M3, M4, the thrust coefficient of the motors M1, M2, M3, M4, and the distance between the motors M1, M2, M3, M4 and a center of mass of the UAV 100.
At block 414, the motor speed selector 310 selects a motor speed configuration based on the output values of the control variables uT, uϕ, uθ, uψ. For example, using the example Table 3 above, the motor speed selector 310 determines the motor speed configuration corresponding to the combination of output values for the control variables uT, uϕ, uθ, uψ. The motor speeds for each motor M1, M2, M3, M4 are selected from a number of values representing discrete speeds or intensity values from the motor input range (e.g., a total motor speed range or spectrum) such as, for example, 1=10%, 2=15%, 3=20%, 4=25%, 5=75%, 6=80%, 7=85%, and 8=90%. Thus, the motor speed selector 310 provides means for selecting motor speeds for the motors M1, M2, M3, M4 of the UAV 100 based on the output values of the control variables uT, uϕ, uθ, uψ. In some examples, instead of using a motor speed configuration table, the motor speed selector 310 may calculate the motor speed values using Equation 17 based on the output values of the control variables uT, uϕ, uθ, uψ, for example.
At block 416, the motor speed selector 310 determines if the selected motor speed configuration is the same as a current motor speed configuration. In other words, the motor speed selector 310 determines whether the motors M1, M2, M3, M4 are already currently operating at the selected speeds. In some examples, the motor speed selector 310 determines the current motor speeds based on a signal from the motor controller(s) 201 (
At block 422 of
At block 504, the motor speed selector 310 determines the output values based on the number of output values for the thrust, roll, pitch, and yaw control variables uT, uϕ, uθ, uψ and the number of rotors. In the example of Table 3, for example, there were 16 combinations, which resulted in a high output value of 26 for the thrust control variable uT, a low output value of 10 for the thrust control variable uT, and a positive output value of 2 and negative output value of −2 for each of the roll, pitch, and yaw control variables uϕ, uθ, uψ.
At block 506, the motor speed selector 310 generates a table of motor speed configurations for different combinations of the output values for the thrust, roll, pitch, and yaw control variables uT, uϕ, uθ, uψ. For example, the motor speed selector 310 may use Equation 17 above with the various combinations of the control variables uT, uϕ, uθ, uψ (e.g., first combination is 10, −2, −2, −2, second combination is 10, −2, −2, 2, and so forth). Each combination of the output values results in different speed values for the motors M1, M2, M3, M4. For instance, in Table 3 above, the combinations of the output values results in eight speed values (1-8). In some examples, the motor speed selector 310 correlates these speed values to specific levels within the motor speed input range, where 1 is the lowest, 2 is the second lowest, and so forth. For example, 1=10%, 2=15%, 3=20%, 4=25%, 5=75%, 6=80%, 7=85%, and 8=90%. Additionally or alternatively, user input may be used to correlate the speed values to the levels in the motor speed input range. After generating the table, the example process of
The processor platform 600 of the illustrated example includes a processor 612. The processor 612 of the illustrated example is hardware. For example, the processor 612 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer. The hardware processor may be a semiconductor based (e.g., silicon based) device. In this example, the processor 612 may implement the disturbance rejecter 300, the position trajectory tracker 302, the orientation reference generator 304, the altitude controller 306, the attitude controller 308, the motor speed selector 310, and/or, more generally, the trajectory tracking controller 216.
The processor 612 of the illustrated example includes a local memory 613 (e.g., a cache). The processor 612 of the illustrated example is in communication with a main memory including a volatile memory 614 and a non-volatile memory 616 via a bus 618. The volatile memory 614 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. The non-volatile memory 616 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 614, 616 is controlled by a memory controller.
The processor platform 600 of the illustrated example also includes an interface circuit 620. The interface circuit 620 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
In the illustrated example, one or more input devices 622 are connected to the interface circuit 620. The input device(s) 622 permit(s) a user to enter data and/or commands into the processor 612. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, isopoint and/or a voice recognition system. In this example, the input device(s) 622 may include, for example, the wireless transceiver 204, the sensor system 206 (including the IMU 208 and/or the GPS sensor 210), the camera 212, and/or the reference trajectory manager 218.
One or more output devices 624 are also connected to the interface circuit 620 of the illustrated example. The output device(s) 624 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a printer and/or speakers). The interface circuit 620 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip and/or a graphics driver processor. In this example, the output device(s) 624 may include, for example, the motor controller(s) 201, the motors M1, M2, M3, M4, and/or the wireless transceiver 204.
The interface circuit 620 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 626 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
The processor platform 600 of the illustrated example also includes one or more mass storage devices 628 for storing software and/or data. Examples of such mass storage devices 628 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives. In this example, the mass storage 628 may include, for example, the memory 220.
Coded instructions 632 of
From the foregoing, it will be appreciated that example methods, apparatus, systems, and articles of manufacture have been disclosed that control a rotorcraft, such as a quadcopter UAV, to fly precisely along a planned trajectory without knowledge of the system parameters, including the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag and thrust coefficients of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft. As such, example methods, apparatus, systems, and articles of manufacture disclosed herein can be easily adapted to be used with different rotorcraft having different system parameters, such as different sizes, weights, payloads, etc. Further, example methods, apparatus, systems, and articles of manufacture disclosed herein can be used while one or more of the system parameters (e.g., mass) change throughout the planned trajectory, unlike known trajectory controllers that are heavily dependent on fixed system parameters. While the examples disclosed herein are described in connection with an unmanned aircraft, the example techniques can also be implemented with a manned rotorcraft.
Example methods, apparatus, systems and articles of manufacture to track a trajectory by a rotorcraft unmanned aerial vehicle are disclosed herein. Further examples and combinations thereof include the following:
Example 1 includes a trajectory tracking system including a rotorcraft having a plurality of propeller motors and a trajectory tracking controller to determine speeds for the propeller motors to navigate the rotorcraft along a trajectory. The trajectory tracking controller includes an attitude controller to calculate output values of roll, pitch, and yaw control variables, an altitude controller to calculate an output value of a thrust control variable, and a motor speed selector to select speeds for the propeller motors based on the output values of the thrust, roll, pitch, and yaw control variables. The calculations of the output values of the thrust, roll, pitch, and yaw control variables are independent of one or more system parameters of the rotorcraft.
Example 2 includes the system of Example 1, wherein the system parameters include at least one of a mass of the rotorcraft, moments of inertia of the rotorcraft, a drag coefficient of the propeller motors, a thrust coefficient of the propeller motors, or a distance between the propeller motors and a center of mass of the rotorcraft.
Example 3 includes system of Example 2, wherein the calculations of the output values of the thrust, roll, pitch, and yaw control variables are independent of the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag coefficient of the propeller motors, the thrust coefficient of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft.
Example 4 includes the system of any of Examples 1-3, wherein the motor speed selector is to select the speeds for the propeller motors using a table having a plurality of motor speed configurations. The motor speed configurations correspond to different combinations of the output values of the thrust, roll, pitch, and yaw control variables.
Example 5 includes the system of Example 4, wherein, for each of the motor speed configurations, each of the speeds is different.
Example 6 includes the system of Example 4, wherein the motor speed selector is to select the speeds from a plurality of discrete speed values for each of the propeller motors.
Example 7 includes the system of Example 6, wherein the motor speed selector is to select the speeds from eight speed values for each of the propeller motors.
Example 8 includes the system of any of Examples 1-3, wherein the output values of the thrust, roll, pitch, and yaw controls variables are one of two output values.
Example 9 include the system of any of Examples 1-3, wherein the attitude controller is to recalculate the output values for the roll, pitch, and yaw control variables and the altitude controller is to recalculate the output value of the thrust control variable at a frequency of at least about 500 Hertz (Hz).
Example 10 includes system of any of Examples 1-3, wherein the trajectory tracking controller further includes an orientation reference generator to determine a roll reference trajectory and a pitch reference trajectory to be performed to navigate the rotorcraft along the trajectory. The attitude controller is to calculate the output value of the roll control variable based on the roll reference trajectory and calculate the output value of the pitch control variable based on the pitch reference trajectory.
Example 11 includes the system of Example 10, wherein the attitude controller is to calculate the output value of the yaw control variable based on a yaw reference trajectory.
Example 12 includes the system of Example 10, wherein the trajectory tracking controller further includes a position trajectory tracker to determine, based on a current position of the rotorcraft and a desired position of the trajectory, forces to be generated along x, y, z axes by the rotorcraft to follow the trajectory. The orientation reference generator is to determine the roll reference trajectory and the pitch reference trajectory based on the forces to be generated along the x, y, z axes.
Example 13 includes the system of Example 12, wherein the altitude controller is to calculate the thrust control variable based on a z reference signal of the desired position of the trajectory.
Example 14 includes the system of Example 12, wherein the rotorcraft includes an inertial measurement unit, and the trajectory tracking controller further includes a disturbance rejecter to determine, based on the current position of the rotorcraft and the desired position of the trajectory, one or more disturbance rejection control laws. The position trajectory tracker is to determine the forces along the x, y, z axes by eliminating disturbances from the inertial measurement unit based on the disturbance rejection control laws.
Example 15 includes the system of any of Examples 1-3, wherein the trajectory tracking controller is carried by the rotorcraft.
Example16 includes the system of any of Examples 1-3, wherein the trajectory tracking controller is remote to the rotorcraft.
Example 17 includes the system of Example 16, wherein the rotorcraft includes a wireless transceiver to communicate with the trajectory tracking controller.
Example 18 includes the system of any of Examples 1-3, wherein the rotorcraft is an unmanned aerial vehicle.
Example 19 includes the system of any of Examples 1-3, wherein the rotorcraft is a quadcopter.
Example 20 includes a non-transitory machine readable storage medium including instructions that, when executed, cause a machine to at least calculate output values for thrust, roll, pitch, and yaw control variables based on a trajectory of a rotorcraft independent of one or more system parameters of the rotorcraft, select motor speeds for propeller motors of the rotorcraft based on the output values for the thrust, roll, pitch, and yaw control variables, and activate the propeller motors based on the selected motor speeds.
Example 21 includes the non-transitory machine readable storage medium of Example 20, wherein the system parameters include at least one of a mass of the rotorcraft, moments of inertia of the rotorcraft, a drag coefficient of the propeller motors, a thrust coefficient of the propeller motors, or a distance between the propeller motors and a center of mass of the rotorcraft.
Example 22 includes the non-transitory machine readable storage medium of Example 21, wherein the instructions, when executed, cause the machine to calculate the output values of the thrust, roll, pitch, and yaw control variables independent of the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag coefficient of the propeller motors, the thrust coefficient of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft.
Example 23 includes the non-transitory machine readable storage medium of any of Examples 20-22, wherein the motor speeds are selected from a table of a plurality of motor speed configurations. The motor speed configurations correspond to different combinations of the output values of the thrust, roll, pitch, and yaw control variables.
Example 24 includes the non-transitory machine readable storage medium of Example 23, wherein, for each of the motor speed configurations, each of the motor speeds is different.
Example 25 includes the non-transitory machine readable storage medium of Example 23, wherein the motor speeds are selected from a plurality of discrete speed values for each of the propeller motors.
Example 26 includes the non-transitory machine readable storage medium of Example 25, wherein the motor speeds are selected from eight discrete speed values for each of the propeller motors.
Example 27 includes the non-transitory machine readable storage medium of any of Examples 20-22, wherein each of the thrust, roll, pitch, and yaw control variables are one of two output values.
Example 28 includes the non-transitory machine readable storage medium of any of Examples 20-22, wherein the instructions, when executed, further cause the machine to recalculate the output values of the thrust, roll, pitch, and yaw control variables, select the motor speeds, and activate the propeller motors at a frequency of at least about 500 Hertz (Hz).
Example 29 includes the non-transitory machine readable storage medium of any of Examples 20-22, wherein the instructions, when executed, further cause the machine to determine a roll reference trajectory and a pitch reference trajectory to be performed to navigate the rotorcraft along the trajectory. The calculation of the output value of the roll control variable is based on the roll reference trajectory and the calculation of the output value of the pitch control variable is based on the pitch reference trajectory.
Example 30 includes the non-transitory machine readable storage medium of Example 29, wherein the instructions, when executed, cause the machine to calculate the output value of the yaw control variable based on a yaw reference trajectory.
Example 31 includes the non-transitory machine readable storage medium of Example 29, wherein the instructions, when executed, further cause the machine to determine, based on a current position of the rotorcraft and a desired position of the trajectory, forces to be generated along x, y, z axes by the rotorcraft to follow the trajectory. The determination of the roll reference trajectory and the pitch reference trajectory are based on the forces to be generated along the x, y, z axes.
Example 32 includes the non-transitory machine readable storage medium of Example 31, wherein the instructions, when executed, cause the machine to calculate the thrust control variable based on a z reference signal of the desired position of the trajectory.
Example 33 includes the non-transitory machine readable storage medium of Example 31, wherein instructions, when executed, further cause the machine to determine, based on the current position of the rotorcraft and the desired position of the trajectory, one or more disturbance rejection control laws. The calculation of the forces to be generated along the x, y, z axes uses the disturbance rejection control laws to eliminate disturbances from an inertial measurement unit of the rotorcraft.
Example 34 includes a trajectory tracking controller including means for calculating an output value of a thrust control variable based on a trajectory of a rotorcraft independent of one or more system parameters of the rotorcraft, means for calculating output values of roll, pitch, and yaw control variables based on the trajectory independent of the one or more of the system parameters, means for selecting motor speeds for propeller motors of the rotorcraft based on the output values of the thrust, roll, pitch, and yaw control variables, and means for activating the propeller motors based on the selected motor speeds.
Example 35 includes the controller of Example 34, wherein the system parameters include at least one of a mass of the rotorcraft, moments of inertia of the rotorcraft, a drag coefficient of the propeller motors, a thrust coefficient of the propeller motors, or a distance between the propeller motors and a center of mass of the rotorcraft.
Example 36 includes the controller of Example 35, wherein the output values of the thrust, roll, pitch, and yaw control variables are calculated independent of the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag coefficient of the propeller motors, the thrust coefficient of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft.
Example 37 includes the controller of any of Examples 34-36, wherein the means for selecting is to select the motor speeds from a table of a plurality of motor speed configurations. The motor speed configurations corresponding to different combinations of the output values of the thrust, roll, pitch, and yaw control variables.
Example 38 includes the controller of Example 37, wherein, for each of the motor speed configurations, each of the motor speeds is different.
Example 39 includes the controller of Example 37, wherein the motor speeds are selected from a plurality of discrete speed values for each of the propeller motors.
Example 40 includes the controller of Example 39, wherein the motor speeds are selected from eight discrete speed values for each of the propeller motors.
Example 41 includes the controller of any of Examples 34-36, wherein each of the thrust, roll, pitch, and yaw control variables are one of two output values.
Example 42 includes the controller of any of Examples 34-36, wherein the means for calculating the output value of the thrust control variable and the means for calculating the output values of the roll, pitch, and yaw control variables are to recalculate the output values for the thrust, roll, pitch, and yaw control variables, respectively, the means for selecting is to select the motor speeds, and the means for activating is to activate the propeller motors at a frequency of at least about 500 Hertz (Hz).
Example 43 includes the controller of any of Examples 34-36, further including means for determining a roll reference trajectory and a pitch reference trajectory to be performed to navigate the rotorcraft along the trajectory. The means for calculating the output values of the roll, pitch, and yaw control variables is to calculate of the output value of the roll control variable based on the roll reference trajectory and calculate the output value of the pitch control variable based on the pitch reference trajectory.
Example 44 includes the controller of Example 43, wherein the means for calculating the output values of the roll, pitch, and yaw control variables is to calculate the output value of the yaw control variable based on a yaw reference trajectory.
Example 45 includes the controller of Example 43, further including means for determining forces to be generated along x, y, z axes by the rotorcraft to follow the trajectory based on a current position of the rotorcraft and a desired position of the trajectory. The means for determining the roll reference trajectory and the pitch reference trajectory is to determine the roll reference trajectory and the pitch reference trajectory based on the forces to be generated along the x, y, z axes.
Example 46 includes the controller of Example 45, wherein the means for calculating the output value of the thrust control variable is to calculate the output value of the thrust control variable based on a z reference signal of the desired position of the trajectory.
Example 47 includes the controller of Example 45, further including means for determining one or more disturbance rejection control laws based on the current position of the rotorcraft and the desired position of the trajectory. The means for determining the forces to be generated along the x, y, z axes uses the disturbance rejection control laws to eliminate disturbances from an inertial measurement unit of the rotorcraft.
Example 48 includes a method to control a rotorcraft to fly along a trajectory including calculating, by executing an instruction with at least one processor, output values for thrust, roll, pitch, and yaw control variables independent of one or more system parameters of the rotorcraft, determining, by executing an instruction with the at least one processor, motor speeds for a plurality of propeller motors of the rotorcraft based on the output values for the thrust, roll, pitch, and yaw control variables, the motor speeds being selected from a table of discrete motor speed values, and activating, via one or more motor controllers, the propeller motors of the rotorcraft based on the determined motor speeds.
Example 49 includes the method of Example 48, wherein the system parameters include at least one of a mass of the rotorcraft, moments of inertia of the rotorcraft, a drag coefficient of the propeller motors, a thrust coefficient of the propeller motors, or a distance between the propeller motors and a center of mass of the rotorcraft.
Example 50 includes the method of Example 49, wherein calculating the output values of the thrust, roll, pitch, and yaw control variables is independent of the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag coefficient of the propeller motors, the thrust coefficient of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft.
Example 51 includes a trajectory tracking controller including an altitude controller to calculate an output value of a thrust control variable based on a trajectory of a rotorcraft independent of one or more system parameters of the rotorcraft, an attitude controller to calculate output values of roll, pitch, and yaw control variables based on the trajectory independent of the one or more of the system parameters, and a motor speed selector to select speeds for propeller motors of the rotorcraft based on the output values of the thrust, roll, pitch, and yaw control variables and activate the propeller motors based on the selected motor speeds.
Example 52 includes the controller of Example 51, wherein the system parameters include at least one of a mass of the rotorcraft, moments of inertia of the rotorcraft, a drag coefficient of the propeller motors, a thrust coefficient of the propeller motors, or a distance between the propeller motors and a center of mass of the rotorcraft.
Example 53 includes the controller of Example 52, wherein the output values of the thrust, roll, pitch, and yaw control variables are calculated independent of the mass of the rotorcraft, the moments of inertia of the rotorcraft, the drag coefficient of the propeller motors, the thrust coefficient of the propeller motors, and the distance between the propeller motors and the center of mass of the rotorcraft.
Example 54 includes the controller of any of Examples 51-53, wherein the motor speed selector is to select the motor speeds from a table of a plurality of motor speed configurations, the motor speed configurations corresponding to different combinations of the output values of the thrust, roll, pitch, and yaw control variables.
Example 55 includes the controller of Example 54, wherein, for each of the motor speed configurations, each of the motor speeds is different.
Example 56 includes the controller of Example 54, wherein the motor speeds are selected from a plurality of discrete speed values for each of the propeller motors.
Example 57 includes the controller of Example 56, wherein the motor speeds are selected from eight discrete speed values for each of the propeller motors.
Example 58 includes the controller of any of Examples 51-53, wherein each of the thrust, roll, pitch, and yaw control variables are one of two output values.
Example 59 includes the controller of any of Examples 51-53, wherein the altitude controller and the attitude controller are to recalculate the output values for the thrust, roll, pitch, and yaw control variables, respectively, the motor speed selector is to select the motor speeds, and the motor controller is to activate the propeller motors at a frequency of at least about 500 Hertz (Hz).
Example 60 includes the controller of any of Examples 51-53, further including an orientation reference generator to determine a roll reference trajectory and a pitch reference trajectory to be performed to navigate the rotorcraft along the trajectory, the attitude controller is to calculate of the output value of the roll control variable based on the roll reference trajectory and calculate the output value of the pitch control variable based on the pitch reference trajectory.
Example 61 includes the controller of Example 60, wherein the attitude controller is to calculate the output value of the yaw control variable based on a yaw reference trajectory.
Example 62 includes the controller of Example 60, further including a position trajectory tracker to determine forces to be generated along x, y, z axes by the rotorcraft to follow the trajectory based on a current position of the rotorcraft and a desired position of the trajectory, the orientation reference generator is to determine the roll reference trajectory and the pitch reference trajectory based on the forces to be generated along the x, y, z axes.
Example 63 includes the controller of Example 62, wherein the altitude controller is to calculate the output value of the thrust control variable based on a z reference signal of the desired position of the trajectory.
Example 64 includes the controller of Example 62, further including a disturbance rejecter to determine one or more disturbance rejection control laws based on the current position of the rotorcraft and the desired position of the trajectory, the position trajectory tracker is to use the disturbance rejection control laws to eliminate disturbances from an inertial measurement unit of the rotorcraft.
Although certain example methods, apparatus, systems, and articles of manufacture have been disclosed herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus, systems, and articles of manufacture fairly falling within the scope of the claims of this patent.
Number | Name | Date | Kind |
---|---|---|---|
8019492 | Halaas | Sep 2011 | B2 |
20120095621 | Zhu | Apr 2012 | A1 |
20170088261 | Sequeira | Mar 2017 | A1 |
Number | Date | Country |
---|---|---|
WO-2014-198642 | Dec 2014 | WO |
2017111971 | Jun 2017 | WO |
Number | Date | Country | |
---|---|---|---|
20190033892 A1 | Jan 2019 | US |