The present disclosure relates generally to a navigation control for an aerial robotic device, and more particularly to a mechanism for navigating an aerial robotic device in the presence of static and non-stationary obstacles within a bounded movement volume.
An unmanned aerial vehicle (UAV) (or uncrewed aerial vehicle, commonly known as a drone) is an aircraft without a human pilot on board and a type of unmanned vehicle. UAVs are a component of an unmanned aircraft system (UAS), which include the UAV, a ground-based controller, and a system of communications between the two. The flight of UAVs may operate with various degrees of autonomy, either under remote control by a human operator or autonomously by onboard computers.
Traditional wired aerial robotic devices require manual control of their movements by a trained operator using a joystick apparatus. However, this is an overly labour-intensive process, and requires significant motor skills on the part of the human operator. Also, the navigation of the aerial robotic device becomes difficult in the presence of stationary and non-stationary obstacles. It is crucial to automatically enable the aerial robotic device to avoid moving obstacles (e.g. incoming vehicles into a drive through facility or pallet loading area etc.) in its path as it moves from a first location to a second location in the space covered by the aerial movement volume.
In an aspect of the present disclosure, there is provided a system for navigating an aerial robotic device (ARD) from a first location to a second location in an aerial movement volume. The system includes an object detection module configured to detect one or more non-stationary objects in the aerial movement volume, and generate a first object record detailing the location of the non-stationary object. The system further includes an object tracking module configured compare the first object record with one or more second object records of objects previously detected in the aerial movement volume, and add the location of the non-stationary object from the first object record to a first position of a tracking list of a substantially matching second object record, such that the tracking list includes a sequentially ordered list of a current and previous trajectory points comprising the current location of the non-stationary object and the locations of one or more previous detections of the corresponding non-stationary object. The system furthermore includes a trajectory prediction module configured to update a prediction list of the substantially matching second object record with one or more next trajectory points predicted over a predefined time period T, wherein N samples of a first object record are acquired at the pre-defined rate At over the pre-defined time period T and wherein, for each current sample, the updating of the prediction list comprises: filtering out measurement noise in the current and previous trajectory points of the tracking list to generate a filtered tracking list of one or more filtered trajectory points; determining a velocity vector of the corresponding object in the current sample based on the filtered trajectory points; determining an acceleration vector of the corresponding object in the current sample based on the velocity vector of the corresponding object in the current and previous samples; determining the longitudinal and normal components of the acceleration vector in the current sample relative to the velocity vector in the current sample; determining an acceleration vector of the corresponding object in a next sample based on the magnitude of the current longitudinal and normal components of the acceleration vector, and a phase of the velocity vector in the next sample; and predicting a trajectory point of the corresponding object in the next sample, based on the velocity and acceleration vectors predicted in the next sample. The system further includes a collision avoidance module configured to navigate the ARD from the first location to the second location in the presence of a non-stationary object based on the updated prediction list of the non-stationary object.
In another aspect of the present disclosure, there is provided a method for navigating an aerial robotic device (ARD) from a first location to a second location in an aerial movement volume. The method includes detecting, by an object detection module, one or more non-stationary objects in the aerial movement volume. The method further includes generating, by the object detection module, a first object record detailing the location of the non-stationary object. The method further includes comparing, by an object tracking module, the first object record with one or more second object records of objects previously detected in the aerial movement volume and adding the location of the non-stationary object from the first object record to a first position of a tracking list of a substantially matching second object record, such that the tracking list includes a sequentially ordered list of a current and previous trajectory points comprising the current location of the corresponding non-stationary object and the location of one or more previous detections of the corresponding non-stationary object
The method further includes updating, by a trajectory prediction module, a prediction list of the substantially matching second object record with one or more next trajectory points predicted over a predefined time period T, wherein N samples of a first object record are acquired at the pre-defined rate At over the pre-defined time period. The updating of the prediction list for each current sample comprises filtering out measurement noise in the current and previous trajectory points of the tracking list to generate a filtered tracking list of one or more filtered trajectory points; determining a velocity vector of the corresponding object in the current sample based on the filtered trajectory points; determining an acceleration vector of the corresponding object in the current sample based on the velocity vector of the corresponding object in the current and previous samples; determining the longitudinal and normal components of the acceleration vector in the current sample relative to the velocity vector in the current sample; determining an acceleration vector of the corresponding object in a next sample based on the magnitude of the current longitudinal and normal components of the acceleration vector, and a phase of the velocity vector in the next sample; and predicting a trajectory point of the corresponding object in the next sample, based on the velocity and acceleration vectors predicted in the next sample. The method further includes navigating the ARD from the first location to the second location in the presence of a non-stationary object based on the updated prediction list of the non-stationary object.
In yet another embodiment of the present disclosure, there is provided a non-transitory computer readable medium configured to store a program causing a computer to navigate an aerial robotic device (ARD) from a first location to a second location in an aerial movement volume. The said program is configured to detect a non-stationary object in the aerial movement volume, and generate a first object record detailing the location of the non-stationary object; compare the first object record with one or more second object records of objects previously detected in the aerial movement volume, and add the location of the non-stationary object from the first object record to a first position of a tracking list of a substantially matching second object record, such that the tracking list includes a sequentially ordered list of a current and previous trajectory points comprising the current location of the corresponding non-stationary object and the locations of one or more previous detections of the corresponding non-stationary object; update a prediction list of the substantially matching second object record with one or more next trajectory points predicted over a predefined time period T, wherein N samples of a first object record are acquired at the pre-defined rate At over the pre-defined time period T and wherein, for each current sample, the updating of the prediction list comprises: filtering out measurement noise in the current and previous trajectory points of the tracking list to generate a filtered tracking list of one or more filtered trajectory points; determining a velocity vector of the corresponding object in the current sample based on filtered trajectory points of the corresponding object in the current and previous samples; determining an acceleration vector of the corresponding object in the current sample based on the velocity vector of the corresponding object in the current and previous samples; determining the longitudinal and normal components of the acceleration vector in the current sample relative to the velocity vector in the current sample; determining an acceleration vector of the corresponding object in a next sample based on the magnitude of the current longitudinal and normal components of the acceleration vector, and a phase of the velocity vector in the next sample; and predicting a trajectory point of the corresponding object in the next sample, based on the velocity and acceleration vectors predicted in the next sample. The said program is further configured to navigate the ARD from the first location to the second location in the presence of a non-stationary object based on the updated prediction list of the non-stationary object.
Various embodiments of the present disclosure provide a system for navigating an aerial robotic device in the presence of non-stationary obstacles within an aerial movement volume of the aerial robotic device. The aerial robotic device is enabled to avoid moving obstacles, for example, incoming vehicles into a drive through facility or pallet loading area etc. in its path as it moves from a first location to a second location in the space covered by the aerial movement volume, using various tracking techniques, prediction algorithms and real time route management.
It will be appreciated that features of the present disclosure are susceptible to being combined in various combinations without departing from the scope of the present disclosure as defined by the appended claims.
The summary above, as well as the following detailed description of illustrative embodiments, is better understood when read in conjunction with the appended drawings. For the purpose of illustrating the present disclosure, exemplary constructions of the disclosure are shown in the drawings. However, the present disclosure is not limited to specific methods and instrumentalities disclosed herein. Moreover, those in the art will understand that the drawings are not to scale. Wherever possible, like elements have been indicated by identical numbers.
In the accompanying drawings, an underlined number is employed to represent an item over which the underlined number is positioned or an item to which the underlined number is adjacent. A non-underlined number relates to an item identified by a line linking the non-underlined number to the item. When a number is non-underlined and accompanied by an associated arrow, the non-underlined number is used to identify a general item at which the arrow is pointing.
The following detailed description illustrates embodiments of the present disclosure and ways in which they can be implemented. Although the best mode of carrying out the present disclosure has been disclosed, those skilled in the art would recognize that other embodiments for carrying out or practicing the present disclosure are also possible.
The carrier device 105 is adapted to move within a bounded horizontal plane 112 defined by the elevated anchor points 104. This movement is achieved through the activation of the electric motors in the anchor points 104 to cause the wire 102 coupled to each electric motor to be further wound or unwound from the electric motor's rotor, thereby shortening or lengthening each such wire 102. The ARD 106 is adapted to move vertically relative to the carrier device 105 through the activation of the electric motor(s) in the carrier device 105 to cause the wire coupled to each electric motor to be further wound or unwound from the electric motor's rotor, thereby shortening or lengthening the wire.
In the context of the present disclosure, one or more stationary and/or moving objects may also be present in the aerial movement volume 110. Thus, the problem solved by the present disclosure is that of enabling the ARD 106 to navigate from a first location to a second location in the aerial movement volume 110, while avoiding moving and stationary objects along the way. The non-stationary objects are hereinafter alternatively referred to as non-stationary obstacles or moving objects or moving obstacles, throughout the document.
The prediction based navigation control system 305 includes an object detection module 306, an object tracking module 307, a trajectory prediction module 308, and a collision avoidance module 309. The object detection module 306 is configured to detect one or more non-stationary objects within the pre-defined region of the ARD 304.
The non-stationary objects include earth-bound objects such as vehicles, buildings and people, and not flying objects. The object detection module 306 includes a radar sensor 310 for mounting on the ARD 304, and configured to detect non-stationary objects within a pre-defined distance of the ARD 304. The object detection module 306 further includes a radar processing module 311 configured to process data from the radar sensor 310 to determine a speed v and a direction of movement 9 of non-stationary objects within a pre-defined distance of the ARD 304. In the context of the present disclosure, the distance is pre-defined based on a detection range of the radar sensor 310. It is to be noted that since the radar sensor 310 is for mounting on the ARD 304 the radar sensor 310 is moved about the the aerial movement volume 110 shown in
The object detection module 306 further includes a decision module 312 configured to determine whether each of the detected first and second objects 302a and 302b is stationary or non-stationary. The decision module 312 is further configured to determine whether the ARD 304 is likely to collide with the second object 302b, or whether the ARD 304 is likely to merely pass by the first object 302a without colliding with it. For brevity, an object with which the ARD 304 is likely to collide may be hereinafter referred to as an obstacle.
In the context of the present disclosure, a 12 o'clock position relative to the ARD 304 is defined to be a 0 degrees angular deviation from the ARD 304, and angles progressing in a clockwise direction from the 12 o'clock position are defined to be positively valued angular deviations in the range 0 to 360 degrees. By the same token, an object moving along a path oriented towards the 12 o'clock position relative to the object, is defined to be moving in a 0 degrees direction, and an object moving in the opposite direction (i.e. towards the 6 o'clock position relative to the object) is defined to be moving in a 180 degrees direction. Thus, an object moving along a path oriented at angles progressing in a clockwise direction from the 12 o'clock position relative to the object is defined to be moving in a direction of 0 to 360 degrees.
In an example, when an object has zero speed and is disposed at 0 degrees angular deviation from the ARD 304, the object is straight ahead of the ARD 304, and the ARD 304 may collide with the object if the ARD 304 continues on its current trajectory. In another example, if an object is determined to be disposed at 0 degrees angular deviation from the ARD 304 and is moving in a 180 degrees direction, i.e. towards the ARD 304, the object is an incoming object, and the ARD 304 may collide with the incoming object if the ARD 304 continues on its current trajectory. In another example, if an object is determined to be disposed at 0 degrees angular deviation from the ARD 304 and is moving in a 0 degrees direction, i.e. away from the ARD 304, the object is an outgoing object, and if the outgoing object is moving faster than the ARD 304, the ARD 304 is unlikely to collide with the outgoing object.
It will be understood that the above-mentioned angular deviations of an object from the ARD 304 and the above-mentioned directions of movement of the object are provided for the purpose of example. In particular, the definition of an “incoming” or “outgoing” status of an object is in no way limited to these angular deviations and directions of movement of the object. Instead, an incoming object will be understood to be an object whose direction of movement from its current position, described with reference to the orientation of the radar sensor 310, causes the object to move towards the ARD 304. Similarly, an outgoing object is an object whose direction of movement from its current position, described with reference to the orientation of the radar sensor 310, causes the object to move away from the ARD 304.
In an embodiment of the present disclosure, the decision module 312 is configured to detect a moving object in the vicinity of the ARD 304 and also determines whether the moving object is an incoming object, or an outgoing object based on the direction of movement of the corresponding object described with reference to the orientation of the radar sensor 310. The decision module 312 is further configured to transmit an alert message to a camera module 314 upon detection by the decision module 312 of an incoming object. In an example, the camera module 314 includes an Red Green Blue Depth (RGBD) camera and a signal processing unit coupled with the carrier device 105 of
For brevity, the data generated by the camera module 314 is hereinafter referred to as a sample. Similarly, a sampling rate corresponds to a time interval Δt between the generation of consecutive samples, and a sample time is the time (ti) at which an ith sample is generated. The sampling rate may depend on the acquisition rate of the radar sensor 308. In an example, the sampling rate is 40 ms. In another example, the sampling rate is 10 ms. Nevertheless, it should be noted that the time interval between consecutive samples may not be uniform. In particular, at any given moment, there may not be any incoming moving objects in the vicinity of the ARD 304 to cause the RGBD camera to be triggered to capture an image/video frame. Thus, the time interval between consecutive samples is dependent on the presence of incoming objects in the vicinity of the ARD 304, rather than the acquisition rate of the sensors. The sampling is performed until the ARD 304 reaches its target position.
For clarity, the coordinates (x1, y1), (x2, y2), (x3, y3) and (x4, y4) are all defined in absolute terms with reference to the aerial movement volume 110, rather than with reference to the ARD 304. Specifically, the absolute coordinates of a moving object at any given moment are established within a reference system defined by the upright members 103, anchor points 104 and the ground that collectively establish the boundaries of the aerial movement volume 110.
The object detection module 306 is further configured at any given sample time tτ to establish NR (tτ) current object records
each of which includes details of a corresponding one of NR(tτ) objects detected in the vicinity of the ARD 304 at the sample time tτ. The said details are derived from a sample generated at the sample time tτ. The NR (tτ) current object records
may be used to populate or update an Object List ObjList(tτ−1) comprising a plurality of stored object records of objects detected at the immediately preceding sample time tτ−1. Specifically, when a new sample is generated, the existing details in the Object List ObjList(tτ−1) are updated with the details of the objects detected in the new sample to create Object List ObjList(tτ).
In an embodiment of the present disclosure, an individual current object record
may be described as
CObj
p
t
={{I, L, H}
p
t
,{x
c, yc, zc}pt
where
In an embodiment of the present disclosure, an individual stored object record
may be described as
Objpt
where
The object tracking module 307 is configured to receive the Object List ObjList(tτ−1) from the object detection module 306 and employ an object tracking algorithm to track each non-stationary object detected within a predefined region of the ARD 304. In an embodiment of the present disclosure, the object tracking module 307 initializes the object tracking algorithm when a first sample is acquired, i.e. at sample time t0. The initialization includes assigning a unique number to the object ID of each stored object record Objpt
In an embodiment of the present disclosure, the object tracking module 307 is configured to track an object by monitoring a center of gravity of its corresponding bounding box. For a cuboid, the center of gravity is defined by the three coordinates (xc, yc, zc). As it has been mentioned before, detected objects are assumed to be earth-bound and not flying objects. Thus, the z coordinates of an object remain constant between successive samples (i.e. zct
More specifically, let a current sample time be tq and let there be NR(tq) objects detected in the vicinity of the ARD 304 at current sample time tq. The details, extracted from the sample generated at sample time tq, of each of the NR(tq) objects are contained in each of the corresponding current object records
Let the object list ObjList(tq−1) from the most recent previous sample time tq−1 contain NR(tq−1) stored object records. Using this formulation, the object tracking module 307 is configured to compare each current object record
with each of the NR(tq−1) stored object records contained in the object list ObjList(tq−1).
For brevity, an pth stored object record in the object list ObjList(tq−1) will be referred to henceforth as a first query object record. Similarly, a current object record (CObjptq) containing the details of a pth object detected in the vicinity of the ARD 304 at the current sample time tq will be referred to henceforth as a second query object record. Let (x*c, y*c)r,t
be the x and y center of gravity coordinates of the bounding box volume enclosing the object represented by the second query object record. The object tracking module 307 is configured to calculate a distance Δ between the first query object record and the second query object record as follows:
The object tracking module 307 is further configured to compare the value of the calculated distance A with a predefined threshold value Th. In the event the distance Δ is less than the threshold value Th, the object tracking module 307 is configured to establish that the first query object record matches the second query object record. In this case, at least some of the details of the first query object record are updated with corresponding details from the second query object record.
Specifically, in an embodiment of the present disclosure, the updating includes replacing the values of the external parameters of the bounding box of the first query object record with the corresponding values of the external parameters of the bounding box of the second query object record. The updating further includes replacing the values of the x, y and z center of gravity coordinates (x*c, y*c,z*c) of the first query object record with the values of the corresponding center of gravity coordinates (xc, yc, zc) of the second query object record. The updating further includes adding the x and y center of gravity coordinates (xc, yc) of the second query object record to the Tracking List TL of the first query object record. Specifically, the x and y center of gravity coordinates (xc, yc) of the second query object record are added to the top of the Tracking List TL of the first query object record. In this way, the Tracking List TL of a stored object record includes a sequentially ordered list of the center of gravity variables of an object detected in the vicinity of the ARD 304 at previous sample times. If the Tracking List TL of a first query object record is already full, before commencement of the updating process, the center of gravity coordinates at the bottom of the Tracking List TL, i.e. from the earliest detection of the corresponding object, are deleted from the Tracking List TL; and the remaining center of gravity coordinates are shifted one step closer to the bottom of the Tracking List TL, to vacate the top of the Tracking List TL to receive the values of the center of gravity coordinates from the second query object record.
Alternatively, in the event the distance Δ exceeds the predefined threshold value Th, the object tracking module 307 is configured to determine that the first query object record does not match the second query object record. By progressing through the object list ObjList(tq−1) and taking each stored object record therein to be a first query object record for comparison with the second query object record, it is possible to determine if the second query object record matches any of the stored object records in the object list ObjList(tq−1). In the event a match is not found, it may be determined that the object whose details are contained in the second query object record is a newly detected object. In this case, the object tracking module 307 is configured to update the object list ObjList(tq−1) by creating a new stored object record therein, allocating a new unique object ID to the new stored object record; and populating the new stored object record with the details from the second query object record.
The process of updating the object list ObjList(tq−1), on the basis of the comparison of each stored object record contained therein with a current object record
is continued tor each object detected in the vicinity of the ARD 304 at the current sample time tq. If, at the end of the updating process, the object list ObjList(tq−1) contains stored object records that do not include values derived from the sample generated at the current sample time tq, these stored object records are deleted from the object list ObjList(tq−1) as they relate to objects that are no longer detected in the vicinity of the ARD 304. On completion of this step, the time index of the object list is incremented, so that ObjList(tq−1) becomes ObjList(tq). Accordingly, the current object list ObjList(tq) now includes a stored object record for each object detected in the vicinity of the ARD 304 at current sample time tq, such that
ObjList(tq)=[Obj1tq, Obj2t
Each such stored object record includes details of a corresponding object, the said details being determined from a sample generated at the current sample time tq. Each such stored object record further includes the past locations, if any, of the center of gravity of the object determined from M previously generated samples, such that
Objit
where:
objIDi=the object ID;
{I, L, H}i=the external parameters of the bounding box enclosing the ith object detected at current sample time tq;
{xc, yc, zc}it
Tracking List TL=[{xc, yc}it
Prediction list PL[]=an empty set to be populated with the predicted future locations of the ith detected object.
The trajectory prediction module 308 is configured to predict future trajectories of all the tracked non-stationary objects over N time windows, each of duration Δt. The overall time interval=N×Δt may be hereinafter referred to as a future time window. In other words, assuming a set of observed non-stationary object trajectory points, (xi, yi), i=1,2, . . . , R, the goal is to predict a set of future trajectory points, (xk,yk), for k=R+1, R+2, . . . , R+N. By representing each of the non-stationary objects detected proximal to the ARD 304 as a 3D bounding box and predicting their future trajectories, it is possible to anticipate the risk of a collision between the ARD 304 and nearby non-stationary objects.
In an embodiment of the present disclosure, the trajectory prediction module 308 is configured to estimate future trajectory points for each object using a dynamic model of a non-stationary object and a set of observed trajectory points. The trajectory prediction module 308 receives the object list ObjList(tq) (as defined in equation (1)) as an input from the object tracking module 307, and generates an updated Object List ObjList(tq) as an output, in which each stored object record Objit
{objIDi, {I, L, H}i, {xc, yc, zc}it
Representing the center of gravity of an object by the center of gravity coordinates of a bounding box enclosing the object, the Tracking List TL of a given stored object record, in the updated Object List ObjList(tq), is updated with a filtered Tracking List populated with filtered x and y center of gravity coordinates of the object, determined from the M immediately preceding samples. Similarly, the Prediction List PL is populated with N predicted future trajectory points of the corresponding object.
The trajectory prediction module 308 is configured to perform trajectory filtering to filter out measurement noise in the trajectory points determined by the object tracking module 307. The trajectory prediction module 308 is configured to generate a filtered trajectory point Pfk, corresponding with {xc, yc}it
Pfk=∝*Pk+(1−∝)Ppk (4)
where:
∝=a smoothing parameter which models a confidence value in the observed trajectory points; and
Ppk=a predicted position of the observed trajectory point Pk.
In an embodiment of the present disclosure, the predicted position Ppk of the observed trajectory point Pk is calculated using a predicted velocity vpk−1 of associated non-stationary object and the predicted position of the trajectory point in the immediately preceding sample, such that,
P
pk
=P
fk−1
+V
pk−1. (5)
The predicted velocity at sample k is predicted as:
v
pk−1
=∝*v
k−1+(1−∝)*vk 2 (6)
vk−1 and vk−2 are the observed velocities of the object at samples k−1 and k−2 respectively.
An observed velocity of the object at a sample k−1 is determined from the filtered trajectory points at these samples as follows:
v
k−i
=P
fk−i−1
, i=1,2 (7)
Combining equations (4) to (7), a linear filter equation may be obtained of a form, such that:
P
fk
=w
0
*P
fk−3
w
1
*P
fk−2
+w
2
*P
fk−1
+w
3
*P
k (8)
where
w
0=−(1−∝)*(1−∝) (9a)
w
1=(1−∝)*(1−2*∝) (9b)
w
2=(1+∝)(1−∝) ..(9c)
w3=∝ (9d)
It is to be noted that, three of the four position vectors in equations (9a-9b) are previous outputs of the filter, namely Pfk−3, Pfk−2 and Pfk−1. Thus, the filter is recursive, which makes its unit impulse response longer and filtering highly effective from a computational point of view. The filter weights add up to one, regardless of the parameter ∝. This property is found in all interpolation filters. Thus, the proposed filter can be also viewed as an interpolator filter.
The trajectory prediction module 308 use the first three observed points of the trajectory in equation (7) at the start of the filtering process, and then replaces the filtered trajectory points (i.e. the output of the filtering process) (Pfi for i=0,1,2) generated from the first 3 samples, with the observed trajectory points generated in those samples (Pi, for i=0,1,2). It may be noted that for every newly generated stored object record the trajectory prediction module 308 filters all the trajectory points in the stored object record's Tracking List TL using equations (4) to (9). However, for a pre-existing stored object record, only the last trajectory point in the stored object record's Tracking List TL is new, so only that last trajectory point is filtered.
In the context of the present disclosure, it is assumed that velocity is measured in terms of changes in the non-stationary object's position coordinates from one sample to the next. Similarly, acceleration is expressed as velocity change from one sample to the next. Further, the trajectory prediction is short-term. Therefore, it is assumed that changes in trajectory direction and the magnitude of the acceleration of a non-stationary object remain constant over a next few predicted video frames/images, unless the predicted trajectory collides with a static (non-moving) object in the aerial movement volume 110. This implies that the magnitude of the non-stationary object's acceleration is also preserved. However, as long as the longitudinal and the normal components of the object's acceleration vector remain correspondingly aligned with the object's direction of movement, the orientation of the object's acceleration vector changes with the orientation of the object's velocity vector.
The state vector Sk of the non-stationary object (using the filtered trajectory from the trajectory filtering step) at a filtered trajectory point Pfk in sample k is given by
S
k=[xk, yk, vxk,vyk, axk, ayk], (10)
where
vxk, vyk=the horizontal and vertical components of the observed velocity vector of the non-stationary object (determined by equation (7));
vxk−1, vyk−1=horizontal and vertical components of the observed velocity vector of the non-stationary object at sample k−1; and
axk, ayk=corresponding horizontal and vertical components of the object's acceleration vector at sample k and computed using the following equation:
a
xk
=v
xk
−v
xk−1 (11a)
a
yk
=v
yk
−v
yk−1 (11b)
Further, the magnitude |v|k and direction φk of the velocity vector vk of state Sk are calculated based on the following equations:
|v|
k=√{square root over (vxk2+vyk2)}, (12a)
φk=arg[vxk, vyk], (12b)
The magnitude |a|k and direction θk of acceleration vector ak of non-stationary object may be represented by the following equations:
|a|k√{square root over (axk2+ayk2)} (13a)
θk=arg[axk, ayk] (13b)
Further, the longitudinal alk and the normal ank components of the acceleration vector ak relative to the velocity vector vk direction are:
a
lk
=|a|
k*cos(φk−θk) (14a)
a
nk
=|a|
k*sin(φk−θk) (14b)
Furthermore, the predicted state Sk+1=[xk+1, yk+1, vxk+1, vyk+1), axk+1, ayk+1], for the next sample, is computed as follows:
x
k+1
=x
k
+v
xk (15a)
y
k+1
=y
k
+v
yk (15b)
v
xk+1
=v
xk
+a
xk (16a)
v
yk+1
=v
yk
+a
yk (16b)
φk+1=arg[vxk+1, vyk+1] (17)
a
lk+1
=a
lk, (18a)
a
nk+1
=a
nk (18b)
a
xk+1
=a
lk*cos(φk+1) (18c)
a
yk+1
=a
lk*sin(φk+1) (18d)
In the context of the present disclosure, the acceleration update equations (18a to 18b) preserve the magnitude of the object's acceleration vector. Also, the acceleration update equations (18a to 18b) re-orients the phase of the object's acceleration vector so that the longitudinal acceleration component corresponds to the current direction of the object's velocity vector; and the normal acceleration component is perpendicular to the current direction of the object's velocity vector. The equations (15 to 18) are propagated as many times, N, as needed. As a result of which, the predicted trajectory is circular. Alternatively, the predicted trajectory may be linear in the absence of a normal acceleration component. Moreover, the angular speed of the non-stationary object is generally variable, and is constant only in the absence of longitudinal acceleration component.
Using the above approach, the trajectory prediction module 308 is configured to generate an updated Object List ObjList(tq) in which the Prediction List PL of each stored object record Objit
The collision avoidance module 309 is configured to predict a collision using information generated by the object tracking module 307 and the trajectory prediction module 308; and to control a trajectory of the ARD 304 to avoid nearby moving obstacles. The ARD 304 follows an optimal navigation path 200 as described in
In an embodiment of the present disclosure, the prediction based navigation control system 305 may be implemented as one or more microprocessors, microcomputers, microcontrollers, digital signal processors, logic circuitries, and/or any devices that manipulate data based on operational instructions. The prediction based navigation control system 305 may be implemented as a combination of hardware and programming (for example, programmable instructions) to implement one or more functionalities thereof.
At step 402 an object list is established and initialised. The object list comprises a set of stored object records. Each stored object record comprises an object identification number together with the external parameters of a bounding box enclosing a detected object, and the center of gravity coordinates of the said bounding box. In one embodiment, the stored object records in the object list are each initialised with values of 0 or Null as appropriate.
At step 404, one or more objects are detected within a pre-defined distance of the ARD by a radar sensor mounted on the ARD. In the context of the present disclosure, the pre-defined distance is determined by the performance of the radar sensor, and most notably, by the detection range of the radar sensor.
At step 406, data from the radar sensor is processed to determine a speed and a direction of movement of the one or more objects. The radar sensor itself moves in the aerial movement volume, as the radar sensor is mounted on the ARD. However, the radar sensor maintains a constant orientation relative to the direction of movement of the ARD.
At step 408, it is determined if an object is non-stationary and it is then determined whether the non-stationary object is an incoming obstacle, or an outgoing obstacle based on a the direction of movement of the corresponding object described with reference to the orientation of the radar sensor 310 .
At step 410, upon detection of an incoming obstacle, a camera module is triggered to capture an image or video frame of the surrounding area of the ARD, and to compute, at step 412, the external parameters of each 3D bounding box enclosing each object detected in the vicinity of the ARD and the center of gravity coordinates of the said bounding boxes.
At step 414, a set of current object records is established at time instant ‘tq’, wherein each current object record includes the external parameters of a bounding box enclosing a corresponding object detected in the vicinity of the ARD at time instant tq, and the center of gravity coordinates of the said bounding box.
At step 502, an object list comprising one or more stored object records, and one or more current object records of objects detected in the vicinity of the ARD are received at the sampling rate.
At step 504, each current object record is compared with each stored object record in the object list. The comparing includes determining whether a distance between the x and y center of gravity coordinates of a stored object record and the x and y center of gravity coordinates of a current object record is less than a pre-defined threshold value. For brevity, a stored object record used in the comparing will be referred to henceforth as a first query object record. Similarly, a current object record used in the comparing will be referred to henceforth as a second query object record.
At step 506, the second query object record is identified to be a match with the first query object record, and at least some of the details of the first query object record are updated with corresponding details of the second query object record, when the calculated distance is less than the pre-defined threshold. In an embodiment of the present disclosure, the updating includes replacing the values of the external parameters of the bounding box of the first query object record, with the values of the external parameters of the bounding box of the second query object record, and replacing the values of the center of gravity coordinates of the first query object record with the values of the center of gravity coordinates of the second query object record. The updating further includes adding the values of the x and y center of gravity coordinates of the second query object record to a top of the tracking list of the first query object record, such that the tracking list includes a sequentially ordered list of the locations of the center of gravity of an object detected from samples generated at, a predefined number M or less, of preceding time instants.
At step 508, the tracking list of each stored object record is updated accordingly. In an embodiment of the present disclosure, the tracking list of each stored object record is updated with a predefined M number of previous trajectory points of each corresponding object.
At step 602, the measurement noise is filtered out in current and previous trajectory points of the tracking list to generate a filtered tracking list of one or more filtered trajectory points. In an embodiment of the present disclosure, a filtered trajectory point is generated based on a trajectory point and three preceding trajectory points from the corresponding tracking list, and a smoothing parameter.
At step 604, a velocity vector of corresponding object in a current sample is determined based on the filtered trajectory points. In an embodiment of the present disclosure, a position of the trajectory point is predicted based on a predicted velocity vector of the corresponding object, and a filtered trajectory point in a previous sample. In another embodiment of the present disclosure, the predicted velocity vector of the object in the current sample is calculated based on velocity vectors of the object in two previous samples. The velocity vector of the object is calculated based on a difference between filtered trajectory points in two previous samples.
At step 606, an acceleration vector of corresponding object in the current sample is determined based on the velocity vector of corresponding object in the current and previous samples. At step 608, the longitudinal and normal components of the acceleration vector are determined in the current sample relative to the velocity vector in the current sample. At step 610, an acceleration vector of the corresponding object is determined in a next sample based on the magnitude of the current longitudinal and normal components of the acceleration vector, and a phase of the velocity vector in the next sample.
At step 612, a trajectory point of the corresponding object in the next sample is predicted based on the velocity and acceleration vectors predicted in the next sample. In an embodiment of the present disclosure, a predicted state vector of the object is generated that includes a next horizontal coordinate computed by adding the current horizontal velocity vector to the current horizontal coordinate, a next vertical coordinate computed by adding the current vertical velocity vector to the current vertical coordinate, a next horizontal acceleration vector computed based on the longitudinal component of the current acceleration vector and a direction of next velocity vector, and a next normal acceleration vector computed based on the normal component of the current acceleration vector, and a direction of next velocity vector.
Now referring to
At step 806 an nth (where n=1) step ahead predicted value is computed of the center of gravity (xARD, YARD)t
of each stored object record in the updated object list ObjList(tq), In an example, a nth step ahead predicted value of the center of gravity coordinates (xc, yc)it
At step 812, a check is performed for each stored object record to ascertain if the distance dARD,Ob jit
If, for any stored object record, the distance dARD,Ob jit
Alternatively, when the distance dARD,Ob jit
In the event the ARD 702 does not have enough time to overtake the corresponding object on the left-hand side, at step 828, it is ascertained whether the ARD 702 has enough time to overtake the corresponding object on the right-hand side to avoid collision. In the event the ARD 702 has enough time to overtake the corresponding object on the right-hand side to avoid collision, at step 830, the trajectory of the ARD 702 is modified to enable it to overtake the object on the right-hand side, and step 818 is performed. For brevity, the step of overtaking by the ARD of an object on the right-hand side will be referred to henceforth as right overtaking. The modification of the trajectory of the ARD 702 for right overtaking has been explained with reference to
In the event the ARD 702 does not have enough time to overtake the corresponding object on the right-hand side, at step 832, it is ascertained whether the ARD 702 has enough time to overtake the corresponding object by moving overhead it. In the event the ARD 702 has enough time to overtake the corresponding object by moving overhead it, at step 834, the the trajectory of the ARD 702 is modified to enable it to overtake the corresponding object by moving overhead it, and step 818 is performed. For brevity, the step of overtaking an object by moving overhead it will be referred to henceforth as overhead overtaking. The modification of the trajectory of the ARD 702 for overhead overtaking has been explained with reference to
When the ARD 702 does not have enough time to overtake the corresponding object by moving overhead it, step 836 is performed to pause the movement of the ARD 702 for one step, and step 802 is performed.
In an embodiment of the present disclosure, the collision avoidance module is configured to use angular deviation to activate and supervise the collision detection when a presumptive collision is possible, for example, when the obstacle 704 moves “in front” of the ARD 702 relative to the movement direction of the ARD 702. This safety mechanism is necessary when computation of the absolute coordinates of the obstacles are affected by harsh environmental conditions such as reflexions in the RGBD image, transparent obstacles, etc.
In another embodiment of the present disclosure, the collision avoidance module is configured to modify navigation parameters of the ARD 702 to avoid an impact with the dynamic obstacles. In an example, the speed of the ARD is reduced to zero, until the obstacle 704 passes in front of it. In another example, a current 3D segment of the ARD's 702 navigation path is replaced with a replacement set of 3D segments designed to enable the ARD 702 to avoid all stationary and non-stationary obstacles. To ensure minimal disruption to a previously established navigation path of the ARD 702, the last segment of the replacement set should have the same ending point as the replaced segment of the ARD's 702 navigation path. The process of calculating a suitable replacement set for a 3D segment of the ARD's navigation path, and the replacement of the 3D segment with the calculated replacement set, is applied recursively to the next one or more segments of the ARD's navigation path until the ARD 702 returns to its previously established navigation path. Another embodiment employs an optimization approach which implements an avoidance decision in the horizontal plane of tall obstacles, and avoidance in the vertical plane of wide obstacles.
In an embodiment of the present disclosure, each of the first and second segments may be defined as a line segment connecting two consecutive 3D points from a trajectory point list. Each line segment may be converted into four tuples of parameters for corresponding controllers of the four electrical stepper motors of corresponding aerial movement volume. The tuple comprises three control parameters (nrotk, dirk, θk), representing the number of rotation steps, the direction of rotation and the speed of rotation required of the electrical stepper motor. The first three tuples are used to control the horizontal movement of corresponding carrier device and the last tuple is used to control the vertical displacement of corresponding ARD.
Modifications to embodiments of the present disclosure described in the foregoing are possible without departing from the scope of the present disclosure as defined by the accompanying claims. Expressions such as “including”, “comprising”, “incorporating”, “consisting of”, “have”, “is” used to describe and claim the present disclosure are intended to be construed in a non-exclusive manner, namely allowing for items, components or elements not explicitly described also to be present. Reference to the singular is also to be construed to relate to the plural.