METHOD AND SYSTEM FOR COLLABORATIVELY DETECTING TANGIBLE BODIES IN AN ENVIRONMENT

Information

  • Patent Application
  • 20220083077
  • Publication Number
    20220083077
  • Date Filed
    September 13, 2021
    3 years ago
  • Date Published
    March 17, 2022
    2 years ago
Abstract
A method is provided for collaboratively detecting tangible bodies in an environment employing a plurality of distance sensors with which respective carriers are equipped, including: for each sensor, acquiring a series of measurements of distance of a closest tangible body along a line of sight; applying an inverse model of the sensor on a local occupancy grid; and constructing a consolidated local occupancy grid via Bayesian fusion of the occupancy probabilities thus determined; and, computing occupancy probabilities of the cells of a global occupancy grid via Bayesian fusion of the occupancy probabilities of corresponding cells of at least certain of said consolidated local occupancy grids. A system for implementing such a method is also provided.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims priority to French patent application No. FR2009291, filed on Sep. 14, 2021, the disclosure of which is incorporated by reference in its entirety.


FIELD OF THE INVENTION

The invention relates to a method for collaboratively detecting tangible bodies in an environment, by means of sensors with which a plurality of carriers, certain of which are movable, and which are travelling through an environment, are equipped. The detection is “i collaborative” in the sense that data generated by a plurality of sensors with which separate carriers are equipped are fused to create a model of the environment. The latter is therefore a result of “collaboration” of the various carriers.


The invention is generally applicable to the field of perception and preferably to that of navigation of robots, drones, autonomous vehicles, etc.


BACKGROUND

There are two main families of perception techniques: geometric methods, which aim to identify the geometry of objects in the surrounding space, and those based on grid occupancy, which aim to determine whether a certain location is occupied by an obstacle (more generally, by a tangible body). The invention relates to techniques based on grid occupancy.


The theoretical foundations of perception methods based on occupancy grids are described in the article (Elfes 1990). The approach described in this article in particular allows information generated by a plurality of sensors, which need not be co-located, to be fused.


The article (Rakotoavao 2016) and patent application FR 3 041 451 discloses a method allowing the occupancy-probability fusion computations required by the method of (Elfes 1990) to be performed in an effective but nevertheless precise way using integer arithmetic.


The articles (Coué 2006), (Pathak 2007) and (Adarve 2012) and the thesis (Fernandez 2015), and the theses (Andrada Valente da Silva 2019) and (Trung-Dung 2009) disclose improvements to the method of (Elfes 1990) and its application to the fusion of information generated by a plurality of, identical or different, sensors borne by a given vehicle.


These methods only allow measurements generated by sensors with which a given carrier, for example an autonomous vehicle, is equipped to be exploited.


However, in many applications, a plurality of carriers equipped with sensors may be travelling through the same region of space, it is enough to think, for example, of a plurality of motor vehicles at a crossroads. In the prior art, these vehicles each compute an occupancy grid covering a limited portion of the environment. Furthermore, if the environment is dynamic and changing at a high rate, or when the carrier is moving, each occupancy grid will need to be frequently recomputed to satisfactorily represent the environment around the carrier. If this is not done, high uncertainties will be observed in the state of occupancy of the cells of the grid.


SUMMARY OF THE INVENTION

The invention aims to at least partially overcome these drawbacks of the prior art. More particularly, it aims to improve the quality—in terms of spatial extent and of uncertainty—of the perception of the environment in the case where a plurality of carriers equipped with sensors are travelling through an environment, and the position of which is known at least approximately (in the case of motor vehicles, an estimation of position may be delivered, for example, by a satellite positioning system).


According to the invention, this aim is achieved using a collaborative approach, in which the “local” occupancy grids corresponding to the measurements performed by the various carriers are fused into a “global” occupancy grid. One important aspect of the invention is that, when the cells of various local grids cover the same region of the environment, the occupancy probabilities of the corresponding cells of the global grid are computed via Bayesian fusion of the occupancy probabilities of the cells of the local grids. This allows the uncertainty in the state of occupancy of the cells of the local grid to be decreased, by optimally using all the available information.


The document (Birk 2006) describes a collaborative method in which a plurality of autonomous mobile robots conjointly acquire a map of the environment through which they are travelling. In this method, the robots move independently, exploring various regions of the environment, with a certain overlap, and generate local maps thereof. The robots do not know their relative positions, but the identification of identical regions in the local maps of various robots allows them to be registered in order to obtain a global map. The method does not allow the determination of the occupancy probabilities of cells corresponding to the regions of overlap of the local maps to be refined collaboratively. Specifically, the notion of occupancy probability is not exploited: the cells are considered to be occupied with certainty, or unoccupied with certainty, or to be in a completely unknown state, in which case they are ignored. The environment is considered to be static or almost static. Furthermore, the method does not allow an approximate knowledge of the position of the various robots at any given time to be exploited.


Document EP 3 121 762 describes a method in which a vehicle fuses the information delivered by its own sensors with data transmitted by other nearby vehicles, which are also equipped with sensors. This collaborative method does not however use occupancy grids, but a feature-based approach that does not allow a veritable map to be obtained and that requires a structured environment. Contrary to methods using occupancy grids, this approach does not therefore allow unknown environments to be mapped, and therefore the situation of carriers travelling through an unknown environment to be addressed.


