The present invention relates to a method and system for determining the location of a sensor, and in particular in some embodiments to the relative location of a sensor mounted on a vehicle or other moving body with respect to another object. In preferred embodiments of the invention the sensor is of a type that emits a signal and detects objects in dependence on reflections of the emitted signal from the objects, by comparing the reflections against an a priori model of the object available to the sensor.
Image processing for computer vision is an established field. One technique that is known in the field of computer vision is that of model-based processing to identify objects within images. Generally, an a priori model having a number of image parameters representing an object to be detected within an image is first defined, and the model is then applied using various matching or best fit techniques to find corresponding objects in images matching the model. One early application of model based image processing is described by Tillet, R. D. Computers and Electronics in Agriculture, Volume 6, Issue 1, July 1991, Pages 51-61, which reports on the development of a model-based technique to locate pigs in fairly unstructured scenes. According to Tillet, model-based image processing is potentially a very powerful technique for identifying and classifying images and is particularly relevant for biological objects such as animals, which are difficult to define in numerical terms. Within Tillet's paper the model is based on an image of a typical pig, viewed from above. The model can then be rotated, translated, scaled and bent laterally to find a good match within an image of another pig. The output of the model helps to segment and classify the pig, and the information can be used to guide further localized image processing.
Whilst therefore known for image based computer vision, model-based processing has so far not been applied to other sensor modalities, and particularly active sensors that rely on returns of a transmitted signal.
The present invention addresses the above by applying model-based processing to a sensor output from a sensor such as a Sonar, radar, or laser range finder. In particular, embodiments of the invention use a priori knowledge of a model signal return expected from a particular object to identify the location of the object relative to the sensor (and/or vice versa). In some embodiments the object is augmented with reflectors that return the sensor signal back towards the sensor so that the object can be more easily detected by the sensor. In some more preferred embodiments the reflectors are arranged in an a priori known pattern on the object, to help identify both the location and the orientation of the object with respect to the sensor. In the preferred embodiment, the sensor is a sonar, mounted on an unmanned underwater vehicle (UUV).
In view of the above, from one aspect the present invention provides a method of locating an object with respect to a sensor, the sensor being of a type that emits energy and detects reflections of the emitted energy in order to detect objects. The method comprises obtaining an a priori model of a configuration of the object, the configuration providing a set of expected sensor returns. Sensor data from a sensor scan is received, the sensor data comprising a plurality of candidate sensor returns that may represent the object to be located. Then, from the candidate sensor returns, a plurality of locations for the object are hypothesised in dependence on a subset of the candidate sensor returns and the a priori model. From the hypothesised plurality of locations, one or more of the hypothesised locations are determined to provide a best fit of the a priori model to the sensor data in dependence at least on the other candidate sensor returns than those in the subset that formed the one or more best fit hypothesised locations. In some embodiments, all of the candidate sensor returns are used in the determination.
In one embodiment the object is provided with energy reflectors arranged to reflect the energy of the sensor, the reflector positions being included in the configuration of the object in the a priori model, wherein the candidate sensor returns are candidate reflector location returns. That is to say, in order to locate the desired object, the energy retro-reflectors are positioned around the object in the known configuration and are able to provide a clear sensor return, capturing the energy of the sensor and directing at least a portion of the energy back in the direction of the sensor itself.
In one embodiment the received sensor data is filtered to remove therefrom candidate returns that do not meet one or more criteria. The one or more criteria may include one or more selected from the group comprising:
Preferably, where filtering occurs, a candidate return is filtered from the group if its relative spatial location with respect to other candidate returns indicates that it could not form part of the object given the object configuration in the a priori model.
In one embodiment the hypothesising is systematic, and a location is hypothesised for each subset of n candidate sensor returns that possibly fits the a priori model, wherein n is preferably 3. Here, the determining step may also include calculating quality measures indicative of the fit of the hypothesised locations to the set of sensor data, and selecting a location as the best-fit in dependence on the quality measures.
In another embodiment the hypothesising is pseudo-random, in that a plurality of pseudo-random locations within the sensor search space are hypothesised as the object location. Here, the determining step includes calculating quality measures indicative of the fit of the pseudo-random locations to the set of sensor data, and re-sampling the plurality of pseudo-random locations in dependence on the quality measures. The quality measure calculations and the re-sampling iterate until convergence on a location or one or more other iteration termination conditions is reached. For example, a certain number of iterations may be permitted, or for a certain amount of time, or iteration may continue until the re-sampled locations are within a certain small distance of each other.
In one embodiment the quality measure for a location is a weight in azimuth and distance calculated in dependence on the position of the candidate sensor returns. Preferably, the location selected as the best-fit is the highest calculated weight, and the calculated weight may be such that it assumes Gaussian noise in both the azimuth and distance measurements.
In one preferred embodiment the sensor is a sonar. Other sensors that may be used include laser rangefinders and radars.
A further aspect provides a method of controlling a vehicle, comprising sensing the location of an object using the method of the first aspect above, and autonomously controlling the movement of the vehicle in dependence on the sensed location of the object. The vehicle may be an unmanned vehicle, a manned submersible or a remotely operated vehicle (ROV). The unmanned vehicle is, therefore, able to locate an object itself, and subsequently use this location information to position itself with respect to the sensed object.
In one embodiment, the unmanned vehicle may be an unmanned underwater vehicle (UUV), and the sensor is a sonar. Additionally, the object may be a docking site, and autonomously controlling the movement of the unmanned underwater vehicle (UUV) may comprise moving the unmanned underwater vehicle (UUV) in dependence on the sensed location of the docking site, and then docking the unmanned underwater vehicle (UUV) on the docking site. Therefore, the unmanned underwater vehicle (UUV) can use the method of the present invention to determine the position of the docking site associated with a vessel such as a ship, and consequently dock itself based on the sensed location of the docking site.
Alternatively, the unmanned vehicle may be an unmanned aerial vehicle (UAV), and the sensor is a radar or laser-rangefinder. Preferably, the object may be a landing site, and autonomously controlling the movement of the unmanned aerial vehicle (UAV) may comprise moving the unmanned aerial vehicle (UAV) in dependence on the sensed location of the landing site, and landing the unmanned aerial vehicle (UAV) on the landing site.
Another aspect of the invention provides a system for locating an object with respect to a sensor, the sensor being of a type that emits energy and detects reflections of the emitted energy in order to detect objects. The system may comprise at least one memory and at least one processor, the at least one memory being arranged to store: i) an a priori model of a configuration of the object, the configuration providing a set of expected sensor returns; and ii) received sensor data from a sensor scan, the sensor data comprising a plurality of candidate sensor returns that may represent the object to be located. The at least one processor, may then be arranged in use to: i) from the candidate sensor returns, hypothesise a plurality of locations for the object in dependence, for a hypothesised location, on a subset of the candidate sensor returns and the a priori model; and ii) from the hypothesised plurality of locations, determine one or more of the hypothesised locations to provide a best fit of the a priori model to the sensor data in dependence at least on the other candidate sensor returns than those in the subset that formed the one or more best fit hypothesised locations.
A further aspect of the invention provides a vehicle comprising a sensor, a propulsion unit, a steering unit, and a system according to the above aspect.
Further features and advantages will be apparent from the appended claims.
Further features and advantages of the present invention will become apparent from the following description of an embodiment thereof, presented by way of example only, and by reference to the drawings, wherein like reference numerals refer to like parts, and wherein:
As shown in
The controller 106 is shown in more detail in
The overall operation of the present embodiment is shown in
At s. 6.4 the sonar 104 is then controlled to undertake a scan, and the returning sonar data is processed by the sonar processing program 504, and a 2D map of candidate sonar buoy (reflector) locations provided to the location determination program 586. The processing of the sonar data to provide the 2D map is beyond the scope of the present application, suffice to say that suitable software is commercially available to use with the SonarBells®, and available from SALT, identified previously. An example 2D sonar return map is shown in
Having obtained the 2D map, at s.6.6 a 2D filtering process is undertaken by the location determination program 586, to remove possible sonar buoy location returns. This filtering is performed firstly on the returns individually, by looking at strength of return, signal to noise ratio, and the relative signal strength to other detections. Some of the candidate buoy location returns will thus be removed from the 2D map, as having signal characteristics that are too low for proper consideration, either absolutely, or relatively.
Further 2D filtering is also performed based on the location of the candidate sonar buoy locations returns relative to each other. In this respect, recall that the location determination program is provided with the a priori model of the sonar buoy locations on the cage 14, and hence has knowledge of the general configuration of sonar buoy returns expected to be seen. Hence, candidate sonar buoy returns in the 2D sonar data that are geographic outliers in that they are not surrounded by a sufficient number of other candidate returns to possibly match the a priori model may also be removed from consideration.
After conducting 2D filtering, at s.6.8 various relative locations of the desired object with respect to the sonar are hypothesized. In embodiments of the invention there are two ways to do this, either systematically or in a pseudo random way. In both cases there are potentially many thousands of possible location results (although there will likely be more with the systematic approach, and the number of hypotheses is controllable with the pseudo random approach), and a best fit match is then undertaken for each hypothesized location to try and match the candidate sonar buoy locations in the 2D data to the a priori model. In this respect, a weighting function is used to find a weight in both azimuth and distance for each hypothesized position given the candidate sonar buoy locations. This will find a location with the highest weight, which is selected as the location of the desired object i.e. the parking cage 14 in this embodiment. Where a pseudo random approach is first undertaken, several iterations may be undertaken, with spawning of new positions around those positions with the highest weights, until a location solution converges within appropriate termination conditions.
In some embodiments of the invention, both the systematic and pseudo random approaches are performed in parallel. Further details of each will be described next with respect to
Two different processing threads are then started, one to systematically search the candidate locations to find the best match, and the other to use a pseudo random technique that is able to manage the search space so that the location determination can occur in the time within sonar pings (or within some other controllable time, in any event). In this respect, one problem with the systematic search is that there can be many thousands or even millions of possible location solutions that need to checked, to determine the best match. However, by using a particle filter approach seeded with pseudo random locations then the number of possible locations to be matched can be kept to a manageable size.
Steps.7.6 to 7.10 illustrate the systematic approach. Firstly, at s.7.6 relative location hypotheses based on x, typically 3, reflector locations in the sonar data are found. For each set of three candidate reflector locations, a relative location of the object to the sonar is found as follows.
Let there be 3 reflectors or transponders with position vectors B0, B1 and B2 and there be a SONAR device at position vector S. The distances to the reflectors or transponders, as measured by the SONAR device are denoted d0, d1 and d2.
d
i
=|B
i
−S|,i=0,1,2 (1.1)
Reset the origin to be at B2. The SONAR position in this new coordinate system is denoted P and the bell locations R0, R1, R2. i.e.
R
1
≡B
i
−B
2
,i=0,1,2 (1.2)
P≡S−B
2 (1.3)
d
i
=|R
i
−P|,i=0,1,2 (1.4)
This can be written without loss of generality as:
P=c
0
R
0
+c
1
R
1
=c
2
Q (1.5)
where
Q≡R
0
×R
1 (1.6)
To solve, the coefficients {ci} need to be found. Manipulation of 1.4 and 1.5 gives
P·R
0
=c
0
R
0
2
+c
1
R
0
·R
1=(d22+R02−d02)/2 (1.7)
P·R
1
=c
0
R
0
·R
1
+c
1
R
1
2=(d22+R12)/1 (1.8)
These can be written as simultaneous linear equations to be solved for {c0,c1}:
algebraically
Mc=v (1.10)
To find c2 use:
P
2
=d
2
2
=c·v+c
2
2
Q
2 (1.11)
There are two solutions for c2, one the negative of the other. Substitute back to get P, then reset origin by adding B2 to get S.
These 2 candidate positions can be resolved to a single position by either considering the azimuth angles or by looking at the position of other reflectors or transponders, if there are more than 3. There are a number of ways this can be done. The techniques described take both into account.
If there are only 3 bells, but these can be unambiguously identified, then azimuth alone can resolve the ambiguity. The technique is as follows:
Call the candidate solutions S0 and S1. Then the best solution Sibest is obtained by:
where {θk} are the azimuth angles corresponding to the measurements {dk}. The azimuth is the angle around the local z axis of the SONAR according to the right hand rule.
Having found hypothesized locations for each set of three candidate reflector locations in the sonar data, at s. 7.8 a best fit quality measure is then found for each hypothesis, given the other candidate reflector locations. This quality measure is found as follows.
The weight of the ith position, wi, used assumes Gaussian noise in both the azimuth and distance measurements. The weight due to azimuth is thus:
where
Δθki=atan 2(sin(θk−Skiθ), cos(θk−Skiθ)) (1.15)
and
S
ki
θ=atan 2(Si·{circumflex over (x)}−Bk·{circumflex over (x)},Bk·ŷ−Si·ŷ)−θk (1.16)
where k=0 . . . K where K is the number of bells in the system. Sigma (θ) is the uncertainty in the azimuth measurement.
Skiθ is constrained such that −π<Skiθ≦π by adding or subtracting multiples of 2π.
And the weight due to distance is thus:
dk is the measured distance to the kth reflector. Sigma (d) is the uncertainty in the distance measurement.
The weights are then combined. The log of these weights are usually used in the calculation as it is a faster calculation and is more accurate when the weight values get very small. The normalisation factors in the Gaussians are the same for all measurements, so are ignored. The combined log weight Wi is thus:
The best hypothesis ibest is thus:
i
best=argmaxi(Wi) (1.19)
The location that has the highest weight is thus selected, at s.7.10.
One problem with the systematic approach noted above is that there may be too many hypothesised locations to check within a reasonable amount of time, especially if the location is being used for real-time navigation of an autonomous vehicle. To get around this, therefore, another way to reduce the search space is to fix the number of solutions to be considered. To do this in the present embodiment an iterative technique is used based on a Particle Filter. The iterative approach replaces the linear algebra described in equations 1.1 to 1.11 above, however the weight calculation remains the same. The particle filter approach is as follows:
In order to generate the new set of candidate solutions, i.e. point 4 above (s.7.16), first calculate a normalisation constant, η.
Resample by selecting solutions at random a large number of times (2000 in the experiments performed), with replacement, such that each solution has a probability Pi of being selected, given by:
For each solution, then apply a motion model. For the experiments performed so far, the SONAR was approximately stationary, so the motion model consists of applying Gaussian noise to the position and azimuth of the solution. If the sonar is moving, then a linear and angular velocity component may also be added at this stage.
With the above, therefore, the location of a sensor such as a sonar may be found with respect to a desired object, the a priori model of which is known to the sensor in advance so that the sensor may detect the object in its returned sensor data. The location may be found in two ways, either systematically, or using a pseudo random particle filter, but in both cases a quality measure is found for hypothesised locations based on candidate sensor returns in the sensor data matching the a priori model. In one preferred embodiment the sensor is a sonar, and the desired object is fitted with sonar reflectors in a known configuration, which are then used to match to the model.
In other embodiments, different sensors may be used, and in particular a radar, or laser rangefinder. In both cases the object to be located may be fitted with appropriate reflectors to reflect the incident sensor energy back to the sensor. The reflectors are preferably in a known configuration and incorporated into the model stored at the sensor, to help with identification of both location and orientation.
However, it is not necessary for both location and orientation of the object to be resolvable straight away, as orientation may be resolved once the vehicle is closer to the object. Likewise, larger objects will be located more accurately from further away. For example, an oil rig will be detected and accurately located from further away than the parking cage of the embodiment.
Embodiments of the invention may find a number of uses, such as for navigation of vehicles, recovery of vehicles, as a safety back-up to a human operator, or for the control of the sensor emission itself. For example, if a sensor is being used to track an object and the location of the object with respect to the sensor is known from embodiments of the invention, the scan of the sensor can be restricted to the general location of the object. This has the effect of reducing the number of candidate locations, and hence lightens the processing load.
In further embodiments the model itself may be augmented, for example with navigational features, such as positions of hazards which are not detectable by the sensor. For example, where the sensor is a sonar, the model may be augmented with the location of navigation hazards to the UUV such as nets, mooring cables, or the like, so that the UUV knows not to approach the hazards.
In addition, the model could be augmented with user interface features, that cause the a particular display on an operator screen when the model determines that a particular location has been reached. For example, for docking operations of a UUV, or landing operations for a UAV, an operator display may be augmented with guidance markings to indicate approach directions to the docking/landing area.
In the above described embodiments a best fit of the model to the hypothesised locations is found by calculating a weight in distance and azimuth for each hypothesis. In other embodiments different techniques may be used to reduce the number of hypotheses. For example, given that the hypotheses are based on matching three candidate reflector locations in the sonar data, of the hypotheses those that match four candidate reflector locations may be found. Then, of those hypotheses that match four candidate locations, a check is made to see which will match five candidate reflector locations, and so on, until one or a small number of hypotheses are found that match the number of candidate reflector locations known to be on the object from the a priori model. Where more than one such location hypothesis is still live at this point, a quality measure such as the weight described previously may be used to decide between the candidate hypotheses.
In addition, in some embodiments of the invention the a priori model is augmented with information relating not simply to the location of reflectors on an object, but also to the expected type or size of reflection expected. For example, in the case of the SonarBells® which come in different sizes, different strength returns can be expected from the bouys of different sizes. By knowing the distribution of the sonar buoys of different sizes across an object in the a priori model, this distribution can then be looked for in the returned sonar data, as well as relative location, to help improve location matching and object orientation determination.
In further embodiments of the present invention, the retro-reflectors may be placed merely in the vicinity of the object to be detected. For example, in
Various further modifications, whether by way of addition, deletion or substitution may be made to the above described embodiment to provide further embodiments, any and all of which are intended to be encompassed by the appended claims.
Number | Date | Country | |
---|---|---|---|
20140012434 A1 | Jan 2014 | US |