A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the patent and trademark office patent file or records, but otherwise reserves all copyright rights whatsoever.
The present disclosure relates generally to flight instrumentation and, more particularly, to systems and methods of determining the airspeed of an airborne object.
Unmanned aerial vehicles (“UAV”), sometimes referred to as “drones,” include pilotless aircraft of various sizes and configurations that can be remotely operated by a user or programmed for automated flight. UAVs can be used for many purposes and are often used in a wide variety of personal, commercial, and tactical applications. For instance, UAVs can be equipped with imaging equipment, such as cameras, video cameras, etc. UAVs equipped with imaging devices find particular use in the surveillance, national defense, and professional videography industries, among others, besides being popular with hobbyists and for recreational purposes.
The flight characteristics of UAVs, similar to other aerial vehicles such as manned aircrafts and helicopters, highly depend on the speed of the UAVs relative to air (airspeed). For example, a fixed-wing UAV must be controlled to fly at or above a certain threshold airspeed, so that the wings of the UAV can generate sufficient lift to keep the UAV airborne. A multi-copter UAV must be controlled to fly below a maximum safe forward airspeed, to avoid unwanted conditions such as retreating blade stalls. Therefore, accurate determination of airspeed is necessary for safe and effective operation of a UAV.
With conventional technologies, the airspeed of a UAV can be estimated based on a lookup table that maps an attitude of the UAV (which indicates an orientation of the UAV relative to a horizontal plane, and can include a yaw angle, a pitch angle, and a roll angle relative to the horizontal ground) to a horizontal airspeed. The lookup table is typically created during a calibration process in which the UAV flies at a fixed altitude and at a predetermined attitude, at a steady speed, and in an environment where there is no air current (e.g., a fully-enclosed indoor environment). When no wind is present, the UAV's ground speed is considered to be its horizontal airspeed. The UAV's ground speed can be determined based on a change in the UAV's horizontal location measured with a Global Positioning System (GPS). The lookup table is created after repeated tests with different attitudes to reflect the correspondence between attitude and airspeed (or ground speed). In operation, the lookup table is used to estimate the UAV's airspeed based on its attitude.
This conventional approach has limits. First, the lookup table, being generated in a windless environment, does not accurately reflect the relationship between attitude and airspeed in an environment with wind, e.g., an outdoor environment. Second, the lookup table only reflects the correspondence between attitude and steady airspeed. In other words, it fails to indicate the airspeed before the UAV reaches the steady speed at a certain attitude. For example, the lookup table cannot be used to estimate the interim airspeed when the UAV is climbing, descending, accelerating, or decelerating.
Accordingly, there is need to provide improved estimation of airspeed, hence improved flight operations.
Consistent with the present disclosure, there is provided a method of determining airspeed of a movable object. The method includes a calibration process to determine a relationship between forces exerted on the movable object and airspeed of the movable object. Forces exerted on the movable object while the movable object is moving are determined, and the airspeed of the movable object is determined based on the determined forces and the relationship.
Consistent with the present disclosure, there is provided a movable object that includes a memory storing a relationship between airspeeds and forces exerted on the movable object; a first sensor that senses forces exerted on the movable object; and a processor configured to determine an airspeed of the movable object based on the relationship and the sensed forces on the movable object.
Consistent with the present disclosure, there is also provided a movable object that includes one or more propellers; an electronic speed control module configured to determine rotational speeds of the one or more propellers; an accelerometers configured to detect one or more forces received by the movable object; an attitude detection unit that includes at least one of a magnetometer, a gyroscope, or an inertial measurement unit; a barometer configured to provide information for determination of air density; a memory storing a relationship between airspeeds and forces exerted on the movable object; and a processor configured to determine an airspeed of the movable object based on the relationship, the detected forces, the rotation speeds, an attitude detected by the attitude detection unit.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the disclosed embodiments as defined in the claims.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate several embodiments and, together with the description, serve to explain the disclosed principles. In the drawings:
The disclosed embodiments provide improved techniques for flight instrumentation and, more particularly, systems and methods of determining the airspeed of an airborne object based on the ground speed of the airborne object, and one or more forces received by the airborne object. The resulting systems and methods provide enhanced accuracy, usability, and robustness in their ability to determine the airspeed of an airborne object operating under different environments and in different flight states.
Reference will now be made in detail to exemplary disclosed embodiments, examples of which are illustrated in the accompanying drawings and disclosed herein. Where convenient, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
Embodiments are provided below using UAVs as exemplary movable objects. As used herein, the term UAV may refer to an aerial device configured to be operated and controlled autonomously (i.e., via an electronic control system) and/or manually by off-board personnel. It will also be understood that other types of airborne movable objects may also or alternatively be used in embodiments consistent with this disclosure. For example, embodiments presented herein should apply to any suitable movable object, device, mechanism, system, or machine configured to travel on or within a suitable medium (e.g., a surface, air, water, rails, space, underground, etc.).
The position, attitude, and movements of movable object 100 may be characterized differently from different perspectives. The earth's or ground frame of reference is labeled as a three-dimensional space with an x-axis, a y-axis, and a z-axis, the x-y plane being parallel to the horizontal ground 104. For example, as shown in the figure, with respect to the earth's frame of reference, movable object 100 is at an altitude 102 above horizontal ground 104, and at an attitude (e.g., with a pitch angle 103) with respect to horizontal ground 104. Movable object 100 is also moving along a direction 106 with horizontal ground speed 108 (with respect to ground 104) and vertical ground speed 109. Movable object 100 is also moving against air currents 110.
At the same time, a coordinate system is also often defined in the movable object's own perspective or frame of reference, and labeled as x′, y′, and z′. In the movable object's coordinate system, movements may consist of lateral and vertical components, the lateral movement being in the plane of the rotations of the propellers and the vertical movement being in the direction perpendicular to the rotation plane. In the present disclosure, the terms “lateral” and “vertical” are defined as such in the coordinate system or reference frame of the movable object. If not otherwise specified, variables without an apostrophe refer to physical properties in the earth's or ground reference frame; variables with an apostrophe refer to physical properties in the movable object's reference frame.
As discussed above, conventional methods, where the attitudes of a UAV are mapped to steady horizontal ground speeds, cannot provide an accurate estimation of the airspeed of an airborne object (like movable object 100) that is undergoing changes in altitude and speed and moving under the influence of air currents. Consistent with embodiments of the present disclosure, estimates of airspeed may be achieved in real time and with better accuracy, as described below in detail.
In a movement with both lateral and vertical components, movable object 100 experiences various forces, including the gravity, so-called H-forces in the lateral direction, thrust T in the vertical direction, and form drag. For ease of discussion, several parameters are defined:
The lateral H-forces generated by propellers 101a and 101b can be represented by the following expression:
H′=kρω
t
W′=kρω
t
S
12
Ru=kρω
t
S
12
R(v+w) (1),
where k is a scaling constant. Lateral forces also include form drag; but compared to the H-forces, form drag in the lateral plane is much smaller, and can therefore be ignored.
Thrust T′ in the vertical direction depends on the rotation speed and diameter d of propeller and can be expressed as:
T′=C
T
ρd
4ω2 (2).
CT is the thrust coefficient and depends on axial or vertical airspeed V′ and the propeller speed. CT decreases as vertical airspeed increases.
Form drag in the vertical direction, caused by friction between a surface of the movable object and the air, can be expressed as:
D′=½ρAV′2CD (3),
where A is the reference surface area and CD is a drag coefficient. Thus, the total vertical forces movable object 100 experiences can be expressed as:
F′=D(V′)−ΣiT′(ωi,V′) (4),
in which the second component represents a sum thrust of all propellers i.
In expressions (1), (2), and (3), S12, propeller diameter d, and reference surface area A are known constants. Most of the variables can be measured with devices, sensors, or components on board movable object 100. For example, ground speed v can be measured by GPS or an imaging device; attitude matrix R can be determined from readings of the inertia measuring unit (IMU), a gyroscope, or a magnetometer, which can provide information about, for example, an angular rate and an orientation of movable object 100; air density ρ can be measured by a barometric altimeter or a temperature sensor; and propeller rotation speed ω can be measured by an electronic speed control (ESC) module. The ESC module can vary the rotation speeds of electric motors that drive the propellers, and can provide information about the rotation speeds.
An accelerometer can sense the proper acceleration of movable object 100, i.e., acceleration relative to free fall and with gravitational force removed. In other words, if movable object 100 is free falling, the accelerometer measures 0 acceleration. If movable object 100 sits still on a desk, the accelerometer measures an acceleration that corresponds to the force exerted by the desk, which is the gravity's reaction force. Following Newton's Second Law, acceleration so measured can be used to derive the total force experienced by movable object 100. Assuming the measured acceleration is
in the movable object's reference frame, the force experienced by movable object 100 is a vector F′=ma′. Because a′ does not reflect the gravitational force, F′ mainly includes only the H-force (expression (1)), thrust T′ (expression (2)), and vertical form drag D′ (expression (3)).
H-force is only in the lateral direction in the movable object's reference frame, and can be derived from the measured acceleration:
H′=S
12
F′=mS
12
a′ (5).
Combined with expression (1), this means
S
12
a′=k
1ρωtS12R(v+w) (6).
In expression (6), only the adjusted scaling constant k1=k/m and wind speed w are unknown.
Likewise, forces in the vertical direction can be expressed using the measured acceleration:
F′
z′
=e
3
T
F′=me
3
T
a′ (7).
Combining (7) with (4) yields (8) below:
me
3
T
a′=D(V′)−ΣiT′(ωi,V′) (8).
Expression (8) can be reduced to (9) below by eliminating the mass element m:
e
3
T
a′=g(V′)−Σif′(ωi,V′) (9),
where g(V′)=D(V′)/m and Σif′(ωi, V′)=ΣiT′(ωi, V′)/m. In expression (9), V′ is unknown. Functions g(V′) and f′(ωi, V′) are also unknown because coefficient CD and the relationship between CT and V′ are unknown.
Consistent with embodiments of the present disclosure, movable object 100 may be calibrated prior to actual flight to determine the scaling constant k1 in expression (6) and the functions g(V′) and r(ωi, V′) in expression (9), such that, during actual flight, measurements of the various variables can be used to determine the airspeed (hence the wind speed) using those expressions. In one aspect, the scaling constant k1 can be determined based on a linear regression method. For example, expression (6) can be rewritten as follows:
If we use y to denote S12 a′, Φ to denote [ρωtS12Rv k1ρωtS12R], and θ to denote the unknowns
then (6*) is simplified as y=Φθ. Instantaneous relationship defined by (6*) can then be represented as yj=Φjθj at time j. It is uncommon for the wind speed to change suddenly in either direction or magnitude. Therefore, θ is considered a slow-changing variable compared to the sampling rate of the sensors on movable object 100. As a result, instantaneous measurements of attitude R, air density ρ, propeller rotational speed ωt, and ground speed v over time can be used to determine scaling constant k1, where k1 is recursively updated over time j. For example, a recursive least squares filter can be applied to expression (6*) to recursively determine k1. After sufficient data has been generated and applied in the calculation, the value of k1 should be reliable.
Alternatively, calibration in the lateral direction may be performed in an indoor environment, where wind speed w can be assumed to be zero. In that case, expression (6) is reduced to:
S
12
a′=k
1ρωtS12Rv (6*)
Measurements of acceleration a′, sum of rotational speeds ωt, density ρ, sum of rotational speeds ωt, attitude R, and ground speed v would permit determination of the constant k1. In the indoor environment, ground speed v may be measured either by onboard sensors or by motion captures equipment. Likewise, a linear regression method can be employed to determine the value of k based on a series of the-mentioned measurements. For example, a set of accelerometer readings, and a set of corresponding values of ρωtS12Rv, can be collected. A function, based on an estimated value of k1, for predicting a value of ρωtS12Rv can be determined, and a value of k1 that minimizes a squared difference between the predicted and actual values of ρωtS12Rv can also be determined. Indoor calibration of the lateral movements is much simplified because the wind speed can be assumed to be 0, but it requires a large indoor field to ensure the calibration is reliable at the entire range of lateral speeds.
During the calibration, movable object 100 may be set to move in different directions, such that attitude R and/or ground velocity v, hence Φ or ρωtS12Rv, change constantly, thereby providing sufficient persistence of excitation and leading to the parameter k1 converging to a correct and more reliable value. Attitude R, for example, can be changed by movable object 100 constantly turning or changing its yaw, either at a constant rate or at different rates. Also, even though θ is a slow-changing variable, a forgetting factor may be used to give certain weight to historical values in the recursive process.
Once k1 (hence k) is determined, the value can then be stored (e.g., in a memory included in movable object 100), and can be used to determine, in real-time, the lateral airspeed W′, based on accelerometer readings representing real-time measurements of the H-force (expression (5)), as well as real-time measurements of air density ρ and rotational speed ω.
Calibration in the vertical direction may be performed in a wind tunnel.
e
3
T
a′=g(V′)−Σif′(ωi,V′) (9).
A series of the data triplets (ωj, V′j, a′j) can then be used to fit the functions g(V′) and f′(ωj, V′). The determination of g(V′) and f(ωi, V′) can be based on regression method as well.
In some embodiments, calibration in the vertical direction can be performed in an outdoor environment, especially when almost no wind is present. For example, movable object 100 can be projected up into the air and then allowed to ascend and descend. As movable object 100 moves vertically, it may be moving at different vertical airspeeds V′. Different combinations of vertical airspeeds V′ and rotational speeds co may also be generated and mapped to different accelerometer readings a, and functions g(V′), and f(ωi, V′) can be determined accordingly.
Once functions g(V′) and f(ωi, V′) are determined, the accelerometer reading a can then be used to solve the vertical/axial speed V′ as a function of acceleration and the speeds of the propellers:
V=h(az′,ω1,ω2, . . . ,ωN) (10).
Parameters of function h are determined based on parameters representing g(V′) and f(ωi, V′). The parameters of functions h(az′, ω1, ω2, . . . , ωN), g(V′), and f(ωi, V′) can be stored (e.g., in a memory included in movable object 100), and can be used to determine, in real-time, the vertical airspeed based on accelerometer readings representing real-time measurements of the vertical forces experienced by movable object 100 (excluding gravitational pull), as well as real-time measurements of rotational speeds ω1 . . . ωN and air density ρ.
During actual flight, the calibrated results are used to determine lateral airspeed W′ and vertical airspeed V′. Then the 3-dimensional airspeed u′ can be determined based on the two. From u′, the airspeed u in the earth's can be determined as u=R−1u′. With u and the GPS read of the ground speed v, the wind speed w can also be determined as u−v.
Reference is now made to
Housing 302 may also house a controller system that includes one or more processors, one or more input/output (I/O) devices, and one or more memories.
Processor 420 may include one or more known processing devices. For example, the processor may be from the family of processors manufactured by Intel, from the family of processors manufactured by Advanced Micro Devices, or the like. Alternatively, the processor may be based on the ARM architecture. In some embodiments, the processor may be a mobile processor. The disclosed embodiments are not limited to any particular type of processor.
I/O devices 422 may be one or more devices configured to allow data to be received and/or transmitted by the controller 410. The I/O devices 422 may include one or more communication devices and interfaces, and any necessary analog-to-digital and digital-to-analog converters, to communicate with and/or control other mechanical components and devices, such as propellers 304, GPS receiver 306, altimeter 309, barometer and temperature sensor 310, attitude detection unit 312, accelerometers 314, and video cameras 316.
Memory 424 may include one or more storage devices configured to store software instructions used by the processor 420 to perform functions related to the disclosed embodiments. For example, the memory 424 may be configured to store software instructions, such as program(s) 426 that performs one or more operations when executed by processor(s) 420. For example, memory 424 may include a single program 426, such as a user-level application, that performs the functions of the disclosed embodiments, or may comprise multiple software programs. Additionally, the processor 420 may execute one or more programs (or portions thereof) remotely located from the controller 410. Furthermore, memory 424 also may be configured to store data, for example, for use by the software program(s) 426.
In some embodiments, systems 300 and 400 can be configured as movable object 100 of
For example, referring back to
Moreover, software program(s) 426 can include one or more software modules configured to execute a second calibration mode for vertical airspeed determination. For example, software program(s) 426 can control movable object 100 to move along a vertical direction with the propellers rotating at a predetermined rotational speed. Software program(s) 426 can also control movable object 100 to move within a wind tunnel such that a rotation axis of the propellers align with the wind direction. In both cases, software program(s) 426 can acquire different combinations of accelerometer reading, propellers rotational speeds, and airspeeds, and then perform an algorithm of regression method to determine the parameters representing g(V′) and Σif′(ωi, V′) in expression (9), h(az′, ω1, ω2, . . . , ωN) in expression (10), and store the parameters in memory 424. After the second calibration mode completes, software program(s) 426 can then determine vertical airspeed based on the stored parameters and new samples of accelerometer readings, attitude, air density, and propellers' rotational speeds.
Reference is now made to
In step 502, the system determines to start a calibration phase for airspeed determination. The determination to start a calibration phrase can be triggered by different events. For example, the system may determine to start a calibration phase when the system just starts up, or that the system has not been airborne for a predetermined amount of time (e.g., a week), etc.
After determining to start a calibration phase, the system proceeds to step 504 to determine whether to proceed with a first calibration mode (for horizontal airspeed determination) or to proceed with a second calibration mode (for vertical airspeed determination). In some embodiments, the system may be configured to first proceed with the first calibration mode followed by the second calibration mode, or vice versa. In some embodiments, the system may also determine to forgo the second calibration mode, if the air current direction is mostly parallel with the ground. In that case, the system may determine the vertical airspeed based on the horizontal airspeed (after first calibration mode completes) and the attitude of the movable object. For example, the system may determine an airspeed of the movable object based on a projection of the horizontal airspeed onto the direction of motion of the movable object (determined based on the attitude), and then projecting the airspeed onto vertical z-axis to determine the vertical airspeed.
After determining to proceed with the first calibration mode in step 504, the system can then proceed to step 506 and perform the first mode of calibration to determine first calibration parameters. Reference is now to
While the movable object moves in the first direction, the system also determines the ground speed along the first direction based on, for example, location information provided by the GPS or determined based on video image data, in step 512. The system also determines the air density based on, for example, barometer and temperature sensor data, in step 514. The system also determines the rotational speeds of the propellers in step 516, and the H-force received by the movable object along the first direction in step 518. In steps 512-518, multiple samples of these parameters can be acquired at different time points. After acquiring the samples of these parameters when the movable object is moving in the first direction, the system then proceed to step 520 to determine a set of regressor vectors based on the determined parameters.
After determining the regressor vectors, the system may then perform a regression analysis, using the regressor vectors, to determine a relationship between the H-force and the airspeed, in step 522. As discussed above, the determination can be based on, for example, recursive least squares method (if both wind speed and the constant k are unknown) or least square estimation (if the wind speed can be assumed zero). Based on a result of step 518, the system can then determine whether there are sufficient data points to perform the analysis. The sufficiency can be determined based on, for example, whether there is a convergence to a certain degree between a predicted model and the determined parameters, whether a range of the determined parameters satisfies a predetermined threshold, etc.
If the system determines that there are not sufficient data points, in step 524, the system may proceed to step 526 and update the first direction. For example, the system may change a yaw angle of the movable object, and then repeat steps 510-522 to acquire more data points for the regression analysis. On the other hand, if the system determines that the data points are sufficient, in step 526, the system can then proceed to step 528 and determine the first calibration parameters based on a result of the regression analysis. The first calibration parameters may include, for example, a constant k that relates the H-force to airspeed, according to expression (1). The system can then provide the first calibration parameters for determination of horizontal airspeed, in step 530.
Referring back to
Reference is now made to
When the movable object is moving along the second direction, the system can proceed to step 538 and control the rotational speeds of the propellers, to obtain different combinations of accelerometer readings (which represent a force received by the movable object along the second direction), airspeeds, and rotational speeds. For example, the movable object may be descending vertically in an outdoor environment and experiences an increase in vertical airspeed. During the descending, the system can change the rotational speed of the propellers, and obtain samples, from an accelerator, of measurements of the vertical force (excluding the gravitational pull) experienced by the movable object. Moreover, the movable object may also be moving horizontally in a wind tunnel, where the wind speed (and the airspeed) is adjusted, and the rotational speed of the propellers are also adjusted, to create different combinations of accelerometer readings, airspeeds, and rotational speeds.
After combinations of accelerometer readings, airspeeds, and rotational speeds are collected, the system can proceed to step 540 to perform regression analysis to determine second calibration parameters representing a relationship between the vertical airspeed and a combination of accelerometer readings and propellers rotational speeds. For example, the system may determine parameters representing g(V′) and Σif′(ω1, V′) in expression (9), h(az′, ω1, ω2, . . . , ωN) in expression (10). After determining the second calibration parameters in step 540, the system can then proceed to step 542 and provide the second calibration parameters for vertical airspeed determination.
Referring back to
Reference is now made to
For the purposes of this disclosure, “modules” may be implemented in software, hardware, firmware, a mix of any of those, or the like. For example, if the disclosed “modules” are implemented in software, they may be stored in memory 424 of system 400 as components of program(s) 426, and include code instructions executable by one or more processors, alone or in various combinations with other modules disclosed in this or other embodiments. On the other hand, the disclosed “modules” can also be implemented in hardware such as, for example, application specific integrated circuits (ASIC), field-programmable gate array (FPGA), etc. System 600 may be housed in, for example, movable object 100.
In some embodiments, calibration module 602 is configure to cause a movable object to enter a calibration mode, in which calibration parameters for horizontal and vertical airspeed determination can be determined. In some embodiments, calibration module 602 is configured to perform, for example, steps 502 and 504 of
In some embodiments, motion control module 603, which can be a part of calibration module 602, is configured to control a motion of the movable object based on the calibration mode, and to update, for example, a direction of motion, rotational speeds of the propellers, etc. In some embodiments, motion control module 603 is configured to perform, for example, steps 510 and 526 of
In some embodiments, sensor module 604, which can be a part of calibration module 602, is configured to acquire flight data of the movable object, which can include, for example, air density, propeller speeds, ground speed, and attitude of the movable object, as well as one or more forces received by the movable object. In some embodiments, sensor module 604 is configured to perform, for example, steps 512-518 of
In some embodiments, calibration parameters module 606 is configured to determine calibration parameters for horizontal and vertical airspeed determination. The determination may include regression analysis and based on the flight data acquired by sensor module 604. In some embodiments, calibration parameters module 606 is configured to perform, for example, steps 520-524 and 528 of
In some embodiments, airspeed determination module 608 is configured to determine an airspeed of the movable object based on the calibration parameters provided by calibration parameters module 606, as well as new flight data acquired by sensor module 604. In some embodiments, airspeed determination module 608 is configured to perform, for example, steps 544 and 548 of
Other embodiments will be apparent to those skilled in the art from consideration of the specification and practice of the disclosed embodiments. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the disclosed embodiments being indicated by the following claims. It is to be understood that the examples and descriptions in this disclosure have been arbitrarily defined herein for the convenience of the description. The disclosed systems and methods are not limited to these simplified examples, and other features and characteristics may be considered so long as the specified functions are appropriately performed.
While certain disclosed embodiments have been discussed with respect to UAVs for purposes of discussion, one skilled in the art will appreciate the useful applications of disclosed methods and systems for identifying target objects. Furthermore, although aspects of the disclosed embodiments are described as being associated with data stored in memory and other tangible computer-readable storage mediums, one skilled in the art will appreciate that these aspects can be stored on and executed from many types of tangible computer-readable media. Further, certain processes and steps of the disclosed embodiments are described in a particular order, one skilled in the art will appreciate that practice of the disclosed embodiments are not so limited and could be accomplished in many ways. Accordingly, the disclosed embodiments are not limited to the above-described examples, but instead are defined by the appended claims in light of their full scope of equivalents.
This application is a continuation of International Application No. PCT/CN2017/103725, filed Sep. 27, 2017, the entire content of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2017/103725 | Sep 2017 | US |
Child | 16721002 | US |