One subject of the invention is therefore a method for collaboratively detecting tangible bodies in an environment, this method employing a plurality of distance sensors with which respective carriers located in said environment are equipped, at least one of said carriers being mobile, each sensor having a position and orientation that are known at least approximately with a known level of uncertainty, the method comprising:


A) for each sensor, acquiring a series of measurements of distance of a closest tangible body along a line of sight; applying, to each said measurement of distance, an inverse model of the sensor on a local occupancy grid providing a discretized spatial representation of its field of view, to determine a probability of occupancy by a tangible body of a set of cells of said occupancy grid; and constructing a consolidated local occupancy grid each cell of which has an occupancy probability computed via Bayesian fusion of the occupancy probabilities thus determined;


B) computing occupancy probabilities of the cells of a global occupancy grid via Bayesian fusion of the occupancy probabilities of corresponding cells of at least certain of said consolidated local occupancy grids corresponding to sensors with which separate carriers are equipped.


Another subject of the invention is a system for collaboratively detecting tangible bodies, comprising:

    • a plurality of distance sensors with which respective carriers are equipped, at least one of said carriers being mobile;
    • a plurality of locating devices with which at least said one or more mobile carriers are equipped, said locating devices being suitable for determining a position and an orientation of the carrier, and their levels of uncertainty; and
    • a processing system configured or programmed to:
      • for each sensor: acquire a series of measurements of distance of a closest tangible body along a line of sight; apply, to each said measurement of distance, an inverse model of the sensor on a local occupancy grid providing a discretized spatial representation of its field of view, to determine a probability of occupancy by a tangible body of a set of cells of said occupancy grid; and construct a consolidated local occupancy grid each cell of which has an occupancy probability computed via Bayesian fusion of the occupancy probabilities thus determined; and
      • compute occupancy probabilities of the cells of a global occupancy grid via Bayesian fusion of the occupancy probabilities of corresponding cells of at least certain of said consolidated local occupancy grids corresponding to sensors with which separate carriers are equipped.


Particular embodiments of such a method and of such a system are the subject matter of the dependent claims.





BRIEF DESCRIPTION OF THE DRAWINGS

The appended drawings illustrate the invention:


[FIG. 1] shows an occupancy grid generated by a vehicle equipped with a distance sensor;


[FIG. 2] illustrates the fusion of two unaligned occupancy grids (defined in different coordinate systems and with different cell sizes) according to a first embodiment of the invention;


[FIG. 3], [FIG. 4], and [FIG. 5] illustrate the selection of cells of the occupancy grid of a vehicle that are “close” to a cell of a global occupancy grid, and the determination of their level of proximity, according to a second embodiment of the invention;


[FIG. 6] is a flowchart of a method according to said second embodiment of the invention;


[FIG. 7], [FIG. 8], [FIG. 9], [FIG. 10], [FIG. 11], and [FIG. 12] illustrate the steps of a method according to a third embodiment of the invention; and


[FIG. 13] is a conceptual schematic of a system according to a fourth embodiment of the invention.





DETAILED DESCRIPTION

[FIG. 1] shows an occupancy grid GO associated with a carrier (here a motor vehicle) V. The grid GO is defined in a coordinate system that is fixed to the vehicle V and occupies a region of the environment that corresponds at least partially to the field of view of one or more distance sensors located on-board the vehicle. The grid is a discretized spatial representation of the environment of the vehicle, and more precisely of the field of view of its one or more distance sensors. It is made up of a set of adjacent cells, each characterized by an occupancy probability, i.e. by the probability that the cell is occupied by an obstacle. These probabilities (represented in the figure by shades of grey) are computed from measurements taken by the one or more sensors, as explained in detail in the aforementioned article (Rakotovao 2016) and patent application FR 3 041 451. More precisely:

    • The (or each) sensor located on-board the vehicle V is considered to be “uncertain”. This means that if an obstacle is located in a region of the environment corresponding to a cell ci of the occupancy grid, then the distance measurement z generated by the sensor will follow a probability distribution p(z|oi), where p(a|b) is the probability density of the random variable a given event b and oi represents the event “the region of the environment corresponding to the cell ci of the occupancy grid contains an obstacle” (the expression “the cell ci is occupied” will be used for the sake of convenience). The probability distribution p(z|oi) is called the “direct model” of the sensor.
    • On the basis of the direct model of the sensor and of a priori occupancy probabilities P(oi) of the cells the “inverse model” of the sensor, i.e. P(oi|z), is computed, this model expressing the probability that each cell ci is occupied, given the acquisition of a distance measurement z:







P


(


o
i

|
z

)


=



p


(

z
|

o
i


)




P


(

o
i

)




p


(
z
)







For example, a priori probabilities P(oi) identically equal to ½ may be used, this expressing complete uncertainty. Concretely, only cells located on the line of sight of the sensor see their occupancy probability modified with respect to their a priori value.


