Unmanned aerial vehicles (UAVs) are remotely piloted or self-piloted aircraft that can carry cameras, sensors, communications equipment, or other payloads. They have been used in a reconnaissance and intelligence-gathering role for many years. More recently, UAVs have been developed for the purpose of surveillance and target tracking.
Autonomous surveillance and target tracking performed by UAVs in either military or civilian environments is becoming an important aspect of intelligence-gathering. Typically, when a target is being tracked from aerial vehicles (e.g. a UAV), human operators must closely monitor imagery streamed from the aircraft to assess target behavior and ensure that the target continues to be in view.
This invention provides a system and method for autonomously tracking a moving target from UAVs with a variety of airframe and sensor payload capabilities so that the target remains within the vehicle's sensor field of view regardless of the specific target motion patterns. The invention uses information about target location, UAV platform type and states, sensor payload capability, and ratio of target-to-UAV speeds to select from a suite of sub-algorithms, each, of which generates desired platform positions (in form of waypoints) and/or sensor orientation commands to keep the target in view.
Features of the present invention will become apparent to those skilled in the art from the following description with reference to the drawings. Understanding that the drawings depict only typical embodiments of the invention and are not therefore to be considered limiting in scope, the invention will be described with additional specificity and detail through the use of the accompanying drawings, in which:
In the following detailed description, embodiments are described in sufficient detail to enable those skilled in the art to practice the invention. It is to be understood that other embodiments may be utilized without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense.
The UAV 112 can either be a hover-capable aerial vehicle or a fixed-wing aerial vehicle. Sensor 114 may be any device capable of imaging a target, such as a camera or radar. Target 116 may be anything being monitored by UAV 112. For example, target 116 may be a ground-based vehicle, an air-based vehicle, a roadway, or a person. To acquire a target, UAV 112 typically sends images from sensor 114 to remote operator 118. Remote operator 118 then defines an area in the image as the target, and sends the target to UAV 112.
Remote operator 118 may be any device capable of communicating with UAV 112. In addition, remote operator 118 may be configured to remotely control UAV 112. Remote operator 118 may be a device such as a desktop computer, laptop, or a personal data assistant (“PDA”), for example.
Aspects of the present invention may be carried out by UAV 112 and/or remote operator 118 (or any other entity capable of controlling UAV 112).
Communication interface 200 comprises a mechanism for communicating over an air interface, so as to facilitate communication between UAV 112 and remote operator 118. Further, communication interface 200 may include one or more antennas to facilitate air interface communication.
Processing unit 202 comprises one or more general purpose processors (e.g., INTEL microprocessors) and/or one or more special purpose processors (e.g., digital signal processors). Data storage 204, in turn, comprises one or more volatile and/or non-volatile storage mechanisms, such as memory and/or disc-drive storage for instance, which may be integrated in whole or in part with processing unit 202.
As shown, data storage 204 includes program logic 206 and reference data 208. Program logic 206 comprises one or more logic modules (applications), and preferably includes machine language instructions executable by processing unit 204 to carry out various functions described herein, such as (1) identifying the coordinates of the footprint of sensor 114, (2) determining whether the target is close to leaving the field of view of the sensor, and (3) causing UAV 112 to fly in a track mode that keeps target 116 in the field of view of sensor 114. Reference data 208, in turn, may include data such as imaging data acquired by sensor 114.
As shown in
where αh and αv are the horizontal and vertical field of view angles for sensor 114.
Returning to
[αh, αv], the horizontal and vertical field of view for sensor 114;
[θ, φ, ψ], the attitude angles of UAV 112, where θ, is the pitch, φ is the roll, and ψ is the yaw. In this example climb requires a positive pitch, the right wing down is a positive roll and clockwise from the top of the vehicle is a positive yaw;
[θc, φc, ψc], the attitude angles of sensor 114, where θ, is the pitch, φ is the roll, and ψ is the yaw. In this example, pitch is measured between 0 and 90 degrees measured from straight down. The Camera lookdown angle is (1-θc), the roll angle is positive right and the yaw angle is positive in the clockwise direction. Consequently, a forward facing sensor 114 has ψc=0, while a left-pointing camera has a ψc=−90 degrees; and
[N, E, h], the position coordinates of UAV 112 where N=north, E=east, and h=height from some reference point (such as UTM northings, eastings and altitude).
The local coordinates of the vertices and center of the footprint are identified as follows:
At step 304, the local coordinates of the midpoints for each side of the sensor footprint are identified as follows:
At step 306, the radii of the ellipse that circumscribes the frame is identified as follows:
where rh is the radius in the horizontal direction and rv is the radius in the vertical direction. The smaller of these two radii corresponds to the length of the semi-minor axis of the ellipse.
At step 308, each coordinate is transformed to inertial coordinates my multiplying the coordinate by pitch-roll-yaw rotation matrices [R] and [Rc], where
[R]=[R(θ)][R(φ)][R(ψ)]; and
[Rc]=[R(θc)][R(φc)][R(ψc)].
Thus,
A=a[R][Rc]
B=b[R][Rc]
C=c[R][Rc]
D=d[R][Rc]
I=i[R][Rc]
ABc=abc[R][Rc]
BCc=bcc[R][Rc]
DCc=dcc[R][Rc]
ADc=adc[R][Rc]
Rotational matrices are well known in the art, and are not described in detail here.
At step 310 the scaled coordinates of the sensor footprint are computed by scaling the inertial coordinates by the height (h) that UAV 112 is flying above the ground (if target 116 is a ground target), or the height of UAV 112 is flying above the target 116 (if target 116 is not necessarily on the ground). The footprint is calculated as follows:
Similarly, the length of the semi-minor axis may be scaled to account for the height UAV 112 is above target 116:
After computing the various coordinates of sensor 114's sensor footprint, at step 310, the target's (1) position relative to the center of the camera footprint (rtarget) on the ground, (2) the distance from the center of the camera footprint to the side (e.g., [ABcg BCcg DCcg ADcg] of the footprint that is closest to the target (rside), and (3) the distance from the center of the frame to the target (rt) are used to determine how close target 116 is from leaving sensor 114's field of view. These positions are illustrated in
In order to determine whether the target is about to leave the target's field of view, the value of rtarget and rside is first calculated. rtarget is calculated by using the following equation:
r
target=(êct−êce)rt
where êct and êce are unit vectors along a line from the target to the center of the footprint and from the mid-point of the closest side to the center respectively. That is, êct is the unit vector along rt, while êce is the unit vector along rside.
rside is calculated using the following equation:
where rAB
By calculating these values over time, UAV 112 (or remote operator 118) can determine if and when target 118 will leave the field of view of sensor 114.
At step 312 the location and speed of target 116 are used to cause UAV 112 to, depending on how fast target 116 is moving relative to the speed UAV 112 is capable of flying, fly in different track modes. These modes include, all at suitable altitude and stand-off ranges, (1) a straight following of the target (SFO), (2) flying orbits around the target (ORB), or (3) doing S-shapes (i.e. sinusoids) (SIN). This enables UAV 112 to maintain target 116 in the sensor footprint of sensor 114. UAV 112 flies in these modes by receiving waypoint commands and flying to the waypoints.
To determine which tracking mode UAV should use, the ratio (σ) of the speed of UAV 112 (vp) to the speed of target 114 (vt) is identified:
If σ is around 1, UAV 112 and target 114 are traveling at similar speeds, and UAV 112 should employ SFO tracking. If σ is greater than 1 (i.e., is travelling faster than target 114), UAV 112 can slow down to match the speed of target 114 and maintain SFO tracking. However, if UAV 112 is unable to travel at such a slow speed (because it would stall), UAV 112 should employ either SIN or ORB tracking. Consequently, UAV 112 should employ SIN tracking. If UAV 112 would be unable to maintain the target in its sensor footprint using SIN tracking (i.e., the amplitude required is too large), then UAV 112 should employ ORB tracking. The value of σ that triggers UAV 112 to engage in a different mode is aircraft specific, as different aircraft have different properties (such as being a hovercraft vs. a fixed-wing aircraft). UAV 112 may automatically switch track modes depending on the value of <J, or may be instructed by remote entity 118 to enter a different track mode depending on the value of σ.
SFO Tracking
If UAV 112 is flying in the SFO track mode, the waypoint (WPTSFO) is calculated as follows:
WPT
SFO=tgtPosn−Ig
Where tgtPosn is the target's position in the inertial frame, and Ig (calculated above) is the offset between the aircraft and the center of the footprint.
SIN Tracking
D=v
t
×T
The period is a free parameter that may be selected as desired. However, longer periods are more desirable because it decreases the size of the amplitude (A), making it easier for UAV 112 to track target 116. The amplitude is determined by considering which direction of the footprint displacement and the distance from the target to the mid-point of the closest side of the footprint:
A=k
tr
|r
side
−r
target
where rside and rtarget were calculated above, and ktr is a parameter used to tune the sensitivity of the algorithm. ktr greater than zero and less than or equal to one and is a multiplicative factor based on the distance from the target to the closest side of the footprint. Generally
although other values may be used.
(xp, yp) is the desired position of UAV 112 in the x2, y2 coordinate system:
The waypoints (WPTSIN) for UAV 112 when it is operating in SIN track mode are calculated as follows:
where (ψtgt) is the target's heading and └R(ψtgt)┘ is the rotation matrix that transforms xp and yp back into the inertial frame.
ORB Tracking
ORB tracking enables UAV 112 to loiter over target 116. The orbiting track waypoints (WPTORB) are given in N, E, h (north, east, height), and are calculated for a UAV having inertial coordinates Nc and Ec as follows:
where (Nt, Et) is the position of target 116, rc=√{square root over (Nc2+Ec2)}, and β is an angle dependent on how many waypoints you want to produce, and where waypoints should be relative to the target. For example, if there are 12 waypoints for UAV 112 to visit,
It should be understood that the first row of the WPTORB is not necessarily the first waypoint visited by UAV 112. Instead, a cost function may be utilized that determines the order in which waypoints are visited by UAV 112. The cost function uses the range to all the waypoints and the required change in heading needed for UAV 112 to get to each waypoint.
In addition, the position of the orbital waypoints relative to the target's frame of motion may be adjusted in order to achieve acceptable tracking performance at smaller speed ratios (higher target speeds). This results in “stretching” UAV 112's orbit ahead of target 116 and can reduce the amount that UAV 112 falls behind.
Once the piecewise elliptical orbit parameters have been chosen, a modified waypoint can be calculated as follows:
WPT′
ORB=tgtPosn+rnorm×offset(tgtVel)+α(WPTORB,tgtPosn,tgtVel)×(WPTORB−tgtPosn)
where tgtPosn is the position of target 116 in the inertial frame, tgtVel is the velocity of target 116 in the inertial frame, rnorm is the radius of the nominal (circular) orbit, and:
The scale factor, α, is computed using the equation of an ellipse. The principal axes of the ellipse are defined as follows:
p
a=cos(θ){circumflex over (v)}+sin(θ){circumflex over (n)}
p
b=−sin(θ){circumflex over (v)}+cos(θ){circumflex over (n)}
The lengths of the axes are defined as follows:
The equation of the ellipse is:
α is the scalar multiplier such that αŵ lies on the ellipse, α may be computed by plugging x=αŵ into the equation xTMx=1. Thus:
Height Adjustment
Regardless of whether UAV 112 is using SFO, SIN or ORB track modes, the height of UAV 112 may be adjusted to maintain target track. Height adjustment may be done using a gradient-descent law to minimize the cost function
with respect to h. As noted above
where γ is the gain of the gradient scheme.
The present invention may be embodied in other specific forms without departing from its essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is therefore indicated by the appended claims rather than by the foregoing description. All changes that come within the meaning and range of equivalency of the claims are to be embraced within their scope.
The U.S. Government may have certain rights in the present invention as provided for by the terms of Contract No. FA8650-04-C-7142 with the Defense Advanced Research Projects Agency.