The direct computation of the inverse model of a sensor for a determined occupancy grid has a complexity that increases exponentially with the dimensions of the grid. The aforementioned article (Rakotovao 2016) and patent application FR 3 041 451 teach a much more efficient approximate method the complexity of which increases linearly.

    • The inverse model, which is stored in a memory, is applied to each measurement taken by the (or each) sensor. In general, a plurality of measurements are available, these being taken simultaneously or successively by one or more sensors; it is then possible to compute the occupancy probability of each cell via Bayesian fusion of these measurements.


If two measurements z1 and z2 are considered the following is for example obtained:







P


(


o
i

|


z
1



z
2



)


=



P


(


o
i

|

z
1


)




P


(


o
i

|

z
2


)






P


(


o
i

|

z
1


)




P


(


o
i

|

z
2


)



+


(

1
-

P


(


o
i

|

z
1


)



)



(

1
-

P


(


o
i

|

z
2


)



)








The generalization to more than two sensors is straightforward—it is enough to consider


P(o|z1Λz2) to be the inverse model of a “virtual” sensor and to fuse it with the measurement delivered by a third sensor, and so on. The above equation is valid only if P(oi)=P(vi)=½, where vi corresponds to “the state of the cell ci is empty”, but its generalization to other assumptions is easy, see for example EP 3 364 213.


Generally, the fusion of two probabilities P1, P2 is given by







F


(


P
1

,

P
2


)


=




P
1

·

P
2





P
1

·

P
2


+


(

1
-

P
1


)

·

(

1
-

P
2


)




.





It is possible to consider that each distance measurement z1, z2, . . . allows a “provisional” occupancy grid to be constructed, often by updating only the occupancy probabilities of cells located on a line of sight of the distance sensor, and that the Bayesian fusion of these grids leads to a “consolidated” occupancy grid. Below, by “local occupancy grid” what will be meant, unless otherwise specified, is the consolidated occupancy grid for a carrier.


Bayesian fusion requires floating-point computations, which are expensive in computational resources; however the aforementioned article (Rakotovao 2016) and patent application FR 3 041 451 teach a much more efficient approximate method requiring only computations on integer variables.


One idea behind the invention is to construct, in the way described above, consolidated occupancy grids for a plurality of carriers, each equipped with one respective distance sensor (the generalization to the case where all or some of the carriers are equipped with a plurality of sensors poses no difficulty), then to fuse these occupancy grids—which may be qualified “local”- to construct a “global” occupancy grid. For example, the carriers may be motor vehicles being driven over a road network and, optionally, (fixed) infrastructure elements such as traffic lights also equipped with distance sensors.


[FIG. 2] illustrates the fusion of two local occupancy grids GO1, GO2 to generate a global occupancy grid GOG, only one cell cGk of which has been shown. Typically, the local occupancy grids are computed via computers located on-board the respective carriers and transmitted via communication means—radio means for example—to a “central computer”, with information on the position and orientation of the carrier (which information is obtained, for example, by means of a satellite navigation system). The central computer—which may be in a fixed station or be located on-board a carrier equipped with sensors, which generates its own local occupancy grid—computes the global occupancy grid.


It will be noted that, in general, the local occupancy grids are not aligned because they have different orientations, because they are defined in different frames of reference attached to carriers that are moving independently. Moreover, as in the case shown in the figure, they may have cells of different size. The global occupancy grid is defined in a coordinate system called the reference coordinate system.


According to a first embodiment of the invention, which embodiment is illustrated in [FIG. 2], a plurality of regions corresponding to superpositions of various cells of the local grids GO1, GO2 are identified in the interior of the cell cGk of the global occupancy grid. These regions have been numbered from 1 to 21 in the figure. For each of these regions an occupation probability is determined via Bayesian fusion of the occupancy probabilities of the local cells in question (it will be recalled that a cell is considered to be “occupied” if an obstacle has been detected in this cell, without the obstacle necessarily occupying the entirety of the cell). Next, an occupancy probability of the cell cGk is computed from the occupancy probabilities of these regions. For example, the entire cell may be assigned the highest occupancy probability among those computed for the regions thereof.


The drawback of this approach is its computational complexity: in the example of [FIG. 2], one Bayesian-fusion operation is required to compute the occupancy probability of each region of the cell cGk of the global grid, i.e. 21 Bayesian-fusion operations to compute for cGk. It is then necessary to use a mechanism that computes a single occupancy-probability value for the cell cGk, for example one employing a maximum function. Furthermore, the number of operations increases exponentially with the number of local occupancy grids as it is desired to fuse. A second and a third embodiment of the invention allow this difficulty to be overcome.


The computation of a global occupancy grid according to a second embodiment is illustrated in [FIG. 3] to [FIG. 6]. It comprises the following steps: which are implemented for each cell cGk of the global occupancy grid:


Firstly, cells of each (consolidated) local occupancy grid that may be considered—via application of a predefined proximity criterion—“close” to said cell of the global occupancy grid are identified. Only these cells contribute to the computation of the occupancy probability of cGk. For example, as illustrated in [FIG. 3] and [FIG. 4], those cells of the local occupancy grid GO1 associated with the carrier (vehicle) V1 that are located at least partially inside a circle CP1 of radius R1 the centre of which coincides with that of the cell cGk may be considered “close” to the cell cGk. Advantageously, the radius R1 increases as the uncertainty in the position of V1 increases (satellite navigation systems, for example, not only allow a position to be estimated, but also the uncertainty affecting this estimation to be known). [FIG. 3] shows the boundary disc CP1 and [FIG. 4] shows the region RPi1 of the occupancy grid GO1 formed by the cells that intersect the boundary disc CP1 and that are therefore considered close to cGk.


Next, for each cell RPi1, a level of proximity with the cell cGk is computed. It should be noted that the proximity criterion used to identify the cells forming part of RPi1 is binary—it is met or it is not—whereas the level of proximity may take a plurality of discrete or continuous values. For example, the level of proximity may be the normalized probability density, computed at the centre of the identified cell, this denoting a probability value such that this cell coincides with the centre of the cell of the global occupancy grid, or a (typically monotonic) function bounded between 0 and 1 of this probability. Specifically, given that the position and orientation of the carrier V1 are known only with a certain imprecision, the position with respect to cGk of the centre of each cell of GO1 is described by a probability distribution.


Next, a contribution of the local occupancy grid GO1 to the occupancy probability of the cell cGk is computed via a weighted mean of the occupancy probabilities of the cells of RPi1, the weighting coefficients being dependent on the corresponding levels of proximity (a coefficient becomes higher as the corresponding cell RP1i gets closer to cGk; for example, it may depend on the inverse of the level of proximity).


Lastly, the various contributions due to the various local occupancy grids are fused (Bayesian fusion) to find the occupancy probability of the cell cGk. To do this, the methods described in (Coue 2006), (Pathak 2007), (Adarve 2012), (Fernandez 2015) may be used, or indeed the “integer fusion” technique disclosed by (Rakotovao et al. 2016) and WO2017/050890 may advantageously be applied.


Instead of proceeding cell by cell of the global occupancy grid, it is possible to associate, with each local occupancy grid GOj, an intermediate local occupancy grid, the geometry (position, orientation, number, shape and arrangement of the cells) of which is identical to that of the global occupancy grid. The occupancy probability of each cell of the intermediate local occupancy grid is computed from the occupancy probabilities of the cells of GOj, as described above. In other words, the local occupancy grids are projected into the reference coordinate system of the global occupancy grid. Lastly, all the intermediate local occupancy grids are fused to obtain the global occupancy grid, this posing no difficulty because these grids are defined in the same coordinate system. The two approaches are similar and differ only in the order in which the operations are carried out. In one case, the occupancy probability of a cell cgk of the occupancy grid is computed, taking into account all the contributions at once. In the other case, firstly the contributions of each local occupancy grid to all the cells of the global occupancy grid are computed, then these contributions are fused.


The computations required to implement a method according to this second embodiment of the invention will now be described in more detail with reference to [FIG. 5].


Let a carrier V; be positioned at (xj, yj) on the global grid and let a cell ci (selected beforehand using the procedure described above) of its (local) grid of coordinate system j associated with the carrier Vj, be positioned at (xij, yij) with respect to the reference coordinate system RR (x, y). The two coordinates systems differ by a rotation of angle φj. The position of a carrier is considered to be defined by the position of a point inside said carrier, for example its centroid, and the position of a cell is considered to be defined by its centre (as a variant, one of its vertices could also be chosen). The relationship between the positions of the carrier Vj and of the cell ci in the reference coordinate system is given by the equations






x
ij
=x
j
+d
ij cos(αij)






y
ij
=y
j
+d
ij sin(αij)


where (xj, yj) is the estimate of the position of the carrier, which position may be modelled using random variables (for example Gaussian variables of average (xj, yj) and variances (σxj2, σyj2)), and αij is the estimate of the orientation of the straight line connecting the position of the carrier with the centre of the cell ci in the reference coordinate system, which may also be modelled using a random variable (for example a truncated Gaussian variable of average αij and of variance σαj2). The distance dij between the carrier and the cell ci is considered to remain constant, because the local grid that contains the cell ci is attached to the vehicle.


On the basis of the above equations and knowledge of the probability distributions xj, yj and αij, it is possible to determine the conjoint probability distribution of the variables (xij, yij), namely f(xij, yij).


To determine f(xij, yij), various approaches may be used: histogram (numerical), characteristic function, Jacobian matrix, differential forms. If for example the estimate of the position of the carrier is considered to be modelled by a Gaussian random variable of probability density fxy(xj, yj), with xj and yj independent and σ=σxjyj, the orientation of the vehicle is considered to follow a truncated Gaussian probability distribution given by








f
α



(

α
ij

)


=

{





1



2

π




σ

α
j




erf


(

π


2



σ

α
j




)





exp


{


-

1

2


σ

α
j

2







(


α
ij

-


α
_

ij


)

2


}







if







α
_

ij


-
π



α
ij





α
_

ij

-
π






0



c
.
c
.









Using differential forms, that the probability element be






f(xij,yij,∂∝ij)|dxij×dyij×dθij|,


where θijij and dxij×dyij×dθij is the exterior product. It may be deduced that





|dxij×dyij×dθij|=|d(xj+dij cos(αij))×d(yj+dij sin(αij))×daij|⇒|dxij×dyij×dθij|=|(dxj−dij sin αijij)×(dyj+dij cos αijij)×(ij)|⇒|dxij×dyij×dθij|=|dxj×dyj×dαij|=dxjdyjij,


taking into account the property dαij× dαij=0 (i.e. the exterior product is alternating). Thus, the probability element may be rewritten as:






f(xij,yijij)|dxij×dyij×dθij|==f(xj+dij cos(αij),yj+dij sin(αij),αij)|dxij×dyij×dθij|==fxy(xj,yj)fαij)dxjdyjij,


With αij independent of xj and yj. Therefore,







f


(


x
ij

,

y
ij


)


=





-







f


(


x
ij

,

y
ij

,

θ
ij


)





d

θ

ij



=






-








f
xy



(



x
ij

-


d
ij



cos


(

α
ij

)




,


y
ij

-


d
ij



sin


(

α
ij

)





)





f
α



(

α
ij

)





d

α

ij





f


(


x
ij

,

y
ij


)



=


g


(


x
ij

,

y
ij


)










α
_






ij

-
π




α
_

ij

+
π




exp


{



d
ij


σ
2




[



(


x
ij

-


x
_

j


)



cosα
ij


+


(


y
ij

-


y
_

j


)



sinα
ij



]


}


exp


{


-

1

2


σ

α
j

2







(


α
ij

-


α
_

ij


)

2


}




d

α

ij


















where






g


(


x
ij

,

y
ij


)



=



exp


{

-


1

2


σ
2





[


d
ij
2

+


(


x
ij

-


x
_

j


)

2

+


(


y
ij

-


y
_

j


)

2


]



}





(

2

π

)


3
/
2




σ
2



σ

α
j




erf


(

π


2



σ

α
j




)




.






The integral may be solved numerically.


The function f(xij, yij) allows the level of proximity between the cell ci of the grid GOi and the cell cGk of the global grid GOG (in black) to be quantified. More precisely, the level of proximity is defined by the value








δ
ijk

=


f


(



x
ij

=

x
Gk


,


y
ij

=

y
Gk



)



max


(

f


(


x
ij

,

y
ij


)


)




,




where (xGk, yGk) is the position of the cell cGk in the reference coordinate system. The quantity δijk is a probability that the centre ci of the cell of the grid GOi coincides with that of the cell cGk of the global grid GOG. The level of proximity δijk is determined for each selected cell ci in the vicinity of each cell cGk of the reference coordinate system of carrier Vj, as was explained above with reference to [FIG. 3] and to [FIG. 4].


In the case of a fixed carrier (infrastructure element) the position of which is known with certainty, δijk=1 is defined directly for all the selected cells. In the case of a mobile carrier, the normalization of δijk by max is necessary because f(xij=XGk, yij=yGk) may be higher than 1; without normalization the paradoxical situation of a level of proximity higher than that achievable in the case of a stationary carrier would be obtained.


Once the levels of proximity δijk have been computed, the occupancy probability in the coordinate system of a carrier Vj is projected onto the reference coordinate system. Let Pij be the occupancy probability of cell ci of the coordinate system j, which probability is determined using the distance sensors installed on the carrier; the occupancy probability of cell cGk of the reference coordinate system is then defined for carrier Vj by:







P
jk

=





i




δ
ijk



P
ij






i



δ
ijk



.





The probability Pjk is therefore a weighted mean of the occupancy-probability values of the cells selected beforehand in the grid GOi the weights of which are measurements of the positional proximity of these cells with respect to the cell cGk of the reference coordinate system.


With this procedure, it is possible to construct the occupancy grids of all the carriers in a given coordinate system with a limited computational complexity. In particular, to decrease the cost of computation, the result of certain intermediate computations could be saved in a table. At this point, the fusion of these occupancy grids poses no particular difficulty and may be carried out advantageously by applying the “integer fusion” technique disclosed by (Rakotovao et al. 2016) and WO2017/050890.


[FIG. 6] is a flowchart of a method according to the second embodiment of the invention. The method of the figure relates to a situation in which M carriers Vj (identified by the index j, j taking values from 1 to M) each deliver one local occupancy grid. The global occupancy grid comprises N cells c. For each carrier (iteration loop over j), the corresponding local occupancy grid is projected onto an intermediate local occupancy grid having the same geometry as the global occupancy grid (nested iteration loop for each cell c); then the intermediate local occupancy grids are fused. As explained above, as a variant, another way of proceeding would be to consider the cells of the global occupancy grid one by one and, for each thereof, to compute and fuse the occupancy-probability contributions due to all the local occupancy grids.


In the second embodiment of the invention that has just been described, each carrier (or more precisely the computer located on-board each carrier) generates a local occupancy grid in its own coordinate system and transmits it to the central computer, which projects all these local grids into a reference coordinate system in order to fuse them and obtain the global occupancy grid. In the third embodiment, the orientation and position of the reference coordinate system are transmitted by the central computer to the carriers, which then generate their local occupancy grids directly in this coordinate system. The local occupancy grids thus generated may then be sent to the central computer, which fuses them.


[FIG. 7] shows three mobile carriers (automobiles) V1, V2, V3 and a fixed carrier (infrastructure element) EI with respective local occupancy grids GO1, GO2, GO3 GOEI that are “empty”, i.e. before the occupancy probabilities of their cells have been computed. Two obstacles O1, O2 are also present. A central computer, which is for example co-located with the infrastructure element EI, transmits to the computers located on-board the mobile carriers (and, where appropriate, on the infrastructure element) data defining a global coordinate system: an origin and the orientation of the axes xG, yG. A global occupancy grid GOG—which is also “empty”—has been represented in the figure by a square grid.


Each mobile carrier determines, for example by means of a satellite navigation system, its position with respect to the origin of the global coordinate system, and the uncertainty in its position (for a static carrier such as EI, the position is assumed to be known without uncertainty). A probability distribution of the position of carrier Vi number “i” p(xi, yi) may therefore be computed, for example assuming that this distribution is a multidimensional normal distribution.


The on-board computer of each carrier receives a succession of distance measurements and uses them to compute the local occupancy grid, using the inverse model of the distance sensor and the position probability p(xi, yi). The uncertainty in the position is therefore taken into account.


Let zt-1 be the sequence of distance measurements {z1, . . . zt-1} acquired before the time t and z the measurement acquired at the time t. The probability that cell “j” of the occupancy grid is occupied is designated P(oj|z, zt-1), this probability being conditional on the measurements z and zt-1. It is possible to demonstrate that:







P


(



o
i

|
z

,

z

t
-
1



)


=



P


(


o
i

|
z

)




P


(


o
i

|

z

t
-
1



)






P


(


o
i

|
z

)




P


(


o
i

|

z

t
-
1



)



+


(

1
-

P


(


o
i

|
z

)



)



(

1
-

P


(


o
i

|

z

t
-
1



)



)














with












P


(


o
i

|
z

)


=





x
i

,

y
i






P


(



o
i

|
z

,

x
i

,

y
i


)




P


(


x
i

,

y
i


)









where P(oi|z, xi, yi) is the inverse model of the sensor, which is computed assuming that the position of the carrier is (xi, yi), P(xi, yi) is the probability that the position of the carrier is actually (xi, yi) and the sum is computed for every possible position (xi and yi are here considered to only take discrete values, this justifying the passage from a probability density—represented by a lowercase “p”- to a probability represented by an uppercase “P”).


Only the uncertainty in the position of the carrier is considered here, but the uncertainty in its orientation may be taken into consideration in the same way (“stance” may be spoken of to designate both the position and orientation of a carrier).


[FIG. 8], [FIG. 9], [FIG. 10] and [FIG. 11] show the local occupancy grids GO1, GO2, GO3 and GOEI of the carriers V1, V2, V3 and EI, respectively. It will be noted, in the case of V3, that the cells of the local occupancy grid are aligned with the reference coordinate system, and not with that of the carrier. [FIG. 12] shows the global occupancy grid GOG obtained by fusion.


Whatever the embodiment in question, the global occupancy grid may be transmitted by the central computer to the on-board computers. The central computer, moreover, is not necessarily “fixed”: it is possible to use, by way of central computer, a computer located on-board a carrier.


The invention has been described with respect to two-dimensional occupancy grids, but the generalization to the three-dimensional case is straightforward.


The invention has been described with respect to the case where each carrier is equipped with a single distance sensor, but the generalization to the case where at least some of the carriers are equipped with a plurality of sensors is straightforward.


Although not essential, it is advantageous to apply the “integer fusion” technique disclosed by (Rakotovao et al. 2016) and WO2017/050890, and which was briefly recalled above.


The idea behind this technique is that, although the probabilities to be fused may in principle take any value in the interval [0, 1], in practice the computations are necessarily performed on discrete values. Therefore, a probability in the interval [0, 1] must necessarily be represented in a discrete manner, by “probability classes” that may be identified by integer indices. A countable subset of the interval [0, 1] the elements pn of which are identified by a relative integer index “n” is called a “system of probability classes” S={pn, n∈custom-character}. Certain systems of probability classes have the property that the fusion of any two probability classes of the system also belongs to the system. Formally ∀pi, pj ∈S, F(pi, p2)∈S. In this case reference is made to “systems of errorless classes” because the fusion operation introduces no error or approximation (the discretization, however, is an approximation). The advantage of these classes is that the result of the fusion is also identified by an integer index. The probability-fusion problem therefore boils down to determining a function Fd that associates with a pair of integer indices another integer index. Floating-point operations on probability values are therefore replaced by integer operations on indices.


One advantageous discretization scheme is based on a countable set Sk of probability classes that is given by the union of the following two subsets:







S
k
-

=

{


1

2
-

k
·
n



,

n

0


}








S
k
+

=

{




k
·
n

+
1



k
·
n

+
2


,

n

0


}





where k is a positive integer (k∈custom-character*). Sk discretizes the interval [0, 1] nonuniformly, with a discretization interval that is relatively large about the value 0.5 and increasingly small as the extreme values 0 and 1 are approached. This is doubly advantageous; specifically:

    • a probability of 0.5 corresponds to a complete uncertainty; it is therefore not very useful to be very precise around such a value; in contrast, it is useful to be precise around the extreme values that correspond to quasi-certainties of non-occupancy (0) or of occupancy (1).
    • beyond a certain value of |n|, the discrete probability values get extremely close to one another; the error introduced by truncating the set is therefore negligible.


      Although Sk is not an errorless system, Sk+ and Sk− are.


Another, errorless, useful quantification system is defined by recursion:








p
0

=
0

,

5
;









p
1

=
p

;








p
2

=

F


(

p
,
p

)



;








p
3

=

F


(


p
2

,
p

)



;












p

n
+
1


=

F


(


p
m

,
p

)










p

-
1


=

1
-
p


;








p

-
2


=

F


(


p

-
1


,

p

-
1



)



;








p

-
3


=

F


(


p

-
2


,

p

-
1



)



;












p

n
-
1


=

F


(


p
n

,

p

-
1



)






where “p” is a parameter such that 0.5<p<1 and







F


(


p
i

,

p
j


)


=




p
i



p
j





p
i



p
j


+


(

1
-

p
i


)



(

1
-

p
j


)




.





[FIG. 13] shows very schematically a system for implementing a method according to the invention. The system comprises distance sensors CD1, CD2, locating devices L1, L2 and computers (more generally local processing units) UT1, UT2, with which respective carriers V1, V2 are equipped. The distance sensors and the locating devices deliver, to the processing unit of the carrier, the distance measurements and position and orientation information required to construct the local occupancy grids. The local processing units exchange data with a central processing unit UTC via a communication network RCM, which typically is wireless. The central processing unit UTC constructs a global occupancy grid from the local occupancy grids and the position of the carriers V1 and V2.


The local and global processing units may be computers, microprocessors or microcontrollers, dedicated or programmable digital circuits, etc., programmed or configured to implement the processing operations described above. The locating devices may be or comprise receivers of satellite navigation signals, inertial measurement units, etc.


BIBLIOGRAPHIC REFERENCES



  • Elfes 1990: A. Elfes, “Occupancy grids: a stochastic spatial representation for active robot perception” (Sixth Conference on Uncertainty in Al, 1990).

  • Rakotovao 2016: T Rakotovao, J Mottin, D Puschini, C Laugier, “Multi-sensor fusion of occupancy grids based on integer arithmetic”, Robotics and Automation (ICRA), 2016 IEEE International Conference on, 1854-1859.

  • Coué 2006: Coue, C., Pradalier, C., Laugier, C., Fraichard, T. and Bessiere, P. “Bayesian Occupancy Filtering for Multitarget Tracking: An Automotive Application”. The International Journal of Robotics Research, January 2006.

  • Pathak 2007: Pathak, K., Birk, A., Poppinga, J., and Schwertfeger, S., “3D forward sensor modeling and application to occupancy grid based sensor fusion”. IEEE/RSJ International Conference on Intelligent Robots and Systems, December 2007.

  • Adarve 2012: Adarve, J. D., Perrollaz, M., Makris, A. and Laugier, C. “Computing Occupancy Grids from Multiple Sensors using Linear Opinion Pools”. IEEE International Conference on Robotics and Automation, May 2012.

  • Fernandez 2015: Fernandez, C. G. D. P., “Grid-based multi-sensor fusion for on-road obstacle detection: application to autonomous driving”. Master's Thesis, KTH-CVAP and Volvo Car Corporation, August 2015.

  • Birk 2006: Birk, A, and Carpin, S.; “Merging occupancy grid maps from multiple robots”; Proceedings of the IEEE, s vol. 94, no 7, pp. 1384-1397, July 2006.

  • (Andrada Valente da Silva 2019) “SLAM and data fusion for autonomous vehicles: from classical approaches to deep learning methods”, Université Paris Sciences et Lettres, 18 Mar. 2019.

  • (Trung-Dung 2009) “Vehicle Perception: Localization, Mapping with Detection, Classification and Tracking of Moving Objects”, Institut National polytechnique de Grenoble, 18 Sep. 2009.


Claims
  • 1. A method for collaboratively detecting tangible bodies (O1, O2) in an environment, this method employing a plurality of distance sensors (CD1, CD2) with which respective carriers (V1, V2) located in said environment are equipped, at least one of said carriers being mobile, each sensor having a position and orientation that are known at least approximately with a known level of uncertainty, the method comprising the following steps: step A) for each sensor, acquiring a series of measurements of distance of a closest tangible body (O1, O2) along a line of sight; applying, to each said measurement of distance, an inverse model of the sensor on a local occupancy grid providing a discretized spatial representation of its field of view, to determine a probability of occupancy by a tangible body of a set of cells of said occupancy grid; and constructing a consolidated local occupancy grid (GO1, GO2) each cell of which has an occupancy probability computed via Bayesian fusion of the occupancy probabilities thus determined; andstep B) computing occupancy probabilities of the cells of a global occupancy grid (GOG) via Bayesian fusion of the occupancy probabilities of corresponding cells of at least certain of said consolidated local occupancy grids corresponding to sensors with which separate carriers are equipped.
  • 2. The method according to claim 1, wherein step B) comprises the following substeps, for each cell (cGi) of the global probability grid: b1) identifying a subset of cells (RPi1) of each consolidated local occupancy grid (GO1) meeting a condition of proximity with said cell of the global occupancy grid;b2) computing a level of proximity of each cell thus identified with said cell of the global occupancy grid;b3) for each local occupancy grid, computing a contribution to the occupancy probability via a weighted mean of the occupancy probabilities of the cells identified in substep b1), the weighting coefficients being dependent on the corresponding levels of proximity; andb4) carrying out Bayesian fusion of the contributions to the occupancy probabilities computed in substep b3).
  • 3. The method according to claim 2, wherein substep b1) comprises identifying the cells of each consolidated local occupancy grid that are located entirely or partially inside a region, of a given radius (R1), centred on the cell of the global probability grid.
  • 4. The method according to claim 3, wherein said radius increases as the uncertainty in the position of the sensor corresponding to the consolidated local occupancy grid increases.
  • 5. The method according to claim 2, wherein the level of proximity computed in substep b2) is representative of the density of the probability that the centre of the identified cell coincides with the centre of the cell of the global occupancy grid.
  • 6. The method according to claim 1, wherein step A) is implemented by a plurality of local processing units (UT1, UT2), each associated with one carrier (V1, V2), and step B) is implemented by a central processing unit (UTC), the method also comprising transmitting the consolidated local occupancy grids from said sensors to said central processing unit.
  • 7. The method according to claim 1, comprising a prior step of determining a reference position and an orientation defining a reference global coordinate system (RR), wherein step A) comprises, for each sensor, constructing a said consolidated local occupancy grid aligned and located in the reference global coordinate system, the occupancy-probability values of said consolidated local occupancy grid being computed taking into account the uncertainty in the position and orientation of the sensor.
  • 8. The method according to claim 7, wherein a sensor has a position and an orientation that are set and known without uncertainty, these being taken as reference position and as orientation of the reference global coordinate system.
  • 9. The method according to claim 7, wherein: a central processing unit (UTC) determines the reference position and the orientation defining a reference global coordinate system (RR) and transmits them to a plurality of local processing units (UT1, UT2), each associated with one carrier;step A) is implemented by said local processing unit;the consolidated local occupancy grids are transmitted by the local processing units to the central processing unit; andstep B) is implemented by said central processing unit.
  • 10. The method according to claim 1, wherein each said inverse sensor model is a discreet model, associating, with each cell of the corresponding occupancy grid, and for each measurement of distance, a probability class chosen from inside a given set of finite cardinality, each said probability class being identified by an integer index; the Bayesian-probability-fusion operations being performed by means of integer computations performed on the indices of the probability classes determined in said step b).
  • 11. A system for collaboratively detecting tangible bodies, comprising: a plurality of distance sensors (CD1, CD2) with which respective carriers (V1, V2) are equipped, at least one of said carriers being mobile;a plurality of locating devices (L1, L2) with which at least said one or more mobile carriers are equipped, said locating devices being suitable for determining a position and an orientation of the carrier, and their levels of uncertainty; anda processing system (UT1, UT2, UTC) configured or programmed to: for each sensor, acquire a series of measurements of distance of a closest tangible body (O1, O2) along a line of sight; apply, to each said measurement of distance, an inverse model of the sensor on a local occupancy grid providing a discretized spatial representation of its field of view, to determine a probability of occupancy by a tangible body of a set of cells of said occupancy grid; construct a consolidated local occupancy grid (GO1, GO2) each cell of which has an occupancy probability computed via Bayesian fusion of the occupancy probabilities thus determined; andcompute occupancy probabilities of the cells of a global occupancy grid (GOG) via Bayesian fusion of the occupancy probabilities of corresponding cells of at least certain of said consolidated local occupancy grids corresponding to sensors with which separate carriers are equipped.
  • 12. The system according to claim 11, wherein the processing system comprises a plurality of local processing units (UT1, UT2) each associated with one carrier, a central processing unit (UTC) and a communication network (RCM) connecting the central processing unit to each local processing unit, and wherein: each local processing unit is configured or programmed to construct a said consolidated local occupancy grid and to transmit it to the central processing unit; andthe central processing unit is configured or programmed to compute the occupancy probabilities of the cells of said global occupancy grid.
  • 13. The system according to claim 12, wherein the central processing unit (UTC) is configured or programmed to, for each cell (cGi) of the global occupancy grid: identify a subset (RPi1) of cells of each consolidated local occupancy grid meeting a condition of proximity with said cell of the global occupancy grid; andcompute a level of proximity of each cell thus identified with said cell of the global occupancy grid;for each local occupancy grid, compute an occupancy probability via a weighted mean of the occupancy probabilities of the identified cells, the weighting coefficients being dependent on the corresponding levels of proximity; andcarrying out Bayesian fusion of the probabilities thus computed.
  • 14. The system according to claim 12, wherein the central processing unit (UTC) is configured or programmed to determine a reference position and an orientation defining a reference global coordinate system (RR), and to transmit them to the local processing units (UT1, UT2); and each local processing unit is configured or programmed to construct a said consolidated local occupancy grid aligned and located in the reference global coordinate system, and to compute probability-occupancy values of said consolidated local occupancy grid while taking into account the uncertainty in the position and the orientation of the respective sensor.
Priority Claims (1)
Number Date Country Kind
2009291 Sep 2020 FR national